forked from pool/xemacs
61 lines
2.0 KiB
EmacsLisp
61 lines
2.0 KiB
EmacsLisp
|
(defvar xe-list-file-name "xe-list")
|
||
|
|
||
|
(defun xe-list-find-el (&optional buffer)
|
||
|
(interactive)
|
||
|
(let ((el-with-elc)
|
||
|
(el-without-elc))
|
||
|
(save-excursion
|
||
|
(if buffer
|
||
|
(set-buffer buffer))
|
||
|
(goto-char (point-min))
|
||
|
(while (re-search-forward "^\\(.*\\.el\\)$" nil t)
|
||
|
(let ((el (match-string 1)))
|
||
|
(save-excursion
|
||
|
(goto-char (point-min))
|
||
|
(if (re-search-forward (concat "^" (regexp-quote el) "c$") nil t)
|
||
|
(setq el-with-elc (cons el el-with-elc))
|
||
|
(setq el-without-elc (cons el el-without-elc)))))))
|
||
|
(list (nreverse el-with-elc) (nreverse el-without-elc))))
|
||
|
|
||
|
(defun xe-list-find-elc (&optional buffer)
|
||
|
(interactive)
|
||
|
(let ((elc-with-el)
|
||
|
(elc-without-el))
|
||
|
(save-excursion
|
||
|
(if buffer
|
||
|
(set-buffer buffer))
|
||
|
(goto-char (point-min))
|
||
|
(while (re-search-forward "^\\(.*\\.elc\\)$" nil t)
|
||
|
(let ((elc (match-string 1))
|
||
|
(el (replace-in-string (match-string 1) "\\.elc$" ".el")))
|
||
|
(save-excursion
|
||
|
(goto-char (point-min))
|
||
|
(if (re-search-forward (concat "^" (regexp-quote el) "$") nil t)
|
||
|
(setq elc-with-el (cons elc elc-with-el))
|
||
|
(setq elc-without-el (cons elc elc-without-el)))))))
|
||
|
(list (nreverse elc-with-el) (nreverse elc-without-el))))
|
||
|
|
||
|
(defun xe-list-write-list-to-file (list file)
|
||
|
(interactive)
|
||
|
(with-temp-buffer
|
||
|
(mapcar (lambda (x) (insert x) (insert "\n"))
|
||
|
list)
|
||
|
(write-file file)))
|
||
|
|
||
|
(defun xe-list-generate-list-files ()
|
||
|
(interactive)
|
||
|
(let ((el-lists)
|
||
|
(elc-lists))
|
||
|
(find-file xe-list-file-name)
|
||
|
(setq el-lists (xe-list-find-el xe-list-file-name))
|
||
|
(setq elc-lists (xe-list-find-elc xe-list-file-name))
|
||
|
(xe-list-write-list-to-file (car el-lists)
|
||
|
(concat xe-list-file-name "-el-with-elc"))
|
||
|
(xe-list-write-list-to-file (car (cdr el-lists))
|
||
|
(concat xe-list-file-name "-el-without-elc"))
|
||
|
(xe-list-write-list-to-file (car elc-lists)
|
||
|
(concat xe-list-file-name "-elc-with-el"))
|
||
|
(xe-list-write-list-to-file (car (cdr elc-lists))
|
||
|
(concat xe-list-file-name "-elc-without-el"))))
|
||
|
|