#include "gettext.h"
#include "support/lstrings.h"
+#include <map>
+
+using namespace lyx::support;
+
using std::endl;
-void LColor::fill(LColor::color col, string const & gui,
- string const & latex, string const & x11,
- string const & lyx) {
- information in;
- in.guiname = gui;
- in.latexname = latex;
- in.x11name = x11;
- in.lyxname = lyx;
- infotab[col] = in;
-}
+namespace {
struct ColorEntry {
- LColor::color lcolor;
+ int lcolor;
char const * guiname;
char const * latexname;
char const * x11name;
char const * lyxname;
};
+}
+
+struct TransformEntry {
+ char const * lyxname;
+ int ncolor;
+};
+
+
+struct LColor::Pimpl {
+ ///
+ struct information {
+ /// the name as it appears in the GUI
+ string guiname;
+ /// the name used in LaTeX
+ string latexname;
+ /// the name for X11
+ string x11name;
+ /// the name for LyX
+ string lyxname;
+ };
+
+ /// initialise a color entry
+ 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);
+ infotab[entry.lcolor] = in;
+ transform[string(entry.lyxname)] = int(entry.lcolor);
+ }
+
+ ///
+ typedef std::map<int, information> InfoTab;
+ /// the table of color information
+ InfoTab infotab;
+
+ typedef std::map<string, int> Transform;
+ /// the transform between colour name string and integer code.
+ Transform transform;
+
+};
+
LColor::LColor()
+ : pimpl_(new Pimpl)
{
// LColor::color, gui, latex, x11, lyx
- ColorEntry items[] = {
+ static ColorEntry const items[] = {
{ none, N_("none"), "none", "black", "none" },
{ black, N_("black"), "black", "black", "black" },
{ white, N_("white"), "white", "white", "white" },
{ preview, N_("previewed snippet"), "preview", "black", "preview" },
{ note, N_("note"), "note", "yellow", "note" },
{ notebg, N_("note background"), "notebg", "yellow", "notebg" },
+ { comment, N_("comment"), "comment", "magenta", "comment" },
+ { commentbg, N_("comment background"), "commentbg", "linen", "commentbg" },
+ { greyedout, N_("greyedout inset"), "greyedout", "red", "greyedout" },
+ { greyedoutbg, N_("greyedout inset background"), "greyedoutbg", "linen", "greyedoutbg" },
{ depthbar, N_("depth bar"), "depthbar", "IndianRed", "depthbar" },
{ language, N_("language"), "language", "Blue", "language" },
{ command, N_("command inset"), "command", "black", "command" },
{ newtext, N_("Added text"), "newtext", "Blue", "newtext" },
{ added_space, N_("added space markers"), "added_space", "Brown", "added_space" },
{ topline, N_("top/bottom line"), "topline", "Brown", "topline" },
- { tabularline, N_("tabular line"), "tabularline", "black",
+ { tabularline, N_("table line"), "tabularline", "black",
"tabularline" },
- { tabularonoffline, N_("tabular on/off line"), "tabularonoffline",
+ { tabularonoffline, N_("table on/off line"), "tabularonoffline",
"LightSteelBlue", "tabularonoffline" },
{ bottomarea, N_("bottom area"), "bottomarea", "grey40", "bottomarea" },
{ pagebreak, N_("page break"), "pagebreak", "RoyalBlue", "pagebreak" },
{ ignore, 0, 0, 0, 0 }
};
- int i = 0;
- while (items[i].guiname) {
- fill(items[i].lcolor, items[i].guiname, items[i].latexname,
- items[i].x11name, items[i].lyxname);
- ++i;
- }
+ for (int i = 0; items[i].guiname; ++i)
+ pimpl_->fill(items[i]);
+}
+
+
+LColor::LColor(LColor const & c)
+ : pimpl_(new Pimpl(*c.pimpl_))
+{}
+
+
+LColor::~LColor()
+{}
+
+
+void LColor::operator=(LColor const & c)
+{
+ LColor tmp(c);
+ boost::swap(pimpl_, tmp.pimpl_);
+}
+
+
+void LColor::fill(LColor::color c,
+ string const & lyxname,
+ string const & x11name,
+ string const & latexname,
+ string const & guiname)
+{
+ ColorEntry ce;
+ ce.lcolor = c;
+ ce.guiname = guiname.c_str();
+ ce.latexname = latexname.c_str();
+ ce.x11name = x11name.c_str();
+ ce.lyxname = lyxname.c_str();
+ pimpl_->fill(ce);
}
string const LColor::getGUIName(LColor::color c) const
{
- InfoTab::const_iterator ici = infotab.find(c);
- if (ici != infotab.end())
+ Pimpl::InfoTab::const_iterator ici = pimpl_->infotab.find(c);
+ if (ici != pimpl_->infotab.end())
return _(ici->second.guiname);
+ return "none";
+}
+
+string const LColor::getGUIName(string const & s) const
+{
+ Pimpl::Transform::const_iterator ici = pimpl_->transform.find(s);
+ if (ici != pimpl_->transform.end()) {
+ Pimpl::InfoTab::const_iterator
+ it = pimpl_->infotab.find(ici->second);
+ if (it != pimpl_->infotab.end())
+ return it->second.guiname;
+ }
return "none";
}
string const LColor::getX11Name(LColor::color c) const
{
- InfoTab::const_iterator ici = infotab.find(c);
- if (ici != infotab.end())
+ Pimpl::InfoTab::const_iterator ici = pimpl_->infotab.find(c);
+ if (ici != pimpl_->infotab.end())
return ici->second.x11name;
lyxerr << "LyX internal error: Missing color"
- " entry in LColor.C for " << int(c) << '\n';
- lyxerr << "Using black.\n";
+ " entry in LColor.C for " << int(c) << endl;
+ lyxerr << "Using black." << endl;
+ return "black";
+}
+
+
+string const LColor::getX11Name(string const & s) const
+{
+ Pimpl::Transform::const_iterator ici = pimpl_->transform.find(s);
+ if (ici != pimpl_->transform.end()) {
+ Pimpl::InfoTab::const_iterator
+ it = pimpl_->infotab.find(ici->second);
+ if (it != pimpl_->infotab.end())
+ return it->second.x11name;
+ }
+ lyxerr << "LyX internal error: Missing color"
+ " entry in LColor.C for " << s << endl;
+ lyxerr << "Using black." << endl;
return "black";
}
string const LColor::getLaTeXName(LColor::color c) const
{
- InfoTab::const_iterator ici = infotab.find(c);
- if (ici != infotab.end())
+ Pimpl::InfoTab::const_iterator ici = pimpl_->infotab.find(c);
+ if (ici != pimpl_->infotab.end())
return ici->second.latexname;
return "black";
}
+string const LColor::getLaTeXName(string const & s) const
+{
+ Pimpl::Transform::const_iterator ici = pimpl_->transform.find(s);
+ if (ici != pimpl_->transform.end()) {
+ Pimpl::InfoTab::const_iterator
+ it = pimpl_->infotab.find(ici->second);
+ if (it != pimpl_->infotab.end())
+ return it->second.latexname;
+ }
+ return "black";
+}
+
+
string const LColor::getLyXName(LColor::color c) const
{
- InfoTab::const_iterator ici = infotab.find(c);
- if (ici != infotab.end())
+ Pimpl::InfoTab::const_iterator ici = pimpl_->infotab.find(c);
+ if (ici != pimpl_->infotab.end())
return ici->second.lyxname;
return "black";
}
+size_t LColor::size() const
+{
+ return pimpl_->infotab.size();
+}
+
+
void LColor::setColor(LColor::color col, string const & x11name)
{
- InfoTab::iterator iti = infotab.find(col);
- if (iti != infotab.end()) {
+ Pimpl::InfoTab::iterator iti = pimpl_->infotab.find(col);
+ if (iti != pimpl_->infotab.end()) {
iti->second.x11name = x11name;
return;
}
- lyxerr << "LyX internal error: color and such.\n";
- lyx::Assert(false);
+ lyxerr << "LyX internal error: color and such." << endl;
+ Assert(false);
}
bool LColor::setColor(string const & lyxname, string const & x11name)
{
- color col = getFromLyXName (lyxname);
+ color col = getFromLyXName(lyxname);
// "inherit" is returned for colors not in the database
// (and anyway should not be redefined)
" redefined" << endl;
return false;
}
- setColor (col, x11name);
+ setColor(col, x11name);
return true;
}
LColor::color LColor::getFromGUIName(string const & guiname) const
{
- InfoTab::const_iterator ici = infotab.begin();
- InfoTab::const_iterator end = infotab.end();
+ Pimpl::InfoTab::const_iterator ici = pimpl_->infotab.begin();
+ Pimpl::InfoTab::const_iterator end = pimpl_->infotab.end();
for (; ici != end; ++ici) {
if (!compare_ascii_no_case(_(ici->second.guiname), guiname))
- return ici->first;
+ return static_cast<LColor::color>(ici->first);
}
return LColor::inherit;
}
LColor::color LColor::getFromLyXName(string const & lyxname) const
{
-
- InfoTab::const_iterator ici = infotab.begin();
- InfoTab::const_iterator end = infotab.end();
- for (; ici != end; ++ici) {
- if (!compare_ascii_no_case(ici->second.lyxname, lyxname))
- return ici->first;
- }
- return LColor::inherit;
+ return static_cast<LColor::color>(pimpl_->transform[lyxname]);
}
+
// The evil global LColor instance
LColor lcolor;
// An equally evil global system LColor instance