Skip to content

Latest commit

 

History

History
729 lines (689 loc) · 52.7 KB

init.org

File metadata and controls

729 lines (689 loc) · 52.7 KB

nq#+OPTIONS: toc:nil

M-EMACS

Table of Contents

About EMACS

Emacs changes how you think about programming.

Emacs is totally introspectable. You can always find out ‘what code runs when I press this button?’.

Emacs is an incremental programming environment. There’s no edit-compile-run cycle. There isn’t even an edit-run cycle. You can execute snippets of code and gradually turn them into a finished project. There’s no distinction between your editor and your interpreter.

Emacs is a mutable environment. You can set variables, tweak functions with advice, or redefine entire functions. Nothing is off-limits.

Emacs provides functionality without applications. Rather than separate applications, functionality is all integrated into your Emacs instance. Amazingly, this works. Ever wanted to use the same snippet tool for writing C++ classes as well as emails?

Emacs is full of incredible software concepts that haven’t hit the mainstream yet. For example:

  • Many platforms have a single item clipboard. Emacs has an infinite clipboard.
  • If you undo a change, and then continue editing, you can’t redo the original change. Emacs allows undoing to any historical state, even allowing tree-based exploration of history.
  • Emacs supports a reverse variable search: you can find variables with a given value.
  • You can perform structural editing of code, allowing you to make changes without breaking syntax. This works for lisps (paredit) and non-lisps (smartparens).
  • Many applications use a modal GUI: for example, you can’t do other edits during a find-and-replace operation. Emacs provides recursive editing that allow you to suspend what you’re currently doing, perform other edits, then continue the original task.

Emacs has a documentation culture. Emacs includes a usage manual, a lisp programming manual, pervasive docstrings and even an interactive tutorial.

Emacs has a broad ecosystem. If you want to edit code in a niche language, there’s probably an Emacs package for it.

Emacs doesn’t have a monopoly on good ideas, and there are other great tools out there. Nonetheless, we believe the Emacs learning curve pays off.

This beautifully written *About EMACS* section credits to Remacs.

About M-EMACS

M-EMACS is a custom GNU Emacs setup and configuration distribution that aims not only to enhance the default Emacs experience, and hopefully be a sample that everyone can easily navigate and reference through a highly detailed README that contains 99% of the entire configuration code.

As a young EMACSer, I have experienced the struggle to find a detailed configuration that is loosely coupled and highly readable. This mostly due to the nature of source codes, sometimes comments are harder to notice or simply not enough. Therefore I decided to construct this README and present any human-readable explanation in a much more human-friendly way. Anyone, particularly Emacs beginners who have no idea where to start with their personal config, is more than welcome to read through this document and copy/paste any part to use it on their own.

This distribution is designed and tested for GNU Emacs 26.1 and above only. However, it is always suggested to use Emacs 27, the latest stable version released, for its significant improvement in the core that’s out of the scope of M-EMACS. images/Sample.png

Community Responses ❤️

Some heartwarming responses from the Emacs community:

  • “Actually I understated how much I liked reading through your config… What makes me excited about this config is the readability and possibility of extending in a similar way.” – from u/Orgmonics
  • “I have to say Matt’s setup has the best clarity of all emacs setups I have ever tried. It’s really a good template to develop your own emacs config. Thanks again…” – from u/fqye
  • “Thanks for the fantastic emacs setup, I love emacs, but trying to get lsp working right was killing me, yours worked out of the box and all I had to do was add some bindings, it’s really a time saver” – from ahonnecke
  • “Thank you for helping a guy out and for sharing this. I hope this evolves to be into something really big.” – from d3v-S
  • and more… Love you guys! ❤️❤️

About README

This README is originated from init.org that is generated using M-x org-gfm-export-to-markdown. Every block of code is generated through this function - it exports sections of code from the elisp/ directory. You will not see their presence in init.org. This not only enables a cleaner organization but also significantly improves Emacs start-up time than the traditional everything in an org file approach.

Installation

  1. Install GNU Emacs.
    • (Optional) On Ubuntu, emacs-snapshot is a great way to get latest version of Emacs.
      sudo add-apt-repository -y ppa:ubuntu-elisp
      sudo apt-get update
      sudo apt-get install emacs-snapshot
              
    • (Optional) Build latest Emacs from source.
      # Install essential build tools
      sudo apt-get install build-essential texinfo libx11-dev libxpm-dev libjpeg-dev libpng-dev libgif-dev libtiff-dev libgtk2.0-dev libncurses-dev gnutls-dev libgtk-3-dev git autoconf
      # Clone source
      git clone --depth=1 https://github.com/emacs-mirror/emacs.git
      # Go to source
      cd emacs/
      # Build Emacs
      ./autogen.sh
      ./configure --with-mailutils
      make
      # Install (optional)
      sudo make install
              
  2. Clone this repo to HOME or ~/ path using git and update all the submodules.
    cd ~
    git clone --recurse-submodules -j8 https://github.com/MatthewZMD/.emacs.d.git
    cd .emacs.d
        
  3. Ensure a stable connection to Melpa Packages, then open Emacs.
  4. Enter y when prompted with Auto-update packages now?, wait for all packages to install.
  5. In your favorite browser, Ctrl-f Prerequisite through this README and follow the Prerequisite instructions.
  6. Restart Emacs.

Further Updates

I will be updating M-EMACS from time to time, it is best to git pull once a while to stay up to date.

Please also execute git submodule update --recursive --remote to sync with all the submodules.

Modification

You have the permission to use, modify, distribute in any way you want.

However, what is free stays free. After all, this is GPL.

Remember you must manually sync this README with all the new changes you made by:

  1. Please do NOT edit this README.md file, edit init.org instead!
  2. If you add a new mode, create a new <file-name>.el file in elisp/ directory.
  3. Put (require '<file-name>) in init.el accordingly.
  4. Add #+INCLUDE: "~/.emacs.d/elisp/<place-holder>.el" src emacs-lisp :range-begin "<start-line-wrapper-exclusive>" :range-end "<end-line-wrapper-exclusive>" in the appropriate section in init.org.
  5. Enter C-x C-s to save and update :lines. (if you don’t see the updated effect, run M-x save-and-update-includes manually)
  6. Call M-x org-gfm-export-to-markdown to update README.md automatically.

Contribution

If you spotted a bug or you have any suggestions, please fill in an issue. If you have something to fix, feel free to create a pull request.

Special Thanks

Everyone starts somewhere, and I started here.

Startup

Lexical Binding

Use lexical-binding. Why?

Until Emacs 24.1 (June 2012), Elisp only had dynamically scoped variables, a feature, mostly by accident, common to old lisp dialects. While dynamic scope has some selective uses, it’s widely regarded as a mistake for local variables, and virtually no other languages have adopted it.

Early Init

Emacs27 introduces early-init.el, which is run before init.el, before package and UI initialization happens.

Compatibility With 26

Ensure emacs-version>=26, manually require early-init configurations if emacs-version<27.

Defer Garbage Collection

Defer garbage collection further back in the startup process, according to hlissner.

The GC eats up quite a bit of time, easily doubling startup time. The trick is to turn up the memory threshold as early as possible.

Disable package-enable-at-startup

Package initialize occurs automatically, before user-init-file is loaded, but after early-init-file. We handle package initialization, so we must prevent Emacs from doing it early!

Unset file-name-handler-alist

Every file opened and loaded by Emacs will run through this list to check for a proper handler for the file, but during startup, it won’t need any of them.

Disable site-run-file

Disable Unnecessary Interface

It will be faster to disable them here before they’ve been initialized.

Garbage Collection

Set gc-cons-threshold Smaller for Interactive Use

A large gc-cons-threshold may cause freezing and stuttering during long-term interactive use.

If you experience freezing, decrease this amount, if you experience stuttering, increase this amount.

Garbage Collect when Emacs is out of focus and avoid garbage collection when using minibuffer.

Load Path

Since all the configuration files are stored in elisp/ folder, they need to be added to load-path now.

Define Constants

Load Private File

An init-private.el file has been designated at user-emacs-directory for you to store personal configurations that you don’t want to source-control.

Package Management

Some packages are disabled with the :disabled tag, because I don’t use them very often. You can disable packages similarly yourself too:

(use-package foo
  :disabled)

Melpa Packages

Configure package archives, where to install online packages and add them to load-path.

Non-Melpa Packages

Add packages contained in site-elisp/ to load-path too.

Add Packages Manually from Git

cd site-elisp/
git submodule add https://github.com/foo/bar.git

Verify .gitmodules file that the newly added package exist.

Update Manually Added Packages

git submodule init
git submodule update

Configure Package Manager

Use Package

My Emacs configuration is almost entirely dependant on use-package.

The use-package macro allows you to isolate package configuration in your .emacs file in a way that is both performance-oriented and, well, tidy. I created it because I have over 80 packages that I use in Emacs, and things were getting difficult to manage. Yet with this utility my total load time is around 2 seconds, with no loss of functionality!

Auto Package Update

Auto package update automatically updates installed packages if at least auto-package-update-interval days have passed since the last update.

Diminish

Diminish, a feature that removes certain minor modes from mode-line.

Global Functionalities

User Information

Prerequisite: Please update this file your personal info.

Bindings

Avy

Avy, a nice way to move around text.

Crux

Crux, a Collection of Ridiculously Useful eXtensions for Emacs.

Ivy, Amx, Counsel, Swiper

Ivy, a generic completion mechanism for Emacs. It utilizes Amx, Counsel and Swiper.

Color Ripgrep

Color rg, a search and refactoring tool based on ripgrep that is used to search text.

Prerequisite: Ensure ripgrep and ensure rg is in PATH.

Find File In Project

Find File In Project, quick access to project files in Emacs.

Prerequisite: Ensure GNU Find is in PATH. Install Gow or Cygwin or MYSYS2 on Windows.

Files Directories

Dired

Dired, the directory editor.

Disk Usage

Disk Usage, a file system analyzer that offers a tabulated view of file listings sorted by size.

Save All Buffers

Winner

Winner, a mode to restore previous window layouts.

Which Key

Which Key, a feature that displays the key bindings following the incomplete command.

Undo Tree

Undo tree, a feature that provides a visualization of the undos in a file.

Discover My Major

Discover my major, a feature that discovers key bindings and their meaning for the current Emacs major mode.

Ace Window

Ace Window, a package for selecting windows to switch to.

Terminal

Shell Here

Shell Here, a tool that opens a shell buffer in (or relative to) default-directory.

Multi Term

Multi Term, a mode based on term.el, for managing multiple terminal buffers in Emacs.

Term Keys

Term Keys, a lossless keyboard input for Emacs in terminal emulators.

Exec Path From Shell

Exec Path From Shell, a library to ensure environment variables inside Emacs look the same as in the user’s shell.

Sudo Edit

Sudo Edit, an utility for opening files with sudo.

Ibuffer

Ibuffer, an advanced replacement for BufferMenu, which lets you operate on buffers much in the same manner as Dired.

It uses IBuffer VC that group buffers by git project and show file state.

Config

Some essential configs that make my life a lot easier.

UTF-8 Coding System

Use UTF-8 as much as possible with unix line endings.

Optimize Editing Experience

History

Small Configs

Functions

Important functions.

Resize Window Width / Height Functions

Edit This Configuration File Shortcut

Update Org Mode Include Automatically

Update Org Mode INCLUDE Statements Automatically from Artur Malabarba.

MiniBuffer Functions

Display Line Overlay

Read Lines From File

Where Am I

UI Enhancements

Doom Themes

Doom Themes, an UI plugin and pack of themes.

Doom Modeline

Doom Modeline, a modeline from DOOM Emacs, but more powerful and faster.

Dashboard

Dashboard

Dashboard, an extensible Emacs startup screen.

Use either KEC_Dark_BK.png or KEC_Light_BK.png depends on the backgrond theme.

Page Break Lines

Page-break-lines, a feature that displays ugly form feed characters as tidy horizontal rules.

Fonts and Icons

Prerequisite: Install all the available fonts and icons from fonts/. Execute M-x all-the-icons-install-fonts and M-x nerd-icons-install-fonts.

Fonts

Function to switch between fonts.

All The Icons

All The Icons, a utility package to collect various Icon Fonts. Enable only in GUI Emacs.

Smooth Scrolling

Configurations to smooth scrolling.

Highlight Lines

Prettify Symbols

Prettify symbols mode, a built-in mode for displaying sequences of characters as fancy characters or symbols.

UI Configs

Title Bar

Simplify Yes/No Prompts

Disable Splash Screen

Line Numbers

Display line numbers, and column numbers in modeline.

Modeline Time and Battery

Display time and battery information in modeline.

Pixel Scroll Precision Mode

Pixel scroll precision mode, introduced in Emacs 29.1, displays text pixel-by-pixel.

General Programming

Magit

Magit, an interface to the version control system Git.

Projectile

Projectile, a Project Interaction Library for Emacs.

Prerequisite: Windows OS: Install Gow and ensure it’s in PATH.

Gow is a lightweight installer that installs useful open source UNIX applications compiled as native win32 binaries. Specifically, tr is needed for Projectile alien indexing.

YASnippet

YASnippet

YASnippet, a programming template system for Emacs. It loads YASnippet Snippets, a collection of yasnippet snippets for many languages.

Dumb Jump

Dumb jump, an Emacs “jump to definition” package.

Parenthesis

Smartparens

Smartparens, a minor mode for dealing with pairs.

Match Parenthesis

Match and automatically pair parenthesis, and show parenthesis even when it went offscreen from Clemens Radermacher.

Indentation

Indent Bars, a fast, configurable indentation guide-bars for Emacs.

Indentation Configuration

Format All

Format all, a feature that lets you auto-format source code.

Prerequisite: Read Supported Languages to see which additional tool you need to install for the specific language.

Ediff

Ediff, a mode to simultaneously browse through the differences between a pair of files or buffers.

Evil Nerd Commenter

Evil Nerd Commenter, a tool that helps you comment code efficiently.

Editing

Iedit

Iedit, a minor mode that allows editing multiple regions simultaneousy in a buffer or a region.

Delete Block

Delete Block, a feature that deletes block efficiently.

Headers

Header2, a support for creation and update of file headers.

Jupyter Notebook

Emacs IPython Notebook, a Jupyter (formerly IPython) client in Emacs.

Usage

  1. Execute M-x ein:run to launch a local Jupyter session.
  2. Login with M-x ein:login to a local or remote session.
  3. Open .ipynb file and press C-c C-o.

Completion / LSP

Instead of the popular Company, I opt-ed to use lsp-bridge that is completely multi-threading technology, handles almost all of my completion needs.

Programming

C/C++/Objective C

Prerequisite: Since all completion features are provided by LSP Mode, it needs to setup.

  • Install CMake >= 3.8 for all OS.
  • *nix OS:
    • It is suggested to use CCLS as LSP server. Now build it.
    • Set ccls-executable to the directory where your ccls is built.
  • Windows OS:
    • Install MinGW for Compilation.
    • It is a pain to build CCLS on Windows, install Clangd and ensure it’s in PATH instead.

CCLS

Emacs CCLS, a client for CCLS, a C/C++/Objective-C language server supporting multi-million line C++ code-bases, powered by libclang.

Modern C++ Font Lock

Modern CPP Font Lock, font-locking for “Modern C++”.

Golang

Go Mode, an Emacs mode for Golang programming.

Prerequisite: gopls is required for Golang’s LSP support.

go get golang.org/x/tools/gopls@latest

Rust

Rust Mode, an Emacs mode for Rust programming.

Python

ESS

Emacs Speaks Statistics, short for ESS, it’s designed to support editing of scripts and interaction with various statistical analysis programs such as R, S-Plus, SAS, Stata and OpenBUGS/JAGS.

Prerequisite: Install R to start using ESS with R.

TeX

Prerequisite: Please install TeX Live.

AUCTeX

AUCTeX, an extensible package for writing and formatting TeX files. It supports many different TeX macro packages, including AMS-TEX, LaTeX, Texinfo, ConTEXt, and docTEX (dtx files).

Yaml

Yaml mode, the Emacs major mode for editing files in the YAML data serialization format.

Buildsystem

Docker

Docker, a mode to manage docker from Emacs.

Dockerfile Mode, an Emacs mode for handling Dockerfiles.

Groovy

Groovy Mode, a groovy major mode, grails minor mode, and a groovy inferior mode.

Cmake

Cmake Mode, a library that provides syntax highlighting and indentation for CMakeLists.txt and *.cmake source files.

Bazel

Bazel Mode, a library that provides major modes for editing Bazel BUILD files, WORKSPACE files, .bazelrc files, as well as Starlark files.

Web Development

Prerequisite: Install NodeJS and ensure it’s in PATH. Execute following commands to enable LSP for JavaScript/TypeScript/HTML:

npm i -g typescript
npm i -g typescript-language-server

Web

Web mode, a major mode for editing web templates.

JavaScript/TypeScript

JavaScript2

JS2 mode, a feature that offers improved JavsScript editing mode.

TypeScript

TypeScript mode, a feature that offers TypeScript support for Emacs.

Vue

Vue mode, a major mode for Vue.js.

Emmet

Emmet, a feature that allows writing HTML using CSS selectors along with C-j. See usage for more information.

Instant Rename Tag

Instant Rename Tag, a plugin that provides ability to rename html tag pairs instantly.

JSON

JSON Mode, a major mode for editing JSON files.

Vue

Vue mode, a major mode for Vue.js.

Emmet

Emmet, a feature that allows writing HTML using CSS selectors along with C-j. See usage for more information.

Instant Rename Tag

Instant Rename Tag, a plugin that provides ability to rename html tag pairs instantly.

JSON

JSON Mode, a major mode for editing JSON files.

Vue

Vue mode, a major mode for Vue.js.

Emmet

Emmet, a feature that allows writing HTML using CSS selectors along with C-j. See usage for more information.

Instant Rename Tag

Instant Rename Tag, a plugin that provides ability to rename html tag pairs instantly.

JSON

JSON Mode, a major mode for editing JSON files.

Office

Org

Org, a Emacs built-in tool for keeping notes, maintaining TODO lists, planning projects, and authoring documents with a fast and effective plain-text system.

Prerequisite: Configure (org-agenda-files (list "~/org/agenda/")) to your agenda folder to use org-agenda. Once this is set, the agenda items tagged with DEADLINE or SCHEDULED will be displayed on the Dashboard (hopefully the dashboard will be more detailed in the future).

Org Roam

Org Roam, a plain-text personal knowledge management system.

TOC Org

TOC Org generates table of contents for .org files

HTMLize

HTMLize, a tool that converts buffer text and decorations to HTML.

GFM Exporter

OX-GFM, a Github Flavored Markdown exporter for Org Mode.

PlantUML and Graphviz

PlantUML Mode, a major mode for editing PlantUML sources.

Prerequisite:

  1. Install plantuml and configure (org-plantuml-jar-path (expand-file-name "path/to/plantuml.jar")).
  2. Install Graphviz on your system to support graph visualization. Execute sudo apt install graphviz in Ubuntu.

PDF Tools

PDF Tools, an Emacs support library for PDF files. It works best on non-Windows OS.

Note: You need convert provided from imagemagick to Pick a Link and Jump with F.

Internet

EAF

Emacs Application Framework, a GUI application framework that revolutionizes Emacs graphical capabilities.

Prerequisite: Please ensure python3 and pip3 are installed, then follow install instructions.

Popweb

Popweb, a lightweight version of EAF that provides multimedia capabilities.

ERC

Emacs Relay Chat, a powerful, modular, and extensible IRC client for Emacs. It utilizes erc-hl-nicks for nickname highlighting and erc-image to fetch and show received images in ERC.

Prerequisite: Put IRC credentials in the file ~/.authinfo and configure my-irc-nick to your IRC nickname.

machine irc.freenode.net login <nickname> password <password> port 6697

MU4E

Mu4e, a package that provides an emacs-based e-mail client which uses mu as its backend. Mu4e Thread Folding is used to toggle between long threads.

Note: This mu4e configuration is tailored for Gmail.

Prerequisite:

  1. Configure IMAP using isync/mbsync, put your .mbsyncrc config file in ~/.emacs.d/mu4e/. A sample is provided.
  2. Install mu.
  3. Execute the follwing commands
    mkdir -p ~/Maildir/gmail/
    mbsync -c ~/.emacs.d/mu4e/.mbsyncrc -Dmn gmail
    mbsync -c ~/.emacs.d/mu4e/.mbsyncrc -a
    mu init --maildir=~/Maildir/ --my-address=YOUR_EMAIL1 --my-address=YOUR_EMAIL2
    mu index
        
    • If you are getting Invalid Credentials error and you are sure the password is correct, check this link.
  4. (Optional) If you want to track meetings using org-mode, set gnus-icalendar-org-capture-file to the meeting’s file.

Tramp

Tramp, short for Transparent Remote Access, Multiple Protocols is a package for editing remote files using a remote shell connection (rlogin, telnet, ssh).

Google Cloud Platform

Connect to Google Cloud Platform using the following:

/gssh:some-instance:/path/to/file

LeetCode

LeetCode, an Emacs LeetCode client. Note that this package is dependant on aio and GraphQL.

Debbugs

Debbugs, a package lets you access the GNU Bug Tracker from within Emacs.

Hacker News

A simple Hacker News Emacs client.

EWW

Emacs Web Wowser, the HTML-based Emacs Web Browser.

Miscellaneous

Chinese

Packages and configurations suitable for Chinese users. Non-Chinese users feel free to add :disabled tags for them.

Pyim

  • Pyim, an Emacs Chinese Pinyin Input. It uses posframe package to display candidates.
  • Pyim BaseDict, the default Chinese-Pyim dictionary.

我已经停止使用作者推荐的无痛中英切换,它对需要同时打英文和中文的情况不是很友好。如需切换输入法,请善用 C-\

Youdao

Youdao interface for Emacs.

Tetris

Although Tetris is part of Emacs, but there still could be some configurations.

Speed Type

Speed type, a game to practice touch/speed typing in Emacs.

2048 Game

2048 Game, an implementation of 2048 in Emacs.

Snow

Let it snow in Emacs!

EPaint

EPaint, a simple paint tool for emacs.

Zone

Zone, a minor-mode ‘zones’ Emacs out, choosing one of its random modes to obfuscate the current buffer.