about summary refs log blame commit diff
path: root/users/wpcarro/emacs/.emacs.d/wpc/wpc-haskell.el
blob: 536790e36d614c22380e92604229c2e326bdedba (plain) (tree)
1
2
3
4
5
6
7
8
9
10
11

                                                                        
                                              
                 
                                   





                                           









                                                                                
                                   
                         
         
                                                                      
 
                
                                  







                                                   
                                  


                                                   
                                                     


                                           
                                   


                                              

                                
 
                      
                            
;;; wpc-haskell.el --- My Haskell preferences -*- lexical-binding: t -*-

;; Author: William Carroll <wpcarro@gmail.com>
;; Version: 0.0.1
;; Package-Requires: ((emacs "24"))

;;; Commentary:
;; Hosts my Haskell development preferences

;;; Code:

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Dependencies
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

(require 'macros)

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Configuration
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

;; font-locking, glyph support, etc
(use-package haskell-mode
  :config
  (macros-add-hook-before-save 'haskell-mode #'haskell-align-imports))

;; Test toggling
(defun wpc-haskell-module->test ()
  "Jump from a module to a test."
  (let ((filename (->> buffer-file-name
                       (s-replace "/src/" "/test/")
                       (s-replace ".hs" "Test.hs")
                       find-file)))
    (make-directory (f-dirname filename) t)
    (find-file filename)))

(defun wpc-haskell-test->module ()
  "Jump from a test to a module."
  (let ((filename (->> buffer-file-name
                       (s-replace "/test/" "/src/")
                       (s-replace "Test.hs" ".hs"))))
    (make-directory (f-dirname filename) t)
    (find-file filename)))

(defun wpc-haskell-test<->module ()
  "Toggle between test and module in Haskell."
  (interactive)
  (if (s-contains? "/src/" buffer-file-name)
      (wpc-haskell-module->test)
    (wpc-haskell-test->module)))

(provide 'wpc-haskell)
;;; wpc-haskell.el ends here