This repository has been archived on 2024-10-22. You can view files and clone it, but cannot push or open issues or pull requests.
spacemacs/README.md

1298 lines
50 KiB
Markdown
Raw Normal View History

2014-09-02 04:24:33 +00:00
# Spacemacs Starter Kit
2012-12-17 21:34:04 +00:00
2014-10-13 03:56:29 +00:00
![title](https://raw.githubusercontent.com/syl20bnr/spacemacs/master/doc/title.png)
2014-10-14 00:59:44 +00:00
[![Gitter](https://badges.gitter.im/Join Chat.svg)](https://gitter.im/syl20bnr/spacemacs?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
2014-09-21 23:58:53 +00:00
**Quick Install:**
git clone --recursive http://github.com/syl20bnr/spacemacs .emacs.d
<!-- markdown-toc start - Don't edit this section. Run M-x markdown-toc/generate-toc again -->
**Table of Contents**
- [Spacemacs Starter Kit](#spacemacs-starter-kit)
- [Goals](#goals)
- [Screenshots](#screenshots)
- [Who can benefit from this ?](#who-can-benefit-from-this-)
2014-09-27 04:13:16 +00:00
- [Prerequisites](#prerequisites)
- [Install](#install)
- [Configuration layers](#configuration-layers)
- [Structure](#structure)
- [Extensions and Packages initialization](#extensions-and-packages-initialization)
- [Contributions](#contributions)
- [Themes Megapack example](#themes-megapack-example)
- [Main principles](#main-principles)
2014-10-03 16:19:13 +00:00
- [Evil](#evil)
2014-10-13 02:17:10 +00:00
- [States](#states)
- [Base States](#base-states)
2014-10-03 16:19:13 +00:00
- [Evil leader](#evil-leader)
- [Micro-states](#micro-states)
2014-10-13 03:51:54 +00:00
- [Tips](#tips)
- [Tips for beginners](#tips-for-beginners)
- [Tips for advanced users](#tips-for-advanced-users)
- [UI tweaks](#ui-tweaks)
- [Commands](#commands)
- [Return to normal mode](#return-to-normal-mode)
- [Executing Vim and Emacs commands](#executing-vim-and-emacs-commands)
- [Key bindings help](#key-bindings-help)
- [Included Evil plugins](#included-evil-plugins)
- [About helm](#about-helm)
- [Navigation](#navigation)
- [Point/Cursor](#pointcursor)
2014-09-24 01:46:52 +00:00
- [Vim motions with ace-jump mode](#vim-motions-with-ace-jump-mode)
- [Buffers and Files](#buffers-and-files)
- [Ido](#ido)
- [Bookmarks](#bookmarks)
- [Window manipulation](#window-manipulation)
- [Golden ratio](#golden-ratio)
- [Text manipulation commands](#text-manipulation-commands)
- [Change font size](#change-font-size)
- [Spell checking](#spell-checking)
- [Region selection](#region-selection)
- [Region narrowing](#region-narrowing)
2014-10-03 16:19:13 +00:00
- [Auto highlight and edition of symbols](#auto-highlight-and-edition-of-symbols)
- [Color theme](#color-theme)
- [UI elements](#ui-elements)
- [Mode-line](#mode-line)
- [Toggles](#toggles)
- [Minor Modes](#minor-modes)
- [Line formatting](#line-formatting)
- [Errors handling](#errors-handling)
- [Project management](#project-management)
2014-10-12 04:12:16 +00:00
- [Working with Git](#working-with-git)
- [Magit](#magit)
- [Quick guide for recurring use cases in Magit](#quick-guide-for-recurring-use-cases-in-magit)
- [Git gutter bitmaps](#git-gutter-bitmaps)
2014-10-14 04:22:24 +00:00
- [Editing Lisp code](#editing-lisp-code)
- [Intuitive navigation model](#intuitive-navigation-model)
- [Text selection](#text-selection)
- [Key bindings map](#key-bindings-map)
- [Modes](#modes)
- [Helm](#helm)
- [Erlang](#erlang)
- [Ledger](#ledger)
- [Org](#org)
- [Perforce](#perforce)
- [Python](#python)
- [Inferior REPL process](#inferior-repl-process)
- [Testing in Python](#testing-in-python)
- [Other Python commands](#other-python-commands)
- [R (ESS)](#r-ess)
- [Inferior REPL process](#inferior-repl-process)
- [Other R commands](#other-r-commands)
- [rcirc](#rcirc)
- [TODO list](#todo-list)
2014-09-26 03:10:46 +00:00
- [Thank you](#thank-you)
<!-- markdown-toc end -->
2013-11-24 04:00:41 +00:00
2014-09-01 04:27:52 +00:00
## Goals
2014-09-03 00:46:10 +00:00
- The main goal of `Spacemacs` is to **bring the power of Vim modal editing
to the powerful Emacs editing platform**.
2014-10-03 16:17:35 +00:00
- Slick integration with `Evil` states (`Vim` modes) with custom
`micro-states` (temporary overlay map): `Spacemacs` tries to **keep your
fingers on the home row** as much as possible, no matter the mode you are in.
2014-09-02 04:28:03 +00:00
2014-09-03 00:46:10 +00:00
- **Community driven configuration** based on a configuration layer system
2014-09-03 01:13:48 +00:00
*(work in progress)*. Contribute your own personal layer upstream and
2014-09-03 00:46:10 +00:00
everybody can use it.
2014-09-22 01:44:06 +00:00
- **Minimalistic and nice custom UI**, keep your available screen space for
what matters: your text files.
2014-09-03 00:46:10 +00:00
2014-09-25 03:36:45 +00:00
- **Mnemonic and consistent key bindings** which should be easier to learn
and remember.
- **Fast boot time**, some time has been invested to make 'Spacemacs' quick
to load.
- **Lower the risk of RSI** by using the space key as much as possible.
- Hopefully, if it's not already the case: Ɛ> **make you love modal editing!** <3
2014-09-01 05:23:13 +00:00
2014-09-07 02:47:20 +00:00
## Screenshots
2014-09-01 05:15:52 +00:00
2014-09-26 04:08:58 +00:00
![spacemacs_startup](https://raw.githubusercontent.com/syl20bnr/spacemacs/master/doc/spacemacs-startup.png)
![spacemacs_python](https://raw.githubusercontent.com/syl20bnr/spacemacs/master/doc/spacemacs-python.png)
2014-09-01 05:15:52 +00:00
2014-09-22 01:57:32 +00:00
*Note: Even though screenshots are updated frequently, `Spacemacs` is evolving
quickly and the screenshots may not reflect exactly the current state of the
project.*
2013-12-13 17:18:28 +00:00
## Who can benefit from this ?
2013-11-23 05:46:33 +00:00
2014-08-31 17:11:49 +00:00
`Spacemacs` is first intended to be used by **Vim users** who want to go to the
2013-12-01 03:37:00 +00:00
next level by using Emacs.
2013-11-23 05:46:33 +00:00
2014-08-31 17:11:49 +00:00
It is also a good fit for people wanting to **lower the [risk of RSI][RSI]**
2013-11-23 05:46:33 +00:00
induced by the default Emacs key bindings.
2014-08-31 17:11:49 +00:00
People wanting to learn **a different way to edit files** or wanting to learn
2014-10-12 01:32:35 +00:00
Vim key bindings (see [Tips for beginners](#tips-for-beginners)).
2013-11-23 05:46:33 +00:00
As a note side, if you are a programmer and you don't know Vim key bindings
yet, I deeply recommend you to learn the basics as recommended in
[Sacha Chua's one-page guide][sacha_guide] about how to learn Emacs.
2014-09-27 02:50:30 +00:00
## Prerequisites
`Spacemacs` is compatible with Emacs 24.3 and above and should boot on all
the major OSes where this version can be installed.
2013-11-23 05:46:33 +00:00
2014-09-27 02:50:30 +00:00
Some packages require external tools to work, a list of all dependencies will
be provided in this read me. _Stay tuned._
## Install
2013-11-23 05:46:33 +00:00
2014-09-27 02:50:30 +00:00
Backup your current `.emacs.d`, clone the repo _with the submodules_ and
you are good to go:
2013-11-23 05:46:33 +00:00
cd ~
mv .emacs.d .emacs.bak
git clone --recursive http://github.com/syl20bnr/spacemacs .emacs.d
2013-11-23 05:46:33 +00:00
## Configuration layers
_This part of Spacemacs is still in beta, the structure can change over
time. Refer to commit messages for more information in case of big changes._
### Structure
Configuration is organized in layers. Each layer has the following structure:
```
[layer_name]
|__ [extensions]
| |__ [mode 1]
| | ...
| |__ [mode n]
|__ config.el
|__ extensions.el
|__ funcs.el
|__ keybindings.el
|__ packages.el
[] = directory
```
Where:
File | Usage
------------------|-----------------------------------------------------------
config.el | Emacs built-in configuration or mandatory configuration
extensions.el | The list of extensions to load and the functions to initialize them
funcs.el | Various functions and macros (often used in keybindings.el)
keybindings.el | Emacs built-in key bindings or mandatory key bindings
packages.el | The list of packages to install and the functions to initialize them
`Packages` are `ELPA` packages which can be installed from an `ELPA` compliant
repository, and `Extensions` are elisp code from git submodules, they can also
be directly stored in this git repository (maybe we call this: site elisp
code ??).
### Extensions and Packages initialization
`Extensions` and `Packages` are listed in variables `<layer>-pre-extensions`,
`<layer>-post-extensions` and `<layer>-packages` where `<layer>` is the layer
name. `Pre-Extensions` are loaded before `Packages` and `Post-Extensions` are
loaded after `Packages`.
They are processed in alphabetical order so sometimes you'll have to use
some `after-eval-load` black magic.
To initialize an extension or a package `xxx`, define a function with this
format in `extensions.el` or `packages.el`:
```elisp
(defun <layer>/init-xxx ()
...body
)
```
## Contributions
`Spacemacs` leverages the configuration layers in order to make it possible for
you to share your own layer with other `Spacemacs` users.
To use a contribution layer, add it to the `dotspacemacs-configuration-layers`
variable of your `~/.spacemacs`
For instance to add the configuration layer of [RMS](#thank-you) just do:
```elisp
(defvar dotspacemacs-configuration-layers '(rms)
"List of contribution to load."
)
```
Oh, you don't find this configuration layer ? So sad, well you can try mine:
[syl20bnr](https://github.com/syl20bnr/spacemacs/tree/master/contrib/syl20bnr)
2014-10-12 01:36:40 +00:00
All pull requests are welcome for all parts of `Spacemacs`.
### Themes Megapack example
This is a simple contribution layer listing a bunch of themes.
To install it, just add `themes-megapack` to your `~/.spacemacs`. You have now
installed around 100 themes you are free to try with `<SPC> h t` (helm-themes).
2013-11-23 05:46:33 +00:00
## Main principles
2013-11-23 05:46:33 +00:00
### Evil
2014-09-01 06:17:18 +00:00
`Spacemacs` uses the [evil][evil] mode to emulate Vim key bindings. It is a
2014-10-12 01:32:02 +00:00
very complete emulation, maybe the most advanced. In fact, Evil is much more
2014-10-12 01:36:40 +00:00
than just a Vim emulation. It has more states than Vim for instance.
2014-10-12 01:32:02 +00:00
2014-10-13 02:17:10 +00:00
#### States
2014-10-12 01:32:02 +00:00
`Spacemacs` has 6 states:
- **Normal** (orange) - like the `normal mode of Vim`, used to execute and
combine commands
- **Insert** (green) - like the `insert mode of Vim`, used to actually insert
text
- **Visual** (gray) - like the `visual mode of Vim`, used to make text
selection
2014-10-15 02:55:40 +00:00
- **Motion** (purple) - exclusive to `Evil`, used to navigate read only
buffers
- **Emacs** (blue) - exclusive to `Evil`, using this state is like using a
regular Emacs without Vim
- **Lisp** (pink) - exclusive to `Spacemacs`, used to navigate Lisp code and
2014-10-15 02:55:40 +00:00
modify it
2014-10-13 02:17:10 +00:00
#### Base States
_(I apologize in advance for the number of repetition of the word `state` in
this section, but I encourage you to read again this section until you correctly
grasp the concept of `base state` since it is an important concept in
`Spacemacs`)_
`Spacemacs` has a notion of `base state`. A `base state` is the state you are
when leaving the `insert state`.
The typical `base state` in Vim is the `normal state` and it is the only one.
`Spacemacs` has more than one base state, here is the list:
- normal
- lisp
This allows a coder of Lisp to completely replace the `normal state` by the
`lisp state`. Indeed, once you fire up the `lisp state` you can just go back
and forth between the `insert state` and the `lisp state`.
Of course there is a rule to break this in order to be able to go back to the
`normal state`. It is pretty simple:
*When in a `base state`, `ESC` or `fd` will always set you back to the
`normal state`.*
So to go back to the `normal state` while in `lisp state` just hit `ESC` or
`fd`.
### Evil leader
2014-09-01 06:17:18 +00:00
`Spacemacs` heavily uses the [evil-leader][evil-leader] mode which brings the
Vim leader key to the Emacs world.
2014-08-31 17:11:49 +00:00
This leader key is commonly set to `,` by Vim users, in `Spacemacs` the leader
key is set on `SPC` (space bar, this is why the name `spacemacs`). This key is
the most accessible key on a keyboard and it is pressed with the thumb which is
a good choice to lower the risk of [RSI][RSI].
2014-09-01 06:17:18 +00:00
So with `Spacemacs` there is no need to remap your keyboard modifiers to
attempt to reduce the risk of RSI, every command can be executed very easily
while you are in `normal` mode by pressing the `SPC` leader key, here are a
few examples:
2013-11-23 05:46:33 +00:00
2014-08-31 17:11:49 +00:00
- Save a buffer: `<SPC> f s`
- Save all opened buffers: `<SPC> f S`
- Open (switch) to a buffer with `helm`: `<SPC> b s`
2013-11-23 05:46:33 +00:00
### Micro-states
`Spacemacs` defines a wide variety of `micro-states` (temporary overlay maps)
where it makes sense. This prevent from repetitive and tedious presses on the
`SPC` key.
When a `micro-state` is active, a documentation is displayed in the minibuffer.
Additional information may as well be displayed in the minibuffer.
2014-10-05 02:53:00 +00:00
[Auto-highlight-symbol micro-state](#auto-highlight-and-edition-of-symbols):
![spacemacs_ahs_micro_state](https://raw.githubusercontent.com/syl20bnr/spacemacs/master/doc/spacemacs-ahs-micro-state.png)
2014-10-05 02:53:00 +00:00
[Text scale micro-state](#change-font-size):
![spacemacs_scale_micro_state](https://raw.githubusercontent.com/syl20bnr/spacemacs/master/doc/spacemacs-scale-micro-state.png)
2014-10-13 03:51:54 +00:00
## Tips
2014-10-12 01:32:35 +00:00
2014-10-13 03:51:54 +00:00
### Tips for beginners
1) If you came here with a pure Emacs background, here is a useful tips to get
2014-10-12 04:23:28 +00:00
you started.
2014-10-12 01:32:35 +00:00
As you may have notice, raw Emacs behavior is indeed available in Evil via the
`Emacs state`!
To start you could setup the `Emacs state` as the default one, pressing `fd`
quickly would bring you to `Normal state` and pressing `ESC` from there would
bring you back in `Emacs state`. This way you should never feel lost.
To do so add the following snippet to your `~/.spacemacs`:
```elisp
(defun dotspacemacs/config ()
"This is were you can ultimately override default Spacemacs configuration.
This function is called at the very end of Spacemacs initialization."
(setq evil-default-state 'emacs)
(define-key evil-normal-state-map [escape] 'evil-emacs-state))
```
2014-10-13 03:51:54 +00:00
### Tips for advanced users
1) To Make `lisp state` the default state in `Emacs Lisp` buffers, insert in
your `~/.spacemacs` the following snippet:
```elisp
(defun dotspacemacs/config ()
"This is were you can ultimately override default Spacemacs configuration.
This function is called at the very end of Spacemacs initialization."
(add-hook 'emacs-lisp-mode-hook 'evil-lisp-state))
```
## UI tweaks
2013-11-23 05:46:33 +00:00
`Spacemacs` has a minimalistic and distraction free UI with a lot of subtle
customizations which make it unique compared to other Emacs kits:
2014-09-23 02:20:42 +00:00
- custom [powerline][powerline] mode-line [with color feedback](#mode-line)
according to current [Flycheck][flycheck] status
- unicode symbols for minor mode lighters which appear in the mode-line
- [custom fringe bitmaps](#errors-handling) and error feedbacks for
[Flycheck][flycheck]
2014-10-12 04:12:16 +00:00
- [custom fringe bitmaps](#git-gutter-bitmaps) for [git gutter][git-gutter].
- dedicated startup page with a mode aimed at easily managing `Spacemacs`
2013-11-23 05:46:33 +00:00
## Commands
2013-11-24 03:50:11 +00:00
Every sequences must be performed in `normal` mode.
2013-11-23 05:46:33 +00:00
### Return to normal mode
2013-12-17 02:11:47 +00:00
`ESC` is the default key to return to normal mode. This is one of the main
design flaw in Vim key bindings because the `ESC` key is very far from the
home row.
2014-08-31 17:11:49 +00:00
The popular way to avoid this is to replace `ESC` by `jj` pressed rapidly.
Unfortunately it is pretty difficult in Emacs to keep a consistent behavior
with this sequence (same thing with `jk` or `kj`).
`Spacemacs` uses the sequence `fd` instead of `jj` which works in any Evil
state and in any buffer and in the minibuffer.
2013-12-17 02:11:47 +00:00
This sequence can be customized in your `~/.spacemacs`, for instance to
revert back to the popular configuration using `jj` (not recommended) add this
to your file:
2013-11-23 05:46:33 +00:00
```elisp
(defun dotspacemacs/init ()
"User initialization for Spacemacs. This function is called at the very startup."
(defvar spacemacs-normal-state-sequence '(?j . ?j))
(defvar spacemacs-normal-state-sequence-delay 0.2)
)
```
2013-11-24 03:50:11 +00:00
### Executing Vim and Emacs commands
2014-09-22 02:37:26 +00:00
Vim commands are executed as usual with the `:` key.
2014-08-31 17:11:49 +00:00
To execute an Emacs command press `<SPC>` (space) before:
2013-11-24 03:50:11 +00:00
<SPC> :
2013-11-23 05:46:33 +00:00
### Key bindings help
A list of all the key bindings can be accessed by pressing:
<SPC> ?
2013-12-01 03:37:00 +00:00
To narrow the list to `Spacemacs` specific key bindings set the pattern to `SPC`
### Included Evil plugins
`Spacemacs` ships with the following evil plugins:
Mode | Description
----------------------------------------|--------------------------------------
[evil-leader][evil-leader] | vim leader that bring a new layer of keys in normal mode
[evil-little-word][evil-plugin01] | port of [camelcasemotion.vim][vim-plugin01]
[evil-operator-comment][evil-plugin01] | comment/uncomment with `CC`
[evil-visualstar][evil-plugin03] | search for current selection with `*`
[evil-exchange][evil-plugin05] | port of [vim-exchange][vim-plugin04]
2014-10-12 04:12:16 +00:00
[evil-surround][evil-plugin04] | port of [surround.vim][vim-plugin03]
2013-12-13 17:15:03 +00:00
### About helm
`Spacemacs` tries to use [helm][helm] as much as possible.
[helm][helm] is coupled to [popwin][popwin] so `helm` window always appears in
2014-10-12 01:36:40 +00:00
a new temporary window at the bottom.
2013-12-13 17:15:03 +00:00
The following `helm` modes are installed with `Spacemacs`:
2014-08-31 17:11:49 +00:00
Key Binding | Mode | Description
------------|-----------------------------------------|------------------------
`<SPC> h s` | [helm-swoop][hswoop] | search for occurrences within a file and edit the result
`<SPC> h y` | [helm-c-yasnippet][hyas] | select snippets
`<SPC> h t` | [helm-themes][hthemes] | select a theme
`<SPC> p f` | [helm-projectile][projectile] | select files within a projectile project
`<SPC> ?` | [helm-descbinds][hdescbinds] | show key bindings
`<SPC> s c` | [cofi/helm-flyspell-correct][hflyspell] | choose a corrected word
2013-12-13 17:15:03 +00:00
2014-09-01 04:27:52 +00:00
### Navigation
#### Point/Cursor
2013-11-23 05:46:33 +00:00
Navigation is performed using the Vi key bindings `hjkl`.
2014-09-01 06:17:18 +00:00
Key Binding | Description
------------|------------------------------------------------------------------
2014-08-31 17:11:49 +00:00
`h` | move cursor left
`j` | move cursor down
`k` | move cursor up
`l` | move cursor right
`H` | move quickly up (10 lines at a time)
`L` | move quickly down (10 lines at a time)
`<SPC> j h` | go to the beginning of line (and set a mark at the previous location in the line)
`<SPC> j l` | go to the end of line (and set a mark at the previous location in the line)
`<SPC> z z` | lock the cursor at the center of the screen
2014-09-24 01:42:08 +00:00
#### Vim motions with ace-jump mode
2013-11-23 05:46:33 +00:00
2014-09-24 01:42:08 +00:00
`Spacemacs` uses the `evil` integration of [ace-jump mode][ace-jump] which
enables the invocation of `ace-jump-mode` during motions.
It is useful for deleting visually a set of lines, try the following sequence
in a buffer containing some text:
d <SPC> l
Key Binding | Description
--------------|------------------------------------------------------------------
`<SPC> <SPC>` | initiate ace jump char mode
`<SPC> l` | initiate ace jump line mode
``<SPC> ``` | go back to the previous location (before the jump)
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
#### Buffers and Files
2013-11-23 05:46:33 +00:00
2013-12-13 17:15:03 +00:00
`Spacemacs` uses `ido` for opening files since `ido` way to navigate
the file system is better than `helm` in my opinion (especially because `ido` can
2013-11-23 05:46:33 +00:00
remember the last selected directories and buffers, maybe helm can do this ?).
`ido` is also used to kill buffers.
2014-08-31 17:11:49 +00:00
Buffer manipulation commands (start with `b`):
2014-09-01 06:17:18 +00:00
Key Binding | Description
--------------|----------------------------------------------------------------
2014-08-31 17:11:49 +00:00
`<SPC> b d` | delete the current buffer (beware the associated file is also deleted)
`<SPC> b k` | kill the current buffer
`<SPC> b K` | kill all buffers except the current one
`<SPC> b m h` | move a buffer to the left
`<SPC> b m j` | move a buffer to the bottom
`<SPC> b m k` | move a buffer to the top
`<SPC> b m l` | move a buffer to the right
`<SPC> b n` | switch to next buffer
`<SPC> b p` | switch to previous buffer
`<SPC> b r` | rename the current buffer
`<SPC> b s` | switch to a buffer using `helm`
`<SPC> b w` | toggle read-only
Files manipulation commands (start with `f`):
2014-09-01 06:17:18 +00:00
Key Binding | Description
--------------|----------------------------------------------------------------
2014-08-31 17:11:49 +00:00
`<SPC> f f` | open a file using `ido`
`<SPC> f i` | open your `init.el` file
`<SPC> f s` | save a file
`<SPC> f S` | save all files
`<SPC> f t` | toggle file tree side bar using [neotree][neotree]
`<SPC> f y` | show current file absolute path in the minibuffer
2013-11-23 05:46:33 +00:00
#### Ido
`Spacemacs` displays the `ido` minibuffer vertically thanks to the
[ido-vertical-mode][ido-vertical-mode].
Basic `ido` operations can be done with `Ctrl` key:
Key Binding | Description
--------------|----------------------------------------------------------------
`C-d` | delete selected file (ask for confirmation)
`C-k` | select previous file or directory
`C-<return>` | open a `dired buffer`
`C-h` | go to parent directory
`C-j` | select next file or directory
`C-l` | open the selected file
`C-S-j` | go to next directory
`C-S-k` | go to previous directory
2014-09-01 04:27:52 +00:00
#### Bookmarks
Bookmarks can be set anywhere in a file. Bookmarks are persistent. They are very
useful to jump to/open a known project. `Spacemacs` used `helm-bookmarks` to
manage them.
2014-09-01 04:27:52 +00:00
Open an `helm` window with the current bookmarks by pressing:
<SPC> h b
Then in the `helm-bookmarks` buffer:
2014-09-01 04:27:52 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
--------------|----------------------------------------------------------------
`CTRL+d` | delete the selected bookmark
`CTRL+e` | edit the selected bookmark
`CTRL+f` | toggle filename location
`CTRL+o` | open the selected bookmark in another window
To save a new bookmark, just type the name of the bookmark and press `RET`.
2014-09-01 04:27:52 +00:00
2013-11-23 05:46:33 +00:00
### Window manipulation
Every window has a number displayed at the start of the mode-line and can
2014-08-31 17:11:49 +00:00
be quickly accessed using `<SPC> number`.
Key Binding | Description
2014-09-01 06:17:18 +00:00
--------------|----------------------------------------------------------------
2014-08-31 17:11:49 +00:00
`<SPC> 1` | go to first window
`<SPC> 2` | go to window number 2
`<SPC> 3` | go to window number 3
`<SPC> 4` | go to window number 4
`<SPC> 5` | go to window number 5
`<SPC> 6` | go to window number 6
`<SPC> 7` | go to window number 7
`<SPC> 8` | go to window number 8
`<SPC> 9` | go to window number 9
`<SPC> 0` | go to window number 10
Windows manipulation commands (start with `w`):
2014-09-01 06:17:18 +00:00
Key Binding | Description
--------------|----------------------------------------------------------------
2014-08-31 17:11:49 +00:00
`<SPC> w b` | split a window horizontally
`<SPC> w c` | close a window
`<SPC> w d` | toggle window dedication (dedicated window cannot be used by a mode)
`<SPC> w H` | move window to the left
`<SPC> w J` | move window to the bottom
`<SPC> w K` | move window to the top
`<SPC> w L` | move window to the right
`<SPC> w m` | maximize/minimize a window
`<SPC> w M` | maximize/minimize a window, when maximized the buffer is centered
2014-08-31 21:30:26 +00:00
`<SPC> w p` | close the current sticky popup window
2014-08-31 17:11:49 +00:00
`<SPC> w r` | rotate windows clockwise
`<SPC> w R` | rotate windows counter-clockwise
`<SPC> w u` | undo window layout (used to effectively undo a close window)
`<SPC> w U` | redo window layout
`<SPC> w v` | split a window vertically
`<SPC> w w` | cycle and focus between windows
2013-11-23 05:46:33 +00:00
#### Golden ratio
Split windows can be dynamically resized depending on whether they are selected
or not. Resizing is performed by the [golden-ratio][golden-ratio] mode.
By default `golden-ratio` if off.
The mode can be toggled on and off with:
<SPC> t g
2014-09-01 04:27:52 +00:00
### Text manipulation commands
2013-11-24 03:50:11 +00:00
2014-08-31 17:11:49 +00:00
Text related commands (start with `x`):
2014-09-01 06:17:18 +00:00
Key Binding | Description
------------------|------------------------------------------------------------
2014-08-31 17:11:49 +00:00
`<SPC> x u` | set the selected text to lower case
`<SPC> x U` | set the selected text to upper case
`<SPC> x d w` | delete trailing whitespaces
`<SPC> x g l` | set languages used by translate commands
`<SPC> x g t` | translate current word using Google Translate
`<SPC> x g T` | reverse source and target languages
`<SPC> x m j` | move down a line of text
`<SPC> x m k` | move up a line of text
`<SPC> x t c` | swap (transpose) the current character with the previous one
`<SPC> x t w` | swap (transpose) the current word with the previous one
`<SPC> x t l` | swap (transpose) the current line with the previous one
`<SPC> x w c` | count the number of words in the selection region
`<SPC> x w C` | count the number of occurrences per word in the select region
2013-11-24 03:50:11 +00:00
### Change font size
The font size of the current buffer can be adjusted with the commands:
Key Binding | Description
--------------|------------------------------------------------------------
`<SPC> x +` | scale up the font and initiate the font scaling micro-state
`<SPC> x -` | scale down the font and initiate the font scaling micro-state
`<SPC> x =` | reset the font size (no scaling) and initiate the font scaling micro-state
`+` | increase the font size
`-` | decrease the font size
`=` | reset the font size
Any other key | leave the font scaling micro-state
2013-11-24 03:50:11 +00:00
### Spell checking
2014-09-01 04:27:52 +00:00
Spell checking commands start with `s`:
2013-11-24 03:50:11 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
------------------|------------------------------------------------------------
2014-09-01 04:27:52 +00:00
`<SPC> s c` | list of corrections in a `helm` buffer
`<SPC> s d` | change dictionary language
`<SPC> s n` | go to the next spell check error
2013-11-24 03:50:11 +00:00
2014-09-01 04:27:52 +00:00
### Region selection
2013-11-24 03:50:11 +00:00
2014-09-01 04:27:52 +00:00
Vi `Visual` modes are all supported by `evil`, `Spacemacs` adds another
2014-09-01 04:50:53 +00:00
`Visual` mode via the [expand-region][expand-region] mode.
2013-11-24 03:50:11 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
--------------|----------------------------------------------------------------
2014-09-01 04:27:52 +00:00
`<SPC> v` | initiate expand-region mode then...
`v` | expand the region by one semantic unit
`V` | contract the region by one semantic unit
`r` | reset the region to initial selection
2014-09-01 04:50:53 +00:00
`ESC` | leave expand-region mode
2014-09-01 04:27:52 +00:00
### Region narrowing
2013-11-24 03:50:11 +00:00
2014-09-01 06:17:18 +00:00
The displayed text of a buffer can be narrowed with the commands
(start with `n`):
2014-09-01 04:27:52 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
--------------|----------------------------------------------------------------
2014-09-01 04:27:52 +00:00
`<SPC> n f` | narrow the buffer to the current function
`<SPC> n p` | narrow the buffer to the visible page
`<SPC> n r` | narrow the buffer to the selected text
`<SPC> n w` | widen, i.e show the whole buffer again
### Auto highlight and edition of symbols
2014-09-01 04:27:52 +00:00
`Spacemacs` supports auto highlighting of the current word (provided by the
2014-10-05 02:53:00 +00:00
[auto-highlight-symbol][auto-highlight] mode) and add a micro-state to it
which makes it a very handy tool to have on your tool belt.
2014-09-01 04:27:52 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
--------------|----------------------------------------------------------------
2014-09-01 04:27:52 +00:00
`<SPC> h e` | edit all occurrences of the current word
`<SPC> t h` | toggle the auto highlighting
2013-11-24 03:50:11 +00:00
Navigation between the highlighted symbols can be done with the commands:
Key Binding | Description
--------------|------------------------------------------------------------
`<SPC> h h` | initiate navigation micro-state
`<SPC> h n` | go to next occurrence and initiate navigation micro-state
`<SPC> h N` | go to previous occurrence and initiate navigation micro-state
`<SPC> h c b` | change range to `whole buffer`
`<SPC> h c d` | change range to `display area`
`<SPC> h c f` | change range to `function`
`<SPC> h C` | change range to default (`whole buffer`)
In 'Spacemacs' highlight symbol micro-state:
Key Binding | Description
--------------|------------------------------------------------------------
`c` | change scope (`function`, `display area`, `whole buffer`)
`e` | edit occurrences
`n` | go to next occurrence
`N` | go to previous occurrence
`d` | go to next definition occurrence
`D` | go to previous definition occurrence
`h` | go to home occurrence (go to starting occurrence)
Any other key | leave the navigation micro-state
The micro-state text in minibuffer display the following information:
<M> [6/11]* press (n) or (N) to navigate, (h) for home symbol, (c) to change scope
2014-10-05 02:53:00 +00:00
Where `<M> [x/y]*` is:
- M: the current range mode
2014-10-05 02:53:00 +00:00
- `<B>`: whole buffer range
- `<D>`: current display range
- `<F>`: current function range
- x: the index of the current highlighted occurrence
- y: the total number of occurrences
- * (star): appears if there is at least one occurrence which is not currently
visible
2013-11-23 05:46:33 +00:00
### Color theme
2014-09-01 04:54:40 +00:00
By default, `Spacemacs` uses the theme [Solarized][solarized-theme].
2013-11-23 05:46:33 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
------------------|------------------------------------------------------------
2014-09-02 18:42:53 +00:00
`<SPC> c t` | cycle between `Spacemacs` themes
2014-09-01 04:27:52 +00:00
`<SPC> h t` | select a theme using a `helm` buffer
2013-11-23 05:46:33 +00:00
2014-09-02 18:42:53 +00:00
`Spacemacs` available themes:
2014-09-01 04:54:40 +00:00
- [Solarized][solarized-theme]
2014-09-01 04:51:57 +00:00
- [Monokai][monokai-theme]
- [Zenburn][zenburn-theme]
2014-09-01 04:52:19 +00:00
2013-11-23 05:46:33 +00:00
### UI elements
2014-09-01 04:52:19 +00:00
#### Mode-line
2013-11-23 05:46:33 +00:00
The mode line is a [powerline][powerline] customized to show the window
number and the colorized Evil current state.
2013-11-23 05:46:33 +00:00
2014-09-01 04:52:19 +00:00
The color codes for modes are:
Evil State | Color
2014-09-01 04:52:19 +00:00
------------------|------------------
Normal | Orange
Insert | Green
Visual | Grey
Emacs | Red
Motion | Purple
2014-09-01 05:38:11 +00:00
When [Flycheck][flycheck] minor mode is enabled, the mode line color changes
according to the current flycheck state:
2014-09-23 02:17:23 +00:00
![flycheck-error](https://raw.githubusercontent.com/syl20bnr/spacemacs/master/doc/flycheck-error.png)
![flycheck-warning](https://raw.githubusercontent.com/syl20bnr/spacemacs/master/doc/flycheck-warning.png)
![flycheck-info](https://raw.githubusercontent.com/syl20bnr/spacemacs/master/doc/flycheck-info.png)
2014-09-01 05:38:11 +00:00
2014-09-01 04:52:19 +00:00
#### Toggles
2014-09-01 04:27:52 +00:00
Some UI indicators can be toggled on and off (toggles start with `t`):
2013-11-23 05:46:33 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
------------------|------------------------------------------------------------
2014-09-01 04:27:52 +00:00
`<SPC> t 8` | display a mark on the 80th column
`<SPC> t F` | toggle display of the fringe
`<SPC> t n` | show the absolute line numbers
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
### Minor Modes
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
`Spacemacs` uses [diminish][diminish] mode to reduce the size of minor mode
indicators:
2013-11-23 05:46:33 +00:00
The minor mode area can be toggled on and off with:
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
<SPC> t m
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
Lighter | Mode
2014-09-01 06:17:18 +00:00
-------------|-----------------------------------------------------------------
⊞ | [golden-ratio][golden-ratio] mode
2014-09-01 04:27:52 +00:00
Ⓐ | [auto-complete][auto-complete] mode
Ⓗ | [auto-highlight-symbol][auto-highlight] mode
Ⓒ | [centered-cursor][centered-cursor] mode
eⓅ | [e-project][e-project] mode
Ⓟ | [projectile][projectile] mode
Ⓕ | flymake mode
Ⓢ | flyspell mode
(Ⓢ) | [smartparens][sp] mode
(Ⓟ) | paredit mode
Ⓨ | [yasnippet][yasnippet] mode
**Note:** in terminal the regular indicators are used instead of the utf-8
ones.
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
### Line formatting
2013-11-23 05:46:33 +00:00
`Spacemacs` replaces the default `J` Vi key binding (join current line with next
line) by a slightly more frequent action which is to `go to the line below point
and indent it`.
Join lines can still be performed with `<SPC> j k`
2014-09-01 04:27:52 +00:00
Line formatting commands start with `j`:
2013-11-23 05:46:33 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
------------------|------------------------------------------------------------
`J` | go to next line and indent it using auto-indent rules
2014-09-13 03:20:43 +00:00
`<SPC> j j` | same as `J` but will split the current line at point
`<SPC> J` | split a quoted string or s-expression in place
`<SPC> j J` | split a quoted string or s-expression and auto-indent
2014-09-01 04:27:52 +00:00
`<SPC> j k` | join the current line with the next line
2013-11-23 05:46:33 +00:00
Used together these key bindings are very powerful to quickly reformat the code.
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
### Errors handling
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
`Spacemacs` uses [Flycheck][flycheck] to gives error feedback on the fly.
The checks are only performed at save time by default.
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
Errors management commands (star with `f` for `flycheck`):
2013-11-23 05:46:33 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
------------------|------------------------------------------------------------
2014-09-01 04:27:52 +00:00
`<SPC> f c` | clear all errors
`<SPC> f l` | display the `flycheck` list of errors/warnings
`<SPC> f n` | go to the next `flycheck` error
`<SPC> f p` | go to the previous flycheck error
2013-11-23 05:46:33 +00:00
Custom fringe bitmaps:
Symbol | Description
:----------------------------------------------------------------------------------------------:|------------
![dot-error](https://raw.githubusercontent.com/syl20bnr/spacemacs/master/doc/dot-error.png) | Error
![dot-warning](https://raw.githubusercontent.com/syl20bnr/spacemacs/master/doc/dot-warning.png) | warning
![dot-info](https://raw.githubusercontent.com/syl20bnr/spacemacs/master/doc/dot-info.png) | Info
2014-09-01 04:27:52 +00:00
### Project management
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
Projects in `Spacemacs` are managed with [projectile][projectile].
So projects are defined implicitly, for instance the root of a project
is found when a `.git` repository or `.projectile` file is encountered
in the file tree.
Projects management commands (start with `p`):
2014-09-01 06:17:18 +00:00
Key Binding | Description
------------------|------------------------------------------------------------
2014-09-01 04:27:52 +00:00
`<SPC> p C` | invalidate the cache of `projectile`
`<SPC> p d` | open a `dired` buffer at the root of the project
`<SPC> p f` | open a file of the project using `helm`
`<SPC> p F` | find a file if the project using `ido`
`<SPC> p k` | kill all the buffers of the project
`<SPC> p g` | grep search in the project
`<SPC> p r` | replace a string in the files of the project
`<SPC> p s` | switch to a buffer of the project
2013-11-23 05:46:33 +00:00
2014-10-12 04:12:16 +00:00
### Working with Git
Git commands (start with `g`):
Key Binding | Description
------------------|------------------------------------------------------------
`<SPC> g c c` | highlight regions by age of commits
`<SPC> g c C` | clear highlights
`<SPC> g c t` | highlight regions by last updated time
`<SPC> g s` | open a `magit` status window
`<SPC> g m` | display the last commit message of the current line
`<SPC> g t` | launch the git time machine
- Highlight by age of commit or last update time is provided by
[smeargle][smeargle].
- Git time machine is provided by [git-timemachine][git-timemachine].
- Git last commit message per line is provided by
[git-messenger][git-messenger]
#### Magit
`Spacemacs` uses [magit][magit] to manage Git repositories.
2014-10-12 04:21:02 +00:00
To open a `status buffer`, type in a buffer of a Git repository:
2014-10-12 04:12:16 +00:00
<SPC> g s
The buffer is opened in `Emacs state` but you can sill navigate up and down
with `k` and `j` respectively (should be like this in all `magit` buffers).
2014-10-12 04:21:02 +00:00
Here are the often used bindings inside a `status buffer`:
2014-10-12 04:12:16 +00:00
Key Binding | Description
------------------|------------------------------------------------------------
`$` | open `command output buffer`
`c c` | open a `commit message buffer`
`b b` | checkout a branch
2014-10-12 04:21:02 +00:00
`b c` | create a branch
2014-10-12 04:12:16 +00:00
`b v` | open the `branch manager buffer`
`f f` | fetch changes
`F -r F` | pull and rebase
`j` | go down
`k` | go up
`K` | discard changes
`l l` | open `log buffer`
`P P` | push
`q` | quit
`s` | on a file or hunk in a diff: stage the file or hunk
2014-10-12 04:21:02 +00:00
`+` | on a hunk: increase hunk size
`-` | on a hunk: decrease hunk size
2014-10-12 04:12:16 +00:00
`S` | stage all
`TAB` | on a file: expand/collapse diff
`u` | on a staged file: unstage
`U` | unstage all staged files
`z z` | stash changes
In a commit message buffer press `C-c C-c` to commit the changes with the
entered message. `C-c C-k` will discard the commit message.
**Note:** Sometimes you will be asked about reverting the commit buffer,
you can answer `y` with no issue.
#### Quick guide for recurring use cases in Magit
- Amend a commit:
- `l l` to open `log buffer`
- `c a` on the commit you want to amend
2014-10-12 04:21:02 +00:00
- `C-c C-c` to submit the changes
2014-10-12 04:12:16 +00:00
- Squash last commit:
- `l l` to open `log buffer`
- `E` on the second to last commit, it opens the `rebase buffer`
- `j` to put point on last commit
- `i` to pass in `insert state`
- `s` to squash it
- `C-c C-c` to continue to the `commit message buffer`
2014-10-12 04:21:02 +00:00
- `C-c C-c` again when you have finished to edit the commit message
2014-10-12 04:12:16 +00:00
- Force push a squashed commit:
2014-10-12 04:21:02 +00:00
- in the `status buffer` you should see the new commit unpushed and the
old commit unpulled
2014-10-12 04:12:16 +00:00
- `P -f P` for force a push (**beware** usually it is not recommended to
rewrite the history of a public repository, but if you are *sure* that you
are the only one to work on a repository it is ok - i.e. in your fork).
- Add upstream remote (the parent repository you have forked):
- `b v` to open the `branch manager buffer`
- `a` to add a remote, type the name (i.e. `upstream`) and the URL
- Pull changes from upstream (the parent repository you have forked) and push:
- `F -r C-u F` and choose `upstream` or the name you gave to it
- `P P` to push the commit to `origin`
#### Git gutter bitmaps
`Spacemacs` has custom fringe bitmaps for
[git-gutter-fringe][git-gutter]:
Symbol | Description
:-------------------------------------------------------------------------------------------:|-----------------
![git-new](https://raw.githubusercontent.com/syl20bnr/spacemacs/master/doc/git-new-line.png) | new line
![git-del](https://raw.githubusercontent.com/syl20bnr/spacemacs/master/doc/git-del-line.png) | at least one line has been deleted
![git-mod](https://raw.githubusercontent.com/syl20bnr/spacemacs/master/doc/git-mod-line.png) | modified line
2014-10-14 04:22:24 +00:00
### Editing Lisp code
2013-11-23 05:46:33 +00:00
2014-10-14 04:22:24 +00:00
Lisp navigation and edition is performed with a custom evil `lisp state`
provided by [evil-lisp-state][evil-lisp-state] package.
2013-11-23 05:46:33 +00:00
2014-10-14 04:22:24 +00:00
#### Intuitive navigation model
2013-11-23 05:46:33 +00:00
`hjkl` behaves like in the default `normal state`.
2014-10-14 04:26:18 +00:00
**Next sexp on the same level (sibling)**
- `L` next sexp
- `H` previous sexp
2013-11-23 05:46:33 +00:00
2014-10-14 04:26:18 +00:00
**Change level (parent/children)**
- `J` go to next sexp one level down
- `K` go to previous one level up
2013-11-23 05:46:33 +00:00
2014-10-14 04:22:24 +00:00
And that's it! All these commands always put the point _at the beginning_ of
the sexp.
2013-11-23 05:46:33 +00:00
2014-10-14 04:22:24 +00:00
#### Text selection
2013-11-23 05:46:33 +00:00
2014-10-14 04:26:18 +00:00
Text selection is done with [expand-region][expand-region] by pressing `v`.
2014-10-14 04:22:24 +00:00
It is also possible to select the whole line with `V`.
2013-11-23 05:46:33 +00:00
2014-10-14 04:22:24 +00:00
#### Key bindings map
2014-10-06 04:37:56 +00:00
While in `lisp state` (assume that `evil-lisp-state-backward-prefix` is set
2014-10-14 04:22:24 +00:00
to default `<tab>`):
Key Binding | Function
2014-10-06 04:37:56 +00:00
--------------|------------------------------------------------------------
`(` | switch to `insert state` and insert "("
`%` | evil-jump-item (use it to go to the end of sexp)
`$` | sp-end-of-sexp
`0` | sp-beginning-of-sexp
2014-10-15 02:55:04 +00:00
`a` | evil-append
`A` | sp-absorb-sexp
`b` | sp-forward-barf-sexp
2014-10-14 04:22:24 +00:00
`<tab>b` | sp-backward-barf-sexp
`c` | sp-convolute-sexp
2014-10-10 13:55:27 +00:00
`C` | sp-comment
`dd` | sp-kill-hybrid-sexp
`dx` | sp-kill-sexp
2014-10-14 04:22:24 +00:00
`<tab>dx` | sp-backward-kill-sexp
2014-10-10 13:55:27 +00:00
`ds` | sp-kill-symbol
2014-10-14 04:22:24 +00:00
`<tab>ds` | sp-backward-kill-symbol
2014-10-10 13:55:27 +00:00
`dw` | sp-kill-word
2014-10-14 04:22:24 +00:00
`<tab>dw` | sp-backward-kill-word
`D` | evil-delete-line
`gs` | go to source of symbol under point
`h` | next char
`H` | previous sexp at the same level
`i` | evil-insert-state
`j` | next visual line
`J` | next sexp one level down
`k` | previous visual line
`K` | previous sexp one level up
`l` | next char
`L` | next sexp of the same level
2014-10-10 13:55:27 +00:00
`m` | sp-join-sexp (think about `merge-sexp`)
`o` | insert sexp after on the same level and switch to `insert state`
`O` | insert sexp before on the same level and switch to `insert state`
2014-10-10 13:55:27 +00:00
`p` | evil-past-after
`P` | evil-past-before
`r` | sp-raise-sexp
`C-r` | undo-tree-redo
`s` | sp-forward-slurp-sexp
2014-10-14 04:22:24 +00:00
`<tab>s` | sp-backward-slurp-sexp
`S` | sp-splice-sexp-killing-forward
2014-10-14 04:22:24 +00:00
`<tab>S` | sp-splice-sexp-killing-backward
2014-10-10 13:55:27 +00:00
`t` | sp-transpose-sexp
`T` | sp-transpose-hybrid-sexp
`u` | undo-tree-undo
2014-10-14 04:22:24 +00:00
`<tab>U` | sp-backward-unwrap-sexp
`v` | er/expand-region
`V` | select whole line and switch to `visual state`
2014-10-15 02:55:04 +00:00
`w` | wrap sexp
`W` | unwrap sexp
2014-10-14 04:22:24 +00:00
`x$` | evil-lisp-state-eval-sexp-end-of-line
`xf` | eval-defun
`xl` | eval-last-sexp
`xx` | eval-sexp
2014-10-10 13:55:27 +00:00
`y` | sp-copy-sexp
2014-10-14 04:22:24 +00:00
`<tab>y` | sp-backward-copy-sexp
`backspace` | sp-backward-delete-char
`S-backspace` | sp-delete-char
`RET` | sp-newline (stay in `lisp state` see `o` to switch to `insert state`)
`ESC` | evil-normal-state
2014-10-14 04:22:24 +00:00
**Reminder:**
`lisp state` is a [base state](#base-states) which means that leaving
the `insert state` when the previous state was `lisp` will set you back
in `lisp state`.
To go back to `normal state` press `<ESC>` or `fd` while in `lisp state`.
### Modes
`Spacemacs` tries to add more natural Vi key bindings to some modes or
simply add new leader key bindings.
Leader key bindings start with `m` because they are bindings related to
the current `major mode`.
#### Helm
`Spacemacs` add `hjkl` navigation to `helm` buffers:
Key Binding | Description
------------------|------------------------------------------------------------
`CTRL+h` | go to previous page
`CTRL+j` | go to previous item
`CTRL+k` | go to next item
`CTRL+l` | go to next page
#### Erlang
`Spacemacs` uses [EDTS][edts] as an Erlang coding environment.
Key Binding | Description
------------------|------------------------------------------------------------
`<SPC> m d` | show man page documentation
`<SPC> m e` | go to next issue
`<SPC> m g` | go to definition
`<SPC> m G` | find a module in the current project
`<SPC> m h` | open the header file under point
`<SPC> m l` | find a function in the current module
`<SPC> m m` | go to the macro definition under point
`<SPC> m r` | go to the record definition under point
#### Ledger
Key Binding | Description
------------------|------------------------------------------------------------
`<SPC> m a` | add a transaction
`<SPC> m d` | delete current transaction
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
#### Org
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
In `org`, [evil-org-mode][evil-org-mode] is activated.
2013-11-23 05:46:33 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
------------------|------------------------------------------------------------
2014-09-01 04:27:52 +00:00
`gh` | outline-up-heading
`gj` | org-forward-heading-same-level
`gk` | org-backward-heading-same-level
`gl` | outline-next-visible-heading
`t` | org-todo
`T` | org-insert-todo-heading nil
`H` | org-beginning-of-line
`L` | org-end-of-line
`;t` | org-show-todo-tree
`o` | always-insert-item
`O` | org-insert-heading
`$` | org-end-of-line
`^` | org-beginning-of-line
`<` | org-metaleft
`>` | org-metaright
`;a` | org-agenda`
#### Perforce
2013-11-23 05:46:33 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
------------------|------------------------------------------------------------
2014-09-01 04:27:52 +00:00
`<SPC> p 4 a` | add a file in depot
`<SPC> p 4 d` | delete a file in depot
`<SPC> p 4 D` | p4-describe
`<SPC> p 4 e` | checkout a file
`<SPC> p 4 r` | rename a file
`<SPC> p 4 R` | revert a file
`<SPC> p 4 S` | submit CL
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
#### Python
2013-11-23 05:46:33 +00:00
##### Inferior REPL process
2013-11-23 05:46:33 +00:00
Start an iPython inferior REPL process with `<SPC> m i`.
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
Send code to inferior process commands:
2013-11-23 05:46:33 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
------------------|------------------------------------------------------------
2014-09-01 04:27:52 +00:00
`<SPC> m b` | send buffer and keep code buffer focused
`<SPC> m B` | send buffer and switch to REPL in insert mode
2014-09-01 04:27:52 +00:00
`<SPC> m f` | send function and keep code buffer focused
`<SPC> m F` | send function and switch to REPL in insert mode
2014-09-01 04:27:52 +00:00
`<SPC> m r` | send region and keep code buffer focused
`<SPC> m R` | send region and switch to REPL in insert mode
2014-09-01 04:27:52 +00:00
`CTRL+j` | next item in REPL history
`CTRL+k` | previous item in REPL history
##### Testing in Python
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
`Spacemacs` uses [nose][nose] as a test runner. An improved version of
[nose.el][nose.el] is shipped with `Spacemacs`, this version adds:
- windows support
- test suite support
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
The root of the project is detected with a `.git` directory or a `setup.cfg` file.
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
Test commands (start with `m t` or `m T`):
2013-11-23 05:46:33 +00:00
2014-09-01 06:17:18 +00:00
No Debug | Description
------------------|------------------------------------------------------------
2014-09-01 04:27:52 +00:00
<SPC> m t a | launch all tests of the project
<SPC> m t f | launch the current test under point
<SPC> m t m | launch all tests of the current module
<SPC> m t s | launch all tests of the current suite
2014-09-01 04:53:01 +00:00
2014-09-01 06:17:18 +00:00
Debug | Description
------------------|------------------------------------------------------------
2014-09-01 04:27:52 +00:00
<SPC> m T a | launch all tests of the project in debug mode
<SPC> m T f | launch the current test under point in debug mode
<SPC> m T m | launch all tests of the current module in debug mode
<SPC> m T s | launch all tests of the current suite in debug mode
##### Other Python commands
2013-11-23 05:46:33 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
------------------|------------------------------------------------------------
2014-09-01 04:27:52 +00:00
`<SPC> m d` | open documentation in `firefox` using [pylookup][pylookup]
`<SPC> m g` | go to definition using [emacs-jedi][jedi]
`<SPC> m p` | add a breakpoint
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
#### R (ESS)
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
**Important**:
In order to speed up the boot time of `Spacemacs`, `ESS` must be loaded
manually via the key binding:
<SPC> e s s
2013-11-23 05:46:33 +00:00
##### Inferior REPL process
2013-11-23 05:46:33 +00:00
Start an `R` inferior REPL process with `<SPC> m i`.
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
Send code to inferior process commands:
2013-11-23 05:46:33 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
------------------|------------------------------------------------------------
2014-09-01 04:27:52 +00:00
`<SPC> m b` | send buffer and keep code buffer focused
`<SPC> m B` | send buffer and switch to REPL in insert mode
2014-09-01 04:27:52 +00:00
`<SPC> m f` | send function and keep code buffer focused
`<SPC> m F` | send function and switch to REPL in insert mode
2014-09-01 04:27:52 +00:00
`<SPC> m l` | send line and keep code buffer focused
`<SPC> m L` | send line and switch to REPL in insert mode
2014-09-01 04:27:52 +00:00
`<SPC> m r` | send region and keep code buffer focused
`<SPC> m R` | send region and switch to REPL in insert mode
2014-09-01 04:27:52 +00:00
`<SPC> m s` | send region or line and step (debug)
`<SPC> m S` | send function or paragraph and step (debug)
`CTRL+j` | next item in REPL history
`CTRL+k` | previous item in REPL history
##### Other R commands
2013-11-23 05:46:33 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
------------------|------------------------------------------------------------
2014-09-01 04:27:52 +00:00
`<SPC> m p` | object introspection popup [ess-R-object-popup][ess-R-object-popup]
`<SPC> m v p` | view data under point using [ess-R-data-view][ess-R-data-view]
`<SPC> m v t` | view table using [ess-R-data-view][ess-R-data-view]
2013-11-23 05:46:33 +00:00
2014-09-01 04:27:52 +00:00
#### rcirc
2013-11-23 05:46:33 +00:00
2014-09-01 06:17:18 +00:00
Key Binding | Description
------------------|------------------------------------------------------------
2014-09-01 04:27:52 +00:00
`CTRL+j` | next item in command history
`CTRL+k` | previous item in command history
2013-11-23 05:46:33 +00:00
## TODO list
- Add support for [multiple-cursors][multiple-cursors] mode.
2014-09-26 03:10:46 +00:00
## Thank you
2014-10-05 02:53:00 +00:00
[Jokes aside](#contributions), thank you Richard for this great piece of software.
2014-09-26 03:10:46 +00:00
Thank you to the whole Emacs community from core developers to elisp hackers!
2013-11-23 05:46:33 +00:00
[evil]: https://gitorious.org/evil/pages/Home
[evil-leader]: https://github.com/cofi/evil-leader
[RSI]: http://en.wikipedia.org/wiki/Repetitive_strain_injury
[sacha_guide]: http://sachachua.com/blog/2013/05/how-to-learn-emacs-a-hand-drawn-one-pager-for-beginners/
[use-package]: https://github.com/jwiegley/use-package
[keychords]: http://www.emacswiki.org/emacs/KeyChord
[centered-cursor]: http://www.emacswiki.org/emacs/centered-cursor-mode.el
[ace-jump]: https://github.com/winterTTr/ace-jump-mode
[helm]: https://github.com/emacs-helm/helm
[popwin]: http://www.emacswiki.org/emacs/PopWin
[golden-ratio]: https://github.com/roman/golden-ratio.el
[solarized-theme]: https://github.com/bbatsov/solarized-emacs
[powerline]: https://github.com/milkypostman/powerline
[diminish]: http://www.emacswiki.org/emacs/DiminishedModes
[auto-complete]: https://github.com/auto-complete
[auto-highlight]: https://github.com/emacsmirror/auto-highlight-symbol
[e-project]: https://github.com/jrockway/eproject
[projectile]: https://github.com/bbatsov/projectile
[sp]: https://github.com/Fuco1/smartparens
[flycheck]: https://github.com/flycheck
[yasnippet]: https://github.com/capitaomorte/yasnippet
[expand-region]: https://github.com/magnars/expand-region.el
[multiple-cursors]: https://github.com/magnars/multiple-cursors.el
[keybindings]: https://github.com/syl20bnr/vimacs/blob/master/my-keybindings.el
2013-12-13 17:15:03 +00:00
[hswoop]: https://github.com/ShingoFukuyama/helm-swoop
[hcss]: https://github.com/ShingoFukuyama/helm-css-scss
[hyas]: https://github.com/emacs-helm/helm-c-yasnippet
[hthemes]: https://github.com/syohex/emacs-helm-themes
[projectile]: https://github.com/bbatsov/projectile
[hdescbinds]: https://github.com/emacs-helm/helm-descbinds
[hflyspell]: https://gist.github.com/cofi/3013327
2013-12-17 02:11:47 +00:00
[evil-plugin01]: https://github.com/tarao/evil-plugins
[evil-plugin02]: https://github.com/redguardtoo/evil-matchit
[evil-plugin03]: https://github.com/bling/evil-visualstar
[evil-plugin04]: https://github.com/timcharper/evil-surround
2014-08-31 17:11:49 +00:00
[evil-plugin05]: https://github.com/Dewdrops/evil-exchange
2013-12-17 02:15:54 +00:00
[vim-plugin01]: http://www.vim.org/scripts/script.php?script_id=1905
[vim-plugin02]: http://www.vim.org/scripts/script.php?script_id=39
[vim-plugin03]: http://www.vim.org/scripts/script.php?script_id=1697
2014-08-31 17:11:49 +00:00
[vim-plugin04]: https://github.com/tommcdo/vim-exchange
2014-09-01 04:27:52 +00:00
[evil-org-mode]: https://github.com/edwtjo/evil-org-mode
[nose]: https://github.com/nose-devs/nose/
[nose.el]: https://github.com/syl20bnr/nose.el
[pylookup]: https://github.com/tsgates/pylookup
[jedi]: https://github.com/tkf/emacs-jedi
[edts]: https://github.com/tjarvstrand/edts
[ess-R-object-popup]: https://github.com/myuhe/ess-R-object-popup.el
[ess-R-data-view]: https://github.com/myuhe/ess-R-data-view.el
2014-09-01 04:52:45 +00:00
[monokai-theme]: https://github.com/oneKelvinSmith/monokai-emacs
[zenburn-theme]: https://github.com/bbatsov/zenburn-emacs
2014-09-22 01:53:22 +00:00
[git-gutter]: https://github.com/syohex/emacs-git-gutter-fringe
2014-10-12 04:12:16 +00:00
[magit]: http://magit.github.io/
[smeargle]: https://github.com/syohex/emacs-smeargle
[git-timemachine]: https://github.com/pidu/git-timemachine
[git-messenger]: https://github.com/syohex/emacs-git-messenger
[neotree]: http://www.emacswiki.org/emacs/NeoTree
2014-10-14 04:23:54 +00:00
[evil-lisp-state]: https://github.com/syl20bnr/evil-lisp-state
[ido-vertical-mode]: https://github.com/gempesaw/ido-vertical-mode.el