X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fchset.C;h=20e28319c5bb4b3b01cbb0ff5178bfb123de6015;hb=9833278ed8cd7f85dbabcfe0e2e8747c5db2db3d;hp=277f7db184d66fe78ccf6f34e66f84c8f9b17e37;hpb=33a28bdc9cdf978601d5d40b693f13924801ad9e;p=lyx.git diff --git a/src/chset.C b/src/chset.C index 277f7db184..20e28319c5 100644 --- a/src/chset.C +++ b/src/chset.C @@ -4,29 +4,40 @@ #pragma implementation #endif -#include - #include "chset.h" #include "support/filetools.h" -#include "support/LRegex.h" -#include "support/LSubstring.h" #include "support/lyxlib.h" #include "debug.h" +#include + +#include + using std::ifstream; using std::getline; using std::pair; using std::make_pair; using std::endl; +using boost::regex; +using boost::regex_match; + +#ifndef USE_INCLUDED_STRING +using boost::smatch; +#else +using boost::cmatch; +#endif + + bool CharacterSet::loadFile(string const & fname) { map_.clear(); name_.erase(); - - if (fname.empty() || fname == "ascii") - return true; // ascii 7-bit - + + // ascii 7-bit + if (fname.empty() || fname == "ascii") + return true; + // open definition file lyxerr[Debug::KBMAP] << "Reading character set file " << fname << ".cdef" << endl; @@ -37,20 +48,22 @@ bool CharacterSet::loadFile(string const & fname) return true; // no definition, use 7-bit ascii } name_ = fname; - + string line; // Ok, I'll be the first to admit that this is probably not // the fastest way to parse the cdef files, but I though it // was a bit neat. Anyway it is wrong to use the lyxlex parse - // without the use of a keyword table. - LRegex reg("^([12][0-9][0-9])[ \t]+\"([^ ]+)\".*"); + // without the use of a keyword table. + regex reg("^([12][0-9][0-9])[ \t]+\"([^ ]+)\".*"); while (getline(ifs, line)) { - if (reg.exact_match(line)) { - LRegex::SubMatches const & sub = reg.exec(line); - int const n = lyx::atoi(line.substr(sub[1].first, - sub[1].second)); - string const str = LSubstring(line, sub[2].first, - sub[2].second); +#ifndef USE_INCLUDED_STRING + smatch sub; +#else + cmatch sub; +#endif + if (regex_match(STRCONV(line), sub, reg)) { + int const n = lyx::atoi(STRCONV(sub.str(1))); + string const str = STRCONV(sub.str(2)); if (lyxerr.debugging(Debug::KBMAP)) lyxerr << "Chardef: " << n << " to [" << str << "]" << endl;