4 * This file is part of LyX, the document processor.
5 * Licence details can be found in the file COPYING.
8 * \author Lars Gullik Bjønnes
9 * \author Alfredo Braunstein
11 * Full author contact details are available in file CREDITS.
17 #include "ParagraphList_fwd.h"
19 #include "support/types.h"
34 std::vector<std::string> const availableSelections(Buffer const & buffer);
36 lyx::size_type numberOfSelections();
38 std::string getSelection(Buffer const & buffer, size_t sel_index);
41 void cutSelection(LCursor & cur, bool doclear, bool realcut);
44 * Sets the selection from the current cursor position to length
45 * characters to the right. No safety checks.
47 void setSelectionRange(LCursor & cur, lyx::pos_type length);
48 /// simply replace using the font of the first selected character
49 void replaceSelectionWithString(LCursor & cur, std::string const & str);
50 /// replace selection helper
51 void replaceSelection(LCursor & cur);
54 void cutSelection(LCursor & cur, bool doclear = true, bool realcut = true);
56 void copySelection(LCursor & cur);
58 void pasteSelection(LCursor & cur, size_t sel_index = 0);
61 void pasteParagraphList(LCursor & cur, ParagraphList const & parlist,
62 textclass_type textclass);
65 /** Needed to switch between different classes. This works
66 * for a list of paragraphs beginning with the specified par.
67 * It changes layouts and character styles.
69 void switchBetweenClasses(lyx::textclass_type c1,
70 lyx::textclass_type c2,
74 // only used by the spellchecker
75 void replaceWord(LCursor & cur, std::string const & replacestring);
78 std::string grabSelection(LCursor const & cur);
80 void eraseSelection(LCursor & cur);
82 std::string grabAndEraseSelection(LCursor & cur);
83 // other selection methods
85 void selCut(LCursor & cur);
87 void selDel(LCursor & cur);
88 /// clears or deletes selection depending on lyxrc setting
89 void selClearOrDel(LCursor & cur);
90 /// pastes n-th element of cut buffer
91 void selPaste(LCursor & cur, size_t n);
93 /** Tabular has its own paste stack for multiple cells
94 * but it needs to know whether there is a more recent
95 * ordinary paste. Therefore which one is newer.
97 //FIXME: this is a workaround for bug 1919. Replace this by
98 //an all-for-one-paste mechanism in 1.5
99 /// store whether tabular or ordinary paste stack is newer
100 void dirtyTabularStack(bool b);
101 /// is the tabular paste stack newer than the ordinary one?
102 bool tabularStackDirty();