doomemacs/README.md

127 lines
5.3 KiB
Markdown
Raw Normal View History

2016-05-24 08:56:19 +08:00
[![MIT](https://img.shields.io/badge/license-MIT-green.svg)](./LICENSE)
2015-06-14 23:26:03 +08:00
2016-05-31 09:19:10 +08:00
[![Yay! Evil!](https://raw.githubusercontent.com/hlissner/.emacs.d/screenshots/cacochan.png)](http://ultravioletbat.deviantart.com/art/Yay-Evil-111710573)
2016-08-22 02:36:54 +08:00
This is an Emacs configuration for a stubborn, melodramatic and shell-dwelling
vimmer disappointed with the text-editor status quo.
2016-08-21 23:23:11 +08:00
2016-08-22 02:36:54 +08:00
Doom tries to look and act like modern editors (whatever that will mean to me on
any given day), emulates vim as best it can and strives to surpass it in any way
possible. All to fit my needs as a software developer, indie gamedev, designer,
scientist and doom enthusiast.
2016-05-31 09:19:10 +08:00
2016-08-22 02:36:54 +08:00
It was tailored for Emacs 25+ on OSX 10.11+. I use [vim] everywhere else.
2016-08-21 23:23:11 +08:00
![Main screenshot](https://raw.githubusercontent.com/hlissner/.emacs.d/screenshots/main.png?raw=true)
**NOTE:** you can [find the theme in a separate repo](https://github.com/hlissner/emacs-doom-theme).
2016-05-24 08:56:19 +08:00
2015-06-14 23:26:03 +08:00
## Installation
2016-06-09 12:38:32 +08:00
```bash
2016-06-09 12:37:38 +08:00
# Install cask + emacs
2015-10-01 01:52:30 +08:00
brew install cask
2016-06-09 12:37:38 +08:00
brew tap railwaycat/emacsmacport
brew install emacs-mac --with-imagemagick --with-modern-icon --HEAD
# Install this emacs.d
2016-04-06 11:53:38 +08:00
git clone https://github.com/hlissner/.emacs.d ~/.emacs.d
2015-06-14 23:26:03 +08:00
cd ~/.emacs.d
make # installs plugins via cask and generates autoloads
2016-01-24 09:38:12 +08:00
2016-05-25 11:38:19 +08:00
# Optional
2016-05-31 09:19:10 +08:00
make compile # compiles core and autoloaded files
2016-02-26 22:30:41 +08:00
make snippets # install hlissner/emacs-snippets into private/snippets
```
2016-01-24 09:38:12 +08:00
2016-05-31 09:19:10 +08:00
For a more comprehensive byte compile, run `:bc!` (`:bc` will compile the
current *.el file).
2015-06-14 23:26:03 +08:00
## Features
2016-01-24 09:38:12 +08:00
To get a picture of what's in here, check out:
2015-12-12 16:18:14 +08:00
2016-05-21 10:37:30 +08:00
* **[The Caskfile](Cask)**: lists installed plugins and where they're configured.
* **[init.el](init.el)**: lists all loaded modules
* **[private/my-bindings.el](private/my-bindings.el)**: most of the custom keybinds
* **[private/my-commands.el](private/my-commands.el)**: available custom ex commands
2016-08-21 23:23:11 +08:00
* **[ext/*.sh](ext/)**: scripts for external dependency setup (e.g. irony-mode)
See screenshots in the [screenshots branch][sc].
2015-12-12 16:18:14 +08:00
2016-04-06 11:53:38 +08:00
### Highlights
2015-12-12 16:18:14 +08:00
2016-08-21 23:23:11 +08:00
* Tamed popup windows with **[shackle]**; see `def-popup!` and `shackle-rules`.
e.g. help buffers will always pop up at the bottom of the frame, and are
removed with ESC.
* Workspaces & session persistence with **[workgroups2]**
* Project and workspace-sensitive buffer navigation and functions
* A vim-like environment with **[evil-mode]**
* vim-seek/vim-sneak functionality with **[evil-snipe]** (provides 2-char motions)
* [Multiple cursors][sc-multiedit] with **[evil-multiedit]**
* Repeat (most) motions with <kbd>SPC</kbd> and
<kbd>shift</kbd>+<kbd>SPC</kbd>
* On-the-fly keybindings with `:[nviom]map`
* Global <kbd>C-x</kbd> omnicompletion (e.g. <kbd>C-x</kbd>+<kbd>C-f</kbd> for
files)
* Fast search utilities:
* Project and buffer navigation with **[ivy]**
* File browser sidebar with **[neotree]**
* Project search (and replace) with **[counsel-ag]** and **[wgrep]**
* Buffer search with **[swiper]**
* REPLs for many languages including Ruby, Python, PHP, JS, Elisp, Haskell and
Lua.
* [Minimalistic diffs in the fringe][sc-diffs] with **[git-gutter-fringe]**.
* Modded **org-mode** to be a modern note-taking/LaTeX/word-processing platform. (WIP)
* Code debugging interface with **[realgud]** (currently supports gdb, trepanjs,
bashdb and zshdb, working on Python/Ruby support)
* A do-what-I-mean jump-to-definition implementation that either uses major-mode
commands or falls back to **[dumb-jump]**/ctags.
* A pretty mode-line with:
* evil-search/iedit/evil-substitute mode-line integration
* Macro-recording indicator
* Python/ruby version in mode-line (for rbenv/pyenv)
2016-08-21 23:23:11 +08:00
### Other features
* Line numbers + highlight with **[nlinum]**
* On-demand [platform agnostic] shell with **eshell**
* Consistent marker-based code-folding with **hideshow**
* Inline code execution anywhere (once or live) with **[quickrun]**
* Snippet expansion and file templates with **[yasnippet]**
* Completion with **[company-mode]**
* Syntax checking with **[flycheck]**
* Custom O/S interaction commands, like **os-reveal** and **os-open-in-browser**
* Custom TODO, FIXME and NOTE highlighting and search
* **big-mode** for presentations and demonstrations
* Tmux integration with `:t` and `:tcd` ex commands
[auto-yasnippet]: https://melpa.org/#/auto-yasnippet
[company-mode]: https://melpa.org/#/company
[counsel-ag]: https://melpa.org/#/counsel
2016-08-21 23:23:11 +08:00
[dumb-jump]: https://melpa.org/#/dumb-jump
[evil-mode]: https://melpa.org/#/evil
2016-08-21 23:23:11 +08:00
[evil-multiedit]: https://melpa.org/#/evil-multiedit
[evil-snipe]: https://melpa.org/#/evil-snipe
[flycheck]: https://melpa.org/#/flycheck
[git-gutter-fringe]: https://melpa.org/#/git-gutter-fringe
[ivy]: https://melpa.org/#/ivy
[neotree]: https://melpa.org/#/neotree
[nlinum]: http://elpa.gnu.org/packages/nlinum.html
[quickrun]: https://melpa.org/#/quickrun
2016-08-21 23:23:11 +08:00
[realgud]: https://melpa.org/#/realgud
[repl-toggle]: https://melpa.org/#/repl-toggle
[shackle]: https://melpa.org/#/shackle
2016-08-21 23:23:11 +08:00
[swiper]: https://melpa.org/#/swiper
[workgroups2]: https://melpa.org/#/workgroups2
[wgrep]: https://melpa.org/#/wgrep
[yasnippet]: https://melpa.org/#/yasnippet
2016-06-07 14:21:50 +08:00
2016-08-21 23:23:11 +08:00
[sc]: https://github.com/hlissner/.emacs.d/tree/screenshots
[sc-diffs]: https://github.com/hlissner/.emacs.d/blob/screenshots/git-gutter.png?raw=true
[sc-multiedit]: https://raw.githubusercontent.com/hlissner/evil-multiedit/screenshots/main.gif?raw=true
2016-08-22 02:36:54 +08:00
[vim]: https://github.com/hlissner/.vim
2016-06-07 14:21:50 +08:00