summaryrefslogtreecommitdiffstats
path: root/src/uscxml/DOMUtils.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/uscxml/DOMUtils.cpp')
-rw-r--r--src/uscxml/DOMUtils.cpp70
1 files changed, 35 insertions, 35 deletions
diff --git a/src/uscxml/DOMUtils.cpp b/src/uscxml/DOMUtils.cpp
index 4805927..7e834f8 100644
--- a/src/uscxml/DOMUtils.cpp
+++ b/src/uscxml/DOMUtils.cpp
@@ -31,40 +31,40 @@ bool DOMUtils::attributeIsTrue(const::std::string& value) {
}
std::string DOMUtils::idForNode(const Arabica::DOM::Node<std::string>& node) {
- std::string nodeId;
- std::string seperator;
- Arabica::DOM::Node<std::string> curr = node;
- while(curr) {
- switch (curr.getNodeType()) {
- case Arabica::DOM::Node_base::ELEMENT_NODE: {
- Arabica::DOM::Element<std::string> elem = Arabica::DOM::Element<std::string>(curr);
- if (HAS_ATTR(elem, "id") && !UUID::isUUID(ATTR(elem, "id"))) {
- nodeId.insert(0, ATTR(elem, "id") + seperator);
- seperator = "_";
- return nodeId;
- } else {
- Arabica::DOM::Node<std::string> sibling = curr.getPreviousSibling();
- int index = 0;
- while(sibling) {
- if (sibling.getNodeType() == Arabica::DOM::Node_base::ELEMENT_NODE) {
- if (iequals(TAGNAME_CAST(sibling), TAGNAME(elem))) {
- index++;
- }
- }
- sibling = sibling.getPreviousSibling();
- }
- nodeId.insert(0, TAGNAME(elem) + toStr(index) + seperator);
- seperator = "_";
- }
- break;
- }
- case Arabica::DOM::Node_base::DOCUMENT_NODE:
- return nodeId;
- }
-
- curr = curr.getParentNode();
- }
- return nodeId;
+ std::string nodeId;
+ std::string seperator;
+ Arabica::DOM::Node<std::string> curr = node;
+ while(curr) {
+ switch (curr.getNodeType()) {
+ case Arabica::DOM::Node_base::ELEMENT_NODE: {
+ Arabica::DOM::Element<std::string> elem = Arabica::DOM::Element<std::string>(curr);
+ if (HAS_ATTR(elem, "id") && !UUID::isUUID(ATTR(elem, "id"))) {
+ nodeId.insert(0, ATTR(elem, "id") + seperator);
+ seperator = "_";
+ return nodeId;
+ } else {
+ Arabica::DOM::Node<std::string> sibling = curr.getPreviousSibling();
+ int index = 0;
+ while(sibling) {
+ if (sibling.getNodeType() == Arabica::DOM::Node_base::ELEMENT_NODE) {
+ if (iequals(TAGNAME_CAST(sibling), TAGNAME(elem))) {
+ index++;
+ }
+ }
+ sibling = sibling.getPreviousSibling();
+ }
+ nodeId.insert(0, TAGNAME(elem) + toStr(index) + seperator);
+ seperator = "_";
+ }
+ break;
+ }
+ case Arabica::DOM::Node_base::DOCUMENT_NODE:
+ return nodeId;
+ }
+
+ curr = curr.getParentNode();
+ }
+ return nodeId;
}
std::string DOMUtils::xPathForNode(const Arabica::DOM::Node<std::string>& node, const std::string& ns) {
@@ -164,7 +164,7 @@ NameSpacingParser NameSpacingParser::fromFile(const std::string& file) {
inputSource.setSystemId(file);
return fromInputSource(inputSource);
}
-
+
NameSpacingParser NameSpacingParser::fromXML(const std::string& xml) {
std::stringstream* ss = new std::stringstream();
(*ss) << xml;