Function: erc-compat--29-auth-source-pass--build-result-many
erc-compat--29-auth-source-pass--build-result-many is a byte-compiled
function defined in erc-compat.el.gz.
Signature
(erc-compat--29-auth-source-pass--build-result-many HOSTS USERS PORTS REQUIRE MAX)
Documentation
Return a plist of HOSTS, PORTS, USERS, and secret.
Source Code
;; Defined in /usr/src/emacs/lisp/erc/erc-compat.el.gz
;; This looks bad, but it just inlines `auth-source-pass--find-match-many'.
(defun erc-compat--29-auth-source-pass--build-result-many
(hosts users ports require max)
"Return a plist of HOSTS, PORTS, USERS, and secret."
(unless (listp hosts) (setq hosts (list hosts)))
(unless (listp users) (setq users (list users)))
(unless (listp ports) (setq ports (list ports)))
(unless max (setq max 1))
(let ((seen (make-hash-table :test #'equal))
(entries (auth-source-pass-entries))
(check (lambda (m k v)
(let ((mv (plist-get m k)))
(if (memq k require)
(and v (equal mv v))
(or (not v) (not mv) (equal mv v))))))
out suffixed suffixedp)
(catch 'done
(dolist (host hosts)
(pcase-let ((`(,_ ,u ,p) (auth-source-pass--disambiguate host)))
(unless (or (not (equal "443" p)) (string-prefix-p "https://" host))
(setq p nil))
(dolist (user (or users (list u)))
(dolist (port (or ports (list p)))
(dolist (e entries)
(when-let*
((m (or (gethash e seen)
(erc-compat--29-auth-source-pass--retrieve-parsed
seen e (integerp port))))
((equal host (plist-get m :host)))
((funcall check m :port port))
((funcall check m :user user))
(parsed (auth-source-pass-parse-entry e))
(secret (or (auth-source-pass--get-attr 'secret parsed)
(not (memq :secret require)))))
(push
`( :host ,host ; prefer user-provided :host over h
,@(and-let* ((u (plist-get m :user))) (list :user u))
,@(and-let* ((p (plist-get m :port))) (list :port p))
,@(and secret (not (eq secret t)) (list :secret secret)))
(if (setq suffixedp (plist-get m :suffix)) suffixed out))
(unless suffixedp
(when (or (zerop (cl-decf max))
(null (setq entries (delete e entries))))
(throw 'done out)))))
(setq suffixed (nreverse suffixed))
(while suffixed
(push (pop suffixed) out)
(when (zerop (cl-decf max))
(throw 'done out))))))))
(reverse out)))