summaryrefslogtreecommitdiff
path: root/lib/zambyte/meta/gauche.scm
diff options
context:
space:
mode:
authorRobby Zambito <contact@robbyzambito.me>2023-02-14 20:33:23 -0500
committerRobby Zambito <contact@robbyzambito.me>2023-02-14 20:33:23 -0500
commit0b17e637d3791d1ca94558429f9deba3a5876166 (patch)
tree898b7b97fe7d5d3b4c6f3c7a8e1658325e8ab112 /lib/zambyte/meta/gauche.scm
parentc72a7be021a04a2c13204d77141ee759ce2500e5 (diff)
Use assoc symbols for keys instead of strings for objects.
Update the test suite to be more compatible with SRFI 64.
Diffstat (limited to 'lib/zambyte/meta/gauche.scm')
-rw-r--r--lib/zambyte/meta/gauche.scm16
1 files changed, 13 insertions, 3 deletions
diff --git a/lib/zambyte/meta/gauche.scm b/lib/zambyte/meta/gauche.scm
index 6f233bf..88093e5 100644
--- a/lib/zambyte/meta/gauche.scm
+++ b/lib/zambyte/meta/gauche.scm
@@ -2,7 +2,11 @@
(rfc json)
(srfi 1))
(begin
- (define json-object list)
+ (define (json-object . pairs)
+ (map (lambda (pair)
+ (cons (symbol->string (car pair))
+ (cdr pair)))
+ pairs))
(define json-list vector)
(define json-null 'null)
(define json-object? list?)
@@ -12,7 +16,7 @@
(eq? obj json-null))
(define (json-object-contains-key? obj key)
- (and (assoc key obj) #t))
+ (and (assoc (symbol->string key) obj) #t))
(define array-handler list->vector)
(define object-handler identity)
@@ -38,5 +42,11 @@
(define json-list-ref vector-ref)
(define json-list-length vector-length)
- (define json-object->alist identity)
+
+ (define (json-object->alist obj)
+ (map (lambda (pair)
+ (cons (string->symbol (car pair))
+ (cdr pair)))
+ obj))
+
(define json-list->list vector->list))