X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FLColor.C;h=33cf10686d3aaa1f3197ee6763e9f18f52e5f7b6;hb=414a11684e77aee713135ae65ec7438cfc4b162f;hp=e515ed5dc866c043b34c03dc1d6e9d91165a2a5f;hpb=31c24b4002c7e3a211defb807b4b258f33ee5e86;p=lyx.git diff --git a/src/LColor.C b/src/LColor.C index e515ed5dc8..33cf10686d 100644 --- a/src/LColor.C +++ b/src/LColor.C @@ -33,7 +33,7 @@ using std::string; namespace { struct ColorEntry { - int lcolor; + LColor::color lcolor; char const * guiname; char const * latexname; char const * x11name; @@ -42,9 +42,11 @@ struct ColorEntry { } -struct LColor::Pimpl { +class LColor::Pimpl { +public: /// - struct information { + class information { + public: /// the name as it appears in the GUI string guiname; /// the name used in LaTeX @@ -59,22 +61,25 @@ struct LColor::Pimpl { void fill(ColorEntry const & entry) { information in; - in.lyxname = string(entry.lyxname); - in.latexname = string(entry.latexname); - in.x11name = string(entry.x11name); - in.guiname = string(entry.guiname); + in.lyxname = entry.lyxname; + in.latexname = entry.latexname; + in.x11name = entry.x11name; + in.guiname = entry.guiname; infotab[entry.lcolor] = in; - transform[string(entry.lyxname)] = int(entry.lcolor); + lyxcolors[entry.lyxname] = entry.lcolor; + latexcolors[entry.latexname] = entry.lcolor; } /// - typedef std::map InfoTab; + typedef std::map InfoTab; /// the table of color information InfoTab infotab; - typedef std::map Transform; - /// the transform between colour name string and integer code. - Transform transform; + typedef std::map Transform; + /// the transform between LyX color name string and integer code. + Transform lyxcolors; + /// the transform between LaTeX color name string and integer code. + Transform latexcolors; }; @@ -160,10 +165,10 @@ LColor::~LColor() {} -void LColor::operator=(LColor const & c) +LColor & LColor::operator=(LColor tmp) { - LColor tmp(c); boost::swap(pimpl_, tmp.pimpl_); + return *this; } @@ -183,7 +188,7 @@ string const LColor::getX11Name(LColor::color c) const return it->second.x11name; lyxerr << "LyX internal error: Missing color" - " entry in LColor.C for " << int(c) << '\n' + " entry in LColor.C for " << c << '\n' << "Using black." << endl; return "black"; } @@ -223,7 +228,7 @@ bool LColor::setColor(LColor::color col, string const & x11name) << " may not be redefined" << endl; return false; } - + it->second.x11name = x11name; return true; } @@ -232,15 +237,14 @@ bool LColor::setColor(LColor::color col, string const & x11name) bool LColor::setColor(string const & lyxname, string const &x11name) { string const lcname = ascii_lowercase(lyxname); - if (pimpl_->transform.find(lcname) == pimpl_->transform.end()) { - lyxerr[Debug::GUI] - << "LColor::setColor: Unknown color \"" + if (pimpl_->lyxcolors.find(lcname) == pimpl_->lyxcolors.end()) { + lyxerr[Debug::GUI] + << "LColor::setColor: Unknown color \"" << lyxname << '"' << endl; addColor(static_cast(pimpl_->infotab.size()), lcname); } - return setColor(static_cast(pimpl_->transform[lcname]), - x11name); + return setColor(pimpl_->lyxcolors[lcname], x11name); } @@ -250,7 +254,7 @@ LColor::color LColor::getFromGUIName(string const & guiname) const Pimpl::InfoTab::const_iterator end = pimpl_->infotab.end(); for (; it != end; ++it) { if (!compare_ascii_no_case(_(it->second.guiname), guiname)) - return static_cast(it->first); + return it->first; } return LColor::inherit; } @@ -266,13 +270,25 @@ void LColor::addColor(LColor::color c, string const & lyxname) const LColor::color LColor::getFromLyXName(string const & lyxname) const { string const lcname = ascii_lowercase(lyxname); - if (pimpl_->transform.find(lcname) == pimpl_->transform.end()) { - lyxerr << "LColor::getFromLyXName: Unknown color \"" + if (pimpl_->lyxcolors.find(lcname) == pimpl_->lyxcolors.end()) { + lyxerr << "LColor::getFromLyXName: Unknown color \"" << lyxname << '"' << endl; return none; } - return static_cast(pimpl_->transform[lcname]); + return pimpl_->lyxcolors[lcname]; +} + + +LColor::color LColor::getFromLaTeXName(string const & latexname) const +{ + if (pimpl_->latexcolors.find(latexname) == pimpl_->latexcolors.end()) { + lyxerr << "LColor::getFromLaTeXName: Unknown color \"" + << latexname << '"' << endl; + return none; + } + + return pimpl_->latexcolors[latexname]; }