From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.io!.POSTED.blaine.gmane.org!not-for-mail From: Daniel Colascione Newsgroups: gmane.emacs.devel Subject: Re: Tree-sitter maturity Date: Sun, 29 Dec 2024 10:21:19 -0500 Message-ID: <947A7DB0-43F7-4288-8FBF-0984FCFFAA93@dancol.org> References: <1ed88fca-788a-fe9f-b6c8-edb2f49751c9@mavit.org.uk> <67428b3d.c80a0220.2f3036.adbdSMTPIN_ADDED_BROKEN@mx.google.com> <86ldwdm7xg.fsf@gnu.org> <6765355b.c80a0220.1a6b24.3117SMTPIN_ADDED_BROKEN@mx.google.com> <00554790-CACA-4233-8846-9E091CF1F7AA@gmail.com> <86msgl2red.fsf@gnu.org> <87o710sr7y.fsf@debian-hx90.lan> <8734i9tmze.fsf@posteo.net> <86plldwb7w.fsf@gnu.org> <86h66pw4sd.fsf@gnu.org> <87ed1qedhl.fsf@> Mime-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable Injection-Info: ciao.gmane.io; posting-host="blaine.gmane.org:116.202.254.214"; logging-data="33275"; mail-complaints-to="usenet@ciao.gmane.io" User-Agent: K-9 Mail for Android Cc: Eli Zaretskii , emacs-devel@gnu.org, philipk@posteo.net, rms@gnu.org, manphiz@gmail.com To: =?ISO-8859-1?Q?Bj=F6rn_Bidar?= Original-X-From: emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org Sun Dec 29 16:22:04 2024 Return-path: Envelope-to: ged-emacs-devel@m.gmane-mx.org Original-Received: from lists.gnu.org ([209.51.188.17]) by ciao.gmane.io with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1tRv7D-0008Sf-NU for ged-emacs-devel@m.gmane-mx.org; Sun, 29 Dec 2024 16:22:04 +0100 Original-Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1tRv6l-00024h-KN; Sun, 29 Dec 2024 10:21:35 -0500 Original-Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1tRv6j-000248-2u for emacs-devel@gnu.org; Sun, 29 Dec 2024 10:21:33 -0500 Original-Received: from dancol.org ([2600:3c01:e000:3d8::1]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1tRv6g-0000bS-H4; Sun, 29 Dec 2024 10:21:32 -0500 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=dancol.org; s=x; h=Content-Transfer-Encoding:Content-Type:MIME-Version:Message-ID: References:In-Reply-To:Subject:CC:To:From:Date:Sender:Reply-To:Content-ID: Content-Description:Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc :Resent-Message-ID:List-Id:List-Help:List-Unsubscribe:List-Subscribe: List-Post:List-Owner:List-Archive; bh=Cp+tuAyEUHT6qhgKrrTeG2Y7N8Il1kHYK/MMYkKigks=; b=ax93Rvh7j1n5JE5MBdDa3YH/ia 4Xh/QEGQMds2HISo+bs/ymF5X1dqIerJUtRi4qbQ2SFSYHAlcDHbCvz2dzzVWIs4xQgYbj1rPXHIL HkcxdqZzF7s5P6/n9KBKYuNvbqTBKaLm2YDMwUY8ubdYjYmfXIbKtf5493IarIrM9nBW+7o+4Ubjs WKLMAjAaH9CD8SmpdMjTRRfDfFOrE/EbzVSDq4DPfISGfhY3bAZ0159DytOY1CRp+ETtmLrjqdA1F 4fAkbc68iYmWdXZ5HB9iYTKhtYFOP4z3GSrl6+lh5MAVSYihPlOA8jXlYr7aWoSSa1mYwMXX0IGSc j2B8YgAA==; Original-Received: from 2603-9001-4203-1ab2-8c81-c450-971b-d6ef.inf6.spectrum.com ([2603:9001:4203:1ab2:8c81:c450:971b:d6ef]:55030 helo=[IPv6:::1]) by dancol.org with esmtpsa (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 (Exim 4.96) (envelope-from ) id 1tRv6b-0007oT-17; Sun, 29 Dec 2024 10:21:25 -0500 In-Reply-To: <87ed1qedhl.fsf@> Received-SPF: pass client-ip=2600:3c01:e000:3d8::1; envelope-from=dancol@dancol.org; helo=dancol.org X-Spam_score_int: -20 X-Spam_score: -2.1 X-Spam_bar: -- X-Spam_report: (-2.1 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, SPF_HELO_PASS=-0.001, SPF_PASS=-0.001 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: emacs-devel@gnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: "Emacs development discussions." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org Original-Sender: emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org Xref: news.gmane.io gmane.emacs.devel:327347 Archived-At: On December 29, 2024 10:05:26 AM EST, "Bj=C3=B6rn Bidar" wrote: >Daniel Colascione writes: > >> On December 27, 2024 9:59:14 AM EST, Eli Zaretskii wro= te: >>>> Date: Fri, 27 Dec 2024 08:46:06 -0500 >>>> From: Daniel Colascione >>>> CC: rms@gnu=2Eorg, manphiz@gmail=2Ecom >>>>=20 >>>> >> It might take a while for that to happen, which is why I still bel= ieve >>>> >> it would be better if tree-sitter major modes would populate >>>> >> `treesit-language-source-alist' on their own, and point to the spe= cific >>>> >> checkouts that the major mode developer tested their implementatio= n >>>> >> against=2E >>>> > >>>> >We could have done that, but there's no way we could keep the value = of >>>> >treesit-language-source-alist up-to-date, because the grammar >>>> >libraries put out new versions much more frequently than Emacs >>>> >releases, especially if you consider libraries that have no official >>>> >versions at all (in which case we can only point to some revision in >>>> >their repository)=2E >>>> > >>>> >The question that bothers me is how useful is it to have >>>> >treesit-language-source-alist that is outdated? What do we expect t= he >>>> >users to do with such an outdated value? >>>> > >>>>=20 >>>> Why not just vendor all the grammars with the Emacs modes that use th= em? >>> >>>We'd need to ask their developers to agree to this=2E=20 >> >> Why? They're free software=2E For copyright assignment? Seems like an e= xception would make sense here=2E >> >>> Other than that, >>>I don't see how is that different from pointing to a specific version >>>of each grammar: both will be outdated a short time after we point to >>>the version or release Emacs with that version=2E >>> >>>So why do you think this is better? >> >> Vendoring enables building a full featured Emacs without a network conn= ection and guarantees build reproducibility in perpetuity=2E > >Did you think of the long term consequences? > >The embedded dependencies would have to be maintained first by Emacs and >later by packagers=2E > >All the infrastructure around syncing of grammars is time spend that >could spend on more long term efforts such as stabilizing the >tree-sitter based modes to not break as easy on grammar changes or to >improve tree-sitter it self=2E I've vendored plenty of things=2E Works fine in practice=2E Big programs l= ike Firefox vendor the world too, and they work fine=2E It's really not tha= t much work=2E It eliminates entire classes of problem=2E It's going to tak= e more time to deal with the problems of taking a dependency and the headac= hes of not having a stable interface than it would to set up a few git subt= rees or submodules and invoke their build system from that of Emacs=2E It's not even the precise mechanics: pulling down a grammar by hash is tan= tamount to just checking in the grammar, but with more moving parts=2E You = still pair one to one the grammar and the Lisp code meant to use it so you = don't end up chasing down weird compatibility issues=2E IMHO, since they're= tightly coupled anyway, we might as well distribute them together=2E As for changing TS grammars not to break: why do you think that would be f= easible? So far TS grammar authors haven't felt particularly obligated to m= aintain compatibility=2E