mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-25 20:19:18 -05:00
emacs-build-system: Byte compile the autoload files.
* guix/build/emacs-build-system.scm (enable-autoloads-compilation) (validate-compiled-autoloads): Add procedures. (%standard-phases): Register the new procedures. * gnu/packages/aux-files/emacs/guix-emacs.el (guix-emacs-find-autoloads): Remove duplicates in the list of autoload files found. * guix/build/emacs-utils.scm (expr->string): Add procedure. (emacs-batch-eval, emacs-batch-edit-file): Use it.
This commit is contained in:
parent
4714d0fc1a
commit
9659459f06
3 changed files with 31 additions and 6 deletions
|
@ -35,8 +35,9 @@
|
||||||
"Return a list of Emacs 'autoloads' files in DIRECTORY.
|
"Return a list of Emacs 'autoloads' files in DIRECTORY.
|
||||||
The files in the list do not have extensions (.el, .elc)."
|
The files in the list do not have extensions (.el, .elc)."
|
||||||
;; `directory-files' doesn't honor group in regexp.
|
;; `directory-files' doesn't honor group in regexp.
|
||||||
(mapcar #'file-name-sans-extension
|
(delete-dups (mapcar #'file-name-sans-extension
|
||||||
(directory-files directory 'full-name guix-emacs-autoloads-regexp)))
|
(directory-files directory 'full-name
|
||||||
|
guix-emacs-autoloads-regexp))))
|
||||||
|
|
||||||
;;;###autoload
|
;;;###autoload
|
||||||
(defun guix-emacs-autoload-packages ()
|
(defun guix-emacs-autoload-packages ()
|
||||||
|
|
|
@ -225,6 +225,21 @@ (define* (make-autoloads #:key outputs inputs #:allow-other-keys)
|
||||||
(parameterize ((%emacs emacs))
|
(parameterize ((%emacs emacs))
|
||||||
(emacs-generate-autoloads elpa-name site-lisp))))
|
(emacs-generate-autoloads elpa-name site-lisp))))
|
||||||
|
|
||||||
|
(define* (enable-autoloads-compilation #:key outputs #:allow-other-keys)
|
||||||
|
"Remove the NO-BYTE-COMPILATION local variable embedded in the generated
|
||||||
|
autoload files."
|
||||||
|
(let* ((out (assoc-ref outputs "out"))
|
||||||
|
(autoloads (find-files out "-autoloads.el$")))
|
||||||
|
(substitute* autoloads
|
||||||
|
((";; no-byte-compile.*") ""))
|
||||||
|
#t))
|
||||||
|
|
||||||
|
(define* (validate-compiled-autoloads #:key outputs #:allow-other-keys)
|
||||||
|
"Verify whether the byte compiled autoloads load fine."
|
||||||
|
(let* ((out (assoc-ref outputs "out"))
|
||||||
|
(autoloads (find-files out "-autoloads.elc$")))
|
||||||
|
(emacs-batch-eval (format #f "(mapc #'load '~s)" autoloads))))
|
||||||
|
|
||||||
(define (emacs-package? name)
|
(define (emacs-package? name)
|
||||||
"Check if NAME correspond to the name of an Emacs package."
|
"Check if NAME correspond to the name of an Emacs package."
|
||||||
(string-prefix? "emacs-" name))
|
(string-prefix? "emacs-" name))
|
||||||
|
@ -253,10 +268,13 @@ (define %standard-phases
|
||||||
(replace 'check check)
|
(replace 'check check)
|
||||||
(replace 'install install)
|
(replace 'install install)
|
||||||
(add-after 'install 'make-autoloads make-autoloads)
|
(add-after 'install 'make-autoloads make-autoloads)
|
||||||
(add-after 'make-autoloads 'patch-el-files patch-el-files)
|
(add-after 'make-autoloads 'enable-autoloads-compilation
|
||||||
|
enable-autoloads-compilation)
|
||||||
|
(add-after 'enable-autoloads-compilation 'patch-el-files patch-el-files)
|
||||||
;; The .el files are byte compiled directly in the store.
|
;; The .el files are byte compiled directly in the store.
|
||||||
(add-after 'patch-el-files 'build build)
|
(add-after 'patch-el-files 'build build)
|
||||||
(add-after 'build 'move-doc move-doc)))
|
(add-after 'build 'validate-compiled-autoloads validate-compiled-autoloads)
|
||||||
|
(add-after 'validate-compiled-autoloads 'move-doc move-doc)))
|
||||||
|
|
||||||
(define* (emacs-build #:key inputs (phases %standard-phases)
|
(define* (emacs-build #:key inputs (phases %standard-phases)
|
||||||
#:allow-other-keys #:rest args)
|
#:allow-other-keys #:rest args)
|
||||||
|
|
|
@ -41,16 +41,22 @@ (define %emacs
|
||||||
;; The `emacs' command.
|
;; The `emacs' command.
|
||||||
(make-parameter "emacs"))
|
(make-parameter "emacs"))
|
||||||
|
|
||||||
|
(define (expr->string expr)
|
||||||
|
"Converts EXPR, an expression, into a string."
|
||||||
|
(if (string? expr)
|
||||||
|
expr
|
||||||
|
(format #f "~s" expr)))
|
||||||
|
|
||||||
(define (emacs-batch-eval expr)
|
(define (emacs-batch-eval expr)
|
||||||
"Run Emacs in batch mode, and execute the elisp code EXPR."
|
"Run Emacs in batch mode, and execute the elisp code EXPR."
|
||||||
(invoke (%emacs) "--quick" "--batch"
|
(invoke (%emacs) "--quick" "--batch"
|
||||||
(format #f "--eval=~S" expr)))
|
(string-append "--eval=" (expr->string expr))))
|
||||||
|
|
||||||
(define (emacs-batch-edit-file file expr)
|
(define (emacs-batch-edit-file file expr)
|
||||||
"Load FILE in Emacs using batch mode, and execute the elisp code EXPR."
|
"Load FILE in Emacs using batch mode, and execute the elisp code EXPR."
|
||||||
(invoke (%emacs) "--quick" "--batch"
|
(invoke (%emacs) "--quick" "--batch"
|
||||||
(string-append "--visit=" file)
|
(string-append "--visit=" file)
|
||||||
(format #f "--eval=~S" expr)))
|
(string-append "--eval=" (expr->string expr))))
|
||||||
|
|
||||||
(define (emacs-batch-disable-compilation file)
|
(define (emacs-batch-disable-compilation file)
|
||||||
(emacs-batch-edit-file file
|
(emacs-batch-edit-file file
|
||||||
|
|
Loading…
Reference in a new issue