Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   *  Copyright 2007-2008, Plutext Pty Ltd.
   *   
   *  This file is part of docx4j.
  
      docx4j is licensed under the Apache License, Version 2.0 (the "License"); 
      you may not use this file except in compliance with the License. 
  
      You may obtain a copy of the License at 
 
         http://www.apache.org/licenses/LICENSE-2.0 
 
     Unless required by applicable law or agreed to in writing, software 
     distributed under the License is distributed on an "AS IS" BASIS, 
     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 
     See the License for the specific language governing permissions and 
     limitations under the License.
 
  */
 
 package org.docx4j.jaxb;
 
 
 
 
 
 public class JaxbValidationEventHandler implements 
     
 	private static Logger log = LoggerFactory.getLogger(JaxbValidationEventHandler.class);		
 	
 	private boolean shouldContinue = true;
 	public void setContinue(boolean val) {
 		 = val;
 	}
 	
 	public final static String UNEXPECTED_MC_ALTERNATE_CONTENT = "unexpected element (uri:\"http://schemas.openxmlformats.org/markup-compatibility/2006\", local:\"AlternateContent\")";
 	
 	
 		
 		if (==null) {
 			try {
 				Source xsltSource  = new StreamSource(
 						org.docx4j.utils.ResourceUtils.getResource(
 								"org/docx4j/jaxb/mc-preprocessor.xslt"));
 				 = XmlUtils.getTransformerTemplate(xsltSource);
 			} catch (IOException e) {
 				.error("Problem setting up  mc-preprocessor.xslt"e);
 				throw(e);
 				.error("Problem setting up  mc-preprocessor.xslt"e);
 				throw(e);
 			}
 		}
 		
 		
 	}
 	
     public boolean handleEvent(ValidationEvent ve) {            
       if (ve.getSeverity()==. 
        || ve.getSeverity()==.){
     	  
           ValidationEventLocator  locator = ve.getLocator();
           
           //print message from validation event
           if (.isDebugEnabled() || ve.getMessage().length() < 120 ) {
         	  .warnprintSeverity(ve) + ": " + ve.getMessage() );
           } else {
         	  /* These messages are long, for example:
         	   * 
         	   *    unexpected element (uri:"http://schemas.openxmlformats.org/wordprocessingml/2006/main", local:"style"). 
         	   *    Expected elements are <{http://schemas.openxmlformats.org/wordprocessingml/2006/main}annotationRef>,
         	   *    ....
         	   *  
         	   * so truncate it.
         	   */
         	  .warnprintSeverity(ve) + ": " + ve.getMessage().substring(0, 120));        	  
           }
           
           if (ve.getLinkedException()!=null && .isDebugEnabled() ) {
               ve.getLinkedException().printStackTrace();        	   
           }
           
           //output line and column number
 //          System.out.println("Column is " + 
//                locator.getColumnNumber() + 
//                " at line number " + locator.getLineNumber());
       } else if (ve.getSeverity()==ve.WARNING) {
    	   .warn(printSeverity(ve) + "Message is " + ve.getMessage());    	   
       }
      // JAXB provider should attempt to continue its current operation. 
      // (Marshalling, Unmarshalling, Validating)
      .info("continuing (with possible element/attribute loss)");
       return ;
             
     }
    
    public String printSeverity(ValidationEvent ve) {
    	
    	String errorLevel;
    	
    	switch (ve.getSeverity()) {
    		case .: { 
              	// FATAL_ERROR is usually not actually fatal! 
    			errorLevel="(non)FATAL_ERROR"
    			break; } 
    		case .: { errorLevel="ERROR"break; }
    		case .: { errorLevel="WARNING"break; }
    		defaulterrorLevel = new Integer (ve.getSeverity()).toString() ;
    	}
    	
    	return "[" + errorLevel + "] ";
    	
    }
  
 }
New to GrepCode? Check out our FAQ X