A magic command for sublime. Create a spellbook, cast spells on your code, make magic happen.
SublimeMagic provides a sublime_magic
command, which looks through user-defined actions and performs the first matching one.
Default keybind is alt + spacebar
but you can set your own. To use the plugin, you have to bind the sublime_magic
command.
Regular example:
{
"keys": ["ctrl+,"],
"command": "sublime_magic"
}
Vintageous example:
{
"keys": [" ", " "],
"command": "sublime_magic",
"context": [{ "key": "vi_command_mode_aware" }]
}
The spellbook (your sublime-settings file) consists of a single spells
array containing the user-defined spells:
{
"spells": []
}
The spells are iterated one-by-one and the first one matching the context
conditions is casted. When there's no spell matching, nothing happens. When there are multiple matching spells, only the top-most one is performed.
Each spell consists of the following required fields:
name
is the human readable name of your spellspell
is the spell code, see "Available spells" for a list of spellsargs
specific to the selected spell
Spells can be limited by settings a context
(similar to key bindings, though not using the same syntax). Known context keys:
scope
- an array of required scope names (using regexp) - all patterns must matchline_matches
- an array of patterns that the current line must matchselection_empty
- whentrue
, some text has to be selected; whenfalse
, there must be no selectionselection_matches
- an array of patterns that the currently selected text must match- need more? - make an issue, or even better a PR :)
{
"name": "Replace single quoted content with clipboard",
"context": {
"scope": ["string\\.quoted\\.single"]
},
"spell": "replace_text",
"args": {
"where": "inside",
"delimiter": "'",
"replacement": "$clipboard"
}
}
- replace_text
- perform_line_regex
- toggle_values
- sublime_command
- more to come - make a PR :)
Have a nice spellbook? Create a pull request and let me add a link here!
Spellbooks:
A simple example:
{
"spells": [
{
"name": "Replace single quoted content with clipboard",
"context": {
"scope": ["string\\.quoted\\.single"]
},
"spell": "replace_text",
"args": {
"where": "inside",
"delimiter": "'",
"replacement": "$clipboard"
}
},
{
"name": "Replace double quoted content with clipboard",
"context": {
"scope": ["string\\.quoted\\.double"]
},
"spell": "replace_text",
"args": {
"where": "inside",
"delimiter": "\"",
"replacement": "$clipboard"
}
},
{
"name": "Replace content after colon with clipboard",
"context": {
"line_matches": [": "]
},
"spell": "replace_text",
"args": {
"where": "after",
"delimiter": ": ",
"replacement": "$clipboard"
}
}
]
}