diff options
author | Robby Zambito <contact@robbyzambito.me> | 2023-02-14 20:33:23 -0500 |
---|---|---|
committer | Robby Zambito <contact@robbyzambito.me> | 2023-02-14 20:33:23 -0500 |
commit | 0b17e637d3791d1ca94558429f9deba3a5876166 (patch) | |
tree | 898b7b97fe7d5d3b4c6f3c7a8e1658325e8ab112 /lib/zambyte/meta/chibi.scm | |
parent | c72a7be021a04a2c13204d77141ee759ce2500e5 (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/chibi.scm')
-rw-r--r-- | lib/zambyte/meta/chibi.scm | 19 |
1 files changed, 4 insertions, 15 deletions
diff --git a/lib/zambyte/meta/chibi.scm b/lib/zambyte/meta/chibi.scm index d7a7783..812694f 100644 --- a/lib/zambyte/meta/chibi.scm +++ b/lib/zambyte/meta/chibi.scm @@ -1,19 +1,14 @@ (import (chibi json) (srfi 1)) (begin - (define (json-object . pairs) - (map - (lambda (pair) - (cons (string->symbol (car pair)) (cdr pair))) - pairs)) - + (define json-object list) (define json-list vector) (define json-null (if #f #f)) (define json-object? list?) (define json-list? vector?) (define (json-object-contains-key? obj key) - (and (assoc (string->symbol key) obj) #t)) + (and (assoc key obj) #t)) (define (json-null? obj) (eq? obj json-null)) @@ -22,18 +17,12 @@ ;; string->json already defined in chibi json (define (json-object-ref json key) - (let ((pair (assoc (string->symbol key) json))) + (let ((pair (assoc key json))) (if pair (cdr pair) ((json-key-not-found))))) (define json-list-ref vector-ref) (define json-list-length vector-length) - - (define (json-object->alist json) - (map - (lambda (pair) - (cons (symbol->string (car pair)) (cdr pair))) - json)) - + (define json-object->alist values) (define json-list->list vector->list)) |