feat(racket): add +hash-lang

`racket-mode` recently added `racket-hash-lang-mode` as an alternative
major mode.

Close: #7543
Co-authored-by: hlissner <hlissner@users.noreply.github.com>
This commit is contained in:
Sorawee Porncharoenwase 2024-09-11 05:51:49 -04:00 committed by Henrik Lissner
parent f6b7e8ae48
commit 1baebdafb3
No known key found for this signature in database
GPG key ID: B60957CA074D39A3
2 changed files with 104 additions and 82 deletions

View file

@ -14,8 +14,12 @@ This module adds support for the [[https://www.racket-lang.org/][Racket programm
Enable support for ~racket-mode~. Requires [[doom-module::tools lsp]] and a langserver Enable support for ~racket-mode~. Requires [[doom-module::tools lsp]] and a langserver
(supports [[https://github.com/jeapostrophe/racket-langserver][racket-langserver]]). (supports [[https://github.com/jeapostrophe/racket-langserver][racket-langserver]]).
- +xp :: - +xp ::
Enable the explore mode (~racket-xp-mode~), which "analyzes expanded code to Enable the explore minor mode (~racket-xp-mode~), which "analyzes expanded
explain and explore." code to explain and explore."
- +hash-lang ::
Enable the hash-lang major mode (~racket-hash-lang-mode~), which "uses
color-lexer, indent, and navigation supplied by a #lang." This flag can be
used along with the ~+xp~ flag.
** Packages ** Packages
- [[doom-package:racket-mode]] - [[doom-package:racket-mode]]

View file

@ -8,31 +8,49 @@
;; ;;
;;; Packages ;;; Packages
(let (mode
mode-map
mode-exts
mode-hook
mode-local-vars-hook)
(if (modulep! +hash-lang)
(setq mode 'racket-hash-lang-mode
mode-exts '("\\.rkt\\'" ; Racket
"\\.scrbl\\'" ; Scribble
"\\.rhm\\'")) ; Rhombus
(setq mode 'racket-mode
mode-exts `("\\.rkt\\'")))
(let ((mode-name (symbol-name mode)))
(setq mode-map (intern (format "%s-map" mode-name))
mode-hook (intern (format "%s-hook" mode-name))
mode-local-vars-hook (intern (format "%s-local-vars-hook" mode-name))))
(use-package! racket-mode (use-package! racket-mode
:mode "\\.rkt\\'" ; give it precedence over :lang scheme :defer t
:init
(dolist (entry mode-exts)
(add-to-list 'auto-mode-alist (cons entry mode)))
:config :config
(set-repl-handler! 'racket-mode #'+racket/open-repl) (set-repl-handler! mode #'+racket/open-repl)
(set-lookup-handlers! '(racket-mode racket-repl-mode) (set-lookup-handlers! `(,mode racket-repl-mode)
:definition #'+racket-lookup-definition :definition #'+racket-lookup-definition
:documentation #'+racket-lookup-documentation) :documentation #'+racket-lookup-documentation)
(set-docsets! 'racket-mode "Racket") (set-docsets! mode "Racket")
(set-ligatures! 'racket-mode (set-ligatures! mode
:lambda "lambda" :lambda "lambda"
:map "map" :map "map"
:dot ".") :dot ".")
(set-rotate-patterns! 'racket-mode (set-rotate-patterns! mode :symbols '(("#true" "#false")))
:symbols '(("#true" "#false"))) (set-formatter! 'raco-fmt '("raco" "fmt") :modes (list mode))
(set-formatter! 'raco-fmt '("raco" "fmt") :modes '(racket-mode))
(add-hook! 'racket-mode-hook (add-hook mode-hook #'rainbow-delimiters-mode)
#'rainbow-delimiters-mode (add-hook mode-hook #'highlight-quoted-mode)
#'highlight-quoted-mode)
(when (modulep! +lsp) (when (modulep! +lsp)
(add-hook 'racket-mode-local-vars-hook #'lsp! 'append)) (add-hook mode-local-vars-hook #'lsp! 'append))
(when (modulep! +xp) (when (modulep! +xp)
(add-hook 'racket-mode-local-vars-hook #'racket-xp-mode) (add-hook mode-local-vars-hook #'racket-xp-mode)
;; Both flycheck and racket-xp produce error popups, but racket-xp's are ;; Both flycheck and racket-xp produce error popups, but racket-xp's are
;; higher quality so disable flycheck's: ;; higher quality so disable flycheck's:
(when (modulep! :checkers syntax) (when (modulep! :checkers syntax)
@ -42,7 +60,7 @@
(unless (or (modulep! :editor parinfer) (unless (or (modulep! :editor parinfer)
(modulep! :editor lispy)) (modulep! :editor lispy))
(add-hook 'racket-mode-hook #'racket-smart-open-bracket-mode)) (add-hook mode-hook #'racket-smart-open-bracket-mode))
(map! (:map racket-xp-mode-map (map! (:map racket-xp-mode-map
[remap racket-doc] #'racket-xp-documentation [remap racket-doc] #'racket-xp-documentation
@ -50,7 +68,7 @@
[remap next-error] #'racket-xp-next-error [remap next-error] #'racket-xp-next-error
[remap previous-error] #'racket-xp-previous-error) [remap previous-error] #'racket-xp-previous-error)
(:localleader (:localleader
:map racket-mode-map :map ,mode-map
"a" #'racket-align "a" #'racket-align
"A" #'racket-unalign "A" #'racket-unalign
"f" #'racket-fold-all-tests "f" #'racket-fold-all-tests
@ -92,4 +110,4 @@
(:prefix ("g" . "goto") (:prefix ("g" . "goto")
"b" #'racket-unvisit "b" #'racket-unvisit
"m" #'racket-visit-module "m" #'racket-visit-module
"d" #'racket-repl-visit-definition)))) "d" #'racket-repl-visit-definition)))))