Expression
Extra source code navigation hotkeys
Details
Installs
- Total 6K
- Win 3K
- Mac 2K
- Linux 1K
Sep 18 | Sep 17 | Sep 16 | Sep 15 | Sep 14 | Sep 13 | Sep 12 | Sep 11 | Sep 10 | Sep 9 | Sep 8 | Sep 7 | Sep 6 | Sep 5 | Sep 4 | Sep 3 | Sep 2 | Sep 1 | Aug 31 | Aug 30 | Aug 29 | Aug 28 | Aug 27 | Aug 26 | Aug 25 | Aug 24 | Aug 23 | Aug 22 | Aug 21 | Aug 20 | Aug 19 | Aug 18 | Aug 17 | Aug 16 | Aug 15 | Aug 14 | Aug 13 | Aug 12 | Aug 11 | Aug 10 | Aug 9 | Aug 8 | Aug 7 | Aug 6 | Aug 5 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Windows | 0 | 2 | 2 | 0 | 0 | 2 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 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 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 2 | 0 | 1 | 1 | 1 |
Linux | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 2 | 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 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
Readme
- Source
- raw.githubusercontent.com
Expression
This is really glorious plugin that provides api used by many other plugins of sublime-enhanced as well as great amount of navigation keyboard shortcuts.
Demo
Installation
This plugin is part of sublime-enhanced plugin set. You can install sublime-enhanced and this plugin will be installed automatically.
If you would like to install this package separately check “Installing packages separately” section of sublime-enhanced package.
Usage
Hit keyboard shortcut to navigate in opened file according to table below.
Commands
Description | Keyboard shortcuts |
---|---|
Goto block up | ctrl+i |
Goto block down | ctrl+k |
Select block up | ctrl+shift+i |
Select block down | ctrl+shift+k |
Goto end of next brackets | ctrl+alt+\ |
Goto in brackets forward | alt+enter |
Goto out of brackets or string forward | alt+shift+enter |
Goto over next brackets forward | ctrl+shift+enter |
Goto in brackets backward | alt+ctrl+backspace |
Goto out of brackets or string backward | alt+shift+backspace |
Goto over brackets backward | alt+ctrl+shift+backspace |
Goto matched bracket or quote | ctrl+alt+enter |
Select in brackets or string | alt+ctrl+shift+enter |
Select in brackets or string including wrapping | alt+ctrl+shift+\ |
Delete in brackets or string | ctrl+alt+shift+/ |
Select to bracket or quote forward | alt+shift+\ |
Select to bracket or quote backward | ctrl+shift+\ |
Delete brackets or string backward | alt+backspace |
Delete brackets or string forward | ctrl+alt+/ |
Goto over brackets or string forward | alt+ctrl+l |
Select brackets or string forward | alt+ctrl+shift+l |
Goto over brackets or string backward | ctrl+alt+j |
Select brackets or string backward | ctrl+alt+shift+j |
Clean brackets or quotes forward | ctrl+/ |
Clean brackets or quotes backward | ctrl+backspace |
Goto search result forward | alt+enter |
Goto search result backward | alt+shift+enter |
API
Guys, API of this plugin is a bit bloated; sorry for that.
find_matches(view, cursor, expression, options = {})
Description:
Find all matches of expression in view according from the cursor and filter it according to options.
Arguments:
view - view where to look for brackets
cursor - int; point inside view from which expression should be matched
expression - string; regexp to match
options:
“backward” - bool; whether to find matches backward or forward from cursor; note that matches will be sorted from closest to most far match.
“range” - [int, int]; range in view where to look for matches; put a huge attention that view.substr(sublime.Region(*options['range'])) will be called and to find resulting match position you explicitly need to add options['range'][0] manually to match.start(group) or match.end(group)
“nesting” - how to treat brackets; True - allow matching in brackets; False or “start” - disallow matching in brackets for match.start(0); “end” - disallow matching in brackets for match.end(0); int - disallow matching in brackets for match.start(int); array of int's - disallow matching in brackets for each element of array
“in_current_nesting” - bool; look only into the current brackets
“string” - same that “nesting” option do but for string (don't allow specified regexp group to hit string)
“comment” - same that “nesting” option do but for comment (don't allow specified regexp group to hit comment)
“scope” - regexp; scope of groups, specified in “scope_groups” should match this regexp; this is useful when you need to match only operators or keyword or another specific scope; if you need to ignore some scope you can specify negative lookahead (e.g. (?!.*operator) - do not match “operator” scope)
“scope_groups” - same that “nesting” but for “scope” option (scope of specified regexp groups should match “scope” option)
“cursor” - same that “nesting” but for cursor point (don't allow specified regexp group to be out of cursor according to “backward” option)
“limit” - how many matches you need
Result:
List of matches.
Comment:
I have find out that regexps is very fast but filtering is very slow and lugs can be noticeable and be really annoying on large files (2k+ lines) even for simple regexps that hit a lot of matches. So specify 'range' and 'limit' where it is possible to reduce execution time.
Probably I'll rewrite this part or whole library in order to minimize execution time and clean out interface of library.
Example:
from Expression import expression
class MyCommand(sublime_plugin.TextCommand):
def run(self, edit):
# find three last r'("|\')(\s*)(+)' before cursor where (\s*)(+) is not
# string and (+) is operator
options = {
'nesting': False,
'scope': r'operator',
'scope_groups': [2],
'string': [2, 3],
'limit': 3,
'backward': True
}
print(expression.find_matches(self.view, self.view.sel()[0].b,
r'("|\')(\s*)(+)', options))
find_match(view, cursor, expression, options = {})
Description:
Like find_matches but returns one match or None if no matches found. Just a helper.
get_nesting(view, cursor, search_range = None, options = {}, expression = r'[({[]')
Description:
Get position inside of brackets that surrounds cursor. Note that it will return position inside of brackets, e.g. for “(value)” position of “v” and “)” will be returned.
Arguments:
view - view where to look for brackets
cursor - int, point inside view where to look for brackets
search_range - int or array([int, int]) for how many symbols should be analyzed; if array passed, first element will be for backward count, second - for forward count of bytes to be analyzed
options - dict with options (see above for options description)
expression - regexp to find first bracket
Result:
Array with 2 integers or None if nothing was found.
Example:
from Expression import expression
class MyCommand(sublime_plugin.TextCommand):
def run(self, edit):
cursor = self.view.sel()[0].b
print(expression.get_nesting(self.view, cursor, 1024, {}, r'\('))
There is a bit more methods but probably I'll add them to “deprecated” as there is no need of them
Additional options for lookup and find_match
Lookup and find match can receive “start” and “end” options which controls resulting “start” and “end” positions.
This options can receive following values:
“start” - (default for “start”) return position of regexp start
“end” - (default for “end”) return position of whole regexp end
“first_non_empty” - first non-empty group
“last_non_empty” - first non-empty group
integer - (group number) return position of specified group
list of integers - (groups number) return position of first non-empty group
Example:
_, position, _ = lookup(self.view, 0, r'\(', {“start”: “end”}) # returns position after next parenthesis
Dependencies
None