diff options
Diffstat (limited to 'src/shared')
-rw-r--r-- | src/shared/commands.js | 34 |
1 files changed, 19 insertions, 15 deletions
diff --git a/src/shared/commands.js b/src/shared/commands.js index 2d95e84..32007bd 100644 --- a/src/shared/commands.js +++ b/src/shared/commands.js @@ -1,20 +1,21 @@ import * as tabs from 'background/tabs'; import * as histories from 'background/histories'; -const normalizeUrl = (string, searchConfig) => { +const normalizeUrl = (args, searchConfig) => { + let concat = args.join(' '); try { - return new URL(string).href; + return new URL(concat).href; } catch (e) { - if (string.includes('.') && !string.includes(' ')) { - return 'http://' + string; + if (concat.includes('.') && !concat.includes(' ')) { + return 'http://' + concat; } - let query = encodeURI(string); + let query = encodeURI(concat); let template = searchConfig.engines[ searchConfig.default ]; for (let key in searchConfig.engines) { - if (string.startsWith(key + ' ')) { - query = encodeURI(string.replace(key + ' ', '')); + if (args[0] === key) { + query = args.slice(1).join(' '); template = searchConfig.engines[key]; } } @@ -87,20 +88,25 @@ const getOpenCompletions = (command, keywords, searchConfig) => { }); }; -const doCommand = (name, remaining, settings) => { +const doCommand = (line, settings) => { + let words = line.trim().split(/ +/); + let name = words.shift(); + switch (name) { case 'o': case 'open': - return openCommand(normalizeUrl(remaining, settings.search)); + return openCommand(normalizeUrl(words, settings.search)); case 't': case 'tabopen': - return tabopenCommand(normalizeUrl(remaining, settings.search)); + return tabopenCommand(normalizeUrl(words, settings.search)); case 'w': case 'winopen': - return winopenCommand(normalizeUrl(remaining, settings.search)); + return winopenCommand(normalizeUrl(words, settings.search)); case 'b': case 'buffer': - return bufferCommand(remaining); + return bufferCommand(words); + case '': + return Promise.resolve(); } throw new Error(name + ' command is not defined'); }; @@ -137,9 +143,7 @@ const getCompletions = (command, keywords, settings) => { }; const exec = (line, settings) => { - let name = line.split(' ')[0]; - let remaining = line.replace(name + ' ', ''); - return doCommand(name, remaining, settings); + return doCommand(line, settings); }; const complete = (line, settings) => { |