-
-
Notifications
You must be signed in to change notification settings - Fork 61
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add editor syntax highlighting for jank #24
Comments
A question: what do you think about replicating what ClojureScript already do? In CLJS, this is a way to do interop: (js* "10 + ~{}" 30) Maybe a |
Someone brought this up at the Conj as well. I actually wasn't familiar with the CLJS interpolation syntax, but I think consistency makes sense. Kondo would still need to understand that |
I'll try to implement this in Pulsar, but first this ticket on Tree-Sitter needs to be done: sogaiu/tree-sitter-clojure#52. Otherwise, "injected" C++ grammar will highlight the whole string, not the contents. |
Excellent! Thanks for the help. I'm looking forward to seeing this. Having great syntax highlighting support for the C++ inside |
Following up on Vim support for this. I've done some research into foreign syntax regions, and managed to get something working, but it's clunky and it flashes when I move the cursor. I suspect it's due to the performance of the syn include @CPP syntax/cpp.vim
syn match jankNativeRawString +"\zs\_.\{-}\ze"+ contains=@CPP
syntax region jankNativeRaw matchgroup=Special start=+(native/raw+ end=+)+ contains=jankNativeRawString This is a good starting point for moving forward, but I wonder if this is complex enough to require semantic highlighting via LSP instead. Either way, if someone wants to pick this up and run with it, I'd love to get C++ highlighting for all of those functions. Of course, this doesn't support going back to Clojure with interpolation. |
Nice! What editor did you do that in? When I had it around that point in vim, with foreign syntax regions, it flickered whenever I moved around or edited text. Are you seeing that? |
I did it on Pulsar editor, it's a fork of Atom. I did with Injections on tree-sitter, basically it "injects" one language into another. In Clojure, a string usually is represented as All the magic happens on this PR: pulsar-edit/pulsar#729, but more specifically, on these lines: https://github.com/pulsar-edit/pulsar/pull/729/files#diff-ed2a3159c63d8f3c78945b50e99346ef08662b9107182d3db84b9be755bd581fR54-R61 As this is all a feature of the editor (injections are used everywhere, all the time) I don't experience any flicker really |
Oh, very cool! Great work. I'll add Pulsar to the list at the top of this thread and we can mark it off once everything's merged. |
IIUC, Neovim and Emacs do or will have ways to work with tree-sitter-clojure as-is:
We haven't reached a decision about whether to modify tree-sitter-clojure yet. Below are some of the bits we've been considering regarding this situation.
|
I don't know much about this jank project, at a glance it sounds very neat. Are there any new syntax constructs in jank that aren't present in Clojure apart of the interpolation in the native/raw strings? If there are we could consider supporting them in tree-sitter-clojure or perhaps a derivative of tree-sitter-clojure. |
This creates a new derived mode for the clojure dialect jank https://jank-lang.org/ See issue #23 for future work and jank-lang/jank#24 for the expressed desire to support nested c++
At this moment, no. jank is meant to be strongly Clojure[Script] source compatible and the only differences it should have will be around how it handles interop. For now, that's just via
That would be superb and I really appreciate the support. There are three primary things needed for strong
It's worth noting that these can nest infinitely, so Again, thanks for the interest here. A great developer tooling experience can make a language blossom just as much as a poor one can ensure it wilts. |
Jeaye Wilkerson ***@***.***> writes:
> Are there any new syntax constructs in jank that aren't present in Clojure apart of the interpolation in the native/raw strings?
At this moment, no. jank is meant to be strongly Clojure[Script] source compatible and the only
differences it should have will be around how it handles interop. For now, that's just via
`native/raw`, but it's possible that the syntax is later extended to more seamlessly support working
with C++. I don't foresee this happening in the coming few years, at least.
That simplifies things a lot. If it's plain old clojure syntax then the
current tree-sitter grammar will work fine. The native/raw construct is
still valid clojure syntax that the grammar won't have any trouble with
(it's parsed as a list, first element is a symbol, second is a string).
> If there are we could consider supporting them in tree-sitter-clojure or perhaps a derivative of tree-sitter-clojure.
That would be superb and I really appreciate the support. There are two primary things needed for strong `native/raw` support:
1. Highlighting the contents as C++ (and ideally getting LSP to work with the C++ here, too, understanding the scope of the expression)
2. Highlighting the interpolation as jank again (and ideally getting back to jank/Clojure LSP in there)
I don't think tree-sitter-clojure would need any changes to support
this. It could be done entirely in editor modes. I've defined a skeleton
`clojure-jank-ts-mode` in clojure-ts-mode as a start. Later on that
Emacs mode can be extended to have a c++ parser deal with the native/raw
strings like Maurício has already demonstrated. I don't have time to
delve into the c++ tree-sitter grammar immediately, but I'm curious to
see how it handles the escape sequences you use. If it doesn't deal with
them well a C++ grammar might need be forked to support it. All editors
with tree-sitter integration should be able to take advantage of that
though.
I've found that Emacs 29 has trouble with nested parsers. Emacs 30
should have better support for them. Any immediate work for these C++
strings in Emacs will need to be pretty simple. Other editors with more
mature tree-sitter integrations will probably fare better.
As for LSP, that is out of my area of expertise. I'm unsure how LSPs
typically handle nested languages like this. I'm sure there is prior art
that can be built upon in clojure-lsp, or inspiration for a new lsp that
uses clojure-lsp and something like clangd under the hood.
It's worth noting that these can nest infinitely, so `jank -> native/raw -> interpolation ->
native/raw -> interpolation` and so on is possible. This is a more pathological case, though, and I
don't think we'd want our happy path to be hindered to support this, if it came to that.
Javascript template strings allow for similar situations. I have no idea
how Emacs will handle this, but I suspect that having a nested parser
from clojure -> c++ then defining a second nested parser from c++
recursively back to the clojure parser will work. Either way I will see
about getting it working. If breaking back out from c++ to clojure
doesn't work well I'll bring it up in the Emacs mailing list. They will
run into something similar with JS template strings, so I think it would
be good to get it working for everyone.
Again, thanks for the interest here. A great developer tooling experience can make a language blossom just as much as a poor one can ensure it wilts.
Happy to help, this seems like a cool project.
…--
Danny Freeman
|
This creates a new derived mode for the clojure dialect jank https://jank-lang.org/ See issue clojure-emacs#23 for future work and jank-lang/jank#24 for the expressed desire to support nested c++
jank has support for a new special form, called
native/raw
. It works in place of Clojure's interop syntax and allows for inline C++. But it also support interpolating jank expressions into that C++. Docs on the rationale and final solution are here: https://github.com/jank-lang/jank/blob/main/DESIGN.md#interopRight now, all of this gets highlighted as a string, in vim/emacs/vscode, but the interpolated forms are Clojure code and should be highlighted accordingly. Ideally normal code completion, repl behavior, etc can work from within those forms, but we can take this one step at a time.
We may be able to make the syntax highlighting changes here in https://tree-sitter.github.io/tree-sitter/ and call it a day. But we might also consider getting into the vim/emacs/vscode configurations for Clojure and then forking them for jank to add this support. Would be your call on how to tackle this. I use vim and would love it to have this working, but we'll want great tooling for everyone, so might as well start with whatever you use.
The text was updated successfully, but these errors were encountered: