]> git.lyx.org Git - lyx.git/blobdiff - src/MetricsInfo.h
Change mouse cursor on tabular selection zones
[lyx.git] / src / MetricsInfo.h
index d717a54282b612147c4c903df076a98dbcaf6ed2..195d705459c6860a338fc41d553d1b1e96f935d0 100644 (file)
 #define METRICSINFO_H
 
 #include "Changes.h"
-#include "Color.h"
+#include "ColorCode.h"
 #include "FontInfo.h"
 
 #include "support/strfwd.h"
-#include "support/types.h"
 
 #include <string>
 
-class BufferView;
 
 namespace lyx {
 
 namespace frontend { class Painter; }
+class BufferView;
 class Inset;
 class MacroContext;
 
@@ -104,7 +103,7 @@ public:
        ColorCode backgroundColor(Inset const * inset, bool sel = true) const;
 
        /// Determines the text color based on the intended color, the
-       /// change tracking state and the selectio state. 
+       /// change tracking state and the selection state. 
        /// \param color what the color should be by default
        Color textColor(Color const & color) const;
 
@@ -118,6 +117,8 @@ public:
        Change change_;
        /// Whether the parent is selected as a whole
        bool selected;
+       /// Whether the spell checker is enabled for the parent
+       bool do_spellcheck;
        ///
        bool full_repaint;
        /// Current background color
@@ -127,14 +128,16 @@ public:
 class TextMetricsInfo {};
 
 
-/// Generic base for temporarily changing things.
-/// The original state gets restored when the Changer is destructed.
+/// Generic base for temporarily changing things. The derived class is
+/// responsible for restoring the original state when the Changer is
+/// destructed.
 template <class Struct, class Temp = Struct>
 class Changer {
-public:
-       ///
-       Changer(Struct & orig) : orig_(orig) {}
 protected:
+       ///
+       Changer(Struct & orig, Temp const & save) : orig_(orig), save_(save) {}
+       ///
+       Changer(Struct & orig) : orig_(orig), save_(orig) {}
        ///
        Struct & orig_;
        ///
@@ -230,7 +233,7 @@ public:
 class ColorChanger : public Changer<FontInfo, ColorCode> {
 public:
        ///
-       ColorChanger(FontInfo & font, docstring const & color,
+       ColorChanger(FontInfo & font, ColorCode color,
                     bool really_change_color = true);
        ///
        ~ColorChanger();