about summary refs log tree commit diff
path: root/users/glittershark/emacs.d/snippets/haskell-mode/test-module
diff options
context:
space:
mode:
Diffstat (limited to 'users/glittershark/emacs.d/snippets/haskell-mode/test-module')
-rw-r--r--users/glittershark/emacs.d/snippets/haskell-mode/test-module22
1 files changed, 22 insertions, 0 deletions
diff --git a/users/glittershark/emacs.d/snippets/haskell-mode/test-module b/users/glittershark/emacs.d/snippets/haskell-mode/test-module
new file mode 100644
index 000000000000..82224b36a49e
--- /dev/null
+++ b/users/glittershark/emacs.d/snippets/haskell-mode/test-module
@@ -0,0 +1,22 @@
+# -*- mode: snippet -*-
+# name: test-module
+# key: test
+# expand-env: ((yas-indent-line 'fixed))
+# --
+{-# LANGUAGE ApplicativeDo #-}
+--------------------------------------------------------------------------------
+module ${1:`(if (not buffer-file-name) "Module"
+                (let ((name (file-name-sans-extension (buffer-file-name)))
+                      (case-fold-search nil))
+                     (if (cl-search "test/" name)
+                         (replace-regexp-in-string "/" "."
+                           (replace-regexp-in-string "^\/[^A-Z]*" ""
+                             (car (last (split-string name "src")))))
+                         (file-name-nondirectory name))))`} where
+--------------------------------------------------------------------------------
+import           Test.Prelude
+import qualified Hedgehog.Gen as Gen
+import qualified Hedgehog.Range as Range
+--------------------------------------------------------------------------------
+import           ${1:$(s-chop-suffix "Test" yas-text)}
+--------------------------------------------------------------------------------