diff options
author | Stefan Radomski <radomski@tk.informatik.tu-darmstadt.de> | 2013-06-20 19:53:21 (GMT) |
---|---|---|
committer | Stefan Radomski <radomski@tk.informatik.tu-darmstadt.de> | 2013-06-20 19:53:21 (GMT) |
commit | 794575f01ce5a6bf7e377eb815f3def5aded74f5 (patch) | |
tree | 9c59df64ee290f68b7b6c8698bfac4169684485e /src/uscxml/Message.cpp | |
parent | d304f85417e3175c5f2ca159dd303309c24e7b81 (diff) | |
download | uscxml-794575f01ce5a6bf7e377eb815f3def5aded74f5.zip uscxml-794575f01ce5a6bf7e377eb815f3def5aded74f5.tar.gz uscxml-794575f01ce5a6bf7e377eb815f3def5aded74f5.tar.bz2 |
New version with XHTML invoker
Diffstat (limited to 'src/uscxml/Message.cpp')
-rw-r--r-- | src/uscxml/Message.cpp | 23 |
1 files changed, 18 insertions, 5 deletions
diff --git a/src/uscxml/Message.cpp b/src/uscxml/Message.cpp index 2425c76..2e82b69 100644 --- a/src/uscxml/Message.cpp +++ b/src/uscxml/Message.cpp @@ -276,6 +276,8 @@ Data Data::fromJSON(const std::string& jsonString) { size_t currTok = 0; do { + jsmntok_t t2 = t[currTok]; + std::string value = trimmed.substr(t[currTok].start, t[currTok].end - t[currTok].start); switch (t[currTok].type) { case JSMN_STRING: dataStack.back()->type = Data::VERBATIM; @@ -291,13 +293,18 @@ Data Data::fromJSON(const std::string& jsonString) { break; } + t2 = t[currTok]; + value = trimmed.substr(t[currTok].start, t[currTok].end - t[currTok].start); + // there are no more tokens if (t[currTok].end == 0 || tokenStack.empty()) break; // next token starts after current one => pop - if (t[currTok].end > tokenStack.back().end) + if (t[currTok].end > tokenStack.back().end) { tokenStack.pop_back(); + dataStack.pop_back(); + } if (tokenStack.back().type == JSMN_OBJECT && (t[currTok].type == JSMN_PRIMITIVE || t[currTok].type == JSMN_STRING)) { // grab key and push new data @@ -328,7 +335,7 @@ void Event::initContent(const std::string& content) { Arabica::SAX2DOM::Parser<std::string> parser; Arabica::SAX::CatchErrorHandler<std::string> errorHandler; parser.setErrorHandler(errorHandler); - + std::istringstream is(content); Arabica::SAX::InputSource<std::string> inputSource; inputSource.setByteStream(is); @@ -336,7 +343,7 @@ void Event::initContent(const std::string& content) { dom = parser.getDocument(); return; } - + this->content = content; } @@ -513,6 +520,13 @@ std::ostream& operator<< (std::ostream& os, const Event& event) { #ifndef SWIGJAVA std::ostream& operator<< (std::ostream& os, const Data& data) { + os << Data::toJSON(data); + return os; +} +#endif + +std::string Data::toJSON(const Data& data) { + std::stringstream os; std::string indent; for (int i = 0; i < _dataIndentation; i++) { indent += " "; @@ -564,8 +578,7 @@ std::ostream& operator<< (std::ostream& os, const Data& data) { } else { os << "undefined"; } - return os; + return os.str(); } -#endif }
\ No newline at end of file |