X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Flyxlex_pimpl.h;h=1f63abc1115d7fcaa4e93306eb16c7a54e78fce4;hb=98c966c64594611e469313314abd1e59524adb4a;hp=2991328f79c46f42f0ce15d03c1789ee28e52a0f;hpb=e5f1824f33b51af675f8d345d5871a76dbd54465;p=lyx.git diff --git a/src/lyxlex_pimpl.h b/src/lyxlex_pimpl.h index 2991328f79..1f63abc111 100644 --- a/src/lyxlex_pimpl.h +++ b/src/lyxlex_pimpl.h @@ -4,6 +4,8 @@ #define LYXLEX_PIMPL_H #include +#include +#include #include "lyxlex.h" @@ -12,62 +14,48 @@ #endif /// -struct LyXLex::Pimpl { +struct LyXLex::Pimpl : boost::noncopyable { /// enum { /// LEX_MAX_BUFF = 2048 }; - + /// - struct pushed_table { - /// - pushed_table(){ - next = 0; - table_elem = 0; - } - /// - pushed_table * next; - /// - keyword_item * table_elem; - /// - int table_siz; - }; - Pimpl(keyword_item * tab, int num); - - string GetString() const; - + /// + string const getString() const; + /// void printError(string const & message) const; - + /// void printTable(std::ostream & os); - + /// void pushTable(keyword_item * tab, int num); - + /// void popTable(); - + /// bool setFile(string const & filename); - + /// void setStream(std::istream & i); - + /// + void setCommentChar(char c); + /// bool next(bool esc = false); - /// int search_kw(char const * const tag) const; - + /// int lex(); - - bool EatLine(); - + /// + bool eatLine(); + /// bool nextToken(); - + /// void pushToken(string const &); - /// fb__ is only used to open files, the stream is accessed through is std::filebuf fb__; /// the stream that we use. std::istream is; - /// + /// string name; /// keyword_item * table; @@ -76,12 +64,30 @@ struct LyXLex::Pimpl { /// char buff[LEX_MAX_BUFF]; /// - short status; - /// - pushed_table * pushed; + int status; /// int lineno; /// string pushTok; + /// + char commentChar; +private: + /// + void verifyTable(); + /// + struct pushed_table { + /// + pushed_table() + : table_elem(0), table_siz(0) {} + /// + pushed_table(keyword_item * ki, int siz) + : table_elem(ki), table_siz(siz) {} + /// + keyword_item * table_elem; + /// + int table_siz; + }; + /// + std::stack pushed; }; #endif