X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Flyxlex_pimpl.h;h=79f4393acef51621bf74b71f86cf0513b947fc12;hb=37d42d45f3f4a5d3e916a080af50b37ae4a9d118;hp=0acc50974d2b92d6a82a4fd7fa3fd690bf269651;hpb=eeaae9c35568b8852210420c727068a872ba3071;p=lyx.git diff --git a/src/lyxlex_pimpl.h b/src/lyxlex_pimpl.h index 0acc50974d..79f4393ace 100644 --- a/src/lyxlex_pimpl.h +++ b/src/lyxlex_pimpl.h @@ -1,31 +1,39 @@ // -*- 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 - #include "lyxlex.h" -#ifdef __GNUG__ -#pragma interface +#ifdef USE_COMPRESSION +# include "support/gzstream.h" #endif +#include + +#include +#include +#include +#include + /// -struct LyXLex::Pimpl : public noncopyable { - /// - enum { - /// - LEX_MAX_BUFF = 2048 - }; - +class LyXLex::Pimpl : boost::noncopyable { +public: /// Pimpl(keyword_item * tab, int num); /// - string const GetString() const; + std::string const getString() const; /// - void printError(string const & message) const; + void printError(std::string const & message) const; /// void printTable(std::ostream & os); /// @@ -33,44 +41,55 @@ struct LyXLex::Pimpl : public noncopyable { /// void popTable(); /// - bool setFile(string const & filename); + bool setFile(std::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__; + void pushToken(std::string const &); + /// fb_ is only used to open files, the stream is accessed through is. + std::filebuf fb_; + +#ifdef USE_COMPRESSION + /// gz_ is only used to open files, the stream is accessed through is. + gz::gzstreambuf gz_; +#endif + /// the stream that we use. std::istream is; - /// - string name; + /// + std::string name; /// keyword_item * table; /// int no_items; /// - char buff[LEX_MAX_BUFF]; + std::vector buff; /// - short status; + int status; /// int lineno; /// - string pushTok; + std::string pushTok; + /// + char commentChar; private: /// void verifyTable(); /// - struct pushed_table { + class pushed_table { + public: /// pushed_table() : table_elem(0), table_siz(0) {}