aboutsummaryrefslogtreecommitdiff
path: root/stdlib/source/specification/compositor.lux
blob: 619ba5fa9ee48ffc7ba61f98f45262a58339ea0d (plain)
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
(.module:
  [lux #*
   ["_" test (#+ Test)]
   [abstract
    [monad (#+ do)]]
   [control
    ["." io (#+ IO)]
    ["." try]]
   [math
    ["r" random]]
   [tool
    [compiler
     ["." analysis]
     ["." directive]
     [phase
      [macro (#+ Expander)]
      [generation (#+ Bundle)]]
     [default
      [platform (#+ Platform)]]]]]
  ["." / #_
   ["#." common (#+ Runner Definer)]
   ["#./" analysis #_
    ["#." type]]
   ["#./" generation #_
    ["#." primitive]
    ["#." structure]
    ["#." reference]
    ["#." case]
    ["#." function]
    ["#." common]]])

(def: (test runner definer state expander)
  (-> Runner Definer analysis.State+ Expander Test)
  ($_ _.and
      (/analysis/type.spec expander state)
      (/generation/primitive.spec runner)
      (/generation/structure.spec runner)
      (/generation/reference.spec runner definer)
      (/generation/case.spec runner)
      (/generation/function.spec runner)
      (/generation/common.spec runner)
      ))

(def: .public (spec platform bundle expander program)
  (All (_ anchor expression directive)
    (-> (IO (Platform IO anchor expression directive))
        (Bundle anchor expression directive)
        Expander
        (-> expression directive)
        Test))
  (do r.monad
    [_ (in [])
     .let [?state,runner,definer (<| io.run!
                                     (do io.monad
                                       [platform platform])
                                     (/common.executors platform
                                                        bundle
                                                        expander
                                                        program))]]
    (case ?state,runner,definer
      (#try.Success [[directive_bundle directive_state] runner definer])
      (..test runner definer
              (value@ [#directive.analysis #directive.state] directive_state)
              expander)

      (#try.Failure error)
      (_.failure error))))