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

Select all by current scope

by mreq ALL

Select everything matching the current scope (with an optional filter).

Details

Installs

  • Total 2K
  • Win 1K
  • Mac 507
  • Linux 293
Jun 21 Jun 20 Jun 19 Jun 18 Jun 17 Jun 16 Jun 15 Jun 14 Jun 13 Jun 12 Jun 11 Jun 10 Jun 9 Jun 8 Jun 7 Jun 6 Jun 5 Jun 4 Jun 3 Jun 2 Jun 1 May 31 May 30 May 29 May 28 May 27 May 26 May 25 May 24 May 23 May 22 May 21 May 20 May 19 May 18 May 17 May 16 May 15 May 14 May 13 May 12 May 11 May 10 May 9 May 8
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 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0
Mac 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 0
Linux 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 0 0 0 0 0 0

Readme

Source
raw.​githubusercontent.​com

Select all by current scope

Provides a select_all_by_current_scope command, which (as the name suggests) select everything matching the current scope (that is the scope of your first cursor).

The command accepts an optional argument scope_must_match containing a regex string, which filters the long scope string to get a single scope name.

This plugin doesn't have any default keybindings. You have to assign them yourself.

Example keybindings

Selects everything matching current scope:

[
  {
    "keys": ["ctrl+alt+shift+a"],
    "command": "select_all_by_current_scope"
  }
]

Selects everything matching the first piece of current scope, which contains the word embedded:

[
  {
    "keys": ["ctrl+alt+shift+a"],
    "command": "select_all_by_current_scope",
    "args": { "scope_must_match": "embedded" }
  }
]

Usecase

Say you have a knitr/Sweave file with embedded R code. You might want to select all the R code. For that, I have the following keybinding:

[
  {
    "keys": ["ctrl+alt+shift+a"],
    "command": "select_all_by_current_scope",
    "args": { "scope_must_match": "embedded" }
    "context": [
      { "key": "selector", "operator": "equal", "operand": "source.r.embedded.knitr" }
    ]
  }
]

How about all the javascript code from an HTML file? Bold text from a Markdown file? That's matched by default:

[
  {
    "keys": ["ctrl+alt+shift+a"],
    "command": "select_all_by_current_scope"
  }
]