emacs-up
is a bare-bones, quick-start Emacs configuration. It is
meant to get newcomers started and productive with Emacs and contains
the minimal configuration required to satisfy employee asks inside
Helpshift. emacs-up
is currently configured for Clojure & Frontend
programming only, but I’m hoping that it will soon be expanded to include other
programming languages used within Helpshift.
- The minimum supported Emacs version for this configuration is
Emacs 25. You can install the latest Emacs through Homebrew as
follows:
$ brew cask install emacs
- Out of the box,
emacs-up
supports development on Clojure versions1.8
and Java8
(and above). If you are someone who has to program against Clojure1.7
,1.6
or older versions, refer to the section below this one on instructions to do that. - Clone
emacs-up
to your machine as your.emacs.d
folder.$ git clone https://github.com/helpshift/emacs-up.git ~/.emacs.d
- Create a
.lein/profiles.clj
file in your home directory. Note: You need a minimum lein version of2.8.3
. I recommend installing the latest current lein (2.9.4
as of this point in time)- The contents of the file should be as follows:
{:user {:plugins [[cider/cider-nrepl "0.25.3"] [refactor-nrepl "2.5.0"]]}}
- You don’t need the cider-nrepl or refactor-nrepl plugin section if
you use
cider-jack-in
to start your REPL and connect to it. We don’t usecider-jack-in
at Helpshift, for reasons outside the scope of this document. - Changes will not apply to REPLs that are already running. After
creating the
profiles.clj
file, you need to stop and restart running REPLs.
- The contents of the file should be as follows:
- For Javascript auto formatting, do,
npm install -g prettier
. - Fire up Emacs and wait for it to download packages (This is a one-time thing).
- Review the next section in this README. It has details of external tools and dependencies that you need to install for working with certain packages. Install these dependencies. (Look for the Needs Install note)
- (For beginners) Go through the tutorial in the
docs/
folder to get started.
avy
: Jump to things in Emacs tree-style.cider
: Clojure IDE and REPL. This package is pinned to a stable version.clj-refactor
: A collection of commands for refactoring Clojure code. This package is pinned to a stable version.company-mode
: Modular in-buffer completion framework for Emacs.dumb-jump
: an Emacs jump to definition package for 40+ languages.flycheck
: On-the-fly syntax checking extensionflycheck-clj-kondo
: Emacs Integration withclj-kondo
, a linter for Clojure code providing on-the-fly syntax checking.- Note: Needs Install: This package needs
clj-kondo
to provide linting information for Clojure files. Installclj-kondo
by following installation instructions at https://github.com/borkdude/clj-kondo/blob/master/doc/install.md
- Note: Needs Install: This package needs
cljstyle-mode
: Emacs Integration withcljstyle
, an automatic formatting tool which ensures that Clojure code is well-formatted.- Note: Needs Install: This package needs
cljstyle
to format your Clojure files when you save the buffer. Installcljstyle
by following installation instructions at https://github.com/greglook/cljstyle#installation
- Note: Needs Install: This package needs
helm
: Emacs incremental completion and narrowing framework.helm-ag
: The silver search with helm interface.- Note: Needs Install: This package depends on Ag - The Silver
Searcher. Installing Ag will allow you to levarage super fast
searches on files and data from within Emacs. Installing this is
optional, not installing it will mean that only
helm-ag
will cease to work. You can find instructions to install Ag here: https://github.com/ggreer/the_silver_searcher.
- Note: Needs Install: This package depends on Ag - The Silver
Searcher. Installing Ag will allow you to levarage super fast
searches on files and data from within Emacs. Installing this is
optional, not installing it will mean that only
helm-cider
:helm
integration forcider
.helm-projectile
:helm
integration forprojectile
.ido
: Interactively do things with buffers and filesido-completing-read-plus
: Fancy completion all over Emacs, not just for buffers and files.magit
: An Emacs mode for Git.paredit
: Minor mode for editing parentheses.projectile
: Project navigation and management library for Emacs.smex
: M-x interface with Ido-style fuzzy matching.yasnippet
: a template system for Emacs.rjsx-mode
: Major mode for JSX and JS filesprettier-js
: Auto formatting for JSX and JS files
If you are developing against Clojure 1.7, you need to install older packages of CIDER, Clj-Refactor and Clojure mode. Don’t worry, I have you covered here.
- Open the file
hs-clj-packages.el
- at the top level in this repository - and modify the value againstclj-version
fromclj18+
toclj17
. (This is the first line of code in the file, so it’s at the very top). - Create a
.lein/profiles.clj
file in your home directory.- The contents of the file should be as follows:
{:user {:plugins [[cider/cider-nrepl "0.17.0"] [refactor-nrepl "2.3.1"]] :dependencies [[nrepl "0.3.1"]]}}
- Changes will not apply to REPLs that are already running. After
creating the
profiles.clj
file, you need to stop and restart running REPLs.
- The contents of the file should be as follows:
- Fire up / Restart your Emacs and wait for it to download packages (This is a one-time thing).
If you are developing against Clojure 1.6 or earlier, you need to install older packages of CIDER, Clj-Refactor and Clojure mode. Don’t worry, I have you covered here.
- Open the file
hs-clj-packages.el
- at the top level in this repository - and modify the value againstclj-version
fromclj18+
toclj16-
. (This is the first line of code in the file, so it’s at the very top). - Create a
.lein/profiles.clj
file in your home directory.- The contents of the file should be as follows:
{:repl {:plugins [[cider/cider-nrepl "0.10.2"] [refactor-nrepl "1.1.0"]] :dependencies [^:replace [org.clojure/tools.nrepl "0.2.12"]]}}
- Changes will not apply to REPLs that are already running. After
creating the
profiles.clj
file, you need to stop and restart running REPLs.
- The contents of the file should be as follows:
- Fire up / Restart your Emacs and wait for it to download packages (This is a one-time thing).
The current version of emacs-up
is v3.4.1
. If you are updating
an existing installation of emacs-up
, the NEWS.org
file lists
major changes and update instructions.