diff --git a/ChangeLog b/ChangeLog index e255d030..d3d2496f 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,12 @@ +Tue Jun 29 19:00:32 CEST 2004 Daniel Veillard + + * xmlschemas.c xmlschemastypes.c include/libxml/xmlerror.h + include/libxml/schemasInternals.h include/libxml/xmlschemastypes.h: + applied Schemas patches from Kasimier Buchcik, there is still + one open issue about referencing freed memory. + * test/schemas/* result/schemas/*: updated with new tests from + Kasimier + Tue Jun 29 14:52:18 CEST 2004 Daniel Veillard * include/libxml/globals.h include/libxml/xmlIO.h diff --git a/doc/APIchunk0.html b/doc/APIchunk0.html index 9398dc9f..4021fee3 100644 --- a/doc/APIchunk0.html +++ b/doc/APIchunk0.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter A:

A-Z
xmlCheckLanguageID
A-Za-z
xmlParseEncName
A-Za-z0-9
xmlParseEncName
@@ -254,8 +255,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -273,7 +274,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk1.html b/doc/APIchunk1.html index a9266485..6addbe31 100644 --- a/doc/APIchunk1.html +++ b/doc/APIchunk1.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter C:

C14N
xmlC14NDocSaveTo
xmlC14NExecute
CATALOG
xmlLoadACatalog
@@ -178,6 +179,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlCheckUTF8
xmlIsBlankNode
xmlSchemaCheckFacet
+xmlSchemaValidateListSimpleTypeFacet
xmlXPathNodeSetIsEmpty
xmlXPathStackIsExternal
Cherokee
xmlUCSIsCherokee
@@ -332,8 +334,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -351,7 +353,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk10.html b/doc/APIchunk10.html index 1f55b13d..ce459406 100644 --- a/doc/APIchunk10.html +++ b/doc/APIchunk10.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter c:

cae
xmlSchemaCheckFacet
calculates
xmlUTF8Size
call
xmlCharEncOutFunc
@@ -173,6 +174,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlParseSDDecl
xmlRelaxNGParse
xmlResetLastError
+xmlSchemaCollapseString
xmlSchemaParse
xmlSubstituteEntitiesDefault
xmlSwitchEncoding
@@ -237,7 +239,6 @@ A:link, A:visited, A:active { text-decoration: underline }
checking
xlinkIsLink
xmlBufferWriteQuotedString
xmlBuildURI
-xmlMemFree
xmlUTF8Strlen
checkings
xmlValidateOneElement
checks
htmlAutoCloseTag
@@ -458,7 +459,9 @@ A:link, A:visited, A:active { text-decoration: underline }
completely
xmlNodeGetBase
complex
XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION
XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION
-
complexType
XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD
+
complexType
XML_SCHEMAS_TYPE_FINAL_EXTENSION
+XML_SCHEMAS_TYPE_FINAL_RESTRICTION
+XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD
complicated
xmlBuildRelativeURI
compound
xmlXPathFreeNodeSet
xmlXPtrFreeLocationSet
@@ -797,8 +800,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -816,7 +819,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk11.html b/doc/APIchunk11.html index 97af8317..89050e69 100644 --- a/doc/APIchunk11.html +++ b/doc/APIchunk11.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,10 +31,12 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter d:

dangerous
xmlTextReaderCurrentNode
+
datatype
xmlSchemaGetBuiltInListSimpleTypeItemType
day
ftpListCallback
day:minute
ftpListCallback
deactivated
xmlTextReaderRelaxNGSetSchema
@@ -161,6 +163,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlParseBalancedChunkMemory
xmlParseBalancedChunkMemoryRecover
xmlParseElementContentDecl
+xmlSchemaGetBuiltInListSimpleTypeItemType
xmlSearchNs
xmlSearchNsByHref
xmlTextReaderIsDefault
@@ -493,7 +496,8 @@ A:link, A:visited, A:active { text-decoration: underline } xmlXPathNodeTrailingSorted
xmlXPathTrailing
xmlXPathTrailingSorted
-
don
xlinkIsLink
+
don
XML_SCHEMAS_ANY_LAX
+xlinkIsLink
xmlCreatePushParserCtxt
xmlNewDocNode
xmlNewDocNodeEatName
@@ -563,8 +567,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -582,7 +586,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk12.html b/doc/APIchunk12.html index dd692ca4..3c8c054a 100644 --- a/doc/APIchunk12.html +++ b/doc/APIchunk12.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter e:

each
_xmlParserCtxt
xmlHashCopy
xmlHashScan
@@ -223,11 +224,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlListDataCompare
equivalent
xmlMallocAtomicLoc
xmlMallocLoc
-xmlMemFree
-xmlMemMalloc
-xmlMemRealloc
xmlMemStrdupLoc
-xmlMemoryStrdup
xmlNodeListGetRawString
xmlNodeListGetString
xmlReallocLoc
@@ -345,6 +342,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlRelaxNGNewParserCtxt
xmlSchemaNewMemParserCtxt
xmlSchemaNewParserCtxt
+xmlSchemaValidateListSimpleTypeFacet
explored
xmlXPathAxisFunc
exposing
xmlTextReaderRead
expressions
LIBXML_REGEXP_ENABLED
@@ -365,7 +363,9 @@ A:link, A:visited, A:active { text-decoration: underline } xlinkExtendedLinkSetFunk
xmlXPathNodeSetMerge
xmlXPtrLocationSetMerge
-
extension
XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION
+
extension
XML_SCHEMAS_FINAL_DEFAULT_EXTENSION
+XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION
+XML_SCHEMAS_TYPE_FINAL_EXTENSION
extensions
_xmlSAXHandler
extract
XML_GET_CONTENT
XML_GET_LINE
@@ -375,8 +375,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -394,7 +394,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk13.html b/doc/APIchunk13.html index 3bc62e32..1caf98e7 100644 --- a/doc/APIchunk13.html +++ b/doc/APIchunk13.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,17 +31,20 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter f:

fTP
xmlNanoFTPConnectTo
facet
XML_SCHEMAS_FACET_COLLAPSE
XML_SCHEMAS_FACET_PRESERVE
XML_SCHEMAS_FACET_REPLACE
XML_SCHEMAS_FACET_UNKNOWN
+_xmlSchemaFacetLink
xmlSchemaCheckFacet
xmlSchemaFreeFacet
xmlSchemaValidateFacet
+xmlSchemaValidateListSimpleTypeFacet
facets
xmlSchemaCheckFacet
fail
xmlC14NDocDumpMemory
xmlC14NDocSave
@@ -154,12 +157,20 @@ A:link, A:visited, A:active { text-decoration: underline }
filled
xmlGetFeaturesList
fills
xmlParseURIReference
filters
xmlParseEncodingDecl
-
final
xmlAutomataSetFinalState
+
final
XML_SCHEMAS_TYPE_FINAL_EXTENSION
+XML_SCHEMAS_TYPE_FINAL_LIST
+XML_SCHEMAS_TYPE_FINAL_RESTRICTION
+XML_SCHEMAS_TYPE_FINAL_UNION
+xmlAutomataSetFinalState
xmlBuildURI
xmlRegExecPushString
xmlRegExecPushString2
xmlValidateDocumentFinal
xmlValidateDtdFinal
+
finalDefault
XML_SCHEMAS_FINAL_DEFAULT_EXTENSION
+XML_SCHEMAS_FINAL_DEFAULT_LIST
+XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION
+XML_SCHEMAS_FINAL_DEFAULT_UNION
find
xmlGetThreadId
xmlIsXHTML
finding
xmlNanoFTPScanProxy
@@ -372,8 +383,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -391,7 +402,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk14.html b/doc/APIchunk14.html index 5abf7cb2..cc079855 100644 --- a/doc/APIchunk14.html +++ b/doc/APIchunk14.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter g:

garbage
xmlGcMemGet
xmlGcMemSetup
genChRanges
xmlIsBaseCharQ
@@ -209,10 +210,10 @@ A:link, A:visited, A:active { text-decoration: underline } xmlNamespaceParseNSDef
xmlNamespaceParseQName
xmlNodeListGetRawString
-xmlOutputBufferCreateFilenameDefault
+xmlOutputBufferCreateFilenameDefault
xmlParserHandlePEReference
xmlParserHandleReference
-xmlParserInputBufferCreateFilenameDefault
+xmlParserInputBufferCreateFilenameDefault
xmlRegNewExecCtxt
xmlRegisterInputCallbacks
xmlRegisterOutputCallbacks
@@ -273,6 +274,7 @@ A:link, A:visited, A:active { text-decoration: underline }
heuristic:
xmlIsRef
hex
xmlURIEscapeStr
hierarchy
xmlParseElementChildrenContentDecl
+xmlSchemaGetBuiltInListSimpleTypeItemType
highly
htmlParseElement
xmlParseElement
xmlRelaxNGParse
@@ -351,8 +353,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -370,7 +372,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk15.html b/doc/APIchunk15.html index 00708d58..bfbe3af0 100644 --- a/doc/APIchunk15.html +++ b/doc/APIchunk15.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter i:

iconv
LIBXML_ICONV_ENABLED
LIBXML_ISO8859X_ENABLED
identify
xmlParseAttributeType
@@ -239,10 +240,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlInitNodeInfoSeq
xmlMallocAtomicLoc
xmlMallocLoc
-xmlMemMalloc
-xmlMemRealloc
xmlMemStrdupLoc
-xmlMemoryStrdup
xmlNanoFTPList
xmlParserAddNodeInfo
xmlParserFindNodeInfo
@@ -304,9 +302,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlAutomataGetInitState
xmlBufferCreateSize
xmlInitNodeInfoSeq
-xmlMemRealloc
xmlMemStrdupLoc
-xmlMemoryStrdup
xmlReallocLoc
xmlShell
xmlXPathNodeSetAdd
@@ -389,6 +385,27 @@ A:link, A:visited, A:active { text-decoration: underline } xmlNewPI
xmlSAX2ProcessingInstruction
insufficient
xmlCanonicPath
+
int
_xmlParserCtxt
+c
+getColumnNumber
+getLineNumber
+htmlHandleOmittedElem
+htmlParseCharRef
+xmlIsLetter
+xmlKeepBlanksDefault
+xmlLineNumbersDefault
+xmlMallocAtomicLoc
+xmlMallocLoc
+xmlMemUsed
+xmlParseCharData
+xmlParseCharRef
+xmlPedanticParserDefault
+xmlReallocLoc
+xmlSAX2GetColumnNumber
+xmlSAX2GetLineNumber
+xmlShellCmd
+xmlSplitQName3
+xmlSubstituteEntitiesDefault
integer
xmlStrcasecmp
xmlStrcmp
xmlStrncasecmp
@@ -476,6 +493,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlHashUpdateEntry2
xmlHashUpdateEntry3
xmlNanoFTPDele
+xmlSchemaGetBuiltInListSimpleTypeItemType
xmlXPathNodeSetItem
items
valuePush
xmlHashCopy
@@ -484,6 +502,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlHashScan3
xmlHashScanFull
xmlHashScanFull3
+xmlSchemaValidateListSimpleTypeFacet
itself
_xmlDoc
xlinkIsLink
xmlCharEncFirstLine
@@ -495,8 +514,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -514,7 +533,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk16.html b/doc/APIchunk16.html index 392ed1b8..f5a2af88 100644 --- a/doc/APIchunk16.html +++ b/doc/APIchunk16.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter j:

just
htmlSetMetaEncoding
inputPop
namePop
@@ -94,8 +95,6 @@ A:link, A:visited, A:active { text-decoration: underline } xmlCharEncodingOutputFunc
xmlMallocAtomicLoc
xmlMallocLoc
-xmlMemMalloc
-xmlMemRealloc
xmlReallocLoc
lang
xmlNodeGetLang
xmlXPathLangFunction
@@ -179,6 +178,7 @@ A:link, A:visited, A:active { text-decoration: underline }
lexical
xmlParseDefaultDecl
xmlSchemaValPredefTypeNode
xmlSchemaValidateFacet
+xmlSchemaValidateListSimpleTypeFacet
xmlSchemaValidatePredefinedType
xmlValidateNCName
xmlValidateNMToken
@@ -248,6 +248,8 @@ A:link, A:visited, A:active { text-decoration: underline }
linear
htmlEntityLookup
htmlEntityValueLookup
linked
_xmlSchemaAttributeLink
+_xmlSchemaFacetLink
+_xmlSchemaTypeLink
linking
xlinkIsLink
links
ftpListCallback
listing
xmlNanoFTPList
@@ -318,10 +320,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlUnlockLibrary
logging
xmlMallocAtomicLoc
xmlMallocLoc
-xmlMemMalloc
-xmlMemRealloc
xmlMemStrdupLoc
-xmlMemoryStrdup
xmlReallocLoc
long
IS_BASECHAR
IS_COMBINING
@@ -356,8 +355,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -375,7 +374,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk17.html b/doc/APIchunk17.html index e44a0212..c9652b39 100644 --- a/doc/APIchunk17.html +++ b/doc/APIchunk17.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter m:

machine
xmlCheckFilename
macro
xmlTextWriterWriteDocType
xmlTextWriterWriteProcessingInstruction
@@ -59,7 +60,6 @@ A:link, A:visited, A:active { text-decoration: underline } xmlMallocFunc
xmlMallocLoc
xmlMemGet
-xmlMemMalloc
xmlMemSetup
mallocAtomicFunc
xmlGcMemGet
xmlGcMemSetup
@@ -288,8 +288,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -307,7 +307,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk18.html b/doc/APIchunk18.html index f4451ce9..bb61c38f 100644 --- a/doc/APIchunk18.html +++ b/doc/APIchunk18.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter n:

named
xmlAddEncodingAlias
names
_xmlDoc
_xmlParserCtxt
@@ -164,7 +165,6 @@ A:link, A:visited, A:active { text-decoration: underline }
nodeset
xmlXPathNodeSetFreeNs
nodesets
xmlXPathNodeSetMerge
non
XML_SCHEMAS_ANYATTR_LAX
-XML_SCHEMAS_ANY_LAX
xmlEncodeEntitiesReentrant
xmlNewChild
xmlNewTextChild
@@ -219,6 +219,7 @@ A:link, A:visited, A:active { text-decoration: underline }
normalization:
xmlCurrentChar
normalizations
xmlTextReaderNormalization
normalize
xmlParseAttValue
+xmlSchemaCollapseString
xmlTextReaderNormalization
normalize-space
xmlXPathNormalizeFunction
normalized
xmlParseAttValue
@@ -266,8 +267,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -285,7 +286,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk19.html b/doc/APIchunk19.html index 44c777b0..566919da 100644 --- a/doc/APIchunk19.html +++ b/doc/APIchunk19.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter o:

object?
xmlXPathNumberFunction
xmlXPathStringFunction
objects
xmlXPathCompareValues
@@ -62,7 +63,6 @@ A:link, A:visited, A:active { text-decoration: underline }
occurences
xmlAutomataNewCountTrans
xmlAutomataNewOnceTrans
occurred
xmlMemStrdupLoc
-xmlMemoryStrdup
occurrence
xmlStrcasestr
xmlStrchr
xmlStrstr
@@ -98,8 +98,8 @@ A:link, A:visited, A:active { text-decoration: underline } xmlLineNumbersDefault
xmlListCopy
xmlNewGlobalNs
-xmlOutputBufferCreateFilenameDefault
-xmlParserInputBufferCreateFilenameDefault
+xmlOutputBufferCreateFilenameDefault
+xmlParserInputBufferCreateFilenameDefault
xmlParserInputBufferGrow
xmlParserInputBufferRead
xmlRegisterNodeDefault
@@ -323,8 +323,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -342,7 +342,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk2.html b/doc/APIchunk2.html index aed367e4..a66f04a3 100644 --- a/doc/APIchunk2.html +++ b/doc/APIchunk2.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter D:

DEBUG_MEMORY
DEBUG_MEMORY
DEBUG_MEMORY_FREED
DEBUG_MEMORY
DEBUG_MEMORY_LOCATION
DEBUG_MEMORY
@@ -88,6 +89,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlParserHandlePEReference
Data
xmlParseCDSect
Datatype
xmlRegexpCompile
+
Datatypes
xmlSchemaGetBuiltInListSimpleTypeItemType
Deallocate
xmlFreeAttributeTable
xmlFreeElementTable
xmlFreeEntitiesTable
@@ -100,6 +102,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSchemaFree
xmlSchemaFreeFacet
xmlSchemaFreeType
+
Deallocates
xmlSchemaFreeWildcard
Debugging
LIBXML_DEBUG_ENABLED
Declaration
xmlParseElementDecl
xmlParseMarkupDecl
@@ -390,8 +393,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -409,7 +412,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk20.html b/doc/APIchunk20.html index add7cc96..8a771c67 100644 --- a/doc/APIchunk20.html +++ b/doc/APIchunk20.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter p:

pairs
startElement
startElementNsSAX2Func
startElementSAXFunc
@@ -190,6 +191,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSchemaValPredefTypeNode
xmlSchemaValidateDoc
xmlSchemaValidateFacet
+xmlSchemaValidateListSimpleTypeFacet
xmlSchemaValidatePredefinedType
xmlSchemaValidateStream
xmlTextReaderPreservePattern
@@ -490,8 +492,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -509,7 +511,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk21.html b/doc/APIchunk21.html index edaaeb12..ca41727d 100644 --- a/doc/APIchunk21.html +++ b/doc/APIchunk21.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter q:

qualified
XML_SCHEMAS_QUALIF_ATTR
XML_SCHEMAS_QUALIF_ELEM
xmlGetDtdQAttrDesc
@@ -143,7 +144,6 @@ A:link, A:visited, A:active { text-decoration: underline } xmlGcMemGet
xmlGcMemSetup
xmlMemGet
-xmlMemRealloc
xmlMemSetup
xmlReallocFunc
xmlReallocLoc
@@ -301,8 +301,8 @@ A:link, A:visited, A:active { text-decoration: underline }
registers
xmlInitCharEncodingHandlers
xmlNewCharEncodingHandler
registration
XML_SKIP_IDS
-xmlOutputBufferCreateFilenameDefault
-xmlParserInputBufferCreateFilenameDefault
+xmlOutputBufferCreateFilenameDefault
+xmlParserInputBufferCreateFilenameDefault
xmlRegisterNodeDefault
regular
LIBXML_REGEXP_ENABLED
xmlRegFreeExecCtxt
@@ -411,6 +411,7 @@ A:link, A:visited, A:active { text-decoration: underline } htmlCreatePushParserCtxt
xmlCreatePushParserCtxt
repr
xmlSchemaValidateFacet
+xmlSchemaValidateListSimpleTypeFacet
representation
_htmlElemDesc
representations
xmlNewTextChild
represented
xmlParseCharData
@@ -431,6 +432,7 @@ A:link, A:visited, A:active { text-decoration: underline }
required
XML_SCHEMAS_ATTR_USE_REQUIRED
htmlRequiredAttrs
xmlCatalogSetDebug
+xmlSchemaCollapseString
xmlXPathStringFunction
requires
XML_SCHEMAS_QUALIF_ATTR
XML_SCHEMAS_QUALIF_ELEM
@@ -493,7 +495,9 @@ A:link, A:visited, A:active { text-decoration: underline }
restored
xmlTextReaderSetErrorHandler
xmlTextReaderSetStructuredErrorHandler
restrict
xmlParseExternalID
-
restriction
XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION
+
restriction
XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION
+XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION
+XML_SCHEMAS_TYPE_FINAL_RESTRICTION
results
xmlXPathEqualValues
xmlXPathNotEqualValues
retrieve
xmlGetGlobalState
@@ -588,8 +592,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -607,7 +611,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk22.html b/doc/APIchunk22.html index 44989532..a4634bba 100644 --- a/doc/APIchunk22.html +++ b/doc/APIchunk22.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter s:

safe
BAD_CAST
xmlInitializeCatalog
xmlLoadCatalog
@@ -253,6 +254,10 @@ A:link, A:visited, A:active { text-decoration: underline } xmlShellSave
xmlShellValidate
xmlShellWrite
+
shema
XML_SCHEMAS_FINAL_DEFAULT_EXTENSION
+XML_SCHEMAS_FINAL_DEFAULT_LIST
+XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION
+XML_SCHEMAS_FINAL_DEFAULT_UNION
shemas
XML_SCHEMAS_QUALIF_ATTR
XML_SCHEMAS_QUALIF_ELEM
shorten
xmlDebugDumpString
@@ -304,6 +309,15 @@ A:link, A:visited, A:active { text-decoration: underline } xmlMutexLock
xmlMutexUnlock
xmlNewMutex
+xmlSchemaGetBuiltInListSimpleTypeItemType
+xmlSchemaValidateListSimpleTypeFacet
+
simpleType
XML_SCHEMAS_TYPE_FINAL_LIST
+XML_SCHEMAS_TYPE_FINAL_RESTRICTION
+XML_SCHEMAS_TYPE_FINAL_UNION
+XML_SCHEMAS_TYPE_VARIETY_ABSENT
+XML_SCHEMAS_TYPE_VARIETY_ATOMIC
+XML_SCHEMAS_TYPE_VARIETY_LIST
+XML_SCHEMAS_TYPE_VARIETY_UNION
simply
xmlSetGenericErrorFunc
xmlSetStructuredErrorFunc
since
xmlBuildRelativeURI
@@ -428,6 +442,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSaveFormatFile
xmlSaveFormatFileEnc
xmlSaveFormatFileTo
+xmlSchemaCollapseString
xmlValidateNCName
xmlValidateNMToken
xmlValidateName
@@ -467,8 +482,6 @@ A:link, A:visited, A:active { text-decoration: underline }
specify
xmlTextReaderLookupNamespace
specifying
xmlMallocAtomicLoc
xmlMallocLoc
-xmlMemMalloc
-xmlMemRealloc
xmlReallocLoc
speed
xmlXPathOrderDocElems
speedup
xmlTextReaderConstString
@@ -600,7 +613,6 @@ A:link, A:visited, A:active { text-decoration: underline } xmlMemGet
xmlMemSetup
xmlMemStrdupLoc
-xmlMemoryStrdup
xmlStrdup
xmlStrdupFunc
stream
_xmlParserCtxt
@@ -651,6 +663,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlFreeURI
xmlNewMutex
xmlParserFindNodeInfo
+xmlSchemaGetBuiltInType
structured
xmlSetStructuredErrorFunc
structures
xmlFreeDoc
xmlFreeNs
@@ -810,8 +823,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -829,7 +842,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk23.html b/doc/APIchunk23.html index 8a6deaee..8ce9e335 100644 --- a/doc/APIchunk23.html +++ b/doc/APIchunk23.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter t:

tag
_htmlElemDesc
htmlAutoCloseTag
htmlIsAutoClosed
@@ -399,6 +400,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlXPtrLocationSetMerge
xmlXPtrNewLocationSetNodes
two-character
xmlCurrentChar
+
typ
_xmlSchemaTypeLink
types
XML_SCHEMAS_FACET_COLLAPSE
_xmlXPathContext
xmlExternalEntityLoader
@@ -410,8 +412,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -429,7 +431,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk24.html b/doc/APIchunk24.html index 7ea991a4..81945fc9 100644 --- a/doc/APIchunk24.html +++ b/doc/APIchunk24.html @@ -7,13 +7,13 @@ H1 {font-family: Verdana,Arial,Helvetica} H2 {font-family: Verdana,Arial,Helvetica} H3 {font-family: Verdana,Arial,Helvetica} A:link, A:visited, A:active { text-decoration: underline } -API Alphabetic Index u-w for libxml2
Action against software patentsGnome2 LogoW3C LogoRed Hat Logo
Made with Libxml2 Logo

The XML C parser and toolkit of Gnome

API Alphabetic Index u-w for libxml2

Developer Menu
API Indexes
Related links

A-B +API Alphabetic Index u-v for libxml2
Action against software patentsGnome2 LogoW3C LogoRed Hat Logo
Made with Libxml2 Logo

The XML C parser and toolkit of Gnome

API Alphabetic Index u-v for libxml2

Developer Menu
API Indexes
Related links

A-B C-C D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter u:

ugly
_xmlParserCtxt
htmlEntityLookup
htmlEntityValueLookup
@@ -60,7 +61,11 @@ A:link, A:visited, A:active { text-decoration: underline } xmlIsLetter
unimplemented
htmlCtxtUseOptions
xmlCtxtUseOptions
-
union
xmlXPathIdFunction
+
union
XML_SCHEMAS_FINAL_DEFAULT_UNION
+XML_SCHEMAS_TYPE_FINAL_UNION
+XML_SCHEMAS_TYPE_VARIETY_ATOMIC
+XML_SCHEMAS_TYPE_VARIETY_UNION
+xmlXPathIdFunction
unique
_xmlParserInput
xmlXPathIdFunction
uniquely
xmlParseAttributeType
@@ -218,6 +223,10 @@ A:link, A:visited, A:active { text-decoration: underline } xmlXPathRegisteredNsCleanup
xmlXPathRegisteredVariablesCleanup
variant
xmlDetectCharEncoding
+
variety
XML_SCHEMAS_TYPE_VARIETY_ABSENT
+XML_SCHEMAS_TYPE_VARIETY_ATOMIC
+XML_SCHEMAS_TYPE_VARIETY_LIST
+XML_SCHEMAS_TYPE_VARIETY_UNION
very
_htmlElemDesc
_xmlParserInput
xmlCharEncFirstLine
@@ -230,224 +239,13 @@ A:link, A:visited, A:active { text-decoration: underline }
visible
xmlC14NExecute
void
xmlSAXParseFileWithData
xmlSAXParseMemoryWithData
-

Letter w:

walker
xmlListReverseWalk
-xmlListWalk
-xmlListWalker
-
walking
_xmlXPathContext
-_xmlXPathParserContext
-xmlListWalker
-
want
xmlCharEncFirstLine
-xmlCharEncInFunc
-xmlCharEncOutFunc
-
warn
xmlCheckVersion
-
warning
_xmlValidCtxt
-docbCreatePushParserCtxt
-htmlCreatePushParserCtxt
-initxmlDefaultSAXHandler
-warningSAXFunc
-xmlCreatePushParserCtxt
-xmlEncodeEntities
-xmlParserValidityWarning
-xmlParserWarning
-xmlRelaxNGGetParserErrors
-xmlRelaxNGGetValidErrors
-xmlRelaxNGSetParserErrors
-xmlRelaxNGSetValidErrors
-xmlSAX2InitDefaultSAXHandler
-xmlSchemaSetParserErrors
-xmlSchemaSetValidErrors
-xmlSearchNs
-xmlTextReaderSetErrorHandler
-xmlTextReaderSetStructuredErrorHandler
-xmlValidityWarningFunc
-
warnings
_xmlParserCtxt
-xmlPedanticParserDefault
-xmlTextReaderSetErrorHandler
-xmlTextReaderSetStructuredErrorHandler
-
way
HTML_COMMENT_NODE
-HTML_ENTITY_REF_NODE
-HTML_PI_NODE
-HTML_PRESERVE_NODE
-HTML_TEXT_NODE
-_xmlDoc
-xmlBoolToText
-xmlKeepBlanksDefault
-xmlNewGlobalNs
-
ways:
xmlValidGetValidElements
-
well
_xmlParserCtxt
-htmlSAXParseDoc
-htmlSAXParseFile
-startElementNsSAX2Func
-xmlCopyDoc
-xmlParseBalancedChunkMemory
-xmlParseBalancedChunkMemoryRecover
-xmlParseCtxtExternalEntity
-xmlParseExternalEntity
-xmlSAX2StartElementNs
-
well-balanced
xmlParseBalancedChunkMemory
-xmlParseBalancedChunkMemoryRecover
-
well-formed
xmlParseCtxtExternalEntity
-xmlParseEntityRef
-xmlParseExtParsedEnt
-xmlParseExternalEntity
-xmlParserHandleReference
-xmlValidateDtdFinal
-
well-formedness
xmlCtxtResetLastError
-xmlParseEntityRef
-xmlResetLastError
-
wellformed
xmlParseFile
-
were
_xmlParserCtxt
-xmlCheckLanguageID
-xmlKeepBlanksDefault
-xmlMemShow
-xmlXIncludeProcess
-xmlXIncludeProcessFlags
-xmlXIncludeProcessNode
-xmlXIncludeProcessTree
-xmlXIncludeProcessTreeFlags
-
wether
_xmlNodeSet
-xmlPatternMatch
-
what
xmlCatalogGetDefaults
-xmlCatalogSetDefaults
-xmlParseNamespace
-xmlTextReaderGetRemainder
-xmlTextWriterWriteRawLen
-
where
_htmlElemDesc
-xmlCopyProp
-xmlCopyPropList
-xmlFileRead
-xmlIOFTPRead
-xmlIOHTTPRead
-xmlNanoHTTPFetch
-xmlNanoHTTPSave
-xmlNewNs
-xmlParseMarkupDecl
-xmlParseSDDecl
-
while
xmlInitCharEncodingHandlers
-xmlParseAttributeType
-xmlParseEnumeratedType
-xmlParseEnumerationType
-xmlParseNotationType
-xmlSetGenericErrorFunc
-xmlSetStructuredErrorFunc
-xmlTextReaderNext
-xmlTextReaderNextSibling
-xmlValidGetValidElements
-
white
xmlKeepBlanksDefault
-xmlParseSDDecl
-xmlTextReaderNormalization
-xmlXPathNormalizeFunction
-
whitespace
xmlIsBlankNode
-xmlParseAttValue
-xmlXPathIdFunction
-xmlXPathNormalizeFunction
-
whitespace-separated
xmlXPathIdFunction
-
whitespaces
ignorableWhitespace
-ignorableWhitespaceSAXFunc
-xmlSAX2IgnorableWhitespace
-
whose
xmlAutomataNewCountTrans
-xmlAutomataNewOnceTrans
-xmlTextReaderLookupNamespace
-
wierd
xmlBuildRelativeURI
-
wildcard
XML_SCHEMAS_ATTRGROUP_GLOBAL
-XML_SCHEMAS_ATTRGROUP_WILDCARD_BUILDED
-XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD
-XML_SCHEMAS_WILDCARD_COMPLETE
-
with_ns
_xmlNodeSet
-
within
_xmlValidCtxt
-xmlAutomataNewCounterTrans
-xmlNewDocComment
-xmlNewDocNode
-xmlNewDocNodeEatName
-xmlNewDocRawNode
-xmlNewDocText
-xmlNodeGetBase
-xmlParseCharData
-xmlParseComment
-xmlParseCtxtExternalEntity
-xmlParseMarkupDecl
-xmlParseSDDecl
-xmlParserFindNodeInfo
-xmlParserHandlePEReference
-xmlParserPrintFileContext
-xmlReconciliateNs
-xmlSAXParseFileWithData
-xmlSAXParseMemoryWithData
-xmlSearchNs
-xmlTextReaderConstXmlLang
-xmlTextReaderXmlLang
-xmlTextWriterWriteBase64
-xmlTextWriterWriteBinHex
-xmlValidGetValidElements
-xmlXPathIntersection
-
without
_xmlEntity
-entityDecl
-entityDeclSAXFunc
-htmlNewDocNoDtD
-xmlNewGlobalNs
-xmlParseEntityRef
-xmlParsePEReference
-xmlParseSDDecl
-xmlParserHandlePEReference
-xmlSAX2EntityDecl
-xmlScanName
-xmlValidateOneAttribute
-xmlValidateOneNamespace
-
won
_xmlParserCtxt
-xmlBufferCreateStatic
-xmlLoadSGMLSuperCatalog
-xmlParseAttValue
-
word
_htmlElemDesc
-
words
xmlXPathNormalizeFunction
-xmlXPathStringLengthFunction
-
work
xmlNodeGetBase
-xmlRemoveProp
-xmlSAXParseDoc
-xmlSAXParseFile
-xmlSAXParseFileWithData
-xmlSAXParseMemory
-xmlSAXParseMemoryWithData
-
worked
xmlNanoFTPCwd
-xmlNanoFTPDele
-
works
xmlShellDu
-
worthwhile
xmlBuildRelativeURI
-
would
htmlAutoCloseTag
-xmlTextReaderGetRemainder
-
write
xmlFileRead
-xmlFindCharEncodingHandler
-xmlGetCharEncodingHandler
-xmlIOFTPRead
-xmlIOHTTPRead
-xmlNewCharEncodingHandler
-xmlOutputBufferCreateIO
-xmlOutputWriteCallback
-xmlSaveToIO
-xmlShellWrite
-
writer
xmlFreeTextWriter
-
writes
xmlBufferWriteQuotedString
-xmlOutputBufferWrite
-xmlOutputBufferWriteEscape
-xmlOutputBufferWriteString
-
writing
xmlOutputBufferCreateFilename
-
www
XINCLUDE_NS
-XINCLUDE_OLD_NS
-getSystemId
-xmlC14NDocDumpMemory
-xmlC14NDocSave
-xmlC14NDocSaveTo
-xmlC14NExecute
-xmlGetCharEncodingName
-xmlParserHandlePEReference
-xmlParserHandleReference
-xmlSAX2GetSystemId
-xmlSchemaGetPredefinedType

A-B C-C D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -465,7 +263,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk25.html b/doc/APIchunk25.html index 89760a7f..13f384a0 100644 --- a/doc/APIchunk25.html +++ b/doc/APIchunk25.html @@ -7,13 +7,13 @@ H1 {font-family: Verdana,Arial,Helvetica} H2 {font-family: Verdana,Arial,Helvetica} H3 {font-family: Verdana,Arial,Helvetica} A:link, A:visited, A:active { text-decoration: underline } -API Alphabetic Index x-x for libxml2
Action against software patentsGnome2 LogoW3C LogoRed Hat Logo
Made with Libxml2 Logo

The XML C parser and toolkit of Gnome

API Alphabetic Index x-x for libxml2

Developer Menu
API Indexes
Related links

A-B +API Alphabetic Index w-w for libxml2
Action against software patentsGnome2 LogoW3C LogoRed Hat Logo
Made with Libxml2 Logo

The XML C parser and toolkit of Gnome

API Alphabetic Index w-w for libxml2

Developer Menu
API Indexes
Related links

A-B C-C D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,445 +31,234 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z -

Letter x:

x00B7
IS_EXTENDER
-
x02D0
IS_EXTENDER
-
x02D1
IS_EXTENDER
-
x0387
IS_EXTENDER
-
x0640
IS_EXTENDER
-
x0E46
IS_EXTENDER
-
x0EC6
IS_EXTENDER
-
x10000-
IS_CHAR
-
x10FFFF
IS_CHAR
-
x20
IS_BLANK
-IS_BYTE_CHAR
-IS_PUBIDCHAR
-xmlParseAttValue
-xmlValidCtxtNormalizeAttributeValue
-xmlValidNormalizeAttributeValue
-
x20-
IS_CHAR
-
x3005
IS_EXTENDER
-
x3007
IS_IDEOGRAPHIC
-
x3021-
IS_IDEOGRAPHIC
-
x3029
IS_IDEOGRAPHIC
-
x3031-
IS_EXTENDER
-
x3035
IS_EXTENDER
-
x309D-
IS_EXTENDER
-
x309E
IS_EXTENDER
-
x30FC-
IS_EXTENDER
-
x30FE
IS_EXTENDER
-
x4E00-
IS_IDEOGRAPHIC
-
x9FA5
IS_IDEOGRAPHIC
-
xD7FF
IS_CHAR
-
xE000-
IS_CHAR
-
xFFFD
IS_CHAR
-
xlink
xlinkGetDefaultDetect
-xlinkGetDefaultHandler
-xlinkSetDefaultDetect
-xlinkSetDefaultHandler
-
xlinkHandlerPtr
xlinkGetDefaultHandler
-
xlinkType
xlinkIsLink
-
xml-c14n
xmlC14NDocDumpMemory
-xmlC14NDocSave
-xmlC14NDocSaveTo
-xmlC14NExecute
-
xml-exc-c14n
xmlC14NDocDumpMemory
-xmlC14NDocSave
-xmlC14NDocSaveTo
-xmlC14NExecute
-
xml-name
xmlParseNamespace
-
xml:
XML_XML_NAMESPACE
-
xml:base
xmlNodeSetBase
-
xml:id
XML_XML_ID
-
xml:lang
xlinkExtendedLinkFunk
-xlinkExtendedLinkSetFunk
-xmlNodeGetLang
-xmlNodeSetLang
-xmlTextReaderConstXmlLang
-xmlTextReaderXmlLang
-xmlXPathLangFunction
-
xml:space
_xmlParserCtxt
-xmlNodeGetSpacePreserve
-xmlNodeSetSpacePreserve
-
xmlAttr
attribute
-attributeSAXFunc
-
xmlAttrPtr
xmlCopyProp
-xmlCopyPropList
-xmlGetID
-
xmlAttributePtr
xmlGetDtdAttrDesc
-xmlGetDtdQAttrDesc
-
xmlAttributeTablePtr
xmlCopyAttributeTable
-
xmlBuffer
xmlCharEncFirstLine
+u-v +w-w +x-x +y-z +

Letter w:

walker
xmlListReverseWalk
+xmlListWalk
+xmlListWalker
+
walking
_xmlXPathContext
+_xmlXPathParserContext
+xmlListWalker
+
want
xmlCharEncFirstLine
xmlCharEncInFunc
xmlCharEncOutFunc
-
xmlBufferPtr
xmlNewTextWriterMemory
-
xmlBuildURI
xmlBuildRelativeURI
-
xmlCatalogAllow
xmlCatalogGetDefaults
-
xmlCatalogPtr
xmlNewCatalog
-
xmlCatalogResolvePublic
xmlCatalogGetPublic
-
xmlCatalogResolveSystem
xmlCatalogGetSystem
-
xmlCharEncoding
_xmlDoc
-_xmlParserCtxt
-xmlGetCharEncodingHandler
-
xmlCharEncodingHandler
xmlNewCharEncodingHandler
-
xmlCharEncodingHandlerPtr
xmlNewCharEncodingHandler
-xmlRegisterCharEncodingHandler
-
xmlCharEncodingInputFunc
xmlNewCharEncodingHandler
-
xmlCharEncodingOutputFunc
xmlNewCharEncodingHandler
-
xmlChars
_xmlParserInput
-xmlBufferWriteCHAR
-xmlParserInputGrow
-xmlParserInputRead
-
xmlCleanupParser
xmlCleanupParser
-
xmlCleanupThreads
xmlCleanupThreads
-
xmlCreateIntSubset
xmlNewDtd
-
xmlDefaultSAXLocator
setDocumentLocator
-setDocumentLocatorSAXFunc
-xmlSAX2SetDocumentLocator
-
xmlDocPtr
xmlCopyDoc
-xmlNewTextWriterDoc
-xmlNewTextWriterTree
-xmlTextReaderCurrentDoc
-
xmlDocumentGetBase
xmlNodeGetBase
-
xmlDtdPtr
xmlCopyDtd
-xmlIOParseDTD
-xmlParseDTD
-xmlSAXParseDTD
-
xmlElementContentPtr
xmlCopyElementContent
-xmlParseElementChildrenContentDecl
-xmlParseElementMixedContentDecl
-
xmlElementPtr
xmlGetDtdElementDesc
-xmlGetDtdQElementDesc
-
xmlElementTablePtr
xmlCopyElementTable
-
xmlEncodeEntities
xmlEncodeEntities
-xmlEncodeEntitiesReentrant
-
xmlEncodeEntitiesReentrant
xmlEncodeEntities
-xmlNewChild
+
warn
xmlCheckVersion
+
warning
_xmlValidCtxt
+docbCreatePushParserCtxt
+htmlCreatePushParserCtxt
+initxmlDefaultSAXHandler
+warningSAXFunc
+xmlCreatePushParserCtxt
+xmlEncodeEntities
+xmlParserValidityWarning
+xmlParserWarning
+xmlRelaxNGGetParserErrors
+xmlRelaxNGGetValidErrors
+xmlRelaxNGSetParserErrors
+xmlRelaxNGSetValidErrors
+xmlSAX2InitDefaultSAXHandler
+xmlSchemaSetParserErrors
+xmlSchemaSetValidErrors
+xmlSearchNs
+xmlTextReaderSetErrorHandler
+xmlTextReaderSetStructuredErrorHandler
+xmlValidityWarningFunc
+
warnings
_xmlParserCtxt
+xmlPedanticParserDefault
+xmlTextReaderSetErrorHandler
+xmlTextReaderSetStructuredErrorHandler
+
way
HTML_COMMENT_NODE
+HTML_ENTITY_REF_NODE
+HTML_PI_NODE
+HTML_PRESERVE_NODE
+HTML_TEXT_NODE
+_xmlDoc
+xmlBoolToText
+xmlKeepBlanksDefault
+xmlNewGlobalNs
+
ways:
xmlValidGetValidElements
+
well
_xmlParserCtxt
+htmlSAXParseDoc
+htmlSAXParseFile
+startElementNsSAX2Func
+xmlCopyDoc
+xmlParseBalancedChunkMemory
+xmlParseBalancedChunkMemoryRecover
+xmlParseCtxtExternalEntity
+xmlParseExternalEntity
+xmlSAX2StartElementNs
+
well-balanced
xmlParseBalancedChunkMemory
+xmlParseBalancedChunkMemoryRecover
+
well-formed
xmlParseCtxtExternalEntity
+xmlParseEntityRef
+xmlParseExtParsedEnt
+xmlParseExternalEntity
+xmlParserHandleReference
+xmlValidateDtdFinal
+
well-formedness
xmlCtxtResetLastError
+xmlParseEntityRef
+xmlResetLastError
+
wellformed
xmlParseFile
+
were
_xmlParserCtxt
+xmlCheckLanguageID
+xmlKeepBlanksDefault
+xmlMemShow
+xmlXIncludeProcess
+xmlXIncludeProcessFlags
+xmlXIncludeProcessNode
+xmlXIncludeProcessTree
+xmlXIncludeProcessTreeFlags
+
wether
_xmlNodeSet
+xmlPatternMatch
+
what
xmlCatalogGetDefaults
+xmlCatalogSetDefaults
+xmlParseNamespace
+xmlTextReaderGetRemainder
+xmlTextWriterWriteRawLen
+
where
_htmlElemDesc
+xmlCopyProp
+xmlCopyPropList
+xmlFileRead
+xmlIOFTPRead
+xmlIOHTTPRead
+xmlNanoHTTPFetch
+xmlNanoHTTPSave
+xmlNewNs
+xmlParseMarkupDecl
+xmlParseSDDecl
+
while
xmlInitCharEncodingHandlers
+xmlParseAttributeType
+xmlParseEnumeratedType
+xmlParseEnumerationType
+xmlParseNotationType
+xmlSetGenericErrorFunc
+xmlSetStructuredErrorFunc
+xmlTextReaderNext
+xmlTextReaderNextSibling
+xmlValidGetValidElements
+
white
xmlKeepBlanksDefault
+xmlParseSDDecl
+xmlSchemaCollapseString
+xmlTextReaderNormalization
+xmlXPathNormalizeFunction
+
whitespace
xmlIsBlankNode
+xmlParseAttValue
+xmlXPathIdFunction
+xmlXPathNormalizeFunction
+
whitespace-separated
xmlXPathIdFunction
+
whitespaces
ignorableWhitespace
+ignorableWhitespaceSAXFunc
+xmlSAX2IgnorableWhitespace
+
whose
xmlAutomataNewCountTrans
+xmlAutomataNewOnceTrans
+xmlTextReaderLookupNamespace
+
wierd
xmlBuildRelativeURI
+
wildcard
XML_SCHEMAS_ATTRGROUP_GLOBAL
+XML_SCHEMAS_ATTRGROUP_WILDCARD_BUILDED
+XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD
+XML_SCHEMAS_WILDCARD_COMPLETE
+xmlSchemaFreeWildcard
+
wildcards
XML_SCHEMAS_ANY_LAX
+XML_SCHEMAS_ANY_STRICT
+XML_SCHEMAS_ATTR_USE_PROHIBITED
+
with_ns
_xmlNodeSet
+
within
_xmlValidCtxt
+xmlAutomataNewCounterTrans
+xmlNewDocComment
xmlNewDocNode
xmlNewDocNodeEatName
-
xmlEntitiesTablePtr
xmlCopyEntitiesTable
-xmlCreateEntitiesTable
-
xmlEntityPtr
getEntity
-getEntitySAXFunc
-getParameterEntity
-getParameterEntitySAXFunc
-xmlNewEntityInputStream
-xmlParseEntityRef
-xmlSAX2GetEntity
-xmlSAX2GetParameterEntity
-
xmlEnumerationPtr
xmlCopyEnumeration
-xmlCreateEnumeration
-
xmlExternalEntityLoader
xmlGetExternalEntityLoader
-
xmlFileOpen_real
xmlFileOpen
-
xmlFree
xmlC14NDocDumpMemory
-xmlDocDumpFormatMemory
-xmlDocDumpFormatMemoryEnc
-xmlDocDumpMemory
-xmlDocDumpMemoryEnc
-xmlGetNoNsProp
-xmlGetNsProp
-xmlGetProp
+xmlNewDocRawNode
+xmlNewDocText
xmlNodeGetBase
-xmlNodeGetContent
-xmlNodeGetLang
-xmlNodeListGetRawString
-xmlNodeListGetString
-xmlTextReaderValue
-
xmlFreeDoc
xmlTextReaderCurrentDoc
-
xmlFreeMutex
xmlFreeMutex
-
xmlGetGlobalState
xmlGetGlobalState
-
xmlGetNoNsProp
xmlGetProp
-
xmlGetNsProp
xmlGetProp
-
xmlGetProp
xmlGetNoNsProp
-
xmlGetThreadId
xmlGetThreadId
-
xmlHashTablePtr
xmlHashCreate
-
xmlIDPtr
xmlAddID
-
xmlIndentTreeOutput
xmlDocDumpFormatMemory
-xmlDocDumpFormatMemoryEnc
-xmlDocFormatDump
-xmlNodeDump
-xmlNodeDumpOutput
-xmlSaveFormatFile
-xmlSaveFormatFileEnc
-
xmlInitParser
htmlInitAutoClose
-
xmlInitThreads
xmlInitThreads
-
xmlInitializeCatalog
xmlCatalogAdd
-
xmlInitializeGlobalState
xmlInitializeGlobalState
-
xmlInputCloseCallback
xmlRegisterInputCallbacks
-
xmlInputMatchCallback
xmlRegisterInputCallbacks
-
xmlInputOpenCallback
xmlRegisterInputCallbacks
-
xmlInputReadCallback
xmlRegisterInputCallbacks
-
xmlIsBaseCharQ
xmlIsBaseChar
-
xmlIsBaseChar_ch
xmlIsBaseChar
-
xmlIsBlankNode
xmlKeepBlanksDefault
-
xmlIsBlankQ
xmlIsBlank
-
xmlIsBlank_ch
xmlIsBlank
-
xmlIsCharQ
xmlIsChar
-
xmlIsChar_ch
xmlIsChar
-
xmlIsCombiningQ
xmlIsCombining
-
xmlIsDigitQ
xmlIsDigit
-
xmlIsDigit_ch
xmlIsDigit
-
xmlIsExtenderQ
xmlIsExtender
-
xmlIsExtender_ch
xmlIsExtender
-
xmlIsIdeographicQ
xmlIsIdeographic
-
xmlIsMainThread
xmlIsMainThread
-
xmlIsPubidCharQ
xmlIsPubidChar
-
xmlIsPubidChar_ch
xmlIsPubidChar
-
xmlKeepBlanksDefault
xmlDocDumpFormatMemory
-xmlDocDumpFormatMemoryEnc
-xmlDocFormatDump
-xmlNodeDump
-xmlNodeDumpOutput
-xmlSaveFormatFile
-xmlSaveFormatFileEnc
-
xmlLineNumbersDefault
xmlGetLineNo
-
xmlListWalk
xmlListWalker
-
xmlLoadExtDtdDefaultValue
XML_COMPLETE_ATTRS
-XML_DETECT_IDS
-XML_SKIP_IDS
-
xmlLocationSetPtr
xmlXPtrFreeLocationSet
-xmlXPtrLocationSetCreate
-
xmlLockLibrary
xmlLockLibrary
-
xmlMutexLock
xmlMutexLock
-
xmlMutexUnlock
xmlMutexUnlock
-
xmlNanoFTPGet
ftpDataCallback
-
xmlNanoFTPList
ftpListCallback
-
xmlNewChild
xmlNewTextChild
-
xmlNewDocRawNode
xmlNewDocNode
-xmlNewDocNodeEatName
-
xmlNewMutex
xmlNewMutex
-
xmlNewNode
xmlNewNodeEatName
-
xmlNewTextChild
xmlNewChild
-xmlNewTextChild
-
xmlNewTextWriter
xmlNewTextWriter
-xmlNewTextWriterDoc
-xmlNewTextWriterFilename
-xmlNewTextWriterMemory
-xmlNewTextWriterPushParser
-xmlNewTextWriterTree
-
xmlNodeListGetString
xmlNodeListGetRawString
-
xmlNodePtr
xmlCopyNode
-xmlCopyNodeList
-xmlDocCopyNode
-xmlDocGetRootElement
-xmlNewTextWriterTree
-xmlTextReaderCurrentNode
-xmlTextReaderPreserve
-xmlXPathNodeSetAdd
-xmlXPathNodeSetAddUnique
-xmlXPathNodeSetCreate
-xmlXPathNodeSetDel
-xmlXPathNodeSetItem
-xmlXPtrBuildNodeList
-
xmlNodeSetPtr
xmlXPathFreeNodeSet
-xmlXPathNodeSetCreate
-
xmlNodeType
xmlTextReaderNodeType
-
xmlNotationPtr
xmlGetDtdNotationDesc
-
xmlNotationTablePtr
xmlCopyNotationTable
-
xmlNsPtr
getNamespace
-xmlCopyNamespace
-xmlCopyNamespaceList
-xmlGetNsList
-
xmlOutputBufferPtr
xmlNewTextWriter
-
xmlOutputCloseCallback
xmlRegisterOutputCallbacks
-
xmlOutputMatchCallback
xmlRegisterOutputCallbacks
-
xmlOutputOpenCallback
xmlRegisterOutputCallbacks
-
xmlOutputWriteCallback
xmlRegisterOutputCallbacks
-
xmlParseAttValue
xmlParseDefaultDecl
-
xmlParseChunk
xmlCreatePushParserCtxt
-
xmlParseElementContentDecl
xmlParseElementChildrenContentDecl
-xmlParseElementMixedContentDecl
-
xmlParseElementDecl
xmlParseElementContentDecl
-
xmlParseExternalID
xmlParseNotationDecl
-
xmlParseFile
xmlParseCatalogFile
-
xmlParseNamespace:
xmlParseNamespace
-
xmlParseURI
xmlURIEscape
-
xmlParserCtxtPtr
xmlNewParserCtxt
-xmlNewTextWriterPushParser
-
xmlParserError
_xmlError
-
xmlParserErrors
docbParseChunk
-htmlParseChunk
-xmlParseChunk
-
xmlParserFindNodeInfoIndex
xmlParserFindNodeInfoIndex
-
xmlParserHandleReference
xmlScanName
-
xmlParserInputBufferPtr
xmlNewTextReader
-xmlTextReaderGetRemainder
-
xmlParserInputPtr
resolveEntity
-resolveEntitySAXFunc
-xmlFreeInputStream
-xmlLoadExternalEntity
-xmlNoNetExternalEntityLoader
+xmlParseCharData
+xmlParseComment
+xmlParseCtxtExternalEntity
+xmlParseMarkupDecl
+xmlParseSDDecl
+xmlParserFindNodeInfo
+xmlParserHandlePEReference
xmlParserPrintFileContext
-xmlParserPrintFileInfo
-xmlSAX2ResolveEntity
-
xmlParserNodeInfo
xmlParserFindNodeInfo
-
xmlParserProperties
xmlTextReaderGetParserProp
-xmlTextReaderSetParserProp
-
xmlPattern
LIBXML_PATTERN_ENABLED
-
xmlPopInput:
xmlPopInput
-
xmlPushInput:
xmlPushInput
-
xmlRFreeMutex
xmlFreeRMutex
-
xmlRMutexLock
xmlRMutexLock
-
xmlRMutexUnlock
xmlRMutexUnlock
-
xmlRNewMutex
xmlNewRMutex
-
xmlReader
LIBXML_READER_ENABLED
-
xmlRefPtr
xmlAddRef
-
xmlRelaxNGParserFlag
xmlRelaxParserSetFlag
-
xmlRelaxNGValidatePushElement
xmlRelaxNGValidateFullElement
-
xmlSAX2Attribute
attribute
-
xmlSAX2AttributeDecl
attributeDecl
-
xmlSAX2CDataBlock
cdataBlock
-
xmlSAX2Characters
characters
-xmlSAX2IgnorableWhitespace
-
xmlSAX2Comment
comment
-xmlSAX2Comment
-
xmlSAX2ElementDecl
elementDecl
-
xmlSAX2EndDocument
endDocument
-
xmlSAX2EndElement
endElement
-
xmlSAX2EntityDecl
entityDecl
-
xmlSAX2ExternalSubset
externalSubset
-
xmlSAX2GetColumnNumber
getColumnNumber
-
xmlSAX2GetEntity
getEntity
-
xmlSAX2GetLineNumber
getLineNumber
-
xmlSAX2GetParameterEntity
getParameterEntity
-
xmlSAX2GetPublicId
getPublicId
-
xmlSAX2GetSystemId
getSystemId
-
xmlSAX2HasExternalSubset
hasExternalSubset
-
xmlSAX2HasInternalSubset
hasInternalSubset
-
xmlSAX2IgnorableWhitespace
ignorableWhitespace
-xmlKeepBlanksDefault
-
xmlSAX2InitDefaultSAXHandler
initxmlDefaultSAXHandler
-
xmlSAX2InitDocbDefaultSAXHandler
initdocbDefaultSAXHandler
-
xmlSAX2InitHtmlDefaultSAXHandler
inithtmlDefaultSAXHandler
-
xmlSAX2InternalSubset
internalSubset
-
xmlSAX2IsStandalone
isStandalone
-
xmlSAX2NotationDecl
notationDecl
-
xmlSAX2ProcessingInstruction
processingInstruction
-
xmlSAX2Reference
reference
-xmlSAX2Reference
-
xmlSAX2ResolveEntity
resolveEntity
-xmlSAX2ResolveEntity
-
xmlSAX2StartDocument
startDocument
-
xmlSAX2StartElement
startElement
-
xmlSAX2UnparsedEntityDecl
unparsedEntityDecl
-
xmlSAXVersion
xmlSAXDefaultVersion
-
xmlSaveOptions
xmlSaveToFd
-xmlSaveToFilename
+xmlReconciliateNs
+xmlSAXParseFileWithData
+xmlSAXParseMemoryWithData
+xmlSearchNs
+xmlTextReaderConstXmlLang
+xmlTextReaderXmlLang
+xmlTextWriterWriteBase64
+xmlTextWriterWriteBinHex
+xmlValidGetValidElements
+xmlXPathIntersection
+
without
_xmlEntity
+entityDecl
+entityDeclSAXFunc
+htmlNewDocNoDtD
+xmlNewGlobalNs
+xmlParseEntityRef
+xmlParsePEReference
+xmlParseSDDecl
+xmlParserHandlePEReference
+xmlSAX2EntityDecl
+xmlScanName
+xmlValidateOneAttribute
+xmlValidateOneNamespace
+
won
_xmlParserCtxt
+xmlBufferCreateStatic
+xmlLoadSGMLSuperCatalog
+xmlParseAttValue
+
word
_htmlElemDesc
+
words
xmlXPathNormalizeFunction
+xmlXPathStringLengthFunction
+
work
xmlNodeGetBase
+xmlRemoveProp
+xmlSAXParseDoc
+xmlSAXParseFile
+xmlSAXParseFileWithData
+xmlSAXParseMemory
+xmlSAXParseMemoryWithData
+
worked
xmlNanoFTPCwd
+xmlNanoFTPDele
+
works
xmlShellDu
+
worry
XML_SCHEMAS_ANY_LAX
+
worthwhile
xmlBuildRelativeURI
+
would
htmlAutoCloseTag
+xmlTextReaderGetRemainder
+
write
xmlFileRead
+xmlFindCharEncodingHandler
+xmlGetCharEncodingHandler
+xmlIOFTPRead
+xmlIOHTTPRead
+xmlNewCharEncodingHandler
+xmlOutputBufferCreateIO
+xmlOutputWriteCallback
xmlSaveToIO
-
xmlSetExternalEntityLoader
resolveEntity
-resolveEntitySAXFunc
-xmlSAX2ResolveEntity
-
xmlSnprintfElementContent
xmlSprintfElementContent
-
xmlStrEqual
xmlStrEqual
-
xmlStrdup
xmlNewNode
-
xmlStringDecodeEntities
xmlDecodeEntities
-
xmlStringGetNodeList
xmlParseAttValue
-
xmlStrncat
xmlStrncatNew
-
xmlStrncmp
xmlUTF8Charcmp
-
xmlTextReader
xmlNewTextReader
-xmlNewTextReaderFilename
-xmlReaderNewDoc
-xmlReaderNewFd
-xmlReaderNewFile
-xmlReaderNewIO
-xmlReaderNewMemory
-xmlReaderNewWalker
-xmlTextReaderCurrentDoc
-xmlTextReaderCurrentNode
-
xmlTextReaderCurrentDoc
xmlTextReaderPreserve
-xmlTextReaderPreservePattern
-
xmlTextReaderLocatorPtr
xmlTextReaderLocatorBaseURI
-xmlTextReaderLocatorLineNumber
-
xmlTextReaderRead
xmlTextReaderExpand
-
xmlTextWriterStartDTDEntity
xmlTextWriterWriteDTDExternalEntity
-
xmlTextWriterWriteDTD
xmlTextWriterWriteDocType
-
xmlTextWriterWritePI
xmlTextWriterWriteProcessingInstruction
-
xmlURI
xmlCreateURI
-xmlFreeURI
-xmlPrintURI
-xmlSaveUri
-
xmlURIEscapeStr
xmlURIEscape
-
xmlURIFromPath
xmlNormalizeWindowsPath
-
xmlURIPtr
xmlParseURI
-
xmlUnlinkNode
xmlFreeNode
-
xmlUnlockLibrary
xmlUnlockLibrary
-
xmlValidCtxtPtr
xmlValidityErrorFunc
-xmlValidityWarningFunc
-
xmlValidGetValidElements
xmlValidGetValidElements
-
xmlValidateAttributeDecl
xmlParseDefaultDecl
-
xmlValidateAttributeValue
xmlParseAttributeType
-
xmlValidateOneAttribute
xmlValidateOneElement
-
xmlWriter
LIBXML_WRITER_ENABLED
-
xmlXPathCheckError
xmlXPathPopBoolean
-xmlXPathPopExternal
-xmlXPathPopNodeSet
-xmlXPathPopNumber
-xmlXPathPopString
-
xmlXPathCompExprPtr
xmlXPathCompile
-xmlXPathCtxtCompile
-
xmlXPathContext
xmlXPathFreeContext
-xmlXPathNewContext
-xmlXPtrNewContext
-
xmlXPathError
err
-
xmlXPathEvalPredicate
xmlXPtrEvalRangePredicate
-
xmlXPathFreeObject
xmlXPathFreeNodeSetList
-
xmlXPathFunction
xmlXPathFunctionLookup
-xmlXPathFunctionLookupNS
-
xmlXPathNodeTrailingSorted
xmlXPathNodeTrailing
-
xmlXPathObjectPtr
xmlXPathCompiledEval
-xmlXPathEval
-xmlXPathEvalExpression
-xmlXPathFreeNodeSetList
-xmlXPathFreeObject
-xmlXPathNewBoolean
-xmlXPathNewCString
-xmlXPathNewFloat
-xmlXPathNewNodeSet
-xmlXPathNewNodeSetList
-xmlXPathNewString
-xmlXPathNewValueTree
-xmlXPathWrapNodeSet
-xmlXPtrEval
-xmlXPtrLocationSetAdd
-xmlXPtrLocationSetCreate
-xmlXPtrLocationSetDel
-xmlXPtrNewCollapsedRange
-xmlXPtrNewLocationSetNodeSet
-xmlXPtrNewLocationSetNodes
-xmlXPtrNewRange
-xmlXPtrNewRangeNodeObject
-xmlXPtrNewRangeNodePoint
-xmlXPtrNewRangeNodes
-xmlXPtrNewRangePointNode
-xmlXPtrNewRangePoints
-xmlXPtrWrapLocationSet
-
xmlXPathParserContext
xmlXPathFreeParserContext
-xmlXPathNewParserContext
-
xmlXPathTrailingSorted
xmlXPathTrailing
-
xmlns
xmlNamespaceParseNSDef
-
xmlns:???
xmlParseAttribute
-
xmltextReader
xmlReaderForDoc
-xmlReaderForFd
-xmlReaderForIO
-xmlReaderForMemory
-xmlReaderNewDoc
-xmlReaderNewFd
-xmlReaderNewIO
-xmlReaderNewMemory
-xmlReaderNewWalker
-xmlReaderWalker
-
xpath
xmlShellPrintXPathError
-xmlShellPrintXPathResult
-
xpointer
XINCLUDE_PARSE_XPOINTER
+xmlShellWrite
+
writer
xmlFreeTextWriter
+
writes
xmlBufferWriteQuotedString
+xmlOutputBufferWrite
+xmlOutputBufferWriteEscape
+xmlOutputBufferWriteString
+
writing
xmlOutputBufferCreateFilename
+
www
XINCLUDE_NS
+XINCLUDE_OLD_NS
+getSystemId
+xmlC14NDocDumpMemory
+xmlC14NDocSave
+xmlC14NDocSaveTo
+xmlC14NExecute
+xmlGetCharEncodingName
+xmlParserHandlePEReference
+xmlParserHandleReference
+xmlSAX2GetSystemId
+xmlSchemaGetPredefinedType

A-B C-C D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -487,7 +276,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk26.html b/doc/APIchunk26.html index fdd4f928..58438e96 100644 --- a/doc/APIchunk26.html +++ b/doc/APIchunk26.html @@ -7,13 +7,13 @@ H1 {font-family: Verdana,Arial,Helvetica} H2 {font-family: Verdana,Arial,Helvetica} H3 {font-family: Verdana,Arial,Helvetica} A:link, A:visited, A:active { text-decoration: underline } -API Alphabetic Index y-z for libxml2
Action against software patentsGnome2 LogoW3C LogoRed Hat Logo
Made with Libxml2 Logo

The XML C parser and toolkit of Gnome

API Alphabetic Index y-z for libxml2

Developer Menu
API Indexes
Related links

A-B +API Alphabetic Index x-x for libxml2
Action against software patentsGnome2 LogoW3C LogoRed Hat Logo
Made with Libxml2 Logo

The XML C parser and toolkit of Gnome

API Alphabetic Index x-x for libxml2

Developer Menu
API Indexes
Related links

A-B C-C D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,64 +31,446 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z -

Letter y:

year
ftpListCallback
-
yes
xmlInputMatchCallback
-xmlIsBlankNode
-xmlIsMixedElement
-xmlNodeIsText
-xmlOutputMatchCallback
-xmlParseEntityRef
-xmlParsePEReference
-xmlParseSDDecl
-xmlParserHandlePEReference
-xmlRegexpIsDeterminist
-xmlTextWriterStartDocument
-
yet
xmlPatterncompile
-xmlSaveDoc
-xmlSaveTree
-
you
xmlNewDocNode
-xmlNewDocNodeEatName
-xmlNewTextChild
-xmlSearchNs
-

Letter z:

zero
docbEncodeEntities
-docbParseChunk
-htmlCtxtReadDoc
-htmlEncodeEntities
-htmlParseChunk
-htmlReadDoc
-xmlBufferCCat
-xmlBufferCat
-xmlByteConsumed
-xmlCopyDoc
-xmlCtxtReadDoc
-xmlDocDumpMemory
-xmlOutputBufferWriteEscape
-xmlOutputBufferWriteString
-xmlParseBalancedChunkMemory
-xmlParseBalancedChunkMemoryRecover
-xmlParseChunk
-xmlReadDoc
-xmlReaderForDoc
-xmlReaderNewDoc
-xmlStrdupFunc
-xmlStrsub
-xmlXPathBooleanFunction
-xmlXPathStringFunction
-
zero-based
xmlTextReaderGetAttributeNo
-xmlTextReaderMoveToAttributeNo
-
zeros
xmlXPathStringFunction
-
zlib
_xmlDoc
+u-v +w-w +x-x +y-z +

Letter x:

x00B7
IS_EXTENDER
+
x02D0
IS_EXTENDER
+
x02D1
IS_EXTENDER
+
x0387
IS_EXTENDER
+
x0640
IS_EXTENDER
+
x0E46
IS_EXTENDER
+
x0EC6
IS_EXTENDER
+
x10000-
IS_CHAR
+
x10FFFF
IS_CHAR
+
x20
IS_BLANK
+IS_BYTE_CHAR
+IS_PUBIDCHAR
+xmlParseAttValue
+xmlValidCtxtNormalizeAttributeValue
+xmlValidNormalizeAttributeValue
+
x20-
IS_CHAR
+
x3005
IS_EXTENDER
+
x3007
IS_IDEOGRAPHIC
+
x3021-
IS_IDEOGRAPHIC
+
x3029
IS_IDEOGRAPHIC
+
x3031-
IS_EXTENDER
+
x3035
IS_EXTENDER
+
x309D-
IS_EXTENDER
+
x309E
IS_EXTENDER
+
x30FC-
IS_EXTENDER
+
x30FE
IS_EXTENDER
+
x4E00-
IS_IDEOGRAPHIC
+
x9FA5
IS_IDEOGRAPHIC
+
xD7FF
IS_CHAR
+
xE000-
IS_CHAR
+
xFFFD
IS_CHAR
+
xlink
xlinkGetDefaultDetect
+xlinkGetDefaultHandler
+xlinkSetDefaultDetect
+xlinkSetDefaultHandler
+
xlinkHandlerPtr
xlinkGetDefaultHandler
+
xlinkType
xlinkIsLink
+
xml-c14n
xmlC14NDocDumpMemory
xmlC14NDocSave
+xmlC14NDocSaveTo
+xmlC14NExecute
+
xml-exc-c14n
xmlC14NDocDumpMemory
+xmlC14NDocSave
+xmlC14NDocSaveTo
+xmlC14NExecute
+
xml-name
xmlParseNamespace
+
xml:
XML_XML_NAMESPACE
+
xml:base
xmlNodeSetBase
+
xml:id
XML_XML_ID
+
xml:lang
xlinkExtendedLinkFunk
+xlinkExtendedLinkSetFunk
+xmlNodeGetLang
+xmlNodeSetLang
+xmlTextReaderConstXmlLang
+xmlTextReaderXmlLang
+xmlXPathLangFunction
+
xml:space
_xmlParserCtxt
+xmlNodeGetSpacePreserve
+xmlNodeSetSpacePreserve
+
xmlAttr
attribute
+attributeSAXFunc
+
xmlAttrPtr
xmlCopyProp
+xmlCopyPropList
+xmlGetID
+
xmlAttributePtr
xmlGetDtdAttrDesc
+xmlGetDtdQAttrDesc
+
xmlAttributeTablePtr
xmlCopyAttributeTable
+
xmlBuffer
xmlCharEncFirstLine
+xmlCharEncInFunc
+xmlCharEncOutFunc
+
xmlBufferPtr
xmlNewTextWriterMemory
+
xmlBuildURI
xmlBuildRelativeURI
+
xmlCatalogAllow
xmlCatalogGetDefaults
+
xmlCatalogPtr
xmlNewCatalog
+
xmlCatalogResolvePublic
xmlCatalogGetPublic
+
xmlCatalogResolveSystem
xmlCatalogGetSystem
+
xmlCharEncoding
_xmlDoc
+_xmlParserCtxt
+xmlGetCharEncodingHandler
+
xmlCharEncodingHandler
xmlNewCharEncodingHandler
+
xmlCharEncodingHandlerPtr
xmlNewCharEncodingHandler
+xmlRegisterCharEncodingHandler
+
xmlCharEncodingInputFunc
xmlNewCharEncodingHandler
+
xmlCharEncodingOutputFunc
xmlNewCharEncodingHandler
+
xmlChars
_xmlParserInput
+xmlBufferWriteCHAR
+xmlParserInputGrow
+xmlParserInputRead
+
xmlCleanupParser
xmlCleanupParser
+
xmlCleanupThreads
xmlCleanupThreads
+
xmlCreateIntSubset
xmlNewDtd
+
xmlDefaultSAXLocator
setDocumentLocator
+setDocumentLocatorSAXFunc
+xmlSAX2SetDocumentLocator
+
xmlDocPtr
xmlCopyDoc
+xmlNewTextWriterDoc
+xmlNewTextWriterTree
+xmlTextReaderCurrentDoc
+
xmlDocumentGetBase
xmlNodeGetBase
+
xmlDtdPtr
xmlCopyDtd
+xmlIOParseDTD
+xmlParseDTD
+xmlSAXParseDTD
+
xmlElementContentPtr
xmlCopyElementContent
+xmlParseElementChildrenContentDecl
+xmlParseElementMixedContentDecl
+
xmlElementPtr
xmlGetDtdElementDesc
+xmlGetDtdQElementDesc
+
xmlElementTablePtr
xmlCopyElementTable
+
xmlEncodeEntities
xmlEncodeEntities
+xmlEncodeEntitiesReentrant
+
xmlEncodeEntitiesReentrant
xmlEncodeEntities
+xmlNewChild
+xmlNewDocNode
+xmlNewDocNodeEatName
+
xmlEntitiesTablePtr
xmlCopyEntitiesTable
+xmlCreateEntitiesTable
+
xmlEntityPtr
getEntity
+getEntitySAXFunc
+getParameterEntity
+getParameterEntitySAXFunc
+xmlNewEntityInputStream
+xmlParseEntityRef
+xmlSAX2GetEntity
+xmlSAX2GetParameterEntity
+
xmlEnumerationPtr
xmlCopyEnumeration
+xmlCreateEnumeration
+
xmlExternalEntityLoader
xmlGetExternalEntityLoader
+
xmlFileOpen_real
xmlFileOpen
+
xmlFree
xmlC14NDocDumpMemory
+xmlDocDumpFormatMemory
+xmlDocDumpFormatMemoryEnc
+xmlDocDumpMemory
+xmlDocDumpMemoryEnc
+xmlGetNoNsProp
+xmlGetNsProp
+xmlGetProp
+xmlNodeGetBase
+xmlNodeGetContent
+xmlNodeGetLang
+xmlNodeListGetRawString
+xmlNodeListGetString
+xmlTextReaderValue
+
xmlFreeDoc
xmlTextReaderCurrentDoc
+
xmlFreeMutex
xmlFreeMutex
+
xmlGetGlobalState
xmlGetGlobalState
+
xmlGetNoNsProp
xmlGetProp
+
xmlGetNsProp
xmlGetProp
+
xmlGetProp
xmlGetNoNsProp
+
xmlGetThreadId
xmlGetThreadId
+
xmlHashTablePtr
xmlHashCreate
+
xmlIDPtr
xmlAddID
+
xmlIndentTreeOutput
xmlDocDumpFormatMemory
+xmlDocDumpFormatMemoryEnc
+xmlDocFormatDump
+xmlNodeDump
+xmlNodeDumpOutput
+xmlSaveFormatFile
+xmlSaveFormatFileEnc
+
xmlInitParser
htmlInitAutoClose
+
xmlInitThreads
xmlInitThreads
+
xmlInitializeCatalog
xmlCatalogAdd
+
xmlInitializeGlobalState
xmlInitializeGlobalState
+
xmlInputCloseCallback
xmlRegisterInputCallbacks
+
xmlInputMatchCallback
xmlRegisterInputCallbacks
+
xmlInputOpenCallback
xmlRegisterInputCallbacks
+
xmlInputReadCallback
xmlRegisterInputCallbacks
+
xmlIsBaseCharQ
xmlIsBaseChar
+
xmlIsBaseChar_ch
xmlIsBaseChar
+
xmlIsBlankNode
xmlKeepBlanksDefault
+
xmlIsBlankQ
xmlIsBlank
+
xmlIsBlank_ch
xmlIsBlank
+
xmlIsCharQ
xmlIsChar
+
xmlIsChar_ch
xmlIsChar
+
xmlIsCombiningQ
xmlIsCombining
+
xmlIsDigitQ
xmlIsDigit
+
xmlIsDigit_ch
xmlIsDigit
+
xmlIsExtenderQ
xmlIsExtender
+
xmlIsExtender_ch
xmlIsExtender
+
xmlIsIdeographicQ
xmlIsIdeographic
+
xmlIsMainThread
xmlIsMainThread
+
xmlIsPubidCharQ
xmlIsPubidChar
+
xmlIsPubidChar_ch
xmlIsPubidChar
+
xmlKeepBlanksDefault
xmlDocDumpFormatMemory
+xmlDocDumpFormatMemoryEnc
+xmlDocFormatDump
+xmlNodeDump
+xmlNodeDumpOutput
+xmlSaveFormatFile
+xmlSaveFormatFileEnc
+
xmlLineNumbersDefault
xmlGetLineNo
+
xmlListWalk
xmlListWalker
+
xmlLoadExtDtdDefaultValue
XML_COMPLETE_ATTRS
+XML_DETECT_IDS
+XML_SKIP_IDS
+
xmlLocationSetPtr
xmlXPtrFreeLocationSet
+xmlXPtrLocationSetCreate
+
xmlLockLibrary
xmlLockLibrary
+
xmlMutexLock
xmlMutexLock
+
xmlMutexUnlock
xmlMutexUnlock
+
xmlNanoFTPGet
ftpDataCallback
+
xmlNanoFTPList
ftpListCallback
+
xmlNewChild
xmlNewTextChild
+
xmlNewDocRawNode
xmlNewDocNode
+xmlNewDocNodeEatName
+
xmlNewMutex
xmlNewMutex
+
xmlNewNode
xmlNewNodeEatName
+
xmlNewTextChild
xmlNewChild
+xmlNewTextChild
+
xmlNewTextWriter
xmlNewTextWriter
+xmlNewTextWriterDoc
+xmlNewTextWriterFilename
+xmlNewTextWriterMemory
+xmlNewTextWriterPushParser
+xmlNewTextWriterTree
+
xmlNodeListGetString
xmlNodeListGetRawString
+
xmlNodePtr
xmlCopyNode
+xmlCopyNodeList
+xmlDocCopyNode
+xmlDocGetRootElement
+xmlNewTextWriterTree
+xmlTextReaderCurrentNode
+xmlTextReaderPreserve
+xmlXPathNodeSetAdd
+xmlXPathNodeSetAddUnique
+xmlXPathNodeSetCreate
+xmlXPathNodeSetDel
+xmlXPathNodeSetItem
+xmlXPtrBuildNodeList
+
xmlNodeSetPtr
xmlXPathFreeNodeSet
+xmlXPathNodeSetCreate
+
xmlNodeType
xmlTextReaderNodeType
+
xmlNotationPtr
xmlGetDtdNotationDesc
+
xmlNotationTablePtr
xmlCopyNotationTable
+
xmlNsPtr
getNamespace
+xmlCopyNamespace
+xmlCopyNamespaceList
+xmlGetNsList
+
xmlOutputBufferPtr
xmlNewTextWriter
+
xmlOutputCloseCallback
xmlRegisterOutputCallbacks
+
xmlOutputMatchCallback
xmlRegisterOutputCallbacks
+
xmlOutputOpenCallback
xmlRegisterOutputCallbacks
+
xmlOutputWriteCallback
xmlRegisterOutputCallbacks
+
xmlParseAttValue
xmlParseDefaultDecl
+
xmlParseChunk
xmlCreatePushParserCtxt
+
xmlParseElementContentDecl
xmlParseElementChildrenContentDecl
+xmlParseElementMixedContentDecl
+
xmlParseElementDecl
xmlParseElementContentDecl
+
xmlParseExternalID
xmlParseNotationDecl
+
xmlParseFile
xmlParseCatalogFile
+
xmlParseNamespace:
xmlParseNamespace
+
xmlParseURI
xmlURIEscape
+
xmlParserCtxtPtr
xmlNewParserCtxt
+xmlNewTextWriterPushParser
+
xmlParserError
_xmlError
+
xmlParserErrors
docbParseChunk
+htmlParseChunk
+xmlParseChunk
+
xmlParserFindNodeInfoIndex
xmlParserFindNodeInfoIndex
+
xmlParserHandleReference
xmlScanName
+
xmlParserInputBufferPtr
xmlNewTextReader
+xmlTextReaderGetRemainder
+
xmlParserInputPtr
resolveEntity
+resolveEntitySAXFunc
+xmlFreeInputStream
+xmlLoadExternalEntity
+xmlNoNetExternalEntityLoader
+xmlParserPrintFileContext
+xmlParserPrintFileInfo
+xmlSAX2ResolveEntity
+
xmlParserNodeInfo
xmlParserFindNodeInfo
+
xmlParserProperties
xmlTextReaderGetParserProp
+xmlTextReaderSetParserProp
+
xmlPattern
LIBXML_PATTERN_ENABLED
+
xmlPopInput:
xmlPopInput
+
xmlPushInput:
xmlPushInput
+
xmlRFreeMutex
xmlFreeRMutex
+
xmlRMutexLock
xmlRMutexLock
+
xmlRMutexUnlock
xmlRMutexUnlock
+
xmlRNewMutex
xmlNewRMutex
+
xmlReader
LIBXML_READER_ENABLED
+
xmlRefPtr
xmlAddRef
+
xmlRelaxNGParserFlag
xmlRelaxParserSetFlag
+
xmlRelaxNGValidatePushElement
xmlRelaxNGValidateFullElement
+
xmlSAX2Attribute
attribute
+
xmlSAX2AttributeDecl
attributeDecl
+
xmlSAX2CDataBlock
cdataBlock
+
xmlSAX2Characters
characters
+xmlSAX2IgnorableWhitespace
+
xmlSAX2Comment
comment
+xmlSAX2Comment
+
xmlSAX2ElementDecl
elementDecl
+
xmlSAX2EndDocument
endDocument
+
xmlSAX2EndElement
endElement
+
xmlSAX2EntityDecl
entityDecl
+
xmlSAX2ExternalSubset
externalSubset
+
xmlSAX2GetColumnNumber
getColumnNumber
+
xmlSAX2GetEntity
getEntity
+
xmlSAX2GetLineNumber
getLineNumber
+
xmlSAX2GetParameterEntity
getParameterEntity
+
xmlSAX2GetPublicId
getPublicId
+
xmlSAX2GetSystemId
getSystemId
+
xmlSAX2HasExternalSubset
hasExternalSubset
+
xmlSAX2HasInternalSubset
hasInternalSubset
+
xmlSAX2IgnorableWhitespace
ignorableWhitespace
+xmlKeepBlanksDefault
+
xmlSAX2InitDefaultSAXHandler
initxmlDefaultSAXHandler
+
xmlSAX2InitDocbDefaultSAXHandler
initdocbDefaultSAXHandler
+
xmlSAX2InitHtmlDefaultSAXHandler
inithtmlDefaultSAXHandler
+
xmlSAX2InternalSubset
internalSubset
+
xmlSAX2IsStandalone
isStandalone
+
xmlSAX2NotationDecl
notationDecl
+
xmlSAX2ProcessingInstruction
processingInstruction
+
xmlSAX2Reference
reference
+xmlSAX2Reference
+
xmlSAX2ResolveEntity
resolveEntity
+xmlSAX2ResolveEntity
+
xmlSAX2StartDocument
startDocument
+
xmlSAX2StartElement
startElement
+
xmlSAX2UnparsedEntityDecl
unparsedEntityDecl
+
xmlSAXVersion
xmlSAXDefaultVersion
+
xmlSaveOptions
xmlSaveToFd
+xmlSaveToFilename
+xmlSaveToIO
+
xmlSetExternalEntityLoader
resolveEntity
+resolveEntitySAXFunc
+xmlSAX2ResolveEntity
+
xmlSnprintfElementContent
xmlSprintfElementContent
+
xmlStrEqual
xmlStrEqual
+
xmlStrdup
xmlNewNode
+
xmlStringDecodeEntities
xmlDecodeEntities
+
xmlStringGetNodeList
xmlParseAttValue
+
xmlStrncat
xmlStrncatNew
+
xmlStrncmp
xmlUTF8Charcmp
+
xmlTextReader
xmlNewTextReader
+xmlNewTextReaderFilename
+xmlReaderNewDoc
+xmlReaderNewFd
+xmlReaderNewFile
+xmlReaderNewIO
+xmlReaderNewMemory
+xmlReaderNewWalker
+xmlTextReaderCurrentDoc
+xmlTextReaderCurrentNode
+
xmlTextReaderCurrentDoc
xmlTextReaderPreserve
+xmlTextReaderPreservePattern
+
xmlTextReaderLocatorPtr
xmlTextReaderLocatorBaseURI
+xmlTextReaderLocatorLineNumber
+
xmlTextReaderRead
xmlTextReaderExpand
+
xmlTextWriterStartDTDEntity
xmlTextWriterWriteDTDExternalEntity
+
xmlTextWriterWriteDTD
xmlTextWriterWriteDocType
+
xmlTextWriterWritePI
xmlTextWriterWriteProcessingInstruction
+
xmlURI
xmlCreateURI
+xmlFreeURI
+xmlPrintURI
+xmlSaveUri
+
xmlURIEscapeStr
xmlURIEscape
+
xmlURIFromPath
xmlNormalizeWindowsPath
+
xmlURIPtr
xmlParseURI
+
xmlUnlinkNode
xmlFreeNode
+
xmlUnlockLibrary
xmlUnlockLibrary
+
xmlValidCtxtPtr
xmlValidityErrorFunc
+xmlValidityWarningFunc
+
xmlValidGetValidElements
xmlValidGetValidElements
+
xmlValidateAttributeDecl
xmlParseDefaultDecl
+
xmlValidateAttributeValue
xmlParseAttributeType
+
xmlValidateOneAttribute
xmlValidateOneElement
+
xmlWriter
LIBXML_WRITER_ENABLED
+
xmlXPathCheckError
xmlXPathPopBoolean
+xmlXPathPopExternal
+xmlXPathPopNodeSet
+xmlXPathPopNumber
+xmlXPathPopString
+
xmlXPathCompExprPtr
xmlXPathCompile
+xmlXPathCtxtCompile
+
xmlXPathContext
xmlXPathFreeContext
+xmlXPathNewContext
+xmlXPtrNewContext
+
xmlXPathError
err
+
xmlXPathEvalPredicate
xmlXPtrEvalRangePredicate
+
xmlXPathFreeObject
xmlXPathFreeNodeSetList
+
xmlXPathFunction
xmlXPathFunctionLookup
+xmlXPathFunctionLookupNS
+
xmlXPathNodeTrailingSorted
xmlXPathNodeTrailing
+
xmlXPathObjectPtr
xmlXPathCompiledEval
+xmlXPathEval
+xmlXPathEvalExpression
+xmlXPathFreeNodeSetList
+xmlXPathFreeObject
+xmlXPathNewBoolean
+xmlXPathNewCString
+xmlXPathNewFloat
+xmlXPathNewNodeSet
+xmlXPathNewNodeSetList
+xmlXPathNewString
+xmlXPathNewValueTree
+xmlXPathWrapNodeSet
+xmlXPtrEval
+xmlXPtrLocationSetAdd
+xmlXPtrLocationSetCreate
+xmlXPtrLocationSetDel
+xmlXPtrNewCollapsedRange
+xmlXPtrNewLocationSetNodeSet
+xmlXPtrNewLocationSetNodes
+xmlXPtrNewRange
+xmlXPtrNewRangeNodeObject
+xmlXPtrNewRangeNodePoint
+xmlXPtrNewRangeNodes
+xmlXPtrNewRangePointNode
+xmlXPtrNewRangePoints
+xmlXPtrWrapLocationSet
+
xmlXPathParserContext
xmlXPathFreeParserContext
+xmlXPathNewParserContext
+
xmlXPathTrailingSorted
xmlXPathTrailing
+
xmlns
xmlNamespaceParseNSDef
+
xmlns:???
xmlParseAttribute
+
xmltextReader
xmlReaderForDoc
+xmlReaderForFd
+xmlReaderForIO
+xmlReaderForMemory
+xmlReaderNewDoc
+xmlReaderNewFd
+xmlReaderNewIO
+xmlReaderNewMemory
+xmlReaderNewWalker
+xmlReaderWalker
+
xpath
xmlShellPrintXPathError
+xmlShellPrintXPathResult
+
xpointer
XINCLUDE_PARSE_XPOINTER

A-B C-C D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -106,7 +488,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk3.html b/doc/APIchunk3.html index ec5e00d0..0e811be7 100644 --- a/doc/APIchunk3.html +++ b/doc/APIchunk3.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter F:

FALSE
xmlTextWriterStartDTDEntity
xmlTextWriterWriteDTDEntity
xmlTextWriterWriteDTDExternalEntity
@@ -150,6 +151,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlXPathGetDocument
xmlXPathGetError
Gets
xmlTextReaderReadState
+
Gives
xmlSchemaGetBuiltInType
Global
_xmlDoc
Gothic
xmlUCSIsGothic
Greek
xmlUCSIsGreek
@@ -245,7 +247,6 @@ A:link, A:visited, A:active { text-decoration: underline } xmlIsLetter
IdeographicDescriptionCharacters
xmlUCSIsIdeographicDescriptionCharacters
Ignore
XML_SCHEMAS_ANYATTR_LAX
-XML_SCHEMAS_ANY_LAX
Ignored
xmlCopyChar
Implements
xmlShell
xmlShellBase
@@ -321,8 +322,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -340,7 +341,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk4.html b/doc/APIchunk4.html index bf7ffdc7..9fa9d433 100644 --- a/doc/APIchunk4.html +++ b/doc/APIchunk4.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter J:

Jan
_htmlElemDesc
Java
xmlCheckUTF8

Letter K:

Kanbun
xmlUCSIsKanbun
@@ -306,8 +307,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -325,7 +326,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk5.html b/doc/APIchunk5.html index b1b37a64..f8192d6d 100644 --- a/doc/APIchunk5.html +++ b/doc/APIchunk5.html @@ -7,13 +7,13 @@ H1 {font-family: Verdana,Arial,Helvetica} H2 {font-family: Verdana,Arial,Helvetica} H3 {font-family: Verdana,Arial,Helvetica} A:link, A:visited, A:active { text-decoration: underline } -API Alphabetic Index O-Q for libxml2
Action against software patentsGnome2 LogoW3C LogoRed Hat Logo
Made with Libxml2 Logo

The XML C parser and toolkit of Gnome

API Alphabetic Index O-Q for libxml2

Developer Menu
API Indexes
Related links

A-B +API Alphabetic Index O-P for libxml2
Action against software patentsGnome2 LogoW3C LogoRed Hat Logo
Made with Libxml2 Logo

The XML C parser and toolkit of Gnome

API Alphabetic Index O-P for libxml2

Developer Menu
API Indexes
Related links

A-B C-C D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter O:

OBSOLETE:
xmlHandleEntity
ONCE
_xmlElementContent
OPT
_xmlElementContent
@@ -42,6 +43,10 @@ A:link, A:visited, A:active { text-decoration: underline }
OUT:
htmlDocDumpMemory
xmlDocDumpFormatMemory
xmlDocDumpMemory
+
Obsolete
XML_SCHEMAS_ANYATTR_LAX
+XML_SCHEMAS_ANYATTR_SKIP
+XML_SCHEMAS_ANYATTR_STRICT
+XML_SCHEMAS_ELEM_NSDEFAULT
Obtain
xmlTextReaderLocatorBaseURI
xmlTextReaderLocatorLineNumber
Ogham
xmlUCSIsOgham
@@ -60,7 +65,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlOutputOpenCallback
xmlOutputWriteCallback
xmlURIUnescapeString
-
OutputBufferCreateFilenameFunc
xmlOutputBufferCreateFilenameDefault
+
OutputBufferCreateFilenameFunc
xmlOutputBufferCreateFilenameDefault
Override
xmlGcMemSetup
xmlMemSetup

Letter P:

P32
xmlValidCtxtNormalizeAttributeValue
@@ -121,12 +126,13 @@ A:link, A:visited, A:active { text-decoration: underline } xmlXPathEvalExpr
Parsed
xmlParseEntityRef
xmlParserHandleReference
-
ParserInputBufferCreateFilenameFunc
xmlParserInputBufferCreateFilenameDefault
+
ParserInputBufferCreateFilenameFunc
xmlParserInputBufferCreateFilenameDefault
Parses
xmlRegexpCompile
xmlTextReaderReadAttributeValue
Parsing
_xmlParserCtxt
xmlXPathErr
Part
xmlRegexpCompile
+xmlSchemaGetBuiltInListSimpleTypeItemType
Path
xmlGetNodePath
xmlXPathEval
xmlXPtrEval
@@ -230,31 +236,13 @@ A:link, A:visited, A:active { text-decoration: underline } xmlXPathReturnNumber
xmlXPathReturnString
xmlXPathReturnTrue
-

Letter Q:

QName
xmlBuildQName
-xmlDictQLookup
-xmlHashQLookup
-xmlNamespaceParseQName
-xmlParseAttribute
-xmlParseEndTag
-xmlParseStartTag
-xmlSplitQName
-xmlSplitQName2
-xmlSplitQName3
-xmlStrQEqual
-xmlValidateQName
-
QNames
xmlHashQLookup2
-
QUIT
xmlNanoFTPQuit
-
Qualified
xmlSplitQName3
-
Query
xmlDictSize
-xmlHashSize
-
Question:
xmlParseTextDecl

A-B C-C D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -272,7 +260,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk6.html b/doc/APIchunk6.html index 1c3baa39..5f9c69ff 100644 --- a/doc/APIchunk6.html +++ b/doc/APIchunk6.html @@ -7,13 +7,13 @@ H1 {font-family: Verdana,Arial,Helvetica} H2 {font-family: Verdana,Arial,Helvetica} H3 {font-family: Verdana,Arial,Helvetica} A:link, A:visited, A:active { text-decoration: underline } -API Alphabetic Index R-S for libxml2
Action against software patentsGnome2 LogoW3C LogoRed Hat Logo
Made with Libxml2 Logo

The XML C parser and toolkit of Gnome

API Alphabetic Index R-S for libxml2

Developer Menu
API Indexes
Related links

A-B +API Alphabetic Index Q-S for libxml2
Action against software patentsGnome2 LogoW3C LogoRed Hat Logo
Made with Libxml2 Logo

The XML C parser and toolkit of Gnome

API Alphabetic Index Q-S for libxml2

Developer Menu
API Indexes
Related links

A-B C-C D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,10 +31,29 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z -

Letter R:

REC
IS_BASECHAR
+u-v +w-w +x-x +y-z +

Letter Q:

QName
xmlBuildQName
+xmlDictQLookup
+xmlHashQLookup
+xmlNamespaceParseQName
+xmlParseAttribute
+xmlParseEndTag
+xmlParseStartTag
+xmlSplitQName
+xmlSplitQName2
+xmlSplitQName3
+xmlStrQEqual
+xmlValidateQName
+
QNames
xmlHashQLookup2
+
QUIT
xmlNanoFTPQuit
+
Qualified
xmlSplitQName3
+
Query
xmlDictSize
+xmlHashSize
+
Question:
xmlParseTextDecl
+

Letter R:

REC
IS_BASECHAR
IS_COMBINING
IS_DIGIT
REC-xml
xmlGetCharEncodingName
@@ -124,8 +143,8 @@ A:link, A:visited, A:active { text-decoration: underline }
RegisterNodeFunc
xmlRegisterNodeDefault
Registers
xmlAddEncodingAlias
xmlDeregisterNodeDefault
-xmlOutputBufferCreateFilenameDefault
-xmlParserInputBufferCreateFilenameDefault
+xmlOutputBufferCreateFilenameDefault
+xmlParserInputBufferCreateFilenameDefault
xmlRegisterDefaultInputCallbacks
xmlRegisterDefaultOutputCallbacks
xmlRegisterNodeDefault
@@ -169,6 +188,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlUnsetProp
Removes
xmlListPopBack
xmlListPopFront
+xmlSchemaCollapseString
xmlXPathNodeSetDel
xmlXPathNodeSetRemove
xmlXPtrLocationSetDel
@@ -274,6 +294,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSchemaFree
xmlSchemaFreeFacet
xmlSchemaFreeType
+xmlSchemaGetBuiltInListSimpleTypeItemType
xmlSchemaParse
Schemas
LIBXML_SCHEMAS_ENABLED
xmlRegexpCompile
@@ -463,8 +484,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -482,7 +503,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk7.html b/doc/APIchunk7.html index 2c47d30e..c755d1b6 100644 --- a/doc/APIchunk7.html +++ b/doc/APIchunk7.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter T:

TEXT
xmlAddChild
xmlAddChildList
xmlAddPrevSibling
@@ -233,7 +234,10 @@ A:link, A:visited, A:active { text-decoration: underline } xmlNewTextChild
xmlTextReaderRelaxNGSetSchema
xmlTextReaderRelaxNGValidate
-
Used
XML_SKIP_IDS
+
Used
XML_SCHEMAS_ANY_LAX
+XML_SCHEMAS_ANY_STRICT
+XML_SCHEMAS_ATTR_USE_PROHIBITED
+XML_SKIP_IDS
xmlCatalogGetDefaults
xmlCatalogSetDebug
xmlCatalogSetDefaults
@@ -251,8 +255,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -270,7 +274,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk8.html b/doc/APIchunk8.html index 0bb9b59d..61f5578a 100644 --- a/doc/APIchunk8.html +++ b/doc/APIchunk8.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,11 +31,13 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter V:

Valid
xmlValidateOneElement
-
Validate
xmlRelaxNGValidateDoc
+
Validate
XML_SCHEMAS_ANY_LAX
+xmlRelaxNGValidateDoc
xmlRelaxNGValidateFullElement
xmlSchemaValidateDoc
xmlSchemaValidateStream
@@ -239,6 +241,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlTextWriterWriteRawLen
above
xmlParseMarkupDecl
xmlXPathSubstringFunction
+
absent
XML_SCHEMAS_TYPE_VARIETY_ABSENT
absoluteURI
xmlParseURI
xmlParseURIReference
abstract
XML_SCHEMAS_ELEM_ABSTRACT
@@ -388,6 +391,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlRegexpCompile
xmlRegexpExec
xmlSchemaValidateFacet
+xmlSchemaValidateListSimpleTypeFacet
xmlShellValidate
xmlValidateDtd
aggregate
xmlNodeBufGetContent
@@ -403,8 +407,6 @@ A:link, A:visited, A:active { text-decoration: underline } xmlBuildQName
xmlMallocAtomicLoc
xmlMallocLoc
-xmlMemMalloc
-xmlMemRealloc
xmlNewMutex
xmlNewRMutex
xmlReallocLoc
@@ -413,10 +415,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlGetBufferAllocationScheme
xmlMallocAtomicLoc
xmlMallocLoc
-xmlMemMalloc
-xmlMemRealloc
xmlMemStrdupLoc
-xmlMemoryStrdup
xmlNormalizeURIPath
xmlReallocLoc
xmlSetBufferAllocationScheme
@@ -538,7 +537,11 @@ A:link, A:visited, A:active { text-decoration: underline } xmlInputMatchCallback
xmlOutputMatchCallback
xmlSetGenericErrorFunc
-
anymore
xmlNamespaceParseNCName
+
anymore
XML_SCHEMAS_ANYATTR_LAX
+XML_SCHEMAS_ANYATTR_SKIP
+XML_SCHEMAS_ANYATTR_STRICT
+XML_SCHEMAS_ELEM_NSDEFAULT
+xmlNamespaceParseNCName
xmlNamespaceParseNSDef
xmlNamespaceParseQName
anyway
xmlRecoverDoc
@@ -608,8 +611,6 @@ A:link, A:visited, A:active { text-decoration: underline }
area
xmlBufferCreateStatic
xmlMallocAtomicLoc
xmlMallocLoc
-xmlMemMalloc
-xmlMemRealloc
xmlParserInputBufferCreateMem
xmlParserInputBufferCreateStatic
xmlReallocLoc
@@ -665,8 +666,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -684,7 +685,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIchunk9.html b/doc/APIchunk9.html index bf83fcd5..477455da 100644 --- a/doc/APIchunk9.html +++ b/doc/APIchunk9.html @@ -12,8 +12,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -31,9 +31,10 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Letter b:

back
xmlEntityReferenceFunc
xmlKeepBlanksDefault
xmlNanoFTPGet
@@ -259,8 +260,11 @@ A:link, A:visited, A:active { text-decoration: underline } xmlRecoverFile
xmlRecoverMemory
xmlRelaxNGParse
+xmlSchemaGetBuiltInType
xmlSchemaParse
xmlTextReaderNextSibling
+
built-in
xmlSchemaGetBuiltInListSimpleTypeItemType
+xmlSchemaGetBuiltInType
builtin
initGenericErrorDefaultFunc
bunch
xmlParseNamespace
but
IS_DIGIT_CH
@@ -298,8 +302,8 @@ A:link, A:visited, A:active { text-decoration: underline } D-E F-I J-N -O-Q -R-S +O-P +Q-S T-U V-a b-b @@ -317,7 +321,8 @@ A:link, A:visited, A:active { text-decoration: underline } q-r s-s t-t -u-w -x-x -y-z +u-v +w-w +x-x +y-z

Daniel Veillard

diff --git a/doc/APIconstructors.html b/doc/APIconstructors.html index 457877b3..08e4f336 100644 --- a/doc/APIconstructors.html +++ b/doc/APIconstructors.html @@ -199,6 +199,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlParseVersionNum
xmlSaveUri
xmlScanName
+xmlSchemaCollapseString
xmlSplitQName
xmlSplitQName2
xmlStrcat
@@ -401,13 +402,13 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSearchNs
xmlSearchNsByHref

Type xmlNsPtr *:

xmlGetNsList
-

Type xmlOutputBufferCreateFilenameFunc:

xmlOutputBufferCreateFilenameDefault
+

Type xmlOutputBufferCreateFilenameFunc:

xmlOutputBufferCreateFilenameDefault
xmlThrDefOutputBufferCreateFilenameDefault

Type xmlOutputBufferPtr:

xmlAllocOutputBuffer
xmlOutputBufferCreateFd
xmlOutputBufferCreateFile
xmlOutputBufferCreateFilename
-xmlOutputBufferCreateFilenameFunc
+xmlOutputBufferCreateFilenameFunc
xmlOutputBufferCreateIO

Type xmlParserCtxtPtr:

xmlCreateDocParserCtxt
xmlCreateEntityParserCtxt
@@ -417,13 +418,13 @@ A:link, A:visited, A:active { text-decoration: underline } xmlCreatePushParserCtxt
xmlCreateURLParserCtxt
xmlNewParserCtxt
-

Type xmlParserInputBufferCreateFilenameFunc:

xmlParserInputBufferCreateFilenameDefault
+

Type xmlParserInputBufferCreateFilenameFunc:

xmlParserInputBufferCreateFilenameDefault
xmlThrDefParserInputBufferCreateFilenameDefault

Type xmlParserInputBufferPtr:

xmlAllocParserInputBuffer
xmlParserInputBufferCreateFd
xmlParserInputBufferCreateFile
xmlParserInputBufferCreateFilename
-xmlParserInputBufferCreateFilenameFunc
+xmlParserInputBufferCreateFilenameFunc
xmlParserInputBufferCreateIO
xmlParserInputBufferCreateMem
xmlParserInputBufferCreateStatic
@@ -462,7 +463,9 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSchemaNewMemParserCtxt
xmlSchemaNewParserCtxt

Type xmlSchemaPtr:

xmlSchemaParse
-

Type xmlSchemaTypePtr:

xmlSchemaGetPredefinedType
+

Type xmlSchemaTypePtr:

xmlSchemaGetBuiltInListSimpleTypeItemType
+xmlSchemaGetBuiltInType
+xmlSchemaGetPredefinedType

Type xmlSchemaValidCtxtPtr:

xmlSchemaNewValidCtxt

Type xmlTextReaderPtr:

xmlNewTextReader
xmlNewTextReaderFilename
diff --git a/doc/APIfiles.html b/doc/APIfiles.html index a9d019ad..3ca8ab38 100644 --- a/doc/APIfiles.html +++ b/doc/APIfiles.html @@ -427,8 +427,12 @@ A:link, A:visited, A:active { text-decoration: underline } xmlMalloc
xmlMallocAtomic
xmlMemStrdup
+xmlOutputBufferCreateFilenameDefault
+xmlOutputBufferCreateFilenameFunc
xmlOutputBufferCreateFilenameValue
xmlParserDebugEntities
+xmlParserInputBufferCreateFilenameDefault
+xmlParserInputBufferCreateFilenameFunc
xmlParserInputBufferCreateFilenameValue
xmlParserVersion
xmlPedanticParserDefaultValue
@@ -925,6 +929,9 @@ A:link, A:visited, A:active { text-decoration: underline }

Module schemasInternals:

XML_SCHEMAS_ANYATTR_LAX
XML_SCHEMAS_ANYATTR_SKIP
XML_SCHEMAS_ANYATTR_STRICT
+XML_SCHEMAS_ANYSIMPLETYPE
+XML_SCHEMAS_ANYTYPE
+XML_SCHEMAS_ANYURI
XML_SCHEMAS_ANY_LAX
XML_SCHEMAS_ANY_SKIP
XML_SCHEMAS_ANY_STRICT
@@ -935,6 +942,14 @@ A:link, A:visited, A:active { text-decoration: underline } XML_SCHEMAS_ATTR_USE_OPTIONAL
XML_SCHEMAS_ATTR_USE_PROHIBITED
XML_SCHEMAS_ATTR_USE_REQUIRED
+XML_SCHEMAS_BASE64BINARY
+XML_SCHEMAS_BOOLEAN
+XML_SCHEMAS_BYTE
+XML_SCHEMAS_DATE
+XML_SCHEMAS_DATETIME
+XML_SCHEMAS_DECIMAL
+XML_SCHEMAS_DOUBLE
+XML_SCHEMAS_DURATION
XML_SCHEMAS_ELEM_ABSTRACT
XML_SCHEMAS_ELEM_DEFAULT
XML_SCHEMAS_ELEM_FIXED
@@ -943,17 +958,67 @@ A:link, A:visited, A:active { text-decoration: underline } XML_SCHEMAS_ELEM_NSDEFAULT
XML_SCHEMAS_ELEM_REF
XML_SCHEMAS_ELEM_TOPLEVEL
+XML_SCHEMAS_ENTITIES
+XML_SCHEMAS_ENTITY
XML_SCHEMAS_FACET_COLLAPSE
XML_SCHEMAS_FACET_PRESERVE
XML_SCHEMAS_FACET_REPLACE
XML_SCHEMAS_FACET_UNKNOWN
+XML_SCHEMAS_FINAL_DEFAULT_EXTENSION
+XML_SCHEMAS_FINAL_DEFAULT_LIST
+XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION
+XML_SCHEMAS_FINAL_DEFAULT_UNION
+XML_SCHEMAS_FLOAT
+XML_SCHEMAS_GDAY
+XML_SCHEMAS_GMONTH
+XML_SCHEMAS_GMONTHDAY
+XML_SCHEMAS_GYEAR
+XML_SCHEMAS_GYEARMONTH
+XML_SCHEMAS_HEXBINARY
+XML_SCHEMAS_ID
+XML_SCHEMAS_IDREF
+XML_SCHEMAS_IDREFS
+XML_SCHEMAS_INT
+XML_SCHEMAS_INTEGER
+XML_SCHEMAS_LANGUAGE
+XML_SCHEMAS_LONG
+XML_SCHEMAS_NAME
+XML_SCHEMAS_NCNAME
+XML_SCHEMAS_NINTEGER
+XML_SCHEMAS_NMTOKEN
+XML_SCHEMAS_NMTOKENS
+XML_SCHEMAS_NNINTEGER
+XML_SCHEMAS_NORMSTRING
+XML_SCHEMAS_NOTATION
+XML_SCHEMAS_NPINTEGER
+XML_SCHEMAS_PINTEGER
+XML_SCHEMAS_QNAME
XML_SCHEMAS_QUALIF_ATTR
XML_SCHEMAS_QUALIF_ELEM
+XML_SCHEMAS_SHORT
+XML_SCHEMAS_STRING
+XML_SCHEMAS_TIME
+XML_SCHEMAS_TOKEN
+XML_SCHEMAS_TYPE_BUILTIN_PRIMITIVE
XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION
XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION
+XML_SCHEMAS_TYPE_FINAL_DEFAULT
+XML_SCHEMAS_TYPE_FINAL_EXTENSION
+XML_SCHEMAS_TYPE_FINAL_LIST
+XML_SCHEMAS_TYPE_FINAL_RESTRICTION
+XML_SCHEMAS_TYPE_FINAL_UNION
XML_SCHEMAS_TYPE_GLOBAL
XML_SCHEMAS_TYPE_MIXED
XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD
+XML_SCHEMAS_TYPE_VARIETY_ABSENT
+XML_SCHEMAS_TYPE_VARIETY_ATOMIC
+XML_SCHEMAS_TYPE_VARIETY_LIST
+XML_SCHEMAS_TYPE_VARIETY_UNION
+XML_SCHEMAS_UBYTE
+XML_SCHEMAS_UINT
+XML_SCHEMAS_ULONG
+XML_SCHEMAS_UNKNOWN
+XML_SCHEMAS_USHORT
XML_SCHEMAS_WILDCARD_COMPLETE
XML_SCHEMA_CONTENT_ANY
XML_SCHEMA_CONTENT_BASIC
@@ -1003,8 +1068,10 @@ A:link, A:visited, A:active { text-decoration: underline } _xmlSchemaAttributeLink
_xmlSchemaElement
_xmlSchemaFacet
+_xmlSchemaFacetLink
_xmlSchemaNotation
_xmlSchemaType
+_xmlSchemaTypeLink
_xmlSchemaWildcard
_xmlSchemaWildcardNs
xmlSchemaAnnot
@@ -1019,15 +1086,21 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSchemaElement
xmlSchemaElementPtr
xmlSchemaFacet
+xmlSchemaFacetLink
+xmlSchemaFacetLinkPtr
xmlSchemaFacetPtr
xmlSchemaFreeType
+xmlSchemaFreeWildcard
xmlSchemaNotation
xmlSchemaNotationPtr
xmlSchemaType
+xmlSchemaTypeLink
+xmlSchemaTypeLinkPtr
xmlSchemaTypePtr
xmlSchemaTypeType
xmlSchemaVal
xmlSchemaValPtr
+xmlSchemaValType
xmlSchemaWildcard
xmlSchemaWildcardNs
xmlSchemaWildcardNsPtr
@@ -1496,8 +1569,6 @@ A:link, A:visited, A:active { text-decoration: underline } xmlOutputBufferCreateFd
xmlOutputBufferCreateFile
xmlOutputBufferCreateFilename
-xmlOutputBufferCreateFilenameDefault
-xmlOutputBufferCreateFilenameFunc
xmlOutputBufferCreateIO
xmlOutputBufferFlush
xmlOutputBufferWrite
@@ -1511,8 +1582,6 @@ A:link, A:visited, A:active { text-decoration: underline } xmlParserInputBufferCreateFd
xmlParserInputBufferCreateFile
xmlParserInputBufferCreateFilename
-xmlParserInputBufferCreateFilenameDefault
-xmlParserInputBufferCreateFilenameFunc
xmlParserInputBufferCreateIO
xmlParserInputBufferCreateMem
xmlParserInputBufferCreateStatic
@@ -1921,6 +1990,28 @@ A:link, A:visited, A:active { text-decoration: underline } XML_SCHEMAP_ATTR_NONAME_NOREF
XML_SCHEMAP_COMPLEXTYPE_NONAME_NOREF
XML_SCHEMAP_COS_CT_EXTENDS_1_3
+XML_SCHEMAP_COS_ST_DERIVED_OK_2_1
+XML_SCHEMAP_COS_ST_DERIVED_OK_2_2
+XML_SCHEMAP_COS_ST_RESTRICTS_1_1
+XML_SCHEMAP_COS_ST_RESTRICTS_1_2
+XML_SCHEMAP_COS_ST_RESTRICTS_1_3_1
+XML_SCHEMAP_COS_ST_RESTRICTS_1_3_2
+XML_SCHEMAP_COS_ST_RESTRICTS_2_1
+XML_SCHEMAP_COS_ST_RESTRICTS_2_3_1_1
+XML_SCHEMAP_COS_ST_RESTRICTS_2_3_1_2
+XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_1
+XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_2
+XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_3
+XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_4
+XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_5
+XML_SCHEMAP_COS_ST_RESTRICTS_3_1
+XML_SCHEMAP_COS_ST_RESTRICTS_3_3_1
+XML_SCHEMAP_COS_ST_RESTRICTS_3_3_1_2
+XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_1
+XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_2
+XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_3
+XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_4
+XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_5
XML_SCHEMAP_CT_PROPS_CORRECT_1
XML_SCHEMAP_CT_PROPS_CORRECT_2
XML_SCHEMAP_CT_PROPS_CORRECT_3
@@ -1981,9 +2072,24 @@ A:link, A:visited, A:active { text-decoration: underline } XML_SCHEMAP_REF_AND_SUBTYPE
XML_SCHEMAP_REGEXP_INVALID
XML_SCHEMAP_RESTRICTION_NONAME_NOREF
+XML_SCHEMAP_S4S_ATTR_MISSING
+XML_SCHEMAP_S4S_ATTR_NOT_ALLOWED
+XML_SCHEMAP_S4S_ELEM_MISSING
+XML_SCHEMAP_S4S_ELEM_NOT_ALLOWED
XML_SCHEMAP_SIMPLETYPE_NONAME
XML_SCHEMAP_SRC_IMPORT_3_1
XML_SCHEMAP_SRC_IMPORT_3_2
+XML_SCHEMAP_SRC_LIST_ITEMTYPE_OR_SIMPLETYPE
+XML_SCHEMAP_SRC_RESOLVE
+XML_SCHEMAP_SRC_RESTRICTION_BASE_OR_SIMPLETYPE
+XML_SCHEMAP_SRC_SIMPLE_TYPE_1
+XML_SCHEMAP_SRC_SIMPLE_TYPE_2
+XML_SCHEMAP_SRC_SIMPLE_TYPE_3
+XML_SCHEMAP_SRC_SIMPLE_TYPE_4
+XML_SCHEMAP_SRC_UNION_MEMBERTYPES_OR_SIMPLETYPES
+XML_SCHEMAP_ST_PROPS_CORRECT_1
+XML_SCHEMAP_ST_PROPS_CORRECT_2
+XML_SCHEMAP_ST_PROPS_CORRECT_3
XML_SCHEMAP_SUPERNUMEROUS_LIST_ITEM_TYPE
XML_SCHEMAP_TYPE_AND_SUBTYPE
XML_SCHEMAP_UNION_NOT_EXPRESSIBLE
@@ -2020,6 +2126,27 @@ A:link, A:visited, A:active { text-decoration: underline } XML_SCHEMAV_ATTRINVALID
XML_SCHEMAV_ATTRUNKNOWN
XML_SCHEMAV_CONSTRUCT
+XML_SCHEMAV_CVC_COMPLEX_TYPE_2_1
+XML_SCHEMAV_CVC_COMPLEX_TYPE_2_2
+XML_SCHEMAV_CVC_COMPLEX_TYPE_2_3
+XML_SCHEMAV_CVC_COMPLEX_TYPE_2_4
+XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_1
+XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_2
+XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_3
+XML_SCHEMAV_CVC_ENUMERATION_VALID
+XML_SCHEMAV_CVC_FACET_VALID
+XML_SCHEMAV_CVC_FRACTIONDIGITS_VALID
+XML_SCHEMAV_CVC_LENGTH_VALID
+XML_SCHEMAV_CVC_MAXEXCLUSIVE_VALID
+XML_SCHEMAV_CVC_MAXINCLUSIVE_VALID
+XML_SCHEMAV_CVC_MAXLENGTH_VALID
+XML_SCHEMAV_CVC_MINEXCLUSIVE_VALID
+XML_SCHEMAV_CVC_MININCLUSIVE_VALID
+XML_SCHEMAV_CVC_MINLENGTH_VALID
+XML_SCHEMAV_CVC_PATTERN_VALID
+XML_SCHEMAV_CVC_TOTALDIGITS_VALID
+XML_SCHEMAV_CVC_TYPE_3_1_1
+XML_SCHEMAV_CVC_TYPE_3_1_2
XML_SCHEMAV_ELEMCONT
XML_SCHEMAV_EXTRACONTENT
XML_SCHEMAV_FACET
@@ -2338,14 +2465,19 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSchemaValidityWarningFunc

Module xmlschemastypes:

xmlSchemaCheckFacet
xmlSchemaCleanupTypes
+xmlSchemaCollapseString
xmlSchemaCompareValues
xmlSchemaFreeFacet
xmlSchemaFreeValue
+xmlSchemaGetBuiltInListSimpleTypeItemType
+xmlSchemaGetBuiltInType
xmlSchemaGetPredefinedType
xmlSchemaInitTypes
+xmlSchemaIsBuiltInTypeFacet
xmlSchemaNewFacet
xmlSchemaValPredefTypeNode
xmlSchemaValidateFacet
+xmlSchemaValidateListSimpleTypeFacet
xmlSchemaValidatePredefinedType

Module xmlstring:

BAD_CAST
xmlChar
diff --git a/doc/APIfunctions.html b/doc/APIfunctions.html index 41ee6758..fb9a9233 100644 --- a/doc/APIfunctions.html +++ b/doc/APIfunctions.html @@ -324,9 +324,11 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSAX2UnparsedEntityDecl
xmlSAXParseDTD
xmlSchemaCheckFacet
+xmlSchemaCollapseString
xmlSchemaGetPredefinedType
xmlSchemaValPredefTypeNode
xmlSchemaValidateFacet
+xmlSchemaValidateListSimpleTypeFacet
xmlSchemaValidatePredefinedType
xmlSearchNs
xmlSearchNsByHref
@@ -570,6 +572,8 @@ A:link, A:visited, A:active { text-decoration: underline } xmlIsIdeographic
xmlIsPubidChar

Type unsigned long:

ftpListCallback
+xmlSchemaValidateListSimpleTypeFacet
+

Type unsigned long *:

xmlSchemaValidateListSimpleTypeFacet

Type va_list:

xmlStrVPrintf
xmlTextWriterWriteVFormatAttribute
xmlTextWriterWriteVFormatAttributeNS
@@ -975,7 +979,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlParserInputBufferCreateFd
xmlParserInputBufferCreateFile
xmlParserInputBufferCreateFilename
-xmlParserInputBufferCreateFilenameFunc
+xmlParserInputBufferCreateFilenameFunc
xmlParserInputBufferCreateIO
xmlParserInputBufferCreateMem
xmlParserInputBufferCreateStatic
@@ -989,7 +993,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlOutputBufferCreateFd
xmlOutputBufferCreateFile
xmlOutputBufferCreateFilename
-xmlOutputBufferCreateFilenameFunc
+xmlOutputBufferCreateFilenameFunc
xmlOutputBufferCreateIO
xmlRegisterCharEncodingHandler
xmlSwitchInputEncoding
@@ -1496,7 +1500,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlValidateOneNamespace
xmlXPathNodeSetAddNs
xmlXPathNodeSetFreeNs
-

Type xmlOutputBufferCreateFilenameFunc:

xmlOutputBufferCreateFilenameDefault
+

Type xmlOutputBufferCreateFilenameFunc:

xmlOutputBufferCreateFilenameDefault
xmlThrDefOutputBufferCreateFilenameDefault

Type xmlOutputBufferPtr:

htmlDocContentDumpFormatOutput
htmlDocContentDumpOutput
@@ -1625,7 +1629,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSwitchEncoding
xmlSwitchInputEncoding
xmlSwitchToEncoding
-

Type xmlParserInputBufferCreateFilenameFunc:

xmlParserInputBufferCreateFilenameDefault
+

Type xmlParserInputBufferCreateFilenameFunc:

xmlParserInputBufferCreateFilenameDefault
xmlThrDefParserInputBufferCreateFilenameDefault

Type xmlParserInputBufferPtr:

xmlFreeParserInputBuffer
xmlIOParseDTD
@@ -1732,6 +1736,7 @@ A:link, A:visited, A:active { text-decoration: underline }

Type xmlSchemaFacetPtr:

xmlSchemaCheckFacet
xmlSchemaFreeFacet
xmlSchemaValidateFacet
+xmlSchemaValidateListSimpleTypeFacet

Type xmlSchemaParserCtxtPtr:

xmlSchemaCheckFacet
xmlSchemaFreeParserCtxt
xmlSchemaParse
@@ -1741,6 +1746,8 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSchemaNewValidCtxt

Type xmlSchemaTypePtr:

xmlSchemaCheckFacet
xmlSchemaFreeType
+xmlSchemaGetBuiltInListSimpleTypeItemType
+xmlSchemaIsBuiltInTypeFacet
xmlSchemaValPredefTypeNode
xmlSchemaValidateFacet
xmlSchemaValidatePredefinedType
@@ -1749,6 +1756,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSchemaValidateFacet

Type xmlSchemaValPtr *:

xmlSchemaValPredefTypeNode
xmlSchemaValidatePredefinedType
+

Type xmlSchemaValType:

xmlSchemaGetBuiltInType

Type xmlSchemaValidCtxtPtr:

xmlSchemaFreeValidCtxt
xmlSchemaSetValidErrors
xmlSchemaValidateDoc
@@ -1757,6 +1765,7 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSchemaSetValidErrors

Type xmlSchemaValidityWarningFunc:

xmlSchemaSetParserErrors
xmlSchemaSetValidErrors
+

Type xmlSchemaWildcardPtr:

xmlSchemaFreeWildcard

Type xmlShellCtxtPtr:

xmlShellBase
xmlShellCat
xmlShellCmd
diff --git a/doc/APIsymbols.html b/doc/APIsymbols.html index ac9d444e..5a90de56 100644 --- a/doc/APIsymbols.html +++ b/doc/APIsymbols.html @@ -694,6 +694,28 @@ A:link, A:visited, A:active { text-decoration: underline } XML_SCHEMAP_ATTR_NONAME_NOREF
XML_SCHEMAP_COMPLEXTYPE_NONAME_NOREF
XML_SCHEMAP_COS_CT_EXTENDS_1_3
+XML_SCHEMAP_COS_ST_DERIVED_OK_2_1
+XML_SCHEMAP_COS_ST_DERIVED_OK_2_2
+XML_SCHEMAP_COS_ST_RESTRICTS_1_1
+XML_SCHEMAP_COS_ST_RESTRICTS_1_2
+XML_SCHEMAP_COS_ST_RESTRICTS_1_3_1
+XML_SCHEMAP_COS_ST_RESTRICTS_1_3_2
+XML_SCHEMAP_COS_ST_RESTRICTS_2_1
+XML_SCHEMAP_COS_ST_RESTRICTS_2_3_1_1
+XML_SCHEMAP_COS_ST_RESTRICTS_2_3_1_2
+XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_1
+XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_2
+XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_3
+XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_4
+XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_5
+XML_SCHEMAP_COS_ST_RESTRICTS_3_1
+XML_SCHEMAP_COS_ST_RESTRICTS_3_3_1
+XML_SCHEMAP_COS_ST_RESTRICTS_3_3_1_2
+XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_1
+XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_2
+XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_3
+XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_4
+XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_5
XML_SCHEMAP_CT_PROPS_CORRECT_1
XML_SCHEMAP_CT_PROPS_CORRECT_2
XML_SCHEMAP_CT_PROPS_CORRECT_3
@@ -754,9 +776,24 @@ A:link, A:visited, A:active { text-decoration: underline } XML_SCHEMAP_REF_AND_SUBTYPE
XML_SCHEMAP_REGEXP_INVALID
XML_SCHEMAP_RESTRICTION_NONAME_NOREF
+XML_SCHEMAP_S4S_ATTR_MISSING
+XML_SCHEMAP_S4S_ATTR_NOT_ALLOWED
+XML_SCHEMAP_S4S_ELEM_MISSING
+XML_SCHEMAP_S4S_ELEM_NOT_ALLOWED
XML_SCHEMAP_SIMPLETYPE_NONAME
XML_SCHEMAP_SRC_IMPORT_3_1
XML_SCHEMAP_SRC_IMPORT_3_2
+XML_SCHEMAP_SRC_LIST_ITEMTYPE_OR_SIMPLETYPE
+XML_SCHEMAP_SRC_RESOLVE
+XML_SCHEMAP_SRC_RESTRICTION_BASE_OR_SIMPLETYPE
+XML_SCHEMAP_SRC_SIMPLE_TYPE_1
+XML_SCHEMAP_SRC_SIMPLE_TYPE_2
+XML_SCHEMAP_SRC_SIMPLE_TYPE_3
+XML_SCHEMAP_SRC_SIMPLE_TYPE_4
+XML_SCHEMAP_SRC_UNION_MEMBERTYPES_OR_SIMPLETYPES
+XML_SCHEMAP_ST_PROPS_CORRECT_1
+XML_SCHEMAP_ST_PROPS_CORRECT_2
+XML_SCHEMAP_ST_PROPS_CORRECT_3
XML_SCHEMAP_SUPERNUMEROUS_LIST_ITEM_TYPE
XML_SCHEMAP_TYPE_AND_SUBTYPE
XML_SCHEMAP_UNION_NOT_EXPRESSIBLE
@@ -793,6 +830,9 @@ A:link, A:visited, A:active { text-decoration: underline } XML_SCHEMAS_ANYATTR_LAX
XML_SCHEMAS_ANYATTR_SKIP
XML_SCHEMAS_ANYATTR_STRICT
+XML_SCHEMAS_ANYSIMPLETYPE
+XML_SCHEMAS_ANYTYPE
+XML_SCHEMAS_ANYURI
XML_SCHEMAS_ANY_LAX
XML_SCHEMAS_ANY_SKIP
XML_SCHEMAS_ANY_STRICT
@@ -803,6 +843,14 @@ A:link, A:visited, A:active { text-decoration: underline } XML_SCHEMAS_ATTR_USE_OPTIONAL
XML_SCHEMAS_ATTR_USE_PROHIBITED
XML_SCHEMAS_ATTR_USE_REQUIRED
+XML_SCHEMAS_BASE64BINARY
+XML_SCHEMAS_BOOLEAN
+XML_SCHEMAS_BYTE
+XML_SCHEMAS_DATE
+XML_SCHEMAS_DATETIME
+XML_SCHEMAS_DECIMAL
+XML_SCHEMAS_DOUBLE
+XML_SCHEMAS_DURATION
XML_SCHEMAS_ELEM_ABSTRACT
XML_SCHEMAS_ELEM_DEFAULT
XML_SCHEMAS_ELEM_FIXED
@@ -811,6 +859,8 @@ A:link, A:visited, A:active { text-decoration: underline } XML_SCHEMAS_ELEM_NSDEFAULT
XML_SCHEMAS_ELEM_REF
XML_SCHEMAS_ELEM_TOPLEVEL
+XML_SCHEMAS_ENTITIES
+XML_SCHEMAS_ENTITY
XML_SCHEMAS_ERR_
XML_SCHEMAS_ERR_ATTRINVALID
XML_SCHEMAS_ERR_ATTRUNKNOWN
@@ -841,17 +891,86 @@ A:link, A:visited, A:active { text-decoration: underline } XML_SCHEMAS_FACET_PRESERVE
XML_SCHEMAS_FACET_REPLACE
XML_SCHEMAS_FACET_UNKNOWN
+XML_SCHEMAS_FINAL_DEFAULT_EXTENSION
+XML_SCHEMAS_FINAL_DEFAULT_LIST
+XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION
+XML_SCHEMAS_FINAL_DEFAULT_UNION
+XML_SCHEMAS_FLOAT
+XML_SCHEMAS_GDAY
+XML_SCHEMAS_GMONTH
+XML_SCHEMAS_GMONTHDAY
+XML_SCHEMAS_GYEAR
+XML_SCHEMAS_GYEARMONTH
+XML_SCHEMAS_HEXBINARY
+XML_SCHEMAS_ID
+XML_SCHEMAS_IDREF
+XML_SCHEMAS_IDREFS
+XML_SCHEMAS_INT
+XML_SCHEMAS_INTEGER
+XML_SCHEMAS_LANGUAGE
+XML_SCHEMAS_LONG
+XML_SCHEMAS_NAME
+XML_SCHEMAS_NCNAME
+XML_SCHEMAS_NINTEGER
+XML_SCHEMAS_NMTOKEN
+XML_SCHEMAS_NMTOKENS
+XML_SCHEMAS_NNINTEGER
+XML_SCHEMAS_NORMSTRING
+XML_SCHEMAS_NOTATION
+XML_SCHEMAS_NPINTEGER
+XML_SCHEMAS_PINTEGER
+XML_SCHEMAS_QNAME
XML_SCHEMAS_QUALIF_ATTR
XML_SCHEMAS_QUALIF_ELEM
+XML_SCHEMAS_SHORT
+XML_SCHEMAS_STRING
+XML_SCHEMAS_TIME
+XML_SCHEMAS_TOKEN
+XML_SCHEMAS_TYPE_BUILTIN_PRIMITIVE
XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION
XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION
+XML_SCHEMAS_TYPE_FINAL_DEFAULT
+XML_SCHEMAS_TYPE_FINAL_EXTENSION
+XML_SCHEMAS_TYPE_FINAL_LIST
+XML_SCHEMAS_TYPE_FINAL_RESTRICTION
+XML_SCHEMAS_TYPE_FINAL_UNION
XML_SCHEMAS_TYPE_GLOBAL
XML_SCHEMAS_TYPE_MIXED
XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD
+XML_SCHEMAS_TYPE_VARIETY_ABSENT
+XML_SCHEMAS_TYPE_VARIETY_ATOMIC
+XML_SCHEMAS_TYPE_VARIETY_LIST
+XML_SCHEMAS_TYPE_VARIETY_UNION
+XML_SCHEMAS_UBYTE
+XML_SCHEMAS_UINT
+XML_SCHEMAS_ULONG
+XML_SCHEMAS_UNKNOWN
+XML_SCHEMAS_USHORT
XML_SCHEMAS_WILDCARD_COMPLETE
XML_SCHEMAV_ATTRINVALID
XML_SCHEMAV_ATTRUNKNOWN
XML_SCHEMAV_CONSTRUCT
+XML_SCHEMAV_CVC_COMPLEX_TYPE_2_1
+XML_SCHEMAV_CVC_COMPLEX_TYPE_2_2
+XML_SCHEMAV_CVC_COMPLEX_TYPE_2_3
+XML_SCHEMAV_CVC_COMPLEX_TYPE_2_4
+XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_1
+XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_2
+XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_3
+XML_SCHEMAV_CVC_ENUMERATION_VALID
+XML_SCHEMAV_CVC_FACET_VALID
+XML_SCHEMAV_CVC_FRACTIONDIGITS_VALID
+XML_SCHEMAV_CVC_LENGTH_VALID
+XML_SCHEMAV_CVC_MAXEXCLUSIVE_VALID
+XML_SCHEMAV_CVC_MAXINCLUSIVE_VALID
+XML_SCHEMAV_CVC_MAXLENGTH_VALID
+XML_SCHEMAV_CVC_MINEXCLUSIVE_VALID
+XML_SCHEMAV_CVC_MININCLUSIVE_VALID
+XML_SCHEMAV_CVC_MINLENGTH_VALID
+XML_SCHEMAV_CVC_PATTERN_VALID
+XML_SCHEMAV_CVC_TOTALDIGITS_VALID
+XML_SCHEMAV_CVC_TYPE_3_1_1
+XML_SCHEMAV_CVC_TYPE_3_1_2
XML_SCHEMAV_ELEMCONT
XML_SCHEMAV_EXTRACONTENT
XML_SCHEMAV_FACET
@@ -1059,8 +1178,10 @@ A:link, A:visited, A:active { text-decoration: underline } _xmlSchemaAttributeLink
_xmlSchemaElement
_xmlSchemaFacet
+_xmlSchemaFacetLink
_xmlSchemaNotation
_xmlSchemaType
+_xmlSchemaTypeLink
_xmlSchemaWildcard
_xmlSchemaWildcardNs
_xmlShellCtxt
@@ -1896,8 +2017,8 @@ A:link, A:visited, A:active { text-decoration: underline } xmlOutputBufferCreateFd
xmlOutputBufferCreateFile
xmlOutputBufferCreateFilename
-xmlOutputBufferCreateFilenameDefault
-xmlOutputBufferCreateFilenameFunc
+xmlOutputBufferCreateFilenameDefault
+xmlOutputBufferCreateFilenameFunc
xmlOutputBufferCreateFilenameValue
xmlOutputBufferCreateIO
xmlOutputBufferFlush
@@ -1987,8 +2108,8 @@ A:link, A:visited, A:active { text-decoration: underline } xmlParserInputBufferCreateFd
xmlParserInputBufferCreateFile
xmlParserInputBufferCreateFilename
-xmlParserInputBufferCreateFilenameDefault
-xmlParserInputBufferCreateFilenameFunc
+xmlParserInputBufferCreateFilenameDefault
+xmlParserInputBufferCreateFilenameFunc
xmlParserInputBufferCreateFilenameValue
xmlParserInputBufferCreateIO
xmlParserInputBufferCreateMem
@@ -2203,12 +2324,15 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSchemaAttributePtr
xmlSchemaCheckFacet
xmlSchemaCleanupTypes
+xmlSchemaCollapseString
xmlSchemaCompareValues
xmlSchemaContentType
xmlSchemaDump
xmlSchemaElement
xmlSchemaElementPtr
xmlSchemaFacet
+xmlSchemaFacetLink
+xmlSchemaFacetLinkPtr
xmlSchemaFacetPtr
xmlSchemaFree
xmlSchemaFreeFacet
@@ -2216,8 +2340,12 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSchemaFreeType
xmlSchemaFreeValidCtxt
xmlSchemaFreeValue
+xmlSchemaFreeWildcard
+xmlSchemaGetBuiltInListSimpleTypeItemType
+xmlSchemaGetBuiltInType
xmlSchemaGetPredefinedType
xmlSchemaInitTypes
+xmlSchemaIsBuiltInTypeFacet
xmlSchemaNewDocParserCtxt
xmlSchemaNewFacet
xmlSchemaNewMemParserCtxt
@@ -2232,16 +2360,20 @@ A:link, A:visited, A:active { text-decoration: underline } xmlSchemaSetParserErrors
xmlSchemaSetValidErrors
xmlSchemaType
+xmlSchemaTypeLink
+xmlSchemaTypeLinkPtr
xmlSchemaTypePtr
xmlSchemaTypeType
xmlSchemaVal
xmlSchemaValPredefTypeNode
xmlSchemaValPtr
+xmlSchemaValType
xmlSchemaValidCtxt
xmlSchemaValidCtxtPtr
xmlSchemaValidError
xmlSchemaValidateDoc
xmlSchemaValidateFacet
+xmlSchemaValidateListSimpleTypeFacet
xmlSchemaValidatePredefinedType
xmlSchemaValidateStream
xmlSchemaValidityErrorFunc
diff --git a/doc/Makefile.am b/doc/Makefile.am index f56c249c..adb32253 100644 --- a/doc/Makefile.am +++ b/doc/Makefile.am @@ -37,6 +37,7 @@ web: $(PAGES) echo "Rebuilding the elfgcchack.h header" ; \ $(bindir)/xsltproc --nonet $(srcdir)/elfgcchack.xsl $(srcdir)/libxml2-api.xml > elfgcchack.h ; \ if [ "`diff -q elfgcchack.h ../elfgcchack.h`" ] ; then \ + echo "updating ../elfgcchack.h"; \ cp elfgcchack.h ../elfgcchack.h; \ fi ; rm -f elfgcchack.h ; fi ); diff --git a/doc/html/libxml-globals.html b/doc/html/libxml-globals.html index 15f32b32..e5daec85 100644 --- a/doc/html/libxml-globals.html +++ b/doc/html/libxml-globals.html @@ -19,6 +19,14 @@ void xmlDeregisterNodeFunc (void xmlInitGlobals (void)

void	xmlInitializeGlobalState	(xmlGlobalStatePtr gs)
+
xmlOutputBufferCreateFilenameFunc	xmlOutputBufferCreateFilenameDefault	(xmlOutputBufferCreateFilenameFunc func)
+
Function type: xmlOutputBufferCreateFilenameFunc
+xmlOutputBufferPtr	xmlOutputBufferCreateFilenameFunc	(const char * URI, 
xmlCharEncodingHandlerPtr encoder,
int compression) +
+
xmlParserInputBufferCreateFilenameFunc	xmlParserInputBufferCreateFilenameDefault	(xmlParserInputBufferCreateFilenameFunc func)
+
Function type: xmlParserInputBufferCreateFilenameFunc
+xmlParserInputBufferPtr	xmlParserInputBufferCreateFilenameFunc	(const char * URI, 
xmlCharEncoding enc) +
xmlRegisterNodeFunc	xmlRegisterNodeDefault	(xmlRegisterNodeFunc func)
Function type: xmlRegisterNodeFunc
 void	xmlRegisterNodeFunc		(xmlNodePtr node)
@@ -32,9 +40,9 @@ void	xmlRegisterNodeFunc		(int	xmlThrDefKeepBlanksDefaultValue	(int v)
int	xmlThrDefLineNumbersDefaultValue	(int v)
int	xmlThrDefLoadExtDtdDefaultValue	(int v)
-
xmlOutputBufferCreateFilenameFunc	xmlThrDefOutputBufferCreateFilenameDefault	(xmlOutputBufferCreateFilenameFunc func)
+
xmlOutputBufferCreateFilenameFunc	xmlThrDefOutputBufferCreateFilenameDefault	(xmlOutputBufferCreateFilenameFunc func)
int	xmlThrDefParserDebugEntities	(int v)
-
xmlParserInputBufferCreateFilenameFunc	xmlThrDefParserInputBufferCreateFilenameDefault	(xmlParserInputBufferCreateFilenameFunc func)
+
xmlParserInputBufferCreateFilenameFunc	xmlThrDefParserInputBufferCreateFilenameDefault	(xmlParserInputBufferCreateFilenameFunc func)
int	xmlThrDefPedanticParserDefaultValue	(int v)
xmlRegisterNodeFunc	xmlThrDefRegisterNodeDefault	(xmlRegisterNodeFunc func)
int	xmlThrDefSaveNoEmptyTags	(int v)
@@ -74,8 +82,8 @@ void xmlRegisterNodeFunc (xmlDeregisterNodeFunc xmlDeregisterNodeDefaultValue xmlMallocFunc xmlMallocAtomic xmlError xmlLastError - xmlParserInputBufferCreateFilenameFunc xmlParserInputBufferCreateFilenameValue - xmlOutputBufferCreateFilenameFunc xmlOutputBufferCreateFilenameValue + xmlParserInputBufferCreateFilenameFunc xmlParserInputBufferCreateFilenameValue + xmlOutputBufferCreateFilenameFunc xmlOutputBufferCreateFilenameValue }

Function: xmlCleanupGlobals

void	xmlCleanupGlobals		(void)

Additional cleanup for multi-threading

Function: xmlDeregisterNodeDefault

xmlDeregisterNodeFunc	xmlDeregisterNodeDefault	(xmlDeregisterNodeFunc func)
@@ -87,7 +95,17 @@ void xmlDeregisterNodeFunc (xmlNodePtr

Additional initialisation for multi-threading

Function: xmlInitializeGlobalState

void	xmlInitializeGlobalState	(xmlGlobalStatePtr gs)

xmlInitializeGlobalState() initialize a global state with all the default values of the library.

-
gs:a pointer to a newly allocated global state

Function: xmlRegisterNodeDefault

xmlRegisterNodeFunc	xmlRegisterNodeDefault	(xmlRegisterNodeFunc func)
+
gs:a pointer to a newly allocated global state

Function: xmlOutputBufferCreateFilenameDefault

xmlOutputBufferCreateFilenameFunc	xmlOutputBufferCreateFilenameDefault	(xmlOutputBufferCreateFilenameFunc func)
+

Registers a callback for URI output file handling

+
func:function pointer to the new OutputBufferCreateFilenameFunc
Returns:the old value of the registration function

Function type: xmlOutputBufferCreateFilenameFunc

Function type: xmlOutputBufferCreateFilenameFunc
+xmlOutputBufferPtr	xmlOutputBufferCreateFilenameFunc	(const char * URI, 
xmlCharEncodingHandlerPtr encoder,
int compression) +

URI:
encoder:
compression:
Returns:

+

Function: xmlParserInputBufferCreateFilenameDefault

xmlParserInputBufferCreateFilenameFunc	xmlParserInputBufferCreateFilenameDefault	(xmlParserInputBufferCreateFilenameFunc func)
+

Registers a callback for URI input file handling

+
func:function pointer to the new ParserInputBufferCreateFilenameFunc
Returns:the old value of the registration function

Function type: xmlParserInputBufferCreateFilenameFunc

Function type: xmlParserInputBufferCreateFilenameFunc
+xmlParserInputBufferPtr	xmlParserInputBufferCreateFilenameFunc	(const char * URI, 
xmlCharEncoding enc) +

URI:
enc:
Returns:

+

Function: xmlRegisterNodeDefault

xmlRegisterNodeFunc	xmlRegisterNodeDefault	(xmlRegisterNodeFunc func)

Registers a callback for node creation

func:function pointer to the new RegisterNodeFunc
Returns:the old value of the registration function

Function type: xmlRegisterNodeFunc

Function type: xmlRegisterNodeFunc
 void	xmlRegisterNodeFunc		(xmlNodePtr node)
@@ -110,11 +128,11 @@ void	xmlRegisterNodeFunc		(xmlNodePtr
 

v:
Returns:

Function: xmlThrDefLoadExtDtdDefaultValue

int	xmlThrDefLoadExtDtdDefaultValue	(int v)

-
v:
Returns:

Function: xmlThrDefOutputBufferCreateFilenameDefault

xmlOutputBufferCreateFilenameFunc	xmlThrDefOutputBufferCreateFilenameDefault	(xmlOutputBufferCreateFilenameFunc func)
+
v:
Returns:

Function: xmlThrDefOutputBufferCreateFilenameDefault

xmlOutputBufferCreateFilenameFunc	xmlThrDefOutputBufferCreateFilenameDefault	(xmlOutputBufferCreateFilenameFunc func)

func:
Returns:

Function: xmlThrDefParserDebugEntities

int	xmlThrDefParserDebugEntities	(int v)

-
v:
Returns:

Function: xmlThrDefParserInputBufferCreateFilenameDefault

xmlParserInputBufferCreateFilenameFunc	xmlThrDefParserInputBufferCreateFilenameDefault	(xmlParserInputBufferCreateFilenameFunc func)
+
v:
Returns:

Function: xmlThrDefParserInputBufferCreateFilenameDefault

xmlParserInputBufferCreateFilenameFunc	xmlThrDefParserInputBufferCreateFilenameDefault	(xmlParserInputBufferCreateFilenameFunc func)

func:
Returns:

Function: xmlThrDefPedanticParserDefaultValue

int	xmlThrDefPedanticParserDefaultValue	(int v)

diff --git a/doc/html/libxml-schemasInternals.html b/doc/html/libxml-schemasInternals.html index 96518afd..4e9c30f9 100644 --- a/doc/html/libxml-schemasInternals.html +++ b/doc/html/libxml-schemasInternals.html @@ -10,7 +10,7 @@ A:link, A:visited, A:active { text-decoration: underline } Module schemasInternals from libxml2
Action against software patentsGnome2 LogoW3C LogoRed Hat Logo
Made with Libxml2 Logo

Module schemasInternals from libxml2

API Menu
API Indexes
Related links

internal interfaces for the XML Schemas handling and schema validity checking

Table of Contents

#define XML_SCHEMAS_ANYATTR_LAX
#define XML_SCHEMAS_ANYATTR_SKIP
#define XML_SCHEMAS_ANYATTR_STRICT
#define XML_SCHEMAS_ANY_LAX
#define XML_SCHEMAS_ANY_SKIP
#define XML_SCHEMAS_ANY_STRICT
#define XML_SCHEMAS_ATTRGROUP_GLOBAL
#define XML_SCHEMAS_ATTRGROUP_WILDCARD_BUILDED
#define XML_SCHEMAS_ATTR_GLOBAL
#define XML_SCHEMAS_ATTR_NSDEFAULT
#define XML_SCHEMAS_ATTR_USE_OPTIONAL
#define XML_SCHEMAS_ATTR_USE_PROHIBITED
#define XML_SCHEMAS_ATTR_USE_REQUIRED
#define XML_SCHEMAS_ELEM_ABSTRACT
#define XML_SCHEMAS_ELEM_DEFAULT
#define XML_SCHEMAS_ELEM_FIXED
#define XML_SCHEMAS_ELEM_GLOBAL
#define XML_SCHEMAS_ELEM_NILLABLE
#define XML_SCHEMAS_ELEM_NSDEFAULT
#define XML_SCHEMAS_ELEM_REF
#define XML_SCHEMAS_ELEM_TOPLEVEL
#define XML_SCHEMAS_FACET_COLLAPSE
#define XML_SCHEMAS_FACET_PRESERVE
#define XML_SCHEMAS_FACET_REPLACE
#define XML_SCHEMAS_FACET_UNKNOWN
#define XML_SCHEMAS_QUALIF_ATTR
#define XML_SCHEMAS_QUALIF_ELEM
#define XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION
#define XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION
#define XML_SCHEMAS_TYPE_GLOBAL
#define XML_SCHEMAS_TYPE_MIXED
#define XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD
#define XML_SCHEMAS_WILDCARD_COMPLETE
Structure xmlSchemaAnnot
struct _xmlSchemaAnnot + Module schemasInternals from libxml2
Action against software patentsGnome2 LogoW3C LogoRed Hat Logo
Made with Libxml2 Logo

Module schemasInternals from libxml2

API Menu
API Indexes
Related links

internal interfaces for the XML Schemas handling and schema validity checking

Table of Contents

#define XML_SCHEMAS_ANYATTR_LAX
#define XML_SCHEMAS_ANYATTR_SKIP
#define XML_SCHEMAS_ANYATTR_STRICT
#define XML_SCHEMAS_ANY_LAX
#define XML_SCHEMAS_ANY_SKIP
#define XML_SCHEMAS_ANY_STRICT
#define XML_SCHEMAS_ATTRGROUP_GLOBAL
#define XML_SCHEMAS_ATTRGROUP_WILDCARD_BUILDED
#define XML_SCHEMAS_ATTR_GLOBAL
#define XML_SCHEMAS_ATTR_NSDEFAULT
#define XML_SCHEMAS_ATTR_USE_OPTIONAL
#define XML_SCHEMAS_ATTR_USE_PROHIBITED
#define XML_SCHEMAS_ATTR_USE_REQUIRED
#define XML_SCHEMAS_ELEM_ABSTRACT
#define XML_SCHEMAS_ELEM_DEFAULT
#define XML_SCHEMAS_ELEM_FIXED
#define XML_SCHEMAS_ELEM_GLOBAL
#define XML_SCHEMAS_ELEM_NILLABLE
#define XML_SCHEMAS_ELEM_NSDEFAULT
#define XML_SCHEMAS_ELEM_REF
#define XML_SCHEMAS_ELEM_TOPLEVEL
#define XML_SCHEMAS_FACET_COLLAPSE
#define XML_SCHEMAS_FACET_PRESERVE
#define XML_SCHEMAS_FACET_REPLACE
#define XML_SCHEMAS_FACET_UNKNOWN
#define XML_SCHEMAS_FINAL_DEFAULT_EXTENSION
#define XML_SCHEMAS_FINAL_DEFAULT_LIST
#define XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION
#define XML_SCHEMAS_FINAL_DEFAULT_UNION
#define XML_SCHEMAS_QUALIF_ATTR
#define XML_SCHEMAS_QUALIF_ELEM
#define XML_SCHEMAS_TYPE_BUILTIN_PRIMITIVE
#define XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION
#define XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION
#define XML_SCHEMAS_TYPE_FINAL_DEFAULT
#define XML_SCHEMAS_TYPE_FINAL_EXTENSION
#define XML_SCHEMAS_TYPE_FINAL_LIST
#define XML_SCHEMAS_TYPE_FINAL_RESTRICTION
#define XML_SCHEMAS_TYPE_FINAL_UNION
#define XML_SCHEMAS_TYPE_GLOBAL
#define XML_SCHEMAS_TYPE_MIXED
#define XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD
#define XML_SCHEMAS_TYPE_VARIETY_ABSENT
#define XML_SCHEMAS_TYPE_VARIETY_ATOMIC
#define XML_SCHEMAS_TYPE_VARIETY_LIST
#define XML_SCHEMAS_TYPE_VARIETY_UNION
#define XML_SCHEMAS_WILDCARD_COMPLETE
Structure xmlSchemaAnnot
struct _xmlSchemaAnnot
Typedef xmlSchemaAnnot * xmlSchemaAnnotPtr
 
Structure xmlSchemaAttribute
struct _xmlSchemaAttribute
Structure xmlSchemaAttributeGroup
struct _xmlSchemaAttributeGroup @@ -22,53 +22,73 @@ A:link, A:visited, A:active { text-decoration: underline }
Structure xmlSchemaElement
struct _xmlSchemaElement
Typedef xmlSchemaElement * xmlSchemaElementPtr
 
Structure xmlSchemaFacet
struct _xmlSchemaFacet +
Structure xmlSchemaFacetLink
struct _xmlSchemaFacetLink +
Typedef xmlSchemaFacetLink * xmlSchemaFacetLinkPtr
 
Typedef xmlSchemaFacet * xmlSchemaFacetPtr
 
Structure xmlSchemaNotation
struct _xmlSchemaNotation
Typedef xmlSchemaNotation * xmlSchemaNotationPtr
 
Structure xmlSchemaType
struct _xmlSchemaType +
Structure xmlSchemaTypeLink
struct _xmlSchemaTypeLink +
Typedef xmlSchemaTypeLink * xmlSchemaTypeLinkPtr
 
Typedef xmlSchemaType * xmlSchemaTypePtr
 
Enum xmlSchemaTypeType
 
Structure xmlSchemaVal
struct _xmlSchemaVal The content of this structure is not made public by the API.
Typedef xmlSchemaVal * xmlSchemaValPtr
+
Enum xmlSchemaValType
 
Structure xmlSchemaWildcard
struct _xmlSchemaWildcard
Structure xmlSchemaWildcardNs
struct _xmlSchemaWildcardNs
Typedef xmlSchemaWildcardNs * xmlSchemaWildcardNsPtr
 
Typedef xmlSchemaWildcard * xmlSchemaWildcardPtr
 
void	xmlSchemaFreeType		(xmlSchemaTypePtr type)
+
void	xmlSchemaFreeWildcard		(xmlSchemaWildcardPtr wildcard)

Description

-

Macro: XML_SCHEMAS_ANYATTR_LAX

#define XML_SCHEMAS_ANYATTR_LAX

Ignore validation non definition on attributes

-

Macro: XML_SCHEMAS_ANYATTR_SKIP

#define XML_SCHEMAS_ANYATTR_SKIP

Skip unknown attribute from validation

-

Macro: XML_SCHEMAS_ANYATTR_STRICT

#define XML_SCHEMAS_ANYATTR_STRICT

Apply strict validation rules on attributes

-

Macro: XML_SCHEMAS_ANY_LAX

#define XML_SCHEMAS_ANY_LAX

Ignore validation non definition on attributes

+

Macro: XML_SCHEMAS_ANYATTR_LAX

#define XML_SCHEMAS_ANYATTR_LAX

Ignore validation non definition on attributes Obsolete, not used anymore.

+

Macro: XML_SCHEMAS_ANYATTR_SKIP

#define XML_SCHEMAS_ANYATTR_SKIP

Skip unknown attribute from validation Obsolete, not used anymore.

+

Macro: XML_SCHEMAS_ANYATTR_STRICT

#define XML_SCHEMAS_ANYATTR_STRICT

Apply strict validation rules on attributes Obsolete, not used anymore.

+

Macro: XML_SCHEMAS_ANY_LAX

#define XML_SCHEMAS_ANY_LAX

Used by wildcards. Validate if type found, don't worry if not found

Macro: XML_SCHEMAS_ANY_SKIP

#define XML_SCHEMAS_ANY_SKIP

Skip unknown attribute from validation

-

Macro: XML_SCHEMAS_ANY_STRICT

#define XML_SCHEMAS_ANY_STRICT

Apply strict validation rules on attributes

+

Macro: XML_SCHEMAS_ANY_STRICT

#define XML_SCHEMAS_ANY_STRICT

Used by wildcards. Apply strict validation rules

Macro: XML_SCHEMAS_ATTRGROUP_GLOBAL

#define XML_SCHEMAS_ATTRGROUP_GLOBAL

The attribute wildcard has been already builded.

Macro: XML_SCHEMAS_ATTRGROUP_WILDCARD_BUILDED

#define XML_SCHEMAS_ATTRGROUP_WILDCARD_BUILDED

The attribute wildcard has been already builded.

Macro: XML_SCHEMAS_ATTR_GLOBAL

#define XML_SCHEMAS_ATTR_GLOBAL

Macro: XML_SCHEMAS_ATTR_NSDEFAULT

#define XML_SCHEMAS_ATTR_NSDEFAULT

allow elements in no namespace

Macro: XML_SCHEMAS_ATTR_USE_OPTIONAL

#define XML_SCHEMAS_ATTR_USE_OPTIONAL

The attribute is optional.

-

Macro: XML_SCHEMAS_ATTR_USE_PROHIBITED

#define XML_SCHEMAS_ATTR_USE_PROHIBITED

The attribute is prohibited.

+

Macro: XML_SCHEMAS_ATTR_USE_PROHIBITED

#define XML_SCHEMAS_ATTR_USE_PROHIBITED

Used by wildcards. The attribute is prohibited.

Macro: XML_SCHEMAS_ATTR_USE_REQUIRED

#define XML_SCHEMAS_ATTR_USE_REQUIRED

The attribute is required.

Macro: XML_SCHEMAS_ELEM_ABSTRACT

#define XML_SCHEMAS_ELEM_ABSTRACT

the element is abstract

Macro: XML_SCHEMAS_ELEM_DEFAULT

#define XML_SCHEMAS_ELEM_DEFAULT

the element has a default value

Macro: XML_SCHEMAS_ELEM_FIXED

#define XML_SCHEMAS_ELEM_FIXED

the element has a fixed value

Macro: XML_SCHEMAS_ELEM_GLOBAL

#define XML_SCHEMAS_ELEM_GLOBAL

the element is global

Macro: XML_SCHEMAS_ELEM_NILLABLE

#define XML_SCHEMAS_ELEM_NILLABLE

the element is nillable

-

Macro: XML_SCHEMAS_ELEM_NSDEFAULT

#define XML_SCHEMAS_ELEM_NSDEFAULT

allow elements in no namespace

+

Macro: XML_SCHEMAS_ELEM_NSDEFAULT

#define XML_SCHEMAS_ELEM_NSDEFAULT

allow elements in no namespace Obsolete, not used anymore.

Macro: XML_SCHEMAS_ELEM_REF

#define XML_SCHEMAS_ELEM_REF

the element is a reference to a type

Macro: XML_SCHEMAS_ELEM_TOPLEVEL

#define XML_SCHEMAS_ELEM_TOPLEVEL

the element is top level obsolete: use XML_SCHEMAS_ELEM_GLOBAL instead

Macro: XML_SCHEMAS_FACET_COLLAPSE

#define XML_SCHEMAS_FACET_COLLAPSE

collapse the types of the facet

Macro: XML_SCHEMAS_FACET_PRESERVE

#define XML_SCHEMAS_FACET_PRESERVE

preserve the type of the facet

Macro: XML_SCHEMAS_FACET_REPLACE

#define XML_SCHEMAS_FACET_REPLACE

replace the type of the facet

Macro: XML_SCHEMAS_FACET_UNKNOWN

#define XML_SCHEMAS_FACET_UNKNOWN

unknown facet handling

+

Macro: XML_SCHEMAS_FINAL_DEFAULT_EXTENSION

#define XML_SCHEMAS_FINAL_DEFAULT_EXTENSION

the shema has "extension" in the set of finalDefault.

+

Macro: XML_SCHEMAS_FINAL_DEFAULT_LIST

#define XML_SCHEMAS_FINAL_DEFAULT_LIST

the shema has "list" in the set of finalDefault.

+

Macro: XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION

#define XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION

the shema has "restriction" in the set of finalDefault.

+

Macro: XML_SCHEMAS_FINAL_DEFAULT_UNION

#define XML_SCHEMAS_FINAL_DEFAULT_UNION

the shema has "union" in the set of finalDefault.

Macro: XML_SCHEMAS_QUALIF_ATTR

#define XML_SCHEMAS_QUALIF_ATTR

the shemas requires qualified attributes

Macro: XML_SCHEMAS_QUALIF_ELEM

#define XML_SCHEMAS_QUALIF_ELEM

the shemas requires qualified elements

+

Macro: XML_SCHEMAS_TYPE_BUILTIN_PRIMITIVE

#define XML_SCHEMAS_TYPE_BUILTIN_PRIMITIVE

Macro: XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION

#define XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION

the simple or complex type has a derivation method of "extension".

Macro: XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION

#define XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION

the simple or complex type has a derivation method of "restriction".

+

Macro: XML_SCHEMAS_TYPE_FINAL_DEFAULT

#define XML_SCHEMAS_TYPE_FINAL_DEFAULT

+

Macro: XML_SCHEMAS_TYPE_FINAL_EXTENSION

#define XML_SCHEMAS_TYPE_FINAL_EXTENSION

the complexType has a final of "extension".

+

Macro: XML_SCHEMAS_TYPE_FINAL_LIST

#define XML_SCHEMAS_TYPE_FINAL_LIST

the simpleType has a final of "list".

+

Macro: XML_SCHEMAS_TYPE_FINAL_RESTRICTION

#define XML_SCHEMAS_TYPE_FINAL_RESTRICTION

the simpleType/complexType has a final of "restriction".

+

Macro: XML_SCHEMAS_TYPE_FINAL_UNION

#define XML_SCHEMAS_TYPE_FINAL_UNION

the simpleType has a final of "union".

Macro: XML_SCHEMAS_TYPE_GLOBAL

#define XML_SCHEMAS_TYPE_GLOBAL

the type is global

Macro: XML_SCHEMAS_TYPE_MIXED

#define XML_SCHEMAS_TYPE_MIXED

the element content type is mixed

Macro: XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD

#define XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD

the complexType owns an attribute wildcard, i.e. it can be freed by the complexType

+

Macro: XML_SCHEMAS_TYPE_VARIETY_ABSENT

#define XML_SCHEMAS_TYPE_VARIETY_ABSENT

the simpleType has a variety of "absent".

+

Macro: XML_SCHEMAS_TYPE_VARIETY_ATOMIC

#define XML_SCHEMAS_TYPE_VARIETY_ATOMIC

the simpleType has a variety of "union".

+

Macro: XML_SCHEMAS_TYPE_VARIETY_LIST

#define XML_SCHEMAS_TYPE_VARIETY_LIST

the simpleType has a variety of "list".

+

Macro: XML_SCHEMAS_TYPE_VARIETY_UNION

#define XML_SCHEMAS_TYPE_VARIETY_UNION

the simpleType has a variety of "union".

Macro: XML_SCHEMAS_WILDCARD_COMPLETE

#define XML_SCHEMAS_WILDCARD_COMPLETE

If the wildcard is complete.

Structure xmlSchemaAnnot

Structure xmlSchemaAnnot
struct _xmlSchemaAnnot { struct _xmlSchemaAnnot * next @@ -111,7 +131,7 @@ The content of this structure is not made public by the API. XML_SCHEMA_CONTENT_ELEMENTS = 2 XML_SCHEMA_CONTENT_MIXED = 3 XML_SCHEMA_CONTENT_SIMPLE = 4 - XML_SCHEMA_CONTENT_MIXED_OR_ELEMENTS = 5 + XML_SCHEMA_CONTENT_MIXED_OR_ELEMENTS = 5 : obsolete, not used XML_SCHEMA_CONTENT_BASIC = 6 XML_SCHEMA_CONTENT_ANY = 7 } @@ -150,6 +170,9 @@ The content of this structure is not made public by the API. int whitespace xmlSchemaValPtr val xmlRegexpPtr regexp +}

Structure xmlSchemaFacetLink

Structure xmlSchemaFacetLink
struct _xmlSchemaFacetLink { + struct _xmlSchemaFacetLink * next : the next facet link ... + xmlSchemaFacetPtr facet : the linked facet }

Structure xmlSchemaNotation

Structure xmlSchemaNotation
struct _xmlSchemaNotation { xmlSchemaTypeType type : The kind of type const xmlChar * name @@ -178,8 +201,14 @@ The content of this structure is not made public by the API. int recurse xmlSchemaAttributeLinkPtr attributeUses xmlSchemaWildcardPtr attributeWildcard + int builtInType + xmlSchemaTypeLinkPtr memberTypes + xmlSchemaFacetLinkPtr facetSet +}

Structure xmlSchemaTypeLink

Structure xmlSchemaTypeLink
struct _xmlSchemaTypeLink { + struct _xmlSchemaTypeLink * next : the next type link ... + xmlSchemaTypePtr type : the linked typ }

Enum xmlSchemaTypeType

Enum xmlSchemaTypeType {
-    XML_SCHEMA_TYPE_BASIC = 1
+    XML_SCHEMA_TYPE_BASIC = 1 : A built-in datatype
     XML_SCHEMA_TYPE_ANY = 2
     XML_SCHEMA_TYPE_FACET = 3
     XML_SCHEMA_TYPE_SIMPLE = 4
@@ -215,7 +244,56 @@ The content of this structure is not made public by the API.
 }
 

Structure xmlSchemaVal

Structure xmlSchemaVal
struct _xmlSchemaVal { The content of this structure is not made public by the API. -}

Structure xmlSchemaWildcard

Structure xmlSchemaWildcard
struct _xmlSchemaWildcard { +}

Enum xmlSchemaValType

Enum xmlSchemaValType {
+    XML_SCHEMAS_UNKNOWN = 0
+    XML_SCHEMAS_STRING = 1
+    XML_SCHEMAS_NORMSTRING = 2
+    XML_SCHEMAS_DECIMAL = 3
+    XML_SCHEMAS_TIME = 4
+    XML_SCHEMAS_GDAY = 5
+    XML_SCHEMAS_GMONTH = 6
+    XML_SCHEMAS_GMONTHDAY = 7
+    XML_SCHEMAS_GYEAR = 8
+    XML_SCHEMAS_GYEARMONTH = 9
+    XML_SCHEMAS_DATE = 10
+    XML_SCHEMAS_DATETIME = 11
+    XML_SCHEMAS_DURATION = 12
+    XML_SCHEMAS_FLOAT = 13
+    XML_SCHEMAS_DOUBLE = 14
+    XML_SCHEMAS_BOOLEAN = 15
+    XML_SCHEMAS_TOKEN = 16
+    XML_SCHEMAS_LANGUAGE = 17
+    XML_SCHEMAS_NMTOKEN = 18
+    XML_SCHEMAS_NMTOKENS = 19
+    XML_SCHEMAS_NAME = 20
+    XML_SCHEMAS_QNAME = 21
+    XML_SCHEMAS_NCNAME = 22
+    XML_SCHEMAS_ID = 23
+    XML_SCHEMAS_IDREF = 24
+    XML_SCHEMAS_IDREFS = 25
+    XML_SCHEMAS_ENTITY = 26
+    XML_SCHEMAS_ENTITIES = 27
+    XML_SCHEMAS_NOTATION = 28
+    XML_SCHEMAS_ANYURI = 29
+    XML_SCHEMAS_INTEGER = 30
+    XML_SCHEMAS_NPINTEGER = 31
+    XML_SCHEMAS_NINTEGER = 32
+    XML_SCHEMAS_NNINTEGER = 33
+    XML_SCHEMAS_PINTEGER = 34
+    XML_SCHEMAS_INT = 35
+    XML_SCHEMAS_UINT = 36
+    XML_SCHEMAS_LONG = 37
+    XML_SCHEMAS_ULONG = 38
+    XML_SCHEMAS_SHORT = 39
+    XML_SCHEMAS_USHORT = 40
+    XML_SCHEMAS_BYTE = 41
+    XML_SCHEMAS_UBYTE = 42
+    XML_SCHEMAS_HEXBINARY = 43
+    XML_SCHEMAS_BASE64BINARY = 44
+    XML_SCHEMAS_ANYTYPE = 45
+    XML_SCHEMAS_ANYSIMPLETYPE = 46
+}
+

Structure xmlSchemaWildcard

Structure xmlSchemaWildcard
struct _xmlSchemaWildcard { xmlSchemaTypeType type : The kind of type const xmlChar * id xmlSchemaAnnotPtr annot @@ -232,4 +310,6 @@ The content of this structure is not made public by the API. const xmlChar * value : the value }

Function: xmlSchemaFreeType

void	xmlSchemaFreeType		(xmlSchemaTypePtr type)

Deallocate a Schema Type structure.

-
type:a schema type structure

Daniel Veillard

+
type:a schema type structure

Function: xmlSchemaFreeWildcard

void	xmlSchemaFreeWildcard		(xmlSchemaWildcardPtr wildcard)
+

Deallocates a wildcard structure.

+
wildcard:a wildcard structure

Daniel Veillard

diff --git a/doc/html/libxml-xmlIO.html b/doc/html/libxml-xmlIO.html index 9d691133..28192abe 100644 --- a/doc/html/libxml-xmlIO.html +++ b/doc/html/libxml-xmlIO.html @@ -48,10 +48,6 @@ int xmlInputReadCallback (void * context, <
xmlOutputBufferPtr	xmlOutputBufferCreateFd	(int fd, 
xmlCharEncodingHandlerPtr encoder)
xmlOutputBufferPtr	xmlOutputBufferCreateFile	(FILE * file, 
xmlCharEncodingHandlerPtr encoder)
xmlOutputBufferPtr	xmlOutputBufferCreateFilename	(const char * URI, 
xmlCharEncodingHandlerPtr encoder,
int compression)
-
xmlOutputBufferCreateFilenameFunc	xmlOutputBufferCreateFilenameDefault	(xmlOutputBufferCreateFilenameFunc func)
-
Function type: xmlOutputBufferCreateFilenameFunc
-xmlOutputBufferPtr	xmlOutputBufferCreateFilenameFunc	(const char * URI, 
xmlCharEncodingHandlerPtr encoder,
int compression) -
xmlOutputBufferPtr	xmlOutputBufferCreateIO	(xmlOutputWriteCallback iowrite, 
xmlOutputCloseCallback ioclose,
void * ioctx,
xmlCharEncodingHandlerPtr encoder)
int	xmlOutputBufferFlush		(xmlOutputBufferPtr out)
int	xmlOutputBufferWrite		(xmlOutputBufferPtr out, 
int len,
const char * buf)
@@ -73,10 +69,6 @@ int xmlOutputWriteCallback (void * contex
xmlParserInputBufferPtr	xmlParserInputBufferCreateFd	(int fd, 
xmlCharEncoding enc)
xmlParserInputBufferPtr	xmlParserInputBufferCreateFile	(FILE * file, 
xmlCharEncoding enc)
xmlParserInputBufferPtr	xmlParserInputBufferCreateFilename	(const char * URI, 
xmlCharEncoding enc)
-
xmlParserInputBufferCreateFilenameFunc	xmlParserInputBufferCreateFilenameDefault	(xmlParserInputBufferCreateFilenameFunc func)
-
Function type: xmlParserInputBufferCreateFilenameFunc
-xmlParserInputBufferPtr	xmlParserInputBufferCreateFilenameFunc	(const char * URI, 
xmlCharEncoding enc) -
xmlParserInputBufferPtr	xmlParserInputBufferCreateIO	(xmlInputReadCallback ioread, 
xmlInputCloseCallback ioclose,
void * ioctx,
xmlCharEncoding enc)
xmlParserInputBufferPtr	xmlParserInputBufferCreateMem	(const char * mem, 
int size,
xmlCharEncoding enc)
xmlParserInputBufferPtr	xmlParserInputBufferCreateStatic	(const char * mem, 
int size,
xmlCharEncoding enc)
@@ -154,12 +146,7 @@ int xmlInputReadCallback (void * context,
char * buffer,

Create a buffered output for the progressive saving to a FILE * buffered C I/O

file:a FILE*
encoder:the encoding converter or NULL
Returns:the new parser output or NULL

Function: xmlOutputBufferCreateFilename

xmlOutputBufferPtr	xmlOutputBufferCreateFilename	(const char * URI, 
xmlCharEncodingHandlerPtr encoder,
int compression)

Create a buffered output for the progressive saving of a file If filename is "-' then we use stdout as the output. Automatic support for ZLIB/Compress compressed document is provided by default if found at compile-time. TODO: currently if compression is set, the library only support writing to a local file.

-
URI:a C string containing the URI or filename
encoder:the encoding converter or NULL
compression:the compression ration (0 none, 9 max).
Returns:the new output or NULL

Function: xmlOutputBufferCreateFilenameDefault

xmlOutputBufferCreateFilenameFunc	xmlOutputBufferCreateFilenameDefault	(xmlOutputBufferCreateFilenameFunc func)
-

Registers a callback for URI output file handling

-
func:function pointer to the new OutputBufferCreateFilenameFunc
Returns:the old value of the registration function

Function type: xmlOutputBufferCreateFilenameFunc

Function type: xmlOutputBufferCreateFilenameFunc
-xmlOutputBufferPtr	xmlOutputBufferCreateFilenameFunc	(const char * URI, 
xmlCharEncodingHandlerPtr encoder,
int compression) -

URI:
encoder:
compression:
Returns:

-

Function: xmlOutputBufferCreateIO

xmlOutputBufferPtr	xmlOutputBufferCreateIO	(xmlOutputWriteCallback iowrite, 
xmlOutputCloseCallback ioclose,
void * ioctx,
xmlCharEncodingHandlerPtr encoder)
+
URI:a C string containing the URI or filename
encoder:the encoding converter or NULL
compression:the compression ration (0 none, 9 max).
Returns:the new output or NULL

Function: xmlOutputBufferCreateIO

xmlOutputBufferPtr	xmlOutputBufferCreateIO	(xmlOutputWriteCallback iowrite, 
xmlOutputCloseCallback ioclose,
void * ioctx,
xmlCharEncodingHandlerPtr encoder)

Create a buffered output for the progressive saving to an I/O handler

iowrite:an I/O write function
ioclose:an I/O close function
ioctx:an I/O handler
encoder:the charset encoding if known
Returns:the new parser output or NULL

Function: xmlOutputBufferFlush

int	xmlOutputBufferFlush		(xmlOutputBufferPtr out)

flushes the output I/O channel

@@ -189,12 +176,7 @@ int xmlOutputWriteCallback (void * context,
const char * buffer,

Create a buffered parser input for the progressive parsing of a FILE * buffered C I/O

file:a FILE*
enc:the charset encoding if known
Returns:the new parser input or NULL

Function: xmlParserInputBufferCreateFilename

xmlParserInputBufferPtr	xmlParserInputBufferCreateFilename	(const char * URI, 
xmlCharEncoding enc)

Create a buffered parser input for the progressive parsing of a file If filename is "-' then we use stdin as the input. Automatic support for ZLIB/Compress compressed document is provided by default if found at compile-time. Do an encoding check if enc == XML_CHAR_ENCODING_NONE

-
URI:a C string containing the URI or filename
enc:the charset encoding if known
Returns:the new parser input or NULL

Function: xmlParserInputBufferCreateFilenameDefault

xmlParserInputBufferCreateFilenameFunc	xmlParserInputBufferCreateFilenameDefault	(xmlParserInputBufferCreateFilenameFunc func)
-

Registers a callback for URI input file handling

-
func:function pointer to the new ParserInputBufferCreateFilenameFunc
Returns:the old value of the registration function

Function type: xmlParserInputBufferCreateFilenameFunc

Function type: xmlParserInputBufferCreateFilenameFunc
-xmlParserInputBufferPtr	xmlParserInputBufferCreateFilenameFunc	(const char * URI, 
xmlCharEncoding enc) -

URI:
enc:
Returns:

-

Function: xmlParserInputBufferCreateIO

xmlParserInputBufferPtr	xmlParserInputBufferCreateIO	(xmlInputReadCallback ioread, 
xmlInputCloseCallback ioclose,
void * ioctx,
xmlCharEncoding enc)
+
URI:a C string containing the URI or filename
enc:the charset encoding if known
Returns:the new parser input or NULL

Function: xmlParserInputBufferCreateIO

xmlParserInputBufferPtr	xmlParserInputBufferCreateIO	(xmlInputReadCallback ioread, 
xmlInputCloseCallback ioclose,
void * ioctx,
xmlCharEncoding enc)

Create a buffered parser input for the progressive parsing for the input from an I/O handler

ioread:an I/O read function
ioclose:an I/O close function
ioctx:an I/O handler
enc:the charset encoding if known
Returns:the new parser input or NULL

Function: xmlParserInputBufferCreateMem

xmlParserInputBufferPtr	xmlParserInputBufferCreateMem	(const char * mem, 
int size,
xmlCharEncoding enc)

Create a buffered parser input for the progressive parsing for the input from a memory area.

diff --git a/doc/html/libxml-xmlerror.html b/doc/html/libxml-xmlerror.html index 41797032..ac0cff77 100644 --- a/doc/html/libxml-xmlerror.html +++ b/doc/html/libxml-xmlerror.html @@ -591,6 +591,27 @@ void xmlStructuredErrorFunc (void * userD XML_SCHEMAV_ATTRINVALID = 1820 : 1820 XML_SCHEMAV_VALUE = 1821 : 1821 XML_SCHEMAV_FACET = 1822 : 1822 + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_1 = 1823 : 1823 + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_2 = 1824 : 1824 + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_3 = 1825 : 1825 + XML_SCHEMAV_CVC_TYPE_3_1_1 = 1826 : 1826 + XML_SCHEMAV_CVC_TYPE_3_1_2 = 1827 : 1827 + XML_SCHEMAV_CVC_FACET_VALID = 1828 : 1828 + XML_SCHEMAV_CVC_LENGTH_VALID = 1829 : 1829 + XML_SCHEMAV_CVC_MINLENGTH_VALID = 1830 : 1830 + XML_SCHEMAV_CVC_MAXLENGTH_VALID = 1831 : 1831 + XML_SCHEMAV_CVC_MININCLUSIVE_VALID = 1832 : 1832 + XML_SCHEMAV_CVC_MAXINCLUSIVE_VALID = 1833 : 1833 + XML_SCHEMAV_CVC_MINEXCLUSIVE_VALID = 1834 : 1834 + XML_SCHEMAV_CVC_MAXEXCLUSIVE_VALID = 1835 : 1835 + XML_SCHEMAV_CVC_TOTALDIGITS_VALID = 1836 : 1836 + XML_SCHEMAV_CVC_FRACTIONDIGITS_VALID = 1837 : 1837 + XML_SCHEMAV_CVC_PATTERN_VALID = 1838 : 1838 + XML_SCHEMAV_CVC_ENUMERATION_VALID = 1839 : 1839 + XML_SCHEMAV_CVC_COMPLEX_TYPE_2_1 = 1840 : 1840 + XML_SCHEMAV_CVC_COMPLEX_TYPE_2_2 = 1841 : 1841 + XML_SCHEMAV_CVC_COMPLEX_TYPE_2_3 = 1842 : 1842 + XML_SCHEMAV_CVC_COMPLEX_TYPE_2_4 = 1843 : 1843 XML_XPTR_UNKNOWN_SCHEME = 1900 XML_XPTR_CHILDSEQ_START = 1901 : 1901 XML_XPTR_EVAL_FAILED = 1902 : 1902 @@ -605,6 +626,43 @@ void xmlStructuredErrorFunc (void * userD XML_HTTP_URL_SYNTAX = 2020 XML_HTTP_USE_IP = 2021 : 2021 XML_HTTP_UNKNOWN_HOST = 2022 : 2022 + XML_SCHEMAP_SRC_SIMPLE_TYPE_1 = 3000 + XML_SCHEMAP_SRC_SIMPLE_TYPE_2 = 3001 : 3001 + XML_SCHEMAP_SRC_SIMPLE_TYPE_3 = 3002 : 3002 + XML_SCHEMAP_SRC_SIMPLE_TYPE_4 = 3003 : 3003 + XML_SCHEMAP_SRC_RESOLVE = 3004 : 3004 + XML_SCHEMAP_SRC_RESTRICTION_BASE_OR_SIMPLETYPE = 3005 : 3004 + XML_SCHEMAP_SRC_LIST_ITEMTYPE_OR_SIMPLETYPE = 3006 : 3005 + XML_SCHEMAP_SRC_UNION_MEMBERTYPES_OR_SIMPLETYPES = 3007 : 3006 + XML_SCHEMAP_ST_PROPS_CORRECT_1 = 3008 : 3007 + XML_SCHEMAP_ST_PROPS_CORRECT_2 = 3009 : 3008 + XML_SCHEMAP_ST_PROPS_CORRECT_3 = 3010 : 3009 + XML_SCHEMAP_COS_ST_RESTRICTS_1_1 = 3011 : 3010 + XML_SCHEMAP_COS_ST_RESTRICTS_1_2 = 3012 : 3011 + XML_SCHEMAP_COS_ST_RESTRICTS_1_3_1 = 3013 : 3012 + XML_SCHEMAP_COS_ST_RESTRICTS_1_3_2 = 3014 : 3013 + XML_SCHEMAP_COS_ST_RESTRICTS_2_1 = 3015 : 3014 + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_1_1 = 3016 : 3015 + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_1_2 = 3017 : 3016 + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_1 = 3018 : 3017 + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_2 = 3019 : 3018 + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_3 = 3020 : 3019 + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_4 = 3021 : 3021 + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_5 = 3022 : 3022 + XML_SCHEMAP_COS_ST_RESTRICTS_3_1 = 3023 : 3023 + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_1 = 3024 : 3024 + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_1_2 = 3025 : 3025 + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_2 = 3026 : 3026 + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_1 = 3027 : 3027 + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_3 = 3028 : 3028 + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_4 = 3029 : 3029 + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_5 = 3030 : 3030 + XML_SCHEMAP_COS_ST_DERIVED_OK_2_1 = 3031 : 3031 + XML_SCHEMAP_COS_ST_DERIVED_OK_2_2 = 3032 : 3032 + XML_SCHEMAP_S4S_ELEM_NOT_ALLOWED = 3033 : 3033 + XML_SCHEMAP_S4S_ELEM_MISSING = 3034 : 3034 + XML_SCHEMAP_S4S_ATTR_NOT_ALLOWED = 3035 : 3035 + XML_SCHEMAP_S4S_ATTR_MISSING = 3036 : 3036 }

Function: initGenericErrorDefaultFunc

void	initGenericErrorDefaultFunc	(xmlGenericErrorFunc * handler)

Set or reset (if NULL) the default handler for generic errors to the builtin error function.

diff --git a/doc/html/libxml-xmlmemory.html b/doc/html/libxml-xmlmemory.html index 6b5c840a..87a0a56d 100644 --- a/doc/html/libxml-xmlmemory.html +++ b/doc/html/libxml-xmlmemory.html @@ -71,14 +71,14 @@ void * xmlMallocFunc (size_t size)
size:an int specifying the size in byte to allocate.
file:the file name or NULL
line:the line number
Returns:a pointer to the allocated area or NULL in case of lack of memory.

Function: xmlMemDisplay

void	xmlMemDisplay			(FILE * fp)

show in-extenso the memory blocks allocated

fp:a FILE descriptor used as the output file, if NULL, the result is written to the file .memorylist

Function: xmlMemFree

void	xmlMemFree			(void * ptr)
-

a free() equivalent, with error checking.

-
ptr:the memory block pointer

Function: xmlMemGet

int	xmlMemGet			(xmlFreeFunc * freeFunc, 
xmlMallocFunc * mallocFunc,
xmlReallocFunc * reallocFunc,
xmlStrdupFunc * strdupFunc)
+

+
ptr:

Function: xmlMemGet

int	xmlMemGet			(xmlFreeFunc * freeFunc, 
xmlMallocFunc * mallocFunc,
xmlReallocFunc * reallocFunc,
xmlStrdupFunc * strdupFunc)

Provides the memory access functions set currently in use

freeFunc:place to save the free() function in use
mallocFunc:place to save the malloc() function in use
reallocFunc:place to save the realloc() function in use
strdupFunc:place to save the strdup() function in use
Returns:0 on success

Function: xmlMemMalloc

void *	xmlMemMalloc			(size_t size)
-

a malloc() equivalent, with logging of the allocation info.

-
size:an int specifying the size in byte to allocate.
Returns:a pointer to the allocated area or NULL in case of lack of memory.

Function: xmlMemRealloc

void *	xmlMemRealloc			(void * ptr, 
size_t size)
-

a realloc() equivalent, with logging of the allocation info.

-
ptr:the initial memory block pointer
size:an int specifying the size in byte to allocate.
Returns:a pointer to the allocated area or NULL in case of lack of memory.

Function: xmlMemSetup

int	xmlMemSetup			(xmlFreeFunc freeFunc, 
xmlMallocFunc mallocFunc,
xmlReallocFunc reallocFunc,
xmlStrdupFunc strdupFunc)
+

+
size:
Returns:

Function: xmlMemRealloc

void *	xmlMemRealloc			(void * ptr, 
size_t size)
+

+
ptr:
size:
Returns:

Function: xmlMemSetup

int	xmlMemSetup			(xmlFreeFunc freeFunc, 
xmlMallocFunc mallocFunc,
xmlReallocFunc reallocFunc,
xmlStrdupFunc strdupFunc)

Override the default memory access functions with a new set This has to be called before any other libxml routines ! Should this be blocked if there was already some allocations done ?

freeFunc:the free() function to use
mallocFunc:the malloc() function to use
reallocFunc:the realloc() function to use
strdupFunc:the strdup() function to use
Returns:0 on success

Function: xmlMemShow

void	xmlMemShow			(FILE * fp, 
int nr)

show a show display of the memory allocated, and dump the @nr last allocated areas which were not freed

@@ -89,8 +89,8 @@ void * xmlMallocFunc (size_t size)
Returns:an int representing the amount of memory allocated.

Function: xmlMemoryDump

void	xmlMemoryDump			(void)

Dump in-extenso the memory blocks allocated to the file .memorylist

Function: xmlMemoryStrdup

char *	xmlMemoryStrdup			(const char * str)
-

a strdup() equivalent, with logging of the allocation info.

-
str:the initial string pointer
Returns:a pointer to the new string or NULL if allocation error occurred.

Function type: xmlReallocFunc

Function type: xmlReallocFunc
+

+
str:
Returns:

Function type: xmlReallocFunc

Function type: xmlReallocFunc
 void *	xmlReallocFunc			(void * mem, 
size_t size)

Signature for a realloc() implementation.

mem:an already allocated block of memory
size:the new size requested in bytes
Returns:a pointer to the newly reallocated block or NULL in case of error.

Function: xmlReallocLoc

void *	xmlReallocLoc			(void * ptr, 
size_t size,
const char * file,
int line)
diff --git a/doc/html/libxml-xmlschemastypes.html b/doc/html/libxml-xmlschemastypes.html index c80729a0..ae2de6d2 100644 --- a/doc/html/libxml-xmlschemastypes.html +++ b/doc/html/libxml-xmlschemastypes.html @@ -12,36 +12,51 @@ A:link, A:visited, A:active { text-decoration: underline } pre.programlisting {border-style: double;background: #EECFA1} Module xmlschemastypes from libxml2
Action against software patentsGnome2 LogoW3C LogoRed Hat Logo
Made with Libxml2 Logo

Module xmlschemastypes from libxml2

API Menu
API Indexes
Related links

module providing the XML Schema Datatypes implementation both definition and validity checking

Table of Contents

int	xmlSchemaCheckFacet		(xmlSchemaFacetPtr facet, 
xmlSchemaTypePtr typeDecl,
xmlSchemaParserCtxtPtr ctxt,
const xmlChar * name)
void	xmlSchemaCleanupTypes		(void)
+
xmlChar *	xmlSchemaCollapseString	(const xmlChar * value)
int	xmlSchemaCompareValues		(xmlSchemaValPtr x, 
xmlSchemaValPtr y)
void	xmlSchemaFreeFacet		(xmlSchemaFacetPtr facet)
void	xmlSchemaFreeValue		(xmlSchemaValPtr value)
+
xmlSchemaTypePtr	xmlSchemaGetBuiltInListSimpleTypeItemType	(xmlSchemaTypePtr type)
+
xmlSchemaTypePtr	xmlSchemaGetBuiltInType	(xmlSchemaValType type)
xmlSchemaTypePtr	xmlSchemaGetPredefinedType	(const xmlChar * name, 
const xmlChar * ns)
void	xmlSchemaInitTypes		(void)
+
int	xmlSchemaIsBuiltInTypeFacet	(xmlSchemaTypePtr type, 
int facetType)
xmlSchemaFacetPtr	xmlSchemaNewFacet	(void)
int	xmlSchemaValPredefTypeNode	(xmlSchemaTypePtr type, 
const xmlChar * value,
xmlSchemaValPtr * val,
xmlNodePtr node)
int	xmlSchemaValidateFacet		(xmlSchemaTypePtr base, 
xmlSchemaFacetPtr facet,
const xmlChar * value,
xmlSchemaValPtr val)
+
int	xmlSchemaValidateListSimpleTypeFacet	(xmlSchemaFacetPtr facet, 
const xmlChar * value,
unsigned long actualLen,
unsigned long * expectedLen)
int	xmlSchemaValidatePredefinedType	(xmlSchemaTypePtr type, 
const xmlChar * value,
xmlSchemaValPtr * val)

Description

Function: xmlSchemaCheckFacet

int	xmlSchemaCheckFacet		(xmlSchemaFacetPtr facet, 
xmlSchemaTypePtr typeDecl,
xmlSchemaParserCtxtPtr ctxt,
const xmlChar * name)

Checks the default values types, especially for facets

facet:the facet
typeDecl:the schema type definition
ctxt:the schema parser context or NULL
name:name of the type
Returns:0 if okay or -1 in cae of error

Function: xmlSchemaCleanupTypes

void	xmlSchemaCleanupTypes		(void)

Cleanup the default XML Schemas type library

-

Function: xmlSchemaCompareValues

int	xmlSchemaCompareValues		(xmlSchemaValPtr x, 
xmlSchemaValPtr y)
+

Function: xmlSchemaCollapseString

xmlChar *	xmlSchemaCollapseString	(const xmlChar * value)
+

Removes and normalize white spaces in the string

+
value:a value
Returns:the new string or NULL if no change was required.

Function: xmlSchemaCompareValues

int	xmlSchemaCompareValues		(xmlSchemaValPtr x, 
xmlSchemaValPtr y)

Compare 2 values

x:a first value
y:a second value
Returns:-1 if x < y, 0 if x == y, 1 if x > y, 2 if x <> y, and -2 in case of error

Function: xmlSchemaFreeFacet

void	xmlSchemaFreeFacet		(xmlSchemaFacetPtr facet)

Deallocate a Schema Facet structure.

facet:a schema facet structure

Function: xmlSchemaFreeValue

void	xmlSchemaFreeValue		(xmlSchemaValPtr value)

Cleanup the default XML Schemas type library

-
value:the value to free

Function: xmlSchemaGetPredefinedType

xmlSchemaTypePtr	xmlSchemaGetPredefinedType	(const xmlChar * name, 
const xmlChar * ns)
+
value:the value to free

Function: xmlSchemaGetBuiltInListSimpleTypeItemType

xmlSchemaTypePtr	xmlSchemaGetBuiltInListSimpleTypeItemType	(xmlSchemaTypePtr type)
+

+
type:the built-in simple type.
Returns:the item type of @type as defined by the built-in datatype hierarchy of XML Schema Part 2: Datatypes, or NULL in case of an error.

Function: xmlSchemaGetBuiltInType

xmlSchemaTypePtr	xmlSchemaGetBuiltInType	(xmlSchemaValType type)
+

Gives you the type struct for a built-in type by its type id.

+
type:the type of the built in type
Returns:the type if found, NULL otherwise.

Function: xmlSchemaGetPredefinedType

xmlSchemaTypePtr	xmlSchemaGetPredefinedType	(const xmlChar * name, 
const xmlChar * ns)

Lookup a type in the default XML Schemas type library

name:the type name
ns:the URI of the namespace usually "http://www.w3.org/2001/XMLSchema"
Returns:the type if found, NULL otherwise

Function: xmlSchemaInitTypes

void	xmlSchemaInitTypes		(void)

Initialize the default XML Schemas type library

-

Function: xmlSchemaNewFacet

xmlSchemaFacetPtr	xmlSchemaNewFacet	(void)
+

Function: xmlSchemaIsBuiltInTypeFacet

int	xmlSchemaIsBuiltInTypeFacet	(xmlSchemaTypePtr type, 
int facetType)
+

+
type:
facetType:
Returns:

Function: xmlSchemaNewFacet

xmlSchemaFacetPtr	xmlSchemaNewFacet	(void)

Allocate a new Facet structure.

Returns:the newly allocated structure or NULL in case or error

Function: xmlSchemaValPredefTypeNode

int	xmlSchemaValPredefTypeNode	(xmlSchemaTypePtr type, 
const xmlChar * value,
xmlSchemaValPtr * val,
xmlNodePtr node)

Check that a value conforms to the lexical space of the predefined type. if true a value is computed and returned in @val.

type:the predefined type
value:the value to check
val:the return computed value
node:the node containing the value
Returns:0 if this validates, a positive error code number otherwise and -1 in case of internal or API error.

Function: xmlSchemaValidateFacet

int	xmlSchemaValidateFacet		(xmlSchemaTypePtr base, 
xmlSchemaFacetPtr facet,
const xmlChar * value,
xmlSchemaValPtr val)

Check a value against a facet condition

-
base:the base type
facet:the facet to check
value:the lexical repr of the value to validate
val:the precomputed value
Returns:0 if the element is schemas valid, a positive error code number otherwise and -1 in case of internal or API error.

Function: xmlSchemaValidatePredefinedType

int	xmlSchemaValidatePredefinedType	(xmlSchemaTypePtr type, 
const xmlChar * value,
xmlSchemaValPtr * val)
+
base:the base type
facet:the facet to check
value:the lexical repr of the value to validate
val:the precomputed value
Returns:0 if the element is schemas valid, a positive error code number otherwise and -1 in case of internal or API error.

Function: xmlSchemaValidateListSimpleTypeFacet

int	xmlSchemaValidateListSimpleTypeFacet	(xmlSchemaFacetPtr facet, 
const xmlChar * value,
unsigned long actualLen,
unsigned long * expectedLen)
+

Checks the value of a list simple type against a facet.

+
facet:the facet to check
value:the lexical repr of the value to validate
actualLen:the number of list items
expectedLen:the resulting expected number of list items
Returns:0 if the value is valid, a positive error code number otherwise and -1 in case of an internal error.

Function: xmlSchemaValidatePredefinedType

int	xmlSchemaValidatePredefinedType	(xmlSchemaTypePtr type, 
const xmlChar * value,
xmlSchemaValPtr * val)

Check that a value conforms to the lexical space of the predefined type. if true a value is computed and returned in @val.

type:the predefined type
value:the value to check
val:the return computed value
Returns:0 if this validates, a positive error code number otherwise and -1 in case of internal or API error.

Daniel Veillard

diff --git a/doc/libxml2-api.xml b/doc/libxml2-api.xml index 3455a6e1..98dbd41e 100644 --- a/doc/libxml2-api.xml +++ b/doc/libxml2-api.xml @@ -1030,93 +1030,158 @@ internal interfaces for XML Schemas internal interfaces for the XML Schemas handling and schema validity checking Daniel Veillard + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + - + - - - - - - - + + + - - + - - - - - - - - - - - - - - - + + + + - - - - - - - - - - + + - - + - - + + + + + + + + + + + + + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - - + + + - + + + + @@ -1127,19 +1192,23 @@ + + - + + + interfaces for thread handling @@ -1694,21 +1763,26 @@ error handling the API used to report errors Daniel Veillard + - + + + + + @@ -1718,6 +1792,8 @@ + + @@ -1727,6 +1803,8 @@ + + @@ -1738,7 +1816,7 @@ - + @@ -1767,7 +1845,8 @@ - + + @@ -1776,10 +1855,14 @@ + + + + @@ -1792,8 +1875,11 @@ + + + @@ -1811,15 +1897,18 @@ + + + @@ -1827,7 +1916,9 @@ - + + + @@ -1853,7 +1944,9 @@ + + @@ -1883,7 +1976,7 @@ - + @@ -1923,12 +2016,14 @@ + + @@ -1949,15 +2044,17 @@ - + + - + + @@ -1966,6 +2063,7 @@ + @@ -1997,6 +2095,7 @@ + @@ -2005,10 +2104,11 @@ + - + @@ -2037,6 +2137,7 @@ + @@ -2047,13 +2148,16 @@ + + + @@ -2064,6 +2168,7 @@ + @@ -2078,11 +2183,13 @@ + + @@ -2102,10 +2209,11 @@ - + - + + @@ -2119,15 +2227,18 @@ - - + + + - + + + @@ -2137,6 +2248,7 @@ + @@ -2152,22 +2264,28 @@ + + - + + + + + @@ -2185,6 +2303,8 @@ + + @@ -2194,12 +2314,18 @@ + + + + + + @@ -2214,7 +2340,8 @@ - + + @@ -2231,13 +2358,13 @@ - + - + @@ -2522,12 +2649,17 @@ Daniel Veillard + + - - + + + + + @@ -3468,22 +3600,22 @@ Special constant found in SAX2 blocks initialized fields - Ignore validation non definition on attributes + Ignore validation non definition on attributes Obsolete, not used anymore. - Skip unknown attribute from validation + Skip unknown attribute from validation Obsolete, not used anymore. - Apply strict validation rules on attributes + Apply strict validation rules on attributes Obsolete, not used anymore. - Ignore validation non definition on attributes + Used by wildcards. Validate if type found, don't worry if not found Skip unknown attribute from validation - Apply strict validation rules on attributes + Used by wildcards. Apply strict validation rules The attribute wildcard has been already builded. @@ -3500,7 +3632,7 @@ The attribute is optional. - The attribute is prohibited. + Used by wildcards. The attribute is prohibited. The attribute is required. @@ -3521,7 +3653,7 @@ the element is nillable - allow elements in no namespace + allow elements in no namespace Obsolete, not used anymore. the element is a reference to a type @@ -3541,18 +3673,46 @@ unknown facet handling + + the shema has "extension" in the set of finalDefault. + + + the shema has "list" in the set of finalDefault. + + + the shema has "restriction" in the set of finalDefault. + + + the shema has "union" in the set of finalDefault. + the shemas requires qualified attributes the shemas requires qualified elements + + the simple or complex type has a derivation method of "extension". the simple or complex type has a derivation method of "restriction". + + + + the complexType has a final of "extension". + + + the simpleType has a final of "list". + + + the simpleType/complexType has a final of "restriction". + + + the simpleType has a final of "union". + the type is global @@ -3562,6 +3722,18 @@ the complexType owns an attribute wildcard, i.e. it can be freed by the complexType + + the simpleType has a variety of "absent". + + + the simpleType has a variety of "union". + + + the simpleType has a variety of "list". + + + the simpleType has a variety of "union". + If the wildcard is complete. @@ -4051,7 +4223,7 @@ - + @@ -4362,6 +4534,28 @@ + + + + + + + + + + + + + + + + + + + + + + @@ -4422,9 +4616,24 @@ + + + + + + + + + + + + + + + @@ -4458,6 +4667,19 @@ + + + + + + + + + + + + + @@ -4484,9 +4706,64 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -4512,7 +4789,7 @@ - + @@ -4532,7 +4809,7 @@ - + @@ -5374,6 +5651,11 @@ actually an xmlCharEncoding'/> + + + + + @@ -5408,11 +5690,20 @@ actually an xmlCharEncoding'/> + + + + + + + + + @@ -11629,6 +11920,12 @@ actually an xmlCharEncoding'/> Cleanup the default XML Schemas type library + + LIBXML_SCHEMAS_ENABLED + Removes and normalize white spaces in the string + + + LIBXML_SCHEMAS_ENABLED Compare 2 values @@ -11680,6 +11977,24 @@ actually an xmlCharEncoding'/> + + LIBXML_SCHEMAS_ENABLED + Deallocates a wildcard structure. + + + + + LIBXML_SCHEMAS_ENABLED + + + + + + LIBXML_SCHEMAS_ENABLED + Gives you the type struct for a built-in type by its type id. + + + LIBXML_SCHEMAS_ENABLED Lookup a type in the default XML Schemas type library @@ -11692,6 +12007,13 @@ actually an xmlCharEncoding'/> Initialize the default XML Schemas type library + + LIBXML_SCHEMAS_ENABLED + + + + + LIBXML_SCHEMAS_ENABLED Create an XML Schemas parse context for that document. NB. The document may be modified during the parsing process. @@ -11771,6 +12093,15 @@ actually an xmlCharEncoding'/> + + LIBXML_SCHEMAS_ENABLED + Checks the value of a list simple type against a facet. + + + + + + LIBXML_SCHEMAS_ENABLED Check that a value conforms to the lexical space of the predefined type. if true a value is computed and returned in @val. diff --git a/doc/libxml2-refs.xml b/doc/libxml2-refs.xml index 907e1514..ec8c513f 100644 --- a/doc/libxml2-refs.xml +++ b/doc/libxml2-refs.xml @@ -688,6 +688,28 @@ + + + + + + + + + + + + + + + + + + + + + + @@ -748,9 +770,24 @@ + + + + + + + + + + + + + + + @@ -787,6 +824,9 @@ + + + @@ -797,6 +837,14 @@ + + + + + + + + @@ -805,6 +853,8 @@ + + @@ -835,17 +885,86 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -1053,8 +1172,10 @@ + + @@ -2197,12 +2318,15 @@ + + + @@ -2210,8 +2334,12 @@ + + + + @@ -2226,16 +2354,20 @@ + + + + @@ -3643,6 +3775,28 @@ + + + + + + + + + + + + + + + + + + + + + + @@ -3703,9 +3857,24 @@ + + + + + + + + + + + + + + + @@ -3742,6 +3911,9 @@ + + + @@ -3752,6 +3924,14 @@ + + + + + + + + @@ -3760,6 +3940,8 @@ + + @@ -3790,17 +3972,86 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -4010,8 +4261,10 @@ + + @@ -5188,12 +5441,15 @@ + + + @@ -5201,8 +5457,12 @@ + + + + @@ -5217,16 +5477,20 @@ + + + + @@ -6172,6 +6436,7 @@ + @@ -6529,6 +6794,8 @@ + + @@ -6968,9 +7235,11 @@ + + @@ -7254,6 +7523,10 @@ + + + + @@ -8642,6 +8915,7 @@ + @@ -8657,6 +8931,8 @@ + + @@ -8670,6 +8946,9 @@ + + + @@ -8684,6 +8963,9 @@ + + + @@ -10008,6 +10290,9 @@ + + + @@ -10018,6 +10303,14 @@ + + + + + + + + @@ -10026,17 +10319,67 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -10086,8 +10429,10 @@ + + @@ -10102,15 +10447,21 @@ + + + + + + @@ -11018,6 +11369,28 @@ + + + + + + + + + + + + + + + + + + + + + + @@ -11078,9 +11451,24 @@ + + + + + + + + + + + + + + + @@ -11117,6 +11505,27 @@ + + + + + + + + + + + + + + + + + + + + + @@ -11449,14 +11858,19 @@ + + + + + @@ -12651,6 +13065,7 @@ + @@ -12961,6 +13376,9 @@ + + + @@ -12975,6 +13393,9 @@ + + + @@ -13606,6 +14027,9 @@ + + + @@ -13818,7 +14242,6 @@ - @@ -14447,6 +14870,12 @@ + + + + + + @@ -14599,6 +15028,7 @@ + @@ -14770,6 +15200,8 @@ + + @@ -14802,8 +15234,6 @@ - - @@ -15003,6 +15433,7 @@ + @@ -15164,6 +15595,7 @@ + @@ -15769,6 +16201,9 @@ + + + @@ -15797,6 +16232,7 @@ + @@ -16168,6 +16604,9 @@ + + + @@ -16378,6 +16817,7 @@ + @@ -16589,6 +17029,10 @@ + + + + @@ -17122,9 +17566,14 @@ + + + + + @@ -17367,6 +17816,7 @@ + @@ -17787,6 +18237,8 @@ + + @@ -18281,6 +18733,9 @@ + + + @@ -18450,6 +18905,7 @@ + @@ -18920,6 +19376,7 @@ + @@ -19480,6 +19937,7 @@ + @@ -19526,7 +19984,9 @@ + + @@ -19548,9 +20008,11 @@ + + @@ -19713,6 +20175,10 @@ + + + + @@ -19720,6 +20186,12 @@ + + + + + + @@ -20343,6 +20815,7 @@ + @@ -21122,6 +21595,7 @@ + @@ -21132,6 +21606,7 @@ + @@ -21351,6 +21826,7 @@ + @@ -21446,6 +21922,8 @@ + + @@ -22212,7 +22690,6 @@ - @@ -22309,6 +22786,7 @@ + @@ -23036,6 +23514,7 @@ + @@ -24053,6 +24532,7 @@ + @@ -24091,6 +24571,7 @@ + @@ -24187,7 +24668,9 @@ + + @@ -24645,6 +25128,12 @@ + + + + + + @@ -24721,6 +25210,17 @@ + + + + + + + + + + + @@ -24885,6 +25385,7 @@ + @@ -25235,6 +25736,7 @@ + @@ -25985,6 +26487,9 @@ + + + @@ -26048,6 +26553,10 @@ + + + + @@ -26293,6 +26802,12 @@ + + + + + + @@ -26316,6 +26831,8 @@ + + @@ -26459,6 +26976,7 @@ + @@ -26489,6 +27007,12 @@ + + + + + + @@ -26565,6 +27089,9 @@ + + + @@ -26612,7 +27139,7 @@ - + @@ -27521,7 +28048,7 @@ - + @@ -27548,6 +28075,7 @@ + @@ -27597,8 +28125,8 @@ - - + + @@ -27616,9 +28144,10 @@ - - - + + + + diff --git a/elfgcchack.h b/elfgcchack.h index fed7fb67..215509d3 100644 --- a/elfgcchack.h +++ b/elfgcchack.h @@ -3836,6 +3836,12 @@ extern __typeof (xmlSchemaCleanupTypes) xmlSchemaCleanupTypes __attribute((alias #define xmlSchemaCleanupTypes xmlSchemaCleanupTypes__internal_alias #endif +#ifdef LIBXML_SCHEMAS_ENABLED +extern __typeof (xmlSchemaCollapseString) xmlSchemaCollapseString__internal_alias __attribute((visibility("hidden"))); +extern __typeof (xmlSchemaCollapseString) xmlSchemaCollapseString __attribute((alias("xmlSchemaCollapseString__internal_alias"))); +#define xmlSchemaCollapseString xmlSchemaCollapseString__internal_alias +#endif + #ifdef LIBXML_SCHEMAS_ENABLED extern __typeof (xmlSchemaCompareValues) xmlSchemaCompareValues__internal_alias __attribute((visibility("hidden"))); extern __typeof (xmlSchemaCompareValues) xmlSchemaCompareValues __attribute((alias("xmlSchemaCompareValues__internal_alias"))); @@ -3886,6 +3892,24 @@ extern __typeof (xmlSchemaFreeValue) xmlSchemaFreeValue __attribute((alias("xmlS #define xmlSchemaFreeValue xmlSchemaFreeValue__internal_alias #endif +#ifdef LIBXML_SCHEMAS_ENABLED +extern __typeof (xmlSchemaFreeWildcard) xmlSchemaFreeWildcard__internal_alias __attribute((visibility("hidden"))); +extern __typeof (xmlSchemaFreeWildcard) xmlSchemaFreeWildcard __attribute((alias("xmlSchemaFreeWildcard__internal_alias"))); +#define xmlSchemaFreeWildcard xmlSchemaFreeWildcard__internal_alias +#endif + +#ifdef LIBXML_SCHEMAS_ENABLED +extern __typeof (xmlSchemaGetBuiltInListSimpleTypeItemType) xmlSchemaGetBuiltInListSimpleTypeItemType__internal_alias __attribute((visibility("hidden"))); +extern __typeof (xmlSchemaGetBuiltInListSimpleTypeItemType) xmlSchemaGetBuiltInListSimpleTypeItemType __attribute((alias("xmlSchemaGetBuiltInListSimpleTypeItemType__internal_alias"))); +#define xmlSchemaGetBuiltInListSimpleTypeItemType xmlSchemaGetBuiltInListSimpleTypeItemType__internal_alias +#endif + +#ifdef LIBXML_SCHEMAS_ENABLED +extern __typeof (xmlSchemaGetBuiltInType) xmlSchemaGetBuiltInType__internal_alias __attribute((visibility("hidden"))); +extern __typeof (xmlSchemaGetBuiltInType) xmlSchemaGetBuiltInType __attribute((alias("xmlSchemaGetBuiltInType__internal_alias"))); +#define xmlSchemaGetBuiltInType xmlSchemaGetBuiltInType__internal_alias +#endif + #ifdef LIBXML_SCHEMAS_ENABLED extern __typeof (xmlSchemaGetPredefinedType) xmlSchemaGetPredefinedType__internal_alias __attribute((visibility("hidden"))); extern __typeof (xmlSchemaGetPredefinedType) xmlSchemaGetPredefinedType __attribute((alias("xmlSchemaGetPredefinedType__internal_alias"))); @@ -3898,6 +3922,12 @@ extern __typeof (xmlSchemaInitTypes) xmlSchemaInitTypes __attribute((alias("xmlS #define xmlSchemaInitTypes xmlSchemaInitTypes__internal_alias #endif +#ifdef LIBXML_SCHEMAS_ENABLED +extern __typeof (xmlSchemaIsBuiltInTypeFacet) xmlSchemaIsBuiltInTypeFacet__internal_alias __attribute((visibility("hidden"))); +extern __typeof (xmlSchemaIsBuiltInTypeFacet) xmlSchemaIsBuiltInTypeFacet __attribute((alias("xmlSchemaIsBuiltInTypeFacet__internal_alias"))); +#define xmlSchemaIsBuiltInTypeFacet xmlSchemaIsBuiltInTypeFacet__internal_alias +#endif + #ifdef LIBXML_SCHEMAS_ENABLED extern __typeof (xmlSchemaNewDocParserCtxt) xmlSchemaNewDocParserCtxt__internal_alias __attribute((visibility("hidden"))); extern __typeof (xmlSchemaNewDocParserCtxt) xmlSchemaNewDocParserCtxt __attribute((alias("xmlSchemaNewDocParserCtxt__internal_alias"))); @@ -3964,6 +3994,12 @@ extern __typeof (xmlSchemaValidateFacet) xmlSchemaValidateFacet __attribute((ali #define xmlSchemaValidateFacet xmlSchemaValidateFacet__internal_alias #endif +#ifdef LIBXML_SCHEMAS_ENABLED +extern __typeof (xmlSchemaValidateListSimpleTypeFacet) xmlSchemaValidateListSimpleTypeFacet__internal_alias __attribute((visibility("hidden"))); +extern __typeof (xmlSchemaValidateListSimpleTypeFacet) xmlSchemaValidateListSimpleTypeFacet __attribute((alias("xmlSchemaValidateListSimpleTypeFacet__internal_alias"))); +#define xmlSchemaValidateListSimpleTypeFacet xmlSchemaValidateListSimpleTypeFacet__internal_alias +#endif + #ifdef LIBXML_SCHEMAS_ENABLED extern __typeof (xmlSchemaValidatePredefinedType) xmlSchemaValidatePredefinedType__internal_alias __attribute((visibility("hidden"))); extern __typeof (xmlSchemaValidatePredefinedType) xmlSchemaValidatePredefinedType __attribute((alias("xmlSchemaValidatePredefinedType__internal_alias"))); diff --git a/include/libxml/schemasInternals.h b/include/libxml/schemasInternals.h index ee14ceb2..84334994 100644 --- a/include/libxml/schemasInternals.h +++ b/include/libxml/schemasInternals.h @@ -24,12 +24,61 @@ extern "C" { #endif +typedef enum { + XML_SCHEMAS_UNKNOWN = 0, + XML_SCHEMAS_STRING, + XML_SCHEMAS_NORMSTRING, + XML_SCHEMAS_DECIMAL, + XML_SCHEMAS_TIME, + XML_SCHEMAS_GDAY, + XML_SCHEMAS_GMONTH, + XML_SCHEMAS_GMONTHDAY, + XML_SCHEMAS_GYEAR, + XML_SCHEMAS_GYEARMONTH, + XML_SCHEMAS_DATE, + XML_SCHEMAS_DATETIME, + XML_SCHEMAS_DURATION, + XML_SCHEMAS_FLOAT, + XML_SCHEMAS_DOUBLE, + XML_SCHEMAS_BOOLEAN, + XML_SCHEMAS_TOKEN, + XML_SCHEMAS_LANGUAGE, + XML_SCHEMAS_NMTOKEN, + XML_SCHEMAS_NMTOKENS, + XML_SCHEMAS_NAME, + XML_SCHEMAS_QNAME, + XML_SCHEMAS_NCNAME, + XML_SCHEMAS_ID, + XML_SCHEMAS_IDREF, + XML_SCHEMAS_IDREFS, + XML_SCHEMAS_ENTITY, + XML_SCHEMAS_ENTITIES, + XML_SCHEMAS_NOTATION, + XML_SCHEMAS_ANYURI, + XML_SCHEMAS_INTEGER, + XML_SCHEMAS_NPINTEGER, + XML_SCHEMAS_NINTEGER, + XML_SCHEMAS_NNINTEGER, + XML_SCHEMAS_PINTEGER, + XML_SCHEMAS_INT, + XML_SCHEMAS_UINT, + XML_SCHEMAS_LONG, + XML_SCHEMAS_ULONG, + XML_SCHEMAS_SHORT, + XML_SCHEMAS_USHORT, + XML_SCHEMAS_BYTE, + XML_SCHEMAS_UBYTE, + XML_SCHEMAS_HEXBINARY, + XML_SCHEMAS_BASE64BINARY, + XML_SCHEMAS_ANYTYPE, + XML_SCHEMAS_ANYSIMPLETYPE +} xmlSchemaValType; /* * XML Schemas defines multiple type of types. */ typedef enum { - XML_SCHEMA_TYPE_BASIC = 1, + XML_SCHEMA_TYPE_BASIC = 1, /* A built-in datatype */ XML_SCHEMA_TYPE_ANY, XML_SCHEMA_TYPE_FACET, XML_SCHEMA_TYPE_SIMPLE, @@ -70,7 +119,7 @@ typedef enum { XML_SCHEMA_CONTENT_ELEMENTS, XML_SCHEMA_CONTENT_MIXED, XML_SCHEMA_CONTENT_SIMPLE, - XML_SCHEMA_CONTENT_MIXED_OR_ELEMENTS, + XML_SCHEMA_CONTENT_MIXED_OR_ELEMENTS, /* obsolete, not used */ XML_SCHEMA_CONTENT_BASIC, XML_SCHEMA_CONTENT_ANY } xmlSchemaContentType; @@ -98,41 +147,47 @@ struct _xmlSchemaAnnot { * XML_SCHEMAS_ANYATTR_SKIP: * * Skip unknown attribute from validation + * Obsolete, not used anymore. */ #define XML_SCHEMAS_ANYATTR_SKIP 1 /** * XML_SCHEMAS_ANYATTR_LAX: * * Ignore validation non definition on attributes + * Obsolete, not used anymore. */ #define XML_SCHEMAS_ANYATTR_LAX 2 /** * XML_SCHEMAS_ANYATTR_STRICT: * * Apply strict validation rules on attributes + * Obsolete, not used anymore. */ #define XML_SCHEMAS_ANYATTR_STRICT 3 /** * XML_SCHEMAS_ANY_SKIP: * - * Skip unknown attribute from validation + * Skip unknown attribute from validation */ #define XML_SCHEMAS_ANY_SKIP 1 /** * XML_SCHEMAS_ANY_LAX: * - * Ignore validation non definition on attributes + * Used by wildcards. + * Validate if type found, don't worry if not found */ #define XML_SCHEMAS_ANY_LAX 2 /** * XML_SCHEMAS_ANY_STRICT: * - * Apply strict validation rules on attributes + * Used by wildcards. + * Apply strict validation rules */ #define XML_SCHEMAS_ANY_STRICT 3 /** * XML_SCHEMAS_ATTR_USE_PROHIBITED: * + * Used by wildcards. * The attribute is prohibited. */ #define XML_SCHEMAS_ATTR_USE_PROHIBITED 0 @@ -274,6 +329,28 @@ struct _xmlSchemaAttributeGroup { xmlSchemaWildcardPtr attributeWildcard; }; +/** + * xmlSchemaTypeLink: + * Used to build a list of types (e.g. member types of + * simpleType with variety "union"). + */ +typedef struct _xmlSchemaTypeLink xmlSchemaTypeLink; +typedef xmlSchemaTypeLink *xmlSchemaTypeLinkPtr; +struct _xmlSchemaTypeLink { + struct _xmlSchemaTypeLink *next;/* the next type link ... */ + xmlSchemaTypePtr type;/* the linked type*/ +}; + +/** + * xmlSchemaFacetLink: + * Used to build a list of facets. + */ +typedef struct _xmlSchemaFacetLink xmlSchemaFacetLink; +typedef xmlSchemaFacetLink *xmlSchemaFacetLinkPtr; +struct _xmlSchemaFacetLink { + struct _xmlSchemaFacetLink *next;/* the next facet link ... */ + xmlSchemaFacetPtr facet;/* the linked facet */ +}; /** * XML_SCHEMAS_TYPE_MIXED: @@ -306,6 +383,66 @@ struct _xmlSchemaAttributeGroup { * it can be freed by the complexType */ #define XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD 1 << 4 +/** + * XML_SCHEMAS_TYPE_VARIETY_ABSENT: + * + * the simpleType has a variety of "absent". + */ +#define XML_SCHEMAS_TYPE_VARIETY_ABSENT 1 << 5 +/** + * XML_SCHEMAS_TYPE_VARIETY_LIST: + * + * the simpleType has a variety of "list". + */ +#define XML_SCHEMAS_TYPE_VARIETY_LIST 1 << 6 +/** + * XML_SCHEMAS_TYPE_VARIETY_UNION: + * + * the simpleType has a variety of "union". + */ +#define XML_SCHEMAS_TYPE_VARIETY_UNION 1 << 7 +/** + * XML_SCHEMAS_TYPE_VARIETY_ATOMIC: + * + * the simpleType has a variety of "union". + */ +#define XML_SCHEMAS_TYPE_VARIETY_ATOMIC 1 << 8 +/** + * XML_SCHEMAS_TYPE_FINAL_EXTENSION: + * + * the complexType has a final of "extension". + */ +#define XML_SCHEMAS_TYPE_FINAL_EXTENSION 1 << 9 +/** + * XML_SCHEMAS_TYPE_FINAL_RESTRICTION: + * + * the simpleType/complexType has a final of "restriction". + */ +#define XML_SCHEMAS_TYPE_FINAL_RESTRICTION 1 << 10 +/** + * XML_SCHEMAS_TYPE_FINAL_LIST: + * + * the simpleType has a final of "list". + */ +#define XML_SCHEMAS_TYPE_FINAL_LIST 1 << 11 +/** + * XML_SCHEMAS_TYPE_FINAL_UNION: + * + * the simpleType has a final of "union". + */ +#define XML_SCHEMAS_TYPE_FINAL_UNION 1 << 12 +/** + * XML_SCHEMAS_TYPE_FINAL_UNION: + * + * the simpleType has a final of "union". + */ +#define XML_SCHEMAS_TYPE_FINAL_DEFAULT 1 << 13 +/** + * XML_SCHEMAS_TYPE_FINAL_UNION: + * + * the simpleType has a final of "union". + */ +#define XML_SCHEMAS_TYPE_BUILTIN_PRIMITIVE 1 << 14 /** * _xmlSchemaType: @@ -336,6 +473,9 @@ struct _xmlSchemaType { int recurse; xmlSchemaAttributeLinkPtr attributeUses; xmlSchemaWildcardPtr attributeWildcard; + int builtInType; + xmlSchemaTypeLinkPtr memberTypes; + xmlSchemaFacetLinkPtr facetSet; }; /* @@ -392,6 +532,7 @@ struct _xmlSchemaType { * XML_SCHEMAS_ELEM_NSDEFAULT: * * allow elements in no namespace + * Obsolete, not used anymore. */ #define XML_SCHEMAS_ELEM_NSDEFAULT 1 << 7 @@ -448,7 +589,6 @@ struct _xmlSchemaElement { * collapse the types of the facet */ #define XML_SCHEMAS_FACET_COLLAPSE 3 - /** * A facet definition. */ @@ -488,7 +628,31 @@ struct _xmlSchemaNotation { * * the shemas requires qualified attributes */ -#define XML_SCHEMAS_QUALIF_ATTR 1 << 1 +#define XML_SCHEMAS_QUALIF_ATTR 1 << 1 +/** + * XML_SCHEMAS_FINAL_DEFAULT_EXTENSION: + * + * the shema has "extension" in the set of finalDefault. + */ +#define XML_SCHEMAS_FINAL_DEFAULT_EXTENSION 1 << 2 +/** + * XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION: + * + * the shema has "restriction" in the set of finalDefault. + */ +#define XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION 1 << 3 +/** + * XML_SCHEMAS_FINAL_DEFAULT_LIST: + * + * the shema has "list" in the set of finalDefault. + */ +#define XML_SCHEMAS_FINAL_DEFAULT_LIST 1 << 4 +/** + * XML_SCHEMAS_FINAL_DEFAULT_UNION: + * + * the shema has "union" in the set of finalDefault. + */ +#define XML_SCHEMAS_FINAL_DEFAULT_UNION 1 << 5 /** * _xmlSchema: * @@ -519,6 +683,7 @@ struct _xmlSchema { }; XMLPUBFUN void XMLCALL xmlSchemaFreeType (xmlSchemaTypePtr type); +XMLPUBFUN void XMLCALL xmlSchemaFreeWildcard(xmlSchemaWildcardPtr wildcard); #ifdef __cplusplus } diff --git a/include/libxml/xmlerror.h b/include/libxml/xmlerror.h index e2f7ba55..513c244e 100644 --- a/include/libxml/xmlerror.h +++ b/include/libxml/xmlerror.h @@ -597,7 +597,28 @@ typedef enum { XML_SCHEMAV_ATTRINVALID, /* 1820 */ XML_SCHEMAV_VALUE, /* 1821 */ XML_SCHEMAV_FACET, /* 1822 */ - XML_XPTR_UNKNOWN_SCHEME = 1900, + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_1, /* 1823 */ + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_2, /* 1824 */ + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_3, /* 1825 */ + XML_SCHEMAV_CVC_TYPE_3_1_1, /* 1826 */ + XML_SCHEMAV_CVC_TYPE_3_1_2, /* 1827 */ + XML_SCHEMAV_CVC_FACET_VALID, /* 1828 */ + XML_SCHEMAV_CVC_LENGTH_VALID, /* 1829 */ + XML_SCHEMAV_CVC_MINLENGTH_VALID, /* 1830 */ + XML_SCHEMAV_CVC_MAXLENGTH_VALID, /* 1831 */ + XML_SCHEMAV_CVC_MININCLUSIVE_VALID, /* 1832 */ + XML_SCHEMAV_CVC_MAXINCLUSIVE_VALID, /* 1833 */ + XML_SCHEMAV_CVC_MINEXCLUSIVE_VALID, /* 1834 */ + XML_SCHEMAV_CVC_MAXEXCLUSIVE_VALID, /* 1835 */ + XML_SCHEMAV_CVC_TOTALDIGITS_VALID, /* 1836 */ + XML_SCHEMAV_CVC_FRACTIONDIGITS_VALID, /* 1837 */ + XML_SCHEMAV_CVC_PATTERN_VALID, /* 1838 */ + XML_SCHEMAV_CVC_ENUMERATION_VALID, /* 1839 */ + XML_SCHEMAV_CVC_COMPLEX_TYPE_2_1, /* 1840 */ + XML_SCHEMAV_CVC_COMPLEX_TYPE_2_2, /* 1841 */ + XML_SCHEMAV_CVC_COMPLEX_TYPE_2_3, /* 1842 */ + XML_SCHEMAV_CVC_COMPLEX_TYPE_2_4, /* 1843 */ + XML_XPTR_UNKNOWN_SCHEME = 1900, XML_XPTR_CHILDSEQ_START, /* 1901 */ XML_XPTR_EVAL_FAILED, /* 1902 */ XML_XPTR_EXTRA_OBJECTS, /* 1903 */ @@ -610,7 +631,44 @@ typedef enum { XML_FTP_ACCNT, /* 2002 */ XML_HTTP_URL_SYNTAX = 2020, XML_HTTP_USE_IP, /* 2021 */ - XML_HTTP_UNKNOWN_HOST /* 2022 */ + XML_HTTP_UNKNOWN_HOST, /* 2022 */ + XML_SCHEMAP_SRC_SIMPLE_TYPE_1 = 3000, + XML_SCHEMAP_SRC_SIMPLE_TYPE_2, /* 3001 */ + XML_SCHEMAP_SRC_SIMPLE_TYPE_3, /* 3002 */ + XML_SCHEMAP_SRC_SIMPLE_TYPE_4, /* 3003 */ + XML_SCHEMAP_SRC_RESOLVE, /* 3004 */ + XML_SCHEMAP_SRC_RESTRICTION_BASE_OR_SIMPLETYPE, /* 3004 */ + XML_SCHEMAP_SRC_LIST_ITEMTYPE_OR_SIMPLETYPE, /* 3005 */ + XML_SCHEMAP_SRC_UNION_MEMBERTYPES_OR_SIMPLETYPES, /* 3006 */ + XML_SCHEMAP_ST_PROPS_CORRECT_1, /* 3007 */ + XML_SCHEMAP_ST_PROPS_CORRECT_2, /* 3008 */ + XML_SCHEMAP_ST_PROPS_CORRECT_3, /* 3009 */ + XML_SCHEMAP_COS_ST_RESTRICTS_1_1, /* 3010 */ + XML_SCHEMAP_COS_ST_RESTRICTS_1_2, /* 3011 */ + XML_SCHEMAP_COS_ST_RESTRICTS_1_3_1, /* 3012 */ + XML_SCHEMAP_COS_ST_RESTRICTS_1_3_2, /* 3013 */ + XML_SCHEMAP_COS_ST_RESTRICTS_2_1, /* 3014 */ + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_1_1, /* 3015 */ + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_1_2, /* 3016 */ + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_1, /* 3017 */ + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_2, /* 3018 */ + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_3, /* 3019 */ + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_4, /* 3021 */ + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_5, /* 3022 */ + XML_SCHEMAP_COS_ST_RESTRICTS_3_1, /* 3023 */ + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_1, /* 3024 */ + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_1_2, /* 3025 */ + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_2, /* 3026 */ + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_1, /* 3027 */ + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_3, /* 3028 */ + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_4, /* 3029 */ + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_5, /* 3030 */ + XML_SCHEMAP_COS_ST_DERIVED_OK_2_1, /* 3031 */ + XML_SCHEMAP_COS_ST_DERIVED_OK_2_2, /* 3032 */ + XML_SCHEMAP_S4S_ELEM_NOT_ALLOWED, /* 3033 */ + XML_SCHEMAP_S4S_ELEM_MISSING, /* 3034 */ + XML_SCHEMAP_S4S_ATTR_NOT_ALLOWED, /* 3035 */ + XML_SCHEMAP_S4S_ATTR_MISSING /* 3036 */ } xmlParserErrors; /** diff --git a/include/libxml/xmlschemastypes.h b/include/libxml/xmlschemastypes.h index 4514c593..b81e9b45 100644 --- a/include/libxml/xmlschemastypes.h +++ b/include/libxml/xmlschemastypes.h @@ -58,6 +58,20 @@ XMLPUBFUN void XMLCALL XMLPUBFUN int XMLCALL xmlSchemaCompareValues (xmlSchemaValPtr x, xmlSchemaValPtr y); +XMLPUBFUN xmlSchemaTypePtr XMLCALL + xmlSchemaGetBuiltInListSimpleTypeItemType(xmlSchemaTypePtr type); +XMLPUBFUN int XMLCALL +xmlSchemaValidateListSimpleTypeFacet(xmlSchemaFacetPtr facet, + const xmlChar *value, + unsigned long actualLen, + unsigned long *expectedLen); +XMLPUBFUN xmlSchemaTypePtr XMLCALL +xmlSchemaGetBuiltInType(xmlSchemaValType type); +XMLPUBFUN int XMLCALL +xmlSchemaIsBuiltInTypeFacet(xmlSchemaTypePtr type, + int facetType); +XMLPUBFUN xmlChar * XMLCALL +xmlSchemaCollapseString(const xmlChar *value); #ifdef __cplusplus } diff --git a/python/libxml2class.txt b/python/libxml2class.txt index 87494bd2..cd098625 100644 --- a/python/libxml2class.txt +++ b/python/libxml2class.txt @@ -220,6 +220,7 @@ regexpCompile() # functions from module xmlschemastypes schemaCleanupTypes() +schemaCollapseString() schemaInitTypes() # functions from module xmlstring diff --git a/result/schemas/anyAttr-processContents-err1_0_0.err b/result/schemas/anyAttr-processContents-err1_0_0.err index 3152bc65..b09e2687 100644 --- a/result/schemas/anyAttr-processContents-err1_0_0.err +++ b/result/schemas/anyAttr-processContents-err1_0_0.err @@ -1,3 +1,3 @@ -./test/schemas/anyAttr-processContents-err1_0.xml:11: element elem.lax: Schemas validity error : Failed to validate basic type language -./test/schemas/anyAttr-processContents-err1_0.xml:11: element elem.lax: Schemas validity error : Attribute bar on elem.lax does not match type -./test/schemas/anyAttr-processContents-err1_0.xml:12: element elem.strict: Schemas validity error : Attribute barB on elem.strict is unknown +./test/schemas/anyAttr-processContents-err1_0.xml:11: element elem.lax: Schemas validity error : The value is not valid. +./test/schemas/anyAttr-processContents-err1_0.xml:11: element elem.lax: Schemas validity error : Attribute "bar": the value is not valid. +./test/schemas/anyAttr-processContents-err1_0.xml:12: element elem.strict: Schemas validity error : Attribute "barB" is not allowed. diff --git a/result/schemas/attruse_0_1.err b/result/schemas/attruse_0_1.err index 60baa1f4..19ef72a5 100644 --- a/result/schemas/attruse_0_1.err +++ b/result/schemas/attruse_0_1.err @@ -1 +1 @@ -./test/schemas/attruse_0_1.xml:3: element barA: Schemas validity error : Attribute attr on barA is required but missing +./test/schemas/attruse_0_1.xml:3: element barA: Schemas validity error : Attribute "attr" is required but missing. diff --git a/result/schemas/attruse_0_2.err b/result/schemas/attruse_0_2.err index 79dcc8a3..d68db7b3 100644 --- a/result/schemas/attruse_0_2.err +++ b/result/schemas/attruse_0_2.err @@ -1 +1 @@ -./test/schemas/attruse_0_2.xml:6: element barC: Schemas validity error : Attribute attr on barC is unknown +./test/schemas/attruse_0_2.xml:6: element barC: Schemas validity error : Attribute "attr" is not allowed. diff --git a/result/schemas/bug143951_0_0 b/result/schemas/bug143951_0_0 new file mode 100644 index 00000000..e69de29b diff --git a/result/schemas/bug143951_0_0.err b/result/schemas/bug143951_0_0.err new file mode 100644 index 00000000..5f9518bb --- /dev/null +++ b/result/schemas/bug143951_0_0.err @@ -0,0 +1,3 @@ +I/O warning : failed to load external entity "test/schemas/bug143951.imp" +Schemas parser error : xmlSchemaParse: could not load test/schemas/bug143951.imp +Schemas parser error : failed to import schema at location test/schemas/bug143951.imp diff --git a/result/schemas/cos-st-restricts-1-2-err_0_0 b/result/schemas/cos-st-restricts-1-2-err_0_0 new file mode 100644 index 00000000..dc342539 --- /dev/null +++ b/result/schemas/cos-st-restricts-1-2-err_0_0 @@ -0,0 +1 @@ +./test/schemas/cos-st-restricts-1-2-err_0.xml fails to validate diff --git a/result/schemas/cos-st-restricts-1-2-err_0_0.err b/result/schemas/cos-st-restricts-1-2-err_0_0.err new file mode 100644 index 00000000..44a5cba8 --- /dev/null +++ b/result/schemas/cos-st-restricts-1-2-err_0_0.err @@ -0,0 +1 @@ +./test/schemas/cos-st-restricts-1-2-err_0.xml:3: element foo: Schemas validity error : The value with length "2" is not facet-valid with respect to length = "3". diff --git a/result/schemas/extension1_0_1.err b/result/schemas/extension1_0_1.err index 7997de7e..84d16bc4 100644 --- a/result/schemas/extension1_0_1.err +++ b/result/schemas/extension1_0_1.err @@ -1 +1 @@ -./test/schemas/extension1_1.xml:1: element title: Schemas validity error : Attribute langue on title is unknown +./test/schemas/extension1_1.xml:1: element title: Schemas validity error : Attribute "langue" is not allowed. diff --git a/result/schemas/extension1_0_2.err b/result/schemas/extension1_0_2.err index 516d2003..4eaa6635 100644 --- a/result/schemas/extension1_0_2.err +++ b/result/schemas/extension1_0_2.err @@ -1 +1 @@ -./test/schemas/extension1_2.xml:1: element title: Schemas validity error : Element title: child salut should not be present +./test/schemas/extension1_2.xml:1: element title: Schemas validity error : Element children are not allowed, because the content type is a simple type. diff --git a/result/schemas/facet-unionST-err1_0_0 b/result/schemas/facet-unionST-err1_0_0 new file mode 100644 index 00000000..baf8280f --- /dev/null +++ b/result/schemas/facet-unionST-err1_0_0 @@ -0,0 +1 @@ +./test/schemas/facet-unionST-err1_0.xml fails to validate diff --git a/result/schemas/facet-unionST-err1_0_0.err b/result/schemas/facet-unionST-err1_0_0.err new file mode 100644 index 00000000..f757848b --- /dev/null +++ b/result/schemas/facet-unionST-err1_0_0.err @@ -0,0 +1,2 @@ +./test/schemas/facet-unionST-err1_0.xml:3: element foo: Schemas validity error : The value failed to validate against the facet "enumeration". +./test/schemas/facet-unionST-err1_0.xml:3: element foo: Schemas validity error : The value is not valid. diff --git a/result/schemas/hexbinary_0_1.err b/result/schemas/hexbinary_0_1.err index c134ddbf..b9f19330 100644 --- a/result/schemas/hexbinary_0_1.err +++ b/result/schemas/hexbinary_0_1.err @@ -1,9 +1,12 @@ -./test/schemas/hexbinary_1.xml:4: element hex: Schemas validity error : Element hex: failed to validate basic type hexBinary -./test/schemas/hexbinary_1.xml:5: element hex: Schemas validity error : Element hex: failed to validate basic type hexBinary -./test/schemas/hexbinary_1.xml:6: element hex: Schemas validity error : Element hex: failed to validate basic type hexBinary -./test/schemas/hexbinary_1.xml:7: element hex: Schemas validity error : Element hex: failed to validate basic type hexBinary -./test/schemas/hexbinary_1.xml:8: element hex: Schemas validity error : Element hex: failed to validate basic type hexBinary -./test/schemas/hexbinary_1.xml:9: element hex: Schemas validity error : Element hex: failed to validate basic type hexBinary -./test/schemas/hexbinary_1.xml:11: element hex2: Schemas validity error : Failed to validate type with facet maxLength -./test/schemas/hexbinary_1.xml:13: element hex3: Schemas validity error : Failed to validate type with facet length -./test/schemas/hexbinary_1.xml:14: element hex3: Schemas validity error : Failed to validate type with facet length +./test/schemas/hexbinary_1.xml:4: element hex: Schemas validity error : The value is not valid. +./test/schemas/hexbinary_1.xml:5: element hex: Schemas validity error : The value is not valid. +./test/schemas/hexbinary_1.xml:6: element hex: Schemas validity error : The value is not valid. +./test/schemas/hexbinary_1.xml:7: element hex: Schemas validity error : The value is not valid. +./test/schemas/hexbinary_1.xml:8: element hex: Schemas validity error : The value is not valid. +./test/schemas/hexbinary_1.xml:9: element hex: Schemas validity error : The value is not valid. +./test/schemas/hexbinary_1.xml:11: element hex2: Schemas validity error : The value failed to validate against the facet "maxLength". +./test/schemas/hexbinary_1.xml:11: element hex2: Schemas validity error : The value is not valid. +./test/schemas/hexbinary_1.xml:13: element hex3: Schemas validity error : The value failed to validate against the facet "length". +./test/schemas/hexbinary_1.xml:13: element hex3: Schemas validity error : The value is not valid. +./test/schemas/hexbinary_1.xml:14: element hex3: Schemas validity error : The value failed to validate against the facet "length". +./test/schemas/hexbinary_1.xml:14: element hex3: Schemas validity error : The value is not valid. diff --git a/result/schemas/length3_0_0.err b/result/schemas/length3_0_0.err index 048a3c62..753136f7 100644 --- a/result/schemas/length3_0_0.err +++ b/result/schemas/length3_0_0.err @@ -1 +1 @@ -./test/schemas/length3_0.xsd:5: element element: Schemas parser error : Schemas: element size type non-positive-integer not found +./test/schemas/length3_0.xsd:5: element element: Schemas parser error : Element "size": the QName "non-positive-integer" of the attribute "type" does not resolve to a schema component. diff --git a/result/schemas/ns0_0_3.err b/result/schemas/ns0_0_3.err index 6578c9ef..25e5bf3c 100644 --- a/result/schemas/ns0_0_3.err +++ b/result/schemas/ns0_0_3.err @@ -1 +1 @@ -./test/schemas/ns0_3.xml:1: element foo: Schemas validity error : Attribute id on foo is unknown +./test/schemas/ns0_3.xml:1: element foo: Schemas validity error : Attribute "id" is not allowed. diff --git a/result/schemas/ns0_0_4.err b/result/schemas/ns0_0_4.err index 14b949db..fc6efc06 100644 --- a/result/schemas/ns0_0_4.err +++ b/result/schemas/ns0_0_4.err @@ -1 +1 @@ -./test/schemas/ns0_4.xml:2: element foo: Schemas validity error : Attribute id on foo is unknown +./test/schemas/ns0_4.xml:2: element foo: Schemas validity error : Attribute "id" is not allowed. diff --git a/result/schemas/ns0_1_0.err b/result/schemas/ns0_1_0.err index 6e5ba4af..83b2fc97 100644 --- a/result/schemas/ns0_1_0.err +++ b/result/schemas/ns0_1_0.err @@ -1 +1 @@ -./test/schemas/ns0_0.xml:1: element foo: Schemas validity error : Attribute id on foo is unknown +./test/schemas/ns0_0.xml:1: element foo: Schemas validity error : Attribute "id" is not allowed. diff --git a/result/schemas/ns0_1_1.err b/result/schemas/ns0_1_1.err index 008b122a..f61c19b9 100644 --- a/result/schemas/ns0_1_1.err +++ b/result/schemas/ns0_1_1.err @@ -1 +1 @@ -./test/schemas/ns0_1.xml:1: element foo: Schemas validity error : Attribute id on foo is unknown +./test/schemas/ns0_1.xml:1: element foo: Schemas validity error : Attribute "id" is not allowed. diff --git a/result/schemas/vdv-first4_0_1.err b/result/schemas/vdv-first4_0_1.err index 6eafb621..155f9067 100644 --- a/result/schemas/vdv-first4_0_1.err +++ b/result/schemas/vdv-first4_0_1.err @@ -1 +1 @@ -./test/schemas/vdv-first4_1.xml:14: element born: Schemas validity error : Failed to validate basic type date +./test/schemas/vdv-first4_1.xml:14: element born: Schemas validity error : The value is not valid. diff --git a/result/schemas/vdv-first4_0_2.err b/result/schemas/vdv-first4_0_2.err index d37271a2..42a19009 100644 --- a/result/schemas/vdv-first4_0_2.err +++ b/result/schemas/vdv-first4_0_2.err @@ -1 +1,2 @@ -./test/schemas/vdv-first4_2.xml:24: element born: Schemas validity error : Failed to validate type with facet pattern +./test/schemas/vdv-first4_2.xml:24: element born: Schemas validity error : The value failed to validate against the facet "pattern". +./test/schemas/vdv-first4_2.xml:24: element born: Schemas validity error : The value is not valid. diff --git a/test/schemas/bug143951_0.xml b/test/schemas/bug143951_0.xml new file mode 100644 index 00000000..a742a0d2 --- /dev/null +++ b/test/schemas/bug143951_0.xml @@ -0,0 +1,9 @@ + + + $File: //depot/NNL/R1.0_SandM_Dev/Projects/SandM/src/uisupport +/xml/cliTestCommands.xml $ + + diff --git a/test/schemas/bug143951_0.xsd b/test/schemas/bug143951_0.xsd new file mode 100644 index 00000000..d5c9511d --- /dev/null +++ b/test/schemas/bug143951_0.xsd @@ -0,0 +1,17 @@ + + + + + + + + + + + + diff --git a/test/schemas/cos-st-restricts-1-2-err_0.xml b/test/schemas/cos-st-restricts-1-2-err_0.xml new file mode 100644 index 00000000..6f60e5b5 --- /dev/null +++ b/test/schemas/cos-st-restricts-1-2-err_0.xml @@ -0,0 +1,3 @@ + +1 2 diff --git a/test/schemas/cos-st-restricts-1-2-err_0.xsd b/test/schemas/cos-st-restricts-1-2-err_0.xsd new file mode 100644 index 00000000..9d3fabff --- /dev/null +++ b/test/schemas/cos-st-restricts-1-2-err_0.xsd @@ -0,0 +1,30 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/test/schemas/facet-unionST-err1_0.xml b/test/schemas/facet-unionST-err1_0.xml new file mode 100644 index 00000000..aa96e203 --- /dev/null +++ b/test/schemas/facet-unionST-err1_0.xml @@ -0,0 +1,4 @@ + +large + diff --git a/test/schemas/facet-unionST-err1_0.xsd b/test/schemas/facet-unionST-err1_0.xsd new file mode 100644 index 00000000..476668bc --- /dev/null +++ b/test/schemas/facet-unionST-err1_0.xsd @@ -0,0 +1,27 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/win32/libxml2.def.src b/win32/libxml2.def.src index 485aad92..940a2cfb 100644 --- a/win32/libxml2.def.src +++ b/win32/libxml2.def.src @@ -1476,6 +1476,9 @@ xmlSchemaCheckFacet xmlSchemaCleanupTypes #endif #ifdef LIBXML_SCHEMAS_ENABLED +xmlSchemaCollapseString +#endif +#ifdef LIBXML_SCHEMAS_ENABLED xmlSchemaCompareValues #endif #ifdef LIBXML_SCHEMAS_ENABLED @@ -1497,6 +1500,13 @@ xmlSchemaFreeValidCtxt #ifdef LIBXML_SCHEMAS_ENABLED xmlSchemaFreeValue #endif +xmlSchemaFreeWildcard +#ifdef LIBXML_SCHEMAS_ENABLED +xmlSchemaGetBuiltInListSimpleTypeItemType +#endif +#ifdef LIBXML_SCHEMAS_ENABLED +xmlSchemaGetBuiltInType +#endif #ifdef LIBXML_SCHEMAS_ENABLED xmlSchemaGetPredefinedType #endif @@ -1504,6 +1514,9 @@ xmlSchemaGetPredefinedType xmlSchemaInitTypes #endif #ifdef LIBXML_SCHEMAS_ENABLED +xmlSchemaIsBuiltInTypeFacet +#endif +#ifdef LIBXML_SCHEMAS_ENABLED xmlSchemaNewDocParserCtxt #endif #ifdef LIBXML_SCHEMAS_ENABLED @@ -1537,6 +1550,9 @@ xmlSchemaValidateDoc xmlSchemaValidateFacet #endif #ifdef LIBXML_SCHEMAS_ENABLED +xmlSchemaValidateListSimpleTypeFacet +#endif +#ifdef LIBXML_SCHEMAS_ENABLED xmlSchemaValidatePredefinedType #endif #ifdef LIBXML_SCHEMAS_ENABLED diff --git a/xmlschemas.c b/xmlschemas.c index 30dba1f7..7f1b5196 100644 --- a/xmlschemas.c +++ b/xmlschemas.c @@ -12,6 +12,9 @@ * - when types are redefined in includes, check that all * types in the redef list are equal * -> need a type equality operation. + * - if we don't intend to use the schema for schemas, we + * need to validate all schema attributes (ref, type, name) + * against their types. */ #define IN_LIBXML #include "libxml.h" @@ -102,6 +105,8 @@ struct _xmlSchemaParserCtxt { xmlDictPtr dict; /* dictionnary for interned string names */ int includes; /* the inclusion level, 0 for root or imports */ + xmlSchemaTypePtr ctxtType; /* The current context simple/complex type */ + xmlSchemaTypePtr parentItem; /* The current parent schema item */ }; @@ -184,18 +189,32 @@ struct _xmlSchemaInclude { * Some predeclarations * * * ************************************************************************/ +#if 0 /* Not currently used. */ static int xmlSchemaValidateSimpleValue(xmlSchemaValidCtxtPtr ctxt, xmlSchemaTypePtr type, const xmlChar * value); +#endif static int xmlSchemaParseInclude(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, xmlNodePtr node); +#if 0 static int xmlSchemaValidateSimpleValueInternal(xmlSchemaValidCtxtPtr ctxt, xmlSchemaTypePtr type, const xmlChar * value, int fireErrors); +#endif /* Not currently used. */ +static void +xmlSchemaTypeFixup(xmlSchemaTypePtr typeDecl, + xmlSchemaParserCtxtPtr ctxt, const xmlChar * name); +static const char * +xmlSchemaFacetTypeToString(xmlSchemaTypeType type); +static int +xmlSchemaValidateSimpleTypeValue(xmlSchemaValidCtxtPtr ctxt, + const xmlChar *value, + int fireErrors, + int applyFacets); /************************************************************************ * * @@ -274,7 +293,7 @@ xmlSchemaPErr2(xmlSchemaParserCtxtPtr ctxt, xmlNodePtr node, xmlSchemaPErr(ctxt, node, error, msg, str1, str2); } -#if 0 + /** * xmlSchemaPErrExt: * @ctxt: the parsing context @@ -316,7 +335,7 @@ xmlSchemaPErrExt(xmlSchemaParserCtxtPtr ctxt, xmlNodePtr node, int error, (const char *) strData3, 0, 0, msg, str1, str2, str3, str4, str5); } -#endif + /** * xmlSchemaVTypeErrMemory: @@ -579,7 +598,7 @@ xmlSchemaFreeAttribute(xmlSchemaAttributePtr attr) * xmlSchemaFreeWildcardNsSet: * set: a schema wildcard namespace * - * Deallocate a list of wildcard constraint structures. + * Deallocates a list of wildcard constraint structures. */ static void xmlSchemaFreeWildcardNsSet(xmlSchemaWildcardNsPtr set) @@ -595,11 +614,11 @@ xmlSchemaFreeWildcardNsSet(xmlSchemaWildcardNsPtr set) /** * xmlSchemaFreeWildcard: - * @schema: a schema attribute group structure + * @wildcard: a wildcard structure * - * Deallocate a Schema Attribute Group structure. + * Deallocates a wildcard structure. */ -static void +void xmlSchemaFreeWildcard(xmlSchemaWildcardPtr wildcard) { if (wildcard == NULL) @@ -635,7 +654,7 @@ xmlSchemaFreeAttributeGroup(xmlSchemaAttributeGroupPtr attr) /** * xmlSchemaFreeAttributeUseList: - * @attrUse: a schema attribute link structure + * @attrUse: an attribute link * * Deallocate a list of schema attribute uses. */ @@ -651,6 +670,24 @@ xmlSchemaFreeAttributeUseList(xmlSchemaAttributeLinkPtr attrUse) } } +/** + * xmlSchemaFreeTypeLinkList: + * @alink: a type link + * + * Deallocate a list of types. + */ +static void +xmlSchemaFreeTypeLinkList(xmlSchemaTypeLinkPtr link) +{ + xmlSchemaTypeLinkPtr next; + + while (link != NULL) { + next = link->next; + xmlFree(link); + link = next; + } +} + /** * xmlSchemaFreeElement: * @schema: a schema element structure @@ -715,6 +752,7 @@ xmlSchemaFreeType(xmlSchemaTypePtr type) if (type->type != XML_SCHEMA_TYPE_BASIC) { if (type->attributeUses != NULL) xmlSchemaFreeAttributeUseList(type->attributeUses); + /* TODO: There must be a way more simple than this. */ if ((type->attributeWildcard != NULL) && ((type->type != XML_SCHEMA_TYPE_COMPLEX) || ((type->type == XML_SCHEMA_TYPE_COMPLEX) && @@ -722,6 +760,29 @@ xmlSchemaFreeType(xmlSchemaTypePtr type) xmlSchemaFreeWildcard(type->attributeWildcard); } } + if (type->memberTypes != NULL) + xmlSchemaFreeTypeLinkList(type->memberTypes); + if (type->facetSet != NULL) { + xmlSchemaFacetLinkPtr next, link; + + link = type->facetSet; + do { + next = link->next; + xmlFree(link); + link = next; + } while (link != NULL); + } + + if ((type->subtypes != NULL) && (type->type != XML_SCHEMA_TYPE_SEQUENCE)) { + switch (type->subtypes->type) { + case XML_SCHEMA_TYPE_SIMPLE_CONTENT: + case XML_SCHEMA_TYPE_COMPLEX_CONTENT: + case XML_SCHEMA_TYPE_RESTRICTION: + case XML_SCHEMA_TYPE_EXTENSION: + case XML_SCHEMA_TYPE_UNION: + xmlSchemaFreeType(type->subtypes); + } + } xmlFree(type); } @@ -951,9 +1012,12 @@ xmlSchemaTypeDump(xmlSchemaTypePtr type, FILE * output) case XML_SCHEMA_CONTENT_MIXED: fprintf(output, "mixed "); break; + /* Removed, since not used. */ + /* case XML_SCHEMA_CONTENT_MIXED_OR_ELEMENTS: fprintf(output, "mixed_or_elems "); break; + */ case XML_SCHEMA_CONTENT_BASIC: fprintf(output, "basic "); break; @@ -1031,6 +1095,36 @@ xmlSchemaDump(FILE * output, xmlSchemaPtr schema) * * ************************************************************************/ +xmlAttrPtr +xmlSchemaGetPropNode(xmlNodePtr node, const xmlChar *name) +{ + xmlAttrPtr prop; + + if ((node == NULL) || (name == NULL)) return(NULL); + prop = node->properties; + while (prop != NULL) { + if ((xmlStrEqual(prop->name, name)) && + (prop->ns == NULL)) + return(prop); + prop = prop->next; + } + return (NULL); +} + +static const xmlChar * +xmlSchemaGetNodeContent(xmlSchemaParserCtxtPtr ctxt, xmlNodePtr node) +{ + xmlChar *val; + const xmlChar *ret; + + val = xmlNodeGetContent(node); + if (val == NULL) + return(NULL); + ret = xmlDictLookup(ctxt->dict, val, -1); + xmlFree(val); + return(ret); +} + /** * xmlSchemaGetProp: * @ctxt: the parser context @@ -1648,12 +1742,12 @@ xmlSchemaAddElement(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, /** * xmlSchemaAddType: - * @ctxt: a schema validation context + * @ctxt: a schema parser context * @schema: the schema being built * @name: the item name * @namespace: the namespace * - * Add an XML schema Simple Type definition + * Add an XML schema item * *WARNING* this interface is highly subject to change * * Returns the new struture or NULL in case of error @@ -1720,6 +1814,174 @@ xmlSchemaAddType(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, return (ret); } +/** + * xmlSchemaNewItemInternal: + * @ctxt: the schema parser context + * @name: the internal name of the restriction + * + * Createa an schema item + * + * Returns the new structure or NULL in case of an error. + */ +static xmlSchemaTypePtr +xmlSchemaNewItemInternal(xmlSchemaParserCtxtPtr ctxt, + const xmlChar * name) +{ + xmlSchemaTypePtr ret = NULL; + + if ((ctxt == NULL) || (name == NULL)) + return (NULL); + +#ifdef DEBUG + fprintf(stderr, "Creating item %s\n", name); +#endif + ret = (xmlSchemaTypePtr) xmlMalloc(sizeof(xmlSchemaType)); + if (ret == NULL) { + xmlSchemaPErrMemory(ctxt, "allocating item", NULL); + return (NULL); + } + memset(ret, 0, sizeof(xmlSchemaType)); + ret->name = xmlDictLookup(ctxt->dict, name, -1); + ret->minOccurs = 1; + ret->maxOccurs = 1; + + return (ret); +} + +/** + * xmlSchemaNewRestriction: + * @ctxt: the schema parser context + * @name: the internal name of the restriction + * + * Create a item + * + * Returns the new structure or NULL in case of an error. + */ +static xmlSchemaTypePtr +xmlSchemaNewRestriction(xmlSchemaParserCtxtPtr ctxt, + const xmlChar * name) +{ + xmlSchemaTypePtr ret; + + ret = xmlSchemaNewItemInternal(ctxt, name); + if (ret != NULL) + ret->type = XML_SCHEMA_TYPE_RESTRICTION; + + return (ret); +} + +/** + * xmlSchemaNewExtension: + * @ctxt: the schema parser context + * @name: the internal name of the extension + * + * Create an item + * + * Returns the new structure or NULL in case of an error. + */ +static xmlSchemaTypePtr +xmlSchemaNewExtension(xmlSchemaParserCtxtPtr ctxt, + const xmlChar * name) +{ + xmlSchemaTypePtr ret; + + ret = xmlSchemaNewItemInternal(ctxt, name); + if (ret != NULL) + ret->type = XML_SCHEMA_TYPE_EXTENSION; + + return (ret); +} + +/** + * xmlSchemaNewSimpleContent: + * @ctxt: the schema parser context + * @name: the internal name of the simpleContent + * + * Create a item + * + * Returns the new structure or NULL in case of an error. + */ +static xmlSchemaTypePtr +xmlSchemaNewSimpleContent(xmlSchemaParserCtxtPtr ctxt, + const xmlChar * name) +{ + xmlSchemaTypePtr ret; + + ret = xmlSchemaNewItemInternal(ctxt, name); + if (ret != NULL) + ret->type = XML_SCHEMA_TYPE_SIMPLE_CONTENT; + + return (ret); +} + +/** + * xmlSchemaNewComplexContent: + * @ctxt: the schema parser context + * @name: the internal name of the complexContent + * + * Create a item + * + * Returns the new structure or NULL in case of an error. + */ +static xmlSchemaTypePtr +xmlSchemaNewComplexContent(xmlSchemaParserCtxtPtr ctxt, + const xmlChar * name) +{ + xmlSchemaTypePtr ret; + + ret = xmlSchemaNewItemInternal(ctxt, name); + if (ret != NULL) + ret->type = XML_SCHEMA_TYPE_COMPLEX_CONTENT; + + return (ret); +} + +/** + * xmlSchemaNewUnion: + * @ctxt: the schema parser context + * @name: the internal name of the union + * + * Create an item + * *WARNING* this interface is highly subject to change + * + * Returns the new structure or NULL in case of an error. + */ +static xmlSchemaTypePtr +xmlSchemaNewUnion(xmlSchemaParserCtxtPtr ctxt, + const xmlChar * name) +{ + xmlSchemaTypePtr ret; + + ret = xmlSchemaNewItemInternal(ctxt, name); + if (ret != NULL) + ret->type = XML_SCHEMA_TYPE_UNION; + + return (ret); +} + +/** + * xmlSchemaNewList: + * @ctxt: the schema parser context + * @name: the internal name of the union + * + * Create an item + * *WARNING* this interface is highly subject to change + * + * Returns the new structure or NULL in case of an error. + */ +static xmlSchemaTypePtr +xmlSchemaNewList(xmlSchemaParserCtxtPtr ctxt, + const xmlChar * name) +{ + xmlSchemaTypePtr ret; + + ret = xmlSchemaNewItemInternal(ctxt, name); + if (ret != NULL) + ret->type = XML_SCHEMA_TYPE_LIST; + + return (ret); +} + /** * xmlSchemaAddGroup: * @ctxt: a schema validation context @@ -1872,7 +2134,7 @@ xmlGetQNameProp(xmlSchemaParserCtxtPtr ctxt, xmlNodePtr node, ns = xmlSearchNs(node->doc, node, prefix); if (ns == NULL) { xmlSchemaPErr(ctxt, node, XML_SCHEMAP_PREFIX_UNDEFINED, - "Attribute %s: the QName prefix %s is undefined\n", + "Attribute \"%s\": the QName prefix \"%s\" is undefined\n", (const xmlChar *) name, prefix); } else { *namespace = xmlDictLookup(ctxt->dict, ns->href, -1); @@ -2034,6 +2296,101 @@ static xmlSchemaWildcardPtr xmlSchemaParseAnyAttribute(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, xmlNodePtr node); +/** + * xmlSchemaParseSchemaAttrValue: + * + * @ctxt: a schema parser context + * @attr: the schema attribute being validated + * @type: the built-in type to be validated against + * @value: the value to be validated + * + * Validates a value against the given built-in type. + * This one is intended to be used internally for validation + * of schema attribute values during parsing of the schema. + * + * Returns 0 if the value is valid, a positive error code + * number otherwise and -1 in case of an internal or API error. + */ +static int +xmlSchemaParseSchemaAttrValue(xmlSchemaParserCtxtPtr ctxt, + xmlAttrPtr attr, + xmlSchemaTypePtr type) +{ + const xmlChar *value; + int ret; + + if ((ctxt == NULL) || (type == NULL) || (attr == NULL)) + return (-1); + value = xmlSchemaGetNodeContent(ctxt, (xmlNodePtr) attr); + switch (type->builtInType) { + case XML_SCHEMAS_NCNAME: + ret = xmlValidateNCName(value, 1); + break; + case XML_SCHEMAS_QNAME: + ret = xmlValidateQName(value, 1); + if ((ret == 0) && (attr != NULL)) { + xmlChar *uri = NULL; + xmlChar *local = NULL; + xmlChar *prefix; + + local = xmlSplitQName2(value, &prefix); + if (prefix != NULL) { + xmlNsPtr ns; + + ns = xmlSearchNs(attr->doc, (xmlNodePtr) attr, prefix); + if (ns == NULL) { + xmlSchemaPErr(ctxt, (xmlNodePtr) attr, + XML_SCHEMAP_PREFIX_UNDEFINED, + "Attribute \"%s\": the QName prefix " + "\"%s\" is undefined.\n", + attr->name, prefix); + ret = 1; + } + } + if (local != NULL) + xmlFree(local); + if (prefix != NULL) + xmlFree(prefix); + } + break; + default: { + xmlSchemaPErr(ctxt, (xmlNodePtr) attr, + XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaParseSchemaAttrValue, validation " + "using this type in not implemented yet\"%s\".\n", + type->name, NULL); + return (-1); + } + } + if (ret > 0) { + if (type->flags & XML_SCHEMAS_TYPE_VARIETY_LIST) { + xmlSchemaPErrExt(ctxt, (xmlNodePtr) attr, + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_2, + NULL, NULL, NULL, + "The schema attribute \"%s\" with the value \"%s\" is not " + "of built-in list simple type \"%s\".\n", + attr->name, value, type->name, NULL, NULL); + } else { + if (type->flags & XML_SCHEMAS_TYPE_BUILTIN_PRIMITIVE) { + xmlSchemaPErrExt(ctxt, (xmlNodePtr) attr, + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_1, + NULL, NULL, NULL, + "The schema attribute \"%s\" with the value \"%s\" is not " + "of built-in primitive type \"%s\".\n", + attr->name, value, type->name, NULL, NULL); + } else { + xmlSchemaPErrExt(ctxt, (xmlNodePtr) attr, + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_1, + NULL, NULL, NULL, + "The schema attribute \"%s\" with the value \"%s\" is not " + "of built-in atomic simple type \"%s\".\n", + attr->name, value, type->name, NULL, NULL); + } + } + } + return (ret); +} + /** * xmlSchemaParseAttrDecls: * @ctxt: a schema validation context @@ -2182,6 +2539,17 @@ xmlSchemaParseFacet(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, } facet->id = xmlSchemaGetProp(ctxt, node, "id"); facet->value = value; + if ((facet->type != XML_SCHEMA_FACET_PATTERN) && + (facet->type != XML_SCHEMA_FACET_ENUMERATION)) { + const xmlChar *fixed; + + fixed = xmlSchemaGetProp(ctxt, node, "fixed"); + if (fixed != NULL) { + if (xmlStrEqual(fixed, BAD_CAST "true")) + facet->fixed = 1; + } + } + child = node->children; if (IS_SCHEMA(child, "annotation")) { @@ -2318,18 +2686,18 @@ xmlSchemaParseAnyAttribute(xmlSchemaParserCtxtPtr ctxt, processContents = xmlSchemaGetProp(ctxt, node, "processContents"); if ((processContents == NULL) || (xmlStrEqual(processContents, (const xmlChar *) "strict"))) { - ret->processContents = XML_SCHEMAS_ANYATTR_STRICT; + ret->processContents = XML_SCHEMAS_ANY_STRICT; } else if (xmlStrEqual(processContents, (const xmlChar *) "skip")) { - ret->processContents = XML_SCHEMAS_ANYATTR_SKIP; + ret->processContents = XML_SCHEMAS_ANY_SKIP; } else if (xmlStrEqual(processContents, (const xmlChar *) "lax")) { - ret->processContents = XML_SCHEMAS_ANYATTR_LAX; + ret->processContents = XML_SCHEMAS_ANY_LAX; } else { xmlSchemaPErr(ctxt, node, XML_SCHEMAP_UNKNOWN_PROCESSCONTENT_CHILD, "anyAttribute has unexpected content " "for processContents: %s\n", processContents, NULL); - ret->processContents = XML_SCHEMAS_ANYATTR_STRICT; + ret->processContents = XML_SCHEMAS_ANY_STRICT; } /* * Build the namespace constraints. @@ -2967,13 +3335,12 @@ xmlSchemaParseUnion(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, snprintf((char *) name, 30, "union %d", ctxt->counter++ + 1); - type = xmlSchemaAddType(ctxt, schema, name, NULL); + type = xmlSchemaNewUnion(ctxt, name); if (type == NULL) return (NULL); type->node = node; - type->type = XML_SCHEMA_TYPE_UNION; type->id = xmlSchemaGetProp(ctxt, node, "id"); - type->ref = xmlSchemaGetProp(ctxt, node, "memberTypes"); + type->base = xmlSchemaGetProp(ctxt, node, "memberTypes"); child = node->children; if (IS_SCHEMA(child, "annotation")) { @@ -3022,6 +3389,7 @@ xmlSchemaParseList(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, xmlSchemaTypePtr type, subtype; xmlNodePtr child = NULL; xmlChar name[30]; + xmlAttrPtr attr; if ((ctxt == NULL) || (schema == NULL) || (node == NULL)) return (NULL); @@ -3033,20 +3401,33 @@ xmlSchemaParseList(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, type->node = node; type->type = XML_SCHEMA_TYPE_LIST; type->id = xmlSchemaGetProp(ctxt, node, "id"); - type->ref = xmlGetQNameProp(ctxt, node, "ref", &(type->refNs)); child = node->children; if (IS_SCHEMA(child, "annotation")) { type->annot = xmlSchemaParseAnnotation(ctxt, schema, child); child = child->next; } - + /* + * Check type of "itemType". + */ + attr = xmlSchemaGetPropNode(node, "itemType"); + if (attr != NULL) { + type->base = xmlGetQNameProp(ctxt, node, "itemType", &(type->baseNs)); + xmlSchemaParseSchemaAttrValue(ctxt, attr, + xmlSchemaGetBuiltInType(XML_SCHEMAS_QNAME)); + + } subtype = NULL; - if (IS_SCHEMA(child, "simpleType")) { - subtype = (xmlSchemaTypePtr) - xmlSchemaParseSimpleType(ctxt, schema, child, 0); - child = child->next; - type->subtypes = subtype; + if (IS_SCHEMA(child, "simpleType")) { + subtype = (xmlSchemaTypePtr) + xmlSchemaParseSimpleType(ctxt, schema, child, 0); + type->subtypes = subtype; + /* + * This is a hack to save the information that a local + * simple type was defined. + */ + type->baseType = subtype; + child = child->next; } if (child != NULL) { xmlSchemaPErr2(ctxt, node, child, XML_SCHEMAP_UNKNOWN_LIST_CHILD, @@ -3072,23 +3453,38 @@ static xmlSchemaTypePtr xmlSchemaParseSimpleType(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, xmlNodePtr node, int topLevel) { - xmlSchemaTypePtr type, subtype; + xmlSchemaTypePtr type, subtype, ctxtType; xmlNodePtr child = NULL; - const xmlChar *name; + const xmlChar *propVal; if ((ctxt == NULL) || (schema == NULL) || (node == NULL)) return (NULL); - - name = xmlSchemaGetProp(ctxt, node, "name"); - if (name == NULL) { + ctxtType = ctxt->ctxtType; + propVal = xmlSchemaGetProp(ctxt, node, "name"); + if (propVal == NULL) { char buf[100]; snprintf(buf, 99, "simpleType %d", ctxt->counter++ + 1); type = xmlSchemaAddType(ctxt, schema, (const xmlChar *)buf, NULL); } else { - /* local = xmlSchemaGetNamespace(ctxt, schema, node, name, &ns); */ - type = xmlSchemaAddType(ctxt, schema, name, schema->targetNamespace); + if (!topLevel) { + xmlSchemaPErr(ctxt, node, + XML_SCHEMAP_S4S_ATTR_NOT_ALLOWED, + "The attribute \"name\" is not allowed on a local " + "simpleType definition\n", + propVal, NULL); + return (NULL); + } + /* + * "name" has to be of type NCName. + * TODO: Actually this should be validated by the schema for schemas. + */ + if (xmlSchemaParseSchemaAttrValue(ctxt, + xmlSchemaGetPropNode(node, BAD_CAST "name"), + xmlSchemaGetBuiltInType(XML_SCHEMAS_NCNAME)) != 0) + return (NULL); + type = xmlSchemaAddType(ctxt, schema, propVal, schema->targetNamespace); } if (type == NULL) return (NULL); @@ -3097,13 +3493,57 @@ xmlSchemaParseSimpleType(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, if (topLevel) type->flags |= XML_SCHEMAS_TYPE_GLOBAL; type->id = xmlSchemaGetProp(ctxt, node, "id"); - + propVal = xmlSchemaGetProp(ctxt, node, "final"); + if (propVal == NULL) { + type->flags |= XML_SCHEMAS_TYPE_FINAL_DEFAULT; + } else { + if (xmlStrEqual(propVal, BAD_CAST "#all")) { + type->flags |= XML_SCHEMAS_TYPE_FINAL_RESTRICTION; + type->flags |= XML_SCHEMAS_TYPE_FINAL_UNION; + type->flags |= XML_SCHEMAS_TYPE_FINAL_LIST; + } else { + const xmlChar *end, *cur = propVal; + xmlChar *item; + + do { + while (IS_BLANK_CH(*cur)) + cur++; + end = cur; + while ((*end != 0) && (!(IS_BLANK_CH(*end)))) + end++; + if (end == cur) + break; + item = xmlStrndup(cur, end - cur); + if (xmlStrEqual(item, BAD_CAST "restriction")) { + if ((type->flags & XML_SCHEMAS_TYPE_FINAL_RESTRICTION) == 0) + type->flags |= XML_SCHEMAS_TYPE_FINAL_RESTRICTION; + } else if (xmlStrEqual(item, BAD_CAST "list")) { + if ((type->flags & XML_SCHEMAS_TYPE_FINAL_LIST) == 0) + type->flags |= XML_SCHEMAS_TYPE_FINAL_LIST; + } else if (xmlStrEqual(item, BAD_CAST "union")) { + if ((type->flags & XML_SCHEMAS_TYPE_FINAL_UNION) == 0) + type->flags |= XML_SCHEMAS_TYPE_FINAL_UNION; + } else { + xmlSchemaPErr(ctxt, node, + XML_SCHEMAS_ERR_INTERNAL, + "The attribute \"final\" of type \"%s\" " + "has an invalid value\n", + type->name, NULL); + } + if (item != NULL) + xmlFree(item); + cur = end; + } while (*cur != 0); + } + } child = node->children; if (IS_SCHEMA(child, "annotation")) { type->annot = xmlSchemaParseAnnotation(ctxt, schema, child); child = child->next; } subtype = NULL; + ctxt->ctxtType = type; + ctxt->parentItem = type; if (IS_SCHEMA(child, "restriction")) { subtype = (xmlSchemaTypePtr) xmlSchemaParseRestriction(ctxt, schema, child, 1); @@ -3118,19 +3558,23 @@ xmlSchemaParseSimpleType(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, child = child->next; } type->subtypes = subtype; - if (subtype == NULL) { - xmlSchemaPErr2(ctxt, node, child, - XML_SCHEMAP_MISSING_SIMPLETYPE_CHILD, - "SimpleType %s does not define a variety\n", - type->name, NULL); - } if (child != NULL) { xmlSchemaPErr2(ctxt, node, child, - XML_SCHEMAP_UNKNOWN_SIMPLETYPE_CHILD, - "SimpleType %s has unexpected content\n", + XML_SCHEMAP_S4S_ELEM_NOT_ALLOWED, + "SimpleType \"%s\" has unexpected content\n", type->name, NULL); + } else { + if (subtype == NULL) { + xmlSchemaPErr2(ctxt, node, child, + XML_SCHEMAP_S4S_ELEM_MISSING, + "SimpleType \"%s\" must have one of or " + " or as a child\n", + type->name, NULL); + } } + ctxt->ctxtType = ctxtType; + return (type); } @@ -3347,8 +3791,6 @@ xmlSchemaImportSchema(xmlSchemaParserCtxtPtr ctxt, schemaLocation, NULL); xmlSchemaFreeParserCtxt(newctxt); - if (import->schemaLocation != NULL) - xmlFree((xmlChar *)import->schemaLocation); xmlFree(import); return NULL; } @@ -3688,6 +4130,8 @@ xmlSchemaParseSchemaTopLevel(xmlSchemaParserCtxtPtr ctxt, child = child->next; } } + ctxt->parentItem = NULL; + ctxt->ctxtType = NULL; } /** @@ -3802,7 +4246,7 @@ xmlSchemaParseInclude(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, if (!IS_SCHEMA(root, "schema")) { xmlSchemaPErr(ctxt, (xmlNodePtr) doc, XML_SCHEMAP_NOT_SCHEMA, - "File %s is not a schemas", schemaLocation, NULL); + "File %s is not a schema", schemaLocation, NULL); xmlFreeDoc(doc); return (-1); } @@ -4006,8 +4450,7 @@ static xmlSchemaTypePtr xmlSchemaParseRestriction(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, xmlNodePtr node, int simple) { - xmlSchemaTypePtr type, subtype; - xmlSchemaFacetPtr facet, lastfacet = NULL; + xmlSchemaTypePtr type, subtype; xmlNodePtr child = NULL; xmlChar name[30]; const xmlChar *oldcontainer; @@ -4018,17 +4461,18 @@ xmlSchemaParseRestriction(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, oldcontainer = ctxt->container; snprintf((char *) name, 30, "restriction %d", ctxt->counter++ + 1); - type = xmlSchemaAddType(ctxt, schema, name, NULL); + type = xmlSchemaNewRestriction(ctxt, name); if (type == NULL) return (NULL); type->node = node; - type->type = XML_SCHEMA_TYPE_RESTRICTION; type->id = xmlSchemaGetProp(ctxt, node, "id"); type->base = xmlGetQNameProp(ctxt, node, "base", &(type->baseNs)); - if ((!simple) && (type->base == NULL)) { + if ((type->base == NULL) && + (ctxt->parentItem->type == XML_SCHEMA_TYPE_COMPLEX_CONTENT)) { xmlSchemaPErr2(ctxt, node, child, - XML_SCHEMAP_RESTRICTION_NONAME_NOREF, - "Restriction %s has no base\n", type->name, NULL); + XML_SCHEMAP_RESTRICTION_NONAME_NOREF, + "Restriction \"%s\" must have a \"base\" attribute.\n", + type->name, NULL); } ctxt->container = name; @@ -4039,71 +4483,107 @@ xmlSchemaParseRestriction(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, } subtype = NULL; - if (IS_SCHEMA(child, "all")) { - subtype = (xmlSchemaTypePtr) - xmlSchemaParseAll(ctxt, schema, child); - child = child->next; - type->subtypes = subtype; - } else if (IS_SCHEMA(child, "choice")) { - subtype = xmlSchemaParseChoice(ctxt, schema, child); - child = child->next; - type->subtypes = subtype; - } else if (IS_SCHEMA(child, "sequence")) { - subtype = (xmlSchemaTypePtr) - xmlSchemaParseSequence(ctxt, schema, child); - child = child->next; - type->subtypes = subtype; - } else if (IS_SCHEMA(child, "group")) { - subtype = (xmlSchemaTypePtr) - xmlSchemaParseGroup(ctxt, schema, child, 0); - child = child->next; - type->subtypes = subtype; - } else { - if (IS_SCHEMA(child, "simpleType")) { - subtype = (xmlSchemaTypePtr) - xmlSchemaParseSimpleType(ctxt, schema, child, 0); - child = child->next; - type->baseType = subtype; - } - /* - * Facets - */ - while ((IS_SCHEMA(child, "minInclusive")) || - (IS_SCHEMA(child, "minExclusive")) || - (IS_SCHEMA(child, "maxInclusive")) || - (IS_SCHEMA(child, "maxExclusive")) || - (IS_SCHEMA(child, "totalDigits")) || - (IS_SCHEMA(child, "fractionDigits")) || - (IS_SCHEMA(child, "pattern")) || - (IS_SCHEMA(child, "enumeration")) || - (IS_SCHEMA(child, "whiteSpace")) || - (IS_SCHEMA(child, "length")) || - (IS_SCHEMA(child, "maxLength")) || - (IS_SCHEMA(child, "minLength"))) { - facet = xmlSchemaParseFacet(ctxt, schema, child); - if (facet != NULL) { - if (lastfacet == NULL) { - type->facets = facet; - lastfacet = facet; - } else { - lastfacet->next = facet; - lastfacet = facet; - } - lastfacet->next = NULL; - } - child = child->next; - } - } - /* TODO: a restriction of simpleType does not contain any - * attribute declarations. - */ - child = xmlSchemaParseAttrDecls(ctxt, schema, child, type); + if (ctxt->parentItem->type == XML_SCHEMA_TYPE_COMPLEX_CONTENT) { + if (IS_SCHEMA(child, "all")) { + subtype = (xmlSchemaTypePtr) + xmlSchemaParseAll(ctxt, schema, child); + child = child->next; + type->subtypes = subtype; + } else if (IS_SCHEMA(child, "choice")) { + subtype = xmlSchemaParseChoice(ctxt, schema, child); + child = child->next; + type->subtypes = subtype; + } else if (IS_SCHEMA(child, "sequence")) { + subtype = (xmlSchemaTypePtr) + xmlSchemaParseSequence(ctxt, schema, child); + child = child->next; + type->subtypes = subtype; + } else if (IS_SCHEMA(child, "group")) { + subtype = (xmlSchemaTypePtr) + xmlSchemaParseGroup(ctxt, schema, child, 0); + child = child->next; + type->subtypes = subtype; + } + } else if ((ctxt->ctxtType->type == XML_SCHEMA_TYPE_SIMPLE) || + (ctxt->parentItem->type == XML_SCHEMA_TYPE_SIMPLE_CONTENT)) { + xmlSchemaFacetPtr facet, lastfacet = NULL; + + if (IS_SCHEMA(child, "simpleType")) { + subtype = (xmlSchemaTypePtr) + xmlSchemaParseSimpleType(ctxt, schema, child, 0); + /* + * For the simple type this serves as the base type. + */ + type->baseType = subtype; + /* + * For the complex type this serves as information for the + * definition of the content type. + * Additionally this is a hack for the simple type, to save + * the information that a local simple type was defined; thus + * allowing to check: src-restriction-base-or-simpleType. + */ + type->subtypes = subtype; + child = child->next; + } + /* + * Add the facets to the parent simpleType/complexType. + */ + while ((IS_SCHEMA(child, "minInclusive")) || + (IS_SCHEMA(child, "minExclusive")) || + (IS_SCHEMA(child, "maxInclusive")) || + (IS_SCHEMA(child, "maxExclusive")) || + (IS_SCHEMA(child, "totalDigits")) || + (IS_SCHEMA(child, "fractionDigits")) || + (IS_SCHEMA(child, "pattern")) || + (IS_SCHEMA(child, "enumeration")) || + (IS_SCHEMA(child, "whiteSpace")) || + (IS_SCHEMA(child, "length")) || + (IS_SCHEMA(child, "maxLength")) || + (IS_SCHEMA(child, "minLength"))) { + facet = xmlSchemaParseFacet(ctxt, schema, child); + if (facet != NULL) { + if (lastfacet == NULL) + ctxt->ctxtType->facets = facet; + else + lastfacet->next = facet; + lastfacet = facet; + lastfacet->next = NULL; + } + child = child->next; + } + /* + * Create links for derivation and validation. + */ + if (lastfacet != NULL) { + xmlSchemaFacetLinkPtr facetLink, lastFacetLink = NULL; + + facet = ctxt->ctxtType->facets; + do { + facetLink = (xmlSchemaFacetLinkPtr) xmlMalloc(sizeof(xmlSchemaFacetLink)); + if (facetLink == NULL) { + xmlSchemaPErrMemory(ctxt, "allocation a facet link", NULL); + xmlFree(facetLink); + return (NULL); + } + facetLink->facet = facet; + facetLink->next = NULL; + if (lastFacetLink == NULL) + ctxt->ctxtType->facetSet = facetLink; + else + lastFacetLink->next = facetLink; + lastFacetLink = facetLink; + facet = facet->next; + } while (facet != NULL); + } + } + if (ctxt->ctxtType->type == XML_SCHEMA_TYPE_COMPLEX) + child = xmlSchemaParseAttrDecls(ctxt, schema, child, type); if (child != NULL) { - xmlSchemaPErr2(ctxt, node, child, - XML_SCHEMAP_UNKNOWN_RESTRICTION_CHILD, - "Restriction %s has unexpected content\n", - type->name, NULL); - } + xmlSchemaPErr2(ctxt, node, child, + XML_SCHEMAP_UNKNOWN_RESTRICTION_CHILD, + "Restriction \"%s\" has unexpected content.\n", + type->name, NULL); + } ctxt->container = oldcontainer; return (type); } @@ -4134,11 +4614,10 @@ xmlSchemaParseExtension(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, oldcontainer = ctxt->container; snprintf((char *) name, 30, "extension %d", ctxt->counter++ + 1); - type = xmlSchemaAddType(ctxt, schema, name, NULL); + type = xmlSchemaNewExtension(ctxt, name); if (type == NULL) return (NULL); type->node = node; - type->type = XML_SCHEMA_TYPE_EXTENSION; type->id = xmlSchemaGetProp(ctxt, node, "id"); ctxt->container = name; @@ -4203,11 +4682,10 @@ xmlSchemaParseSimpleContent(xmlSchemaParserCtxtPtr ctxt, return (NULL); snprintf((char *) name, 30, "simpleContent %d", ctxt->counter++ + 1); - type = xmlSchemaAddType(ctxt, schema, name, NULL); + type = xmlSchemaNewSimpleContent(ctxt, name); if (type == NULL) return (NULL); type->node = node; - type->type = XML_SCHEMA_TYPE_SIMPLE_CONTENT; type->id = xmlSchemaGetProp(ctxt, node, "id"); child = node->children; @@ -4215,7 +4693,8 @@ xmlSchemaParseSimpleContent(xmlSchemaParserCtxtPtr ctxt, type->annot = xmlSchemaParseAnnotation(ctxt, schema, child); child = child->next; } - subtype = NULL; + ctxt->parentItem = type; + subtype = NULL; if (IS_SCHEMA(child, "restriction")) { subtype = (xmlSchemaTypePtr) xmlSchemaParseRestriction(ctxt, schema, child, 0); @@ -4257,13 +4736,11 @@ xmlSchemaParseComplexContent(xmlSchemaParserCtxtPtr ctxt, if ((ctxt == NULL) || (schema == NULL) || (node == NULL)) return (NULL); - snprintf((char *) name, 30, "complexContent %d", ctxt->counter++ + 1); - type = xmlSchemaAddType(ctxt, schema, name, NULL); + type = xmlSchemaNewComplexContent(ctxt, name); if (type == NULL) return (NULL); - type->node = node; - type->type = XML_SCHEMA_TYPE_COMPLEX_CONTENT; + type->node = node; type->id = xmlSchemaGetProp(ctxt, node, "id"); child = node->children; @@ -4271,6 +4748,7 @@ xmlSchemaParseComplexContent(xmlSchemaParserCtxtPtr ctxt, type->annot = xmlSchemaParseAnnotation(ctxt, schema, child); child = child->next; } + ctxt->parentItem = type; subtype = NULL; if (IS_SCHEMA(child, "restriction")) { subtype = (xmlSchemaTypePtr) @@ -4306,7 +4784,7 @@ static xmlSchemaTypePtr xmlSchemaParseComplexType(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, xmlNodePtr node, int topLevel) { - xmlSchemaTypePtr type, subtype; + xmlSchemaTypePtr type, subtype, ctxtType; xmlNodePtr child = NULL; const xmlChar *name; const xmlChar *oldcontainer; @@ -4315,6 +4793,8 @@ xmlSchemaParseComplexType(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, if ((ctxt == NULL) || (schema == NULL) || (node == NULL)) return (NULL); + ctxtType = ctxt->ctxtType; + oldcontainer = ctxt->container; name = xmlSchemaGetProp(ctxt, node, "name"); if (name == NULL) { @@ -4344,6 +4824,7 @@ xmlSchemaParseComplexType(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, type->annot = xmlSchemaParseAnnotation(ctxt, schema, child); child = child->next; } + ctxt->ctxtType = type; if (IS_SCHEMA(child, "simpleContent")) { /* 3.4.3 : 2.2 * Specifying mixed='true' when the @@ -4385,6 +4866,7 @@ xmlSchemaParseComplexType(xmlSchemaParserCtxtPtr ctxt, xmlSchemaPtr schema, if (type->attributeWildcard != NULL) type->flags |= XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD; ctxt->container = oldcontainer; + ctxt->ctxtType = ctxtType; return (type); } @@ -4435,7 +4917,10 @@ xmlSchemaParseSchema(xmlSchemaParserCtxtPtr ctxt, xmlNodePtr node) val, NULL); } } else { - schema->flags |= XML_SCHEMAS_QUALIF_ELEM; + /* Removed, since the default value for elementFormDefault + * is "unqualified". + */ + /* schema->flags |= XML_SCHEMAS_QUALIF_ELEM; */ } val = xmlSchemaGetProp(ctxt, node, "attributeFormDefault"); if (val != NULL) { @@ -4449,6 +4934,51 @@ xmlSchemaParseSchema(xmlSchemaParserCtxtPtr ctxt, xmlNodePtr node) } } + val = xmlSchemaGetProp(ctxt, node, "finalDefault"); + if (val != NULL) { + if (xmlStrEqual(val, BAD_CAST "#all")) { + schema->flags |= XML_SCHEMAS_FINAL_DEFAULT_EXTENSION; + schema->flags |= XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION; + schema->flags |= XML_SCHEMAS_FINAL_DEFAULT_LIST; + schema->flags |= XML_SCHEMAS_FINAL_DEFAULT_UNION; + } else { + const xmlChar *end, *cur = val; + xmlChar *item; + + do { + while (IS_BLANK_CH(*cur)) + cur++; + end = cur; + while ((*end != 0) && (!(IS_BLANK_CH(*end)))) + end++; + if (end == cur) + break; + item = xmlStrndup(cur, end - cur); + if (xmlStrEqual(item, BAD_CAST "extension")) { + if ((schema->flags & XML_SCHEMAS_FINAL_DEFAULT_EXTENSION) == 0) + schema->flags |= XML_SCHEMAS_FINAL_DEFAULT_EXTENSION; + } else if (xmlStrEqual(item, BAD_CAST "restriction")) { + if ((schema->flags & XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION) == 0) + schema->flags |= XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION; + } else if (xmlStrEqual(item, BAD_CAST "list")) { + if ((schema->flags & XML_SCHEMAS_FINAL_DEFAULT_LIST) == 0) + schema->flags |= XML_SCHEMAS_FINAL_DEFAULT_LIST; + } else if (xmlStrEqual(item, BAD_CAST "union")) { + if ((schema->flags & XML_SCHEMAS_FINAL_DEFAULT_UNION) == 0) + schema->flags |= XML_SCHEMAS_FINAL_DEFAULT_UNION; + } else { + xmlSchemaPErr(ctxt, node, + XML_SCHEMAS_ERR_INTERNAL, + "Invalid value for the attribute \"finalDefault\".\n", + NULL, NULL); + } + if (item != NULL) + xmlFree(item); + cur = end; + } while (*cur != 0); + } + } + xmlSchemaParseSchemaTopLevel(ctxt, schema, node->children); } else { xmlDocPtr doc; @@ -4632,6 +5162,7 @@ xmlSchemaBuildAContentModel(xmlSchemaTypePtr type, case XML_SCHEMA_TYPE_ANY: /* TODO : handle the namespace too */ /* TODO : make that a specific transition type */ + /* Daniel says: use xmlAutomataNewTransition2 */ TODO ctxt->state = xmlAutomataNewTransition(ctxt->am, ctxt->state, NULL, BAD_CAST "*", NULL); @@ -5102,9 +5633,12 @@ xmlSchemaRefFixupCallback(xmlSchemaElementPtr elem, elemDecl = xmlSchemaGetElem(ctxt->schema, elem->ref, elem->refNs, 0); if (elemDecl == NULL) { - xmlSchemaPErr(ctxt, elem->node, XML_SCHEMAP_UNKNOWN_REF, - "Schemas: element %s ref to %s not found\n", - name, elem->ref); + xmlSchemaPErr(ctxt, elem->node, + XML_SCHEMAP_SRC_RESOLVE, + "Element \"%s\": the QName \"%s\" of the attribute " + "\"ref\" does not resolve to a schema " + "component.\n", + name, elem->ref); return; } elem->refDecl = elemDecl; @@ -5121,9 +5655,11 @@ xmlSchemaRefFixupCallback(xmlSchemaElementPtr elem, elem->namedTypeNs); if (typeDecl == NULL) { - xmlSchemaPErr(ctxt, elem->node, XML_SCHEMAP_UNKNOWN_TYPE, - "Schemas: element %s type %s not found\n", name, - elem->namedType); + xmlSchemaPErr(ctxt, elem->node, + XML_SCHEMAP_SRC_RESOLVE, + "Element \"%s\": the QName \"%s\" of the attribute " + "\"type\" does not resolve to a schema " + "component.\n", name, elem->namedType); return; } elem->subtypes = typeDecl; @@ -5139,29 +5675,38 @@ xmlSchemaRefFixupCallback(xmlSchemaElementPtr elem, */ static void xmlSchemaParseListRefFixup(xmlSchemaTypePtr type, xmlSchemaParserCtxtPtr ctxt) -{ - const xmlChar *itemType, *namespace; - xmlSchemaTypePtr subtype; - - /* Handle the "itemType" attribute. */ - itemType = xmlGetQNameProp(ctxt, type->node, "itemType", &namespace); - if (itemType != NULL) { - /* Do not allow more that one item type. */ - if (type->subtypes != NULL) { - xmlSchemaPErr(ctxt, type->node, - XML_SCHEMAP_SUPERNUMEROUS_LIST_ITEM_TYPE, - "List %s has more than one item type defined\n", - type->name, NULL); - } - subtype = xmlSchemaGetType(ctxt->schema, itemType, namespace); - if (subtype == NULL) { +{ + /* + * src-list-itemType-or-simpleType + * Either the itemType [attribute] or the [child] of + * the element must be present, but not both. + */ + if (((type->base == NULL) && + (type->subtypes == NULL)) || + ((type->base != NULL) && + (type->subtypes != NULL))) { + /* + * src-restriction-base-or-simpleType + * Either the base [attribute] or the simpleType [child] of the + * element must be present, but not both. + */ + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_SRC_LIST_ITEMTYPE_OR_SIMPLETYPE, + "List \"%s\": " + "Either the \"base\" attribute or the child " + "must be present, but not both.\n", + type->name, NULL); + } else if (type->base!= NULL) { + type->subtypes = xmlSchemaGetType(ctxt->schema, type->base, type->baseNs); + if (type->subtypes == NULL) { xmlSchemaPErr(ctxt, type->node, XML_SCHEMAP_UNKNOWN_TYPE, - "List %s references an unknown item type: %s\n", - type->name, xmlSchemaGetProp(ctxt, type->node, - "itemType")); - } else - type->subtypes = subtype; - } + "List \"%s\" references an unknown item type: \"%s\"\n", + type->name, type->base); + } + } + if ((type->subtypes != NULL) && + (type->subtypes->contentType == XML_SCHEMA_CONTENT_UNKNOWN)) + xmlSchemaTypeFixup(type->subtypes, ctxt, NULL); } /** @@ -5169,60 +5714,170 @@ xmlSchemaParseListRefFixup(xmlSchemaTypePtr type, xmlSchemaParserCtxtPtr ctxt) * @typeDecl: the schema type definition * @ctxt: the schema parser context * - * Checks the memberTypes references of the union type. + * Checks and builds the memberTypes of the union type. + * Returns -1 in case of an internal error, 0 otherwise. */ -static void +static int xmlSchemaParseUnionRefCheck(xmlSchemaTypePtr type, xmlSchemaParserCtxtPtr ctxt) { const xmlChar *cur, *end, *prefix, *ncName, *namespace; xmlChar *tmp; - xmlSchemaTypePtr subtype; + xmlSchemaTypeLinkPtr link, lastLink = NULL, prevLink, subLink, newLink; + xmlSchemaTypePtr memberType, ctxtType; xmlNsPtr ns; int len; - if ((type->type != XML_SCHEMA_TYPE_UNION) || (type->ref == NULL)) - return; + /* 1 If the alternative is chosen, then [Definition:] + * define the explicit members as the type definitions ·resolved· + * to by the items in the ·actual value· of the memberTypes [attribute], + * if any, followed by the type definitions corresponding to the + * s among the [children] of , if any. + */ - cur = type->ref; - do { - while (IS_BLANK_CH(*cur)) - cur++; - end = cur; - while ((*end != 0) && (!(IS_BLANK_CH(*end)))) - end++; - if (end == cur) - break; - tmp = xmlStrndup(cur, end - cur); - ncName = xmlSplitQName3(tmp, &len); - if (ncName != NULL) { - prefix = xmlDictLookup(ctxt->dict, tmp, len); - } else { - prefix = NULL; - ncName = tmp; - } - ns = xmlSearchNs(type->node->doc, type->node, prefix); - if (ns == NULL) { - if (prefix != NULL) { - xmlSchemaPErr(ctxt, type->node, XML_SCHEMAP_PREFIX_UNDEFINED, - "Union %s: the namespace prefix of member type " - "%s is undefined\n", - type->name, (const xmlChar *) tmp); - } - namespace = NULL; - } else { - namespace = xmlDictLookup(ctxt->dict, ns->href, -1); - } - /* Lookup the referenced type */ - subtype = xmlSchemaGetType(ctxt->schema, ncName, namespace); - if (subtype == NULL) { - xmlSchemaPErr(ctxt, type->node, XML_SCHEMAP_UNKNOWN_MEMBER_TYPE, - "Union %s references an unknown member type %s\n", - type->name, (const xmlChar *) tmp); - } - xmlFree(tmp); - cur = end; - } while (*cur != 0); + if (type->type != XML_SCHEMA_TYPE_UNION) + return (-1); + if (ctxt->ctxtType == NULL) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaParseUnionRefCheck, no parent type " + "available", NULL, NULL); + return (-1); + } + /* + * src-union-memberTypes-or-simpleTypes + * Either the memberTypes [attribute] of the element must + * be non-empty or there must be at least one simpleType [child]. + */ + if ((type->base == NULL) && + (type->subtypes == NULL)) { + /* + * src-restriction-base-or-simpleType + * Either the base [attribute] or the simpleType [child] of the + * element must be present, but not both. + */ + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_SRC_UNION_MEMBERTYPES_OR_SIMPLETYPES, + "Union \"%s\": " + "Either the \"memberTypes\" attribute must be non-empty " + "or there must be at least one child.\n", + type->name, NULL); + } + + ctxtType = ctxt->ctxtType; + if (type->base != NULL) { + cur = type->base; + do { + while (IS_BLANK_CH(*cur)) + cur++; + end = cur; + while ((*end != 0) && (!(IS_BLANK_CH(*end)))) + end++; + if (end == cur) + break; + tmp = xmlStrndup(cur, end - cur); + ncName = xmlSplitQName3(tmp, &len); + if (ncName != NULL) { + prefix = xmlDictLookup(ctxt->dict, tmp, len); + } else { + prefix = NULL; + ncName = tmp; + } + ns = xmlSearchNs(type->node->doc, type->node, prefix); + if (ns == NULL) { + if (prefix != NULL) { + xmlSchemaPErr(ctxt, type->node, XML_SCHEMAP_PREFIX_UNDEFINED, + "Union \"%s\": the namespace prefix of member type " + "\"%s\" is undefined\n", + type->name, (const xmlChar *) tmp); + } + namespace = NULL; + } else { + namespace = xmlDictLookup(ctxt->dict, ns->href, -1); + } + memberType = xmlSchemaGetType(ctxt->schema, ncName, namespace); + if (memberType == NULL) { + xmlSchemaPErr(ctxt, type->node, XML_SCHEMAP_UNKNOWN_MEMBER_TYPE, + "Union \"%s\" references an unknown member type \"%s\".\n", + type->name, (const xmlChar *) tmp); + } else { + if (memberType->contentType == XML_SCHEMA_CONTENT_UNKNOWN) + xmlSchemaTypeFixup(memberType, ctxt, NULL); + link = (xmlSchemaTypeLinkPtr) xmlMalloc(sizeof(xmlSchemaTypeLink)); + if (link == NULL) { + xmlSchemaPErrMemory(ctxt, "allocating a type link", NULL); + return (-1); + } + link->type = memberType; + link->next = NULL; + if (lastLink == NULL) + ctxtType->memberTypes = link; + else + lastLink->next = link; + lastLink = link; + } + xmlFree(tmp); + cur = end; + } while (*cur != 0); + } + /* + * Add local simple types, + */ + memberType = type->subtypes; + while (memberType != NULL) { + if (memberType->contentType == XML_SCHEMA_CONTENT_UNKNOWN) + xmlSchemaTypeFixup(memberType, ctxt, NULL); + link = (xmlSchemaTypeLinkPtr) xmlMalloc(sizeof(xmlSchemaTypeLink)); + if (link == NULL) { + xmlSchemaPErrMemory(ctxt, "allocating a type link", NULL); + return (-1); + } + link->type = memberType; + link->next = NULL; + if (lastLink == NULL) + ctxtType->memberTypes = link; + else + lastLink->next = link; + lastLink = link; + memberType = memberType->next; + } + /* + * The actual value is then formed by replacing any union type + * definition in the ·explicit members· with the members of their + * {member type definitions}, in order. + */ + link = ctxtType->memberTypes; + while (link != NULL) { + if (link->type->flags & XML_SCHEMAS_TYPE_VARIETY_UNION) { + subLink = link->type->memberTypes; + if (subLink != NULL) { + link->type = subLink->type; + if (subLink->next != NULL) { + lastLink = link->next; + subLink = subLink->next; + prevLink = link; + while (subLink != NULL) { + newLink = (xmlSchemaTypeLinkPtr) + xmlMalloc(sizeof(xmlSchemaTypeLink)); + if (newLink == NULL) { + xmlSchemaPErrMemory(ctxt, "allocating a type link", + NULL); + return (-1); + } + newLink->type = memberType; + prevLink->next = newLink; + prevLink = newLink; + newLink->next = lastLink; + + subLink = subLink->next; + } + } + } + } + link = link->next; + } + + return (0); } /** @@ -5282,9 +5937,9 @@ xmlSchemaIsDerivedFromBuiltInType(xmlSchemaParserCtxtPtr ctxt, xmlSchemaTypePtr type, int valType) { /* TODO: Check if this works in every case. */ - if ((type->type == XML_SCHEMA_TYPE_BASIC) && + if ((type->type == XML_SCHEMA_TYPE_BASIC) && (type->contentType == XML_SCHEMA_CONTENT_BASIC)) { - if (type->flags == valType) + if (type->builtInType == valType) return(1); } else if (type->type == XML_SCHEMA_TYPE_ATTRIBUTE) { if (((xmlSchemaAttributePtr) type)->subtypes != NULL) @@ -5307,6 +5962,26 @@ xmlSchemaIsDerivedFromBuiltInType(xmlSchemaParserCtxtPtr ctxt, return (0); } +/** + * xmlSchemaIsDerivedFromBuiltInType: + * @type: the simpleType definition + * + * Returns the primitive type of the given type or + * NULL in case of error. + */ +static xmlSchemaTypePtr +xmlSchemaGetPrimitiveType(xmlSchemaTypePtr type) +{ + while (type != NULL) { + if (type->flags & XML_SCHEMAS_TYPE_BUILTIN_PRIMITIVE) + return (type); + type = type->baseType; + } + + return (NULL); +} + + /** * xmlSchemaBuildAttributeUsesOwned: * @ctxt: the schema parser context @@ -6026,8 +6701,10 @@ xmlSchemaBuildAttributeValidation(xmlSchemaParserCtxtPtr ctxt, xmlSchemaTypePtr xmlSchemaAttributeLinkPtr cur, base, tmp, id = NULL, prev = NULL, uses = NULL, lastUse = NULL, lastBaseUse = NULL; xmlSchemaAttributePtr attrs; + xmlSchemaTypePtr anyType; int baseIsAnyType = 0; + anyType = xmlSchemaGetBuiltInType(XML_SCHEMAS_ANYTYPE); /* * Complex Type Definition with complex content Schema Component. * @@ -6035,29 +6712,37 @@ xmlSchemaBuildAttributeValidation(xmlSchemaParserCtxtPtr ctxt, xmlSchemaTypePtr */ if (type->attributeUses != NULL) { xmlSchemaPErr(ctxt, type->node, XML_SCHEMAS_ERR_INTERNAL, - "Internal error: xmlSchemaParseBuildAttributeUses: " + "Internal error: xmlSchemaBuildAttributeValidation: " "attribute uses already builded.\n", NULL, NULL); return (-1); } + if (type->baseType == NULL) { + xmlSchemaPErr(ctxt, type->node, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaBuildAttributeValidation: " + "complex type \"%s\" has no base type.\n", + type->name, NULL); + return (-1); + } if ((type->flags & XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION) || (type->flags & XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION)) { - + + baseType = type->baseType; + if (baseType == NULL) { + xmlSchemaPErr(ctxt, type->node, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaBuildAttributeValidation: " + "type has no base type.\n", + NULL, NULL); + return (-1); + } + + if (baseType == anyType) + baseIsAnyType = 1; /* * Inherit the attribute uses of the base type. */ - baseType = type->subtypes->subtypes->baseType; /* - * TODO: URGENT: This is not nice, but currently - * xmlSchemaTypeAnyTypeDef is static in xmlschematypes.c. - */ - if ((baseType->type == XML_SCHEMA_TYPE_BASIC) && - xmlStrEqual(baseType->name, BAD_CAST "anyType")) { - baseIsAnyType = 1; - } - /* - * TODO: Does the spec state that it is an error to "extend" the - * anyType? + * NOTE: It is allowed to "extend" the anyType complex type. */ if (!baseIsAnyType) { if (baseType != NULL) { @@ -6079,26 +6764,45 @@ xmlSchemaBuildAttributeValidation(xmlSchemaParserCtxtPtr ctxt, xmlSchemaTypePtr } } } - attrs = type->subtypes->subtypes->attributes; + if ((type->subtypes != NULL) && + ((type->subtypes->type == XML_SCHEMA_TYPE_COMPLEX_CONTENT) || + (type->subtypes->type == XML_SCHEMA_TYPE_SIMPLE_CONTENT))) { + attrs = type->subtypes->subtypes->attributes; + type->attributeWildcard = type->subtypes->subtypes->attributeWildcard; + } else { + /* Short hand form of the complexType. */ + attrs = type->attributes; + } /* * Handle attribute wildcards. */ - type->attributeWildcard = type->subtypes->subtypes->attributeWildcard; - if (xmlSchemaBuildCompleteAttributeWildcard(ctxt, - attrs, &type->attributeWildcard) == -1) { + attrs, &type->attributeWildcard) == -1) { if ((type->attributeWildcard != NULL) && - (type->attributeWildcard != type->subtypes->subtypes->attributeWildcard)) + /* Either we used the short hand form... */ + ((type->subtypes == NULL) || + /* Or complexType -> restriction/extension */ + (type->attributeWildcard != type->subtypes->subtypes->attributeWildcard))) type->flags |= XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD; return (-1); } + /* + * TODO: This "onwed_attr_wildcard" is quite sensless: we should + * create the wildcard right from the start on the complexType, + * rather than on the /. + */ if ((type->attributeWildcard != NULL) && - (type->attributeWildcard != type->subtypes->subtypes->attributeWildcard)) + /* Either we used the short hand form... */ + ((type->subtypes == NULL) || + /* Or complexType -> restriction/extension */ + (type->attributeWildcard != type->subtypes->subtypes->attributeWildcard))) type->flags |= XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD; if ((type->flags & XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION) && - (baseType != NULL) && (baseType->type == XML_SCHEMA_TYPE_COMPLEX) && - (baseType->attributeWildcard != NULL)) { + ((baseIsAnyType) || + ((baseType != NULL) && + (baseType->type == XML_SCHEMA_TYPE_COMPLEX) && + (baseType->attributeWildcard != NULL)))) { if (type->attributeWildcard != NULL) { /* * Union the complete wildcard with the base wildcard. @@ -6113,70 +6817,75 @@ xmlSchemaBuildAttributeValidation(xmlSchemaParserCtxtPtr ctxt, xmlSchemaTypePtr type->attributeWildcard = baseType->attributeWildcard; } } - if (!baseIsAnyType) { - if (type->flags & XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION) { - if (type->attributeWildcard != NULL) { - /* - * Derivation Valid (Restriction, Complex) - * 4.1 The {base type definition} must also have one. - */ - if (baseType->attributeWildcard == NULL) { - xmlSchemaPErr(ctxt, type->node, XML_SCHEMAP_DERIVATION_OK_RESTRICTION_4_1, - "The derived type \"%s\" has an attribute wildcard, " - "but the base type \"%s\" does not have one.\n", - type->name, baseType->name); - return (1); - } else if (xmlSchemaIsWildcardNsConstraintSubset(ctxt, - type->attributeWildcard, baseType->attributeWildcard) == 0) { - /* 4.2 */ - xmlSchemaPErr(ctxt, type->node, XML_SCHEMAP_DERIVATION_OK_RESTRICTION_4_2, - "The wildcard in the derived type \"%s\" is not a valid " - "subset of the one in the base type \"%s\".\n", - type->name, baseType->name); - return (1); - } - /* 4.3 Unless the {base type definition} is the ·ur-type - * definition·, the complex type definition's {attribute - * wildcard}'s {process contents} must be identical to or - * stronger than the {base type definition}'s {attribute - * wildcard}'s {process contents}, where strict is stronger - * than lax is stronger than skip. - */ - if (type->attributeWildcard->processContents < - baseType->attributeWildcard->processContents) { - xmlSchemaPErr(ctxt, type->node, XML_SCHEMAP_DERIVATION_OK_RESTRICTION_4_3, - "The process contents of the wildcard in the " - "derived type \"%s\" is weaker than " - "that in the base type \"%s\".\n", - type->name, baseType->name); - return (1); - } - } - } else if (type->flags & XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION) { - /* - * Derivation Valid (Extension) - * At this point the type and the base have both, either - * no wildcard or a wildcard. + + if (type->flags & XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION) { + if (type->attributeWildcard != NULL) { + /* + * Derivation Valid (Restriction, Complex) + * 4.1 The {base type definition} must also have one. */ - if ((baseType->attributeWildcard != NULL) && - (baseType->attributeWildcard != type->attributeWildcard)) { - /* 1.3 */ - if (xmlSchemaIsWildcardNsConstraintSubset(ctxt, - baseType->attributeWildcard, type->attributeWildcard) == 0) { - xmlSchemaPErr(ctxt, type->node, XML_SCHEMAP_COS_CT_EXTENDS_1_3, - "The wildcard in the derived type \"%s\" is not a valid " - "superset of the one in the base type \"%s\".\n", - type->name, baseType->name); - return (1); - } - } + if (baseType->attributeWildcard == NULL) { + xmlSchemaPErr(ctxt, type->node, XML_SCHEMAP_DERIVATION_OK_RESTRICTION_4_1, + "The derived type \"%s\" has an attribute wildcard, " + "but the base type \"%s\" does not have one.\n", + type->name, baseType->name); + return (1); + } else if (xmlSchemaIsWildcardNsConstraintSubset(ctxt, + type->attributeWildcard, baseType->attributeWildcard) == 0) { + /* 4.2 */ + xmlSchemaPErr(ctxt, type->node, XML_SCHEMAP_DERIVATION_OK_RESTRICTION_4_2, + "The wildcard in the derived type \"%s\" is not a valid " + "subset of the one in the base type \"%s\".\n", + type->name, baseType->name); + return (1); + } + /* 4.3 Unless the {base type definition} is the ·ur-type + * definition·, the complex type definition's {attribute + * wildcard}'s {process contents} must be identical to or + * stronger than the {base type definition}'s {attribute + * wildcard}'s {process contents}, where strict is stronger + * than lax is stronger than skip. + */ + if ((type->baseType != anyType) && + (type->attributeWildcard->processContents < + baseType->attributeWildcard->processContents)) { + xmlSchemaPErr(ctxt, type->node, XML_SCHEMAP_DERIVATION_OK_RESTRICTION_4_3, + "The process contents of the wildcard in the " + "derived type \"%s\" is weaker than " + "that in the base type \"%s\".\n", + type->name, baseType->name); + return (1); + } } - } - } else { - /* + } else if (type->flags & XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION) { + /* + * Derivation Valid (Extension) + * At this point the type and the base have both, either + * no wildcard or a wildcard. + */ + if ((baseType->attributeWildcard != NULL) && + (baseType->attributeWildcard != type->attributeWildcard)) { + /* 1.3 */ + if (xmlSchemaIsWildcardNsConstraintSubset(ctxt, + baseType->attributeWildcard, type->attributeWildcard) == 0) { + xmlSchemaPErr(ctxt, type->node, XML_SCHEMAP_COS_CT_EXTENDS_1_3, + "The wildcard in the derived type \"%s\" is not a valid " + "superset of the one in the base type \"%s\".\n", + type->name, baseType->name); + return (1); + } + } + } + } + /* + * Removed, since anyType was plugged into the derivation hierarchy. + */ + /* + else { + * * Although the complexType is implicitely derived by "restriction" * from the ur-type, this is not (yet?) reflected by libxml2. - */ + * baseType = NULL; attrs = type->attributes; if (attrs != NULL) { @@ -6191,7 +6900,7 @@ xmlSchemaBuildAttributeValidation(xmlSchemaParserCtxtPtr ctxt, xmlSchemaTypePtr ((type->flags & XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD) == 0)) type->flags |= XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD; } - } + } */ /* * Gather attribute uses defined by this type. */ @@ -6384,11 +7093,7 @@ xmlSchemaBuildAttributeValidation(xmlSchemaParserCtxtPtr ctxt, xmlSchemaTypePtr * not have {type definition}s which are or are derived from ID. */ if ((cur->attr->subtypes != NULL) && - /* - * TODO: FIXME: XML_SCHEMAS_ID should be used instead of "23" !!!, - * but the xmlSchemaValType is not made public yet. - */ - (xmlSchemaIsDerivedFromBuiltInType(ctxt, (xmlSchemaTypePtr) cur->attr, 23))) { + (xmlSchemaIsDerivedFromBuiltInType(ctxt, (xmlSchemaTypePtr) cur->attr, XML_SCHEMAS_ID))) { if (id != NULL) { xmlSchemaPErr(ctxt, cur->attr->node, XML_SCHEMAP_CT_PROPS_CORRECT_5, "ct-props-correct.5: Two attribute declarations, " @@ -6425,13 +7130,913 @@ xmlSchemaBuildAttributeValidation(xmlSchemaParserCtxtPtr ctxt, xmlSchemaTypePtr (baseType->type == XML_SCHEMA_TYPE_COMPLEX) && (baseType->contentType == XML_SCHEMA_CONTENT_UNKNOWN)) { xmlSchemaPErr(ctxt, baseType->node, XML_SCHEMAS_ERR_INTERNAL, - "Internal error: xmlSchemaParseBuildAttributeUses: " + "Internal error: xmlSchemaBuildAttributeValidation: " "attribute uses not builded on base type \"%s\".\n", baseType->name, NULL); } return (0); } +/** + * xmlSchemaTypeFinalContains: + * @schema: the schema + * @type: the type definition + * @final: the final + * + * Evaluates if a type definition contains the given "final". + * This does take "finalDefault" into account as well. + * + * Returns 1 if the type does containt the given "final", + * 0 otherwise. + */ +static int +xmlSchemaTypeFinalContains(xmlSchemaPtr schema, xmlSchemaTypePtr type, int final) +{ + int tfinal = final, tflags = type->flags; + + if (type == NULL) + return (0); + if (type->flags & XML_SCHEMAS_TYPE_FINAL_DEFAULT) { + switch (final) { + case XML_SCHEMAS_TYPE_FINAL_RESTRICTION: + tfinal = XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION; + break; + case XML_SCHEMAS_TYPE_FINAL_EXTENSION: + tfinal = XML_SCHEMAS_FINAL_DEFAULT_EXTENSION; + break; + case XML_SCHEMAS_TYPE_FINAL_LIST: + tfinal = XML_SCHEMAS_FINAL_DEFAULT_LIST; + break; + case XML_SCHEMAS_TYPE_FINAL_UNION: + tfinal = XML_SCHEMAS_FINAL_DEFAULT_UNION; + break; + } + tflags = schema->flags; + } + if (tflags & tfinal) + return (1); + else + return (0); + +} + +/** + * xmlSchemaGetUnionSimpleTypeMemberTypes: + * @type: the Union Simple Type + * + * Returns a list of member types of @type if existing, + * returns NULL otherwise. + */ +xmlSchemaTypeLinkPtr +xmlSchemaGetUnionSimpleTypeMemberTypes(xmlSchemaTypePtr type) +{ + while (type != NULL) { + if (type->memberTypes != NULL) + return (type->memberTypes); + else + type = type->baseType; + } + return (NULL); +} + +/** + * xmlSchemaGetListSimpleTypeItemType: + * @type: the simple type definition + * + * Returns the item type definition of the list simple type. + */ +static xmlSchemaTypePtr +xmlSchemaGetListSimpleTypeItemType(xmlSchemaTypePtr type) +{ + if ((type->flags & XML_SCHEMAS_TYPE_VARIETY_LIST) == 0) + return (NULL); + /* + * Note: In libxml2, the built-in types do not reflect + * the datatype hierarchy (yet?) - we have to treat them + * in a special way. + */ + if (type->type == XML_SCHEMA_TYPE_BASIC) + return (xmlSchemaGetBuiltInListSimpleTypeItemType(type)); + if (type->subtypes->type == XML_SCHEMA_TYPE_LIST) + /* 1 If the alternative is chosen, then the type + * definition ·resolved· to by the ·actual value· of the + * itemType [attribute] of , if present, otherwise + * the type definition corresponding to the + * among the [children] of . + */ + return (type->subtypes->subtypes); + else { + /* 2 If the option is chosen, then the + * {item type definition} of the {base type definition}. + */ + return (xmlSchemaGetListSimpleTypeItemType(type->baseType)); + } +} + +/** + * xmlSchemaCheckCOSSTDerivedOK: + * @type: the derived simple type definition + * @baseType: the base type definition + * + * Checks wheter @type can be validly + * derived from @baseType. + * + * Returns 0 on success, an positive error code otherwise. + */ +static int +xmlSchemaCheckCOSSTDerivedOK(xmlSchemaPtr schema, + xmlSchemaTypePtr type, + xmlSchemaTypePtr baseType, + int subset) +{ + /* + * Schema Component Constraint: Type Derivation OK (Simple) + * + * + * 1 They are the same type definition. + * TODO: The identy check might have to be more complex than this. + */ + if (type == baseType) + return (0); + /* + * 2.1 restriction is not in the subset, or in the {final} + * of its own {base type definition}; + */ + if ((subset & XML_SCHEMAS_TYPE_FINAL_RESTRICTION) || + (xmlSchemaTypeFinalContains(schema, + type->baseType, XML_SCHEMAS_TYPE_FINAL_RESTRICTION))) { + return (XML_SCHEMAP_COS_ST_DERIVED_OK_2_1); + } + /* 2.2 */ + if (type->baseType == baseType) { + /* + * 2.2.1 D's ·base type definition· is B. + */ + return (0); + } + /* + * 2.2.2 D's ·base type definition· is not the ·ur-type definition· + * and is validly derived from B given the subset, as defined by this + * constraint. + */ + if ((type->baseType != xmlSchemaGetBuiltInType(XML_SCHEMAS_ANYTYPE)) && + (xmlSchemaCheckCOSSTDerivedOK(schema, type->baseType, baseType, subset) == 0)) { + return (0); + } + /* + * 2.2.3 D's {variety} is list or union and B is the ·simple ur-type + * definition·. + */ + if (((type->flags & XML_SCHEMAS_TYPE_VARIETY_LIST) || + (type->flags & XML_SCHEMAS_TYPE_VARIETY_UNION)) && + (baseType == xmlSchemaGetBuiltInType(XML_SCHEMAS_ANYSIMPLETYPE))) { + return (0); + } + /* + * 2.2.4 B's {variety} is union and D is validly derived from a type + * definition in B's {member type definitions} given the subset, as + * defined by this constraint. + * + * NOTE: This seems not to involve built-in types, since there is no + * built-in Union Simple Type. + */ + if (baseType->flags & XML_SCHEMAS_TYPE_VARIETY_UNION) { + xmlSchemaTypeLinkPtr cur; + + cur = baseType->memberTypes; + while (cur != NULL) { + if (xmlSchemaCheckCOSSTDerivedOK(schema, type, + cur->type, subset) == 0) + return (0); + cur = cur->next; + } + } + + return (XML_SCHEMAP_COS_ST_DERIVED_OK_2_2); +} + + +/** + * xmlSchemaCheckSTPropsCorrect: + * @ctxt: the schema parser context + * @type: the simple type definition + * + * Checks st-props-correct. + * + * Returns 0 if the properties are correct, + * if not, a positive error code and -1 on internal + * errors. + */ +static int +xmlSchemaCheckSTPropsCorrect(xmlSchemaParserCtxtPtr ctxt, + xmlSchemaTypePtr type) +{ + xmlSchemaTypePtr baseType = type->baseType, anySimpleType, + anyType; + + /* + * Schema Component Constraint: Simple Type Definition Properties Correct + * + * NOTE: This is somehow redundant, since we actually built a simple type + * to have all the needed information; this acts as an self test. + */ + anySimpleType = xmlSchemaGetBuiltInType(XML_SCHEMAS_ANYSIMPLETYPE); + anyType = xmlSchemaGetBuiltInType(XML_SCHEMAS_ANYTYPE); + /* + * TODO: 1 The values of the properties of a simple type definition must be as + * described in the property tableau in Datatype definition, modulo the + * impact of Missing Sub-components (§5.3). + */ + /* Base type: If the datatype has been ·derived· by ·restriction· + * then the Simple Type Definition component from which it is ·derived·, + * otherwise the Simple Type Definition for anySimpleType (§4.1.6). + */ + if (baseType == NULL) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_ST_PROPS_CORRECT_1, + "Simple type \"%s\" does not have a base type.\n", + type->name, NULL); + return (XML_SCHEMAP_ST_PROPS_CORRECT_1); + } + if ((baseType->type != XML_SCHEMA_TYPE_SIMPLE) && + ((baseType->type != XML_SCHEMA_TYPE_BASIC) || + (baseType == anyType))) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_ST_PROPS_CORRECT_1, + "Simple type \"%s\": its base type \"%s\" is not a simple " + "type.\n", + type->name, baseType->name); + return (XML_SCHEMAP_ST_PROPS_CORRECT_1); + } + if ((baseType != anySimpleType) && + (type->subtypes->type != XML_SCHEMA_TYPE_RESTRICTION)) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_ST_PROPS_CORRECT_1, + "Simple type \"%s\" (not derived by restriction) must have" + "the simple ur-type definition as base type, not \"%s\".\n", + type->name, NULL); + return (XML_SCHEMAP_ST_PROPS_CORRECT_1); + } + /* + * Variety: One of {atomic, list, union}. + */ + if (((type->flags & XML_SCHEMAS_TYPE_VARIETY_ATOMIC) == 0) && + ((type->flags & XML_SCHEMAS_TYPE_VARIETY_UNION) == 0) && + ((type->flags & XML_SCHEMAS_TYPE_VARIETY_LIST) == 0)) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_ST_PROPS_CORRECT_1, + "Simple type \"%s\" has an absent variety.\n", + type->name, NULL); + return (XML_SCHEMAP_ST_PROPS_CORRECT_1); + } + /* TODO: Finish this. */ + + /* + * 2 All simple type definitions must be derived ultimately from the ·simple + * ur-type definition (so· circular definitions are disallowed). That is, it + * must be possible to reach a built-in primitive datatype or the ·simple + * ur-type definition· by repeatedly following the {base type definition}. + */ + baseType = type->baseType; + while ((baseType != NULL) && (baseType->type != XML_SCHEMA_TYPE_BASIC)) { + if (baseType->contentType == XML_SCHEMA_CONTENT_UNKNOWN) + xmlSchemaTypeFixup(baseType, ctxt, NULL); + if (baseType == anySimpleType) + break; + else if (baseType == type) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_ST_PROPS_CORRECT_2, + "Simple type \"%s\" is not derived from the simple " + "ur-type definition (circular definitions are disallowed).\n", + type->name, NULL); + return (XML_SCHEMAP_ST_PROPS_CORRECT_2); + } + baseType = baseType->baseType; + } + /* + * 3 The {final} of the {base type definition} must not contain restriction. + */ + if (xmlSchemaTypeFinalContains(ctxt->schema, baseType, + XML_SCHEMAS_TYPE_FINAL_RESTRICTION)) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_ST_PROPS_CORRECT_3, + "Simple type \"%s\": the \"final\" of its base type " + "\"%s\" must not contain \"restriction\".\n", + type->name, baseType->name); + return (XML_SCHEMAP_ST_PROPS_CORRECT_3); + } + return (0); +} + +/** + * xmlSchemaCheckDerivationValidSimpleRestriction: + * @ctxt: the schema parser context + * @type: the simple type definition + * + * Checks if the given @type (simpleType) is derived + * validly by restriction. + * + * Returns -1 on internal errors, 0 if the type is validly derived, + * a positive error code otherwise. + */ +static int +xmlSchemaCheckCOSSTRestricts(xmlSchemaParserCtxtPtr ctxt, + xmlSchemaTypePtr type) +{ + + if (type->type != XML_SCHEMA_TYPE_SIMPLE) { + xmlSchemaPErr(ctxt, type->node, + XML_ERR_INTERNAL_ERROR, + "xmlSchemaCheckDerivationValidSimpleRestriction: the given " + "type \"%s\" is not a user-derived simpleType.\n", + type->name, NULL); + return (-1); + } + + if (type->flags & XML_SCHEMAS_TYPE_VARIETY_ATOMIC) { + xmlSchemaTypePtr primitive; + /* + * 1.1 The {base type definition} must be an atomic simple + * type definition or a built-in primitive datatype. + */ + if ((type->baseType->flags & XML_SCHEMAS_TYPE_VARIETY_ATOMIC) == 0) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_1_1, + "Atomic simple type \"%s\": " + "its base type \"%s\" is not an atomic simple type.\n", + type->name, NULL); + return (XML_SCHEMAP_COS_ST_RESTRICTS_1_1); + } + /* 1.2 The {final} of the {base type definition} must not contain + * restriction. + */ + /* OPTIMIZE: This is already done in xmlSchemaCheckStPropsCorrect */ + if (xmlSchemaTypeFinalContains(ctxt->schema, type->baseType, + XML_SCHEMAS_TYPE_FINAL_RESTRICTION)) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_1_2, + "Atomic simple type \"%s\": the \"final\" of its base type " + "\"%s\" must not contain \"restriction\".\n", + type->name, type->baseType->name); + return (XML_SCHEMAP_COS_ST_RESTRICTS_1_2); + } + + /* + * 1.3.1 DF must be an allowed constraining facet for the {primitive + * type definition}, as specified in the appropriate subsection of 3.2 + * Primitive datatypes. + */ + if (type->facets != NULL) { + xmlSchemaFacetPtr facet; + int ok = 1; + + primitive = xmlSchemaGetPrimitiveType(type); + if (primitive == NULL) { + xmlSchemaPErr(ctxt, type->node, + XML_ERR_INTERNAL_ERROR, + "xmlSchemaCheckDerivationValidSimpleRestriction: failed " + "to get primitive type of type \"%s\".\n", + type->name, NULL); + return (-1); + } + facet = type->facets; + do { + if (xmlSchemaIsBuiltInTypeFacet(primitive, facet->type) == 0) { + xmlSchemaPErrExt(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_1_3_1, + NULL, NULL, NULL, + "Atomic simple type \"%s\": the facet \"%s\" " + "is not allowed on primitive type \"%s\".\n", + type->name, + xmlSchemaFacetTypeToString(facet->type), + primitive->name, NULL, NULL); + + ok = 0; + } + facet = facet->next; + } while (facet != NULL); + if (ok == 0) + return (XML_SCHEMAP_COS_ST_RESTRICTS_1_3_1); + + } + /* + * TODO: 1.3.2 (facet derivation) + */ + } else if (type->flags & XML_SCHEMAS_TYPE_VARIETY_LIST) { + xmlSchemaTypePtr itemType = NULL; + + itemType = xmlSchemaGetListSimpleTypeItemType(type); + if (itemType == NULL) { + xmlSchemaPErr(ctxt, type->node, + XML_ERR_INTERNAL_ERROR, + "Internal error: xmlSchemaCheckDerivationValidSimpleRestriction: " + "failed to evaluate the item type of type \"%s\".\n", + type->name, NULL); + return (-1); + } + /* + * 2.1 The {item type definition} must have a {variety} of atomic or + * union (in which case all the {member type definitions} + * must be atomic). + */ + if (((itemType->flags & XML_SCHEMAS_TYPE_VARIETY_ATOMIC) == 0) && + ((itemType->flags & XML_SCHEMAS_TYPE_VARIETY_UNION) == 0)) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_2_1, + "List simple type \"%s\": its item type \"%s\" " + "is not an atomic or union simple type.\n", + type->name, itemType->name); + return (XML_SCHEMAP_COS_ST_RESTRICTS_2_1); + } else if (itemType->flags & XML_SCHEMAS_TYPE_VARIETY_UNION) { + xmlSchemaTypeLinkPtr member; + + member = itemType->memberTypes; + while (member != NULL) { + if ((member->type->flags & + XML_SCHEMAS_TYPE_VARIETY_ATOMIC) == 0) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_2_1, + "List simple type \"%s\": its item type " + "is a union simple type, but the member type " + "\"%s\" of this item type is not an \"atomic\" " + "simple type.\n", + type->name, member->type->name); + return (XML_SCHEMAP_COS_ST_RESTRICTS_2_1); + } + member = member->next; + } + } + + if (type->baseType == xmlSchemaGetBuiltInType(XML_SCHEMAS_ANYSIMPLETYPE)) { + xmlSchemaFacetPtr facet; + /* + * This is the case if we have: schema, + itemType, XML_SCHEMAS_TYPE_FINAL_LIST)) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_1_1, + "List simple type \"%s\": the \"final\" of its item type " + "\"%s\" must not contain \"list\".\n", + type->name, itemType->name); + return (XML_SCHEMAP_COS_ST_RESTRICTS_2_3_1_1); + } + /* + * 2.3.1.2 The {facets} must only contain the whiteSpace + * facet component. + */ + if (type->facets != NULL) { + facet = type->facets; + do { + if (facet->type != XML_SCHEMA_FACET_WHITESPACE) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_1_2, + "List simple type \"%s\": the facet \"%s\" " + "is not allowed.\n", + type->name, xmlSchemaFacetTypeToString(facet->type)); + return (XML_SCHEMAP_COS_ST_RESTRICTS_2_3_1_2); + } + facet = facet->next; + } while (facet != NULL); + } + /* + * TODO: Datatypes states: + * A ·list· datatype can be ·derived· from an ·atomic· datatype + * whose ·lexical space· allows space (such as string or anyURI)or + * a ·union· datatype any of whose {member type definitions}'s + * ·lexical space· allows space. + */ + } else { + /* + * This is the case if we have: baseType->flags & XML_SCHEMAS_TYPE_VARIETY_LIST) == 0) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_1, + "List simple type \"%s\": its base type \"%s\" must " + "have a variety of list.\n", + type->name, type->baseType->name); + return (XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_1); + } + /* + * 2.3.2.2 The {final} of the {base type definition} must not + * contain restriction. + */ + if (xmlSchemaTypeFinalContains(ctxt->schema, type->baseType, + XML_SCHEMAS_TYPE_FINAL_RESTRICTION)) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_2, + "List simple type \"%s\": its base type \"%s\" must not " + "have a \"final\" containing \"restriction\".\n", + type->name, type->baseType->name); + return (XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_2); + } + /* + * 2.3.2.3 The {item type definition} must be validly derived + * from the {base type definition}'s {item type definition} given + * the empty set, as defined in Type Derivation OK (Simple) (§3.14.6). + */ + { + xmlSchemaTypePtr baseItemType; + + baseItemType = xmlSchemaGetListSimpleTypeItemType(type->baseType); + if (baseItemType == NULL) { + xmlSchemaPErr(ctxt, type->node, + XML_ERR_INTERNAL_ERROR, + "xmlSchemaCheckDerivationValidSimpleRestriction: " + "List simple type \"%s\": failed to " + "evaluate the item type of its base type \"%s\".\n", + type->name, type->baseType->name); + return (-1); + } + if ((itemType != baseItemType) && + (xmlSchemaCheckCOSSTDerivedOK(ctxt->schema, itemType, + baseItemType, 0) != 0)) { + xmlSchemaPErrExt(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_3, NULL, NULL, NULL, + "List simple type \"%s\": its item type \"%s\" is not " + "validly derived from the item type \"%s\" of the " + "base type \"%s\" as defined in Type Derivation OK " + "(Simple).\n", + type->name, itemType->name, baseItemType->name, + type->baseType->name, NULL); + return (XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_3); + } + } + + if (type->facets != NULL) { + xmlSchemaFacetPtr facet; + int ok = 1; + /* + * 2.3.2.4 Only length, minLength, maxLength, whiteSpace, pattern + * and enumeration facet components are allowed among the {facets}. + */ + facet = type->facets; + do { + switch (facet->type) { + case XML_SCHEMA_FACET_LENGTH: + case XML_SCHEMA_FACET_MINLENGTH: + case XML_SCHEMA_FACET_MAXLENGTH: + case XML_SCHEMA_FACET_WHITESPACE: + /* + * TODO: 2.5.1.2 List datatypes + * The value of ·whiteSpace· is fixed to the value collapse. + */ + case XML_SCHEMA_FACET_PATTERN: + case XML_SCHEMA_FACET_ENUMERATION: + break; + default: { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_4, + "List simple type \"%s\": the facet \"%s\" " + "is not allowed.\n", + type->name, + xmlSchemaFacetTypeToString(facet->type)); + /* + * We could return, but it's nicer to report all + * invalid facets. + */ + ok = 0; + } + } + facet = facet->next; + } while (facet != NULL); + if (ok == 0) + return (XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_4); + /* + * TODO: 2.3.2.5 For each facet in the {facets} (call this DF), if there + * is a facet of the same kind in the {facets} of the {base type + * definition} (call this BF),then the DF's {value} must be a valid + * restriction of BF's {value} as defined in [XML Schemas: Datatypes]. + */ + } + + + } + } else if (type->flags & XML_SCHEMAS_TYPE_VARIETY_UNION) { + /* + * 3.1 The {member type definitions} must all have {variety} of + * atomic or list. + */ + xmlSchemaTypeLinkPtr member; + + member = type->memberTypes; + while (member != NULL) { + if (((member->type->flags & + XML_SCHEMAS_TYPE_VARIETY_ATOMIC) == 0) && + ((member->type->flags & + XML_SCHEMAS_TYPE_VARIETY_LIST) == 0)) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_3_1, + "Union simple type \"%s\": the member type " + "\"%s\" is not an \"atomic\" simple type.\n", + type->name, member->type->name); + return (XML_SCHEMAP_COS_ST_RESTRICTS_3_1); + } + member = member->next; + } + /* + * 3.3.1 If the {base type definition} is the ·simple ur-type + * definition· + */ + if (type->baseType == xmlSchemaGetBuiltInType(XML_SCHEMAS_ANYSIMPLETYPE)) { + /* + * 3.3.1.1 All of the {member type definitions} must have a + * {final} which does not contain union. + */ + member = type->memberTypes; + while (member != NULL) { + if (xmlSchemaTypeFinalContains(ctxt->schema, member->type, + XML_SCHEMAS_TYPE_FINAL_UNION)) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_1, + "Union simple type \"%s\": the \"final\" of member type " + "\"%s\" contains \"union\".\n", + type->name, member->type->name); + return (XML_SCHEMAP_COS_ST_RESTRICTS_3_3_1); + } + member = member->next; + } + /* + * 3.3.1.2 The {facets} must be empty. + */ + if (type->facetSet != NULL) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_1_2, + "Union simple type \"%s\": the facets must be empty.\n", + type->name, NULL); + return (XML_SCHEMAP_COS_ST_RESTRICTS_3_3_1_2); + } + } else { + /* + * 3.3.2.1 The {base type definition} must have a {variety} of union. + */ + if ((type->baseType->flags & XML_SCHEMAS_TYPE_VARIETY_UNION) == 0) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_1, + "Union simple type \"%s\": its base type \"%s\" has not a " + "variety of union.\n", + type->name, type->baseType->name); + return (XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_1); + } + /* + * 3.3.2.2 The {final} of the {base type definition} must not contain restriction. + */ + if (xmlSchemaTypeFinalContains(ctxt->schema, type->baseType, + XML_SCHEMAS_TYPE_FINAL_RESTRICTION)) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_2, + "Union simple type \"%s\": the \"final\" of its base " + "type \"%s\" must not contain \"restriction\".\n", + type->name, type->baseType->name); + return (XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_2); + } + /* + * 3.3.2.3 The {member type definitions}, in order, must be validly + * derived from the corresponding type definitions in the {base + * type definition}'s {member type definitions} given the empty set, + * as defined in Type Derivation OK (Simple) (§3.14.6). + */ + { + xmlSchemaTypeLinkPtr baseMember; + + /* + * OPTIMIZE: if the type is restricting, it has no local defined + * member types and inherits the member types of the base type; + * thus a check for equality can be skipped. + */ + /* + * TODO: Even worse: I cannot see a scenario where a restricting + * union simple type can have other member types as the member + * types of it's base type. This check seems not necessary with + * respect to the derivation process in libxml2. + */ + if (type->memberTypes != NULL) { + member = type->memberTypes; + baseMember = xmlSchemaGetUnionSimpleTypeMemberTypes(type->baseType); + if ((member == NULL) && (baseMember != NULL)) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAS_ERR_INTERNAL, + "Internal error: " + "xmlSchemaCheckDerivationValidSimpleRestriction " + "(3.3.2.3), union simple type \"%s\", unequal number " + "of member types in the base type\n", + type->name, NULL); + } + while (member != NULL) { + if (baseMember == NULL) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAS_ERR_INTERNAL, + "Internal error: " + "xmlSchemaCheckDerivationValidSimpleRestriction " + "(3.3.2.3), union simple type \"%s\", unequal number " + "of member types in the base type\n", + type->name, NULL); + } + if ((member->type != baseMember->type) && + (xmlSchemaCheckCOSSTDerivedOK(ctxt->schema, + member->type, baseMember->type, 0) != 0)) { + xmlSchemaPErrExt(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_3, NULL, + NULL, NULL, + "Union simple type \"%s\": its member type " + "\"%s\" is not validly derived from its " + "corresponding member type \"%s\" of the base " + "type \"%s\" as defined in Type Derivation OK " + "(Simple).\n", + type->name, member->type->name, + baseMember->type->name, + type->baseType->name, NULL); + return (XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_3); + } + member = member->next; + baseMember = baseMember->next; + } + } + } + /* + * 3.3.2.4 Only pattern and enumeration facet components are + * allowed among the {facets}. + */ + if (type->facets != NULL) { + xmlSchemaFacetPtr facet; + int ok = 1; + + facet = type->facets; + do { + if ((facet->type != XML_SCHEMA_FACET_PATTERN) && + (facet->type != XML_SCHEMA_FACET_ENUMERATION)) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_4, + "Union simple type \"%s\": the facet \"%s\" " + "is not allowed.\n", + type->name, + xmlSchemaFacetTypeToString(facet->type)); + ok = 0; + } + facet = facet->next; + } while (facet != NULL); + if (ok == 0) + return (XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_4); + + } + /* + * TODO: 3.3.2.5 (facet derivation) + */ + } + } + + return (0); +} + +/** + * xmlSchemaCheckSRCSimpleType: + * @ctxt: the schema parser context + * @type: the simple type definition + * + * Checks crc-simple-type constraints. + * + * Returns 0 if the constraints are satisfied, + * if not a positive error code and -1 on internal + * errors. + */ +static int +xmlSchemaCheckSRCSimpleType(xmlSchemaParserCtxtPtr ctxt, + xmlSchemaTypePtr type) +{ + /* + * NOTE: src-simple-type 2-4 are redundant, since the checks + * were are done for the corresponding , and + * elements, but W3C wants a error as well, so it gets one. + * Maby this can be skipped in the future, if we get sure it's not needed. + */ + if (type->subtypes == NULL) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaCheckSRCSimpleType, " + "no subtype on simple type \"%s\".\n", + type->name, NULL); + return (-1); + } + /* + * src-simple-type.1 The corresponding simple type definition, if any, + * must satisfy the conditions set out in Constraints on Simple Type + * Definition Schema Components (§3.14.6). + */ + if ((xmlSchemaCheckSTPropsCorrect(ctxt, type) != 0) || + (xmlSchemaCheckCOSSTRestricts(ctxt, type) != 0)) { + /* + * TODO: Removed this, since it got annoying to get an + * extra error report, if anything failed until now. + * Enable this if needed. + */ + /* + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_SRC_SIMPLE_TYPE_1, + "Simple type \"%s\" does not satisfy the constraints " + "on simple type definitions.\n", + type->name, NULL); + */ + return (XML_SCHEMAP_SRC_SIMPLE_TYPE_1); + } + + if (type->subtypes->type == XML_SCHEMA_TYPE_RESTRICTION) { + /* + * src-simple-type.2 If the alternative is chosen, + * either it must have a base [attribute] or a among its + * [children], but not both. + */ + if (((type->subtypes->base == NULL) && + ((type->subtypes->subtypes == NULL) || + (type->subtypes->subtypes->type != XML_SCHEMA_TYPE_SIMPLE))) || + ((type->subtypes->base != NULL) && + (type->subtypes->subtypes != NULL) && + (type->subtypes->subtypes->type == XML_SCHEMA_TYPE_SIMPLE))) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_SRC_SIMPLE_TYPE_2, + "Simple type \"%s\": " + "The alternative is chosen, thus either the " + "\"base\" attribute or the child " + "must be present, but not both.\n", + type->name, NULL); + return (XML_SCHEMAP_SRC_SIMPLE_TYPE_2); + } + } else if (type->subtypes->type == XML_SCHEMA_TYPE_LIST) { + /* src-simple-type.3 If the alternative is chosen, either it must have + * an itemType [attribute] or a among its [children], + * but not both. + * NOTE: baseType is set to the local simple type definiton, + * if existent, at parse time. This is a hack and not nice. + */ + if (((type->subtypes->base == NULL) && + (type->baseType == NULL)) || + ((type->subtypes->base != NULL) && + (type->subtypes->baseType != NULL))) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_SRC_SIMPLE_TYPE_3, + "Simple type \"%s\": " + "The alternative is chosen, thus either the " + "\"itemType\" attribute or the child " + "must be present, but not both.\n", + type->name, NULL); + return (XML_SCHEMAP_SRC_SIMPLE_TYPE_3); + } + + + } else if (type->subtypes->type == XML_SCHEMA_TYPE_UNION) { + xmlSchemaTypeLinkPtr member; + xmlSchemaTypePtr ancestor, anySimpleType; + + anySimpleType = xmlSchemaGetBuiltInType(XML_SCHEMAS_ANYSIMPLETYPE); + + /* src-simple-type.4 Circular union type definition is disallowed. That is, if + * the alternative is chosen, there must not be any entries + * in the memberTypes [attribute] at any depth which resolve to the + * component corresponding to the . + */ + member = type->memberTypes; + while (member != NULL) { + ancestor = member->type; + while ((ancestor != NULL) && (ancestor->type != XML_SCHEMA_TYPE_BASIC)) { + if (ancestor->contentType == XML_SCHEMA_CONTENT_UNKNOWN) + xmlSchemaTypeFixup(ancestor, ctxt, NULL); + if (ancestor == anySimpleType) + break; + else if (ancestor == type) { + xmlSchemaPErr(ctxt, type->node, + XML_SCHEMAP_SRC_SIMPLE_TYPE_4, + "Simple type \"%s\" is not derived from the simple " + "ur-type definition (circular definitions are disallowed).\n", + type->name, NULL); + return (XML_SCHEMAP_SRC_SIMPLE_TYPE_4); + } else if (ancestor->flags & XML_SCHEMAS_TYPE_VARIETY_LIST) { + /* + * TODO: Although a list simple type must not have a union ST + * type as item type, which in turn has a list ST as member + * type, we will assume this here as well, since this check + * was not yet performed. + */ + + } + ancestor = ancestor->baseType; + } + member = member->next; + } + + } + + return (0); +} + /** * xmlSchemaTypeFixup: * @typeDecl: the schema type definition @@ -6443,35 +8048,46 @@ static void xmlSchemaTypeFixup(xmlSchemaTypePtr typeDecl, xmlSchemaParserCtxtPtr ctxt, const xmlChar * name) { + xmlSchemaTypePtr ctxtType; + if (typeDecl == NULL) return; if (name == NULL) name = typeDecl->name; if (typeDecl->contentType == XML_SCHEMA_CONTENT_UNKNOWN) { switch (typeDecl->type) { - case XML_SCHEMA_TYPE_SIMPLE_CONTENT:{ - xmlSchemaTypeFixup(typeDecl->subtypes, ctxt, NULL); - if (typeDecl->subtypes != NULL) + case XML_SCHEMA_TYPE_SIMPLE_CONTENT:{ + if (typeDecl->subtypes != NULL) { + if (typeDecl->subtypes->contentType == + XML_SCHEMA_CONTENT_UNKNOWN) { + xmlSchemaTypeFixup(typeDecl->subtypes, ctxt, + NULL); + } typeDecl->contentType = typeDecl->subtypes->contentType; + } break; } case XML_SCHEMA_TYPE_RESTRICTION:{ + xmlSchemaTypePtr base = NULL; + + ctxt->ctxtType->flags |= + XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION; if (typeDecl->subtypes != NULL) xmlSchemaTypeFixup(typeDecl->subtypes, ctxt, NULL); if (typeDecl->base != NULL) { - xmlSchemaTypePtr baseType; - - baseType = + base = xmlSchemaGetType(ctxt->schema, typeDecl->base, typeDecl->baseNs); - if (baseType == NULL) { + if (base == NULL) { xmlSchemaPErr(ctxt, typeDecl->node, - XML_SCHEMAP_UNKNOWN_BASE_TYPE, - "Schemas: type %s base type %s not found\n", - name, typeDecl->base); - } else if (baseType->contentType == + XML_SCHEMAP_SRC_RESOLVE, + "Restriction \"%s\": the QName \"%s\" of the " + "attribute \"base\" does not resolve to a schema " + "component.\n", + name, typeDecl->base); + } else if (base->contentType == XML_SCHEMA_CONTENT_UNKNOWN) { /* * The base type might be not "type fixed" yet, @@ -6480,94 +8096,89 @@ xmlSchemaTypeFixup(xmlSchemaTypePtr typeDecl, * TODO: Is a check for circular derivation already * done? */ - xmlSchemaTypeFixup(baseType, ctxt, NULL); - } - typeDecl->baseType = baseType; + xmlSchemaTypeFixup(base, ctxt, NULL); + } } - if (typeDecl->subtypes == NULL) - if (typeDecl->baseType != NULL) { + if (ctxt->ctxtType->type == XML_SCHEMA_TYPE_COMPLEX) { + /* + * ComplexType restriction. + */ + /* + * Base type: The type definition ·resolved· to by the ·actual + * value· of the base [attribute] + */ + ctxt->ctxtType->baseType = base; + /* + * Content type. + */ + if (typeDecl->subtypes == NULL) + /* 1.1.1 */ + typeDecl->contentType = XML_SCHEMA_CONTENT_EMPTY; + else if ((typeDecl->subtypes->subtypes == NULL) && + ((typeDecl->subtypes->type == + XML_SCHEMA_TYPE_ALL) + || (typeDecl->subtypes->type == + XML_SCHEMA_TYPE_SEQUENCE))) + /* 1.1.2 */ + typeDecl->contentType = XML_SCHEMA_CONTENT_EMPTY; + else if ((typeDecl->subtypes->type == + XML_SCHEMA_TYPE_CHOICE) + && (typeDecl->subtypes->subtypes == NULL)) + /* 1.1.3 */ + typeDecl->contentType = XML_SCHEMA_CONTENT_EMPTY; + else { + /* 1.2 and 2.X are applied at the other layer */ typeDecl->contentType = - typeDecl->baseType->contentType; + XML_SCHEMA_CONTENT_ELEMENTS; + } + } else { + /* + * SimpleType restriction. + */ + /* Base type: + * The Simple Type Definition component resolved to by + * the actual value of the base [attribute] or the + * [children], whichever is present. + */ + if ((base == NULL) && (typeDecl->subtypes != NULL)) { + base = typeDecl->subtypes; + ctxt->ctxtType->baseType = base; + if (base->contentType == XML_SCHEMA_CONTENT_UNKNOWN) + xmlSchemaTypeFixup(base, ctxt, NULL); } else - /* 1.1.1 */ - typeDecl->contentType = XML_SCHEMA_CONTENT_EMPTY; - else if ((typeDecl->subtypes->subtypes == NULL) && - ((typeDecl->subtypes->type == - XML_SCHEMA_TYPE_ALL) - || (typeDecl->subtypes->type == - XML_SCHEMA_TYPE_SEQUENCE))) - /* 1.1.2 */ - typeDecl->contentType = XML_SCHEMA_CONTENT_EMPTY; - else if ((typeDecl->subtypes->type == - XML_SCHEMA_TYPE_CHOICE) - && (typeDecl->subtypes->subtypes == NULL)) - /* 1.1.3 */ - typeDecl->contentType = XML_SCHEMA_CONTENT_EMPTY; - else { - /* 1.2 and 2.X are applied at the other layer */ - typeDecl->contentType = - XML_SCHEMA_CONTENT_ELEMENTS; - } + ctxt->ctxtType->baseType = base; + + if (((typeDecl->base == NULL) && + ((typeDecl->subtypes == NULL) || + (typeDecl->subtypes->type != XML_SCHEMA_TYPE_SIMPLE))) || + ((typeDecl->base != NULL) && + (typeDecl->subtypes != NULL) && + (typeDecl->subtypes->type == XML_SCHEMA_TYPE_SIMPLE))) { + /* + * src-restriction-base-or-simpleType + * Either the base [attribute] or the simpleType [child] of the + * element must be present, but not both. + */ + xmlSchemaPErr(ctxt, typeDecl->node, + XML_SCHEMAP_SRC_RESTRICTION_BASE_OR_SIMPLETYPE, + "Restriction \"%s\": " + "Either the \"base\" attribute or the child " + "must be present, but not both.\n", + typeDecl->name, NULL); + } + } break; } case XML_SCHEMA_TYPE_EXTENSION:{ - xmlSchemaContentType explicitContentType; - xmlSchemaTypePtr base; - - if (typeDecl->base != NULL) { - xmlSchemaTypePtr baseType; - - baseType = - xmlSchemaGetType(ctxt->schema, typeDecl->base, - typeDecl->baseNs); - if (baseType == NULL) { - xmlSchemaPErr(ctxt, typeDecl->node, - XML_SCHEMAP_UNKNOWN_BASE_TYPE, - "Schemas: type %s base type %s not found\n", - name, typeDecl->base); - } else if (baseType->contentType == - XML_SCHEMA_CONTENT_UNKNOWN) { - /* - * The base type might be not "type fixed" yet, - * so do it now. */ - /* - * TODO: Is a check for circular derivation already - * done? - */ - xmlSchemaTypeFixup(baseType, ctxt, NULL); - } - typeDecl->baseType = baseType; - } - if (typeDecl->subtypes != NULL) - xmlSchemaTypeFixup(typeDecl->subtypes, ctxt, NULL); - - explicitContentType = XML_SCHEMA_CONTENT_ELEMENTS; - if (typeDecl->subtypes == NULL) - /* 1.1.1 */ - explicitContentType = XML_SCHEMA_CONTENT_EMPTY; - else if ((typeDecl->subtypes->subtypes == NULL) && - ((typeDecl->subtypes->type == - XML_SCHEMA_TYPE_ALL) - || (typeDecl->subtypes->type == - XML_SCHEMA_TYPE_SEQUENCE))) - /* 1.1.2 */ - explicitContentType = XML_SCHEMA_CONTENT_EMPTY; - else if ((typeDecl->subtypes->type == - XML_SCHEMA_TYPE_CHOICE) - && (typeDecl->subtypes->subtypes == NULL)) - /* 1.1.3 */ - explicitContentType = XML_SCHEMA_CONTENT_EMPTY; - - base = xmlSchemaGetType(ctxt->schema, typeDecl->base, - typeDecl->baseNs); - if (base == NULL) { - xmlSchemaPErr(ctxt, typeDecl->node, - XML_SCHEMAP_UNKNOWN_BASE_TYPE, - "Schemas: base type %s of type %s not found\n", - typeDecl->base, name); - return; - } - if (typeDecl->recurse) { + xmlSchemaTypePtr base = NULL; + xmlSchemaContentType explicitContentType; + + /* + * An extension does exist on a complexType only. + */ + ctxt->ctxtType->flags |= + XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION; + if (typeDecl->recurse) { /* TODO: The word "recursive" should be changed to "circular" here. */ xmlSchemaPErr(ctxt, typeDecl->node, XML_SCHEMAP_UNKNOWN_BASE_TYPE, @@ -6575,59 +8186,113 @@ xmlSchemaTypeFixup(xmlSchemaTypePtr typeDecl, name, NULL); return; } - typeDecl->recurse = 1; - xmlSchemaTypeFixup(base, ctxt, NULL); - typeDecl->recurse = 0; - if (explicitContentType == XML_SCHEMA_CONTENT_EMPTY) { - /* 2.1 */ - typeDecl->contentType = base->contentType; - } else if (base->contentType == - XML_SCHEMA_CONTENT_EMPTY) { - /* 2.2 imbitable ! */ - typeDecl->contentType = - XML_SCHEMA_CONTENT_ELEMENTS; - } else { - /* 2.3 imbitable pareil ! */ - typeDecl->contentType = - XML_SCHEMA_CONTENT_ELEMENTS; + if (typeDecl->base != NULL) { + base = + xmlSchemaGetType(ctxt->schema, typeDecl->base, + typeDecl->baseNs); + if (base == NULL) { + xmlSchemaPErr(ctxt, typeDecl->node, + XML_SCHEMAP_SRC_RESOLVE, + "Extension \"%s\": the QName \"%s\" of the " + "attribute \"base\" does not resolve to a schema " + "component.\n", + name, typeDecl->base); + } else if (base->contentType == + XML_SCHEMA_CONTENT_UNKNOWN) { + typeDecl->recurse = 1; + xmlSchemaTypeFixup(base, ctxt, NULL); + typeDecl->recurse = 0; + } + /* + * The type definition ·resolved· to by the ·actual + * value· of the base [attribute] + */ + ctxt->ctxtType->baseType = base; + /* + * TODO: This one is still needed for computation of + * the content model by xmlSchemaBuildAContentModel. + * Try to get rid of it. + */ + typeDecl->baseType = base; } + if ((typeDecl->subtypes != NULL) && + (typeDecl->subtypes->contentType == XML_SCHEMA_CONTENT_UNKNOWN)) + xmlSchemaTypeFixup(typeDecl->subtypes, ctxt, NULL); + + explicitContentType = XML_SCHEMA_CONTENT_ELEMENTS; + if (typeDecl->subtypes == NULL) + /* 1.1.1 */ + explicitContentType = XML_SCHEMA_CONTENT_EMPTY; + else if ((typeDecl->subtypes->subtypes == NULL) && + ((typeDecl->subtypes->type == + XML_SCHEMA_TYPE_ALL) + || (typeDecl->subtypes->type == + XML_SCHEMA_TYPE_SEQUENCE))) + /* 1.1.2 */ + explicitContentType = XML_SCHEMA_CONTENT_EMPTY; + else if ((typeDecl->subtypes->type == + XML_SCHEMA_TYPE_CHOICE) + && (typeDecl->subtypes->subtypes == NULL)) + /* 1.1.3 */ + explicitContentType = XML_SCHEMA_CONTENT_EMPTY; + if (base != NULL) { + /* It will be reported later, if the base is missing. */ + if (explicitContentType == XML_SCHEMA_CONTENT_EMPTY) { + /* 2.1 */ + typeDecl->contentType = base->contentType; + } else if (base->contentType == + XML_SCHEMA_CONTENT_EMPTY) { + /* 2.2 imbitable ! */ + typeDecl->contentType = + XML_SCHEMA_CONTENT_ELEMENTS; + } else { + /* 2.3 imbitable pareil ! */ + typeDecl->contentType = + XML_SCHEMA_CONTENT_ELEMENTS; + } + } break; } case XML_SCHEMA_TYPE_COMPLEX:{ + if ((typeDecl->subtypes == NULL) || + ((typeDecl->subtypes->type != + XML_SCHEMA_TYPE_SIMPLE_CONTENT) && + (typeDecl->subtypes->type != + XML_SCHEMA_TYPE_COMPLEX_CONTENT))) { + /* + * This case is understood as shorthand for complex + * content restricting the ur-type definition, and + * the details of the mappings should be modified as + * necessary. + */ + typeDecl->baseType = xmlSchemaGetBuiltInType(XML_SCHEMAS_ANYTYPE); + typeDecl->flags |= + XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION; + } if (typeDecl->subtypes == NULL) { - typeDecl->contentType = XML_SCHEMA_CONTENT_EMPTY; - + typeDecl->contentType = XML_SCHEMA_CONTENT_EMPTY; if (typeDecl->flags & XML_SCHEMAS_TYPE_MIXED) typeDecl->contentType = - XML_SCHEMA_CONTENT_MIXED; + XML_SCHEMA_CONTENT_MIXED; } else { + if ((typeDecl->subtypes != NULL) && + (typeDecl->subtypes->contentType == + XML_SCHEMA_CONTENT_UNKNOWN)) { + ctxtType = ctxt->ctxtType; + ctxt->ctxtType = typeDecl; + xmlSchemaTypeFixup(typeDecl->subtypes, ctxt, + NULL); + ctxt->ctxtType = ctxtType; + } if (typeDecl->flags & XML_SCHEMAS_TYPE_MIXED) { typeDecl->contentType = XML_SCHEMA_CONTENT_MIXED; - } else { - xmlSchemaTypeFixup(typeDecl->subtypes, ctxt, - NULL); - if (typeDecl->subtypes != NULL) + } else { + if (typeDecl->subtypes != NULL) { typeDecl->contentType = typeDecl->subtypes->contentType; - } - /* Evaluate the derivation method. */ - if ((typeDecl->subtypes != NULL) && - ((typeDecl->subtypes->type == - XML_SCHEMA_TYPE_COMPLEX_CONTENT) || - (typeDecl->subtypes->type == - XML_SCHEMA_TYPE_SIMPLE_CONTENT)) && - (typeDecl->subtypes->subtypes != NULL)) { - if (typeDecl->subtypes->subtypes->type == - XML_SCHEMA_TYPE_EXTENSION) { - typeDecl->flags |= - XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION; - } else if (typeDecl->subtypes->subtypes->type == - XML_SCHEMA_TYPE_RESTRICTION) { - typeDecl->flags |= - XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION; - } - } + } + } } xmlSchemaBuildAttributeValidation(ctxt, typeDecl); break; @@ -6660,23 +8325,149 @@ xmlSchemaTypeFixup(xmlSchemaTypePtr typeDecl, } break; } + case XML_SCHEMA_TYPE_SIMPLE: + /* + * Simple Type Definition Schema Component + * + */ + typeDecl->contentType = XML_SCHEMA_CONTENT_SIMPLE; + if (typeDecl->subtypes->contentType == + XML_SCHEMA_CONTENT_UNKNOWN) { + ctxtType = ctxt->ctxtType; + ctxt->ctxtType = typeDecl; + xmlSchemaTypeFixup(typeDecl->subtypes, ctxt, NULL); + ctxt->ctxtType = ctxtType; + } + /* Fixup base type */ + if ((typeDecl->baseType != NULL) && + (typeDecl->baseType->contentType == + XML_SCHEMA_CONTENT_UNKNOWN)) { + /* OPTIMIZE: Actually this one will never by hit, since + * the base type is already type-fixed in . + */ + ctxtType = ctxt->ctxtType; + ctxt->ctxtType = typeDecl; + xmlSchemaTypeFixup(typeDecl->baseType, ctxt, NULL); + ctxt->ctxtType = ctxtType; + } + /* Base type: + * 2 If the or alternative is chosen, + * then the ·simple ur-type definition·. + */ + if (typeDecl->subtypes->type == + XML_SCHEMA_TYPE_LIST) { + typeDecl->baseType = xmlSchemaGetBuiltInType(XML_SCHEMAS_ANYSIMPLETYPE); + typeDecl->flags |= XML_SCHEMAS_TYPE_VARIETY_LIST; + } else if (typeDecl->subtypes->type == + XML_SCHEMA_TYPE_UNION) { + typeDecl->baseType = xmlSchemaGetBuiltInType(XML_SCHEMAS_ANYSIMPLETYPE); + typeDecl->flags |= XML_SCHEMAS_TYPE_VARIETY_UNION; + } else if (typeDecl->subtypes->type == + XML_SCHEMA_TYPE_RESTRICTION) { + xmlSchemaFacetLinkPtr facet, cur, last = NULL; + + /* + * Variety + * If the alternative is chosen, then the + * {variety} of the {base type definition}. + */ + if (typeDecl->baseType != NULL) { + if (typeDecl->baseType->flags & + XML_SCHEMAS_TYPE_VARIETY_ATOMIC) + typeDecl->flags |= XML_SCHEMAS_TYPE_VARIETY_ATOMIC; + else if (typeDecl->baseType->flags & + XML_SCHEMAS_TYPE_VARIETY_LIST) + typeDecl->flags |= XML_SCHEMAS_TYPE_VARIETY_LIST; + else if (typeDecl->baseType->flags & + XML_SCHEMAS_TYPE_VARIETY_UNION) + typeDecl->flags |= XML_SCHEMAS_TYPE_VARIETY_UNION; + /* + * Schema Component Constraint: Simple Type Restriction + * (Facets) + * NOTE: Satisfaction of 1 and 2 arise from the fixup + * applied beforehand. + * + * 3 The {facets} of R are the union of S and the {facets} + * of B, eliminating duplicates. To eliminate duplicates, + * when a facet of the same kind occurs in both S and the + * {facets} of B, the one in the {facets} of B is not + * included, with the exception of enumeration and pattern + * facets, for which multiple occurrences with distinct values + * are allowed. + */ + if (typeDecl->baseType->facetSet != NULL) { + last = typeDecl->facetSet; + if (last != NULL) + while (last->next != NULL) + last = last->next; + cur = typeDecl->baseType->facetSet; + for (; cur != NULL; cur = cur->next) { + /* + * Base patterns won't be add here: + * they are ORed in a type and + * ANDed in derived types. This will + * happed at validation level by + * walking the base axis of the type. + */ + if (cur->facet->type == + XML_SCHEMA_FACET_PATTERN) + continue; + facet = NULL; + if ((typeDecl->facetSet != NULL) && + (cur->facet->type != + XML_SCHEMA_FACET_PATTERN) && + (cur->facet->type != + XML_SCHEMA_FACET_ENUMERATION)) { + facet = typeDecl->facetSet; + do { + if (cur->facet->type == + facet->facet->type) + break; + facet = facet->next; + } while (facet != NULL); + } + if (facet == NULL) { + facet = (xmlSchemaFacetLinkPtr) + xmlMalloc(sizeof(xmlSchemaFacetLink)); + if (facet == NULL) { + xmlSchemaPErrMemory(ctxt, + "fixing simpleType", NULL); + return; + } + facet->facet = cur->facet; + facet->next = NULL; + if (last == NULL) + typeDecl->facetSet = facet; + else + last->next = facet; + last = facet; + } + } + } + } + } + /* + * Check constraints. + */ + xmlSchemaCheckSRCSimpleType(ctxt, typeDecl); + break; case XML_SCHEMA_TYPE_SEQUENCE: case XML_SCHEMA_TYPE_GROUP: case XML_SCHEMA_TYPE_ALL: case XML_SCHEMA_TYPE_CHOICE: typeDecl->contentType = XML_SCHEMA_CONTENT_ELEMENTS; break; - case XML_SCHEMA_TYPE_LIST: + case XML_SCHEMA_TYPE_LIST: xmlSchemaParseListRefFixup(typeDecl, ctxt); - /* no break on purpose */ - case XML_SCHEMA_TYPE_UNION: - if (typeDecl->type == XML_SCHEMA_TYPE_UNION) - xmlSchemaParseUnionRefCheck(typeDecl, ctxt); - /* no break on purpose */ + typeDecl->contentType = XML_SCHEMA_CONTENT_SIMPLE; + break; + case XML_SCHEMA_TYPE_UNION: + xmlSchemaParseUnionRefCheck(typeDecl, ctxt); + typeDecl->contentType = XML_SCHEMA_CONTENT_SIMPLE; + break; case XML_SCHEMA_TYPE_BASIC: case XML_SCHEMA_TYPE_ANY: case XML_SCHEMA_TYPE_FACET: - case XML_SCHEMA_TYPE_SIMPLE: case XML_SCHEMA_TYPE_UR: case XML_SCHEMA_TYPE_ELEMENT: case XML_SCHEMA_TYPE_ATTRIBUTE: @@ -6726,9 +8517,12 @@ xmlSchemaTypeFixup(xmlSchemaTypePtr typeDecl, case XML_SCHEMA_CONTENT_MIXED: xmlGenericError(xmlGenericErrorContext, "mixed\n"); break; + /* Removed, since not used. */ + /* case XML_SCHEMA_CONTENT_MIXED_OR_ELEMENTS: xmlGenericError(xmlGenericErrorContext, "mixed or elems\n"); break; + */ case XML_SCHEMA_CONTENT_BASIC: xmlGenericError(xmlGenericErrorContext, "basic\n"); break; @@ -6761,8 +8555,7 @@ xmlSchemaCheckFacet(xmlSchemaFacetPtr facet, if (nonNegativeIntegerType == NULL) { nonNegativeIntegerType = - xmlSchemaGetPredefinedType(BAD_CAST "nonNegativeInteger", - xmlSchemaNs); + xmlSchemaGetBuiltInType(XML_SCHEMAS_NNINTEGER); } switch (facet->type) { case XML_SCHEMA_FACET_MININCLUSIVE: @@ -6774,21 +8567,44 @@ xmlSchemaCheckFacet(xmlSchemaFacetPtr facet, * at that point. */ xmlSchemaValidCtxtPtr vctxt; - + xmlSchemaTypePtr base; + + /* + * TODO: Try to avoid creating a new context. + */ vctxt = xmlSchemaNewValidCtxt(NULL); if (vctxt == NULL) - break; - xmlSchemaValidateSimpleValue(vctxt, typeDecl, + break; + /* xmlSchemaValidateSimpleValue(vctxt, typeDecl, facet->value); + */ + /* The value ·must· be in the + * ·value space· of the ·base type·. + */ + base = typeDecl->baseType; + if (base == NULL) { + xmlSchemaPErr(ctxt, typeDecl->node, + XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaCheckFacet, " + "the type \"%s\" has no base type.\n", + typeDecl->name, NULL); + return (-1); + } + vctxt->type = base; + xmlSchemaValidateSimpleTypeValue(vctxt, facet->value, 0, 1); facet->val = vctxt->value; vctxt->value = NULL; if (facet->val == NULL) { /* error code */ if (ctxt != NULL) { - xmlSchemaPErr(ctxt, facet->node, - XML_SCHEMAP_INVALID_FACET, - "Schemas: type %s facet value %s invalid\n", - name, facet->value); + xmlSchemaPErrExt(ctxt, facet->node, + XML_SCHEMAP_INVALID_FACET, + NULL, NULL, NULL, + "Type \"%s\": the value \"%s\" of the " + "facet \"%s\" is invalid.\n", + name, facet->value, + xmlSchemaFacetTypeToString(facet->type), + NULL, NULL); } ret = -1; } @@ -6802,18 +8618,37 @@ xmlSchemaCheckFacet(xmlSchemaFacetPtr facet, */ xmlSchemaValidCtxtPtr vctxt; int tmp; + xmlSchemaTypePtr base; + /* 4.3.5.5 Constraints on enumeration Schema Components + * Schema Component Constraint: enumeration valid restriction + * It is an ·error· if any member of {value} is not in the + * ·value space· of {base type definition}. + */ vctxt = xmlSchemaNewValidCtxt(NULL); if (vctxt == NULL) break; - tmp = xmlSchemaValidateSimpleValue(vctxt, typeDecl, + base = typeDecl->baseType; + if (base == NULL) { + xmlSchemaPErr(ctxt, typeDecl->node, + XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaCheckFacet, " + "the type \"%s\" has no base type.\n", + typeDecl->name, NULL); + return (-1); + } + vctxt->type = base; + tmp = xmlSchemaValidateSimpleTypeValue(vctxt, facet->value, 0, 1); + /* tmp = xmlSchemaValidateSimpleValue(vctxt, typeDecl, facet->value); + */ if (tmp != 0) { if (ctxt != NULL) { xmlSchemaPErr(ctxt, facet->node, - XML_SCHEMAP_INVALID_ENUM, - "Schemas: type %s enumeration value %s invalid\n", - name, facet->value); + XML_SCHEMAP_INVALID_ENUM, + "Type \"%s\": the value \"%s\" of the " + "facet \"enumeration\" is invalid.\n", + name, facet->value); } ret = -1; } @@ -6824,9 +8659,10 @@ xmlSchemaCheckFacet(xmlSchemaFacetPtr facet, facet->regexp = xmlRegexpCompile(facet->value); if (facet->regexp == NULL) { xmlSchemaPErr(ctxt, typeDecl->node, - XML_SCHEMAP_REGEXP_INVALID, - "Schemas: type %s facet regexp %s invalid\n", - name, facet->value); + XML_SCHEMAP_REGEXP_INVALID, + "Type \"%s\": the value \"%s\" of the " + "facet \"pattern\" is invalid.\n", + name, facet->value); ret = -1; } break; @@ -6844,10 +8680,14 @@ xmlSchemaCheckFacet(xmlSchemaFacetPtr facet, if (tmp != 0) { /* error code */ if (ctxt != NULL) { - xmlSchemaPErr(ctxt, facet->node, - XML_SCHEMAP_INVALID_FACET_VALUE, - "Schemas: type %s facet value %s invalid\n", - name, facet->value); + xmlSchemaPErrExt(ctxt, facet->node, + XML_SCHEMAP_INVALID_FACET_VALUE, + NULL, NULL, NULL, + "Type \"%s\": the value \"%s\" of the " + "facet \"%s\" is invalid.\n", + name, facet->value, + xmlSchemaFacetTypeToString(facet->type), + NULL, NULL); } ret = -1; } @@ -6863,9 +8703,10 @@ xmlSchemaCheckFacet(xmlSchemaFacetPtr facet, } else { if (ctxt != NULL) { xmlSchemaPErr(ctxt, facet->node, - XML_SCHEMAP_INVALID_WHITE_SPACE, - "Schemas: type %s whiteSpace value %s invalid\n", - name, facet->value); + XML_SCHEMAP_INVALID_WHITE_SPACE, + "Type \"%s\": the value \"%s\" of the " + "facet \"whiteSpace\" is invalid.\n", + name, facet->value); } ret = -1; } @@ -6888,17 +8729,19 @@ xmlSchemaCheckDefaults(xmlSchemaTypePtr typeDecl, xmlSchemaParserCtxtPtr ctxt, const xmlChar * name) { if (name == NULL) - name = typeDecl->name; - if (typeDecl->type == XML_SCHEMA_TYPE_RESTRICTION) { - if (typeDecl->facets != NULL) { - xmlSchemaFacetPtr facet = typeDecl->facets; - - while (facet != NULL) { - xmlSchemaCheckFacet(facet, typeDecl, ctxt, name); - facet = facet->next; - } - } - } + name = typeDecl->name; + /* + * NOTE: It is intended to use the facets list, instead + * of facetSet. + */ + if (typeDecl->facets != NULL) { + xmlSchemaFacetPtr facet = typeDecl->facets; + + while (facet != NULL) { + xmlSchemaCheckFacet(facet, typeDecl, ctxt, name); + facet = facet->next; + } + } } /** @@ -6923,9 +8766,11 @@ xmlSchemaAttrGrpFixup(xmlSchemaAttributeGroupPtr attrgrp, ref = xmlSchemaGetAttributeGroup(ctxt->schema, attrgrp->ref, attrgrp->refNs); if (ref == NULL) { xmlSchemaPErr(ctxt, attrgrp->node, - XML_SCHEMAP_UNKNOWN_ATTRIBUTE_GROUP, - "Schemas: attribute group %s reference %s not found\n", - name, attrgrp->ref); + XML_SCHEMAP_SRC_RESOLVE, + "Attribute group \"%s\": the QName \"%s\" of the attribute " + "\"ref\" does not resolve to a schema " + "component.\n", + name, attrgrp->ref); return; } xmlSchemaAttrGrpFixup(ref, ctxt, NULL); @@ -6957,6 +8802,12 @@ static void xmlSchemaAttrFixup(xmlSchemaAttributePtr attrDecl, xmlSchemaParserCtxtPtr ctxt, const xmlChar * name) { + /* + * The simple type definition corresponding to the element + * information item in the [children], if present, otherwise the simple + * type definition ·resolved· to by the ·actual value· of the type + * [attribute], if present, otherwise the ·simple ur-type definition·. + */ if (name == NULL) name = attrDecl->name; if (attrDecl->subtypes != NULL) @@ -6964,30 +8815,34 @@ xmlSchemaAttrFixup(xmlSchemaAttributePtr attrDecl, if (attrDecl->typeName != NULL) { xmlSchemaTypePtr type; - type = xmlSchemaGetType(ctxt->schema, attrDecl->typeName, - attrDecl->typeNs); - if (type == NULL) { - xmlSchemaPErr(ctxt, attrDecl->node, XML_SCHEMAP_UNKNOWN_TYPE, - "Schemas: attribute %s type %s not found\n", - name, attrDecl->typeName); - } + type = xmlSchemaGetType(ctxt->schema, attrDecl->typeName, + attrDecl->typeNs); + if (type == NULL) { + xmlSchemaPErr(ctxt, attrDecl->node, + XML_SCHEMAP_SRC_RESOLVE, + "Attribute \"%s\": the QName \"%s\" of the attribute " + "\"type\" does not resolve to a schema " + "component.\n", + name, attrDecl->typeName); + } attrDecl->subtypes = type; } else if (attrDecl->ref != NULL) { xmlSchemaAttributePtr ref; ref = xmlSchemaGetAttribute(ctxt->schema, attrDecl->ref, attrDecl->refNs); if (ref == NULL) { - xmlSchemaPErr(ctxt, attrDecl->node, XML_SCHEMAP_UNKNOWN_REF, - "Schemas: attribute %s reference %s not found\n", - name, attrDecl->ref); + xmlSchemaPErr(ctxt, attrDecl->node, + XML_SCHEMAP_SRC_RESOLVE, + "Attribute \"%s\": the QName \"%s\" of the attribute " + "\"ref\" does not resolve to a schema " + "component.\n", + name, attrDecl->ref); return; } xmlSchemaAttrFixup(ref, ctxt, NULL); attrDecl->subtypes = ref->subtypes; } else { - xmlSchemaPErr(ctxt, attrDecl->node, XML_SCHEMAP_NOTYPE_NOREF, - "Schemas: attribute %s has no type nor reference\n", - name, NULL); + attrDecl->subtypes = xmlSchemaGetBuiltInType(XML_SCHEMAS_ANYSIMPLETYPE); } } @@ -7213,41 +9068,44 @@ xmlSchemaFacetTypeToString(xmlSchemaTypeType type) static int xmlSchemaValidateFacetsInternal(xmlSchemaValidCtxtPtr ctxt, xmlSchemaTypePtr base, - xmlSchemaFacetPtr facets, + xmlSchemaFacetLinkPtr facets, const xmlChar * value, int fireErrors) { int ret = 0; int tmp = 0; xmlSchemaTypeType type; - xmlSchemaFacetPtr facet = facets; + xmlSchemaFacetLinkPtr facetLink = facets; - while (facet != NULL) { - type = facet->type; + while (facetLink != NULL) { + type = facetLink->facet->type; if (type == XML_SCHEMA_FACET_ENUMERATION) { tmp = 1; - while (facet != NULL) { + while (facetLink != NULL) { tmp = - xmlSchemaValidateFacet(base, facet, value, + xmlSchemaValidateFacet(base, facetLink->facet, value, ctxt->value); if (tmp == 0) { return 0; } - facet = facet->next; + facetLink = facetLink->next; } } else - tmp = xmlSchemaValidateFacet(base, facet, value, ctxt->value); + tmp = xmlSchemaValidateFacet(base, facetLink->facet, value, + ctxt->value); if (tmp != 0) { ret = tmp; - if (fireErrors) - xmlSchemaVErr(ctxt, ctxt->cur, XML_SCHEMAS_ERR_FACET, - "Failed to validate type with facet %s\n", - (const xmlChar *) xmlSchemaFacetTypeToString(type), - NULL); + if (fireErrors) { + xmlSchemaVErr(ctxt, ctxt->cur, tmp, + "The value failed to validate against the facet \"%s\".\n", + (const xmlChar *) xmlSchemaFacetTypeToString(type), + NULL); + + } } - if (facet != NULL) - facet = facet->next; + if (facetLink != NULL) + facetLink = facetLink->next; } return (ret); } @@ -7268,7 +9126,7 @@ xmlSchemaValidateFacetsInternal(xmlSchemaValidCtxtPtr ctxt, static int xmlSchemaValidateFacets(xmlSchemaValidCtxtPtr ctxt, xmlSchemaTypePtr base, - xmlSchemaFacetPtr facets, const xmlChar * value) + xmlSchemaFacetLinkPtr facets, const xmlChar * value) { return(xmlSchemaValidateFacetsInternal(ctxt, base, facets, value, 1)); } @@ -7278,7 +9136,7 @@ xmlSchemaValidateFacets(xmlSchemaValidCtxtPtr ctxt, * Simple type validation * * * ************************************************************************/ - +#if 0 /* Not currently used. */ /** * xmlSchemaValidateSimpleValueUnion: * @ctxt: a schema validation context @@ -7410,7 +9268,6 @@ xmlSchemaValidateSimpleValueInternal(xmlSchemaValidCtxtPtr ctxt, } } else if (type->type == XML_SCHEMA_TYPE_RESTRICTION) { xmlSchemaTypePtr base; - xmlSchemaFacetPtr facet; base = type->baseType; if (base != NULL) { @@ -7425,9 +9282,11 @@ xmlSchemaValidateSimpleValueInternal(xmlSchemaValidCtxtPtr ctxt, * building the Schemas */ if (ctxt->schema != NULL) { - if (ret == 0) { - facet = type->facets; - ret = xmlSchemaValidateFacetsInternal(ctxt, base, facet, + xmlSchemaFacetLinkPtr facetLink; + + if ((ret == 0) && (type->facetSet != NULL)) { + facetLink = type->facetSet; + ret = xmlSchemaValidateFacetsInternal(ctxt, base, facetLink, value, fireErrors); } } @@ -7481,6 +9340,7 @@ xmlSchemaValidateSimpleValueInternal(xmlSchemaValidCtxtPtr ctxt, } return (ret); } +#endif /************************************************************************ * * @@ -7580,25 +9440,28 @@ xmlSchemaCheckAttributes(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) ret = 1; if (cur->state == XML_SCHEMAS_ATTR_UNKNOWN) xmlSchemaVErr(ctxt, node, XML_SCHEMAS_ERR_ATTRUNKNOWN, - "Attribute %s on %s is unknown\n", - cur->attr->name, node->name); + "Attribute \"%s\" is not allowed.\n", + cur->attr->name, NULL); else if (cur->state == XML_SCHEMAS_ATTR_PROHIBITED) + /* + * TODO: This won't ever be touched so remove it. + */ xmlSchemaVErr(ctxt, node, XML_SCHEMAS_ERR_ATTRUNKNOWN, - "Attribute %s on %s is prohibited\n", - cur->attr->name, node->name); - else if (cur->state == XML_SCHEMAS_ATTR_INVALID_VALUE) + "Attribute \"%s\" is prohibited.\n", + cur->attr->name, NULL); + else if (cur->state == XML_SCHEMAS_ATTR_INVALID_VALUE) { xmlSchemaVErr(ctxt, node, XML_SCHEMAS_ERR_ATTRINVALID, - "Attribute %s on %s does not match type\n", + "Attribute \"%s\": the value is not valid.\n", cur->attr->name, node->name); - else if (cur->state == XML_SCHEMAS_ATTR_MISSING) { + } else if (cur->state == XML_SCHEMAS_ATTR_MISSING) { if (cur->decl->ref != NULL) xmlSchemaVErr(ctxt, node, XML_SCHEMAS_ERR_MISSING, - "Attribute %s on %s is required but missing\n", - cur->decl->ref, node->name); + "Attribute \"%s\" is required but missing.\n", + cur->decl->ref, NULL); else xmlSchemaVErr(ctxt, node, XML_SCHEMAS_ERR_MISSING, - "Attribute %s on %s is required but missing\n", - cur->decl->name, node->name); + "Attribute \"%s\" is required but missing.\n", + cur->decl->name, NULL); } } cur = cur->next; @@ -7718,16 +9581,13 @@ static xmlNodePtr xmlSchemaSkipIgnored(xmlSchemaValidCtxtPtr ctxt ATTRIBUTE_UNUSED, xmlSchemaTypePtr type, xmlNodePtr node) { - int mixed = 0; - /* * TODO complete and handle entities */ - mixed = ((type->contentType == XML_SCHEMA_CONTENT_MIXED) || - (type->contentType == XML_SCHEMA_CONTENT_MIXED_OR_ELEMENTS)); while ((node != NULL) && ((node->type == XML_COMMENT_NODE) || - ((mixed == 1) && (node->type == XML_TEXT_NODE)) || + ((type->contentType == XML_SCHEMA_CONTENT_MIXED) && + (node->type == XML_TEXT_NODE)) || (((type->contentType == XML_SCHEMA_CONTENT_ELEMENTS) && (node->type == XML_TEXT_NODE) && (IS_BLANK_NODE(node)))))) { node = node->next; @@ -7800,7 +9660,7 @@ xmlSchemaValidateSimpleRestrictionType(xmlSchemaValidCtxtPtr ctxt, ret = xmlSchemaValidateCheckNodeList(child); if (ret < 0) { xmlSchemaVErr(ctxt, node, XML_SCHEMAS_ERR_INTERNAL, - "Internal error: xmlSchemaValidateSimpleType %s content\n", + "Internal error: xmlSchemaValidateSimpleRestrictionType %s content\n", node->name, NULL); return (-1); } else if (ret == 0) { @@ -7816,6 +9676,7 @@ xmlSchemaValidateSimpleRestrictionType(xmlSchemaValidCtxtPtr ctxt, } #endif +#if 0 /* Not used any more */ /** * xmlSchemaValidateSimpleType: * @ctxt: a schema validation context @@ -7900,18 +9761,12 @@ xmlSchemaValidateSimpleType(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) value = xmlNodeGetContent(child); switch (variety->type) { case XML_SCHEMA_TYPE_RESTRICTION:{ - xmlSchemaFacetPtr facet; - base = variety->baseType; if (base != NULL) { ret = xmlSchemaValidateSimpleValue(ctxt, base, value); } else { - TODO} - if (ret == 0) { - facet = variety->facets; - ret = - xmlSchemaValidateFacets(ctxt, base, facet, value); - } + TODO} + /* Removed due to changes of attribute validation: if ((ret == 0) && (variety->attributes != NULL)) { ret = xmlSchemaValidateAttributes(ctxt, node, @@ -7933,6 +9788,9 @@ xmlSchemaValidateSimpleType(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) ret = ctxt->err; } } + if ((ret == 0) && (variety->facetSet != NULL)) { + ret = xmlSchemaValidateFacets(ctxt, base, variety->facetSet, value); + } if (value != NULL) xmlFree(value); @@ -7943,6 +9801,494 @@ xmlSchemaValidateSimpleType(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) ctxt->type = type; return (ret); } +#endif + +/** + * xmlSchemaValidateSimpleTypeValue: + * @ctxt: a schema validation context + * @value: the value to be validated + * @fireErrors: shall errors be reported? + * @applyFacets: shall facets be applied? + * + * Validates a value by the given type (user derived or built-in). + * + * Returns 0 if the value is valid, a positive error code + * number otherwise and -1 in case of an internal or API error. + * Note on reported errors: Although it might be nice to report + * the name of the simple/complex type, used to validate the content + * of a node, it is quite unnecessary: for global defined types + * the local name of the element is equal to the NCName of the type, + * for local defined types it makes no sense to output the internal + * computed name of the type. TODO: Instead, one should attach the + * struct of the type involved to the error handler - this allows + * the report of any additional information by the user. + * TODO: Correct character normalization of union simple types. + */ +static int +xmlSchemaValidateSimpleTypeValue(xmlSchemaValidCtxtPtr ctxt, + const xmlChar *value, + int fireErrors, + int applyFacets) +{ + xmlSchemaTypePtr type; + int ret = 0; + type = ctxt->type; + + if (type->type == XML_SCHEMA_TYPE_BASIC) { + xmlNodePtr child; + + if (ctxt->value != NULL) { + xmlSchemaFreeValue(ctxt->value); + ctxt->value = NULL; + } + child = ctxt->node; + while (child != NULL) { + switch (child->type) { + case XML_TEXT_NODE: + case XML_CDATA_SECTION_NODE: + case XML_PI_NODE: + case XML_COMMENT_NODE: + case XML_XINCLUDE_START: + case XML_XINCLUDE_END: + break; + case XML_ENTITY_REF_NODE: + case XML_ENTITY_NODE: + TODO break; + case XML_ELEMENT_NODE: + xmlSchemaVErr(ctxt, ctxt->cur, XML_SCHEMAS_ERR_INVALIDELEM, + "Element \"%s\": child \"%s\" should not be present.\n", + ctxt->cur->name, child->name); + return (ctxt->err); + case XML_ATTRIBUTE_NODE: + case XML_DOCUMENT_NODE: + case XML_DOCUMENT_TYPE_NODE: + case XML_DOCUMENT_FRAG_NODE: + case XML_NOTATION_NODE: + case XML_HTML_DOCUMENT_NODE: + case XML_DTD_NODE: + case XML_ELEMENT_DECL: + case XML_ATTRIBUTE_DECL: + case XML_ENTITY_DECL: + case XML_NAMESPACE_DECL: +#ifdef LIBXML_DOCB_ENABLED + case XML_DOCB_DOCUMENT_NODE: +#endif + xmlSchemaVErr(ctxt, ctxt->cur, XML_SCHEMAS_ERR_INVALIDELEM, + "Element \"%s\": node type of node unexpected here.\n", + ctxt->cur->name, NULL); + return (ctxt->err); + } + child = child->next; + } + ret = xmlSchemaValPredefTypeNode(type, value, &(ctxt->value), + ctxt->cur); + if (ret > 0) { + if (type->flags & XML_SCHEMAS_TYPE_VARIETY_LIST) + ret = XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_2; + else + ret = XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_1; + if (fireErrors) { + if (ctxt->cur->type == XML_ATTRIBUTE_NODE) + xmlSchemaVErr(ctxt, ctxt->cur, + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_1, + "The value of attribute \"%s\" is not valid.\n", + ctxt->cur->name, NULL); + else + xmlSchemaVErr(ctxt, ctxt->cur, + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_1, + "The value is not valid.\n", + NULL, NULL); + } + } else if (ret < 0) { + xmlSchemaVErr(ctxt, ctxt->cur, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateSimpleTypeValue, " + "validating built-in type \"%s\"\n", + type->name, NULL); + } + } else if (type->flags & XML_SCHEMAS_TYPE_VARIETY_ATOMIC) { + /* 1.2.1 if {variety} is ·atomic· then the string must ·match· + * a literal in the ·lexical space· of {base type definition} + */ + ctxt->type = type->baseType; + ret = xmlSchemaValidateSimpleTypeValue(ctxt, value, 0, 0); + if (ret < 0) { + xmlSchemaVErr(ctxt, ctxt->cur, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateSimpleTypeValue, " + "validating atomic simple type \"%s\"\n", + type->name, NULL); + } else if (ret > 0) { + ret = XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_1; + if (fireErrors) { + xmlSchemaVErr(ctxt, ctxt->cur, + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_1, + "The value is not valid.\n", + NULL, NULL); + } + + } else if ((applyFacets) && + (type->facetSet != NULL)) { + xmlSchemaTypePtr builtIn; + + /* + * Check facets. Be sure to pass the built-in type to + * xmlSchemaValidateFacetsInternal. + */ + builtIn = type->baseType; + while (builtIn->type != XML_SCHEMA_TYPE_BASIC) + builtIn = builtIn->baseType; + ret = xmlSchemaValidateFacetsInternal(ctxt, builtIn, + type->facetSet, value, fireErrors); + if (ret < 0) { + xmlSchemaVErr(ctxt, ctxt->cur, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateSimpleTypeValue, " + "validating facets of atomic simple type \"%s\"\n", + type->name, NULL); + } else if (ret > 0) { + ret = XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_1; + if (fireErrors) { + xmlSchemaVErr(ctxt, ctxt->cur, + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_1, + "The value is not valid.\n", + NULL, NULL); + } + } + } + } else if (type->flags & XML_SCHEMAS_TYPE_VARIETY_LIST) { + + xmlSchemaTypePtr tmpType; + const xmlChar *cur, *end; + xmlChar *tmp; + int len = 0; + + /* 1.2.2 if {variety} is ·list· then the string must be a sequence + * of white space separated tokens, each of which ·match·es a literal + * in the ·lexical space· of {item type definition} + */ + + tmpType = xmlSchemaGetListSimpleTypeItemType(type); + cur = value; + do { + while (IS_BLANK_CH(*cur)) + cur++; + end = cur; + while ((*end != 0) && (!(IS_BLANK_CH(*end)))) + end++; + if (end == cur) + break; + tmp = xmlStrndup(cur, end - cur); + len++; + ctxt->type = tmpType; + ret = xmlSchemaValidateSimpleTypeValue(ctxt, tmp, 0, 1); + xmlFree(tmp); + if (ret > 0) { + ret = XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_2; + if (fireErrors) { + xmlSchemaVErr(ctxt, ctxt->cur, + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_2, + "The value is not valid.\n", + NULL, NULL); + } + break; + } else if (ret < 0) + break; + cur = end; + } while (*cur != 0); + /* + * Check facets. + */ + if (ret < 0) { + xmlSchemaVErr(ctxt, ctxt->cur, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateSimpleTypeValue, " + "validating list simple type \"%s\"\n", + type->name, NULL); + } else if ((ret == 0) && (applyFacets) && + (type->facetSet != NULL)) { + int expLen, okFacet = 0, hasFacet = 0; + xmlSchemaFacetPtr facet; + xmlSchemaFacetLinkPtr facetLink; + xmlChar *collapsedValue = NULL; + + /* + * The value of ·whiteSpace· is fixed to the value collapse. + */ + collapsedValue = xmlSchemaCollapseString((const xmlChar *) value); + if (collapsedValue != NULL) + value = (const xmlChar *) collapsedValue; + facetLink = type->facetSet; + do { + facet = facetLink->facet; + /* + * List types need a special facet treatment. + * Skip whiteSpace, since it is fixed to "collapse". + */ + if ((facet->type != XML_SCHEMA_FACET_WHITESPACE) && + (facet->type != XML_SCHEMA_FACET_PATTERN)) { + ret = xmlSchemaValidateListSimpleTypeFacet(facet, value, + len, &expLen); + if (facet->type == XML_SCHEMA_FACET_ENUMERATION) { + hasFacet = 1; + if (ret == 0) + okFacet = 1; + } else if ((ret > 0) && (fireErrors)) { + char l[25], fl[25]; + /* FIXME: What is the max expected string length of the + * length value? + */ + snprintf(l, 24, "%d", len); + snprintf(fl, 24, "%d", expLen); + if (ret == XML_SCHEMAV_CVC_LENGTH_VALID) { + xmlSchemaVErr(ctxt, ctxt->cur, ret, + "The value with length \"%s\" is not " + "facet-valid with respect to length = \"%s\".\n", + l, fl); + } else if (ret == XML_SCHEMAV_CVC_MINLENGTH_VALID) { + xmlSchemaVErr(ctxt, ctxt->cur, ret, + "The value with length \"%s\" is not " + "facet-valid with respect to minLength = \"%s\".\n", + l, fl); + } else if (ret == XML_SCHEMAV_CVC_MAXLENGTH_VALID) { + xmlSchemaVErr(ctxt, ctxt->cur, ret, + "The value with length \"%s\" is not " + "facet-valid with respect to maxLength = \"%s\".\n", + l, fl); + } else { + xmlSchemaVErr(ctxt, ctxt->cur, ret, + "The value is not valid with respect " + "to the facet \"%s\".\n", + xmlSchemaFacetTypeToString(facet->type), + NULL); + } + } else if (ret < 0) { + xmlSchemaVErr(ctxt, ctxt->cur, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateSimpleTypeValue, " + "validating facets of list simple type \"%s\"\n", + type->name, NULL); + break; + } + } + facetLink = facetLink->next; + } while (facetLink != NULL); + if (ret >= 0) { + if ((hasFacet) && (okFacet == 0)) { + ret = XML_SCHEMAV_CVC_ENUMERATION_VALID; + if (fireErrors) { + /* + * TODO: Try to create a report that outputs all the enumeration + * values in use. + */ + xmlSchemaVErr(ctxt, ctxt->cur, XML_SCHEMAV_CVC_ENUMERATION_VALID, + "The value is not valid with respect " + "to the \"enumeration\" facet(s).\n", + NULL, NULL); + } + + } + /* + * Pattern facets are ORed at type level and ANDed + * if derived. Walk the base axis. + */ + hasFacet = 0; + tmpType = type; + do { + okFacet = 0; + for (facetLink = tmpType->facetSet; facetLink != NULL; + facetLink = facetLink->next) { + if (facetLink->facet->type != XML_SCHEMA_FACET_PATTERN) + continue; + okFacet = xmlSchemaValidateListSimpleTypeFacet( + facetLink->facet, value, len, &expLen); + if (okFacet <= 0) + break; + } + if (okFacet != 0) + break; + tmpType = tmpType->baseType; + } while ((tmpType != NULL) && (tmpType->type != XML_SCHEMA_TYPE_BASIC)); + if (okFacet < 0) { + xmlSchemaVErr(ctxt, ctxt->cur, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateSimpleTypeValue, " + "validating \"pattern\" facets of type \"%s\"\n", + type->name, NULL); + } else if (okFacet > 0) { + ret = XML_SCHEMAV_CVC_PATTERN_VALID; + if (fireErrors) { + xmlSchemaVErr(ctxt, ctxt->cur, XML_SCHEMAV_CVC_ENUMERATION_VALID, + "The value is not valid with respect " + "to the \"pattern\" facet(s) of type " + "\"%s\".\n", + tmpType->name, NULL); + } + } + } + + if (collapsedValue != NULL) + xmlFree(collapsedValue); + } + } else if (type->flags & XML_SCHEMAS_TYPE_VARIETY_UNION) { + xmlSchemaTypeLinkPtr memberLink; + + /* + * TODO: For all datatypes ·derived· by ·union· whiteSpace does + * not apply directly; however, the normalization behavior of ·union· + * types is controlled by the value of whiteSpace on that one of the + * ·memberTypes· against which the ·union· is successfully validated. + * + * This means that the value is normalized by the first validating + * member type, then the facets of the union type are applied. This + * needs changing of the value! + */ + + /* + * 1.2.3 if {variety} is ·union· then the string must ·match· a + * literal in the ·lexical space· of at least one member of + * {member type definitions} + */ + memberLink = xmlSchemaGetUnionSimpleTypeMemberTypes(type); + if (memberLink == NULL) { + xmlSchemaVErr(ctxt, ctxt->cur, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateSimpleTypeValue, " + "union simple type \"%s\" has no member types\n", + type->name, NULL); + ret = -1; + } + if (ret == 0) { + while (memberLink != NULL) { + ctxt->type = memberLink->type; + ret = xmlSchemaValidateSimpleTypeValue(ctxt, value, 0, 1); + if ((ret <= 0) || (ret == 0)) + break; + memberLink = memberLink->next; + } + if (ret > 0) { + ret = XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_3; + if (fireErrors) { + xmlSchemaVErr(ctxt, ctxt->cur, + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_3, + "The value is not valid.\n", + NULL, NULL); + } + } else if (ret < 0) { + xmlSchemaVErr(ctxt, ctxt->cur, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateSimpleTypeValue, " + "validating members of union simple type \"%s\"\n", + type->name, NULL); + } + } + /* + * Apply facets (pattern, enumeration). + */ + if ((ret == 0) && (applyFacets) && + (type->facetSet != NULL)) { + xmlSchemaTypePtr anySimpleType; + /* + * Check facets. Be sure to pass the built-in type (the + * simple ur-type in this case) to xmlSchemaValidateFacetsInternal. + */ + anySimpleType = type->baseType; + while (anySimpleType->type != XML_SCHEMA_TYPE_BASIC) + anySimpleType = anySimpleType->baseType; + ret = xmlSchemaValidateFacetsInternal(ctxt, anySimpleType, + type->facetSet, value, fireErrors); + if (ret < 0) { + xmlSchemaVErr(ctxt, ctxt->cur, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateSimpleTypeValue, " + "validating facets of union simple type \"%s\"\n", + type->name, NULL); + } else if (ret > 0) { + ret = XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_3; + if (fireErrors) { + xmlSchemaVErr(ctxt, ctxt->cur, + XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_1, + "The value is not valid.\n", + NULL, NULL); + } + } + } + } + ctxt->type = type; + return (ret); +} + +/** + * xmlSchemaValidateSimpleTypeElement: + * @ctxt: a schema validation context + * @node: the element node to be validated. + * + * Validate the element against a simple type. + * + * Returns 0 if the element is valid, a positive error code + * number otherwise and -1 in case of an internal or API error. + */ +static int +xmlSchemaValidateSimpleTypeElement(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) +{ + xmlNodePtr child; + xmlSchemaTypePtr type; + xmlAttrPtr attr; + int ret; + xmlChar *value; + + + child = ctxt->node; + type = ctxt->type; + + if ((ctxt == NULL) || (type == NULL)) { + xmlSchemaVErr(ctxt, node, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateSimpleTypeElement %s\n", + node->name, NULL); + return (-1); + } + + /* + * Only text and text based entities references shall be found there + */ + ret = xmlSchemaValidateCheckNodeList(child); + if (ret < 0) { + xmlSchemaVErr(ctxt, node, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateSimpleTypeElement %s content\n", + node->name, NULL); + return (-1); + } else if (ret == 0) { + /* 3.1.2 The element information item must have no element + * information item [children]. + */ + xmlSchemaVErr(ctxt, node, XML_SCHEMAV_CVC_TYPE_3_1_2, + "Element \"%s\" must have no element children.\n", + node->name, NULL); + return (-1); + } + /* + * Validation Rule: Element Locally Valid (Type): 3.1.1 + */ + attr = node->properties; + while (attr != NULL) { + if ((attr->ns == NULL) || + (!xmlStrEqual(attr->ns->href, xmlSchemaInstanceNs)) || + ((!xmlStrEqual(attr->name, BAD_CAST "type")) && + (!xmlStrEqual(attr->name, BAD_CAST "nil")) && + (!xmlStrEqual(attr->name, BAD_CAST "schemaLocation")) && + (!xmlStrEqual + (attr->name, BAD_CAST "noNamespaceSchemaLocation")))) { + xmlSchemaVErr(ctxt, node, + XML_SCHEMAV_CVC_TYPE_3_1_1, + "The attributes of element \"%s\" must be empty, excepting " + "those whose namespace name is identical to " + "http://www.w3.org/2001/XMLSchema-instance and whose local " + "name is one of type, nil, schemaLocation or " + "noNamespaceSchemaLocation.\n", + node->name, attr->name); + return (ctxt->err); + } + attr = attr->next; + } + value = xmlNodeGetContent(child); + ret = xmlSchemaValidateSimpleTypeValue(ctxt, value, 1, 1); + if (value != NULL) + xmlFree(value); + + ctxt->type = type; + return (ret); +} /** * xmlSchemaValidateElementType: @@ -7965,6 +10311,7 @@ xmlSchemaValidateElementType(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) int ret; xmlSchemaAttrStatePtr attrs = NULL, attrTop = NULL; + /* This one is called by xmlSchemaValidateContent only. */ /* * TODO: Look into "xmlSchemaValidateElement" for missing parts, which should * go in here as well. @@ -8010,13 +10357,7 @@ xmlSchemaValidateElementType(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) attrs = ctxt->attr; attrTop = ctxt->attrTop; - xmlSchemaRegisterAttributes(ctxt, child->properties); - - /* - * An element declaration does not hold any information about - * attributes; thus, the following was removed. - */ - /* xmlSchemaValidateAttributes(ctxt, child, type->attributes); */ + xmlSchemaRegisterAttributes(ctxt, child->properties); /* * Verify the element content recursively @@ -8072,6 +10413,7 @@ xmlSchemaValidateElementType(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) return (ctxt->err); } +#if 0 /* Not currently used. */ /** * xmlSchemaValidateBasicType: * @ctxt: a schema validation context @@ -8099,6 +10441,13 @@ xmlSchemaValidateBasicType(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) node->name, NULL); return (-1); } + if (type->type != XML_SCHEMA_TYPE_BASIC) { + xmlSchemaVErr(ctxt, node, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateBasicType, " + "the given type is not a built-in type.\n", + node->name, NULL); + return (-1); + } /* * First check the content model of the node. */ @@ -8150,9 +10499,11 @@ xmlSchemaValidateBasicType(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) xmlSchemaFreeValue(ctxt->value); ctxt->value = NULL; } + ret = xmlSchemaValidatePredefinedType(type, value, &(ctxt->value)); + if (value != NULL) - xmlFree(value); + xmlFree(value); if (ret != 0) { xmlSchemaVErr(ctxt, node, XML_SCHEMAS_ERR_VALUE, "Element %s: failed to validate basic type %s\n", @@ -8160,6 +10511,7 @@ xmlSchemaValidateBasicType(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) } return (ret); } +#endif /** * xmlSchemaValidateComplexType: @@ -8171,112 +10523,221 @@ xmlSchemaValidateBasicType(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) * Validation Rule: Element Locally Valid (Complex Type) * * Returns 0 if the element is schemas valid, a positive error code - * number otherwise and -1 in case of internal or API error. + * number otherwise and -1 in case of internal or API error. + * Note on reported errors: Although it might be nice to report + * the name of the simple/complex type, used to validate the content + * of a node, it is quite unnecessary: for global defined types + * the local name of the element is equal to the NCName of the type, + * for local defined types it makes no sense to output the internal + * computed name of the type. TODO: Instead, one should attach the + * struct of the type involved to the error handler - this allows + * the report of any additional information by the user. */ static int xmlSchemaValidateComplexType(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) { xmlNodePtr child; - xmlSchemaTypePtr type, subtype; - int ret; - - /* TODO: Handle xsd:restriction & xsd:extension */ + xmlSchemaTypePtr type; + int ret = 0; child = ctxt->node; type = ctxt->type; ctxt->cur = node; switch (type->contentType) { - case XML_SCHEMA_CONTENT_EMPTY: - if (type->baseType != NULL) { - } else if (child != NULL) { - xmlSchemaVErr(ctxt, node, XML_SCHEMAS_ERR_NOTEMPTY, - "Element %s is supposed to be empty\n", - node->name, NULL); - } - /* Removed due to changes of attribute validation: - if (type->attributes != NULL) { - xmlSchemaValidateAttributes(ctxt, node, type->attributes); - } + case XML_SCHEMA_CONTENT_EMPTY: { + /* + * 1 If the {content type} is empty, then the element information + * item has no character or element information item [children]. */ - subtype = type->subtypes; - while (subtype != NULL) { - ctxt->type = subtype; - xmlSchemaValidateComplexType(ctxt, node); - subtype = subtype->next; - } - break; - case XML_SCHEMA_CONTENT_ELEMENTS: - case XML_SCHEMA_CONTENT_MIXED: - case XML_SCHEMA_CONTENT_MIXED_OR_ELEMENTS: - /* - * Skip ignorable nodes in that context - */ - /* ComplexType, ComplexContent */ + /* TODO: Hmm, Xerces reports nodes like Comment to be invalid + * content, but XSV does not. + */ + /* + * TODO: Is the entity stuff correct? + */ + while (child != NULL) { + if ((child->type == XML_ELEMENT_NODE) || + /* + * TODO: Ask Daniel if this are all character nodes. + */ + (child->type == XML_TEXT_NODE) || + (child->type == XML_CDATA_SECTION_NODE) || + (child->type == XML_ENTITY_REF_NODE) || + (child->type == XML_ENTITY_NODE)) { + break; + } + child = child->next; + } if (child != NULL) { - child = xmlSchemaSkipIgnored(ctxt, type, child); - while (child != NULL) { - if (child->type == XML_ELEMENT_NODE) { - ret = xmlRegExecPushString(ctxt->regexp, - child->name, child); -#ifdef DEBUG_AUTOMATA - if (ret < 0) - xmlGenericError(xmlGenericErrorContext, - " --> %s Error\n", child->name); - else - xmlGenericError(xmlGenericErrorContext, - " --> %s\n", child->name); -#endif - } - child = child->next; - /* - * Skip ignorable nodes in that context - */ - child = xmlSchemaSkipIgnored(ctxt, type, child); - } - } - - if (((type->contentType == XML_SCHEMA_CONTENT_MIXED) || - (type->contentType == XML_SCHEMA_CONTENT_MIXED_OR_ELEMENTS)) && - (type->subtypes != NULL)) { - TODO - } - - /* Removed due to changes of attribute validation: - if (type->attributes != NULL) { - xmlSchemaValidateAttributes(ctxt, node, type->attributes); - } - */ + xmlSchemaVErr(ctxt, node, XML_SCHEMAV_CVC_COMPLEX_TYPE_2_1, + "Character or element children are not allowed, " + "because the content type is empty.\n", + NULL, NULL); + } break; - case XML_SCHEMA_CONTENT_BASIC:{ - if (type->subtypes != NULL) { - ctxt->type = type->subtypes; - xmlSchemaValidateComplexType(ctxt, node); - } - if (type->baseType != NULL) { - ctxt->type = type->baseType; - if (type->baseType->type == XML_SCHEMA_TYPE_BASIC) - xmlSchemaValidateBasicType(ctxt, node); - else if (type->baseType->type == XML_SCHEMA_TYPE_COMPLEX) - xmlSchemaValidateComplexType(ctxt, node); - /* TODO: This might be incorrect. */ - else if (type->baseType->type == XML_SCHEMA_TYPE_SIMPLE) - xmlSchemaValidateSimpleType(ctxt, node); + } + case XML_SCHEMA_CONTENT_ELEMENTS: + case XML_SCHEMA_CONTENT_MIXED: + while (child != NULL) { + if (child->type == XML_ELEMENT_NODE) { + ret = xmlRegExecPushString(ctxt->regexp, + child->name, child); +#ifdef DEBUG_AUTOMATA + if (ret < 0) + xmlGenericError(xmlGenericErrorContext, + " --> %s Error\n", child->name); else xmlGenericError(xmlGenericErrorContext, - "unexpected content type of base: %d\n", - type->contentType); - } - /* Removed due to changes of attribute validation: - if (type->attributes != NULL) { - xmlSchemaValidateAttributes(ctxt, node, - type->attributes); - } + " --> %s\n", child->name); +#endif + } else if ((type->contentType == XML_SCHEMA_CONTENT_ELEMENTS) && + /* + * TODO: Ask Daniel if this are all character nodes. + */ + (((child->type == XML_TEXT_NODE) && (!IS_BLANK_NODE(child))) || + (child->type == XML_ENTITY_NODE) || + (child->type == XML_ENTITY_REF_NODE) || + (child->type == XML_CDATA_SECTION_NODE))) { + /* + * 2.3 If the {content type} is element-only, then the + * element information item has no character information + * item [children] other than those whose [character + * code] is defined as a white space in [XML 1.0 (Second + * Edition)]. + */ + xmlSchemaVErr(ctxt, node, XML_SCHEMAV_CVC_COMPLEX_TYPE_2_3, + "Character children are not allowed, " + "because the content type is element-only.\n", + NULL, NULL); + break; + } + child = child->next; + } + break; + case XML_SCHEMA_CONTENT_SIMPLE: + case XML_SCHEMA_CONTENT_BASIC:{ + xmlSchemaTypePtr base, anyType; + xmlChar *value = NULL; + /* + * We hit a complexType with a simpleContent resolving + * to a user derived or built-in simple type. + */ + anyType = xmlSchemaGetBuiltInType(XML_SCHEMAS_ANYTYPE); + /* + * Internal check for integrity of the base type. + */ + base = type->baseType; + while ((base != NULL) && + (base->type != XML_SCHEMA_TYPE_SIMPLE) && + (base->type != XML_SCHEMA_TYPE_BASIC) && + (base != anyType)) { + base = base->baseType; + } + if ((base == NULL) || + (((type->contentType == XML_SCHEMA_CONTENT_SIMPLE) && + (base->type != XML_SCHEMA_TYPE_SIMPLE)) || + ((type->contentType == XML_SCHEMA_CONTENT_BASIC) && + (base->type != XML_SCHEMA_TYPE_BASIC)))) { + xmlSchemaVErr(ctxt, node, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateComplexType, " + "Element \"%s\": the base type of the corresponding " + "complex type \"%s\" is not a user derived or a " + "built-in simple type.\n", + node->name, type->name); + return (-1); + } + /* + * 2.2 If the {content type} is a simple type definition, + * then the element information item has no element + * information item [children], and the ·normalized value· + * of the element information item is ·valid· with respect + * to that simple type definition as defined by String + * Valid (§3.14.4). + */ + child = node->children; + while (child != NULL) { + if (child->type == XML_ELEMENT_NODE) { + xmlSchemaVErr(ctxt, node, XML_SCHEMAV_CVC_COMPLEX_TYPE_2_2, + "Element children are not allowed, because " + "the content type is a simple type.\n", + NULL, NULL); + ret = XML_SCHEMAV_CVC_COMPLEX_TYPE_2_2; + break; + } + child = child->next; + } + if (ret == 0) { + /* + * Validate the character content against a simple type. */ - ctxt->type = type; - break; - } - case XML_SCHEMA_CONTENT_SIMPLE:{ + if (ctxt->node == NULL) + value = NULL; + else + value = xmlNodeGetContent(node); + ctxt->type = base; + ret = xmlSchemaValidateSimpleTypeValue(ctxt, value, 1, 1); + ctxt->type = type; + if (ret > 0) { + xmlSchemaVErr(ctxt, node, XML_SCHEMAV_CVC_COMPLEX_TYPE_2_2, + "The character value " + "is not valid with respect to the simple type.\n", + NULL, NULL); + ret = XML_SCHEMAV_CVC_COMPLEX_TYPE_2_2; + } else if (ret < 0) { + xmlSchemaVErr(ctxt, node, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateComplexType, " + "Element \"%s\": error while validating character " + "content against complex type \"%s\".\n", + node->name, type->name); + return (-1); + } + } + if (ret == 0) { + /* + * Apply facets of the complexType. Be sure to pass the + * built-in type to xmlSchemaValidateFacetsInternal. + */ + /* TODO: I don't know yet if the facets of the simple type + * are used, or if the facets, defined by this complex type, + * are to be used only. This here applies both facet sets. + */ + while (base->type != XML_SCHEMA_TYPE_BASIC) + base = base->baseType; + if (base == NULL) { + xmlSchemaVErr(ctxt, node, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateComplexType, " + "Element \"%s\": error while validating character " + "content against complex type \"%s\"; failed to " + "compute the built-in simple type for facet " + "validation.\n", + node->name, type->name); + return (-1); + } + ret = xmlSchemaValidateFacetsInternal(ctxt, base, + type->facetSet, value, 1); + if (ret > 0) { + xmlSchemaVErr(ctxt, node, XML_SCHEMAV_CVC_COMPLEX_TYPE_2_2, + "The character value " + "is not valid with respect to the simple type.\n", + NULL, NULL); + ret = XML_SCHEMAV_CVC_COMPLEX_TYPE_2_2; + } else if (ret < 0) { + xmlSchemaVErr(ctxt, ctxt->cur, XML_SCHEMAS_ERR_INTERNAL, + "Internal error: xmlSchemaValidateComplexType, " + "Element \"%s\": error while validating character " + "content against complex type \"%s\"; failed to " + "apply facets.\n", + type->name, NULL); + } + } + if (value != NULL) + xmlFree(value); + /* TODO: facets */ + break; + } + /* + case XML_SCHEMA_CONTENT_SIMPLE:{ if (type->subtypes != NULL) { ctxt->type = type->subtypes; xmlSchemaValidateComplexType(ctxt, node); @@ -8285,22 +10746,25 @@ xmlSchemaValidateComplexType(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) ctxt->type = type->baseType; xmlSchemaValidateComplexType(ctxt, node); } - /* Removed due to changes of attribute validation: + * Removed due to changes of attribute validation: if (type->attributes != NULL) { xmlSchemaValidateAttributes(ctxt, node, type->attributes); } - */ + * ctxt->type = type; break; } + */ default: TODO xmlGenericError(xmlGenericErrorContext, "unimplemented content type %d\n", type->contentType); } - if (type->type == XML_SCHEMA_TYPE_COMPLEX) + if (type->type == XML_SCHEMA_TYPE_COMPLEX) { xmlSchemaValidateAttributes(ctxt, node, type); + } + ctxt->cur = node; return (ctxt->err); } @@ -8325,10 +10789,6 @@ xmlSchemaValidateContent(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) type = ctxt->type; ctxt->cur = node; - /* - * Removed, since redundant. - */ - /* xmlSchemaValidateAttributes(ctxt, node, type->attributes); */ ctxt->cur = node; switch (type->type) { @@ -8361,13 +10821,11 @@ xmlSchemaValidateContent(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) break; } case XML_SCHEMA_TYPE_BASIC: - xmlSchemaValidateBasicType(ctxt, node); + case XML_SCHEMA_TYPE_SIMPLE: + xmlSchemaValidateSimpleTypeElement(ctxt, node); break; case XML_SCHEMA_TYPE_FACET: - TODO break; - case XML_SCHEMA_TYPE_SIMPLE: - xmlSchemaValidateSimpleType(ctxt, node); - break; + TODO break; case XML_SCHEMA_TYPE_SEQUENCE: TODO break; case XML_SCHEMA_TYPE_CHOICE: @@ -8424,10 +10882,6 @@ xmlSchemaValidateContent(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr node) case XML_SCHEMA_TYPE_ANY_ATTRIBUTE: TODO break; } - /* - * Removed, since redundant. - */ - /* xmlSchemaValidateAttributes(ctxt, node, type->attributes); */ if (ctxt->node == NULL) return (ctxt->err); @@ -8508,11 +10962,7 @@ xmlSchemaValidateType(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr elem, ctxt->type = elemDecl->subtypes; ctxt->node = elem->children; - xmlSchemaValidateContent(ctxt, elem); - /* Removed, since an element declaration does not hold any attribute - * declarations */ - /* xmlSchemaValidateAttributes(ctxt, elem, elemDecl->attributes); */ - + xmlSchemaValidateContent(ctxt, elem); return (ctxt->err); } @@ -8622,6 +11072,7 @@ xmlSchemaValidateAttributes(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr elem, xmlSche #endif found = 1; ctxt->cur = (xmlNodePtr) attr; + ctxt->node = attr->children; if (attrDecl->subtypes == NULL) { curState->state = XML_SCHEMAS_ATTR_TYPE_NOT_RESOLVED; @@ -8637,8 +11088,9 @@ xmlSchemaValidateAttributes(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr elem, xmlSche continue; } value = xmlNodeListGetString(elem->doc, attr->children, 1); - ret = xmlSchemaValidateSimpleValue(ctxt, attrDecl->subtypes, - value); + ctxt->type = attrDecl->subtypes; + ret = xmlSchemaValidateSimpleTypeValue(ctxt, value, 0, 1); + ctxt->type = type; if (ret != 0) curState->state = XML_SCHEMAS_ATTR_INVALID_VALUE; else @@ -8749,8 +11201,9 @@ xmlSchemaValidateAttributes(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr elem, xmlSche attr->name, nsURI); if (attrDecl != NULL) { value = xmlNodeListGetString(elem->doc, attr->children, 1); - ret = xmlSchemaValidateSimpleValue(ctxt, attrDecl->subtypes, - value); + ctxt->type = attrDecl->subtypes; + ret = xmlSchemaValidateSimpleTypeValue(ctxt, value, 1, 1); + ctxt->type = type; if (ret != 0) curState->state = XML_SCHEMAS_ATTR_INVALID_VALUE; else @@ -8804,22 +11257,7 @@ xmlSchemaValidateElement(xmlSchemaValidCtxtPtr ctxt, xmlNodePtr elem) elemDecl = xmlHashLookup3(ctxt->schema->elemDecl, elem->name, NULL, NULL); } - /* - * special case whe elementFormDefault is unqualified for top-level elem. - */ - /* - * This was removed, since elementFormDefault does not apply to top-level - * element declarations. - */ - /* - if ((elemDecl == NULL) && (elem->ns != NULL) && - (elem->parent != NULL) && (elem->parent->type != XML_ELEMENT_NODE) && - (xmlStrEqual(ctxt->schema->targetNamespace, elem->ns->href)) && - ((ctxt->schema->flags & XML_SCHEMAS_QUALIF_ELEM) == 0)) { - elemDecl = xmlHashLookup3(ctxt->schema->elemDecl, - elem->name, NULL, NULL); - } - */ + /* This one is called by xmlSchemaValidateDocument only. */ /* * 3.3.4 : 1 @@ -8903,7 +11341,7 @@ xmlSchemaValidateDocument(xmlSchemaValidCtxtPtr ctxt, xmlDocPtr doc) { xmlNodePtr root; xmlSchemaElementPtr elemDecl; - + root = xmlDocGetRootElement(doc); if (root == NULL) { xmlSchemaVErr(ctxt, (xmlNodePtr) doc, XML_SCHEMAS_ERR_NOROOT, diff --git a/xmlschemastypes.c b/xmlschemastypes.c index 6cd13ae9..7214adb9 100644 --- a/xmlschemastypes.c +++ b/xmlschemastypes.c @@ -39,59 +39,13 @@ #define XML_SCHEMAS_NAMESPACE_NAME \ (const xmlChar *)"http://www.w3.org/2001/XMLSchema" -typedef enum { - XML_SCHEMAS_UNKNOWN = 0, - XML_SCHEMAS_STRING, - XML_SCHEMAS_NORMSTRING, - XML_SCHEMAS_DECIMAL, - XML_SCHEMAS_TIME, - XML_SCHEMAS_GDAY, - XML_SCHEMAS_GMONTH, - XML_SCHEMAS_GMONTHDAY, - XML_SCHEMAS_GYEAR, - XML_SCHEMAS_GYEARMONTH, - XML_SCHEMAS_DATE, - XML_SCHEMAS_DATETIME, - XML_SCHEMAS_DURATION, - XML_SCHEMAS_FLOAT, - XML_SCHEMAS_DOUBLE, - XML_SCHEMAS_BOOLEAN, - XML_SCHEMAS_TOKEN, - XML_SCHEMAS_LANGUAGE, - XML_SCHEMAS_NMTOKEN, - XML_SCHEMAS_NMTOKENS, - XML_SCHEMAS_NAME, - XML_SCHEMAS_QNAME, - XML_SCHEMAS_NCNAME, - XML_SCHEMAS_ID, - XML_SCHEMAS_IDREF, - XML_SCHEMAS_IDREFS, - XML_SCHEMAS_ENTITY, - XML_SCHEMAS_ENTITIES, - XML_SCHEMAS_NOTATION, - XML_SCHEMAS_ANYURI, - XML_SCHEMAS_INTEGER, - XML_SCHEMAS_NPINTEGER, - XML_SCHEMAS_NINTEGER, - XML_SCHEMAS_NNINTEGER, - XML_SCHEMAS_PINTEGER, - XML_SCHEMAS_INT, - XML_SCHEMAS_UINT, - XML_SCHEMAS_LONG, - XML_SCHEMAS_ULONG, - XML_SCHEMAS_SHORT, - XML_SCHEMAS_USHORT, - XML_SCHEMAS_BYTE, - XML_SCHEMAS_UBYTE, - XML_SCHEMAS_HEXBINARY, - XML_SCHEMAS_BASE64BINARY -} xmlSchemaValType; static unsigned long powten[10] = { 1, 10, 100, 1000, 10000, 100000, 1000000, 10000000L, 100000000L, 1000000000L }; + /* Date value */ typedef struct _xmlSchemaValDate xmlSchemaValDate; typedef xmlSchemaValDate *xmlSchemaValDatePtr; @@ -249,10 +203,11 @@ xmlSchemaTypeErrMemory(xmlNodePtr node, const char *extra) * @name: the type name * @type: the value type associated * - * Initialize one default type + * Initialize one primitive built-in type */ static xmlSchemaTypePtr -xmlSchemaInitBasicType(const char *name, xmlSchemaValType type) { +xmlSchemaInitBasicType(const char *name, xmlSchemaValType type, + xmlSchemaTypePtr baseType) { xmlSchemaTypePtr ret; ret = (xmlSchemaTypePtr) xmlMalloc(sizeof(xmlSchemaType)); @@ -263,10 +218,43 @@ xmlSchemaInitBasicType(const char *name, xmlSchemaValType type) { memset(ret, 0, sizeof(xmlSchemaType)); ret->name = (const xmlChar *)name; ret->type = XML_SCHEMA_TYPE_BASIC; - ret->flags = type; + ret->baseType = baseType; + /* + * Hack to reflect the variety. + */ + if ((type == XML_SCHEMAS_IDREFS) || + (type == XML_SCHEMAS_NMTOKENS) || + (type == XML_SCHEMAS_ENTITIES)) + ret->flags |= XML_SCHEMAS_TYPE_VARIETY_LIST; + else if (type != XML_SCHEMAS_UNKNOWN) + ret->flags |= XML_SCHEMAS_TYPE_VARIETY_ATOMIC; ret->contentType = XML_SCHEMA_CONTENT_BASIC; + switch (type) { + case XML_SCHEMAS_STRING: + case XML_SCHEMAS_DECIMAL: + case XML_SCHEMAS_DATE: + case XML_SCHEMAS_DATETIME: + case XML_SCHEMAS_TIME: + case XML_SCHEMAS_GYEAR: + case XML_SCHEMAS_GYEARMONTH: + case XML_SCHEMAS_GMONTH: + case XML_SCHEMAS_GMONTHDAY: + case XML_SCHEMAS_GDAY: + case XML_SCHEMAS_DURATION: + case XML_SCHEMAS_FLOAT: + case XML_SCHEMAS_DOUBLE: + case XML_SCHEMAS_BOOLEAN: + case XML_SCHEMAS_ANYURI: + case XML_SCHEMAS_HEXBINARY: + case XML_SCHEMAS_BASE64BINARY: + case XML_SCHEMAS_QNAME: + case XML_SCHEMAS_NOTATION: + ret->flags |= XML_SCHEMAS_TYPE_BUILTIN_PRIMITIVE; + } + xmlHashAddEntry2(xmlSchemaTypesBank, ret->name, XML_SCHEMAS_NAMESPACE_NAME, ret); + ret->builtInType = type; return(ret); } @@ -282,106 +270,172 @@ xmlSchemaInitTypes(void) return; xmlSchemaTypesBank = xmlHashCreate(40); + /* - * primitive datatypes - */ - xmlSchemaTypeStringDef = xmlSchemaInitBasicType("string", - XML_SCHEMAS_STRING); + * 3.4.7 Built-in Complex Type Definition + */ xmlSchemaTypeAnyTypeDef = xmlSchemaInitBasicType("anyType", - XML_SCHEMAS_UNKNOWN); - xmlSchemaTypeAnySimpleTypeDef = xmlSchemaInitBasicType("anySimpleType", - XML_SCHEMAS_UNKNOWN); + XML_SCHEMAS_UNKNOWN, + NULL); + xmlSchemaTypeAnyTypeDef->baseType = xmlSchemaTypeAnyTypeDef; + xmlSchemaTypeAnyTypeDef->contentType = XML_SCHEMA_CONTENT_MIXED; + { + xmlSchemaWildcardPtr wild; + + wild = (xmlSchemaWildcardPtr) xmlMalloc(sizeof(xmlSchemaWildcard)); + if (wild == NULL) { + xmlSchemaTypeErrMemory(NULL, "could not create a wildcard on anyType"); + return; + } + memset(wild, 0, sizeof(xmlSchemaWildcard)); + wild->any = 1; + wild->processContents = XML_SCHEMAS_ANY_LAX; + wild->minOccurs = 1; + wild->maxOccurs = 1; + xmlSchemaTypeAnyTypeDef->attributeWildcard = wild; + } + xmlSchemaTypeAnySimpleTypeDef = xmlSchemaInitBasicType("anySimpleType", + XML_SCHEMAS_UNKNOWN, + xmlSchemaTypeAnyTypeDef); + /* + * primitive datatypes + */ + xmlSchemaTypeStringDef = xmlSchemaInitBasicType("string", + XML_SCHEMAS_STRING, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeDecimalDef = xmlSchemaInitBasicType("decimal", - XML_SCHEMAS_DECIMAL); + XML_SCHEMAS_DECIMAL, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeDateDef = xmlSchemaInitBasicType("date", - XML_SCHEMAS_DATE); + XML_SCHEMAS_DATE, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeDatetimeDef = xmlSchemaInitBasicType("dateTime", - XML_SCHEMAS_DATETIME); + XML_SCHEMAS_DATETIME, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeTimeDef = xmlSchemaInitBasicType("time", - XML_SCHEMAS_TIME); + XML_SCHEMAS_TIME, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeGYearDef = xmlSchemaInitBasicType("gYear", - XML_SCHEMAS_GYEAR); + XML_SCHEMAS_GYEAR, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeGYearMonthDef = xmlSchemaInitBasicType("gYearMonth", - XML_SCHEMAS_GYEARMONTH); + XML_SCHEMAS_GYEARMONTH, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeGMonthDef = xmlSchemaInitBasicType("gMonth", - XML_SCHEMAS_GMONTH); + XML_SCHEMAS_GMONTH, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeGMonthDayDef = xmlSchemaInitBasicType("gMonthDay", - XML_SCHEMAS_GMONTHDAY); + XML_SCHEMAS_GMONTHDAY, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeGDayDef = xmlSchemaInitBasicType("gDay", - XML_SCHEMAS_GDAY); + XML_SCHEMAS_GDAY, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeDurationDef = xmlSchemaInitBasicType("duration", - XML_SCHEMAS_DURATION); + XML_SCHEMAS_DURATION, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeFloatDef = xmlSchemaInitBasicType("float", - XML_SCHEMAS_FLOAT); + XML_SCHEMAS_FLOAT, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeDoubleDef = xmlSchemaInitBasicType("double", - XML_SCHEMAS_DOUBLE); + XML_SCHEMAS_DOUBLE, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeBooleanDef = xmlSchemaInitBasicType("boolean", - XML_SCHEMAS_BOOLEAN); + XML_SCHEMAS_BOOLEAN, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeAnyURIDef = xmlSchemaInitBasicType("anyURI", - XML_SCHEMAS_ANYURI); + XML_SCHEMAS_ANYURI, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeHexBinaryDef = xmlSchemaInitBasicType("hexBinary", - XML_SCHEMAS_HEXBINARY); + XML_SCHEMAS_HEXBINARY, + xmlSchemaTypeAnySimpleTypeDef); xmlSchemaTypeBase64BinaryDef - = xmlSchemaInitBasicType("base64Binary", XML_SCHEMAS_BASE64BINARY); + = xmlSchemaInitBasicType("base64Binary", XML_SCHEMAS_BASE64BINARY, + xmlSchemaTypeAnySimpleTypeDef); + xmlSchemaTypeNotationDef = xmlSchemaInitBasicType("NOTATION", + XML_SCHEMAS_NOTATION, + xmlSchemaTypeAnySimpleTypeDef); + xmlSchemaTypeQNameDef = xmlSchemaInitBasicType("QName", + XML_SCHEMAS_QNAME, + xmlSchemaTypeAnySimpleTypeDef); /* * derived datatypes */ xmlSchemaTypeIntegerDef = xmlSchemaInitBasicType("integer", - XML_SCHEMAS_INTEGER);; + XML_SCHEMAS_INTEGER, + xmlSchemaTypeDecimalDef); xmlSchemaTypeNonPositiveIntegerDef = xmlSchemaInitBasicType("nonPositiveInteger", - XML_SCHEMAS_NPINTEGER);; + XML_SCHEMAS_NPINTEGER, + xmlSchemaTypeIntegerDef); xmlSchemaTypeNegativeIntegerDef = - xmlSchemaInitBasicType("negativeInteger", XML_SCHEMAS_NINTEGER);; + xmlSchemaInitBasicType("negativeInteger", XML_SCHEMAS_NINTEGER, + xmlSchemaTypeNonPositiveIntegerDef); xmlSchemaTypeLongDef = - xmlSchemaInitBasicType("long", XML_SCHEMAS_LONG);; - xmlSchemaTypeIntDef = xmlSchemaInitBasicType("int", XML_SCHEMAS_INT);; + xmlSchemaInitBasicType("long", XML_SCHEMAS_LONG, + xmlSchemaTypeIntegerDef); + xmlSchemaTypeIntDef = xmlSchemaInitBasicType("int", XML_SCHEMAS_INT, + xmlSchemaTypeLongDef); xmlSchemaTypeShortDef = xmlSchemaInitBasicType("short", - XML_SCHEMAS_SHORT);; + XML_SCHEMAS_SHORT, + xmlSchemaTypeIntDef); xmlSchemaTypeByteDef = xmlSchemaInitBasicType("byte", - XML_SCHEMAS_BYTE);; + XML_SCHEMAS_BYTE, + xmlSchemaTypeShortDef); xmlSchemaTypeNonNegativeIntegerDef = xmlSchemaInitBasicType("nonNegativeInteger", - XML_SCHEMAS_NNINTEGER); + XML_SCHEMAS_NNINTEGER, + xmlSchemaTypeIntegerDef); xmlSchemaTypeUnsignedLongDef = - xmlSchemaInitBasicType("unsignedLong", XML_SCHEMAS_ULONG);; + xmlSchemaInitBasicType("unsignedLong", XML_SCHEMAS_ULONG, + xmlSchemaTypeNonNegativeIntegerDef); xmlSchemaTypeUnsignedIntDef = - xmlSchemaInitBasicType("unsignedInt", XML_SCHEMAS_UINT);; + xmlSchemaInitBasicType("unsignedInt", XML_SCHEMAS_UINT, + xmlSchemaTypeUnsignedLongDef); xmlSchemaTypeUnsignedShortDef = - xmlSchemaInitBasicType("unsignedShort", XML_SCHEMAS_USHORT);; + xmlSchemaInitBasicType("unsignedShort", XML_SCHEMAS_USHORT, + xmlSchemaTypeUnsignedIntDef); xmlSchemaTypeUnsignedByteDef = - xmlSchemaInitBasicType("unsignedByte", XML_SCHEMAS_UBYTE);; + xmlSchemaInitBasicType("unsignedByte", XML_SCHEMAS_UBYTE, + xmlSchemaTypeUnsignedShortDef); xmlSchemaTypePositiveIntegerDef = - xmlSchemaInitBasicType("positiveInteger", XML_SCHEMAS_PINTEGER); - + xmlSchemaInitBasicType("positiveInteger", XML_SCHEMAS_PINTEGER, + xmlSchemaTypeNonNegativeIntegerDef); xmlSchemaTypeNormStringDef = xmlSchemaInitBasicType("normalizedString", - XML_SCHEMAS_NORMSTRING); + XML_SCHEMAS_NORMSTRING, + xmlSchemaTypeStringDef); xmlSchemaTypeTokenDef = xmlSchemaInitBasicType("token", - XML_SCHEMAS_TOKEN); + XML_SCHEMAS_TOKEN, + xmlSchemaTypeNormStringDef); xmlSchemaTypeLanguageDef = xmlSchemaInitBasicType("language", - XML_SCHEMAS_LANGUAGE); - xmlSchemaTypeIdDef = xmlSchemaInitBasicType("ID", XML_SCHEMAS_ID); - xmlSchemaTypeIdrefDef = xmlSchemaInitBasicType("IDREF", - XML_SCHEMAS_IDREF); - xmlSchemaTypeIdrefsDef = xmlSchemaInitBasicType("IDREFS", - XML_SCHEMAS_IDREFS); - xmlSchemaTypeEntityDef = xmlSchemaInitBasicType("ENTITY", - XML_SCHEMAS_ENTITY); - xmlSchemaTypeEntitiesDef = xmlSchemaInitBasicType("ENTITIES", - XML_SCHEMAS_ENTITIES); - xmlSchemaTypeNotationDef = xmlSchemaInitBasicType("NOTATION", - XML_SCHEMAS_NOTATION); + XML_SCHEMAS_LANGUAGE, + xmlSchemaTypeTokenDef); xmlSchemaTypeNameDef = xmlSchemaInitBasicType("Name", - XML_SCHEMAS_NAME); - xmlSchemaTypeQNameDef = xmlSchemaInitBasicType("QName", - XML_SCHEMAS_QNAME); - xmlSchemaTypeNCNameDef = xmlSchemaInitBasicType("NCName", - XML_SCHEMAS_NCNAME); + XML_SCHEMAS_NAME, + xmlSchemaTypeTokenDef); xmlSchemaTypeNmtokenDef = xmlSchemaInitBasicType("NMTOKEN", - XML_SCHEMAS_NMTOKEN); + XML_SCHEMAS_NMTOKEN, + xmlSchemaTypeTokenDef); + xmlSchemaTypeNCNameDef = xmlSchemaInitBasicType("NCName", + XML_SCHEMAS_NCNAME, + xmlSchemaTypeNameDef); + xmlSchemaTypeIdDef = xmlSchemaInitBasicType("ID", XML_SCHEMAS_ID, + xmlSchemaTypeNCNameDef); + xmlSchemaTypeIdrefDef = xmlSchemaInitBasicType("IDREF", + XML_SCHEMAS_IDREF, + xmlSchemaTypeNCNameDef); + xmlSchemaTypeIdrefsDef = xmlSchemaInitBasicType("IDREFS", + XML_SCHEMAS_IDREFS, + xmlSchemaTypeIdrefDef); xmlSchemaTypeNmtokensDef = xmlSchemaInitBasicType("NMTOKENS", - XML_SCHEMAS_NMTOKENS); + XML_SCHEMAS_NMTOKENS, + xmlSchemaTypeNmtokenDef); + xmlSchemaTypeEntityDef = xmlSchemaInitBasicType("ENTITY", + XML_SCHEMAS_ENTITY, + xmlSchemaTypeNCNameDef); + xmlSchemaTypeEntitiesDef = xmlSchemaInitBasicType("ENTITIES", + XML_SCHEMAS_ENTITIES, + xmlSchemaTypeNCNameDef); xmlSchemaTypesInitialized = 1; } @@ -394,10 +448,202 @@ void xmlSchemaCleanupTypes(void) { if (xmlSchemaTypesInitialized == 0) return; + xmlSchemaFreeWildcard(xmlSchemaTypeAnyTypeDef->attributeWildcard); xmlHashFree(xmlSchemaTypesBank, (xmlHashDeallocator) xmlSchemaFreeType); xmlSchemaTypesInitialized = 0; } +/** + * xmlSchemaGetBuiltInType: + * @type: the built-in type + * @facetType: the facet type + * + * Evaluates if a specific facet can be + * used in conjunction with a type. + * + * Returns 1 if the facet can be used with the given built-in type, + * 0 otherwise and -1 in case the type is not a built-in type. + */ +int +xmlSchemaIsBuiltInTypeFacet(xmlSchemaTypePtr type, int facetType) +{ + if (type->type != XML_SCHEMA_TYPE_BASIC) + return (-1); + switch (type->builtInType) { + case XML_SCHEMAS_BOOLEAN: + if ((facetType == XML_SCHEMA_FACET_PATTERN) || + (facetType == XML_SCHEMA_FACET_WHITESPACE)) + return (1); + else + return (0); + case XML_SCHEMAS_STRING: + case XML_SCHEMAS_NOTATION: + case XML_SCHEMAS_QNAME: + case XML_SCHEMAS_ANYURI: + case XML_SCHEMAS_BASE64BINARY: + case XML_SCHEMAS_HEXBINARY: + if ((facetType == XML_SCHEMA_FACET_LENGTH) || + (facetType == XML_SCHEMA_FACET_MINLENGTH) || + (facetType == XML_SCHEMA_FACET_MAXLENGTH) || + (facetType == XML_SCHEMA_FACET_PATTERN) || + (facetType == XML_SCHEMA_FACET_ENUMERATION) || + (facetType == XML_SCHEMA_FACET_WHITESPACE)) + return (1); + else + return (0); + case XML_SCHEMAS_DECIMAL: + if ((facetType == XML_SCHEMA_FACET_TOTALDIGITS) || + (facetType == XML_SCHEMA_FACET_FRACTIONDIGITS) || + (facetType == XML_SCHEMA_FACET_PATTERN) || + (facetType == XML_SCHEMA_FACET_WHITESPACE) || + (facetType == XML_SCHEMA_FACET_ENUMERATION) || + (facetType == XML_SCHEMA_FACET_MAXINCLUSIVE) || + (facetType == XML_SCHEMA_FACET_MAXEXCLUSIVE) || + (facetType == XML_SCHEMA_FACET_MININCLUSIVE) || + (facetType == XML_SCHEMA_FACET_MINEXCLUSIVE)) + return (1); + else + return (0); + case XML_SCHEMAS_TIME: + case XML_SCHEMAS_GDAY: + case XML_SCHEMAS_GMONTH: + case XML_SCHEMAS_GMONTHDAY: + case XML_SCHEMAS_GYEAR: + case XML_SCHEMAS_GYEARMONTH: + case XML_SCHEMAS_DATE: + case XML_SCHEMAS_DATETIME: + case XML_SCHEMAS_DURATION: + case XML_SCHEMAS_FLOAT: + case XML_SCHEMAS_DOUBLE: + if ((facetType == XML_SCHEMA_FACET_PATTERN) || + (facetType == XML_SCHEMA_FACET_ENUMERATION) || + (facetType == XML_SCHEMA_FACET_WHITESPACE) || + (facetType == XML_SCHEMA_FACET_MAXINCLUSIVE) || + (facetType == XML_SCHEMA_FACET_MAXEXCLUSIVE) || + (facetType == XML_SCHEMA_FACET_MININCLUSIVE) || + (facetType == XML_SCHEMA_FACET_MINEXCLUSIVE)) + return (1); + else + return (0); + default: + return (0); + } + return (0); +} + +/** + * xmlSchemaGetBuiltInType: + * @type: the type of the built in type + * + * Gives you the type struct for a built-in + * type by its type id. + * + * Returns the type if found, NULL otherwise. + */ +xmlSchemaTypePtr +xmlSchemaGetBuiltInType(xmlSchemaValType type) +{ + if (xmlSchemaTypesInitialized == 0) + xmlSchemaInitTypes(); + switch (type) { + + case XML_SCHEMAS_ANYSIMPLETYPE: + return (xmlSchemaTypeAnySimpleTypeDef); + case XML_SCHEMAS_STRING: + return (xmlSchemaTypeStringDef); + case XML_SCHEMAS_NORMSTRING: + return (xmlSchemaTypeNormStringDef); + case XML_SCHEMAS_DECIMAL: + return (xmlSchemaTypeDecimalDef); + case XML_SCHEMAS_TIME: + return (xmlSchemaTypeTimeDef); + case XML_SCHEMAS_GDAY: + return (xmlSchemaTypeGDayDef); + case XML_SCHEMAS_GMONTH: + return (xmlSchemaTypeGMonthDef); + case XML_SCHEMAS_GMONTHDAY: + return (xmlSchemaTypeGMonthDayDef); + case XML_SCHEMAS_GYEAR: + return (xmlSchemaTypeGYearDef); + case XML_SCHEMAS_GYEARMONTH: + return (xmlSchemaTypeGYearMonthDef); + case XML_SCHEMAS_DATE: + return (xmlSchemaTypeDateDef); + case XML_SCHEMAS_DATETIME: + return (xmlSchemaTypeDatetimeDef); + case XML_SCHEMAS_DURATION: + return (xmlSchemaTypeDurationDef); + case XML_SCHEMAS_FLOAT: + return (xmlSchemaTypeFloatDef); + case XML_SCHEMAS_DOUBLE: + return (xmlSchemaTypeDoubleDef); + case XML_SCHEMAS_BOOLEAN: + return (xmlSchemaTypeBooleanDef); + case XML_SCHEMAS_TOKEN: + return (xmlSchemaTypeTokenDef); + case XML_SCHEMAS_LANGUAGE: + return (xmlSchemaTypeLanguageDef); + case XML_SCHEMAS_NMTOKEN: + return (xmlSchemaTypeNmtokenDef); + case XML_SCHEMAS_NMTOKENS: + return (xmlSchemaTypeNmtokensDef); + case XML_SCHEMAS_NAME: + return (xmlSchemaTypeNameDef); + case XML_SCHEMAS_QNAME: + return (xmlSchemaTypeQNameDef); + case XML_SCHEMAS_NCNAME: + return (xmlSchemaTypeNCNameDef); + case XML_SCHEMAS_ID: + return (xmlSchemaTypeIdDef); + case XML_SCHEMAS_IDREF: + return (xmlSchemaTypeIdrefDef); + case XML_SCHEMAS_IDREFS: + return (xmlSchemaTypeIdrefsDef); + case XML_SCHEMAS_ENTITY: + return (xmlSchemaTypeEntityDef); + case XML_SCHEMAS_ENTITIES: + return (xmlSchemaTypeEntitiesDef); + case XML_SCHEMAS_NOTATION: + return (xmlSchemaTypeNotationDef); + case XML_SCHEMAS_ANYURI: + return (xmlSchemaTypeAnyURIDef); + case XML_SCHEMAS_INTEGER: + return (xmlSchemaTypeIntegerDef); + case XML_SCHEMAS_NPINTEGER: + return (xmlSchemaTypeNonPositiveIntegerDef); + case XML_SCHEMAS_NINTEGER: + return (xmlSchemaTypeNegativeIntegerDef); + case XML_SCHEMAS_NNINTEGER: + return (xmlSchemaTypeNonNegativeIntegerDef); + case XML_SCHEMAS_PINTEGER: + return (xmlSchemaTypePositiveIntegerDef); + case XML_SCHEMAS_INT: + return (xmlSchemaTypeIntDef); + case XML_SCHEMAS_UINT: + return (xmlSchemaTypeUnsignedIntDef); + case XML_SCHEMAS_LONG: + return (xmlSchemaTypeLongDef); + case XML_SCHEMAS_ULONG: + return (xmlSchemaTypeUnsignedLongDef); + case XML_SCHEMAS_SHORT: + return (xmlSchemaTypeShortDef); + case XML_SCHEMAS_USHORT: + return (xmlSchemaTypeUnsignedShortDef); + case XML_SCHEMAS_BYTE: + return (xmlSchemaTypeByteDef); + case XML_SCHEMAS_UBYTE: + return (xmlSchemaTypeUnsignedByteDef); + case XML_SCHEMAS_HEXBINARY: + return (xmlSchemaTypeHexBinaryDef); + case XML_SCHEMAS_BASE64BINARY: + return (xmlSchemaTypeBase64BinaryDef); + case XML_SCHEMAS_ANYTYPE: + return (xmlSchemaTypeAnyTypeDef); + default: + return (NULL); + } +} + /** * xmlSchemaNewValue: * @type: the value type @@ -486,6 +732,30 @@ xmlSchemaGetPredefinedType(const xmlChar *name, const xmlChar *ns) { return((xmlSchemaTypePtr) xmlHashLookup2(xmlSchemaTypesBank, name, ns)); } +/** + * xmlSchemaGetBuiltInListSimpleTypeItemType: + * @type: the built-in simple type. + * + * Returns the item type of @type as defined by the built-in datatype + * hierarchy of XML Schema Part 2: Datatypes, or NULL in case of an error. + */ +xmlSchemaTypePtr +xmlSchemaGetBuiltInListSimpleTypeItemType(xmlSchemaTypePtr type) +{ + if (type->type != XML_SCHEMA_TYPE_BASIC) + return (NULL); + switch (type->builtInType) { + case XML_SCHEMAS_NMTOKENS: + return (xmlSchemaTypeNmtokenDef ); + case XML_SCHEMAS_IDREFS: + return (xmlSchemaTypeIdrefDef); + case XML_SCHEMAS_ENTITIES: + return (xmlSchemaTypeEntityDef); + default: + return (NULL); + } +} + /**************************************************************** * * * Convenience macros and functions * @@ -1269,7 +1539,7 @@ xmlSchemaStrip(const xmlChar *value) { * * Returns the new string or NULL if no change was required. */ -static xmlChar * +xmlChar * xmlSchemaCollapseString(const xmlChar *value) { const xmlChar *start = value, *end, *f; xmlChar *g; @@ -1442,6 +1712,7 @@ xmlSchemaParseUInt(const xmlChar **str, unsigned long *llo, * * Check that a value conforms to the lexical space of the atomic type. * if true a value is computed and returned in @val. + * This checks the value space for list types as well (IDREFS, NMTOKENS). * * Returns 0 if this validates, a positive error code number otherwise * and -1 in case of internal or API error. @@ -1455,24 +1726,24 @@ xmlSchemaValAtomicType(xmlSchemaTypePtr type, const xmlChar * value, int ret = 0; if (xmlSchemaTypesInitialized == 0) - return (-1); + xmlSchemaInitTypes(); if (type == NULL) return (-1); if (val != NULL) *val = NULL; if ((flags == 0) && (value != NULL)) { - if ((type->flags != XML_SCHEMAS_STRING) && - (type->flags != XML_SCHEMAS_NORMSTRING)) { + if ((type->builtInType != XML_SCHEMAS_STRING) && + (type->builtInType != XML_SCHEMAS_NORMSTRING)) { norm = xmlSchemaCollapseString(value); if (norm != NULL) value = norm; } } - switch (type->flags) { + switch (type->builtInType) { case XML_SCHEMAS_UNKNOWN: - if (type == xmlSchemaTypeAnyTypeDef) + if (type == xmlSchemaTypeAnySimpleTypeDef) goto return0; goto error; case XML_SCHEMAS_STRING: @@ -1548,7 +1819,7 @@ xmlSchemaValAtomicType(xmlSchemaTypePtr type, const xmlChar * value, case XML_SCHEMAS_GYEARMONTH: case XML_SCHEMAS_DATE: case XML_SCHEMAS_DATETIME: - ret = xmlSchemaValidateDates(type->flags, value, val); + ret = xmlSchemaValidateDates(type->builtInType, value, val); break; case XML_SCHEMAS_DURATION: ret = xmlSchemaValidateDuration(type, value, val); @@ -1649,7 +1920,7 @@ xmlSchemaValAtomicType(xmlSchemaTypePtr type, const xmlChar * value, if (v != NULL) { if (sscanf((const char *) value, "%f", &(v->value.f)) == 1) { - *val = v; + *val = v; } else { xmlSchemaFreeValue(v); goto return1; @@ -2210,21 +2481,21 @@ xmlSchemaValAtomicType(xmlSchemaTypePtr type, const xmlChar * value, goto return1; if (*cur != 0) goto return1; - if (type->flags == XML_SCHEMAS_NPINTEGER) { + if (type->builtInType == XML_SCHEMAS_NPINTEGER) { if ((sign == 0) && ((hi != 0) || (mi != 0) || (lo != 0))) goto return1; - } else if (type->flags == XML_SCHEMAS_PINTEGER) { + } else if (type->builtInType == XML_SCHEMAS_PINTEGER) { if (sign == 1) goto return1; if ((hi == 0) && (mi == 0) && (lo == 0)) goto return1; - } else if (type->flags == XML_SCHEMAS_NINTEGER) { + } else if (type->builtInType == XML_SCHEMAS_NINTEGER) { if (sign == 0) goto return1; if ((hi == 0) && (mi == 0) && (lo == 0)) goto return1; - } else if (type->flags == XML_SCHEMAS_NNINTEGER) { + } else if (type->builtInType == XML_SCHEMAS_NNINTEGER) { if ((sign == 1) && ((hi != 0) || (mi != 0) || (lo != 0))) goto return1; @@ -2233,7 +2504,7 @@ xmlSchemaValAtomicType(xmlSchemaTypePtr type, const xmlChar * value, * We can store a value only if no overflow occured */ if ((ret > 0) && (val != NULL)) { - v = xmlSchemaNewValue(type->flags); + v = xmlSchemaNewValue(type->builtInType); if (v != NULL) { v->value.decimal.lo = lo; v->value.decimal.mi = lo; @@ -2267,7 +2538,7 @@ xmlSchemaValAtomicType(xmlSchemaTypePtr type, const xmlChar * value, goto return1; if (*cur != 0) goto return1; - if (type->flags == XML_SCHEMAS_LONG) { + if (type->builtInType == XML_SCHEMAS_LONG) { if (hi >= 922) { if (hi > 922) goto return1; @@ -2280,7 +2551,7 @@ xmlSchemaValAtomicType(xmlSchemaTypePtr type, const xmlChar * value, goto return1; } } - } else if (type->flags == XML_SCHEMAS_INT) { + } else if (type->builtInType == XML_SCHEMAS_INT) { if (hi != 0) goto return1; if (mi >= 21) { @@ -2291,14 +2562,14 @@ xmlSchemaValAtomicType(xmlSchemaTypePtr type, const xmlChar * value, if ((sign == 1) && (lo > 47483648)) goto return1; } - } else if (type->flags == XML_SCHEMAS_SHORT) { + } else if (type->builtInType == XML_SCHEMAS_SHORT) { if ((mi != 0) || (hi != 0)) goto return1; if ((sign == 1) && (lo > 32768)) goto return1; if ((sign == 0) && (lo > 32767)) goto return1; - } else if (type->flags == XML_SCHEMAS_BYTE) { + } else if (type->builtInType == XML_SCHEMAS_BYTE) { if ((mi != 0) || (hi != 0)) goto return1; if ((sign == 1) && (lo > 128)) @@ -2307,7 +2578,7 @@ xmlSchemaValAtomicType(xmlSchemaTypePtr type, const xmlChar * value, goto return1; } if (val != NULL) { - v = xmlSchemaNewValue(type->flags); + v = xmlSchemaNewValue(type->builtInType); if (v != NULL) { v->value.decimal.lo = lo; v->value.decimal.mi = lo; @@ -2335,7 +2606,7 @@ xmlSchemaValAtomicType(xmlSchemaTypePtr type, const xmlChar * value, goto return1; if (*cur != 0) goto return1; - if (type->flags == XML_SCHEMAS_ULONG) { + if (type->builtInType == XML_SCHEMAS_ULONG) { if (hi >= 1844) { if (hi > 1844) goto return1; @@ -2346,7 +2617,7 @@ xmlSchemaValAtomicType(xmlSchemaTypePtr type, const xmlChar * value, goto return1; } } - } else if (type->flags == XML_SCHEMAS_UINT) { + } else if (type->builtInType == XML_SCHEMAS_UINT) { if (hi != 0) goto return1; if (mi >= 42) { @@ -2355,19 +2626,19 @@ xmlSchemaValAtomicType(xmlSchemaTypePtr type, const xmlChar * value, if (lo > 94967295) goto return1; } - } else if (type->flags == XML_SCHEMAS_USHORT) { + } else if (type->builtInType == XML_SCHEMAS_USHORT) { if ((mi != 0) || (hi != 0)) goto return1; if (lo > 65535) goto return1; - } else if (type->flags == XML_SCHEMAS_UBYTE) { + } else if (type->builtInType == XML_SCHEMAS_UBYTE) { if ((mi != 0) || (hi != 0)) goto return1; if (lo > 255) goto return1; } if (val != NULL) { - v = xmlSchemaNewValue(type->flags); + v = xmlSchemaNewValue(type->builtInType); if (v != NULL) { v->value.decimal.lo = lo; v->value.decimal.mi = mi; @@ -2477,11 +2748,11 @@ xmlSchemaCompareDecimals(xmlSchemaValPtr x, xmlSchemaValPtr y) if (x->value.decimal.frac == y->value.decimal.frac) { if (x->value.decimal.hi < y->value.decimal.hi) return (-order); - if (x->value.decimal.hi < y->value.decimal.hi) + if (x->value.decimal.hi > y->value.decimal.hi) return (order); if (x->value.decimal.mi < y->value.decimal.mi) return (-order); - if (x->value.decimal.mi < y->value.decimal.mi) + if (x->value.decimal.mi > y->value.decimal.mi) return (order); if (x->value.decimal.lo < y->value.decimal.lo) return (-order); @@ -3444,6 +3715,53 @@ xmlSchemaNormLen(const xmlChar *value) { return(ret); } +/** + * xmlSchemaValidateListSimpleTypeFacet: + * @facet: the facet to check + * @value: the lexical repr of the value to validate + * @actualLen: the number of list items + * @expectedLen: the resulting expected number of list items + * + * Checks the value of a list simple type against a facet. + * + * Returns 0 if the value is valid, a positive error code + * number otherwise and -1 in case of an internal error. + */ +int +xmlSchemaValidateListSimpleTypeFacet(xmlSchemaFacetPtr facet, + const xmlChar *value, + unsigned long actualLen, + unsigned long *expectedLen) +{ + /* + * TODO: Check if this will work with large numbers. + * (compare value.decimal.mi and value.decimal.hi as well?). + */ + if (facet->type == XML_SCHEMA_FACET_LENGTH) { + if (actualLen != facet->val->value.decimal.lo) { + *expectedLen = facet->val->value.decimal.lo; + return (XML_SCHEMAV_CVC_LENGTH_VALID); + } + } else if (facet->type == XML_SCHEMA_FACET_MINLENGTH) { + if (actualLen < facet->val->value.decimal.lo) { + *expectedLen = facet->val->value.decimal.lo; + return (XML_SCHEMAV_CVC_MINLENGTH_VALID); + } + } else if (facet->type == XML_SCHEMA_FACET_MAXLENGTH) { + if (actualLen > facet->val->value.decimal.lo) { + *expectedLen = facet->val->value.decimal.lo; + return (XML_SCHEMAV_CVC_MAXLENGTH_VALID); + } + } else + /* + * NOTE: That we can pass NULL as xmlSchemaValPtr to + * xmlSchemaValidateFacet, since the remaining facet types + * are: XML_SCHEMA_FACET_PATTERN, XML_SCHEMA_FACET_ENUMERATION. + */ + return(xmlSchemaValidateFacet(NULL, facet, value, NULL)); + return (0); +} + /** * xmlSchemaValidateFacet: * @base: the base type @@ -3469,8 +3787,7 @@ xmlSchemaValidateFacet(xmlSchemaTypePtr base ATTRIBUTE_UNUSED, if (ret == 1) return(0); if (ret == 0) { - /* TODO error code */ - return(1); + return(XML_SCHEMAV_CVC_PATTERN_VALID); } return(ret); case XML_SCHEMA_FACET_MAXEXCLUSIVE: @@ -3482,7 +3799,7 @@ xmlSchemaValidateFacet(xmlSchemaTypePtr base ATTRIBUTE_UNUSED, if (ret == -1) return(0); /* error code */ - return(1); + return(XML_SCHEMAV_CVC_MAXEXCLUSIVE_VALID); case XML_SCHEMA_FACET_MAXINCLUSIVE: ret = xmlSchemaCompareValues(val, facet->val); if (ret == -2) { @@ -3492,7 +3809,7 @@ xmlSchemaValidateFacet(xmlSchemaTypePtr base ATTRIBUTE_UNUSED, if ((ret == -1) || (ret == 0)) return(0); /* error code */ - return(1); + return(XML_SCHEMAV_CVC_MAXINCLUSIVE_VALID); case XML_SCHEMA_FACET_MINEXCLUSIVE: ret = xmlSchemaCompareValues(val, facet->val); if (ret == -2) { @@ -3502,7 +3819,7 @@ xmlSchemaValidateFacet(xmlSchemaTypePtr base ATTRIBUTE_UNUSED, if (ret == 1) return(0); /* error code */ - return(1); + return(XML_SCHEMAV_CVC_MINEXCLUSIVE_VALID); case XML_SCHEMA_FACET_MININCLUSIVE: ret = xmlSchemaCompareValues(val, facet->val); if (ret == -2) { @@ -3512,15 +3829,20 @@ xmlSchemaValidateFacet(xmlSchemaTypePtr base ATTRIBUTE_UNUSED, if ((ret == 1) || (ret == 0)) return(0); /* error code */ - return(1); + return(XML_SCHEMAV_CVC_MININCLUSIVE_VALID); case XML_SCHEMA_FACET_WHITESPACE: /* TODO whitespaces */ + /* + * NOTE: Whitespace should be handled to normalize + * the value to be validated against a the facets; + * not to normalize the value in-between. + */ return(0); case XML_SCHEMA_FACET_ENUMERATION: if ((facet->value != NULL) && (xmlStrEqual(facet->value, value))) return(0); - return(1); + return(XML_SCHEMAV_CVC_ENUMERATION_VALID); case XML_SCHEMA_FACET_LENGTH: case XML_SCHEMA_FACET_MAXLENGTH: case XML_SCHEMA_FACET_MINLENGTH: { @@ -3537,7 +3859,7 @@ xmlSchemaValidateFacet(xmlSchemaTypePtr base ATTRIBUTE_UNUSED, else if ((val != NULL) && (val->type == XML_SCHEMAS_BASE64BINARY)) len = val->value.base64.total; else { - switch (base->flags) { + switch (base->builtInType) { case XML_SCHEMAS_IDREF: case XML_SCHEMAS_NORMSTRING: case XML_SCHEMAS_TOKEN: @@ -3549,6 +3871,10 @@ xmlSchemaValidateFacet(xmlSchemaTypePtr base ATTRIBUTE_UNUSED, len = xmlSchemaNormLen(value); break; case XML_SCHEMAS_STRING: + /* + * FIXME: What exactly to do with anyURI? + */ + case XML_SCHEMAS_ANYURI: if (value != NULL) len = xmlUTF8Strlen(value); break; @@ -3558,13 +3884,13 @@ xmlSchemaValidateFacet(xmlSchemaTypePtr base ATTRIBUTE_UNUSED, } if (facet->type == XML_SCHEMA_FACET_LENGTH) { if (len != facet->val->value.decimal.lo) - return(1); + return(XML_SCHEMAV_CVC_LENGTH_VALID); } else if (facet->type == XML_SCHEMA_FACET_MINLENGTH) { if (len < facet->val->value.decimal.lo) - return(1); + return(XML_SCHEMAV_CVC_MINLENGTH_VALID); } else { if (len > facet->val->value.decimal.lo) - return(1); + return(XML_SCHEMAV_CVC_MAXLENGTH_VALID); } break; } @@ -3596,11 +3922,11 @@ xmlSchemaValidateFacet(xmlSchemaTypePtr base ATTRIBUTE_UNUSED, } if (facet->type == XML_SCHEMA_FACET_TOTALDIGITS) { if (val->value.decimal.total > facet->val->value.decimal.lo) - return(1); + return(XML_SCHEMAV_CVC_TOTALDIGITS_VALID); } else if (facet->type == XML_SCHEMA_FACET_FRACTIONDIGITS) { if (val->value.decimal.frac > facet->val->value.decimal.lo) - return(1); + return(XML_SCHEMAV_CVC_FRACTIONDIGITS_VALID); } break; default: