vgritsenko 2002/07/25 07:00:31 Modified: . Tag: cocoon_2_0_3_branch changes.xml . changes.xml src/java/org/apache/cocoon/components/language/generator Tag: cocoon_2_0_3_branch ProgramGeneratorImpl.java src/java/org/apache/cocoon/util Tag: cocoon_2_0_3_branch TraxErrorHandler.java Log: Include all warnings and errors reported by the XSLT engine into the TransformerException if transformation fails or terminated by the stylesheet. Compensate for the Xalan incremental processing bug. Revision Changes Path No revision No revision 1.138.2.37 +6 -1 xml-cocoon2/changes.xml Index: changes.xml =================================================================== RCS file: /home/cvs/xml-cocoon2/changes.xml,v retrieving revision 1.138.2.36 retrieving revision 1.138.2.37 diff -u -r1.138.2.36 -r1.138.2.37 --- changes.xml 24 Jul 2002 03:38:45 -0000 1.138.2.36 +++ changes.xml 25 Jul 2002 14:00:31 -0000 1.138.2.37 @@ -39,6 +39,11 @@ </devs> <release version="@version@" date="@date@"> + <action dev="VG" type="fix"> + Include all warnings and errors reported by the XSLT engine into the + TransformerException if transformation fails or terminated by the + stylesheet. + </action> <action dev="VG" type="update"> Update HSQLDB to version 1.7.0. Now it properly shuts down with Cocoon. </action> 1.222 +6 -1 xml-cocoon2/changes.xml Index: changes.xml =================================================================== RCS file: /home/cvs/xml-cocoon2/changes.xml,v retrieving revision 1.221 retrieving revision 1.222 diff -u -r1.221 -r1.222 --- changes.xml 24 Jul 2002 03:38:44 -0000 1.221 +++ changes.xml 25 Jul 2002 14:00:31 -0000 1.222 @@ -39,6 +39,11 @@ </devs> <release version="@version@" date="@date@"> + <action dev="VG" type="fix"> + Include all warnings and errors reported by the XSLT engine into the + TransformerException if transformation fails or terminated by the + stylesheet. + </action> <action dev="VG" type="update"> Update HSQLDB to version 1.7.0. Now it properly shuts down with Cocoon. </action> No revision No revision 1.15.2.2 +10 -1 xml-cocoon2/src/java/org/apache/cocoon/components/language/generator/ProgramGeneratorImpl.java Index: ProgramGeneratorImpl.java =================================================================== RCS file: /home/cvs/xml-cocoon2/src/java/org/apache/cocoon/components/language/generator/ProgramGeneratorImpl.java,v retrieving revision 1.15.2.1 retrieving revision 1.15.2.2 diff -u -r1.15.2.1 -r1.15.2.2 --- ProgramGeneratorImpl.java 14 Apr 2002 03:42:51 -0000 1.15.2.1 +++ ProgramGeneratorImpl.java 25 Jul 2002 14:00:31 -0000 1.15.2.2 @@ -368,6 +368,15 @@ // Generate code String code = markupLanguage.generateCode(is, normalizedName, programmingLanguage, resolver); + if (code == null || code.length() == 0) { + // FIXME(VG): Xalan with incremental-processing=true does not propagate exceptions + // from working thread to main thread. See + // http://nagoya.apache.org/bugzilla/show_bug.cgi?id=8033 + throw new ProcessingException("Failed to generate program code (this may happen " + + "if you use Xalan in incremental processing mode). " + + "Please check log file and/or console for errors."); + } + String encoding = markupLanguage.getEncoding(); // Format source code if applicable No revision No revision 1.4.2.1 +29 -13 xml-cocoon2/src/java/org/apache/cocoon/util/TraxErrorHandler.java Index: TraxErrorHandler.java =================================================================== RCS file: /home/cvs/xml-cocoon2/src/java/org/apache/cocoon/util/TraxErrorHandler.java,v retrieving revision 1.4 retrieving revision 1.4.2.1 diff -u -r1.4 -r1.4.2.1 --- TraxErrorHandler.java 22 Feb 2002 07:03:57 -0000 1.4 +++ TraxErrorHandler.java 25 Jul 2002 14:00:31 -0000 1.4.2.1 @@ -66,6 +66,7 @@ */ public class TraxErrorHandler implements ErrorListener { + private StringBuffer warnings = new StringBuffer("Errors in XSLT transformation:\n"); private Logger logger = null; public TraxErrorHandler( Logger logger ) { @@ -73,50 +74,65 @@ } public void warning( TransformerException exception ) - throws TransformerException { + throws TransformerException + { final String message = getMessage( exception ); if ( this.logger != null ) { - this.logger.warn( message, exception ); + this.logger.warn( message ); } else { System.out.println( "WARNING: " + message ); } + warnings.append("Warning: "); + warnings.append(message); + warnings.append("\n"); } public void error( TransformerException exception ) - throws TransformerException { + throws TransformerException + { final String message = getMessage( exception ); if ( this.logger != null ) { this.logger.error( message, exception ); } else { System.out.println( "ERROR: " + message ); } + warnings.append("Error: "); + warnings.append(message); + warnings.append("\n"); } public void fatalError( TransformerException exception ) - throws TransformerException { + throws TransformerException + { final String message = getMessage( exception ); if ( this.logger != null ) { this.logger.fatalError( message, exception ); } else { System.out.println( "FATAL-ERROR: " + message ); } - throw exception; + warnings.append("Fatal: "); + warnings.append(message); + warnings.append("\n"); + try { + throw new TransformerException(warnings.toString()); + } finally { + warnings = new StringBuffer(); + } } private String getMessage( TransformerException exception ) { - SourceLocator locator = exception.getLocator(); + SourceLocator locator = exception.getLocator(); if ( null != locator ) { - // System.out.println("Parser fatal error: "+exception.getMessage()); String id = ( locator.getPublicId() != locator.getPublicId() ) ? locator.getPublicId() : ( null != locator.getSystemId() ) ? locator.getSystemId() : "SystemId Unknown"; - return new StringBuffer( "Error in TraxTransformer: " ) - .append( id ).append( "; Line " ).append( locator.getLineNumber() ) - .append( "; Column " ).append( locator.getColumnNumber() ) - .append( "; " ).toString(); + return "File " + id + + "; Line " + locator.getLineNumber() + + "; Column " + locator.getColumnNumber() + + "; " + exception.getMessage(); } - return "Error in TraxTransformer: " + exception; + return exception.getMessage(); } }
---------------------------------------------------------------------- In case of troubles, e-mail: [EMAIL PROTECTED] To unsubscribe, e-mail: [EMAIL PROTECTED] For additional commands, e-mail: [EMAIL PROTECTED]