~ chicken-core (chicken-5) 157b2b371d23ba775ac2694a0445962fc70bd515


commit 157b2b371d23ba775ac2694a0445962fc70bd515
Author:     felix <felix@call-with-current-continuation.org>
AuthorDate: Wed Sep 1 08:06:32 2010 -0400
Commit:     felix <felix@call-with-current-continuation.org>
CommitDate: Wed Sep 1 08:06:32 2010 -0400

    applied 8343cb22 from irregex-bugfixes branch

diff --git a/irregex-core.scm b/irregex-core.scm
index 0baeb1a3..a1be5465 100644
--- a/irregex-core.scm
+++ b/irregex-core.scm
@@ -31,10 +31,12 @@
 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
 ;;;; History
 ;;
-;; 0.8.2: 2010/08/03 - (...)? submatch extraction fix and alternate
+;; 0.8.2: 2010/08/06 - (...)? submatch extraction fix and alternate
 ;;                     named submatches from Peter Bex
-;;                     Added irregex-match-valid-index? to export list
-;;                     and made it accept named submatches.  The procedures
+;;                     Added irregex-split, irregex-extract,
+;;                     irregex-match-names and irregex-match-valid-index?
+;;                     to Chicken and Guile module export lists and made
+;;                     the latter accept named submatches.  The procedures
 ;;                     irregex-match-{start,end}-{index,chunk} now also
 ;;                     accept named submatches, with the index argument
 ;;                     made optional.  Improved argument type checks.
@@ -259,9 +261,11 @@
    (else
     (let ((n (car opt)))
       (if (number? n)
-          (or (and (irregex-match-valid-numeric-index? m n) n)
-              (and strict?
-                   (%irregex-error location "not a valid index" m n)))
+          (if (and (integer? n) (exact? n))
+              (or (and (irregex-match-valid-numeric-index? m n) n)
+                  (and strict?
+                       (%irregex-error location "not a valid index" m n)))
+              (%irregex-error location "not an exact integer" n))
           (let lp ((ls (irregex-match-names m))
                    (unknown? #t))
             (cond
@@ -278,7 +282,9 @@
   (if (not (irregex-match-data? m))
       (%irregex-error 'irregex-match-valid-index? "not match data" m))
   (if (integer? n)
-      (irregex-match-valid-numeric-index? m n)
+      (if (not (exact? n))
+          (%irregex-error 'irregex-match-valid-index? "not an exact integer" n)
+          (irregex-match-valid-numeric-index? m n))
       (irregex-match-valid-named-index? m n)))
 
 (define (irregex-match-substring m . opt)
@@ -1289,9 +1295,7 @@
                    (else
                     (let ((c (cond ((assv c posix-escape-sequences) => cdr)
                                    (else c))))
-                      (go (+ i 2)
-                          (cons (string-ref str (+ i 1)) (cons c chars))
-                          ranges))))))
+                      (go (+ i 2) (cons c chars) ranges))))))
               (else
                (if (and utf8? (<= #x80 (char->integer c) #xFF))
                    (let ((len (utf8-start-char->length c)))
@@ -1962,8 +1966,10 @@
   (if (not (string? str)) (%irregex-error 'irregex-search "not a string" str))
   (let ((start (or (and (pair? o) (car o)) 0))
         (end (or (and (pair? o) (pair? (cdr o)) (cadr o)) (string-length str))))
-    (if (not (integer? start)) (%irregex-error 'irregex-search "not an integer" start))
-    (if (not (integer? end)) (%irregex-error 'irregex-search "not an integer" end))
+    (if (not (and (integer? start) (exact? start)))
+        (%irregex-error 'irregex-search "not an exact integer" start))
+    (if (not (and (integer? end) (exact? end)))
+        (%irregex-error 'irregex-search "not an exact integer" end))
     (irregex-search/chunked x
                             irregex-basic-string-chunker
                             (list str start end)
@@ -2059,6 +2065,10 @@
   (if (not (string? str)) (%irregex-error 'irregex-match "not a string" str))
   (let ((start (or (and (pair? o) (car o)) 0))
         (end (or (and (pair? o) (pair? (cdr o)) (cadr o)) (string-length str))))
+    (if (not (and (integer? start) (exact? start)))
+        (%irregex-error 'irregex-match "not an exact integer" start))
+    (if (not (and (integer? end) (exact? end)))
+        (%irregex-error 'irregex-match "not an exact integer" end))
     (irregex-match/chunked irx
                            irregex-basic-string-chunker
                            (list str start end))))
@@ -3755,8 +3765,10 @@
          (end (if (and (pair? o) (pair? (cdr o)) (pair? (cddr o)))
                   (caddr o)
                   (string-length str))))
-    (if (not (integer? start)) (%irregex-error 'irregex-fold "not an integer" start))
-    (if (not (integer? end)) (%irregex-error 'irregex-fold "not an integer" end))
+    (if (not (and (integer? start) (exact? start)))
+        (%irregex-error 'irregex-fold "not an exact integer" start))
+    (if (not (and (integer? end) (exact? end)))
+        (%irregex-error 'irregex-fold "not an exact integer" end))
     (irregex-match-chunker-set! matches irregex-basic-string-chunker)
     (let lp ((i start) (acc knil))
       (if (>= i end)
Trap