unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#33890: 27.0.50; Incorrect behaviour of cl-loop macro
@ 2018-12-27  9:28 Quek Yu Han
  2018-12-31  6:22 ` Glenn Morris
  0 siblings, 1 reply; 2+ messages in thread
From: Quek Yu Han @ 2018-12-27  9:28 UTC (permalink / raw)
  To: 33890

It appears that a change to the `cl-loop` macro in Emacs 27 introduced a
bug where certain clauses would be evaluated more than once in a loop
with a "when" clause.

See the following minimal example which finds the index of an element in
a list:


(cl-loop
 for x in '(a b c d e)
 for index = 0 then (1+ index)
 when (eq x 'e)
 return index)


In Emacs 26.1 this returns `4` as expected, but in Emacs 27.0.50 it
returns `7`, due to the index being incremented twice per loop. The same
occurs after a `emacs -Q` restart.

For reference here is the macroexpanded form of the above expression,
with the difference between 26 and 27 outlined (everything else is
identical):


(cl-block nil
  (let* ((--cl-var-- '(a b c d e))
         (x nil)
         (index nil)
         (--cl-var-- t)
         (--cl-var-- t)
         --cl-var--)
    (while (and (consp --cl-var--)
                (progn
                  (setq x (car --cl-var--))
                  (setq index
                        (if --cl-var-- 0 (1+ index)))
                  (if (eq x 'e)
                      (setq --cl-var-- index
                            --cl-var-- nil)
                    t)))
      (setq --cl-var-- (cdr --cl-var--))

;;;============== ADDED IN EMACS 27 =================
      (and (and (consp --cl-var--)
                (progn
                  (setq x (car --cl-var--))
                  (setq index
                        (if --cl-var-- 0 (1+ index)))
                  (if (eq x 'e)
                      (setq --cl-var-- index
                            --cl-var-- nil)
                    t))))
;;;==================================================

      (setq --cl-var-- nil))
    --cl-var--))



Thanks!





In GNU Emacs 27.0.50 (build 1, x86_64-apple-darwin17.6.0, NS
appkit-1561.40 Version 10.13.5 (Build 17F77))
 of 2018-07-08 built on QYH.local
Repository revision: 98463bed07ecc9057094928ffdc2321eaaf3ab52
Windowing system distributor 'Apple', version 10.3.1671
System Description:  Mac OS X 10.14.2

Recent messages:
For information about GNU Emacs and the GNU system, type C-h C-a.

Configured using:
 'configure --disable-dependency-tracking --disable-silent-rules
 --enable-locallisppath=/usr/local/share/emacs/site-lisp
 --infodir=/usr/local/Cellar/emacs-plus/HEAD-98463be/share/info/emacs
 --prefix=/usr/local/Cellar/emacs-plus/HEAD-98463be --with-xml2
 --without-dbus --with-gnutls --with-imagemagick --with-modules
 --with-rsvg --with-xwidgets --with-ns --disable-ns-self-contained'

Configured features:
RSVG IMAGEMAGICK NOTIFY ACL GNUTLS LIBXML2 ZLIB TOOLKIT_SCROLL_BARS NS
MODULES THREADS XWIDGETS LCMS2

Important settings:
  value of $LC_ALL: en_US.UTF-8
  value of $LC_CTYPE: UTF-8
  value of $LANG: en_US.UTF-8
  locale-coding-system: utf-8-unix

Major mode: Lisp Interaction

Minor modes in effect:
  tooltip-mode: t
  global-eldoc-mode: t
  eldoc-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
  auto-composition-mode: t
  auto-encryption-mode: t
  auto-compression-mode: t
  line-number-mode: t
  transient-mark-mode: t

Load-path shadows:
None found.

Features:
(shadow sort mail-extr emacsbug message rmc puny seq byte-opt gv
bytecomp byte-compile cconv dired dired-loaddefs format-spec rfc822 mml
easymenu mml-sec password-cache epa derived epg epg-config gnus-util
rmail rmail-loaddefs 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 elec-pair time-date
tooltip eldoc electric uniquify ediff-hook vc-hooks lisp-float-type
mwheel term/ns-win ns-win ucs-normalize mule-util term/common-win
tool-bar dnd fontset image regexp-opt fringe tabulated-list replace
newcomment text-mode elisp-mode lisp-mode prog-mode register page
menu-bar rfn-eshadow isearch timer select scroll-bar mouse jit-lock
font-lock syntax facemenu font-core term/tty-colors frame cl-generic
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 charscript charprop
case-table epa-hook jka-cmpr-hook help simple abbrev obarray minibuffer
cl-preloaded nadvice loaddefs button faces cus-face macroexp files
text-properties overlay sha1 md5 base64 format env code-pages mule
custom widget hashtable-print-readable backquote xwidget-internal kqueue
cocoa ns lcms2 multi-tty make-network-process emacs)

Memory information:
((conses 16 203880 9574)
 (symbols 48 20001 1)
 (miscs 40 33 114)
 (strings 32 28869 1418)
 (string-bytes 1 768776)
 (vectors 16 35252)
 (vector-slots 8 725502 18860)
 (floats 8 47 69)
 (intervals 56 230 0)
 (buffers 992 11))





^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2018-12-31  6:22 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-12-27  9:28 bug#33890: 27.0.50; Incorrect behaviour of cl-loop macro Quek Yu Han
2018-12-31  6:22 ` Glenn Morris

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