]> git.lyx.org Git - lyx.git/blobdiff - src/insets/insettext.h
prevent crash when inserting minipage in table cell,
[lyx.git] / src / insets / insettext.h
index 33c7d5c363a439c6ef47c351f71763c93858f873..d88a94a8442c9da83726929fa39594f025efc99b 100644 (file)
 #ifndef INSETTEXT_H
 #define INSETTEXT_H
 
-
 #include "updatableinset.h"
+#include "textcursor.h"
 #include "LString.h"
 #include "LColor.h"
 #include "ParagraphList.h"
+#include "RowList.h"
+#include "dimension.h"
+#include "lyxtext.h"
 
 #include "support/types.h"
 
+#include "frontends/mouse_state.h"
+
 #include <boost/shared_ptr.hpp>
 
 class Painter;
@@ -47,17 +52,15 @@ public:
                ///
                CURSOR = 1,
                ///
-               CLEAR_FRAME = 2,
-               ///
-               DRAW_FRAME = 4,
+               DRAW_FRAME = 2,
                ///
-               SELECTION = 8,
+               SELECTION = 4,
                ///
-               CURSOR_PAR = 16,
+               CURSOR_PAR = 8,
                ///
-               FULL = 32,
+               FULL = 16,
                ///
-               INIT = 64
+               INIT = 32
        };
        ///
        enum DrawFrame {
@@ -71,12 +74,9 @@ public:
        ///
        InsetText(BufferParams const &);
        ///
-       explicit
-       InsetText(InsetText const &, bool same_id = false);
+       explicit InsetText(InsetText const &);
        ///
-       ~InsetText();
-       ///
-       Inset * clone(Buffer const &, bool same_id = false) const;
+       virtual std::auto_ptr<InsetBase> clone() const;
        ///
        InsetText & operator=(InsetText const & it);
        /// empty inset to empty par, or just mark as erased
@@ -86,30 +86,18 @@ public:
        ///
        void write(Buffer const *, std::ostream &) const;
        ///
-       int ascent(BufferView *, LyXFont const &) const;
-       ///
-       int descent(BufferView *, LyXFont const &) const;
-       ///
-       int width(BufferView *, LyXFont const & f) const;
+       void metrics(MetricsInfo &, Dimension &) const;
        ///
-       int textWidth(BufferView *, bool fordraw = false) const;
+       int textWidth() const;
        ///
-       void draw(BufferView *, LyXFont const &, int , float &, bool) const;
+       void draw(PainterInfo & pi, int x, int y) const;
        ///
-       void update(BufferView *, LyXFont const &, bool = false);
-       ///
-       void setUpdateStatus(BufferView *, int what) const;
+       void setUpdateStatus(int what) const;
        ///
        string const editMessage() const;
        ///
-       void edit(BufferView *, int, int, mouse_button::state);
-       ///
-       void edit(BufferView *, bool front = true);
-       ///
        bool isTextInset() const { return true; }
        ///
-       bool doClearArea() const;
-       ///
        void insetUnlock(BufferView *);
        ///
        bool lockInsetInInset(BufferView *, UpdatableInset *);
@@ -117,54 +105,48 @@ public:
        bool unlockInsetInInset(BufferView *,
                                UpdatableInset *, bool lr = false);
        ///
-       bool updateInsetInInset(BufferView *, Inset *);
+       bool updateInsetInInset(BufferView *, InsetOld *);
        ///
        RESULT localDispatch(FuncRequest const &);
        ///
        int latex(Buffer const *, std::ostream &,
-                 bool fragile, bool free_spc) const;
+                 LatexRunParams const &) const;
        ///
        int ascii(Buffer const *, std::ostream &, int linelen) const;
        ///
-       int linuxdoc(Buffer const *, std::ostream &) const { return 0; }
+       int linuxdoc(Buffer const *, std::ostream &) const ;
        ///
        int docbook(Buffer const *, std::ostream &, bool mixcont) const ;
        ///
        void validate(LaTeXFeatures & features) const;
        ///
-       Inset::Code lyxCode() const { return Inset::TEXT_CODE; }
-       ///
+       InsetOld::Code lyxCode() const { return InsetOld::TEXT_CODE; }
+       /// FIXME, document
        void getCursorPos(BufferView *, int & x, int & y) const;
+       /// Get the absolute document x,y of the cursor
+       virtual void getCursor(BufferView &, int &, int &) const;
        ///
        int insetInInsetY() const;
        ///
-       void toggleInsetCursor(BufferView *);
-       ///
-       void showInsetCursor(BufferView *, bool show = true);
-       ///
-       void hideInsetCursor(BufferView *);
-       ///
        void fitInsetCursor(BufferView *) const;
        ///
-       bool insertInset(BufferView *, Inset *);
+       bool insertInset(BufferView *, InsetOld *);
        ///
-       bool insetAllowed(Inset::Code) const;
+       bool insetAllowed(InsetOld::Code) const;
        ///
        UpdatableInset * getLockingInset() const;
        ///
-       UpdatableInset * getFirstLockingInsetOfType(Inset::Code);
+       UpdatableInset * getFirstLockingInsetOfType(InsetOld::Code);
        ///
        void setFont(BufferView *, LyXFont const &,
                     bool toggleall = false,
                     bool selectall = false);
        ///
-       int getMaxWidth(BufferView *, UpdatableInset const *) const;
-       ///
-       void init(InsetText const * ins = 0, bool same_id = false);
+       void init(InsetText const * ins);
        ///
        void writeParagraphData(Buffer const *, std::ostream &) const;
        ///
-       void setParagraphData(Paragraph *, bool same_id = false);
+       void setParagraphData(ParagraphList const &);
        ///
        void setText(string const &, LyXFont const &);
        ///
@@ -179,13 +161,15 @@ public:
        LyXText * getLyXText(BufferView const *,
                             bool const recursive = false) const;
        ///
+       void setViewCache(BufferView const * bv) const;
+       ///
        void deleteLyXText(BufferView *, bool recursive = true) const;
        ///
        void resizeLyXText(BufferView *, bool force = false) const;
        ///
        bool showInsetDialog(BufferView *) const;
        ///
-       std::vector<string> const getLabelList() const;
+       void getLabelList(std::vector<string> &) const;
        ///
        bool nodraw() const;
        ///
@@ -199,22 +183,14 @@ public:
                UpdatableInset::scroll(bv, offset);
        }
        ///
-       void selectAll(BufferView * bv);
-       ///
        void clearSelection(BufferView * bv);
        ///
-       Inset * getInsetFromID(int id) const;
-       ///
-       Paragraph * firstParagraph() const;
+       InsetOld * getInsetFromID(int id) const;
        ///
-       Paragraph * getFirstParagraph(int) const;
+       ParagraphList * getParagraphs(int) const;
        ///
        LyXCursor const & cursor(BufferView *) const;
        ///
-       Paragraph * paragraph() const;
-       ///
-       void paragraph(Paragraph *);
-       ///
        bool allowSpellcheck() const { return true; }
        ///
        WordLangTuple const
@@ -248,21 +224,24 @@ public:
        ///
        void getDrawFont(LyXFont &) const;
        /// append text onto the existing text
-       void appendParagraphs(BufferParams const & bp, Paragraph *);
+       void appendParagraphs(Buffer * bp, ParagraphList &);
 
        ///
-       void addPreview(grfx::PreviewLoader &) const;
+       void addPreview(lyx::graphics::PreviewLoader &) const;
 
        //
        // Public structures and variables
        ///
        mutable int need_update;
 
+       bool haveParagraphs() const {
+               return true;
+       }
        ///
        ParagraphList paragraphs;
 protected:
        ///
-       void updateLocal(BufferView *, int what, bool mark_dirty) const;
+       void updateLocal(BufferView *, int what, bool mark_dirty);
        /// set parameters for an initial lock of this inset
        void lockInset(BufferView *);
        /// lock an inset inside this one
@@ -286,19 +265,6 @@ private:
        ///
        void lfunMouseMotion(FuncRequest const &);
 
-       ///
-       struct InnerCache {
-               ///
-               InnerCache(boost::shared_ptr<LyXText>);
-               ///
-               boost::shared_ptr<LyXText> text;
-               ///
-               bool remove;
-       };
-       ///
-       typedef std::map<BufferView *, InnerCache> Cache;
-       ///
-       typedef Cache::value_type value_type;
        ///
        RESULT moveRight(BufferView *,
                                         bool activate_inset = true,
@@ -330,49 +296,39 @@ private:
        ///
        void removeNewlines();
        ///
-       int cx(BufferView *) const;
-       ///
-       int cix(BufferView *) const;
+       int cx() const;
        ///
-       int cy(BufferView *) const;
+       int cix() const;
        ///
-       int ciy(BufferView *) const;
+       int cy() const;
        ///
-       lyx::pos_type cpos(BufferView *) const;
+       int ciy() const;
        ///
-       Paragraph * cpar(BufferView *) const;
+       lyx::pos_type cpos() const;
        ///
-       bool cboundary(BufferView *) const;
+       ParagraphList::iterator cpar() const;
        ///
-       Row * crow(BufferView *) const;
+       bool cboundary() const;
        ///
-       void drawFrame(Painter &, bool cleared) const;
+       RowList::iterator crow() const;
        ///
-       void clearFrame(Painter &, bool cleared) const;
+       void drawFrame(Painter &, int x) const;
        ///
-       void clearInset(BufferView *, int baseline, bool & cleared) const;
+       void clearInset(BufferView *, int start_x, int baseline) const;
        ///
-       void saveLyXTextState(LyXText *) const;
+       void saveLyXTextState() const;
        ///
-       void restoreLyXTextState(BufferView *, LyXText *) const;
+       void restoreLyXTextState() const;
        ///
-       void reinitLyXText() const;
-       ///
-       void collapseParagraphs(BufferView *) const;
+       void collapseParagraphs(BufferView *);
 
        /* Private structures and variables */
        ///
        mutable bool locked;
        ///
-       mutable int insetAscent;
-       ///
-       mutable int insetDescent;
-       ///
-       mutable int insetWidth;
-       ///
        mutable int top_y;
        ///
-       Paragraph * inset_par;
+       ParagraphList::iterator inset_par;
        ///
        lyx::pos_type inset_pos;
        ///
@@ -382,45 +338,17 @@ private:
        ///
        mutable int inset_y;
        ///
-       mutable int old_max_width;
-       ///
        bool no_selection;
        ///
        UpdatableInset * the_locking_inset;
        ///
-       mutable Paragraph * old_par;
-       /// The cache.
-       mutable Cache cache;
+       mutable ParagraphList::iterator old_par;
        ///
        mutable int last_drawn_width;
-       ///
-       mutable bool frame_is_visible;
-       ///
-       mutable BufferView * cached_bview;
-       ///
-       mutable boost::shared_ptr<LyXText> cached_text;
-       ///
-       struct save_state {
-               Paragraph * lpar;
-               Paragraph * selstartpar;
-               Paragraph * selendpar;
-               lyx::pos_type pos;
-               lyx::pos_type selstartpos;
-               lyx::pos_type selendpos;
-               bool boundary;
-               bool selstartboundary;
-               bool selendboundary;
-               bool selection;
-               bool mark_set;
-               bool refresh;
-       };
-       ///
-       mutable save_state sstate;
 
-       ///
-       // this is needed globally so we know that we're using it actually and
-       // so the LyXText-Cache is not erased until used!
-       mutable LyXText * lt;
+       /// some funny 'temporarily saved state'
+       mutable TextCursor sstate;
+
        ///
        // to remember old painted frame dimensions to clear it on the right spot!
        ///
@@ -428,15 +356,18 @@ private:
        mutable int frame_y;
        mutable int frame_w;
        mutable int frame_h;
-       ///
-       bool in_update; /* as update is not reentrant! */
-       mutable BufferView * do_resize;
-       mutable bool do_reinit;
        mutable bool in_insetAllowed;
        ///
        // these are used to check for mouse movement in Motion selection code
        ///
        int mouse_x;
        int mouse_y;
+public:
+       ///
+       void reinitLyXText() const;
+       ///
+       mutable LyXText text_;
+       ///
+       mutable int textwidth_;
 };
 #endif