]> granicus.if.org Git - libexpat/commitdiff
Added documentation on how Expat deals with XML versions other than
authorFred L. Drake, Jr. <fdrake@users.sourceforge.net>
Thu, 8 Aug 2002 22:17:28 +0000 (22:17 +0000)
committerFred L. Drake, Jr. <fdrake@users.sourceforge.net>
Thu, 8 Aug 2002 22:17:28 +0000 (22:17 +0000)
1.0, and shows how an application can affect it.
Closes SF bug #584041.

expat/doc/reference.html

index 1237666d4f955b469463f008cb89ff2eff7603df..ab6c84fa0c3e3346e73f48e4787ced2d786a92b7 100644 (file)
@@ -395,6 +395,46 @@ the shared variables. You can then tell expat (with the <code><a href=
 pointer to this structure to the handlers. This is typically the first
 argument received by most handlers.</p>
 
+<h3>XML Version</h3>
+
+<p>Expat is an XML 1.0 parser, and as such never complains based on
+the value of the <code>version</code> psuedo-attribute in the XML
+declaration, if present.</p>
+
+<p>If an application needs to check the version number (to support
+alternate processing), it should use the <code><a href=
+"#XML_SetXmlDeclHandler" >XML_SetXmlDeclHandler</a></code> function to
+set a handler that uses the information in the XML declaration to
+determine what to do.  This example shows how to check that only a
+version number of <code>"1.0"</code> is accepted:</p>
+
+<pre class="eg">
+static int wrong_version;
+static XML_Parser parser;
+
+static void
+xmldecl_handler(void            *userData,
+                const XML_Char  *version,
+                const XML_Char  *encoding,
+                int              standalone)
+{
+  static const XML_Char Version_1_0[] = {'1', '.', '0', 0};
+
+  int i;
+
+  for (i = 0; i < (sizeof(Version_1_0) / sizeof(Version_1_0[0])); ++i) {
+    if (version[i] != Version_1_0[i]) {
+      wrong_version = 1;
+      /* also clear all other handlers: */
+      XML_SetCharacterDataHandler(parser, NULL);
+      ...
+      return;
+    }
+  }
+  ...
+}
+</pre>
+
 <h3>Namespace Processing</h3>
 
 <p>When the parser is created using the <code><a href=