~ chicken-core (chicken-5) 32d0deac00795122cc03146c04523a7145ac626a


commit 32d0deac00795122cc03146c04523a7145ac626a
Author:     Mario Domenech Goulart <address@hidden>
AuthorDate: Sat Jan 11 18:11:47 2014 -0200
Commit:     felix <felix@call-with-current-continuation.org>
CommitDate: Tue Jan 28 09:16:05 2014 +0100

    Fix bug in string-index-right and string-skip-right
    
    Patch by David Van Horn to the SRFI-13 mailing list (see
    http://srfi.schemers.org/srfi-13/post-mail-archive/msg00007.html).
    Ported to CHICKEN by Seth Alves (see
    http://lists.nongnu.org/archive/html/chicken-hackers/2014-01/msg00022.html).
    
    Signed-off-by: Evan Hanson <address@hidden>

diff --git a/srfi-13.scm b/srfi-13.scm
index 7b161532..876a2bda 100644
--- a/srfi-13.scm
+++ b/srfi-13.scm
@@ -1208,17 +1208,17 @@
   (let-string-start+end (start end) string-index-right str maybe-start+end
     (cond ((char? criteria)
 	   (let lp ((i (- end 1)))
-	     (and (>= i 0)
+	     (and (>= i start)
 		  (if (char=? criteria (string-ref str i)) i
 		      (lp (- i 1))))))
 	  ((char-set? criteria)
 	   (let lp ((i (- end 1)))
-	     (and (>= i 0)
+	     (and (>= i start)
 		  (if (char-set-contains? criteria (string-ref str i)) i
 		      (lp (- i 1))))))
 	  ((procedure? criteria)
 	   (let lp ((i (- end 1)))
-	     (and (>= i 0)
+	     (and (>= i start)
 		  (if (criteria (string-ref str i)) i
 		      (lp (- i 1))))))
 	  (else (##sys#error 'string-index-right "Second param is neither char-set, char, or predicate procedure."
@@ -1250,19 +1250,19 @@
   (let-string-start+end (start end) string-skip-right str maybe-start+end
     (cond ((char? criteria)
 	   (let lp ((i (- end 1)))
-	     (and (>= i 0)
+	     (and (>= i start)
 		  (if (char=? criteria (string-ref str i))
 		      (lp (- i 1))
 		      i))))
 	  ((char-set? criteria)
 	   (let lp ((i (- end 1)))
-	     (and (>= i 0)
+	     (and (>= i start)
 		  (if (char-set-contains? criteria (string-ref str i))
 		      (lp (- i 1))
 		      i))))
 	  ((procedure? criteria)
 	   (let lp ((i (- end 1)))
-	     (and (>= i 0)
+	     (and (>= i start)
 		  (if (criteria (string-ref str i)) (lp (- i 1))
 		      i))))
 	  (else (##sys#error 'string-skip-right "CRITERIA param is neither char-set or char."
diff --git a/tests/srfi-13-tests.scm b/tests/srfi-13-tests.scm
index 29d6b80b..a9735cc6 100644
--- a/tests/srfi-13-tests.scm
+++ b/tests/srfi-13-tests.scm
@@ -688,3 +688,21 @@
                 (handle-exceptions exn
                   (k #f)
                   (string=? "abrcaaba" (string-delete char-set:upper-case "abrAcaDabRa"))))))
+
+
+; http://srfi.schemers.org/srfi-13/post-mail-archive/msg00007.html
+; From: David Van Horn <address@hidden>
+; Date: Wed, 01 Nov 2006 07:53:34 +0100
+;
+; Both string-index-right and string-skip-right will continue to search
+; left past a given start index.
+;
+;    (string-index-right "abbb" #\a 1) ;; => 0, but should be #f
+;    (string-skip-right  "abbb" #\b 1) ;; => 0, but should be #f
+;
+; This also causes incorrect results for string-trim-right,
+; string-trim-both and string-tokenize when given a non-zero start
+; argument.
+
+(test "string-index-right" #f (string-index-right "abbb" #\a 1))
+(test "string-skip-right" #f (string-skip-right  "abbb" #\b 1))
Trap