X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FBufferView_pimpl.h;h=9391bb6d2f791b52b4f672af8fe611f5f0d022e9;hb=98c966c64594611e469313314abd1e59524adb4a;hp=eae9c2a4afd5bdfa06d4589862f2ee950eba0c88;hpb=2889b5fd3e8987d0c265ff4726a7fb6c6cb6c034;p=lyx.git diff --git a/src/BufferView_pimpl.h b/src/BufferView_pimpl.h index eae9c2a4af..9391bb6d2f 100644 --- a/src/BufferView_pimpl.h +++ b/src/BufferView_pimpl.h @@ -3,10 +3,15 @@ #ifndef BUFFERVIEW_PIMPL_H #define BUFFERVIEW_PIMPL_H +#include + #include "BufferView.h" -#include "UpdateInset.h" -#include "BackStack.h" -#include "Timeout.h" +#include "commandtags.h" +#include "frontends/Timeout.h" +#include "WorkArea.h" +#include "box.h" +#include "insets/insetspecialchar.h" +#include "support/types.h" #ifdef __GNUG__ #pragma interface @@ -16,7 +21,9 @@ class LyXView; class WorkArea; class LyXScreen; -struct BufferView::Pimpl { +/// +struct BufferView::Pimpl : public SigC::Object { + /// Pimpl(BufferView * i, LyXView * o, int xpos, int ypos, int width, int height); /// @@ -37,11 +44,9 @@ struct BufferView::Pimpl { int resizeCurrentBuffer(); /// void update(); - /// - void update(signed char f); - /// - void gotoError(); - /// Update pixmap of screen + // + void update(LyXText *, BufferView::UpdateCodes); + /// Update pixmap of screen void updateScreen(); /// void workAreaExpose(); @@ -49,17 +54,19 @@ struct BufferView::Pimpl { void updateScrollbar(); /// void scrollCB(double value); -#if 0 + /** + * 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); /// - void create_view(); -#endif - /// - Inset * checkInsetHit(int & x, int & y, unsigned int button); - /// int scrollUp(long time); /// int scrollDown(long time); /// + void workAreaKeyPress(KeySym, unsigned int state); + /// void workAreaMotionNotify(int x, int y, unsigned int state); /// void workAreaButtonPress(int x, int y, unsigned int button); @@ -70,25 +77,29 @@ struct BufferView::Pimpl { /// void tripleClick(int x, int y, unsigned int button); /// + void selectionRequested(); + /// + void selectionLost(); + /// void enterView(); /// void leaveView(); /// void cursorToggle(); /// - void cursorPrevious(); + void cursorPrevious(LyXText *); /// - void cursorNext(); + void cursorNext(LyXText *); /// bool available() const; /// - void beforeChange(); + void beforeChange(LyXText *); /// - void savePosition(); + void savePosition(unsigned int i); /// - void restorePosition(); + void restorePosition(unsigned int i); /// - bool NoSavedPositions(); + bool isSavedPosition(unsigned int i); /// void setState(); /// @@ -116,40 +127,85 @@ struct BufferView::Pimpl { /// void center(); /// - BufferView * bv_; + bool insertInset(Inset * inset, string const & lout = string()); /// - LyXView * owner_; + void updateInset(Inset * inset, bool mark_dirty); /// - Buffer * buffer_; + 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; /// - LyXScreen * screen; + friend class BufferView; + /// open and lock an updatable inset + bool open_new_inset(UpdatableInset * new_inset, bool behind = false); /// - long current_scrollbar_value; + void specialChar(InsetSpecialChar::Kind); /// - bool lyx_focus; + void newline(); /// - bool work_area_focus; + void hfill(); /// - FL_OBJECT * figinset_canvas; -#if 0 + void smartQuote(); /// - FL_OBJECT * timer_cursor; -#else - Timeout cursor_timeout; -#endif - /// - BackStack backstack; + void insertAndEditInset(Inset *); + /// + void gotoInset(std::vector const & codes, + bool same_content); + /// + void gotoInset(Inset::Code codes, bool same_content); + /// + BufferView * bv_; /// - int last_click_x, last_click_y; + LyXView * owner_; /// - WorkArea * workarea; + Buffer * buffer_; /// - UpdateInset updatelist; + boost::scoped_ptr screen_; + /// + long current_scrollbar_value; + /// + Timeout cursor_timeout; + /// + WorkArea workarea_; /// void pasteClipboard(bool asPara); /// void stuffClipboard(string const &) const; -private: + /// bool using_xterm_cursor; + /// + struct Position { + /// Filename + 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, 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 + Inset * getInsetByCode(Inset::Code code); + /// + void MenuInsertLyXFile(string const & filen); + /// + bool inset_slept; }; #endif