mirror of
https://git.savannah.gnu.org/git/guix.git
synced 2025-01-20 06:26:21 +01:00
utils: Change 'patch-shebangs' to use binary input.
* guix/build/utils.scm (get-char*): New procedure. (patch-shebang): Use it instead of 'read-char'. (fold-port-matches): Remove local 'get-char' and use 'get-char*' instead.
This commit is contained in:
parent
f9efe568c3
commit
ca1e3ad2fa
1 changed files with 11 additions and 11 deletions
|
@ -618,6 +618,14 @@ (define (set-file-time file stat)
|
|||
(stat:atimensec stat)
|
||||
(stat:mtimensec stat)))
|
||||
|
||||
(define (get-char* p)
|
||||
;; We call it `get-char', but that's really a binary version
|
||||
;; thereof. (The real `get-char' cannot be used here because our
|
||||
;; bootstrap Guile is hacked to always use UTF-8.)
|
||||
(match (get-u8 p)
|
||||
((? integer? x) (integer->char x))
|
||||
(x x)))
|
||||
|
||||
(define patch-shebang
|
||||
(let ((shebang-rx (make-regexp "^[[:blank:]]*([[:graph:]]+)[[:blank:]]*([[:graph:]]*)(.*)$")))
|
||||
(lambda* (file
|
||||
|
@ -653,8 +661,8 @@ (define (patch p interpreter rest-of-line)
|
|||
|
||||
(call-with-ascii-input-file file
|
||||
(lambda (p)
|
||||
(and (eq? #\# (read-char p))
|
||||
(eq? #\! (read-char p))
|
||||
(and (eq? #\# (get-char* p))
|
||||
(eq? #\! (get-char* p))
|
||||
(let ((line (false-if-exception (read-line p))))
|
||||
(and=> (and line (regexp-exec shebang-rx line))
|
||||
(lambda (m)
|
||||
|
@ -753,21 +761,13 @@ (define initial-pattern
|
|||
(map char-set (string->list pattern))
|
||||
pattern))
|
||||
|
||||
(define (get-char p)
|
||||
;; We call it `get-char', but that's really a binary version
|
||||
;; thereof. (The real `get-char' cannot be used here because our
|
||||
;; bootstrap Guile is hacked to always use UTF-8.)
|
||||
(match (get-u8 p)
|
||||
((? integer? x) (integer->char x))
|
||||
(x x)))
|
||||
|
||||
;; Note: we're not really striving for performance here...
|
||||
(let loop ((chars '())
|
||||
(pattern initial-pattern)
|
||||
(matched '())
|
||||
(result init))
|
||||
(cond ((null? chars)
|
||||
(loop (list (get-char port))
|
||||
(loop (list (get-char* port))
|
||||
pattern
|
||||
matched
|
||||
result))
|
||||
|
|
Loading…
Reference in a new issue