3 * \file BufferView_pimpl.h
4 * Copyright 2002 the LyX Team
5 * Read the file COPYING
10 #ifndef BUFFERVIEW_PIMPL_H
11 #define BUFFERVIEW_PIMPL_H
13 #include "BufferView.h"
14 #include "frontends/Timeout.h"
15 #include "frontends/key_state.h"
16 #include "frontends/mouse_state.h"
17 #include "frontends/LyXKeySym.h"
19 #include "insets/insetspecialchar.h"
20 #include "support/types.h"
22 #include <boost/scoped_ptr.hpp>
23 #include <boost/signals/trackable.hpp>
34 struct BufferView::Pimpl : public boost::signals::trackable {
36 Pimpl(BufferView * i, LyXView * o,
37 int xpos, int ypos, int width, int height);
39 Painter & painter() const;
40 /// return the work area for this bview
41 WorkArea & workarea() const;
42 /// return the screen for this bview
43 LyXScreen & screen() const;
45 void buffer(Buffer *);
46 /// Return true if the cursor was fitted.
49 void redoCurrentBuffer();
51 int resizeCurrentBuffer();
55 void update(LyXText *, BufferView::UpdateCodes);
57 * Repaint pixmap. Used for when we've made a visible
58 * change but don't need the full update() logic
62 void workAreaResize();
64 void updateScrollbar();
66 void scrollDocView(int value);
68 * Returns an inset if inset was hit, or 0 if not.
70 * If hit, the coordinates are changed relative to the inset.
72 Inset * checkInsetHit(LyXText *, int & x, int & y);
73 /// wheel mouse scroll
74 int scroll(long time);
76 void workAreaKeyPress(LyXKeySymPtr key,
77 key_modifier::state state);
79 void workAreaMotionNotify(int x, int y, mouse_button::state state);
81 void workAreaButtonPress(int x, int y, mouse_button::state button);
83 void workAreaButtonRelease(int x, int y, mouse_button::state button);
85 void doubleClick(int x, int y, mouse_button::state button);
87 void tripleClick(int x, int y, mouse_button::state button);
89 void selectionRequested();
95 bool available() const;
97 void beforeChange(LyXText *);
99 void savePosition(unsigned int i);
101 void restorePosition(unsigned int i);
103 bool isSavedPosition(unsigned int i);
113 void toggleSelection(bool = true);
119 bool insertInset(Inset * inset, string const & lout = string());
121 void updateInset(Inset * inset, bool mark_dirty);
123 bool dispatch(FuncRequest const & ev);
126 * Return the on-screen dimensions of the inset at the cursor.
127 * Pre-condition: the cursor must be at an inset.
129 Box insetDimensions(LyXText const & text, LyXCursor const & cursor) const;
131 * check if the given co-ordinates are inside an inset at the
132 * given cursor, if one exists. If so, the inset is returned,
133 * and the co-ordinates are made relative. Otherwise, 0 is returned.
135 Inset * checkInset(LyXText const & text, LyXCursor const & cursor,
136 int & x, int & y) const;
138 friend class BufferView;
139 /// open and lock an updatable inset
140 bool open_new_inset(UpdatableInset * new_inset, bool behind = false);
151 boost::scoped_ptr<LyXScreen> screen_;
153 boost::scoped_ptr<WorkArea> workarea_;
155 Timeout cursor_timeout;
157 void stuffClipboard(string const &) const;
159 bool using_xterm_cursor;
164 /// Cursor paragraph Id
167 lyx::pos_type par_pos;
169 Position() : par_id(0), par_pos(0) {}
171 Position(string const & f, int id, lyx::pos_type pos)
172 : filename(f), par_id(id), par_pos(pos) {}
175 std::vector<Position> saved_positions;
176 /// Get next inset of this class from current cursor position
177 Inset * getInsetByCode(Inset::Code code);
179 void MenuInsertLyXFile(string const & filen);
181 #endif // BUFFERVIEW_PIMPL_H