Package batch.driver

Source Code of batch.driver.IValidatorImpl

package batch.driver;

import java.io.File;

import javax.xml.parsers.SAXParserFactory;

import org.iso_relax.verifier.Schema;
import org.iso_relax.verifier.VerifierFilter;
import org.xml.sax.ContentHandler;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;
import org.xml.sax.SAXParseException;
import org.xml.sax.XMLReader;

import batch.model.ISchema;

import com.sun.msv.driver.textui.ReportErrorHandler;
import com.sun.msv.grammar.Grammar;
import com.sun.msv.reader.GrammarReader;
import com.sun.msv.reader.GrammarReaderController;
import com.sun.msv.reader.util.GrammarLoader;
import com.sun.msv.verifier.IVerifier;
import com.sun.msv.verifier.ValidityViolation;
import com.sun.msv.verifier.Verifier;
import com.sun.msv.verifier.regexp.REDocumentDeclaration;

/**
* Test harness for RELAX NG conformance test suite.
*/
public abstract class IValidatorImpl extends AbstractValidatorExImpl
{
    /**
     * If true, this validator will apply extra checkes to the schema.
     */
    private final boolean strictCheck;
   
    /**
     * SAXParserFactory which should be used to parse a schema.
     */
    protected SAXParserFactory factory;
   
    public IValidatorImpl( boolean _strictCheck ) {
        strictCheck = _strictCheck;
       
        if(strictCheck) {
            // if we run a strict check, wrap it by the s4s
            factory = new com.sun.msv.verifier.jaxp.SAXParserFactoryImpl(
                getSchemaForSchema());
        } else {
            // create a plain SAXParserFactory
            factory = SAXParserFactory.newInstance();
            factory.setNamespaceAware(true);
        }
    }
   
    /**
     * Gets the schema for schema for this language.
     */
    protected Schema getSchemaForSchema() { return null; }
   
    public ISchema parseSchema( File file ) throws Exception {
        GrammarReader reader = getReader();
       
        InputSource source = com.sun.msv.util.Util.getInputSource(
            file.getAbsolutePath());
        XMLReader parser = factory.newSAXParser().getXMLReader();
       
        if(!strictCheck) {
            parser.setContentHandler(reader);
        } else {
            Schema schema = getSchemaForSchema();
            final boolean[] error = new boolean[1];
           
            // set up a pipe line so that the file will be validated by s4s
            VerifierFilter filter = schema.newVerifier().getVerifierFilter();
            filter.setErrorHandler( new ReportErrorHandler() {
                public void error( SAXParseException e ) throws SAXException {
                    super.error(e);
                    error[0]=true;
                }
                public void fatalError( SAXParseException e ) throws SAXException {
                    super.fatalError(e);
                    error[0]=true;
                }
            });
           
            filter.setContentHandler(reader);
            parser.setContentHandler((ContentHandler)filter);
           
            if( error[0]==true )        return null;
        }

        try {
            parser.parse(source);
        } catch( ValidityViolation vv ) {
            System.out.println(vv.getMessage());
            return null;
        }
       
        Grammar grammar = getGrammarFromReader(reader,file);
       
        if( grammar==null )    return null;
        else                return new ISchemaImpl( grammar );
    }

    public Grammar parseSchema( InputSource is, GrammarReaderController controller ) throws Exception {
        return GrammarLoader.loadSchema(is,createController(),factory);
    }

    /**
     * creates a GrammarReader object to parse a grammar.
     *
     * <p>
     * override this method to use different reader implementation.
     * RELAX NG test harness can be used to test XML Schema, TREX, etc.
     */
    protected abstract GrammarReader getReader();
   
    protected Grammar getGrammarFromReader( GrammarReader reader, File schema ) {
        return reader.getResultAsGrammar();
    }
   
    /**
     * creates a Verifier object to validate a document.
     *
     * <p>
     * override this method to use a different verifier implementation.
     */
    protected IVerifier getVerifier( Grammar grammar ) {
        return new Verifier( new REDocumentDeclaration(grammar),
            new ReportErrorHandler() );
    }
}
TOP

Related Classes of batch.driver.IValidatorImpl

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.