Introduce jump-back navigation through bookmark 0

http://bugzilla.lyx.org/show_bug.cgi?id=898
http://www.mail-archive.com/lyx-devel@lists.lyx.org/msg147949.html


git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@28478 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Pavel Sanda 2009-02-13 13:46:08 +00:00
parent d1f83e4942
commit e59dbac2ed
5 changed files with 34 additions and 6 deletions

View File

@ -88,7 +88,7 @@ Menuset
# #
Menu "context-label" Menu "context-label"
Item "Next Cross-Reference|N" "reference-next" Item "Next Cross-Reference|N" "reference-next"
Item "Go back to Reference|G" "bookmark-goto 0" Item "Go back|G" "bookmark-goto 0"
Separator Separator
Item "Copy as Reference|C" "copy-label-as-reference" Item "Copy as Reference|C" "copy-label-as-reference"
Separator Separator
@ -275,7 +275,7 @@ Menuset
Item "Paste" "paste" Item "Paste" "paste"
Submenu "Paste Recent|e" "edit_pasterecent" Submenu "Paste Recent|e" "edit_pasterecent"
Separator Separator
Item "Jump to Saved Bookmark|B" "bookmark-goto 0" Item "Jump Back to Saved Bookmark|B" "bookmark-goto 0"
Separator Separator
Item "Move Paragraph Up|o" "paragraph-move-up" Item "Move Paragraph Up|o" "paragraph-move-up"
Item "Move Paragraph Down|v" "paragraph-move-down" Item "Move Paragraph Down|v" "paragraph-move-down"

View File

@ -218,7 +218,7 @@ struct BufferView::Private
Private(BufferView & bv): wh_(0), cursor_(bv), Private(BufferView & bv): wh_(0), cursor_(bv),
anchor_pit_(0), anchor_ypos_(0), anchor_pit_(0), anchor_ypos_(0),
inlineCompletionUniqueChars_(0), inlineCompletionUniqueChars_(0),
last_inset_(0), gui_(0) last_inset_(0), bookmark_edit_position_(0), gui_(0)
{} {}
/// ///
@ -261,6 +261,9 @@ struct BufferView::Private
*/ */
Inset * last_inset_; Inset * last_inset_;
// cache for id of the paragraph which was edited the last time
int bookmark_edit_position_;
mutable TextMetricsCache text_metrics_; mutable TextMetricsCache text_metrics_;
/// Whom to notify. /// Whom to notify.
@ -670,6 +673,16 @@ CursorStatus BufferView::cursorStatus(DocIterator const & dit) const
} }
void BufferView::bookmarkEditPosition()
{
// Don't eat cpu time for each keystroke
if (d->cursor_.paragraph().id() == d->bookmark_edit_position_)
return;
saveBookmark(0);
d->bookmark_edit_position_ = d->cursor_.paragraph().id();
}
void BufferView::saveBookmark(unsigned int idx) void BufferView::saveBookmark(unsigned int idx)
{ {
// tentatively save bookmark, id and pos will be used to // tentatively save bookmark, id and pos will be used to

View File

@ -289,6 +289,8 @@ public:
void insertPlaintextFile(support::FileName const & f, bool asParagraph); void insertPlaintextFile(support::FileName const & f, bool asParagraph);
/// ///
void insertLyXFile(support::FileName const & f); void insertLyXFile(support::FileName const & f);
/// save temporary bookmark for jump back navigation
void bookmarkEditPosition();
private: private:
/// noncopyable /// noncopyable

View File

@ -257,15 +257,27 @@ void LyXFunc::gotoBookmark(unsigned int idx, bool openFile, bool switchToBuffer)
if (!theBufferList().exists(bm.filename)) if (!theBufferList().exists(bm.filename))
return; return;
// bm can be changed when saving
BookmarksSection::Bookmark tmp = bm;
// Special case idx == 0 used for back-from-back jump navigation
if (idx == 0)
dispatch(FuncRequest(LFUN_BOOKMARK_SAVE, "0"));
// if the current buffer is not that one, switch to it. // if the current buffer is not that one, switch to it.
if (lyx_view_->buffer()->fileName() != bm.filename) { if (lyx_view_->buffer()->fileName() != tmp.filename) {
if (!switchToBuffer) if (!switchToBuffer)
return; return;
dispatch(FuncRequest(LFUN_BUFFER_SWITCH, file)); dispatch(FuncRequest(LFUN_BUFFER_SWITCH, file));
} }
// moveToPosition try paragraph id first and then paragraph (pit, pos). // moveToPosition try paragraph id first and then paragraph (pit, pos).
if (!view()->moveToPosition(bm.bottom_pit, bm.bottom_pos, if (!view()->moveToPosition(tmp.bottom_pit, tmp.bottom_pos,
bm.top_id, bm.top_pos)) tmp.top_id, tmp.top_pos))
return;
// bm changed
if (idx == 0)
return; return;
// Cursor jump succeeded! // Cursor jump succeeded!

View File

@ -1385,6 +1385,7 @@ void Text::dispatch(Cursor & cur, FuncRequest & cmd)
cur.resetAnchor(); cur.resetAnchor();
moveCursor(cur, false); moveCursor(cur, false);
bv->bookmarkEditPosition();
break; break;
} }