%XML.XPATH.Document
class %XML.XPATH.Document extends %Library.RegisteredObject
Implements an interface to the XPATH Document. XML contained in a file or binary stream may be selected and navigated. %XML.XPATH.Document should never be created directly with %New(), but via the CreateFromFile() or CreateFromStream() factory methodsProperty Inventory
Method Inventory
- CreateFromFile()
- CreateFromStream()
- CreateFromString()
- EvaluateExpression()
- Example1()
- Example2()
- Example3()
- ExampleDisplayResults()
- GetPrefix()
- NormalizeFileName()
- PrefixMappingsSet()
Properties
property PrefixMappings as %String;
This holds a string specifying prefix mappings for the document. This is a comma delimited list
of prefix to namespace mappings. Each mapping is defined as a prefix, a space and then the uri to
which that prefix maps. This is especially useful if the document defines a default namespace with the
xmlns="http://somenamespaceuri" syntax but does not supply an explicit prefix mapping. For example, this
PrefixMappings string would map the myprefix prefix to the http://somenamespaceuri uri.
"myprefix http://somenamespaceuri
Property methods: PrefixMappingsDisplayToLogical(), PrefixMappingsGet(), PrefixMappingsIsValid(), PrefixMappingsLogicalToDisplay(), PrefixMappingsLogicalToOdbc(), PrefixMappingsNormalize()
property ResultHandler as %XML.XPATH.ResultHandler;
This holds the default ResultHandler
Property methods: ResultHandlerGet(), ResultHandlerGetSwizzled(), ResultHandlerIsValid(), ResultHandlerNewObject(), ResultHandlerSet()
Methods
classmethod CreateFromFile(pSource As %String, Output pDocument As %XML.XPATH.Document, pResolver As %XML.SAX.EntityResolver = $$$NULLOREF, pErrorHandler As %XML.XSLT.ErrorHandler = $$$NULLOREF, pFlags As %Integer = 0, pSchemaSpec As %String = "", pPrefixMappings As %String = "") as %Status
Use this method a create an instance of an %XML.XPATH.Document from a file path name.
classmethod CreateFromStream(pStream As %AbstractStream, Output pDocument As %XML.XPATH.Document, pResolver As %XML.SAX.EntityResolver = $$$NULLOREF, pErrorHandler As %XML.XSLT.ErrorHandler = $$$NULLOREF, pFlags As %Integer = 0, pSchemaSpec As %String = "", pPrefixMappings As %String = "") as %Status
Use this method to create an instance of an %XML.XPATH.Document from a binary stream. It's important to use a binary stream because
if a character stream is used then (for a unicode cache) the characters will be automatically converted to unicode (utf-16). This can
cause a problem if the XML stream has a header declaring a different coding as it introduces an inconsistency between the
declared encoding and the actual encoding. This will cause the XML Parser to issue an error message and fail.
classmethod CreateFromString(pString As %String, Output pDocument As %XML.XPATH.Document, pResolver As %XML.SAX.EntityResolver = $$$NULLOREF, pErrorHandler As %XML.XSLT.ErrorHandler = $$$NULLOREF, pFlags As %Integer = 0, pSchemaSpec As %String = "", pPrefixMappings As %String = "") as %Status
Use this method to create an instance of a %XML.XPATH.Document from a string.
The input string is expected to be UTF-8 encoded.
The input string is expected to be UTF-8 encoded.
method EvaluateExpression(pContext As %String, pExpression As %String, Output pResults As %ListOfObjects(CLASSNAME="%XML.XPATH.RESULT")) as %Status
This method evaluates an XPATH context and expression. The context selects the intial nodeset from the document and
the expression further filters the node set. See
http://www.w3.org/TR/xpathOpens in a new tab for full details of XPATH syntax and usage
If the method succeeds it returns a list of Results which can be queried for their types and values.
classmethod Example1()
Evaluates an XPATH expression which returns a DOM Result
classmethod Example2()
Evaluates an XPATH expression which returns a VALUE Result
classmethod Example3()
Evaluates an XPATH expression which returns a VALUE Result ( demonstrates use of CreateFromString() )
classmethod ExampleDisplayResults(pResults As %ListOfObjects(CLASSNAME="%XML.XPATH.Result"))
method GetPrefix(pUrl="") as %String
May be called to determine the prefix defined for a particular url in the
Prefix Mappings passed to the CreateFromXXX() calls
This is the setter for the PrefixMappings, it parses the mappings into
an array which can be queried by the GetPrefix() method
Inherited Members
Inherited Methods
- %AddToSaveSet()
- %ClassIsLatestVersion()
- %ClassName()
- %ConstructClone()
- %DispatchClassMethod()
- %DispatchGetModified()
- %DispatchGetProperty()
- %DispatchMethod()
- %DispatchSetModified()
- %DispatchSetMultidimProperty()
- %DispatchSetProperty()
- %Extends()
- %GetParameter()
- %IsA()
- %IsModified()
- %New()
- %NormalizeObject()
- %ObjectModified()
- %OriginalNamespace()
- %PackageName()
- %RemoveFromSaveSet()
- %SerializeObject()
- %SetModified()
- %ValidateObject()