]> git.eshelyaron.com Git - emacs.git/commitdiff
(bindat--unpack-group, bindat--length-group)
authorKim F. Storm <storm@cua.dk>
Fri, 29 Dec 2006 01:20:48 +0000 (01:20 +0000)
committerKim F. Storm <storm@cua.dk>
Fri, 29 Dec 2006 01:20:48 +0000 (01:20 +0000)
(bindat--pack-group): Let-bind COUNT during repeat block evaluation.

lisp/emacs-lisp/bindat.el

index 792272ef88a9f8f497a17c74ac4766d77c63b248..6053fb3cf094cf1531ad0e62192af19bd0fb68a8 100644 (file)
         ((eq type 'struct)
          (setq data (bindat--unpack-group (eval len))))
         ((eq type 'repeat)
-         (let ((index 0))
-           (while (< index len)
+         (let ((index 0) (count len))
+           (while (< index count)
              (setq data (cons (bindat--unpack-group (nthcdr tail item)) data))
              (setq index (1+ index)))
            (setq data (nreverse data))))
@@ -415,8 +415,8 @@ e.g. corresponding to STRUCT.FIELD1[INDEX2].FIELD3..."
          (bindat--length-group
           (if field (bindat-get-field struct field) struct) (eval len)))
         ((eq type 'repeat)
-         (let ((index 0))
-           (while (< index len)
+         (let ((index 0) (count len))
+           (while (< index count)
              (bindat--length-group
                (nth index (bindat-get-field struct field))
                (nthcdr tail item))
@@ -559,8 +559,8 @@ e.g. corresponding to STRUCT.FIELD1[INDEX2].FIELD3..."
          (bindat--pack-group
           (if field (bindat-get-field struct field) struct) (eval len)))
         ((eq type 'repeat)
-         (let ((index 0))
-           (while (< index len)
+         (let ((index 0) (count len))
+           (while (< index count)
              (bindat--pack-group
                (nth index (bindat-get-field struct field))
                (nthcdr tail item))