2014-11-22 21:53:38 +00:00
|
|
|
|
# Spacemacs Documentation
|
|
|
|
|
|
2014-11-22 05:45:19 +00:00
|
|
|
|
<!-- markdown-toc start - Don't edit this section. Run M-x markdown-toc/generate-toc again -->
|
|
|
|
|
**Table of Contents**
|
|
|
|
|
|
2014-11-22 21:53:38 +00:00
|
|
|
|
- [Spacemacs Documentation](#spacemacs-documentation)
|
2015-02-09 02:21:23 +00:00
|
|
|
|
- [Core Pillars](#core-pillars)
|
|
|
|
|
- [Mnemonic](#mnemonic)
|
|
|
|
|
- [Discoverability](#discoverability)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Consistency](#consistency)
|
|
|
|
|
- [Crowd-Configured](#crowd-configured)
|
|
|
|
|
- [Goals](#goals)
|
|
|
|
|
- [Screenshots](#screenshots)
|
|
|
|
|
- [Who can benefit from this ?](#who-can-benefit-from-this-)
|
2015-02-09 02:21:23 +00:00
|
|
|
|
- [Update and Rollback](#update-and-rollback)
|
|
|
|
|
- [Update Spacemacs repository](#update-spacemacs-repository)
|
|
|
|
|
- [Update packages](#update-packages)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Configuration layers](#configuration-layers)
|
|
|
|
|
- [Structure](#structure)
|
|
|
|
|
- [Extensions and Packages](#extensions-and-packages)
|
|
|
|
|
- [Declaration](#declaration)
|
|
|
|
|
- [Initialization](#initialization)
|
|
|
|
|
- [Exclusion](#exclusion)
|
|
|
|
|
- [Packages synchronization (Vundle like feature)](#packages-synchronization-vundle-like-feature)
|
|
|
|
|
- [Types of configuration layers](#types-of-configuration-layers)
|
|
|
|
|
- [Submitting a configuration layer upstream](#submitting-a-configuration-layer-upstream)
|
|
|
|
|
- [Example: Themes Megapack example](#example-themes-megapack-example)
|
2014-11-26 03:28:13 +00:00
|
|
|
|
- [Managing private configuration layers](#managing-private-configuration-layers)
|
|
|
|
|
- [Using the private directory](#using-the-private-directory)
|
|
|
|
|
- [Using an external Git repository](#using-an-external-git-repository)
|
|
|
|
|
- [Using a personal branch](#using-a-personal-branch)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Dotfile Configuration](#dotfile-configuration)
|
|
|
|
|
- [Installation](#installation)
|
|
|
|
|
- [Content](#content)
|
2014-11-22 06:17:38 +00:00
|
|
|
|
- [Using configuration layers](#using-configuration-layers)
|
2015-01-26 04:22:41 +00:00
|
|
|
|
- [Setting configuration layers variables](#setting-configuration-layers-variables)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Excluding packages](#excluding-packages)
|
|
|
|
|
- [Hooks](#hooks)
|
|
|
|
|
- [Custom variables](#custom-variables)
|
|
|
|
|
- [Main principles](#main-principles)
|
|
|
|
|
- [Evil](#evil)
|
|
|
|
|
- [States](#states)
|
|
|
|
|
- [Evil leader](#evil-leader)
|
|
|
|
|
- [Universal argument](#universal-argument)
|
2014-12-16 03:57:00 +00:00
|
|
|
|
- [Micro-states](#micro-states)
|
2014-12-16 03:48:27 +00:00
|
|
|
|
- [Differences between Vim, Evil and Spacemacs](#differences-between-vim-evil-and-spacemacs)
|
|
|
|
|
- [The vim-surround case](#the-vim-surround-case)
|
2015-01-10 20:04:00 +00:00
|
|
|
|
- [Evil plugins](#evil-plugins)
|
2015-02-09 02:21:23 +00:00
|
|
|
|
- [Spacemacs UI](#spacemacs-ui)
|
|
|
|
|
- [Graphical UI](#graphical-ui)
|
|
|
|
|
- [Color themes](#color-themes)
|
|
|
|
|
- [Font](#font)
|
|
|
|
|
- [Graphical UI Toggles](#graphical-ui-toggles)
|
|
|
|
|
- [Mode-line](#mode-line)
|
|
|
|
|
- [Flycheck integration](#flycheck-integration)
|
|
|
|
|
- [Anzu integration](#anzu-integration)
|
|
|
|
|
- [Battery status integration](#battery-status-integration)
|
|
|
|
|
- [Powerline separators](#powerline-separators)
|
|
|
|
|
- [Minor Modes](#minor-modes)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Commands](#commands)
|
2015-02-09 02:21:23 +00:00
|
|
|
|
- [Vim key bindings](#vim-key-bindings)
|
|
|
|
|
- [Escaping](#escaping)
|
|
|
|
|
- [Executing Vim and Emacs ex/M-x commands](#executing-vim-and-emacs-exm-x-commands)
|
|
|
|
|
- [Leader key](#leader-key)
|
2014-12-03 05:32:25 +00:00
|
|
|
|
- [Reserved prefix command for user](#reserved-prefix-command-for-user)
|
2015-02-05 04:13:52 +00:00
|
|
|
|
- [Helm](#helm)
|
|
|
|
|
- [Helm micro-state](#helm-micro-state)
|
2015-02-09 02:21:23 +00:00
|
|
|
|
- [Discovering](#discovering)
|
|
|
|
|
- [Key bindings](#key-bindings)
|
|
|
|
|
- [Available layers](#available-layers)
|
|
|
|
|
- [Available packages in Spacemacs](#available-packages-in-spacemacs)
|
|
|
|
|
- [New packages from ELPA repositories](#new-packages-from-elpa-repositories)
|
|
|
|
|
- [Toggles](#toggles)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Navigating](#navigating)
|
|
|
|
|
- [Point/Cursor](#pointcursor)
|
|
|
|
|
- [Smooth scrolling](#smooth-scrolling)
|
|
|
|
|
- [Vim motions with ace-jump mode](#vim-motions-with-ace-jump-mode)
|
|
|
|
|
- [Window manipulation](#window-manipulation)
|
2014-12-03 05:32:25 +00:00
|
|
|
|
- [Resizing windows](#resizing-windows)
|
2014-12-10 01:02:55 +00:00
|
|
|
|
- [Reposition window](#reposition-window)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Golden ratio](#golden-ratio)
|
|
|
|
|
- [Buffers and Files](#buffers-and-files)
|
2015-01-01 06:09:33 +00:00
|
|
|
|
- [Emacs and Spacemacs files](#emacs-and-spacemacs-files)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Ido](#ido)
|
|
|
|
|
- [NeoTree file tree](#neotree-file-tree)
|
2015-01-01 06:00:56 +00:00
|
|
|
|
- [NeoTree navigation](#neotree-navigation)
|
|
|
|
|
- [Opening files with NeoTree](#opening-files-with-neotree)
|
|
|
|
|
- [Other NeoTree key bindings](#other-neotree-key-bindings)
|
|
|
|
|
- [NeoTree mode-line](#neotree-mode-line)
|
2014-12-06 06:31:56 +00:00
|
|
|
|
- [Shells](#shells)
|
2014-12-12 04:49:49 +00:00
|
|
|
|
- [Key bindings](#key-bindings)
|
|
|
|
|
- [Staying in insert state](#staying-in-insert-state)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Bookmarks](#bookmarks)
|
2015-01-23 06:57:17 +00:00
|
|
|
|
- [DocView mode](#docview-mode)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Searching](#searching)
|
2014-11-28 00:24:56 +00:00
|
|
|
|
- [Project Searching](#project-searching)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Persistent highlighting](#persistent-highlighting)
|
|
|
|
|
- [Stacking highlights](#stacking-highlights)
|
2014-12-02 21:27:27 +00:00
|
|
|
|
- [Highlight current symbol](#highlight-current-symbol)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Visual Star](#visual-star)
|
|
|
|
|
- [Listing symbols by semantic](#listing-symbols-by-semantic)
|
|
|
|
|
- [Helm-swoop](#helm-swoop)
|
|
|
|
|
- [Editing](#editing)
|
|
|
|
|
- [Text manipulation commands](#text-manipulation-commands)
|
2014-12-13 05:50:25 +00:00
|
|
|
|
- [Smartparens Strict mode](#smartparens-strict-mode)
|
2014-12-13 06:05:09 +00:00
|
|
|
|
- [Zooming](#zooming)
|
|
|
|
|
- [Text](#text)
|
|
|
|
|
- [Frame](#frame)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Increase/Decrease numbers](#increasedecrease-numbers)
|
|
|
|
|
- [Spell checking](#spell-checking)
|
|
|
|
|
- [Region selection](#region-selection)
|
2014-12-23 03:15:49 +00:00
|
|
|
|
- [Expand-region](#expand-region)
|
|
|
|
|
- [Indent text object](#indent-text-object)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Region narrowing](#region-narrowing)
|
|
|
|
|
- [Line formatting](#line-formatting)
|
|
|
|
|
- [Auto-completion](#auto-completion)
|
2014-12-18 02:26:52 +00:00
|
|
|
|
- [Replacing text with iedit](#replacing-text-with-iedit)
|
|
|
|
|
- [iedit states key bindings](#iedit-states-key-bindings)
|
|
|
|
|
- [State transitions](#state-transitions)
|
|
|
|
|
- [In iedit state](#in-iedit-state)
|
|
|
|
|
- [In iedit-insert state](#in-iedit-insert-state)
|
|
|
|
|
- [Examples](#examples)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Commenting](#commenting)
|
2014-11-29 03:47:03 +00:00
|
|
|
|
- [Deleting files](#deleting-files)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Editing Lisp code](#editing-lisp-code)
|
2015-01-21 04:05:56 +00:00
|
|
|
|
- [Lisp state Key Bindings](#lisp-state-key-bindings)
|
|
|
|
|
- [Lisp state Auto-switch commands](#lisp-state-auto-switch-commands)
|
2015-01-21 04:27:46 +00:00
|
|
|
|
- [Lisp state commands](#lisp-state-commands)
|
2015-01-21 04:05:56 +00:00
|
|
|
|
- [Lisp state Other commands](#lisp-state-other-commands)
|
2015-02-09 02:21:23 +00:00
|
|
|
|
- [Managing projects](#managing-projects)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Registers](#registers)
|
|
|
|
|
- [Errors handling](#errors-handling)
|
2014-12-05 05:02:26 +00:00
|
|
|
|
- [Compiling](#compiling)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Modes](#modes)
|
2014-12-19 05:35:14 +00:00
|
|
|
|
- [Major Mode leader key](#major-mode-leader-key)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Helm](#helm)
|
|
|
|
|
- [Org](#org)
|
|
|
|
|
- [Python](#python)
|
|
|
|
|
- [JavaScript](#javascript)
|
|
|
|
|
- [rcirc](#rcirc)
|
2014-12-18 02:26:52 +00:00
|
|
|
|
- [HTML and CSS](#html-and-css)
|
2014-12-13 05:50:25 +00:00
|
|
|
|
- [Emacs Server](#emacs-server)
|
|
|
|
|
- [Connecting to the Emacs server](#connecting-to-the-emacs-server)
|
|
|
|
|
- [Keeping the server alive](#keeping-the-server-alive)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Troubleshoot](#troubleshoot)
|
|
|
|
|
- [Loading fails](#loading-fails)
|
|
|
|
|
- [I have no file ~/.spacemacs](#i-have-no-file-spacemacs)
|
2015-01-01 06:15:34 +00:00
|
|
|
|
- [Tips](#tips)
|
|
|
|
|
- [evil-lisp-state as default state](#evil-lisp-state-as-default-state)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- [Achievements](#achievements)
|
|
|
|
|
- [Thank you](#thank-you)
|
|
|
|
|
|
|
|
|
|
<!-- markdown-toc end -->
|
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
# Core Pillars
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
Four core pillars: Mnemonic, Discoverability, Consistency, "Crowd-Configured".
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
If any of these core pillars is violated open an issue and we'll fix it.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
## Mnemonic
|
|
|
|
|
|
|
|
|
|
`Spacemacs` organizes key bindings by mnemonic namespaces as much as possible.
|
|
|
|
|
If you are looking for commands to operate on your buffer, they are right under
|
|
|
|
|
<kbd>SPC b</kbd>, if you want to operate on your project, then it is
|
|
|
|
|
<kbd>SPC p</kbd>, etc...
|
|
|
|
|
|
|
|
|
|
## Discoverability
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
`Spacemacs` comes with a dedicated major mode `spacemacs-mode`. Its goal is to
|
2015-02-09 02:21:23 +00:00
|
|
|
|
give useful feedbacks and easily perform maintenance tasks.
|
|
|
|
|
|
|
|
|
|
It also comes with dedicated [helm][] sources to quickly find layers, packages
|
|
|
|
|
and more.
|
|
|
|
|
|
|
|
|
|
[guide-key][] is enabled by default, it will display all the available key
|
|
|
|
|
bindings in a dedicated popup buffer.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
## Consistency
|
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
Similar functionalities should have the same key binding no matter which major
|
|
|
|
|
is currently active. For instance if you are looking for the definition of a
|
|
|
|
|
function, the binding is <kbd>SPC m g g</kbd>, `m` for `major mode` and `g g`
|
|
|
|
|
for `go to thing at point`. No matter what is the major mode it is the same
|
|
|
|
|
binding to perform this action.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
This is also true for the documentation, each configuration layer comes with
|
|
|
|
|
an associated `README.md` file with the same base layout.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
The consistency core pillar is supported by a convention file:
|
|
|
|
|
[CONVENTIONS.md][]
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
## Crowd-Configured
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
By defining an very light structure called `configuration layer` which is easy
|
|
|
|
|
to understand, `Spacemacs` makes it easy to contribute additional support.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
The conventions in [CONVENTIONS.md][] make it easy to get the spacemacs way
|
|
|
|
|
and keep consistency even if there are a lot of contributions.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
`Crowd-configuration` is the most powerful pillar of `Spacemacs`. Anybody can
|
|
|
|
|
submit upstream improvements to configuration layers or a whole new one. Any
|
|
|
|
|
user can easily and directly use this layer by adding it to a list in a
|
|
|
|
|
dotfile. It is even possible to exclude _any_ unwanted packages.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
# Goals
|
|
|
|
|
|
|
|
|
|
- **Bring the power of modal editing** to the powerful Emacs editing platform.
|
|
|
|
|
|
|
|
|
|
- Integrate nicely with `Evil` states (`Vim` modes): `Spacemacs` tries to
|
|
|
|
|
**keep your fingers on the home row** as much as possible, no matter the mode
|
|
|
|
|
you are in.
|
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
- **Crowed-configured**: Contribute easily your improvements and new
|
|
|
|
|
configuration layers.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
- **Minimalistic and nice graphical UI**, keep your available screen space for
|
|
|
|
|
what matters: your text files.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
- **Mnemonic and consistent key bindings** which should be easier to learn
|
2015-02-09 02:21:23 +00:00
|
|
|
|
and remember and be the same in all major modes.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
- **Fast boot time**, everything is lazy-loaded.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
- **Lower the risk of RSI** by heavily using the space bar instead of modifiers.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
- Hopefully, if it's not already the case:
|
|
|
|
|
|
|
|
|
|
Ɛ>Ɛ>Ɛ> **make you love modal editing!** <3<3<3
|
|
|
|
|
|
|
|
|
|
# Screenshots
|
|
|
|
|
|
|
|
|
|
_Startup_
|
2014-12-12 00:55:44 +00:00
|
|
|
|
![spacemacs_startup](img/spacemacs-startup.png)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
_Python_
|
2014-12-12 00:55:44 +00:00
|
|
|
|
![spacemacs_python](img/spacemacs-python.png)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
_Terminal (urxvt)_
|
2014-12-12 00:55:44 +00:00
|
|
|
|
![spacemacs_urxvt](img/spacemacs-urxvt.png)
|
2014-11-22 05:45:19 +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.*
|
|
|
|
|
|
|
|
|
|
# Who can benefit from this ?
|
|
|
|
|
|
|
|
|
|
`Spacemacs` is first intended to be used by **Vim users** who want to go to the
|
|
|
|
|
next level by using Emacs.
|
|
|
|
|
|
|
|
|
|
It is also a good fit for people wanting to **lower the [risk of RSI][RSI]**
|
2015-02-09 02:21:23 +00:00
|
|
|
|
induced by the default Emacs key bindings (this is an assumption, there is no
|
|
|
|
|
official studies to prove this).
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
Emacs users wanting to learn **a different way to edit files** or wanting to
|
2015-01-18 04:40:31 +00:00
|
|
|
|
learn Vim key bindings.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
As a side note, 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.
|
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
# Update and Rollback
|
|
|
|
|
|
|
|
|
|
For now it is still needed to update the `Spacemacs` repository manually.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
## Update Spacemacs repository
|
|
|
|
|
|
|
|
|
|
Close Emacs and update the git repository:
|
|
|
|
|
|
|
|
|
|
```sh
|
|
|
|
|
git pull --rebase
|
|
|
|
|
git submodule sync; git submodule update
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
**Note** It is recommended to update the packages first, see next session.
|
|
|
|
|
|
|
|
|
|
## Update packages
|
|
|
|
|
|
|
|
|
|
To update `Spacemacs` press <kbd>RET</kbd> (enter) or click on the link
|
|
|
|
|
`[Update]` in the startup page under the banner then restart Emacs.
|
|
|
|
|
|
|
|
|
|
If anything goes wrong you should be able to rollback the update by pressing
|
|
|
|
|
<kbd>RET</kbd> or clicking on the `[Rollback]` link next to the `[Update]`
|
|
|
|
|
link and choose a rollback slot (sorted by date).
|
|
|
|
|
|
|
|
|
|
# Configuration layers
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
## 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 generally elisp code from git submodules.
|
|
|
|
|
|
|
|
|
|
## Extensions and Packages
|
|
|
|
|
|
|
|
|
|
### Declaration
|
|
|
|
|
|
|
|
|
|
`Extensions` and `Packages` are declared 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 `eval-after-load` black magic.
|
|
|
|
|
|
|
|
|
|
Example:
|
|
|
|
|
|
|
|
|
|
```elisp
|
|
|
|
|
(defvar <layer>-packages
|
|
|
|
|
'(
|
|
|
|
|
package1
|
|
|
|
|
package2
|
|
|
|
|
)
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### Initialization
|
|
|
|
|
|
|
|
|
|
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
|
|
|
|
|
)
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
It is common to define the body with the [use-package][use-package] macro.
|
|
|
|
|
|
|
|
|
|
### Exclusion
|
|
|
|
|
|
|
|
|
|
It is possible to exclude some packages from `Spacemacs` in a per layer basis.
|
|
|
|
|
This is useful when a configuration layer aims to replace a stock package
|
|
|
|
|
declared in the `Spacemacs` layer.
|
|
|
|
|
|
|
|
|
|
To do so add the package names to exclude to the variable
|
|
|
|
|
`<layer>-excluded-packages`.
|
|
|
|
|
|
|
|
|
|
Example:
|
|
|
|
|
|
|
|
|
|
```elisp
|
|
|
|
|
(defvar <layer>-excluded-packages
|
|
|
|
|
'(
|
|
|
|
|
package1
|
|
|
|
|
)
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## Packages synchronization (Vundle like feature)
|
|
|
|
|
|
|
|
|
|
`Spacemacs` features a synchronization engine for the ELPA packages. It means
|
|
|
|
|
that `Spacemacs` will auto-install the new packages in `<layer>-packages` lists
|
|
|
|
|
_and_ auto-delete orphan packages in your `elpa` directory.
|
|
|
|
|
|
2015-01-22 23:34:36 +00:00
|
|
|
|
It effectively makes `Spacemacs` behave like [Vundle][vundle].
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
## Types of configuration layers
|
|
|
|
|
|
|
|
|
|
There are three types of configuration layers:
|
|
|
|
|
- core (this is the `Spacemacs` layer)
|
|
|
|
|
- private (in the `private` directory, they are ignored by Git)
|
|
|
|
|
- contrib (in the `contrib` directory, those layers are contributions shared by
|
|
|
|
|
the community and merged upstream).
|
|
|
|
|
|
|
|
|
|
## Submitting a configuration layer upstream
|
|
|
|
|
|
|
|
|
|
If you decide to provide a `contrib` configuration layer, please check
|
|
|
|
|
the contribution guidelines in [CONTRIBUTE.md][].
|
|
|
|
|
|
|
|
|
|
## Example: Themes Megapack example
|
|
|
|
|
|
|
|
|
|
This is a simple `contrib` configuration layer listing a bunch of themes,
|
|
|
|
|
you can find it [here][themes-megapack].
|
|
|
|
|
|
2014-12-05 06:34:56 +00:00
|
|
|
|
To install it, just add `themes-megapack` to your `~/.spacemacs` like so:
|
|
|
|
|
|
|
|
|
|
```elisp
|
|
|
|
|
dotspacemacs-configuration-layers '(themes-megapack)
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
You have now installed around 100 themes you are free to try with <kbd>SPC T h</kbd>
|
2014-11-27 16:02:18 +00:00
|
|
|
|
(helm-themes).
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-11-26 03:28:13 +00:00
|
|
|
|
## Managing private configuration layers
|
|
|
|
|
|
|
|
|
|
`Spacemacs` configuration system is flexible enough to let you manage your
|
|
|
|
|
private layers in different ways.
|
|
|
|
|
|
|
|
|
|
### Using the private directory
|
|
|
|
|
|
|
|
|
|
Everything in the private directory is ignored by Git so it is a good place
|
|
|
|
|
to store private layers. There is a huge drawback to this approach though:
|
|
|
|
|
_your layers are not source controlled_.
|
|
|
|
|
|
|
|
|
|
### Using an external Git repository
|
|
|
|
|
|
|
|
|
|
This is the recommended way to manage your private layers.
|
|
|
|
|
|
|
|
|
|
The best approach is to store all your private layers into an external Git
|
|
|
|
|
repository. It is especially a good practice to store them in your `dotfiles`
|
2014-11-27 23:05:36 +00:00
|
|
|
|
repository if you have one. Put also your `~/.spacemacs` file in it.
|
2014-11-26 03:28:13 +00:00
|
|
|
|
|
|
|
|
|
Then you are free to symlink your layers into `~/emacs.d/private` _or_ let
|
|
|
|
|
them anywhere you want and reference the parent directory in the variable
|
|
|
|
|
`dotspacemacs-configuration-layer-path` of your `~/.spacemacs`.
|
|
|
|
|
|
|
|
|
|
Note that you could also have a dedicated repository for all your private
|
|
|
|
|
layers and then directly clone this repository in `~/.emacs.d/private`.
|
|
|
|
|
|
|
|
|
|
### Using a personal branch
|
|
|
|
|
|
2014-11-27 23:05:36 +00:00
|
|
|
|
The final main way to manage your private layers is to push them in a personal
|
2014-11-26 03:28:13 +00:00
|
|
|
|
branch that you keep up to date with upstream `master` or `develop`.
|
|
|
|
|
|
2014-11-22 05:45:19 +00:00
|
|
|
|
# Dotfile Configuration
|
|
|
|
|
|
|
|
|
|
User configuration can be stored in your `~/.spacemacs` file.
|
|
|
|
|
|
|
|
|
|
## Installation
|
|
|
|
|
|
|
|
|
|
`~/.spacemacs` is an optional file. If you want to use it you have to copy it
|
2014-12-02 01:05:51 +00:00
|
|
|
|
manually from the template file `~/.emacs.d/core/templates/.spacemacs.template`
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
```sh
|
2014-12-02 01:05:51 +00:00
|
|
|
|
$ cp ~/.emacs.d/core/templates/.spacemacs.template ~/.spacemacs
|
2014-11-22 05:45:19 +00:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## Content
|
|
|
|
|
|
2014-11-22 06:17:38 +00:00
|
|
|
|
### Using configuration layers
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-11-22 06:17:38 +00:00
|
|
|
|
To use a configuration layer, add it to the `dotspacemacs-configuration-layers`
|
2014-11-22 05:45:19 +00:00
|
|
|
|
variable of your `~/.spacemacs`.
|
|
|
|
|
|
|
|
|
|
For instance to add the configuration layer of [RMS](#thank-you):
|
|
|
|
|
```elisp
|
|
|
|
|
(setq-default dotspacemacs-configuration-layers '(rms))
|
|
|
|
|
```
|
|
|
|
|
If this layer does not exist you can still try another one in
|
2015-01-26 04:22:41 +00:00
|
|
|
|
[the `contrib` directory](../contrib).
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-11-22 06:17:38 +00:00
|
|
|
|
Configuration layers are expected to be stored in `~/.emacs.d/private` or
|
|
|
|
|
`~/.emacs.d/contrib`. But you are free to keep them somewhere else by declaring
|
|
|
|
|
additional paths where `Spacemacs` can look for configuration layers.
|
|
|
|
|
This is done by setting the list
|
2014-11-22 05:45:19 +00:00
|
|
|
|
`dotspacemacs-configuration-layer-path` in your `~/.spacemacs`:
|
|
|
|
|
|
|
|
|
|
```elisp
|
2014-11-22 06:17:38 +00:00
|
|
|
|
(setq-default dotspacemacs-configuration-layer-path '("~/.myconfig/"))
|
2014-11-22 05:45:19 +00:00
|
|
|
|
```
|
|
|
|
|
|
2015-01-26 04:22:41 +00:00
|
|
|
|
### Setting configuration layers variables
|
|
|
|
|
|
|
|
|
|
Some configuration layers have configuration variables to enable specific
|
|
|
|
|
support. For instance the [git layer][] has several configuration variables,
|
|
|
|
|
they can be set directly in the `dotspacemacs-configuration-layers` like this:
|
|
|
|
|
|
|
|
|
|
```elisp
|
|
|
|
|
;; List of configuration layers to load.
|
|
|
|
|
dotspacemacs-configuration-layers '(company-mode
|
|
|
|
|
(git :variables
|
|
|
|
|
git-magit-status-fullscreen t
|
|
|
|
|
git-enable-github-support t
|
|
|
|
|
git-gutter-use-fringe t)
|
|
|
|
|
smex)
|
|
|
|
|
```
|
|
|
|
|
|
2014-11-22 05:45:19 +00:00
|
|
|
|
### Excluding packages
|
|
|
|
|
|
|
|
|
|
You can exclude packages you don't want to install with the variable
|
|
|
|
|
`dotspacemacs-excluded-packages`, this variable can exclude both packages and
|
|
|
|
|
extensions (see [Configuration layers](#configuration-layers) for more info
|
|
|
|
|
on packages and extensions).
|
|
|
|
|
|
|
|
|
|
For instance to disable the `rainbow-delimiters` package:
|
|
|
|
|
```elisp
|
|
|
|
|
(setq-default dotspacemacs-excluded-packages '(rainbow-delimiters))
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
When you exclude a package, `Spacemacs` will automatically delete it for you
|
|
|
|
|
the next time you launch Emacs. All the orphan dependencies are as well
|
|
|
|
|
delete automatically.
|
|
|
|
|
|
|
|
|
|
### Hooks
|
|
|
|
|
|
|
|
|
|
Two special functions of the `~/.spacemacs` file can be used to perform
|
|
|
|
|
configuration at the beginning and end of `Spacemacs` loading process.
|
|
|
|
|
|
|
|
|
|
- `dotspacemacs/init` is triggered at the very beginning of `Spacemacs`
|
|
|
|
|
loading.
|
|
|
|
|
- `dotspacemacs/config` is triggered at the very end of `Spacemacs` loading.
|
|
|
|
|
|
|
|
|
|
### Custom variables
|
|
|
|
|
|
|
|
|
|
Custom variables configuration from `M-x customize-group` which are
|
|
|
|
|
automatically saved by Emacs are stored at the end of your `~/.spacemacs`
|
|
|
|
|
file.
|
|
|
|
|
|
|
|
|
|
# Main principles
|
|
|
|
|
|
|
|
|
|
## Evil
|
|
|
|
|
|
|
|
|
|
`Spacemacs` uses the [evil][evil] mode to emulate Vim key bindings. It is a
|
|
|
|
|
very complete emulation, maybe the most advanced. In fact, Evil is much more
|
|
|
|
|
than just a Vim emulation. It has more states than Vim for instance.
|
|
|
|
|
|
|
|
|
|
### States
|
|
|
|
|
|
2014-12-18 02:26:52 +00:00
|
|
|
|
`Spacemacs` has 8 states:
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
- **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
|
|
|
|
|
- **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-12-18 02:26:52 +00:00
|
|
|
|
modify it (see [Editing Lisp code](#editing-lisp-code))
|
|
|
|
|
- **Iedit** (red) - exclusive to `Spacemacs`, used to navigate between multiple
|
|
|
|
|
regions of text using `iedit`
|
|
|
|
|
(see [Replacing text with iedit](#replacing-text-with-iedit))
|
|
|
|
|
- **Iedit Insert** (red) - exclusive to `Spacemacs`, used to replace multiple
|
|
|
|
|
regions of text using `iedit`
|
|
|
|
|
(see [Replacing text with iedit](#replacing-text-with-iedit))
|
|
|
|
|
|
|
|
|
|
Note: Technically speaking there are also the `operator` and `replace` evil
|
|
|
|
|
states.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
## Evil leader
|
|
|
|
|
|
|
|
|
|
`Spacemacs` heavily uses the [evil-leader][evil-leader] mode which brings the
|
|
|
|
|
Vim leader key to the Emacs world.
|
|
|
|
|
|
|
|
|
|
This leader key is commonly set to `,` by Vim users, in `Spacemacs` the leader
|
2014-11-27 16:02:18 +00:00
|
|
|
|
key is set on <kbd>SPC</kbd> (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-11-22 05:45:19 +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
|
2014-11-27 16:02:18 +00:00
|
|
|
|
while you are in `normal` mode by pressing the <kbd>SPC</kbd> leader key,
|
|
|
|
|
here are a few examples:
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
- Save a buffer: <kbd>SPC f s</kbd>
|
|
|
|
|
- Save all opened buffers: <kbd>SPC f S</kbd>
|
|
|
|
|
- Open (switch) to a buffer with `helm`: <kbd>SPC b s</kbd>
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
## Universal argument
|
|
|
|
|
|
|
|
|
|
The universal argument `C-u` is an important command in Emacs but it is also
|
|
|
|
|
a very handy Vim key binding to scroll up.
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
`Spacemacs` binds <kbd>C-u</kbd> to `scroll-up` and change the universal
|
|
|
|
|
argument binding to <kbd>SPC u</kbd>.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-12-16 03:57:00 +00:00
|
|
|
|
## Micro-states
|
|
|
|
|
|
|
|
|
|
`Spacemacs` defines a wide variety of `micro-states` (temporary overlay maps)
|
2015-01-21 07:01:05 +00:00
|
|
|
|
where it makes sense. This prevents one from doing repetitive and tedious presses on the
|
2014-12-16 03:57:00 +00:00
|
|
|
|
<kbd>SPC</kbd> key.
|
|
|
|
|
|
|
|
|
|
When a `micro-state` is active, a documentation is displayed in the minibuffer.
|
|
|
|
|
Additional information may as well be displayed in the minibuffer.
|
|
|
|
|
|
|
|
|
|
[Auto-highlight-symbol micro-state](#auto-highlight-and-edition-of-symbols):
|
|
|
|
|
![spacemacs_ahs_micro_state](img/spacemacs-ahs-micro-state.png)
|
|
|
|
|
|
|
|
|
|
[Text scale micro-state](#change-font-size):
|
|
|
|
|
![spacemacs_scale_micro_state](img/spacemacs-scale-micro-state.png)
|
|
|
|
|
|
2014-12-16 03:48:27 +00:00
|
|
|
|
# Differences between Vim, Evil and Spacemacs
|
|
|
|
|
|
|
|
|
|
No doubt that `Evil` is one of the most advanced `Vim` emulation and you should
|
|
|
|
|
not see big difference between `Vim` and `Emacs`. I did not find any command I
|
2014-12-16 03:57:00 +00:00
|
|
|
|
used in Vim that I missed in Emacs with `Evil`.
|
2014-12-16 03:48:27 +00:00
|
|
|
|
|
|
|
|
|
Send a PR to add the differences you found in this section.
|
|
|
|
|
|
|
|
|
|
## The vim-surround case
|
|
|
|
|
|
2014-12-16 03:57:00 +00:00
|
|
|
|
There is one obvious visible difference though. It is not between `Evil` and
|
|
|
|
|
`Vim` but between `Spacemacs` and [vim-surround][]: the `surround` command is
|
|
|
|
|
on <kbd>S</kbd> in `vim-surround` whereas it is on <kbd>s</kbd> in `Spacemacs`.
|
2014-12-16 03:48:27 +00:00
|
|
|
|
|
|
|
|
|
This is something that can surprise some Vim users so let me explain why this is
|
|
|
|
|
the case:
|
|
|
|
|
- `s` and `c` do the same thing in `visual state`,
|
|
|
|
|
- `s` is only useful to delete _one_ character and add more than one character
|
|
|
|
|
which is a _very_ narrow use case,
|
|
|
|
|
- `c` accept motions and can do everything `s` can do in `normal state`,
|
|
|
|
|
- this is also true for `r` but `r` is more useful because it stays in
|
|
|
|
|
`normal state`.
|
|
|
|
|
- `surround` command is just a more powerful command that `s`
|
|
|
|
|
|
|
|
|
|
If you are not convinced, then here is the snippet to revert back to the default
|
|
|
|
|
`Vim + vim-surround` setup (add it to your `dotspacemacs/config` function or
|
|
|
|
|
your `~/.spacemacs`):
|
|
|
|
|
|
|
|
|
|
```elisp
|
|
|
|
|
(evil-define-key 'visual evil-surround-mode-map "s" 'evil-substitute)
|
|
|
|
|
(evil-define-key 'visual evil-surround-mode-map "S" 'evil-surround-region)
|
|
|
|
|
```
|
|
|
|
|
|
2015-01-10 20:04:00 +00:00
|
|
|
|
# Evil plugins
|
|
|
|
|
|
|
|
|
|
`Spacemacs` ships with the following evil plugins:
|
|
|
|
|
|
|
|
|
|
Mode | Description
|
|
|
|
|
----------------------------------------|--------------------------------------
|
|
|
|
|
[evil-leader][] | vim leader that bring a new layer of keys in normal mode
|
|
|
|
|
[evil-indent-textobject][] | add text object based on indentation level
|
|
|
|
|
[evil-visualstar][] | search for current selection with `*`
|
|
|
|
|
[evil-exchange][] | port of [vim-exchange][]
|
|
|
|
|
[evil-surround][] | port of [vim-surround][]
|
2015-01-16 04:45:53 +00:00
|
|
|
|
[evil-matchit][] | port of [matchit.vim][]
|
2015-01-10 20:04:00 +00:00
|
|
|
|
[evil-nerd-commenter][] | port of [nerdcommenter][]
|
|
|
|
|
[evil-search-highlight-persist][] | emulation of hlsearch behavior
|
|
|
|
|
[evil-numbers][] | like C-a/C-x in vim
|
|
|
|
|
[evil-args][] | motions and text objects for arguments
|
|
|
|
|
[evil-jumper][] | jump list emulation
|
|
|
|
|
[NeoTree][neotree] | mimic [NERD Tree][nerdtree]
|
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
# Spacemacs UI
|
|
|
|
|
|
|
|
|
|
`Spacemacs` has unique UI elements to make the Emacs experience even
|
|
|
|
|
more enjoyable:
|
|
|
|
|
- dedicated startup page with a mode aimed at easily managing `Spacemacs`
|
|
|
|
|
- dedicated helm source via `helm-spacemacs`
|
|
|
|
|
- a [guide-key][] buffer
|
|
|
|
|
|
|
|
|
|
## Graphical UI
|
|
|
|
|
|
|
|
|
|
`Spacemacs` has a minimalistic and distraction free graphical UI:
|
|
|
|
|
- custom [powerline][powerline] mode-line
|
|
|
|
|
[with color feedback](#flycheck-integration) 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]
|
|
|
|
|
- [custom fringe bitmaps](../contrib/git/README.md#git-gutter-bitmaps) for
|
|
|
|
|
git gutter (available in [git layer][])
|
|
|
|
|
|
|
|
|
|
### Color themes
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-11-28 04:14:51 +00:00
|
|
|
|
By default, `Spacemacs` uses the theme [solarized-light][solarized-theme].
|
|
|
|
|
|
2015-01-24 03:02:08 +00:00
|
|
|
|
It is possible to define your default themes in your `~/.spacemacs` with
|
|
|
|
|
the variable `dotspacemacs-themes`. For instance, to specify `leuven` and
|
|
|
|
|
`zenburn` (high contract theme and low contrast theme):
|
2014-11-28 04:14:51 +00:00
|
|
|
|
|
|
|
|
|
```elisp
|
2015-01-24 03:02:08 +00:00
|
|
|
|
(setq-default dotspacemacs-themes '(leuven zenburn))
|
2014-11-28 04:14:51 +00:00
|
|
|
|
```
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-11-30 16:48:22 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
---------------------|------------------------------------------------------------
|
2015-01-24 03:02:08 +00:00
|
|
|
|
<kbd>SPC T n</kbd> | switch to next theme listed in `dotspacemacs-themes`.
|
2015-01-25 08:36:28 +00:00
|
|
|
|
<kbd>SPC T h</kbd> | select a theme using a `helm` buffer.
|
2014-11-30 16:48:22 +00:00
|
|
|
|
|
|
|
|
|
**Note:** Due to the inner working of themes in Emacs, switching theme during
|
|
|
|
|
the same session may have some weird side effects. Although these side effects
|
2015-01-24 03:02:08 +00:00
|
|
|
|
should be pretty rare.
|
2014-11-30 16:48:22 +00:00
|
|
|
|
|
2015-01-24 03:02:08 +00:00
|
|
|
|
**Hint** If you are an `Org` user, [leuven-theme][] is amazing ;-)
|
2014-12-02 05:11:47 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
### Font
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
The default font used by `Spacemacs` is [source code pro][] by Adobe. It is
|
|
|
|
|
recommended to install it on your system.
|
|
|
|
|
|
|
|
|
|
To change the default font set the variable `dotspacemacs-default-font` in
|
|
|
|
|
your `.spacemacs` file.
|
|
|
|
|
|
|
|
|
|
By default its value is:
|
|
|
|
|
|
|
|
|
|
```elisp
|
|
|
|
|
(setq-default dotspacemacs-default-font '("Source Code Pro"
|
|
|
|
|
:size 13
|
|
|
|
|
:weight normal
|
|
|
|
|
:width normal
|
|
|
|
|
:powerline-scale 1.1))
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
The properties should be pretty straightforward, it is possible to set any
|
|
|
|
|
valid property of a [font-spec][]:
|
|
|
|
|
- `:family` Font family or fontset (a string).
|
|
|
|
|
- `:width` Relative character width. This should be one of the symbols:
|
|
|
|
|
- ultra-condensed
|
|
|
|
|
- extra-condensed
|
|
|
|
|
- condensed
|
|
|
|
|
- semi-condensed
|
|
|
|
|
- normal
|
|
|
|
|
- semi-expanded
|
|
|
|
|
- expanded
|
|
|
|
|
- extra-expanded
|
|
|
|
|
- ultra-expanded
|
|
|
|
|
- `:height` The height of the font. In the simplest case, this is an integer in
|
|
|
|
|
units of 1/10 point.
|
|
|
|
|
- `:weight` Font weight—one of the symbols (from densest to faintest):
|
|
|
|
|
- ultra-bold
|
|
|
|
|
- extra-bold
|
|
|
|
|
- bold
|
|
|
|
|
- semi-bold
|
|
|
|
|
- normal
|
|
|
|
|
- semi-light
|
|
|
|
|
- light
|
|
|
|
|
- extra-light
|
|
|
|
|
- ultra-light
|
|
|
|
|
- `:slant` Font slant—one of the symbols:
|
|
|
|
|
- italic
|
|
|
|
|
- oblique
|
|
|
|
|
- normal
|
|
|
|
|
- reverse-italic
|
|
|
|
|
- reverse-oblique
|
|
|
|
|
- `:size` The font size—either a non-negative integer that specifies the pixel
|
|
|
|
|
size, or a floating-point number that specifies the point size.
|
|
|
|
|
- `:adstyle` Additional typographic style information for the font, such as
|
|
|
|
|
‘sans’. The value should be a string or a symbol.
|
|
|
|
|
- `:registry` The charset registry and encoding of the font, such as
|
|
|
|
|
‘iso8859-1’. The value should be a string or a symbol.
|
|
|
|
|
- `:script` The script that the font must support (a symbol).
|
|
|
|
|
|
|
|
|
|
The special property `:powerline-scale` is `Spacemacs` specific and it is for
|
|
|
|
|
quick tweaking of the mode-line height in order to avoid crappy rendering of
|
|
|
|
|
the separators like on the following screenshot (default value is 1.1).
|
|
|
|
|
|
|
|
|
|
_Ugly separators_
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
![ugly-separators](img/crappy-powerline-separators.png)
|
|
|
|
|
|
|
|
|
|
### Graphical UI Toggles
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
Some graphical UI indicators can be toggled on and off (toggles start with `t`):
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
----------------------|------------------------------------------------------------
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC t 8</kbd> | display a mark on the 80th column
|
|
|
|
|
<kbd>SPC t F</kbd> | toggle frame fullscreen
|
|
|
|
|
<kbd>SPC t f</kbd> | toggle display of the fringe
|
2015-01-24 05:32:47 +00:00
|
|
|
|
<kbd>SPC t h</kbd> | toggle highlight of the current line
|
2014-12-18 03:19:57 +00:00
|
|
|
|
<kbd>SPC t i</kbd> | toggle aggressive indent
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC t l</kbd> | toggle truncate lines
|
|
|
|
|
<kbd>SPC t L</kbd> | toggle visual lines
|
|
|
|
|
<kbd>SPC t M</kbd> | toggle frame maximize
|
|
|
|
|
<kbd>SPC t n</kbd> | show the absolute line numbers
|
2014-12-27 18:15:18 +00:00
|
|
|
|
<kbd>SPC t t</kbd> | toggle frame transparency
|
2015-01-16 03:36:36 +00:00
|
|
|
|
<kbd>SPC t T</kbd> | toggle tool bar
|
|
|
|
|
<kbd>SPC t U</kbd> | toggle menu bar
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
**Note** These toggles are all available via the `helm-spacemacs` interface
|
|
|
|
|
(press <kbd>SPC fe h</kbd> to display the `helm-spacemacs` buffer).
|
|
|
|
|
|
|
|
|
|
### Mode-line
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
The mode line is an heavily customized [powerline][powerline] with the
|
|
|
|
|
following capabilities:
|
|
|
|
|
- show the window number
|
|
|
|
|
- color code for current state
|
|
|
|
|
- show the number of search occurrences via anzu
|
|
|
|
|
- toggle flycheck info
|
2014-11-24 03:34:57 +00:00
|
|
|
|
- toggle battery info
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- toggle minor mode lighters
|
|
|
|
|
|
|
|
|
|
Reminder of the color codes for the states:
|
|
|
|
|
|
2014-12-18 02:29:38 +00:00
|
|
|
|
Evil State | Color
|
|
|
|
|
-------------------|------------------
|
|
|
|
|
Normal | Orange
|
|
|
|
|
Insert | Green
|
|
|
|
|
Visual | Grey
|
|
|
|
|
Emacs | Blue
|
|
|
|
|
Motion | Purple
|
|
|
|
|
Lisp | Pink
|
|
|
|
|
Iedit/Iedit-Insert | Red
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
Some elements can be dynamically toggled:
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
-----------------------|------------------------------------------------------------
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC t m m</kbd> | toggle the minor mode lighters
|
|
|
|
|
<kbd>SPC t m b</kbd> | toggle the battery status
|
|
|
|
|
<kbd>SPC t m f</kbd> | toggle the flycheck info
|
2015-01-08 05:34:23 +00:00
|
|
|
|
<kbd>SPC t m v</kbd> | toggle the new version lighter
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
#### Flycheck integration
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
When [Flycheck][flycheck] minor mode is enabled, a new element appears showing
|
|
|
|
|
the number of errors, warnings and info.
|
|
|
|
|
|
2014-12-12 00:55:44 +00:00
|
|
|
|
![powerline-wave](img/powerline-wave.png)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
#### Anzu integration
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
[Anzu][anzu] shows the number of occurrence when performing a search. `Spacemacs`
|
|
|
|
|
integrates nicely the Anzu status by displaying it temporarily when `n` or `N` are
|
|
|
|
|
being pressed. See the `5/6` segment on the screenshot below.
|
|
|
|
|
|
2014-12-12 00:55:44 +00:00
|
|
|
|
![powerline-anzu](img/powerline-anzu.png)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
#### Battery status integration
|
2014-11-24 03:34:57 +00:00
|
|
|
|
|
|
|
|
|
[fancy-battery][] displays the percentage of total charge of the battery as
|
|
|
|
|
well as the time remaining to charge or discharge completely the battery.
|
|
|
|
|
|
|
|
|
|
A color code is used for the battery status:
|
|
|
|
|
|
|
|
|
|
Battery State | Color
|
|
|
|
|
------------------|------------------
|
|
|
|
|
Charging | Green
|
|
|
|
|
Discharging | Orange
|
|
|
|
|
Critical | Red
|
|
|
|
|
|
|
|
|
|
Note the these colors may vary depending on your theme.
|
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
#### Powerline separators
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
It is possible to easily customize the `powerline separator` by setting the
|
|
|
|
|
`powerline-default-separator` variable in your `~./spacemacs`. For instance
|
|
|
|
|
if you want to set back the separator to the well-known `arrow` separator
|
|
|
|
|
add the following snippet to your configuration file:
|
|
|
|
|
|
|
|
|
|
```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 powerline-default-separator 'arrow)
|
2014-12-29 09:11:20 +00:00
|
|
|
|
)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
To save you the time to try all the possible separators provided by the
|
|
|
|
|
powerline, here is an exhaustive set of screenshots:
|
|
|
|
|
|
|
|
|
|
Separator | Screenshot
|
|
|
|
|
------------------|------------------------------------------------------------
|
2014-12-12 00:55:44 +00:00
|
|
|
|
`alternate` | ![powerline-alternate](img/powerline-alternate.png)
|
|
|
|
|
`arrow` | ![powerline-arrow](img/powerline-arrow.png)
|
|
|
|
|
`arrow-fade` | ![powerline-arrow-fade](img/powerline-arrow-fade.png)
|
|
|
|
|
`bar` | ![powerline-bar](img/powerline-bar.png)
|
|
|
|
|
`box` | ![powerline-box](img/powerline-box.png)
|
|
|
|
|
`brace` | ![powerline-brace](img/powerline-brace.png)
|
|
|
|
|
`butt` | ![powerline-butt](img/powerline-butt.png)
|
|
|
|
|
`chamfer` | ![powerline-chamfer](img/powerline-chamfer.png)
|
|
|
|
|
`contour` | ![powerline-contour](img/powerline-contour.png)
|
|
|
|
|
`curve` | ![powerline-curve](img/powerline-curve.png)
|
|
|
|
|
`rounded` | ![powerline-rounded](img/powerline-rounded.png)
|
|
|
|
|
`roundstub` | ![powerline-roundstub](img/powerline-roundstub.png)
|
|
|
|
|
`slant` | ![powerline-slant](img/powerline-slant.png)
|
|
|
|
|
`wave` | ![powerline-wave](img/powerline-wave.png)
|
|
|
|
|
`zigzag` | ![powerline-zigzag](img/powerline-zigzag.png)
|
|
|
|
|
`nil` | ![powerline-nil](img/powerline-nil.png)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
#### Minor Modes
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
`Spacemacs` uses [diminish][diminish] mode to reduce the size of minor mode
|
|
|
|
|
indicators:
|
|
|
|
|
|
|
|
|
|
The minor mode area can be toggled on and off with:
|
|
|
|
|
|
|
|
|
|
<SPC> t m m
|
|
|
|
|
|
2014-12-23 21:39:57 +00:00
|
|
|
|
Unicode symbols are displayed by default. Setting the variable
|
|
|
|
|
`dotspacemacs-mode-line-unicode-symbols` to `nil` in your `~/.spacemacs` will
|
|
|
|
|
display ASCII characters instead (may be useful in terminal).
|
|
|
|
|
|
|
|
|
|
Unicode | ASCII | Mode
|
|
|
|
|
:-----------:|:----------:|----------------------------------------------------
|
2014-12-23 21:50:27 +00:00
|
|
|
|
`⊞` | G | [golden-ratio][golden-ratio] mode
|
2014-12-23 21:39:57 +00:00
|
|
|
|
`Ⓐ` | A | [auto-complete][auto-complete] mode
|
|
|
|
|
`Ⓒ` | C | [centered-cursor][centered-cursor] mode
|
|
|
|
|
`Ⓔ` | E | [evil-org][evil-org-mode] mode
|
|
|
|
|
`Ⓕ` | F | flycheck mode
|
2014-12-23 21:50:27 +00:00
|
|
|
|
`Ⓚ` | K | guide-key mode
|
2014-12-23 21:39:57 +00:00
|
|
|
|
`Ⓘ` | I | aggressive indent mode
|
|
|
|
|
`(Ⓟ)` | (P) | paredit mode
|
|
|
|
|
`Ⓢ` | S | flyspell mode
|
|
|
|
|
`(Ⓢ)` | (S) | [smartparens][sp] mode
|
|
|
|
|
`Ⓦ` | W | whitespace mode
|
|
|
|
|
`Ⓨ` | Y | [yasnippet][yasnippet] mode
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
# Commands
|
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
## Vim key bindings
|
2014-12-03 05:32:25 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
`Spacemacs` is based on `Vim` modal user interface to navigate and edit text.
|
|
|
|
|
If you are not familiar with the `Vim` way of editing text you can try the
|
|
|
|
|
[evil tutor][] lessons by pressing <kbd>SPC h T</kbd> at any time.
|
2014-12-03 05:32:25 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
### Escaping
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
`Spacemacs` uses [evil-escape][] to easily switch between `insert state` and
|
2015-01-22 02:34:54 +00:00
|
|
|
|
`normal state` by quickly pressing the `fd` keys.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
The choice of `fd` was made to be able to use the same sequence to escape from
|
|
|
|
|
"everything" in Emacs:
|
|
|
|
|
- escape from all evil states to normal state
|
|
|
|
|
- escape from evil-lisp-state to normal state
|
|
|
|
|
- abort evil ex command
|
|
|
|
|
- quit minibuffer
|
|
|
|
|
- abort isearch
|
|
|
|
|
- quit magit buffers
|
|
|
|
|
- quit help buffers
|
2014-12-09 00:22:57 +00:00
|
|
|
|
- quit apropos buffers
|
|
|
|
|
- quit ert buffers
|
|
|
|
|
- quit undo-tree buffer
|
|
|
|
|
- quit paradox
|
|
|
|
|
- quit gist-list menu
|
2014-11-22 05:45:19 +00:00
|
|
|
|
- hide neotree buffer
|
|
|
|
|
|
2015-01-19 03:40:41 +00:00
|
|
|
|
This sequence can be customized in your `~/.spacemacs`. Example to set it
|
|
|
|
|
to `jj` (it is important set the variable in `dotspacemacs/init`):
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
```elisp
|
2014-12-08 23:31:36 +00:00
|
|
|
|
(defun dotspacemacs/init ()
|
2015-01-19 03:40:41 +00:00
|
|
|
|
(setq-default evil-escape-key-sequence "jj"))
|
2014-11-22 05:45:19 +00:00
|
|
|
|
```
|
|
|
|
|
|
2015-01-22 02:34:54 +00:00
|
|
|
|
**Note:** Although `jj` or `jk` are popular choices of vim users, these key
|
|
|
|
|
sequences are not optimal for `Spacemacs`. Indeed it is very easy in
|
|
|
|
|
`visual state` to press quickly `jj` and inadvertently escape to `normal state`.
|
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
### Executing Vim and Emacs ex/M-x commands
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-12-13 03:22:33 +00:00
|
|
|
|
Command | Key Binding
|
|
|
|
|
:---------------:|------------------------------------------------------------------
|
|
|
|
|
Vim (ex-command) | <kbd>`:`</kbd>
|
|
|
|
|
Emacs (M-x) | <kbd>SPC :</kbd>
|
|
|
|
|
|
|
|
|
|
The command key `:` can be easily changed with the variable
|
|
|
|
|
`dotspacemacs-command-key` of your `~/.spacemacs`. Note that is will change both
|
|
|
|
|
`:` and `SPC :` bindings to keep the symmetry between Vim and Emacs. A good
|
|
|
|
|
key can be `,` for example.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
### Leader key
|
|
|
|
|
|
|
|
|
|
On top of `Vim` modes (modes are called states in `Spacemacs`) there is a
|
|
|
|
|
special key called the leader key which once pressed gives a whole new
|
|
|
|
|
keyboard layer. The leader key is by default <kbd>SPC</kbd> (space).
|
|
|
|
|
It is possible to change this key with the variable `dotspacemacs-leader-key`.
|
|
|
|
|
|
|
|
|
|
## Reserved prefix command for user
|
|
|
|
|
|
|
|
|
|
<kbd>SPC o</kbd> is reserved for the user. Setting key bindings behind
|
|
|
|
|
`<SPC> o` is **guaranteed** to never conflict with `Spacemacs` defaults key
|
|
|
|
|
bindings.
|
|
|
|
|
|
2015-02-05 04:13:52 +00:00
|
|
|
|
## Helm
|
|
|
|
|
|
|
|
|
|
`Spacemacs` is powered by [Helm][helm-link] which is an incremental completion
|
|
|
|
|
and selection narrowing framework.
|
|
|
|
|
|
|
|
|
|
`Helm` is the central control tower of `Spacemacs`, it is used to manage
|
|
|
|
|
buffers, projects, search results, configuration layers, toggles and more...
|
|
|
|
|
|
|
|
|
|
Mastering `Helm` will make you a `Spacemacs` power user. Do not hesitate
|
|
|
|
|
to read the [Helm documentation wiki][helm-doc].
|
|
|
|
|
|
|
|
|
|
### Helm micro-state
|
|
|
|
|
|
|
|
|
|
`Spacemacs` defines a [micro-state](#micro-states) for `Helm` to make it
|
|
|
|
|
work like [Vim's Unit][] plugin.
|
|
|
|
|
|
|
|
|
|
Initiate the micro-state with <kbd>TAB</kbd> while in a `Helm` buffer. Use
|
|
|
|
|
<kbd>TAB</kbd> again to exit from the micro-state (actually, like with any
|
|
|
|
|
micro-state, pressing any key that is not bound to the micro-state key map
|
|
|
|
|
will turn-off the micro-state).
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
--------------------|------------------------------------------------------------
|
|
|
|
|
<kbd>TAB</kbd> | initiate the micro-state
|
2015-02-06 03:55:56 +00:00
|
|
|
|
<kbd>1</kbd> | execute action 0
|
|
|
|
|
<kbd>2</kbd> | execute action 1
|
|
|
|
|
<kbd>3</kbd> | execute action 2
|
|
|
|
|
<kbd>4</kbd> | execute action 3
|
|
|
|
|
<kbd>5</kbd> | execute action 4
|
|
|
|
|
<kbd>6</kbd> | execute action 5
|
|
|
|
|
<kbd>7</kbd> | execute action 6
|
|
|
|
|
<kbd>8</kbd> | execute action 7
|
|
|
|
|
<kbd>9</kbd> | execute action 8
|
|
|
|
|
<kbd>0</kbd> | execute action 9
|
2015-02-05 05:15:53 +00:00
|
|
|
|
<kbd>a</kbd> | switch to actions page
|
2015-02-05 04:13:52 +00:00
|
|
|
|
<kbd>g</kbd> | go to first candidate
|
|
|
|
|
<kbd>G</kbd> | go to last candidate
|
2015-02-06 03:55:56 +00:00
|
|
|
|
<kbd>h</kbd> | go to previous source
|
2015-02-05 04:13:52 +00:00
|
|
|
|
<kbd>j</kbd> | select next candidate
|
|
|
|
|
<kbd>k</kbd> | select previous candidate
|
2015-02-06 03:55:56 +00:00
|
|
|
|
<kbd>l</kbd> | go to next source
|
2015-02-05 05:15:53 +00:00
|
|
|
|
<kbd>r</kbd> | switch to actions page and leave the micro-state (useful combined with <kbd>TAB</kbd>)
|
2015-02-05 04:13:52 +00:00
|
|
|
|
<kbd>t</kbd> | mark current candidate
|
|
|
|
|
<kbd>T</kbd> | mark all candidates
|
|
|
|
|
<kbd>v</kbd> | execute persistent action
|
|
|
|
|
Any other key | leave the micro-state
|
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
## Discovering
|
|
|
|
|
|
|
|
|
|
### Key bindings
|
|
|
|
|
|
|
|
|
|
An help buffer is displayed each time the <kbd>SPC</kbd> key is pressed in
|
|
|
|
|
normal mode. It lists the available key bindings and their associated
|
|
|
|
|
commands.
|
|
|
|
|
|
|
|
|
|
By default the [guide-key][] buffer will be displayed quickly after the key
|
|
|
|
|
has been pressed. You can change the delay by setting the variable
|
|
|
|
|
`dotspacemacs-guide-key-delay` to your liking (the value is in second).
|
|
|
|
|
|
|
|
|
|
### Available layers
|
|
|
|
|
|
|
|
|
|
All layers can be easily discovered via `helm-spacemacs` accessible with
|
|
|
|
|
<kbd>SPC f e h</kbd>.
|
|
|
|
|
|
|
|
|
|
The following helm actions are available:
|
|
|
|
|
- default: open the layer `README.md`
|
|
|
|
|
- 2nd: open the layer `packages.el`
|
|
|
|
|
- 3nd: open the layer `extensions.el`
|
|
|
|
|
|
|
|
|
|
#### Available packages in Spacemacs
|
|
|
|
|
|
|
|
|
|
`helm-spacemacs` also lists all the packages available in `Spacemacs`.
|
|
|
|
|
The entry format is `(layer) packages`. If you type `flycheck` you'll
|
|
|
|
|
be able to see all the layers where `flycheck` is used.
|
|
|
|
|
|
|
|
|
|
The following helm actions are available on packages:
|
|
|
|
|
- default: go the package init function
|
|
|
|
|
|
|
|
|
|
#### New packages from ELPA repositories
|
|
|
|
|
|
|
|
|
|
`package-list-packages` is where you can browse for all available packages
|
|
|
|
|
in the different Elpa repositories. It is possible to upgrade packages
|
|
|
|
|
from there but it is not recommended, use the `[Update]` link on the
|
|
|
|
|
`Spacemacs` startup page instead.
|
|
|
|
|
|
|
|
|
|
`Spacemacs` proposes to use [Paradox][] instead of `package-list-packages`
|
|
|
|
|
to list available ELPA packages.
|
|
|
|
|
Paradox enhances the package list buffer with better feedbacks, new
|
|
|
|
|
filters and Github information like the number of stars. Optionally you
|
|
|
|
|
can also star packages directly in the buffer.
|
|
|
|
|
|
|
|
|
|
**Important Note 1** Installing a new package from `Paradox` won't make it
|
|
|
|
|
persistent. To install a package persistently you have to add it explicitly
|
|
|
|
|
to a configuration layer.
|
|
|
|
|
|
|
|
|
|
**Important Note 2** Don't _update_ your packages from `Paradox` or
|
|
|
|
|
`package-list-packages` because they don't support the rollback feature of
|
|
|
|
|
Spacemacs.
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
---------------------|------------------------------------------------------------
|
|
|
|
|
<kbd>/</kbd> | evil-search
|
|
|
|
|
<kbd>f k</kbd> | filter by keywords
|
|
|
|
|
<kbd>f r</kbd> | filter by regexp
|
|
|
|
|
<kbd>f u</kbd> | display only installed package with updates available
|
|
|
|
|
<kbd>h</kbd> | go left
|
|
|
|
|
<kbd>H</kbd> | show help (not accurate)
|
|
|
|
|
<kbd>j</kbd> | go down
|
|
|
|
|
<kbd>k</kbd> | go up
|
|
|
|
|
<kbd>l</kbd> | go right
|
|
|
|
|
<kbd>L</kbd> | show last commits
|
|
|
|
|
<kbd>n</kbd> | next search occurrence
|
|
|
|
|
<kbd>N</kbd> | previous search occurrence
|
|
|
|
|
<kbd>o</kbd> | open package homepage
|
|
|
|
|
<kbd>r</kbd> | refresh
|
|
|
|
|
<kbd>S P</kbd> | sort by package name
|
|
|
|
|
<kbd>S S</kbd> | sort by status (installed, available, etc...)
|
|
|
|
|
<kbd>S *</kbd> | sort by Github stars
|
|
|
|
|
<kbd>v</kbd> | `visual state`
|
|
|
|
|
<kbd>V</kbd> | `visual-line state`
|
|
|
|
|
<kbd>x</kbd> | execute (action flags)
|
|
|
|
|
|
|
|
|
|
### Toggles
|
|
|
|
|
|
|
|
|
|
`helm-spacemacs` is also a central place to discover the available toggles.
|
|
|
|
|
To display only the toggles source press <kbd>C-l</kbd> (or in
|
|
|
|
|
[Helm micro-state](#helm-micro-state) you can press just <kbd>l</kbd>).
|
|
|
|
|
|
|
|
|
|
The following helm actions are available on packages:
|
|
|
|
|
- default: toggle on/off
|
|
|
|
|
|
|
|
|
|
**Tips** Use <kbd>SPC h l</kbd> to resume the last helm session. It is
|
|
|
|
|
handy to quickly toggle on and off a toggle.
|
|
|
|
|
|
2014-11-22 05:45:19 +00:00
|
|
|
|
## Navigating
|
|
|
|
|
|
|
|
|
|
### Point/Cursor
|
|
|
|
|
|
|
|
|
|
Navigation is performed using the Vi key bindings `hjkl`.
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
---------------------|------------------------------------------------------------------
|
|
|
|
|
<kbd>`h`</kbd> | move cursor left
|
|
|
|
|
<kbd>`j`</kbd> | move cursor down
|
|
|
|
|
<kbd>`k`</kbd> | move cursor up
|
|
|
|
|
<kbd>`l`</kbd> | move cursor right
|
|
|
|
|
<kbd>`H`</kbd> | move quickly up (10 lines at a time)
|
|
|
|
|
<kbd>`L`</kbd> | move quickly down (10 lines at a time)
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC j h</kbd> | go to the beginning of line (and set a mark at the previous location in the line)
|
|
|
|
|
<kbd>SPC j l</kbd> | go to the end of line (and set a mark at the previous location in the line)
|
|
|
|
|
<kbd>SPC z z</kbd> | lock the cursor at the center of the screen
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
#### Smooth scrolling
|
|
|
|
|
|
|
|
|
|
[smooth-scrolling]() prevent the point to jump when it reaches the top or
|
|
|
|
|
bottom of the screen. It is enabled by default.
|
|
|
|
|
|
|
|
|
|
On Windows, you may want to disable it. To disable the smooth scrolling set
|
|
|
|
|
the `dotspacemacs-smooth-scrolling` variable in your `~/.spacemacs` to `nil`:
|
|
|
|
|
|
|
|
|
|
```elisp
|
|
|
|
|
(setq-default dotspacemacs-smooth-scrolling t)
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### Vim motions with ace-jump mode
|
|
|
|
|
|
|
|
|
|
`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
|
|
|
|
|
|
2014-12-03 05:19:14 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
---------------------|------------------------------------------------------------------
|
|
|
|
|
<kbd>SPC SPC</kbd> | initiate ace jump word mode
|
2014-11-27 16:02:18 +00:00
|
|
|
|
<kbd>SPC l</kbd> | initiate ace jump line mode
|
|
|
|
|
<kbd>SPC `</kbd> | go back to the previous location (before the jump)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
Hint: you may change to char mode by `C-c C-c` in word mode.
|
|
|
|
|
|
|
|
|
|
### Window manipulation
|
|
|
|
|
|
|
|
|
|
Every window has a number displayed at the start of the mode-line and can
|
|
|
|
|
be quickly accessed using `<SPC> number`.
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
--------------------|----------------------------------------------------------------
|
2014-12-03 05:20:18 +00:00
|
|
|
|
<kbd>SPC 1</kbd> | go to first window
|
|
|
|
|
<kbd>SPC 2</kbd> | go to window number 2
|
|
|
|
|
<kbd>SPC 3</kbd> | go to window number 3
|
|
|
|
|
<kbd>SPC 4</kbd> | go to window number 4
|
|
|
|
|
<kbd>SPC 5</kbd> | go to window number 5
|
|
|
|
|
<kbd>SPC 6</kbd> | go to window number 6
|
|
|
|
|
<kbd>SPC 7</kbd> | go to window number 7
|
|
|
|
|
<kbd>SPC 8</kbd> | go to window number 8
|
|
|
|
|
<kbd>SPC 9</kbd> | go to window number 9
|
|
|
|
|
<kbd>SPC 0</kbd> | go to window number 10
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
Windows manipulation commands (start with `w`):
|
|
|
|
|
|
2014-12-14 18:19:33 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
------------------------------------------|----------------------------------------------------------------
|
|
|
|
|
<kbd>SPC w c</kbd> | close a window
|
|
|
|
|
<kbd>SPC w d</kbd> | toggle window dedication (dedicated window cannot be reused by a mode)
|
|
|
|
|
<kbd>SPC w H</kbd> | move window to the left
|
|
|
|
|
<kbd>SPC w J</kbd> | move window to the bottom
|
|
|
|
|
<kbd>SPC w K</kbd> | move window to the top
|
|
|
|
|
<kbd>SPC w L</kbd> | move window to the right
|
|
|
|
|
<kbd>SPC w m</kbd> | maximize/minimize a window
|
|
|
|
|
<kbd>SPC w M</kbd> | maximize/minimize a window, when maximized the buffer is centered
|
|
|
|
|
<kbd>SPC w o</kbd> | cycle and focus between frames
|
|
|
|
|
<kbd>SPC w p m</kbd> | open messages buffer in a popup window
|
|
|
|
|
<kbd>SPC w p p</kbd> | close the current sticky popup window
|
2014-12-24 05:19:43 +00:00
|
|
|
|
<kbd>SPC w r</kbd> | initiate window size micro-state
|
|
|
|
|
<kbd>SPC w R</kbd> | rotate windows clockwise
|
2014-12-14 18:19:33 +00:00
|
|
|
|
<kbd>SPC w s</kbd> or <kbd>SPC w /</kbd> | horizontal split
|
2014-12-24 05:19:43 +00:00
|
|
|
|
<kbd>SPC w S</kbd> | horizontal split and focus new window
|
2014-12-14 18:19:33 +00:00
|
|
|
|
<kbd>SPC w u</kbd> | undo window layout (used to effectively undo a closed window)
|
|
|
|
|
<kbd>SPC w U</kbd> | redo window layout
|
|
|
|
|
<kbd>SPC w v</kbd> or <kbd>SPC w -</kbd> | vertical split
|
2014-12-24 05:19:43 +00:00
|
|
|
|
<kbd>SPC w V</kbd> | vertical split and focus new window
|
2014-12-14 18:19:33 +00:00
|
|
|
|
<kbd>SPC w w</kbd> | cycle and focus between windows
|
2014-12-03 05:20:18 +00:00
|
|
|
|
|
|
|
|
|
#### Resizing windows
|
|
|
|
|
|
|
|
|
|
`Spacemacs` defines a micro-state to resize windows.
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
--------------------|------------------------------------------------------------
|
|
|
|
|
<kbd>SPC w S</kbd> | initiate micro-state
|
|
|
|
|
<kbd>H</kbd> | shrink window horizontally
|
|
|
|
|
<kbd>J</kbd> | shrink window vertically
|
|
|
|
|
<kbd>K</kbd> | enlarge window vertically
|
|
|
|
|
<kbd>L</kbd> | enlarge window horizontally
|
|
|
|
|
Any other key | leave the micro-state
|
|
|
|
|
|
|
|
|
|
The micro-state text in minibuffer display the following information:
|
|
|
|
|
|
|
|
|
|
[WidthxHeight] Resize window: (H/L) shrink/enlarge horizontally, (J/K) shrink/enlarge vertically
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-12-10 01:02:55 +00:00
|
|
|
|
#### Reposition window
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
--------------------|------------------------------------------------------------
|
|
|
|
|
<kbd>z f</kbd> | Make current function or comments visible
|
|
|
|
|
|
|
|
|
|
`z f` tries to accommodate current function or comments into window as much as possible.
|
|
|
|
|
|
2014-11-22 05:45:19 +00:00
|
|
|
|
#### Golden ratio
|
|
|
|
|
|
2014-12-03 05:20:18 +00:00
|
|
|
|
If you resize windows like crazy you may want to give a try to [golden-ratio][].
|
|
|
|
|
|
|
|
|
|
`golden-ratio` resizes windows dynamically depending on whether they are
|
|
|
|
|
selected or not. By default `golden-ratio` is off.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
The mode can be toggled on and off with:
|
|
|
|
|
|
2014-12-23 21:50:27 +00:00
|
|
|
|
<SPC> t g
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
### Buffers and Files
|
|
|
|
|
|
|
|
|
|
`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
|
|
|
|
|
remember the last selected directories and buffers, maybe helm can do this ?).
|
|
|
|
|
`ido` is also used to kill buffers.
|
|
|
|
|
|
|
|
|
|
Buffer manipulation commands (start with `b`):
|
|
|
|
|
|
2014-12-25 05:32:26 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
------------------------------------------|----------------------------------------------------------------
|
2015-01-21 02:56:54 +00:00
|
|
|
|
<kbd>SPC b 0</kbd> | move to the beginning of buffer (useful in `emacs state` buffers)
|
|
|
|
|
<kbd>SPC b $</kbd> | move to the end of buffer (useful in `emacs state` buffers)
|
2014-12-25 05:32:26 +00:00
|
|
|
|
<kbd>SPC b b</kbd> or <kbd>SPC TAB</kbd> | switch to alternate buffer (switch back and forth)
|
|
|
|
|
<kbd>SPC b e</kbd> | erase the content of the buffer (ask for confirmation)
|
|
|
|
|
<kbd>SPC b k</kbd> | kill the current buffer
|
|
|
|
|
<kbd>SPC b K</kbd> | kill all buffers except the current one
|
|
|
|
|
<kbd>SPC b C-K</kbd> | kill all buffers matching the regexp
|
|
|
|
|
<kbd>SPC b m h</kbd> | move a buffer to the left
|
|
|
|
|
<kbd>SPC b m j</kbd> | move a buffer to the bottom
|
|
|
|
|
<kbd>SPC b m k</kbd> | move a buffer to the top
|
|
|
|
|
<kbd>SPC b m l</kbd> | move a buffer to the right
|
|
|
|
|
<kbd>SPC b n</kbd> | switch to next buffer
|
|
|
|
|
<kbd>SPC b p</kbd> | switch to previous buffer
|
|
|
|
|
<kbd>SPC b r</kbd> | rename the current buffer
|
|
|
|
|
<kbd>SPC b R</kbd> | revert the current buffer (reload from disk)
|
|
|
|
|
<kbd>SPC b s</kbd> | switch to a buffer using `helm`
|
|
|
|
|
<kbd>SPC b w</kbd> | toggle read-only (writable state)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
Files manipulation commands (start with `f`):
|
|
|
|
|
|
2014-12-20 04:54:46 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
------------------------------------------|----------------------------------------------------------------
|
2015-02-10 08:31:10 +00:00
|
|
|
|
<kbd>SPC f D</kbd> | delete a file and the associated buffer (ask for confirmation)
|
2014-12-20 04:54:46 +00:00
|
|
|
|
<kbd>SPC f f</kbd> | open a file using `ido`
|
2015-01-14 06:10:13 +00:00
|
|
|
|
<kbd>SPC f j</kbd> | jump to the current buffer file in dired
|
2015-01-12 04:08:55 +00:00
|
|
|
|
<kbd>SPC f o</kbd> | open a file using the default external program
|
2014-12-20 04:54:46 +00:00
|
|
|
|
<kbd>SPC f s</kbd> | save a file
|
|
|
|
|
<kbd>SPC f S</kbd> | save all files
|
2015-01-04 05:24:21 +00:00
|
|
|
|
<kbd>SPC f r</kbd> | open a recent file with `helm`
|
2014-12-25 00:57:13 +00:00
|
|
|
|
<kbd>SPC f t</kbd> | toggle file tree side bar using [NeoTree][neotree]
|
2014-12-20 04:54:46 +00:00
|
|
|
|
<kbd>SPC f y</kbd> | show current file absolute path in the minibuffer
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-01-01 06:09:33 +00:00
|
|
|
|
#### Emacs and Spacemacs files
|
|
|
|
|
|
|
|
|
|
Convenient key bindings are located under the prefix <kbd>SPC f e</kbd> to
|
|
|
|
|
quickly navigate between `Emacs` and `Spacemacs` specific files.
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
------------------------------------------|----------------------------------------------------------------
|
|
|
|
|
<kbd>SPC f e c</kbd> | open `ido` in the `contrib` folder
|
|
|
|
|
<kbd>SPC f e d</kbd> | open the spacemacs dotfile (`~/.spacemacs`)
|
|
|
|
|
<kbd>SPC f e h</kbd> | discover `Spacemacs` layers and packages using `helm`
|
|
|
|
|
<kbd>SPC f e i</kbd> | open the all mighty `init.el`
|
|
|
|
|
<kbd>SPC f e s</kbd> | open `ido` in the `spacemacs` layer folder
|
|
|
|
|
|
2014-11-22 05:45:19 +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:
|
|
|
|
|
|
2015-01-08 21:25:03 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
------------------------|----------------------------------------------------------------
|
|
|
|
|
<kbd>C-\<return\></kbd> | open a `dired buffer`
|
|
|
|
|
<kbd>M-\<return\></kbd> | open a `dired buffer` in terminal
|
|
|
|
|
<kbd>C-d</kbd> | delete selected file (ask for confirmation)
|
|
|
|
|
<kbd>C-h</kbd> | go to parent directory
|
|
|
|
|
<kbd>C-j</kbd> | select next file or directory
|
|
|
|
|
<kbd>C-S-j</kbd> | go to next directory
|
|
|
|
|
<kbd>C-k</kbd> | select previous file or directory
|
|
|
|
|
<kbd>C-S-k</kbd> | go to previous directory
|
|
|
|
|
<kbd>C-l</kbd> | open the selected file
|
|
|
|
|
<kbd>C-n</kbd> | next history element
|
2015-01-16 03:17:58 +00:00
|
|
|
|
<kbd>C-o</kbd> | open selected file in other window
|
2015-01-08 21:25:03 +00:00
|
|
|
|
<kbd>C-p</kbd> | previous history element
|
2015-01-16 03:17:58 +00:00
|
|
|
|
<kbd>C-s</kbd> | open selected file in a vertically split window
|
2015-01-08 21:25:03 +00:00
|
|
|
|
<kbd>C-t</kbd> | open selected file in a new frame
|
2015-01-16 03:17:58 +00:00
|
|
|
|
<kbd>C-v</kbd> | open selected file in a horizontally split window
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
### NeoTree file tree
|
|
|
|
|
|
|
|
|
|
`Spacemacs` provides a quick and simple way to navigate in an unknown project
|
|
|
|
|
file tree with [NeoTree][neotree].
|
|
|
|
|
|
|
|
|
|
To toggle the `NeoTree` buffer press:
|
|
|
|
|
|
2014-12-25 00:57:13 +00:00
|
|
|
|
<SPC> f t
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-01-02 01:12:13 +00:00
|
|
|
|
The NeoTree window always has the number `0` so it does not shift the current
|
|
|
|
|
number of the other windows. To select the NeoTree window you then use
|
|
|
|
|
<kbd>SPC 0</kbd>.
|
|
|
|
|
|
2015-01-01 06:00:56 +00:00
|
|
|
|
#### NeoTree navigation
|
|
|
|
|
|
|
|
|
|
Navigation is centered on the `hjkl` with the hope to provide a fast navigation
|
|
|
|
|
experience like in [ranger][]:
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
---------------------------------|----------------------------------------------------------------
|
2015-01-04 06:49:53 +00:00
|
|
|
|
<kbd>h</kbd> | collapse expanded directory or go to parent node
|
2015-01-02 01:12:13 +00:00
|
|
|
|
<kbd>H</kbd> | previous sibling
|
2015-01-01 06:00:56 +00:00
|
|
|
|
<kbd>j</kbd> | next file or directory
|
|
|
|
|
<kbd>J</kbd> | next expanded directory on level down
|
|
|
|
|
<kbd>k</kbd> | previous file or directory
|
|
|
|
|
<kbd>K</kbd> | parent directory, when reaching the root change it to parent directory
|
2015-01-02 01:12:13 +00:00
|
|
|
|
<kbd>l</kbd> or <kbd>RET</kbd> | expand directory
|
|
|
|
|
<kbd>L</kbd> | next sibling
|
2015-01-01 06:00:56 +00:00
|
|
|
|
|
|
|
|
|
**Note:** The point is automatically set to the first letter of a node for a
|
|
|
|
|
smoother experience.
|
|
|
|
|
|
|
|
|
|
#### Opening files with NeoTree
|
|
|
|
|
|
|
|
|
|
By default a file is opened in the last active window. It is possible to choose
|
|
|
|
|
window number where to open a file by using a numeric argument, for instance
|
2015-01-02 01:12:13 +00:00
|
|
|
|
<kbd>2 l</kbd> or <kbd>2 RET</kbd> will open the current file in the windows 2.
|
2015-01-01 06:00:56 +00:00
|
|
|
|
It is also possible to open the file in a split window with <kbd>|</kbd> and
|
|
|
|
|
<kbd>-</kbd>:
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
----------------------------------|----------------------------------------------------------------
|
2015-01-02 01:12:13 +00:00
|
|
|
|
<kbd>l</kbd> or <kbd>RET</kbd> | open file in last active window
|
|
|
|
|
<kbd># l</kbd> or <kbd>2 RET</kbd>| open file in window number `#`
|
2015-01-19 22:03:21 +00:00
|
|
|
|
<kbd>\|</kbd> | open file in an vertically split window
|
2015-01-01 06:00:56 +00:00
|
|
|
|
<kbd>-</kbd> | open file in an horizontally split window
|
|
|
|
|
|
|
|
|
|
#### Other NeoTree key bindings
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
---------------------------------|----------------------------------------------------------------
|
2015-01-01 06:00:56 +00:00
|
|
|
|
<kbd>TAB</kbd> | toggle stretching of the buffer
|
2014-11-27 16:02:18 +00:00
|
|
|
|
<kbd>c</kbd> | create a node
|
|
|
|
|
<kbd>d</kbd> | delete a node
|
|
|
|
|
<kbd>g</kbd> | refresh
|
2015-01-02 01:12:13 +00:00
|
|
|
|
<kbd>s</kbd> | toggle showing of hidden files
|
2014-11-27 16:02:18 +00:00
|
|
|
|
<kbd>q</kbd> or <kbd>fd</kbd> | hide `NeoTree` buffer
|
|
|
|
|
<kbd>r</kbd> | rename a node
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-01-01 06:00:56 +00:00
|
|
|
|
#### NeoTree mode-line
|
|
|
|
|
|
|
|
|
|
The mode-line has the following format `[x/y] d (D:a, F:b)` where:
|
|
|
|
|
- `x` is the index of the current selected file or directory
|
|
|
|
|
- `y` the total number of items (file and directory) in the current directory
|
|
|
|
|
- `d` the name of the current directory
|
|
|
|
|
- `a` the number of directories in the current directory
|
|
|
|
|
- `b` the number of files in the current directory
|
|
|
|
|
|
2014-12-06 06:31:56 +00:00
|
|
|
|
### Shells
|
|
|
|
|
|
2014-12-12 04:49:49 +00:00
|
|
|
|
#### Key bindings
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
--------------------|----------------------------------------------------------------
|
|
|
|
|
<kbd>C-j</kbd> | next item in history
|
|
|
|
|
<kbd>C-k</kbd> | previous item in history
|
|
|
|
|
<kbd>SPC m h</kbd> | browse history with `helm` (works in `eshell` and `shell`)
|
|
|
|
|
|
|
|
|
|
#### Staying in insert state
|
|
|
|
|
|
2014-12-06 06:31:56 +00:00
|
|
|
|
Navigating in shell buffers can be tricky because it is not possible to use the
|
|
|
|
|
leader in `insert state`. Switching back and forth between normal and insert
|
2015-01-19 04:24:42 +00:00
|
|
|
|
states can be tedious. The solution to this is to use <kbd>C-o</kbd> then use
|
|
|
|
|
the leader key. <kbd>C-o</kbd> set the next key to be evaluated in
|
|
|
|
|
`normal state`.
|
2014-12-06 06:31:56 +00:00
|
|
|
|
|
2014-11-22 05:45:19 +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.
|
|
|
|
|
|
|
|
|
|
Open an `helm` window with the current bookmarks by pressing:
|
|
|
|
|
|
|
|
|
|
<SPC> h b
|
|
|
|
|
|
|
|
|
|
Then in the `helm-bookmarks` buffer:
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
-------------------|----------------------------------------------------------------
|
|
|
|
|
<kbd>CTRL+d</kbd> | delete the selected bookmark
|
|
|
|
|
<kbd>CTRL+e</kbd> | edit the selected bookmark
|
|
|
|
|
<kbd>CTRL+f</kbd> | toggle filename location
|
|
|
|
|
<kbd>CTRL+o</kbd> | open the selected bookmark in another window
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
To save a new bookmark, just type the name of the bookmark and press `RET`.
|
|
|
|
|
|
2015-01-23 06:57:17 +00:00
|
|
|
|
### DocView mode
|
|
|
|
|
|
|
|
|
|
`doc-view-mode` is a built-in major mode to view DVI, PostScript (PS), PDF,
|
|
|
|
|
OpenDocument, and Microsoft Office documents.
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
-------------------|----------------------------------------------------------------
|
|
|
|
|
<kbd>/</kbd> | search forward
|
|
|
|
|
<kbd>?</kbd> | search backward
|
|
|
|
|
<kbd>+</kbd> | enlarge
|
|
|
|
|
<kbd>-</kbd> | shrink
|
|
|
|
|
<kbd>gg</kbd> | go to first page
|
|
|
|
|
<kbd>G</kbd> | go to last page
|
|
|
|
|
<kbd>h</kbd> | previous page
|
|
|
|
|
<kbd>H</kbd> | adjust to height
|
|
|
|
|
<kbd>j</kbd> | next line
|
|
|
|
|
<kbd>k</kbd> | previous line
|
|
|
|
|
<kbd>K</kbd> | kill proc and buffer
|
|
|
|
|
<kbd>l</kbd> | next page
|
|
|
|
|
<kbd>n</kbd> | go to next search occurrence
|
|
|
|
|
<kbd>N</kbd> | go to previous search occurrence
|
|
|
|
|
<kbd>P</kbd> | fit page to window
|
|
|
|
|
<kbd>r</kbd> | revert
|
|
|
|
|
<kbd>W</kbd> | adjust to width
|
|
|
|
|
<kbd>C-d</kbd> | scroll down
|
|
|
|
|
<kbd>C-k</kbd> | kill proc
|
|
|
|
|
<kbd>C-u</kbd> | scroll up
|
|
|
|
|
<kbd>C-c C-c</kbd> | toggle display text and image display
|
|
|
|
|
<kbd>C-c C-t</kbd> | open new buffer with doc's text contents
|
|
|
|
|
|
2014-11-22 05:45:19 +00:00
|
|
|
|
## Searching
|
|
|
|
|
|
2014-11-27 18:17:55 +00:00
|
|
|
|
### Project Searching
|
|
|
|
|
|
2014-11-28 00:13:51 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
--------------------------------------|---------------------------------------------
|
|
|
|
|
<kbd>SPC /</kbd> or <kbd>SPC a</kbd> | with [The Silver Searcher][ag]
|
|
|
|
|
<kbd>SPC A</kbd> | with `ack`
|
|
|
|
|
<kbd>SPC g</kbd> | with `grep`
|
2014-12-04 03:38:47 +00:00
|
|
|
|
<kbd>SPC h l</kbd> | show last helm popup
|
2014-11-27 18:17:55 +00:00
|
|
|
|
|
2014-11-22 05:45:19 +00:00
|
|
|
|
### Persistent highlighting
|
|
|
|
|
|
|
|
|
|
`Spacemacs` uses `evil-search-highlight-persist` to keep the searched expression
|
|
|
|
|
highlighted until the next search. It is also possible to clear the
|
2014-11-27 16:02:18 +00:00
|
|
|
|
highlighting by pressing <kbd>SPC s c</kbd> or executing the ex command `:noh`.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
### Stacking highlights
|
|
|
|
|
|
|
|
|
|
With [hl-anything][] it is possible to highlight all occurrences of the word
|
|
|
|
|
under point. The highlights can be stacked.
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
-----------------------|----------------------------------------------------------------
|
2014-12-01 02:08:48 +00:00
|
|
|
|
<kbd>SPC h c</kbd> | clear the highlightings
|
|
|
|
|
<kbd>SPC h g c</kbd> | clear the highlightings globally (all opened buffers)
|
|
|
|
|
<kbd>SPC h h</kbd> | highlight all occurrence of the word at point
|
|
|
|
|
<kbd>SPC h g h</kbd> | highlight all occurrence of the word at point globally (all opened buffers)
|
|
|
|
|
<kbd>SPC h n</kbd> | next highlighted occurrence
|
|
|
|
|
<kbd>SPC h N</kbd> | previous highlighted occurrence
|
|
|
|
|
<kbd>SPC h p</kbd> | toggle auto-highlight of the enclosing parenthesis
|
|
|
|
|
<kbd>SPC h r</kbd> | restore saved highlights in the current buffer
|
|
|
|
|
<kbd>SPC h s</kbd> | save current highlights
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-12-02 21:27:27 +00:00
|
|
|
|
### Highlight current symbol
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-12-02 21:27:27 +00:00
|
|
|
|
`Spacemacs` supports highlighting of the current symbol on demand (provided by
|
2015-01-21 07:01:05 +00:00
|
|
|
|
the [auto-highlight-symbol][auto-highlight] mode) and adding a micro-state to
|
2014-12-02 21:27:27 +00:00
|
|
|
|
easily navigate and rename this symbol.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-12-02 21:27:27 +00:00
|
|
|
|
It is also possible to change the range of the navigation on the fly to:
|
|
|
|
|
- buffer
|
|
|
|
|
- function
|
|
|
|
|
- visible area
|
|
|
|
|
|
|
|
|
|
To initiate the highlighting of the current symbol under point press
|
|
|
|
|
<kbd>SPC s h</kbd>.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
Navigation between the highlighted symbols can be done with the commands:
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
-----------------------|------------------------------------------------------------
|
|
|
|
|
<kbd>*</kbd> | initiate navigation micro-state
|
2014-12-01 02:08:48 +00:00
|
|
|
|
<kbd>SPC s b</kbd> | go to the last searched occurrence of the last highlighted symbol
|
2014-12-18 02:26:52 +00:00
|
|
|
|
<kbd>SPC s e</kbd> | edit all occurrences of the current symbol(*)
|
2014-12-02 21:27:27 +00:00
|
|
|
|
<kbd>SPC s h</kbd> | highlight the current symbol and all its occurrence within the current range
|
2014-12-01 02:08:48 +00:00
|
|
|
|
<kbd>SPC s R</kbd> | change range to default (`whole buffer`)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
In 'Spacemacs' highlight symbol micro-state:
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
--------------|------------------------------------------------------------
|
2014-12-18 02:26:52 +00:00
|
|
|
|
<kbd>e</kbd> | edit occurrences (*)
|
2014-11-27 16:02:18 +00:00
|
|
|
|
<kbd>n</kbd> | go to next occurrence
|
|
|
|
|
<kbd>N</kbd> | go to previous occurrence
|
|
|
|
|
<kbd>d</kbd> | go to next definition occurrence
|
|
|
|
|
<kbd>D</kbd> | go to previous definition occurrence
|
|
|
|
|
<kbd>r</kbd> | change range (`function`, `display area`, `whole buffer`)
|
|
|
|
|
<kbd>R</kbd> | go to home occurrence (reset position to starting occurrence)
|
2014-11-22 05:45:19 +00:00
|
|
|
|
Any other key | leave the navigation micro-state
|
|
|
|
|
|
2014-12-18 02:26:52 +00:00
|
|
|
|
(*) using [iedit][] or the default implementation of `auto-highlight-symbol`
|
|
|
|
|
|
2014-11-22 05:45:19 +00:00
|
|
|
|
The micro-state text in minibuffer display the following information:
|
|
|
|
|
|
2014-12-03 05:19:42 +00:00
|
|
|
|
<M> [6/11]* press (n/N) to navigate, (e) to edit, (r) to change range or (R) for reset
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
Where `<M> [x/y]*` is:
|
|
|
|
|
- M: the current range mode
|
|
|
|
|
- `<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
|
|
|
|
|
- `*`: appears if there is at least one occurrence which is not currently
|
|
|
|
|
visible.
|
|
|
|
|
|
|
|
|
|
### Visual Star
|
|
|
|
|
|
|
|
|
|
With [evil-visualstar][] you can search for the next occurrence of the current
|
|
|
|
|
selection.
|
|
|
|
|
|
|
|
|
|
It is pretty useful combined with the [expand-region](#region-selection)
|
|
|
|
|
bindings.
|
|
|
|
|
|
|
|
|
|
_Note:_ If the current state is not the `visual state` then pressing `*` uses
|
|
|
|
|
[auto-highlight-symbol](#auto-highlight-symbols) and its micro-state.
|
|
|
|
|
|
|
|
|
|
### Listing symbols by semantic
|
|
|
|
|
|
|
|
|
|
Use `helm-semantic-or-imenu` command from `Helm` to quickly navigate between
|
|
|
|
|
the symbols in a buffer.
|
|
|
|
|
|
|
|
|
|
To list all the symbols of a buffer press:
|
|
|
|
|
|
|
|
|
|
<SPC> s l
|
|
|
|
|
|
|
|
|
|
### Helm-swoop
|
|
|
|
|
|
|
|
|
|
This is very similar to `moccur`, it displays a `helm` buffer with all the
|
|
|
|
|
occurrences of the word under point. You can then change the search query
|
|
|
|
|
in real-time and navigate between them easily.
|
|
|
|
|
|
|
|
|
|
You can even edit the occurrences directly in the `helm` buffer and apply
|
|
|
|
|
the modifications to the buffer.
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
-----------------------|----------------------------------------------------------------
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC s s</kbd> | execute `helm-swoop`
|
|
|
|
|
<kbd>SPC s S</kbd> | execute `helm-multi-swoop`
|
|
|
|
|
<kbd>SPC s C-s</kbd> | execute `helm-multi-swoop-all`
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
## Editing
|
|
|
|
|
|
|
|
|
|
### Text manipulation commands
|
|
|
|
|
|
|
|
|
|
Text related commands (start with `x`):
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
-----------------------|------------------------------------------------------------
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC x u</kbd> | set the selected text to lower case
|
|
|
|
|
<kbd>SPC x U</kbd> | set the selected text to upper case
|
|
|
|
|
<kbd>SPC x d w</kbd> | delete trailing whitespaces
|
|
|
|
|
<kbd>SPC x g l</kbd> | set languages used by translate commands
|
|
|
|
|
<kbd>SPC x g t</kbd> | translate current word using Google Translate
|
|
|
|
|
<kbd>SPC x g T</kbd> | reverse source and target languages
|
|
|
|
|
<kbd>SPC x m j</kbd> | move down a line of text
|
|
|
|
|
<kbd>SPC x m k</kbd> | move up a line of text
|
|
|
|
|
<kbd>SPC x t c</kbd> | swap (transpose) the current character with the previous one
|
|
|
|
|
<kbd>SPC x t w</kbd> | swap (transpose) the current word with the previous one
|
|
|
|
|
<kbd>SPC x t l</kbd> | swap (transpose) the current line with the previous one
|
|
|
|
|
<kbd>SPC x w c</kbd> | count the number of words in the selection region
|
|
|
|
|
<kbd>SPC x w C</kbd> | count the number of occurrences per word in the select region
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-12-13 03:22:55 +00:00
|
|
|
|
### Smartparens Strict mode
|
|
|
|
|
|
|
|
|
|
[Smartparens][sp] comes with a strict mode which prevents deletion of
|
|
|
|
|
parenthesis if the result is unbalanced.
|
|
|
|
|
|
|
|
|
|
This mode can be frustrating for novices, this is why it is not enabled by
|
|
|
|
|
default.
|
|
|
|
|
|
|
|
|
|
It is possible to enable it easily for _all programming modes_ with the
|
|
|
|
|
variable `dotspacemacs-smartparens-strict-mode` of you `~/.spacemacs`.
|
|
|
|
|
|
|
|
|
|
```elisp
|
|
|
|
|
(setq-default dotspacemacs-smartparens-strict-mode t)
|
|
|
|
|
```
|
|
|
|
|
|
2014-12-13 06:05:09 +00:00
|
|
|
|
### Zooming
|
|
|
|
|
|
|
|
|
|
#### Text
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
The font size of the current buffer can be adjusted with the commands:
|
|
|
|
|
|
2014-12-13 06:05:09 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
-----------------------|------------------------------------------------------------
|
|
|
|
|
<kbd>SPC z x +</kbd> | scale up the font and initiate the font scaling micro-state
|
|
|
|
|
<kbd>SPC z x -</kbd> | scale down the font and initiate the font scaling micro-state
|
|
|
|
|
<kbd>SPC z x =</kbd> | reset the font size (no scaling) and initiate the font scaling micro-state
|
|
|
|
|
<kbd>+</kbd> | increase the font size
|
|
|
|
|
<kbd>-</kbd> | decrease the font size
|
|
|
|
|
<kbd>=</kbd> | reset the font size
|
|
|
|
|
Any other key | leave the font scaling micro-state
|
|
|
|
|
|
|
|
|
|
Note that _only_ the text of the current buffer is scaled, the other buffers,
|
|
|
|
|
the mode-line and the minibuffer are not affected. To zoom the whole content of
|
|
|
|
|
a frame use the `zoom frame` bindings (see next section).
|
|
|
|
|
|
|
|
|
|
#### Frame
|
|
|
|
|
|
|
|
|
|
You can zoom in and out the whole content of the frame with the commands:
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
-----------------------|------------------------------------------------------------
|
|
|
|
|
<kbd>SPC z f +</kbd> | zoom in the frame content
|
|
|
|
|
<kbd>SPC z f -</kbd> | zoom out the frame content
|
|
|
|
|
<kbd>SPC z f =</kbd> | reset the frame content size
|
|
|
|
|
<kbd>+</kbd> | zoom in
|
|
|
|
|
<kbd>-</kbd> | zoom out
|
|
|
|
|
<kbd>=</kbd> | reset zoom
|
|
|
|
|
Any other key | leave the zoom frame micro-state
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
### Increase/Decrease numbers
|
|
|
|
|
|
|
|
|
|
`Spacemacs` uses [evil-numbers][] to easily increase or increase numbers.
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
-----------------------|------------------------------------------------------------
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC n +</kbd> | increase the number under point by one and initiate micro-state
|
|
|
|
|
<kbd>SPC n -</kbd> | decrease the number under point by one and initiate micro-state
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
In micro-state:
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
--------------|------------------------------------------------------------
|
2014-11-27 16:02:18 +00:00
|
|
|
|
<kbd>+</kbd> | increase the number under point by one
|
|
|
|
|
<kbd>-</kbd> | decrease the number under point by one
|
2014-11-22 05:45:19 +00:00
|
|
|
|
Any other key | leave the micro-state
|
|
|
|
|
|
|
|
|
|
**Tips:** you can increase or decrease a value by more that once by using a
|
2014-11-27 16:02:18 +00:00
|
|
|
|
prefix argument (ie. `10 SPC n +` will add 10 to the number under point).
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
### Spell checking
|
|
|
|
|
|
|
|
|
|
Spell checking commands start with `S`:
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
---------------------|------------------------------------------------------------
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC S c</kbd> | list of corrections in a `helm` buffer
|
|
|
|
|
<kbd>SPC S d</kbd> | change dictionary language
|
|
|
|
|
<kbd>SPC S n</kbd> | go to the next spell check error
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### Region selection
|
|
|
|
|
|
2014-12-23 03:15:49 +00:00
|
|
|
|
Vi `Visual` modes are all supported by `evil`.
|
|
|
|
|
|
|
|
|
|
#### Expand-region
|
|
|
|
|
|
|
|
|
|
`Spacemacs` adds another `Visual` mode via the [expand-region][] mode.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
-------------------|----------------------------------------------------------------
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC v</kbd> | initiate expand-region mode then...
|
2014-11-27 16:02:18 +00:00
|
|
|
|
<kbd>v</kbd> | expand the region by one semantic unit
|
|
|
|
|
<kbd>V</kbd> | contract the region by one semantic unit
|
|
|
|
|
<kbd>r</kbd> | reset the region to initial selection
|
|
|
|
|
<kbd>ESC</kbd> | leave expand-region mode
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-12-23 03:15:49 +00:00
|
|
|
|
#### Indent text object
|
|
|
|
|
|
|
|
|
|
With [evil-indent-textobject] the following action can be performed in
|
|
|
|
|
`normal state`:
|
|
|
|
|
- <kbd>ii</kbd> - Inner Indentation: the surrounding textblock with the same
|
|
|
|
|
indentation
|
|
|
|
|
- <kbd>ai</kbd> - Above and Indentation: ii + the line above with a different
|
|
|
|
|
indentation
|
|
|
|
|
- <kbd>aI</kbd> - Above and Indentation+: ai + the line below with a different
|
|
|
|
|
indentation
|
|
|
|
|
|
|
|
|
|
Example (`|` is the point):
|
|
|
|
|
|
|
|
|
|
```elisp
|
|
|
|
|
(while (not done)
|
|
|
|
|
(messa|ge "All work and no play makes Jack a dull boy."))
|
|
|
|
|
(1+ 41)
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
- <kbd>vii</kbd> will select the line with message
|
|
|
|
|
- <kbd>vai</kbd> will select the whole while loop
|
|
|
|
|
- <kbd>vaI</kbd> will select the whole fragment
|
|
|
|
|
|
2014-11-22 05:45:19 +00:00
|
|
|
|
### Region narrowing
|
|
|
|
|
|
|
|
|
|
The displayed text of a buffer can be narrowed with the commands
|
|
|
|
|
(start with `n`):
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
-----------------------|----------------------------------------------------------------
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC n f</kbd> | narrow the buffer to the current function
|
|
|
|
|
<kbd>SPC n p</kbd> | narrow the buffer to the visible page
|
|
|
|
|
<kbd>SPC n r</kbd> | narrow the buffer to the selected text
|
|
|
|
|
<kbd>SPC n w</kbd> | widen, i.e show the whole buffer again
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
### Line formatting
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
`Spacemacs` performs `go to the line below point and indent it` with
|
|
|
|
|
<kbd>SPC j k</kbd>.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
You may repeat this operation with `evil-repeat` if you need to indent many lines.
|
|
|
|
|
|
|
|
|
|
Line formatting commands start with `j`:
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
---------------------------|------------------------------------------------------------
|
|
|
|
|
<kbd>J</kbd> | join the current line with the next line
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC j j</kbd> | same as <kbd>SPC j k</kbd> but will split the current line at point
|
|
|
|
|
<kbd>SPC J</kbd> | split a quoted string or s-expression in place
|
|
|
|
|
<kbd>SPC j J</kbd> | split a quoted string or s-expression and auto-indent
|
|
|
|
|
<kbd>SPC j k</kbd> | go to next line and indent it using auto-indent rules
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
Used together these key bindings are very powerful to quickly reformat the code.
|
|
|
|
|
|
|
|
|
|
### Auto-completion
|
|
|
|
|
|
|
|
|
|
`Spacemacs` uses [auto-complete][] auto-completion engine.
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
-------------------|------------------------------------------------------------
|
|
|
|
|
<kbd>C-j</kbd> | select next candidate
|
|
|
|
|
<kbd>C-k</kbd> | select previous candidate
|
|
|
|
|
<kbd>TAB</kbd> | expand selection or select next candidate
|
|
|
|
|
<kbd>S-TAB</kbd> | select previous candidate
|
|
|
|
|
<kbd>return</kbd> | complete word, if word is already completed insert a carriage return
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-12-18 02:26:52 +00:00
|
|
|
|
### Replacing text with iedit
|
|
|
|
|
|
|
|
|
|
`Spacemacs` uses the powerful [iedit][] mode through [evil-iedit-state][] to
|
|
|
|
|
quickly edit multiple occurrences of a symbol or selection.
|
|
|
|
|
|
|
|
|
|
`evil-iedit-state` defines two new evil states:
|
|
|
|
|
- `iedit state`
|
|
|
|
|
- `iedit-insert state`
|
|
|
|
|
|
|
|
|
|
The color code for these states is `red`.
|
|
|
|
|
|
|
|
|
|
`evil-iedit-state` has also a nice integration with [expand-region][] for quick
|
|
|
|
|
edition of the current selected text by pressing <kbd>e</kbd>.
|
|
|
|
|
|
|
|
|
|
#### iedit states key bindings
|
|
|
|
|
|
|
|
|
|
##### State transitions
|
|
|
|
|
|
|
|
|
|
Key Binding | From | To
|
|
|
|
|
-------------------|:------------------:|:-------------------------:
|
|
|
|
|
<kbd>SPC s e</kbd> | normal or visual | iedit
|
|
|
|
|
<kbd>e</kbd> | expand-region | iedit
|
|
|
|
|
<kbd>ESC</kbd> | iedit | normal
|
|
|
|
|
<kbd>C-g</kbd> | iedit | normal
|
|
|
|
|
<kbd>fd</kbd> | iedit | normal
|
|
|
|
|
<kbd>ESC</kbd> | iedit-insert | iedit
|
|
|
|
|
<kbd>C-g</kbd> | iedit-insert | normal
|
|
|
|
|
<kbd>fd</kbd> | iedit-insert | normal
|
|
|
|
|
|
|
|
|
|
To sum-up, in `iedit-insert state` you have to press <kbd>ESC</kbd> twice to
|
|
|
|
|
go back to the `normal state`. You can also at any time press <kbd>C-g</kbd>
|
|
|
|
|
or <kbd>fd</kbd> to return to `normal state`.
|
|
|
|
|
|
|
|
|
|
**Note:** evil commands which switch to `insert state` will switch in
|
|
|
|
|
`iedit-insert state`.
|
|
|
|
|
|
|
|
|
|
##### In iedit state
|
|
|
|
|
|
|
|
|
|
`iedit state` inherits from `normal state`, the following key bindings are
|
|
|
|
|
specific to `iedit state`.
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
------------------|------------------------------------------------------------
|
|
|
|
|
<kbd>ESC</kbd> | go back to `normal state`
|
|
|
|
|
<kbd>TAB</kbd> | toggle current occurrence
|
|
|
|
|
<kbd>0</kbd> | go to the beginning of the current occurrence
|
|
|
|
|
<kbd>$</kbd> | go to the end of the current occurrence
|
|
|
|
|
<kbd>#</kbd> | prefix all occurrences with an increasing number (<kbd>SPC u</kbd> to choose the starting number).
|
|
|
|
|
<kbd>A</kbd> | go to the end of the current occurrence and switch to `iedit-insert state`
|
|
|
|
|
<kbd>D</kbd> | delete the occurrences
|
|
|
|
|
<kbd>F</kbd> | restrict the scope to the function
|
|
|
|
|
<kbd>gg</kbd> | go to first occurrence
|
|
|
|
|
<kbd>G</kbd> | go to last occurrence
|
|
|
|
|
<kbd>I</kbd> | go to the beginning of the current occurrence and switch to `iedit-insert state`
|
|
|
|
|
<kbd>J</kbd> | increase the edition scope by one line below
|
|
|
|
|
<kbd>K</kbd> | increase the edition scope by one line above
|
|
|
|
|
<kbd>L</kbd> | restrict the scope to the current line
|
|
|
|
|
<kbd>n</kbd> | go to next occurrence
|
|
|
|
|
<kbd>N</kbd> | go to previous occurrence
|
|
|
|
|
<kbd>p</kbd> | replace occurrences with last yanked (copied) text
|
|
|
|
|
<kbd>S</kbd> | (substitute) delete the occurrences and switch to `iedit-insert state`
|
|
|
|
|
<kbd>V</kbd> | toggle visibility of lines with no occurrence
|
|
|
|
|
<kbd>U</kbd> | Up-case the occurrences
|
|
|
|
|
<kbd>C-U</kbd> | down-case the occurrences
|
|
|
|
|
|
|
|
|
|
**Note:** <kbd>0</kbd>, <kbd>$</kbd>, <kbd>A</kbd> and <kbd>I</kbd> have the
|
|
|
|
|
default Vim behavior when used outside of an occurrence.
|
|
|
|
|
|
|
|
|
|
##### In iedit-insert state
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
---------------------------|------------------------------------------------------------
|
|
|
|
|
<kbd>ESC</kbd> | go back to `iedit state`
|
|
|
|
|
<kbd>C-g</kbd> | go back to `normal state`
|
|
|
|
|
|
|
|
|
|
#### Examples
|
|
|
|
|
|
|
|
|
|
- manual selection of several words then replace: <kbd>v w w SPC s e S "toto" ESC ESC</kbd>
|
|
|
|
|
- append text to a word on two lines: <kbd>v i w SPC s e J i "toto" ESC ESC</kbd>
|
|
|
|
|
- substitute symbol _with expand-region_: <kbd>SPC v v e S "toto" ESC ESC</kbd>
|
|
|
|
|
- replace symbol with yanked (copied) text _with expand region_: <kbd>SPC v e p ESC ESC</kbd>
|
|
|
|
|
|
2014-11-22 05:45:19 +00:00
|
|
|
|
### Commenting
|
|
|
|
|
|
|
|
|
|
Comments are handled by [evil-nerd-commenter][], it's bound to the following keys.
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
---------------------|------------------------------------------------------------
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC ;</kbd> | comment operator
|
|
|
|
|
<kbd>SPC c i</kbd> | comment invert
|
|
|
|
|
<kbd>SPC c l</kbd> | comment lines
|
|
|
|
|
<kbd>SPC c p</kbd> | comment paragraphs
|
|
|
|
|
<kbd>SPC c r</kbd> | comment region
|
|
|
|
|
<kbd>SPC c t</kbd> | comment to line
|
|
|
|
|
<kbd>SPC c y</kbd> | comment and yank
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
**Tips:** To comment efficiently a block of line use the combo:
|
|
|
|
|
|
|
|
|
|
<SPC> ; <SPC> l
|
|
|
|
|
|
2014-11-29 03:47:03 +00:00
|
|
|
|
### Deleting files
|
|
|
|
|
|
|
|
|
|
Deletion is configured to send deleted files to system trash.
|
|
|
|
|
|
|
|
|
|
On OS X the `trash` program is required. It can be installed with
|
|
|
|
|
[homebrew][] with the following command:
|
|
|
|
|
|
|
|
|
|
```sh
|
|
|
|
|
$ brew install trash
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
To disable the trash you can set the variable `delete-by-moving-to-trash`
|
|
|
|
|
to `nil` in your `~/.spacemacs`.
|
|
|
|
|
|
2014-11-22 05:45:19 +00:00
|
|
|
|
### Editing Lisp code
|
|
|
|
|
|
2015-01-12 04:00:13 +00:00
|
|
|
|
Edition of lisp code is provided by [evil-lisp-state][].
|
|
|
|
|
|
2015-01-21 04:05:56 +00:00
|
|
|
|
Some commands will set the current state to `lisp state` where
|
|
|
|
|
different commands combo can be repeated without pressing on
|
|
|
|
|
<kbd>SPC m</kbd>.
|
2015-01-12 04:00:13 +00:00
|
|
|
|
|
|
|
|
|
When in `lisp state` the color of the mode-line changes to pink.
|
|
|
|
|
|
|
|
|
|
Examples:
|
2015-01-19 03:36:16 +00:00
|
|
|
|
- to slurp three times while in normal state: <kbd>SPC m 3 n</kbd>
|
|
|
|
|
- to wrap a symbol in parenthesis then slurping two times: <kbd>SPC m w 2 n</kbd>
|
2015-01-12 04:00:13 +00:00
|
|
|
|
|
2015-01-21 04:05:56 +00:00
|
|
|
|
#### Lisp state Key Bindings
|
|
|
|
|
|
|
|
|
|
##### Lisp state Auto-switch commands
|
|
|
|
|
|
|
|
|
|
These commands switch to `lisp state`.
|
2015-01-12 04:00:13 +00:00
|
|
|
|
|
|
|
|
|
Key Binding | Function
|
|
|
|
|
---------------------|------------------------------------------------------------
|
2015-01-21 04:05:56 +00:00
|
|
|
|
<kbd>SPC</kbd> | evil leader
|
2015-01-19 03:36:16 +00:00
|
|
|
|
<kbd>SPC m %</kbd> | evil jump item
|
|
|
|
|
<kbd>SPC m :</kbd> | ex command
|
2015-01-12 04:00:13 +00:00
|
|
|
|
<kbd>SPC m (</kbd> | insert expression before (same level as current one)
|
|
|
|
|
<kbd>SPC m )</kbd> | insert expression after (same level as current one)
|
2015-01-19 03:36:16 +00:00
|
|
|
|
<kbd>SPC m $</kbd> | go to the end of current sexp
|
|
|
|
|
<kbd>SPC m 0</kbd> | go to the beginning of current sexp
|
2015-01-12 04:00:13 +00:00
|
|
|
|
<kbd>SPC m a</kbd> | absorb expression
|
2015-01-21 04:05:56 +00:00
|
|
|
|
<kbd>SPC m A</kbd> | transpose expression
|
2015-01-12 04:00:13 +00:00
|
|
|
|
<kbd>SPC m b</kbd> | forward barf expression
|
|
|
|
|
<kbd>SPC m B</kbd> | backward barf expression
|
|
|
|
|
<kbd>SPC m c</kbd> | convolute expression
|
2015-01-19 03:36:16 +00:00
|
|
|
|
<kbd>SPC m h</kbd> | backward char
|
|
|
|
|
<kbd>SPC m H</kbd> | previous symbol
|
2015-01-12 04:00:13 +00:00
|
|
|
|
<kbd>SPC m i</kbd> | switch to `insert state`
|
|
|
|
|
<kbd>SPC m I</kbd> | go to beginning of current expression and switch to `insert state`
|
2015-01-19 03:36:16 +00:00
|
|
|
|
<kbd>SPC m j</kbd> | next visual line
|
|
|
|
|
<kbd>SPC m J</kbd> | next closing parenthesis
|
|
|
|
|
<kbd>SPC m k</kbd> | previous visual line
|
|
|
|
|
<kbd>SPC m K</kbd> | previous opening parenthesis
|
|
|
|
|
<kbd>SPC m l</kbd> | forward char
|
|
|
|
|
<kbd>SPC m L</kbd> | next symbol
|
2015-01-12 04:00:13 +00:00
|
|
|
|
<kbd>SPC m m</kbd> | merge (join) expression
|
|
|
|
|
<kbd>SPC m n</kbd> | forwared slurp expression
|
|
|
|
|
<kbd>SPC m N</kbd> | backward slurp expression
|
|
|
|
|
<kbd>SPC m p</kbd> | paste after
|
|
|
|
|
<kbd>SPC m P</kbd> | paste before
|
|
|
|
|
<kbd>SPC m q</kbd> | unwrap current expression and kill all symbols after point
|
|
|
|
|
<kbd>SPC m Q</kbd> | unwrap current expression and kill all symbols before point
|
|
|
|
|
<kbd>SPC m r</kbd> | raise expression (replace parent expression by current one)
|
|
|
|
|
<kbd>SPC m u</kbd> | undo
|
|
|
|
|
<kbd>SPC m C-r</kbd> | redo
|
|
|
|
|
<kbd>SPC m v</kbd> | switch to `visual state`
|
|
|
|
|
<kbd>SPC m V</kbd> | switch to `visual line state`
|
|
|
|
|
<kbd>SPC m C-v</kbd> | switch to `visual block state`
|
|
|
|
|
<kbd>SPC m w</kbd> | wrap expression with parenthesis
|
|
|
|
|
<kbd>SPC m W</kbd> | unwrap expression
|
|
|
|
|
<kbd>SPC m xs</kbd> | delete symbol
|
|
|
|
|
<kbd>SPC m xw</kbd> | delete word
|
|
|
|
|
<kbd>SPC m xx</kbd> | delete expression
|
|
|
|
|
<kbd>SPC m y</kbd> | copy expression
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-01-21 04:27:46 +00:00
|
|
|
|
##### Lisp state commands
|
|
|
|
|
|
|
|
|
|
These commands can be executed in `lisp state'.
|
|
|
|
|
|
|
|
|
|
Key Binding | Function
|
|
|
|
|
---------------|------------------------------------------------------------
|
|
|
|
|
<kbd>h</kbd> | backward char
|
|
|
|
|
<kbd>j</kbd> | next visual line
|
|
|
|
|
<kbd>k</kbd> | previous visual line
|
|
|
|
|
<kbd>l</kbd> | forward char
|
|
|
|
|
|
2015-01-21 04:05:56 +00:00
|
|
|
|
##### Lisp state Other commands
|
|
|
|
|
|
2015-01-21 04:27:46 +00:00
|
|
|
|
These commands can be executed in any state.
|
2015-01-21 04:05:56 +00:00
|
|
|
|
|
|
|
|
|
Key Binding | Function
|
|
|
|
|
---------------------|------------------------------------------------------------
|
|
|
|
|
<kbd>SPC m e $</kbd> | go to end of line and evaluate last sexp
|
|
|
|
|
<kbd>SPC m e e</kbd> | evaluate last sexp
|
|
|
|
|
<kbd>SPC m e f</kbd> | evaluate current defun
|
|
|
|
|
<kbd>SPC m g g</kbd> | go to definition
|
2015-01-21 04:27:46 +00:00
|
|
|
|
<kbd>SPC m h h</kbd> | describe elisp thing at point (show documentation)
|
2015-01-21 04:05:56 +00:00
|
|
|
|
<kbd>SPC m t b</kbd> | execute buffer tests
|
|
|
|
|
<kbd>SPC m t q</kbd> | ask for test function to execute
|
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
### Managing projects
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
Projects in `Spacemacs` are managed with [projectile][projectile]. In
|
|
|
|
|
`projectile` 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.
|
|
|
|
|
|
2014-11-28 00:24:56 +00:00
|
|
|
|
`Helm` is used whenever it is possible.
|
|
|
|
|
|
|
|
|
|
To search in a project see [project searching](#project-searching).
|
|
|
|
|
|
|
|
|
|
`projectile` commands start with <kbd>p</kbd>:
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
--------------------|------------------------------------------------------------
|
|
|
|
|
<kbd>SPC p /</kbd> | run `ag`
|
|
|
|
|
<kbd>SPC p a</kbd> | run `ag`
|
|
|
|
|
<kbd>SPC p A</kbd> | run `ack`
|
|
|
|
|
<kbd>SPC p b</kbd> | switch to project buffer
|
|
|
|
|
<kbd>SPC p d</kbd> | find directory
|
|
|
|
|
<kbd>SPC p D</kbd> | open project root in `dired`
|
|
|
|
|
<kbd>SPC p f</kbd> | find file
|
|
|
|
|
<kbd>SPC p g</kbd> | run `grep`
|
|
|
|
|
<kbd>SPC p h</kbd> | find file using `helm`
|
|
|
|
|
<kbd>SPC p I</kbd> | invalidate the projectile cache
|
|
|
|
|
<kbd>SPC p j</kbd> | find a tag
|
|
|
|
|
<kbd>SPC p k</kbd> | kill all project buffers
|
|
|
|
|
<kbd>SPC p o</kbd> | run `multi-occur`
|
|
|
|
|
<kbd>SPC p R</kbd> | regenerate the project's [e|g]tags
|
|
|
|
|
<kbd>SPC p r</kbd> | replace a string
|
|
|
|
|
<kbd>SPC p s</kbd> | switch project
|
|
|
|
|
<kbd>SPC p t</kbd> | find tags
|
|
|
|
|
<kbd>SPC p T</kbd> | find test files
|
|
|
|
|
<kbd>SPC p v</kbd> | open project root in `vc-dir` or `magit`
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
## Registers
|
|
|
|
|
|
|
|
|
|
Access commands to the various registers start with `r`:
|
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
---------------------|------------------------------------------------------------
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC r e</kbd> | show evil yank and named registers
|
|
|
|
|
<kbd>SPC r m</kbd> | show marks register
|
|
|
|
|
<kbd>SPC r r</kbd> | show helm register
|
|
|
|
|
<kbd>SPC r y</kbd> | show kill ring
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
## Errors handling
|
|
|
|
|
|
|
|
|
|
`Spacemacs` uses [Flycheck][flycheck] to gives error feedback on the fly.
|
|
|
|
|
The checks are only performed at save time by default.
|
|
|
|
|
|
2014-12-23 03:54:56 +00:00
|
|
|
|
Errors management commands (star with `e`):
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
---------------------|------------------------------------------------------------
|
2014-12-23 03:54:56 +00:00
|
|
|
|
<kbd>SPC e c</kbd> | clear all errors
|
|
|
|
|
<kbd>SPC e f</kbd> | toggle flycheck
|
|
|
|
|
<kbd>SPC e l</kbd> | display the `flycheck` list of errors/warnings
|
|
|
|
|
<kbd>SPC e n</kbd> | go to the next error
|
|
|
|
|
<kbd>SPC e p</kbd> | go to the previous error
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
Custom fringe bitmaps:
|
|
|
|
|
|
2014-12-19 04:04:23 +00:00
|
|
|
|
Symbol | Description
|
|
|
|
|
:----------------------------------:|------------
|
2014-12-12 00:55:44 +00:00
|
|
|
|
![dot-error](img/dot-error.png) | Error
|
|
|
|
|
![dot-warning](img/dot-warning.png) | warning
|
|
|
|
|
![dot-info](img/dot-info.png) | Info
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-12-05 05:02:26 +00:00
|
|
|
|
## Compiling
|
|
|
|
|
|
|
|
|
|
`Spacemacs` binds a few commands to support compiling a project.
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
---------------------|------------------------------------------------------------
|
2014-12-19 04:04:23 +00:00
|
|
|
|
<kbd>SPC c c</kbd> | use `helm-make` via projectile
|
|
|
|
|
<kbd>SPC c C</kbd> | compile
|
|
|
|
|
<kbd>SPC c r</kbd> | recompile
|
2014-12-05 05:02:26 +00:00
|
|
|
|
|
2014-11-22 05:45:19 +00:00
|
|
|
|
## Modes
|
|
|
|
|
|
2014-12-19 05:35:14 +00:00
|
|
|
|
### Major Mode leader key
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-12-19 05:35:14 +00:00
|
|
|
|
Key bindings specific to the current `major mode` start with <kbd>SPC m</kbd>.
|
|
|
|
|
For convenience a shortcut key called the major mode leader key is set by
|
|
|
|
|
default on <kbd>,</kbd> which saves one precious keystroke.
|
|
|
|
|
|
|
|
|
|
It is possible to change the major mode leader key by defining the variable
|
|
|
|
|
`dotspacemacs-major-mode-leader-key` in your `~/.spacemacs`. For example to
|
|
|
|
|
setup the key on tabulation:
|
|
|
|
|
|
|
|
|
|
```elisp
|
2014-12-19 04:04:23 +00:00
|
|
|
|
(setq-default dotspacemacs-major-mode-leader-key "<tab>")
|
2014-12-19 05:35:14 +00:00
|
|
|
|
```
|
|
|
|
|
|
2014-11-22 05:45:19 +00:00
|
|
|
|
### Helm
|
|
|
|
|
|
|
|
|
|
`Spacemacs` add `hjkl` navigation to `helm` buffers:
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
------------------|------------------------------------------------------------
|
2014-11-27 16:02:18 +00:00
|
|
|
|
<kbd>CTRL+h</kbd> | go to previous page
|
|
|
|
|
<kbd>CTRL+j</kbd> | go to previous item
|
|
|
|
|
<kbd>CTRL+k</kbd> | go to next item
|
|
|
|
|
<kbd>CTRL+l</kbd> | go to next page
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
### Org
|
|
|
|
|
|
2014-11-27 15:31:44 +00:00
|
|
|
|
In `org`, [evil-org-mode][] is activated.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-11-27 16:02:18 +00:00
|
|
|
|
Key Binding | Description
|
|
|
|
|
----------------------|------------------------------------------------------------
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC m a</kbd> | org-agenda
|
|
|
|
|
<kbd>SPC m A</kbd> | org-archive-subtree
|
2014-12-12 03:42:01 +00:00
|
|
|
|
<kbd>SPC m c</kbd> | org-capture
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC m C</kbd> | evil-org-recompute-clocks
|
2014-12-12 03:42:01 +00:00
|
|
|
|
<kbd>SPC m d</kbd> | org-deadline
|
|
|
|
|
<kbd>SPC m e</kbd> | org-export-dispatch
|
|
|
|
|
<kbd>SPC m i</kbd> | org-clock-in
|
2014-12-03 05:19:14 +00:00
|
|
|
|
<kbd>SPC m l</kbd> | evil-org-open-links
|
2014-12-12 03:42:01 +00:00
|
|
|
|
<kbd>SPC m m</kbd> | org-ctrl-c-ctrl-c
|
|
|
|
|
<kbd>SPC m o</kbd> | org-clock-out
|
|
|
|
|
<kbd>SPC m r</kbd> | org-refile
|
|
|
|
|
<kbd>SPC m s</kbd> | org-schedule
|
|
|
|
|
<kbd>SPC m t</kbd> | org-show-todo-tree
|
2014-11-27 16:02:18 +00:00
|
|
|
|
<kbd>gh</kbd> | outline-up-heading
|
|
|
|
|
<kbd>gj</kbd> | org-forward-heading-same-level
|
|
|
|
|
<kbd>gk</kbd> | org-backward-heading-same-level
|
|
|
|
|
<kbd>gl</kbd> | outline-next-visible-heading
|
|
|
|
|
<kbd>t</kbd> | org-todo
|
|
|
|
|
<kbd>T</kbd> | org-insert-todo-heading nil
|
|
|
|
|
<kbd>H</kbd> | org-beginning-of-line
|
|
|
|
|
<kbd>L</kbd> | org-end-of-line
|
|
|
|
|
<kbd>o</kbd> | always-insert-item
|
|
|
|
|
<kbd>O</kbd> | org-insert-heading
|
|
|
|
|
<kbd>$</kbd> | org-end-of-line
|
|
|
|
|
<kbd>^</kbd> | org-beginning-of-line
|
|
|
|
|
<kbd><</kbd> | org-metaleft
|
|
|
|
|
<kbd>></kbd> | org-metaright
|
|
|
|
|
<kbd>TAB</kbd> | org-cycle
|
|
|
|
|
<kbd>M-l</kbd> | org-metaright
|
|
|
|
|
<kbd>M-h</kbd> | org-metaleft
|
|
|
|
|
<kbd>M-k</kbd> | org-metaup
|
|
|
|
|
<kbd>M-j</kbd> | org-metadown
|
|
|
|
|
<kbd>M-L</kbd> | org-shiftmetaright
|
|
|
|
|
<kbd>M-H</kbd> | org-shiftmetaleft
|
|
|
|
|
<kbd>M-K</kbd> | org-shiftmetaup
|
|
|
|
|
<kbd>M-J</kbd> | org-shiftmetadown
|
|
|
|
|
<kbd>M-o</kbd> | org-insert-heading+org-metaright
|
|
|
|
|
<kbd>M-t</kbd> | org-insert-todo-heading nil+ org-metaright
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
### Python
|
|
|
|
|
|
2014-11-22 06:17:38 +00:00
|
|
|
|
Writing python code with spacemacs is supported by python contribution. Please see
|
|
|
|
|
[python contribution][python-contrib] documentation for detail.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
### JavaScript
|
|
|
|
|
|
2014-12-07 17:57:09 +00:00
|
|
|
|
More featured JavaScript support is provided by the javascript contribution. Please see
|
|
|
|
|
[javascript contribution][javascript-contrib] documentation for detail.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
### rcirc
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
------------------|------------------------------------------------------------
|
2014-11-27 16:02:18 +00:00
|
|
|
|
<kbd>CTRL+j</kbd> | next item in command history
|
|
|
|
|
<kbd>CTRL+k</kbd> | previous item in command history
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2014-12-16 03:23:55 +00:00
|
|
|
|
### HTML and CSS
|
|
|
|
|
|
|
|
|
|
HTML contribution provides support for editing HTML, CSS, Scss and Less files. Please see
|
|
|
|
|
[html contribution][html-contrib] documentation for detail.
|
|
|
|
|
|
2014-12-13 05:50:25 +00:00
|
|
|
|
# Emacs Server
|
|
|
|
|
|
|
|
|
|
`Spacemacs` starts a server at launch. This server is killed whenever you close
|
|
|
|
|
your Emacs windows.
|
|
|
|
|
|
|
|
|
|
## Connecting to the Emacs server
|
|
|
|
|
|
|
|
|
|
TODO
|
|
|
|
|
|
|
|
|
|
## Keeping the server alive
|
|
|
|
|
|
|
|
|
|
It is possible to keep the server alive when you close Emacs by setting the
|
|
|
|
|
variable `dotspacemacs-persistent-server` to `t` in your `~./spacemacs`.
|
|
|
|
|
|
|
|
|
|
```elisp
|
|
|
|
|
(setq-default dotspacemacs-persistent-server t)
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
When this variable is set to `t`, the only way to quit Emacs _and_ kill the
|
|
|
|
|
server is to use the following bindings:
|
|
|
|
|
|
|
|
|
|
Key Binding | Description
|
|
|
|
|
-------------------|------------------------------------------------------------
|
2015-01-29 16:19:55 +00:00
|
|
|
|
<kbd>SPC q q</kbd> | Quit Emacs and kill the server, prompt for changed buffers to save
|
|
|
|
|
<kbd>SPC q Q</kbd> | Quit Emacs and kill the server, lose all unsaved changes.
|
2014-12-13 05:50:25 +00:00
|
|
|
|
<kbd>SPC q s</kbd> | Save the buffers, quit Emacs and kill the server
|
2015-01-29 16:19:55 +00:00
|
|
|
|
<kbd>SPC q z</kbd> | Kill the current frame
|
2014-12-13 05:50:25 +00:00
|
|
|
|
|
2014-11-22 05:45:19 +00:00
|
|
|
|
## Troubleshoot
|
|
|
|
|
|
|
|
|
|
### Loading fails
|
|
|
|
|
|
|
|
|
|
If during the first boot of Emacs nothing seems to happen or if the
|
|
|
|
|
installation seems to abort prematurely, you can check for an error message
|
|
|
|
|
by opening the `*Warning*` buffer:
|
|
|
|
|
|
|
|
|
|
C-x b warning RET
|
|
|
|
|
|
|
|
|
|
_('C-x b' means 'Ctrl + x then b' and 'RET' means 'return')_
|
|
|
|
|
|
|
|
|
|
Then you can copy/paste the error in a [Github issue][issues], thank you.
|
|
|
|
|
|
|
|
|
|
### I have no file ~/.spacemacs
|
|
|
|
|
|
2014-12-02 04:18:20 +00:00
|
|
|
|
You have to manually copy the `~/.emacs.d/core/templates/.spacemacs.template`
|
|
|
|
|
file to `~/.spacemacs`
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-01-01 06:15:34 +00:00
|
|
|
|
# Tips
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
2015-01-01 06:15:34 +00:00
|
|
|
|
## evil-lisp-state as default state
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
To Make `lisp state` the default state in `Emacs Lisp` buffers, insert in
|
|
|
|
|
your `~/.spacemacs` the following snippet:
|
|
|
|
|
|
|
|
|
|
```elisp
|
|
|
|
|
(defun dotspacemacs/config ()
|
|
|
|
|
(add-hook 'emacs-lisp-mode-hook 'evil-lisp-state))
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
# Achievements
|
|
|
|
|
|
|
|
|
|
Achievements | Account
|
|
|
|
|
-----------------------------------------------------|------------------------
|
|
|
|
|
[First contribution][1st-contrib] | [trishume][]
|
|
|
|
|
[First contribution layer][1st-clayer] | [trishume][]
|
|
|
|
|
[First blog article on Spacemacs][1st-article] | [Wolfy87][]
|
2014-12-30 05:04:03 +00:00
|
|
|
|
[First contributed banner][1st-cbanner] | [chrisbarrett][]
|
2014-12-23 04:38:07 +00:00
|
|
|
|
[100th issue (PR)][100th-issue] | [danielwuz][]
|
2014-12-19 06:07:35 +00:00
|
|
|
|
[200th issue (question)][200th-issue] | [justrajdeep][]
|
2014-12-23 04:38:07 +00:00
|
|
|
|
[300th issue (PR)][300th-issue] | [danielwuz][]
|
2015-01-10 04:55:17 +00:00
|
|
|
|
[400th issue (PR)][400th-issue] | [CestDiego][]
|
2015-01-31 03:59:59 +00:00
|
|
|
|
[500th issue (PR)][500th-issue] | [bjarkevad][]
|
2014-12-09 02:30:12 +00:00
|
|
|
|
[100th pull request][100th-PR] | [bru][]
|
2015-01-15 03:44:13 +00:00
|
|
|
|
[200th pull request][200th-PR] | [smt][]
|
2014-12-23 04:38:07 +00:00
|
|
|
|
PR gunner (8 PRs in a row) | [ralesi][]
|
2015-01-31 04:02:04 +00:00
|
|
|
|
100th fork | [balajisivaraman][]
|
2014-11-22 05:45:19 +00:00
|
|
|
|
100th star | [Jackneill][]
|
2014-12-02 02:48:21 +00:00
|
|
|
|
200th star | [jb55][]
|
2014-12-19 06:07:35 +00:00
|
|
|
|
400th star | [dbohdan][]
|
2015-01-24 03:15:06 +00:00
|
|
|
|
600th star | [laat][]
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
# Thank you
|
|
|
|
|
|
2014-11-22 06:17:38 +00:00
|
|
|
|
[Jokes aside](#using-configuration-layers), thank you Richard for this great
|
|
|
|
|
piece of software.
|
2014-11-22 05:45:19 +00:00
|
|
|
|
|
|
|
|
|
Thank you to all the contributors and the whole Emacs community from core
|
|
|
|
|
developers to elisp hackers!
|
|
|
|
|
|
2015-02-09 02:21:23 +00:00
|
|
|
|
[CONVENTIONS.md]: ./CONVENTIONS.md
|
2014-11-22 05:45:19 +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
|
2015-02-05 04:13:52 +00:00
|
|
|
|
[helm-link]: https://github.com/emacs-helm/helm
|
|
|
|
|
[helm-doc]: https://github.com/emacs-helm/helm/wiki
|
2014-11-22 05:45:19 +00:00
|
|
|
|
[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
|
2015-01-27 04:21:05 +00:00
|
|
|
|
[font-spec]: http://www.gnu.org/software/emacs/manual/html_node/elisp/Low_002dLevel-Font.html
|
2014-11-22 05:45:19 +00:00
|
|
|
|
[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
|
2014-11-28 00:13:51 +00:00
|
|
|
|
[ag]: https://github.com/ggreer/the_silver_searcher
|
2014-11-22 05:45:19 +00:00
|
|
|
|
[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
|
|
|
|
|
[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
|
2014-12-18 02:26:52 +00:00
|
|
|
|
[iedit]: https://github.com/tsdh/iedit
|
|
|
|
|
[evil-iedit-state]: https://github.com/syl20bnr/evil-iedit-state
|
2014-12-23 03:15:49 +00:00
|
|
|
|
[evil-indent-textobject]: https://github.com/cofi/evil-indent-textobject
|
2014-11-22 05:45:19 +00:00
|
|
|
|
[evil-visualstar]: https://github.com/bling/evil-visualstar
|
|
|
|
|
[evil-exchange]: https://github.com/Dewdrops/evil-exchange
|
|
|
|
|
[evil-surround]: https://github.com/timcharper/evil-surround
|
|
|
|
|
[camelcasemotion.vim]: http://www.vim.org/scripts/script.php?script_id=1905
|
|
|
|
|
[vim-exchange]: https://github.com/tommcdo/vim-exchange
|
|
|
|
|
[vim-surround]: https://github.com/tpope/vim-surround
|
|
|
|
|
[evil-nerd-commenter]: https://github.com/redguardtoo/evil-nerd-commenter
|
|
|
|
|
[nerdcommenter]: https://github.com/scrooloose/nerdcommenter
|
2015-01-16 04:45:53 +00:00
|
|
|
|
[evil-matchit]: https://github.com/redguardtoo/evil-matchit
|
|
|
|
|
[matchit.vim]: http://www.vim.org/scripts/script.php?script_id=39
|
2014-12-15 04:27:08 +00:00
|
|
|
|
[source code pro]: https://github.com/adobe-fonts/source-code-pro
|
2014-11-22 05:45:19 +00:00
|
|
|
|
[evil-escape]: https://github.com/syl20bnr/evil-escape
|
|
|
|
|
[evil-args]: https://github.com/wcsmith/evil-args
|
|
|
|
|
[evil-jumper]: https://github.com/bling/evil-jumper
|
|
|
|
|
[evil-numbers]: https://github.com/cofi/evil-numbers
|
|
|
|
|
[evil-org-mode]: https://github.com/edwtjo/evil-org-mode
|
|
|
|
|
[evil-lisp-state]: https://github.com/syl20bnr/evil-lisp-state
|
2015-02-05 04:13:52 +00:00
|
|
|
|
[Vim's Unit]: https://github.com/Shougo/unite.vim
|
2014-12-14 04:59:02 +00:00
|
|
|
|
[git-gutter]: https://github.com/syohex/emacs-git-gutter-fringe
|
2014-11-22 05:45:19 +00:00
|
|
|
|
[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
|
|
|
|
|
[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-12-02 05:11:47 +00:00
|
|
|
|
[leuven-theme]: https://github.com/fniessen/emacs-leuven-theme
|
2014-11-22 05:45:19 +00:00
|
|
|
|
[monokai-theme]: https://github.com/oneKelvinSmith/monokai-emacs
|
|
|
|
|
[zenburn-theme]: https://github.com/bbatsov/zenburn-emacs
|
|
|
|
|
[ido-vertical-mode]: https://github.com/gempesaw/ido-vertical-mode.el
|
|
|
|
|
[issues]: https://github.com/syl20bnr/spacemacs/issues
|
|
|
|
|
[vundle]: https://github.com/gmarik/Vundle.vim
|
|
|
|
|
[anzu]: https://github.com/syohex/emacs-anzu
|
2015-01-26 04:26:09 +00:00
|
|
|
|
[javascript-contrib]: ../contrib/lang/javascript
|
|
|
|
|
[themes-megapack]: ../contrib/themes-megapack
|
|
|
|
|
[python-contrib]: ../contrib/lang/python
|
2015-01-26 04:22:41 +00:00
|
|
|
|
[git layer]: ../contrib/git
|
2015-01-26 04:26:09 +00:00
|
|
|
|
[html-contrib]: ../contrib/lang/html
|
2014-11-22 05:45:19 +00:00
|
|
|
|
[guide-key]: https://github.com/kai2nenobu/guide-key
|
|
|
|
|
[guide-key-tip]: https://github.com/aki2o/guide-key-tip
|
|
|
|
|
[gitter]: https://gitter.im/syl20bnr/spacemacs
|
2015-01-26 04:26:09 +00:00
|
|
|
|
[CONTRIBUTE.md]: ./CONTRIBUTE.md
|
2014-11-22 05:45:19 +00:00
|
|
|
|
[neotree]: https://github.com/jaypei/emacs-neotree
|
|
|
|
|
[nerdtree]: https://github.com/scrooloose/nerdtree
|
|
|
|
|
[anaconda-mode]: https://github.com/proofit404/anaconda-mode
|
|
|
|
|
[1st-contrib]: https://github.com/syl20bnr/spacemacs/pull/19
|
|
|
|
|
[1st-clayer]: https://github.com/syl20bnr/spacemacs/commit/e802027d75d0c0aed55539b0da2dfa0df94dfd39
|
|
|
|
|
[1st-article]: http://oli.me.uk/2014/11/06/spacemacs-emacs-vim/
|
2014-12-30 05:04:03 +00:00
|
|
|
|
[1st-cbanner]: https://github.com/syl20bnr/spacemacs/commit/7b44a56263049482ed540ed6815a295633ffe9d1
|
2014-11-22 05:45:19 +00:00
|
|
|
|
[100th-issue]: https://github.com/syl20bnr/spacemacs/pull/100
|
2014-12-19 06:07:35 +00:00
|
|
|
|
[200th-issue]: https://github.com/syl20bnr/spacemacs/pull/200
|
|
|
|
|
[300th-issue]: https://github.com/syl20bnr/spacemacs/pull/300
|
2015-01-10 04:55:17 +00:00
|
|
|
|
[400th-issue]: https://github.com/syl20bnr/spacemacs/pull/400
|
2015-01-31 03:59:59 +00:00
|
|
|
|
[500th-issue]: https://github.com/syl20bnr/spacemacs/pull/500
|
2014-12-09 02:30:12 +00:00
|
|
|
|
[100th-PR]: https://github.com/syl20bnr/spacemacs/pull/228
|
2015-01-15 03:44:13 +00:00
|
|
|
|
[200th-PR]: https://github.com/syl20bnr/spacemacs/pull/418
|
2014-11-22 05:45:19 +00:00
|
|
|
|
[trishume]:https://github.com/trishume
|
|
|
|
|
[Wolfy87]:https://github.com/Wolfy87
|
|
|
|
|
[danielwuz]:https://github.com/danielwuz
|
2015-01-10 04:55:17 +00:00
|
|
|
|
[CestDiego]:https://github.com/CestDiego
|
2015-01-31 03:59:59 +00:00
|
|
|
|
[bjarkevad]:https://github.com/bjarkevad
|
2014-12-30 05:04:03 +00:00
|
|
|
|
[chrisbarrett]:https://github.com/chrisbarrett
|
2014-12-19 06:07:35 +00:00
|
|
|
|
[justrajdeep]:https://github.com/justrajdeep
|
|
|
|
|
[dbohdan]:https://github.com/dbohdan
|
2015-01-24 03:15:06 +00:00
|
|
|
|
[laat]:https://github.com/laat
|
2014-12-09 02:30:12 +00:00
|
|
|
|
[bru]:https://github.com/bru
|
2015-01-15 03:44:13 +00:00
|
|
|
|
[smt]:https://github.com/smt
|
2014-12-23 04:38:07 +00:00
|
|
|
|
[ralesi]:https://github.com/ralesi
|
2015-01-31 04:02:04 +00:00
|
|
|
|
[balajisivaraman]:https://github.com/balajisivaraman
|
2014-11-22 05:45:19 +00:00
|
|
|
|
[Jackneill]:https://github.com/Jackneill
|
2014-12-02 02:48:21 +00:00
|
|
|
|
[jb55]:https://github.com/jb55
|
2014-11-22 05:45:19 +00:00
|
|
|
|
[use-package]: https://github.com/jwiegley/use-package
|
2014-12-06 01:35:39 +00:00
|
|
|
|
[Paradox]: https://github.com/Bruce-Connor/paradox
|
2014-11-24 03:34:57 +00:00
|
|
|
|
[fancy-battery]: https://github.com/lunaryorn/fancy-battery.el
|
2014-12-06 06:31:30 +00:00
|
|
|
|
[MacType]: https://code.google.com/p/mactype/
|