|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.apache.xmlbeans.XmlOptions
Used to supply options for loading, saving, and compiling, and validating.
There are two styles for using XmlOptions: multiline setup, and single-line use. Here are two examples. First, multiline style:
XmlOptions opts = new XmlOptions(); opts.setSavePrettyPrint(); opts.setSavePrettyPrintIndent(4); System.out.println(xobj.xmlText(opts));The alternative is single-line usage:
System.out.println(xobj.xmlText( new XmlOptions().setSavePrettyPrint().setSavePrettyPrintIndent(4)));Table showing where each option gets used. Note that:
newInstance
methods will also
apply for parse
methodsvalidate
methods are also used for
compile
methods, since compilation usually implies
validation against Schema for SchemasnewInstance methods |
parse methods |
validate methods |
compile methods |
save and xmlText methods |
---|---|---|---|---|
setDocumentType setDocumentSourceName setValidateOnSet setUnsynchronized |
setLoad*** setEntityResolver |
setErrorListener setValidateTreatLaxAsSkip |
setErrorListener setCompile*** setEntityResolver setGenerateJavaVersion |
setSave*** setUseDefaultNamespace setCharacterEncoding |
Constructor Summary | |
XmlOptions()
Construct a new blank XmlOptions. |
|
XmlOptions(XmlOptions other)
Construct a new XmlOptions, copying the options. |
Method Summary | |
Object |
get(Object option)
Used to get a generic option |
boolean |
hasOption(Object option)
Used to test a generic option |
static boolean |
hasOption(XmlOptions options,
Object option)
|
static XmlOptions |
maskNull(XmlOptions o)
If passed null, returns an empty options object. |
void |
put(Object option)
Used to set a generic option |
void |
put(Object option,
int value)
Used to set a generic option |
void |
put(Object option,
Object value)
Used to set a generic option |
void |
remove(Object option)
|
static Object |
safeGet(XmlOptions o,
Object option)
Used to test a generic option on an options object that may be null |
XmlOptions |
setCharacterEncoding(String encoding)
When parsing or writing a document, this sets the character encoding to use. |
XmlOptions |
setCompileDownloadUrls()
If this option is set, then the schema compiler will try to download schemas that appear in imports and includes from network based URLs. |
XmlOptions |
setCompileMdefNamespaces(Set mdefNamespaces)
If this option is set, then the schema compiler will permit and ignore multiple definitions of the same component (element, attribute, type, etc) names in the given namespaces. |
XmlOptions |
setCompileNoAnnotations()
if this option is set, the schema compiler will skip annotations when processing Schema components. |
XmlOptions |
setCompileNoPvrRule()
If this option is set, the particle valid (restriciton) rule is not enforced when building a SchemaTypeSystem . |
XmlOptions |
setCompileNoUpaRule()
If this option is set, the unique particle attribution rule is not enforced when building a SchemaTypeSystem . |
XmlOptions |
setCompileNoValidation()
If this option is set, validation is not done on the Schema XmlBeans when building a SchemaTypeSystem |
XmlOptions |
setCompileSubstituteNames(Map nameMap)
This option allows for QName substitution during schema compilation. |
XmlOptions |
setDocumentSourceName(String documentSourceName)
This option sets the document source name into the xml store when parsing a document. |
XmlOptions |
setDocumentType(SchemaType type)
When parsing a document, this sets the type of the root element. |
XmlOptions |
setEntityResolver(EntityResolver resolver)
If this option is set when compiling a schema, then the given EntityResolver will be consulted in order to resolve any URIs while downloading imported schemas. |
XmlOptions |
setErrorListener(Collection c)
Sets a collection object for collecting XmlError objects
during parsing, validation, and compilation. |
XmlOptions |
setGenerateJavaVersion(String source)
If this option is set, then the schema compiler will print java code that is compatible with the desired Java version. |
XmlOptions |
setLoadAdditionalNamespaces(Map nses)
Set additional namespace mappings to be added when parsing a document. |
XmlOptions |
setLoadLineNumbers()
If this option is set, line number annotations are placed in the store when parsing a document. |
XmlOptions |
setLoadMessageDigest()
If this option is set when loading from an InputStream or File, then the loader will compute a 160-bit SHA-1 message digest of the XML file while loading it and make it available via XmlObject.documentProperties().getMessageDigest(); The schema compiler uses message digests to detect and eliminate duplicate imported xsd files. |
XmlOptions |
setLoadReplaceDocumentElement(QName replacement)
If this option is set, the document element is replaced with the given QName when parsing. |
XmlOptions |
setLoadStripComments()
If this option is set, all comments are stripped when parsing a document. |
XmlOptions |
setLoadStripProcinsts()
If this option is set, all processing instructions are stripped when parsing a document. |
XmlOptions |
setLoadStripWhitespace()
If this option is set, all insignificant whitespace is stripped when parsing a document. |
XmlOptions |
setLoadSubstituteNamespaces(Map substNamespaces)
This option sets a map of namespace uri substitutions that happen when parsing a document. |
XmlOptions |
setLoadTrimTextBuffer()
If this option is set, the underlying xml text buffer is trimmed immediately after parsing a document resulting in a smaller memory footprint. |
XmlOptions |
setLoadUseDefaultResolver()
By default, XmlBeans does not resolve entities when parsing xml documents (unless an explicit entity resolver is specified). |
XmlOptions |
setLoadUseXMLReader(XMLReader xmlReader)
By default, XmlBeans uses an internal Piccolo parser, other parsers can be used by providing an XMLReader. |
XmlOptions |
setSaveAggresiveNamespaces()
Deprecated. replaced by setSaveAggressiveNamespaces() |
XmlOptions |
setSaveAggressiveNamespaces()
Causes the saver to reduce the number of namespace prefix declarations. |
XmlOptions |
setSaveFilterProcinst(String filterProcinst)
This option causes the saver to filter a Processing Instruction with the given target |
XmlOptions |
setSaveImplicitNamespaces(Map implicitNamespaces)
If namespaces have already been declared outside the scope of the fragment being saved, this allows those mappings to be passed down to the saver, so the prefixes are not re-declared. |
XmlOptions |
setSaveInner()
This option controls whether saving begins on the element or its contents |
XmlOptions |
setSaveNamespacesFirst()
This option will cause the saver to save namespace attributes first. |
XmlOptions |
setSaveNoXmlDecl()
This option controls whether saving saves out the XML declaration ( |
XmlOptions |
setSaveOuter()
This option controls whether saving begins on the element or its contents |
XmlOptions |
setSavePrettyPrint()
This option will cause the saver to reformat white space for easier reading. |
XmlOptions |
setSavePrettyPrintIndent(int indent)
When used with setSavePrettyPrint this sets the indent
amount to use. |
XmlOptions |
setSavePrettyPrintOffset(int offset)
When used with setSavePrettyPrint this sets the offset
amount to use. |
XmlOptions |
setSaveSuggestedPrefixes(Map suggestedPrefixes)
A map of hints to pass to the saver for which prefixes to use for which namespace URI. |
XmlOptions |
setSaveSyntheticDocumentElement(QName name)
This option causes the saver to wrap the current fragment in an element with the given name. |
XmlOptions |
setSaveUseOpenFrag()
When saving a fragment, this option changes the qname of the synthesized root element. |
XmlOptions |
setSchemaCodePrinter(SchemaCodePrinter printer)
If this option is set when compiling a schema, then the given SchemaTypeCodePrinter.Printer will be used to generate the Java code. |
XmlOptions |
setUnsynchronized()
This option controls whether or not operations on XmlBeans are thread safe. |
XmlOptions |
setUseDefaultNamespace()
If this option is set, the saver will try to use the default namespace for the most commonly used URI. |
XmlOptions |
setValidateOnSet()
If this option is set when an instance is created, then value facets will be checked on each call to a setter or getter method on instances of XmlObject within the instance document. |
XmlOptions |
setValidateTreatLaxAsSkip()
Instructs the validator to skip elements matching an |
XmlOptions |
setXqueryCurrentNodeVar(String varName)
Sets the name of the variable that represents the current node in a query expression. |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
public static final String GENERATE_JAVA_14
public static final String GENERATE_JAVA_15
public static final String SAVE_NAMESPACES_FIRST
public static final String SAVE_SYNTHETIC_DOCUMENT_ELEMENT
public static final String SAVE_PRETTY_PRINT
public static final String SAVE_PRETTY_PRINT_INDENT
public static final String SAVE_PRETTY_PRINT_OFFSET
public static final String SAVE_AGGRESSIVE_NAMESPACES
public static final String SAVE_USE_DEFAULT_NAMESPACE
public static final String SAVE_IMPLICIT_NAMESPACES
public static final String SAVE_SUGGESTED_PREFIXES
public static final String SAVE_FILTER_PROCINST
public static final String SAVE_USE_OPEN_FRAGMENT
public static final String SAVE_OUTER
public static final String SAVE_INNER
public static final String SAVE_NO_XML_DECL
public static final String LOAD_REPLACE_DOCUMENT_ELEMENT
public static final String LOAD_STRIP_WHITESPACE
public static final String LOAD_STRIP_COMMENTS
public static final String LOAD_STRIP_PROCINSTS
public static final String LOAD_LINE_NUMBERS
public static final String LOAD_SUBSTITUTE_NAMESPACES
public static final String LOAD_TRIM_TEXT_BUFFER
public static final String LOAD_ADDITIONAL_NAMESPACES
public static final String LOAD_MESSAGE_DIGEST
public static final String LOAD_USE_DEFAULT_RESOLVER
public static final String LOAD_USE_XMLREADER
public static final String XQUERY_CURRENT_NODE_VAR
public static final String CHARACTER_ENCODING
public static final String ERROR_LISTENER
public static final String DOCUMENT_TYPE
public static final String DOCUMENT_SOURCE_NAME
public static final String COMPILE_SUBSTITUTE_NAMES
public static final String COMPILE_NO_VALIDATION
public static final String COMPILE_NO_UPA_RULE
public static final String COMPILE_NO_PVR_RULE
public static final String COMPILE_NO_ANNOTATIONS
public static final String COMPILE_DOWNLOAD_URLS
public static final String COMPILE_MDEF_NAMESPACES
public static final String VALIDATE_ON_SET
public static final String VALIDATE_TREAT_LAX_AS_SKIP
public static final String UNSYNCHRONIZED
public static final String ENTITY_RESOLVER
public static final String SCHEMA_CODE_PRINTER
public static final String GENERATE_JAVA_VERSION
Constructor Detail |
public XmlOptions()
public XmlOptions(XmlOptions other)
Method Detail |
public XmlOptions setSaveNamespacesFirst()
XmlTokenSource.save(java.io.File, XmlOptions)
,
XmlTokenSource.xmlText(XmlOptions)
public XmlOptions setSavePrettyPrint()
XmlTokenSource.save(java.io.File, XmlOptions)
,
XmlTokenSource.xmlText(XmlOptions)
public XmlOptions setSavePrettyPrintIndent(int indent)
setSavePrettyPrint
this sets the indent
amount to use.
indent
- the indent amount to usesetSavePrettyPrint()
,
XmlTokenSource.save(java.io.File, XmlOptions)
,
XmlTokenSource.xmlText(XmlOptions)
public XmlOptions setSavePrettyPrintOffset(int offset)
setSavePrettyPrint
this sets the offset
amount to use.
offset
- the offset amount to usesetSavePrettyPrint()
,
XmlTokenSource.save(java.io.File, XmlOptions)
,
XmlTokenSource.xmlText(XmlOptions)
public XmlOptions setCharacterEncoding(String encoding)
encoding
- the character encodingXmlObject.Factory.parse(java.io.File, XmlOptions)
,
XmlTokenSource.save(java.io.File, XmlOptions)
public XmlOptions setDocumentType(SchemaType type)
QName
.
type
- The root element's document type.XmlObject.Factory.parse(java.io.File, XmlOptions)
public XmlOptions setErrorListener(Collection c)
Sets a collection object for collecting XmlError
objects
during parsing, validation, and compilation. When set, the collection
will contain all the errors after the operation takes place. Notice that
the errors will only have line numbers if the document was
loaded with line numbers enabled.
The following simple example illustrates using an error listener during validation.
// Create an XmlOptions instance and set the error listener. XmlOptions validateOptions = new XmlOptions(); ArrayList errorList = new ArrayList(); validateOptions.setErrorListener(errorList); // Validate the XML. boolean isValid = newEmp.validate(validateOptions); // If the XML isn't valid, loop through the listener's contents, // printing contained messages. if (!isValid) { for (int i = 0; i < errorList.size(); i++) { XmlError error = (XmlError)errorList.get(i); System.out.println("\n"); System.out.println("Message: " + error.getMessage() + "\n"); System.out.println("Location of invalid XML: " + error.getCursorLocation().xmlText() + "\n"); } }
c
- A collection that will be filled with XmlError
objects
via Collection.add(java.lang.Object)
XmlError
,
XmlObject.Factory.parse(java.io.File, XmlOptions)
,
XmlObject.validate(XmlOptions)
,
XmlBeans.compileXsd(org.apache.xmlbeans.XmlObject[], org.apache.xmlbeans.SchemaTypeLoader, org.apache.xmlbeans.XmlOptions)
,
setLoadLineNumbers()
public XmlOptions setSaveAggressiveNamespaces()
XmlTokenSource.save(java.io.File, XmlOptions)
,
XmlTokenSource.xmlText(XmlOptions)
public XmlOptions setSaveAggresiveNamespaces()
setSaveAggressiveNamespaces()
public XmlOptions setSaveSyntheticDocumentElement(QName name)
name
- the name to use for the top level elementXmlTokenSource.save(java.io.File, XmlOptions)
,
XmlTokenSource.xmlText(XmlOptions)
public XmlOptions setUseDefaultNamespace()
XmlTokenSource.save(java.io.File, XmlOptions)
,
XmlTokenSource.xmlText(XmlOptions)
public XmlOptions setSaveImplicitNamespaces(Map implicitNamespaces)
implicitNamespaces
- a map of prefixes to uris that can be
used by the saver without being declaredXmlTokenSource.save(java.io.File, XmlOptions)
,
XmlTokenSource.xmlText(XmlOptions)
public XmlOptions setSaveSuggestedPrefixes(Map suggestedPrefixes)
suggestedPrefixes
- a map from URIs to prefixesXmlTokenSource.save(java.io.File, XmlOptions)
,
XmlTokenSource.xmlText(XmlOptions)
public XmlOptions setSaveFilterProcinst(String filterProcinst)
filterProcinst
- the name of a Processing Instruction to filter
on saveXmlTokenSource.save(java.io.File, XmlOptions)
,
XmlTokenSource.xmlText(XmlOptions)
public XmlOptions setSaveUseOpenFrag()
XmlTokenSource.save(java.io.File, XmlOptions)
,
XmlTokenSource.xmlText(XmlOptions)
public XmlOptions setSaveOuter()
XmlTokenSource.save(java.io.File, XmlOptions)
,
XmlTokenSource.xmlText(XmlOptions)
public XmlOptions setSaveInner()
XmlTokenSource.save(java.io.File, XmlOptions)
,
XmlTokenSource.xmlText(XmlOptions)
public XmlOptions setSaveNoXmlDecl()
XmlTokenSource.save(java.io.File, XmlOptions)
,
XmlTokenSource.xmlText(XmlOptions)
public XmlOptions setLoadReplaceDocumentElement(QName replacement)
XmlObject.Factory.parse(java.io.File, XmlOptions)
public XmlOptions setLoadStripWhitespace()
XmlObject.Factory.parse(java.io.File, XmlOptions)
public XmlOptions setLoadStripComments()
XmlObject.Factory.parse(java.io.File, XmlOptions)
public XmlOptions setLoadStripProcinsts()
XmlObject.Factory.parse(java.io.File, XmlOptions)
public XmlOptions setLoadLineNumbers()
XmlError
objects to contain
line numbers.
XmlObject.Factory.parse(java.io.File, XmlOptions)
,
XmlError
public XmlOptions setLoadSubstituteNamespaces(Map substNamespaces)
This is particularly useful if you have documents that use no namespace, but you wish to avoid the name collision problems that occur when you introduce schema definitions without a target namespace.
By mapping the empty string "" (the absence of a URI) to a specific namespace, you can force the parser to behave as if a no-namespace document were actually in the specified namespace. This allows you to type the instance according to a schema in a nonempty namespace, and therefore avoid the problematic practice of using schema definitions without a target namespace.
substNamespaces
- a map of document URIs to replacement URIsXmlObject.Factory.parse(java.io.File, XmlOptions)
public XmlOptions setLoadTrimTextBuffer()
XmlObject.Factory.parse(java.io.File, XmlOptions)
public XmlOptions setLoadAdditionalNamespaces(Map nses)
nses
- additional namespace mappingsXmlObject.Factory.parse(java.io.File, XmlOptions)
public XmlOptions setLoadMessageDigest()
XmlObject.Factory.parse(java.io.File, XmlOptions)
public XmlOptions setLoadUseDefaultResolver()
XmlObject.Factory.parse(java.io.File, XmlOptions)
public XmlOptions setLoadUseXMLReader(XMLReader xmlReader)
XmlObject.Factory.parse(java.io.File, XmlOptions)
public XmlOptions setXqueryCurrentNodeVar(String varName)
varName
- The new variable name to use for the query.XmlObject.execQuery(java.lang.String)
,
XmlCursor.execQuery(java.lang.String)
public XmlOptions setDocumentSourceName(String documentSourceName)
XmlObject.Factory.parse(java.lang.String, XmlOptions)
public XmlOptions setCompileSubstituteNames(Map nameMap)
QName
substitution during schema compilation.
nameMap
- a map from QName
s to substitute QName
s.XmlBeans.compileXsd(org.apache.xmlbeans.XmlObject[], org.apache.xmlbeans.SchemaTypeLoader, org.apache.xmlbeans.XmlOptions)
public XmlOptions setCompileNoValidation()
SchemaTypeSystem
XmlBeans.compileXsd(org.apache.xmlbeans.XmlObject[], org.apache.xmlbeans.SchemaTypeLoader, org.apache.xmlbeans.XmlOptions)
public XmlOptions setCompileNoUpaRule()
SchemaTypeSystem
. See
Appendix H of the XML Schema specification
for information on the UPA rule.
XmlBeans.compileXsd(org.apache.xmlbeans.XmlObject[], org.apache.xmlbeans.SchemaTypeLoader, org.apache.xmlbeans.XmlOptions)
public XmlOptions setCompileNoPvrRule()
SchemaTypeSystem
. See
Section 3.9.6 of the XML Schema specification
for information on the PVR rule.
XmlBeans.compileXsd(org.apache.xmlbeans.XmlObject[], org.apache.xmlbeans.SchemaTypeLoader, org.apache.xmlbeans.XmlOptions)
public XmlOptions setCompileNoAnnotations()
XmlBeans.compileXsd(org.apache.xmlbeans.XmlObject[], org.apache.xmlbeans.SchemaTypeLoader, org.apache.xmlbeans.XmlOptions)
public XmlOptions setCompileDownloadUrls()
XmlBeans.compileXsd(org.apache.xmlbeans.XmlObject[], org.apache.xmlbeans.SchemaTypeLoader, org.apache.xmlbeans.XmlOptions)
public XmlOptions setCompileMdefNamespaces(Set mdefNamespaces)
mdefNamespaces
- a set of namespace URIs as StringsXmlBeans.compileXsd(org.apache.xmlbeans.XmlObject[], org.apache.xmlbeans.SchemaTypeLoader, org.apache.xmlbeans.XmlOptions)
public XmlOptions setValidateOnSet()
XmlObject.Factory.parse(java.io.File, XmlOptions)
public XmlOptions setValidateTreatLaxAsSkip()
public XmlOptions setUnsynchronized()
public XmlOptions setEntityResolver(EntityResolver resolver)
XmlBeans.compileXsd(org.apache.xmlbeans.XmlObject[], org.apache.xmlbeans.SchemaTypeLoader, org.apache.xmlbeans.XmlOptions)
public XmlOptions setSchemaCodePrinter(SchemaCodePrinter printer)
XmlBeans.compileXsd(org.apache.xmlbeans.XmlObject[], org.apache.xmlbeans.SchemaTypeLoader, org.apache.xmlbeans.XmlOptions)
public XmlOptions setGenerateJavaVersion(String source)
source
- A Java version numberGENERATE_JAVA_14
,
GENERATE_JAVA_15
,
XmlBeans.compileXmlBeans(java.lang.String, org.apache.xmlbeans.SchemaTypeSystem, org.apache.xmlbeans.XmlObject[], org.apache.xmlbeans.BindingConfig, org.apache.xmlbeans.SchemaTypeLoader, org.apache.xmlbeans.Filer, org.apache.xmlbeans.XmlOptions)
public static XmlOptions maskNull(XmlOptions o)
public void put(Object option)
public void put(Object option, Object value)
public void put(Object option, int value)
public boolean hasOption(Object option)
public static boolean hasOption(XmlOptions options, Object option)
public Object get(Object option)
public void remove(Object option)
public static Object safeGet(XmlOptions o, Object option)
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |