X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FBufferView_pimpl.h;h=9391bb6d2f791b52b4f672af8fe611f5f0d022e9;hb=98c966c64594611e469313314abd1e59524adb4a;hp=6f3e376230ac8ae264fb75859b7f2551ea654706;hpb=d1182f17daa1a164d9527ccbe6500840d7ac6bc8;p=lyx.git diff --git a/src/BufferView_pimpl.h b/src/BufferView_pimpl.h index 6f3e376230..9391bb6d2f 100644 --- a/src/BufferView_pimpl.h +++ b/src/BufferView_pimpl.h @@ -6,11 +6,12 @@ #include #include "BufferView.h" -#include "UpdateInset.h" #include "commandtags.h" #include "frontends/Timeout.h" #include "WorkArea.h" -#include "paragraph.h" +#include "box.h" +#include "insets/insetspecialchar.h" +#include "support/types.h" #ifdef __GNUG__ #pragma interface @@ -36,7 +37,7 @@ struct BufferView::Pimpl : public SigC::Object { /// void redraw(); /// Return true if the cursor was fitted. - bool fitCursor(LyXText *); + bool fitCursor(); /// void redoCurrentBuffer(); /// @@ -45,7 +46,7 @@ struct BufferView::Pimpl : public SigC::Object { void update(); // void update(LyXText *, BufferView::UpdateCodes); - /// Update pixmap of screen + /// Update pixmap of screen void updateScreen(); /// void workAreaExpose(); @@ -53,10 +54,13 @@ struct BufferView::Pimpl : public SigC::Object { void updateScrollbar(); /// void scrollCB(double value); + /** + * Returns an inset if inset was hit, or 0 if not. + * + * If hit, the coordinates are changed relative to the inset. + */ + Inset * checkInsetHit(LyXText *, int & x, int & y); /// - Inset * checkInsetHit(LyXText *, int & x, int & y, - unsigned int button); - /// int scrollUp(long time); /// int scrollDown(long time); @@ -73,6 +77,10 @@ struct BufferView::Pimpl : public SigC::Object { /// void tripleClick(int x, int y, unsigned int button); /// + void selectionRequested(); + /// + void selectionLost(); + /// void enterView(); /// void leaveView(); @@ -125,26 +133,31 @@ struct BufferView::Pimpl : public SigC::Object { /// bool Dispatch(kb_action action, string const & argument); private: + /** + * Return the on-screen dimensions of the inset at the cursor. + * Pre-condition: the cursor must be at an inset. + */ + Box insetDimensions(LyXText const & text, LyXCursor const & cursor) const; + /** + * check if the given co-ordinates are inside an inset at the given cursor, + * if one exists. If so, the inset is returned, and the co-ordinates are + * made relative. Otherwise, 0 is returned. + */ + Inset * checkInset(LyXText const & text, LyXCursor const & cursor, int & x, int & y) const; /// friend class BufferView; /// open and lock an updatable inset bool open_new_inset(UpdatableInset * new_inset, bool behind = false); /// - void protectedBlank(LyXText * lt); + void specialChar(InsetSpecialChar::Kind); /// void newline(); /// void hfill(); /// - void menuSeparator(); - /// - void endOfSentenceDot(); + void smartQuote(); /// - void ldots(); - /// - void hyphenationPoint(); - /// - void insertNote(); + void insertAndEditInset(Inset *); /// void gotoInset(std::vector const & codes, bool same_content); @@ -165,8 +178,6 @@ private: /// WorkArea workarea_; /// - UpdateInset updatelist; - /// void pasteClipboard(bool asPara); /// void stuffClipboard(string const &) const; @@ -175,22 +186,22 @@ private: /// struct Position { /// Filename - string filename; - /// Cursor paragraph Id - int par_id; - /// Cursor position - Paragraph::size_type par_pos; + string filename; + /// Cursor paragraph Id + int par_id; + /// Cursor position + lyx::pos_type par_pos; /// Position() : par_id(0), par_pos(0) {} /// - Position(string const & f, int id, Paragraph::size_type pos) - : filename(f), par_id(id), par_pos(pos) {} + Position(string const & f, int id, lyx::pos_type pos) + : filename(f), par_id(id), par_pos(pos) {} }; /// std::vector saved_positions; /// void moveCursorUpdate(bool selecting); - /// Get next inset of this class from current cursor position + /// Get next inset of this class from current cursor position Inset * getInsetByCode(Inset::Code code); /// void MenuInsertLyXFile(string const & filen);