diff options
author | Stefan Radomski <github@mintwerk.de> | 2017-07-10 15:13:06 (GMT) |
---|---|---|
committer | Stefan Radomski <github@mintwerk.de> | 2017-07-10 15:13:06 (GMT) |
commit | 286f8d747d198a66b81396ba8197b101ae2d59ed (patch) | |
tree | 2ad222fdbcb2ba6f7ead0ca41e5a6d98ae4c4287 /src/uscxml/util/Predicates.cpp | |
parent | 799a95c560338643894ffd80510db8b48baa2f45 (diff) | |
download | uscxml-286f8d747d198a66b81396ba8197b101ae2d59ed.zip uscxml-286f8d747d198a66b81396ba8197b101ae2d59ed.tar.gz uscxml-286f8d747d198a66b81396ba8197b101ae2d59ed.tar.bz2 |
More performance for microsteppers
Diffstat (limited to 'src/uscxml/util/Predicates.cpp')
-rw-r--r-- | src/uscxml/util/Predicates.cpp | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/src/uscxml/util/Predicates.cpp b/src/uscxml/util/Predicates.cpp index 3f6128f..6649907 100644 --- a/src/uscxml/util/Predicates.cpp +++ b/src/uscxml/util/Predicates.cpp @@ -183,21 +183,23 @@ bool isState(const DOMElement* state, bool properOnly) { if (!state) return false; - std::string localName = LOCALNAME(state); - if (iequals("state", localName)) + // comparison with XMLCh* is faster than transcoding each + const XMLCh* localname = state->getLocalName(); + + if (kXMLCharState.iequals(localname) == 0) return true; - if (iequals("scxml", localName)) + if (kXMLCharScxml.iequals(localname) == 0) return true; - if (iequals("parallel", localName)) + if (kXMLCharParallel.iequals(localname) == 0) return true; - if (iequals("final", localName)) + if (kXMLCharFinal.iequals(localname) == 0) return true; if (properOnly) return false; - if (iequals("history", localName)) + if (kXMLCharHistory.iequals(localname) == 0) return true; - if (iequals("initial", localName)) + if (kXMLCharInitial.iequals(localname) == 0) return true; return false; |