X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Flyxlex_pimpl.C;h=80b757359aba6fd8828880adec12a68fc4f02494;hb=35204f8f33d7400a5fefeffea533fb4cb4097211;hp=a13a9fa6d621bbae7f485553350e54f9fceec4fd;hpb=e34a1e90af5fd0e5849942341bc12ed5bba991cd;p=lyx.git diff --git a/src/lyxlex_pimpl.C b/src/lyxlex_pimpl.C index a13a9fa6d6..80b757359a 100644 --- a/src/lyxlex_pimpl.C +++ b/src/lyxlex_pimpl.C @@ -19,12 +19,19 @@ #include "support/filetools.h" #include "support/lyxalgo.h" #include "support/lstrings.h" +#include "support/types.h" +#include "support/unicode.h" -using lyx::support::compare_ascii_no_case; -using lyx::support::getExtFromContents; -using lyx::support::MakeDisplayPath; -using lyx::support::split; -using lyx::support::subst; +#include + + +namespace lyx { + +using support::compare_ascii_no_case; +using support::getFormatFromContents; +using support::makeDisplayPath; +using support::split; +using support::subst; using std::endl; using std::getline; @@ -37,8 +44,9 @@ using std::ostream; namespace { -struct compare_tags +class compare_tags : public std::binary_function { +public: // used by lower_bound, sort and sorted bool operator()(keyword_item const & a, keyword_item const & b) const { @@ -62,7 +70,13 @@ LyXLex::Pimpl::Pimpl(keyword_item * tab, int num) string const LyXLex::Pimpl::getString() const { - return string(buff.begin(), buff.end()); + return buff; +} + + +docstring const LyXLex::Pimpl::getDocString() const +{ + return from_utf8(buff); } @@ -70,7 +84,7 @@ void LyXLex::Pimpl::printError(string const & message) const { string const tmpmsg = subst(message, "$$Token", getString()); lyxerr << "LyX: " << tmpmsg << " [around line " << lineno - << " of file " << MakeDisplayPath(name) << ']' << endl; + << " of file " << to_utf8(makeDisplayPath(name)) << ']' << endl; } @@ -131,9 +145,8 @@ void LyXLex::Pimpl::popTable() bool LyXLex::Pimpl::setFile(string const & filename) { - // Check the format of the file. - string const format = getExtFromContents(filename); + string const format = getFormatFromContents(filename); if (format == "gzip" || format == "zip" || format == "compress") { lyxerr[Debug::LYXLEX] << "lyxlex: compressed" << endl; @@ -141,14 +154,15 @@ bool LyXLex::Pimpl::setFile(string const & filename) // The check only outputs a debug message, because it triggers // a bug in compaq cxx 6.2, where is_open() returns 'true' for // a fresh new filebuf. (JMarc) - if (gz_.is_open() || istream::off_type(is.tellg()) > -1) + if (!gz_.empty() || istream::off_type(is.tellg()) > -1) lyxerr[Debug::LYXLEX] << "Error in LyXLex::setFile: " "file or stream already set." << endl; - gz_.open(filename.c_str(), ios::in); + gz_.push(io::gzip_decompressor()); + gz_.push(io::file_source(filename)); is.rdbuf(&gz_); name = filename; lineno = 0; - return gz_.is_open() && is.good(); + return gz_.component(1)->is_open() && is.good(); } else { lyxerr[Debug::LYXLEX] << "lyxlex: UNcompressed" << endl; @@ -190,13 +204,12 @@ bool LyXLex::Pimpl::next(bool esc /* = false */) // we extract the first word and leaves the rest // in pushTok. (Lgb) if (pushTok.find(' ') != string::npos && pushTok[0] == '\\') { - string tmp; - pushTok = split(pushTok, tmp, ' '); - buff.assign(tmp.begin(), tmp.end()); + buff.clear(); + pushTok = split(pushTok, buff, ' '); return true; } else { - buff.assign(pushTok.begin(), pushTok.end()); - pushTok.erase(); + buff = pushTok; + pushTok.clear(); return true; } } @@ -240,7 +253,7 @@ bool LyXLex::Pimpl::next(bool esc /* = false */) ++lineno; } - buff.pop_back(); + buff.resize(buff.size()-1); status = LEX_DATA; break; } @@ -361,7 +374,7 @@ bool LyXLex::Pimpl::next(bool esc /* = false */) ++lineno; } - buff.pop_back(); + buff.resize(buff.size() -1); status = LEX_DATA; break; } @@ -440,7 +453,7 @@ bool LyXLex::Pimpl::eatLine() if (c == '\n') { ++lineno; - buff.pop_back(); + buff.resize(buff.size() - 1); status = LEX_DATA; return true; } else { @@ -456,13 +469,12 @@ bool LyXLex::Pimpl::nextToken() // we extract the first word and leaves the rest // in pushTok. (Lgb) if (pushTok.find(' ') != string::npos && pushTok[0] == '\\') { - string tmp; - pushTok = split(pushTok, tmp, ' '); - buff.assign(tmp.begin(), tmp.end()); + buff.clear(); + pushTok = split(pushTok, buff, ' '); return true; } else { - buff.assign(pushTok.begin(), pushTok.end()); - pushTok.erase(); + buff = pushTok; + pushTok.clear(); return true; } } @@ -510,3 +522,6 @@ void LyXLex::Pimpl::pushToken(string const & pt) { pushTok = pt; } + + +} // namespace lyx