summaryrefslogtreecommitdiff
path: root/lisp/emacs-lisp/check-declare.el
diff options
context:
space:
mode:
authorGlenn Morris <rgm@gnu.org>2007-11-22 06:53:24 +0000
committerGlenn Morris <rgm@gnu.org>2007-11-22 06:53:24 +0000
commit64cea5550d3c36c42da295585b8591e7fc58e6a6 (patch)
tree248e81859c528ff28fe1567963631bb3eaad97e8 /lisp/emacs-lisp/check-declare.el
parentd5cf82def8b4b45a7a1295d38c1eddacecac5898 (diff)
downloademacs-64cea5550d3c36c42da295585b8591e7fc58e6a6.tar.gz
(check-declare-verify): Fix previous change. Warn if could not find
an arglist to check.
Diffstat (limited to 'lisp/emacs-lisp/check-declare.el')
-rw-r--r--lisp/emacs-lisp/check-declare.el48
1 files changed, 29 insertions, 19 deletions
diff --git a/lisp/emacs-lisp/check-declare.el b/lisp/emacs-lisp/check-declare.el
index c1cdb3a2e80..a4767794132 100644
--- a/lisp/emacs-lisp/check-declare.el
+++ b/lisp/emacs-lisp/check-declare.el
@@ -108,17 +108,22 @@ ine-derived-mode\\|ine-minor-mode\\|alias[ \t]+'\\)\\)\
;; (min . max) for a fixed number of arguments, or
;; arglists with optional elements.
;; (min) for arglists with &rest.
+ ;; sig = 'err means we could not find an arglist.
sig (cond (cflag
- (re-search-forward "," nil t 3)
- (skip-chars-forward " \t\n")
- ;; Assuming minargs and maxargs on same line.
- (when (looking-at "\\([0-9]+\\)[ \t]*,[ \t]*\
+ (or
+ (when (re-search-forward "," nil t 3)
+ (skip-chars-forward " \t\n")
+ ;; Assuming minargs and maxargs on same line.
+ (when (looking-at "\\([0-9]+\\)[ \t]*,[ \t]*\
\\([0-9]+\\|MANY\\|UNEVALLED\\)")
- (setq minargs (string-to-number (match-string 1))
- maxargs (match-string 2))
- (cons minargs (unless (string-match "[^0-9]"
- maxargs)
- (string-to-number maxargs)))))
+ (setq minargs (string-to-number
+ (match-string 1))
+ maxargs (match-string 2))
+ (cons minargs (unless (string-match "[^0-9]"
+ maxargs)
+ (string-to-number
+ maxargs)))))
+ 'err))
((string-equal (match-string 1)
"define-derived-mode")
'(0 . 0))
@@ -129,24 +134,29 @@ ine-derived-mode\\|ine-minor-mode\\|alias[ \t]+'\\)\\)\
((string-equal (match-string 1)
"defalias")
t)
+ ((looking-at "\\((\\|nil\\)")
+ (byte-compile-arglist-signature
+ (read (current-buffer))))
(t
- (if (looking-at "\\((\\|nil\\)")
- (byte-compile-arglist-signature
- (read (current-buffer))))))
+ 'err))
;; alist of functions and arglist signatures.
siglist (cons (cons fn sig) siglist)))))
(dolist (e fnlist)
(setq arglist (nth 2 e)
type
- (if re ; re non-nil means found a file
- (if (setq sig (assoc (cadr e) siglist))
+ (if re ; re non-nil means found a file
+ (if (setq sig (assoc (cadr e) siglist)) ; found function
;; Recall we use t to mean no arglist specified,
;; to distinguish from an empty arglist.
- (unless (or (eq arglist t)
- (eq sig t))
- (unless (equal (byte-compile-arglist-signature arglist)
- (cdr sig))
- "arglist mismatch"))
+ (unless (eq arglist t)
+ (setq sig (cdr-safe sig))
+ (cond ((eq sig t)) ; defalias, can't check
+ ((eq sig 'err)
+ "arglist not found") ; internal error
+ ((not (equal (byte-compile-arglist-signature
+ arglist)
+ sig))
+ "arglist mismatch")))
"function not found")
"file not found"))
(when type