;;; alchemist.el --- Elixir tooling integration into Emacs ;; Copyright © 2014-2015 Samuel Tonini ;; ;; Author: Samuel Tonini ;; URL: http://www.github.com/tonini/alchemist.el ;; Version: 0.14.0-cvs ;; Package-Requires: ((emacs "24")) ;; Keywords: languages, mix, elixir, elixirc, hex ;; This file is not part of GNU Emacs. ;; This program is free software: you can redistribute it and/or modify ;; it under the terms of the GNU General Public License as published by ;; the Free Software Foundation, either version 3 of the License, or ;; (at your option) any later version. ;; This program is distributed in the hope that it will be useful, ;; but WITHOUT ANY WARRANTY; without even the implied warranty of ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;; GNU General Public License for more details. ;; You should have received a copy of the GNU General Public License ;; along with this program. If not, see . ;;; Commentary: ;; Alchemist integrate Elixir's tooling into Emacs ;;; Code: (defgroup alchemist nil "Elixir Tooling Integration Into Emacs." :prefix "alchemist-" :group 'applications :link '(url-link :tag "Github" "https://github.com/tonini/alchemist.el") :link '(emacs-commentary-link :tag "Commentary" "alchemist")) (require 'alchemist-utils) (require 'alchemist-project) (require 'alchemist-buffer) (require 'alchemist-compile) (require 'alchemist-execute) (require 'alchemist-mix) (require 'alchemist-hooks) (require 'alchemist-help) (require 'alchemist-complete) (require 'alchemist-message) (require 'alchemist-iex) (require 'alchemist-eval) (require 'alchemist-goto) (eval-after-load 'company '(progn (require 'alchemist-company))) (defun alchemist-mode-hook () "Hook which enables `alchemist-mode'" (alchemist-mode 1)) (defvar alchemist--version "0.14.0-cvs") ;;;###autoload (defun alchemist-version (&optional show-version) "Display Alchemist's version." (interactive) (message "Alchemist %s" (replace-regexp-in-string "-cvs" "snapshot" alchemist--version))) (defvar alchemist-mode-map (let ((map (make-sparse-keymap))) (define-key map (kbd "C-c a t") 'alchemist-mix-test) (define-key map (kbd "C-c a m t f") 'alchemist-mix-test-file) (define-key map (kbd "C-c a m t b") 'alchemist-mix-test-this-buffer) (define-key map (kbd "C-c a m t .") 'alchemist-mix-test-at-point) (define-key map (kbd "C-c a c c") 'alchemist-compile) (define-key map (kbd "C-c a c f") 'alchemist-compile-file) (define-key map (kbd "C-c a c b") 'alchemist-compile-this-buffer) (define-key map (kbd "C-c a e e") 'alchemist-execute) (define-key map (kbd "C-c a e f") 'alchemist-execute-file) (define-key map (kbd "C-c a e b") 'alchemist-execute-this-buffer) (define-key map (kbd "C-c a h h") 'alchemist-help) (define-key map (kbd "C-c a h e") 'alchemist-help-search-at-point) (define-key map (kbd "C-c a h m") 'alchemist-help-search-marked-region) (define-key map (kbd "C-c a p f") 'alchemist-project-find-test) (define-key map (kbd "C-c a p t") 'alchemist-project-open-tests-for-current-file) (define-key map (kbd "C-c a i i") 'alchemist-iex-run) (define-key map (kbd "C-c a i p") 'alchemist-iex-project-run) (define-key map (kbd "C-c a i l") 'alchemist-iex-send-current-line) (define-key map (kbd "C-c a i c") 'alchemist-iex-send-current-line-and-go) (define-key map (kbd "C-c a i r") 'alchemist-iex-send-region) (define-key map (kbd "C-c a i m") 'alchemist-iex-send-region-and-go) (define-key map (kbd "C-c a i b") 'alchemist-iex-compile-this-buffer) (define-key map (kbd "C-c a v l") 'alchemist-eval-current-line) (define-key map (kbd "C-c a v k") 'alchemist-eval-print-current-line) (define-key map (kbd "C-c a v j") 'alchemist-eval-quoted-current-line) (define-key map (kbd "C-c a v h") 'alchemist-eval-print-quoted-current-line) (define-key map (kbd "C-c a v o") 'alchemist-eval-region) (define-key map (kbd "C-c a v i") 'alchemist-eval-print-region) (define-key map (kbd "C-c a v u") 'alchemist-eval-quoted-region) (define-key map (kbd "C-c a v y") 'alchemist-eval-print-quoted-region) (define-key map (kbd "C-c a v q") 'alchemist-eval-buffer) (define-key map (kbd "C-c a v w") 'alchemist-eval-print-buffer) (define-key map (kbd "C-c a v e") 'alchemist-eval-quoted-buffer) (define-key map (kbd "C-c a v r") 'alchemist-eval-print-quoted-buffer) (define-key map (kbd "M-.") 'alchemist-goto-definition-at-point) (define-key map (kbd "M-,") 'alchemist-goto-jump-back) map) "The keymap used when `alchemist-mode' is active.") ;;;###autoload (define-minor-mode alchemist-mode "Toggle alchemist mode. Key bindings: \\{alchemist-mode-map}" nil ;; The indicator for the mode line. " alchemist" :group 'alchemist :global nil :keymap 'alchemist-mode-map (cond (alchemist-mode (alchemist-buffer-initialize-modeline)) (t (alchemist-buffer-reset-modeline)))) (add-hook 'elixir-mode-hook 'alchemist-mode-hook) (provide 'alchemist) ;;; alchemist.el ends here