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
|
/**
* This file contains all the snippets in the doxygen documentation.
*
* It is not actually a test as such, but makes sure that the snippets will
* actually compile and do what we claim they do.
*/
//#define protected public
#include "uscxml/config.h"
#include "uscxml/Common.h"
#include "uscxml/Interpreter.h"
#include "uscxml/interpreter/InterpreterImpl.h"
#include "uscxml/util/DOM.h"
#include <iostream>
using namespace uscxml;
using namespace XERCESC_NS;
void testDOMUtils() {
const char* xml =
"<scxml>"
" <state doc=\"1\" post=\"1\">"
" <transition doc=\"1\" post=\"1\" />"
" </state>"
" <state doc=\"2\" post=\"3\">"
" <transition doc=\"2\" post=\"3\" />"
" <state doc=\"3\" post=\"2\">"
" <transition doc=\"2\" post=\"2\" />"
" </state>"
" </state>"
" <final id=\"done\" />"
"</scxml>";
size_t index = 1;
Interpreter interpreter = Interpreter::fromXML(xml, "");
interpreter.step();
XERCESC_NS::DOMElement* scxml = interpreter.getImpl()->getDocument()->getDocumentElement();
{
// postfix
std::list<DOMElement*> result;
DOMUtils::filterElementGeneric({ "state" }, result, scxml, DOMUtils::POSTFIX, true, true);
index = 1;
for (auto trans : result) {
assert(HAS_ATTR(trans, X("post")));
std::cout << "post: " << ATTR(trans, X("post")) << std::endl;
assert(ATTR(trans, X("post")) == toStr(index));
index++;
}
}
{
// document
std::list<DOMElement*> result;
DOMUtils::filterElementGeneric({ "state" }, result, scxml, DOMUtils::DOCUMENT, true, true);
index = 1;
for (auto trans : result) {
assert(HAS_ATTR(trans, X("doc")));
std::cout << "doc: " << ATTR(trans, X("doc")) << std::endl;
assert(ATTR(trans, X("doc")) == toStr(index));
index++;
}
}
}
int main(int argc, char** argv) {
try {
testDOMUtils();
} catch (ErrorEvent e) {
std::cout << e;
}
}
|