From 5d108606177a27f9199a972aeb99b18ef4c0465c Mon Sep 17 00:00:00 2001 From: Glenn Morris Date: Fri, 10 May 2013 19:29:57 -0700 Subject: [PATCH] More cus-test.el tweaks * admin/cus-test.el (cus-test-libs-noloads): Add a few more files. (cus-test-load-libs, cus-test-opts): Add option to load more/all Lisp files. (cus-test-get-lisp-files): Ignore .*.el files. --- admin/ChangeLog | 7 +++++++ admin/cus-test.el | 34 ++++++++++++++++++++++++---------- 2 files changed, 31 insertions(+), 10 deletions(-) diff --git a/admin/ChangeLog b/admin/ChangeLog index 8ae595df980..b83b0811e54 100644 --- a/admin/ChangeLog +++ b/admin/ChangeLog @@ -1,3 +1,10 @@ +2013-05-11 Glenn Morris + + * cus-test.el (cus-test-libs-noloads): Add a few more files. + (cus-test-load-libs, cus-test-opts): + Add option to load more/all Lisp files. + (cus-test-get-lisp-files): Ignore .*.el files. + 2013-05-10 Glenn Morris * cus-test.el (cus-test-libs-noloads): Add some files. diff --git a/admin/cus-test.el b/admin/cus-test.el index 90fb40b77c2..3553f62bb0e 100644 --- a/admin/cus-test.el +++ b/admin/cus-test.el @@ -99,9 +99,14 @@ (defvar cus-test-skip-list nil "List of variables to disregard by `cus-test-apropos'.") -;; Loading dunnet in batch mode leads to a Dead end. -(defvar cus-test-libs-noloads '("play/dunnet.el" "emulation/edt-mapper.el" - "loadup.el" "mail/blessmail.el") +(defvar cus-test-libs-noloads + ;; Loading dunnet in batch mode leads to a Dead end. + ;; blessmail writes a file. + ;; characters cannot be loaded twice ("Category `a' is already defined"). + '("play/dunnet.el" "emulation/edt-mapper.el" + "loadup.el" "mail/blessmail.el" "international/characters.el" + "cedet/ede/loaddefs.el" "cedet/semantic/loaddefs.el" + "net/tramp-loaddefs.el") "List of files not to load by `cus-test-load-libs'. Names should be as they appear in loaddefs.el.") @@ -277,9 +282,11 @@ The detected problematic options are stored in `cus-test-errors'." (run-hooks 'cus-test-after-load-libs-hook))) ;; This is just cus-test-libs, but loading in the current Emacs process. -(defun cus-test-load-libs () +(defun cus-test-load-libs (&optional more) "Load the libraries with autoloads. -Don't load libraries in `cus-test-libs-noloads'." +Don't load libraries in `cus-test-libs-noloads'. +If optional argument MORE is \"defcustom\", load all files with defcustoms. +If it is \"all\", load all Lisp files." (interactive) (cus-test-load-1 (let ((lispdir (file-name-directory (locate-library "loaddefs")))) @@ -292,7 +299,9 @@ Don't load libraries in `cus-test-libs-noloads'." (error (push (cons file alpha) cus-test-libs-errors) (message "Error for %s: %s" file alpha)))) - (cus-test-get-autoload-deps))))) + (if more + (cus-test-get-lisp-files (equal more "all")) + (cus-test-get-autoload-deps)))))) (defun cus-test-get-autoload-deps () "Return the list of files with autoloads." @@ -313,7 +322,7 @@ Optional argument ALL non-nil means list all Lisp files." ;; Hack to remove leading "./". (mapcar (lambda (e) (substring e 2)) (apply 'process-lines find-program - "-name" "*.el" + "-name" "[^.]*.el" ; ignore .dir-locals.el (unless all (list "-exec" grep-program "-l" "^[ \t]*(defcustom" "{}" "+")))) @@ -326,16 +335,21 @@ Optional argument ALL non-nil means list all Lisp files." ;;; The routines for batch mode: -(defun cus-test-opts () +(defun cus-test-opts (&optional all) "Test custom options. This function is suitable for batch mode. E.g., invoke src/emacs -batch -l admin/cus-test.el -f cus-test-opts -in the Emacs source directory." +in the Emacs source directory. +Normally only tests options belonging to files in loaddefs.el. +If optional argument ALL is non-nil, test all files with defcustoms." (interactive) + (and noninteractive + command-line-args-left + (setq all (pop command-line-args-left))) (message "Running %s" 'cus-test-load-libs) - (cus-test-load-libs) + (cus-test-load-libs (if all "defcustom")) (message "Running %s" 'cus-test-load-custom-loads) (cus-test-load-custom-loads) (message "Running %s" 'cus-test-apropos) -- 2.39.2