J3RN / inf-elixir

An Emacs plugin for interacting with an Elixir REPL
GNU General Public License v3.0
44 stars 10 forks source link
elixir elixir-lang elixir-repl emacs emacs-lisp iex inf-elixir

inf-elixir

License GPL 3 MELPA MELPA Stable CircleCI status

This is a package to allow you to pop open and interact with Elixir REPL (IEx, presently).

Features

TODO

Installation

inf-elixir is proudly distributed by MELPA and MELPA Stable. I would also strongly encourage folks to use MELPA Stable, as the releases there will be more, well, stable. In order to install the package, follow the Getting Started instructions on the MELPA website or the Getting Started instructions on the MELPA Stable website.

Once your installation is configured to use MELPA, inf-elixir can be installed with M-x package-install RET inf-elixir RET.

use-package can be used to install and/or configure inf-elixir:

(use-package inf-elixir
  :bind (("C-c i i" . 'inf-elixir)
         ("C-c i p" . 'inf-elixir-project)
         ("C-c i l" . 'inf-elixir-send-line)
         ("C-c i r" . 'inf-elixir-send-region)
         ("C-c i b" . 'inf-elixir-send-buffer)
         ("C-c i R" . 'inf-elixir-reload-module)))

Or with Doom Emacs:

packages.el

(package! inf-elixir)

config.el

(map! :after elixir-mode
        :localleader
        :map elixir-mode-map
        :prefix ("i" . "inf-elixir")
        "i" 'inf-elixir
        "p" 'inf-elixir-project
        "l" 'inf-elixir-send-line
        "r" 'inf-elixir-send-region
        "b" 'inf-elixir-send-buffer
        "R" 'inf-elixir-reload-module)

Keybindings

inf-elixir intentionally ships with no keybindings by default. This grants the user the freedom to specify whatever keybindings they would like. Functions that users would probably have an interest in binding are:

An example of keybindings is included in the use-package declaration above.

Development

I am not yet using any kind of build tool (like Eldev or Cask) to develop this plugin. Generally speaking, working with the code involves:

  1. Clone the git repository
  2. Make some changes
  3. Load your changes with M-x load-file RET inf-elixir.el RET
  4. Verify your changes worked
  5. Send a PR :pray:

There are some tests written with ERT that can be run with this command:

$ emacs -batch -l ert -l inf-elixir.el -l tests/inf-elixir-test.el -f ert-run-tests-batch-and-exit