My Emacs Configuration written with a literate programming style
Find a file
Howard Abrams b9e1d96307 Reformat the org structure
This just brings most headers up a level.
2024-05-07 14:36:54 -07:00
data
elisp Reorganizing my Publishing Approach 2023-12-20 19:54:30 -08:00
screenshots Screenshot for my Org Mode rendering 2023-12-22 11:50:47 -08:00
snippets Fix a few journaling bugs 2024-02-27 20:54:41 -08:00
support Moved the Git and other Apps from Config 2023-12-21 21:22:16 -08:00
templates Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
.gitignore Fix bugs with the web site publishing 2024-01-18 20:52:06 -08:00
beep-notify.wav
bootstrap.org More Element/Matrix and less IRC 2024-03-22 13:43:12 -07:00
CONTRIBUTING.md Add CONTRIBUTING and a Code of Conduct 2022-01-10 22:24:49 +00:00
ha-agendas.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-applications.org Fix dired issues 2024-05-07 14:36:29 -07:00
ha-aux-apps.org More Element/Matrix and less IRC 2024-03-22 13:43:12 -07:00
ha-capturing-notes.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-config.org Fix dired issues 2024-05-07 14:36:29 -07:00
ha-dashboard.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-data.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-display.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-email.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-eshell.org Made Eshell banner more reliable 2024-04-25 14:03:44 -07:00
ha-evil.org Key chords don't work reliably with my new keyboard 2024-04-25 13:37:50 -07:00
ha-feed-reader.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-general.org Reformat the org structure 2024-05-07 14:36:54 -07:00
ha-irc.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-org-clipboard.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-org-graphviz-example.png Minor copyright touchups on my snippets. 2022-03-09 17:14:21 -08:00
ha-org-journaling.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-org-plantuml-example.png Get PlantUML back to working in org mode documents 2022-04-11 20:37:15 -07:00
ha-org-publishing.org Fix up HTML export and use some Jack HTML 2024-04-25 13:37:27 -07:00
ha-org-sprint.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-org-word-processor.org Let's see if this fixes my ligature problem on Linux 2024-03-27 17:46:15 -07:00
ha-org.org Fix a bug in how I use jack-html 2024-04-29 15:35:53 -07:00
ha-passwords.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-programming-clojure.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-programming-elisp.org Better Lisp Editing with major-mode-hydra 2024-03-22 13:44:17 -07:00
ha-programming-haskell.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-programming-ocaml.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-programming-python.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-programming-ruby.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-programming-rust.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-programming-scheme.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
ha-programming.org Migrating from direnv to mise 2024-04-29 17:30:45 -07:00
ha-remoting.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
initialize Fix a couple of bugs for 29.1 2023-08-04 08:29:54 -07:00
LICENSE
README-Linux.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
README-MacOS.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00
README.org Decided I like lowercase headers better 2024-03-06 20:02:25 -08:00

My Emacs Configuration

Introduction

Ive crafted my Emacs configuration, I cheekily call hamacs, in a literate programming model, heavily inspired by my recent journey into Henrik Lissner's Doom Emacs and Spacemacs. While I used both extensively, I decided I would roll my own as Emacs people like myself, tend to be control freaks (at least a little bit).

The advantage to rolling yer own is I tend to use what I add, leading to less bloat. In reality, this is more fun.

Using literate programming for my Emacs configuration gives me an easy way to share my code. Feel free to steal whatever you find interesting, as sharing makes our community great. Notice that functions and features I have written begin with ha-, but everything else is either stock Emacs or a package I download using straight (see bootstrap for the details) and configure with use-package (see either this introduction or this wiki page for those details)… meaning most blocks of code should work on its own.

Ive separated my configuration into chapters around particular subjects, applications and programming languages. This feature allows you, dear reader, to jump our to items of interest, but allows me to selectively load individual chapters. For instance, if Im not doing much with Ruby at work, I can remove that chapter from the list in my bootstrap. I also dont load my UI configuration when I am using the Terminal (doesnt happen much, actually).

Hit me up with questions on Mastodon: @howard@emacs.ch.

If you want to try the entire process, after installing Emacs (see my instructions for both MacOS and Linux), clone this repo with:

  git clone https://github.com/howardabrams/hamacs

And then, run:

./initialize

To create ~/.emacs.d/init.el which starts the process loading the files. Heres how my Emacs looks when it starts:

/git/howard/hamacs/media/commit/b9e1d9630735f3bb212db9e0fc3c52cb04467ef0/screenshots/dashboard-small.png

Core Configuration

Bootstrap
configures straight and loads basic libraries the rest of the code depends on. It then loads the following files in order.
Configuration
contains most of my configuration, setting up my sequence key menus, evil, etc.
Evilness
configuration for using VI, er, vim keybindings in Emacs.
GUI Display
sets up the visual aspects of an Emacs GUI, including themes and fonts.
Dashboard
sets up initial window layout of the main project with a dashboard.
Data
functions for dealing with a buffer-full of data.

Org Mode Configuration

Initial Org Configuration
configures the basics for org-mode formatted files. Specific features come from their own files.
Word Processing
attempts to make Org files visually look like a word processor, including turning off the colors for headers, and instead increasing their size.
Clipboard
automatically converting HTML from a clipboard into Org-formatted content.
Journaling
for writing journal entries and tasks.
Publishing
code for publishing my website, www.howardism.org.
Sprint Notes
functions for working with the my Org-focused sprint file.
Agendas
attempts to "supe-up" my task list.
Capturing Notes
my engineering notebook.

Terminal Configuration

If you know me, I appreciate the light-weight nature of Eshell (see this talk at EmacsConf 2022), but Eshell doesnt work that well with some of my remote work.

Eshell
customization and enhancement to the Emacs shell.
Remote Access
my interface to systems using SSH and Vterm.

Programming Configuration

While Im a language polyglot, I often focus on one or two languages at a time, but continue to keep my configuration for those languages around. Im attempting to convert over to LSP (with varying degrees of success).

General Programming
configuration for all programming languages, or at least, the simple ones.
Emacs Lisp
additions to Emacs Lisp programming.
Python
configuration for working with Python and LSP.
Scheme
configuration for Guile and Racket.
Clojure
configuration for Clojure.
Ruby
configuration for Ruby.

Miscellanea

Applications
optional applications, like Twitter and Telegram.
Email
reading email using notmuch in a Hey fashion.
RSS Reader
configuration of elfeed as well as my RSS feeds.
IRC
connection to IRC servers using rcirc and bitlbee.
Passwords
code for generating passwords.

Summary

The elisp directory contains non-literate code.

Other functions and files come from essays written on my blog. To help with this synchronization, I created a support/final-initialize.el file, but that shouldnt be too interesting to others.

🤓