;ELC ;;; Compiled ;;; in Emacs version 28.0.50 ;;; with all optimizations. (byte-code "\300\301!\210\300\302!\210\300\303!\210\300\304!\210\305\306\307\310\311\301%\210\312\313\314\315\316DD\317\320\321%\210\312\322\314\315\323DD\324\320\325%\207" [require company cl-lib help-mode find-func custom-declare-group company-elisp nil "Completion backend for Emacs Lisp." :group custom-declare-variable company-elisp-detect-function-context funcall function #[0 "\300\207" [t] 1] "If enabled, offer Lisp functions only in appropriate contexts.\nFunctions are offered for completion only after \\=' and (." :type (choice (const :tag "Off" nil) (const :tag "On" t)) company-elisp-show-locals-first #[0 "\300\207" [t] 1] "If enabled, locally bound variables and functions are displayed\nfirst in the candidates list." (choice (const :tag "Off" nil) (const :tag "On" t))] 6) (defalias 'company-elisp--prefix #[0 "\300 \211\203 \301 \203`GZ\206`Sf\302U\202\303 \205!\207\304\207" [company-grab-symbol company-in-string-or-comment 96 company-elisp--should-complete stop] 3]) #@15 (fn SYMBOL) (defalias 'company-elisp--predicate #[257 "\300!\206\301!\206\302!\206\303!\207" [boundp fboundp facep featurep] 3 (#$ . 1086)]) #@20 (fn &rest NAMES) (defalias 'company-elisp--fns-regexp #[128 "\300\301!\302Q\207" ["\\_<\\(?:cl-\\)?" regexp-opt "\\*?\\_>"] 4 (#$ . 1245)]) (defvar company-elisp-parse-limit 30) (defvar company-elisp-parse-depth 100) (defvar company-elisp-defun-names '("defun" "defmacro" "defsubst")) #@72 Regular expression matching head of a multiple variable bindings form. (defvar company-elisp-var-binding-regexp (apply 'company-elisp--fns-regexp "let" "lambda" "lexical-let" company-elisp-defun-names) (#$ . 1539)) #@71 Regular expression matching head of a form with one variable binding. (defvar company-elisp-var-binding-regexp-1 (company-elisp--fns-regexp "dolist" "dotimes") (#$ . 1760)) #@63 Regular expression matching head of a function bindings form. (defvar company-elisp-fun-binding-regexp (company-elisp--fns-regexp "flet" "labels") (#$ . 1939)) (defvar company-elisp-defuns-regexp (byte-code "\301\302\303\"P\207" [company-elisp-defun-names "([ \n]*" apply company-elisp--fns-regexp] 4)) (defalias 'company-elisp--should-complete #[0 "`\301 @\211\302V\205=\212\303[!\210\304!\205<\305u\210\306\307!\210`U?\205<\3101:\311`\312\"\211?\2064\211V\2620\202<\210\313)?\207" [company-elisp-defuns-regexp syntax-ppss 0 up-list looking-at nil forward-sexp 1 (scan-error) scan-sexps 2 t] 5]) #@27 (fn PREFIX FUNCTIONS-P) (defalias 'company-elisp--locals #[514 "\305\306!\307Q`\310\3111\331\212\312\211W\205\323\310\313\314!\210\212\310f\315=\203\312\316u\210\31715\212\320 \210`X)0\2029\210\202\312\203\312\321\310w\210\322\203J \202K\n!\203\237\323\316!\210\3241\233 \312\211W\205\224\310\212\322\325!\203k\323\316!\210\322 !\203\210\326\316!\327 \"\203\201\210\202\210\211B\262\210)\330 \266\211T\262\202Y\266\2020\210\202\312\210\202\312\204\312\322\f!\203\312\323\316!\210\322!\203\312\326\316!\327\"\203\304\210\202\312\211B\262\210)\210\211T\262\202\266\202)0\210\207\210\207" [company-elisp-parse-depth company-elisp-fun-binding-regexp company-elisp-var-binding-regexp company-elisp-parse-limit company-elisp-var-binding-regexp-1 "[ \n]*\\(\\_<" regexp-quote "\\(?:\\sw\\|\\s_\\)*\\_>\\)" nil (scan-error) 0 up-list -1 40 1 (error) forward-list " \n" looking-at down-list (scan-error) "[ \n]*(" match-string-no-properties memql forward-sexp] 15 (#$ . 2555)]) #@15 (fn PREFIX) (defalias 'company-elisp-candidates #[257 "\301!\302\303=\"\304\"\305\211:\203+@\262\235\204$B\262A\262\202\211\237\266\203\203>\306\307\310\"\307\310\"\"\207\306\"\207" [company-elisp-show-locals-first company-elisp--candidates-predicate company-elisp--locals fboundp company-elisp--globals nil append sort string<] 10 (#$ . 3586)]) #@25 (fn PREFIX PREDICATE) (defalias 'company-elisp--globals #[514 "\301#\207" [obarray all-completions] 6 (#$ . 3966)]) #@15 (fn PREFIX) (defalias 'company-elisp--candidates-predicate #[257 "\302`GZ\211\206 `Sf \203C\211\303>\204C\211\304=\203?\212\30515Sb\210\306 \2061\307\310!\210\306 0\2027\210\302)\204?\311\202D\312\202D\313)\207" [completion-ignore-case company-elisp-detect-function-context nil (39 96) 40 (error) company-elisp--before-binding-varlist-p up-list -1 fboundp boundp company-elisp--predicate] 5 (#$ . 4093)]) (defalias 'company-elisp--before-binding-varlist-p #[0 "\212\301\302!\303u\210\205 \304!)\207" [company-elisp-var-binding-regexp search-backward "(" 1 looking-at] 2]) #@15 (fn SYMBOL) (defalias 'company-elisp--doc #[257 "\300!\301!\203\302\303\"\202\304\305\303#\211;\205%\306\307\"\205%\310\311\"\207" [intern fboundp documentation t documentation-property variable-documentation string-match ".*$" match-string 0] 6 (#$ . 4688)]) #@93 `company-mode' completion backend for Emacs Lisp. (fn COMMAND &optional ARG &rest IGNORED) (defalias 'company-elisp #[641 "\301\267\202\243\302\303!\207\304\305\306\"\205\244\307 \207\310!\207\207\311!\207\312!\313 \314\315\"\216\3161k\317!\2039\320!\210\202e\321!\203F\322!\210\202e\323!\203S\324!\210\202e\325!\203`\326!\210\202e\327\330\331\"\210\332 0\202m\210\331)\207\312!\317!\203}\333\331\"\207\321!\203\210\333\334\"\207\323!\203\230\335\336\337!!!\340B\207\325!\205\242\333\341\"\207\331\207" [company-elisp-show-locals-first #s(hash-table size 7 test eq rehash-size 1.5 rehash-threshold 0.8125 purecopy t data (interactive 6 prefix 10 candidates 20 sorted 24 meta 26 doc-buffer 30 location 111)) company-begin-backend company-elisp derived-mode-p emacs-lisp-mode inferior-emacs-lisp-mode company-elisp--prefix company-elisp-candidates company-elisp--doc intern current-window-configuration make-closure #[0 "\301\300!\207" [V0 set-window-configuration] 2] (error) fboundp describe-function boundp describe-variable featurep describe-package facep describe-face signal user-error nil help-buffer find-definition-noselect defvar find-file-noselect find-library-name symbol-name 0 defface] 8 (#$ . 4968) (byte-code "\300C\207" [interactive] 1)]) (provide 'company-elisp)