GNU bug report logs -
#77256
Treesit language-at-point
Previous Next
Reported by: Juri Linkov <juri <at> linkov.net>
Date: Tue, 25 Mar 2025 18:44:02 UTC
Severity: normal
Fixed in version 31.0.50
Done: Juri Linkov <juri <at> linkov.net>
Bug is archived. No further changes may be made.
Full log
Message #70 received at 77256 <at> debbugs.gnu.org (full text, mbox):
>>> Is it?
>>> I can't find any code out there that seems to care what is its default
>>> value (all users set it but doesn't look at it, AFAICT).
> The default value shouldn't matter. What’s the difference between
> a major-mode-set non-nil value and a default non-nil value?
No difference, in theory, indeed.
The problem is when code cares about the nil -vs- non-nil value of the variable.
>> This case looks problematic:
>>
>> ;; LANG can be nil. We don't want to use the fallback
>> ;; in `treesit-language-at', so here we call
>> ;; `treesit-language-at-point-function' directly.
>> (let* ((lang (and treesit-language-at-point-function
>> (funcall treesit-language-at-point-function
>> pos)))
>>
>> But I believe this whole 'let*' can be replaced by just
>> the 'treesit-parsers-at' call. I hope Yuan could confirm this.
>
> Why is this problematic?
Because the `and` treats `treesit-language-at-point-function` as
a boolean rather than as a function (and according to the comment, it
does so to avoid the default behavior, so if we set the var to a non-nil
value that provides the default behavior, it defeats the purpose of the
test).
But apparently, Juri's patch gets rid of this problem. 🙂
Stefan
This bug report was last modified 91 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.