]> git.lyx.org Git - lyx.git/blobdiff - src/insets/lyxinset.h
Small fixes from Lior and Angus
[lyx.git] / src / insets / lyxinset.h
index 20117dae392f6a3d5a57b8189086c5e6a3076b48..a8b2d2cc73a36fd7b08ddbb9b5bbb0122d31bdd9 100644 (file)
 class BufferView;
 class Buffer;
 class Painter;
+class LyXText;
 
 struct LaTeXFeatures;
 
 
-
 /// Insets
 class Inset {
 public:
@@ -45,13 +45,13 @@ public:
                ///
                TOC_CODE,  // do these insets really need a code? (ale)
                ///
-               LOF_CODE,
+               LOF_CODE, // 2
                ///
                LOT_CODE,
                ///
                LOA_CODE,
                ///
-               QUOTE_CODE,
+               QUOTE_CODE, // 5
                ///
                MARK_CODE,
                ///
@@ -61,7 +61,7 @@ public:
                ///
                HTMLURL_CODE,
                ///
-               SEPARATOR_CODE,
+               SEPARATOR_CODE, // 10
                ///
                ENDING_CODE,
                ///
@@ -71,7 +71,7 @@ public:
                ///
                ACCENT_CODE,
                ///
-               MATH_CODE,
+               MATH_CODE, // 15
                ///
                INDEX_CODE,
                ///
@@ -81,7 +81,7 @@ public:
                ///
                PARENT_CODE,
                ///
-               BIBTEX_CODE,
+               BIBTEX_CODE, // 20
                ///
                TEXT_CODE,
                ///
@@ -91,39 +91,61 @@ public:
                ///
                MARGIN_CODE,
                ///
+               FLOAT_CODE, // 25
+               ///
+               MINIPAGE_CODE,
+               ///
                SPECIALCHAR_CODE,
                ///
                TABULAR_CODE,
                ///
-               EXTERNAL_CODE
+               EXTERNAL_CODE,
+               ///
+               THEOREM_CODE, // 30
+               ///
+               CAPTION_CODE,
+               ///
+               MATHMACRO_CODE,
+               ///
+               ERROR_CODE
        };
 
+       ///
+       enum {
+               ///
+               TEXT_TO_INSET_OFFSET = 2
+       };
+
+       ///
        enum EDITABLE {
-           NOT_EDITABLE = 0,
-           IS_EDITABLE,
-           HIGHLY_EDITABLE
+               ///
+               NOT_EDITABLE = 0,
+               ///
+               IS_EDITABLE,
+               ///
+               HIGHLY_EDITABLE
        };
 
        ///
-       Inset() { owner_ = 0; top_x = top_baseline = 0; }
+       Inset() { owner_ = 0; top_x = top_baseline = 0; scx = 0; }
        ///
        virtual ~Inset() {}
        ///
-       virtual int ascent(Painter &, LyXFont const &) const = 0;
+       virtual int ascent(BufferView *, LyXFont const &) const = 0;
        ///
-       virtual int descent(Painter &, LyXFont const &) const = 0;
+       virtual int descent(BufferView *, LyXFont const &) const = 0;
        ///
-       virtual int width(Painter &, LyXFont const &) const = 0;
+       virtual int width(BufferView *, LyXFont const &) const = 0;
        ///
        virtual void draw(BufferView *, LyXFont const &,
-                         int baseline, float & x) const = 0;
+                         int baseline, float & x, bool cleared) const = 0;
        /// update the inset representation
-       virtual void update(BufferView *, LyXFont const &, bool =false)
+       virtual void update(BufferView *, LyXFont const &, bool = false)
                {}
        ///
-       virtual LyXFont ConvertFont(LyXFont font);
+       virtual LyXFont const ConvertFont(LyXFont const & font) const;
        /// what appears in the minibuffer when opening
-       virtual const char * EditMessage() const;
+       virtual string const EditMessage() const;
        ///
        virtual void Edit(BufferView *, int x, int y, unsigned int button);
        ///
@@ -153,7 +175,8 @@ public:
        virtual int Latex(Buffer const *, std::ostream &, bool fragile,
                          bool free_spc) const = 0;
        ///
-       virtual int Ascii(Buffer const *, std::ostream &) const = 0;
+       virtual int Ascii(Buffer const *,
+                         std::ostream &, int linelen = 0) const = 0;
        ///
        virtual int Linuxdoc(Buffer const *, std::ostream &) const = 0;
        ///
@@ -166,39 +189,55 @@ public:
        /// returns LyX code associated with the inset. Used for TOC, ...)
        virtual Inset::Code LyxCode() const { return NO_CODE; }
   
-       virtual std::vector<string> getLabelList() const {
+       virtual std::vector<string> const getLabelList() const {
                return std::vector<string>();
        }
 
        ///
-       virtual Inset * Clone() const = 0;
+       virtual Inset * Clone(Buffer const &) const = 0;
 
        /// returns true to override begin and end inset in file
        virtual bool DirectWrite() const;
 
        /// Returns true if the inset should be centered alone
-       virtual bool display() const { return false; }  
+       virtual bool display() const { return false; }
        /// Changes the display state of the inset
-       virtual void display(bool) {}  
+       virtual void display(bool) {}
+       ///
+       /// returns true if this inset needs a row on it's own
+       ///
+       virtual bool needFullRow() const { return false; }
        ///
        virtual bool InsertInsetAllowed(Inset *) const { return false; }
        ///
-       virtual void setInsetName(const char * s) { name = s; }
+       void setInsetName(string const & s) { name = s; }
        ///
-       virtual string getInsetName() const { return name; }
+       string const getInsetName() const { return name; }
        ///
-       virtual void setOwner(Inset * inset) { owner_ = inset; }
+       void setOwner(Inset * inset) { owner_ = inset; }
        ///
-       virtual Inset * owner() const { return owner_; }
+       Inset * owner() const { return owner_; }
        ///
        int x() const { return top_x; }
        ///
        int y() const { return top_baseline; }
+       //
+       // because we could have fake text insets and have to call this
+       // inside them without cast!!!
+       ///
+       virtual LyXText * getLyXText(BufferView const *) const;
+       ///
+       virtual void deleteLyXText(BufferView *, bool = true) const {}
+       ///
+       virtual void resizeLyXText(BufferView *) const {}
+       /// returns the actuall scroll-value
+       int scroll() const { return scx; }
 
 protected:
        ///
        mutable int top_x;
        mutable int top_baseline;
+       mutable int scx;
 
 private:
        ///
@@ -262,16 +301,14 @@ public:
        }
 
        ///
-       UpdatableInset() { scx = mx_scx = 0; }
-       ///
-       //virtual ~UpdatableInset() {}
+       UpdatableInset() {}
        ///
        virtual EDITABLE Editable() const;
    
        /// may call ToggleLockedInsetCursor
        virtual void ToggleInsetCursor(BufferView *);
        ///
-       virtual void ShowInsetCursor(BufferView *);
+       virtual void ShowInsetCursor(BufferView *, bool show=true);
        ///
        virtual void HideInsetCursor(BufferView *);
        ///
@@ -291,7 +328,7 @@ public:
        virtual void Edit(BufferView *, int x, int y, unsigned int button);
        ///
        virtual void draw(BufferView *, LyXFont const &,
-                         int baseline, float & x) const;
+                         int baseline, float & x, bool cleared) const;
        ///
        virtual void SetFont(BufferView *, LyXFont const &,
                             bool toggleall = false);
@@ -305,7 +342,7 @@ public:
        virtual UpdatableInset * GetFirstLockingInsetOfType(Inset::Code c)
                { return (c == LyxCode()) ? this : 0; }
        ///
-       virtual int InsetInInsetY() { return 0; }
+       virtual unsigned int InsetInInsetY() { return 0; }
        ///
        virtual bool UpdateInsetInInset(BufferView *, Inset *)
                { return false; }
@@ -322,14 +359,16 @@ public:
        virtual bool isCursorVisible() const { return cursor_visible; }
        ///
        virtual int getMaxWidth(Painter & pain, UpdatableInset const *) const;
+       ///
+       int scroll() const { return scx; }
 
 protected:
        ///
        mutable bool cursor_visible;
 
-private:
-       ///
-       int mx_scx;
-       mutable int scx;
+       // scrolls to absolute position in bufferview-workwidth * sx units
+       void scroll(BufferView *, float sx) const;
+       // scrolls offset pixels
+       void scroll(BufferView *, int offset) const;
 };
 #endif