Inspired by the magic medusa hydra, by Andy Drop.
;;; uru.el --- a simple package -*- lexical-binding: t; -*-
;; Copyright (C) 2021 Jeet Ray
;; Author: Jeet Ray <aiern@protonmail.com>
;; Keywords: lisp
;; Version: 0.0.1
;; This program 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 program 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 program. If not, see <http://www.gnu.org/licenses/>.
;;; Commentary:
;; Put a description of the package here
;;; Code:
(require 'dash)
(defvar meq/var/ua-major-mode-deinos nil)
;;;###autoload
(defmacro defuru* (ua major-mode derived name &rest args)
(push `(,ua ,major-mode ,derived ,(meq/inconcat (symbol-name name) "/body")) meq/var/ua-major-mode-deinos)
`(defdeino ,name ,@args))
;;;###autoload
(defmacro defuru (major-mode derived name &rest args) `(defuru* nil ,major-mode ,derived ,name ,@args))
;;;###autoload
(defmacro defurua (ua major-mode name &rest args) `(defuru* ,ua ,major-mode nil ,name ,@args))
(defun uru* (uru-list) (if (or (caddr uru-list) current-prefix-arg)
(when (derived-mode-p (cadr uru-list)) (funcall (cadddr uru-list)))
(when (equal major-mode (cadr uru-list)) (funcall (cadddr uru-list)))))
;;;###autoload
(defun uru (&optional ua) (interactive "p")
(mapc #'uru* (if current-prefix-arg
(--filter (= (car it) ua) (--remove (booleanp (car it)) meq/var/ua-major-mode-deinos))
(--filter (booleanp (car it)) meq/var/ua-major-mode-deinos)))
(unless deino-curr-map (message "Sorry! No uru deinos were created for this major-mode!")))
(with-eval-after-load 'use-package
;; Adapted From: https://github.com/jwiegley/use-package/blob/master/use-package-core.el#L1153
;;;###autoload
(defalias 'use-package-normalize/:uru 'use-package-normalize-forms)
;; Adapted From: https://gitlab.com/to1ne/use-package-hydra/-/blob/master/use-package-hydra.el#L79
;;;###autoload
(defun use-package-handler/:uru (name keyword args rest state)
(use-package-concat (mapcar #'(lambda (def) `(defuru ,@def)) args)
(use-package-process-keywords name rest state)))
(add-to-list 'use-package-keywords :uru t)
;;;###autoload
(defalias 'use-package-normalize/:urua 'use-package-normalize-forms)
;;;###autoload
(defun use-package-handler/:urua (name keyword args rest state)
(use-package-concat (mapcar #'(lambda (def) `(defurua ,@def)) args)
(use-package-process-keywords name rest state)))
(add-to-list 'use-package-keywords :urua t))
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(require 'meq)
(defvar meq/var/ua-minor-mode-deinos nil)
;;;###autoload
(defmacro defminoru* (ua minor-mode name &rest args)
(push `(,ua ,minor-mode ,(meq/inconcat (symbol-name name) "/body")) meq/var/ua-minor-mode-deinos)
`(defdeino ,name ,@args))
;;;###autoload
(defmacro defminoru (minor-mode name &rest args) `(defminoru* nil ,minor-mode ,name ,@args))
;;;###autoload
(defmacro defminorua (ua minor-mode name &rest args) `(defminoru* ,ua ,minor-mode ,name ,@args))
(defun minoru* (minoru-list) (when (eval `(meq/fbatp ,(cadr minoru-list))) (funcall (caddr minoru-list))))
;;;###autoload
(defun minoru (&optional ua) (interactive "p")
(mapc #'minoru* (if current-prefix-arg
(--filter (= (car it) ua) (--remove (booleanp (car it)) meq/var/ua-minor-mode-deinos))
(--filter (booleanp (car it)) meq/var/ua-minor-mode-deinos)))
(unless deino-curr-map (message "Sorry! No uru deinos were created for this minor-mode!")))
(with-eval-after-load 'use-package
;;;###autoload
(defalias 'use-package-normalize/:minoru 'use-package-normalize-forms)
;;;###autoload
(defun use-package-handler/:minoru (name keyword args rest state)
(use-package-concat (mapcar #'(lambda (def) `(defminoru ,@def)) args)
(use-package-process-keywords name rest state)))
(add-to-list 'use-package-keywords :minoru t)
;;;###autoload
(defalias 'use-package-normalize/:minorua 'use-package-normalize-forms)
;;;###autoload
(defun use-package-handler/:minorua (name keyword args rest state)
(use-package-concat (mapcar #'(lambda (def) `(defminorua ,@def)) args)
(use-package-process-keywords name rest state)))
(add-to-list 'use-package-keywords :minorua t))
(provide 'uru)
;;; uru.el ends here