* bug#5852: 23.1; Incorrect references in ses-mode @ 2010-04-07 16:15 Göran Uddeborg 2020-02-29 3:14 ` Stefan Kangas 2024-01-14 13:17 ` Mattias Engdegård 0 siblings, 2 replies; 22+ messages in thread From: Göran Uddeborg @ 2010-04-07 16:15 UTC (permalink / raw) To: 5852 I discovered this when emacs sometimes complains that I have circular references in ses-mode files where there shouldn't be any. When investigating the ses file I've noticed some cells contain references that are incorrect. When I remove these incorrect references, the complaints about circular references go away, so I strongly suspect the problems are related. And even if I'm wrong, the incorrect references is a bug. While I haven't been able to create a simple test case where I get a circular reference complaint, I can easily get to a state where there are incorrect references. Create a ses file with these keystrokes: C-x C-f s . s e s <return> <tab> 1 <return> C-o 2 <return> <tab> <left> ( + SPC B 1 SPC A 2 <return> C-n C-o 3 <return> ( + SPC B 2 SPC A 3 <return> C-a C-o 4 <return> C-p C-SPC C-f M-w C-n C-b C-y C-n C-y C-x C-s In the resulting file, cell B2 has cell B4 incorrectly listed among its references: (ses-cell B2 3 (+ B1 A2) nil (B3 B4)) Only B3 does actually reference B2. In GNU Emacs 23.1.1 (x86_64-redhat-linux-gnu, GTK+ Version 2.18.3) of 2009-12-02 on x86-3.fedora.phx.redhat.com Windowing system distributor `Fedora Project', version 11.0.10705000 configured using `configure '--build=x86_64-redhat-linux-gnu' '--host=x86_64-redhat-linux-gnu' '--target=x86_64-redhat-linux-gnu' '--program-prefix=' '--prefix=/usr' '--exec-prefix=/usr' '--bindir=/usr/bin' '--sbindir=/usr/sbin' '--sysconfdir=/etc' '--datadir=/usr/share' '--includedir=/usr/include' '--libdir=/usr/lib64' '--libexecdir=/usr/libexec' '--localstatedir=/var' '--sharedstatedir=/var/lib' '--mandir=/usr/share/man' '--infodir=/usr/share/info' '--with-dbus' '--with-gif' '--with-jpeg' '--with-png' '--with-rsvg' '--with-tiff' '--with-xft' '--with-xpm' '--with-x-toolkit=gtk' 'build_alias=x86_64-redhat-linux-gnu' 'host_alias=x86_64-redhat-linux-gnu' 'target_alias=x86_64-redhat-linux-gnu' 'CFLAGS=-DMAIL_USE_LOCKF -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic'' Important settings: value of $LC_ALL: nil value of $LC_COLLATE: nil value of $LC_CTYPE: nil value of $LC_MESSAGES: nil value of $LC_MONETARY: nil value of $LC_NUMERIC: nil value of $LC_TIME: nil value of $LANG: sv_SE.utf8 value of $XMODIFIERS: nil locale-coding-system: utf-8-unix default-enable-multibyte-characters: t Major mode: SES Minor modes in effect: tooltip-mode: t tool-bar-mode: t mouse-wheel-mode: t menu-bar-mode: t file-name-shadow-mode: t global-font-lock-mode: t font-lock-mode: t blink-cursor-mode: t global-auto-composition-mode: t auto-composition-mode: t auto-encryption-mode: t auto-compression-mode: t line-number-mode: t transient-mark-mode: t Recent input: <tab> 1 <tab> <backspace> <return> C-o 2 <return> <tab> <left> ( + SPC B 1 SPC A 2 <return> <return> <return> C-n C-o 3 <return> ( + SPC B 2 SPC A 3 <return> C-n C-o C-p C-o 4 <return> C-p C-SPC C-f M-w C-n C-b C-y C-n C-y C-x C-s <help-echo> M-x r e p o r t - e m a c s - b u g <return> Recent messages: [2 times] Yanking...done Mark set Yanking...done [2 times] Yanking...done [2 times] Yanking...done Saving file /home/g=f6ran/x.ses... Wrote /home/g=f6ran/x.ses ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2010-04-07 16:15 bug#5852: 23.1; Incorrect references in ses-mode Göran Uddeborg @ 2020-02-29 3:14 ` Stefan Kangas 2020-02-29 20:13 ` Vincent Belaïche 2024-01-14 13:17 ` Mattias Engdegård 1 sibling, 1 reply; 22+ messages in thread From: Stefan Kangas @ 2020-02-29 3:14 UTC (permalink / raw) To: Vincent Belaïche; +Cc: Göran Uddeborg, 5852 Hi Vincent, Could you please take a look at the below bug report? It was reported in 2010, before you were listed as the maintainer of ses.el. Thanks in advance. Best regards, Stefan Kangas Göran Uddeborg <goeran@uddeborg.se> writes: > I discovered this when emacs sometimes complains that I have circular > references in ses-mode files where there shouldn't be any. When > investigating the ses file I've noticed some cells contain references > that are incorrect. When I remove these incorrect references, the > complaints about circular references go away, so I strongly suspect > the problems are related. And even if I'm wrong, the incorrect > references is a bug. > > While I haven't been able to create a simple test case where I get a > circular reference complaint, I can easily get to a state where there > are incorrect references. Create a ses file with these keystrokes: > > C-x C-f s . s e s <return> <tab> 1 <return> C-o 2 <return> > <tab> <left> ( + SPC B 1 SPC A 2 <return> > C-n C-o 3 <return> ( + SPC B 2 SPC A 3 <return> C-a > C-o 4 <return> C-p C-SPC C-f M-w C-n C-b C-y C-n C-y > C-x C-s > > In the resulting file, cell B2 has cell B4 incorrectly listed among > its references: > > (ses-cell B2 3 (+ B1 A2) nil (B3 B4)) > > Only B3 does actually reference B2. > > > In GNU Emacs 23.1.1 (x86_64-redhat-linux-gnu, GTK+ Version 2.18.3) > of 2009-12-02 on x86-3.fedora.phx.redhat.com > Windowing system distributor `Fedora Project', version 11.0.10705000 > configured using `configure '--build=x86_64-redhat-linux-gnu' '--host=x86_64-redhat-linux-gnu' '--target=x86_64-redhat-linux-gnu' '--program-prefix=' '--prefix=/usr' '--exec-prefix=/usr' '--bindir=/usr/bin' '--sbindir=/usr/sbin' '--sysconfdir=/etc' '--datadir=/usr/share' '--includedir=/usr/include' '--libdir=/usr/lib64' '--libexecdir=/usr/libexec' '--localstatedir=/var' '--sharedstatedir=/var/lib' '--mandir=/usr/share/man' '--infodir=/usr/share/info' '--with-dbus' '--with-gif' '--with-jpeg' '--with-png' '--with-rsvg' '--with-tiff' '--with-xft' '--with-xpm' '--with-x-toolkit=gtk' 'build_alias=x86_64-redhat-linux-gnu' 'host_alias=x86_64-redhat-linux-gnu' 'target_alias=x86_64-redhat-linux-gnu' 'CFLAGS=-DMAIL_USE_LOCKF -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic'' > > Important settings: > value of $LC_ALL: nil > value of $LC_COLLATE: nil > value of $LC_CTYPE: nil > value of $LC_MESSAGES: nil > value of $LC_MONETARY: nil > value of $LC_NUMERIC: nil > value of $LC_TIME: nil > value of $LANG: sv_SE.utf8 > value of $XMODIFIERS: nil > locale-coding-system: utf-8-unix > default-enable-multibyte-characters: t > > Major mode: SES > > Minor modes in effect: > tooltip-mode: t > tool-bar-mode: t > mouse-wheel-mode: t > menu-bar-mode: t > file-name-shadow-mode: t > global-font-lock-mode: t > font-lock-mode: t > blink-cursor-mode: t > global-auto-composition-mode: t > auto-composition-mode: t > auto-encryption-mode: t > auto-compression-mode: t > line-number-mode: t > transient-mark-mode: t > > Recent input: > <tab> 1 <tab> <backspace> <return> C-o 2 <return> <tab> > <left> ( + SPC B 1 SPC A 2 <return> <return> <return> > C-n C-o 3 <return> ( + SPC B 2 SPC A 3 <return> C-n > C-o C-p C-o 4 <return> C-p C-SPC C-f M-w C-n C-b C-y > C-n C-y C-x C-s <help-echo> M-x r e p o r t - e m a > c s - b u g <return> > > Recent messages: > [2 times] > Yanking...done > Mark set > Yanking...done > [2 times] > Yanking...done > [2 times] > Yanking...done > Saving file /home/g=f6ran/x.ses... > Wrote /home/g=f6ran/x.ses ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2020-02-29 3:14 ` Stefan Kangas @ 2020-02-29 20:13 ` Vincent Belaïche 2021-07-18 13:36 ` Lars Ingebrigtsen 0 siblings, 1 reply; 22+ messages in thread From: Vincent Belaïche @ 2020-02-29 20:13 UTC (permalink / raw) To: stefan; +Cc: Göran Uddeborg, 5852, Vincent Belaïche Dear Stefan and Güran, I confirm that the bug still exists, I followed the instructions by Güran and I reproduced the same result. Actually, after doing all these and typing: M-x ses-repair-cell-reference-all I get the following answer : --8<----8<----8<----8<----8<-- begin -->8---->8---->8---->8---->8---- Warning (emacs): ---------------------------------------------------------------- Some references were corrupted. The following is a list where each element ELT is such that (car ELT) is the reference of cell CELL with corruption, and (cdr ELT) is a property list where * property ‘:corrupt-property’ means that property ‘:ses-repair-reference’ of cell CELL was initially non nil, * property ‘:missing’ is a list of missing references * property ‘:irrelevant’ is a list of non needed references ((B2 :irrelevant (B4))) --8<----8<----8<----8<----8<-- end -->8---->8---->8---->8---->8---- This shows that the cut and paste can actually breaks the reference list in some cases. Please note that 'ses-repair-cell-reference-all' is the command that I added to SES after I became the maintainer in order to fix broken reference lists, as this can still happen if you type C-g during some cell editing post-commands. However I hadn't realized that even by normal editing (no C-g) you can get broken references. I will investigate why and feed back once I have a better idea of what is happening. VBR, Vincent. Le 29/02/2020 à 04:14, Stefan Kangas a écrit : > Hi Vincent, > > Could you please take a look at the below bug report? It was reported > in 2010, before you were listed as the maintainer of ses.el. > > Thanks in advance. > > Best regards, > Stefan Kangas > > > Göran Uddeborg <goeran@uddeborg.se> writes: > >> I discovered this when emacs sometimes complains that I have circular >> references in ses-mode files where there shouldn't be any. When >> investigating the ses file I've noticed some cells contain references >> that are incorrect. When I remove these incorrect references, the >> complaints about circular references go away, so I strongly suspect >> the problems are related. And even if I'm wrong, the incorrect >> references is a bug. >> >> While I haven't been able to create a simple test case where I get a >> circular reference complaint, I can easily get to a state where there >> are incorrect references. Create a ses file with these keystrokes: >> >> C-x C-f s . s e s <return> <tab> 1 <return> C-o 2 <return> >> <tab> <left> ( + SPC B 1 SPC A 2 <return> >> C-n C-o 3 <return> ( + SPC B 2 SPC A 3 <return> C-a >> C-o 4 <return> C-p C-SPC C-f M-w C-n C-b C-y C-n C-y >> C-x C-s >> >> In the resulting file, cell B2 has cell B4 incorrectly listed among >> its references: >> >> (ses-cell B2 3 (+ B1 A2) nil (B3 B4)) >> >> Only B3 does actually reference B2. >> >> >> In GNU Emacs 23.1.1 (x86_64-redhat-linux-gnu, GTK+ Version 2.18.3) >> of 2009-12-02 on x86-3.fedora.phx.redhat.com >> Windowing system distributor `Fedora Project', version 11.0.10705000 >> configured using `configure '--build=x86_64-redhat-linux-gnu' '--host=x86_64-redhat-linux-gnu' '--target=x86_64-redhat-linux-gnu' '--program-prefix=' '--prefix=/usr' '--exec-prefix=/usr' '--bindir=/usr/bin' '--sbindir=/usr/sbin' '--sysconfdir=/etc' '--datadir=/usr/share' '--includedir=/usr/include' '--libdir=/usr/lib64' '--libexecdir=/usr/libexec' '--localstatedir=/var' '--sharedstatedir=/var/lib' '--mandir=/usr/share/man' '--infodir=/usr/share/info' '--with-dbus' '--with-gif' '--with-jpeg' '--with-png' '--with-rsvg' '--with-tiff' '--with-xft' '--with-xpm' '--with-x-toolkit=gtk' 'build_alias=x86_64-redhat-linux-gnu' 'host_alias=x86_64-redhat-linux-gnu' 'target_alias=x86_64-redhat-linux-gnu' 'CFLAGS=-DMAIL_USE_LOCKF -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic'' >> >> Important settings: >> value of $LC_ALL: nil >> value of $LC_COLLATE: nil >> value of $LC_CTYPE: nil >> value of $LC_MESSAGES: nil >> value of $LC_MONETARY: nil >> value of $LC_NUMERIC: nil >> value of $LC_TIME: nil >> value of $LANG: sv_SE.utf8 >> value of $XMODIFIERS: nil >> locale-coding-system: utf-8-unix >> default-enable-multibyte-characters: t >> >> Major mode: SES >> >> Minor modes in effect: >> tooltip-mode: t >> tool-bar-mode: t >> mouse-wheel-mode: t >> menu-bar-mode: t >> file-name-shadow-mode: t >> global-font-lock-mode: t >> font-lock-mode: t >> blink-cursor-mode: t >> global-auto-composition-mode: t >> auto-composition-mode: t >> auto-encryption-mode: t >> auto-compression-mode: t >> line-number-mode: t >> transient-mark-mode: t >> >> Recent input: >> <tab> 1 <tab> <backspace> <return> C-o 2 <return> <tab> >> <left> ( + SPC B 1 SPC A 2 <return> <return> <return> >> C-n C-o 3 <return> ( + SPC B 2 SPC A 3 <return> C-n >> C-o C-p C-o 4 <return> C-p C-SPC C-f M-w C-n C-b C-y >> C-n C-y C-x C-s <help-echo> M-x r e p o r t - e m a >> c s - b u g <return> >> >> Recent messages: >> [2 times] >> Yanking...done >> Mark set >> Yanking...done >> [2 times] >> Yanking...done >> [2 times] >> Yanking...done >> Saving file /home/g=f6ran/x.ses... >> Wrote /home/g=f6ran/x.ses ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2020-02-29 20:13 ` Vincent Belaïche @ 2021-07-18 13:36 ` Lars Ingebrigtsen 2021-07-24 21:46 ` Vincent Belaïche 0 siblings, 1 reply; 22+ messages in thread From: Lars Ingebrigtsen @ 2021-07-18 13:36 UTC (permalink / raw) To: Vincent Belaïche Cc: stefan, 5852, Göran Uddeborg, Vincent Belaïche Vincent Belaïche <vincentbelaiche@orange.fr> writes: > I will investigate why and feed back once I have a better idea of what > is happening. Hi, this was a year ago. Did you make any progress on this issue? -- (domestic pets only, the antidote for overdose, milk.) bloggy blog: http://lars.ingebrigtsen.no ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2021-07-18 13:36 ` Lars Ingebrigtsen @ 2021-07-24 21:46 ` Vincent Belaïche 2021-07-25 5:48 ` Vincent Belaïche 0 siblings, 1 reply; 22+ messages in thread From: Vincent Belaïche @ 2021-07-24 21:46 UTC (permalink / raw) To: Lars Ingebrigtsen Cc: Stefan Kangas, Vincent Belaïche, 5852, Göran Uddeborg Hello Lars, Sorry for not making any feedback for so long, actually I was just distracted by some other business, and I somewhat had forgotten about it. I suspect a race condition between the post command hook and the next command. That is to say when one yanks the fomula (the first yank), one relocates the reference but for this one uses current references that have not yet been relocated because the previous post-command hook execution is not yet over. The bug does not show every time I do the experiment. I tried this morning with my office PC which is a fast machine, and it proved out quite hard to reproduce, even when I launched some big C program compilation in parallel to eat the mips. Next week I will do some experiment with my home PC which is quite quite slower, and I make some feedback. Unfortunateless both machine do not have the same emacs version, but anyway all changes in SES since the version on my home PC are not related to this bug, so nevertheless that will be a good indication whether my guess is correct. V. Le dim. 18 juil. 2021 à 15:37, Lars Ingebrigtsen <larsi@gnus.org> a écrit : > > Vincent Belaïche <vincentbelaiche@orange.fr> writes: > > > I will investigate why and feed back once I have a better idea of what > > is happening. > > Hi, > > this was a year ago. Did you make any progress on this issue? > > -- > (domestic pets only, the antidote for overdose, milk.) > bloggy blog: http://lars.ingebrigtsen.no ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2021-07-24 21:46 ` Vincent Belaïche @ 2021-07-25 5:48 ` Vincent Belaïche 2021-07-25 5:56 ` Vincent Belaïche 0 siblings, 1 reply; 22+ messages in thread From: Vincent Belaïche @ 2021-07-25 5:48 UTC (permalink / raw) To: Lars Ingebrigtsen Cc: Stefan Kangas, Vincent Belaïche, 5852, Göran Uddeborg Just to add something : reading again SES code, and (info "(elisp) Command Overview") I am a bit skeptical about the explanation in my previous email. It seems that only key strokes are queue, but command execution and post command hook are in sequence, so not done concurrently. I wrote this function to try to reproduce the bug, and on my office PC it does not reproduce it: (defun bug-5852 ();;--- "Check no irrelevant reference is created when a row is inserted and a formula is yanked" (interactive);;--- (let ((ses-initial-size '(3 . 3))) (with-temp-buffer (ses-mode) (dolist (val '( (ses-edit-cell 0 1 1) (ses-edit-cell 1 0 2) (ses-edit-cell 1 1 (+ B1 A2)) (ses-edit-cell 2 0 3) (ses-edit-cell 2 1 (+ B2 A3)) (ses-jump A3) (ses-insert-row 1) (ses-edit-cell 2 0 4) (ses-jump B2) )) (apply 'funcall-interactively val) (ses-command-hook)) (let ((beg (point-marker))) (ses-jump 'C2) ; C-n (copy-region-as-kill beg (point) nil) (set-marker beg nil)) (dolist (val '( (ses-jump B3) (yank) (ses-jump B4) (yank) )) (apply 'funcall-interactively val) (ses-command-hook)) (ses-repair-cell-reference-all) ))) Please note that the main difference with the provided example is that motion is done with ses-jump, and not with motion commands. Also the save to keyring is not done interatively. V. Le sam. 24 juil. 2021 à 23:46, Vincent Belaïche <vincent.belaiche@gmail.com> a écrit : > > Hello Lars, > > Sorry for not making any feedback for so long, actually I was just > distracted by some other business, and I somewhat had forgotten about > it. > > I suspect a race condition between the post command hook and the next > command. That is to say when one yanks the fomula (the first yank), > one relocates the reference but for this one uses current references > that have not yet been relocated because the previous post-command > hook execution is not yet over. > > The bug does not show every time I do the experiment. I tried this > morning with my office PC which is a fast machine, and it proved out > quite hard to reproduce, even when I launched some big C program > compilation in parallel to eat the mips. > > Next week I will do some experiment with my home PC which is quite > quite slower, and I make some feedback. Unfortunateless both machine > do not have the same emacs version, but anyway all changes in SES > since the version on my home PC are not related to this bug, so > nevertheless that will be a good indication whether my guess is > correct. > > V. > > Le dim. 18 juil. 2021 à 15:37, Lars Ingebrigtsen <larsi@gnus.org> a écrit : > > > > Vincent Belaïche <vincentbelaiche@orange.fr> writes: > > > > > I will investigate why and feed back once I have a better idea of what > > > is happening. > > > > Hi, > > > > this was a year ago. Did you make any progress on this issue? > > > > -- > > (domestic pets only, the antidote for overdose, milk.) > > bloggy blog: http://lars.ingebrigtsen.no ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2021-07-25 5:48 ` Vincent Belaïche @ 2021-07-25 5:56 ` Vincent Belaïche 2021-07-25 6:17 ` Vincent Belaïche 0 siblings, 1 reply; 22+ messages in thread From: Vincent Belaïche @ 2021-07-25 5:56 UTC (permalink / raw) To: Lars Ingebrigtsen Cc: Stefan Kangas, Vincent Belaïche, 5852, Göran Uddeborg On more significant difference between the function bug-5852 and the example is the the initial size is (3 . 3) instead of (1. 1). This is because I speculated that only the last row insertion (C-o) plays a role. V. Le dim. 25 juil. 2021 à 07:48, Vincent Belaïche <vincent.belaiche@gmail.com> a écrit : > > Just to add something : reading again SES code, and (info "(elisp) > Command Overview") I am a bit skeptical about the explanation in my > previous email. > It seems that only key strokes are queue, but command execution and > post command hook are in sequence, so not done concurrently. > I wrote this function to try to reproduce the bug, and on my office PC > it does not reproduce it: > > (defun bug-5852 ();;--- > "Check no irrelevant reference is created when a row is inserted and > a formula is yanked" > (interactive);;--- > (let ((ses-initial-size '(3 . 3))) > (with-temp-buffer > (ses-mode) > (dolist (val '( > (ses-edit-cell 0 1 1) > (ses-edit-cell 1 0 2) > (ses-edit-cell 1 1 (+ B1 A2)) > (ses-edit-cell 2 0 3) > (ses-edit-cell 2 1 (+ B2 A3)) > (ses-jump A3) > (ses-insert-row 1) > (ses-edit-cell 2 0 4) > (ses-jump B2) > )) > (apply 'funcall-interactively val) > (ses-command-hook)) > (let ((beg (point-marker))) > (ses-jump 'C2) ; C-n > (copy-region-as-kill beg (point) nil) > (set-marker beg nil)) > (dolist (val '( > (ses-jump B3) > (yank) > (ses-jump B4) > (yank) > )) > (apply 'funcall-interactively val) > (ses-command-hook)) > (ses-repair-cell-reference-all) > ))) > > Please note that the main difference with the provided example is that > motion is done with ses-jump, and not with motion commands. Also the > save to keyring is not done interatively. > V. > > Le sam. 24 juil. 2021 à 23:46, Vincent Belaïche > <vincent.belaiche@gmail.com> a écrit : > > > > Hello Lars, > > > > Sorry for not making any feedback for so long, actually I was just > > distracted by some other business, and I somewhat had forgotten about > > it. > > > > I suspect a race condition between the post command hook and the next > > command. That is to say when one yanks the fomula (the first yank), > > one relocates the reference but for this one uses current references > > that have not yet been relocated because the previous post-command > > hook execution is not yet over. > > > > The bug does not show every time I do the experiment. I tried this > > morning with my office PC which is a fast machine, and it proved out > > quite hard to reproduce, even when I launched some big C program > > compilation in parallel to eat the mips. > > > > Next week I will do some experiment with my home PC which is quite > > quite slower, and I make some feedback. Unfortunateless both machine > > do not have the same emacs version, but anyway all changes in SES > > since the version on my home PC are not related to this bug, so > > nevertheless that will be a good indication whether my guess is > > correct. > > > > V. > > > > Le dim. 18 juil. 2021 à 15:37, Lars Ingebrigtsen <larsi@gnus.org> a écrit : > > > > > > Vincent Belaïche <vincentbelaiche@orange.fr> writes: > > > > > > > I will investigate why and feed back once I have a better idea of what > > > > is happening. > > > > > > Hi, > > > > > > this was a year ago. Did you make any progress on this issue? > > > > > > -- > > > (domestic pets only, the antidote for overdose, milk.) > > > bloggy blog: http://lars.ingebrigtsen.no ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2021-07-25 5:56 ` Vincent Belaïche @ 2021-07-25 6:17 ` Vincent Belaïche 2021-07-25 6:18 ` Vincent Belaïche 0 siblings, 1 reply; 22+ messages in thread From: Vincent Belaïche @ 2021-07-25 6:17 UTC (permalink / raw) To: Lars Ingebrigtsen Cc: Stefan Kangas, Vincent Belaïche, 5852, Göran Uddeborg The same test function, but with comments : (defun bug-5852 ();;--- "Check no irrelevant reference is created when a row is inserted and a formula is yanked" (interactive);;--- (let ((ses-initial-size '(3 . 3))); size before last row insertion, due to all preceding TAB & C-o (with-temp-buffer (ses-mode) (dolist (val '( (ses-edit-cell 0 1 1) ; 1 RET (ses-edit-cell 1 0 2) ; 2 RET (ses-edit-cell 1 1 (+ B1 A2)) ; ( + SPC B1 SPC A2 RET (ses-edit-cell 2 0 3) ; 3 RET (ses-edit-cell 2 1 (+ B2 A3)) ; ( + SPC B2 SPC A3 RET (ses-jump A3) ; C-n (ses-insert-row 1) ; C-o (ses-edit-cell 2 0 4) ; 4 RET (ses-jump B2) ; C-p )) (apply 'funcall-interactively val) (ses-command-hook)) (let ((beg (point-marker))); C-SPC (ses-jump 'C2) ; C-f (copy-region-as-kill beg (point) nil); M-w (set-marker beg nil)) (dolist (val '( (ses-jump B3); C-n C-b (yank) ; C-y (ses-jump B4); C-n (yank); C-y )) (apply 'funcall-interactively val) (ses-command-hook)) (ses-repair-cell-reference-all) ))) Le dim. 25 juil. 2021 à 07:56, Vincent Belaïche <vincent.belaiche@gmail.com> a écrit : > > On more significant difference between the function bug-5852 and the > example is the the initial size is (3 . 3) instead of (1. 1). This is > because I speculated that only the last row insertion (C-o) plays a > role. > > V. > > Le dim. 25 juil. 2021 à 07:48, Vincent Belaïche > <vincent.belaiche@gmail.com> a écrit : > > > > Just to add something : reading again SES code, and (info "(elisp) > > Command Overview") I am a bit skeptical about the explanation in my > > previous email. > > It seems that only key strokes are queue, but command execution and > > post command hook are in sequence, so not done concurrently. > > I wrote this function to try to reproduce the bug, and on my office PC > > it does not reproduce it: > > > > (defun bug-5852 ();;--- > > "Check no irrelevant reference is created when a row is inserted and > > a formula is yanked" > > (interactive);;--- > > (let ((ses-initial-size '(3 . 3))) > > (with-temp-buffer > > (ses-mode) > > (dolist (val '( > > (ses-edit-cell 0 1 1) > > (ses-edit-cell 1 0 2) > > (ses-edit-cell 1 1 (+ B1 A2)) > > (ses-edit-cell 2 0 3) > > (ses-edit-cell 2 1 (+ B2 A3)) > > (ses-jump A3) > > (ses-insert-row 1) > > (ses-edit-cell 2 0 4) > > (ses-jump B2) > > )) > > (apply 'funcall-interactively val) > > (ses-command-hook)) > > (let ((beg (point-marker))) > > (ses-jump 'C2) ; C-n > > (copy-region-as-kill beg (point) nil) > > (set-marker beg nil)) > > (dolist (val '( > > (ses-jump B3) > > (yank) > > (ses-jump B4) > > (yank) > > )) > > (apply 'funcall-interactively val) > > (ses-command-hook)) > > (ses-repair-cell-reference-all) > > ))) > > > > Please note that the main difference with the provided example is that > > motion is done with ses-jump, and not with motion commands. Also the > > save to keyring is not done interatively. > > V. > > > > Le sam. 24 juil. 2021 à 23:46, Vincent Belaïche > > <vincent.belaiche@gmail.com> a écrit : > > > > > > Hello Lars, > > > > > > Sorry for not making any feedback for so long, actually I was just > > > distracted by some other business, and I somewhat had forgotten about > > > it. > > > > > > I suspect a race condition between the post command hook and the next > > > command. That is to say when one yanks the fomula (the first yank), > > > one relocates the reference but for this one uses current references > > > that have not yet been relocated because the previous post-command > > > hook execution is not yet over. > > > > > > The bug does not show every time I do the experiment. I tried this > > > morning with my office PC which is a fast machine, and it proved out > > > quite hard to reproduce, even when I launched some big C program > > > compilation in parallel to eat the mips. > > > > > > Next week I will do some experiment with my home PC which is quite > > > quite slower, and I make some feedback. Unfortunateless both machine > > > do not have the same emacs version, but anyway all changes in SES > > > since the version on my home PC are not related to this bug, so > > > nevertheless that will be a good indication whether my guess is > > > correct. > > > > > > V. > > > > > > Le dim. 18 juil. 2021 à 15:37, Lars Ingebrigtsen <larsi@gnus.org> a écrit : > > > > > > > > Vincent Belaïche <vincentbelaiche@orange.fr> writes: > > > > > > > > > I will investigate why and feed back once I have a better idea of what > > > > > is happening. > > > > > > > > Hi, > > > > > > > > this was a year ago. Did you make any progress on this issue? > > > > > > > > -- > > > > (domestic pets only, the antidote for overdose, milk.) > > > > bloggy blog: http://lars.ingebrigtsen.no ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2021-07-25 6:17 ` Vincent Belaïche @ 2021-07-25 6:18 ` Vincent Belaïche 2021-07-25 6:32 ` Vincent Belaïche 0 siblings, 1 reply; 22+ messages in thread From: Vincent Belaïche @ 2021-07-25 6:18 UTC (permalink / raw) To: Lars Ingebrigtsen Cc: Stefan Kangas, Vincent Belaïche, 5852, Göran Uddeborg The bug-5852 test function does not reproduce the bug on my home PC either … V. Le dim. 25 juil. 2021 à 08:17, Vincent Belaïche <vincent.belaiche@gmail.com> a écrit : > > The same test function, but with comments : > > > (defun bug-5852 ();;--- > "Check no irrelevant reference is created when a row is inserted and > a formula is yanked" > (interactive);;--- > (let ((ses-initial-size '(3 . 3))); size before last row insertion, > due to all preceding TAB & C-o > (with-temp-buffer > (ses-mode) > (dolist (val '( > (ses-edit-cell 0 1 1) ; 1 RET > (ses-edit-cell 1 0 2) ; 2 RET > (ses-edit-cell 1 1 (+ B1 A2)) ; ( + SPC B1 SPC A2 RET > (ses-edit-cell 2 0 3) ; 3 RET > (ses-edit-cell 2 1 (+ B2 A3)) ; ( + SPC B2 SPC A3 RET > (ses-jump A3) ; C-n > (ses-insert-row 1) ; C-o > (ses-edit-cell 2 0 4) ; 4 RET > (ses-jump B2) ; C-p > )) > (apply 'funcall-interactively val) > (ses-command-hook)) > (let ((beg (point-marker))); C-SPC > (ses-jump 'C2) ; C-f > (copy-region-as-kill beg (point) nil); M-w > (set-marker beg nil)) > (dolist (val '( > (ses-jump B3); C-n C-b > (yank) ; C-y > (ses-jump B4); C-n > (yank); C-y > )) > (apply 'funcall-interactively val) > (ses-command-hook)) > (ses-repair-cell-reference-all) > ))) > > Le dim. 25 juil. 2021 à 07:56, Vincent Belaïche > <vincent.belaiche@gmail.com> a écrit : > > > > On more significant difference between the function bug-5852 and the > > example is the the initial size is (3 . 3) instead of (1. 1). This is > > because I speculated that only the last row insertion (C-o) plays a > > role. > > > > V. > > > > Le dim. 25 juil. 2021 à 07:48, Vincent Belaïche > > <vincent.belaiche@gmail.com> a écrit : > > > > > > Just to add something : reading again SES code, and (info "(elisp) > > > Command Overview") I am a bit skeptical about the explanation in my > > > previous email. > > > It seems that only key strokes are queue, but command execution and > > > post command hook are in sequence, so not done concurrently. > > > I wrote this function to try to reproduce the bug, and on my office PC > > > it does not reproduce it: > > > > > > (defun bug-5852 ();;--- > > > "Check no irrelevant reference is created when a row is inserted and > > > a formula is yanked" > > > (interactive);;--- > > > (let ((ses-initial-size '(3 . 3))) > > > (with-temp-buffer > > > (ses-mode) > > > (dolist (val '( > > > (ses-edit-cell 0 1 1) > > > (ses-edit-cell 1 0 2) > > > (ses-edit-cell 1 1 (+ B1 A2)) > > > (ses-edit-cell 2 0 3) > > > (ses-edit-cell 2 1 (+ B2 A3)) > > > (ses-jump A3) > > > (ses-insert-row 1) > > > (ses-edit-cell 2 0 4) > > > (ses-jump B2) > > > )) > > > (apply 'funcall-interactively val) > > > (ses-command-hook)) > > > (let ((beg (point-marker))) > > > (ses-jump 'C2) ; C-n > > > (copy-region-as-kill beg (point) nil) > > > (set-marker beg nil)) > > > (dolist (val '( > > > (ses-jump B3) > > > (yank) > > > (ses-jump B4) > > > (yank) > > > )) > > > (apply 'funcall-interactively val) > > > (ses-command-hook)) > > > (ses-repair-cell-reference-all) > > > ))) > > > > > > Please note that the main difference with the provided example is that > > > motion is done with ses-jump, and not with motion commands. Also the > > > save to keyring is not done interatively. > > > V. > > > > > > Le sam. 24 juil. 2021 à 23:46, Vincent Belaïche > > > <vincent.belaiche@gmail.com> a écrit : > > > > > > > > Hello Lars, > > > > > > > > Sorry for not making any feedback for so long, actually I was just > > > > distracted by some other business, and I somewhat had forgotten about > > > > it. > > > > > > > > I suspect a race condition between the post command hook and the next > > > > command. That is to say when one yanks the fomula (the first yank), > > > > one relocates the reference but for this one uses current references > > > > that have not yet been relocated because the previous post-command > > > > hook execution is not yet over. > > > > > > > > The bug does not show every time I do the experiment. I tried this > > > > morning with my office PC which is a fast machine, and it proved out > > > > quite hard to reproduce, even when I launched some big C program > > > > compilation in parallel to eat the mips. > > > > > > > > Next week I will do some experiment with my home PC which is quite > > > > quite slower, and I make some feedback. Unfortunateless both machine > > > > do not have the same emacs version, but anyway all changes in SES > > > > since the version on my home PC are not related to this bug, so > > > > nevertheless that will be a good indication whether my guess is > > > > correct. > > > > > > > > V. > > > > > > > > Le dim. 18 juil. 2021 à 15:37, Lars Ingebrigtsen <larsi@gnus.org> a écrit : > > > > > > > > > > Vincent Belaïche <vincentbelaiche@orange.fr> writes: > > > > > > > > > > > I will investigate why and feed back once I have a better idea of what > > > > > > is happening. > > > > > > > > > > Hi, > > > > > > > > > > this was a year ago. Did you make any progress on this issue? > > > > > > > > > > -- > > > > > (domestic pets only, the antidote for overdose, milk.) > > > > > bloggy blog: http://lars.ingebrigtsen.no ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2021-07-25 6:18 ` Vincent Belaïche @ 2021-07-25 6:32 ` Vincent Belaïche 2021-07-25 6:38 ` Vincent Belaïche 0 siblings, 1 reply; 22+ messages in thread From: Vincent Belaïche @ 2021-07-25 6:32 UTC (permalink / raw) To: Lars Ingebrigtsen Cc: Stefan Kangas, Vincent Belaïche, 5852, Göran Uddeborg By doing the test manually on my home PC I found some interesting difference. After 2 RET on my home PC the cursor goes to the end of buffer narrowed region, while on my office PC it goes to B2. This means that the TAB that follows won't the same effect. On my home PC it creates a 3rd row, while on my office PC it creates the 3rd column. I found the reason why so : my home PC had some customization for the ses-after-entry-functions. After erasing customization I had the same behaviour … Anyway, that does not affect the bug-5852 test function as it only uses ses-jump for motion. V. Le dim. 25 juil. 2021 à 08:18, Vincent Belaïche <vincent.belaiche@gmail.com> a écrit : > > The bug-5852 test function does not reproduce the bug on my home PC either … > V. > > Le dim. 25 juil. 2021 à 08:17, Vincent Belaïche > <vincent.belaiche@gmail.com> a écrit : > > > > The same test function, but with comments : > > > > > > (defun bug-5852 ();;--- > > "Check no irrelevant reference is created when a row is inserted and > > a formula is yanked" > > (interactive);;--- > > (let ((ses-initial-size '(3 . 3))); size before last row insertion, > > due to all preceding TAB & C-o > > (with-temp-buffer > > (ses-mode) > > (dolist (val '( > > (ses-edit-cell 0 1 1) ; 1 RET > > (ses-edit-cell 1 0 2) ; 2 RET > > (ses-edit-cell 1 1 (+ B1 A2)) ; ( + SPC B1 SPC A2 RET > > (ses-edit-cell 2 0 3) ; 3 RET > > (ses-edit-cell 2 1 (+ B2 A3)) ; ( + SPC B2 SPC A3 RET > > (ses-jump A3) ; C-n > > (ses-insert-row 1) ; C-o > > (ses-edit-cell 2 0 4) ; 4 RET > > (ses-jump B2) ; C-p > > )) > > (apply 'funcall-interactively val) > > (ses-command-hook)) > > (let ((beg (point-marker))); C-SPC > > (ses-jump 'C2) ; C-f > > (copy-region-as-kill beg (point) nil); M-w > > (set-marker beg nil)) > > (dolist (val '( > > (ses-jump B3); C-n C-b > > (yank) ; C-y > > (ses-jump B4); C-n > > (yank); C-y > > )) > > (apply 'funcall-interactively val) > > (ses-command-hook)) > > (ses-repair-cell-reference-all) > > ))) > > > > Le dim. 25 juil. 2021 à 07:56, Vincent Belaïche > > <vincent.belaiche@gmail.com> a écrit : > > > > > > On more significant difference between the function bug-5852 and the > > > example is the the initial size is (3 . 3) instead of (1. 1). This is > > > because I speculated that only the last row insertion (C-o) plays a > > > role. > > > > > > V. > > > > > > Le dim. 25 juil. 2021 à 07:48, Vincent Belaïche > > > <vincent.belaiche@gmail.com> a écrit : > > > > > > > > Just to add something : reading again SES code, and (info "(elisp) > > > > Command Overview") I am a bit skeptical about the explanation in my > > > > previous email. > > > > It seems that only key strokes are queue, but command execution and > > > > post command hook are in sequence, so not done concurrently. > > > > I wrote this function to try to reproduce the bug, and on my office PC > > > > it does not reproduce it: > > > > > > > > (defun bug-5852 ();;--- > > > > "Check no irrelevant reference is created when a row is inserted and > > > > a formula is yanked" > > > > (interactive);;--- > > > > (let ((ses-initial-size '(3 . 3))) > > > > (with-temp-buffer > > > > (ses-mode) > > > > (dolist (val '( > > > > (ses-edit-cell 0 1 1) > > > > (ses-edit-cell 1 0 2) > > > > (ses-edit-cell 1 1 (+ B1 A2)) > > > > (ses-edit-cell 2 0 3) > > > > (ses-edit-cell 2 1 (+ B2 A3)) > > > > (ses-jump A3) > > > > (ses-insert-row 1) > > > > (ses-edit-cell 2 0 4) > > > > (ses-jump B2) > > > > )) > > > > (apply 'funcall-interactively val) > > > > (ses-command-hook)) > > > > (let ((beg (point-marker))) > > > > (ses-jump 'C2) ; C-n > > > > (copy-region-as-kill beg (point) nil) > > > > (set-marker beg nil)) > > > > (dolist (val '( > > > > (ses-jump B3) > > > > (yank) > > > > (ses-jump B4) > > > > (yank) > > > > )) > > > > (apply 'funcall-interactively val) > > > > (ses-command-hook)) > > > > (ses-repair-cell-reference-all) > > > > ))) > > > > > > > > Please note that the main difference with the provided example is that > > > > motion is done with ses-jump, and not with motion commands. Also the > > > > save to keyring is not done interatively. > > > > V. > > > > > > > > Le sam. 24 juil. 2021 à 23:46, Vincent Belaïche > > > > <vincent.belaiche@gmail.com> a écrit : > > > > > > > > > > Hello Lars, > > > > > > > > > > Sorry for not making any feedback for so long, actually I was just > > > > > distracted by some other business, and I somewhat had forgotten about > > > > > it. > > > > > > > > > > I suspect a race condition between the post command hook and the next > > > > > command. That is to say when one yanks the fomula (the first yank), > > > > > one relocates the reference but for this one uses current references > > > > > that have not yet been relocated because the previous post-command > > > > > hook execution is not yet over. > > > > > > > > > > The bug does not show every time I do the experiment. I tried this > > > > > morning with my office PC which is a fast machine, and it proved out > > > > > quite hard to reproduce, even when I launched some big C program > > > > > compilation in parallel to eat the mips. > > > > > > > > > > Next week I will do some experiment with my home PC which is quite > > > > > quite slower, and I make some feedback. Unfortunateless both machine > > > > > do not have the same emacs version, but anyway all changes in SES > > > > > since the version on my home PC are not related to this bug, so > > > > > nevertheless that will be a good indication whether my guess is > > > > > correct. > > > > > > > > > > V. > > > > > > > > > > Le dim. 18 juil. 2021 à 15:37, Lars Ingebrigtsen <larsi@gnus.org> a écrit : > > > > > > > > > > > > Vincent Belaïche <vincentbelaiche@orange.fr> writes: > > > > > > > > > > > > > I will investigate why and feed back once I have a better idea of what > > > > > > > is happening. > > > > > > > > > > > > Hi, > > > > > > > > > > > > this was a year ago. Did you make any progress on this issue? > > > > > > > > > > > > -- > > > > > > (domestic pets only, the antidote for overdose, milk.) > > > > > > bloggy blog: http://lars.ingebrigtsen.no ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2021-07-25 6:32 ` Vincent Belaïche @ 2021-07-25 6:38 ` Vincent Belaïche 2021-07-25 6:44 ` Lars Ingebrigtsen 0 siblings, 1 reply; 22+ messages in thread From: Vincent Belaïche @ 2021-07-25 6:38 UTC (permalink / raw) To: Lars Ingebrigtsen Cc: Stefan Kangas, Vincent Belaïche, 5852, Göran Uddeborg Just to say that I did the test manually on my home PC a couple of time, and I could not reproduce the problem. That is quite annoying, yesterday I reproduced it on my office PC once. V. Le dim. 25 juil. 2021 à 08:32, Vincent Belaïche <vincent.belaiche@gmail.com> a écrit : > > By doing the test manually on my home PC I found some interesting > difference. After > > 2 RET > > on my home PC the cursor goes to the end of buffer narrowed region, > while on my office PC it goes to B2. This means that the TAB that > follows won't the same effect. On my home PC it creates a 3rd row, > while on my office PC it creates the 3rd column. > I found the reason why so : my home PC had some customization for the > ses-after-entry-functions. After erasing customization I had the same > behaviour … > Anyway, that does not affect the bug-5852 test function as it only > uses ses-jump for motion. > V. > > Le dim. 25 juil. 2021 à 08:18, Vincent Belaïche > <vincent.belaiche@gmail.com> a écrit : > > > > The bug-5852 test function does not reproduce the bug on my home PC either … > > V. > > > > Le dim. 25 juil. 2021 à 08:17, Vincent Belaïche > > <vincent.belaiche@gmail.com> a écrit : > > > > > > The same test function, but with comments : > > > > > > > > > (defun bug-5852 ();;--- > > > "Check no irrelevant reference is created when a row is inserted and > > > a formula is yanked" > > > (interactive);;--- > > > (let ((ses-initial-size '(3 . 3))); size before last row insertion, > > > due to all preceding TAB & C-o > > > (with-temp-buffer > > > (ses-mode) > > > (dolist (val '( > > > (ses-edit-cell 0 1 1) ; 1 RET > > > (ses-edit-cell 1 0 2) ; 2 RET > > > (ses-edit-cell 1 1 (+ B1 A2)) ; ( + SPC B1 SPC A2 RET > > > (ses-edit-cell 2 0 3) ; 3 RET > > > (ses-edit-cell 2 1 (+ B2 A3)) ; ( + SPC B2 SPC A3 RET > > > (ses-jump A3) ; C-n > > > (ses-insert-row 1) ; C-o > > > (ses-edit-cell 2 0 4) ; 4 RET > > > (ses-jump B2) ; C-p > > > )) > > > (apply 'funcall-interactively val) > > > (ses-command-hook)) > > > (let ((beg (point-marker))); C-SPC > > > (ses-jump 'C2) ; C-f > > > (copy-region-as-kill beg (point) nil); M-w > > > (set-marker beg nil)) > > > (dolist (val '( > > > (ses-jump B3); C-n C-b > > > (yank) ; C-y > > > (ses-jump B4); C-n > > > (yank); C-y > > > )) > > > (apply 'funcall-interactively val) > > > (ses-command-hook)) > > > (ses-repair-cell-reference-all) > > > ))) > > > > > > Le dim. 25 juil. 2021 à 07:56, Vincent Belaïche > > > <vincent.belaiche@gmail.com> a écrit : > > > > > > > > On more significant difference between the function bug-5852 and the > > > > example is the the initial size is (3 . 3) instead of (1. 1). This is > > > > because I speculated that only the last row insertion (C-o) plays a > > > > role. > > > > > > > > V. > > > > > > > > Le dim. 25 juil. 2021 à 07:48, Vincent Belaïche > > > > <vincent.belaiche@gmail.com> a écrit : > > > > > > > > > > Just to add something : reading again SES code, and (info "(elisp) > > > > > Command Overview") I am a bit skeptical about the explanation in my > > > > > previous email. > > > > > It seems that only key strokes are queue, but command execution and > > > > > post command hook are in sequence, so not done concurrently. > > > > > I wrote this function to try to reproduce the bug, and on my office PC > > > > > it does not reproduce it: > > > > > > > > > > (defun bug-5852 ();;--- > > > > > "Check no irrelevant reference is created when a row is inserted and > > > > > a formula is yanked" > > > > > (interactive);;--- > > > > > (let ((ses-initial-size '(3 . 3))) > > > > > (with-temp-buffer > > > > > (ses-mode) > > > > > (dolist (val '( > > > > > (ses-edit-cell 0 1 1) > > > > > (ses-edit-cell 1 0 2) > > > > > (ses-edit-cell 1 1 (+ B1 A2)) > > > > > (ses-edit-cell 2 0 3) > > > > > (ses-edit-cell 2 1 (+ B2 A3)) > > > > > (ses-jump A3) > > > > > (ses-insert-row 1) > > > > > (ses-edit-cell 2 0 4) > > > > > (ses-jump B2) > > > > > )) > > > > > (apply 'funcall-interactively val) > > > > > (ses-command-hook)) > > > > > (let ((beg (point-marker))) > > > > > (ses-jump 'C2) ; C-n > > > > > (copy-region-as-kill beg (point) nil) > > > > > (set-marker beg nil)) > > > > > (dolist (val '( > > > > > (ses-jump B3) > > > > > (yank) > > > > > (ses-jump B4) > > > > > (yank) > > > > > )) > > > > > (apply 'funcall-interactively val) > > > > > (ses-command-hook)) > > > > > (ses-repair-cell-reference-all) > > > > > ))) > > > > > > > > > > Please note that the main difference with the provided example is that > > > > > motion is done with ses-jump, and not with motion commands. Also the > > > > > save to keyring is not done interatively. > > > > > V. > > > > > > > > > > Le sam. 24 juil. 2021 à 23:46, Vincent Belaïche > > > > > <vincent.belaiche@gmail.com> a écrit : > > > > > > > > > > > > Hello Lars, > > > > > > > > > > > > Sorry for not making any feedback for so long, actually I was just > > > > > > distracted by some other business, and I somewhat had forgotten about > > > > > > it. > > > > > > > > > > > > I suspect a race condition between the post command hook and the next > > > > > > command. That is to say when one yanks the fomula (the first yank), > > > > > > one relocates the reference but for this one uses current references > > > > > > that have not yet been relocated because the previous post-command > > > > > > hook execution is not yet over. > > > > > > > > > > > > The bug does not show every time I do the experiment. I tried this > > > > > > morning with my office PC which is a fast machine, and it proved out > > > > > > quite hard to reproduce, even when I launched some big C program > > > > > > compilation in parallel to eat the mips. > > > > > > > > > > > > Next week I will do some experiment with my home PC which is quite > > > > > > quite slower, and I make some feedback. Unfortunateless both machine > > > > > > do not have the same emacs version, but anyway all changes in SES > > > > > > since the version on my home PC are not related to this bug, so > > > > > > nevertheless that will be a good indication whether my guess is > > > > > > correct. > > > > > > > > > > > > V. > > > > > > > > > > > > Le dim. 18 juil. 2021 à 15:37, Lars Ingebrigtsen <larsi@gnus.org> a écrit : > > > > > > > > > > > > > > Vincent Belaïche <vincentbelaiche@orange.fr> writes: > > > > > > > > > > > > > > > I will investigate why and feed back once I have a better idea of what > > > > > > > > is happening. > > > > > > > > > > > > > > Hi, > > > > > > > > > > > > > > this was a year ago. Did you make any progress on this issue? > > > > > > > > > > > > > > -- > > > > > > > (domestic pets only, the antidote for overdose, milk.) > > > > > > > bloggy blog: http://lars.ingebrigtsen.no ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2021-07-25 6:38 ` Vincent Belaïche @ 2021-07-25 6:44 ` Lars Ingebrigtsen 2021-07-25 17:27 ` Vincent Belaïche 2023-12-29 12:03 ` Vincent Belaïche 0 siblings, 2 replies; 22+ messages in thread From: Lars Ingebrigtsen @ 2021-07-25 6:44 UTC (permalink / raw) To: Vincent Belaïche Cc: 5852, Vincent Belaïche, Stefan Kangas, Göran Uddeborg Vincent Belaïche <vincent.belaiche@gmail.com> writes: > Just to say that I did the test manually on my home PC a couple of > time, and I could not reproduce the problem. > That is quite annoying, yesterday I reproduced it on my office PC once. Yeah, timing dependent bugs are really annoying to try to debug.. -- (domestic pets only, the antidote for overdose, milk.) bloggy blog: http://lars.ingebrigtsen.no ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2021-07-25 6:44 ` Lars Ingebrigtsen @ 2021-07-25 17:27 ` Vincent Belaïche 2021-07-30 21:01 ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors 2023-12-29 12:03 ` Vincent Belaïche 1 sibling, 1 reply; 22+ messages in thread From: Vincent Belaïche @ 2021-07-25 17:27 UTC (permalink / raw) To: Lars Ingebrigtsen, Stefan Monnier Cc: 5852, Vincent Belaïche, Stefan Kangas, Göran Uddeborg Dear Stefan (Monnier), I am calling to your deep knowledge of Emacs internals. We have a bug which seems to be real time dependant, which makes me think that there is some race condition somewhere. I think it can't be any race between the command and the post-command hook, because they are run sequentially in the command loop : post-command hook of command N does not overlap command N+1, please confirm … Now, I have another speculation : SES gets the current cell from the cursor position by reading some buffer text property 'cursor-intangible. I speculate that the radix of the bug is that when a command sets this cursor property, then the buffer is actually modified in the backgroun, and the change may not be yet in effect when the next command runs. Could you confirm / infirm this speculation. One more thing is the following : in SES the cursor-intangile property is the symbol corresponding to the cell object (which under the hood is a vector), not the cell object itself. This means that the property has to change when there are row/column insertion / deletion, which also inherently change the buffer, because of symbol relocation. I think this might be some bad design choice, and pointing directly at the cell object would have saved some troubles (and probably would also create a bunch of other problems, so do not take my statement for sure). Of course the idea of using symbols makes sense as they make it easy for the formulas, and as such some sort of relocation is unavoidable. On the other hand, the cell index (say (0 0) for A1, (0 1) for B1, (1 0) for A2, etc…), is retrieved from a property of the cell symbol, so things are a bit intricate … Vincent. Le dim. 25 juil. 2021 à 08:44, Lars Ingebrigtsen <larsi@gnus.org> a écrit : > > Vincent Belaïche <vincent.belaiche@gmail.com> writes: > > > Just to say that I did the test manually on my home PC a couple of > > time, and I could not reproduce the problem. > > That is quite annoying, yesterday I reproduced it on my office PC once. > > Yeah, timing dependent bugs are really annoying to try to debug.. > > -- > (domestic pets only, the antidote for overdose, milk.) > bloggy blog: http://lars.ingebrigtsen.no ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2021-07-25 17:27 ` Vincent Belaïche @ 2021-07-30 21:01 ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors 2021-08-02 21:02 ` Vincent Belaïche 0 siblings, 1 reply; 22+ messages in thread From: Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2021-07-30 21:01 UTC (permalink / raw) To: Vincent Belaïche Cc: Stefan Kangas, Lars Ingebrigtsen, Vincent Belaïche, 5852, Göran Uddeborg > are run sequentially in the command loop : post-command hook of > command N does not overlap command N+1, please confirm … That's usually true, yes. There can be exceptions when command N itself can run commands during execution, via a recursive command-loop (e.g. query&replace uses that, or minibuffer interactions). > Now, I have another speculation : SES gets the current cell from the > cursor position by reading some buffer text property > 'cursor-intangible. I speculate that the radix of the bug is that when > a command sets this cursor property, then the buffer is actually > modified in the backgroun, and the change may not be yet in effect > when the next command runs. Could you confirm / infirm this > speculation. Hmm... no that doesn't sound right. Emacs does try to do a few things in the background, but it's quite limited (things like `font-lock`, basically). When a property like `cursor-intangible` is set, it happens immediately. > One more thing is the following : in SES the cursor-intangile property > is the symbol corresponding to the cell object (which under the hood > is a vector), not the cell object itself. This means that the property > has to change when there are row/column insertion / deletion, which > also inherently change the buffer, because of symbol relocation. I > think this might be some bad design choice, and pointing directly at > the cell object would have saved some troubles (and probably would > also create a bunch of other problems, so do not take my statement for > sure). Indeed, pointing directly at the cell's vector would probably be better (at least from the point of view of insertions/deletions but), but if so, each cell would probably need to contain its own name (or its coordinates). Stefan ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2021-07-30 21:01 ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2021-08-02 21:02 ` Vincent Belaïche 0 siblings, 0 replies; 22+ messages in thread From: Vincent Belaïche @ 2021-08-02 21:02 UTC (permalink / raw) To: Stefan Monnier Cc: 5852, Lars Ingebrigtsen, Stefan Kangas, Göran Uddeborg Thank you for the feedback, I am afraid I will need to work again at it, in order to create a systematic bug reporduction. [...] > > One more thing is the following : in SES the cursor-intangile property > > is the symbol corresponding to the cell object (which under the hood > > is a vector), not the cell object itself. This means that the property > > has to change when there are row/column insertion / deletion, which > > also inherently change the buffer, because of symbol relocation. I > > think this might be some bad design choice, and pointing directly at > > the cell object would have saved some troubles (and probably would > > also create a bunch of other problems, so do not take my statement for > > sure). > > Indeed, pointing directly at the cell's vector would probably be better > (at least from the point of view of insertions/deletions but), but if > so, each cell would probably need to contain its own name (or its > coordinates). > > > Stefan > What you wrote confirms my gut feeling. I came to this conclusion as I was thinking how to implement functions such as row transposition. FYI, AFAIK, the cell already contains the corresponding symbol, and the (row, col) coordinates can be derived from the symbol through the ses-cell symbol property. V. ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2021-07-25 6:44 ` Lars Ingebrigtsen 2021-07-25 17:27 ` Vincent Belaïche @ 2023-12-29 12:03 ` Vincent Belaïche 2023-12-29 12:36 ` Stefan Kangas 2023-12-29 22:01 ` Göran Uddeborg 1 sibling, 2 replies; 22+ messages in thread From: Vincent Belaïche @ 2023-12-29 12:03 UTC (permalink / raw) To: Lars Ingebrigtsen, Stefan Kangas Cc: Göran Uddeborg, Vincent Belaïche, 5852 Dear all, I am _very very_ glad to a announce that I have fixed bug#5852 ! I just pushed the fix to master now. Thank you again to Göran for the report, without which this would not have been impossible. The bug was only loosely time dependent. What happened is that the data area update is deferred on the command hook, if I try to reproduce the bug by doing some kdb macro, it seems that the command hook is not called in between the two yanks, and this hides the bug. That was my mistake during my first investigation. Translating the manual to French helped me be more aware of all the arcanes of SES. The root cause of the bug has nothing to do with copy/cut/paste, it was far deeper, the formula setting function was bugged, as it did not registered cells the reference list of which is changed by the formula setting as needing rewrite to the data area ! It was hard to realized where the bug was, because the data structures in memory was OK, but there was a discrepancy between the data areay and the data structures, so the bugs only gets manifest when you reload a sheet --- or as in the new test if you call ses-mode again. So as long as you do not reload a sheet everything is OK. @Stefan Kangas is there any record book for longest lived bugs, maybe I can get a prize for this 13 years old bug, unless Richard has left some bug form the 1970 or so version of Emacs :-P ? Happy end of year to you all ! Vincent. Le dim. 25 juil. 2021 à 08:44, Lars Ingebrigtsen <larsi@gnus.org> a écrit : > > Vincent Belaïche <vincent.belaiche@gmail.com> writes: > > > Just to say that I did the test manually on my home PC a couple of > > time, and I could not reproduce the problem. > > That is quite annoying, yesterday I reproduced it on my office PC once. > > Yeah, timing dependent bugs are really annoying to try to debug.. > > -- > (domestic pets only, the antidote for overdose, milk.) > bloggy blog: http://lars.ingebrigtsen.no ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2023-12-29 12:03 ` Vincent Belaïche @ 2023-12-29 12:36 ` Stefan Kangas 2023-12-29 14:19 ` Eli Zaretskii 2023-12-29 22:01 ` Göran Uddeborg 1 sibling, 1 reply; 22+ messages in thread From: Stefan Kangas @ 2023-12-29 12:36 UTC (permalink / raw) To: Vincent Belaïche, Lars Ingebrigtsen Cc: Göran Uddeborg, Vincent Belaïche, 5852 Vincent Belaïche <vincent.belaiche@gmail.com> writes: > I am _very very_ glad to a announce that I have fixed bug#5852 ! I > just pushed the fix to master now. > > Thank you again to Göran for the report, without which this would not > have been impossible. Thanks for fixing this old bug, and congratulations! > @Stefan Kangas is there any record book for longest lived bugs, maybe > I can get a prize for this 13 years old bug, unless Richard has left > some bug form the 1970 or so version of Emacs :-P ? No one is keeping track really, but it's not too hard to dig out some information from git log (grep for "Bug#[0-9][0-9][0-9][0-9]?[^0-9])". AFAICT, the current record holder is Mauro Aranda with his fix for Bug#2807 back in October (or possibly his fix for Bug#997). Our bug tracker only goes back to 2008 or so though, while some bugs have been around for 30 or 40 years without being recorded there. It's harder to search for those fixes in the git logs, though. ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2023-12-29 12:36 ` Stefan Kangas @ 2023-12-29 14:19 ` Eli Zaretskii 2023-12-29 15:19 ` Vincent Belaïche 0 siblings, 1 reply; 22+ messages in thread From: Eli Zaretskii @ 2023-12-29 14:19 UTC (permalink / raw) To: Stefan Kangas; +Cc: 5852, larsi, goeran, vincent.b.1, vincent.belaiche > Cc: Göran Uddeborg <goeran@uddeborg.se>, > Vincent Belaïche <vincent.b.1@hotmail.fr>, > 5852@debbugs.gnu.org > From: Stefan Kangas <stefankangas@gmail.com> > Date: Fri, 29 Dec 2023 04:36:03 -0800 > > Vincent Belaïche <vincent.belaiche@gmail.com> writes: > > > @Stefan Kangas is there any record book for longest lived bugs, maybe > > I can get a prize for this 13 years old bug, unless Richard has left > > some bug form the 1970 or so version of Emacs :-P ? > > No one is keeping track really, but it's not too hard to dig out some > information from git log (grep for "Bug#[0-9][0-9][0-9][0-9]?[^0-9])". > > AFAICT, the current record holder is Mauro Aranda with his fix for > Bug#2807 back in October (or possibly his fix for Bug#997). My personal record is bug#24064: a 22-year old bug. Followed closely by bug#64253 (a 21-year old bug), bug#31829 (a 16-year old bug), and bug#56219 (a 15-year old bug). ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2023-12-29 14:19 ` Eli Zaretskii @ 2023-12-29 15:19 ` Vincent Belaïche 0 siblings, 0 replies; 22+ messages in thread From: Vincent Belaïche @ 2023-12-29 15:19 UTC (permalink / raw) To: Eli Zaretskii, Stefan Kangas Cc: 5852@debbugs.gnu.org, larsi@gnus.org, goeran@uddeborg.se, vincent.belaiche@gmail.com [-- Attachment #1: Type: text/plain, Size: 1879 bytes --] Hello, Thank you for the feedback and congratulations for your own records ! I forgot to mention this : to repair any existing spreadsheet made prior to the bugfix, the procedure is as follows : * M-x ses-repair-cell-reference-all will fix all the reference lists in the in-memory data structures * C-c C-l will recompute the whole spreadsheet, which will cause the data area to be completely rewritten After these two commands, your spreadsheet is bug#5852-neat. V. ________________________________ De : Eli Zaretskii <eliz@gnu.org> Envoyé : vendredi 29 décembre 2023 15:19 À : Stefan Kangas <stefankangas@gmail.com> Cc : vincent.belaiche@gmail.com <vincent.belaiche@gmail.com>; larsi@gnus.org <larsi@gnus.org>; goeran@uddeborg.se <goeran@uddeborg.se>; vincent.b.1@hotmail.fr <vincent.b.1@hotmail.fr>; 5852@debbugs.gnu.org <5852@debbugs.gnu.org> Objet : Re: bug#5852: 23.1; Incorrect references in ses-mode > Cc: Göran Uddeborg <goeran@uddeborg.se>, > Vincent Belaïche <vincent.b.1@hotmail.fr>, > 5852@debbugs.gnu.org > From: Stefan Kangas <stefankangas@gmail.com> > Date: Fri, 29 Dec 2023 04:36:03 -0800 > > Vincent Belaïche <vincent.belaiche@gmail.com> writes: > > > @Stefan Kangas is there any record book for longest lived bugs, maybe > > I can get a prize for this 13 years old bug, unless Richard has left > > some bug form the 1970 or so version of Emacs :-P ? > > No one is keeping track really, but it's not too hard to dig out some > information from git log (grep for "Bug#[0-9][0-9][0-9][0-9]?[^0-9])". > > AFAICT, the current record holder is Mauro Aranda with his fix for > Bug#2807 back in October (or possibly his fix for Bug#997). My personal record is bug#24064: a 22-year old bug. Followed closely by bug#64253 (a 21-year old bug), bug#31829 (a 16-year old bug), and bug#56219 (a 15-year old bug). [-- Attachment #2: Type: text/html, Size: 4570 bytes --] ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2023-12-29 12:03 ` Vincent Belaïche 2023-12-29 12:36 ` Stefan Kangas @ 2023-12-29 22:01 ` Göran Uddeborg 1 sibling, 0 replies; 22+ messages in thread From: Göran Uddeborg @ 2023-12-29 22:01 UTC (permalink / raw) To: Vincent Belaïche Cc: 5852, Lars Ingebrigtsen, Stefan Kangas, Vincent Belaïche Thanks a lot Vincent and everyone else for putting all those efforts into finding this bug! Now I'm looking forward to Emacs 30! ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2010-04-07 16:15 bug#5852: 23.1; Incorrect references in ses-mode Göran Uddeborg 2020-02-29 3:14 ` Stefan Kangas @ 2024-01-14 13:17 ` Mattias Engdegård 2024-01-14 13:35 ` Mattias Engdegård 1 sibling, 1 reply; 22+ messages in thread From: Mattias Engdegård @ 2024-01-14 13:17 UTC (permalink / raw) To: vincent.belaiche Cc: goeran, Vincent Belaïche, 5852, Eli Zaretskii, Stefan Kangas Some test problems fixed in 139037f8; please verify. ^ permalink raw reply [flat|nested] 22+ messages in thread
* bug#5852: 23.1; Incorrect references in ses-mode 2024-01-14 13:17 ` Mattias Engdegård @ 2024-01-14 13:35 ` Mattias Engdegård 0 siblings, 0 replies; 22+ messages in thread From: Mattias Engdegård @ 2024-01-14 13:35 UTC (permalink / raw) To: vincent.belaiche Cc: goeran, Vincent Belaïche, 5852, Eli Zaretskii, Stefan Kangas > Some test problems fixed in 139037f8; please verify. That should be a83e60ec, sorry. ^ permalink raw reply [flat|nested] 22+ messages in thread
end of thread, other threads:[~2024-01-14 13:35 UTC | newest] Thread overview: 22+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2010-04-07 16:15 bug#5852: 23.1; Incorrect references in ses-mode Göran Uddeborg 2020-02-29 3:14 ` Stefan Kangas 2020-02-29 20:13 ` Vincent Belaïche 2021-07-18 13:36 ` Lars Ingebrigtsen 2021-07-24 21:46 ` Vincent Belaïche 2021-07-25 5:48 ` Vincent Belaïche 2021-07-25 5:56 ` Vincent Belaïche 2021-07-25 6:17 ` Vincent Belaïche 2021-07-25 6:18 ` Vincent Belaïche 2021-07-25 6:32 ` Vincent Belaïche 2021-07-25 6:38 ` Vincent Belaïche 2021-07-25 6:44 ` Lars Ingebrigtsen 2021-07-25 17:27 ` Vincent Belaïche 2021-07-30 21:01 ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors 2021-08-02 21:02 ` Vincent Belaïche 2023-12-29 12:03 ` Vincent Belaïche 2023-12-29 12:36 ` Stefan Kangas 2023-12-29 14:19 ` Eli Zaretskii 2023-12-29 15:19 ` Vincent Belaïche 2023-12-29 22:01 ` Göran Uddeborg 2024-01-14 13:17 ` Mattias Engdegård 2024-01-14 13:35 ` Mattias Engdegård
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).