mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-12 06:06:53 -05:00
utils: Add `string-tokenize*'.
* guix/utils.scm (string-tokenize*): New procedure. * tests/utils.scm ("string-tokenize*"): New test.
This commit is contained in:
parent
19cb517012
commit
2bcfb9e065
2 changed files with 38 additions and 0 deletions
|
@ -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
|
||||||
|
|
|
@ -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))))
|
||||||
|
|
Loading…
Reference in a new issue