X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2Finsettext.h;h=54ee58bec7f553e06ea28ea003eaf37bd17b6ad8;hb=65ec1c0437fd53ac6cff0b329f1563d91e481b6e;hp=abc0cf3aac08f7d7463c50819d33e5ed53f45ed2;hpb=389fa29ba55badfafd7b4b5765182f5963d47f35;p=lyx.git diff --git a/src/insets/insettext.h b/src/insets/insettext.h index abc0cf3aac..54ee58bec7 100644 --- a/src/insets/insettext.h +++ b/src/insets/insettext.h @@ -19,18 +19,21 @@ #pragma interface #endif -#include "lyxinset.h" +#include "inset.h" #include "LString.h" +#include "LColor.h" +#include "paragraph.h" #include "lyxcursor.h" +#include + class Painter; class BufferView; class Buffer; class LyXCursor; -class LyXParagraph; -class LColor; class LyXText; class LyXScreen; +class Row; /** A text inset is like a TeX box to write full text @@ -73,19 +76,19 @@ public: InsetText(); /// explicit - InsetText(InsetText const &); + InsetText(InsetText const &, bool same_id = false); /// ~InsetText(); /// - Inset * Clone(Buffer const &) const; + Inset * clone(Buffer const &, bool same_id = false) const; /// InsetText & operator=(InsetText const & it); /// void clear(); /// - void Read(Buffer const *, LyXLex &); + void read(Buffer const *, LyXLex &); /// - void Write(Buffer const *, std::ostream &) const; + void write(Buffer const *, std::ostream &) const; /// int ascent(BufferView *, LyXFont const &) const; /// @@ -93,115 +96,166 @@ public: /// int width(BufferView *, LyXFont const & f) const; /// - int textWidth(BufferView *) const; + int textWidth(BufferView *, bool fordraw = false) const; /// void draw(BufferView *, LyXFont const &, int , float &, bool) const; /// - void update(BufferView *, LyXFont const &, bool =false); + void update(BufferView *, LyXFont const &, bool = false); + /// + void setUpdateStatus(BufferView *, int what) const; /// - void SetUpdateStatus(BufferView *, int what) const; + string const editMessage() const; /// - string const EditMessage() const; + void edit(BufferView *, int, int, unsigned int); /// - void Edit(BufferView *, int, int, unsigned int); + void edit(BufferView *, bool front = true); /// - bool IsTextInset() const { return true; } + bool isTextInset() const { return true; } /// bool doClearArea() const; /// - void InsetUnlock(BufferView *); + void insetUnlock(BufferView *); /// - bool LockInsetInInset(BufferView *, UpdatableInset *); + bool lockInsetInInset(BufferView *, UpdatableInset *); /// - bool UnlockInsetInInset(BufferView *, UpdatableInset *, bool lr = false); + bool unlockInsetInInset(BufferView *, + UpdatableInset *, bool lr = false); /// - bool UpdateInsetInInset(BufferView *, Inset *); + bool updateInsetInInset(BufferView *, Inset *); /// - void InsetButtonRelease(BufferView *, int, int, int); + bool insetButtonRelease(BufferView *, int, int, int); /// - void InsetButtonPress(BufferView *, int, int, int); + void insetButtonPress(BufferView *, int, int, int); /// - void InsetMotionNotify(BufferView *, int, int, int); + void insetMotionNotify(BufferView *, int, int, int); /// - void InsetKeyPress(XKeyEvent *); + void insetKeyPress(XKeyEvent *); /// - UpdatableInset::RESULT LocalDispatch(BufferView *, kb_action, string const &); + UpdatableInset::RESULT localDispatch(BufferView *, + kb_action, string const &); /// - int Latex(Buffer const *, std::ostream &, + int latex(Buffer const *, std::ostream &, bool fragile, bool free_spc) const; /// - int Ascii(Buffer const *, std::ostream &, int linelen) const; + int ascii(Buffer const *, std::ostream &, int linelen) const; + /// + int linuxdoc(Buffer const *, std::ostream &) const { return 0; } + /// + int docbook(Buffer const *, std::ostream &) const ; /// - int Linuxdoc(Buffer const *, std::ostream &) const { return 0; } + void validate(LaTeXFeatures & features) const; /// - int DocBook(Buffer const *, std::ostream &) const ; + Inset::Code lyxCode() const { return Inset::TEXT_CODE; } /// - void Validate(LaTeXFeatures & features) const; + void getCursorPos(BufferView *, int & x, int & y) const; /// - Inset::Code LyxCode() const { return Inset::TEXT_CODE; } + unsigned int insetInInsetY(); /// - void GetCursorPos(BufferView *, int & x, int & y) const; + void toggleInsetCursor(BufferView *); /// - unsigned int InsetInInsetY(); + void showInsetCursor(BufferView *, bool show = true); /// - void ToggleInsetCursor(BufferView *); + void hideInsetCursor(BufferView *); /// - bool InsertInset(BufferView *, Inset *); + void fitInsetCursor(BufferView *) const; /// - UpdatableInset * GetLockingInset(); + bool insertInset(BufferView *, Inset *); /// - UpdatableInset * GetFirstLockingInsetOfType(Inset::Code); + bool insetAllowed(Inset::Code) const; /// - void SetFont(BufferView *, LyXFont const &, bool toggleall = false, + UpdatableInset * getLockingInset() const; + /// + UpdatableInset * getFirstLockingInsetOfType(Inset::Code); + /// + void setFont(BufferView *, LyXFont const &, + bool toggleall = false, bool selectall = false); /// int getMaxWidth(BufferView *, UpdatableInset const *) const; /// - void init(InsetText const * ins = 0); + void init(InsetText const * ins = 0, bool same_id = false); + /// + void writeParagraphData(Buffer const *, std::ostream &) const; /// - void WriteParagraphData(Buffer const *, std::ostream &) const; + void setParagraphData(Paragraph *, bool same_id = false); /// - void SetParagraphData(LyXParagraph *); + void setText(string const &); /// - void SetText(string const &); + void setAutoBreakRows(bool); /// - void SetAutoBreakRows(bool); + bool getAutoBreakRows() const { return autoBreakRows; } /// - void SetDrawFrame(BufferView *, DrawFrame); + void setDrawFrame(BufferView *, DrawFrame); /// - void SetFrameColor(BufferView *, LColor::color); + void setFrameColor(BufferView *, LColor::color); /// - LyXText * getLyXText(BufferView const *, bool const recursive=false) const; + LyXText * getLyXText(BufferView const *, + bool const recursive = false) const; /// - void deleteLyXText(BufferView *, bool recursive=true) const; + void deleteLyXText(BufferView *, bool recursive = true) const; /// - void resizeLyXText(BufferView *, bool force=false) const; + void resizeLyXText(BufferView *, bool force = false) const; /// - bool ShowInsetDialog(BufferView *) const; + bool showInsetDialog(BufferView *) const; /// std::vector const getLabelList() const; /// bool nodraw() const; /// - int scroll(bool recursive=true) const; - void scroll(BufferView *bv, float sx) const { + int scroll(bool recursive = true) const; + /// + void scroll(BufferView * bv, float sx) const { UpdatableInset::scroll(bv, sx); } - void scroll(BufferView *bv, int offset) const { + /// + void scroll(BufferView * bv, int offset) const { UpdatableInset::scroll(bv, offset); } /// - void selectAll(BufferView *bv); + void selectAll(BufferView * bv); /// - void clearSelection(BufferView *bv); - - LyXParagraph * par; + void clearSelection(BufferView * bv); + /// + Paragraph * getParFromID(int id) const; + /// + Inset * getInsetFromID(int id) const; + /// + Paragraph * firstParagraph() const; + /// + Paragraph * getFirstParagraph(int) const; + /// + LyXCursor const & cursor(BufferView *) const; + /// + Paragraph * paragraph() const; + /// + void paragraph(Paragraph *); + /// + bool allowSpellcheck() { return true; } + /// + string const selectNextWordToSpellcheck(BufferView *, + float & value) const; + void selectSelectedWord(BufferView *); + /// + void toggleSelection(BufferView *, bool kill_selection); + /// + bool searchForward(BufferView *, string const &, + bool = true, bool = false); + /// + bool searchBackward(BufferView *, string const &, + bool = true, bool = false); + /// + bool checkInsertChar(LyXFont &); + /// + // + // Public structures and variables /// mutable int need_update; protected: /// - void UpdateLocal(BufferView *, int what, bool mark_dirty); + void updateLocal(BufferView *, int what, bool mark_dirty) const; + /// + void lockInset(BufferView *, UpdatableInset *); /// mutable int drawTextXOffset; /// @@ -215,20 +269,27 @@ protected: private: /// - typedef std::map Cache; - /// - typedef Cache::value_type value_type; + struct InnerCache { + /// + InnerCache(boost::shared_ptr); + /// + boost::shared_ptr text; + /// + bool remove; + }; /// - int BeginningOfMainBody(Buffer const *, LyXParagraph * par) const; + typedef std::map Cache; /// - void ShowInsetCursor(BufferView *, bool show=true); + typedef Cache::value_type value_type; /// - void HideInsetCursor(BufferView *); + int beginningOfMainBody(Buffer const *, Paragraph * par) const; /// - UpdatableInset::RESULT moveRight(BufferView *, bool activate_inset = true, + UpdatableInset::RESULT moveRight(BufferView *, + bool activate_inset = true, bool selecting = false); /// - UpdatableInset::RESULT moveLeft(BufferView *, bool activate_inset = true, + UpdatableInset::RESULT moveLeft(BufferView *, + bool activate_inset = true, bool selecting = false); /// UpdatableInset::RESULT moveRightIntern(BufferView *, bool behind, @@ -244,14 +305,12 @@ private: /// UpdatableInset::RESULT moveDown(BufferView *); /// - void SetCharFont(Buffer const *, int pos, LyXFont const & font); - /// - string const getText(int); + void setCharFont(Buffer const *, int pos, LyXFont const & font); /// bool checkAndActivateInset(BufferView * bv, bool behind); /// bool checkAndActivateInset(BufferView * bv, int x = 0, int y = 0, - int button = 0); + int button = 0); /// void removeNewlines(); /// @@ -259,26 +318,32 @@ private: /// int cy(BufferView *) const; /// - LyXParagraph::size_type cpos(BufferView *) const; + lyx::pos_type cpos(BufferView *) const; /// - LyXParagraph * cpar(BufferView *) const; + Paragraph * cpar(BufferView *) const; /// bool cboundary(BufferView *) const; /// Row * crow(BufferView *) const; /// - /// This instead of a macro - LyXText * TEXT(BufferView * bv) const { - return getLyXText(bv); - } - /// void drawFrame(Painter &, bool cleared) const; + /// void clearFrame(Painter &, bool cleared) const; /// - void clearInset(Painter &, int baseline, bool & cleared) const; + void clearInset(BufferView *, int baseline, bool & cleared) const; + /// + void saveLyXTextState(LyXText *) const; + /// + void restoreLyXTextState(BufferView *, LyXText *) const; + /// + void reinitLyXText() const; + /// + void collapseParagraphs(BufferParams const & bparams) const; /* Private structures and variables */ /// + Paragraph * par; + /// mutable bool locked; /// mutable int insetAscent; @@ -287,15 +352,11 @@ private: /// mutable int insetWidth; /// - mutable int last_width; - /// - mutable int last_height; - /// mutable int top_y; /// - LyXParagraph * inset_par; + Paragraph * inset_par; /// - LyXParagraph::size_type inset_pos; + lyx::pos_type inset_pos; /// bool inset_boundary; /// @@ -311,12 +372,55 @@ private: /// UpdatableInset * the_locking_inset; /// - LyXParagraph * old_par; + mutable Paragraph * old_par; /// The cache. mutable Cache cache; /// mutable int last_drawn_width; /// mutable bool frame_is_visible; + /// + mutable BufferView * cached_bview; + /// + mutable boost::shared_ptr 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; + /// + // to remember old painted frame dimensions to clear it on the right spot! + /// + mutable int frame_x; + 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; }; #endif