category | tool | filename | contributors | |||
---|---|---|---|---|---|---|
tool |
emacs |
emacs.txt |
|
Emacs started its life as "the extensible, customizable display editor" and grew over the years into a full-blown ecosystem. Many tasks, usually relegated to a diverse set of tools can be accomplished from within Emacs in a consistent, familiar interface. Examples include directory management, viewing PDF documents, editing files over SSH, managing git repos,… (the list is quite long). In short, Emacs is yours to make of it what you will: the spectrum of users varies from those who use it to edit text files to extreme purists who use it to virtually replace their operating system.
Emacs is extensible via a specialized dialect of Lisp known as Emacs Lisp (Elisp) which has a lot of macros geared towards editing text and managing text buffers. Any key (combination) you use in Emacs is bound to an Emacs Lisp function and may be remapped to any other function, including ones you write yourself.
The Emacs manual and the community in general uses a convention to refer to different key combinations used within Emacs. Specifically, Emacs has the notion of a "modifier key" that is pressed along with another key to modify its action.
An example of this notation is "C-c". In this key combination "C" is the modifier and stands for the "Ctrl" key and "c" is the key whose action is being modified (the literal character "c").
The modifier shorthand:
"C-" --> The "CTRL" key
"M-" --> The "Meta" key (usually, the "Alt" key)
"s-" --> The "Super" key (the "Cmd" key on Macs and the "Windows" key on PCs)
There are other, less commonly used modifiers that I will not get into here.
The key combination "C-x C-s" means you press "Ctrl+x" followed by "Ctrl+s"
In addition to the above modifiers, the special keys "Esc", "Return (Enter)" and "Shift" are denoted by "ESC", "RET" and "S", respectively.
Here, I discuss some basic Emacs concepts and terminology that may be confusing to newcomers (especially to people used to Vim terminology)
- A bunch of text that Emacs is editing is known as a buffer
- A buffer does not necessarily correspond to an actual file on disk. It may be just a bunch of text in memory.
- When a buffer corresponds to a file on disk, we say that the buffer is visiting that file.
- Emacs typically has many buffers open at once.
- The display of Emacs may be split into different windows (not to be confused with your operating system's windows: the operating system window for Emacs can have multiple Emacs windows inside it).
- An operating system window for Emacs is called an Emacs frame. Thus, when the Emacs manual talks about opening a new frame, this essentially means opening a new OS window containing an(other) instance of Emacs.
- The concepts conventionally known as cutting and pasting are referred to as killing and yanking, respectively in Emacs parlance.
- The current position of the cursor is called the point in Emacs. Technically, point is defined as the position right before the character where the cursor currently is.
- Finally, each buffer may have several modes associated with it: a major mode and possibly several minor modes.
- The major mode defines the main behavior of Emacs in the
currently selected buffer. This can be roughly thought of as the
file type. For example, if you're editing a Python file, the major
mode is (by default)
python-mode
which causes Emacs to highlight Python syntax and automatically indent and outdent your code blocks as syntactically required by your Python code. - Minor modes define subtle changes in behavior and several minor
modes may be active at once in the same buffer. An example minor
mode is
flyspell-mode
which automatically highlights spelling errors in your buffer.
The GUI version of Emacs can be navigated with the mouse like you would expect from a conventional GUI text editor.
The aim here is to focus on navigation solely using the keyboard as this enhances productivity immensely.
* Line movement
C-n --> Next line
C-p --> Previous line
* Character movement
C-f --> Go forward one character
C-b --> Go backward one character
* Word movement
M-f --> Go forward one word
M-b --> Go backward one word
* Sentence movement
M-a --> Move to the beginning of the sentence
M-e --> Move to the end of the sentence
* Beginning and end of line
C-a --> Move to the beginning of the line
C-e --> Move to the end of the line
* Beginning and end of buffer
M-< ("Meta+Shift+,") --> Go to the beginning of the buffer
M-> ("Meta+Shift+.") --> Go to the end of the buffer
* Screen movement
C-v --> Scroll down by one screen-full (the last two lines of the previous screen are kept as overlap for a smoother transition)
M-v --> Scroll up by one screen-full (same as above but with the first two lines)
* Centering the screen
C-l --> Move current line to the screen's center
The above key combination actually cycles through different states depending on how many times it's been pressed.
C-l --> Move current line to the screen's center
C-l C-l --> Move current line to the top of the screen
C-l C-l C-l --> Restore the position of the current line to where it was before the first C-l was pressed
If you press "C-l" a 4th time, it cycles back to centering the current line.
* Repeating movement commands
Most movement commands take a numerical prefix argument that says "repeat the following command that many times".
Example:
C-u 3 C-p --> Go up 3 lines
C-u 5 C-f --> Go forward 5 characters
One notable exception are the screen scrolling commands:
C-u 3 C-v --> Scroll downward 3 lines (maintaining the position of the cursor)
Bonus: many of the above navigation commands are the default navigation commands in Bash (e.g. pressing "C-b" while entering a Bash command takes you back one character).
* Quitting Emacs [ Now you can't say you don't know how to quit Emacs :-) ]
C-x C-c --> Quit Emacs and get prompted to save any unsaved files (buffers not visiting a file will simply be discarded unless you're running in client-server mode)
* Saving a buffer
C-x C-s --> Save the current buffer. If not visiting a file, it will prompt you for a file name to use to save the buffer.
* Searching within a buffer
C-s --> Search forwards within the buffer. Search is incremental and case-insensitive by default.
Press C-s to move to the next match.
If you press "RET", point is moved to the currently highlighted word and the search ends.
C-r --> Same as C-s except it searches backward
C-_ or C-/ --> Undo the last action. Keep pressing it to move up the undo tree.
C-? or M-_ --> Redo the previous change
The "undo" and "redo" commands can take prefix numerical arguments to undo or redo that many actions:
C-u 3 C-_ --> Undo the last 3 changes.
You can execute any currently loaded Elisp functions (including ones you have written yourself) via "M-x"
M-x RET --> Prompts you for name of function to execute (Tab completion is available).
Example:
M-x RET search-forward-regexp RET --> Prompts you for a regular expression and searches forward in the buffer for it
Emacs is configured using Elisp. On startup, it looks for a
configuration file either in ~/.emacs
or ~/.emacs.d/init.el
where
~
refers to your home directory. If you're on Windows, consult this
article
for the appropriate location of your configuration file.
If you are considering the transition from Vim to Emacs and you're put
off by the non-modal nature of Emacs editing, there is an Emacs
extension known as evil-mode
which lets you have many Vim concepts
inside Emacs. Here are some things added to Emacs by evil-mode
:
- Modal editing: you get normal, insert, visual and block visual modes like Vim. In addition, you get an "Emacs" mode where movement and navigation follow the Emacs bindings.
- Same movement keys as Vim in normal mode
- Leader key combinations
- Pressing ":" in normal mode allows you to execute commands (including system commands)
In my own experience, evil-mode
helps make the transition seamless and
allows you to blend the arguably more intuitive and ergonomic
keybindings of Vim with the unbridled power of Emacs for a truly
superior editing experience.
Emacs features a pretty powerful help system that allows you to discover new functionality all the time.
Obtaining help on specific topics. Tab completion is available for function and variable names.
C-h f RET --> Prompts you for the name of an elisp function and
displays help text on it along with a clickable link
to its source code.
C-h v RET --> Same as above with variables
C-h k RET --> Allows you to enter a key combination and displays the
name of the elisp function bound to it.
Searching for help:
C-h a --> Prompts you for a string to search for a command in the
help system. Similar to the 'apropos' or 'man -k'
commands in Unix systems.
Starting a tutorial:
C-h C-t --> Starts a tutorial designed to familiarize you with
basic Emacs functionality.
As I hinted above, Emacs functionality goes way beyond being a mere text editor. I will list here a couple of Emacs "apps" that are fairly powerful and popular and may interest you in and of themselves.
Technnically, org-mode
, a major mode for buffer editing that provides
organizational tools. It is very difficult to succinctly describe what
Org can do because it's a behemoth of a tool that has many diverse uses
to different people. I will attempt to describe the main features I use
briefly.
- Divide your file into sections and sub-sections for easy outlining and organizing of concepts.
- Different headings in the outline are foldable/expandable so that you can focus on what you need to focus on and eliminate distractions.
- You can maintain a TODO list within Org
- You can compile TODO lists from many files into an agenda
- Track the time you spend on each TODO task
- Manage tables in plain text (including spreadsheet-like capabilities)
- Using the extension
org-babel
, write and execute code blocks in your file. The results are captured and are re-usable within the file itself. Think Jupyter notebook for any language. - Display inline images and LaTeX formulas as images within your file (makes for a great note-taking system and/or personal wiki)
- Export your file into many different formats (LaTeX, PDF, html,…)
Org mode is a very powerful tool to add to your productivity arsenal and, on a personal note, was the reason that caused me to start using Emacs after years of using Vim.
This is a frontend to git
from within Emacs. It features a very
intuitive and discoverable interface, yet exposes very powerful
functionality that allows you to manage commits at the chunk level,
inspect diffs, rebase, cherry-pick, … all from within the comfort of
your own editor.
If you are considering using Emacs, a common trap that beginning users fall into is to copy someone else's configuration file and use it as is. I highly recommend against doing this for several reasons:
- It will discourage you from learning and finding things out for yourself
- Someone else's configuration will probably contain many things relevant to them that you won't need or ever use.
- It defeats the purpose of having a customizable text editor that can fit your own needs.
What I encourage you to do is to look at other people's configurations and seek to understand them and adapt only what makes sense to you. You can find out about new features of Emacs through many YouTube videos, screencasts or blog posts and then learn for yourself how to add them to your configuration and workflow. This way, you grow your configuration incrementally while increasing your knowledge of Emacs along the way.