From dc871e324d59c1cd691fdedca8807d11e5b959d0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Przemys=C5=82aw=20Buczkowski?= Date: Mon, 14 Jan 2013 20:18:15 +0100 Subject: [PATCH] TextView:Cmd/Ctrl-Home/End Shift-selection support Fixes #6859 Signed-off-by: Siarzhuk Zharski --- headers/os/interface/TextView.h | 2 ++ src/kits/interface/TextView.cpp | 41 +++++++++++++++++++++++++++++++-- 2 files changed, 41 insertions(+), 2 deletions(-) diff --git a/headers/os/interface/TextView.h b/headers/os/interface/TextView.h index cf23a1a51b..4e746fda13 100644 --- a/headers/os/interface/TextView.h +++ b/headers/os/interface/TextView.h @@ -455,6 +455,8 @@ private: int32 fLastClickOffset; bool fInstalledNavigateWordwiseShortcuts; bool fInstalledNavigateToTopOrBottomShortcuts; + bool fInstalledSelectWordwiseShortcuts; + bool fInstalledSelectToTopOrBottomShortcuts; uint32 _reserved[6]; }; diff --git a/src/kits/interface/TextView.cpp b/src/kits/interface/TextView.cpp index 3d97a6339b..47d665e231 100644 --- a/src/kits/interface/TextView.cpp +++ b/src/kits/interface/TextView.cpp @@ -3343,6 +3343,8 @@ BTextView::_InitObject(BRect textRect, const BFont *initialFont, fInstalledNavigateWordwiseShortcuts = false; fInstalledNavigateToTopOrBottomShortcuts = false; + fInstalledSelectWordwiseShortcuts = false; + fInstalledSelectToTopOrBottomShortcuts = false; // We put these here instead of in the constructor initializer list // to have less code duplication, and a single place where to do changes @@ -3619,6 +3621,7 @@ BTextView::_HandlePageKey(uint32 inPageKey, bool commandKeyDown) currentMessage->FindInt32("modifiers", &mods); bool shiftDown = mods & B_SHIFT_KEY; + bool controlDown = mods & B_CONTROL_KEY; STELine* line = NULL; int32 selStart = fSelStart; int32 selEnd = fSelEnd; @@ -3631,7 +3634,7 @@ BTextView::_HandlePageKey(uint32 inPageKey, bool commandKeyDown) break; } - if (commandKeyDown) { + if (commandKeyDown || controlDown) { _ScrollTo(0, 0); fCaretOffset = 0; } else { @@ -3664,7 +3667,7 @@ BTextView::_HandlePageKey(uint32 inPageKey, bool commandKeyDown) break; } - if (commandKeyDown) { + if (commandKeyDown || controlDown) { _ScrollTo(0, fTextRect.bottom + fLayoutData->bottomInset); fCaretOffset = fText->Length(); } else { @@ -5178,6 +5181,18 @@ BTextView::_Activate() new BMessage(NAVIGATE_TO_NEXT_WORD), this); fInstalledNavigateWordwiseShortcuts = true; } + if (!Window()->HasShortcut(B_LEFT_ARROW, B_COMMAND_KEY | B_SHIFT_KEY) + && !Window()->HasShortcut(B_RIGHT_ARROW, B_COMMAND_KEY | B_SHIFT_KEY)) { + BMessage* message = new BMessage(NAVIGATE_TO_PREVIOUS_WORD); + message->AddInt32("modifiers", B_SHIFT_KEY); + Window()->AddShortcut(B_LEFT_ARROW, B_COMMAND_KEY | B_SHIFT_KEY, + message, this); + message = new BMessage(NAVIGATE_TO_NEXT_WORD); + message->AddInt32("modifiers", B_SHIFT_KEY); + Window()->AddShortcut(B_RIGHT_ARROW, B_COMMAND_KEY | B_SHIFT_KEY, + message, this); + fInstalledSelectWordwiseShortcuts = true; + } if (!Window()->HasShortcut(B_HOME, B_COMMAND_KEY) && !Window()->HasShortcut(B_END, B_COMMAND_KEY)) { Window()->AddShortcut(B_HOME, B_COMMAND_KEY, @@ -5186,6 +5201,18 @@ BTextView::_Activate() new BMessage(NAVIGATE_TO_BOTTOM), this); fInstalledNavigateToTopOrBottomShortcuts = true; } + if (!Window()->HasShortcut(B_HOME, B_COMMAND_KEY | B_SHIFT_KEY) + && !Window()->HasShortcut(B_END, B_COMMAND_KEY | B_SHIFT_KEY)) { + BMessage* message = new BMessage(NAVIGATE_TO_TOP); + message->AddInt32("modifiers", B_SHIFT_KEY); + Window()->AddShortcut(B_HOME, B_COMMAND_KEY | B_SHIFT_KEY, + message, this); + message = new BMessage(NAVIGATE_TO_BOTTOM); + message->AddInt32("modifiers", B_SHIFT_KEY); + Window()->AddShortcut(B_END, B_COMMAND_KEY | B_SHIFT_KEY, + message, this); + fInstalledSelectToTopOrBottomShortcuts = true; + } } } @@ -5212,11 +5239,21 @@ BTextView::_Deactivate() Window()->RemoveShortcut(B_RIGHT_ARROW, B_COMMAND_KEY); fInstalledNavigateWordwiseShortcuts = false; } + if (fInstalledSelectWordwiseShortcuts) { + Window()->RemoveShortcut(B_LEFT_ARROW, B_COMMAND_KEY | B_SHIFT_KEY); + Window()->RemoveShortcut(B_RIGHT_ARROW, B_COMMAND_KEY | B_SHIFT_KEY); + fInstalledSelectWordwiseShortcuts = false; + } if (fInstalledNavigateToTopOrBottomShortcuts) { Window()->RemoveShortcut(B_HOME, B_COMMAND_KEY); Window()->RemoveShortcut(B_END, B_COMMAND_KEY); fInstalledNavigateToTopOrBottomShortcuts = false; } + if (fInstalledSelectToTopOrBottomShortcuts) { + Window()->RemoveShortcut(B_HOME, B_COMMAND_KEY | B_SHIFT_KEY); + Window()->RemoveShortcut(B_END, B_COMMAND_KEY | B_SHIFT_KEY); + fInstalledSelectToTopOrBottomShortcuts = false; + } } }