diff options
author | Eduardo Julian | 2022-10-23 19:10:49 -0400 |
---|---|---|
committer | Eduardo Julian | 2022-10-23 19:10:49 -0400 |
commit | 2fce6d44e0b4ada7ea270ff9a890504edbf8e3a3 (patch) | |
tree | 7fa035dd99c38400a354d61afb866bca1f4f8a2c /stdlib/source/library | |
parent | 8c63a525089597af1f9282c76daf97bf2b6058e0 (diff) |
New Delay type with associated constants + compile-time warning for undefined computations.
Diffstat (limited to 'stdlib/source/library')
8 files changed, 68 insertions, 22 deletions
diff --git a/stdlib/source/library/lux.lux b/stdlib/source/library/lux.lux index e6aae9218..026b11544 100644 --- a/stdlib/source/library/lux.lux +++ b/stdlib/source/library/lux.lux @@ -5459,8 +5459,10 @@ [location location .let [[module line column] location location (all .text_composite# (text#encoded module) "," (nat#encoded line) "," (nat#encoded column)) - message (all .text_composite# "Undefined behavior @ " location)]] - (in (list (` (..panic! (, (text$ message))))))) + message (all .text_composite# "Undefined behavior at " location)]] + (exec + (.log# (all .text_composite# "WARNING: " message)) + (in (list (` (..panic! (, (text$ message)))))))) _ (failure (..wrong_syntax_error (symbol ..undefined))))))) @@ -5807,7 +5809,8 @@ g!dummy (generated_symbol "g!dummy")] (when body' (list body' labels) - (in (list (recursive_type g!self g!dummy name body') labels)) + (in (list (recursive_type g!self g!dummy name body') + labels)) (list body') (in (list (recursive_type g!self g!dummy name body'))) diff --git a/stdlib/source/library/lux/control/concurrency/async.lux b/stdlib/source/library/lux/control/concurrency/async.lux index 75bec2d4b..4285b3b82 100644 --- a/stdlib/source/library/lux/control/concurrency/async.lux +++ b/stdlib/source/library/lux/control/concurrency/async.lux @@ -19,7 +19,7 @@ [primitive (.except)] ["[0]" variance (.only Mutable)]]]]] [// - ["[0]" thread] + ["[0]" thread (.only Delay)] ["[0]" atom (.only Atom atom)]]) (def Value @@ -202,7 +202,7 @@ left||right)))) (def .public (schedule! milli_seconds computation) - (All (_ a) (-> Nat (IO a) (Async a))) + (All (_ a) (-> Delay (IO a) (Async a))) (let [[!out resolve] (sharing [a] (is (IO a) computation) @@ -221,14 +221,14 @@ (..schedule! 0)) (def .public (after milli_seconds value) - (All (_ a) (-> Nat a (Async a))) + (All (_ a) (-> Delay a (Async a))) (..schedule! milli_seconds (io value))) (def .public (delay milli_seconds) - (-> Nat (Async Any)) + (-> Delay (Async Any)) (..after milli_seconds [])) (def .public (within milli_seconds async) - (All (_ r w) (-> Nat (Async' r w) (Async (Maybe r)))) + (All (_ r w) (-> Delay (Async' r w) (Async (Maybe r)))) (..or (..delay milli_seconds) async)) diff --git a/stdlib/source/library/lux/control/concurrency/frp.lux b/stdlib/source/library/lux/control/concurrency/frp.lux index b5005661a..e5fcac64d 100644 --- a/stdlib/source/library/lux/control/concurrency/frp.lux +++ b/stdlib/source/library/lux/control/concurrency/frp.lux @@ -14,6 +14,7 @@ [meta ["[0]" type (.only sharing)]]]] [// + [thread (.only Delay)] ["[0]" atom (.only Atom)] ["[0]" async (.only Async Async') (.use "[1]#[0]" monad)]]) @@ -237,7 +238,7 @@ (def .public (poll milli_seconds action) (All (_ a) - (-> Nat (IO a) [(Channel a) (Sink a)])) + (-> Delay (IO a) [(Channel a) (Sink a)])) (let [[output sink] (channel [])] (exec (io.run! (loop (again [_ []]) @@ -248,7 +249,7 @@ [output sink]))) (def .public (periodic milli_seconds) - (-> Nat [(Channel Any) (Sink Any)]) + (-> Delay [(Channel Any) (Sink Any)]) (..poll milli_seconds (io []))) (def .public (iterations f init) @@ -299,7 +300,7 @@ (in {.#End})))) (def .public (sequential milli_seconds values) - (All (_ a) (-> Nat (List a) (Channel a))) + (All (_ a) (-> Delay (List a) (Channel a))) (when values {.#End} ..empty diff --git a/stdlib/source/library/lux/control/concurrency/structured.lux b/stdlib/source/library/lux/control/concurrency/structured.lux index 8c0aab11b..69e58c9d0 100644 --- a/stdlib/source/library/lux/control/concurrency/structured.lux +++ b/stdlib/source/library/lux/control/concurrency/structured.lux @@ -18,7 +18,7 @@ [primitive (.except)]]]]] ["[0]" // ["[1]" async (.use "[1]#[0]" monad)] - ["[0]" thread] + ["[0]" thread (.only Delay)] ["[0]" atom (.only Atom)]]) (primitive .public (Async value) @@ -287,7 +287,7 @@ (def .public (schedule! scope milli_seconds action) (All (_ value) - (-> (Scope value) Nat (Action value) + (-> (Scope value) Delay (Action value) (Async value))) (let [[async resolve!] (sharing [value] (is (Action value) @@ -324,7 +324,7 @@ (def .public (after scope milli_seconds value) (All (_ value) - (-> (Scope value) Nat value + (-> (Scope value) Delay value (Async value))) (..schedule! scope milli_seconds (function (_ _) @@ -332,6 +332,6 @@ (def .public (delay scope milli_seconds) (All (_ value) - (-> (Scope value) Nat + (-> (Scope value) Delay (Async Any))) (..after scope milli_seconds [])) diff --git a/stdlib/source/library/lux/control/concurrency/thread.lux b/stdlib/source/library/lux/control/concurrency/thread.lux index 1b752dea7..81b2f04c8 100644 --- a/stdlib/source/library/lux/control/concurrency/thread.lux +++ b/stdlib/source/library/lux/control/concurrency/thread.lux @@ -116,8 +116,27 @@ {try.#Success _} [])) +(type .public Delay + Nat) + +(def .public milli_second + Delay + 1) + +(with_template [<name> <scale> <base>] + [(def .public <name> + Delay + (n.* <scale> <base>))] + + [second 1,000 milli_second] + [minute 60 second] + [hour 60 minute] + [day 24 hour] + [week 7 day] + ) + (def .public (schedule! milli_seconds action) - (-> Nat (IO Any) (IO Any)) + (-> Delay (IO Any) (IO Any)) (with_expansions [<jvm> (let [runnable (ffi.object [] [java/lang/Runnable] [] (java/lang/Runnable [] (run self []) void diff --git a/stdlib/source/library/lux/world/net/http/request.lux b/stdlib/source/library/lux/world/net/http/request.lux index c69666791..26005abe2 100644 --- a/stdlib/source/library/lux/world/net/http/request.lux +++ b/stdlib/source/library/lux/world/net/http/request.lux @@ -52,7 +52,8 @@ [blobs (frp.list body)] (in (at encoding.utf8 decoded (merge blobs))))) -(def failure (//response.bad_request "")) +(def failure + (//response.bad_request "")) (def .public (json reader server) (All (_ a) (-> (<json>.Reader a) (-> a Server) Server)) diff --git a/stdlib/source/library/lux/world/net/uri.lux b/stdlib/source/library/lux/world/net/uri.lux index 0fb3ff834..c05a9e4d5 100644 --- a/stdlib/source/library/lux/world/net/uri.lux +++ b/stdlib/source/library/lux/world/net/uri.lux @@ -1,10 +1,7 @@ (.require - [library - [lux (.except)]]) + [library + [lux (.except)]]) ... https://en.wikipedia.org/wiki/Uniform_Resource_Identifier (type .public URI Text) - -(def .public separator - "/") diff --git a/stdlib/source/library/lux/world/net/uri/path.lux b/stdlib/source/library/lux/world/net/uri/path.lux new file mode 100644 index 000000000..f9ee860a3 --- /dev/null +++ b/stdlib/source/library/lux/world/net/uri/path.lux @@ -0,0 +1,25 @@ +(.require + [library + [lux (.except) + [data + [text + ["%" \\format]] + [collection + ["[0]" list (.use "[1]#[0]" mix)]]]]]) + +(type .public Segment + Text) + +... https://en.wikipedia.org/wiki/Uniform_Resource_Identifier +(type .public Path + Text) + +(def .public separator + Text + "/") + +(def .public path + (-> (List Segment) Path) + (list#mix (function (_ head tail) + (%.format ..separator head tail)) + "")) |