;;; tools/lookup/autoload/online.el -*- lexical-binding: t; -*- (defvar +lookup--last-provider nil) (defun +lookup--online-provider (&optional force-p namespace) (let ((key (or namespace major-mode))) (or (and (not force-p) (cdr (assq key +lookup--last-provider))) (when-let (provider (completing-read "Search on: " (mapcar #'car +lookup-provider-url-alist) nil t)) (setf (alist-get key +lookup--last-provider) provider) provider)))) ;;;###autoload (defun +lookup-online-backend-fn (identifier) "Opens the browser and searches for IDENTIFIER online. Will prompt for which search engine to use the first time (or if the universal argument is non-nil)." (+lookup/online identifier (+lookup--online-provider (not current-prefix-arg)))) ;;;###autoload (defun +lookup/online (arg &optional query provider) "Looks up QUERY (a string) in you browser using PROVIDER. PROVIDER should be a key of `+lookup-provider-url-alist'. When used interactively, it will prompt for a query and, for the first time, the provider from `+lookup-provider-url-alist'. On consecutive uses, the last provider will be reused. If the universal argument is supplied, always prompt for the provider." (interactive "P") (let* ((provider (or provider (+lookup--online-provider arg))) (query (or query (+lookup-symbol-or-region))) (backend (cl-find-if (lambda (x) (or (stringp x) (fboundp x))) (cdr (assoc provider +lookup-provider-url-alist))))) (if (and (functionp backend) (commandp backend)) (call-interactively backend) (unless backend (user-error "%S is an invalid query engine backend for %S provider" backend provider)) (cl-check-type backend (or string function)) (condition-case-unless-debug e (progn (unless query (setq query (read-string (format "Search for (on %s): " provider) (thing-at-point 'symbol t)))) (when (or (functionp backend) (symbolp backend)) (setq backend (funcall backend))) (when (string-empty-p query) (user-error "The query query is empty")) (funcall +lookup-open-url-fn (format backend (url-encode-url query)))) (error (setq +lookup--last-provider (delq (assq major-mode +lookup--last-provider) +lookup--last-provider)) (signal (car e) (cdr e))))))) ;;;###autoload (defun +lookup/online-select () "Runs `+lookup/online', but always prompts for the provider to use." (interactive) (let ((current-prefix-arg t)) (call-interactively #'+lookup/online)))