mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-18 08:51:48 -05:00
serialization: Factorize 'read-byte-string'.
* guix/serialization.scm (read-byte-string): New procedure. (read-string, read-latin1-string): Use it.
This commit is contained in:
parent
87d7928294
commit
472e4c4303
1 changed files with 12 additions and 14 deletions
|
@ -109,28 +109,26 @@ (define (write-string s p)
|
||||||
(bytevector-copy! s 0 b 8 l)
|
(bytevector-copy! s 0 b 8 l)
|
||||||
(put-bytevector p b)))
|
(put-bytevector p b)))
|
||||||
|
|
||||||
(define (read-string p)
|
(define (read-byte-string p)
|
||||||
(let* ((len (read-int p))
|
(let* ((len (read-int p))
|
||||||
(m (modulo len 8))
|
(m (modulo len 8))
|
||||||
(bv (get-bytevector-n* p len))
|
(bv (get-bytevector-n* p len)))
|
||||||
(str (utf8->string bv)))
|
|
||||||
(or (zero? m)
|
(or (zero? m)
|
||||||
(get-bytevector-n* p (- 8 m)))
|
(get-bytevector-n* p (- 8 m)))
|
||||||
str))
|
bv))
|
||||||
|
|
||||||
|
(define (read-string p)
|
||||||
|
(utf8->string (read-byte-string p)))
|
||||||
|
|
||||||
(define (read-latin1-string p)
|
(define (read-latin1-string p)
|
||||||
(let* ((len (read-int p))
|
"Read an ISO-8859-1 string from P."
|
||||||
(m (modulo len 8))
|
;; Note: do not use 'get-string-n' to work around Guile bug
|
||||||
;; Note: do not use 'get-string-n' to work around Guile bug
|
;; <http://bugs.gnu.org/19621>. See <http://bugs.gnu.org/19610> for
|
||||||
;; <http://bugs.gnu.org/19621>. See <http://bugs.gnu.org/19610> for
|
;; a discussion.
|
||||||
;; a discussion.
|
(let ((bv (read-byte-string p)))
|
||||||
(str (get-bytevector-n* p len)))
|
|
||||||
(or (zero? m)
|
|
||||||
(get-bytevector-n* p (- 8 m)))
|
|
||||||
|
|
||||||
;; XXX: Rewrite using (ice-9 iconv) when the minimum requirement is
|
;; XXX: Rewrite using (ice-9 iconv) when the minimum requirement is
|
||||||
;; upgraded to Guile >= 2.0.9.
|
;; upgraded to Guile >= 2.0.9.
|
||||||
(list->string (map integer->char (bytevector->u8-list str)))))
|
(list->string (map integer->char (bytevector->u8-list bv)))))
|
||||||
|
|
||||||
(define (write-string-list l p)
|
(define (write-string-list l p)
|
||||||
(write-int (length l) p)
|
(write-int (length l) p)
|
||||||
|
|
Loading…
Reference in a new issue