aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--background_scripts/commands.coffee20
-rw-r--r--content_scripts/vomnibar.coffee13
2 files changed, 19 insertions, 14 deletions
diff --git a/background_scripts/commands.coffee b/background_scripts/commands.coffee
index 80ca0f96..47eb7e8e 100644
--- a/background_scripts/commands.coffee
+++ b/background_scripts/commands.coffee
@@ -52,11 +52,11 @@ Commands =
tokens = line.replace(/\s+$/, "").split /\s+/
switch tokens[0]
when "map"
- [ _, key, command, options... ] = tokens
+ [ _, key, command, optionList... ] = tokens
if command? and @availableCommands[command]
key = @normalizeKey key
logMessage? "Mapping #{key} to #{command}"
- @mapKeyToCommand { key, command, options }
+ @mapKeyToCommand { key, command, options: @parseCommandOptions optionList }
when "unmap"
if tokens.length == 2
@@ -74,6 +74,22 @@ Commands =
Settings.set "passNextKeyKeys",
(key for own key of @keyToCommandRegistry when @keyToCommandRegistry[key].command == "passNextKey" and 1 < key.length)
+ # Command options follow command mappings, and are of one of two forms:
+ # key=value - a value
+ # key - a flag
+ parseCommandOptions: (optionList) ->
+ options = {}
+ for option in optionList
+ parse = option.split "="
+ switch parse.length
+ when 1
+ options[parse[0]] = true
+ when 2
+ options[parse[0]] = parse[1]
+ else
+ console.log "Vimium configuration error: invalid option: #{option}."
+ options
+
clearKeyMappingsAndSetDefaults: ->
@keyToCommandRegistry = {}
@mapKeyToCommand { key, command } for own key, command of defaultKeyMappings
diff --git a/content_scripts/vomnibar.coffee b/content_scripts/vomnibar.coffee
index 6c08ce92..55a46777 100644
--- a/content_scripts/vomnibar.coffee
+++ b/content_scripts/vomnibar.coffee
@@ -10,18 +10,7 @@ Vomnibar =
options = {}
searchEngines = Settings.get("searchEngines") ? ""
SearchEngines.refreshAndUse searchEngines, (engines) ->
- for option in registryEntry.options
- [ key, value ] = option.split "="
- switch key
- when "keyword"
- if value? and engines[value]?
- options.keyword = value
- else
- console.log "Vimium configuration error: no such custom search engine: #{option}."
- else
- console.log "Vimium configuration error: unused flag: #{option}."
-
- callback? options
+ callback? registryEntry.options
# sourceFrameId here (and below) is the ID of the frame from which this request originates, which may be different
# from the current frame.