4 // Copyright (C) 2006 Matthias Braun <matze@braunis.de>
6 // This program is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU General Public License
8 // as published by the Free Software Foundation; either version 2
9 // of the License, or (at your option) any later version.
11 // This program is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
16 // You should have received a copy of the GNU General Public License
17 // along with this program; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
20 #ifndef __LISPPARSER_H__
21 #define __LISPPARSER_H__
25 #include "obstack/obstack.h"
27 namespace TinyGetText {
29 class DictionaryManager;
41 Parser(bool translate = true);
45 * Parses a lispfile and returns the s-expression structure.
46 * Note that all memory is held by the parser so don't destroy the parser
47 * before you are finished with the lisp tree
49 const Lisp* parse(const std::string& filename);
51 * Same as parse but reads from a generic std::istream. The sourcename is
52 * used for errormessages to indicate the source of the data.
54 const Lisp* parse(std::istream& stream, const std::string& sourcename);
57 void parse_error(const char* msg) const;
62 TinyGetText::DictionaryManager* dictionary_manager;
63 TinyGetText::Dictionary* dictionary;
64 Lexer::TokenType token;
69 } // end of namespace lisp