Skip to content

syvlorg/prime

Repository files navigation

prime.el

;;; prime.el --- a simple package                     -*- lexical-binding: t; -*-

;; Copyright (C) 2021  Jeet Ray

;; Author: Jeet Ray <[email protected]>
;; 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 'alloy)
(require 'deino)
(require 's)

(defvar primus-key ",")
(eval `(defdeino primus (:color blue) "j" ("`" nil "cancel")))
(eval `(alloy-def :keymaps demon-run (alloy-chord ,(s-repeat 2 primus-key)) 'primus/body))

(defun prime--replace-spaces (str) (s-replace " " "/" str))
(defun prime--construct-name (str) (prime--replace-spaces (concat "prime/" str)))

(defmacro prime* (parent first-call key func &optional name* &rest args)
    (let* ((ds (deino--create-dataset
                (if (stringp name*) name* (if (symbolp func) (symbol-name func) nil))
                key
                parent
                func
                #'prime--construct-name+))

            (next-key (s-join " " (cdr (d--g ds :keys))))
            (next-deino-body (if (d--g ds :two-key) func (meq/inconcat (d--g ds :next-name) "/body")))
            (next-deino-settings (when (d--g ds :two-key) args)))
        (when first-call
            (unless (d--g ds :current-body-plus)
                (eval `(defdeino ,(intern (d--g ds :current-name)) (:color blue) nil ("`" nil "cancel"))))
            (eval `(defdeino+ primus nil (,(d--g ds :carkeys)
                                          ,(d--g ds :current-body)
                                          ,(d--g ds :current-name)))))
        (unless (d--g ds :one-key)
            (eval `(prime* ,(d--g ds :current-parent) nil ,next-key ,func ,name* ,@next-deino-settings))
            `(,(meq/inconcat "defdeino" (if (d--g ds :current-body-plus) "+" ""))
                ,(intern (d--g ds :current-name))
                ,@(if (d--g ds :current-body-plus)
                    (list nil)
                    `((:color blue) nil
                        ("`" nil "cancel")
                        ("DEL" ,(if first-call #'primus/body (meq/inconcat (prime--construct-name parent) "/body")) "back")))
                (,(d--g ds :spare-keys) ,next-deino-body ,(d--g ds :next-name) ,@next-deino-settings)))))

(defun prime--construct-name+ (keys &optional delimiter) (deino--construct-name+ keys #'prime--construct-name delimiter))

;;;###autoload
(defmacro prime (key func &optional name &rest args) `(prime* nil t ,key ,func ,name ,@args))

;;;###autoload
(defun prime+ (&rest args) (eval `(defdeino+ primus ,@args)))

;;;###autoload
(defun primer (key &rest args)
    (add-hook
        'window-setup-hook
        #'(lambda nil (eval `(defdeino+ primus nil (,key ,(meq/inconcat (prime--construct-name+ key) "/body") ,@args))))))

;;;###autoload
(defun primer+ (key &optional delimiter &rest args) (deino--nested-rename key #'prime--construct-name+ args))

;;;###autoload
(defun primed (key description &optional delimiter) (deino--nested-describe key #'prime--construct-name+ description delimiter))

(with-eval-after-load 'use-package
  ;; Primarily adapted from https://gitlab.com/to1ne/use-package-hydra/-/blob/master/use-package-hydra.el

  ;;;###autoload
  (defalias 'use-package-normalize/:prime 'use-package-normalize-forms)

  ;;;###autoload
  (defun use-package-handler/:prime (name keyword args rest state)
    "Generate prime with NAME for `:prime' KEYWORD.
  ARGS, REST, and STATE are prepared by `use-package-normalize/:prime'."
    (use-package-concat
    (mapcar #'(lambda (def) `(prime ,@def)) args)
    (use-package-process-keywords name rest state)))

  (add-to-list 'use-package-keywords :prime t)

  ;;;###autoload
  (defalias 'use-package-normalize/:prime+ 'use-package-normalize-forms)

  ;;;###autoload
  (defun use-package-handler/:prime+ (name keyword args rest state)
    "Generate prime+ with NAME for `:prime+' KEYWORD.
  ARGS, REST, and STATE are prepared by `use-package-normalize/:prime+'."
    (use-package-concat
    (mapcar #'(lambda (def) `(prime+ ,@def)) args)
    (use-package-process-keywords name rest state)))

  (add-to-list 'use-package-keywords :prime+ t)

  ;;;###autoload
  (defalias 'use-package-normalize/:primer 'use-package-normalize-forms)

  ;;;###autoload
  (defun use-package-handler/:primer (name keyword args rest state)
    "Generate primer with NAME for `:primer' KEYWORD.
  ARGS, REST, and STATE are prepared by `use-package-normalize/:primer'."
    (use-package-concat
    (mapcar #'(lambda (def) `(primer ,@def)) args)
    (use-package-process-keywords name rest state)))

  (add-to-list 'use-package-keywords :primer t)

  ;;;###autoload
  (defalias 'use-package-normalize/:primed 'use-package-normalize-forms)

  ;;;###autoload
  (defun use-package-handler/:primed (name keyword args rest state)
    "Generate primed with NAME for `:primed' KEYWORD.
  ARGS, REST, and STATE are prepared by `use-package-normalize/:primed'."
    (use-package-concat
    (mapcar #'(lambda (def) `(primed ,@def)) args)
    (use-package-process-keywords name rest state)))

  (add-to-list 'use-package-keywords :primed t)

  ;;;###autoload
  (defalias 'use-package-normalize/:primer+ 'use-package-normalize-forms)

  ;;;###autoload
  (defun use-package-handler/:primer+ (name keyword args rest state)
    "Generate primer+ with NAME for `:primer+' KEYWORD.
  ARGS, REST, and STATE are prepared by `use-package-normalize/:primer+'."
    (use-package-concat
    (mapcar #'(lambda (def) `(primer+ ,@def)) args)
    (use-package-process-keywords name rest state)))

  (add-to-list 'use-package-keywords :primer+ t))

(provide 'prime)
;;; prime.el ends here

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published