summaryrefslogtreecommitdiffstats
path: root/src/uscxml/util/Predicates.cpp
diff options
context:
space:
mode:
authorStefan Radomski <github@mintwerk.de>2017-07-10 15:13:06 (GMT)
committerStefan Radomski <github@mintwerk.de>2017-07-10 15:13:06 (GMT)
commit286f8d747d198a66b81396ba8197b101ae2d59ed (patch)
tree2ad222fdbcb2ba6f7ead0ca41e5a6d98ae4c4287 /src/uscxml/util/Predicates.cpp
parent799a95c560338643894ffd80510db8b48baa2f45 (diff)
downloaduscxml-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.cpp16
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;