Compare commits
1 Commits
main
...
9a20b487c8
| Author | SHA1 | Date | |
|---|---|---|---|
| 9a20b487c8 |
3
.gitmodules
vendored
3
.gitmodules
vendored
@@ -1,3 +0,0 @@
|
|||||||
[submodule "fasm-mode"]
|
|
||||||
path = fasm-mode
|
|
||||||
url = https://github.com/GabrielFrigo4/fasm-mode
|
|
||||||
136
config.org
136
config.org
@@ -399,18 +399,6 @@
|
|||||||
(setq org-adapt-indentation t)
|
(setq org-adapt-indentation t)
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
* Multiple Cursors
|
|
||||||
I have been converted by Tsoding.
|
|
||||||
|
|
||||||
#+begin_src emacs-lisp
|
|
||||||
(use-package multiple-cursors
|
|
||||||
:config
|
|
||||||
(global-set-key (kbd "C-S-c C-S-c") 'mc/edit-lines)
|
|
||||||
(global-set-key (kbd "C->") 'mc/mark-next-like-this)
|
|
||||||
(global-set-key (kbd "C-<") 'mc/mark-previous-like-this)
|
|
||||||
(global-set-key (kbd "C-c C-<") 'mc/mark-all-like-this))
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
* Language Integrations
|
* Language Integrations
|
||||||
** Generic
|
** Generic
|
||||||
Generally, 8-character-wide tabs are not my thing.
|
Generally, 8-character-wide tabs are not my thing.
|
||||||
@@ -553,6 +541,12 @@
|
|||||||
(use-package rust-mode)
|
(use-package rust-mode)
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
|
Then =rust-analyzer= via LSP does the rest :)
|
||||||
|
|
||||||
|
#+begin_src emacs-lisp
|
||||||
|
(add-hook 'rust-mode-hook #'lsp-deferred)
|
||||||
|
#+end_src
|
||||||
|
|
||||||
** Lisps
|
** Lisps
|
||||||
*** Common Lisp
|
*** Common Lisp
|
||||||
Use SLIME and Quicklisp for Common Lisp (SBCL).
|
Use SLIME and Quicklisp for Common Lisp (SBCL).
|
||||||
@@ -797,6 +791,13 @@
|
|||||||
(use-package crontab-mode)
|
(use-package crontab-mode)
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
|
** Python
|
||||||
|
Going to use LSP for Python:
|
||||||
|
|
||||||
|
#+begin_src emacs-lisp
|
||||||
|
(add-hook 'python-mode-hook #'lsp-deferred)
|
||||||
|
#+end_src
|
||||||
|
|
||||||
** Ada
|
** Ada
|
||||||
*** Old ada-mode
|
*** Old ada-mode
|
||||||
Unfortunately, the =ada-mode= on ELPA is hot garbage. It requires
|
Unfortunately, the =ada-mode= on ELPA is hot garbage. It requires
|
||||||
@@ -1048,55 +1049,6 @@
|
|||||||
(add-hook 'before-save-hook 'gofmt-before-save)))
|
(add-hook 'before-save-hook 'gofmt-before-save)))
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
** Forth
|
|
||||||
#+begin_src emacs-lisp
|
|
||||||
(use-package forth-mode)
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
** Fasm
|
|
||||||
The =fasm-mode= package wasn't on MELPA or ELPA, so I've instead
|
|
||||||
added it as a submodule of this repo. We therefore need to add it
|
|
||||||
to the load path:
|
|
||||||
|
|
||||||
#+begin_src emacs-lisp
|
|
||||||
(let* ((home (getenv "HOME"))
|
|
||||||
(path (concat home "/.emacs.d/fasm-mode")))
|
|
||||||
(add-to-list 'load-path path))
|
|
||||||
(autoload 'fasm-mode "fasm-mode")
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
And then use it for =.asm= files:
|
|
||||||
|
|
||||||
#+begin_src emacs-lisp
|
|
||||||
(add-to-list 'auto-mode-alist '("\\.asm\\'" . fasm-mode))
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
** OCaml
|
|
||||||
For some reason the OCaml support package is called =tuareg=??
|
|
||||||
|
|
||||||
#+begin_src emacs-lisp
|
|
||||||
(use-package tuareg)
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
OCaml also has its own build system, Dune. There's also a mode for
|
|
||||||
Dune's files:
|
|
||||||
|
|
||||||
#+begin_src emacs-lisp
|
|
||||||
(use-package dune)
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
** Vala
|
|
||||||
=vala-mode= provides everything I need:
|
|
||||||
|
|
||||||
#+begin_src emacs-lisp
|
|
||||||
(use-package vala-mode)
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
** ASN.1
|
|
||||||
#+begin_src emacs-lisp
|
|
||||||
(use-package asn1-mode)
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
* Tool Integrations
|
* Tool Integrations
|
||||||
** Git
|
** Git
|
||||||
=magit= is truly a wonderful creation! Add keybinding for
|
=magit= is truly a wonderful creation! Add keybinding for
|
||||||
@@ -1137,16 +1089,6 @@
|
|||||||
leave it at that for now as I'm not sure precisely what behaviour
|
leave it at that for now as I'm not sure precisely what behaviour
|
||||||
I'd want.
|
I'd want.
|
||||||
|
|
||||||
Magit also doesn't seem to provide a means of specifying the =-S=
|
|
||||||
flag for commit signing (only =--gpg-sign==) so I need to add that:
|
|
||||||
|
|
||||||
#+begin_src emacs-lisp
|
|
||||||
(eval-after-load 'magit
|
|
||||||
'(progn
|
|
||||||
(transient-append-suffix 'magit-commit "-C"
|
|
||||||
'("-S" "Sign commit" "-S"))))
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
** Docker
|
** Docker
|
||||||
I use docker quite a lot, unfortunately, so it's nice to be able to
|
I use docker quite a lot, unfortunately, so it's nice to be able to
|
||||||
spawn containers etc from Emacs. The =docker= package provides a
|
spawn containers etc from Emacs. The =docker= package provides a
|
||||||
@@ -1243,7 +1185,7 @@
|
|||||||
(setq Man-notify-method 'pushy)
|
(setq Man-notify-method 'pushy)
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
** Script-Fu
|
** Script-Fu Mode
|
||||||
GIMP has a scheme-based language -- Script-Fu -- built into it that
|
GIMP has a scheme-based language -- Script-Fu -- built into it that
|
||||||
you can use to script things (based). Sadly, the built-in console
|
you can use to script things (based). Sadly, the built-in console
|
||||||
is rather lackluster as a coding environment. Happily, there /is/
|
is rather lackluster as a coding environment. Happily, there /is/
|
||||||
@@ -1253,12 +1195,12 @@
|
|||||||
|
|
||||||
It's things like this that make me really glad I switched to Emacs
|
It's things like this that make me really glad I switched to Emacs
|
||||||
because this is ridiculously cool. By my definition of "cool"
|
because this is ridiculously cool. By my definition of "cool"
|
||||||
anyway (what can I say, I'm a massive nerd).
|
anyway -- what can I say, I'm a massive nerd.
|
||||||
|
|
||||||
I should probably extract this and make a standalone package out of
|
I should probably extract this and make a standalone package out of
|
||||||
it and stick it on Melpa at some point.
|
it and stick it on Melpa at some point.
|
||||||
|
|
||||||
*** REPL
|
*** REPL Mode
|
||||||
The Script-Fu server request format is very simple:
|
The Script-Fu server request format is very simple:
|
||||||
|
|
||||||
| Bytes | Description |
|
| Bytes | Description |
|
||||||
@@ -1313,7 +1255,7 @@
|
|||||||
|
|
||||||
The response format is similarly simple:
|
The response format is similarly simple:
|
||||||
|
|
||||||
| Bytes | Description |
|
| Bytes | Content |
|
||||||
|-------+-----------------------------------------|
|
|-------+-----------------------------------------|
|
||||||
| 0 | 'G' magic byte (47h) |
|
| 0 | 'G' magic byte (47h) |
|
||||||
| 1 | Status code -- 0 on success, 1 on error |
|
| 1 | Status code -- 0 on success, 1 on error |
|
||||||
@@ -1370,8 +1312,8 @@
|
|||||||
(interactive)
|
(interactive)
|
||||||
(let ((buffer (get-buffer-create "*Script-Fu REPL*")))
|
(let ((buffer (get-buffer-create "*Script-Fu REPL*")))
|
||||||
(when (not (comint-check-proc buffer))
|
(when (not (comint-check-proc buffer))
|
||||||
(make-comint-in-buffer "Script-Fu REPL"
|
(make-comint-in-buffer "Script-Fu REPL" buffer
|
||||||
buffer script-fu-repl-server)
|
script-fu-repl-server)
|
||||||
(with-current-buffer buffer (script-fu-repl-mode)))
|
(with-current-buffer buffer (script-fu-repl-mode)))
|
||||||
(pop-to-buffer buffer '((display-buffer-in-direction)
|
(pop-to-buffer buffer '((display-buffer-in-direction)
|
||||||
(direction . below)
|
(direction . below)
|
||||||
@@ -1379,7 +1321,7 @@
|
|||||||
buffer))
|
buffer))
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
*** Code Editing
|
*** Code Editing Mode
|
||||||
With the client stuff done, we can define the code editing mode:
|
With the client stuff done, we can define the code editing mode:
|
||||||
|
|
||||||
#+begin_src emacs-lisp
|
#+begin_src emacs-lisp
|
||||||
@@ -1387,9 +1329,7 @@
|
|||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
Now to define something to send an expression or region to the
|
Now to define something to send an expression or region to the
|
||||||
REPL. Since =script-fu-repl= returns the buffer we can use that
|
REPL:
|
||||||
to transparently start a REPL or get the existing one if one's
|
|
||||||
already running.
|
|
||||||
|
|
||||||
#+begin_src emacs-lisp
|
#+begin_src emacs-lisp
|
||||||
(defun script-fu-mode-send-region-or-sexp ()
|
(defun script-fu-mode-send-region-or-sexp ()
|
||||||
@@ -1400,19 +1340,21 @@
|
|||||||
(buffer-substring-no-properties start end))
|
(buffer-substring-no-properties start end))
|
||||||
(thing-at-point 'sexp t))))
|
(thing-at-point 'sexp t))))
|
||||||
(if (not code) (message "No code to send.")
|
(if (not code) (message "No code to send.")
|
||||||
(let* ((repl-proc (get-buffer-process (script-fu-repl))))
|
(let* ((repl-buffer (script-fu-repl))
|
||||||
|
(repl-proc (get-buffer-process repl-buffer)))
|
||||||
(script-fu-repl-send repl-proc code)))))
|
(script-fu-repl-send repl-proc code)))))
|
||||||
|
|
||||||
(define-key script-fu-mode-map (kbd "C-c C-c")
|
(define-key script-fu-mode-map (kbd "C-c C-c")
|
||||||
'script-fu-mode-send-region-or-sexp)
|
'script-fu-mode-send-region-or-sexp)
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
And finally, a similar thing for the whole file:
|
And finally a similar thing for the whole file:
|
||||||
|
|
||||||
#+begin_src emacs-lisp
|
#+begin_src emacs-lisp
|
||||||
(defun script-fu-mode-send-file ()
|
(defun script-fu-mode-send-file ()
|
||||||
(interactive)
|
(interactive)
|
||||||
(let* ((repl-proc (get-buffer-process (script-fu-repl)))
|
(let* ((repl-buffer (script-fu-repl))
|
||||||
|
(repl-proc (get-buffer-process repl-buffer))
|
||||||
(buffer-contents
|
(buffer-contents
|
||||||
(buffer-substring-no-properties (point-min)
|
(buffer-substring-no-properties (point-min)
|
||||||
(point-max))))
|
(point-max))))
|
||||||
@@ -1423,23 +1365,6 @@
|
|||||||
|
|
||||||
I think that's all I need for now!
|
I think that's all I need for now!
|
||||||
|
|
||||||
** Maxima
|
|
||||||
Maxima is an absolutely amazing tool for mathematical symbolic
|
|
||||||
processing. And to make matters better, it's lispy. It's giving
|
|
||||||
old school expert system but make it actually astonishingly useful
|
|
||||||
type shit.
|
|
||||||
|
|
||||||
The =maxima= package provides good Emacs integration, with syntax
|
|
||||||
highlighting for the DSL and a nice inferior process mode for the
|
|
||||||
interpreter. Files for the DSL conventionally have the ".mac"
|
|
||||||
extension, so want to open those files in =maxima-mode=.
|
|
||||||
|
|
||||||
#+begin_src emacs-lisp
|
|
||||||
(use-package maxima
|
|
||||||
:mode ("\\.mac\\'" . maxima-mode)
|
|
||||||
:interpreter ("maxima" . maxima-mode))
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
* Backup and Autosave
|
* Backup and Autosave
|
||||||
** Keep $PWD Tidy
|
** Keep $PWD Tidy
|
||||||
Emacs' default behaviour of dumping temporary files in the current
|
Emacs' default behaviour of dumping temporary files in the current
|
||||||
@@ -1504,15 +1429,6 @@
|
|||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
* Misc
|
* Misc
|
||||||
** Global key for [[help:align-regexp][align-regexp]]
|
|
||||||
I didn't know it was a thing but now that I do, I need a
|
|
||||||
keybinding. Hopefully it doesn't conflict with too many things
|
|
||||||
haha.
|
|
||||||
|
|
||||||
#+begin_src emacs-lisp
|
|
||||||
(global-set-key (kbd "C-c a") 'align-regexp)
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
** God mode
|
** God mode
|
||||||
God mode essentially makes Emacs a bit more VI-like by introducing
|
God mode essentially makes Emacs a bit more VI-like by introducing
|
||||||
a mode where modifier keys are implicitly held down, thereby
|
a mode where modifier keys are implicitly held down, thereby
|
||||||
|
|||||||
Submodule fasm-mode deleted from d6578064bc
Reference in New Issue
Block a user