emacs-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: Adding Flycheck to NonGNU ELPA


From: Bozhidar Batsov
Subject: Re: Adding Flycheck to NonGNU ELPA
Date: Wed, 21 Feb 2024 22:24:57 +0100
User-agent: Cyrus-JMAP/3.11.0-alpha0-153-g7e3bb84806-fm-20240215.007-g7e3bb848

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 Wed, Feb 21, 2024, at 7:19 PM, Dmitry Gutov wrote:
On 21/02/2024 19:00, Philip Kaludercic wrote:
> Dmitry Gutov <dmitry@gutov.dev> writes:

>> 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.




reply via email to

[Prev in Thread] Current Thread [Next in Thread]