X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Flyxlex_pimpl.h;h=c7acd92e7901f88a8d446e1bb9c05cc9e3d13131;hb=f268743f8c014ef2dadd260fd1a3873cb1d2038b;hp=0e1b1f265cae2593985b97b5080238707be13d56;hpb=7110b8eda4ab2dc3e87c53c89225caaff972f9eb;p=lyx.git diff --git a/src/lyxlex_pimpl.h b/src/lyxlex_pimpl.h index 0e1b1f265c..c7acd92e79 100644 --- a/src/lyxlex_pimpl.h +++ b/src/lyxlex_pimpl.h @@ -1,42 +1,33 @@ // -*- C++ -*- +/** + * \file lyxlex_pimpl.h + * This file is part of LyX, the document processor. + * Licence details can be found in the file COPYING. + * + * \author Lars Gullik Bjønnes + * + * Full author contact details are available in file CREDITS. + */ #ifndef LYXLEX_PIMPL_H #define LYXLEX_PIMPL_H -#include - #include "lyxlex.h" -#ifdef __GNUG__ -#pragma interface -#endif +#include "support/gzstream.h" + +#include + +#include +#include +#include /// -struct LyXLex::Pimpl { - /// - 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; - }; +struct LyXLex::Pimpl : boost::noncopyable { /// Pimpl(keyword_item * tab, int num); /// - string GetString() const; + string const getString() const; /// void printError(string const & message) const; /// @@ -50,37 +41,59 @@ struct LyXLex::Pimpl { /// 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 + /// fb__ is only used to open files, the stream is accessed through is. std::filebuf fb__; + /// gz__ is only used to open files, the stream is accessed through is. + gz::gzstreambuf gz__; + /// the stream that we use. std::istream is; - /// + /// string name; /// keyword_item * table; /// int no_items; /// - char buff[LEX_MAX_BUFF]; - /// - short status; + std::vector buff; /// - 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