-class CutAndPaste {
-public:
- /// realcut == false is we actually want a delete
- static
- bool cutSelection(Paragraph * startpar, Paragraph ** endpar,
- int start, int & end, char tc, bool doclear = false,
- bool realcut = true);
- ///
- static
- bool copySelection(Paragraph * startpar, Paragraph * endpar,
- int start, int end, char tc);
- ///
- static
- bool pasteSelection(Paragraph ** par, Paragraph ** endpar,
- int & pos, char tc);
- ///
- static
- int nrOfParagraphs();
- /** needed to switch between different classes this works
- for a list of paragraphs beginning with the specified par
- return value is the number of wrong conversions
- */
- static
- int SwitchLayoutsBetweenClasses(lyx::textclass_type c1,
- lyx::textclass_type c2,
- Paragraph * par,
- BufferParams const & bparams);
- ///
- static
- bool checkPastePossible(Paragraph *);
-};
+void cutSelection(LCursor & cur, bool doclear = true, bool realcut = true);
+///
+void copySelection(LCursor & cur);
+///
+void pasteSelection(LCursor & cur, ErrorList &, size_t sel_index = 0);
+
+/// Paste the paragraph list \p parlist at the position given by \p cur.
+/// Does not handle undo. Does only work in text, not mathed.
+void pasteParagraphList(LCursor & cur, ParagraphList const & parlist,
+ textclass_type textclass, ErrorList & errorList);
+
+
+/** Needed to switch between different classes. This works
+ * for a list of paragraphs beginning with the specified par.
+ * It changes layouts and character styles.
+ */
+void switchBetweenClasses(textclass_type c1, textclass_type c2,
+ InsetText & in, ErrorList &);
+
+///
+docstring grabSelection(LCursor const & cur);
+///
+void eraseSelection(LCursor & cur);
+///
+docstring grabAndEraseSelection(LCursor & cur);
+// other selection methods
+///
+void selCut(LCursor & cur);
+///
+void selDel(LCursor & cur);
+/// clears or deletes selection depending on lyxrc setting
+void selClearOrDel(LCursor & cur);
+/// pastes n-th element of cut buffer
+void selPaste(LCursor & cur, size_t n);
+
+/** Tabular has its own paste stack for multiple cells
+ * but it needs to know whether there is a more recent
+ * ordinary paste. Therefore which one is newer.
+ */
+//FIXME: this is a workaround for bug 1919. Replace this by
+//an all-for-one-paste mechanism in 1.5
+/// store whether tabular or ordinary paste stack is newer
+void dirtyTabularStack(bool b);
+/// is the tabular paste stack newer than the ordinary one?
+bool tabularStackDirty();
+} // namespace cap
+} // namespce lyx