;; ============================================================================= ;; ___ _ __ ___ __ _ ___ ___ ;; / _ \ '_ ` _ \ / _` |/ __/ __| ;; | __/ | | | | | (_| | (__\__ \ ;; (_)___|_| |_| |_|\__,_|\___|___/ ;; ============================================================================= (setq user-full-name (replace-regexp-in-string "\n$" "" (shell-command-to-string "git config --get user.email"))) (setq user-mail-address (replace-regexp-in-string "\n$" "" (shell-command-to-string "git config --get user.name"))) ;; ============================================================================= ;; Load Path Configuration ;; ============================================================================= (if (not (file-exists-p "~/.emacs.d/elpa")) (make-directory "~/.emacs.d/elpa")) (let ((default-directory "~/.emacs.d/lisp/")) (normal-top-level-add-subdirs-to-load-path)) (let ((default-directory "~/.emacs.d/elpa/")) (normal-top-level-add-subdirs-to-load-path)) (add-to-list 'custom-theme-load-path "~/.emacs.d/elpa/") (setq custom-file "~/.emacs.d/custom.el") (when (file-exists-p custom-file) (load custom-file)) ;; ============================================================================= ;; ELPA/package.el/MELPA ;; ============================================================================= (require 'package) (when (< emacs-major-version 24) (add-to-list 'package-archives '("gnu" . "http://elpa.gnu.org/packages/") t)) (add-to-list 'package-archives '("marmalade" . "http://marmalade-repo.org/packages/") t) (add-to-list 'package-archives '("melpa" . "http://melpa.org/packages/") t) (package-initialize) (defvar packages-appearance '(monokai-theme solarized-theme zenburn-theme base16-theme molokai-theme tango-2-theme color-theme-sanityinc-tomorrow smart-mode-line ansi-color rainbow-delimiters)) (defvar packages-essential '(epl projectile flycheck ace-jump-mode helm helm-projectile popup smex magit auto-complete ido-ubiquitous mo-git-blame multiple-cursors flx-ido yasnippet cl-lib)) (defvar packages-other '(latex-preview-pane auctex paredit inf-ruby undo-tree gitconfig-mode exec-path-from-shell slime string-inflection yaml-mode sgml-mode dired+ ctags ctags-update hackernews)) (defvar packages-python '(jedi pymacs pytest sphinx-doc)) (defvar packages-scala '(scala-mode2 ensime)) (defvar packages-js '(js2-mode js3-mode web-beautify tern tern-auto-complete)) (defun ensure-packages-installed (packages) (condition-case ex (dolist (p packages) (when (not (package-installed-p p)) (package-install p))) ('error (package-refresh-contents) (ensure-packages-installed packages) nil))) (ensure-packages-installed (append packages-essential packages-python packages-scala packages-js packages-appearance packages-other)) ;; ============================================================================= ;; Disables ;; ============================================================================= ;; Get rid of any gui like features... (if (fboundp 'scroll-bar-mode) (scroll-bar-mode -1)) (if (fboundp 'tool-bar-mode) (tool-bar-mode -1)) (if (fboundp 'menu-bar-mode) (menu-bar-mode -1)) ;; Disable the creation of backup files. (setq backup-inhibited t) (setq make-backup-files nil) (setq auto-save-default nil) (put 'set-goal-column 'disabled nil) (auto-fill-mode -1) ;; ============================================================================= ;; General Emacs Options ;; ============================================================================= ;; Set path from shell. (exec-path-from-shell-initialize) ;; This makes it so that emacs --daemon puts its files in ~/.emacs.d/server ;; (among other things) (setq server-use-tcp t) ;; Give duplicate open buffers better titles. (require 'uniquify) (setq uniquify-buffer-name-style 'forward) ;; Display line and column numbers in mode line. (line-number-mode t) (column-number-mode t) (global-linum-mode t) (setq visible-bell t) (global-auto-complete-mode) ;; Don't disable downcase and upcase region. (put 'upcase-region 'disabled nil) (put 'downcase-region 'disabled nil) (setq c-subword-mode t) (setq flyspell-issue-welcome-flag nil) (latex-preview-pane-enable) (add-hook 'after-init-hook '(lambda () (setq debug-on-error t))) (add-hook 'after-init-hook #'global-flycheck-mode) ;; ============================================================================= ;; Mode Hooks ;; ============================================================================= (add-hook 'prog-mode-hook (lambda () (auto-fill-mode nil))) (add-hook 'prog-mode-hook (lambda () (subword-mode t))) (add-hook 'prog-mode-hook (lambda () (rainbow-delimiters-mode t))) (add-hook 'prog-mode-hook (lambda () (auto-complete-mode t))) ;; (add-hook 'prog-mode-hook (lambda () (highlight-lines-matching-regexp ;; ".\\{81\\}" 'hi-blue))) ;; ============================================================================= ;; Navigation: helm/projectile/ido ;; ============================================================================= (require 'ido) (require 'flx-ido) (require 'helm-config) (helm-mode 1) (ido-mode t) (ido-everywhere 1) (flx-ido-mode 1) (setq ido-enable-flex-matching t) (projectile-global-mode) (setq projectile-enable-caching t) ;; disable ido faces to see flx highlights. (setq ido-use-faces nil) ;; This makes flx-ido much faster. (setq gc-cons-threshold 20000000) (autoload 'smex "smex" (global-set-key (kbd "M-x") 'smex)) ;; ============================================================================= ;; functions ;; ============================================================================= (defun get-buffer-name() (interactive) (file-relative-name (buffer-file-name))) (defun message-buffer-name() (interactive) (message (get-buffer-name))) (defun os-copy (&optional b e) (interactive "r") (shell-command-on-region b e "source ~/.zshrc; cat | smart_copy")) (defun os-paste () (interactive) (insert (shell-command-to-string "source ~/.zshrc; ospaste"))) (defun all-copy (&optional b e) (interactive "r") (os-copy b e) (tmux-copy b e) (kill-ring-save b e)) (defun open-pdf () (interactive) (let ( (pdf-file (replace-regexp-in-string "\.tex$" ".pdf" buffer-file-name))) (shell-command (concat "open " pdf-file)))) (defun tmux-copy (&optional b e) (interactive "r") (shell-command-on-region b e "cat | tmux loadb -")) (defun tmux-copy-buffer-name (&optional b e) (interactive "r") (shell-command (concat "echo " (shell-quote-argument (ffip-get-buffer-name)) " | tmux loadb -"))) ;; ============================================================================= ;; Python ;; ============================================================================= (defun python-tabs () (setq tab-width 4 indent-tabs-mode t python-indent-offset 4)) (defvar use-python-tabs nil) (defun add-virtual-envs-to-jedi-server () (let ((virtual-envs (get-virtual-envs))) (when virtual-envs (set (make-local-variable 'jedi:server-args) (make-virtualenv-args virtual-envs))))) (defun make-virtualenv-args (virtual-envs) (apply #'append (mapcar (lambda (env) `("-v" ,env)) virtual-envs))) (defun get-virtual-envs () (interactive) (condition-case ex (let (project-root (projectile-project-root)) (cl-remove-if-not 'file-exists-p (mapcar (lambda (env-suffix) (concat project-root env-suffix)) '(".tox/py27/" "env" ".tox/venv/")))) ('error (message (format "Caught exception: [%s]" ex)) (setq retval (cons 'exception (list ex)))) nil)) (add-hook 'python-mode-hook (lambda () (setq show-trailing-whitespace t))) (add-hook 'python-mode-hook (lambda () (if use-python-tabs python-tabs))) (add-hook 'python-mode-hook (lambda () (subword-mode t))) (add-hook 'python-mode-hook 'jedi:setup) (add-hook 'python-mode-hook 'add-virtual-envs-to-jedi-server) (setq jedi:complete-on-dot t) ;; Macros (fset 'ipdb "import ipdb; ipdb.set_trace()") (fset 'main "if __name__ == '__main__':") (fset 'sphinx-class ":class:`~") ;; ============================================================================= ;; Scala ;; ============================================================================= (require 'ensime) (require 'scala-mode2) (add-hook 'scala-mode-hook 'ensime-scala-mode-hook) (add-hook 'scala-mode-hook '(lambda () (require 'whitespace) ;; clean-up whitespace at save (make-local-variable 'before-save-hook) (add-hook 'before-save-hook 'whitespace-cleanup) ;; turn on highlight. To configure what is highlighted, customize ;; the *whitespace-style* variable. A sane set of things to ;; highlight is: face, tabs, trailing (whitespace-mode))) ;; ============================================================================= ;; JavaScript ;; ============================================================================= (add-hook 'js-mode-hook (lambda () (tern-mode t))) (eval-after-load 'tern '(progn (require 'tern-auto-complete) (tern-ac-setup))) ;; ============================================================================= ;; Custom Key Bindings ;; ============================================================================= (defun bind-eval-and-replace () (define-key emacs-lisp-mode-map (kbd "C-c C-r") #'esk-eval-and-replace)) (add-hook 'lisp-mode-hook 'bind-eval-and-replace) (add-hook 'lisp-interaction-mode-hook 'bind-eval-and-replace) (add-hook 'elisp-interaction-mode-hook 'bind-eval-and-replace) ;; Miscellaneous (global-unset-key (kbd "C-o")) ;; Avoid collision with tmux binding. (global-set-key (kbd "C-;") 'ace-jump-char-mode) (global-set-key (kbd "C-M-;") 'comment-dwim) (global-set-key (kbd "C-c +") 'message-buffer-name) (global-set-key (kbd "C-c e") 'os-copy) (global-set-key (kbd "C-c g") 'jedi:goto-definition) (global-set-key (kbd "C-c j") 'ace-jump-mode) (global-set-key (kbd "C-c t") 'pytest-one) (global-set-key (kbd "C-x C-b") 'buffer-menu) (global-set-key (kbd "C-x C-c") 'kill-emacs) (global-set-key (kbd "C-x C-i") 'imenu) (global-set-key (kbd "C-x C-r") (lambda () (interactive) (revert-buffer t t))) (global-set-key (kbd "C-x O") (lambda () (interactive) (other-window -1))) (global-set-key (kbd "C-x f") 'helm-projectile) (global-set-key (kbd "C-x w") 'whitespace-mode) (global-set-key (kbd "M-g") 'goto-line) ;; Multiple Cursors (global-set-key (kbd "C-x r t") 'mc/edit-lines) (global-set-key (kbd "C->") 'mc/mark-next-like-this) (global-set-key (kbd "C-<") 'mc/mark-previous-like-this) (global-set-key (kbd "C-c <") 'mc/mark-all-like-this) (global-set-key (kbd "C->") 'mc/mark-next-like-this) (eval-after-load 'js2-mode '(define-key js2-mode-map (kbd "C-c b") 'web-beautify-js)) (eval-after-load 'json-mode '(define-key json-mode-map (kbd "C-c b") 'web-beautify-js)) (eval-after-load 'sgml-mode '(define-key html-mode-map (kbd "C-c b") 'web-beautify-html)) (eval-after-load 'css-mode '(define-key css-mode-map (kbd "C-c b") 'web-beautify-css)) ;; ============================================================================= ;; Appearance ;; ============================================================================= ;; make whitespace-mode use just basic coloring (setq whitespace-style (quote (spaces tabs newline ;;space-mark tab-mark newline-mark))) (setq whitespace-display-mappings '((space-mark 32 [183] [46]) (tab-mark 9 [9655 9] [92 9]))) (defun colorize-compilation-buffer () (toggle-read-only) (ansi-color-apply-on-region (point-min) (point-max)) (toggle-read-only)) (add-hook 'compilation-filter-hook 'colorize-compilation-buffer) ;; smart-mode-line (sml/setup) (sml/apply-theme 'respectful) ;; ============================================================================= ;; Themes ;; ============================================================================= (load-theme 'monokai t) ;; Choose random theme: (defvar dark-themes '(monokai molokai solarized-dark base16-default)) (defvar light-themes '(zenburn solarized-light)) (defun random-choice (choices) (nth (random (length choices)) choices)) (defun get-appropriate-theme () (let ((hour (string-to-number (format-time-string "%H")))) (if (or (< hour 6) (> hour 18)) (random-choice dark-themes) (random-choice light-theme)))) (setq current-theme nil) (defun set-theme () (interactive) (let ((appropriate-theme (get-appropriate-theme))) (if (eq appropriate-theme current-theme) nil (progn (load-theme-no-hl-line appropriate-theme) (setq current-theme appropriate-theme))))) (defun load-theme-no-hl-line (theme) (load-theme theme t) (setq hl-line-mode nil)) ;; enable to set theme based on time of day. ;; (run-at-time "12:00" 3600 'set-theme) ;; Set the default font for emacs. ;;(set-frame-font "Menlo 11" t t)