forked from parsley72/tinyxpath2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhtmlutil.cpp
99 lines (84 loc) · 3.42 KB
/
htmlutil.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/*
www.sourceforge.net/projects/tinyxpath
Copyright (c) 2002-2004 Yves Berquin ([email protected])
This software is provided 'as-is', without any express or implied
warranty. In no event will the authors be held liable for any
damages arising from the use of this software.
Permission is granted to anyone to use this software for any
purpose, including commercial applications, and to alter it and
redistribute it freely, subject to the following restrictions:
1. The origin of this software must not be misrepresented; you must
not claim that you wrote the original software. If you use this
software in a product, an acknowledgment in the product documentation
would be appreciated but is not required.
2. Altered source versions must be plainly marked as such, and
must not be misrepresented as being the original software.
3. This notice may not be removed or altered from any source
distribution.
*/
/**
\file htmlutil.cpp
\author Yves Berquin
HTML utilities for TinyXPath project
*/
#include "htmlutil.h"
#include <cassert>
#include "tinyxml2.h"
using namespace std;
using namespace tinyxml2;
/// Generate some indentation on the HTML or file output
void v_levelize(int i_level, FILE* Fp_out, bool o_html) {
for (int i_loop = 0; i_loop < i_level; i_loop++) {
if (o_html) {
fprintf(Fp_out, " ");
} else {
fprintf(Fp_out, " ");
}
}
}
/// Dumps an XML tree to an HTML document
/// \n This is a recursive function, called again at each element in the tree
void v_out_html(FILE* Fp_out, ///< Output HTML file
const XMLNode* XNp_source, ///< Input XML tree
unsigned u_level) ///< Current level
{
const XMLNode* XNp_child;
const XMLAttribute* XAp_att;
XNp_child = XNp_source->FirstChild();
while (XNp_child) {
if (XNp_child->ToDocument()) {
fprintf(Fp_out, "\nStart document\n");
} else if (XNp_child->ToElement()) {
v_levelize((int)u_level, Fp_out, true);
fprintf(Fp_out, "<"); // '<'
fprintf(Fp_out, "%s", XNp_child->ToElement()->Value());
// fprintf (Fp_out, "<small>[%d]</small>", XNp_child -> GetUserValue ());
XAp_att = XNp_child->ToElement()->FirstAttribute();
while (XAp_att) {
fprintf(Fp_out, " %s='%s'", XAp_att->Name(), XAp_att->Value());
XAp_att = XAp_att->Next();
}
if (XNp_child->FirstChild()) {
fprintf(Fp_out, "><br>\n"); // '>\n'
} else {
fprintf(Fp_out, " /><br>\n");
}
} else if (XNp_child->ToComment()) {
fprintf(Fp_out, "<!-- %s --><br>\n", XNp_child->ToComment()->Value());
} else if (XNp_child->ToText()) {
fprintf(Fp_out, "%s\n", XNp_child->ToText()->Value());
} else if (!XNp_child->ToUnknown() && !XNp_child->ToDeclaration()) {
assert(false);
}
v_out_html(Fp_out, XNp_child, u_level + 1);
if (XNp_child->ToDocument()) {
fprintf(Fp_out, "\nEnd document\n");
} else if (XNp_child->ToElement() && XNp_child->FirstChild()) {
v_levelize((int)u_level, Fp_out, true);
fprintf(Fp_out, "<");
fprintf(Fp_out, "/%s", XNp_child->ToElement()->Value());
fprintf(Fp_out, "><br>\n"); // '>\n'
}
XNp_child = XNp_child->NextSibling();
}
}