diff options
author | odave <aryadevchavali1@gmail.com> | 2020-03-17 17:03:10 +0000 |
---|---|---|
committer | odave <aryadevchavali1@gmail.com> | 2020-03-17 17:03:10 +0000 |
commit | 9ced0a3677eb55120e71a4c1bf652ea24aadf272 (patch) | |
tree | 7cfc590965f180dce756dcc8112540bda0d3ebef /doom.d/modules/private/gentemplate | |
parent | 110cf1b5f31552b2ef7cfb42b11acf3d31773a9e (diff) | |
download | dotfiles-9ced0a3677eb55120e71a4c1bf652ea24aadf272.tar.gz dotfiles-9ced0a3677eb55120e71a4c1bf652ea24aadf272.tar.bz2 dotfiles-9ced0a3677eb55120e71a4c1bf652ea24aadf272.zip |
~gentemplate.org -> gentemplate module
Gentemplate is one of those things that just makes sense as a module.
Thus, converted it. I may convert a few more org files into full blown modules.
Diffstat (limited to 'doom.d/modules/private/gentemplate')
-rw-r--r-- | doom.d/modules/private/gentemplate/README.org | 21 | ||||
-rw-r--r-- | doom.d/modules/private/gentemplate/config.el | 32 |
2 files changed, 53 insertions, 0 deletions
diff --git a/doom.d/modules/private/gentemplate/README.org b/doom.d/modules/private/gentemplate/README.org new file mode 100644 index 0000000..86e7463 --- /dev/null +++ b/doom.d/modules/private/gentemplate/README.org @@ -0,0 +1,21 @@ +#+TITLE: private/gentemplate +#+DATE: March 17, 2020 +#+SINCE: {replace with next tagged release version} +#+STARTUP: inlineimages nofold + +* Description +This module allows users to clone templates from my Github to specific machines. +These templates allow for quick and easy setup for languages or frameworks where +this sort of thing isn't very nice to do (for example C++). + +This module is used through the main function =+gentemplate/generate-template=. +It will ask what template you want to use then where to put it, finally doing +the necessary work to get you that template. You may mutate the variables +=+gentemplate/template-list= and =+gentemplate/profile-url= to customise your +templates. +* Prerequisites +- git +* Requirements +- ivy +- magit +- cl diff --git a/doom.d/modules/private/gentemplate/config.el b/doom.d/modules/private/gentemplate/config.el new file mode 100644 index 0000000..ae5b973 --- /dev/null +++ b/doom.d/modules/private/gentemplate/config.el @@ -0,0 +1,32 @@ +;;; private/gentemplate/config.el -*- lexical-binding: t; -*- + +(require 'cl) + +(setq +gentemplate/template-list (list "CTemplate" "CPPTemplate" "PythonTemplate" "NodeTemplate" "ArduinoTemplate" "JavaTemplate")) +(setq +gentemplate/profile-url "https://github.com/oreodave/") + +(defun +gentemplate/offline () + (eq (list-length (network-interface-list)) 1)) + +(after! magit-clone + (defun +gentemplate/download-template (template-name dest) + "Download a given template via its `template-name' to the `dest' folder" + (magit-clone-regular (concat +gentemplate/profile-url template-name) dest nil))) + +(defun +gentemplate/copy-template (template-name dest) + "Copy a template project via it's `template-name' to a folder called `dest'" + (copy-directory (expand-file-name (concat "~/Code/Templates/" template-name)) dest)) + +(after! (ivy magit-clone) + (defun +gentemplate/generate-template () + (interactive) + (ivy-read + "Enter template: " + +gentemplate/template-list + :action + (lambda (template-name) + (let ((dir (read-directory-name "Enter directory to download to: ")) + (offline (+gentemplate/offline))) + (if offline + (+gentemplate/copy-template template-name dir) + (+gentemplate/download-template template-name dir))))))) |