com.ctc.wstx.msv.RelaxNGSchemaFactory Maven / Gradle / Ivy
/* Woodstox XML processor
*
* Copyright (c) 2004- Tatu Saloranta, [email protected]
*
* Licensed under the License specified in the file LICENSE which is
* included with the source code.
* You may not use this file except in compliance with the License.
*
* 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 com.ctc.wstx.msv;
import javax.xml.parsers.SAXParserFactory;
import javax.xml.stream.*;
import org.xml.sax.InputSource;
import org.codehaus.stax2.validation.*;
import com.sun.msv.grammar.trex.TREXGrammar;
import com.sun.msv.reader.GrammarReaderController;
import com.sun.msv.reader.trex.ng.RELAXNGReader;
/**
* This is a StAX2 schema factory that can parse and create schema instances
* for creating validators that validate documents to check their validity
* against specific Relax NG specifications. It requires
* Sun Multi-Schema Validator
* (http://www.sun.com/software/xml/developers/multischema/)
* to work, and acts as a quite thin wrapper layer (although not a completely
* trivial one, since MSV only exports SAX API, some adapting is needed)
*/
public class RelaxNGSchemaFactory
extends BaseSchemaFactory
{
/**
* For now, there's no need for fine-grained error/problem reporting
* infrastructure, so let's just use a dummy controller.
*/
protected final GrammarReaderController mDummyController =
new com.sun.msv.reader.util.IgnoreController();
public RelaxNGSchemaFactory()
{
super(XMLValidationSchema.SCHEMA_ID_RELAXNG);
}
/*
///////////////////////////////////////////////////////////////////////
// Non-public methods
///////////////////////////////////////////////////////////////////////
*/
protected XMLValidationSchema loadSchema(InputSource src, Object sysRef)
throws XMLStreamException
{
/* 26-Oct-2007, TSa: Are sax parser factories safe to share?
* If not, should just create new instances for each
* parsed schema.
*/
/* Another thing; should we use a controller to get notified about
* errors in parsing?
*/
SAXParserFactory saxFactory = getSaxFactory();
MyGrammarController ctrl = new MyGrammarController();
TREXGrammar grammar = RELAXNGReader.parse(src, saxFactory, ctrl);
if (grammar == null) {
String msg = "Failed to load RelaxNG schema from '"+sysRef+"'";
String emsg = ctrl.mErrorMsg;
if (emsg != null) {
msg = msg + ": "+emsg;
}
throw new XMLStreamException(msg);
}
return new RelaxNGSchema(grammar);
}
}