utils: Add `string-tokenize*'.

* guix/utils.scm (string-tokenize*): New procedure.
* tests/utils.scm ("string-tokenize*"): New test.
This commit is contained in:
Ludovic Courtès 2013-04-28 21:38:40 +02:00
parent 19cb517012
commit 2bcfb9e065
2 changed files with 38 additions and 0 deletions

View file

@ -60,6 +60,7 @@ (define-module (guix utils)
version-compare version-compare
version>? version>?
package-name->name+version package-name->name+version
string-tokenize*
file-extension file-extension
call-with-temporary-output-file call-with-temporary-output-file
fold2)) fold2))
@ -471,6 +472,33 @@ (define (file-extension file)
(let ((dot (string-rindex file #\.))) (let ((dot (string-rindex file #\.)))
(and dot (substring file (+ 1 dot) (string-length file))))) (and dot (substring file (+ 1 dot) (string-length file)))))
(define (string-tokenize* string separator)
"Return the list of substrings of STRING separated by SEPARATOR. This is
like `string-tokenize', but SEPARATOR is a string."
(define (index string what)
(let loop ((string string)
(offset 0))
(cond ((string-null? string)
#f)
((string-prefix? what string)
offset)
(else
(loop (string-drop string 1) (+ 1 offset))))))
(define len
(string-length separator))
(let loop ((string string)
(result '()))
(cond ((index string separator)
=>
(lambda (offset)
(loop (string-drop string (+ offset len))
(cons (substring string 0 offset)
result))))
(else
(reverse (cons string result))))))
(define (call-with-temporary-output-file proc) (define (call-with-temporary-output-file proc)
"Call PROC with a name of a temporary file and open output port to that "Call PROC with a name of a temporary file and open output port to that
file; close the file and delete it when leaving the dynamic extent of this file; close the file and delete it when leaving the dynamic extent of this

View file

@ -64,6 +64,16 @@ (define-module (test-utils)
("nixpkgs" "1.0pre22125_a28fe19") ("nixpkgs" "1.0pre22125_a28fe19")
("gtk2" "2.38.0")))) ("gtk2" "2.38.0"))))
(test-equal "string-tokenize*"
'(("foo")
("foo" "bar" "baz")
("foo" "bar" "")
("foo" "bar" "baz"))
(list (string-tokenize* "foo" ":")
(string-tokenize* "foo;bar;baz" ";")
(string-tokenize* "foo!bar!" "!")
(string-tokenize* "foo+-+bar+-+baz" "+-+")))
(test-equal "fold2, 1 list" (test-equal "fold2, 1 list"
(list (reverse (iota 5)) (list (reverse (iota 5))
(map - (reverse (iota 5)))) (map - (reverse (iota 5))))