/* 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 . */ /** * @file TokenStack.hpp * * Contains the TokenStack class used for collecting the currently enabled user * defined tokens on a per-field basis. * * @author Andreas Stöckel (astoecke@techfak.uni-bielefeld.de) */ #ifndef _OUSIA_PARSER_STACK_TOKEN_STACK_HPP_ #define _OUSIA_PARSER_STACK_TOKEN_STACK_HPP_ #include #include #include #include namespace ousia { namespace parser_stack { /** * The TokenStack class is used by the Stack class to collect all currently * enabled user defined tokens. */ class TokenStack { private: /** * Stack containing vectors of TokenSyntaxDescriptor instances as given by * the user. */ std::vector> stack; public: /** * Pushes a list of SyntaxDescriptor instances onto the internal stack. * * @param tokens is a list of SyntaxDescriptor instances that should be * stored on the stack. */ void pushTokens(const std::vector &tokens); /** * Removes the previously pushed list of tokens from the stack. */ void popTokens(); /** * Returns a set containing all currently enabled tokens. The set of enabled * tokens are those tokens that were pushed last onto the stack. This set * has to be passed to the TokenizedData instance in order to gather all * tokens that are currently possible. * * @return a set of tokens containing all the Tokens that are currently * possible. */ TokenSet tokens() const; }; } } #endif /* _OUSIA_PARSER_STACK_TOKEN_STACK_HPP_ */