rsvg2 1.2.1-x86-mingw32 → 1.2.2-x86-mingw32
Sign up to get free protection for your applications and to get access to all the features.
- data/lib/1.9/rsvg2.so +0 -0
- data/lib/2.0/rsvg2.so +0 -0
- metadata +332 -508
- data/lib/1.8/rsvg2.so +0 -0
- data/vendor/local/manifest/libxml2-dev_2.7.7-1_win32.mft +0 -267
- data/vendor/local/manifest/libxml2_2.7.7-1_win32.mft +0 -2
- data/vendor/local/share/doc/libxml2-2.7.7/Copyright +0 -27
- data/vendor/local/share/doc/libxml2-2.7.7/examples/testHTML.c +0 -880
- data/vendor/local/share/doc/libxml2-2.7.7/examples/testSAX.c +0 -1198
- data/vendor/local/share/doc/libxml2-2.7.7/examples/testXPath.c +0 -227
- data/vendor/local/share/doc/libxml2-2.7.7/examples/xmllint.c +0 -3722
- data/vendor/local/share/doc/libxml2-2.7.7/html/DOM.gif +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/FAQ.html +0 -282
- data/vendor/local/share/doc/libxml2-2.7.7/html/Libxml2-Logo-180x168.gif +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/Libxml2-Logo-90x34.gif +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/encoding.html +0 -206
- data/vendor/local/share/doc/libxml2-2.7.7/html/examples.xml +0 -751
- data/vendor/local/share/doc/libxml2-2.7.7/html/examples.xsl +0 -174
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/book1.html +0 -13
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/home.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/index.html +0 -13
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/left.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-DOCBparser.html +0 -51
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-HTMLparser.html +0 -182
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-HTMLtree.html +0 -73
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-SAX.html +0 -125
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-SAX2.html +0 -128
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-c14n.html +0 -38
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-catalog.html +0 -142
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-chvalid.html +0 -72
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-debugXML.html +0 -120
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-dict.html +0 -49
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-encoding.html +0 -118
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-entities.html +0 -79
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-globals.html +0 -152
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-hash.html +0 -116
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-lib.html +0 -13
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-list.html +0 -120
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-nanoftp.html +0 -92
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-nanohttp.html +0 -65
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-parser.html +0 -555
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-parserInternals.html +0 -319
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-pattern.html +0 -76
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-relaxng.html +0 -162
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-schemasInternals.html +0 -373
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-schematron.html +0 -81
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-threads.html +0 -72
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-tree.html +0 -958
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-uri.html +0 -73
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-valid.html +0 -289
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xinclude.html +0 -59
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xlink.html +0 -82
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xmlIO.html +0 -206
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xmlautomata.html +0 -85
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xmlerror.html +0 -862
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xmlexports.html +0 -20
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xmlmemory.html +0 -107
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xmlmodule.html +0 -38
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xmlreader.html +0 -327
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xmlregexp.html +0 -143
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xmlsave.html +0 -59
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xmlschemas.html +0 -173
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xmlschemastypes.html +0 -123
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xmlstring.html +0 -108
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xmlunicode.html +0 -512
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xmlversion.html +0 -60
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xmlwriter.html +0 -258
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xpath.html +0 -307
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xpathInternals.html +0 -394
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/libxml-xpointer.html +0 -83
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/right.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/html/up.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/io1.c +0 -166
- data/vendor/local/share/doc/libxml2-2.7.7/html/io1.res +0 -5
- data/vendor/local/share/doc/libxml2-2.7.7/html/io2.c +0 -58
- data/vendor/local/share/doc/libxml2-2.7.7/html/io2.res +0 -2
- data/vendor/local/share/doc/libxml2-2.7.7/html/libxml.gif +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/parse1.c +0 -56
- data/vendor/local/share/doc/libxml2-2.7.7/html/parse2.c +0 -72
- data/vendor/local/share/doc/libxml2-2.7.7/html/parse3.c +0 -60
- data/vendor/local/share/doc/libxml2-2.7.7/html/parse4.c +0 -143
- data/vendor/local/share/doc/libxml2-2.7.7/html/reader1.c +0 -107
- data/vendor/local/share/doc/libxml2-2.7.7/html/reader1.res +0 -14
- data/vendor/local/share/doc/libxml2-2.7.7/html/reader2.c +0 -122
- data/vendor/local/share/doc/libxml2-2.7.7/html/reader3.c +0 -120
- data/vendor/local/share/doc/libxml2-2.7.7/html/reader3.res +0 -13
- data/vendor/local/share/doc/libxml2-2.7.7/html/reader4.c +0 -122
- data/vendor/local/share/doc/libxml2-2.7.7/html/reader4.res +0 -3
- data/vendor/local/share/doc/libxml2-2.7.7/html/redhat.gif +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/smallfootonly.gif +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/structure.gif +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/test1.xml +0 -1
- data/vendor/local/share/doc/libxml2-2.7.7/html/test2.xml +0 -13
- data/vendor/local/share/doc/libxml2-2.7.7/html/test3.xml +0 -39
- data/vendor/local/share/doc/libxml2-2.7.7/html/testWriter.c +0 -1198
- data/vendor/local/share/doc/libxml2-2.7.7/html/tree1.c +0 -94
- data/vendor/local/share/doc/libxml2-2.7.7/html/tree1.res +0 -4
- data/vendor/local/share/doc/libxml2-2.7.7/html/tree2.c +0 -118
- data/vendor/local/share/doc/libxml2-2.7.7/html/tree2.res +0 -18
- data/vendor/local/share/doc/libxml2-2.7.7/html/tst.xml +0 -7
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/apa.html +0 -8
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/apb.html +0 -14
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/apc.html +0 -82
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/apd.html +0 -76
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/ape.html +0 -78
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/apf.html +0 -67
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/apg.html +0 -75
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/aph.html +0 -76
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/api.html +0 -4
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/ar01s02.html +0 -14
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/ar01s03.html +0 -47
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/ar01s04.html +0 -54
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/ar01s05.html +0 -55
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/ar01s06.html +0 -35
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/ar01s07.html +0 -30
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/ar01s08.html +0 -38
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/ar01s09.html +0 -63
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/blank.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/callouts/1.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/callouts/10.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/callouts/2.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/callouts/3.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/callouts/4.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/callouts/5.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/callouts/6.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/callouts/7.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/callouts/8.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/callouts/9.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/caution.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/draft.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/home.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/important.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/next.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/note.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/prev.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/tip.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/toc-blank.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/toc-minus.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/toc-plus.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/up.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/images/warning.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/includeaddattribute.c +0 -64
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/includeaddkeyword.c +0 -75
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/includeconvert.c +0 -73
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/includegetattribute.c +0 -72
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/includekeyword.c +0 -79
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/includexpath.c +0 -74
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/index.html +0 -14
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/ix01.html +0 -1
- data/vendor/local/share/doc/libxml2-2.7.7/html/tutorial/xmltutorial.pdf +0 -1336
- data/vendor/local/share/doc/libxml2-2.7.7/html/w3c.png +0 -0
- data/vendor/local/share/doc/libxml2-2.7.7/html/writer.xml +0 -2
- data/vendor/local/share/doc/libxml2-2.7.7/html/xml.html +0 -5344
- data/vendor/local/share/doc/libxml2-2.7.7/html/xpath1.c +0 -250
- data/vendor/local/share/doc/libxml2-2.7.7/html/xpath1.res +0 -5
- data/vendor/local/share/doc/libxml2-2.7.7/html/xpath2.c +0 -190
- data/vendor/local/share/doc/libxml2-2.7.7/html/xpath2.res +0 -30
- data/vendor/local/src/tml/packaging/libxml2_2.7.7-1_win32.log +0 -1244
- data/vendor/local/src/tml/packaging/libxml2_2.7.7-1_win32.sh +0 -66
@@ -1,67 +0,0 @@
|
|
1
|
-
<html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>F.�Code for Add Attribute Example</title><meta name="generator" content="DocBook XSL Stylesheets V1.61.2"><link rel="home" href="index.html" title="Libxml Tutorial"><link rel="up" href="index.html" title="Libxml Tutorial"><link rel="previous" href="ape.html" title="E.�Code for Add Keyword Example"><link rel="next" href="apg.html" title="G.�Code for Retrieving Attribute Value Example"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center">F.�Code for Add Attribute Example</th></tr><tr><td width="20%" align="left"><a accesskey="p" href="ape.html">Prev</a>�</td><th width="60%" align="center">�</th><td width="20%" align="right">�<a accesskey="n" href="apg.html">Next</a></td></tr></table><hr></div><div class="appendix" lang="en"><div class="titlepage"><div><div><h2 class="title"><a name="addattributeappendix"></a>F.�Code for Add Attribute Example</h2></div></div><div></div></div><p>
|
2
|
-
</p><pre class="programlisting">
|
3
|
-
#include <stdio.h>
|
4
|
-
#include <string.h>
|
5
|
-
#include <stdlib.h>
|
6
|
-
#include <libxml/xmlmemory.h>
|
7
|
-
#include <libxml/parser.h>
|
8
|
-
|
9
|
-
|
10
|
-
xmlDocPtr
|
11
|
-
parseDoc(char *docname, char *uri) {
|
12
|
-
|
13
|
-
xmlDocPtr doc;
|
14
|
-
xmlNodePtr cur;
|
15
|
-
xmlNodePtr newnode;
|
16
|
-
xmlAttrPtr newattr;
|
17
|
-
|
18
|
-
doc = xmlParseFile(docname);
|
19
|
-
|
20
|
-
if (doc == NULL ) {
|
21
|
-
fprintf(stderr,"Document not parsed successfully. \n");
|
22
|
-
return (NULL);
|
23
|
-
}
|
24
|
-
|
25
|
-
cur = xmlDocGetRootElement(doc);
|
26
|
-
|
27
|
-
if (cur == NULL) {
|
28
|
-
fprintf(stderr,"empty document\n");
|
29
|
-
xmlFreeDoc(doc);
|
30
|
-
return (NULL);
|
31
|
-
}
|
32
|
-
|
33
|
-
if (xmlStrcmp(cur->name, (const xmlChar *) "story")) {
|
34
|
-
fprintf(stderr,"document of the wrong type, root node != story");
|
35
|
-
xmlFreeDoc(doc);
|
36
|
-
return (NULL);
|
37
|
-
}
|
38
|
-
|
39
|
-
newnode = xmlNewTextChild (cur, NULL, "reference", NULL);
|
40
|
-
newattr = xmlNewProp (newnode, "uri", uri);
|
41
|
-
return(doc);
|
42
|
-
}
|
43
|
-
|
44
|
-
int
|
45
|
-
main(int argc, char **argv) {
|
46
|
-
|
47
|
-
char *docname;
|
48
|
-
char *uri;
|
49
|
-
xmlDocPtr doc;
|
50
|
-
|
51
|
-
if (argc <= 2) {
|
52
|
-
printf("Usage: %s docname, uri\n", argv[0]);
|
53
|
-
return(0);
|
54
|
-
}
|
55
|
-
|
56
|
-
docname = argv[1];
|
57
|
-
uri = argv[2];
|
58
|
-
doc = parseDoc (docname, uri);
|
59
|
-
if (doc != NULL) {
|
60
|
-
xmlSaveFormatFile (docname, doc, 1);
|
61
|
-
xmlFreeDoc(doc);
|
62
|
-
}
|
63
|
-
return (1);
|
64
|
-
}
|
65
|
-
|
66
|
-
</pre><p>
|
67
|
-
</p></div><div class="navfooter"><hr><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="ape.html">Prev</a>�</td><td width="20%" align="center"><a accesskey="u" href="index.html">Up</a></td><td width="40%" align="right">�<a accesskey="n" href="apg.html">Next</a></td></tr><tr><td width="40%" align="left" valign="top">E.�Code for Add Keyword Example�</td><td width="20%" align="center"><a accesskey="h" href="index.html">Home</a></td><td width="40%" align="right" valign="top">�G.�Code for Retrieving Attribute Value Example</td></tr></table></div></body></html>
|
@@ -1,75 +0,0 @@
|
|
1
|
-
<html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>G.�Code for Retrieving Attribute Value Example</title><meta name="generator" content="DocBook XSL Stylesheets V1.61.2"><link rel="home" href="index.html" title="Libxml Tutorial"><link rel="up" href="index.html" title="Libxml Tutorial"><link rel="previous" href="apf.html" title="F.�Code for Add Attribute Example"><link rel="next" href="aph.html" title="H.�Code for Encoding Conversion Example"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center">G.�Code for Retrieving Attribute Value Example</th></tr><tr><td width="20%" align="left"><a accesskey="p" href="apf.html">Prev</a>�</td><th width="60%" align="center">�</th><td width="20%" align="right">�<a accesskey="n" href="aph.html">Next</a></td></tr></table><hr></div><div class="appendix" lang="en"><div class="titlepage"><div><div><h2 class="title"><a name="getattributeappendix"></a>G.�Code for Retrieving Attribute Value Example</h2></div></div><div></div></div><p>
|
2
|
-
</p><pre class="programlisting">
|
3
|
-
#include <stdio.h>
|
4
|
-
#include <string.h>
|
5
|
-
#include <stdlib.h>
|
6
|
-
#include <libxml/xmlmemory.h>
|
7
|
-
#include <libxml/parser.h>
|
8
|
-
|
9
|
-
void
|
10
|
-
getReference (xmlDocPtr doc, xmlNodePtr cur) {
|
11
|
-
|
12
|
-
xmlChar *uri;
|
13
|
-
cur = cur->xmlChildrenNode;
|
14
|
-
while (cur != NULL) {
|
15
|
-
if ((!xmlStrcmp(cur->name, (const xmlChar *)"reference"))) {
|
16
|
-
uri = xmlGetProp(cur, "uri");
|
17
|
-
printf("uri: %s\n", uri);
|
18
|
-
xmlFree(uri);
|
19
|
-
}
|
20
|
-
cur = cur->next;
|
21
|
-
}
|
22
|
-
return;
|
23
|
-
}
|
24
|
-
|
25
|
-
|
26
|
-
void
|
27
|
-
parseDoc(char *docname) {
|
28
|
-
|
29
|
-
xmlDocPtr doc;
|
30
|
-
xmlNodePtr cur;
|
31
|
-
|
32
|
-
doc = xmlParseFile(docname);
|
33
|
-
|
34
|
-
if (doc == NULL ) {
|
35
|
-
fprintf(stderr,"Document not parsed successfully. \n");
|
36
|
-
return;
|
37
|
-
}
|
38
|
-
|
39
|
-
cur = xmlDocGetRootElement(doc);
|
40
|
-
|
41
|
-
if (cur == NULL) {
|
42
|
-
fprintf(stderr,"empty document\n");
|
43
|
-
xmlFreeDoc(doc);
|
44
|
-
return;
|
45
|
-
}
|
46
|
-
|
47
|
-
if (xmlStrcmp(cur->name, (const xmlChar *) "story")) {
|
48
|
-
fprintf(stderr,"document of the wrong type, root node != story");
|
49
|
-
xmlFreeDoc(doc);
|
50
|
-
return;
|
51
|
-
}
|
52
|
-
|
53
|
-
getReference (doc, cur);
|
54
|
-
xmlFreeDoc(doc);
|
55
|
-
return;
|
56
|
-
}
|
57
|
-
|
58
|
-
int
|
59
|
-
main(int argc, char **argv) {
|
60
|
-
|
61
|
-
char *docname;
|
62
|
-
|
63
|
-
if (argc <= 1) {
|
64
|
-
printf("Usage: %s docname\n", argv[0]);
|
65
|
-
return(0);
|
66
|
-
}
|
67
|
-
|
68
|
-
docname = argv[1];
|
69
|
-
parseDoc (docname);
|
70
|
-
|
71
|
-
return (1);
|
72
|
-
}
|
73
|
-
|
74
|
-
</pre><p>
|
75
|
-
</p></div><div class="navfooter"><hr><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="apf.html">Prev</a>�</td><td width="20%" align="center"><a accesskey="u" href="index.html">Up</a></td><td width="40%" align="right">�<a accesskey="n" href="aph.html">Next</a></td></tr><tr><td width="40%" align="left" valign="top">F.�Code for Add Attribute Example�</td><td width="20%" align="center"><a accesskey="h" href="index.html">Home</a></td><td width="40%" align="right" valign="top">�H.�Code for Encoding Conversion Example</td></tr></table></div></body></html>
|
@@ -1,76 +0,0 @@
|
|
1
|
-
<html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>H.�Code for Encoding Conversion Example</title><meta name="generator" content="DocBook XSL Stylesheets V1.61.2"><link rel="home" href="index.html" title="Libxml Tutorial"><link rel="up" href="index.html" title="Libxml Tutorial"><link rel="previous" href="apg.html" title="G.�Code for Retrieving Attribute Value Example"><link rel="next" href="api.html" title="I.�Acknowledgements"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center">H.�Code for Encoding Conversion Example</th></tr><tr><td width="20%" align="left"><a accesskey="p" href="apg.html">Prev</a>�</td><th width="60%" align="center">�</th><td width="20%" align="right">�<a accesskey="n" href="api.html">Next</a></td></tr></table><hr></div><div class="appendix" lang="en"><div class="titlepage"><div><div><h2 class="title"><a name="convertappendix"></a>H.�Code for Encoding Conversion Example</h2></div></div><div></div></div><p>
|
2
|
-
</p><pre class="programlisting">
|
3
|
-
#include <string.h>
|
4
|
-
#include <libxml/parser.h>
|
5
|
-
|
6
|
-
|
7
|
-
unsigned char*
|
8
|
-
convert (unsigned char *in, char *encoding)
|
9
|
-
{
|
10
|
-
unsigned char *out;
|
11
|
-
int ret,size,out_size,temp;
|
12
|
-
xmlCharEncodingHandlerPtr handler;
|
13
|
-
|
14
|
-
size = (int)strlen(in)+1;
|
15
|
-
out_size = size*2-1;
|
16
|
-
out = malloc((size_t)out_size);
|
17
|
-
|
18
|
-
if (out) {
|
19
|
-
handler = xmlFindCharEncodingHandler(encoding);
|
20
|
-
|
21
|
-
if (!handler) {
|
22
|
-
free(out);
|
23
|
-
out = NULL;
|
24
|
-
}
|
25
|
-
}
|
26
|
-
if (out) {
|
27
|
-
temp=size-1;
|
28
|
-
ret = handler->input(out, &out_size, in, &temp);
|
29
|
-
if (ret || temp-size+1) {
|
30
|
-
if (ret) {
|
31
|
-
printf("conversion wasn't successful.\n");
|
32
|
-
} else {
|
33
|
-
printf("conversion wasn't successful. converted: %i octets.\n",temp);
|
34
|
-
}
|
35
|
-
free(out);
|
36
|
-
out = NULL;
|
37
|
-
} else {
|
38
|
-
out = realloc(out,out_size+1);
|
39
|
-
out[out_size]=0; /*null terminating out*/
|
40
|
-
|
41
|
-
}
|
42
|
-
} else {
|
43
|
-
printf("no mem\n");
|
44
|
-
}
|
45
|
-
return (out);
|
46
|
-
}
|
47
|
-
|
48
|
-
|
49
|
-
int
|
50
|
-
main(int argc, char **argv) {
|
51
|
-
|
52
|
-
unsigned char *content, *out;
|
53
|
-
xmlDocPtr doc;
|
54
|
-
xmlNodePtr rootnode;
|
55
|
-
char *encoding = "ISO-8859-1";
|
56
|
-
|
57
|
-
|
58
|
-
if (argc <= 1) {
|
59
|
-
printf("Usage: %s content\n", argv[0]);
|
60
|
-
return(0);
|
61
|
-
}
|
62
|
-
|
63
|
-
content = argv[1];
|
64
|
-
|
65
|
-
out = convert(content, encoding);
|
66
|
-
|
67
|
-
doc = xmlNewDoc ("1.0");
|
68
|
-
rootnode = xmlNewDocNode(doc, NULL, (const xmlChar*)"root", out);
|
69
|
-
xmlDocSetRootElement(doc, rootnode);
|
70
|
-
|
71
|
-
xmlSaveFormatFileEnc("-", doc, encoding, 1);
|
72
|
-
return (1);
|
73
|
-
}
|
74
|
-
|
75
|
-
</pre><p>
|
76
|
-
</p></div><div class="navfooter"><hr><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="apg.html">Prev</a>�</td><td width="20%" align="center"><a accesskey="u" href="index.html">Up</a></td><td width="40%" align="right">�<a accesskey="n" href="api.html">Next</a></td></tr><tr><td width="40%" align="left" valign="top">G.�Code for Retrieving Attribute Value Example�</td><td width="20%" align="center"><a accesskey="h" href="index.html">Home</a></td><td width="40%" align="right" valign="top">�I.�Acknowledgements</td></tr></table></div></body></html>
|
@@ -1,4 +0,0 @@
|
|
1
|
-
<html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>I.�Acknowledgements</title><meta name="generator" content="DocBook XSL Stylesheets V1.61.2"><link rel="home" href="index.html" title="Libxml Tutorial"><link rel="up" href="index.html" title="Libxml Tutorial"><link rel="previous" href="aph.html" title="H.�Code for Encoding Conversion Example"><link rel="next" href="ix01.html" title="Index"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center">I.�Acknowledgements</th></tr><tr><td width="20%" align="left"><a accesskey="p" href="aph.html">Prev</a>�</td><th width="60%" align="center">�</th><td width="20%" align="right">�<a accesskey="n" href="ix01.html">Next</a></td></tr></table><hr></div><div class="appendix" lang="en"><div class="titlepage"><div><div><h2 class="title"><a name="id2588597"></a>I.�Acknowledgements</h2></div></div><div></div></div><p>A number of people have generously offered feedback, code and
|
2
|
-
suggested improvements to this tutorial. In no particular order:
|
3
|
-
<span class="simplelist">Daniel Veillard, Marcus Labib Iskander, Christopher R. Harris, Igor Zlatkovic, Niraj Tolia, David Turover</span>
|
4
|
-
</p></div><div class="navfooter"><hr><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="aph.html">Prev</a>�</td><td width="20%" align="center"><a accesskey="u" href="index.html">Up</a></td><td width="40%" align="right">�<a accesskey="n" href="ix01.html">Next</a></td></tr><tr><td width="40%" align="left" valign="top">H.�Code for Encoding Conversion Example�</td><td width="20%" align="center"><a accesskey="h" href="index.html">Home</a></td><td width="40%" align="right" valign="top">�Index</td></tr></table></div></body></html>
|
@@ -1,14 +0,0 @@
|
|
1
|
-
<html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>Data Types</title><meta name="generator" content="DocBook XSL Stylesheets V1.61.2"><link rel="home" href="index.html" title="Libxml Tutorial"><link rel="up" href="index.html" title="Libxml Tutorial"><link rel="previous" href="index.html" title="Libxml Tutorial"><link rel="next" href="ar01s03.html" title="Parsing the file"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center">Data Types</th></tr><tr><td width="20%" align="left"><a accesskey="p" href="index.html">Prev</a>�</td><th width="60%" align="center">�</th><td width="20%" align="right">�<a accesskey="n" href="ar01s03.html">Next</a></td></tr></table><hr></div><div class="sect1" lang="en"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a name="xmltutorialdatatypes"></a>Data Types</h2></div></div><div></div></div><p><span class="application">Libxml</span> declares a number of data types we
|
2
|
-
will encounter repeatedly, hiding the messy stuff so you do not have to deal
|
3
|
-
with it unless you have some specific need.</p><p>
|
4
|
-
</p><div class="variablelist"><dl><dt><span class="term"><a class="indexterm" name="id2526186"></a>
|
5
|
-
<a href="http://xmlsoft.org/html/libxml-tree.html#XMLCHAR" target="_top">xmlChar</a></span></dt><dd><p>A basic replacement for char, a byte in a UTF-8 encoded
|
6
|
-
string. If your data uses another encoding, it must be converted to
|
7
|
-
UTF-8 for use with <span class="application">libxml's</span>
|
8
|
-
functions. More information on encoding is available on the <a href="http://www.xmlsoft.org/encoding.html" target="_top"><span class="application">libxml</span> encoding support web page</a>.</p></dd><dt><span class="term"><a class="indexterm" name="id2526232"></a>
|
9
|
-
<a href="http://xmlsoft.org/html/libxml-tree.html#XMLDOC" target="_top">xmlDoc</a></span></dt><dd><p>A structure containing the tree created by a parsed doc. <a href="http://xmlsoft.org/html/libxml-tree.html#XMLDOCPTR" target="_top">xmlDocPtr</a>
|
10
|
-
is a pointer to the structure.</p></dd><dt><span class="term"><a class="indexterm" name="id2526266"></a>
|
11
|
-
<a href="http://xmlsoft.org/html/libxml-tree.html#XMLNODEPTR" target="_top">xmlNodePtr</a>
|
12
|
-
and <a href="http://xmlsoft.org/html/libxml-tree.html#XMLNODE" target="_top">xmlNode</a></span></dt><dd><p>A structure containing a single node. <a href="http://xmlsoft.org/html/libxml-tree.html#XMLNODEPTR" target="_top">xmlNodePtr</a>
|
13
|
-
is a pointer to the structure, and is used in traversing the document tree.</p></dd></dl></div><p>
|
14
|
-
</p></div><div class="navfooter"><hr><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="index.html">Prev</a>�</td><td width="20%" align="center"><a accesskey="u" href="index.html">Up</a></td><td width="40%" align="right">�<a accesskey="n" href="ar01s03.html">Next</a></td></tr><tr><td width="40%" align="left" valign="top">Libxml Tutorial�</td><td width="20%" align="center"><a accesskey="h" href="index.html">Home</a></td><td width="40%" align="right" valign="top">�Parsing the file</td></tr></table></div></body></html>
|
@@ -1,47 +0,0 @@
|
|
1
|
-
<html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>Parsing the file</title><meta name="generator" content="DocBook XSL Stylesheets V1.61.2"><link rel="home" href="index.html" title="Libxml Tutorial"><link rel="up" href="index.html" title="Libxml Tutorial"><link rel="previous" href="ar01s02.html" title="Data Types"><link rel="next" href="ar01s04.html" title="Retrieving Element Content"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center">Parsing the file</th></tr><tr><td width="20%" align="left"><a accesskey="p" href="ar01s02.html">Prev</a>�</td><th width="60%" align="center">�</th><td width="20%" align="right">�<a accesskey="n" href="ar01s04.html">Next</a></td></tr></table><hr></div><div class="sect1" lang="en"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a name="xmltutorialparsing"></a>Parsing the file</h2></div></div><div></div></div><p><a class="indexterm" name="fileparsing"></a>
|
2
|
-
Parsing the file requires only the name of the file and a single
|
3
|
-
function call, plus error checking. Full code: <a href="apc.html" title="C.�Code for Keyword Example">Appendix�C, <i>Code for Keyword Example</i></a></p><p>
|
4
|
-
</p><pre class="programlisting">
|
5
|
-
<a name="declaredoc"></a><img src="images/callouts/1.png" alt="1" border="0"> xmlDocPtr doc;
|
6
|
-
<a name="declarenode"></a><img src="images/callouts/2.png" alt="2" border="0"> xmlNodePtr cur;
|
7
|
-
|
8
|
-
<a name="parsefile"></a><img src="images/callouts/3.png" alt="3" border="0"> doc = xmlParseFile(docname);
|
9
|
-
|
10
|
-
<a name="checkparseerror"></a><img src="images/callouts/4.png" alt="4" border="0"> if (doc == NULL ) {
|
11
|
-
fprintf(stderr,"Document not parsed successfully. \n");
|
12
|
-
return;
|
13
|
-
}
|
14
|
-
|
15
|
-
<a name="getrootelement"></a><img src="images/callouts/5.png" alt="5" border="0"> cur = xmlDocGetRootElement(doc);
|
16
|
-
|
17
|
-
<a name="checkemptyerror"></a><img src="images/callouts/6.png" alt="6" border="0"> if (cur == NULL) {
|
18
|
-
fprintf(stderr,"empty document\n");
|
19
|
-
xmlFreeDoc(doc);
|
20
|
-
return;
|
21
|
-
}
|
22
|
-
|
23
|
-
<a name="checkroottype"></a><img src="images/callouts/7.png" alt="7" border="0"> if (xmlStrcmp(cur->name, (const xmlChar *) "story")) {
|
24
|
-
fprintf(stderr,"document of the wrong type, root node != story");
|
25
|
-
xmlFreeDoc(doc);
|
26
|
-
return;
|
27
|
-
}
|
28
|
-
|
29
|
-
</pre><p>
|
30
|
-
</p><div class="calloutlist"><table border="0" summary="Callout list"><tr><td width="5%" valign="top" align="left"><a href="#declaredoc"><img src="images/callouts/1.png" alt="1" border="0"></a> </td><td valign="top" align="left"><p>Declare the pointer that will point to your parsed document.</p></td></tr><tr><td width="5%" valign="top" align="left"><a href="#declarenode"><img src="images/callouts/2.png" alt="2" border="0"></a> </td><td valign="top" align="left"><p>Declare a node pointer (you'll need this in order to
|
31
|
-
interact with individual nodes).</p></td></tr><tr><td width="5%" valign="top" align="left"><a href="#checkparseerror"><img src="images/callouts/4.png" alt="4" border="0"></a> </td><td valign="top" align="left"><p>Check to see that the document was successfully parsed. If it
|
32
|
-
was not, <span class="application">libxml</span> will at this point
|
33
|
-
register an error and stop.
|
34
|
-
</p><div class="note" style="margin-left: 0.5in; margin-right: 0.5in;"><table border="0" summary="Note"><tr><td rowspan="2" align="center" valign="top" width="25"><img alt="[Note]" src="images/note.png"></td><th align="left">Note</th></tr><tr><td colspan="2" align="left" valign="top"><p><a class="indexterm" name="id2525337"></a>
|
35
|
-
One common example of an error at this point is improper
|
36
|
-
handling of encoding. The <span class="acronym">XML</span> standard requires
|
37
|
-
documents stored with an encoding other than UTF-8 or UTF-16 to
|
38
|
-
contain an explicit declaration of their encoding. If the
|
39
|
-
declaration is there, <span class="application">libxml</span> will
|
40
|
-
automatically perform the necessary conversion to UTF-8 for
|
41
|
-
you. More information on <span class="acronym">XML's</span> encoding
|
42
|
-
requirements is contained in the <a href="http://www.w3.org/TR/REC-xml#charencoding" target="_top">standard</a>.</p></td></tr></table></div><p>
|
43
|
-
</p></td></tr><tr><td width="5%" valign="top" align="left"><a href="#getrootelement"><img src="images/callouts/5.png" alt="5" border="0"></a> </td><td valign="top" align="left"><p>Retrieve the document's root element.</p></td></tr><tr><td width="5%" valign="top" align="left"><a href="#checkemptyerror"><img src="images/callouts/6.png" alt="6" border="0"></a> </td><td valign="top" align="left"><p>Check to make sure the document actually contains something.</p></td></tr><tr><td width="5%" valign="top" align="left"><a href="#checkroottype"><img src="images/callouts/7.png" alt="7" border="0"></a> </td><td valign="top" align="left"><p>In our case, we need to make sure the document is the right
|
44
|
-
type. "story" is the root type of the documents used in this
|
45
|
-
tutorial.</p></td></tr></table></div><p>
|
46
|
-
<a class="indexterm" name="id2525415"></a>
|
47
|
-
</p></div><div class="navfooter"><hr><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="ar01s02.html">Prev</a>�</td><td width="20%" align="center"><a accesskey="u" href="index.html">Up</a></td><td width="40%" align="right">�<a accesskey="n" href="ar01s04.html">Next</a></td></tr><tr><td width="40%" align="left" valign="top">Data Types�</td><td width="20%" align="center"><a accesskey="h" href="index.html">Home</a></td><td width="40%" align="right" valign="top">�Retrieving Element Content</td></tr></table></div></body></html>
|
@@ -1,54 +0,0 @@
|
|
1
|
-
<html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>Retrieving Element Content</title><meta name="generator" content="DocBook XSL Stylesheets V1.61.2"><link rel="home" href="index.html" title="Libxml Tutorial"><link rel="up" href="index.html" title="Libxml Tutorial"><link rel="previous" href="ar01s03.html" title="Parsing the file"><link rel="next" href="ar01s05.html" title="Using XPath to Retrieve Element Content"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center">Retrieving Element Content</th></tr><tr><td width="20%" align="left"><a accesskey="p" href="ar01s03.html">Prev</a>�</td><th width="60%" align="center">�</th><td width="20%" align="right">�<a accesskey="n" href="ar01s05.html">Next</a></td></tr></table><hr></div><div class="sect1" lang="en"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a name="xmltutorialgettext"></a>Retrieving Element Content</h2></div></div><div></div></div><p><a class="indexterm" name="id2525439"></a>
|
2
|
-
Retrieving the content of an element involves traversing the document
|
3
|
-
tree until you find what you are looking for. In this case, we are looking
|
4
|
-
for an element called "keyword" contained within element called "story". The
|
5
|
-
process to find the node we are interested in involves tediously walking the
|
6
|
-
tree. We assume you already have an xmlDocPtr called <tt class="varname">doc</tt>
|
7
|
-
and an xmlNodPtr called <tt class="varname">cur</tt>.</p><p>
|
8
|
-
</p><pre class="programlisting">
|
9
|
-
<a name="getchildnode"></a><img src="images/callouts/1.png" alt="1" border="0">cur = cur->xmlChildrenNode;
|
10
|
-
<a name="huntstoryinfo"></a><img src="images/callouts/2.png" alt="2" border="0">while (cur != NULL) {
|
11
|
-
if ((!xmlStrcmp(cur->name, (const xmlChar *)"storyinfo"))){
|
12
|
-
parseStory (doc, cur);
|
13
|
-
}
|
14
|
-
|
15
|
-
cur = cur->next;
|
16
|
-
}
|
17
|
-
</pre><p>
|
18
|
-
|
19
|
-
</p><div class="calloutlist"><table border="0" summary="Callout list"><tr><td width="5%" valign="top" align="left"><a href="#getchildnode"><img src="images/callouts/1.png" alt="1" border="0"></a> </td><td valign="top" align="left"><p>Get the first child node of <tt class="varname">cur</tt>. At this
|
20
|
-
point, <tt class="varname">cur</tt> points at the document root, which is
|
21
|
-
the element "story".</p></td></tr><tr><td width="5%" valign="top" align="left"><a href="#huntstoryinfo"><img src="images/callouts/2.png" alt="2" border="0"></a> </td><td valign="top" align="left"><p>This loop iterates through the elements that are children of
|
22
|
-
"story", looking for one called "storyinfo". That
|
23
|
-
is the element that will contain the "keywords" we are
|
24
|
-
looking for. It uses the <span class="application">libxml</span> string
|
25
|
-
comparison
|
26
|
-
function, <tt class="function"><a href="http://xmlsoft.org/html/libxml-parser.html#XMLSTRCMP" target="_top">xmlStrcmp</a></tt>. If there is a match, it calls the function <tt class="function">parseStory</tt>.</p></td></tr></table></div><p>
|
27
|
-
</p><p>
|
28
|
-
</p><pre class="programlisting">
|
29
|
-
void
|
30
|
-
parseStory (xmlDocPtr doc, xmlNodePtr cur) {
|
31
|
-
|
32
|
-
xmlChar *key;
|
33
|
-
<a name="anothergetchild"></a><img src="images/callouts/1.png" alt="1" border="0"> cur = cur->xmlChildrenNode;
|
34
|
-
<a name="findkeyword"></a><img src="images/callouts/2.png" alt="2" border="0"> while (cur != NULL) {
|
35
|
-
if ((!xmlStrcmp(cur->name, (const xmlChar *)"keyword"))) {
|
36
|
-
<a name="foundkeyword"></a><img src="images/callouts/3.png" alt="3" border="0"> key = xmlNodeListGetString(doc, cur->xmlChildrenNode, 1);
|
37
|
-
printf("keyword: %s\n", key);
|
38
|
-
xmlFree(key);
|
39
|
-
}
|
40
|
-
cur = cur->next;
|
41
|
-
}
|
42
|
-
return;
|
43
|
-
}
|
44
|
-
</pre><p>
|
45
|
-
</p><div class="calloutlist"><table border="0" summary="Callout list"><tr><td width="5%" valign="top" align="left"><a href="#anothergetchild"><img src="images/callouts/1.png" alt="1" border="0"></a> </td><td valign="top" align="left"><p>Again we get the first child node.</p></td></tr><tr><td width="5%" valign="top" align="left"><a href="#findkeyword"><img src="images/callouts/2.png" alt="2" border="0"></a> </td><td valign="top" align="left"><p>Like the loop above, we then iterate through the nodes, looking
|
46
|
-
for one that matches the element we're interested in, in this case
|
47
|
-
"keyword".</p></td></tr><tr><td width="5%" valign="top" align="left"><a href="#foundkeyword"><img src="images/callouts/3.png" alt="3" border="0"></a> </td><td valign="top" align="left"><p>When we find the "keyword" element, we need to print
|
48
|
-
its contents. Remember that in <span class="acronym">XML</span>, the text
|
49
|
-
contained within an element is a child node of that element, so we
|
50
|
-
turn to <tt class="varname">cur->xmlChildrenNode</tt>. To retrieve it, we
|
51
|
-
use the function <tt class="function"><a href="http://xmlsoft.org/html/libxml-tree.html#XMLNODELISTGETSTRING" target="_top">xmlNodeListGetString</a></tt>, which also takes the <tt class="varname">doc</tt> pointer as an argument. In this case, we just print it out.</p><div class="note" style="margin-left: 0.5in; margin-right: 0.5in;"><table border="0" summary="Note"><tr><td rowspan="2" align="center" valign="top" width="25"><img alt="[Note]" src="images/note.png"></td><th align="left">Note</th></tr><tr><td colspan="2" align="left" valign="top"><p>Because <tt class="function">xmlNodeListGetString</tt> allocates
|
52
|
-
memory for the string it returns, you must use
|
53
|
-
<tt class="function">xmlFree</tt> to free it.</p></td></tr></table></div></td></tr></table></div><p>
|
54
|
-
</p></div><div class="navfooter"><hr><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="ar01s03.html">Prev</a>�</td><td width="20%" align="center"><a accesskey="u" href="index.html">Up</a></td><td width="40%" align="right">�<a accesskey="n" href="ar01s05.html">Next</a></td></tr><tr><td width="40%" align="left" valign="top">Parsing the file�</td><td width="20%" align="center"><a accesskey="h" href="index.html">Home</a></td><td width="40%" align="right" valign="top">�Using XPath to Retrieve Element Content</td></tr></table></div></body></html>
|
@@ -1,55 +0,0 @@
|
|
1
|
-
<html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>Using XPath to Retrieve Element Content</title><meta name="generator" content="DocBook XSL Stylesheets V1.61.2"><link rel="home" href="index.html" title="Libxml Tutorial"><link rel="up" href="index.html" title="Libxml Tutorial"><link rel="previous" href="ar01s04.html" title="Retrieving Element Content"><link rel="next" href="ar01s06.html" title="Writing element content"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center">Using XPath to Retrieve Element Content</th></tr><tr><td width="20%" align="left"><a accesskey="p" href="ar01s04.html">Prev</a>�</td><th width="60%" align="center">�</th><td width="20%" align="right">�<a accesskey="n" href="ar01s06.html">Next</a></td></tr></table><hr></div><div class="sect1" lang="en"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a name="xmltutorialxpath"></a>Using XPath to Retrieve Element Content</h2></div></div><div></div></div><p>In addition to walking the document tree to find an element,
|
2
|
-
<span class="application">Libxml2</span> includes support for
|
3
|
-
use of <span class="application">XPath</span> expressions to retrieve sets of
|
4
|
-
nodes that match a specified criteria. Full documentation of the
|
5
|
-
<span class="application">XPath</span> <span class="acronym">API</span> is <a href="http://xmlsoft.org/html/libxml-xpath.html" target="_top">here</a>.
|
6
|
-
</p><p><span class="application">XPath</span> allows searching through a document
|
7
|
-
for nodes that match specified criteria. In the example below we search
|
8
|
-
through a document for the contents of all <tt class="varname">keyword</tt>
|
9
|
-
elements.
|
10
|
-
</p><div class="note" style="margin-left: 0.5in; margin-right: 0.5in;"><table border="0" summary="Note"><tr><td rowspan="2" align="center" valign="top" width="25"><img alt="[Note]" src="images/note.png"></td><th align="left">Note</th></tr><tr><td colspan="2" align="left" valign="top"><p>A full discussion of <span class="application">XPath</span> is beyond
|
11
|
-
the scope of this document. For details on its use, see the <a href="http://www.w3.org/TR/xpath" target="_top">XPath specification</a>.</p></td></tr></table></div><p>
|
12
|
-
Full code for this example is at <a href="apd.html" title="D.�Code for XPath Example">Appendix�D, <i>Code for XPath Example</i></a>.
|
13
|
-
</p><p>Using <span class="application">XPath</span> requires setting up an
|
14
|
-
xmlXPathContext and then supplying the <span class="application">XPath</span>
|
15
|
-
expression and the context to the
|
16
|
-
<tt class="function">xmlXPathEvalExpression</tt> function. The function returns
|
17
|
-
an xmlXPathObjectPtr, which includes the set of nodes satisfying the
|
18
|
-
<span class="application">XPath</span> expression.</p><p>
|
19
|
-
</p><pre class="programlisting">
|
20
|
-
xmlXPathObjectPtr
|
21
|
-
getnodeset (xmlDocPtr doc, xmlChar *xpath){
|
22
|
-
|
23
|
-
<a name="cocontext"></a><img src="images/callouts/1.png" alt="1" border="0">xmlXPathContextPtr context;
|
24
|
-
xmlXPathObjectPtr result;
|
25
|
-
|
26
|
-
<a name="cocreatecontext"></a><img src="images/callouts/2.png" alt="2" border="0">context = xmlXPathNewContext(doc);
|
27
|
-
<a name="corunxpath"></a><img src="images/callouts/3.png" alt="3" border="0">result = xmlXPathEvalExpression(xpath, context);
|
28
|
-
<a name="cocheckxpathresult"></a><img src="images/callouts/4.png" alt="4" border="0">if(xmlXPathNodeSetIsEmpty(result->nodesetval)){
|
29
|
-
xmlXPathFreeObject(result);
|
30
|
-
printf("No result\n");
|
31
|
-
return NULL;
|
32
|
-
</pre><p>
|
33
|
-
</p><div class="calloutlist"><table border="0" summary="Callout list"><tr><td width="5%" valign="top" align="left"><a href="#cocontext"><img src="images/callouts/1.png" alt="1" border="0"></a> </td><td valign="top" align="left"><p>First we declare our variables.</p></td></tr><tr><td width="5%" valign="top" align="left"><a href="#cocreatecontext"><img src="images/callouts/2.png" alt="2" border="0"></a> </td><td valign="top" align="left"><p>Initialize the <tt class="varname">context</tt> variable.</p></td></tr><tr><td width="5%" valign="top" align="left"><a href="#corunxpath"><img src="images/callouts/3.png" alt="3" border="0"></a> </td><td valign="top" align="left"><p>Apply the <span class="application">XPath</span> expression.</p></td></tr><tr><td width="5%" valign="top" align="left"><a href="#cocheckxpathresult"><img src="images/callouts/4.png" alt="4" border="0"></a> </td><td valign="top" align="left"><p>Check the result and free the memory allocated to
|
34
|
-
<tt class="varname">result</tt> if no result is found.</p></td></tr></table></div><p>
|
35
|
-
</p><p>The xmlPathObjectPtr returned by the function contains a set of nodes
|
36
|
-
and other information needed to iterate through the set and act on the
|
37
|
-
results. For this example, our functions returns the
|
38
|
-
<tt class="varname">xmlXPathObjectPtr</tt>. We use it to print the contents of
|
39
|
-
<tt class="varname">keyword</tt> nodes in our document. The node set object
|
40
|
-
includes the number of elements in the set (<tt class="varname">nodeNr</tt>) and
|
41
|
-
an array of nodes (<tt class="varname">nodeTab</tt>):
|
42
|
-
</p><pre class="programlisting">
|
43
|
-
<a name="conodesetcounter"></a><img src="images/callouts/1.png" alt="1" border="0">for (i=0; i < nodeset->nodeNr; i++) {
|
44
|
-
<a name="coprintkeywords"></a><img src="images/callouts/2.png" alt="2" border="0">keyword = xmlNodeListGetString(doc, nodeset->nodeTab[i]->xmlChildrenNode, 1);
|
45
|
-
printf("keyword: %s\n", keyword);
|
46
|
-
xmlFree(keyword);
|
47
|
-
}
|
48
|
-
</pre><p>
|
49
|
-
</p><div class="calloutlist"><table border="0" summary="Callout list"><tr><td width="5%" valign="top" align="left"><a href="#conodesetcounter"><img src="images/callouts/1.png" alt="1" border="0"></a> </td><td valign="top" align="left"><p>The value of <tt class="varname">nodeset->Nr</tt> holds the number of
|
50
|
-
elements in the node set. Here we use it to iterate through the array.</p></td></tr><tr><td width="5%" valign="top" align="left"><a href="#coprintkeywords"><img src="images/callouts/2.png" alt="2" border="0"></a> </td><td valign="top" align="left"><p>Here we print the contents of each of the nodes returned.
|
51
|
-
</p><div class="note" style="margin-left: 0.5in; margin-right: 0.5in;"><table border="0" summary="Note"><tr><td rowspan="2" align="center" valign="top" width="25"><img alt="[Note]" src="images/note.png"></td><th align="left">Note</th></tr><tr><td colspan="2" align="left" valign="top"><p>Note that we are printing the child node of the node that is
|
52
|
-
returned, because the contents of the <tt class="varname">keyword</tt>
|
53
|
-
element are a child text node.</p></td></tr></table></div><p>
|
54
|
-
</p></td></tr></table></div><p>
|
55
|
-
</p></div><div class="navfooter"><hr><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="ar01s04.html">Prev</a>�</td><td width="20%" align="center"><a accesskey="u" href="index.html">Up</a></td><td width="40%" align="right">�<a accesskey="n" href="ar01s06.html">Next</a></td></tr><tr><td width="40%" align="left" valign="top">Retrieving Element Content�</td><td width="20%" align="center"><a accesskey="h" href="index.html">Home</a></td><td width="40%" align="right" valign="top">�Writing element content</td></tr></table></div></body></html>
|
@@ -1,35 +0,0 @@
|
|
1
|
-
<html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>Writing element content</title><meta name="generator" content="DocBook XSL Stylesheets V1.61.2"><link rel="home" href="index.html" title="Libxml Tutorial"><link rel="up" href="index.html" title="Libxml Tutorial"><link rel="previous" href="ar01s05.html" title="Using XPath to Retrieve Element Content"><link rel="next" href="ar01s07.html" title="Writing Attribute"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center">Writing element content</th></tr><tr><td width="20%" align="left"><a accesskey="p" href="ar01s05.html">Prev</a>�</td><th width="60%" align="center">�</th><td width="20%" align="right">�<a accesskey="n" href="ar01s07.html">Next</a></td></tr></table><hr></div><div class="sect1" lang="en"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a name="xmltutorialwritingcontent"></a>Writing element content</h2></div></div><div></div></div><p><a class="indexterm" name="id2586968"></a>
|
2
|
-
Writing element content uses many of the same steps we used above
|
3
|
-
— parsing the document and walking the tree. We parse the document,
|
4
|
-
then traverse the tree to find the place we want to insert our element. For
|
5
|
-
this example, we want to again find the "storyinfo" element and
|
6
|
-
this time insert a keyword. Then we'll write the file to disk. Full code:
|
7
|
-
<a href="ape.html" title="E.�Code for Add Keyword Example">Appendix�E, <i>Code for Add Keyword Example</i></a></p><p>
|
8
|
-
The main difference in this example is in
|
9
|
-
<tt class="function">parseStory</tt>:
|
10
|
-
|
11
|
-
</p><pre class="programlisting">
|
12
|
-
void
|
13
|
-
parseStory (xmlDocPtr doc, xmlNodePtr cur, char *keyword) {
|
14
|
-
|
15
|
-
<a name="addkeyword"></a><img src="images/callouts/1.png" alt="1" border="0"> xmlNewTextChild (cur, NULL, "keyword", keyword);
|
16
|
-
return;
|
17
|
-
}
|
18
|
-
</pre><p>
|
19
|
-
</p><div class="calloutlist"><table border="0" summary="Callout list"><tr><td width="5%" valign="top" align="left"><a href="#addkeyword"><img src="images/callouts/1.png" alt="1" border="0"></a> </td><td valign="top" align="left"><p>The <tt class="function"><a href="http://xmlsoft.org/html/libxml-tree.html#XMLNEWTEXTCHILD" target="_top">xmlNewTextChild</a></tt>
|
20
|
-
function adds a new child element at the
|
21
|
-
current node pointer's location in the
|
22
|
-
tree, specified by <tt class="varname">cur</tt>.</p></td></tr></table></div><p>
|
23
|
-
</p><p>
|
24
|
-
<a class="indexterm" name="id2587052"></a>
|
25
|
-
Once the node has been added, we would like to write the document to
|
26
|
-
file. Is you want the element to have a namespace, you can add it here as
|
27
|
-
well. In our case, the namespace is NULL.
|
28
|
-
</p><pre class="programlisting">
|
29
|
-
xmlSaveFormatFile (docname, doc, 1);
|
30
|
-
</pre><p>
|
31
|
-
The first parameter is the name of the file to be written. You'll notice
|
32
|
-
it is the same as the file we just read. In this case, we just write over
|
33
|
-
the old file. The second parameter is a pointer to the xmlDoc
|
34
|
-
structure. Setting the third parameter equal to one ensures indenting on output.
|
35
|
-
</p></div><div class="navfooter"><hr><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="ar01s05.html">Prev</a>�</td><td width="20%" align="center"><a accesskey="u" href="index.html">Up</a></td><td width="40%" align="right">�<a accesskey="n" href="ar01s07.html">Next</a></td></tr><tr><td width="40%" align="left" valign="top">Using XPath to Retrieve Element Content�</td><td width="20%" align="center"><a accesskey="h" href="index.html">Home</a></td><td width="40%" align="right" valign="top">�Writing Attribute</td></tr></table></div></body></html>
|
@@ -1,30 +0,0 @@
|
|
1
|
-
<html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>Writing Attribute</title><meta name="generator" content="DocBook XSL Stylesheets V1.61.2"><link rel="home" href="index.html" title="Libxml Tutorial"><link rel="up" href="index.html" title="Libxml Tutorial"><link rel="previous" href="ar01s06.html" title="Writing element content"><link rel="next" href="ar01s08.html" title="Retrieving Attributes"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center">Writing Attribute</th></tr><tr><td width="20%" align="left"><a accesskey="p" href="ar01s06.html">Prev</a>�</td><th width="60%" align="center">�</th><td width="20%" align="right">�<a accesskey="n" href="ar01s08.html">Next</a></td></tr></table><hr></div><div class="sect1" lang="en"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a name="xmltutorialwritingattribute"></a>Writing Attribute</h2></div></div><div></div></div><p><a class="indexterm" name="id2587093"></a>
|
2
|
-
Writing an attribute is similar to writing text to a new element. In
|
3
|
-
this case, we'll add a reference <span class="acronym">URI</span> to our
|
4
|
-
document. Full code:<a href="apf.html" title="F.�Code for Add Attribute Example">Appendix�F, <i>Code for Add Attribute Example</i></a>.</p><p>
|
5
|
-
A <tt class="sgmltag-element">reference</tt> is a child of the <tt class="sgmltag-element">story</tt>
|
6
|
-
element, so finding the place to put our new element and attribute is
|
7
|
-
simple. As soon as we do the error-checking test in our
|
8
|
-
<tt class="function">parseDoc</tt>, we are in the right spot to add our
|
9
|
-
element. But before we do that, we need to make a declaration using a
|
10
|
-
data type we have not seen yet:
|
11
|
-
</p><pre class="programlisting">
|
12
|
-
xmlAttrPtr newattr;
|
13
|
-
</pre><p>
|
14
|
-
We also need an extra xmlNodePtr:
|
15
|
-
</p><pre class="programlisting">
|
16
|
-
xmlNodePtr newnode;
|
17
|
-
</pre><p>
|
18
|
-
</p><p>
|
19
|
-
The rest of <tt class="function">parseDoc</tt> is the same as before until we
|
20
|
-
check to see if our root element is <tt class="sgmltag-element">story</tt>. If it is,
|
21
|
-
then we know we are at the right spot to add our element:
|
22
|
-
|
23
|
-
</p><pre class="programlisting">
|
24
|
-
<a name="addreferencenode"></a><img src="images/callouts/1.png" alt="1" border="0"> newnode = xmlNewTextChild (cur, NULL, "reference", NULL);
|
25
|
-
<a name="addattributenode"></a><img src="images/callouts/2.png" alt="2" border="0"> newattr = xmlNewProp (newnode, "uri", uri);
|
26
|
-
</pre><p>
|
27
|
-
</p><div class="calloutlist"><table border="0" summary="Callout list"><tr><td width="5%" valign="top" align="left"><a href="#addreferencenode"><img src="images/callouts/1.png" alt="1" border="0"></a> </td><td valign="top" align="left"><p>First we add a new node at the location of the current node
|
28
|
-
pointer, <tt class="varname">cur.</tt> using the <a href="http://xmlsoft.org/html/libxml-tree.html#XMLNEWTEXTCHILD" target="_top">xmlNewTextChild</a> function.</p></td></tr></table></div><p>
|
29
|
-
</p><p>Once the node is added, the file is written to disk just as in the
|
30
|
-
previous example in which we added an element with text content.</p></div><div class="navfooter"><hr><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="ar01s06.html">Prev</a>�</td><td width="20%" align="center"><a accesskey="u" href="index.html">Up</a></td><td width="40%" align="right">�<a accesskey="n" href="ar01s08.html">Next</a></td></tr><tr><td width="40%" align="left" valign="top">Writing element content�</td><td width="20%" align="center"><a accesskey="h" href="index.html">Home</a></td><td width="40%" align="right" valign="top">�Retrieving Attributes</td></tr></table></div></body></html>
|