-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathxml_util.cpp
99 lines (84 loc) · 2.76 KB
/
xml_util.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 (yvesb@users.sourceforge.net)
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 xml_util.cpp
\author Yves Berquin
*/
#include "xml_util.h"
#include <cassert>
#include <string>
using namespace std;
using namespace tinyxml2;
namespace TinyXPath {
/// Cardinality in the terms of XPath counts from 1 for the first element
int i_xml_cardinality(const XMLElement* XEp_elem, ///< Base element. Must not be null
bool o_by_name) ///< true if we ask for the cardinality for our name only
{
const XMLNode* XNp_parent;
const XMLElement* XEp_child;
string S_name;
int i_res;
assert(XEp_elem);
XNp_parent = XEp_elem->Parent();
assert(XNp_parent);
if (o_by_name) {
S_name = XEp_elem->Value();
XEp_child = XNp_parent->FirstChildElement(S_name.c_str());
i_res = 1;
while (XEp_child) {
if (XEp_child == XEp_elem)
return i_res;
else {
i_res++;
XEp_child = XEp_child->NextSiblingElement(S_name.c_str());
}
}
} else {
XEp_child = XNp_parent->FirstChildElement();
i_res = 1;
while (XEp_child) {
if (XEp_child == XEp_elem)
return i_res;
else {
i_res++;
XEp_child = XEp_child->NextSiblingElement();
}
}
}
assert(false);
return -1;
}
/// Family size : Nb of sibling elements (including ourselves)
int i_xml_family_size(const XMLElement* XEp_elem) ///< Base element. Must not be null
{
const XMLElement* XEp_child;
const XMLNode* XNp_parent;
int i_res;
assert(XEp_elem);
XNp_parent = XEp_elem->Parent();
assert(XNp_parent);
XEp_child = XNp_parent->FirstChildElement();
i_res = 0;
while (XEp_child) {
i_res++;
XEp_child = XEp_child->NextSiblingElement();
}
return i_res;
}
} // namespace TinyXPath