Skip to content

Latest commit

 

History

History
1609 lines (1172 loc) · 46.6 KB

config.org

File metadata and controls

1609 lines (1172 loc) · 46.6 KB

Emacs Configuration File

Key binding explanations:

  • C-c <C-left> - Means CTRL must be pressed for both.

To look up

LOOK UP AND BIND WINNER MODE LOOK UP AND ENABLE FLEX IDO MODE:

Encoding

See:

Basically, use UTF-8 unix encoding for all files with the given file extensions. Make it unix line endings as well.

;; disable CJK coding/encoding (Chinese/Japanese/Korean characters)
; (setq utf-translate-cjk-mode nil)

;; Use UTF-8 for all character encoding and 
(set-language-environment 'utf-8)
(set-locale-environment "en.UTF-8")

;; Set line endings to be unix
;; See https://stackoverflow.com/a/1674535/5108875
(prefer-coding-system 'utf-8-unix)
(set-buffer-file-coding-system 'utf-8-unix)
(setq-default buffer-file-coding-system 'utf-8-unix)
(setq-default default-buffer-file-coding-system 'utf-8-unix)
(set-selection-coding-system 'utf-8-unix)
(set-default-coding-systems 'utf-8-unix)
(set-terminal-coding-system 'utf-8-unix)
(set-keyboard-coding-system 'utf-8-unix)

;; Note for windows this will cause problems,
;; and should be overriden (see the windows.org encoding section)

In order to change the encoding on a buffer by buffer basis:

Call set-buffer-file-coding-system, then give one of: {mac, dos, unix}. Then, save the file.

For more information on line endings, see: http://ergoemacs.org/emacs/emacs_line_ending_char.html

Use-package notes

Use-package

The use-package macro is used to configure packages. The syntax is simple:

(use-package <package-name> :<keyword> <arbitrary-elisp> :<keyword> <arbitrary-elisp>

...

)

The simplest declaration is: (use-package foo) Each subsection below describes a keyword and example usage.

:init

Executes code before a package is loaded.

Example: (use-package foo :init (setq foo-variable t))

:config

Executes code after a package is loaded.

:bind

Example: (use-package ace-jump-mode :bind (“C-.” . ace-jump-mode))

This does two things: first, it creates an autoload for the ace-jump-mode command and defers loading of ace-jump-mode until you actually use it. Second, it binds the key C-. to that command.

Example 2 (use-package hi-lock :bind ((“M-o l” . highlight-lines-matching-regexp) (“M-o r” . highlight-regexp) (“M-o w” . highlight-phrase))) Same, but taking a list or a list of conses.

:mode

:ensure

:interpreter

:load-path

Example 1 (use-package ess-site :load-path “site-lisp/ess/lisp/” :commands R)

Description This takes a symbol, a function, a string or a list of strings. If the path is relative, it is expanded within user-emacs-directory:

:no-require

:if

(use-package edit-server :if window-system :init (add-hook ‘after-init-hook ‘server-start t) (add-hook ‘after-init-hook ‘edit-server-start t))

:diminish

Example 1 (use-package abbrev :diminish abbrev-mode :config (if (file-exists-p abbrev-file-name) (quietly-read-abbrev-file))) Description Removes the minor mode string from the modeline.

Use the :init keyword to execute code before a package is loaded. It accepts one or more forms, up until the next keyword:

  • In general, you should keep :init forms as simple and quick as possible, and put as much as you can get away with into the :config block. This way, deferred loading can help your Emacs to start as quickly as possible.

Initialisation

Customisation options included here are placed for a faster/faster looking initialisation.

;; Turn off mouse interface early in startup to avoid momentary display
(when window-system
  ;; (menu-bar-mode -1)    ;; Menu bar - file, edit, etc.
  (tool-bar-mode -1)    ;; Tool bar - buttons under menu bar.
  (scroll-bar-mode -1)  ;; Scroll bar on side of buffers
  ;; (tooltip-mode -1)    ;; On: Help text as popup/Off: as text in minibuffer.
)

;; Don't show the tutorial startup page.
(setq inhibit-startup-message t) 

Load Path

The following contains directories which are added to emac’s load path. That way if you want to configure a package which is not installed using MELPA but exists in another folder - you can.

N.B. The (add-to-list ‘load-path <path>) function DOES NOT recursively add subdirectories.

;; "~/.emacs.d/lisp/" for custom downloaded lisp files.
(add-to-list 'load-path "~/.emacs.d/lisp/")  

Personal Minor Mode

Create my own minor mode to contain my own functionality. See

  • tutsplus - Venture into Emacs/02 Usage/12 Major and Minor Modes
  • tutsplus - Venture into Emacs/02 Usage/13 Customizations

Custom Minor Mode Functions

Dired Mode

We can give the options that dired mode uses when it calls ls so that they are:

  • l: Use the long listing format.
  • a: Show all files including hidden ones.
  • h: Print sizes in human readable format (K, M G etc.)
  • F: Append an indicator onto relevant files/directories:
    • / is a directory
    • @ is a symlink
    • | is a named pipe (fifo)
    • = is a socket.
    • * for executable files
    • > is for a “door” – a file type currently not implemented for Linux, but supported on Sun/Solaris.
(setq dired-listing-switches "-lahF")

Minibuffer

Set the colour of the minibuffer prompt to green for better readability.

(custom-set-faces  
 '(minibuffer-prompt ((t (:foreground "green"))))  
)  

Powerline

(use-package powerline
  :ensure t
  :init (powerline-center-theme)
)

Whitespace

Show trailing whitespace

See:

The following defines a function “tf-toggle…” which when toggled on will highlight any trailing whitespace in a buffer.

(defun tf-toggle-show-trailing-whitespace ()
  "Toggle show-trailing-whitespace between t and nil"
  (interactive)
  (setq show-trailing-whitespace (not show-trailing-whitespace)))

Buffers, Windows, Frames, and Scratch Buffer

Buffers

ibuffer

iBuffer is an improved version of the default ‘C-x C-b’ (list-buffers command). It comes with emacs by default so to use it we just need to define the list-buffers command as an alias for it.

See: http://ergoemacs.org/emacs/emacs_buffer_management.html

;; make ibuffer the default buffer lister.
(defalias 'list-buffers 'ibuffer)

open as root

See

If we open emacs as a standard user we cannot open files that we do not have permissions for. The following allows you to open a file as root from within an existing emacs session. We give it a key binding for ease of use.

(defun sudo-edit (&optional arg)
  "Edit currently visited file as root.

With a prefix ARG prompt for a file to visit.
Will also prompt for a file to visit if current
buffer is not visiting a file."
  (interactive "P")
  (if (or arg (not buffer-file-name))
      (find-file (concat "/sudo:root@localhost:"
                         (ido-read-file-name "Find file(as root): ")))
    (find-alternate-file (concat "/sudo:root@localhost:" buffer-file-name))))

    (global-set-key (kbd "<f7>") 'sudo-edit)

Windows

Existing Bindings

KeysCommandDescription
C-x oother-windowMove point to other window.
C-x 0delete-windowDeletes current window, reducing window count by 1.
C-x 1delete-other-windowsMakes window point is on, sole window.
C-x 2split-window-belowSplits current window horizontally into two.
C-x 3split-window-rightSplits current window vertically into two.
C-x 4
C-x 5Used as a prefix for frame commands
C-x +balance-windowsUndos the affects of resizing windows so they balance.

Custom Bindings

Splitting windows

Splitting windows does not move the cursor to the other window. The following remaps the default keys to move to the other window when it is created.

(defun vsplit-other-window ()
  "Splits the window vertically and switches to that window."
  (interactive)
  (split-window-vertically)
  (other-window 1 nil))
(defun hsplit-other-window ()
  "Splits the window horizontally and switches to that window."
  (interactive)
  (split-window-horizontally)
  (other-window 1 nil))

(global-set-key (kbd "C-x 2") 'vsplit-other-window)
(global-set-key (kbd "C-x 3") 'hsplit-other-window)

Moving between windows

Moving between multiple windows is annoying when you just use ‘C-x o’ (other-window). The following remaps C-c <arrow> to move between windows.

(global-set-key (kbd "C-c <left>")  'windmove-left)
(global-set-key (kbd "C-c <right>") 'windmove-right)
(global-set-key (kbd "C-c <up>")    'windmove-up)
(global-set-key (kbd "C-c <down>")  'windmove-down)

;; Repeat for keys where CTRL is kept pressed to prevent accidentally holding
;; CTRL and calling a different command function.
(global-set-key (kbd "C-c <C-left>")  'windmove-left)
(global-set-key (kbd "C-c <C-right>") 'windmove-right)
(global-set-key (kbd "C-c <C-up>")    'windmove-up)
(global-set-key (kbd "C-c <C-down>")  'windmove-down)

Re-sizing windows

Resizing windows is a pain with the mouse. Default bindings exist for increasing the window’s size horizontally (C-{ and C-}) but there are none for doing it vertically. The following remapps the functions to do resizing (horizontally and vertically) to ‘C-x <arrow>’ for consistency. This overwrites the two key default key bindings: C-x <left> and C-x <right> which run the commands `previous-buffer` and `next-buffer` respectively.

Left and down are shrink, right and up are enlarge.

(global-set-key (kbd "C-x <left>")  'shrink-window-horizontally)
(global-set-key (kbd "C-x <right>") 'enlarge-window-horizontally)
(global-set-key (kbd "C-x <down>")  'shrink-window)
(global-set-key (kbd "C-x <up>")    'enlarge-window)

;; Repeat for keys where CTRL is kept pressed to prevent accidentally holding
;; CTRL and calling a different command function.
(global-set-key (kbd "C-x <C-left>")  'shrink-window-horizontally)
(global-set-key (kbd "C-x <C-right>") 'enlarge-window-horizontally)
(global-set-key (kbd "C-x <C-down>")  'shrink-window)
(global-set-key (kbd "C-x <C-up>")    'enlarge-window)

Winner mode

Winner mode allows you to undo/redo changes to window changes in Emacs.

Turning it on conflicts with C-c <left> and C-c <right>. Deal with conflict and enable in future. Its benefits are too good to ignore!

;; (global-set-key (kbd "")  'winner-mode)
;; (global-set-key (kbd "C-v <left>")  'winner-redo)
;; (global-set-key (kbd "")  'winner-undo)

Frames

See http://www.emacswiki.org/emacs/FrameMove on how to intgrate framemove into windmove.

Scratch Buffer

Convenient package to create *scratch* buffers that are based on the current buffer’s major mode. This is more convienent than manually creating a buffer to do some scratch work or reusing the initial *scratch* buffer.

(use-package scratch
  :ensure t)

Formatting and Display

Existing Bindings

KeysCommandDescription
M-qfill-paragraphWraps lines in the given paragraph around the
`column-fill` variable column.
C-u M-qfill-paragraphWraps text in paragraph but it is justified.

Custom Bindings

Visual line mode

Visual line mode (VLM) is (sometimes) useful when dealing with lines which are longer than the window can display in a line of its own. Usually when this occurs an arrow is placed on the line to highlight that. Also the behaviour is not very nice e.g. killing the line means killing the whole line (which could be 1000’s lines below the actual visual line we want to kill).

By enabling VLM the behaviour is (sometimes) much more friendlier - we still want lines which cannot be displayed on a single window line to have the arrow in the margin but we want normal line operations to work on the visual line. VLM does this. Other times it is just annoying as you may just want to kill the whole line.

; (global-visual-line-mode)

; Have arrows in margins to indicate logical line is wrapped
; even in visual line mode
(setq visual-line-fringe-indicators '(left-curly-arrow right-curly-arrow))

; (diminish 'visual-line-mode)  ;; Remove 'vl Wrap' from mode line.

auto-fill-mode

auto-fill-mode is a minor mode which automatically wraps lines after the `fill-column` variable is reached. We set it when a text mode is opened so that it does not affect the shells/terminals.

(global-set-key (kbd "C-c q") 'auto-fill-mode)
(add-hook 'text-mode-hook 'turn-on-auto-fill)
(setq fill-column 80)  ; This is a buffer local change only (not global)

Setting the fill-column variable is a buffer local change and so we need to set it by using a hook for the major mode we are interested in.

(add-hook 'text-mode-hook (lambda () (set-fill-column 95)))
(add-hook 'org-mode-hook (lambda () (set-fill-column 95)))

Themes

Custom Theme Directory

The variable “custom-theme-directory” is the default user directory for storing custom theme files. The command `customize-create-theme’ writes theme files into this directory. By default, Emacs searches for custom themes in this directory first—see `custom-theme-load-path’.

(setq custom-theme-directory "~/.emacs.d/themes/") ;; For enabling color themes.

Sane Defaults

;; Keep all backup and auto-save files in one directory
(setq backup-directory-alist '(("." . "~/.emacs.d/backups")))
(setq auto-save-file-name-transforms '((".*" "~/.emacs.d/auto-save-list/" t)))

(setq-default indent-tabs-mode nil) ;; Do not use tabs - use spaces instead. 
(setq-default indicate-empty-lines t) ;; Indicate lines at bottom of file which are empty like vi.

(setq confirm-kill-emacs 'y-or-n-p) ;; Always confirm when exiting

(setq                                     ;; If two buffers with same name open, uniquify names.
 uniquify-buffer-name-style 'post-forward ;; Does not work for some reason.
 uniquify-separator         ":")

(show-paren-mode 1) ;; Highlight pairs of parens
(electric-pair-mode 1) ;; Automatically introduces closing parenthesis, brackets, braces, etc.
(delete-selection-mode t) ;; Delete the region when typing instead of only moving cursor.
(column-number-mode t) ;; Always show column number in modeline.

Org Mode

Org setup

;; For org mode allow using shift to highlight text
;; (setq org-support-shift-select 'always) 

Org Startup

Startup images

The variable `org-startup-with-inline-images` can be set globally to show inline images when loading a new Org file.

(setq org-startup-with-inline-images t)

Alternatively, you can set inline colours locally on a perfile basis by adding one of the following lines anywhere in the buffer:

`#+STARTUP: inlineimages` `#+STARTUP: noinlineimages`

You can also toggle inline images with: C-c C-x C-v (org-toggle-inline-images)

Setting custom width of images inline and for export

In order to be able to amend the image width displayed inline we need to do two things:

  1. Set org-image-actual-width to nil
  2. Give the image a width attribute

N.B. if no width attribute is given the image will be displayed inline in its entirety without scaling i.e. however big it is.

;; Doing step 1
(setq org-image-actual-width nil)

Example of Step 2 when inserting an image:

./Images/business_domain_centric_approach_a.png

Startup folded

See:

When Emacs first visits an Org file, the global state is set to showeverything, i.e., all file content is visible. We don’t want this behaviour so we set org-startup-folded to true

(setq org-startup-folded t)

Alternatively you can set the startup behaviour on a per-file basis by adding one of the following startup directives to the org file:

Org blocks

Org babel/source blocks

;; Enable syntax highlighting for source code blocks within an org mode file.
(setq org-src-fontify-natively t)

;; Allow for the evaluation of the following source blocks
(org-babel-do-load-languages
 'org-babel-load-languages 
  '((emacs-lisp . t)
    (python . t)))

Org insert blocks

See:

Pressing ‘<s TAB’ in org mode automatically used to automatically inserts a ‘source code block’. Newer versions of org don’t do this.

  • you can use C-c C-, instead.
  • we add the behaviour back by requiring the ‘org-tempo module
;; Add org-tempo to org modules to bring back snippet shortcuts
(require 'org-tempo)

Org misc settings

See:

By default org mode assumes:

  • anything after a ‘_’ should be subscript
    • e.g. some_name_of_variable
  • anything after a ‘^’ should be superscript
    • e.g. 2^x
  • this may or may not be what is desired

By setting org-use-sub-superscripts to “{}” then you can explicitly make org use sub/superscript where you want:

  • e.g:
    • some_name_of_variable - no subscript
    • a_{i} - subscript
    • a^x - no superscript
    • a^{x} - superscript
; Only make something after a '_' subscript if it is enclosed with {}
; Only make something after a '^' superscript if it is enclosed with {}
(setq org-use-sub-superscripts "{}")

; Set pretty-entities to true so superscripts and subscripts are displayed
; as WYSIWYM e.g. 2^{2} will appear as superscript and x_{i} will be subscript
(setq org-pretty-entities t)

Custom Tweaks

Open current directory of buffer in explorer

Taken from:

This creates an interactive function ‘browse-file-directory’ which will open up the directory in your OS’s file browser.

(defun explorer-here ()
  "Open the current file's directory however the OS would."
  (interactive)
  (if default-directory
      (browse-url-of-file (expand-file-name default-directory))
    (error "No `default-directory' to open")))

Text Mode

Org Table Minor Mode

We want to create org tables easily in text files without having to change the major mode to org mode. So if we are in a text file, open org table minor mode so we can do this.

(add-hook 'text-mode-hook 'orgtbl-mode)

Searching and CUA Mode

Searching

The library ‘igrep’ provides useful searching functionality such as ‘fgrep-find’.

;; 'M-x fgrep-find' useful for finding occurences of a string in a directory.
;; But it requires grep - so only use it if the OS is not windows

;; N.B. in emacs-lisp it is an 'if () then () else ()' construct
(if (eq system-type 'windows-nt)
  ;; if it is Windows do nothing
  (message "Detected emacs is running in Windows so not loading grep")
  ;; if not Windows assume we have the grep binary
  (progn
    (require 'igrep)
    ;; Define keybinding so can be pressed whether CTRL is held down or not.
    (global-set-key (kbd "C-x g") 'fgrep-find)
    (global-set-key (kbd "C-x C-g") 'fgrep-find))
)

Ack

Ack is a perl program

CUA Mode

CUA mode rectangles are very useful.

(setq cua-auto-tabify-rectangles nil) ;; Don't tabify after rectangle commands
(transient-mark-mode 1) ;; No region when it is not highlighted

;; Overwrite the Emacs rectangle command to use the CUA mode version instead
(global-set-key (kbd "C-x SPC") 'cua-rectangle-mark-mode)

Eshell, Shell, Term, and Ansi-Term

Shell autocompletion

See: http://stackoverflow.com/questions/163591/bash-autocompletion-in-emacs-shell-mode

In the emacs shell, it’s actually emacs doing the auto-completion, not bash. If the shell and emacs are out of sync (e.g. by using pushd, popd or some bash user function that changes the shell’s current directory), then auto-completion stops working.

To fix this, just type ‘dirs’ into the shell and things get back in sync. Alternatively there is the following keybinding:

(global-set-key "\M-\r" 'shell-resync-dirs) ;; Alt + return

Bash Completion Package

See: https://github.com/szermatt/emacs-bash-completion

Package allows for bash completition in normal shell.

(use-package bash-completion
  :ensure t
)  

;; Load package at start up.
(require 'bash-completion)
(bash-completion-setup)

; Turn package off: 
; (setq bash-completion-enabled nil)

Colours

Resources for section:

We want to be able to have the shell show colours like a normal terminal. To deal with colours in the shell we need to deal with comint-mode. ComintMode is for making shell or repl like buffers in which to interact with an external process.

;; Add color to a shell running in emacs ‘M-x shell’
(autoload 'ansi-color-for-comint-mode-on "ansi-color" nil t)
(add-hook 'shell-mode-hook 'ansi-color-for-comint-mode-on)
(add-to-list 'comint-output-filter-functions 'ansi-color-process-output)

;; Define the color vector. These are used for SGR (Select Graphic
;; Rendition) control sequences determining a color.
(setq ansi-color-names-vector
  ["black" 
   "#FF0000"         ;; "red" 
   "green" 
   "yellow" 
   "PaleBlue" 
   "magenta" 
   "cyan" 
   "white"]
)

Set specific colours for the terminal and shell.

(custom-set-faces
 ;; Terminal Colours
 '(term-color-blue ((t (:background "#008B8B" :foreground "#008B8B"))))
 '(term-color-red ((t (:background "tomato" :foreground "tomato"))))
 ;; Shell Colours

)

Shell Prompt Colour

Run the command M-x list-faces-display and open the comint-highlight-prompt option. line. Make sure that the comint-highlight-prompt face is NOT set to inherit from anything. In my case it was set to inherit from the minibuffer prompt - which sets things such as :weight, :foreground and :background. Removing the inheritance will prevent the colour for the prompt from being overridden by the comint-highlight-prompt face.

(set-face-attribute 'comint-highlight-prompt nil :inherit nil)

(custom-set-faces
  ;; Set the prompt to be green
  '(comint-highlight-prompt ((t (:foreground "green"))))
)

Opening a shell/terminal

We create two functions:

Key BindingFunction NameFunction Description
C-M-1new-shell-same-windowOpens a new shell buffer, replacing the buffer in
custom functionthe current window.
C-M-!new-shell-new-windowOpens a new shell buffer, replacing the buffer in a
custom functiondifferent window
C-M-2ansi-termOpens an ansi terminal, replacing the buffer in the
built in functioncurrent window.
(defun new-shell-same-window (name)
  "Opens a new shell buffer with the given name in asterisks (*name*) in the current directory and changes the prompt to 'name>'."
  (interactive "sShell in same window. Enter Name: ")
  (pop-to-buffer-same-window (concat "*" name "*"))
  (unless (eq major-mode 'shell-mode)
    (shell (current-buffer))
    (sleep-for 0 200)
    (delete-region (point-min) (point-max))
    (comint-simple-send (get-buffer-process (current-buffer)) 
                        (concat "export PS1=\"\033[33m" name "\033[0m:\033[35m\\W\033[0m>\""))))

;; Binds C-M-1 to open a new shell in the current window.
(global-set-key (kbd "C-M-1") 'new-shell-same-window)
(defun new-shell-new-window (name)
  "Opens a new shell buffer with the given name in asterisks (*name*) in the current directory and changes the prompt to 'name>'."
  (interactive "sShell in new window. Enter Name: ")
  (pop-to-buffer (concat "*" name "*"))
  (unless (eq major-mode 'shell-mode)
    (shell (current-buffer))
    (sleep-for 0 200)
    (delete-region (point-min) (point-max))
    (comint-simple-send (get-buffer-process (current-buffer)) 
                        (concat "export PS1=\"\033[33m" name "\033[0m:\033[35m\\W\033[0m>\""))))

;; Binds C-M-! to open a new shell in a new window.
(global-set-key (kbd "C-M-!") 'new-shell-new-window)
;; C-M-2 opens new ANSI terminal in the current window. 
(global-set-key (kbd "C-M-2") 'ansi-term) 

M-x shell

Colours (General)

M-x commands to use to understand colours:

CommandDescription
M-x list-colors-displayLists the colour names available to use to set
colours of different `attributes`.
M-x list-faces-displayLists the `attributes` available to set the
colours to one of the `list-colors-display`.

Grammar and spell checking

Flyspell enables on-the-fly spell checking in Emacs by the means of a minor mode. It is called Flyspell. This facility is hardly intrusive. It requires no help. Flyspell highlights incorrect words as soon as they are completed or as soon as the TextCursor hits a new word.

From Emacs 24.2, Emacs includes Flyspell. However, Flyspell needs a spell checking tool, which is not included in Emacs. One of the older tools is called iSpell (there is still a lot of documentation which refers to iSpell) but it has more or less been replaced by aspell now.

Getting Aspell

Windows

Taken from https://emacs.stackexchange.com/a/45752:

  • You can install aspell or hunspell with https://www.msys2.org/. MSYS2 has native binaries for aspell available which are compatible with Emacs 26.1. Note you can also install emacs using MSYS2 as well.
    • Install MSYS2 using the instructions from their site.
    • It was quite easy to do (just a normal windows installer but took ages stuck at 50%).)
  • After installing, MSYS2 MinGW 64-bit should be in your start menu. Launch that, which brings up a terminal, and search for packages using pacman -Ss aspell.
  • There are several options. I ended up using the following two packages to install aspell and an English dictionary:

    pacman -S mingw64/mingw-w64-x86_64-aspell pacman -S mingw64/mingw-w64-x86_64-aspell-en

  • Now you can enter which aspell in the same terminal to find it’s location. It’ll probably be in C:\msys64\mingw64\bin.
  • Add that path to your “Path” environmental variable.

Archived Instructions

Original instructions:

  1. Make sure you have cygwin installed
  2. Make sure you have the apt-cyg utility available so you can install cygwin packages on the command line.
  3. Run apt-cyg install aspell to install aspell and apt-cyg install apell-en to install the english dictionaries required.

Default Dictionary

We want the default dictionary to be British english rather than American.

(setq ispell-dictionary "british")

Flyspell major Modes

We want to turn flyspell mode on for the following major modes:

(add-hook 'org-mode-hook 'flyspell-mode)

; For Scala just enable flyspell in the comments
(add-hook 'scala-mode-hook
        (lambda ()
          (flyspell-prog-mode)))

; For Java just enable flyspell in the comments
(add-hook 'java-mode-hook
        (lambda ()
          (flyspell-prog-mode)))

Langtool

See:

Langtool is a grammar checker that is commonly paired with Openoffice or Libreoffice. The tool itself is a simple command line utility, so it is relatively easy to interface with other programs; someone interfaced it with Emacs.

  • Langtool requires Java
(use-package langtool
  :ensure t
  :config
  ; (require 'langtool)
  ; (setq langtool-language-tool-jar "/path/to/languagetool-commandline.jar")
)

Unicode and LaTeX

Unicode

The function ‘insert-char’ allows you to insert unicode characters based on their hex code.

(global-set-key (kbd "C-c u") 'insert-char) ; u for unicode

Latex

;; Enable flyspell mode by default when editing LaTex.
(add-hook 'LaTeX-mode-hook 'turn-on-flyspell) 

Languages

Apache Web Server

We want apache-mode - a major mode for editing Apache configuration files. This is useful for apache2.conf / httpd.conf / .htaccess

(use-package apache-mode
  :ensure t
)

CSharp

(use-package csharp-mode
  :ensure t
)

Gherkin

Gherkin is the language used in cucumber.

; We use feature mode which is a major mode for gherkin
(use-package feature-mode
  :ensure t
)

Gradle

(use-package gradle-mode
  :ensure t
)

Groovy

(use-package groovy-mode
  :ensure t
)

Kotlin

(use-package kotlin-mode
  :ensure t
)

Python

(use-package elpy
  :ensure t
  :config
  (elpy-enable)
  (define-key yas-minor-mode-map (kbd "C-c k") 'yas-expand) ;; Fixing a key binding bug in elpy
  (define-key global-map (kbd "C-c o") 'iedit-mode) ;; Fixing another key binding elpy bug in iedit mode

)


Haskell

The following configuration assumes that the system has the following installed on the host machine:

  • Haskell platform (GHC, GHCi, Prelude, Cabal, etc.)
  • Hlint

Haskell Mode

For starters we need to ensure we have Haskell mode installed.

(use-package haskell-mode
  :ensure t
)

Miranda

The following makes use of the Miranda Major Mode script originally found at: http://www.iro.umontreal.ca/~lapalme/layout/miranda-mode.el

  1. Make sure the miranda-mode.el file is in a directory that is in the load path.

This setting affects those files with a .m extension.

(load-file "~/.emacs.d/lisp/miranda-mode.el")

Scala

Taken from:

Steps for setting up SCALA in emacs:

  1. Grab the package ‘ensime’. This automatically installs:
    • scala-mode
    • sbt-mode
; ensime not available for some reason anymore.
; get error: Error (use-package): Failed to install ensime: Package ‘ensime-’ is unavailable
;; (use-package ensime
;;   :ensure t
;;)
  1. Make sure the sbt binary is in the PATH.
  2. Add the sbt-ensime plugin to the sbt (scala build tool) config:
    • File usually found: `~/.sbt/0.13/plugins/plugins.sbt’
    • Add the following source code to the relevant plugins.sbt file:
    if (sys.props("java.version").startsWith("1.6"))
      addSbtPlugin("org.ensime" % "sbt-ensime" % "1.0.0")
    else
      addSbtPlugin("org.ensime" % "sbt-ensime" % "1.11.2")
        
  3. Navigate to the base directory of a hello world scala application
    • Run ‘sbt’
    • Run ‘sbt compile’
    • Run ‘sbt ensimeConfig’
  4. Open a file in the scala project you want to run.
    • In the emacs line mode at the bottom it will say [ENSIME: Disconnected]
  5. Create a connection to ensime
    • Run `M-x ensime`
  6. The first time it will run will take a while - it will update the server.
    • It will appear `Scala : [<name of directory>]’ once connected
;; If you don't set this to nil you will get a message about
;; using snapshot version each time ENSIME connects to the server
(setq ensime-startup-snapshot-notification nil)

Common errors

Error: Could not retrieve sbt 0.13.9 apt-get install ca-certificates-java sudo update-ca-certificates -f

Shared Folders You cannot make symlinks between shared folders of a VM and the VM’s other filesystem. See http://stackoverflow.com/questions/28144833/operation-not-permitted-in-sbt-typesafe-activator-inside-vagrant-synced-folder

You have a different version of scala for ENSIME (2.10.5) and root (2.11.7). [error] You have a different version of scala for ENSIME (2.10.5) and root (2.11.7). [error] If this is not what you intended, use either [error] scalaVersion in ThisBuild := “2.11.7” [error] in your build.sbt or add [error] ensimeScalaVersion in ThisBuild := “2.11.7” [error] to a local ensime.sbt [warn] No Java sources detected in /usr/lib/jvm/java-8-openjdk-amd64 (your ENSIME experience will not be as good as it could be.)

In the project’s build.sbt file add the line which defines the ensimeScalaVersion:

name := course.value + "-" + assignment.value

scalaVersion := "2.11.7"

ensimeScalaVersion in ThisBuild := "2.11.7" // For ensime (emacs)

Ensime key bindings

REPL

C-c C-v zLaunch embedded Scala REPL which is project aware

Errors

C-c C-c eList all errors and warnings in separate window.
C-c C-v eWith cursor on error, display error in minibuffer

Solidity

(use-package solidity-mode
  :ensure t
)

Idris

Configuration assuming you have Idris mode installed as well as the binaries (which are available in your path)

(use-package idris-mode
  :ensure t
)

Features

The currently supported features of idris in emacs (via the compiler) )are:

  • REPL
  • Type checking
  • Processing and displaying of errors
  • Proof mode
  • Case splitting
  • etc.
BindingFunction nameDescription
M-x idris-replidris-replLoad an idris REPL
C-c C-lidris-load-fileLoads the current buffer/file into the idris-repl

`M-x idris-repl` provides an interactive repl whose interaction is like a normal terminal repl but specifically for emacs.

INI

(use-package ini-mode
  :ensure t
)

XML

Keybindings for nXML mode:

KeyFunctionDescription
C-c C-fnxml-finish-elementInsert close tag automatically
;; We create this nxml keymap for easy folding of XML elements
;; https://emacs.stackexchange.com/questions/2884/the-old-how-to-fold-xml-question

(require 'hideshow)
(require 'sgml-mode)
(require 'nxml-mode)

(add-to-list 'hs-special-modes-alist
             '(nxml-mode
               "<!--\\|<[^/>]*[^/]>"
               "-->\\|</[^/>]*[^/]>"

               "<!--"
               sgml-skip-tag-forward
               nil))

(add-hook 'nxml-mode-hook 'hs-minor-mode)

;; optional key bindings, easier than hs defaults
(define-key nxml-mode-map (kbd "C-c h") 'hs-toggle-hiding)

PHP

(use-package php-mode
  :ensure t)

Visual Basic

From https://github.com/emacsmirror/emacswiki.org/blob/master/visual-basic-mode.el

(load-file "~/.emacs.d/lisp/visual-basic-mode.el")

; Set mode to autoload for the given file extensions
(setq auto-mode-alist (append '(("\\.\\(frm\\|bas\\|cls\\|vba\\)$" .
                                visual-basic-mode)) auto-mode-alist))

Jinja2

Jinja2 major mode is useful for editing j2 templates

(use-package jinja2-mode
  :ensure t)

TRAMP

docker support

This adds package docker-tramp which offers TRAMP integration for docker containers. E.G. you can type:

C-x C-f /docker:user@container:/path/to/file

where user is the user that you want to use (optional) container is the id or name of the container

(use-package docker-tramp
  :ensure t
  ; By default it shows the id of the open containers when use type `/docker:`
  ; This is inconvenient - we would rather show the name so set the variable to true.
  :init (setq docker-tramp-use-names t))

vagrant TRAMP

Causes issues when installed, so left out.

; (use-package vagrant-tramp
;   :ensure t)

Ido and Finding Files

IDO

(use-package ido
  :init
  (progn
    (setq ido-enable-flex-matching t)
    ; (setq ido-everywhere t) ;; causes issues when enabled on emacs 26+
    (ido-mode t)
    ;; (use-package ido-ubiquitous
    ;;   :ensure t
    ;;   :init (ido-ubiquitous-mode))
    (use-package ido-vertical-mode
      :ensure t
      :init (ido-vertical-mode 1)
      (setq ido-vertical-define-keys 'C-n-and-C-p-only))))

When switching buffers in multiple frames, by default, if an existing frame has the buffer open, ido will just move the cursor to that buffer. We don’t want that functionality so we change the default buffer method to change in the selected window instead.

(setq ido-default-buffer-method 'selected-window)

Recent Files

(require 'recentf)
(recentf-mode 1)
(setq recentf-max-menu-items 25)
(global-set-key (kbd "C-x C-r") 'recentf-open-files)

Built In Packages

Save Place

Save place allows you to reopen a buffer and have the point at the position it was when the buffer was closed automatically.

(require 'saveplace)
(setq save-place-file (concat user-emacs-directory ".saveplace.el"))
(setq-default save-place t)

Electric Indent Mode

Electric indent mode automatically indents your next line when hitting return. This can be useful for when in python you just want to continue the indentation on the next line at the same level.

Although it works well most of the time, it has known issues with certain modes e.g. ReST mode (rst-mode). See:

After playing with it, I find it more annoying than useful. Use ‘C-j’ instead.

; (electric-indent-mode t)

Misc. ELPA, MELPA Packages

This section uses the ‘use-package’ package to configure the packages downloaded from ELPA/MEPLA etc.

Ace Jump Mode

A quick way to jump around text in buffers.

Demos:

(use-package ace-jump-mode
  :ensure t
  :diminish ace-jump-mode
  :commands ace-jump-mode
  :bind ("C-M-j" . ace-jump-mode))  ;; ("C-S-s" . ace-jump-mode))  ;; CTRL-SHIFT-s together
        

Expand Region

Expands a region by semantic units e.g. for (setq alphabet-start “abc def”) and the point being somewhere within the “abc def” it would expand region to be in whole string, then to contents of the sexp setq alphabet-start “abc def” and finally to the entire sexp.

(use-package expand-region
  :ensure t
;  :diminish ace-jump-mode
  :bind ("C-=" . er/expand-region))

Helm

Helm is incremental completion and selection narrowing framework for Emacs. It will help steer you in the right direction when you’re looking for stuff in Emacs (like buffers, files, etc).

It makes buffers interactive and much nicer to deal with (among other things)!

(use-package helm
  :ensure t
  :diminish helm-mode
  :init (helm-mode)
  :bind (("M-y" . helm-show-kill-ring)
         ("C-x r b" . helm-bookmarks)
         ("M-x" . helm-M-x)
        ;; ("C-x C-b" . helm-buffers-list)
        )
)

;; From other config
  ;; :init (progn
  ;;         (require 'helm-config)
  ;;         (use-package helm-projectile
  ;;           :ensure t
  ;;           :commands helm-projectile
  ;;           :bind ("C-c p h" . helm-projectile))
  ;;         (use-package helm-ag :ensure t)
  ;;         (setq helm-locate-command "mdfind -interpret -name %s %s"
  ;;               helm-ff-newfile-prompt-p helm
  ;;               nil-M-x-fuzzy-match t)
  ;;         (helm-mode))
  ;; :bind (("C-c h" . helm-command-prefix)
  ;;        ("C-x b" . helm-mini)
  ;;        ("C-`" . helm-resume)
  ;;        ("M-x" . helm-M-x)
  ;;        ("C-x C-f" . helm-find-files))

Helm Swoop

Helm swoop is a nice replacement for M-x occur (M-s o).

(use-package helm-swoop
  :ensure t
  :bind(("M-s o" . helm-swoop)     
        ("M-s M-o" . helm-swoop)
       )
)

Highlight Indentation

(use-package highlight-indent-guides
  :ensure t
  :init 
   (highlight-indent-guides-mode)
   (setq highlight-indent-guides-method 'column)
)

Highlight Characters (Tabs))

The highlight characters package is useful to specifically highlight annoying tabs in a buffer.

(load-file "~/.emacs.d/lisp/highlight-chars.el")

Let’s enable this tab highlighting by default:

(add-hook 'font-lock-mode-hook 'hc-highlight-tabs)

Magit

Interface for git projects.

;; (use-package magit
;;   :ensure t
;;   :bind ("C-c g" . magit-status)
;;   :config
;;   (define-key magit-status-mode-map (kbd "q") 'magit-quit-session))

Multiple Cursors

We’ll also need to (require 'multiple-cusors) because of an autoload issue.

Multiple-cursors uses two lists of commands to know what to do: the run-once list and the run-for-all list. It comes with a set of defaults, but it would be beyond silly to try and include all the known Emacs commands.

So that’s why multiple-cursors occasionally asks what to do about a command. It will then remember your choice by saving it in ~/.emacs.d/.mc-lists.el. You can change the location with: (setq mc/list-file “/my/preferred/file”) - do this before requiring multiple cursors.

(use-package multiple-cursors
  :ensure t
  :init 
  ; (setq mc/list-file "/my/preferred/file")
  (require 'multiple-cursors)
  :bind (("C-S-c C-S-c" . mc/edit-lines)
         ("C->"         . mc/mark-next-like-this)
         ("C-<"         . mc/mark-previous-like-this)
         ("C-c C-<"     . mc/mark-all-like-this)
         ("C-!"         . mc/mark-next-symbol-like-this)
         ("C-S-d"       . mc/mark-all-dwim)))

Undo Tree

Undo tree allows you to visually view the undos which you have done in your buffer. Useful keybindings once enabled globally are:

KeyCommandDescription
C-_ C-/undo-tree-undoUndo changes.
M-_ C-?undo-tree-redoRedo changes.
C-x uundo-tree-visualizeVisualize the undo tree.
C-x r uundo-tree-save-state-to-registerSave current buffer state to register.
C-x r Uundo-tree-restore-state-from-registerRestore buffer state from register.
<up>undo-tree-visualize-undoUndo changes.
<down>undo-tree-visualize-undoUndo changes.
<left>undo-tree-visualize-switch-branch-leftSwitch to previous undo-tree branch.
<right>undo-tree-visualize-switch-branch-rightSwitch to next undo-tree branch.
tundo-tree-visualizer-toggle-timestampsToggle display of time-stamps.
qundo-tree-visualizer-quitQuit undo-tree-visualizer.
(use-package undo-tree
  :ensure t
  :init 
   (global-undo-tree-mode)
   (setq undo-tree-visualizer-diff t)  
)

Which Key

which-key is a minor mode for Emacs that displays the key bindings following your currently entered incomplete command (a prefix) in a popup. For example, after enabling the minor mode if you enter C-x and wait for the default of 1 second the minibuffer will expand with all of the available key bindings that follow C-x (or as many as space allows given your settings). This includes prefixes like C-x 8 which are shown in a different face.

(use-package which-key
  :ensure t
)

(require 'which-key)
(which-key-mode)
(which-key-setup-side-window-right-bottom)

Once a which-key buffer opens you can press C-h and then:

nnext page
pprevious page
uundo last key stroke

YAML Mode

YAML is a human readable data serialization format. Sometimes used for config files (Haskell Stack uses it a lot).

(use-package yaml-mode
  :ensure t
)

When in YAML we want to highlight indentations to make it clearer which level we are at:

(add-hook 'text-mode-hook 'highlight-indent-guides-mode)