# HG changeset patch # User Karl Heuer # Date 890612120 0 # Node ID 9eb6fcceba90c71fd62bf38f2ef4de7230944036 # Parent 4a9b37818facfa25cedef3cb685003d3b4f537a9 (normal-top-level-add-subdirs-to-load-path): New function. diff -r 4a9b37818fac -r 9eb6fcceba90 lisp/startup.el --- a/lisp/startup.el Mon Mar 23 00:14:06 1998 +0000 +++ b/lisp/startup.el Mon Mar 23 00:15:20 1998 +0000 @@ -333,6 +333,26 @@ (defvar init-file-had-error nil) +(defun normal-top-level-add-subdirs-to-load-path () + "Add all subdirectories of current directory to `load-path'." + (let (dirs + (pending (list default-directory))) + ;; This loop does a breadth-first tree walk on DIR's subtree, + ;; putting each subdir into DIRS as its contents are examined. + (while pending + (setq dirs (cons (car pending) dirs)) + (setq pending (cdr pending)) + (let ((contents (directory-files (car dirs))) + (default-directory (car dirs))) + (while contents + (unless (member (car contents) + '("." ".." "RCS")) + (when (file-directory-p (car contents)) + (setq pending (nconc pending + (list (expand-file-name (car contents))))))) + (setq contents (cdr contents))))) + (normal-top-level-add-to-load-path dirs))) + ;; This function is called from the subdirs.el file. (defun normal-top-level-add-to-load-path (dirs) (let ((tail load-path)