ghc-mod/elisp/ghc-ins-mod.el

63 lines
1.7 KiB
EmacsLisp
Raw Normal View History

2011-12-27 07:28:02 +00:00
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;
;;; ghc-ins-mod.el
;;;
;; Author: Kazu Yamamoto <Kazu@Mew.org>
;; Created: Dec 27, 2011
;;; Code:
(defvar ghc-hoogle-command "hoogle")
(defun ghc-insert-module ()
(interactive)
2014-03-13 13:21:58 +00:00
(ghc-executable-find ghc-hoogle-command
2012-01-23 06:12:24 +00:00
(let* ((expr0 (ghc-things-at-point))
2011-12-27 07:42:44 +00:00
(expr (ghc-read-expression expr0)))
2011-12-28 08:04:47 +00:00
(let ((mods (ghc-function-to-modules expr)))
(if (null mods)
(message "No module guessed")
(let* ((first (car mods))
(mod (if (= (length mods) 1)
first
(completing-read "Module name: " mods nil t first))))
(save-excursion
(ghc-goto-module-position)
(insert "import " mod "\n"))))))))
2011-12-27 07:28:02 +00:00
(defun ghc-goto-module-position ()
(goto-char (point-max))
(if (re-search-backward "^import" nil t)
2012-01-23 06:12:24 +00:00
(ghc-goto-empty-line)
2011-12-27 07:28:02 +00:00
(if (re-search-backward "^module" nil t)
2012-01-23 06:12:24 +00:00
(ghc-goto-empty-line)
2011-12-27 07:28:02 +00:00
(goto-char (point-min)))))
2012-01-23 06:12:24 +00:00
(defun ghc-goto-empty-line ()
(unless (re-search-forward "^$" nil t)
(forward-line)))
2012-01-23 09:30:07 +00:00
;; To avoid Data.Functor
(defvar ghc-applicative-operators '("<$>" "<$" "<*>" "<**>" "<*" "*>" "<|>"))
2011-12-27 07:28:02 +00:00
(defun ghc-function-to-modules (fn)
2012-01-23 09:30:07 +00:00
(if (member fn ghc-applicative-operators)
'("Control.Applicative")
(ghc-function-to-modules-hoogle fn)))
(defun ghc-function-to-modules-hoogle (fn)
2011-12-27 07:28:02 +00:00
(with-temp-buffer
2012-01-23 09:30:07 +00:00
(let* ((fn1 (if (string-match "^[a-zA-Z0-9'_]+$" fn)
fn
(concat "(" fn ")")))
(regex (concat "^\\([a-zA-Z0-9.]+\\) " fn1 " "))
ret)
2014-03-14 05:01:07 +00:00
(ghc-call-process ghc-hoogle-command nil t nil "search" fn1)
2012-01-23 09:30:07 +00:00
(goto-char (point-min))
2011-12-27 07:28:02 +00:00
(while (re-search-forward regex nil t)
(setq ret (cons (match-string 1) ret)))
(nreverse ret))))
(provide 'ghc-ins-mod)