]> git.lyx.org Git - lyx.git/blobdiff - src/Text.h
Amend 207eaeee9071cb
[lyx.git] / src / Text.h
index b5160a95389deed6eba93631f9bafe6aea316883..9ef9c9626054274cbc1f962c23bbbc790a87e5f5 100644 (file)
 
 namespace lyx {
 
-class Buffer;
 class BufferParams;
 class BufferView;
+class Change;
 class CompletionList;
 class Cursor;
 class CursorData;
 class CursorSlice;
-class DocIterator;
 class ErrorList;
 class Font;
 class FontInfo;
 class FuncRequest;
 class FuncStatus;
 class Inset;
-class Lexer;
-class PainterInfo;
-class Spacing;
+class InsetText;
+class Paragraph;
+class ParagraphParameters;
+
+namespace support { class Lexer; }
 
 /// This class encapsulates the main text data and operations in LyX.
 /// This is more or less the private implementation of InsetText.
@@ -98,7 +99,7 @@ public:
 
        /// Returns whether something would be changed by changeDepth
        /// FIXME: replace Cursor with DocIterator.
-       bool changeDepthAllowed(Cursor & cur, DEPTH_CHANGE type) const;
+       bool changeDepthAllowed(Cursor const & cur, DEPTH_CHANGE type) const;
 
        /// Set font over selection paragraphs and rebreak.
        /// FIXME: replace Cursor with DocIterator.
@@ -141,12 +142,13 @@ public:
        void forOutliner(docstring & os, size_t maxlen, pit_type start, pit_type end,
                         bool shorten = true) const;
 
-       /// insert a character at cursor position
+       /// FIXME: investigate why those two function behave differently wrt cursor.
+       /// insert a character at cursor position and move cursor forward
        /// FIXME: replace Cursor with DocIterator.
        void insertChar(Cursor & cur, char_type c);
-       /// insert an inset at cursor position
+       /// insert an inset at cursor position; do not move cursor
        /// FIXME: replace Cursor with DocIterator.
-       void insertInset(Cursor & cur, Inset * inset);
+       bool insertInset(Cursor & cur, Inset * inset);
 
        /// try to handle that request
        /// FIXME: replace Cursor with DocIterator.
@@ -171,6 +173,8 @@ public:
        void getWord(CursorSlice & from, CursorSlice & to, word_location const) const;
        /// just selects the word the cursor is in
        void selectWord(Cursor & cur, word_location loc);
+       /// expands the selection to the word the cursor is in
+       void expandWordSel(Cursor & cur);
        /// select all text
        void selectAll(Cursor & cur);
 
@@ -245,6 +249,8 @@ public:
        // Dissolve the inset under cursor
        /// FIXME: replace Cursor with DocIterator.
        bool dissolveInset(Cursor & cur);
+       /// FIXME: replace Cursor with DocIterator.
+       bool splitInset(Cursor & cur);
        ///
        bool selectWordWhenUnderCursor(Cursor & cur, word_location);
        /// Change the case of the word at cursor position.
@@ -258,9 +264,9 @@ public:
         settings are given to the new one.
         This function will handle a multi-paragraph selection.
         */
-       void setParagraphs(Cursor & cur, docstring const & arg, bool modify = false);
+       void setParagraphs(Cursor const & cur, docstring const & arg, bool merge = false);
        /// Sets parameters for current or selected paragraphs
-       void setParagraphs(Cursor & cur, ParagraphParameters const & p);
+       void setParagraphs(Cursor const & cur, ParagraphParameters const & p);
 
        /* these things are for search and replace */
 
@@ -294,7 +300,7 @@ public:
        void write(std::ostream & os) const;
        /// returns true if \end_document has not been read
        /// insetPtr is the containing Inset
-       bool read(Lexer & lex, ErrorList & errorList,
+       bool read(support::Lexer & lex, ErrorList & errorList,
                  InsetText * insetPtr);
 
        /// delete double spaces, leading spaces, and empty paragraphs around old cursor.
@@ -308,6 +314,13 @@ public:
        /// Does NOT handle undo (responsibility of the caller)
        void deleteEmptyParagraphMechanism(pit_type first, pit_type last, bool trackChanges);
 
+       /// delete double spaces, leading spaces, and empty paragraphs
+       /// from \first to \last paragraph and \first_pos to \last_pos
+       /// Does NOT handle undo (responsibility of the caller)
+       void deleteEmptyParagraphMechanism(pit_type first, pit_type last,
+                                          pos_type first_pos, pos_type last_pos,
+                                          bool trackChanges);
+
        /// To resolve macros properly the texts get their DocIterator.
        /// Every macro definition is stored with its DocIterator
        /// as well. Only those macros with a smaller iterator become
@@ -320,8 +333,9 @@ public:
        bool completionSupported(Cursor const & cur) const;
        ///
        CompletionList const * createCompletionList(Cursor const & cur) const;
-       ///
-       bool insertCompletion(Cursor & cur, docstring const & s, bool /*finished*/);
+       /// Do a completion at the cursor position. Return true on success.
+       /// The completion does not contain the prefix. Handles undo.
+       bool insertCompletion(Cursor & cur, docstring const & s);
        ///
        docstring completionPrefix(Cursor const & cur) const;
        /// find a paragraph before \p par with the given \p depth, if such
@@ -356,7 +370,7 @@ private:
        /// handle the case where bibitems were deleted
        bool handleBibitems(Cursor & cur);
        /// are we in a list item (description etc.)?
-       bool inDescriptionItem(Cursor & cur) const;
+       bool inDescriptionItem(Cursor const & cur) const;
        ///
        void charInserted(Cursor & cur);
        /// set 'number' font property
@@ -368,10 +382,10 @@ private:
        void pasteString(Cursor & cur, docstring const & str,
                        bool asParagraphs);
        ///
-       void readParToken(Paragraph & par, Lexer & lex, std::string const & token,
+       void readParToken(Paragraph & par, support::Lexer & lex, std::string const & token,
                Font & font, Change & change, ErrorList & errorList);
        ///
-       void readParagraph(Paragraph & par, Lexer & lex, ErrorList & errorList);
+       void readParagraph(Paragraph & par, support::Lexer & lex, ErrorList & errorList);
        /// Set Label Width string to all paragraphs of the same layout
        /// and depth in a sequence.
        void setLabelWidthStringToSequence(Cursor const & cur, docstring const & s);