/* Ousía Copyright (C) 2014, 2015 Benjamin Paaßen, Andreas Stöckel This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #include "TokenStack.hpp" #include namespace ousia { namespace parser_stack { void TokenStack::pushTokens(const std::vector &tokens, bool inherit) { // TODO: Implement inheritance stack.push_back(tokens); } TokenDescriptor TokenStack::lookup(TokenId token) const { TokenDescriptor res; if (!stack.empty()) { for (const SyntaxDescriptor &descr : stack.back()) { if (descr.close == token) { res.close.emplace_back(descr); } if (descr.shortForm == token) { res.shortForm.emplace_back(descr); } if (descr.open == token) { res.open.emplace_back(descr); } } } return res; } void TokenStack::popTokens() { stack.pop_back(); } TokenSet TokenStack::tokens() const { TokenSet res; if (!stack.empty()) { for (const SyntaxDescriptor &descr : stack.back()) { descr.insertIntoTokenSet(res); } } return res; } } }