diff options
author | Ashley Valent <avalent@atlassian.com> | 2015-02-11 11:22:15 +1100 |
---|---|---|
committer | Ashley Valent <avalent@atlassian.com> | 2015-02-11 11:22:15 +1100 |
commit | 3b6a695b60d81691ab8e31197fc8e0444df0e394 (patch) | |
tree | 84529e1bc0a54cdd9471e53c597e913797c04014 /plugins/web-search | |
parent | 3ba10ad0a2ed85c26e096126a7899a401cf8f9e7 (diff) | |
parent | ef7e53a78d0e4196c2d1e6e5b268209759d51753 (diff) | |
download | zsh-3b6a695b60d81691ab8e31197fc8e0444df0e394.tar.gz zsh-3b6a695b60d81691ab8e31197fc8e0444df0e394.tar.bz2 zsh-3b6a695b60d81691ab8e31197fc8e0444df0e394.zip |
Merge branch 'master' of github.com:avalent/oh-my-zsh
Diffstat (limited to 'plugins/web-search')
-rw-r--r-- | plugins/web-search/web-search.plugin.zsh | 61 |
1 files changed, 33 insertions, 28 deletions
diff --git a/plugins/web-search/web-search.plugin.zsh b/plugins/web-search/web-search.plugin.zsh index 28559deb9..572427b0b 100644 --- a/plugins/web-search/web-search.plugin.zsh +++ b/plugins/web-search/web-search.plugin.zsh @@ -1,43 +1,46 @@ # web_search from terminal function web_search() { - # get the open command - local open_cmd - if [[ "$OSTYPE" = darwin* ]]; then - open_cmd='open' - else - open_cmd='xdg-open' - fi + emulate -L zsh + + # define search engine URLS + typeset -A urls + urls=( + google "https://www.google.com/search?q=" + bing "https://www.bing.com/search?q=" + yahoo "https://search.yahoo.com/search?p=" + duckduckgo "https://www.duckduckgo.com/?q=" + yandex "https://yandex.ru/yandsearch?text=" + ) + + # define the open command + case "$OSTYPE" in + darwin*) open_cmd="open" ;; + cygwin*) open_cmd="cygstart" ;; + linux*) open_cmd="xdg-open" ;; + *) echo "Platform $OSTYPE not supported" + return 1 + ;; + esac # check whether the search engine is supported - if [[ ! $1 =~ '(google|bing|yahoo|duckduckgo)' ]]; - then + if [[ -z "$urls[$1]" ]]; then echo "Search engine $1 not supported." return 1 fi - local url="http://www.$1.com" - - # no keyword provided, simply open the search engine homepage - if [[ $# -le 1 ]]; then - $open_cmd "$url" - return - fi - if [[ $1 == 'duckduckgo' ]]; then - #slightly different search syntax for DDG - url="${url}/?q=" + # search or go to main page depending on number of arguments passed + if [[ $# -gt 1 ]]; then + # build search url: + # join arguments passed with '+', then append to search engine URL + url="${urls[$1]}${(j:+:)@[2,-1]}" else - url="${url}/search?q=" + # build main page url: + # split by '/', then rejoin protocol (1) and domain (2) parts with '//' + url="${(j://:)${(s:/:)urls[$1]}[1,2]}" fi - shift # shift out $1 - - while [[ $# -gt 0 ]]; do - url="${url}$1+" - shift - done - url="${url%?}" # remove the last '+' - nohup $open_cmd "$url" >/dev/null 2&>1 + nohup $open_cmd "$url" &>/dev/null } @@ -45,6 +48,8 @@ alias bing='web_search bing' alias google='web_search google' alias yahoo='web_search yahoo' alias ddg='web_search duckduckgo' +alias yandex='web_search yandex' + #add your own !bang searches here alias wiki='web_search duckduckgo \!w' alias news='web_search duckduckgo \!n' |