diff options
author | Roland Reichwein <mail@reichwein.it> | 2020-03-15 18:19:49 +0100 |
---|---|---|
committer | Roland Reichwein <mail@reichwein.it> | 2020-03-15 18:19:49 +0100 |
commit | 9f69b006dde3c3fbe19ed3e0275d3b7348f2aa87 (patch) | |
tree | 6ac42793568339463f913cf39474794c8613d0b6 /cppbnf.cpp | |
parent | 3a7006fcf5f8ecffd852fbba6d8ee03ce8a35dce (diff) |
New lexer
Diffstat (limited to 'cppbnf.cpp')
-rwxr-xr-x | cppbnf.cpp | 11 |
1 files changed, 3 insertions, 8 deletions
@@ -39,11 +39,6 @@ namespace { return result; } - bool isTerminal(const std::string& symbol, const BNF& bnf) - { - return bnf.find(symbol) == bnf.end(); - } - size_t numberOfStartSymbols(const BNF& bnf) { // exactly 1 start symbol @@ -75,7 +70,7 @@ namespace { for (const auto& list : lists) { for (const auto& i : list) { - if (!isTerminal(i, bnf)) { + if (!isTerminal(bnf, i)) { // every non-terminal symbol must be longer that 1 char if (i.size() == 1) { std::cerr << "Warning: Non-Terminal symbol " << i << " in " << symbol << " is too short." << std::endl; @@ -107,7 +102,7 @@ namespace { for (const auto& [symbol, lists] : bnf) { for (const auto& list : lists) { for (const auto& i : list) { - if (i.size() != 1 && isTerminal(i, bnf)) { + if (i.size() != 1 && isTerminal(bnf, i)) { std::cerr << "Warning: Terminal symbol in " << symbol << " is too long: "s << i << std::endl; return false; } @@ -197,7 +192,7 @@ namespace { for (auto& [symbol, lists] : bnf) { for (auto& list : lists) { for (int i = 0; i < list.size(); i++) { - if (list[i].size() > 1 && isTerminal(list[i], bnf)) { + if (list[i].size() > 1 && isTerminal(bnf, list[i])) { auto newList = vectorize(list[i]); list.erase(list.begin() + i); list.insert(list.begin() + i, newList.begin(), newList.end()); |