* bug#74890: 31.0.50; (thing-at-point 'string) raises error
@ 2024-12-15 8:27 Jean Louis
[not found] ` <handler.74890.B.17342851868303.ack@debbugs.gnu.org>
2024-12-15 18:31 ` bug#74890: 31.0.50; (thing-at-point 'string) raises error Eli Zaretskii
0 siblings, 2 replies; 7+ messages in thread
From: Jean Louis @ 2024-12-15 8:27 UTC (permalink / raw)
To: 74890
I can see that I cannot run (thing-at-point 'string) safely, though I
cannot exactly determine the condition.
In the buffer I have only this:
Hello
which is string "Hello" and when I place cursor behind "o" and run
(thing-at-point 'string) I am getting the backtrace below. But if I make
one space like "Hello " and place cursor on that empty space in the
buffer, I am getting NIL and no error. Though I cannot repeat this with
emacs -Q and thus I do not know why is this happening exactly.
I think that (eq (char-syntax (char-after)) 34) cannot read the char
which is not there "after".
Backtrace:
Debugger entered--Lisp error: (wrong-type-argument characterp nil)
char-syntax(nil)
(eq (char-syntax (char-after)) 34)
(not (eq (char-syntax (char-after)) 34))
(if (not (eq (char-syntax (char-after)) 34)) (setq syntax (syntax-ppss)) (or (progn (forward-char) (setq syntax (syntax-ppss)) (nth 3 syntax)) (progn (forward-char (- (or nil 1))) (setq syntax (syntax-ppss)) (nth 3 syntax))))
(let (syntax beg end) (if (not (eq (char-syntax (char-after)) 34)) (setq syntax (syntax-ppss)) (or (progn (forward-char) (setq syntax (syntax-ppss)) (nth 3 syntax)) (progn (forward-char (- (or nil 1))) (setq syntax (syntax-ppss)) (nth 3 syntax)))) (and (nth 3 syntax) (condition-case nil (progn (setq beg (nth 8 syntax)) (setq end (progn (goto-char (nth 8 syntax)) (forward-sexp) (point)))) (error nil)) (cons beg end)))
(save-excursion (let (syntax beg end) (if (not (eq (char-syntax (char-after)) 34)) (setq syntax (syntax-ppss)) (or (progn (forward-char) (setq syntax (syntax-ppss)) (nth 3 syntax)) (progn (forward-char (- (or nil 1))) (setq syntax (syntax-ppss)) (nth 3 syntax)))) (and (nth 3 syntax) (condition-case nil (progn (setq beg (nth 8 syntax)) (setq end (progn (goto-char ...) (forward-sexp) (point)))) (error nil)) (cons beg end))))
tap-bounds-of-string-at-point()
(let ((bounds (tap-bounds-of-string-at-point))) (and bounds (buffer-substring (car bounds) (cdr bounds))))
tap-string-at-point()
funcall(tap-string-at-point)
(prog1 (funcall thing-fn) (constrain-to-field nil opoint))
(let* ((opoint (point)) (thg (prog1 (funcall thing-fn) (constrain-to-field nil opoint)))) thg)
(if thing-fn (let* ((opoint (point)) (thg (prog1 (funcall thing-fn) (constrain-to-field nil opoint)))) thg) (let ((bounds (tap-bounds-of-thing-at-point thing syntax-table))) (and bounds (buffer-substring (car bounds) (cdr bounds)))))
(let* ((thing-fn (or (get thing 'tap-thing-at-point) (get thing 'thing-at-point))) (something (if thing-fn (let* ((opoint (point)) (thg (prog1 ... ...))) thg) (let ((bounds (tap-bounds-of-thing-at-point thing syntax-table))) (and bounds (buffer-substring (car bounds) (cdr bounds))))))) (if (and (stringp something) no-properties) (progn (set-text-properties 0 (length something) nil something))) something)
thing-at-point(string)
eval((thing-at-point 'string) t)
#f(compiled-function () #<bytecode 0x15ba1ac9559f7d5d>)()
#f(compiled-function () #<bytecode -0x5db3e1955cb81d1>)()
eval-expression((thing-at-point 'string) nil nil 127)
funcall-interactively(eval-expression (thing-at-point 'string) nil nil 127)
command-execute(eval-expression)
In GNU Emacs 31.0.50 (build 4, x86_64-pc-linux-gnu, GTK+ Version
3.24.38, cairo version 1.16.0) of 2024-12-05 built on lco2
Repository revision: 25b4bf7fcd75564f23b2e60e29e8ff7354186371
Repository branch: master
Windowing system distributor 'The X.Org Foundation', version 11.0.12101007
System Description: Debian GNU/Linux 12 (bookworm)
Configured using:
'configure --with-mailutils --with-native-compilation=yes
--with-tree-sitter --with-imagemagick'
Configured features:
ACL CAIRO DBUS FREETYPE GIF GLIB GMP GNUTLS GSETTINGS HARFBUZZ
IMAGEMAGICK JPEG LCMS2 LIBSELINUX LIBXML2 MODULES NATIVE_COMP NOTIFY
INOTIFY PDUMPER PNG RSVG SECCOMP SOUND SQLITE3 THREADS TIFF
TOOLKIT_SCROLL_BARS TREE_SITTER WEBP X11 XDBE XIM XINPUT2 XPM GTK3 ZLIB
Important settings:
value of $LC_ALL: en_US.UTF-8
value of $LANG: de_DE.UTF-8
value of $XMODIFIERS: @im=exwm-xim
locale-coding-system: utf-8-unix
Major mode: Lisp Interaction
Minor modes in effect:
tooltip-mode: t
global-eldoc-mode: t
eldoc-mode: t
show-paren-mode: t
electric-indent-mode: t
mouse-wheel-mode: t
tool-bar-mode: t
menu-bar-mode: t
file-name-shadow-mode: t
global-font-lock-mode: t
font-lock-mode: t
blink-cursor-mode: t
minibuffer-regexp-mode: t
line-number-mode: t
indent-tabs-mode: t
transient-mark-mode: t
auto-composition-mode: t
auto-encryption-mode: t
auto-compression-mode: t
Load-path shadows:
None found.
Features:
(shadow sort mail-extr emacsbug message mailcap yank-media puny dired
dired-loaddefs rfc822 mml mml-sec password-cache epa derived epg rfc6068
epg-config gnus-util text-property-search time-date subr-x mm-decode
mm-bodies mm-encode mail-parse rfc2231 mailabbrev gmm-utils mailheader
cl-loaddefs cl-lib sendmail rfc2047 rfc2045 ietf-drums mm-util
mail-prsvr mail-utils rmc iso-transl tooltip cconv eldoc paren electric
uniquify ediff-hook vc-hooks lisp-float-type elisp-mode mwheel
term/x-win x-win term/common-win x-dnd touch-screen tool-bar dnd fontset
image regexp-opt fringe tabulated-list replace newcomment text-mode
lisp-mode prog-mode register page tab-bar menu-bar rfn-eshadow isearch
easymenu timer select scroll-bar mouse jit-lock font-lock syntax
font-core term/tty-colors frame minibuffer nadvice seq simple cl-generic
indonesian philippine cham georgian utf-8-lang misc-lang vietnamese
tibetan thai tai-viet lao korean japanese eucjp-ms cp51932 hebrew greek
romanian slovak czech european ethiopic indian cyrillic chinese
composite emoji-zwj charscript charprop case-table epa-hook
jka-cmpr-hook help abbrev obarray oclosure cl-preloaded button loaddefs
theme-loaddefs faces cus-face macroexp files window text-properties
overlay sha1 md5 base64 format env code-pages mule custom widget keymap
hashtable-print-readable backquote threads dbusbind inotify lcms2
dynamic-setting system-font-setting font-render-setting cairo gtk
x-toolkit xinput2 x multi-tty move-toolbar make-network-process
native-compile emacs)
Memory information:
((conses 16 49894 11144) (symbols 48 5434 0) (strings 32 14122 1285)
(string-bytes 1 414224) (vectors 16 9179)
(vector-slots 8 129869 10829) (floats 8 22 2) (intervals 56 247 8)
(buffers 992 11))
--
Jean
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#74890: Acknowledgement (31.0.50; (thing-at-point 'string) raises error)
[not found] ` <handler.74890.B.17342851868303.ack@debbugs.gnu.org>
@ 2024-12-15 18:12 ` Jean Louis
2024-12-15 20:44 ` Stefan Kangas
0 siblings, 1 reply; 7+ messages in thread
From: Jean Louis @ 2024-12-15 18:12 UTC (permalink / raw)
To: 74890; +Cc: Drew Adams
Now I realized that this bug is related to Drew's thingatpt+ as when I turned it off, the bug did not appear again.
Drew, do you maybe know how to improve this?
Jean Louis
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#74890: 31.0.50; (thing-at-point 'string) raises error
2024-12-15 8:27 bug#74890: 31.0.50; (thing-at-point 'string) raises error Jean Louis
[not found] ` <handler.74890.B.17342851868303.ack@debbugs.gnu.org>
@ 2024-12-15 18:31 ` Eli Zaretskii
2024-12-15 22:10 ` Jean Louis
1 sibling, 1 reply; 7+ messages in thread
From: Eli Zaretskii @ 2024-12-15 18:31 UTC (permalink / raw)
To: Jean Louis; +Cc: 74890
> From: Jean Louis <bugs@gnu.support>
> Date: Sun, 15 Dec 2024 11:27:24 +0300
>
>
> I can see that I cannot run (thing-at-point 'string) safely, though I
> cannot exactly determine the condition.
>
> In the buffer I have only this:
>
> Hello
>
> which is string "Hello" and when I place cursor behind "o" and run
> (thing-at-point 'string) I am getting the backtrace below. But if I make
> one space like "Hello " and place cursor on that empty space in the
> buffer, I am getting NIL and no error. Though I cannot repeat this with
> emacs -Q and thus I do not know why is this happening exactly.
>
> I think that (eq (char-syntax (char-after)) 34) cannot read the char
> which is not there "after".
>
> Backtrace:
>
> Debugger entered--Lisp error: (wrong-type-argument characterp nil)
> char-syntax(nil)
> (eq (char-syntax (char-after)) 34)
Please show a complete recipe, preferably starting from "emacs -Q". I
tried to reproduce this problem, but couldn't, which probably means
some special steps are required to see it.
I also don't understand your claims about "char after", because
there's always something "after" point.
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#74890: Acknowledgement (31.0.50; (thing-at-point 'string) raises error)
2024-12-15 18:12 ` bug#74890: Acknowledgement (31.0.50; (thing-at-point 'string) raises error) Jean Louis
@ 2024-12-15 20:44 ` Stefan Kangas
0 siblings, 0 replies; 7+ messages in thread
From: Stefan Kangas @ 2024-12-15 20:44 UTC (permalink / raw)
To: Jean Louis, 74890-done; +Cc: Drew Adams
Jean Louis <bugs@gnu.support> writes:
> Now I realized that this bug is related to Drew's thingatpt+ as when I
> turned it off, the bug did not appear again.
Thanks, since this bug is not about Emacs, I'm closing it now.
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#74890: 31.0.50; (thing-at-point 'string) raises error
2024-12-15 18:31 ` bug#74890: 31.0.50; (thing-at-point 'string) raises error Eli Zaretskii
@ 2024-12-15 22:10 ` Jean Louis
2024-12-16 0:49 ` Drew Adams via Bug reports for GNU Emacs, the Swiss army knife of text editors
0 siblings, 1 reply; 7+ messages in thread
From: Jean Louis @ 2024-12-15 22:10 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: 74890
* Eli Zaretskii <eliz@gnu.org> [2024-12-15 21:32]:
> > Debugger entered--Lisp error: (wrong-type-argument characterp nil)
> > char-syntax(nil)
> > (eq (char-syntax (char-after)) 34)
>
> Please show a complete recipe, preferably starting from "emacs -Q". I
> tried to reproduce this problem, but couldn't, which probably means
> some special steps are required to see it.
>
> I also don't understand your claims about "char after", because
> there's always something "after" point.
When I removed loading of Drew's thingatpt+ I could not observe this problem anymore.
I just think it is related to function from that library `tap-bounds-of-string-at-point'
Jean
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#74890: 31.0.50; (thing-at-point 'string) raises error
2024-12-15 22:10 ` Jean Louis
@ 2024-12-16 0:49 ` Drew Adams via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-12-16 6:12 ` Jean Louis
0 siblings, 1 reply; 7+ messages in thread
From: Drew Adams via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2024-12-16 0:49 UTC (permalink / raw)
To: Jean Louis, Eli Zaretskii; +Cc: 74890@debbugs.gnu.org
> > > Debugger entered--Lisp error: (wrong-type-argument characterp nil)
> > > char-syntax(nil)
> > > (eq (char-syntax (char-after)) 34)
> >
> > Please show a complete recipe, preferably starting from "emacs -Q". I
> > tried to reproduce this problem, but couldn't, which probably means
> > some special steps are required to see it.
> >
> > I also don't understand your claims about "char after", because
> > there's always something "after" point.
No, there's _not_ always something (some text) after
point. And that, I think, is what this report is about.
From Jean's description, the only text in the buffer is
`Hello', where that `o' char is the last char, and
point is _after_, not on/at, that `o'.
> When I removed loading of Drew's thingatpt+ I could not observe this
> problem anymore.
>
> I just think it is related to function from that library `tap-bounds-of-
> string-at-point'
Hi Jean,
I see the same thing with `emacs -Q' for Emacs 29.4,
which is the latest Emacs release AFAIK:
Debugger entered--Lisp error: (wrong-type-argument characterp nil)
thing-at-point-bounds-of-string-at-point()
bounds-of-thing-at-point(string)
thing-at-point(string)
eval-expression((thing-at-point 'string) nil nil 127)
funcall-interactively(eval-expression (thing-at-point 'string) nil nil 127)
command-execute(eval-expression)
To me, this behavior makes sense since, per your recipe,
there's _no character_ at point, and for thing-at-point
to tell whether or not _the buffer text at point_
represents a given type of thing or not there must at
least be a char at point!
(You'll get the same error if you try thing-at-point
in an empty buffer - no char at point to test. I see
that too with Emacs 29.4.)
An alternative behavior - incorrect/poorer IMO - could
conceivably be to return nil. But to me (and to vanilla
Emacs -Q for all releases I know of), that would be
claiming that _there's text at point_ that does not
represent such a thing.
Your Emacs bug #74890 says you're using an Emacs 31
development version. Emacs 30 hasn't even been released
yet! The bleeding edge bleeds, and I'm hoping Emacs 31's
current failure to raise an error in this context is an
ephemeral bug that'll be fixed before release. (This is a
regression - a backward-incompatible change. But it may
be intentional.)
If _released_ Emacs 31 thing-at-point changes the behavior
to instead return nil, then I'll have to decide whether to
follow suit. My feeling, for now at least, is that that's
poor behavior (a bug). And if I go with that feeling then
at most I'll perhaps provide an option to give users such
(misguided) behavior if they so choose.
To me, it's important that thing-at-point be usable _not_
just to grab some text at point to use as a default value
but - more importantly, if less commonly - to test whether
there's a given type of thing at point, i.e., for
_conditional/filtering_ behavior. With such an outlook I
think it's important for the testing to be doable and done
on (duh!) text, i.e., a character at point.
That such filtering behavior is important to me is also
why my code returns nil when just _after_ a thing (not
on/at a thing).
One day, vanilla Emacs opted to return a thing that's just
before, not at point. I disagreed with that change when
it was made, but was overruled. I think it's due to a
shortsighted opinion that the only use for thing-at-point
is to grab some text for use as a default value - not _at_
point, but _near_ point. For that use case thingatpt+.el
provides different functions: *-near[est]-point. Those
functions let you specify what you mean by "near".
When you can repro the bug with `thingatpt+.el', but not
`emacs -Q', in an actual Emacs release (e.g. 31), please
send me a mail with a recipe to repro it. Thx.
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#74890: 31.0.50; (thing-at-point 'string) raises error
2024-12-16 0:49 ` Drew Adams via Bug reports for GNU Emacs, the Swiss army knife of text editors
@ 2024-12-16 6:12 ` Jean Louis
0 siblings, 0 replies; 7+ messages in thread
From: Jean Louis @ 2024-12-16 6:12 UTC (permalink / raw)
To: Drew Adams; +Cc: 74890
* Drew Adams <drew.adams@oracle.com> [2024-12-16 03:49]:
> > > > Debugger entered--Lisp error: (wrong-type-argument characterp nil)
> > > > char-syntax(nil)
> > > > (eq (char-syntax (char-after)) 34)
> > >
> > > Please show a complete recipe, preferably starting from "emacs -Q". I
> > > tried to reproduce this problem, but couldn't, which probably means
> > > some special steps are required to see it.
> > >
> > > I also don't understand your claims about "char after", because
> > > there's always something "after" point.
>
> No, there's _not_ always something (some text) after
> point. And that, I think, is what this report is about.
> From Jean's description, the only text in the buffer is
> `Hello', where that `o' char is the last char, and
> point is _after_, not on/at, that `o'.
That is right.
> I see the same thing with `emacs -Q' for Emacs 29.4,
> which is the latest Emacs release AFAIK:
>
> Debugger entered--Lisp error: (wrong-type-argument characterp nil)
> thing-at-point-bounds-of-string-at-point()
> bounds-of-thing-at-point(string)
> thing-at-point(string)
> eval-expression((thing-at-point 'string) nil nil 127)
> funcall-interactively(eval-expression (thing-at-point 'string) nil nil 127)
> command-execute(eval-expression)
I do not have error in default Emacs with -Q with this version:
GNU Emacs 31.0.50 (build 4, x86_64-pc-linux-gnu, GTK+ Version 3.24.38, cairo version 1.16.0) of 2024-12-05
> To me, this behavior makes sense since, per your recipe,
> there's _no character_ at point, and for thing-at-point
> to tell whether or not _the buffer text at point_
> represents a given type of thing or not there must at
> least be a char at point!
I am used to have silent thing-at-point, so I do not expect any
error. I expect the thing to be there or not, as that is how I am
testing it with my functions. Errors shall be handled with underlying
functions IMHO.
> (You'll get the same error if you try thing-at-point
> in an empty buffer - no char at point to test. I see
> that too with Emacs 29.4.)
Not on 31.0.50 as I have just tried it.
Or maybe you mean with your library?
> An alternative behavior - incorrect/poorer IMO - could
> conceivably be to return nil. But to me (and to vanilla
> Emacs -Q for all releases I know of), that would be
> claiming that _there's text at point_ that does not
> represent such a thing.
If the function tests for thing to be "text at point", then yes.
Otherwise, no, as function is testing for something specific, in my
case it was (thing-at-point 'string) where by the default function
without thingatpt+.el does work, and with thingatpt+.el loaded, it
raises errors.
> Your Emacs bug #74890 says you're using an Emacs 31
> development version. Emacs 30 hasn't even been released
> yet!
Yes of course, the bug is reported for that version, not earlier.
> The bleeding edge bleeds, and I'm hoping Emacs 31's current failure
> to raise an error in this context is an ephemeral bug that'll be
> fixed before release. (This is a regression - a
> backward-incompatible change. But it may be intentional.)
I don't see how that should be bug, and it is actually only raising
error with thingatpt+.el loaded.
(thing-at-point 'string) should give me string or nil
Not error.
I am testing for string, I am not testing if there is text under the
point.
> If _released_ Emacs 31 thing-at-point changes the behavior
> to instead return nil, then I'll have to decide whether to
> follow suit. My feeling, for now at least, is that that's
> poor behavior (a bug). And if I go with that feeling then
> at most I'll perhaps provide an option to give users such
> (misguided) behavior if they so choose.
I am expecting you to understand, I am testing with various functions
`thing-at-point' for specifics, if there is no text, that means that
specific is not there, and why should I get error as user of the function?
It is not error if something is not found!
So the underlying function shall be silently handled for the function
user.
I have been using thingatpt+.el for last 2 years basically, it
remained silent until this special case was discovered, as I was
improving the action button M-RET which verifies many different
things at point.
> To me, it's important that thing-at-point be usable _not_
> just to grab some text at point to use as a default value
> but - more importantly, if less commonly - to test whether
> there's a given type of thing at point, i.e., for
> _conditional/filtering_ behavior. With such an outlook I
> think it's important for the testing to be doable and done
> on (duh!) text, i.e., a character at point.
It is usable as long as underlying functions do well.
(thing-at-point 'url) will find URL, and not number for example or
UUID.
So if there is no URL or no UUID, one need not raise errors.
I hope you will come to same thinking.
> That such filtering behavior is important to me is also
> why my code returns nil when just _after_ a thing (not
> on/at a thing).
That is fine approach to me.
> When you can repro the bug with `thingatpt+.el', but not
> `emacs -Q', in an actual Emacs release (e.g. 31), please
> send me a mail with a recipe to repro it. Thx.
$ emacs -Q
- open empty buffer C-x b akjsndjansjkdn
- evaluate (thing-at-point 'string) and it will return NIL
- I am moving to directory Drew Adams and then evalute:
(add-to-list 'load-path (expand-file-name "."))
- then evaluate (thing-at-point 'string) and it will raise error
--
Jean Louis
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2024-12-16 6:12 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-12-15 8:27 bug#74890: 31.0.50; (thing-at-point 'string) raises error Jean Louis
[not found] ` <handler.74890.B.17342851868303.ack@debbugs.gnu.org>
2024-12-15 18:12 ` bug#74890: Acknowledgement (31.0.50; (thing-at-point 'string) raises error) Jean Louis
2024-12-15 20:44 ` Stefan Kangas
2024-12-15 18:31 ` bug#74890: 31.0.50; (thing-at-point 'string) raises error Eli Zaretskii
2024-12-15 22:10 ` Jean Louis
2024-12-16 0:49 ` Drew Adams via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-12-16 6:12 ` Jean Louis
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).