3 * This file is part of LyX, the document processor.
4 * Licence details can be found in the file COPYING.
8 * Full author contact details are available in file CREDITS.
14 #include "BufferView.h"
17 #include "dispatchresult.h"
18 #include "iterators.h"
20 #include "paragraph.h"
22 #include "insets/updatableinset.h"
28 DispatchResult Cursor::dispatch(FuncRequest const & cmd)
30 for (int i = data_.size() - 1; i >= 0; --i) {
31 lyxerr << "trying to dispatch to inset" << data_[i].inset_ << endl;
32 DispatchResult res = data_[i].inset_->dispatch(cmd);
33 lyxerr << " result: " << res.val() << endl;
35 if (res == DISPATCHED) {
40 if (res == DISPATCHED_NOUPDATE)
43 lyxerr << "# unhandled result: " << res.val() << endl;
49 void buildCursor(Cursor & cursor, BufferView & bv)
51 UpdatableInset * inset = bv.theLockingInset();
52 lyxerr << "\nbuildCursor: " << inset << endl;
56 inset = inset->getLockingInset();
59 ParIterator pit = bv.buffer()->par_iterator_begin();
60 ParIterator end = bv.buffer()->par_iterator_end();
61 for ( ; pit != end && !ok; ++pit) {
62 InsetList::iterator it = pit->insetlist.begin();
63 InsetList::iterator iend = pit->insetlist.end();
64 for ( ; it != iend && !ok; ++it)
65 if (it->inset == inset || it->inset == inset->owner())
70 lyxerr << " tli not found! inset: " << inset << endl;
75 for (size_t i = 0, n = cursor.data_.size(); i != n; ++i) {
76 lyxerr << " inset: " << cursor.data_[i].inset_
77 << " idx: " << cursor.data_[i].idx_
78 << " text: " << cursor.data_[i].text_
79 << " par: " << cursor.data_[i].par_
80 << " pos: " << cursor.data_[i].pos_