summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndreas Stöckel <astoecke@techfak.uni-bielefeld.de>2015-03-02 00:34:15 +0100
committerAndreas Stöckel <astoecke@techfak.uni-bielefeld.de>2015-03-02 00:34:15 +0100
commit596fdab71b8bd116e20e33647d68f1d7a567696e (patch)
treecba0b3a79d9608265d9171942324935931d75421
parent8197dc488926e8645efb47e60d0988a6a65fc15f (diff)
Wrote isUserDefinedToken function which checks whether a token is a valid user defined token and added unit tests
-rw-r--r--src/core/common/Utils.cpp24
-rw-r--r--src/core/common/Utils.hpp19
-rw-r--r--test/core/common/UtilsTest.cpp31
3 files changed, 73 insertions, 1 deletions
diff --git a/src/core/common/Utils.cpp b/src/core/common/Utils.cpp
index 85d2c28..219b437 100644
--- a/src/core/common/Utils.cpp
+++ b/src/core/common/Utils.cpp
@@ -118,5 +118,29 @@ bool Utils::endsWith(const std::string &s, const std::string &suffix)
return suffix.size() <= s.size() &&
s.substr(s.size() - suffix.size(), suffix.size()) == suffix;
}
+
+bool Utils::isUserDefinedToken(const std::string &token)
+{
+ // Make sure the token meets is neither empty, nor starts or ends with an
+ // alphanumeric character
+ const size_t len = token.size();
+ if (len == 0 || isAlphanumeric(token[0]) || isAlphanumeric(token[len - 1])) {
+ return false;
+ }
+
+ // Make sure the token is not any special OSML token
+ if (token == "\\" || token == "%" || token == "%{" || token == "}%" ||
+ token == "{!" || token == "<\\" || token == "\\>") {
+ return false;
+ }
+
+ // Make sure the token contains other characters but { and }
+ for (char c: token) {
+ if (c != '{' && c != '}') {
+ return true;
+ }
+ }
+ return false;
+}
}
diff --git a/src/core/common/Utils.hpp b/src/core/common/Utils.hpp
index 82a8f8c..25a4de5 100644
--- a/src/core/common/Utils.hpp
+++ b/src/core/common/Utils.hpp
@@ -103,6 +103,25 @@ public:
static bool isNamespacedIdentifier(const std::string &name);
/**
+ * Returns true if the given characters form a valid user-defined token.
+ * This function returns true under the following circumstances:
+ * <ul>
+ * <li>The given token is not empty</li>
+ * <li>The given token starts and ends with a non-alphanumeric character
+ * </li>
+ * <li>The token is none of the following character sequences (which are
+ * special in OSML):
+ * <ul>
+ * <li>'{', '}' or any combined repetition of these characters</li>
+ * <li>'\', '{!', '<\', '\>'</li>
+ * <li>'%', '%{', '}%'</li>
+ * </ul>
+ * </li>
+ * </ul>
+ */
+ static bool isUserDefinedToken(const std::string &token);
+
+ /**
* Returns true if the given character is a linebreak character.
*/
static bool isLinebreak(const char c) { return (c == '\n') || (c == '\r'); }
diff --git a/test/core/common/UtilsTest.cpp b/test/core/common/UtilsTest.cpp
index 4bf1587..54890ee 100644
--- a/test/core/common/UtilsTest.cpp
+++ b/test/core/common/UtilsTest.cpp
@@ -131,4 +131,33 @@ TEST(Utils, collapse)
ASSERT_EQ("long test", Utils::collapse(" long test "));
}
-} \ No newline at end of file
+TEST(Utils, isUserDefinedToken)
+{
+ EXPECT_FALSE(Utils::isUserDefinedToken(""));
+ EXPECT_FALSE(Utils::isUserDefinedToken("a"));
+ EXPECT_TRUE(Utils::isUserDefinedToken(":"));
+ EXPECT_TRUE(Utils::isUserDefinedToken("::"));
+ EXPECT_TRUE(Utils::isUserDefinedToken("!?"));
+ EXPECT_TRUE(Utils::isUserDefinedToken("."));
+ EXPECT_TRUE(Utils::isUserDefinedToken("<<"));
+ EXPECT_TRUE(Utils::isUserDefinedToken(">>"));
+ EXPECT_TRUE(Utils::isUserDefinedToken("''"));
+ EXPECT_TRUE(Utils::isUserDefinedToken("``"));
+ EXPECT_TRUE(Utils::isUserDefinedToken("´´"));
+ EXPECT_TRUE(Utils::isUserDefinedToken("´"));
+ EXPECT_TRUE(Utils::isUserDefinedToken("`"));
+ EXPECT_TRUE(Utils::isUserDefinedToken("<"));
+ EXPECT_TRUE(Utils::isUserDefinedToken(">"));
+ EXPECT_FALSE(Utils::isUserDefinedToken("a:"));
+ EXPECT_FALSE(Utils::isUserDefinedToken("a:a"));
+ EXPECT_FALSE(Utils::isUserDefinedToken(":a"));
+ EXPECT_FALSE(Utils::isUserDefinedToken("{"));
+ EXPECT_FALSE(Utils::isUserDefinedToken("{{"));
+ EXPECT_FALSE(Utils::isUserDefinedToken("}}"));
+ EXPECT_FALSE(Utils::isUserDefinedToken("{{}{}"));
+ EXPECT_FALSE(Utils::isUserDefinedToken("<\\"));
+ EXPECT_FALSE(Utils::isUserDefinedToken("\\>"));
+ EXPECT_FALSE(Utils::isUserDefinedToken("{!"));
+}
+
+}