1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114
|
# 01feb25 Software Lab. Alexander Burger
(de checkJson (X Item)
(unless (= X Item)
(quit "Bad JSON" Item) ) )
(de parseJson (Str Arr)
(let L (str Str "_")
(recur ()
(case (++ L)
("{"
(make
(for (X (recurse) (not (= "}" X)) (recurse))
(checkJson ":" (recurse))
(link (cons (intern X) (recurse)))
(T (= "}" (setq X (recurse))))
(checkJson "," X) ) ) )
("["
(make
(and Arr (link T)) # Array marker
(for (X (recurse) (not (= "]" X)) (recurse))
(link X)
(T (= "]" (setq X (recurse))))
(checkJson "," X) ) ) )
(T
(let X @
(cond
((pair X) (pack X))
((and (= "-" X) (format (car L)))
(- (++ L)) )
((and (num? X) (sub? (car L) "Ee"))
(and
(or (index "," (shift 'L)) (index "}" L))
(format (cut (dec @) 'L))
((if (lt0 @) */ *) X (** 10 (abs @))) ) )
(T X) ) ) ) ) ) ) )
(de readJson (Arr)
(case (read "_")
("{"
(make
(for (X (readJson Arr) (not (= "}" X)) (readJson Arr))
(checkJson ":" (readJson Arr))
(link (cons (intern X) (readJson Arr)))
(T (= "}" (setq X (readJson Arr))))
(checkJson "," X) ) ) )
("["
(make
(and Arr (link T)) # Array marker
(for (X (readJson Arr) (not (= "]" X)) (readJson Arr))
(link X)
(T (= "]" (setq X (readJson Arr))))
(checkJson "," X) ) ) )
(T
(let X @
(cond
((pair X) (pack X))
((and (= "-" X) (format (peek)))
(- (read)) )
((and (num? X) (sub? (peek) "Ee"))
(when (format (cdr (till ",}")))
((if (lt0 @) */ *) X (** 10 (abs @))) ) )
(T X) ) ) ) ) )
(de packJson (Item F)
(pack
(make
(recur (Item F)
(cond
((atom Item) (link (if Item (sym @) "{}")))
((=T (car Item))
(link "[")
(map
'((X)
(recurse (car X))
(and (cdr X) (link ", ")) )
(cdr Item) )
(link "]") )
((and (car Item) (atom @) (not F))
(link "\"" (sym (car Item)) "\": ")
(recurse (cdr Item) T) )
(T
(link "{")
(map
'((X)
(recurse (car X))
(and (cdr X) (link ", ")) )
Item )
(link "}") ) ) ) ) ) )
(de printJson (Item F)
(cond
((atom Item) (if Item (print @) (prin "{}")))
((=T (car Item))
(prin "[")
(map
'((X)
(printJson (car X))
(and (cdr X) (prin ", ")) )
(cdr Item) )
(prin "]") )
((and (car Item) (atom @) (not F))
(prin "\"")
(print (car Item))
(prin "\": ")
(printJson (cdr Item) T) )
(T
(prin "{")
(map
'((X)
(printJson (car X))
(and (cdr X) (prin ", ")) )
Item )
(prin "}") ) ) )
|