Added string-replace and string-index implemented in #lang whalesong
This commit is contained in:
parent
6b65afadab
commit
7e8718eb28
51
whalesong/selfhost/selfhost-strings.rkt
Normal file
51
whalesong/selfhost/selfhost-strings.rkt
Normal file
|
@ -0,0 +1,51 @@
|
|||
#lang whalesong (require "selfhost-lang.rkt" whalesong/lang/for)
|
||||
|
||||
(provide string-replace) ; (string-replace k r s) replace all occurences of k in s with r
|
||||
|
||||
; string-index : string string [integer] -> integer
|
||||
; return the index of the first occurence of k in the string s
|
||||
; whose index is from or greater
|
||||
(define (string-index k s [from 0])
|
||||
(define kn (string-length k))
|
||||
(define sn (string-length s))
|
||||
(and (<= (+ from kn) sn)
|
||||
(for/or ([i (in-range from (- sn kn -1))])
|
||||
(and (for/and ([j (in-range i (+ i kn))] [l (in-range kn)])
|
||||
(char=? (string-ref s j) (string-ref k l)))
|
||||
i))))
|
||||
|
||||
; a new string is returned where occurences of the string k (the key)
|
||||
; are replaced with the string r (the replacement) in the string s.
|
||||
(define (string-replace k r s)
|
||||
(define kn (string-length k))
|
||||
(define sn (string-length s))
|
||||
(let loop ([start 0] [from 0] [chunks '()])
|
||||
(define i (string-index k s from))
|
||||
(displayln (list 'loop start from chunks i))
|
||||
(cond
|
||||
[i
|
||||
(define new-start (+ i kn))
|
||||
(loop new-start
|
||||
new-start
|
||||
(cons r (cons (substring s start i) chunks)))]
|
||||
[(empty? chunks)
|
||||
(string-copy s)]
|
||||
[else
|
||||
(apply string-append
|
||||
(reverse (cons (if (<= start sn)
|
||||
(substring s start)
|
||||
"")
|
||||
chunks)))])))
|
||||
|
||||
; Test must evaluate to #t
|
||||
#;(and (= (string-index "bar" "foobarbazbar")
|
||||
(string-index "bar" "foobarbazbar" 1)
|
||||
(string-index "bar" "foobarbazbar" 2)
|
||||
(string-index "bar" "foobarbazbar" 3)
|
||||
3)
|
||||
(= (string-index "bar" "foobarbazbar" 4) 9)
|
||||
(equal? (string-index "bar" "foobarbazbar" 10) #f))
|
||||
|
||||
; (string-replace "foo" "_" "abfoocdfoooo")
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user