]> git.lyx.org Git - lyx.git/blobdiff - src/LColor.C
code cosmetics to the iterator fix
[lyx.git] / src / LColor.C
index 0ea92a1e12052691ead27d79b74317a9ca6ea450..33cf10686d3aaa1f3197ee6763e9f18f52e5f7b6 100644 (file)
@@ -1,25 +1,33 @@
-/* This file is part of
- * ======================================================
+/**
+ * \file LColor.C
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
  *
- *           LyX, The Document Processor
+ * \author Asger Alstrup
+ * \author Lars Gullik Bjønnes
+ * \author Matthias Ettrich
+ * \author Jean-Marc Lasgouttes
+ * \author John Levon
+ * \author André Pönitz
+ * \author Martin Vermeer
  *
- *         Copyright 1998-2001 The LyX Team
- *
- *======================================================*/
+ * Full author contact details are available in file CREDITS.
+ */
 
 #include <config.h>
 
 #include "debug.h"
-#include "LColor.h"
-#include "support/LAssert.h"
 #include "gettext.h"
+#include "LColor.h"
 #include "support/lstrings.h"
 
 #include <map>
 
-using namespace lyx::support;
+using lyx::support::compare_ascii_no_case;
+using lyx::support::ascii_lowercase;
 
 using std::endl;
+using std::string;
 
 
 namespace {
@@ -34,10 +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
@@ -51,17 +60,27 @@ struct LColor::Pimpl {
        /// initialise a color entry
        void fill(ColorEntry const & entry)
        {
-               information & in = infotab[entry.lcolor];
-               in.guiname   = entry.guiname;
+               information in;
+               in.lyxname   = entry.lyxname;
                in.latexname = entry.latexname;
                in.x11name   = entry.x11name;
-               in.lyxname   = entry.lyxname;
+               in.guiname   = entry.guiname;
+               infotab[entry.lcolor] = in;
+               lyxcolors[entry.lyxname] = entry.lcolor;
+               latexcolors[entry.latexname] = entry.lcolor;
        }
 
        ///
        typedef std::map<LColor::color, information> InfoTab;
        /// the table of color information
        InfoTab infotab;
+
+       typedef std::map<string, LColor::color> 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;
+
 };
 
 
@@ -143,108 +162,133 @@ LColor::LColor(LColor const & c)
 
 
 LColor::~LColor()
-{
-       delete pimpl_;
-}
+{}
 
 
-void LColor::operator=(LColor const & c)
+LColor & LColor::operator=(LColor tmp)
 {
-       LColor tmp(c);
-       std::swap(pimpl_, tmp.pimpl_);
+       boost::swap(pimpl_, tmp.pimpl_);
+       return *this;
 }
 
 
-
 string const LColor::getGUIName(LColor::color c) const
 {
-       Pimpl::InfoTab::const_iterator ici = pimpl_->infotab.find(c);
-       if (ici != pimpl_->infotab.end())
-               return _(ici->second.guiname);
+       Pimpl::InfoTab::const_iterator it = pimpl_->infotab.find(c);
+       if (it != pimpl_->infotab.end())
+               return _(it->second.guiname);
        return "none";
 }
 
 
 string const LColor::getX11Name(LColor::color c) const
 {
-       Pimpl::InfoTab::const_iterator ici = pimpl_->infotab.find(c);
-       if (ici != pimpl_->infotab.end())
-               return ici->second.x11name;
+       Pimpl::InfoTab::const_iterator it = pimpl_->infotab.find(c);
+       if (it != pimpl_->infotab.end())
+               return it->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 " << c << '\n'
+              << "Using black." << endl;
        return "black";
 }
 
 
 string const LColor::getLaTeXName(LColor::color c) const
 {
-       Pimpl::InfoTab::const_iterator ici = pimpl_->infotab.find(c);
-       if (ici != pimpl_->infotab.end())
-               return ici->second.latexname;
+       Pimpl::InfoTab::const_iterator it = pimpl_->infotab.find(c);
+       if (it != pimpl_->infotab.end())
+               return it->second.latexname;
        return "black";
 }
 
 
 string const LColor::getLyXName(LColor::color c) const
 {
-       Pimpl::InfoTab::const_iterator ici = pimpl_->infotab.find(c);
-       if (ici != pimpl_->infotab.end())
-               return ici->second.lyxname;
+       Pimpl::InfoTab::const_iterator it = pimpl_->infotab.find(c);
+       if (it != pimpl_->infotab.end())
+               return it->second.lyxname;
        return "black";
 }
 
 
-void LColor::setColor(LColor::color col, string const & x11name)
+bool LColor::setColor(LColor::color col, string const & x11name)
 {
-       Pimpl::InfoTab::iterator iti = pimpl_->infotab.find(col);
-       if (iti != pimpl_->infotab.end()) {
-               iti->second.x11name = x11name;
-               return;
+       Pimpl::InfoTab::iterator it = pimpl_->infotab.find(col);
+       if (it == pimpl_->infotab.end()) {
+               lyxerr << "Color " << col << " not found in database."
+                      << std::endl;
+               return false;
        }
-       lyxerr << "LyX internal error: color and such.\n";
-       Assert(false);
-}
-
-
-bool LColor::setColor(string const & lyxname, string const & x11name)
-{
-       color col = getFromLyXName(lyxname);
 
        // "inherit" is returned for colors not in the database
        // (and anyway should not be redefined)
-       if (col == inherit || col == ignore) {
-               lyxerr << "Color " << lyxname << " is undefined or may not be"
-                       " redefined" << endl;
+       if (col == none || col == inherit || col == ignore) {
+               lyxerr << "Color " << getLyXName(col)
+                      << " may not be redefined" << endl;
                return false;
        }
-       setColor (col, x11name);
+
+       it->second.x11name = x11name;
        return true;
 }
 
 
+bool LColor::setColor(string const & lyxname, string const &x11name)
+{
+       string const lcname = ascii_lowercase(lyxname);
+       if (pimpl_->lyxcolors.find(lcname) == pimpl_->lyxcolors.end()) {
+               lyxerr[Debug::GUI]
+                       << "LColor::setColor: Unknown color \""
+                      << lyxname << '"' << endl;
+               addColor(static_cast<color>(pimpl_->infotab.size()), lcname);
+       }
+
+       return setColor(pimpl_->lyxcolors[lcname], x11name);
+}
+
+
 LColor::color LColor::getFromGUIName(string const & guiname) const
 {
-       Pimpl::InfoTab::const_iterator ici = pimpl_->infotab.begin();
+       Pimpl::InfoTab::const_iterator it = 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;
+       for (; it != end; ++it) {
+               if (!compare_ascii_no_case(_(it->second.guiname), guiname))
+                       return it->first;
        }
        return LColor::inherit;
 }
 
 
+void LColor::addColor(LColor::color c, string const & lyxname) const
+{
+       ColorEntry ce = { c, "", "", "", lyxname.c_str() };
+       pimpl_->fill(ce);
+}
+
+
 LColor::color LColor::getFromLyXName(string const & lyxname) const
 {
-       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.lyxname, lyxname))
-                       return ici->first;
+       string const lcname = ascii_lowercase(lyxname);
+       if (pimpl_->lyxcolors.find(lcname) == pimpl_->lyxcolors.end()) {
+               lyxerr << "LColor::getFromLyXName: Unknown color \""
+                      << lyxname << '"' << endl;
+               return none;
        }
-       return LColor::inherit;
+
+       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];
 }