]> git.lyx.org Git - lyx.git/blobdiff - src/Color.h
* src/LyXRC.{cpp,h}:
[lyx.git] / src / Color.h
index b2a43b7784f7f34e7f42261625d1dcde1d0e22f6..d632bbce2f6fc48b9fbc3c740e55fab9d8f644fd 100644 (file)
@@ -19,7 +19,9 @@
 #ifndef LCOLOR_H
 #define LCOLOR_H
 
-#include "support/docstring.h"
+#include "ColorCode.h"
+
+#include "support/strfwd.h"
 
 #include <boost/scoped_ptr.hpp>
 
@@ -49,140 +51,6 @@ class Color
 // explanation.
 {
 public:
-       /// Names of colors, including all logical colors
-       enum color {
-               /// No particular color---clear or default
-               none,
-               /// The different text colors
-               black,
-               ///
-               white,
-               ///
-               red,
-               ///
-               green,
-               ///
-               blue,
-               ///
-               cyan,
-               ///
-               magenta,
-               ///
-               yellow,
-
-               // Needed interface colors
-
-               /// Cursor color
-               cursor,
-               /// Background color
-               background,
-               /// Foreground color
-               foreground,
-               /// Background color of selected text
-               selection,
-               /// Text color in LaTeX mode
-               latex,
-               /// The color used for previews
-               preview,
-
-               /// Text color for notes
-               note,
-               /// Background color of notes
-               notebg,
-               /// Text color for comments
-               comment,
-               /// Background color of comments
-               commentbg,
-               /// Text color for greyedout inset
-               greyedout,
-               /// Background color of greyedout inset
-               greyedoutbg,
-               /// Shaded box background
-               shadedbg,
-
-               /// Color for the depth bars in the margin
-               depthbar,
-               /// Color for marking foreign language words
-               language,
-
-               /// Text color for command insets
-               command,
-               /// Background color for command insets
-               commandbg,
-               /// Frame color for command insets
-               commandframe,
-
-               /// Special chars text color
-               special,
-
-               /// Graphics inset background color
-               graphicsbg,
-               /// Math inset text color
-               math,
-               /// Math inset background color
-               mathbg,
-               /// Macro math inset background color
-               mathmacrobg,
-               /// Math inset frame color
-               mathframe,
-               /// Math line color
-               mathline,
-
-               /// caption frame color
-               captionframe,
-
-               /// collapsable insets text
-               collapsable,
-               /// collapsable insets frame
-               collapsableframe,
-
-               /// Inset marker background color
-               insetbg,
-               /// Inset marker frame color
-               insetframe,
-
-               /// Error box text color
-               error,
-               /// EOL marker color
-               eolmarker,
-               /// Added space colour
-               added_space,
-               /// Appendix marker color
-               appendix,
-               /// changebar color
-               changebar,
-               /// strike-out color
-               strikeout,
-               /// added text color
-               newtext,
-               /// Top and bottom line color
-               topline,
-               /// Table line color
-               tabularline,
-               /// Table line color
-               tabularonoffline,
-               /// Bottom area color
-               bottomarea,
-               /// Page break color
-               pagebreak,
-
-               // FIXME: why are the next four separate ??
-               /// Color used for button frame
-               buttonframe,
-               /// Color used for bottom background
-               buttonbg,
-               /// Color used for buttom under focus
-               buttonhoverbg,
-
-               // Logical attributes
-
-               /// Color is inherited
-               inherit,
-               /// For ignoring updates of a color
-               ignore
-       };
-
-
        ///
        Color();
        ///
@@ -195,7 +63,7 @@ public:
        /** set the given LyX color to the color defined by the X11 name given
         *  \returns true if successful.
         */
-       bool setColor(Color::color col, std::string const & x11name);
+       bool setColor(ColorCode col, std::string const & x11name);
 
        /** set the given LyX color to the color defined by the X11
         *  name given \returns true if successful. A new color entry
@@ -204,24 +72,24 @@ public:
        bool setColor(std::string const & lyxname, std::string const & x11name);
 
        /// Get the GUI name of \c color.
-       docstring const getGUIName(Color::color c) const;
+       docstring const getGUIName(ColorCode c) const;
 
        /// Get the X11 name of \c color.
-       std::string const getX11Name(Color::color c) const;
+       std::string const getX11Name(ColorCode c) const;
 
        /// Get the LaTeX name of \c color.
-       std::string const getLaTeXName(Color::color c) const;
+       std::string const getLaTeXName(ColorCode c) const;
 
        /// Get the LyX name of \c color.
-       std::string const getLyXName(Color::color c) const;
+       std::string const getLyXName(ColorCode c) const;
 
-       /// \returns the Color::color associated with the LyX name.
-       Color::color getFromLyXName(std::string const & lyxname) const;
-       /// \returns the Color::color associated with the LaTeX name.
-       Color::color getFromLaTeXName(std::string const & latexname) const;
+       /// \returns the ColorCode associated with the LyX name.
+       ColorCode getFromLyXName(std::string const & lyxname) const;
+       /// \returns the ColorCode associated with the LaTeX name.
+       ColorCode getFromLaTeXName(std::string const & latexname) const;
 private:
        ///
-       void addColor(Color::color c, std::string const & lyxname) const;
+       void addColor(ColorCode c, std::string const & lyxname) const;
        ///
        class Pimpl;
        ///
@@ -229,42 +97,12 @@ private:
 };
 
 
-/** \c Color_color is a wrapper for Color::color. It can be forward-declared and
- *  passed as a function argument without having to expose Color.h.
- */
-class Color_color {
-       Color::color val_;
-public:
-       /** The default constructor is nasty,
-        *  but allows us to use Color_color in STL containers.
-        */
-       Color_color() : val_(static_cast<Color::color>(-1)) {}
-
-       Color_color(Color::color val) : val_(val) {}
-       operator Color::color() const{ return val_; }
-};
-
-
 /// the current color definitions
 extern Color lcolor;
 /// the system color definitions
 extern Color system_lcolor;
 
 
-struct RGBColor;
-/// returns a string of form #rrggbb, given an RGBColor struct
-std::string const X11hexname(RGBColor const & col);
-
-struct HSVColor {
-       double h;
-       double s;
-       double v;
-       HSVColor() : h(0.0), s(0.0), v(0.0) {}
-       HSVColor(double hue, double sat, double val)
-               : h(hue), s(sat), v(val) {}
-       HSVColor(RGBColor const &);
-};
-
 struct RGBColor {
        unsigned int r;
        unsigned int g;
@@ -272,21 +110,10 @@ struct RGBColor {
        RGBColor() : r(0), g(0), b(0) {}
        RGBColor(unsigned int red, unsigned int green, unsigned int blue)
                : r(red), g(green), b(blue) {}
-       RGBColor(HSVColor const &);
        /// \param x11hexname is of the form "#ffa071"
        RGBColor(std::string const & x11hexname);
 };
 
-struct NamedColor : public RGBColor {
-       std::string lyxname;
-       std::string guiname;
-       NamedColor() : RGBColor() {}
-       NamedColor(std::string const & lyx, std::string const & gui,
-                  RGBColor const & c)
-               : RGBColor(c), lyxname(lyx), guiname(gui) {}
-       RGBColor const & color() const { return *this; }
-};
-
 inline
 bool operator==(RGBColor const & c1, RGBColor const & c2)
 {
@@ -300,6 +127,9 @@ bool operator!=(RGBColor const & c1, RGBColor const & c2)
        return !(c1 == c2);
 }
 
+/// returns a string of form #rrggbb, given an RGBColor struct
+std::string const X11hexname(RGBColor const & col);
+
 } // namespace lyx
 
 #endif