diff options
author | Stefan Radomski <radomski@tk.informatik.tu-darmstadt.de> | 2015-01-19 16:41:18 (GMT) |
---|---|---|
committer | Stefan Radomski <radomski@tk.informatik.tu-darmstadt.de> | 2015-01-19 16:41:18 (GMT) |
commit | ff86d690dc02d7dd495000331d378e7d8eb688ac (patch) | |
tree | 5214786f7e575952d3cba0919e5071f3a783050b /src/uscxml/transform/ChartToMinimalSCXML.cpp | |
parent | 42437db418574f2a80d098e568b9498a21343800 (diff) | |
download | uscxml-ff86d690dc02d7dd495000331d378e7d8eb688ac.zip uscxml-ff86d690dc02d7dd495000331d378e7d8eb688ac.tar.gz uscxml-ff86d690dc02d7dd495000331d378e7d8eb688ac.tar.bz2 |
Plenty of smaller fixes and adaptations
Diffstat (limited to 'src/uscxml/transform/ChartToMinimalSCXML.cpp')
-rw-r--r-- | src/uscxml/transform/ChartToMinimalSCXML.cpp | 35 |
1 files changed, 27 insertions, 8 deletions
diff --git a/src/uscxml/transform/ChartToMinimalSCXML.cpp b/src/uscxml/transform/ChartToMinimalSCXML.cpp index 270794d..ecfa12b 100644 --- a/src/uscxml/transform/ChartToMinimalSCXML.cpp +++ b/src/uscxml/transform/ChartToMinimalSCXML.cpp @@ -36,7 +36,7 @@ Transformer ChartToMinimalSCXML::transform(const Interpreter& other) { return boost::shared_ptr<TransformerImpl>(new ChartToMinimalSCXML(other)); } -ChartToMinimalSCXML::ChartToMinimalSCXML(const Interpreter& other) : TransformerImpl(), _retainAsComments(false) { +ChartToMinimalSCXML::ChartToMinimalSCXML(const Interpreter& other) : TransformerImpl(), _retainAsComments(false), _step(1) { cloneFrom(other.getImpl()); // a bit messy but needed for SCXML IO Processor with session id target @@ -85,10 +85,7 @@ void ChartToMinimalSCXML::writeTo(std::ostream& stream) { } char* waitForEnv = getenv("USCXML_MINIMIZE_WAIT_MS"); - char* waitForCmpl = getenv("USCXML_MINIMIZE_WAIT_FOR_COMPLETION"); - char* retainAsComments = getenv("USCXML_MINIMIZE_RETAIN_AS_COMMENTS"); - if (retainAsComments != NULL && DOMUtils::attributeIsTrue(retainAsComments)) - _retainAsComments = true; + _retainAsComments = envVarIsTrue("USCXML_MINIMIZE_RETAIN_AS_COMMENTS"); long waitFor = -1; @@ -100,7 +97,7 @@ void ChartToMinimalSCXML::writeTo(std::ostream& stream) { } } - if (waitForCmpl != NULL && DOMUtils::attributeIsTrue(waitForCmpl)) { + if (envVarIsTrue("USCXML_MINIMIZE_WAIT_FOR_COMPLETION")) { interpret(); } else { start(); @@ -181,14 +178,15 @@ void ChartToMinimalSCXML::removeUnvisited(Arabica::DOM::Node<std::string>& node) // detach unvisited nodes from DOM if (_visited.find(node) == _visited.end()) { - std::cout << DOMUtils::xPathForNode(node) << std::endl; + std::cerr << DOMUtils::xPathForNode(node) << std::endl; if (_retainAsComments) { std::stringstream oldContent; oldContent << node; node.getParentNode().replaceChild(_document.createComment(boost::replace_all_copy(oldContent.str(),"--", "-")), node); } else { // removeChildren is not working as expected - node.getParentNode().replaceChild(_document.createTextNode(""), node); +// node.getParentNode().replaceChild(_document.createTextNode(""), node); + node.getParentNode().removeChild(node); } return; } @@ -231,11 +229,29 @@ void ChartToMinimalSCXML::beforeTakingTransition(Interpreter interpreter, const markAsVisited(Arabica::DOM::Element<std::string>(targets[i])); } markAsVisited(transition); + + std::stringstream commentSS; + if (HAS_ATTR(transition, "event")) { + commentSS << " Step #" << _step++ << " - transition taken for event '" << _currEvent.name << "' "; + } else { + commentSS << " Step #" << _step++ << " - spontaneous transition taken "; + } + if (envVarIsTrue("USCXML_ANNOTATE_PROGRESS")) + transition.getParentNode().insertBefore(_document.createComment(commentSS.str()), transition); + StateTransitionMonitor::beforeTakingTransition(interpreter, transition, moreComing); } void ChartToMinimalSCXML::beforeEnteringState(Interpreter interpreter, const Arabica::DOM::Element<std::string>& state, bool moreComing) { markAsVisited(state); + + std::stringstream commentSS; + commentSS << " Step #" << _step++ << " - state entered "; + + Arabica::DOM::Element<std::string> ncState = const_cast<Arabica::DOM::Element<std::string>&>(state); + if (envVarIsTrue("USCXML_ANNOTATE_PROGRESS")) + ncState.insertBefore(_document.createComment(commentSS.str()), ncState.getFirstChild()); + StateTransitionMonitor::beforeEnteringState(interpreter, state, moreComing); } @@ -262,4 +278,7 @@ void ChartToMinimalSCXML::cancelInvoke(const Arabica::DOM::Element<std::string>& InterpreterRC::cancelInvoke(element); } +void ChartToMinimalSCXML::onStableConfiguration(uscxml::Interpreter interpreter) { +} + }
\ No newline at end of file |