diff options
| author | Tuowen Zhao <ztuowen@gmail.com> | 2020-07-04 11:54:44 -0600 | 
|---|---|---|
| committer | Tuowen Zhao <ztuowen@gmail.com> | 2020-07-04 11:54:44 -0600 | 
| commit | 59344b5c59b7190ad3b14a2e8e02db8b5559141b (patch) | |
| tree | a8e7ede89d3b896967d7d18d071107bd06c77897 /plugins/web-search | |
| parent | a3be2e4084285d7625e63bfe4b951c58143e3c9c (diff) | |
| parent | a15f0f0e9ff17c1ca5c6d694d732e72c7c03a62b (diff) | |
| download | zsh-59344b5c59b7190ad3b14a2e8e02db8b5559141b.tar.gz zsh-59344b5c59b7190ad3b14a2e8e02db8b5559141b.tar.bz2 zsh-59344b5c59b7190ad3b14a2e8e02db8b5559141b.zip  | |
Merge remote-tracking branch 'origin/master'
Diffstat (limited to 'plugins/web-search')
| -rw-r--r-- | plugins/web-search/README.md | 26 | ||||
| -rw-r--r-- | plugins/web-search/web-search.plugin.zsh | 17 | 
2 files changed, 42 insertions, 1 deletions
diff --git a/plugins/web-search/README.md b/plugins/web-search/README.md index 9c01f0724..da90f90a0 100644 --- a/plugins/web-search/README.md +++ b/plugins/web-search/README.md @@ -40,6 +40,8 @@ Available search contexts are:  | `givero`              | `https://www.givero.com/search?q=`       |  | `stackoverflow`       | `https://stackoverflow.com/search?q=`    |  | `wolframalpha`        | `https://wolframalpha.com/input?i=`      | +| `archive`             | `https://web.archive.org/web/*/`         | +| `scholar`             | `https://scholar.google.com/scholar?q=`  |  Also there are aliases for bang-searching DuckDuckGo: @@ -51,3 +53,27 @@ Also there are aliases for bang-searching DuckDuckGo:  | `map`     | `!m`  |  | `image`   | `!i`  |  | `ducky`   | `!`   | + +### Custom search engines + +If you want to add other search contexts to the plugin, you can use the +`$ZSH_WEB_SEARCH_ENGINES` variable. Set it before Oh My Zsh is sourced, +with the following format: + +```zsh +ZSH_WEB_SEARCH_ENGINES=( +    <context> <URL> +    <context> <URL> +) +``` + +where `<context>` is the name of the search context, and `<URL>` a URL of +the same type as the search contexts above. For example, to add `reddit`, +you'd do: + +```zsh +ZSH_WEB_SEARCH_ENGINES=(reddit "https://www.reddit.com/search/?q=") +``` + +These custom search engines will also be turned to aliases, so you can +both do `web_search reddit <query>` or `reddit <query>`. diff --git a/plugins/web-search/web-search.plugin.zsh b/plugins/web-search/web-search.plugin.zsh index f975bad7a..0a2b8809e 100644 --- a/plugins/web-search/web-search.plugin.zsh +++ b/plugins/web-search/web-search.plugin.zsh @@ -6,6 +6,7 @@ function web_search() {    # define search engine URLS    typeset -A urls    urls=( +    $ZSH_WEB_SEARCH_ENGINES      google      "https://www.google.com/search?q="      bing        "https://www.bing.com/search?q="      yahoo       "https://search.yahoo.com/search?p=" @@ -20,11 +21,13 @@ function web_search() {      givero      "https://www.givero.com/search?q="      stackoverflow  "https://stackoverflow.com/search?q="      wolframalpha   "https://www.wolframalpha.com/input/?i=" +    archive     "https://web.archive.org/web/*/" +    scholar        "https://scholar.google.com/scholar?q="    )    # check whether the search engine is supported    if [[ -z "$urls[$1]" ]]; then -    echo "Search engine $1 not supported." +    echo "Search engine '$1' not supported."      return 1    fi @@ -57,6 +60,8 @@ alias qwant='web_search qwant'  alias givero='web_search givero'  alias stackoverflow='web_search stackoverflow'  alias wolframalpha='web_search wolframalpha' +alias archive='web_search archive' +alias scholar='web_search scholar'  #add your own !bang searches here  alias wiki='web_search duckduckgo \!w' @@ -65,3 +70,13 @@ alias youtube='web_search duckduckgo \!yt'  alias map='web_search duckduckgo \!m'  alias image='web_search duckduckgo \!i'  alias ducky='web_search duckduckgo \!' + +# other search engine aliases +if [[ ${#ZSH_WEB_SEARCH_ENGINES} -gt 0 ]]; then +  typeset -A engines +  engines=($ZSH_WEB_SEARCH_ENGINES) +  for key in ${(k)engines}; do +    alias "$key"="web_search $key" +  done +  unset engines key +fi  | 
