UP | HOME

dotDOOM

Table of Contents

This looks better on the website.

1. What?

This is actually a doom-emacs private module. I was feeling rather whimsical.

1.1. Configuration

This is documented here.

1.2. Packages

I also document the packages I use in a separately here.

2. Why?

My Dotfiles repo, managed with the brilliant dotgit, was getting rather overwhelmed with emacs commits. Also managing snippets with dotgit was not exactly pleasant, since each symlink needed to be listed in the filelist.

2.1. Who?

I’m Rohit Goswami (or HaoZeke, or rg0swami), and well, if you need to know more about why you might want to use my work, check my site, or any of the other sites I manage, or even my publications or my code.

3. How?

Well it just goes where doom expects config files.

# Honestly, this should be $HOME/.config
git clone git@github.com:HaoZeke/dotDoom $XDG_CONFIG_DIR/doom

4. Config

Since the config.el needs no page of its own, it is simply included below:

;;; init.el -*- lexical-binding: t; -*-
;; This file controls what Doom modules are enabled and what order they load in.
;; Remember to run 'doom sync' after modifying it!

;; NOTE Press 'SPC h d h' (or 'C-h d h' for non-vim users) to access Doom's
;;      documentation. There you'll find information about all of Doom's modules
;;      and what flags they support.

;; NOTE Move your cursor over a module's name (or its flags) and press 'K' (or
;;      'C-c g k' for non-vim users) to view its documentation. This works on
;;      flags as well (those symbols that start with a plus).
;;
;;      Alternatively, press 'gd' (or 'C-c g d') on a module to browse its
;;      directory (for easy access to its source code).

;; Copy me to ~/.doom.d/init.el or ~/.config/doom/init.el, then edit me!

(doom! :input
       ;;chinese
       ;;japanese

       :completion
       (company          ; the ultimate code completion backend
        +childframe)      ; a better UI for company (Emacs 26+)
      ;; (helm             ; the *other* search engine for love and life
      ;;   +childframe      ; a better UI for helm (Emacs 26+)
      ;;   +fuzzy)          ; enable fuzzy search backend for helm
      ;; ido               ; the other *other* search engine...
       (ivy              ; a search engine for love and life
        +childframe      ; a better UI for ivy (Emacs 26+)
        +prescient       ; better? filtering and sorting?
        +icons           ; enables file icons
        +fuzzy)          ; enable fuzzy search backend for ivy

      :ui
      deft              ; notational velocity for Emacs
      doom              ; what makes DOOM look the way it does
      doom-dashboard    ; a nifty splash screen for Emacs
      doom-quit         ; DOOM quit-message prompts when you quit Emacs
      (emoji +unicode)  ; 🙂
      fill-column       ; a `fill-column' indicator
      hl-todo           ; highlight TODO/FIXME/NOTE tags
      hydra
      ;; indent-guides  ; highlighted indent columns
      ;;ligatures       ; ligatures and symbols to make your code pretty again
      ;;minimap           ; show a map of the code on the side
      modeline          ; snazzy, Atom-inspired modeline, plus API
      nav-flash         ; blink the current line after jumping
      ;; neotree        ; a project drawer, like NERDTree for vim
      ophints           ; highlight the region an operation acts on
      (popup            ; tame sudden yet inevitable temporary windows
        +all            ; catch all popups that start with an asterix
        +defaults)      ; default popup rules
      ligatures         ; replace bits of code with prettymbols
      ;; tabs           ; a tab bar for Emacs
      treemacs          ; a project drawer, like neotree but cooler
      unicode           ; extended unicode support for various languages
      vc-gutter         ; vcs diff in the fringe
      vi-tilde-fringe   ; fringe tildes to mark beyond EOB
      window-select     ; visually switch windows
      workspaces        ; tab emulation, persistence & separate workspaces
      ;; zen              ; distraction-free coding or writing

      :editor
      (evil +everywhere) ; come to the dark side, we have cookies
      file-templates     ; auto-snippets for empty files
      fold               ; (nigh) universal code folding
      format             ; Automated prettiness (no more +onsave)
      ;; god             ; run Emacs commands without modifier keys
      ;; lispy           ; vim for lisp, for people who dont like vim
      multiple-cursors   ; editing in many places at once
      ;; objed           ; text object editing for the innocent
      ;; parinfer        ; turn lisp into python, sort of
      rotate-text        ; cycle region at point between text candidates
      snippets           ; my elves. They type so I don't have to
      word-wrap       ; soft wrapping with language aware indent


       :emacs
       (dired            ; making dired pretty [functional]
        +ranger           ; bringing the goodness of ranger to dired
        +icons)            ; colorful icons for dired-mode
       electric          ; smarter, keyword-based electric-indent
       ibuffer           ; interactive buffer management
       (undo             ; persistent, smarter undo for your inevitable mistakes
        +tree)           ; bit more unstable, but has pretty visuals
       vc                ; version-control and Emacs, sitting in a tree

       :term
       ;; eshell            ; a consistent, cross-platform shell (WIP)
       ;; shell           ; a terminal REPL for Emacs
       term              ; terminals in Emacs
       ;; vterm             ; another terminal in Emacs
      
       :checkers
       (syntax             ; tasing you for every semicolon you forget
        +childframe)       ; use childframes for error popups (Emacs 26+ only)
       (spell              ; tasing you for misspelling mispelling
       +aspell            ; use the most supported backend
       +everywhere)       ; spell check in programming modes as well (in comments)
       ;;grammar           ; tasing grammar mistake every you make

       :tools
       ;; ansible
       ;; debugger      ; FIXME stepping through code, to help you add bugs
       direnv
       ;; docker
       editorconfig     ; let someone else argue about tabs vs spaces
       ein              ; tame Jupyter notebooks with emacs
       (eval +overlay)  ; run code, run (also, repls)
       gist             ; interacting with github gists
       (lookup          ; helps you navigate your code and documentation
        +dictionary     ; enable word definitions and thesaurus lookup
        +offline        ; install and prefer offline dictionary/thesaurus
        +docsets)       ; ...on in Dash docsets locally
       (lsp +eglot)     ; M-x vscode
       magit            ; a git porcelain for Emacs
       ;;make           ; run make tasks from Emacs
       ;;pass           ;password manager for nerds
       pdf              ; pdf enhancements
       ;;prodigy        ; FIXME managing external services & code builders
       ;;rgb            ; creating color strings
       ;;taskrunner     ; taskrunner for all your projects
       ;;terraform      ; infrastructure as code
       tmux             ; an API for interacting with tmux
       ;;upload         ; map local to remote projects via ssh/ftp
       ;;biblio         ; prioritize native implementations [DEPRECATED]

       :os
       (:if IS-MAC macos)  ; improve compatibility with macOS
       ;;tty               ; improve the terminal Emacs experience

       :lang
       ;;agda               ; types of types of types of types...
       ;;beancount          ; mind the GAAP
       (cc +lsp)            ; C/C++/Obj-C madness
       ;;clojure            ; java with a lisp
       ;;common-lisp        ; if you've seen one lisp, you've seen them all
       ;;coq                ; proofs-as-programs
       ;;crystal            ; ruby at the speed of c
       ;;csharp             ; unity, .NET, and mono shenanigans
       data                 ; config/data formats
       ;;(dart +flutter)    ; paint ui and not much else
       ;;elixir             ; erlang done right
       ;;elm                ; care for a cup of TEA?
       emacs-lisp           ; drown in parentheses
       ;;erlang             ; an elegant language for a more civilized age
       ess                  ; emacs speaks statistics
       ;;factor
       ;;faust              ; dsp, but you get to keep your soul
       ;;fsharp             ; ML stands for Microsoft's Language
       ;;fstar              ; (dependent) types and (monadic) effects and Z3
       ;;gdscript           ; the language you waited for
       (go +lsp)            ; the hipster dialect
       (haskell +dante)     ; a language that's lazier than I am
       ;;hy                 ; readability of scheme w/ speed of python
       ;;idris              ; a language you can depend on
       json                 ; At least it ain't XML
       ;;(java +meghanada)  ; the poster child for carpal tunnel syndrome
       javascript           ; all(hope(abandon(ye(who(enter(here))))))
       julia                ; a better, faster MATLAB
       ;;kotlin             ; a better, slicker Java(Script)
       (latex               ; writing papers in Emacs has never been so fun
        +latexmk            ; no other option TBH
        +cdlatex            ; for better math
        +fold)              ; neat folding things
       ;;lean               ; for folks with too much to prove
       ;;ledger             ; be audit you can be
       lua                  ; one-based indices? one-based indices
       markdown             ; writing docs for people to ignore
       ;;nim                ; python + lisp at the speed of c
       nix                  ; I hereby declare "nix geht mehr!"
       ;;ocaml              ; an objective camel
       (org                 ; organize your plain life in plain text
        ;; +brain           ; for org-brain support
        ;; +dragndrop       ; file drag & drop support
        +gnuplot            ; render gnuplot
        +hugo               ; use Emacs for hugo blogging
        ;; +ipython         ; So much more asynchronous, overshadowed by jupyter
        ;; +journal         ; journaling in org
        +jupyter            ; enable jupyter integration
        +pandoc             ; pandoc integration into org's exporter
       ;;+pomodoro          ; be fruitful with the tomato technique
        +present            ; using Emacs for presentations
        +roam)              ; some sort of faster note system
       ;;php                ; perl's insecure younger brother
       ;;plantuml           ; diagrams for confusing people more
       ;;purescript         ; javascript, but functional
       (python +lsp)               ; beautiful is better than ugly
       ;;+poetry)           ; the future of the written word
       ;; qt                ; the 'cutest' gui framework ever
       ;; racket            ; a DSL for DSLs
       ;;raku               ; the artist formerly known as perl6
       ;;rest               ; Emacs as a REST client
       rst                  ; ReST in peace
       ruby                 ; 1.step do {|i| p "Ruby is #{i.even? ? 'love' : 'life'}"}
       rust                 ; Fe2O3.unwrap().unwrap().unwrap().unwrap()
       ;;scala              ; java, but good
       ;;(scheme +guile)    ; a fully conniving family of lisps
       (sh  +lsp)           ; she sells (ba|z)sh shells on the C xor
       ;;sml
       ;;solidity           ; do you need a blockchain? No.
       ;;swift              ; who asked for emoji variables?
       ;;terra              ; Earth and Moon in alignment for performance.
       web                  ; the tubes
       yaml                 ; JSON, but readable
       ;;zig                ; C, but simpler
       ;;assembly           ; assembly for fun or debugging [DEPRECATED]
       ;;perl               ; write code no one else can comprehend [DEPRECATED]

       :email
       ;;(mu4e +gmail)
       ;;notmuch
       ;;(wanderlust +gmail)

       ;; Applications are complex and opinionated modules that transform Emacs
       ;; toward a specific purpose. They may have additional dependencies and
       ;; should be loaded late.

       :app
       ;;calendar
       ;;emms
       ;;everywhere        ; *leave* Emacs!? You must be joking
       ;;irc               ; how neckbeards socialize
       ;;(rss +org)        ; emacs as an RSS reader
       ;;twitter           ; twitter client https://twitter.com/vnought
       ;;write             ; emacs for writers (fiction, notes, papers, etc.) [DEPRECATED]
      
       :config
       ;; For literate config users. This will tangle+compile a config.org
       ;; literate config in your `doom-private-dir' whenever it changes.
       literate

       ;; The default module set reasonable defaults for Emacs. It also provides
       ;; a Spacemacs-inspired keybinding scheme, a custom yasnippet library,
       ;; and additional ex commands for evil-mode. Use it as a reference for
       ;; your own modules.
       (default +bindings +smartparens))

5. License

It is a personal configuration. So I guess the MIT license will do for now.

Date: 2020:04:09

Author: Rohit Goswami

Created: 2021-07-20 Tue 16:29