X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Flyxlex.h;h=0c1469a9eec86c6e541bbe803f6601f35992400f;hb=ba62665f966508db5a4de6864f4aa7374c5a5356;hp=13937e6a7d8b9f7f21974eeca6db6f4e4f2984d6;hpb=1cd14974e16ee6749af2380dd25d89942fc61962;p=lyx.git diff --git a/src/lyxlex.h b/src/lyxlex.h index 13937e6a7d..0c1469a9ee 100644 --- a/src/lyxlex.h +++ b/src/lyxlex.h @@ -17,12 +17,17 @@ #ifndef LYXLEX_H #define LYXLEX_H +#include "support/docstring.h" + #include #include -#include +namespace lyx { + +namespace support { class FileName; } + /// struct keyword_item { /// @@ -56,13 +61,17 @@ public: }; /// stream is open and end of stream is not reached + /// FIXME: Rename to good() since this is the name of the + /// corresponding std::stream method. bool isOK() const; /// stream is ok + /// FIXME: This does not behave like the std::stream counterpart. operator void const *() const; /// stream is not ok + /// FIXME: This does not behave like the std::stream counterpart. bool operator!() const; /// return true if able to open file, else false - bool setFile(std::string const & filename); + bool setFile(support::FileName const & filename); /// void setStream(std::istream & is); /// @@ -96,10 +105,13 @@ public: /// bool getBool() const; /// - float getFloat() const; + double getFloat() const; /// std::string const getString() const; + /// + docstring const getDocString() const; + /** Get a long string, ended by the tag `endtag'. This string can span several lines. The first line serves as a template for how many spaces the lines @@ -111,8 +123,6 @@ public: /// bool eatLine(); - /// - int findToken(char const * const str[]); /// Pushes a token list on a stack and replaces it with a new one. void pushTable(keyword_item *, int); @@ -133,8 +143,8 @@ public: /// extract string LyXLex & operator>>(std::string &); - /// extract float - LyXLex & operator>>(float &); + /// extract docstring + LyXLex & operator>>(docstring &); /// extract double LyXLex & operator>>(double &); /// extract integer @@ -144,8 +154,12 @@ public: /// extract bool LyXLex & operator>>(bool &); + /// Quotes a string so that reading it again with LyXLex::next(true) + /// gets the original string + static std::string const quoteString(std::string const &); + private: - struct Pimpl; + class Pimpl; /// Pimpl * pimpl_; }; @@ -157,7 +171,8 @@ private: exceptions. @author Lgb */ -struct pushpophelper { +class pushpophelper { +public: /// pushpophelper(LyXLex & lexrc, keyword_item * i, int s) : lex(lexrc) { lex.pushTable(i, s); @@ -177,4 +192,7 @@ struct pushpophelper { #define pushpophelper(x, y, z) unnamed_pushpophelper; // Tip gotten from Bobby Schmidt's column in C/C++ Users Journal + +} // namespace lyx + #endif