* frontends/WorkArea.h(workAreaResize, scrollDocView, workAreaKeyPress,

dispatch, selectionReuqested, selectionLost): remove signals

* BufferView.[Ch] (selectionRequested, selectionLost, workAreaResize,
  workAreaKeyPress, workAreaDispatch): add forwarding functions to the pimpl

* BufferView_pimpl.C (Pimpl): Remove the setup of the now deleted signals,
  also remove corresponding connection objects.

* frontends/xforms/XWorkArea.h:
* frontends/qt2/QWorkArea.h:
* frontends/qt4/QWorkArea.h:
* frontends/gtk/GWorkArea.h: add LyXView as class variable view_ (qt
  classes also get view() medthod)

* frontends/qt2/QWorkArea.C:
* frontends/qt2/QContentPane.C:
* frontends/qt4/QWorkArea.C:
* frontends/xforms/XWorkArea.C:
* frontends/gtk/GWorkArea.C: Change from calling signals to call
  the functions directly through view_.view()


git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@13671 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Lars Gullik Bjønnes 2006-04-13 18:58:48 +00:00
parent b5cdc90ef9
commit 67d576f75e
13 changed files with 139 additions and 98 deletions

View File

@ -235,6 +235,36 @@ bool BufferView::dispatch(FuncRequest const & ev)
}
void BufferView::selectionRequested()
{
pimpl_->selectionRequested();
}
void BufferView::selectionLost()
{
pimpl_->selectionLost();
}
void BufferView::workAreaResize()
{
pimpl_->workAreaResize();
}
void BufferView::workAreaKeyPress(LyXKeySymPtr key, key_modifier::state state)
{
pimpl_->workAreaKeyPress(key, state);
}
bool BufferView::workAreaDispatch(FuncRequest const & ev)
{
return pimpl_->workAreaDispatch(ev);
}
void BufferView::scroll(int lines)
{
pimpl_->scroll(lines);

View File

@ -15,6 +15,8 @@
#ifndef BUFFER_VIEW_H
#define BUFFER_VIEW_H
#include "frontends/LyXKeySym.h"
#include "support/types.h"
#include <boost/utility.hpp>
@ -175,6 +177,20 @@ public:
/// execute the given function
bool dispatch(FuncRequest const & argument);
///
void selectionRequested();
///
void selectionLost();
///
void workAreaResize();
/// Receive a keypress
void workAreaKeyPress(LyXKeySymPtr key, key_modifier::state state);
/// a function should be executed from the workarea
bool workAreaDispatch(FuncRequest const & ev);
/// clear the X selection
void unsetXSel();

View File

@ -116,14 +116,7 @@ unsigned int const saved_positions_num = 20;
// to these connections we avoid a segfault upon startup, and also at exit.
// (Lgb)
boost::signals::connection dispatchcon;
boost::signals::connection timecon;
boost::signals::connection doccon;
boost::signals::connection resizecon;
boost::signals::connection kpresscon;
boost::signals::connection selectioncon;
boost::signals::connection lostcon;
/// Return an inset of this class if it exists at the current cursor position
template <class T>
@ -153,22 +146,11 @@ BufferView::Pimpl::Pimpl(BufferView & bv, LyXView * owner,
screen_.reset(LyXScreenFactory::create(workarea()));
// Setup the signals
doccon = workarea().scrollDocView
.connect(boost::bind(&BufferView::Pimpl::scrollDocView, this, _1));
resizecon = workarea().workAreaResize
.connect(boost::bind(&BufferView::Pimpl::workAreaResize, this));
dispatchcon = workarea().dispatch
.connect(boost::bind(&BufferView::Pimpl::workAreaDispatch, this, _1));
kpresscon = workarea().workAreaKeyPress
.connect(boost::bind(&BufferView::Pimpl::workAreaKeyPress, this, _1, _2));
selectioncon = workarea().selectionRequested
.connect(boost::bind(&BufferView::Pimpl::selectionRequested, this));
lostcon = workarea().selectionLost
.connect(boost::bind(&BufferView::Pimpl::selectionLost, this));
timecon = cursor_timeout.timeout
.connect(boost::bind(&BufferView::Pimpl::cursorToggle, this));
cursor_timeout.start();
saved_positions.resize(saved_positions_num);
// load saved bookmarks
lyx::Session::BookmarkList & bmList = LyX::ref().session().loadBookmarks();

View File

@ -58,19 +58,6 @@ public:
virtual std::string const getClipboard() const = 0;
/// fill the clipboard
virtual void putClipboard(std::string const &) const = 0;
/// work area dimensions have changed
boost::signal<void()> workAreaResize;
/// the scrollbar has changed
boost::signal<void(int)> scrollDocView;
/// a key combination has been pressed
boost::signal<void(LyXKeySymPtr, key_modifier::state)> workAreaKeyPress;
/// some mouse event
boost::signal<void(FuncRequest)> dispatch;
/// emitted when an X client has requested our selection
boost::signal<void()> selectionRequested;
/// emitted when another X client has stolen our selection
boost::signal<void()> selectionLost;
};
#endif // WORKAREA_H

View File

@ -23,6 +23,7 @@
#include "GtkmmX.h"
#include "GLyXKeySym.h"
#include "BufferView.h"
#include "debug.h"
#include "funcrequest.h"
#include "LColor.h"
@ -172,7 +173,7 @@ void inputCommitRelay(GtkIMContext */*imcontext*/, gchar * str, GWorkArea * area
GWorkArea::GWorkArea(LyXView & owner, int width, int height)
: workAreaPixmap_(0), painter_(*this), draw_(0), colorHandler_(*this),
: view_(owner), workAreaPixmap_(0), painter_(*this), draw_(0), colorHandler_(*this),
adjusting_(false)
{
workArea_.set_size_request(width, height);
@ -331,7 +332,7 @@ bool GWorkArea::onConfigure(GdkEventConfigure * /*event*/)
gtk_im_context_set_client_window(
imContext_, workArea_.get_window()->gobj());
}
workAreaResize();
view_.view()->workAreaResize();
return true;
}
@ -374,7 +375,7 @@ void GWorkArea::onScroll()
adjusting_ = true;
double val = vscrollbar_.get_adjustment()->get_value();
scrollDocView(static_cast<int>(val));
view_.view()->scrollDocView(static_cast<int>(val));
adjusting_ = false;
}
@ -420,7 +421,7 @@ bool GWorkArea::onButtonPress(GdkEventButton * event)
default:
break;
}
dispatch(FuncRequest(ka,
view_.view()->workAreaDispatch(FuncRequest(ka,
static_cast<int>(event->x),
static_cast<int>(event->y),
gButtonToLyx(event->button)));
@ -431,7 +432,7 @@ bool GWorkArea::onButtonPress(GdkEventButton * event)
bool GWorkArea::onButtonRelease(GdkEventButton * event)
{
dispatch(FuncRequest(LFUN_MOUSE_RELEASE,
view_.view()->workAreaDispatch(FuncRequest(LFUN_MOUSE_RELEASE,
static_cast<int>(event->x),
static_cast<int>(event->y),
gButtonToLyx(event->button)));
@ -456,7 +457,7 @@ bool GWorkArea::onMotionNotify(GdkEventMotion * event)
}
timeBefore = event->time;
}
dispatch(FuncRequest(LFUN_MOUSE_MOTION,
view_.view()->workAreaDispatch(FuncRequest(LFUN_MOUSE_MOTION,
static_cast<int>(event->x),
static_cast<int>(event->y),
gtkButtonState(event->state)));
@ -480,7 +481,7 @@ bool GWorkArea::onKeyPress(GdkEventKey * event)
!inputGet) {
#endif
GLyXKeySym *glk = new GLyXKeySym(event->keyval);
workAreaKeyPress(LyXKeySymPtr(glk),
view_.view()->workAreaKeyPress(LyXKeySymPtr(glk),
gtkKeyState(event->state));
#ifdef I18N
} else if (!inputCache_.empty())
@ -493,7 +494,7 @@ bool GWorkArea::onKeyPress(GdkEventKey * event)
void GWorkArea::onClipboardGet(Gtk::SelectionData & /*selection_data*/,
guint /*info*/)
{
selectionRequested();
view_.view()->selectionRequested();
}

View File

@ -97,6 +97,7 @@ private:
bool onKeyPress(GdkEventKey * event);
void onClipboardGet(Gtk::SelectionData & selection_data, guint info);
void onClipboardClear();
LyXView & view_;
Gtk::HBox hbox_;
Gtk::DrawingArea workArea_;
Gtk::VScrollbar vscrollbar_;

View File

@ -10,6 +10,9 @@
#include <config.h>
#include "BufferView.h"
#include "frontends/LyXView.h"
// Qt defines a macro 'signals' that clashes with a boost namespace.
// All is well if the namespace is visible first.
#include "QWorkArea.h"
@ -155,7 +158,7 @@ void QContentPane::generateSyntheticMouseEvent()
synthetic_mouse_event_.scrollbar_value_old = scrollbar_value;
// ... and dispatch the event to the LyX core.
wa_->dispatch(synthetic_mouse_event_.cmd);
wa_->view().view()->workAreaDispatch(synthetic_mouse_event_.cmd);
}
}
@ -163,7 +166,7 @@ void QContentPane::generateSyntheticMouseEvent()
void QContentPane::scrollBarChanged(int val)
{
if (track_scrollbar_)
wa_->scrollDocView(val);
wa_->view().view()->scrollDocView(val);
}
@ -174,13 +177,13 @@ void QContentPane::mousePressEvent(QMouseEvent * e)
FuncRequest cmd(LFUN_MOUSE_TRIPLE,
dc_event_.x, dc_event_.y,
q_button_state(dc_event_.state));
wa_->dispatch(cmd);
wa_->view().view()->workAreaDispatch(cmd);
return;
}
FuncRequest const cmd(LFUN_MOUSE_PRESS, e->x(), e->y(),
q_button_state(e->button()));
wa_->dispatch(cmd);
wa_->view().view()->workAreaDispatch(cmd);
}
@ -191,7 +194,7 @@ void QContentPane::mouseReleaseEvent(QMouseEvent * e)
FuncRequest const cmd(LFUN_MOUSE_RELEASE, e->x(), e->y(),
q_button_state(e->button()));
wa_->dispatch(cmd);
wa_->view().view()->workAreaDispatch(cmd);
}
@ -251,7 +254,7 @@ void QContentPane::mouseMoveEvent(QMouseEvent * e)
synthetic_mouse_event_.scrollbar_value_old = scrollbar_value;
// ... and dispatch the event to the LyX core.
wa_->dispatch(cmd);
wa_->view().view()->workAreaDispatch(cmd);
}
}
@ -289,7 +292,7 @@ void QContentPane::keyeventTimeout()
boost::shared_ptr<QLyXKeySym> sym(new QLyXKeySym);
sym->set(ev.get());
wa_->workAreaKeyPress(sym, q_key_state(ev->state()));
wa_->view().view()->workAreaKeyPress(sym, q_key_state(ev->state()));
keyeventQueue_.pop();
handle_autos = false;
@ -310,7 +313,7 @@ void QContentPane::doubleClickTimeout()
FuncRequest cmd(LFUN_MOUSE_DOUBLE,
dc_event_.x, dc_event_.y,
q_button_state(dc_event_.state));
wa_->dispatch(cmd);
wa_->view().view()->workAreaDispatch(cmd);
}
@ -331,7 +334,7 @@ void QContentPane::resizeEvent(QResizeEvent *)
}
pixmap_->resize(width(), height());
wa_->workAreaResize();
wa_->view().view()->workAreaResize();
}
@ -339,7 +342,7 @@ void QContentPane::paintEvent(QPaintEvent * e)
{
if (!pixmap_.get()) {
pixmap_.reset(new QPixmap(width(), height()));
wa_->workAreaResize();
wa_->view().view()->workAreaResize();
return;
}

View File

@ -10,6 +10,9 @@
#include <config.h>
#include "frontends/LyXView.h"
#include "BufferView.h"
#include "QWorkArea.h"
#include "lcolorcache.h"
@ -46,11 +49,11 @@ using std::string;
namespace os = lyx::support::os;
namespace {
QWorkArea const * wa_ptr = 0;
QWorkArea * wa_ptr = 0;
}
QWorkArea::QWorkArea(LyXView &, int, int)
: WorkArea(), QWidget(qApp->mainWidget()), painter_(*this)
QWorkArea::QWorkArea(LyXView & owner, int, int)
: WorkArea(), QWidget(qApp->mainWidget()), owner_(owner), painter_(*this)
{
scrollbar_ = new QScrollBar(QScrollBar::Vertical, this);
content_ = new QContentPane(this);
@ -103,12 +106,12 @@ bool lyxX11EventFilter(XEvent * xev)
case SelectionRequest:
lyxerr[Debug::GUI] << "X requested selection." << endl;
if (wa_ptr)
wa_ptr->selectionRequested();
wa_ptr->view().view()->selectionRequested();
break;
case SelectionClear:
lyxerr[Debug::GUI] << "Lost selection." << endl;
if (wa_ptr)
wa_ptr->selectionLost();
wa_ptr->view().view()->selectionLost();
break;
}
return false;
@ -183,7 +186,7 @@ pascal OSErr handleOpenDocuments(const AppleEvent* inEvent,
void QWorkArea::haveSelection(bool own) const
{
wa_ptr = this;
wa_ptr = const_cast<QWorkArea*>(this);
if (!QApplication::clipboard()->supportsSelection())
return;
@ -230,7 +233,7 @@ void QWorkArea::dragEnterEvent(QDragEnterEvent * event)
}
void QWorkArea::dropEvent(QDropEvent* event)
void QWorkArea::dropEvent(QDropEvent * event)
{
QStringList files;
@ -238,9 +241,9 @@ void QWorkArea::dropEvent(QDropEvent* event)
lyxerr[Debug::GUI] << "QWorkArea::dropEvent: got URIs!"
<< endl;
for (QStringList::Iterator i = files.begin();
i!=files.end(); ++i) {
i != files.end(); ++i) {
string const file = os::internal_path(fromqstr(*i));
dispatch(FuncRequest(LFUN_FILE_OPEN, file));
view().view()->workAreaDispatch(FuncRequest(LFUN_FILE_OPEN, file));
}
}
}

View File

@ -63,7 +63,15 @@ public:
/// get the content pane widget
QWidget * getContent() const { return content_; }
///
LyXView & view()
{
return owner_;
}
private:
/// The owning LyXView
LyXView & owner_;
/// scroll bar
QScrollBar * scrollbar_;
/// content

View File

@ -60,7 +60,7 @@ namespace os = lyx::support::os;
namespace {
QWorkArea const * wa_ptr = 0;
QWorkArea * wa_ptr = 0;
/// return the LyX key state from Qt's
key_modifier::state q_key_state(Qt::ButtonState state)
@ -120,8 +120,8 @@ SyntheticMouseEvent::SyntheticMouseEvent()
{}
QWorkArea::QWorkArea(LyXView &, int w, int h)
: QAbstractScrollArea(qApp->mainWidget()), WorkArea(), painter_(this)
QWorkArea::QWorkArea(LyXView & owner, int w, int h)
: QAbstractScrollArea(qApp->mainWidget()), WorkArea(), view_(owner), painter_(this)
{
setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOn);
setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
@ -224,7 +224,7 @@ void QWorkArea::adjustViewWithScrollBar(int action)
<< " linestep=" << verticalScrollBar()->lineStep()
<< endl;
this->scrollDocView(verticalScrollBar()->sliderPosition());
view_.view()->scrollDocView(verticalScrollBar()->sliderPosition());
}
@ -292,7 +292,7 @@ void QWorkArea::dropEvent(QDropEvent* event)
for (QStringList::Iterator i = files.begin();
i!=files.end(); ++i) {
string const file = os::internal_path(fromqstr(*i));
dispatch(FuncRequest(LFUN_FILE_OPEN, file));
view_.view()->workAreaDispatch(FuncRequest(LFUN_FILE_OPEN, file));
}
}
}
@ -305,13 +305,13 @@ void QWorkArea::mousePressEvent(QMouseEvent * e)
FuncRequest cmd(LFUN_MOUSE_TRIPLE,
dc_event_.x, dc_event_.y,
q_button_state(dc_event_.state));
this->dispatch(cmd);
view_.view()->workAreaDispatch(cmd);
return;
}
FuncRequest const cmd(LFUN_MOUSE_PRESS, e->x(), e->y(),
q_button_state(e->button()));
this->dispatch(cmd);
view_.view()->workAreaDispatch(cmd);
}
@ -322,7 +322,7 @@ void QWorkArea::mouseReleaseEvent(QMouseEvent * e)
FuncRequest const cmd(LFUN_MOUSE_RELEASE, e->x(), e->y(),
q_button_state(e->button()));
this->dispatch(cmd);
view_.view()->workAreaDispatch(cmd);
}
@ -382,7 +382,7 @@ void QWorkArea::mouseMoveEvent(QMouseEvent * e)
synthetic_mouse_event_.scrollbar_value_old = scrollbar_value;
// ... and dispatch the event to the LyX core.
this->dispatch(cmd);
view_.view()->workAreaDispatch(cmd);
}
}
@ -412,7 +412,7 @@ void QWorkArea::generateSyntheticMouseEvent()
synthetic_mouse_event_.scrollbar_value_old = scrollbar_value;
// ... and dispatch the event to the LyX core.
this->dispatch(synthetic_mouse_event_.cmd);
view_.view()->workAreaDispatch(synthetic_mouse_event_.cmd);
}
}
@ -429,7 +429,7 @@ void QWorkArea::keyPressEvent(QKeyEvent * e)
boost::shared_ptr<QLyXKeySym> sym(new QLyXKeySym);
sym->set(e);
this->workAreaKeyPress(sym, q_key_state(e->state()));
view_.view()->workAreaKeyPress(sym, q_key_state(e->state()));
}
@ -458,7 +458,7 @@ void QWorkArea::keyeventTimeout()
<< " key=" << ev->key()
<< endl;
this->workAreaKeyPress(sym, q_key_state(ev->state()));
view_.view()->workAreaKeyPress(sym, q_key_state(ev->state()));
keyeventQueue_.pop();
handle_autos = false;
@ -481,7 +481,7 @@ void QWorkArea::mouseDoubleClickEvent(QMouseEvent * e)
FuncRequest cmd(LFUN_MOUSE_DOUBLE,
dc_event_.x, dc_event_.y,
q_button_state(dc_event_.state));
this->dispatch(cmd);
view_.view()->workAreaDispatch(cmd);
}
@ -495,7 +495,7 @@ void QWorkArea::resizeEvent(QResizeEvent * resizeEvent)
screen_device_ = QPixmap(viewport()->width(), viewport()->height());
paint_device_ = QImage(viewport()->width(), viewport()->height(), QImage::Format_RGB32);
this->workAreaResize();
view_.view()->workAreaResize();
/*
lyxerr[Debug::GUI] << BOOST_CURRENT_FUNCTION
@ -538,6 +538,7 @@ void QWorkArea::paintEvent(QPaintEvent * e)
q.drawPixmap(e->rect(), screen_device_, e->rect());
}
QPixmap QWorkArea::copyScreen(int x, int y, int w, int h) const
{
return screen_device_.copy(x, y, w, h);
@ -588,12 +589,12 @@ bool lyxX11EventFilter(XEvent * xev)
case SelectionRequest:
lyxerr[Debug::GUI] << "X requested selection." << endl;
if (wa_ptr)
wa_ptr->selectionRequested();
wa_ptr->view().view()->selectionRequested();
break;
case SelectionClear:
lyxerr[Debug::GUI] << "Lost selection." << endl;
if (wa_ptr)
wa_ptr->selectionLost();
wa_ptr->view().view()->selectionLost();
break;
}
return false;
@ -657,7 +658,7 @@ pascal OSErr handleOpenDocuments(const AppleEvent* inEvent,
FSRefMakePath(&ref, (UInt8*)qstr_buf,
1024);
s_arg=QString::fromUtf8(qstr_buf);
wa_ptr->dispatch(
wa_ptr->view().view()->workAreaDispatch(
FuncRequest(LFUN_FILE_OPEN,
fromqstr(s_arg)));
break;

View File

@ -145,6 +145,10 @@ public:
*/
void drawScreen(int x, int y, QPixmap pixmap);
LyXView & view()
{
return view_;
}
protected:
/// repaint part of the widget
@ -185,6 +189,8 @@ public slots:
void adjustViewWithScrollBar(int action = 0);
private:
///
LyXView & view_;
/// Buffer view width.
int workWidth_;

View File

@ -12,6 +12,7 @@
#include <config.h>
#include "XWorkArea.h"
#include "BufferView.h"
#include "Color.h"
#include "XFormsView.h"
@ -108,7 +109,7 @@ int C_event_cb(FL_FORM * form, void * xev)
XWorkArea::XWorkArea(LyXView & owner, int w, int h)
: workareapixmap(0), painter_(*this)
: view_(owner), workareapixmap(0), painter_(*this)
{
fl_freeze_all_forms();
@ -219,7 +220,7 @@ void XWorkArea::redraw(int width, int height)
height,
fl_get_visual_depth());
workAreaResize();
view_.view()->workAreaResize();
}
@ -276,7 +277,7 @@ void XWorkArea::scroll_cb()
<< "scroll: docheight: " << doc_height_ << endl;
}
scrollDocView(int(val));
view_.view()->scrollDocView(int(val));
waitForX(false);
}
@ -331,7 +332,7 @@ int XWorkArea::work_area_handler(FL_OBJECT * ob, int event,
// Should really have used xbutton.state
lyxerr[Debug::WORKAREA] << "Workarea event: PUSH" << endl;
area->dispatch(
area->view_.view()->workAreaDispatch(
FuncRequest(LFUN_MOUSE_PRESS,
ev->xbutton.x - ob->x,
ev->xbutton.y - ob->y,
@ -349,7 +350,7 @@ int XWorkArea::work_area_handler(FL_OBJECT * ob, int event,
lyxerr[Debug::WORKAREA] << "Workarea event: RELEASE" << endl;
area->dispatch(
area->view_.view()->workAreaDispatch(
FuncRequest(LFUN_MOUSE_RELEASE,
ev->xbutton.x - ob->x,
ev->xbutton.y - ob->y,
@ -418,7 +419,7 @@ int XWorkArea::work_area_handler(FL_OBJECT * ob, int event,
ev->xbutton.x - ob->x,
ev->xbutton.y - ob->y,
x_button_state(key));
area->dispatch(cmd);
area->view_.view()->workAreaDispatch(cmd);
}
break;
}
@ -509,7 +510,7 @@ int XWorkArea::work_area_handler(FL_OBJECT * ob, int event,
XLyXKeySym * xlk = new XLyXKeySym;
xlk->initFromKeySym(ret_key);
area->workAreaKeyPress(LyXKeySymPtr(xlk),
area->view_.view()->workAreaKeyPress(LyXKeySymPtr(xlk),
x_key_state(ret_state));
break;
}
@ -542,7 +543,7 @@ int XWorkArea::work_area_handler(FL_OBJECT * ob, int event,
ev->xbutton.x - ob->x,
ev->xbutton.y - ob->y,
x_button_state(key));
area->dispatch(cmd);
area->view_.view()->workAreaDispatch(cmd);
}
break;
@ -558,7 +559,7 @@ int XWorkArea::work_area_handler(FL_OBJECT * ob, int event,
ev->xbutton.x - ob->x,
ev->xbutton.y - ob->y,
x_button_state(key));
area->dispatch(cmd);
area->view_.view()->workAreaDispatch(cmd);
}
break;
@ -601,11 +602,11 @@ int XWorkArea::event_cb(XEvent * xev)
switch (xev->type) {
case SelectionRequest:
lyxerr[Debug::GUI] << "X requested selection." << endl;
selectionRequested();
view_.view()->selectionRequested();
break;
case SelectionClear:
lyxerr[Debug::GUI] << "Lost selection." << endl;
selectionLost();
view_.view()->selectionLost();
break;
}
return 0;

View File

@ -65,6 +65,8 @@ public:
/// handles SelectionRequest X Event, to fill the clipboard
int event_cb(XEvent * xev);
private:
LyXView & view_;
/// generate the pixmap, and copy backing pixmap to it,
/// and send resize event if needed
void redraw(int, int);