ctrl+shift+p filters: :st2 :st3 :win :osx :linux
Browse

Extend Selection

by aanchev ALL

Sublime Text 2/3 plugin to quickly add an arbitrary selection to the current one.

Details

Installs

  • Total 811
  • Win 484
  • Mac 182
  • Linux 145
Apr 25 Apr 24 Apr 23 Apr 22 Apr 21 Apr 20 Apr 19 Apr 18 Apr 17 Apr 16 Apr 15 Apr 14 Apr 13 Apr 12 Apr 11 Apr 10 Apr 9 Apr 8 Apr 7 Apr 6 Apr 5 Apr 4 Apr 3 Apr 2 Apr 1 Mar 31 Mar 30 Mar 29 Mar 28 Mar 27 Mar 26 Mar 25 Mar 24 Mar 23 Mar 22 Mar 21 Mar 20 Mar 19 Mar 18 Mar 17 Mar 16 Mar 15 Mar 14 Mar 13 Mar 12
Windows 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
Mac 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0
Linux 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Readme

Source
raw.​githubusercontent.​com

Sublime ExtendSelection

ExtendSelection is a Sublime Text 2/3 plugin that allows you to make multiple selections more easily.

After triggering the “Extend Selection” command (be it by using the key shortcuts, or the menu item in the “Selection” menu), you simply make a new selection and it will get added to the current one, instead of replacing it. You can make the new selection(s) in whatever way you would like - any method of navigation should be handled well.

Recommendation

Before you continue, do consider the package MultiEditUtils. It offers a lot more and can be used to achieve the same functionality as this plugin's.

Usage

Add the next selection to the current one

alt+shift+m

It will listen for the next change in the selection and append it to the previous selection (“current selection” at time of pressing alt+shift+m).

Example

For example, if I want to keep my current selection at line 15, column 10 and add to it a caret at line 12, I would trigger the “Extend Selection” command (default alt+shift+m), then call “Goto line”, type “:12” and press enter. That will move my caret to the beginning of line 12 but because I triggered “Extend Selection” beforehand, the new selection will be added to the previous one, rather than replacing it. So I will have a multi-selection at line 12, column 0 and line 15, column 10.

Manually completing “Extend Selection”

You can also extend the current selection with multiple new selections. Trigger “Start extending the selection” which is bound to ctrl+alt+m by default. Then make as many selections as you want. They will all add to the current one rather than overriding it. When you are done making selections, complete the command by calling “Finish extending the selection”, bound to ctrl+alt+m again (Esc would also work).

You may also have a look at the “Stay active until timeout expires” setting described below.

Example

selection at row 9 column 5
trigger “Start extending the selection” (ctrl+alt+m)
make selection at row 10 column 0 to row 12 column 51
make selection at row 0 column 0 to row 0 column 27
call “Finish extending the selection” (ctrl+alt+m again, or Esc)
selection is now multi-selection at 9:5, 10:0 to 12:51 and 0:0 to 0:27

Settings

Combine 'one-move' change events

"combine_onemove_events": true

The plugin by default tries to handle drag-selections (mouse dragging). This is achieved by combining new selections that are within one move from the recently-made new selection. While this does work, it also means that further selections made using the arrow keys, for example, will also be 'combined' with the latest one.

Example of when this may be unwanted

selection at row 10 column 2
trigger ExtendSelection (alt+shift+m)
drag-select from row 15 column 5 to row 15 column 20
shift+right
This will add to the last selection, instead of doing shift+right for EVERY selection

Please beware of this and disable the feature if that behaviour is undesired.

Stay active until timeout expires

"active_until_timeout": 0 //ms

The completion of the command can be delayed for a specified amount of time. This means that selection changes will continue to be handled by the command even after the first one, until the timeout expires. The timeout refreshes after each selection change, so if frequent enough changes are made all of them will be handled by the command.

This is potentially confusing, even with a small timeout delay. Because of that, this feature is disabled by default.

The setting specifies the time to delay the completion by. The value is in milliseconds. Negative values and zero effectively disable the behaviour.

Example

“active_until_timeout” is set to 500
selection at row 11 column 3
trigger ExtendSelection (alt+shift+m)
make a selection at row 16 column 6
within 0.5 second, make a selection at row 17 column 7
the actual selection is now multi-selection at 11:3 , 16:6 and 17:7
wait 0.5 second, and the command completes

Installation

Install via PackageControl

If you have the PackageControl plugin installed, you can use that to install ExtendSelection.

Just type cmd-shift-p (ctrl-shift-p on win/linux) to bring up the command palette then type install and pick Package Control: Install Package from the dropdown.

Then type ExtendSelection and choose the ExtendSelection plugin from the dropdown. Hit enter and it will install.

Manual Installation

Manual installation should be as easy as cloning this git repository into your Sublime Packages directory.
(mind the version of sublime)

On Windows:

cd "%AppData%\Sublime Text 2\Packages"
git clone git://github.com/anly2/sublime-extend-selection.git ExtendSelection

Or you can copy the files manually into a folder \Packages\ExtendSelection, if you do not have git or are not feeling comfortable with it.

Versions

[1.2.0] - released 15/12/15
Added:
  • a feature named 'active_until_timeout' that delays the actual completion of the command for a specified time
[1.1.1] - released 14/12/15
Added:
  • a feature named 'combine_onemove_events' that handles drag-selections
[1.0.0] - released 24/10/15

Initial release with basic functionality.