1
0
mirror of https://gitlab.gnome.org/GNOME/libxml2.git synced 2025-10-24 13:33:01 +03:00

preparing release of 2.6.26 Daniel

* configure.ini NEWS doc//* libxml.spec.in : preparing release of 2.6.26
Daniel
This commit is contained in:
Daniel Veillard
2006-06-08 08:16:33 +00:00
parent 7cb3fa9d51
commit fabafd54c7
31 changed files with 4606 additions and 4611 deletions

View File

@@ -1,3 +1,7 @@
Tue Jun 6 17:50:43 CEST 2006 Daniel Veillard <daniel@veillard.com>
* configure.ini NEWS doc//* libxml.spec.in : preparing release of 2.6.26
Tue Jun 6 17:25:23 CEST 2006 Kasimier Buchcik <libxml2-cvs@cazic.net> Tue Jun 6 17:25:23 CEST 2006 Kasimier Buchcik <libxml2-cvs@cazic.net>
* xpath.c: Fixed self-invented a segfault in xmlXPathCtxtCompile(), * xpath.c: Fixed self-invented a segfault in xmlXPathCtxtCompile(),

View File

@@ -5,7 +5,7 @@ AC_CANONICAL_HOST
LIBXML_MAJOR_VERSION=2 LIBXML_MAJOR_VERSION=2
LIBXML_MINOR_VERSION=6 LIBXML_MINOR_VERSION=6
LIBXML_MICRO_VERSION=25 LIBXML_MICRO_VERSION=26
LIBXML_MICRO_VERSION_SUFFIX= LIBXML_MICRO_VERSION_SUFFIX=
LIBXML_VERSION=$LIBXML_MAJOR_VERSION.$LIBXML_MINOR_VERSION.$LIBXML_MICRO_VERSION$LIBXML_MICRO_VERSION_SUFFIX LIBXML_VERSION=$LIBXML_MAJOR_VERSION.$LIBXML_MINOR_VERSION.$LIBXML_MICRO_VERSION$LIBXML_MICRO_VERSION_SUFFIX
LIBXML_VERSION_INFO=`expr $LIBXML_MAJOR_VERSION + $LIBXML_MINOR_VERSION`:$LIBXML_MICRO_VERSION:$LIBXML_MINOR_VERSION LIBXML_VERSION_INFO=`expr $LIBXML_MAJOR_VERSION + $LIBXML_MINOR_VERSION`:$LIBXML_MICRO_VERSION:$LIBXML_MINOR_VERSION

File diff suppressed because one or more lines are too long

View File

@@ -12,51 +12,49 @@ A:link, A:visited, A:active { text-decoration: underline }
<li><a href="FAQ.html#Compilatio">Compilation</a></li> <li><a href="FAQ.html#Compilatio">Compilation</a></li>
<li><a href="FAQ.html#Developer">Developer corner</a></li> <li><a href="FAQ.html#Developer">Developer corner</a></li>
</ul><h3><a name="License" id="License">License</a>(s)</h3><ol><li><em>Licensing Terms for libxml</em> </ul><h3><a name="License" id="License">License</a>(s)</h3><ol><li><em>Licensing Terms for libxml</em>
<p>libxml2 is released under the <a href="http://www.opensource.org/licenses/mit-license.html">MITLicense</a>; <p>libxml2 is released under the <a href="http://www.opensource.org/licenses/mit-license.html">MITLicense</a>;see
see the file Copyright in the distribution for the precisewording</p> the file Copyright in the distribution for the precisewording</p>
</li> </li>
<li><em>Can I embed libxml2 in a proprietary application ?</em> <li><em>Can I embed libxml2 in a proprietary application ?</em>
<p>Yes. The MIT License allows you to keep proprietary the changes <p>Yes. The MIT License allows you to keep proprietary the changesyoumade
youmade to libxml, but it would be graceful to send-back bug fixes to libxml, but it would be graceful to send-back bug fixesandimprovements
andimprovements as patches for possible incorporation in the as patches for possible incorporation in themaindevelopment tree.</p>
maindevelopment tree.</p>
</li> </li>
</ol><h3><a name="Installati" id="Installati">Installation</a></h3><ol><li><strong><span style="background-color: #FF0000">Do Not </ol><h3><a name="Installati" id="Installati">Installation</a></h3><ol><li><strong><span style="background-color: #FF0000">Do
Uselibxml1</span></strong>, use libxml2</li> NotUselibxml1</span></strong>, use libxml2</li>
<li><em>Where can I get libxml</em>? <li><em>Where can I get libxml</em>?
<p>The original distribution comes from <a href="ftp://xmlsoft.org/libxml2/">xmlsoft.org</a>or <a href="ftp://ftp.gnome.org/pub/GNOME/sources/libxml2/2.6/">gnome.org</a></p> <p>The original distribution comes from <a href="ftp://xmlsoft.org/libxml2/">xmlsoft.org</a>or <a href="ftp://ftp.gnome.org/pub/GNOME/sources/libxml2/2.6/">gnome.org</a></p>
<p>Most Linux and BSD distributions include libxml, this is probably <p>Most Linux and BSD distributions include libxml, this is
thesafer way for end-users to use libxml.</p> probablythesafer way for end-users to use libxml.</p>
<p>David Doolin provides precompiled Windows versions at <a href="http://www.ce.berkeley.edu/~doolin/code/libxmlwin32/ ">http://www.ce.berkeley.edu/~doolin/code/libxmlwin32/</a></p> <p>David Doolin provides precompiled Windows versions at <a href="http://www.ce.berkeley.edu/~doolin/code/libxmlwin32/ ">http://www.ce.berkeley.edu/~doolin/code/libxmlwin32/</a></p>
</li> </li>
<li><em>I see libxml and libxml2 releases, which one should I install ?</em> <li><em>I see libxml and libxml2 releases, which one should I install ?</em>
<ul><li>If you are not constrained by backward compatibility issues <ul><li>If you are not constrained by backward compatibility
withexisting applications, install libxml2 only</li> issueswithexisting applications, install libxml2 only</li>
<li>If you are not doing development, you can safely install <li>If you are not doing development, you can safely
both.Usually the packages <a href="http://rpmfind.net/linux/RPM/libxml.html">libxml</a>and <a href="http://rpmfind.net/linux/RPM/libxml2.html">libxml2</a>arecompatible installboth.Usually the packages <a href="http://rpmfind.net/linux/RPM/libxml.html">libxml</a>and <a href="http://rpmfind.net/linux/RPM/libxml2.html">libxml2</a>arecompatible(this
(this is not the case for development packages).</li> is not the case for development packages).</li>
<li>If you are a developer and your system provides separate <li>If you are a developer and your system provides
packagingfor shared libraries and the development components, it is separatepackagingfor shared libraries and the development components,
possibleto install libxml and libxml2, and also <a href="http://rpmfind.net/linux/RPM/libxml-devel.html">libxml-devel</a>and it ispossibleto install libxml and libxml2, and also <a href="http://rpmfind.net/linux/RPM/libxml-devel.html">libxml-devel</a>and<a href="http://rpmfind.net/linux/RPM/libxml2-devel.html">libxml2-devel</a>toofor
<a href="http://rpmfind.net/linux/RPM/libxml2-devel.html">libxml2-devel</a>too libxml2 &gt;= 2.3.0</li>
for libxml2 &gt;= 2.3.0</li> <li>If you are developing a new application, please
<li>If you are developing a new application, please develop developagainstlibxml2(-devel)</li>
againstlibxml2(-devel)</li>
</ul></li> </ul></li>
<li><em>I can't install the libxml package, it conflicts with libxml0</em> <li><em>I can't install the libxml package, it conflicts with libxml0</em>
<p>You probably have an old libxml0 package used to provide the <p>You probably have an old libxml0 package used to provide
sharedlibrary for libxml.so.0, you can probably safely remove it. The thesharedlibrary for libxml.so.0, you can probably safely remove it.
libxmlpackages provided on <a href="ftp://xmlsoft.org/libxml2/">xmlsoft.org</a>providelibxml.so.0</p> Thelibxmlpackages provided on <a href="ftp://xmlsoft.org/libxml2/">xmlsoft.org</a>providelibxml.so.0</p>
</li> </li>
<li><em>I can't install the libxml(2) RPM package due to <li><em>I can't install the libxml(2) RPM package due
faileddependencies</em> tofaileddependencies</em>
<p>The most generic solution is to re-fetch the latest src.rpm , <p>The most generic solution is to re-fetch the latest src.rpm
andrebuild it locally with</p> ,andrebuild it locally with</p>
<p><code>rpm --rebuild libxml(2)-xxx.src.rpm</code>.</p> <p><code>rpm --rebuild libxml(2)-xxx.src.rpm</code>.</p>
<p>If everything goes well it will generate two binary rpm packages <p>If everything goes well it will generate two binary rpm
(oneproviding the shared libs and xmllint, and the other one, the packages(oneproviding the shared libs and xmllint, and the other one,
-develpackage, providing includes, static libraries and scripts needed to the-develpackage, providing includes, static libraries and scripts needed
buildapplications with libxml(2)) that you can install locally.</p> tobuildapplications with libxml(2)) that you can install locally.</p>
</li> </li>
</ol><h3><a name="Compilatio" id="Compilatio">Compilation</a></h3><ol><li><em>What is the process to compile libxml2 ?</em> </ol><h3><a name="Compilatio" id="Compilatio">Compilation</a></h3><ol><li><em>What is the process to compile libxml2 ?</em>
<p>As most UNIX libraries libxml2 follows the "standard":</p> <p>As most UNIX libraries libxml2 follows the "standard":</p>
@@ -67,107 +65,106 @@ A:link, A:visited, A:active { text-decoration: underline }
<p><code>./configure [possible options]</code></p> <p><code>./configure [possible options]</code></p>
<p><code>make</code></p> <p><code>make</code></p>
<p><code>make install</code></p> <p><code>make install</code></p>
<p>At that point you may have to rerun ldconfig or a similar utility <p>At that point you may have to rerun ldconfig or a similar
toupdate your list of installed shared libs.</p> utilitytoupdate your list of installed shared libs.</p>
</li> </li>
<li><em>What other libraries are needed to compile/install libxml2 ?</em> <li><em>What other libraries are needed to compile/install libxml2 ?</em>
<p>Libxml2 does not require any other library, the normal C ANSI <p>Libxml2 does not require any other library, the normal C ANSIAPIshould
APIshould be sufficient (please report any violation to this rule you be sufficient (please report any violation to this rule youmayfind).</p>
mayfind).</p> <p>However if found at configuration time libxml2 will detect and
<p>However if found at configuration time libxml2 will detect and use usethefollowing libs:</p>
thefollowing libs:</p> <ul><li><a href="http://www.info-zip.org/pub/infozip/zlib/">libz</a>:ahighly
<ul><li><a href="http://www.info-zip.org/pub/infozip/zlib/">libz</a>: portable and available widely compression library.</li>
ahighly portable and available widely compression library.</li> <li>iconv: a powerful character encoding conversion library.
<li>iconv: a powerful character encoding conversion library. It Itisincluded by default in recent glibc libraries, so it doesn't
isincluded by default in recent glibc libraries, so it doesn't need needtobe installed specifically on Linux. It now seems a <a href="http://www.opennc.org/onlinepubs/7908799/xsh/iconv.html">partofthe
tobe installed specifically on Linux. It now seems a <a href="http://www.opennc.org/onlinepubs/7908799/xsh/iconv.html">partof official UNIX</a>specification. Here is one <a href="http://www.gnu.org/software/libiconv/">implementation
the official UNIX</a>specification. Here is one <a href="http://www.gnu.org/software/libiconv/">implementation of ofthelibrary</a>which source can be found <a href="ftp://ftp.ilog.fr/pub/Users/haible/gnu/">here</a>.</li>
thelibrary</a>which source can be found <a href="ftp://ftp.ilog.fr/pub/Users/haible/gnu/">here</a>.</li>
</ul></li> </ul></li>
<li><em>Make check fails on some platforms</em> <li><em>Make check fails on some platforms</em>
<p>Sometimes the regression tests' results don't completely match <p>Sometimes the regression tests' results don't completely matchthevalue
thevalue produced by the parser, and the makefile uses diff to print produced by the parser, and the makefile uses diff to printthedelta. On
thedelta. On some platforms the diff return breaks the compilation some platforms the diff return breaks the compilationprocess;if the diff
process;if the diff is small this is probably not a serious problem.</p> is small this is probably not a serious problem.</p>
<p>Sometimes (especially on Solaris) make checks fail due to <p>Sometimes (especially on Solaris) make checks fail due tolimitationsin
limitationsin make. Try using GNU-make instead.</p> make. Try using GNU-make instead.</p>
</li> </li>
<li><em>I use the CVS version and there is no configure script</em> <li><em>I use the CVS version and there is no configure script</em>
<p>The configure script (and other Makefiles) are generated. Use <p>The configure script (and other Makefiles) are generated.
theautogen.sh script to regenerate the configure script and Usetheautogen.sh script to regenerate the configure script
Makefiles,like:</p> andMakefiles,like:</p>
<p><code>./autogen.sh --prefix=/usr --disable-shared</code></p> <p><code>./autogen.sh --prefix=/usr --disable-shared</code></p>
</li> </li>
<li><em>I have troubles when running make tests with gcc-3.0</em> <li><em>I have troubles when running make tests with gcc-3.0</em>
<p>It seems the initial release of gcc-3.0 has a problem with <p>It seems the initial release of gcc-3.0 has a problem withtheoptimizer
theoptimizer which miscompiles the URI module. Please use which miscompiles the URI module. Please useanothercompiler.</p>
anothercompiler.</p>
</li> </li>
</ol><h3><a name="Developer" id="Developer">Developer</a>corner</h3><ol><li><em>Troubles compiling or linking programs using libxml2</em> </ol><h3><a name="Developer" id="Developer">Developer</a>corner</h3><ol><li><em>Troubles compiling or linking programs using libxml2</em>
<p>Usually the problem comes from the fact that the compiler doesn't <p>Usually the problem comes from the fact that the compiler
getthe right compilation or linking flags. There is a small shell doesn'tgetthe right compilation or linking flags. There is a small
script<code>xml2-config</code>which is installed as part of libxml2 shellscript<code>xml2-config</code>which is installed as part of
usualinstall process which provides those flags. Use</p> libxml2usualinstall process which provides those flags. Use</p>
<p><code>xml2-config --cflags</code></p> <p><code>xml2-config --cflags</code></p>
<p>to get the compilation flags and</p> <p>to get the compilation flags and</p>
<p><code>xml2-config --libs</code></p> <p><code>xml2-config --libs</code></p>
<p>to get the linker flags. Usually this is done directly from <p>to get the linker flags. Usually this is done directly fromtheMakefile
theMakefile as:</p> as:</p>
<p><code>CFLAGS=`xml2-config --cflags`</code></p> <p><code>CFLAGS=`xml2-config --cflags`</code></p>
<p><code>LIBS=`xml2-config --libs`</code></p> <p><code>LIBS=`xml2-config --libs`</code></p>
</li> </li>
<li><em>I want to install my own copy of libxml2 in my home directory <li><em>I want to install my own copy of libxml2 in my home
andlink my programs against it, but it doesn't work</em> directoryandlink my programs against it, but it doesn't work</em>
<p>There are many different ways to accomplish this. Here is one way <p>There are many different ways to accomplish this. Here is one waytodo
todo this under Linux. Suppose your home directory is this under Linux. Suppose your home directory
<code>/home/user.</code>Then:</p> is<code>/home/user.</code>Then:</p>
<ul><li>Create a subdirectory, let's call it <code>myxml</code></li> <ul><li>Create a subdirectory, let's call it <code>myxml</code></li>
<li>unpack the libxml2 distribution into that subdirectory</li> <li>unpack the libxml2 distribution into that subdirectory</li>
<li>chdir into the unpacked distribution(<code>/home/user/myxml/libxml2 <li>chdir into the unpacked
</code>)</li> distribution(<code>/home/user/myxml/libxml2</code>)</li>
<li>configure the library using the "<code>--prefix</code>" <li>configure the library using the
switch,specifying an installation subdirectory "<code>--prefix</code>"switch,specifying an installation
in<code>/home/user/myxml</code>, e.g. subdirectoryin<code>/home/user/myxml</code>, e.g.
<p><code>./configure --prefix <p><code>./configure
/home/user/myxml/xmlinst</code>{otherconfiguration options}</p> --prefix/home/user/myxml/xmlinst</code>{otherconfiguration
options}</p>
</li> </li>
<li>now run <code>make</code>followed by <code>make install</code></li> <li>now run <code>make</code>followed by <code>make install</code></li>
<li>At this point, the installation subdirectory contains the <li>At this point, the installation subdirectory contains
complete"private" include files, library files and binary program thecomplete"private" include files, library files and binary
files (e.g.xmllint), located in programfiles (e.g.xmllint), located in
<p><code>/home/user/myxml/xmlinst/lib,/home/user/myxml/xmlinst/include <p><code>/home/user/myxml/xmlinst/lib,/home/user/myxml/xmlinst/include</code>and
</code>and <code>/home/user/myxml/xmlinst/bin</code></p> <code>/home/user/myxml/xmlinst/bin</code></p>
respectively.</li> respectively.</li>
<li>In order to use this "private" library, you should first add it <li>In order to use this "private" library, you should first add
tothe beginning of your default PATH (so that your own private ittothe beginning of your default PATH (so that your own
programfiles such as xmllint will be used instead of the normal privateprogramfiles such as xmllint will be used instead of the
systemones). To do this, the Bash command would be normalsystemones). To do this, the Bash command would be
<p><code>export PATH=/home/user/myxml/xmlinst/bin:$PATH</code></p> <p><code>export PATH=/home/user/myxml/xmlinst/bin:$PATH</code></p>
</li> </li>
<li>Now suppose you have a program <code>test1.c</code>that you <li>Now suppose you have a program <code>test1.c</code>that
wouldlike to compile with your "private" library. Simply compile it youwouldlike to compile with your "private" library. Simply compile
usingthe command itusingthe command
<p><code>gcc `xml2-config --cflags --libs` -o test test.c</code></p> <p><code>gcc `xml2-config --cflags --libs` -o test test.c</code></p>
Note that, because your PATH has been set with Note that, because your PATH has been set
<code>/home/user/myxml/xmlinst/bin</code>at the beginning, the with<code>/home/user/myxml/xmlinst/bin</code>at the beginning,
xml2-configprogram which you just installed will be used instead of thexml2-configprogram which you just installed will be used instead
the systemdefault one, and this will <em>automatically</em>get the ofthe systemdefault one, and this will <em>automatically</em>get
correctlibraries linked with your program.</li> thecorrectlibraries linked with your program.</li>
</ul></li> </ul></li>
<p></p> <p></p>
<li><em>xmlDocDump() generates output on one line.</em> <li><em>xmlDocDump() generates output on one line.</em>
<p>Libxml2 will not <strong>invent</strong>spaces in the content of <p>Libxml2 will not <strong>invent</strong>spaces in the content
adocument since <strong>all spaces in the content of a document ofadocument since <strong>all spaces in the content of a
aresignificant</strong>. If you build a tree from the API and documentaresignificant</strong>. If you build a tree from the API
wantindentation:</p> andwantindentation:</p>
<ol><li>the correct way is to generate those yourself too.</li> <ol><li>the correct way is to generate those yourself too.</li>
<li>the dangerous way is to ask libxml2 to add those blanks to <li>the dangerous way is to ask libxml2 to add those blanks
yourcontent <strong>modifying the content of your document in toyourcontent <strong>modifying the content of your document
theprocess</strong>. The result may not be what you expect. There intheprocess</strong>. The result may not be what you expect.
is<strong>NO</strong>way to guarantee that such a modification Thereis<strong>NO</strong>way to guarantee that such a
won'taffect other parts of the content of your document. See <a href="http://xmlsoft.org/html/libxml-parser.html#xmlKeepBlanksDefault">xmlKeepBlanksDefault()</a>and modificationwon'taffect other parts of the content of your document.
<a href="http://xmlsoft.org/html/libxml-tree.html#xmlSaveFormatFile">xmlSaveFormatFile()</a></li> See <a href="http://xmlsoft.org/html/libxml-parser.html#xmlKeepBlanksDefault">xmlKeepBlanksDefault()</a>and<a href="http://xmlsoft.org/html/libxml-tree.html#xmlSaveFormatFile">xmlSaveFormatFile()</a></li>
</ol></li> </ol></li>
<li>Extra nodes in the document: <li>Extra nodes in the document:
<p><em>For a XML file as below:</em></p> <p><em>For a XML file as below:</em></p>
@@ -176,10 +173,10 @@ A:link, A:visited, A:active { text-decoration: underline }
&lt;NODE CommFlag="0"/&gt; &lt;NODE CommFlag="0"/&gt;
&lt;NODE CommFlag="1"/&gt; &lt;NODE CommFlag="1"/&gt;
&lt;/PLAN&gt;</pre> &lt;/PLAN&gt;</pre>
<p><em>after parsing it with the <p><em>after parsing it with
functionpxmlDoc=xmlParseFile(...);</em></p> thefunctionpxmlDoc=xmlParseFile(...);</em></p>
<p><em>I want to the get the content of the first node (node with <p><em>I want to the get the content of the first node (node
theCommFlag="0")</em></p> withtheCommFlag="0")</em></p>
<p><em>so I did it as following;</em></p> <p><em>so I did it as following;</em></p>
<pre>xmlNodePtr pnode; <pre>xmlNodePtr pnode;
pnode=pxmlDoc-&gt;children-&gt;children;</pre> pnode=pxmlDoc-&gt;children-&gt;children;</pre>
@@ -187,64 +184,62 @@ pnode=pxmlDoc-&gt;children-&gt;children;</pre>
<pre>pnode=pxmlDoc-&gt;children-&gt;children-&gt;next;</pre> <pre>pnode=pxmlDoc-&gt;children-&gt;children-&gt;next;</pre>
<p><em>then it works. Can someone explain it to me.</em></p> <p><em>then it works. Can someone explain it to me.</em></p>
<p></p> <p></p>
<p>In XML all characters in the content of the document are <p>In XML all characters in the content of the document
significant<strong>including blanks and formatting line aresignificant<strong>including blanks and formatting
breaks</strong>.</p> linebreaks</strong>.</p>
<p>The extra nodes you are wondering about are just that, text nodes <p>The extra nodes you are wondering about are just that, text
withthe formatting spaces which are part of the document but that people nodeswiththe formatting spaces which are part of the document but that
tendto forget. There is a function <a href="http://xmlsoft.org/html/libxml-parser.html">xmlKeepBlanksDefault()</a>to peopletendto forget. There is a function <a href="http://xmlsoft.org/html/libxml-parser.html">xmlKeepBlanksDefault()</a>toremove
remove those at parse time, but that's an heuristic, and itsuse should be those at parse time, but that's an heuristic, and itsuse should belimited
limited to cases where you are certain there is nomixed-content in the to cases where you are certain there is nomixed-content in
document.</p> thedocument.</p>
</li> </li>
<li><em>I get compilation errors of existing code like when <li><em>I get compilation errors of existing code like
accessing<strong>root</strong>or <strong>child fields</strong>of whenaccessing<strong>root</strong>or <strong>child
nodes.</em> fields</strong>ofnodes.</em>
<p>You are compiling code developed for libxml version 1 and using <p>You are compiling code developed for libxml version 1 and
alibxml2 development environment. Either switch back to libxml v1 devel usingalibxml2 development environment. Either switch back to libxml v1
oreven better fix the code to compile with libxml2 (or both) by <a href="upgrade.html">following the instructions</a>.</p> develoreven better fix the code to compile with libxml2 (or both) by <a href="upgrade.html">following the instructions</a>.</p>
</li> </li>
<li><em>I get compilation errors about non <li><em>I get compilation errors about
existing<strong>xmlRootNode</strong>or nonexisting<strong>xmlRootNode</strong>or<strong>xmlChildrenNode</strong>fields.</em>
<strong>xmlChildrenNode</strong>fields.</em> <p>The source code you are using has been <a href="upgrade.html">upgraded</a>to be able to compile with both
<p>The source code you are using has been <a href="upgrade.html">upgraded</a>to be able to compile with both libxmland libxmlandlibxml2, but you need to install a more recent
libxml2, but you need to install a more recent version:libxml(-devel) version:libxml(-devel)&gt;= 1.8.8 or libxml2(-devel) &gt;= 2.1.0</p>
&gt;= 1.8.8 or libxml2(-devel) &gt;= 2.1.0</p>
</li> </li>
<li><em>XPath implementation looks seriously broken</em> <li><em>XPath implementation looks seriously broken</em>
<p>XPath implementation prior to 2.3.0 was really incomplete. Upgrade toa <p>XPath implementation prior to 2.3.0 was really incomplete. Upgrade
recent version, there are no known bugs in the current version.</p> toarecent version, there are no known bugs in the current version.</p>
</li> </li>
<li><em>The example provided in the web page does not compile.</em> <li><em>The example provided in the web page does not compile.</em>
<p>It's hard to maintain the documentation in sync with the <p>It's hard to maintain the documentation in sync with
code&lt;grin/&gt; ...</p> thecode&lt;grin/&gt; ...</p>
<p>Check the previous points 1/ and 2/ raised before, and please <p>Check the previous points 1/ and 2/ raised before, and
sendpatches.</p> pleasesendpatches.</p>
</li> </li>
<li><em>Where can I get more examples and information than provided on <li><em>Where can I get more examples and information than provided
theweb page?</em> ontheweb page?</em>
<p>Ideally a libxml2 book would be nice. I have no such plan ... But <p>Ideally a libxml2 book would be nice. I have no such plan ...
youcan:</p> Butyoucan:</p>
<ul><li>check more deeply the <a href="html/libxml-lib.html">existinggenerated doc</a></li> <ul><li>check more deeply the <a href="html/libxml-lib.html">existinggenerated doc</a></li>
<li>have a look at <a href="examples/index.html">the set <li>have a look at <a href="examples/index.html">the
ofexamples</a>.</li> setofexamples</a>.</li>
<li>look for examples of use for libxml2 function using the Gnome <li>look for examples of use for libxml2 function using the
code.For example the following will query the full Gnome CVS base for Gnomecode.For example the following will query the full Gnome CVS
theuse of the <strong>xmlAddChild()</strong>function: base fortheuse of the <strong>xmlAddChild()</strong>function:
<p><a href="http://cvs.gnome.org/lxr/search?string=xmlAddChild">http://cvs.gnome.org/lxr/search?string=xmlAddChild</a></p> <p><a href="http://cvs.gnome.org/lxr/search?string=xmlAddChild">http://cvs.gnome.org/lxr/search?string=xmlAddChild</a></p>
<p>This may be slow, a large hardware donation to the gnome <p>This may be slow, a large hardware donation to the
projectcould cure this :-)</p> gnomeprojectcould cure this :-)</p>
</li> </li>
<li><a href="http://cvs.gnome.org/bonsai/rview.cgi?cvsroot=/cvs/gnome&amp;dir=gnome-xml">Browsethe <li><a href="http://cvs.gnome.org/bonsai/rview.cgi?cvsroot=/cvs/gnome&amp;dir=gnome-xml">Browsethelibxml2
libxml2 source</a>, I try to write code as clean and documentedas source</a>, I try to write code as clean and documentedaspossible, so
possible, so looking at it may be helpful. In particular the codeof looking at it may be helpful. In particular the codeofxmllint.c and
xmllint.c and of the various testXXX.c test programs shouldprovide of the various testXXX.c test programs shouldprovidegood examples of
good examples of how to do things with the library.</li> how to do things with the library.</li>
</ul></li> </ul></li>
<li>What about C++ ? <li>What about C++ ?
<p>libxml2 is written in pure C in order to allow easy reuse on a <p>libxml2 is written in pure C in order to allow easy reuse on anumberof
numberof platforms, including embedded systems. I don't intend to convert platforms, including embedded systems. I don't intend to converttoC++.</p>
toC++.</p>
<p>There is however a C++ wrapper which may fulfill your needs:</p> <p>There is however a C++ wrapper which may fulfill your needs:</p>
<ul><li>by Ari Johnson &lt;ari@btigate.com&gt;: <ul><li>by Ari Johnson &lt;ari@btigate.com&gt;:
<p>Website: <a href="http://libxmlplusplus.sourceforge.net/">http://libxmlplusplus.sourceforge.net/</a></p> <p>Website: <a href="http://libxmlplusplus.sourceforge.net/">http://libxmlplusplus.sourceforge.net/</a></p>
@@ -258,10 +253,10 @@ pnode=pxmlDoc-&gt;children-&gt;children;</pre>
--> -->
</ul></li> </ul></li>
<li>How to validate a document a posteriori ? <li>How to validate a document a posteriori ?
<p>It is possible to validate documents which had not been validated <p>It is possible to validate documents which had not been
atinitial parsing time or documents which have been built from validatedatinitial parsing time or documents which have been built
scratchusing the API. Use the <a href="http://xmlsoft.org/html/libxml-valid.html#xmlValidateDtd">xmlValidateDtd()</a>function. fromscratchusing the API. Use the <a href="http://xmlsoft.org/html/libxml-valid.html#xmlValidateDtd">xmlValidateDtd()</a>function.It
It is also possible to simply add a DTD to an existingdocument:</p> is also possible to simply add a DTD to an existingdocument:</p>
<pre>xmlDocPtr doc; /* your existing document */ <pre>xmlDocPtr doc; /* your existing document */
xmlDtdPtr dtd = xmlParseDTD(NULL, filename_of_dtd); /* parse the DTD */ xmlDtdPtr dtd = xmlParseDTD(NULL, filename_of_dtd); /* parse the DTD */
@@ -273,10 +268,10 @@ xmlDtdPtr dtd = xmlParseDTD(NULL, filename_of_dtd); /* parse the DTD */
</pre> </pre>
</li> </li>
<li>So what is this funky "xmlChar" used all the time? <li>So what is this funky "xmlChar" used all the time?
<p>It is a null terminated sequence of utf-8 characters. And only <p>It is a null terminated sequence of utf-8 characters. And
utf-8!You need to convert strings encoded in different ways to utf-8 onlyutf-8!You need to convert strings encoded in different ways to
beforepassing them to the API. This can be accomplished with the iconv utf-8beforepassing them to the API. This can be accomplished with the
libraryfor instance.</p> iconvlibraryfor instance.</p>
</li> </li>
<li>etc ...</li> <li>etc ...</li>
</ol><p></p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html> </ol><p></p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html>

View File

@@ -7,8 +7,9 @@ H1 {font-family: Verdana,Arial,Helvetica}
H2 {font-family: Verdana,Arial,Helvetica} H2 {font-family: Verdana,Arial,Helvetica}
H3 {font-family: Verdana,Arial,Helvetica} H3 {font-family: Verdana,Arial,Helvetica}
A:link, A:visited, A:active { text-decoration: underline } A:link, A:visited, A:active { text-decoration: underline }
</style><title>XML</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>XML</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p><a href="http://www.w3.org/TR/REC-xml">XML is a </style><title>XML</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>XML</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p><a href="http://www.w3.org/TR/REC-xml">XML is astandard</a>formarkup-based
standard</a>formarkup-based structured documents. Here is <a name="example" id="example">an example XMLdocument</a>:</p><pre>&lt;?xml version="1.0"?&gt; structured documents. Here is <a name="example" id="example">an example
XMLdocument</a>:</p><pre>&lt;?xml version="1.0"?&gt;
&lt;EXAMPLE prop1="gnome is great" prop2="&amp;amp; linux too"&gt; &lt;EXAMPLE prop1="gnome is great" prop2="&amp;amp; linux too"&gt;
&lt;head&gt; &lt;head&gt;
&lt;title&gt;Welcome to Gnome&lt;/title&gt; &lt;title&gt;Welcome to Gnome&lt;/title&gt;
@@ -19,16 +20,17 @@ standard</a>formarkup-based structured documents. Here is <a name="example" id="
&lt;image href="linus.gif"/&gt; &lt;image href="linus.gif"/&gt;
&lt;p&gt;...&lt;/p&gt; &lt;p&gt;...&lt;/p&gt;
&lt;/chapter&gt; &lt;/chapter&gt;
&lt;/EXAMPLE&gt;</pre><p>The first line specifies that it is an XML document and gives &lt;/EXAMPLE&gt;</pre><p>The first line specifies that it is an XML document and
usefulinformation about its encoding. Then the rest of the document is a givesusefulinformation about its encoding. Then the rest of the document is
textformat whose structure is specified by tags between brackets. atextformat whose structure is specified by tags between
<strong>Eachtag opened has to be closed</strong>. XML is pedantic about this. brackets.<strong>Eachtag opened has to be closed</strong>. XML is pedantic
However, ifa tag is empty (no content), a single tag can serve as both the about this.However, ifa tag is empty (no content), a single tag can serve as
opening andclosing tag if it ends with <code>/&gt;</code>rather than both theopening andclosing tag if it ends with <code>/&gt;</code>rather
with<code>&gt;</code>. Note that, for example, the image tag has no content thanwith<code>&gt;</code>. Note that, for example, the image tag has no
(justan attribute) and is closed by ending the tag with content(justan attribute) and is closed by ending the tag
<code>/&gt;</code>.</p><p>XML can be applied successfully to a wide range of tasks, ranging fromlong with<code>/&gt;</code>.</p><p>XML can be applied successfully to a wide range of tasks, ranging
term structured document maintenance (where it follows the steps ofSGML) to fromlongterm structured document maintenance (where it follows the steps
simple data encoding mechanisms like configuration file formatting(glade), ofSGML) tosimple data encoding mechanisms like configuration file
spreadsheets (gnumeric), or even shorter lived documents such asWebDAV where formatting(glade),spreadsheets (gnumeric), or even shorter lived documents
it is used to encode remote calls between a client and aserver.</p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html> such asWebDAV whereit is used to encode remote calls between a client and
aserver.</p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html>

View File

@@ -7,7 +7,8 @@ H1 {font-family: Verdana,Arial,Helvetica}
H2 {font-family: Verdana,Arial,Helvetica} H2 {font-family: Verdana,Arial,Helvetica}
H3 {font-family: Verdana,Arial,Helvetica} H3 {font-family: Verdana,Arial,Helvetica}
A:link, A:visited, A:active { text-decoration: underline } A:link, A:visited, A:active { text-decoration: underline }
</style><title>XSLT</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>XSLT</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p>Check <a href="http://xmlsoft.org/XSLT">the separate libxslt page</a></p><p><a href="http://www.w3.org/TR/xslt">XSL Transformations</a>, is alanguage </style><title>XSLT</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>XSLT</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p>Check <a href="http://xmlsoft.org/XSLT">the separate libxslt page</a></p><p><a href="http://www.w3.org/TR/xslt">XSL Transformations</a>, is
for transforming XML documents into other XML documents (orHTML/textual alanguagefor transforming XML documents into other XML documents
output).</p><p>A separate library called libxslt is available implementing XSLT-1.0 (orHTML/textualoutput).</p><p>A separate library called libxslt is available implementing
forlibxml2. This module "libxslt" too can be found in the Gnome CVS base.</p><p>You can check the progresses on the libxslt <a href="http://xmlsoft.org/XSLT/ChangeLog.html">Changelog</a>.</p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html> XSLT-1.0forlibxml2. This module "libxslt" too can be found in the Gnome CVS
base.</p><p>You can check the progresses on the libxslt <a href="http://xmlsoft.org/XSLT/ChangeLog.html">Changelog</a>.</p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html>

File diff suppressed because one or more lines are too long

View File

@@ -7,60 +7,62 @@ H1 {font-family: Verdana,Arial,Helvetica}
H2 {font-family: Verdana,Arial,Helvetica} H2 {font-family: Verdana,Arial,Helvetica}
H3 {font-family: Verdana,Arial,Helvetica} H3 {font-family: Verdana,Arial,Helvetica}
A:link, A:visited, A:active { text-decoration: underline } A:link, A:visited, A:active { text-decoration: underline }
</style><title>Reporting bugs and getting help</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>Reporting bugs and getting help</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p>Well, bugs or missing features are always possible, and I will make apoint </style><title>Reporting bugs and getting help</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>Reporting bugs and getting help</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p>Well, bugs or missing features are always possible, and I will make
of fixing them in a timely fashion. The best way to report a bug is touse the apointof fixing them in a timely fashion. The best way to report a bug is
<a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Gnomebug touse the<a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Gnomebugtracking
tracking database</a>(make sure to use the "libxml2" module name). Ilook at database</a>(make sure to use the "libxml2" module name). Ilook atreports
reports there regularly and it's good to have a reminder when a bugis still there regularly and it's good to have a reminder when a bugis stillopen. Be
open. Be sure to specify that the bug is for the package libxml2.</p><p>For small problems you can try to get help on IRC, the #xml channel sure to specify that the bug is for the package libxml2.</p><p>For small problems you can try to get help on IRC, the #xml
onirc.gnome.org (port 6667) usually have a few person subscribed which may channelonirc.gnome.org (port 6667) usually have a few person subscribed which
help(but there is no garantee and if a real issue is raised it should go on mayhelp(but there is no garantee and if a real issue is raised it should go
themailing-list for archival).</p><p>There is also a mailing-list <a href="mailto:xml@gnome.org">xml@gnome.org</a>for libxml, with an <a href="http://mail.gnome.org/archives/xml/">on-line archive</a>(<a href="http://xmlsoft.org/messages">old</a>). To subscribe to this list,please onthemailing-list for archival).</p><p>There is also a mailing-list <a href="mailto:xml@gnome.org">xml@gnome.org</a>for libxml, with an <a href="http://mail.gnome.org/archives/xml/">on-line archive</a>(<a href="http://xmlsoft.org/messages">old</a>). To subscribe to this
visit the <a href="http://mail.gnome.org/mailman/listinfo/xml">associated list,pleasevisit the <a href="http://mail.gnome.org/mailman/listinfo/xml">associatedWeb</a>page
Web</a>page andfollow the instructions. <strong>Do not send code, I won't andfollow the instructions. <strong>Do not send code, I won'tdebug
debug it</strong>(but patches are really appreciated!).</p><p>Please note that with the current amount of virus and SPAM, sending mailto it</strong>(but patches are really appreciated!).</p><p>Please note that with the current amount of virus and SPAM, sending
the list without being subscribed won't work. There is *far too manybounces* mailtothe list without being subscribed won't work. There is *far too
(in the order of a thousand a day !) I cannot approve them manuallyanymore. manybounces*(in the order of a thousand a day !) I cannot approve them
If your mail to the list bounced waiting for administrator approval,it is manuallyanymore.If your mail to the list bounced waiting for administrator
LOST ! Repost it and fix the problem triggering the error. Also pleasenote approval,it isLOST ! Repost it and fix the problem triggering the error. Also
that <span style="color: #FF0000; background-color: #FFFFFF">emails witha pleasenotethat <span style="color: #FF0000; background-color: #FFFFFF">emails
legal warning asking to not copy or redistribute freely the informationsthey withalegal warning asking to not copy or redistribute freely the
contain</span>are <strong>NOT</strong>acceptable for the mailing-list,such informationstheycontain</span>are <strong>NOT</strong>acceptable for the
mail will as much as possible be discarded automatically, and are lesslikely mailing-list,suchmail will as much as possible be discarded automatically,
to be answered if they made it to the list, <strong>DO NOT</strong>post to and are lesslikelyto be answered if they made it to the list, <strong>DO
the list from an email address where such legal requirements areautomatically NOT</strong>post tothe list from an email address where such legal
added, get private paying support if you can't shareinformations.</p><p>Check the following <strong><span style="color: #FF0000">beforeposting</span></strong>:</p><ul><li>Read the <a href="FAQ.html">FAQ</a>and <a href="search.php">use requirements areautomaticallyadded, get private paying support if you can't
thesearch engine</a>to get information related to your problem.</li> shareinformations.</p><p>Check the following <strong><span style="color: #FF0000">beforeposting</span></strong>:</p><ul><li>Read the <a href="FAQ.html">FAQ</a>and <a href="search.php">usethesearch engine</a>to get information related to
<li>Make sure you are <a href="ftp://xmlsoft.org/libxml2/">using a your problem.</li>
recentversion</a>, and that the problem still shows up in a recent <li>Make sure you are <a href="ftp://xmlsoft.org/libxml2/">using
version.</li> arecentversion</a>, and that the problem still shows up in a
<li>Check the <a href="http://mail.gnome.org/archives/xml/">listarchives</a>to see if the recentversion.</li>
problem was reported already. In this casethere is probably a fix <li>Check the <a href="http://mail.gnome.org/archives/xml/">listarchives</a>to see if
available, similarly check the <a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">registeredopen theproblem was reported already. In this casethere is probably a
bugs</a>.</li> fixavailable, similarly check the <a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">registeredopenbugs</a>.</li>
<li>Make sure you can reproduce the bug with xmllint or one of the <li>Make sure you can reproduce the bug with xmllint or one of
testprograms found in source in the distribution.</li> thetestprograms found in source in the distribution.</li>
<li>Please send the command showing the error as well as the input (as <li>Please send the command showing the error as well as the input
anattachment)</li> (asanattachment)</li>
</ul><p>Then send the bug with associated information to reproduce it to the <a href="mailto:xml@gnome.org">xml@gnome.org</a>list; if it's really </ul><p>Then send the bug with associated information to reproduce it to the <a href="mailto:xml@gnome.org">xml@gnome.org</a>list; if it's
libxmlrelated I will approve it. Please do not send mail to me directly, it reallylibxmlrelated I will approve it. Please do not send mail to me
makesthings really hard to track and in some cases I am not the best person directly, itmakesthings really hard to track and in some cases I am not the
toanswer a given question, ask on the list.</p><p>To <span style="color: #E50000">be really clear about support</span>:</p><ul><li>Support or help <span style="color: #E50000">requests MUST be sent best persontoanswer a given question, ask on the list.</p><p>To <span style="color: #E50000">be really clear about support</span>:</p><ul><li>Support or help <span style="color: #E50000">requests MUST be senttothe
tothe list or on bugzilla</span>in case of problems, so that the list or on bugzilla</span>in case of problems, so that theQuestionand
Questionand Answers can be shared publicly. Failing to do so carries the Answers can be shared publicly. Failing to do so carries
implicitmessage "I want free support but I don't want to share the theimplicitmessage "I want free support but I don't want to share
benefits withothers" and is not welcome. I will automatically Carbon-Copy thebenefits withothers" and is not welcome. I will automatically
thexml@gnome.org mailing list for any technical reply made about libxml2 Carbon-Copythexml@gnome.org mailing list for any technical reply made
orlibxslt.</li> about libxml2orlibxslt.</li>
<li>There is <span style="color: #E50000">no garantee of support</span>, <li>There is <span style="color: #E50000">no garantee of
ifyour question remains unanswered after a week, repost it, making sure support</span>,ifyour question remains unanswered after a week, repost
yougave all the detail needed and the information requested.</li> it, making sureyougave all the detail needed and the information
<li>Failing to provide information as requested or double checking firstfor requested.</li>
prior feedback also carries the implicit message "the time of thelibrary <li>Failing to provide information as requested or double checking
maintainers is less valuable than my time" and might not bewelcome.</li> firstforprior feedback also carries the implicit message "the time of
</ul><p>Of course, bugs reported with a suggested patch for fixing them thelibrarymaintainers is less valuable than my time" and might not
willprobably be processed faster than those without.</p><p>If you're looking for help, a quick look at <a href="http://mail.gnome.org/archives/xml/">the list archive</a>may bewelcome.</li>
actuallyprovide the answer. I usually send source samples when answering </ul><p>Of course, bugs reported with a suggested patch for fixing
libxml2usage questions. The <a href="http://xmlsoft.org/html/book1.html">auto-generated themwillprobably be processed faster than those without.</p><p>If you're looking for help, a quick look at <a href="http://mail.gnome.org/archives/xml/">the list
documentation</a>isnot as polished as I would like (i need to learn more archive</a>mayactuallyprovide the answer. I usually send source samples when
about DocBook), butit's a good starting point.</p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html> answeringlibxml2usage questions. The <a href="http://xmlsoft.org/html/book1.html">auto-generateddocumentation</a>isnot
as polished as I would like (i need to learn moreabout DocBook), butit's a
good starting point.</p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html>

View File

@@ -14,77 +14,78 @@ A:link, A:visited, A:active { text-decoration: underline }
<li><a href="#reference">How to tune catalog usage</a></li> <li><a href="#reference">How to tune catalog usage</a></li>
<li><a href="#validate">How to debug catalog processing</a></li> <li><a href="#validate">How to debug catalog processing</a></li>
<li><a href="#Declaring">How to create and maintain catalogs</a></li> <li><a href="#Declaring">How to create and maintain catalogs</a></li>
<li><a href="#implemento">The implementor corner quick review of <li><a href="#implemento">The implementor corner quick review
theAPI</a></li> oftheAPI</a></li>
<li><a href="#Other">Other resources</a></li> <li><a href="#Other">Other resources</a></li>
</ol><h3><a name="General2" id="General2">General overview</a></h3><p>What is a catalog? Basically it's a lookup mechanism used when an entity(a </ol><h3><a name="General2" id="General2">General overview</a></h3><p>What is a catalog? Basically it's a lookup mechanism used when an
file or a remote resource) references another entity. The catalog lookupis entity(afile or a remote resource) references another entity. The catalog
inserted between the moment the reference is recognized by the software(XML lookupisinserted between the moment the reference is recognized by the
parser, stylesheet processing, or even images referenced for inclusionin a software(XMLparser, stylesheet processing, or even images referenced for
rendering) and the time where loading that resource is actuallystarted.</p><p>It is basically used for 3 things:</p><ul><li>mapping from "logical" names, the public identifiers and a moreconcrete inclusionin arendering) and the time where loading that resource is
name usable for download (and URI). For example it can associatethe actuallystarted.</p><p>It is basically used for 3 things:</p><ul><li>mapping from "logical" names, the public identifiers and a
logical name moreconcretename usable for download (and URI). For example it can
associatethelogical name
<p>"-//OASIS//DTD DocBook XML V4.1.2//EN"</p> <p>"-//OASIS//DTD DocBook XML V4.1.2//EN"</p>
<p>of the DocBook 4.1.2 XML DTD with the actual URL where it can <p>of the DocBook 4.1.2 XML DTD with the actual URL where it
bedownloaded</p> canbedownloaded</p>
<p>http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd</p> <p>http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd</p>
</li> </li>
<li>remapping from a given URL to another one, like an HTTP <li>remapping from a given URL to another one, like an
indirectionsaying that HTTPindirectionsaying that
<p>"http://www.oasis-open.org/committes/tr.xsl"</p> <p>"http://www.oasis-open.org/committes/tr.xsl"</p>
<p>should really be looked at</p> <p>should really be looked at</p>
<p>"http://www.oasis-open.org/committes/entity/stylesheets/base/tr.xsl"</p> <p>"http://www.oasis-open.org/committes/entity/stylesheets/base/tr.xsl"</p>
</li> </li>
<li>providing a local cache mechanism allowing to load the <li>providing a local cache mechanism allowing to load
entitiesassociated to public identifiers or remote resources, this is a theentitiesassociated to public identifiers or remote resources, this is
reallyimportant feature for any significant deployment of XML or SGML areallyimportant feature for any significant deployment of XML or
since itallows to avoid the aleas and delays associated to fetching SGMLsince itallows to avoid the aleas and delays associated to
remoteresources.</li> fetchingremoteresources.</li>
</ul><h3><a name="definition" id="definition">The definitions</a></h3><p>Libxml, as of 2.4.3 implements 2 kind of catalogs:</p><ul><li>the older SGML catalogs, the official spec is SGML Open </ul><h3><a name="definition" id="definition">The definitions</a></h3><p>Libxml, as of 2.4.3 implements 2 kind of catalogs:</p><ul><li>the older SGML catalogs, the official spec is SGML
TechnicalResolution TR9401:1997, but is better understood by reading <a href="http://www.jclark.com/sp/catalog.htm">the SP Catalog OpenTechnicalResolution TR9401:1997, but is better understood by reading
page</a>fromJames Clark. This is relatively old and not the preferred <a href="http://www.jclark.com/sp/catalog.htm">the SP
mode ofoperation of libxml.</li> Catalogpage</a>fromJames Clark. This is relatively old and not the
<li><a href="http://www.oasis-open.org/committees/entity/spec.html">XMLCatalogs</a>is preferredmode ofoperation of libxml.</li>
far more flexible, more recent, uses an XML syntax andshould scale quite <li><a href="http://www.oasis-open.org/committees/entity/spec.html">XMLCatalogs</a>isfar
better. This is the default option of libxml.</li> more flexible, more recent, uses an XML syntax andshould scale
</ul><p></p><h3><a name="Simple" id="Simple">Using catalog</a></h3><p>In a normal environment libxml2 will by default check the presence of quitebetter. This is the default option of libxml.</li>
acatalog in /etc/xml/catalog, and assuming it has been correctly </ul><p></p><h3><a name="Simple" id="Simple">Using catalog</a></h3><p>In a normal environment libxml2 will by default check the presence
populated,the processing is completely transparent to the document user. To ofacatalog in /etc/xml/catalog, and assuming it has been
take aconcrete example, suppose you are authoring a DocBook document, this correctlypopulated,the processing is completely transparent to the document
onestarts with the following DOCTYPE definition:</p><pre>&lt;?xml version='1.0'?&gt; user. Totake aconcrete example, suppose you are authoring a DocBook document,
thisonestarts with the following DOCTYPE definition:</p><pre>&lt;?xml version='1.0'?&gt;
&lt;!DOCTYPE book PUBLIC "-//Norman Walsh//DTD DocBk XML V3.1.4//EN" &lt;!DOCTYPE book PUBLIC "-//Norman Walsh//DTD DocBk XML V3.1.4//EN"
"http://nwalsh.com/docbook/xml/3.1.4/db3xml.dtd"&gt;</pre><p>When validating the document with libxml, the catalog will beautomatically "http://nwalsh.com/docbook/xml/3.1.4/db3xml.dtd"&gt;</pre><p>When validating the document with libxml, the catalog will
consulted to lookup the public identifier "-//Norman Walsh//DTDDocBk XML beautomaticallyconsulted to lookup the public identifier "-//Norman
V3.1.4//EN" and the system Walsh//DTDDocBk XMLV3.1.4//EN" and the
identifier"http://nwalsh.com/docbook/xml/3.1.4/db3xml.dtd", and if these systemidentifier"http://nwalsh.com/docbook/xml/3.1.4/db3xml.dtd", and if
entities havebeen installed on your system and the catalogs actually point to theseentities havebeen installed on your system and the catalogs actually
them, libxmlwill fetch them from the local disk.</p><p style="font-size: 10pt"><strong>Note</strong>: Really don't use point tothem, libxmlwill fetch them from the local disk.</p><p style="font-size: 10pt"><strong>Note</strong>: Really don't usethisDOCTYPE
thisDOCTYPE example it's a really old version, but is fine as an example.</p><p>Libxml2 will check the catalog each time that it is requested to load example it's a really old version, but is fine as an example.</p><p>Libxml2 will check the catalog each time that it is requested to
anentity, this includes DTD, external parsed entities, stylesheets, etc ... loadanentity, this includes DTD, external parsed entities, stylesheets, etc
Ifyour system is correctly configured all the authoring phase and ...Ifyour system is correctly configured all the authoring phase
processingshould use only local files, even if your document stays portable andprocessingshould use only local files, even if your document stays
because ituses the canonical public and system ID, referencing the remote portablebecause ituses the canonical public and system ID, referencing the
document.</p><h3><a name="Some" id="Some">Some examples:</a></h3><p>Here is a couple of fragments from XML Catalogs used in libxml2 remotedocument.</p><h3><a name="Some" id="Some">Some examples:</a></h3><p>Here is a couple of fragments from XML Catalogs used in
earlyregression tests in <code>test/catalogs</code>:</p><pre>&lt;?xml version="1.0"?&gt; libxml2earlyregression tests in <code>test/catalogs</code>:</p><pre>&lt;?xml version="1.0"?&gt;
&lt;!DOCTYPE catalog PUBLIC &lt;!DOCTYPE catalog PUBLIC
"-//OASIS//DTD Entity Resolution XML Catalog V1.0//EN" "-//OASIS//DTD Entity Resolution XML Catalog V1.0//EN"
"http://www.oasis-open.org/committees/entity/release/1.0/catalog.dtd"&gt; "http://www.oasis-open.org/committees/entity/release/1.0/catalog.dtd"&gt;
&lt;catalog xmlns="urn:oasis:names:tc:entity:xmlns:xml:catalog"&gt; &lt;catalog xmlns="urn:oasis:names:tc:entity:xmlns:xml:catalog"&gt;
&lt;public publicId="-//OASIS//DTD DocBook XML V4.1.2//EN" &lt;public publicId="-//OASIS//DTD DocBook XML V4.1.2//EN"
uri="http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd"/&gt; uri="http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd"/&gt;
...</pre><p>This is the beginning of a catalog for DocBook 4.1.2, XML Catalogs ...</pre><p>This is the beginning of a catalog for DocBook 4.1.2, XML
arewritten in XML, there is a specific namespace for catalog Catalogsarewritten in XML, there is a specific namespace for
elements"urn:oasis:names:tc:entity:xmlns:xml:catalog". The first entry in catalogelements"urn:oasis:names:tc:entity:xmlns:xml:catalog". The first entry
thiscatalog is a <code>public</code>mapping it allows to associate a inthiscatalog is a <code>public</code>mapping it allows to associate
PublicIdentifier with an URI.</p><pre>... aPublicIdentifier with an URI.</p><pre>...
&lt;rewriteSystem systemIdStartString="http://www.oasis-open.org/docbook/" &lt;rewriteSystem systemIdStartString="http://www.oasis-open.org/docbook/"
rewritePrefix="file:///usr/share/xml/docbook/"/&gt; rewritePrefix="file:///usr/share/xml/docbook/"/&gt;
...</pre><p>A <code>rewriteSystem</code>is a very powerful instruction, it says ...</pre><p>A <code>rewriteSystem</code>is a very powerful instruction, it saysthatany
thatany URI starting with a given prefix should be looked at another URI starting with a given prefix should be looked at anotherURIconstructed by
URIconstructed by replacing the prefix with an new one. In effect this acts replacing the prefix with an new one. In effect this actslikea cache system
likea cache system for a full area of the Web. In practice it is extremely for a full area of the Web. In practice it is extremelyusefulwith a file
usefulwith a file prefix if you have installed a copy of those resources on prefix if you have installed a copy of those resources onyourlocal system.</p><pre>...
yourlocal system.</p><pre>...
&lt;delegatePublic publicIdStartString="-//OASIS//DTD XML Catalog //" &lt;delegatePublic publicIdStartString="-//OASIS//DTD XML Catalog //"
catalog="file:///usr/share/xml/docbook.xml"/&gt; catalog="file:///usr/share/xml/docbook.xml"/&gt;
&lt;delegatePublic publicIdStartString="-//OASIS//ENTITIES DocBook XML" &lt;delegatePublic publicIdStartString="-//OASIS//ENTITIES DocBook XML"
@@ -95,21 +96,21 @@ yourlocal system.</p><pre>...
catalog="file:///usr/share/xml/docbook.xml"/&gt; catalog="file:///usr/share/xml/docbook.xml"/&gt;
&lt;delegateURI uriStartString="http://www.oasis-open.org/docbook/" &lt;delegateURI uriStartString="http://www.oasis-open.org/docbook/"
catalog="file:///usr/share/xml/docbook.xml"/&gt; catalog="file:///usr/share/xml/docbook.xml"/&gt;
...</pre><p>Delegation is the core features which allows to build a tree of ...</pre><p>Delegation is the core features which allows to build a tree
catalogs,easier to maintain than a single catalog, based on Public ofcatalogs,easier to maintain than a single catalog, based on
Identifier, SystemIdentifier or URI prefixes it instructs the catalog PublicIdentifier, SystemIdentifier or URI prefixes it instructs the
software to look upentries in another resource. This feature allow to build catalogsoftware to look upentries in another resource. This feature allow to
hierarchies ofcatalogs, the set of entries presented should be sufficient to buildhierarchies ofcatalogs, the set of entries presented should be
redirect theresolution of all DocBook references to the specific catalog sufficient toredirect theresolution of all DocBook references to the specific
in<code>/usr/share/xml/docbook.xml</code>this one in turn could delegate catalogin<code>/usr/share/xml/docbook.xml</code>this one in turn could
allreferences for DocBook 4.2.1 to a specific catalog installed at the same delegateallreferences for DocBook 4.2.1 to a specific catalog installed at
timeas the DocBook resources on the local machine.</p><h3><a name="reference" id="reference">How to tune catalog usage:</a></h3><p>The user can change the default catalog behaviour by redirecting queriesto the sametimeas the DocBook resources on the local machine.</p><h3><a name="reference" id="reference">How to tune catalog usage:</a></h3><p>The user can change the default catalog behaviour by redirecting
its own set of catalogs, this can be done by setting queriestoits own set of catalogs, this can be done by
the<code>XML_CATALOG_FILES</code>environment variable to a list of catalogs, settingthe<code>XML_CATALOG_FILES</code>environment variable to a list of
anempty one should deactivate loading the default catalogs,anempty one should deactivate loading the
<code>/etc/xml/catalog</code>default catalog</p><h3><a name="validate" id="validate">How to debug catalog processing:</a></h3><p>Setting up the <code>XML_DEBUG_CATALOG</code>environment variable willmake default<code>/etc/xml/catalog</code>default catalog</p><h3><a name="validate" id="validate">How to debug catalog processing:</a></h3><p>Setting up the <code>XML_DEBUG_CATALOG</code>environment variable
libxml2 output debugging informations for each catalog operations, willmakelibxml2 output debugging informations for each catalog
forexample:</p><pre>orchis:~/XML -&gt; xmllint --memory --noout test/ent2 operations,forexample:</p><pre>orchis:~/XML -&gt; xmllint --memory --noout test/ent2
warning: failed to load external entity "title.xml" warning: failed to load external entity "title.xml"
orchis:~/XML -&gt; export XML_DEBUG_CATALOG= orchis:~/XML -&gt; export XML_DEBUG_CATALOG=
orchis:~/XML -&gt; xmllint --memory --noout test/ent2 orchis:~/XML -&gt; xmllint --memory --noout test/ent2
@@ -117,26 +118,26 @@ Failed to parse catalog /etc/xml/catalog
Failed to parse catalog /etc/xml/catalog Failed to parse catalog /etc/xml/catalog
warning: failed to load external entity "title.xml" warning: failed to load external entity "title.xml"
Catalogs cleanup Catalogs cleanup
orchis:~/XML -&gt; </pre><p>The test/ent2 references an entity, running the parser from memory orchis:~/XML -&gt; </pre><p>The test/ent2 references an entity, running the parser from memorymakesthe
makesthe base URI unavailable and the the "title.xml" entity cannot be base URI unavailable and the the "title.xml" entity cannot beloaded.Setting
loaded.Setting up the debug environment variable allows to detect that an up the debug environment variable allows to detect that anattempt ismade to
attempt ismade to load the <code>/etc/xml/catalog</code>but since it's not load the <code>/etc/xml/catalog</code>but since it's notpresent theresolution
present theresolution fails.</p><p>But the most advanced way to debug XML catalog processing is to use fails.</p><p>But the most advanced way to debug XML catalog processing is to
the<strong>xmlcatalog</strong>command shipped with libxml2, it allows to usethe<strong>xmlcatalog</strong>command shipped with libxml2, it allows
loadcatalogs and make resolution queries to see what is going on. This is toloadcatalogs and make resolution queries to see what is going on. This
alsoused for the regression tests:</p><pre>orchis:~/XML -&gt; ./xmlcatalog test/catalogs/docbook.xml \ isalsoused for the regression tests:</p><pre>orchis:~/XML -&gt; ./xmlcatalog test/catalogs/docbook.xml \
"-//OASIS//DTD DocBook XML V4.1.2//EN" "-//OASIS//DTD DocBook XML V4.1.2//EN"
http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd
orchis:~/XML -&gt; </pre><p>For debugging what is going on, adding one -v flags increase the orchis:~/XML -&gt; </pre><p>For debugging what is going on, adding one -v flags increase
verbositylevel to indicate the processing done (adding a second flag also theverbositylevel to indicate the processing done (adding a second flag
indicatewhat elements are recognized at parsing):</p><pre>orchis:~/XML -&gt; ./xmlcatalog -v test/catalogs/docbook.xml \ alsoindicatewhat elements are recognized at parsing):</p><pre>orchis:~/XML -&gt; ./xmlcatalog -v test/catalogs/docbook.xml \
"-//OASIS//DTD DocBook XML V4.1.2//EN" "-//OASIS//DTD DocBook XML V4.1.2//EN"
Parsing catalog test/catalogs/docbook.xml's content Parsing catalog test/catalogs/docbook.xml's content
Found public match -//OASIS//DTD DocBook XML V4.1.2//EN Found public match -//OASIS//DTD DocBook XML V4.1.2//EN
http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd
Catalogs cleanup Catalogs cleanup
orchis:~/XML -&gt; </pre><p>A shell interface is also available to debug and process multiple orchis:~/XML -&gt; </pre><p>A shell interface is also available to debug and process
queries(and for regression tests):</p><pre>orchis:~/XML -&gt; ./xmlcatalog -shell test/catalogs/docbook.xml \ multiplequeries(and for regression tests):</p><pre>orchis:~/XML -&gt; ./xmlcatalog -shell test/catalogs/docbook.xml \
"-//OASIS//DTD DocBook XML V4.1.2//EN" "-//OASIS//DTD DocBook XML V4.1.2//EN"
&gt; help &gt; help
Commands available: Commands available:
@@ -152,18 +153,18 @@ exit: quit the shell
&gt; public "-//OASIS//DTD DocBook XML V4.1.2//EN" &gt; public "-//OASIS//DTD DocBook XML V4.1.2//EN"
http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd
&gt; quit &gt; quit
orchis:~/XML -&gt; </pre><p>This should be sufficient for most debugging purpose, this was orchis:~/XML -&gt; </pre><p>This should be sufficient for most debugging purpose, this wasactuallyused
actuallyused heavily to debug the XML Catalog implementation itself.</p><h3><a name="Declaring" id="Declaring">How to create and maintain</a>catalogs:</h3><p>Basically XML Catalogs are XML files, you can either use XML tools heavily to debug the XML Catalog implementation itself.</p><h3><a name="Declaring" id="Declaring">How to create and maintain</a>catalogs:</h3><p>Basically XML Catalogs are XML files, you can either use XML toolstomanage
tomanage them or use <strong>xmlcatalog</strong>for this. The basic step them or use <strong>xmlcatalog</strong>for this. The basic stepisto create a
isto create a catalog the -create option provide this facility:</p><pre>orchis:~/XML -&gt; ./xmlcatalog --create tst.xml catalog the -create option provide this facility:</p><pre>orchis:~/XML -&gt; ./xmlcatalog --create tst.xml
&lt;?xml version="1.0"?&gt; &lt;?xml version="1.0"?&gt;
&lt;!DOCTYPE catalog PUBLIC "-//OASIS//DTD Entity Resolution XML Catalog V1.0//EN" &lt;!DOCTYPE catalog PUBLIC "-//OASIS//DTD Entity Resolution XML Catalog V1.0//EN"
"http://www.oasis-open.org/committees/entity/release/1.0/catalog.dtd"&gt; "http://www.oasis-open.org/committees/entity/release/1.0/catalog.dtd"&gt;
&lt;catalog xmlns="urn:oasis:names:tc:entity:xmlns:xml:catalog"/&gt; &lt;catalog xmlns="urn:oasis:names:tc:entity:xmlns:xml:catalog"/&gt;
orchis:~/XML -&gt; </pre><p>By default xmlcatalog does not overwrite the original catalog and save orchis:~/XML -&gt; </pre><p>By default xmlcatalog does not overwrite the original catalog and
theresult on the standard output, this can be overridden using the savetheresult on the standard output, this can be overridden using
-nooutoption. The <code>-add</code>command allows to add entries in the-nooutoption. The <code>-add</code>command allows to add entries
thecatalog:</p><pre>orchis:~/XML -&gt; ./xmlcatalog --noout --create --add "public" \ inthecatalog:</p><pre>orchis:~/XML -&gt; ./xmlcatalog --noout --create --add "public" \
"-//OASIS//DTD DocBook XML V4.1.2//EN" \ "-//OASIS//DTD DocBook XML V4.1.2//EN" \
http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd tst.xml http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd tst.xml
orchis:~/XML -&gt; cat tst.xml orchis:~/XML -&gt; cat tst.xml
@@ -174,82 +175,80 @@ orchis:~/XML -&gt; cat tst.xml
&lt;public publicId="-//OASIS//DTD DocBook XML V4.1.2//EN" &lt;public publicId="-//OASIS//DTD DocBook XML V4.1.2//EN"
uri="http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd"/&gt; uri="http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd"/&gt;
&lt;/catalog&gt; &lt;/catalog&gt;
orchis:~/XML -&gt; </pre><p>The <code>-add</code>option will always take 3 parameters even if some orchis:~/XML -&gt; </pre><p>The <code>-add</code>option will always take 3 parameters even if
ofthe XML Catalog constructs (like nextCatalog) will have only a someofthe XML Catalog constructs (like nextCatalog) will have only
singleargument, just pass a third empty string, it will be ignored.</p><p>Similarly the <code>-del</code>option remove matching entries from asingleargument, just pass a third empty string, it will be ignored.</p><p>Similarly the <code>-del</code>option remove matching entries
thecatalog:</p><pre>orchis:~/XML -&gt; ./xmlcatalog --del \ fromthecatalog:</p><pre>orchis:~/XML -&gt; ./xmlcatalog --del \
"http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd" tst.xml "http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd" tst.xml
&lt;?xml version="1.0"?&gt; &lt;?xml version="1.0"?&gt;
&lt;!DOCTYPE catalog PUBLIC "-//OASIS//DTD Entity Resolution XML Catalog V1.0//EN" &lt;!DOCTYPE catalog PUBLIC "-//OASIS//DTD Entity Resolution XML Catalog V1.0//EN"
"http://www.oasis-open.org/committees/entity/release/1.0/catalog.dtd"&gt; "http://www.oasis-open.org/committees/entity/release/1.0/catalog.dtd"&gt;
&lt;catalog xmlns="urn:oasis:names:tc:entity:xmlns:xml:catalog"/&gt; &lt;catalog xmlns="urn:oasis:names:tc:entity:xmlns:xml:catalog"/&gt;
orchis:~/XML -&gt; </pre><p>The catalog is now empty. Note that the matching of orchis:~/XML -&gt; </pre><p>The catalog is now empty. Note that the matching
<code>-del</code>isexact and would have worked in a similar fashion with the of<code>-del</code>isexact and would have worked in a similar fashion with
Public IDstring.</p><p>This is rudimentary but should be sufficient to manage a not too thePublic IDstring.</p><p>This is rudimentary but should be sufficient to manage a not
complexcatalog tree of resources.</p><h3><a name="implemento" id="implemento">The implementor corner quick review of toocomplexcatalog tree of resources.</p><h3><a name="implemento" id="implemento">The implementor corner quick review
theAPI:</a></h3><p>First, and like for every other module of libxml, there is anautomatically oftheAPI:</a></h3><p>First, and like for every other module of libxml, there is
generated <a href="html/libxml-catalog.html">API page forcatalog anautomaticallygenerated <a href="html/libxml-catalog.html">API page
support</a>.</p><p>The header for the catalog interfaces should be included as:</p><pre>#include &lt;libxml/catalog.h&gt;</pre><p>The API is voluntarily kept very simple. First it is not obvious forcatalogsupport</a>.</p><p>The header for the catalog interfaces should be included as:</p><pre>#include &lt;libxml/catalog.h&gt;</pre><p>The API is voluntarily kept very simple. First it is not
thatapplications really need access to it since it is the default behaviour obviousthatapplications really need access to it since it is the default
oflibxml2 (Note: it is possible to completely override libxml2 default behaviouroflibxml2 (Note: it is possible to completely override libxml2
catalogby using <a href="html/libxml-parser.html">xmlSetExternalEntityLoader</a>toplug an defaultcatalogby using <a href="html/libxml-parser.html">xmlSetExternalEntityLoader</a>toplug
application specific resolver).</p><p>Basically libxml2 support 2 catalog lists:</p><ul><li>the default one, global shared by all the application</li> anapplication specific resolver).</p><p>Basically libxml2 support 2 catalog lists:</p><ul><li>the default one, global shared by all the application</li>
<li>a per-document catalog, this one is built if the document uses <li>a per-document catalog, this one is built if the document
the<code>oasis-xml-catalog</code>PIs to specify its own catalog list, it usesthe<code>oasis-xml-catalog</code>PIs to specify its own catalog list,
isassociated to the parser context and destroyed when the parsing itisassociated to the parser context and destroyed when the
contextis destroyed.</li> parsingcontextis destroyed.</li>
</ul><p>the document one will be used first if it exists.</p><h4>Initialization routines:</h4><p>xmlInitializeCatalog(), xmlLoadCatalog() and xmlLoadCatalogs() should </ul><p>the document one will be used first if it exists.</p><h4>Initialization routines:</h4><p>xmlInitializeCatalog(), xmlLoadCatalog() and xmlLoadCatalogs()
beused at startup to initialize the catalog, if the catalog should shouldbeused at startup to initialize the catalog, if the catalog
beinitialized with specific values xmlLoadCatalog() or shouldbeinitialized with specific values xmlLoadCatalog()
xmlLoadCatalogs()should be called before xmlInitializeCatalog() which would orxmlLoadCatalogs()should be called before xmlInitializeCatalog() which
otherwise do adefault initialization first.</p><p>The xmlCatalogAddLocal() call is used by the parser to grow the wouldotherwise do adefault initialization first.</p><p>The xmlCatalogAddLocal() call is used by the parser to grow thedocumentown
documentown catalog list if needed.</p><h4>Preferences setup:</h4><p>The XML Catalog spec requires the possibility to select defaultpreferences catalog list if needed.</p><h4>Preferences setup:</h4><p>The XML Catalog spec requires the possibility to select
between public and system delegation,xmlCatalogSetDefaultPrefer() allows defaultpreferencesbetween public and system
this, xmlCatalogSetDefaults() andxmlCatalogGetDefaults() allow to control if delegation,xmlCatalogSetDefaultPrefer() allowsthis, xmlCatalogSetDefaults()
XML Catalogs resolution shouldbe forbidden, allowed for global catalog, for andxmlCatalogGetDefaults() allow to control ifXML Catalogs resolution
document catalog or both, thedefault is to allow both.</p><p>And of course xmlCatalogSetDebug() allows to generate debug shouldbe forbidden, allowed for global catalog, fordocument catalog or both,
messages(through the xmlGenericError() mechanism).</p><h4>Querying routines:</h4><p>xmlCatalogResolve(), xmlCatalogResolveSystem(), thedefault is to allow both.</p><p>And of course xmlCatalogSetDebug() allows to generate
xmlCatalogResolvePublic()and xmlCatalogResolveURI() are relatively explicit debugmessages(through the xmlGenericError() mechanism).</p><h4>Querying routines:</h4><p>xmlCatalogResolve(),
if you read the XMLCatalog specification they correspond to section 7 xmlCatalogResolveSystem(),xmlCatalogResolvePublic()and xmlCatalogResolveURI()
algorithms, they shouldalso work if you have loaded an SGML catalog with a are relatively explicitif you read the XMLCatalog specification they
simplified semantic.</p><p>xmlCatalogLocalResolve() and xmlCatalogLocalResolveURI() are the same correspond to section 7algorithms, they shouldalso work if you have loaded an
butoperate on the document catalog list</p><h4>Cleanup and Miscellaneous:</h4><p>xmlCatalogCleanup() free-up the global catalog, xmlCatalogFreeLocal() SGML catalog with asimplified semantic.</p><p>xmlCatalogLocalResolve() and xmlCatalogLocalResolveURI() are the
isthe per-document equivalent.</p><p>xmlCatalogAdd() and xmlCatalogRemove() are used to dynamically modify samebutoperate on the document catalog list</p><h4>Cleanup and Miscellaneous:</h4><p>xmlCatalogCleanup() free-up the global catalog, xmlCatalogFreeLocal()isthe
thefirst catalog in the global list, and xmlCatalogDump() allows to dump per-document equivalent.</p><p>xmlCatalogAdd() and xmlCatalogRemove() are used to dynamically
acatalog state, those routines are primarily designed for xmlcatalog, I'm modifythefirst catalog in the global list, and xmlCatalogDump() allows to
notsure that exposing more complex interfaces (like navigation ones) would dumpacatalog state, those routines are primarily designed for xmlcatalog,
bereally useful.</p><p>The xmlParseCatalogFile() is a function used to load XML Catalog I'mnotsure that exposing more complex interfaces (like navigation ones)
files,it's similar as xmlParseFile() except it bypass all catalog lookups, wouldbereally useful.</p><p>The xmlParseCatalogFile() is a function used to load XML Catalogfiles,it's
it'sprovided because this functionality may be useful for client tools.</p><h4>threaded environments:</h4><p>Since the catalog tree is built progressively, some care has been taken similar as xmlParseFile() except it bypass all catalog lookups,it'sprovided
totry to avoid troubles in multithreaded environments. The code is now because this functionality may be useful for client tools.</p><h4>threaded environments:</h4><p>Since the catalog tree is built progressively, some care has been
threadsafe assuming that the libxml2 library has been compiled with takentotry to avoid troubles in multithreaded environments. The code is
threadssupport.</p><p></p><h3><a name="Other" id="Other">Other resources</a></h3><p>The XML Catalog specification is relatively recent so there isn't nowthreadsafe assuming that the libxml2 library has been compiled
muchliterature to point at:</p><ul><li>You can find a good rant from Norm Walsh about <a href="http://www.arbortext.com/Think_Tank/XML_Resources/Issue_Three/issue_three.html">theneed withthreadssupport.</p><p></p><h3><a name="Other" id="Other">Other resources</a></h3><p>The XML Catalog specification is relatively recent so there
for catalogs</a>, it provides a lot of context informations even ifI isn'tmuchliterature to point at:</p><ul><li>You can find a good rant from Norm Walsh about <a href="http://www.arbortext.com/Think_Tank/XML_Resources/Issue_Three/issue_three.html">theneedfor
don't agree with everything presented. Norm also wrote a more catalogs</a>, it provides a lot of context informations even ifIdon't
recentarticle <a href="http://wwws.sun.com/software/xml/developers/resolver/article/">XMLentities agree with everything presented. Norm also wrote a morerecentarticle <a href="http://wwws.sun.com/software/xml/developers/resolver/article/">XMLentitiesand
and URI resolvers</a>describing them.</li> URI resolvers</a>describing them.</li>
<li>An <a href="http://home.ccil.org/~cowan/XML/XCatalog.html">old <li>An <a href="http://home.ccil.org/~cowan/XML/XCatalog.html">oldXMLcatalog
XMLcatalog proposal</a>from John Cowan</li> proposal</a>from John Cowan</li>
<li>The <a href="http://www.rddl.org/">Resource Directory <li>The <a href="http://www.rddl.org/">Resource
DescriptionLanguage</a>(RDDL) another catalog system but more oriented DirectoryDescriptionLanguage</a>(RDDL) another catalog system but more
towardproviding metadata for XML namespaces.</li> orientedtowardproviding metadata for XML namespaces.</li>
<li>the page from the OASIS Technical <a href="http://www.oasis-open.org/committees/entity/">Committee on <li>the page from the OASIS Technical <a href="http://www.oasis-open.org/committees/entity/">Committee
EntityResolution</a>who maintains XML Catalog, you will find pointers to onEntityResolution</a>who maintains XML Catalog, you will find pointers
thespecification update, some background and pointers to others tothespecification update, some background and pointers to
toolsproviding XML Catalog support</li> otherstoolsproviding XML Catalog support</li>
<li>There is a <a href="buildDocBookCatalog">shell script</a>to generateXML <li>There is a <a href="buildDocBookCatalog">shell script</a>to
Catalogs for DocBook 4.1.2 . If it can write to the /etc/xml/directory, generateXMLCatalogs for DocBook 4.1.2 . If it can write to the
it will set-up /etc/xml/catalog and /etc/xml/docbook based onthe /etc/xml/directory,it will set-up /etc/xml/catalog and /etc/xml/docbook
resources found on the system. Otherwise it will just create~/xmlcatalog based ontheresources found on the system. Otherwise it will just
and ~/dbkxmlcatalog and doing: create~/xmlcatalogand ~/dbkxmlcatalog and doing:
<p><code>export XML_CATALOG_FILES=$HOME/xmlcatalog</code></p> <p><code>export XML_CATALOG_FILES=$HOME/xmlcatalog</code></p>
<p>should allow to process DocBook documentations without <p>should allow to process DocBook documentations withoutrequiringnetwork
requiringnetwork accesses for the DTD or stylesheets</p> accesses for the DTD or stylesheets</p>
</li> </li>
<li>I have uploaded <a href="ftp://xmlsoft.org/libxml2/test/dbk412catalog.tar.gz">asmall <li>I have uploaded <a href="ftp://xmlsoft.org/libxml2/test/dbk412catalog.tar.gz">asmalltarball</a>containing
tarball</a>containing XML Catalogs for DocBook 4.1.2 which seemsto work XML Catalogs for DocBook 4.1.2 which seemsto workfine for me too</li>
fine for me too</li> <li>The <a href="http://www.xmlsoft.org/xmlcatalog_man.html">xmlcatalogmanualpage</a></li>
<li>The <a href="http://www.xmlsoft.org/xmlcatalog_man.html">xmlcatalogmanual
page</a></li>
</ul><p>If you have suggestions for corrections or additions, simply contactme:</p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html> </ul><p>If you have suggestions for corrections or additions, simply contactme:</p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html>

View File

@@ -7,33 +7,29 @@ H1 {font-family: Verdana,Arial,Helvetica}
H2 {font-family: Verdana,Arial,Helvetica} H2 {font-family: Verdana,Arial,Helvetica}
H3 {font-family: Verdana,Arial,Helvetica} H3 {font-family: Verdana,Arial,Helvetica}
A:link, A:visited, A:active { text-decoration: underline } A:link, A:visited, A:active { text-decoration: underline }
</style><title>Contributions</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>Contributions</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><ul><li>Bjorn Reese, William Brack and Thomas Broyer have provided a number </style><title>Contributions</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>Contributions</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><ul><li>Bjorn Reese, William Brack and Thomas Broyer have provided a
ofpatches, Gary Pennington worked on the validation API, threading numberofpatches, Gary Pennington worked on the validation API,
supportand Solaris port.</li> threadingsupportand Solaris port.</li>
<li>John Fleck helps maintaining the documentation and man pages.</li> <li>John Fleck helps maintaining the documentation and man pages.</li>
<li><a href="mailto:igor@zlatkovic.com">Igor Zlatkovic</a>is now <li><a href="mailto:igor@zlatkovic.com">Igor Zlatkovic</a>is
themaintainer of the Windows port, <a href="http://www.zlatkovic.com/projects/libxml/index.html">he nowthemaintainer of the Windows port, <a href="http://www.zlatkovic.com/projects/libxml/index.html">heprovidesbinaries</a></li>
providesbinaries</a></li>
<li><a href="mailto:Gary.Pennington@sun.com">Gary Pennington</a>provides<a href="http://garypennington.net/libxml2/">Solaris binaries</a></li> <li><a href="mailto:Gary.Pennington@sun.com">Gary Pennington</a>provides<a href="http://garypennington.net/libxml2/">Solaris binaries</a></li>
<li><a href="http://mail.gnome.org/archives/xml/2001-March/msg00014.html">MattSergeant</a>developed <li><a href="http://mail.gnome.org/archives/xml/2001-March/msg00014.html">MattSergeant</a>developed<a href="http://axkit.org/download/">XML::LibXSLT</a>, a Perl
<a href="http://axkit.org/download/">XML::LibXSLT</a>, a Perl wrapper wrapperforlibxml2/libxslt as part of the <a href="http://axkit.com/">AxKitXMLapplication server</a></li>
forlibxml2/libxslt as part of the <a href="http://axkit.com/">AxKit <li><a href="mailto:fnatter@gmx.net">Felix Natter</a>and <a href="mailto:geertk@ai.rug.nl">Geert Kloosterman</a>provide <a href="libxml-doc.el">an emacs module</a>to lookup
XMLapplication server</a></li> libxml(2)functionsdocumentation</li>
<li><a href="mailto:fnatter@gmx.net">Felix Natter</a>and <a href="mailto:geertk@ai.rug.nl">Geert Kloosterman</a>provide <a href="libxml-doc.el">an emacs module</a>to lookup libxml(2)
functionsdocumentation</li>
<li><a href="mailto:sherwin@nlm.nih.gov">Ziying Sherwin</a>provided <a href="http://xmlsoft.org/messages/0488.html">man pages</a></li> <li><a href="mailto:sherwin@nlm.nih.gov">Ziying Sherwin</a>provided <a href="http://xmlsoft.org/messages/0488.html">man pages</a></li>
<li>there is a module for <a href="http://acs-misc.sourceforge.net/nsxml.html">libxml/libxslt <li>there is a module for <a href="http://acs-misc.sourceforge.net/nsxml.html">libxml/libxsltsupportin
supportin OpenNSD/AOLServer</a></li> OpenNSD/AOLServer</a></li>
<li><a href="mailto:dkuhlman@cutter.rexx.com">Dave Kuhlman</a>provided <li><a href="mailto:dkuhlman@cutter.rexx.com">Dave
thefirst version of libxml/libxslt <a href="http://www.rexx.com/~dkuhlman">wrappers for Python</a></li> Kuhlman</a>providedthefirst version of libxml/libxslt <a href="http://www.rexx.com/~dkuhlman">wrappers for Python</a></li>
<li>Petr Kozelka provides <a href="http://sourceforge.net/projects/libxml2-pas">Pascal units to <li>Petr Kozelka provides <a href="http://sourceforge.net/projects/libxml2-pas">Pascal units
gluelibxml2</a>with Kylix and Delphi and other Pascal compilers</li> togluelibxml2</a>with Kylix and Delphi and other Pascal compilers</li>
<li><a href="mailto:aleksey@aleksey.com">Aleksey Sanin</a>implemented the<a href="http://www.w3.org/Signature/">XML Canonicalization and XMLDigital <li><a href="mailto:aleksey@aleksey.com">Aleksey Sanin</a>implemented the<a href="http://www.w3.org/Signature/">XML Canonicalization and
Signature</a><a href="http://www.aleksey.com/xmlsec/">implementations for XMLDigitalSignature</a><a href="http://www.aleksey.com/xmlsec/">implementations forlibxml2</a></li>
libxml2</a></li> <li><a href="mailto:Steve.Ball@explain.com.au">SteveBall</a>andcontributors
<li><a href="mailto:Steve.Ball@explain.com.au">Steve maintain <a href="http://tclxml.sourceforge.net/">tclbindings for libxml2
Ball</a>andcontributors maintain <a href="http://tclxml.sourceforge.net/">tclbindings for libxml2 and andlibxslt</a>, as well as <a href="http://tclxml.sf.net/tkxmllint.html">tkxmllint</a>a GUI
libxslt</a>, as well as <a href="http://tclxml.sf.net/tkxmllint.html">tkxmllint</a>a GUI forxmllint forxmllintand <a href="http://tclxml.sf.net/tkxsltproc.html">tkxsltproc</a>a GUIfor
and <a href="http://tclxml.sf.net/tkxsltproc.html">tkxsltproc</a>a GUI xsltproc.</li>
for xsltproc.</li>
</ul><p></p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html> </ul><p></p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html>

File diff suppressed because one or more lines are too long

View File

@@ -7,30 +7,28 @@ H1 {font-family: Verdana,Arial,Helvetica}
H2 {font-family: Verdana,Arial,Helvetica} H2 {font-family: Verdana,Arial,Helvetica}
H3 {font-family: Verdana,Arial,Helvetica} H3 {font-family: Verdana,Arial,Helvetica}
A:link, A:visited, A:active { text-decoration: underline } A:link, A:visited, A:active { text-decoration: underline }
</style><title>Downloads</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>Downloads</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p>The latest versions of libxml2 can be found on the <a href="ftp://xmlsoft.org/libxml2/">xmlsoft.org</a>server ( <a href="http://xmlsoft.org/sources/">HTTP</a>, <a href="ftp://xmlsoft.org/libxml2/">FTP</a>and rsync are available), there is </style><title>Downloads</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>Downloads</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p>The latest versions of libxml2 can be found on the <a href="ftp://xmlsoft.org/libxml2/">xmlsoft.org</a>server ( <a href="http://xmlsoft.org/sources/">HTTP</a>, <a href="ftp://xmlsoft.org/libxml2/">FTP</a>and rsync are available), there
alsomirrors (<a href="ftp://ftp.planetmirror.com/pub/xmlsoft/">Australia</a>( isalsomirrors (<a href="ftp://ftp.planetmirror.com/pub/xmlsoft/">Australia</a>(<a href="http://xmlsoft.planetmirror.com/">Web</a>), <a href="ftp://fr.rpmfind.net/pub/libxml/">France</a>) or on the <a href="ftp://ftp.gnome.org/pub/GNOME/MIRRORS.html">Gnome FTP server</a>as <a href="ftp://ftp.gnome.org/pub/GNOME/sources/libxml2/2.6/">source
<a href="http://xmlsoft.planetmirror.com/">Web</a>), <a href="ftp://fr.rpmfind.net/pub/libxml/">France</a>) or on the <a href="ftp://ftp.gnome.org/pub/GNOME/MIRRORS.html">Gnome FTP server</a>as <a href="ftp://ftp.gnome.org/pub/GNOME/sources/libxml2/2.6/">source archive</a>, archive</a>,Antonin Sprinzl also provide <a href="ftp://gd.tuwien.ac.at/pub/libxml/">amirror in Austria</a>. (NOTE
Antonin Sprinzl also provide <a href="ftp://gd.tuwien.ac.at/pub/libxml/">amirror in Austria</a>. (NOTE that thatyou need both the <a href="http://rpmfind.net/linux/RPM/libxml2.html">libxml(2)</a>and <a href="http://rpmfind.net/linux/RPM/libxml2-devel.html">libxml(2)-devel</a>packagesinstalled
you need both the <a href="http://rpmfind.net/linux/RPM/libxml2.html">libxml(2)</a>and <a href="http://rpmfind.net/linux/RPM/libxml2-devel.html">libxml(2)-devel</a>packages to compile applications using libxml.)</p><p>You can find all the history of libxml(2) and libxslt releases in the <a href="http://xmlsoft.org/sources/old/">old</a>directory.
installed to compile applications using libxml.)</p><p>You can find all the history of libxml(2) and libxslt releases in the <a href="http://xmlsoft.org/sources/old/">old</a>directory. The TheprecompiledWindows binaries made by Igor Zlatovic are available in the <a href="http://xmlsoft.org/sources/win32/">win32</a>directory.</p><p>Binary ports:</p><ul><li>Red Hat RPMs for i386 are available directly on <a href="ftp://xmlsoft.org/libxml2/">xmlsoft.org</a>, the source RPM
precompiledWindows binaries made by Igor Zlatovic are available in the <a href="http://xmlsoft.org/sources/win32/">win32</a>directory.</p><p>Binary ports:</p><ul><li>Red Hat RPMs for i386 are available directly on <a href="ftp://xmlsoft.org/libxml2/">xmlsoft.org</a>, the source RPM will willcompile onany architecture supported by Red Hat.</li>
compile onany architecture supported by Red Hat.</li> <li><a href="mailto:igor@zlatkovic.com">Igor Zlatkovic</a>is
<li><a href="mailto:igor@zlatkovic.com">Igor Zlatkovic</a>is now nowthemaintainer of the Windows port, <a href="http://www.zlatkovic.com/projects/libxml/index.html">heprovidesbinaries</a>.</li>
themaintainer of the Windows port, <a href="http://www.zlatkovic.com/projects/libxml/index.html">he
providesbinaries</a>.</li>
<li>Blastwave provides <a href="http://www.blastwave.org/packages.php/libxml2">Solarisbinaries</a>.</li> <li>Blastwave provides <a href="http://www.blastwave.org/packages.php/libxml2">Solarisbinaries</a>.</li>
<li><a href="mailto:Steve.Ball@explain.com.au">Steve Ball</a>provides <a href="http://www.explain.com.au/oss/libxml2xslt.html">Mac Os <li><a href="mailto:Steve.Ball@explain.com.au">Steve Ball</a>provides <a href="http://www.explain.com.au/oss/libxml2xslt.html">Mac
Xbinaries</a>.</li> OsXbinaries</a>.</li>
<li>The HP-UX porting center provides <a href="http://hpux.connect.org.uk/hppd/hpux/Gnome/">HP-UX binaries</a></li> <li>The HP-UX porting center provides <a href="http://hpux.connect.org.uk/hppd/hpux/Gnome/">HP-UX binaries</a></li>
<li>Bull provides precompiled <a href="http://gnome.bullfreeware.com/new_index.html">RPMs for <li>Bull provides precompiled <a href="http://gnome.bullfreeware.com/new_index.html">RPMs forAIX</a>aspatr
AIX</a>aspatr of their GNOME packages</li> of their GNOME packages</li>
</ul><p>If you know other supported binary ports, please <a href="http://veillard.com/">contact me</a>.</p><p><a name="Snapshot" id="Snapshot">Snapshot:</a></p><ul><li>Code from the W3C cvs base libxml2 module, updated hourly <a href="ftp://xmlsoft.org/libxml2/libxml2-cvs-snapshot.tar.gz">libxml2-cvs-snapshot.tar.gz</a>.</li> </ul><p>If you know other supported binary ports, please <a href="http://veillard.com/">contact me</a>.</p><p><a name="Snapshot" id="Snapshot">Snapshot:</a></p><ul><li>Code from the W3C cvs base libxml2 module, updated hourly <a href="ftp://xmlsoft.org/libxml2/libxml2-cvs-snapshot.tar.gz">libxml2-cvs-snapshot.tar.gz</a>.</li>
<li>Docs, content of the web site, the list archive included <a href="ftp://xmlsoft.org/libxml2/libxml-docs.tar.gz">libxml-docs.tar.gz</a>.</li> <li>Docs, content of the web site, the list archive included <a href="ftp://xmlsoft.org/libxml2/libxml-docs.tar.gz">libxml-docs.tar.gz</a>.</li>
</ul><p><a name="Contribs" id="Contribs">Contributions:</a></p><p>I do accept external contributions, especially if compiling on </ul><p><a name="Contribs" id="Contribs">Contributions:</a></p><p>I do accept external contributions, especially if compiling
anotherplatform, get in touch with the list to upload the package, wrappers onanotherplatform, get in touch with the list to upload the package,
forvarious languages have been provided, and can be found in the <a href="python.html">bindings section</a></p><p>Libxml2 is also available from CVS:</p><ul><li><p>The <a href="http://cvs.gnome.org/viewcvs/libxml2/">Gnome wrappersforvarious languages have been provided, and can be found in the <a href="python.html">bindings section</a></p><p>Libxml2 is also available from CVS:</p><ul><li><p>The <a href="http://cvs.gnome.org/viewcvs/libxml2/">GnomeCVSbase</a>. Check the
CVSbase</a>. Check the <a href="http://developer.gnome.org/tools/cvs.html">Gnome CVS Tools</a>page; <a href="http://developer.gnome.org/tools/cvs.html">Gnome CVS
the CVS module is <b>libxml2</b>.</p> Tools</a>page;the CVS module is <b>libxml2</b>.</p>
</li> </li>
<li>The <strong>libxslt</strong>module is also present there</li> <li>The <strong>libxslt</strong>module is also present there</li>
</ul><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html> </ul><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html>

View File

@@ -7,44 +7,44 @@ H1 {font-family: Verdana,Arial,Helvetica}
H2 {font-family: Verdana,Arial,Helvetica} H2 {font-family: Verdana,Arial,Helvetica}
H3 {font-family: Verdana,Arial,Helvetica} H3 {font-family: Verdana,Arial,Helvetica}
A:link, A:visited, A:active { text-decoration: underline } A:link, A:visited, A:active { text-decoration: underline }
</style><title>Encodings support</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>Encodings support</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p>If you are not really familiar with Internationalization (usual shortcutis </style><title>Encodings support</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>Encodings support</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p>If you are not really familiar with Internationalization (usual
I18N) , Unicode, characters and glyphs, I suggest you read a <a href="http://www.tbray.org/ongoing/When/200x/2003/04/06/Unicode">presentation</a>by shortcutisI18N) , Unicode, characters and glyphs, I suggest you read a <a href="http://www.tbray.org/ongoing/When/200x/2003/04/06/Unicode">presentation</a>byTim
Tim Bray on Unicode and why you should care about it.</p><p>If you don't understand why <b>it does not make sense to have a Bray on Unicode and why you should care about it.</p><p>If you don't understand why <b>it does not make sense to have
stringwithout knowing what encoding it uses</b>, then as Joel Spolsky said <a href="http://www.joelonsoftware.com/articles/Unicode.html">please do notwrite astringwithout knowing what encoding it uses</b>, then as Joel Spolsky said
another line of code until you finish reading that article.</a>. It isa <a href="http://www.joelonsoftware.com/articles/Unicode.html">please do
prerequisite to understand this page, and avoid a lot of problems notwriteanother line of code until you finish reading that article.</a>. It
withlibxml2, XML or text processing in general.</p><p>Table of Content:</p><ol><li><a href="encoding.html#What">What does internationalization supportmean isaprerequisite to understand this page, and avoid a lot of
?</a></li> problemswithlibxml2, XML or text processing in general.</p><p>Table of Content:</p><ol><li><a href="encoding.html#What">What does internationalization
<li><a href="encoding.html#internal">The internal encoding, how supportmean?</a></li>
andwhy</a></li> <li><a href="encoding.html#internal">The internal encoding,
howandwhy</a></li>
<li><a href="encoding.html#implemente">How is it implemented ?</a></li> <li><a href="encoding.html#implemente">How is it implemented ?</a></li>
<li><a href="encoding.html#Default">Default supported encodings</a></li> <li><a href="encoding.html#Default">Default supported encodings</a></li>
<li><a href="encoding.html#extend">How to extend the <li><a href="encoding.html#extend">How to extend theexistingsupport</a></li>
existingsupport</a></li> </ol><h3><a name="What" id="What">What does internationalization support mean ?</a></h3><p>XML was designed from the start to allow the support of any charactersetby
</ol><h3><a name="What" id="What">What does internationalization support mean ?</a></h3><p>XML was designed from the start to allow the support of any character using Unicode. Any conformant XML parser has to support the UTF-8andUTF-16
setby using Unicode. Any conformant XML parser has to support the UTF-8 default encodings which can both express the full unicode ranges.UTF8is a
andUTF-16 default encodings which can both express the full unicode ranges. variable length encoding whose greatest points are to reuse thesameencoding
UTF8is a variable length encoding whose greatest points are to reuse the for ASCII and to save space for Western encodings, but it is abitmore complex
sameencoding for ASCII and to save space for Western encodings, but it is a to handle in practice. UTF-16 use 2 bytes per character(andsometimes combines
bitmore complex to handle in practice. UTF-16 use 2 bytes per character two pairs), it makes implementation easier, but looksabit overkill for
(andsometimes combines two pairs), it makes implementation easier, but looks Western languages encoding. Moreover the XMLspecificationallows the document
abit overkill for Western languages encoding. Moreover the XML to be encoded in other encodings at thecondition thatthey are clearly labeled
specificationallows the document to be encoded in other encodings at the as such. For example the following isa wellformedXML document encoded in
condition thatthey are clearly labeled as such. For example the following is ISO-8859-1 and using accentuated lettersthat weFrench like for both markup
a wellformedXML document encoded in ISO-8859-1 and using accentuated letters and content:</p><pre>&lt;?xml version="1.0" encoding="ISO-8859-1"?&gt;
that weFrench like for both markup and content:</p><pre>&lt;?xml version="1.0" encoding="ISO-8859-1"?&gt;
&lt;tr<EFBFBD>s&gt;l<EFBFBD>&lt;/tr<74>s&gt;</pre><p>Having internationalization support in libxml2 means the following:</p><ul><li>the document is properly parsed</li> &lt;tr<EFBFBD>s&gt;l<EFBFBD>&lt;/tr<74>s&gt;</pre><p>Having internationalization support in libxml2 means the following:</p><ul><li>the document is properly parsed</li>
<li>informations about it's encoding are saved</li> <li>informations about it's encoding are saved</li>
<li>it can be modified</li> <li>it can be modified</li>
<li>it can be saved in its original encoding</li> <li>it can be saved in its original encoding</li>
<li>it can also be saved in another encoding supported by libxml2 <li>it can also be saved in another encoding supported by
(forexample straight UTF8 or even an ASCII form)</li> libxml2(forexample straight UTF8 or even an ASCII form)</li>
</ul><p>Another very important point is that the whole libxml2 API, with </ul><p>Another very important point is that the whole libxml2 API,
theexception of a few routines to read with a specific encoding or save to withtheexception of a few routines to read with a specific encoding or save
aspecific encoding, is completely agnostic about the original encoding of toaspecific encoding, is completely agnostic about the original encoding
thedocument.</p><p>It should be noted too that the HTML parser embedded in libxml2 now ofthedocument.</p><p>It should be noted too that the HTML parser embedded in libxml2 nowobeythe
obeythe same rules too, the following document will be (as of 2.2.2) handled same rules too, the following document will be (as of 2.2.2) handledinan
inan internationalized fashion by libxml2 too:</p><pre>&lt;!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" internationalized fashion by libxml2 too:</p><pre>&lt;!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"
"http://www.w3.org/TR/REC-html40/loose.dtd"&gt; "http://www.w3.org/TR/REC-html40/loose.dtd"&gt;
&lt;html lang="fr"&gt; &lt;html lang="fr"&gt;
&lt;head&gt; &lt;head&gt;
@@ -52,60 +52,60 @@ inan internationalized fashion by libxml2 too:</p><pre>&lt;!DOCTYPE HTML PUBLIC
&lt;/head&gt; &lt;/head&gt;
&lt;body&gt; &lt;body&gt;
&lt;p&gt;W3C cr<63>e des standards pour le Web.&lt;/body&gt; &lt;p&gt;W3C cr<63>e des standards pour le Web.&lt;/body&gt;
&lt;/html&gt;</pre><h3><a name="internal" id="internal">The internal encoding, how and why</a></h3><p>One of the core decisions was to force all documents to be converted to &lt;/html&gt;</pre><h3><a name="internal" id="internal">The internal encoding, how and why</a></h3><p>One of the core decisions was to force all documents to be converted
adefault internal encoding, and that encoding to be UTF-8, here are toadefault internal encoding, and that encoding to be UTF-8, here
therationales for those choices:</p><ul><li>keeping the native encoding in the internal form would force the aretherationales for those choices:</p><ul><li>keeping the native encoding in the internal form would force
libxmlusers (or the code associated) to be fully aware of the encoding of thelibxmlusers (or the code associated) to be fully aware of the encoding
theoriginal document, for examples when adding a text node to a oftheoriginal document, for examples when adding a text node to
document,the content would have to be provided in the document encoding, adocument,the content would have to be provided in the document
i.e. theclient code would have to check it before hand, make sure it's encoding,i.e. theclient code would have to check it before hand, make
conformantto the encoding, etc ... Very hard in practice, though in some sure it'sconformantto the encoding, etc ... Very hard in practice, though
specificcases this may make sense.</li> in somespecificcases this may make sense.</li>
<li>the second decision was which encoding. From the XML spec only UTF8 <li>the second decision was which encoding. From the XML spec only
andUTF16 really makes sense as being the two only encodings for which UTF8andUTF16 really makes sense as being the two only encodings for
thereis mandatory support. UCS-4 (32 bits fixed size encoding) could whichthereis mandatory support. UCS-4 (32 bits fixed size encoding)
beconsidered an intelligent choice too since it's a direct Unicode couldbeconsidered an intelligent choice too since it's a direct
mappingsupport. I selected UTF-8 on the basis of efficiency and Unicodemappingsupport. I selected UTF-8 on the basis of efficiency
compatibilitywith surrounding software: andcompatibilitywith surrounding software:
<ul><li>UTF-8 while a bit more complex to convert from/to (i.e. <ul><li>UTF-8 while a bit more complex to convert from/to (i.e.slightlymore
slightlymore costly to import and export CPU wise) is also far more costly to import and export CPU wise) is also far morecompactthan
compactthan UTF-16 (and UCS-4) for a majority of the documents I see UTF-16 (and UCS-4) for a majority of the documents I seeit usedfor
it usedfor right now (RPM RDF catalogs, advogato data, various right now (RPM RDF catalogs, advogato data, variousconfigurationfile
configurationfile formats, etc.) and the key point for today's formats, etc.) and the key point for today'scomputerarchitecture is
computerarchitecture is efficient uses of caches. If one nearly efficient uses of caches. If one nearlydouble thememory requirement
double thememory requirement to store the same amount of data, this to store the same amount of data, thiswill trashcaches (main
will trashcaches (main memory/external caches/internal caches) and my memory/external caches/internal caches) and mytake isthat this harms
take isthat this harms the system far more than the CPU requirements the system far more than the CPU requirementsneededfor the conversion
neededfor the conversion to UTF-8</li> to UTF-8</li>
<li>Most of libxml2 version 1 users were using it with straight <li>Most of libxml2 version 1 users were using it with
ASCIImost of the time, doing the conversion with an internal straightASCIImost of the time, doing the conversion with an
encodingrequiring all their code to be rewritten was a serious internalencodingrequiring all their code to be rewritten was a
show-stopperfor using UTF-16 or UCS-4.</li> seriousshow-stopperfor using UTF-16 or UCS-4.</li>
<li>UTF-8 is being used as the de-facto internal encoding standard <li>UTF-8 is being used as the de-facto internal encoding
forrelated code like the <a href="http://www.pango.org/">pango</a>upcoming Gnome text widget, and standardforrelated code like the <a href="http://www.pango.org/">pango</a>upcoming Gnome text widget,
a lot of Unix code (yet another placewhere Unix programmer base takes anda lot of Unix code (yet another placewhere Unix programmer base
a different approach from Microsoft- they are using UTF-16)</li> takesa different approach from Microsoft- they are using UTF-16)</li>
</ul></li> </ul></li>
</ul><p>What does this mean in practice for the libxml2 user:</p><ul><li>xmlChar, the libxml2 data type is a byte, those bytes must be </ul><p>What does this mean in practice for the libxml2 user:</p><ul><li>xmlChar, the libxml2 data type is a byte, those bytes must
assembledas UTF-8 valid strings. The proper way to terminate an xmlChar * beassembledas UTF-8 valid strings. The proper way to terminate an xmlChar
stringis simply to append 0 byte, as usual.</li> *stringis simply to append 0 byte, as usual.</li>
<li>One just need to make sure that when using chars outside the ASCII <li>One just need to make sure that when using chars outside the
set,the values has been properly converted to UTF-8</li> ASCIIset,the values has been properly converted to UTF-8</li>
</ul><h3><a name="implemente" id="implemente">How is it implemented ?</a></h3><p>Let's describe how all this works within libxml, basically the </ul><h3><a name="implemente" id="implemente">How is it implemented ?</a></h3><p>Let's describe how all this works within libxml, basically
I18N(internationalization) support get triggered only during I/O operation, theI18N(internationalization) support get triggered only during I/O
i.e.when reading a document or saving one. Let's look first at the operation,i.e.when reading a document or saving one. Let's look first at
readingsequence:</p><ol><li>when a document is processed, we usually don't know the encoding, thereadingsequence:</p><ol><li>when a document is processed, we usually don't know the
asimple heuristic allows to detect UTF-16 and UCS-4 from encodings encoding,asimple heuristic allows to detect UTF-16 and UCS-4 from
wherethe ASCII range (0-0x7F) maps with ASCII</li> encodingswherethe ASCII range (0-0x7F) maps with ASCII</li>
<li>the xml declaration if available is parsed, including the <li>the xml declaration if available is parsed, including
encodingdeclaration. At that point, if the autodetected encoding is theencodingdeclaration. At that point, if the autodetected encoding
differentfrom the one declared a call to xmlSwitchEncoding() is isdifferentfrom the one declared a call to xmlSwitchEncoding()
issued.</li> isissued.</li>
<li>If there is no encoding declaration, then the input has to be in <li>If there is no encoding declaration, then the input has to be
eitherUTF-8 or UTF-16, if it is not then at some point when processing ineitherUTF-8 or UTF-16, if it is not then at some point when
theinput, the converter/checker of UTF-8 form will raise an encoding processingtheinput, the converter/checker of UTF-8 form will raise an
error.You may end-up with a garbled document, or no document at all ! encodingerror.You may end-up with a garbled document, or no document at
Example: all !Example:
<pre>~/XML -&gt; ./xmllint err.xml <pre>~/XML -&gt; ./xmllint err.xml
err.xml:1: error: Input is not proper UTF-8, indicate encoding ! err.xml:1: error: Input is not proper UTF-8, indicate encoding !
&lt;tr<EFBFBD>s&gt;l<EFBFBD>&lt;/tr<74>s&gt; &lt;tr<EFBFBD>s&gt;l<EFBFBD>&lt;/tr<74>s&gt;
@@ -114,94 +114,93 @@ err.xml:1: error: Bytes: 0xE8 0x73 0x3E 0x6C
&lt;tr<EFBFBD>s&gt;l<EFBFBD>&lt;/tr<74>s&gt; &lt;tr<EFBFBD>s&gt;l<EFBFBD>&lt;/tr<74>s&gt;
^</pre> ^</pre>
</li> </li>
<li>xmlSwitchEncoding() does an encoding name lookup, canonicalize it, <li>xmlSwitchEncoding() does an encoding name lookup, canonicalize
andthen search the default registered encoding converters for that it,andthen search the default registered encoding converters for
encoding.If it's not within the default set and iconv() support has been thatencoding.If it's not within the default set and iconv() support has
compiledit, it will ask iconv for such an encoder. If this fails then the beencompiledit, it will ask iconv for such an encoder. If this fails then
parserwill report an error and stops processing: theparserwill report an error and stops processing:
<pre>~/XML -&gt; ./xmllint err2.xml <pre>~/XML -&gt; ./xmllint err2.xml
err2.xml:1: error: Unsupported encoding UnsupportedEnc err2.xml:1: error: Unsupported encoding UnsupportedEnc
&lt;?xml version="1.0" encoding="UnsupportedEnc"?&gt; &lt;?xml version="1.0" encoding="UnsupportedEnc"?&gt;
^</pre> ^</pre>
</li> </li>
<li>From that point the encoder processes progressively the input (it <li>From that point the encoder processes progressively the input
isplugged as a front-end to the I/O module) for that entity. It (itisplugged as a front-end to the I/O module) for that entity.
capturesand converts on-the-fly the document to be parsed to UTF-8. The Itcapturesand converts on-the-fly the document to be parsed to UTF-8.
parseritself just does UTF-8 checking of this input and process Theparseritself just does UTF-8 checking of this input and
ittransparently. The only difference is that the encoding information processittransparently. The only difference is that the encoding
hasbeen added to the parsing context (more precisely to the informationhasbeen added to the parsing context (more precisely to
inputcorresponding to this entity).</li> theinputcorresponding to this entity).</li>
<li>The result (when using DOM) is an internal form completely in UTF-8with <li>The result (when using DOM) is an internal form completely in
just an encoding information on the document node.</li> UTF-8withjust an encoding information on the document node.</li>
</ol><p>Ok then what happens when saving the document (assuming youcollected/built </ol><p>Ok then what happens when saving the document (assuming
an xmlDoc DOM like structure) ? It depends on the functioncalled, youcollected/builtan xmlDoc DOM like structure) ? It depends on the
xmlSaveFile() will just try to save in the original encoding, functioncalled,xmlSaveFile() will just try to save in the original
whilexmlSaveFileTo() and xmlSaveFileEnc() can optionally save to a encoding,whilexmlSaveFileTo() and xmlSaveFileEnc() can optionally save to
givenencoding:</p><ol><li>if no encoding is given, libxml2 will look for an encoding agivenencoding:</p><ol><li>if no encoding is given, libxml2 will look for an
valueassociated to the document and if it exists will try to save to encodingvalueassociated to the document and if it exists will try to save
thatencoding, tothatencoding,
<p>otherwise everything is written in the internal form, i.e. UTF-8</p> <p>otherwise everything is written in the internal form, i.e. UTF-8</p>
</li> </li>
<li>so if an encoding was specified, either at the API level or on <li>so if an encoding was specified, either at the API level or
thedocument, libxml2 will again canonicalize the encoding name, lookup onthedocument, libxml2 will again canonicalize the encoding name,
for aconverter in the registered set or through iconv. If not found lookupfor aconverter in the registered set or through iconv. If not
thefunction will return an error code</li> foundthefunction will return an error code</li>
<li>the converter is placed before the I/O buffer layer, as another kind <li>the converter is placed before the I/O buffer layer, as another
ofbuffer, then libxml2 will simply push the UTF-8 serialization to kindofbuffer, then libxml2 will simply push the UTF-8 serialization
throughthat buffer, which will then progressively be converted and pushed tothroughthat buffer, which will then progressively be converted and
ontothe I/O layer.</li> pushedontothe I/O layer.</li>
<li>It is possible that the converter code fails on some input, for <li>It is possible that the converter code fails on some input,
exampletrying to push an UTF-8 encoded Chinese character through the forexampletrying to push an UTF-8 encoded Chinese character through
UTF-8 toISO-8859-1 converter won't work. Since the encoders are theUTF-8 toISO-8859-1 converter won't work. Since the encoders
progressive theywill just report the error and the number of bytes areprogressive theywill just report the error and the number of
converted, at thatpoint libxml2 will decode the offending character, bytesconverted, at thatpoint libxml2 will decode the offending
remove it from thebuffer and replace it with the associated charRef character,remove it from thebuffer and replace it with the associated
encoding &amp;#123; andresume the conversion. This guarantees that any charRefencoding &amp;#123; andresume the conversion. This guarantees that
document will be savedwithout losses (except for markup names where this anydocument will be savedwithout losses (except for markup names where
is not legal, this isa problem in the current version, in practice avoid thisis not legal, this isa problem in the current version, in practice
using non-asciicharacters for tag or attribute names). A special "ascii" avoidusing non-asciicharacters for tag or attribute names). A special
encoding nameis used to save documents to a pure ascii form can be used "ascii"encoding nameis used to save documents to a pure ascii form can be
whenportability is really crucial</li> usedwhenportability is really crucial</li>
</ol><p>Here are a few examples based on the same test document:</p><pre>~/XML -&gt; ./xmllint isolat1 </ol><p>Here are a few examples based on the same test document:</p><pre>~/XML -&gt; ./xmllint isolat1
&lt;?xml version="1.0" encoding="ISO-8859-1"?&gt; &lt;?xml version="1.0" encoding="ISO-8859-1"?&gt;
&lt;tr<EFBFBD>s&gt;l<EFBFBD>&lt;/tr<74>s&gt; &lt;tr<EFBFBD>s&gt;l<EFBFBD>&lt;/tr<74>s&gt;
~/XML -&gt; ./xmllint --encode UTF-8 isolat1 ~/XML -&gt; ./xmllint --encode UTF-8 isolat1
&lt;?xml version="1.0" encoding="UTF-8"?&gt; &lt;?xml version="1.0" encoding="UTF-8"?&gt;
&lt;très&gt;l<EFBFBD> <20>&lt;/très&gt; &lt;très&gt;l<EFBFBD> <20>&lt;/très&gt;
~/XML -&gt; </pre><p>The same processing is applied (and reuse most of the code) for HTML ~/XML -&gt; </pre><p>The same processing is applied (and reuse most of the code) for
I18Nprocessing. Looking up and modifying the content encoding is a bit HTMLI18Nprocessing. Looking up and modifying the content encoding is a
moredifficult since it is located in a &lt;meta&gt; tag under the bitmoredifficult since it is located in a &lt;meta&gt; tag under
&lt;head&gt;,so a couple of functions htmlGetMetaEncoding() and the&lt;head&gt;,so a couple of functions htmlGetMetaEncoding()
htmlSetMetaEncoding() havebeen provided. The parser also attempts to switch andhtmlSetMetaEncoding() havebeen provided. The parser also attempts to
encoding on the fly whendetecting such a tag on input. Except for that the switchencoding on the fly whendetecting such a tag on input. Except for that
processing is the same(and again reuses the same code).</p><h3><a name="Default" id="Default">Default supported encodings</a></h3><p>libxml2 has a set of default converters for the following theprocessing is the same(and again reuses the same code).</p><h3><a name="Default" id="Default">Default supported encodings</a></h3><p>libxml2 has a set of default converters for the followingencodings(located
encodings(located in encoding.c):</p><ol><li>UTF-8 is supported by default (null handlers)</li> in encoding.c):</p><ol><li>UTF-8 is supported by default (null handlers)</li>
<li>UTF-16, both little and big endian</li> <li>UTF-16, both little and big endian</li>
<li>ISO-Latin-1 (ISO-8859-1) covering most western languages</li> <li>ISO-Latin-1 (ISO-8859-1) covering most western languages</li>
<li>ASCII, useful mostly for saving</li> <li>ASCII, useful mostly for saving</li>
<li>HTML, a specific handler for the conversion of UTF-8 to ASCII with <li>HTML, a specific handler for the conversion of UTF-8 to ASCII
HTMLpredefined entities like &amp;copy; for the Copyright sign.</li> withHTMLpredefined entities like &amp;copy; for the Copyright sign.</li>
</ol><p>More over when compiled on an Unix platform with iconv support the fullset </ol><p>More over when compiled on an Unix platform with iconv support the
of encodings supported by iconv can be instantly be used by libxml. On alinux fullsetof encodings supported by iconv can be instantly be used by libxml. On
machine with glibc-2.1 the list of supported encodings and aliases fill3 full alinuxmachine with glibc-2.1 the list of supported encodings and aliases
pages, and include UCS-4, the full set of ISO-Latin encodings, and thevarious fill3 fullpages, and include UCS-4, the full set of ISO-Latin encodings, and
Japanese ones.</p><p>To convert from the UTF-8 values returned from the API to another thevariousJapanese ones.</p><p>To convert from the UTF-8 values returned from the API to
encodingthen it is possible to use the function provided from <a href="html/libxml-encoding.html">the encoding module</a>like <a href="html/libxml-encoding.html#UTF8Toisolat1">UTF8Toisolat1</a>, or use anotherencodingthen it is possible to use the function provided from <a href="html/libxml-encoding.html">the encoding module</a>like <a href="html/libxml-encoding.html#UTF8Toisolat1">UTF8Toisolat1</a>, or
thePOSIX <a href="http://www.opengroup.org/onlinepubs/009695399/functions/iconv.html">iconv()</a>API usethePOSIX <a href="http://www.opengroup.org/onlinepubs/009695399/functions/iconv.html">iconv()</a>APIdirectly.</p><h4>Encoding aliases</h4><p>From 2.2.3, libxml2 has support to register encoding names aliases.Thegoal
directly.</p><h4>Encoding aliases</h4><p>From 2.2.3, libxml2 has support to register encoding names aliases. is to be able to parse document whose encoding is supported butwherethe name
Thegoal is to be able to parse document whose encoding is supported but differs (for example from the default set of names acceptedbyiconv). The
wherethe name differs (for example from the default set of names accepted following functions allow to register and handle new aliasesforexisting
byiconv). The following functions allow to register and handle new aliases encodings. Once registered libxml2 will automatically lookupthealiases when
forexisting encodings. Once registered libxml2 will automatically lookup handling a document:</p><ul><li>int xmlAddEncodingAlias(const char *name, const char *alias);</li>
thealiases when handling a document:</p><ul><li>int xmlAddEncodingAlias(const char *name, const char *alias);</li>
<li>int xmlDelEncodingAlias(const char *alias);</li> <li>int xmlDelEncodingAlias(const char *alias);</li>
<li>const char * xmlGetEncodingAlias(const char *alias);</li> <li>const char * xmlGetEncodingAlias(const char *alias);</li>
<li>void xmlCleanupEncodingAliases(void);</li> <li>void xmlCleanupEncodingAliases(void);</li>
</ul><h3><a name="extend" id="extend">How to extend the existing support</a></h3><p>Well adding support for new encoding, or overriding one of the </ul><h3><a name="extend" id="extend">How to extend the existing support</a></h3><p>Well adding support for new encoding, or overriding one of
encoders(assuming it is buggy) should not be hard, just write input and theencoders(assuming it is buggy) should not be hard, just write input
outputconversion routines to/from UTF-8, and register them andoutputconversion routines to/from UTF-8, and register
usingxmlNewCharEncodingHandler(name, xxxToUTF8, UTF8Toxxx), and they will themusingxmlNewCharEncodingHandler(name, xxxToUTF8, UTF8Toxxx), and they
becalled automatically if the parser(s) encounter such an encoding willbecalled automatically if the parser(s) encounter such an
name(register it uppercase, this will help). The description of the encodingname(register it uppercase, this will help). The description of
encoders,their arguments and expected return values are described in the theencoders,their arguments and expected return values are described in
encoding.hheader.</p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html> theencoding.hheader.</p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html>

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@@ -7,18 +7,17 @@ H1 {font-family: Verdana,Arial,Helvetica}
H2 {font-family: Verdana,Arial,Helvetica} H2 {font-family: Verdana,Arial,Helvetica}
H3 {font-family: Verdana,Arial,Helvetica} H3 {font-family: Verdana,Arial,Helvetica}
A:link, A:visited, A:active { text-decoration: underline } A:link, A:visited, A:active { text-decoration: underline }
</style><title>How to help</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>How to help</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p>You can help the project in various ways, the best thing to do first is </style><title>How to help</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>How to help</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p>You can help the project in various ways, the best thing to do first
tosubscribe to the mailing-list as explained before, check the <a href="http://mail.gnome.org/archives/xml/">archives </a>and the <a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Gnome istosubscribe to the mailing-list as explained before, check the <a href="http://mail.gnome.org/archives/xml/">archives </a>and the <a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Gnomebugdatabase</a>:</p><ol><li>Provide patches when you find problems.</li>
bugdatabase</a>:</p><ol><li>Provide patches when you find problems.</li> <li>Provide the diffs when you port libxml2 to a new platform. They
<li>Provide the diffs when you port libxml2 to a new platform. They may maynotbe integrated in all cases but help pinpointing
notbe integrated in all cases but help pinpointing portability portabilityproblemsand</li>
problemsand</li> <li>Provide documentation fixes (either as patches to the code commentsoras
<li>Provide documentation fixes (either as patches to the code comments HTML diffs).</li>
oras HTML diffs).</li>
<li>Provide new documentations pieces (translations, examples, etc...).</li> <li>Provide new documentations pieces (translations, examples, etc...).</li>
<li>Check the TODO file and try to close one of the items.</li> <li>Check the TODO file and try to close one of the items.</li>
<li>Take one of the points raised in the archive or the bug database <li>Take one of the points raised in the archive or the bug
andprovide a fix. <a href="mailto:daniel@veillard.com">Get in touch with databaseandprovide a fix. <a href="mailto:daniel@veillard.com">Get in
me</a>before to avoid synchronization problems and check that the touch withme</a>before to avoid synchronization problems and check that
suggestedfix will fit in nicely :-)</li> thesuggestedfix will fit in nicely :-)</li>
</ol><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html> </ol><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html>

View File

@@ -216,73 +216,73 @@ A:link, A:visited, A:active { text-decoration: underline }
<tr> <tr>
<td bgcolor="#fffacd"> <td bgcolor="#fffacd">
<p></p> <p></p>
<p style="text-align: right; font-style: italic; font-size: 10pt">"Programmingwith <p style="text-align: right; font-style: italic; font-size: 10pt">"Programmingwithlibxml2
libxml2 is like the thrilling embrace of an exotic stranger." <a href="http://diveintomark.org/archives/2004/02/18/libxml2">MarkPilgrim</a></p> is like the thrilling embrace of an exotic stranger." <a href="http://diveintomark.org/archives/2004/02/18/libxml2">MarkPilgrim</a></p>
<p>Libxml2 is the XML C parser and toolkit developed for the Gnome <p>Libxml2 is the XML C parser and toolkit developed for the Gnomeproject(but
project(but usable outside of the Gnome platform), it is free software usable outside of the Gnome platform), it is free softwareavailableunder the
availableunder the <a href="http://www.opensource.org/licenses/mit-license.html">MITLicense</a>. <a href="http://www.opensource.org/licenses/mit-license.html">MITLicense</a>.XML
XML itself is a metalanguage to design markup languages, i.e.text language itself is a metalanguage to design markup languages, i.e.text languagewhere
where semantic and structure are added to the content usingextra "markup" semantic and structure are added to the content usingextra
information enclosed between angle brackets. HTML is the mostwell-known "markup"information enclosed between angle brackets. HTML is the
markup language. Though the library is written in C <a href="python.html">a mostwell-knownmarkup language. Though the library is written in C <a href="python.html">avariety of language bindings</a>make it available inother
variety of language bindings</a>make it available inother environments.</p> environments.</p>
<p>Libxml2 is known to be very portable, the library should build and <p>Libxml2 is known to be very portable, the library should build
workwithout serious troubles on a variety of systems (Linux, Unix, andworkwithout serious troubles on a variety of systems (Linux,
Windows,CygWin, MacOS, MacOS X, RISC Os, OS/2, VMS, QNX, MVS, ...)</p> Unix,Windows,CygWin, MacOS, MacOS X, RISC Os, OS/2, VMS, QNX, MVS, ...)</p>
<p>Libxml2 implements a number of existing standards related to <p>Libxml2 implements a number of existing standards related
markuplanguages:</p> tomarkuplanguages:</p>
<ul><li>the XML standard: <a href="http://www.w3.org/TR/REC-xml">http://www.w3.org/TR/REC-xml</a></li> <ul><li>the XML standard: <a href="http://www.w3.org/TR/REC-xml">http://www.w3.org/TR/REC-xml</a></li>
<li>Namespaces in XML: <a href="http://www.w3.org/TR/REC-xml-names/">http://www.w3.org/TR/REC-xml-names/</a></li> <li>Namespaces in XML: <a href="http://www.w3.org/TR/REC-xml-names/">http://www.w3.org/TR/REC-xml-names/</a></li>
<li>XML Base: <a href="http://www.w3.org/TR/xmlbase/">http://www.w3.org/TR/xmlbase/</a></li> <li>XML Base: <a href="http://www.w3.org/TR/xmlbase/">http://www.w3.org/TR/xmlbase/</a></li>
<li><a href="http://www.cis.ohio-state.edu/rfc/rfc2396.txt">RFC <li><a href="http://www.cis.ohio-state.edu/rfc/rfc2396.txt">RFC2396</a>:Uniform
2396</a>:Uniform Resource Identifiers <a href="http://www.ietf.org/rfc/rfc2396.txt">http://www.ietf.org/rfc/rfc2396.txt</a></li> Resource Identifiers <a href="http://www.ietf.org/rfc/rfc2396.txt">http://www.ietf.org/rfc/rfc2396.txt</a></li>
<li>XML Path Language (XPath) 1.0: <a href="http://www.w3.org/TR/xpath">http://www.w3.org/TR/xpath</a></li> <li>XML Path Language (XPath) 1.0: <a href="http://www.w3.org/TR/xpath">http://www.w3.org/TR/xpath</a></li>
<li>HTML4 parser: <a href="http://www.w3.org/TR/html401/">http://www.w3.org/TR/html401/</a></li> <li>HTML4 parser: <a href="http://www.w3.org/TR/html401/">http://www.w3.org/TR/html401/</a></li>
<li>XML Pointer Language (XPointer) Version 1.0: <a href="http://www.w3.org/TR/xptr">http://www.w3.org/TR/xptr</a></li> <li>XML Pointer Language (XPointer) Version 1.0: <a href="http://www.w3.org/TR/xptr">http://www.w3.org/TR/xptr</a></li>
<li>XML Inclusions (XInclude) Version 1.0: <a href="http://www.w3.org/TR/xinclude/">http://www.w3.org/TR/xinclude/</a></li> <li>XML Inclusions (XInclude) Version 1.0: <a href="http://www.w3.org/TR/xinclude/">http://www.w3.org/TR/xinclude/</a></li>
<li>ISO-8859-x encodings, as well as <a href="http://www.cis.ohio-state.edu/rfc/rfc2044.txt">rfc2044</a>[UTF-8]and <li>ISO-8859-x encodings, as well as <a href="http://www.cis.ohio-state.edu/rfc/rfc2044.txt">rfc2044</a>[UTF-8]and<a href="http://www.cis.ohio-state.edu/rfc/rfc2781.txt">rfc2781</a>[UTF-16]Unicode
<a href="http://www.cis.ohio-state.edu/rfc/rfc2781.txt">rfc2781</a>[UTF-16] encodings, and more if using iconv support</li>
Unicode encodings, and more if using iconv support</li>
<li>part of SGML Open Technical Resolution TR9401:1997</li> <li>part of SGML Open Technical Resolution TR9401:1997</li>
<li>XML Catalogs Working Draft 06 August 2001: <a href="http://www.oasis-open.org/committees/entity/spec-2001-08-06.html">http://www.oasis-open.org/committees/entity/spec-2001-08-06.html</a></li> <li>XML Catalogs Working Draft 06 August 2001: <a href="http://www.oasis-open.org/committees/entity/spec-2001-08-06.html">http://www.oasis-open.org/committees/entity/spec-2001-08-06.html</a></li>
<li>Canonical XML Version 1.0: <a href="http://www.w3.org/TR/xml-c14n">http://www.w3.org/TR/xml-c14n</a>and <li>Canonical XML Version 1.0: <a href="http://www.w3.org/TR/xml-c14n">http://www.w3.org/TR/xml-c14n</a>andthe
the Exclusive XML Canonicalization CR draft <a href="http://www.w3.org/TR/xml-exc-c14n">http://www.w3.org/TR/xml-exc-c14n</a></li> Exclusive XML Canonicalization CR draft <a href="http://www.w3.org/TR/xml-exc-c14n">http://www.w3.org/TR/xml-exc-c14n</a></li>
<li>Relax NG, ISO/IEC 19757-2:2003, <a href="http://www.oasis-open.org/committees/relax-ng/spec-20011203.html">http://www.oasis-open.org/committees/relax-ng/spec-20011203.html</a></li> <li>Relax NG, ISO/IEC 19757-2:2003, <a href="http://www.oasis-open.org/committees/relax-ng/spec-20011203.html">http://www.oasis-open.org/committees/relax-ng/spec-20011203.html</a></li>
<li>W3C XML Schemas Part 2: Datatypes <a href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/">REC 02 <li>W3C XML Schemas Part 2: Datatypes <a href="http://www.w3.org/TR/2001/REC-xmlschema-2-20010502/">REC
May2001</a></li> 02May2001</a></li>
<li>W3C <a href="http://www.w3.org/TR/xml-id/">xml:id</a>Working Draft <li>W3C <a href="http://www.w3.org/TR/xml-id/">xml:id</a>Working
7April 2004</li> Draft7April 2004</li>
</ul> </ul>
<p>In most cases libxml2 tries to implement the specifications in arelatively <p>In most cases libxml2 tries to implement the specifications in
strictly compliant way. As of release 2.4.16, libxml2 passed all1800+ tests arelativelystrictly compliant way. As of release 2.4.16, libxml2 passed
from the <a href="http://www.oasis-open.org/committees/xml-conformance/">OASIS XML all1800+ testsfrom the <a href="http://www.oasis-open.org/committees/xml-conformance/">OASIS
TestsSuite</a>.</p> XMLTestsSuite</a>.</p>
<p>To some extent libxml2 provides support for the following <p>To some extent libxml2 provides support for the
additionalspecifications but doesn't claim to implement them completely:</p> followingadditionalspecifications but doesn't claim to implement them
<ul><li>Document Object Model (DOM) <a href="http://www.w3.org/TR/DOM-Level-2-Core/">http://www.w3.org/TR/DOM-Level-2-Core/</a>the completely:</p>
document model, but it doesn't implement the API itself, gdome2 doesthis <ul><li>Document Object Model (DOM) <a href="http://www.w3.org/TR/DOM-Level-2-Core/">http://www.w3.org/TR/DOM-Level-2-Core/</a>thedocument
on top of libxml2</li> model, but it doesn't implement the API itself, gdome2 doesthison top of
<li><a href="http://www.cis.ohio-state.edu/rfc/rfc959.txt">RFC libxml2</li>
959</a>:libxml2 implements a basic FTP client code</li> <li><a href="http://www.cis.ohio-state.edu/rfc/rfc959.txt">RFC959</a>:libxml2
<li><a href="http://www.cis.ohio-state.edu/rfc/rfc1945.txt">RFC implements a basic FTP client code</li>
1945</a>:HTTP/1.0, again a basic HTTP client code</li> <li><a href="http://www.cis.ohio-state.edu/rfc/rfc1945.txt">RFC1945</a>:HTTP/1.0,
<li>SAX: a SAX2 like interface and a minimal SAX1 implementation again a basic HTTP client code</li>
compatiblewith early expat versions</li> <li>SAX: a SAX2 like interface and a minimal SAX1
implementationcompatiblewith early expat versions</li>
</ul> </ul>
<p>A partial implementation of <a href="http://www.w3.org/TR/2001/REC-xmlschema-1-20010502/">XML Schemas Part1: <p>A partial implementation of <a href="http://www.w3.org/TR/2001/REC-xmlschema-1-20010502/">XML Schemas
Structure</a>is being worked on but it would be far too early to make Part1:Structure</a>is being worked on but it would be far too early to
anyconformance statement about it at the moment.</p> makeanyconformance statement about it at the moment.</p>
<p>Separate documents:</p> <p>Separate documents:</p>
<ul><li><a href="http://xmlsoft.org/XSLT/">the libxslt page</a>providing <ul><li><a href="http://xmlsoft.org/XSLT/">the libxslt
animplementation of XSLT 1.0 and common extensions like EXSLT page</a>providinganimplementation of XSLT 1.0 and common extensions like
forlibxml2</li> EXSLTforlibxml2</li>
<li><a href="http://www.cs.unibo.it/~casarini/gdome2/">the gdome2 page</a>: <li><a href="http://www.cs.unibo.it/~casarini/gdome2/">the gdome2
a standard DOM2 implementation for libxml2</li> page</a>:a standard DOM2 implementation for libxml2</li>
<li><a href="http://www.aleksey.com/xmlsec/">the XMLSec page</a>: <li><a href="http://www.aleksey.com/xmlsec/">the XMLSec
animplementation of <a href="http://www.w3.org/TR/xmldsig-core/">W3C page</a>:animplementation of <a href="http://www.w3.org/TR/xmldsig-core/">W3CXMLDigital Signature</a>for
XMLDigital Signature</a>for libxml2</li> libxml2</li>
<li>also check the related links section below for more related and <li>also check the related links section below for more related
activeprojects.</li> andactiveprojects.</li>
</ul> </ul>
<p>Logo designed by <a href="mailto:liyanage@access.ch">Marc Liyanage</a>.</p> <p>Logo designed by <a href="mailto:liyanage@access.ch">Marc Liyanage</a>.</p>
<p> <p>

File diff suppressed because one or more lines are too long

View File

@@ -7,23 +7,23 @@ H1 {font-family: Verdana,Arial,Helvetica}
H2 {font-family: Verdana,Arial,Helvetica} H2 {font-family: Verdana,Arial,Helvetica}
H3 {font-family: Verdana,Arial,Helvetica} H3 {font-family: Verdana,Arial,Helvetica}
A:link, A:visited, A:active { text-decoration: underline } A:link, A:visited, A:active { text-decoration: underline }
</style><title>Introduction</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>Introduction</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p>This document describes libxml, the <a href="http://www.w3.org/XML/">XML</a>C parser and toolkit developed for the<a href="http://www.gnome.org/">Gnome</a>project. <a href="http://www.w3.org/XML/">XML is a standard</a>for building </style><title>Introduction</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>Introduction</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p>This document describes libxml, the <a href="http://www.w3.org/XML/">XML</a>C parser and toolkit developed for the<a href="http://www.gnome.org/">Gnome</a>project. <a href="http://www.w3.org/XML/">XML is a standard</a>for
tag-basedstructured documents/data.</p><p>Here are some key points about libxml:</p><ul><li>Libxml2 exports Push (progressive) and Pull (blocking) type buildingtag-basedstructured documents/data.</p><p>Here are some key points about libxml:</p><ul><li>Libxml2 exports Push (progressive) and Pull (blocking)
parserinterfaces for both XML and HTML.</li> typeparserinterfaces for both XML and HTML.</li>
<li>Libxml2 can do DTD validation at parse time, using a parsed <li>Libxml2 can do DTD validation at parse time, using a
documentinstance, or with an arbitrary DTD.</li> parseddocumentinstance, or with an arbitrary DTD.</li>
<li>Libxml2 includes complete <a href="http://www.w3.org/TR/xpath">XPath</a>, <a href="http://www.w3.org/TR/xptr">XPointer</a>and <a href="http://www.w3.org/TR/xinclude">XInclude</a>implementations.</li> <li>Libxml2 includes complete <a href="http://www.w3.org/TR/xpath">XPath</a>, <a href="http://www.w3.org/TR/xptr">XPointer</a>and <a href="http://www.w3.org/TR/xinclude">XInclude</a>implementations.</li>
<li>It is written in plain C, making as few assumptions as possible, <li>It is written in plain C, making as few assumptions as
andsticking closely to ANSI C/POSIX for easy embedding. Works possible,andsticking closely to ANSI C/POSIX for easy embedding.
onLinux/Unix/Windows, ported to a number of other platforms.</li> WorksonLinux/Unix/Windows, ported to a number of other platforms.</li>
<li>Basic support for HTTP and FTP client allowing applications to <li>Basic support for HTTP and FTP client allowing applications
fetchremote resources.</li> tofetchremote resources.</li>
<li>The design is modular, most of the extensions can be compiled out.</li> <li>The design is modular, most of the extensions can be compiled out.</li>
<li>The internal document representation is as close as possible to the <a href="http://www.w3.org/DOM/">DOM</a>interfaces.</li> <li>The internal document representation is as close as possible to the <a href="http://www.w3.org/DOM/">DOM</a>interfaces.</li>
<li>Libxml2 also has a <a href="http://www.megginson.com/SAX/index.html">SAX like interface</a>;the <li>Libxml2 also has a <a href="http://www.megginson.com/SAX/index.html">SAX like
interface is designed to be compatible with <a href="http://www.jclark.com/xml/expat.html">Expat</a>.</li> interface</a>;theinterface is designed to be compatible with <a href="http://www.jclark.com/xml/expat.html">Expat</a>.</li>
<li>This library is released under the <a href="http://www.opensource.org/licenses/mit-license.html">MITLicense</a>. <li>This library is released under the <a href="http://www.opensource.org/licenses/mit-license.html">MITLicense</a>.See
See the Copyright file in the distribution for the precisewording.</li> the Copyright file in the distribution for the precisewording.</li>
</ul><p>Warning: unless you are forced to because your application links with </ul><p>Warning: unless you are forced to because your application links
aGnome-1.X library requiring it, <strong><span style="background-color: #FF0000">Do Not Use libxml1</span></strong>, withaGnome-1.X library requiring it, <strong><span style="background-color: #FF0000">Do Not Use
uselibxml2</p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html> libxml1</span></strong>,uselibxml2</p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html>

File diff suppressed because one or more lines are too long

View File

@@ -8,33 +8,9 @@
</vendor> </vendor>
<product id="libxml2"> <product id="libxml2">
<name>libxml2</name> <name>libxml2</name>
<version>2.6.24</version> <version>2.6.25</version>
<last-release> Apr 28 2006</last-release> <last-release> Jun 6 2006:</last-release>
<info-url>http://xmlsoft.org/</info-url> <info-url>http://xmlsoft.org/</info-url>
<changes> - Portability fixes: configure on Windows, testapi compile on <changes>Do not use or package 2.6.25</changes>
windows(Kasimier Buchcik, venkat naidu), Borland C++ 6 compile (Eric
Zurcher),HP-UX compiler workaround (Rick Jones), xml2-config bugfix,
gcc-4.1cleanups, Python detection scheme (Joseph Sacco), UTF-8 file paths
onWindows (Roland Schwingel).
- Improvements: xmlDOMWrapReconcileNamespaces xmlDOMWrapCloneNode
(KasimierBuchcik), XML catalog debugging (Rick Jones), update to Unicode
4.01.
- Bug fixes: xmlParseChunk() problem in 2.6.23, xmlParseInNodeContext()on
HTML docs, URI behaviour on Windows (Rob Richards), comment streamingbug,
xmlParseComment (with William Brack), regexp bug fixes (DV &amp;Youri
Golovanov), xmlGetNodePath on text/CDATA (Kasimier),one Relax-NG
interleave bug, xmllint --path and --valid,XSD bugfixes (Kasimier),
remove debugleft in Python bindings (Nic Ferrier), xmlCatalogAdd bug
(Martin Cole),xmlSetProp fixes (Rob Richards), HTML IDness (Rob
Richards), a largenumber of cleanups and small fixes based on Coverity
reports, bugin character ranges, Unicode tables const (Aivars Kalvans),
schemasfix (Stefan Kost), xmlRelaxNGParse error
deallocation,xmlSchemaAddSchemaDoc error deallocation, error handling on
unallowedcode point, ixmllint --nonet to never reach the net (Gary
Coady),line break in writer after end PI (Jason Viers).
- Documentation: man pages updates and cleanups (Daniel Leidert).
- New features: Relax NG structure error handlers.
</changes>
</product> </product>
</xsa> </xsa>

View File

@@ -7,44 +7,44 @@ H1 {font-family: Verdana,Arial,Helvetica}
H2 {font-family: Verdana,Arial,Helvetica} H2 {font-family: Verdana,Arial,Helvetica}
H3 {font-family: Verdana,Arial,Helvetica} H3 {font-family: Verdana,Arial,Helvetica}
A:link, A:visited, A:active { text-decoration: underline } A:link, A:visited, A:active { text-decoration: underline }
</style><title>Namespaces</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>Namespaces</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p>The libxml2 library implements <a href="http://www.w3.org/TR/REC-xml-names/">XML namespaces</a>support </style><title>Namespaces</title></head><body bgcolor="#8b7765" text="#000000" link="#a06060" vlink="#000000"><table border="0" width="100%" cellpadding="5" cellspacing="0" align="center"><tr><td width="120"><a href="http://swpat.ffii.org/"><img src="epatents.png" alt="Action against software patents" /></a></td><td width="180"><a href="http://www.gnome.org/"><img src="gnome2.png" alt="Gnome2 Logo" /></a><a href="http://www.w3.org/Status"><img src="w3c.png" alt="W3C Logo" /></a><a href="http://www.redhat.com/"><img src="redhat.gif" alt="Red Hat Logo" /></a><div align="left"><a href="http://xmlsoft.org/"><img src="Libxml2-Logo-180x168.gif" alt="Made with Libxml2 Logo" /></a></div></td><td><table border="0" width="90%" cellpadding="2" cellspacing="0" align="center" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3" bgcolor="#fffacd"><tr><td align="center"><h1>The XML C parser and toolkit of Gnome</h1><h2>Namespaces</h2></td></tr></table></td></tr></table></td></tr></table><table border="0" cellpadding="4" cellspacing="0" width="100%" align="center"><tr><td bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="2" width="100%"><tr><td valign="top" width="200" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Main Menu</b></center></td></tr><tr><td bgcolor="#fffacd"><form action="search.php" enctype="application/x-www-form-urlencoded" method="get"><input name="query" type="text" size="20" value="" /><input name="submit" type="submit" value="Search ..." /></form><ul><li><a href="index.html">Home</a></li><li><a href="html/index.html">Reference Manual</a></li><li><a href="intro.html">Introduction</a></li><li><a href="FAQ.html">FAQ</a></li><li><a href="docs.html" style="font-weight:bold">Developer Menu</a></li><li><a href="bugs.html">Reporting bugs and getting help</a></li><li><a href="help.html">How to help</a></li><li><a href="downloads.html">Downloads</a></li><li><a href="news.html">Releases</a></li><li><a href="XMLinfo.html">XML</a></li><li><a href="XSLT.html">XSLT</a></li><li><a href="xmldtd.html">Validation &amp; DTDs</a></li><li><a href="encoding.html">Encodings support</a></li><li><a href="catalog.html">Catalog support</a></li><li><a href="namespaces.html">Namespaces</a></li><li><a href="contribs.html">Contributions</a></li><li><a href="examples/index.html" style="font-weight:bold">Code Examples</a></li><li><a href="html/index.html" style="font-weight:bold">API Menu</a></li><li><a href="guidelines.html">XML Guidelines</a></li><li><a href="ChangeLog.html">Recent Changes</a></li></ul></td></tr></table><table width="100%" border="0" cellspacing="1" cellpadding="3"><tr><td colspan="1" bgcolor="#eecfa1" align="center"><center><b>Related links</b></center></td></tr><tr><td bgcolor="#fffacd"><ul><li><a href="http://mail.gnome.org/archives/xml/">Mail archive</a></li><li><a href="http://xmlsoft.org/XSLT/">XSLT libxslt</a></li><li><a href="http://phd.cs.unibo.it/gdome2/">DOM gdome2</a></li><li><a href="http://www.aleksey.com/xmlsec/">XML-DSig xmlsec</a></li><li><a href="ftp://xmlsoft.org/">FTP</a></li><li><a href="http://www.zlatkovic.com/projects/libxml/">Windows binaries</a></li><li><a href="http://www.blastwave.org/packages.php/libxml2">Solaris binaries</a></li><li><a href="http://www.explain.com.au/oss/libxml2xslt.html">MacOsX binaries</a></li><li><a href="http://libxmlplusplus.sourceforge.net/">C++ bindings</a></li><li><a href="http://www.zend.com/php5/articles/php5-xmlphp.php#Heading4">PHP bindings</a></li><li><a href="http://sourceforge.net/projects/libxml2-pas/">Pascal bindings</a></li><li><a href="http://libxml.rubyforge.org/">Ruby bindings</a></li><li><a href="http://tclxml.sourceforge.net/">Tcl bindings</a></li><li><a href="http://bugzilla.gnome.org/buglist.cgi?product=libxml2">Bug Tracker</a></li></ul></td></tr></table></td></tr></table></td><td valign="top" bgcolor="#8b7765"><table border="0" cellspacing="0" cellpadding="1" width="100%"><tr><td><table border="0" cellspacing="0" cellpadding="1" width="100%" bgcolor="#000000"><tr><td><table border="0" cellpadding="3" cellspacing="1" width="100%"><tr><td bgcolor="#fffacd"><p>The libxml2 library implements <a href="http://www.w3.org/TR/REC-xml-names/">XML
byrecognizing namespace constructs in the input, and does namespace namespaces</a>supportbyrecognizing namespace constructs in the input, and
lookupautomatically when building the DOM tree. A namespace declaration does namespacelookupautomatically when building the DOM tree. A namespace
isassociated with an in-memory structure and all elements or attributes declarationisassociated with an in-memory structure and all elements or
withinthat namespace point to it. Hence testing the namespace is a simple and attributeswithinthat namespace point to it. Hence testing the namespace is a
fastequality operation at the user level.</p><p>I suggest that people using libxml2 use a namespace, and declare it in simple andfastequality operation at the user level.</p><p>I suggest that people using libxml2 use a namespace, and declare it
theroot element of their document as the default namespace. Then they don't intheroot element of their document as the default namespace. Then they
needto use the prefix in the content but we will have a basis for future don'tneedto use the prefix in the content but we will have a basis for
semanticrefinement and merging of data from different sources. This doesn't futuresemanticrefinement and merging of data from different sources. This
increasethe size of the XML output significantly, but significantly increases doesn'tincreasethe size of the XML output significantly, but significantly
itsvalue in the long-term. Example:</p><pre>&lt;mydoc xmlns="http://mydoc.example.org/schemas/"&gt; increasesitsvalue in the long-term. Example:</p><pre>&lt;mydoc xmlns="http://mydoc.example.org/schemas/"&gt;
&lt;elem1&gt;...&lt;/elem1&gt; &lt;elem1&gt;...&lt;/elem1&gt;
&lt;elem2&gt;...&lt;/elem2&gt; &lt;elem2&gt;...&lt;/elem2&gt;
&lt;/mydoc&gt;</pre><p>The namespace value has to be an absolute URL, but the URL doesn't have &lt;/mydoc&gt;</pre><p>The namespace value has to be an absolute URL, but the URL doesn't
topoint to any existing resource on the Web. It will bind all the element havetopoint to any existing resource on the Web. It will bind all the
andattributes with that URL. I suggest to use an URL within a domain elementandattributes with that URL. I suggest to use an URL within a
youcontrol, and that the URL should contain some kind of version information domainyoucontrol, and that the URL should contain some kind of version
ifpossible. For example, <code>"http://www.gnome.org/gnumeric/1.0/"</code>is informationifpossible. For example,
agood namespace scheme.</p><p>Then when you load a file, make sure that a namespace carrying <code>"http://www.gnome.org/gnumeric/1.0/"</code>isagood namespace scheme.</p><p>Then when you load a file, make sure that a namespace
theversion-independent prefix is installed on the root element of your carryingtheversion-independent prefix is installed on the root element of
document,and if the version information don't match something you know, warn yourdocument,and if the version information don't match something you know,
the userand be liberal in what you accept as the input. Also do *not* try to warnthe userand be liberal in what you accept as the input. Also do *not* try
basenamespace checking on the prefix value. &lt;foo:text&gt; may be exactly tobasenamespace checking on the prefix value. &lt;foo:text&gt; may be
thesame as &lt;bar:text&gt; in another document. What really matters is the exactlythesame as &lt;bar:text&gt; in another document. What really matters
URIassociated with the element or the attribute, not the prefix string (which is theURIassociated with the element or the attribute, not the prefix string
isjust a shortcut for the full URI). In libxml, element and attributes have (whichisjust a shortcut for the full URI). In libxml, element and attributes
an<code>ns</code>field pointing to an xmlNs structure detailing the havean<code>ns</code>field pointing to an xmlNs structure detailing
namespaceprefix and its URI.</p><p>@@Interfaces@@</p><pre>xmlNodePtr node; thenamespaceprefix and its URI.</p><p>@@Interfaces@@</p><pre>xmlNodePtr node;
if(!strncmp(node-&gt;name,"mytag",5) if(!strncmp(node-&gt;name,"mytag",5)
&amp;&amp; node-&gt;ns &amp;&amp; node-&gt;ns
&amp;&amp; !strcmp(node-&gt;ns-&gt;href,"http://www.mysite.com/myns/1.0")) { &amp;&amp; !strcmp(node-&gt;ns-&gt;href,"http://www.mysite.com/myns/1.0")) {
... ...
}</pre><p>Usually people object to using namespaces together with validity }</pre><p>Usually people object to using namespaces together with validitychecking.I
checking.I will try to make sure that using namespaces won't break validity will try to make sure that using namespaces won't break validitychecking,so
checking,so even if you plan to use or currently are using validation I even if you plan to use or currently are using validation Istronglysuggest
stronglysuggest adding namespaces to your document. A default namespace adding namespaces to your document. A default
scheme<code>xmlns="http://...."</code>should not break validity even on namespacescheme<code>xmlns="http://...."</code>should not break validity even
lessflexible parsers. Using namespaces to mix and differentiate content onlessflexible parsers. Using namespaces to mix and differentiate
comingfrom multiple DTDs will certainly break current validation schemes. To contentcomingfrom multiple DTDs will certainly break current validation
checksuch documents one needs to use schema-validation, which is supported schemes. Tochecksuch documents one needs to use schema-validation, which is
inlibxml2 as well. See <a href="http://www.relaxng.org/">relagx-ng</a>and <a href="http://www.w3c.org/XML/Schema">w3c-schema</a>.</p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html> supportedinlibxml2 as well. See <a href="http://www.relaxng.org/">relagx-ng</a>and <a href="http://www.w3c.org/XML/Schema">w3c-schema</a>.</p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html>

File diff suppressed because it is too large Load Diff

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because it is too large Load Diff

View File

@@ -17,83 +17,84 @@ A:link, A:visited, A:active { text-decoration: underline }
<li><a href="#Some">Some examples</a></li> <li><a href="#Some">Some examples</a></li>
<li><a href="#validate">How to validate</a></li> <li><a href="#validate">How to validate</a></li>
<li><a href="#Other">Other resources</a></li> <li><a href="#Other">Other resources</a></li>
</ol><h3><a name="General5" id="General5">General overview</a></h3><p>Well what is validation and what is a DTD ?</p><p>DTD is the acronym for Document Type Definition. This is a description </ol><h3><a name="General5" id="General5">General overview</a></h3><p>Well what is validation and what is a DTD ?</p><p>DTD is the acronym for Document Type Definition. This is a
ofthe content for a family of XML files. This is part of the XML descriptionofthe content for a family of XML files. This is part of the
1.0specification, and allows one to describe and verify that a given XML1.0specification, and allows one to describe and verify that a
documentinstance conforms to the set of rules detailing its structure and givendocumentinstance conforms to the set of rules detailing its structure
content.</p><p>Validation is the process of checking a document against a DTD andcontent.</p><p>Validation is the process of checking a document against a
(moregenerally against a set of construction rules).</p><p>The validation process and building DTDs are the two most difficult DTD(moregenerally against a set of construction rules).</p><p>The validation process and building DTDs are the two most difficultpartsof
partsof the XML life cycle. Briefly a DTD defines all the possible elements the XML life cycle. Briefly a DTD defines all the possible elementsto befound
to befound within your document, what is the formal shape of your document within your document, what is the formal shape of your documenttree(by
tree(by defining the allowed content of an element; either text, a defining the allowed content of an element; either text, aregularexpression
regularexpression for the allowed list of children, or mixed content i.e. for the allowed list of children, or mixed content i.e.both textand
both textand children). The DTD also defines the valid attributes for all children). The DTD also defines the valid attributes for allelements andthe
elements andthe types of those attributes.</p><h3><a name="definition1" id="definition1">The definition</a></h3><p>The <a href="http://www.w3.org/TR/REC-xml">W3C XML Recommendation</a>(<a href="http://www.xml.com/axml/axml.html">Tim Bray's annotated version types of those attributes.</p><h3><a name="definition1" id="definition1">The definition</a></h3><p>The <a href="http://www.w3.org/TR/REC-xml">W3C XML Recommendation</a>(<a href="http://www.xml.com/axml/axml.html">Tim Bray's annotated
ofRev1</a>):</p><ul><li><a href="http://www.w3.org/TR/REC-xml#elemdecls">Declaringelements</a></li> versionofRev1</a>):</p><ul><li><a href="http://www.w3.org/TR/REC-xml#elemdecls">Declaringelements</a></li>
<li><a href="http://www.w3.org/TR/REC-xml#attdecls">Declaringattributes</a></li> <li><a href="http://www.w3.org/TR/REC-xml#attdecls">Declaringattributes</a></li>
</ul><p>(unfortunately) all this is inherited from the SGML world, the syntax </ul><p>(unfortunately) all this is inherited from the SGML world, the
isancient...</p><h3><a name="Simple1" id="Simple1">Simple rules</a></h3><p>Writing DTDs can be done in many ways. The rules to build them if you syntaxisancient...</p><h3><a name="Simple1" id="Simple1">Simple rules</a></h3><p>Writing DTDs can be done in many ways. The rules to build them if
needsomething permanent or something which can evolve over time can be youneedsomething permanent or something which can evolve over time can
radicallydifferent. Really complex DTDs like DocBook ones are flexible but beradicallydifferent. Really complex DTDs like DocBook ones are flexible
quiteharder to design. I will just focus on DTDs for a formats with a fixed butquiteharder to design. I will just focus on DTDs for a formats with a
simplestructure. It is just a set of basic rules, and definitely not fixedsimplestructure. It is just a set of basic rules, and definitely
exhaustive norusable for complex DTD design.</p><h4><a name="reference1" id="reference1">How to reference a DTD from a document</a>:</h4><p>Assuming the top element of the document is <code>spec</code>and the dtdis notexhaustive norusable for complex DTD design.</p><h4><a name="reference1" id="reference1">How to reference a DTD from a document</a>:</h4><p>Assuming the top element of the document is <code>spec</code>and the
placed in the file <code>mydtd</code>in the subdirectory<code>dtds</code>of dtdisplaced in the file <code>mydtd</code>in the
the directory from where the document were loaded:</p><p><code>&lt;!DOCTYPE spec SYSTEM "dtds/mydtd"&gt;</code></p><p>Notes:</p><ul><li>The system string is actually an URI-Reference (as defined in <a href="http://www.ietf.org/rfc/rfc2396.txt">RFC 2396</a>) so you can use subdirectory<code>dtds</code>ofthe directory from where the document were
afull URL string indicating the location of your DTD on the Web. This is loaded:</p><p><code>&lt;!DOCTYPE spec SYSTEM "dtds/mydtd"&gt;</code></p><p>Notes:</p><ul><li>The system string is actually an URI-Reference (as defined in <a href="http://www.ietf.org/rfc/rfc2396.txt">RFC 2396</a>) so you can
areally good thing to do if you want others to validate your useafull URL string indicating the location of your DTD on the Web. This
document.</li> isareally good thing to do if you want others to validate
<li>It is also possible to associate a <code>PUBLIC</code>identifier yourdocument.</li>
(amagic string) so that the DTD is looked up in catalogs on the client <li>It is also possible to associate a <code>PUBLIC</code>identifier(amagic
sidewithout having to locate it on the web.</li> string) so that the DTD is looked up in catalogs on the clientsidewithout
<li>A DTD contains a set of element and attribute declarations, but having to locate it on the web.</li>
theydon't define what the root of the document should be. This is <li>A DTD contains a set of element and attribute declarations,
explicitlytold to the parser/validator as the first element of buttheydon't define what the root of the document should be. This
the<code>DOCTYPE</code>declaration.</li> isexplicitlytold to the parser/validator as the first element
</ul><h4><a name="Declaring2" id="Declaring2">Declaring elements</a>:</h4><p>The following declares an element <code>spec</code>:</p><p><code>&lt;!ELEMENT spec (front, body, back?)&gt;</code></p><p>It also expresses that the spec element contains one ofthe<code>DOCTYPE</code>declaration.</li>
<code>front</code>,one <code>body</code>and one optional </ul><h4><a name="Declaring2" id="Declaring2">Declaring elements</a>:</h4><p>The following declares an element <code>spec</code>:</p><p><code>&lt;!ELEMENT spec (front, body, back?)&gt;</code></p><p>It also expresses that the spec element contains one<code>front</code>,one
<code>back</code>children elements inthis order. The declaration of one <code>body</code>and one optional<code>back</code>children elements inthis
element of the structure and its contentare done in a single declaration. order. The declaration of oneelement of the structure and its contentare done
Similarly the following declares<code>div1</code>elements:</p><p><code>&lt;!ELEMENT div1 (head, (p | list | note)*, div2?)&gt;</code></p><p>which means div1 contains one <code>head</code>then a series of in a single declaration.Similarly the following
optional<code>p</code>, <code>list</code>s and <code>note</code>s and then declares<code>div1</code>elements:</p><p><code>&lt;!ELEMENT div1 (head, (p | list | note)*, div2?)&gt;</code></p><p>which means div1 contains one <code>head</code>then a series
anoptional <code>div2</code>. And last but not least an element can ofoptional<code>p</code>, <code>list</code>s and <code>note</code>s and
containtext:</p><p><code>&lt;!ELEMENT b (#PCDATA)&gt;</code></p><p><code>b</code>contains text or being of mixed content (text and elementsin thenanoptional <code>div2</code>. And last but not least an element
no particular order):</p><p><code>&lt;!ELEMENT p (#PCDATA|a|ul|b|i|em)*&gt;</code></p><p><code>p </code>can contain text or <code>a</code>, cancontaintext:</p><p><code>&lt;!ELEMENT b (#PCDATA)&gt;</code></p><p><code>b</code>contains text or being of mixed content (text and
<code>ul</code>,<code>b</code>, <code>i </code>or <code>em</code>elements in elementsinno particular order):</p><p><code>&lt;!ELEMENT p (#PCDATA|a|ul|b|i|em)*&gt;</code></p><p><code>p </code>can contain text or
no particularorder.</p><h4><a name="Declaring1" id="Declaring1">Declaring attributes</a>:</h4><p>Again the attributes declaration includes their content definition:</p><p><code>&lt;!ATTLIST termdef name CDATA #IMPLIED&gt;</code></p><p>means that the element <code>termdef</code>can have a <code>a</code>,<code>ul</code>,<code>b</code>, <code>i </code>or
<code>name</code>attribute containing text (<code>CDATA</code>) and which is <code>em</code>elements inno particularorder.</p><h4><a name="Declaring1" id="Declaring1">Declaring attributes</a>:</h4><p>Again the attributes declaration includes their content definition:</p><p><code>&lt;!ATTLIST termdef name CDATA #IMPLIED&gt;</code></p><p>means that the element <code>termdef</code>can have
optional(<code>#IMPLIED</code>). The attribute value can also be defined a<code>name</code>attribute containing text (<code>CDATA</code>) and which
within aset:</p><p><code>&lt;!ATTLIST list type isoptional(<code>#IMPLIED</code>). The attribute value can also be
(bullets|ordered|glossary)"ordered"&gt;</code></p><p>means <code>list</code>element have a <code>type</code>attribute with definedwithin aset:</p><p><code>&lt;!ATTLIST list
3allowed values "bullets", "ordered" or "glossary" and which default type(bullets|ordered|glossary)"ordered"&gt;</code></p><p>means <code>list</code>element have a <code>type</code>attribute
to"ordered" if the attribute is not explicitly specified.</p><p>The content type of an attribute can be text with3allowed values "bullets", "ordered" or "glossary" and which
(<code>CDATA</code>),anchor/reference/references(<code>ID</code>/<code>IDREF</code>/<code>IDREFS</code>), defaultto"ordered" if the attribute is not explicitly specified.</p><p>The content type of an attribute can be
entity(ies)(<code>ENTITY</code>/<code>ENTITIES</code>) or text(<code>CDATA</code>),anchor/reference/references(<code>ID</code>/<code>IDREF</code>/<code>IDREFS</code>),entity(ies)(<code>ENTITY</code>/<code>ENTITIES</code>)
name(s)(<code>NMTOKEN</code>/<code>NMTOKENS</code>). The following defines orname(s)(<code>NMTOKEN</code>/<code>NMTOKENS</code>). The following
that a<code>chapter</code>element can have an optional definesthat a<code>chapter</code>element can have an
<code>id</code>attributeof type <code>ID</code>, usable for reference from optional<code>id</code>attributeof type <code>ID</code>, usable for reference
attribute of typeIDREF:</p><p><code>&lt;!ATTLIST chapter id ID #IMPLIED&gt;</code></p><p>The last value of an attribute definition can be fromattribute of typeIDREF:</p><p><code>&lt;!ATTLIST chapter id ID #IMPLIED&gt;</code></p><p>The last value of an attribute definition can
<code>#REQUIRED</code>meaning that the attribute has to be given, be<code>#REQUIRED</code>meaning that the attribute has to be
<code>#IMPLIED</code>meaning that it is optional, or the default value given,<code>#IMPLIED</code>meaning that it is optional, or the default
(possibly prefixed by<code>#FIXED</code>if it is the only allowed).</p><p>Notes:</p><ul><li>Usually the attributes pertaining to a given element are declared in value(possibly prefixed by<code>#FIXED</code>if it is the only allowed).</p><p>Notes:</p><ul><li>Usually the attributes pertaining to a given element are declared
asingle expression, but it is just a convention adopted by a lot of inasingle expression, but it is just a convention adopted by a lot
DTDwriters: ofDTDwriters:
<pre>&lt;!ATTLIST termdef <pre>&lt;!ATTLIST termdef
id ID #REQUIRED id ID #REQUIRED
name CDATA #IMPLIED&gt;</pre> name CDATA #IMPLIED&gt;</pre>
<p>The previous construct defines both <p>The previous construct defines
<code>id</code>and<code>name</code>attributes for the element both<code>id</code>and<code>name</code>attributes for the
<code>termdef</code>.</p> element<code>termdef</code>.</p>
</li> </li>
</ul><h3><a name="Some1" id="Some1">Some examples</a></h3><p>The directory <code>test/valid/dtds/</code>in the libxml2 </ul><h3><a name="Some1" id="Some1">Some examples</a></h3><p>The directory <code>test/valid/dtds/</code>in the
distributioncontains some complex DTD examples. The example in the libxml2distributioncontains some complex DTD examples. The example in
file<code>test/valid/dia.xml</code>shows an XML file where the simple DTD thefile<code>test/valid/dia.xml</code>shows an XML file where the simple
isdirectly included within the document.</p><h3><a name="validate1" id="validate1">How to validate</a></h3><p>The simplest way is to use the xmllint program included with libxml. DTDisdirectly included within the document.</p><h3><a name="validate1" id="validate1">How to validate</a></h3><p>The simplest way is to use the xmllint program included with
The<code>--valid</code>option turns-on validation of the files given as libxml.The<code>--valid</code>option turns-on validation of the files given
input.For example the following validates a copy of the first revision of the asinput.For example the following validates a copy of the first revision of
XML1.0 specification:</p><p><code>xmllint --valid --noout test/valid/REC-xml-19980210.xml</code></p><p>the -- noout is used to disable output of the resulting tree.</p><p>The <code>--dtdvalid dtd</code>allows validation of the document(s)against theXML1.0 specification:</p><p><code>xmllint --valid --noout test/valid/REC-xml-19980210.xml</code></p><p>the -- noout is used to disable output of the resulting tree.</p><p>The <code>--dtdvalid dtd</code>allows validation of the
a given DTD.</p><p>Libxml2 exports an API to handle DTDs and validation, check the <a href="http://xmlsoft.org/html/libxml-valid.html">associateddescription</a>.</p><h3><a name="Other1" id="Other1">Other resources</a></h3><p>DTDs are as old as SGML. So there may be a number of examples on-line, document(s)againsta given DTD.</p><p>Libxml2 exports an API to handle DTDs and validation, check the <a href="http://xmlsoft.org/html/libxml-valid.html">associateddescription</a>.</p><h3><a name="Other1" id="Other1">Other resources</a></h3><p>DTDs are as old as SGML. So there may be a number of examples
Iwill just list one for now, others pointers welcome:</p><ul><li><a href="http://www.xml101.com:8081/dtd/">XML-101 DTD</a></li> on-line,Iwill just list one for now, others pointers welcome:</p><ul><li><a href="http://www.xml101.com:8081/dtd/">XML-101 DTD</a></li>
</ul><p>I suggest looking at the examples found under test/valid/dtd and any ofthe </ul><p>I suggest looking at the examples found under test/valid/dtd and any
large number of books available on XML. The dia example in test/validshould ofthelarge number of books available on XML. The dia example in
be both simple and complete enough to allow you to build your own.</p><p></p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html> test/validshouldbe both simple and complete enough to allow you to build your
own.</p><p></p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html>

View File

@@ -13,65 +13,64 @@ A:link, A:visited, A:active { text-decoration: underline }
<li><a href="#Output">Output I/O handlers</a></li> <li><a href="#Output">Output I/O handlers</a></li>
<li><a href="#entities">The entities loader</a></li> <li><a href="#entities">The entities loader</a></li>
<li><a href="#Example2">Example of customized I/O</a></li> <li><a href="#Example2">Example of customized I/O</a></li>
</ol><h3><a name="General1" id="General1">General overview</a></h3><p>The module <code><a href="http://xmlsoft.org/html/libxml-xmlio.html">xmlIO.h</a></code>providesthe </ol><h3><a name="General1" id="General1">General overview</a></h3><p>The module <code><a href="http://xmlsoft.org/html/libxml-xmlio.html">xmlIO.h</a></code>providestheinterfaces
interfaces to the libxml2 I/O system. This consists of 4 main parts:</p><ul><li>Entities loader, this is a routine which tries to fetch the to the libxml2 I/O system. This consists of 4 main parts:</p><ul><li>Entities loader, this is a routine which tries to fetch
entities(files) based on their PUBLIC and SYSTEM identifiers. The default theentities(files) based on their PUBLIC and SYSTEM identifiers. The
loaderdon't look at the public identifier since libxml2 do not maintain defaultloaderdon't look at the public identifier since libxml2 do not
acatalog. You can redefine you own entity loader by maintainacatalog. You can redefine you own entity loader
using<code>xmlGetExternalEntityLoader()</code>and<code>xmlSetExternalEntityLoader()</code>. byusing<code>xmlGetExternalEntityLoader()</code>and<code>xmlSetExternalEntityLoader()</code>.<a href="#entities">Check theexample</a>.</li>
<a href="#entities">Check theexample</a>.</li> <li>Input I/O buffers which are a commodity structure used by
<li>Input I/O buffers which are a commodity structure used by the theparser(s)input layer to handle fetching the informations to feed
parser(s)input layer to handle fetching the informations to feed the theparser. Thisprovides buffering and is also a placeholder where
parser. Thisprovides buffering and is also a placeholder where the theencodingconverters to UTF8 are piggy-backed.</li>
encodingconverters to UTF8 are piggy-backed.</li> <li>Output I/O buffers are similar to the Input ones and fulfillsimilartask
<li>Output I/O buffers are similar to the Input ones and fulfill but when generating a serialization from a tree.</li>
similartask but when generating a serialization from a tree.</li> <li>A mechanism to register sets of I/O callbacks and associate
<li>A mechanism to register sets of I/O callbacks and associate them themwithspecific naming schemes like the protocol part of the URIs.
withspecific naming schemes like the protocol part of the URIs. <p>This affect the default I/O operations and allows to use
<p>This affect the default I/O operations and allows to use specific specificI/Ohandlers for certain names.</p>
I/Ohandlers for certain names.</p>
</li> </li>
</ul><p>The general mechanism used when loading http://rpmfind.net/xml.html </ul><p>The general mechanism used when loading
forexample in the HTML parser is the following:</p><ol><li>The default entity loader calls http://rpmfind.net/xml.htmlforexample in the HTML parser is the following:</p><ol><li>The default entity loader
<code>xmlNewInputFromFile()</code>withthe parsing context and the URI calls<code>xmlNewInputFromFile()</code>withthe parsing context and the
string.</li> URIstring.</li>
<li>the URI string is checked against the existing registered handlersusing <li>the URI string is checked against the existing registered
their match() callback function, if the HTTP module was compiledin, it is handlersusingtheir match() callback function, if the HTTP module was
registered and its match() function will succeeds</li> compiledin, it isregistered and its match() function will succeeds</li>
<li>the open() function of the handler is called and if successful <li>the open() function of the handler is called and if
willreturn an I/O Input buffer</li> successfulwillreturn an I/O Input buffer</li>
<li>the parser will the start reading from this buffer and <li>the parser will the start reading from this buffer
progressivelyfetch information from the resource, calling the read() andprogressivelyfetch information from the resource, calling the
function of thehandler until the resource is exhausted</li> read()function of thehandler until the resource is exhausted</li>
<li>if an encoding change is detected it will be installed on the <li>if an encoding change is detected it will be installed on
inputbuffer, providing buffering and efficient use of the theinputbuffer, providing buffering and efficient use of
conversionroutines</li> theconversionroutines</li>
<li>once the parser has finished, the close() function of the handler <li>once the parser has finished, the close() function of the
iscalled once and the Input buffer and associated resources handleriscalled once and the Input buffer and associated
aredeallocated.</li> resourcesaredeallocated.</li>
</ol><p>The user defined callbacks are checked first to allow overriding of </ol><p>The user defined callbacks are checked first to allow overriding
thedefault libxml2 I/O routines.</p><h3><a name="basic" id="basic">The basic buffer type</a></h3><p>All the buffer manipulation handling is done using ofthedefault libxml2 I/O routines.</p><h3><a name="basic" id="basic">The basic buffer type</a></h3><p>All the buffer manipulation handling is done
the<code>xmlBuffer</code>type define in <code><a href="http://xmlsoft.org/html/libxml-tree.html">tree.h</a></code>which is usingthe<code>xmlBuffer</code>type define in <code><a href="http://xmlsoft.org/html/libxml-tree.html">tree.h</a></code>which
aresizable memory buffer. The buffer allocation strategy can be selected to isaresizable memory buffer. The buffer allocation strategy can be selected
beeither best-fit or use an exponential doubling one (CPU vs. memory tobeeither best-fit or use an exponential doubling one (CPU vs.
usetrade-off). The values are memoryusetrade-off). The values
<code>XML_BUFFER_ALLOC_EXACT</code>and<code>XML_BUFFER_ALLOC_DOUBLEIT</code>, are<code>XML_BUFFER_ALLOC_EXACT</code>and<code>XML_BUFFER_ALLOC_DOUBLEIT</code>,and
and can be set individually or on asystem wide basis using can be set individually or on asystem wide basis
<code>xmlBufferSetAllocationScheme()</code>. A numberof functions allows to using<code>xmlBufferSetAllocationScheme()</code>. A numberof functions allows
manipulate buffers with names starting with tomanipulate buffers with names starting
the<code>xmlBuffer...</code>prefix.</p><h3><a name="Input" id="Input">Input I/O handlers</a></h3><p>An Input I/O handler is a simple withthe<code>xmlBuffer...</code>prefix.</p><h3><a name="Input" id="Input">Input I/O handlers</a></h3><p>An Input I/O handler is a
structure<code>xmlParserInputBuffer</code>containing a context associated to simplestructure<code>xmlParserInputBuffer</code>containing a context
theresource (file descriptor, or pointer to a protocol handler), the read() associated totheresource (file descriptor, or pointer to a protocol handler),
andclose() callbacks to use and an xmlBuffer. And extra xmlBuffer and a the read()andclose() callbacks to use and an xmlBuffer. And extra xmlBuffer
charsetencoding handler are also present to support charset conversion and acharsetencoding handler are also present to support charset
whenneeded.</p><h3><a name="Output" id="Output">Output I/O handlers</a></h3><p>An Output handler <code>xmlOutputBuffer</code>is completely similar to conversionwhenneeded.</p><h3><a name="Output" id="Output">Output I/O handlers</a></h3><p>An Output handler <code>xmlOutputBuffer</code>is completely similar
anInput one except the callbacks are write() and close().</p><h3><a name="entities" id="entities">The entities loader</a></h3><p>The entity loader resolves requests for new entities and create inputs toanInput one except the callbacks are write() and close().</p><h3><a name="entities" id="entities">The entities loader</a></h3><p>The entity loader resolves requests for new entities and create
forthe parser. Creating an input from a filename or an URI string is inputsforthe parser. Creating an input from a filename or an URI string
donethrough the xmlNewInputFromFile() routine. The default entity loader do isdonethrough the xmlNewInputFromFile() routine. The default entity loader
nothandle the PUBLIC identifier associated with an entity (if any). So it donothandle the PUBLIC identifier associated with an entity (if any). So
justcalls xmlNewInputFromFile() with the SYSTEM identifier (which is itjustcalls xmlNewInputFromFile() with the SYSTEM identifier (which
mandatory inXML).</p><p>If you want to hook up a catalog mechanism then you simply need tooverride ismandatory inXML).</p><p>If you want to hook up a catalog mechanism then you simply need
the default entity loader, here is an example:</p><pre>#include &lt;libxml/xmlIO.h&gt; tooverridethe default entity loader, here is an example:</p><pre>#include &lt;libxml/xmlIO.h&gt;
xmlExternalEntityLoader defaultLoader = NULL; xmlExternalEntityLoader defaultLoader = NULL;
@@ -100,11 +99,10 @@ int main(..) {
xmlSetExternalEntityLoader(xmlMyExternalEntityLoader); xmlSetExternalEntityLoader(xmlMyExternalEntityLoader);
... ...
}</pre><h3><a name="Example2" id="Example2">Example of customized I/O</a></h3><p>This example come from <a href="http://xmlsoft.org/messages/0708.html">areal use case</a>, }</pre><h3><a name="Example2" id="Example2">Example of customized I/O</a></h3><p>This example come from <a href="http://xmlsoft.org/messages/0708.html">areal use case</a>,xmlDocDump()
xmlDocDump() closes the FILE * passed by the applicationand this was a closes the FILE * passed by the applicationand this was aproblem. The <a href="http://xmlsoft.org/messages/0711.html">solution</a>wasto redefine anew
problem. The <a href="http://xmlsoft.org/messages/0711.html">solution</a>was output handler with the closing call deactivated:</p><ol><li>First define a new I/O output allocator where the output don't
to redefine anew output handler with the closing call deactivated:</p><ol><li>First define a new I/O output allocator where the output don't closethe closethefile:
file:
<pre>xmlOutputBufferPtr <pre>xmlOutputBufferPtr
xmlOutputBufferCreateOwn(FILE *file, xmlCharEncodingHandlerPtr encoder) { xmlOutputBufferCreateOwn(FILE *file, xmlCharEncodingHandlerPtr encoder) {
<EFBFBD><EFBFBD><EFBFBD><EFBFBD>xmlOutputBufferPtr ret; <EFBFBD><EFBFBD><EFBFBD><EFBFBD>xmlOutputBufferPtr ret;

View File

@@ -12,92 +12,91 @@ A:link, A:visited, A:active { text-decoration: underline }
<li><a href="#cleanup">Cleaning up after parsing</a></li> <li><a href="#cleanup">Cleaning up after parsing</a></li>
<li><a href="#Debugging">Debugging routines</a></li> <li><a href="#Debugging">Debugging routines</a></li>
<li><a href="#General4">General memory requirements</a></li> <li><a href="#General4">General memory requirements</a></li>
</ol><h3><a name="General3" id="General3">General overview</a></h3><p>The module <code><a href="http://xmlsoft.org/html/libxml-xmlmemory.html">xmlmemory.h</a></code>provides </ol><h3><a name="General3" id="General3">General overview</a></h3><p>The module <code><a href="http://xmlsoft.org/html/libxml-xmlmemory.html">xmlmemory.h</a></code>providesthe
the interfaces to the libxml2 memory system:</p><ul><li>libxml2 does not use the libc memory allocator directly but interfaces to the libxml2 memory system:</p><ul><li>libxml2 does not use the libc memory allocator directly
xmlFree(),xmlMalloc() and xmlRealloc()</li> butxmlFree(),xmlMalloc() and xmlRealloc()</li>
<li>those routines can be reallocated to a specific set of routine, <li>those routines can be reallocated to a specific set of
bydefault the libc ones i.e. free(), malloc() and realloc()</li> routine,bydefault the libc ones i.e. free(), malloc() and realloc()</li>
<li>the xmlmemory.c module includes a set of debugging routine</li> <li>the xmlmemory.c module includes a set of debugging routine</li>
</ul><h3><a name="setting" id="setting">Setting libxml2 set of memory routines</a></h3><p>It is sometimes useful to not use the default memory allocator, either </ul><h3><a name="setting" id="setting">Setting libxml2 set of memory routines</a></h3><p>It is sometimes useful to not use the default memory allocator,
fordebugging, analysis or to implement a specific behaviour on memory eitherfordebugging, analysis or to implement a specific behaviour on
management(like on embedded systems). Two function calls are available to do memorymanagement(like on embedded systems). Two function calls are available
so:</p><ul><li><a href="http://xmlsoft.org/html/libxml-xmlmemory.html">xmlMemGet()</a>which to doso:</p><ul><li><a href="http://xmlsoft.org/html/libxml-xmlmemory.html">xmlMemGet()</a>whichreturn
return the current set of functions in use by the parser</li> the current set of functions in use by the parser</li>
<li><a href="http://xmlsoft.org/html/libxml-xmlmemory.html">xmlMemSetup()</a>which <li><a href="http://xmlsoft.org/html/libxml-xmlmemory.html">xmlMemSetup()</a>whichallow
allow to set up a new set of memory allocation functions</li> to set up a new set of memory allocation functions</li>
</ul><p>Of course a call to xmlMemSetup() should probably be done before </ul><p>Of course a call to xmlMemSetup() should probably be done beforecallingany
callingany other libxml2 routines (unless you are sure your allocations other libxml2 routines (unless you are sure your allocationsroutines
routines arecompatibles).</p><h3><a name="cleanup" id="cleanup">Cleaning up after parsing</a></h3><p>Libxml2 is not stateless, there is a few set of memory structures arecompatibles).</p><h3><a name="cleanup" id="cleanup">Cleaning up after parsing</a></h3><p>Libxml2 is not stateless, there is a few set of memory
needingallocation before the parser is fully functional (some encoding structuresneedingallocation before the parser is fully functional (some
structuresfor example). This also mean that once parsing is finished there is encodingstructuresfor example). This also mean that once parsing is finished
a tinyamount of memory (a few hundred bytes) which can be recollected if you there isa tinyamount of memory (a few hundred bytes) which can be recollected
don'treuse the parser immediately:</p><ul><li><a href="http://xmlsoft.org/html/libxml-parser.html">xmlCleanupParser()</a>is if youdon'treuse the parser immediately:</p><ul><li><a href="http://xmlsoft.org/html/libxml-parser.html">xmlCleanupParser()</a>isa
a centralized routine to free the parsing states. Note that itwon't centralized routine to free the parsing states. Note that
deallocate any produced tree if any (use the xmlFreeDoc() andrelated itwon'tdeallocate any produced tree if any (use the xmlFreeDoc()
routines for this).</li> andrelatedroutines for this).</li>
<li><a href="http://xmlsoft.org/html/libxml-parser.html">xmlInitParser()</a>is <li><a href="http://xmlsoft.org/html/libxml-parser.html">xmlInitParser()</a>isthe
the dual routine allowing to preallocate the parsing statewhich can be dual routine allowing to preallocate the parsing statewhich can beuseful
useful for example to avoid initialization reentrancyproblems when using for example to avoid initialization reentrancyproblems when usinglibxml2
libxml2 in multithreaded applications</li> in multithreaded applications</li>
</ul><p>Generally xmlCleanupParser() is safe, if needed the state will be </ul><p>Generally xmlCleanupParser() is safe, if needed the state will berebuildat
rebuildat the next invocation of parser routines, but be careful of the the next invocation of parser routines, but be careful of theconsequencesin
consequencesin multithreaded applications.</p><h3><a name="Debugging" id="Debugging">Debugging routines</a></h3><p>When configured using --with-mem-debug flag (off by default), libxml2 multithreaded applications.</p><h3><a name="Debugging" id="Debugging">Debugging routines</a></h3><p>When configured using --with-mem-debug flag (off by default), libxml2usesa
usesa set of memory allocation debugging routines keeping track of all set of memory allocation debugging routines keeping track of
allocatedblocks and the location in the code where the routine was called. A allallocatedblocks and the location in the code where the routine was called.
couple ofother debugging routines allow to dump the memory allocated infos to Acouple ofother debugging routines allow to dump the memory allocated infos
a fileor call a specific routine when a given block number is allocated:</p><ul><li><a href="http://xmlsoft.org/html/libxml-xmlmemory.html">xmlMallocLoc()</a><a href="http://xmlsoft.org/html/libxml-xmlmemory.html">xmlReallocLoc()</a>and toa fileor call a specific routine when a given block number is allocated:</p><ul><li><a href="http://xmlsoft.org/html/libxml-xmlmemory.html">xmlMallocLoc()</a><a href="http://xmlsoft.org/html/libxml-xmlmemory.html">xmlReallocLoc()</a>and<a href="http://xmlsoft.org/html/libxml-xmlmemory.html">xmlMemStrdupLoc()</a>arethe
<a href="http://xmlsoft.org/html/libxml-xmlmemory.html">xmlMemStrdupLoc()</a>are memory debugging replacement allocation routines</li>
the memory debugging replacement allocation routines</li> <li><a href="http://xmlsoft.org/html/libxml-xmlmemory.html">xmlMemoryDump()</a>dumpsall
<li><a href="http://xmlsoft.org/html/libxml-xmlmemory.html">xmlMemoryDump()</a>dumps the informations about the allocated memory block leftsin
all the informations about the allocated memory block leftsin the the<code>.memdump</code>file</li>
<code>.memdump</code>file</li> </ul><p>When developing libxml2 memory debug is enabled, the tests
</ul><p>When developing libxml2 memory debug is enabled, the tests programs programscallxmlMemoryDump () and the "make test" regression tests will check
callxmlMemoryDump () and the "make test" regression tests will check for foranymemory leak during the full regression test sequence, this helps
anymemory leak during the full regression test sequence, this helps a alotensuring that libxml2 does not leak memory and bullet
lotensuring that libxml2 does not leak memory and bullet proof proofmemoryallocations use (some libc implementations are known to be far
memoryallocations use (some libc implementations are known to be far too toopermissiveresulting in major portability problems!).</p><p>If the .memdump reports a leak, it displays the allocation functionandalso
permissiveresulting in major portability problems!).</p><p>If the .memdump reports a leak, it displays the allocation function tries to give some informations about the content and structure
andalso tries to give some informations about the content and structure of oftheallocated blocks left. This is sufficient in most cases to find
theallocated blocks left. This is sufficient in most cases to find the theculprit,but not always. Assuming the allocation problem is reproducible,
culprit,but not always. Assuming the allocation problem is reproducible, it itispossible to find more easily:</p><ol><li>write down the block number xxxx not allocated</li>
ispossible to find more easily:</p><ol><li>write down the block number xxxx not allocated</li> <li>export the environment variable XML_MEM_BREAKPOINT=xxxx ,
<li>export the environment variable XML_MEM_BREAKPOINT=xxxx , the theeasiestwhen using GDB is to simply give the command
easiestwhen using GDB is to simply give the command
<p><code>set environment XML_MEM_BREAKPOINT xxxx</code></p> <p><code>set environment XML_MEM_BREAKPOINT xxxx</code></p>
<p>before running the program.</p> <p>before running the program.</p>
</li> </li>
<li>run the program under a debugger and set a breakpoint <li>run the program under a debugger and set a
onxmlMallocBreakpoint() a specific function called when this precise breakpointonxmlMallocBreakpoint() a specific function called when this
blockis allocated</li> preciseblockis allocated</li>
<li>when the breakpoint is reached you can then do a fine analysis of <li>when the breakpoint is reached you can then do a fine analysis
theallocation an step to see the condition resulting in the oftheallocation an step to see the condition resulting in
missingdeallocation.</li> themissingdeallocation.</li>
</ol><p>I used to use a commercial tool to debug libxml2 memory problems but </ol><p>I used to use a commercial tool to debug libxml2 memory problems
afternoticing that it was not detecting memory leaks that simple mechanism butafternoticing that it was not detecting memory leaks that simple
wasused and proved extremely efficient until now. Lately I have also used <a href="http://developer.kde.org/~sewardj/">valgrind</a>with quite somesuccess, mechanismwasused and proved extremely efficient until now. Lately I have also
it is tied to the i386 architecture since it works by emulating theprocessor used <a href="http://developer.kde.org/~sewardj/">valgrind</a>with quite
and instruction set, it is slow but extremely efficient, i.e. itspot memory somesuccess,it is tied to the i386 architecture since it works by emulating
usage errors in a very precise way.</p><h3><a name="General4" id="General4">General memory requirements</a></h3><p>How much libxml2 memory require ? It's hard to tell in average it theprocessorand instruction set, it is slow but extremely efficient, i.e.
dependsof a number of things:</p><ul><li>the parser itself should work in a fixed amount of memory, except itspot memoryusage errors in a very precise way.</p><h3><a name="General4" id="General4">General memory requirements</a></h3><p>How much libxml2 memory require ? It's hard to tell in average itdependsof
forinformation maintained about the stacks of names and entities a number of things:</p><ul><li>the parser itself should work in a fixed amount of memory,
locations.The I/O and encoding handlers will probably account for a few exceptforinformation maintained about the stacks of names and
KBytes.This is true for both the XML and HTML parser (though the HTML entitieslocations.The I/O and encoding handlers will probably account for
parserneed more state).</li> a fewKBytes.This is true for both the XML and HTML parser (though the
<li>If you are generating the DOM tree then memory requirements will HTMLparserneed more state).</li>
grownearly linear with the size of the data. In general for a <li>If you are generating the DOM tree then memory requirements
balancedtextual document the internal memory requirement is about 4 times willgrownearly linear with the size of the data. In general for
thesize of the UTF8 serialization of this document (example the abalancedtextual document the internal memory requirement is about 4
XML-1.0recommendation is a bit more of 150KBytes and takes 650KBytes of timesthesize of the UTF8 serialization of this document (example
mainmemory when parsed). Validation will add a amount of memory required theXML-1.0recommendation is a bit more of 150KBytes and takes 650KBytes
formaintaining the external Dtd state which should be linear with ofmainmemory when parsed). Validation will add a amount of memory
thecomplexity of the content model defined by the Dtd</li> requiredformaintaining the external Dtd state which should be linear
<li>If you need to work with fixed memory requirements or don't need withthecomplexity of the content model defined by the Dtd</li>
thefull DOM tree then using the <a href="xmlreader.html">xmlReaderinterface</a>is probably the best way to <li>If you need to work with fixed memory requirements or don't needthefull
proceed, it still allows tovalidate or operate on subset of the tree if DOM tree then using the <a href="xmlreader.html">xmlReaderinterface</a>is
needed.</li> probably the best way toproceed, it still allows tovalidate or operate on
<li>If you don't care about the advanced features of libxml2 subset of the tree ifneeded.</li>
likevalidation, DOM, XPath or XPointer, don't use entities, need to work <li>If you don't care about the advanced features of libxml2likevalidation,
withfixed memory requirements, and try to get the fastest parsing DOM, XPath or XPointer, don't use entities, need to workwithfixed memory
possiblethen the SAX interface should be used, but it has known requirements, and try to get the fastest parsingpossiblethen the SAX
restrictions.</li> interface should be used, but it has knownrestrictions.</li>
</ul><p></p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html> </ul><p></p><p><a href="bugs.html">Daniel Veillard</a></p></td></tr></table></td></tr></table></td></tr></table></td></tr></table></td></tr></table></body></html>