+
Skip to content

syvlorg/uru

Repository files navigation

uru.el

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

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 2

  •  
  •  
点击 这是indexloc提供的php浏览器服务,不要输入任何密码和下载