+ Preseve quotation of [],? and * while processing braces.
+ Unquote constant patterns before file existence check.
This commit is contained in:
parent
6ad71da933
commit
e603ebb626
|
@ -69,7 +69,7 @@
|
||||||
(cond ((string=? pat "") (values '() #t))
|
(cond ((string=? pat "") (values '() #t))
|
||||||
|
|
||||||
((constant-glob? pat)
|
((constant-glob? pat)
|
||||||
(values (cons pat '()) #f)) ; Don't check filesys.
|
(values (cons (glob-unquote pat) '()) #f)) ; Don't check filesys.
|
||||||
|
|
||||||
(else (let* ((dots? (char=? #\. (string-ref pat 0))) ; Match dot files?
|
(else (let* ((dots? (char=? #\. (string-ref pat 0))) ; Match dot files?
|
||||||
(candidates (maybe-directory-files fname dots?))
|
(candidates (maybe-directory-files fname dots?))
|
||||||
|
@ -249,12 +249,16 @@
|
||||||
(parse-comma-sequence pattern (+ i 1))
|
(parse-comma-sequence pattern (+ i 1))
|
||||||
(lp i (cross-append prefixes pats) '()))))
|
(lp i (cross-append prefixes pats) '()))))
|
||||||
((#\\)
|
((#\\)
|
||||||
(let ((i (+ i 1)))
|
(let ((next-i (+ i 1)))
|
||||||
(if (= i pattern-len)
|
(if (= next-i pattern-len)
|
||||||
(error "Dangling escape char in glob pattern" pattern)
|
(error "Dangling escape char in glob pattern" pattern)
|
||||||
(lp (+ i 1)
|
(if (memv (string-ref pattern next-i) '(#\{, #\,, #\},#\\))
|
||||||
prefixes
|
(lp (+ next-i 1)
|
||||||
(cons (string-ref pattern i) pat)))))
|
prefixes
|
||||||
|
(cons (string-ref pattern next-i) pat))
|
||||||
|
(lp (+ i 1)
|
||||||
|
prefixes
|
||||||
|
(cons (string-ref pattern i) pat))))))
|
||||||
((#\,)
|
((#\,)
|
||||||
(if comma-terminates?
|
(if comma-terminates?
|
||||||
(values (finish prefixes pat) i)
|
(values (finish prefixes pat) i)
|
||||||
|
@ -313,4 +317,21 @@
|
||||||
(cons #\\ result)
|
(cons #\\ result)
|
||||||
result))))))
|
result))))))
|
||||||
|
|
||||||
|
(define (glob-unquote string)
|
||||||
|
(let ((len (string-length string)))
|
||||||
|
(let lp ((i 0)
|
||||||
|
(result '()))
|
||||||
|
(if (= i len)
|
||||||
|
(list->string (reverse result))
|
||||||
|
(let* ((c (string-ref string i)))
|
||||||
|
(if (char=? c #\\)
|
||||||
|
(let ((next-i (+ i 1)))
|
||||||
|
(if (= next-i len)
|
||||||
|
(error "Dangling escape char in glob pattern" string)
|
||||||
|
(let ((quoted (string-ref string next-i)))
|
||||||
|
(lp (+ i 2)
|
||||||
|
(cons quoted result)))))
|
||||||
|
(lp (+ i 1)
|
||||||
|
(cons c result))))))))
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue