99 lines
3.8 KiB
EmacsLisp
99 lines
3.8 KiB
EmacsLisp
;;; package-recipe-mode.el --- Minor mode for editing package recipes -*- lexical-binding:t; coding:utf-8 -*-
|
|
|
|
;; Copyright (C) 2011-2022 Donald Ephraim Curtis
|
|
;; Copyright (C) 2012-2022 Steve Purcell
|
|
;; Copyright (C) 2016-2022 Jonas Bernoulli
|
|
;; Copyright (C) 2009 Phil Hagelberg
|
|
|
|
;; Author: Donald Ephraim Curtis <dcurtis@milkbox.net>
|
|
;; Homepage: https://github.com/melpa/package-build
|
|
;; Keywords: maint tools
|
|
|
|
;; SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
;; This file is free software: you can redistribute it and/or modify
|
|
;; it under the terms of the GNU General Public License as published
|
|
;; by the Free Software Foundation, either version 3 of the License,
|
|
;; or (at your option) any later version.
|
|
;;
|
|
;; This file is distributed in the hope that it will be useful,
|
|
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
;; GNU General Public License for more details.
|
|
;;
|
|
;; You should have received a copy of the GNU General Public License
|
|
;; along with this file. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
;;; Commentary:
|
|
|
|
;; This library defines the minor mode `package-build-minor-mode',
|
|
;; which will likely be replaced with the `emacs-lisp-mode' derived
|
|
;; `package-recipe-mode' eventually.
|
|
|
|
;;; Code:
|
|
|
|
(require 'package-build)
|
|
|
|
(defvar package-build-minor-mode-map
|
|
(let ((m (make-sparse-keymap)))
|
|
(define-key m (kbd "C-c C-c") 'package-build-current-recipe)
|
|
m)
|
|
"Keymap for `package-build-minor-mode'.")
|
|
|
|
(define-minor-mode package-build-minor-mode
|
|
"Helpful functionality for building packages."
|
|
:lighter " PBuild"
|
|
(when package-build-minor-mode
|
|
(message "Use C-c C-c to build this recipe.")))
|
|
|
|
;;;###autoload
|
|
(defun package-build-create-recipe (name fetcher)
|
|
"Create a new recipe for the package named NAME using FETCHER."
|
|
(interactive
|
|
(list (read-string "Package name: ")
|
|
(intern (completing-read "Fetcher: " package-recipe--fetchers
|
|
nil t nil nil "github"))))
|
|
(let ((recipe-file (expand-file-name name package-build-recipes-dir)))
|
|
(when (file-exists-p recipe-file)
|
|
(error "Recipe already exists"))
|
|
(find-file recipe-file)
|
|
(insert (pp-to-string `(,(intern name)
|
|
:fetcher ,fetcher
|
|
,@(cl-case fetcher
|
|
(github (list :repo "USER/REPO"))
|
|
(t (list :url "SCM_URL_HERE"))))))
|
|
(emacs-lisp-mode)
|
|
(package-build-minor-mode)
|
|
(goto-char (point-min))))
|
|
|
|
;;;###autoload
|
|
(defun package-build-current-recipe ()
|
|
"Build archive for the recipe defined in the current buffer."
|
|
(interactive)
|
|
(unless (and (buffer-file-name)
|
|
(file-equal-p (file-name-directory (buffer-file-name))
|
|
package-build-recipes-dir))
|
|
(error "Buffer is not visiting a recipe"))
|
|
(when (buffer-modified-p)
|
|
(if (y-or-n-p (format "Save file %s? " buffer-file-name))
|
|
(save-buffer)
|
|
(error "Aborting")))
|
|
(check-parens)
|
|
(let ((name (file-name-nondirectory (buffer-file-name))))
|
|
(package-build-archive name t)
|
|
(let ((output-buffer-name "*package-build-result*"))
|
|
(with-output-to-temp-buffer output-buffer-name
|
|
(princ ";; Please check the following package descriptor.\n")
|
|
(princ ";; If the correct package description or dependencies are missing,\n")
|
|
(princ ";; then the source .el file is likely malformed, and should be fixed.\n")
|
|
(pp (assoc (intern name) (package-build-archive-alist))))
|
|
(with-current-buffer output-buffer-name
|
|
(emacs-lisp-mode)
|
|
(view-mode)))
|
|
(when (yes-or-no-p "Install new package? ")
|
|
(package-install-file
|
|
(package-build--artifact-file
|
|
(assq (intern name) (package-build-archive-alist)))))))
|
|
|
|
(provide 'package-recipe-mode)
|
|
;;; package-recipe-mode.el ends here
|