I also think we're discussing some orthogonal issues here. Let's take things one step at a time - I'm open to discussing whatever concerns some people have about Flycheck and some form of collaboration with Flymake (e.g. common standard for checker definitions) down the road.
Thanks to Dmitry and Stefan for supporting the inclusion of Flycheck to NonGNU ELPA!
On 21/02/2024 19:00, Philip Kaludercic wrote:
>
>> On 20/02/2024 13:48, Philip Kaludercic wrote:
>>
>>> If Flycheck were to use the same interface as Flymake, then the
>>> situation would be better, as it would only be a different UI with
>>> perhaps some other priorities.
>>
>> Flycheck uses macros to define checkers and output parsers. Perhaps
>> one day those could expand to Flymake's functional interface under the
>> covers, but for that to happen, it would help a lot if we were more
>> welcoming.
>
> That is what flymake-collection is supposedly working on.
Should I point out that Flycheck's staying out of built-in ELPA sources
still didn't help Flymake grow a comparable library of checkers during
the years that passed?
Mohsin's efforts are commendable, but I don't think either will take
away from another. Because anyway, when writing a checker the hard[er]
part is determining which commands to use and with which arguments,
rather than the code that does it (which is normally fairly similar
between checkers). Porting them over in either direction is easy enough.
> No, but effort is wasted on developing incompatible backends. If
> Flycheck could take a similar route like Company in recommending to
> develop against the default/built-in interface (CAPF and Flymake
> respectively), then I really wouldn't mind having a second UI, but
> considering the misinformation that Flycheck still promote, I don't see
> any interest from their side to converge to a common denominator.
If there is wrong information in their public documentation or
statements, we definitely should ask them to issue corrections.
>> Note that when Xref was introduced, there were no existing protocols
>> out there, in third-party packages or not, that could be used for the
>> same purpose (abstraction over code navigation sources).
>
> True, but that only made it easier. If there had been some MELPA
> package called "jumpy" of whatever, then some packages would support
> xref, the others "jumpy", others again would have to try and support
> both. People would constantly be asking "what is the difference between
> xref and jumpy", and others again wouldn't notice xref at all because
> they assume that every feature in Emacs has to be installed via some
> external package.
Yes, people indeed ask questions. Just like they asked about the
difference between lsp-mode and eglot, and still continue to do so. That
did spur better competition for a time, with both sides playing catchup
in different aspects.
I don't see how anybody is going to stop asking about Flycheck vs
Flymake--they're still doing it now. And Flycheck has much better
visibility in the community anyway.
> This also reminds me of another point: Xref, Flymake, CAPF, ... are all
> interfaces, that don't have to bring with them implementations for all
> kinds of languages. That is the job of a major mode, and it is a lot
> more reasonable for a major mode to implement this interface, if
> provided by a core package, than if they had to use an third-party
> package that is not even part of GNU ELPA.
It's a good argument which would have probably worked better if the
difference in development speed and release frequency between core Emacs
and 3rd party packages weren't so big.
But we can still use it to encourage potential contributors to take up
the effort.
One of the handy bits that Flycheck has, though, it the provision of
several checkers for many of the languages. And (I think?) and interface
the switch between them. That might not fit the major-mode-hook model so
neatly; with Flymake, we usually limit ourselves to automatic detection
and failover.
>>> I know that there are differences, and I hope that the situation
>>> improves, but to mention another negative that probably disqualifies
>>> adding the package just on its own: `lsp-install-server'. The command
>>> can download arbitrary executable files as servers and runs them
>>> locally.
>>
>> curl can download arbitrary executable files, and it's still free
>> software. The question is which urls are pre-configured.
>
> The objection is not that lsp-mode is not free software, it is that it
> doesn't respect their users by downloading arbitrary binaries from the
> net and running them on their own machines, even if all the servers were
> free (which I don't know, I haven't checked all of them).
I'm pretty sure it only does that when asked. And if said software is
FLOSS, I don't see the problem--finding the sources is easy enough.
>> If we come to consider the inclusion of lsp-mode seriously (meaning,
>> there would be some interest from the maintainers), I'm happy to
>> discuss requesting that whatever proprietary servers are configured in
>> (I think there is 1 proprietary option for PHP among the total 4
>> available, not sure what else) are split off into separate packages
>> that we don't publish.
>
> My impression of the lsp-mode maintainers is that they have no interest
> in collaborating with core development.
Not at the moment, and there are pretty obvious factors playing into it.
But we should leave that door open.