]> git.lyx.org Git - lyx.git/blobdiff - src/insets/lyxinset.h
some reindentation, revert workarea xpos++, constify, remove all traces of LyXParagra...
[lyx.git] / src / insets / lyxinset.h
index 482037f17ebda121a3194d6552219d7988937014..5d14cd0ae3ac00a5fa595c19a901b64d6bd18089 100644 (file)
@@ -19,9 +19,9 @@
 
 #include <X11/Xlib.h>
 
-#include "gettext.h"
 #include "lyxfont.h"
 #include "lyxlex.h"
+#include "commandtags.h"
 
 class BufferView;
 class Buffer;
@@ -31,7 +31,6 @@ class LyXText;
 struct LaTeXFeatures;
 
 
-
 /// Insets
 class Inset {
 public:
@@ -46,17 +45,11 @@ public:
                ///
                TOC_CODE,  // do these insets really need a code? (ale)
                ///
-               LOF_CODE,
-               ///
-               LOT_CODE,
-               ///
-               LOA_CODE,
-               ///
                QUOTE_CODE,
                ///
                MARK_CODE,
                ///
-               REF_CODE,
+               REF_CODE, // 5
                ///
                URL_CODE,
                ///
@@ -66,7 +59,7 @@ public:
                ///
                ENDING_CODE,
                ///
-               LABEL_CODE,
+               LABEL_CODE, // 10
                ///
                IGNORE_CODE,
                ///
@@ -76,7 +69,7 @@ public:
                ///
                INDEX_CODE,
                ///
-               INCLUDE_CODE,
+               INCLUDE_CODE, // 15
                ///
                GRAPHICS_CODE,
                ///
@@ -86,7 +79,7 @@ public:
                ///
                TEXT_CODE,
                ///
-               ERT_CODE,
+               ERT_CODE, // 20
                ///
                FOOT_CODE,
                ///
@@ -96,42 +89,61 @@ public:
                ///
                MINIPAGE_CODE,
                ///
-               SPECIALCHAR_CODE,
+               SPECIALCHAR_CODE, // 25
                ///
                TABULAR_CODE,
                ///
-               EXTERNAL_CODE
+               EXTERNAL_CODE,
+               ///
+               THEOREM_CODE,
+               ///
+               CAPTION_CODE,
+               ///
+               MATHMACRO_CODE, // 30
+               ///
+               ERROR_CODE,
+               ///
+               CITE_CODE,
+               ///
+               FLOAT_LIST_CODE
        };
 
        ///
-       enum { TEXT_TO_INSET_OFFSET = 2 };
-
-       enum EDITABLE {
-           NOT_EDITABLE = 0,
-           IS_EDITABLE,
-           HIGHLY_EDITABLE
+       enum {
+               ///
+               TEXT_TO_INSET_OFFSET = 2
        };
 
        ///
-       Inset() { owner_ = 0; top_x = top_baseline = 0; }
+       enum EDITABLE {
+               ///
+               NOT_EDITABLE = 0,
+               ///
+               IS_EDITABLE,
+               ///
+               HIGHLY_EDITABLE
+       };
+       
        ///
+       Inset() : top_x(0), top_baseline(0), scx(0), owner_(0) {}
+       /// Virtual base destructor
        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, 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,15 +165,16 @@ public:
        ///
        virtual void Read(Buffer const *, LyXLex & lex) = 0;
        /** returns the number of rows (\n's) of generated tex code.
-        fragile == true means, that the inset should take care about
-        fragile commands by adding a \protect before.
-        If the free_spc (freespacing) variable is set, then this inset
-        is in a free-spacing paragraph.
-        */
+           fragile == true means, that the inset should take care about
+           fragile commands by adding a \protect before.
+           If the free_spc (freespacing) variable is set, then this inset
+           is in a free-spacing paragraph.
+       */
        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;
        ///
@@ -170,17 +183,17 @@ public:
        virtual void Validate(LaTeXFeatures & features) const;
        ///
        virtual bool Deletable() const;
-
+       
        /// 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;
 
@@ -195,23 +208,41 @@ public:
        ///
        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 *,
+                                    bool const recursive = false) const;
+       ///
+       virtual void deleteLyXText(BufferView *, bool = true) const {}
+       ///
+       virtual void resizeLyXText(BufferView *) const {}
+       /// returns the actuall scroll-value
+       virtual int scroll(bool recursive=true) const {
+               if (!recursive || !owner_)
+                       return scx;
+               return 0;
+       }
 
 protected:
        ///
        mutable int top_x;
+       ///
        mutable int top_baseline;
-
+       ///
+       mutable int scx;
 private:
        ///
        Inset * owner_;
@@ -226,27 +257,27 @@ private:
 //  [Alejandro 080596] 
 
 /** Extracted from Matthias notes:
 
 * An inset can simple call LockInset in it's edit call and *ONLY* 
 * in it's edit call.
 *
 * Unlocking is either done by LyX or the inset itself with a 
 * UnlockInset-call
 *
 * During the lock, all button and keyboard events will be modified
 * and send to the inset through the following inset-features. Note that
 * Inset::InsetUnlock will be called from inside UnlockInset. It is meant
 * to contain the code for restoring the menus and things like this.
 
 * If a inset wishes any redraw and/or update it just has to call
 * UpdateInset(this).
 
 * It's is completly irrelevant, where the inset is. UpdateInset will
 * find it in any paragraph in any buffer. 
 * Of course the_locking_inset and the insets in the current paragraph/buffer
 *  are checked first, so no performance problem should occur.
 */
-class UpdatableInset: public Inset {
+ * 
+ * An inset can simple call LockInset in it's edit call and *ONLY* 
+ * in it's edit call.
+ *
+ * Unlocking is either done by LyX or the inset itself with a 
+ * UnlockInset-call
+ *
+ * During the lock, all button and keyboard events will be modified
+ * and send to the inset through the following inset-features. Note that
+ * Inset::InsetUnlock will be called from inside UnlockInset. It is meant
+ * to contain the code for restoring the menus and things like this.
+ * 
+ * If a inset wishes any redraw and/or update it just has to call
+ * UpdateInset(this).
+ * 
+ * It's is completly irrelevant, where the inset is. UpdateInset will
+ * find it in any paragraph in any buffer. 
+ * Of course the_locking_inset and the insets in the current paragraph/buffer
+ *  are checked first, so no performance problem should occur.
+ */
+class UpdatableInset : public Inset {
 public:
        /** Dispatch result codes
            Now that nested updatable insets are allowed, the local dispatch
@@ -255,17 +286,17 @@ public:
         
            DISPATCHED   = the inset catched the action
            DISPATCHED_NOUPDATE = the inset catched the action and no update
-                                  is needed here to redraw the inset
+                                 is needed here to redraw the inset
            FINISHED     = the inset must be unlocked as a result
                           of the action
            UNDISPATCHED = the action was not catched, it should be
                           dispatched by lower level insets
        */ 
        enum RESULT {
-           UNDISPATCHED = 0,
-           DISPATCHED,
-           DISPATCHED_NOUPDATE,
-           FINISHED
+               UNDISPATCHED = 0,
+               DISPATCHED,
+               DISPATCHED_NOUPDATE,
+               FINISHED
        };
     
        /// To convert old binary dispatch results
@@ -274,16 +305,15 @@ public:
        }
 
        ///
-       UpdatableInset() { scx = mx_scx = 0; }
-       ///
-       //virtual ~UpdatableInset() {}
+       UpdatableInset() : cursor_visible_(false), block_drawing_(false) {}
+
        ///
        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 *);
        ///
@@ -317,7 +347,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; }
@@ -329,24 +359,45 @@ public:
                                        bool /*lr*/ = false)
                { return false; }
        ///  An updatable inset could handle lyx editing commands
-       virtual RESULT LocalDispatch(BufferView *, int, string const &);
+       virtual RESULT LocalDispatch(BufferView *, kb_action, string const &);
        ///
-       virtual bool isCursorVisible() const { return cursor_visible; }
+       bool isCursorVisible() const { return cursor_visible_; }
        ///
-       virtual int getMaxWidth(Painter & pain, UpdatableInset const *) const;
+       virtual int getMaxWidth(BufferView * bv, UpdatableInset const *) const;
        ///
-       /// because we could have fake text insets and have to call this
-       /// inside them without cast!!!
-       virtual LyXText * getLyXText(BufferView *) const { return 0; }
-       virtual void deleteLyXText(BufferView *) {}
+       int scroll(bool recursive=true) const {
+               // We need this method to not clobber the real method in Inset
+               return Inset::scroll(recursive);
+       }
+       ///
+       virtual bool ShowInsetDialog(BufferView *) const { return false; }
+       ///
+       virtual void nodraw(bool b) {
+               block_drawing_ = b;
+       }
+       ///
+       virtual bool nodraw() const {
+               return block_drawing_;
+       }
 
 protected:
        ///
-       mutable bool cursor_visible;
+       void toggleCursorVisible() const {
+               cursor_visible_ = !cursor_visible_;
+       }
+       ///
+       void setCursorVisible(bool b) const {
+               cursor_visible_ = b;
+       }
+       /// scrolls to absolute position in bufferview-workwidth * sx units
+       void scroll(BufferView *, float sx) const;
+       /// scrolls offset pixels
+       void scroll(BufferView *, int offset) const;
 
 private:
        ///
-       int mx_scx;
-       mutable int scx;
+       mutable bool cursor_visible_;
+       ///
+       bool block_drawing_;
 };
 #endif