Backport jump-back button

http://www.mail-archive.com/lyx-devel@lists.lyx.org/msg147979.html


git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/branches/BRANCH_1_6_X@28819 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Pavel Sanda 2009-03-16 19:14:38 +00:00
parent d735335c88
commit f6ad811535
10 changed files with 45 additions and 9 deletions

View File

@ -1341,6 +1341,7 @@ lib_images_files = Split('''
amssymb.png
banner.png
bookmark-goto.png
bookmark-goto_0.png
bookmark-save.png
box-insert.png
break-line.png

View File

@ -270,6 +270,7 @@ dist_images_DATA = \
images/amssymb.png \
images/banner.png \
images/bookmark-goto.png \
images/bookmark-goto_0.png \
images/bookmark-save.png \
images/box-insert.png \
images/break-line.png \

Binary file not shown.

After

Width:  |  Height:  |  Size: 937 B

View File

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

View File

@ -67,6 +67,7 @@ ToolbarSet
Item "Copy" "copy"
Item "Paste" "paste"
Item "Find and replace" "dialog-show findreplace"
Item "Navigate back" "bookmark-goto 0"
Separator
Item "Toggle emphasis" "font-emph"
Item "Toggle noun" "font-noun"

View File

@ -216,7 +216,7 @@ struct BufferView::Private
Private(BufferView & bv): wh_(0), cursor_(bv),
anchor_pit_(0), anchor_ypos_(0),
inlineCompletionUniqueChars_(0),
last_inset_(0), gui_(0)
last_inset_(0), bookmark_edit_position_(0), gui_(0)
{}
///
@ -259,6 +259,9 @@ struct BufferView::Private
*/
Inset * last_inset_;
// cache for id of the paragraph which was edited the last time
int bookmark_edit_position_;
mutable TextMetricsCache text_metrics_;
/// Whom to notify.
@ -659,6 +662,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)
{
// tenatively 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 insertLyXFile(support::FileName const & f);
/// save temporary bookmark for jump back navigation
void bookmarkEditPosition();
private:
/// noncopyable

View File

@ -2237,7 +2237,7 @@ void LyXAction::init()
* \var lyx::FuncCode lyx::LFUN_LABEL_GOTO
* \li Action: Goto a label.
* \li Syntax: label-goto [<LABEL>]
* \li Params: <LABEL>: Requested label. If no label is given and refernce
* \li Params: <LABEL>: Requested label. If no label is given and reference
is on cursor position, Bookmark 0 is saved and
cursor moves to the position of referenced label.
* \li Origin: Ale, 6 Aug 1997
@ -2264,10 +2264,15 @@ void LyXAction::init()
/*!
* \var lyx::FuncCode lyx::LFUN_BOOKMARK_GOTO
* \li Action: Goto a bookmark.
* \li Notion: Moves the cursor to the numbered bookmark, opening the file
* \li Action: Moves the cursor to the numbered bookmark, opening the file
if necessary. Note that bookmarsk are saved per-session, not
per file.
* \li Notion: Bookmark 0 has a special purpose. It is automatically set \n
1. to the paragraph you are currently editing \n
2. to the paragraph from where you are jumping to the last-edited
position (jump-back feature) \n
3. when jumping from crossreference to the requested label by
#LFUN_LABEL_GOTO.
* \li Syntax: bookmark-goto <NUMBER>
* \li Params: <NUMBER>: the number of the bookmark to restore.
* \li Origin: Dekel, 27 January 2001

View File

@ -256,15 +256,27 @@ void LyXFunc::gotoBookmark(unsigned int idx, bool openFile, bool switchToBuffer)
if (!theBufferList().exists(bm.filename))
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 (lyx_view_->buffer()->fileName() != bm.filename) {
if (lyx_view_->buffer()->fileName() != tmp.filename) {
if (!switchToBuffer)
return;
dispatch(FuncRequest(LFUN_BUFFER_SWITCH, file));
}
// moveToPosition try paragraph id first and then paragraph (pit, pos).
if (!view()->moveToPosition(bm.bottom_pit, bm.bottom_pos,
bm.top_id, bm.top_pos))
if (!view()->moveToPosition(tmp.bottom_pit, tmp.bottom_pos,
tmp.top_id, tmp.top_pos))
return;
// bm changed
if (idx == 0)
return;
// Cursor jump succeeded!

View File

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