mirror of
https://github.com/janet-lang/janet
synced 2024-11-18 06:34:48 +00:00
Merge pull request #10 from Gavlooth/master
Fix if-let when-let and add put-in (assoc-in)
This commit is contained in:
commit
b70d6cad1b
22
examples/utils.dst
Normal file
22
examples/utils.dst
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
|
||||||
|
(defn put-in [coll keys val]
|
||||||
|
(defn assoc [the-coll n]
|
||||||
|
(if-let [current-key (get keys n)
|
||||||
|
current-val (get the-coll current-key)]
|
||||||
|
(put the-coll current-key (assoc current-val (inc n)))
|
||||||
|
val))
|
||||||
|
(assoc coll 0))
|
||||||
|
|
||||||
|
|
||||||
|
(defn update-in [coll keys an-fn]
|
||||||
|
(def new-keys (array-slice coll 0 -2) )
|
||||||
|
(def last-key (get (array-slice coll -1 -2) 0))
|
||||||
|
(defn assoc [the-coll n]
|
||||||
|
(if-let [current-key (get keys n)
|
||||||
|
current-val (get the-coll current-key)]
|
||||||
|
(put the-coll current-key (assoc current-val (inc n)))
|
||||||
|
( update the-coll last-key an-fn )))
|
||||||
|
(assoc coll new-keys 0))
|
||||||
|
|
||||||
|
|
||||||
|
;; (defn update-in-test [ ] (update-in @{:a "x" :b {:y {"pipa" 3}}} [:b :y "pipa"] type))
|
@ -367,13 +367,15 @@ If no match is found, returns nil"
|
|||||||
(tuple 'when (tuple not condition) exp-1))
|
(tuple 'when (tuple not condition) exp-1))
|
||||||
|
|
||||||
(defmacro if-let
|
(defmacro if-let
|
||||||
"Takes the first one or two forms in a vector and if true binds
|
"Takes the first one or two forms in a vector and if both are true binds
|
||||||
all the forms with let and evaluates the first expression else
|
all the forms with let and evaluates the first expression else
|
||||||
evaluates the second"
|
evaluates the second"
|
||||||
[bindings then else]
|
[bindings then else]
|
||||||
(def head (ast-unwrap1 bindings))
|
(tuple 'let bindings
|
||||||
(tuple 'let head
|
(tuple 'if (tuple 'and (tuple 'get bindings 1)
|
||||||
(tuple 'if (and (get head 1) (if (get head 2) (get head 3) true))
|
(tuple 'if
|
||||||
|
(tuple '> (tuple 'length bindings) 2)
|
||||||
|
(tuple 'get bindings 3) 'true))
|
||||||
then
|
then
|
||||||
else)))
|
else)))
|
||||||
|
|
||||||
@ -381,11 +383,13 @@ If no match is found, returns nil"
|
|||||||
"Takes the first one or two forms in vector and if true binds
|
"Takes the first one or two forms in vector and if true binds
|
||||||
all the forms with let and evaluates the body"
|
all the forms with let and evaluates the body"
|
||||||
[bindings & body]
|
[bindings & body]
|
||||||
(def head (ast-unwrap1 bindings))
|
(tuple 'let bindings
|
||||||
(tuple 'let head
|
|
||||||
(tuple
|
(tuple
|
||||||
'when
|
'when
|
||||||
(and (get head 1) (if (get head 2) (get head 3) true))
|
(tuple 'and (tuple 'get bindings 1)
|
||||||
|
(tuple 'if
|
||||||
|
(tuple '> (tuple 'length bindings) 2)
|
||||||
|
(tuple 'get bindings 3) 'true))
|
||||||
(apply1 tuple (array-concat ['do] (ast-unwrap1 body))))))
|
(apply1 tuple (array-concat ['do] (ast-unwrap1 body))))))
|
||||||
|
|
||||||
(defn comp
|
(defn comp
|
||||||
|
Loading…
Reference in New Issue
Block a user