aboutsummaryrefslogtreecommitdiffstats
path: root/yql/essentials/tests/s-expressions/suites/InMem/ToDictOpt.yqls
blob: 0a2fab711ecbd63b853290c03f805791b4ec5fde (plain) (blame)
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
(
#comment
(let config (DataSource 'config))
(let world (Configure! world config 'PureDataSource 'yt))

(let res_sink (DataSink 'result))
(let list (AsList
'((Just (Uint32 '1)) (String 'a))
'((Just (Uint32 '2)) (String 'b))
'((Just (Uint32 '1)) (String 'c))
'((Nothing (OptionalType (DataType 'Uint32))) (String 'd))
))

(let macro (lambda '(world name flags) (block '(

(let dict (ToDict list (lambda '(x) (Nth x '0)) (lambda '(x) (Nth x '1)) flags))

(let world (Write! world res_sink (Key) (String name) '()))
(let world (Write! world res_sink (Key) dict '('('type))))
(let world (Write! world res_sink (Key) (Contains dict (Just (Uint32 '1))) '()))
(let world (Write! world res_sink (Key) (Contains dict (Just (Uint32 '2))) '()))
(let world (Write! world res_sink (Key) (Contains dict (Just (Uint32 '3))) '()))
(let world (Write! world res_sink (Key) (Contains dict (Nothing (OptionalType (DataType 'Uint32)))) '()))
(let world (Write! world res_sink (Key) (Lookup dict (Just (Uint32 '1))) '()))
(let world (Write! world res_sink (Key) (Lookup dict (Just (Uint32 '2))) '()))
(let world (Write! world res_sink (Key) (Lookup dict (Just (Uint32 '3))) '()))
(let world (Write! world res_sink (Key) (Lookup dict (Nothing (OptionalType (DataType 'Uint32)))) '()))

(return world)
))))

(let world (Apply macro world 'Sorted/One '('Sorted 'One)))
(let world (Apply macro world 'Sorted/Many '('Sorted 'Many)))
(let world (Apply macro world 'Hashed/One '('Hashed 'One)))
(let world (Apply macro world 'Hashed/Many '('Hashed 'Many)))

(let world (Commit! world res_sink))
(return world)
)