-
-
Notifications
You must be signed in to change notification settings - Fork 53
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
Implement find-usages #51
Comments
We may want to consider removing the |
This functionality is limited only to functions in loaded namespaces, but it still pretty handy. One notable problem that we should ideally solve is that `fdeps` doesn't track function dependencies in lambdas.
I've hacked together a simple prototype of the idea. It works pretty well IMO (especially compared to nothing), but it has one caveat -
Here
I'm not sure what exactly this filters, but it's certainly not public vars. I see that currently private function deps are part of the results. |
I wonder if the nested function ends up in a field in the outer function? |
I can only hope so. Haven't played much with this yet. |
It seems that the only reasonable way to get access to the lambdas would be to do a classpath search for the classes that they result in. Then we can get their fn object and get its dependencies. |
I think that in principle the "REBL approach" is too hacky, it relies on compiler internals, which not only are subject to change but also might make for a worse solution - essentially our solution would be limited by whatever the compiler can offer. If we needed an improvement, the compiler code is not something we can fork, and also any improvements could be as well rejected. There's the alternative of tools.analyzer, as refactor-nrepl's So that leaves clj-kondo as a viable option. I think it's a good investment: people are using clj-kondo / clojure-lsp because they 'just work' and false positives are rarer than one might think. I summarized my thinking / tentative intentions in clojure-lsp/clojure-lsp#658. I keep believing invoking clj-kondo from the same JVM that hosts the repl is a very nice hybrid, and one that I have used for a few years now. It also would be a pretty good thing for the community to consolidate the tooling landscape - less fragmented, with more manpower, and therefore higher-quality. |
In general I agree with the reasoning, but I also don't see the harm in having some find-usages implementation that's basic, but doesn't require any additional setup/tools. That's the main reason I wrote this basic implementation back in the day.
Yeah, I also thought it'd be a good idea to use clj-kondo from nREPL, but never got to doing work in this direction. |
Cognitect recently released a new version of REBL that has a find usages feature. @SevereOverfl0w asked Rich about the implementation and Rich was kind enough to share the crux of it:
Some notes from Rich:
So people have already been building cool things with that idea https://gist.github.com/vlaaad/0350b61e127e82165d195b490999ec0a
So, what we need to do now is add this to Orchard and then wrap it in CIDER nREPL. That should be pretty easy and have a huge impact for the end users.
The text was updated successfully, but these errors were encountered: