create-mendix-widget-gleam 2.0.14 → 2.0.16
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/package.json +5 -1
- package/src/index.mjs +32 -12
- package/template/gleam.toml +1 -1
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@command.cache +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@command.cache_inline +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@command.cache_meta +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@cursor.cache +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@cursor.cache_inline +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@cursor.cache_meta +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@event.cache +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@event.cache_inline +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@event.cache_meta +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@internal@consts.cache +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@internal@consts.cache_inline +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@internal@consts.cache_meta +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@stdout.cache +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@stdout.cache_inline +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@stdout.cache_meta +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@style.cache +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@style.cache_inline +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@style.cache_meta +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@terminal.cache +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@terminal.cache_inline +0 -0
- package/tui/build/dev/javascript/etch/_gleam_artefacts/etch@terminal.cache_meta +0 -0
- package/tui/build/dev/javascript/etch/etch/command.mjs +479 -0
- package/tui/build/dev/javascript/etch/etch/cursor.mjs +164 -0
- package/tui/build/dev/javascript/etch/etch/event.mjs +2399 -0
- package/tui/build/dev/javascript/etch/etch/internal/consts.mjs +3 -0
- package/tui/build/dev/javascript/etch/etch/stdout.mjs +375 -0
- package/tui/build/dev/javascript/etch/etch/style.mjs +741 -0
- package/tui/build/dev/javascript/etch/etch/terminal.mjs +137 -0
- package/tui/build/dev/javascript/etch/gleam.mjs +1 -0
- package/tui/build/dev/javascript/etch/input/event_ffi.erl +73 -0
- package/tui/build/dev/javascript/etch/input/input_ffi.mjs +192 -0
- package/tui/build/dev/javascript/etch/input/signal_handler.erl +33 -0
- package/tui/build/dev/javascript/etch/terminal/terminal_ffi.erl +22 -0
- package/tui/build/dev/javascript/etch/terminal/terminal_ffi.mjs +37 -0
- package/tui/build/dev/javascript/etch/terminal/tty_state.erl +29 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@application.cache +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@application.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@application.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@atom.cache +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@atom.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@atom.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@charlist.cache +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@charlist.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@charlist.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@node.cache +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@node.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@node.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@port.cache +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@port.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@port.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@process.cache +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@process.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@process.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@reference.cache +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@reference.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_erlang/_gleam_artefacts/gleam@erlang@reference.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam/erlang/application.mjs +38 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam/erlang/atom.mjs +2 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam/erlang/charlist.mjs +1 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam/erlang/node.mjs +12 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam/erlang/port.mjs +1 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam/erlang/process.mjs +161 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam/erlang/reference.mjs +1 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam.mjs +1 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam@erlang@application.erl +43 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam@erlang@atom.erl +94 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam@erlang@charlist.erl +42 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam@erlang@node.erl +80 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam@erlang@port.erl +8 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam@erlang@process.erl +868 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam@erlang@reference.erl +21 -0
- package/tui/build/dev/javascript/gleam_erlang/gleam_erlang_ffi.erl +164 -0
- package/tui/build/dev/javascript/gleam_javascript/_gleam_artefacts/gleam@javascript@array.cache +0 -0
- package/tui/build/dev/javascript/gleam_javascript/_gleam_artefacts/gleam@javascript@array.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_javascript/_gleam_artefacts/gleam@javascript@array.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_javascript/_gleam_artefacts/gleam@javascript@promise.cache +0 -0
- package/tui/build/dev/javascript/gleam_javascript/_gleam_artefacts/gleam@javascript@promise.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_javascript/_gleam_artefacts/gleam@javascript@promise.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_javascript/_gleam_artefacts/gleam@javascript@symbol.cache +0 -0
- package/tui/build/dev/javascript/gleam_javascript/_gleam_artefacts/gleam@javascript@symbol.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_javascript/_gleam_artefacts/gleam@javascript@symbol.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_javascript/gleam/javascript/array.mjs +24 -0
- package/tui/build/dev/javascript/gleam_javascript/gleam/javascript/promise.mjs +105 -0
- package/tui/build/dev/javascript/gleam_javascript/gleam/javascript/symbol.mjs +7 -0
- package/tui/build/dev/javascript/gleam_javascript/gleam.mjs +1 -0
- package/tui/build/dev/javascript/gleam_javascript/gleam_javascript_ffi.mjs +133 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@bit_array.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@bit_array.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@bit_array.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@bool.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@bool.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@bool.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@bytes_tree.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@bytes_tree.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@bytes_tree.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@dict.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@dict.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@dict.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@dynamic.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@dynamic.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@dynamic.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@dynamic@decode.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@dynamic@decode.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@dynamic@decode.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@float.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@float.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@float.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@function.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@function.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@function.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@int.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@int.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@int.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@io.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@io.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@io.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@list.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@list.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@list.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@option.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@option.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@option.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@order.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@order.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@order.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@pair.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@pair.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@pair.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@result.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@result.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@result.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@set.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@set.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@set.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@string.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@string.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@string.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@string_tree.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@string_tree.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@string_tree.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@uri.cache +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@uri.cache_inline +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/_gleam_artefacts/gleam@uri.cache_meta +0 -0
- package/tui/build/dev/javascript/gleam_stdlib/dict.mjs +710 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/bit_array.mjs +286 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/bool.mjs +295 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/bytes_tree.mjs +225 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/dict.mjs +455 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/dynamic/decode.mjs +993 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/dynamic.mjs +35 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/float.mjs +528 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/function.mjs +6 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/int.mjs +764 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/io.mjs +8 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/list.mjs +3063 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/option.mjs +386 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/order.mjs +166 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/pair.mjs +96 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/result.mjs +448 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/set.mjs +413 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/string.mjs +695 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/string_tree.mjs +128 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam/uri.mjs +1151 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam.mjs +1 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@bit_array.erl +347 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@bool.erl +334 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@bytes_tree.erl +211 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@dict.erl +513 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@dynamic.erl +105 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@dynamic@decode.erl +1114 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@float.erl +711 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@function.erl +18 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@int.erl +972 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@io.erl +76 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@list.erl +2735 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@option.erl +381 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@order.erl +188 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@pair.erl +104 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@result.erl +500 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@set.erl +430 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@string.erl +964 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@string_tree.erl +202 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam@uri.erl +1042 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam_stdlib.erl +534 -0
- package/tui/build/dev/javascript/gleam_stdlib/gleam_stdlib.mjs +1133 -0
- package/tui/build/dev/javascript/gleam_version +1 -0
- package/tui/build/dev/javascript/prelude.mjs +1575 -0
- package/tui/build/dev/javascript/tui/_gleam_artefacts/tui.cache +0 -0
- package/tui/build/dev/javascript/tui/_gleam_artefacts/tui.cache_inline +0 -0
- package/tui/build/dev/javascript/tui/_gleam_artefacts/tui.cache_meta +0 -0
- package/tui/build/dev/javascript/tui/_gleam_artefacts/tui.cache_warnings +0 -0
- package/tui/build/dev/javascript/tui/_gleam_artefacts/tui@prompt.cache +0 -0
- package/tui/build/dev/javascript/tui/_gleam_artefacts/tui@prompt.cache_inline +0 -0
- package/tui/build/dev/javascript/tui/_gleam_artefacts/tui@prompt.cache_meta +0 -0
- package/tui/build/dev/javascript/tui/_gleam_artefacts/tui@prompt.cache_warnings +0 -0
- package/tui/build/dev/javascript/tui/gleam.mjs +1 -0
- package/tui/build/dev/javascript/tui/tui/prompt.mjs +521 -0
- package/tui/build/dev/javascript/tui/tui.mjs +334 -0
- package/tui/build/dev/javascript/tui/tui_ffi.mjs +32 -0
|
@@ -0,0 +1,413 @@
|
|
|
1
|
+
import { CustomType as $CustomType, isEqual } from "../gleam.mjs";
|
|
2
|
+
import * as $dict from "../gleam/dict.mjs";
|
|
3
|
+
import * as $list from "../gleam/list.mjs";
|
|
4
|
+
import * as $result from "../gleam/result.mjs";
|
|
5
|
+
|
|
6
|
+
class Set extends $CustomType {
|
|
7
|
+
constructor(dict) {
|
|
8
|
+
super();
|
|
9
|
+
this.dict = dict;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
const token = undefined;
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* Creates a new empty set.
|
|
17
|
+
*/
|
|
18
|
+
export function new$() {
|
|
19
|
+
return new Set($dict.new$());
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Gets the number of members in a set.
|
|
24
|
+
*
|
|
25
|
+
* This function runs in constant time.
|
|
26
|
+
*
|
|
27
|
+
* ## Examples
|
|
28
|
+
*
|
|
29
|
+
* ```gleam
|
|
30
|
+
* assert new()
|
|
31
|
+
* |> insert(1)
|
|
32
|
+
* |> insert(2)
|
|
33
|
+
* |> size
|
|
34
|
+
* == 2
|
|
35
|
+
* ```
|
|
36
|
+
*/
|
|
37
|
+
export function size(set) {
|
|
38
|
+
return $dict.size(set.dict);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Determines whether or not the set is empty.
|
|
43
|
+
*
|
|
44
|
+
* ## Examples
|
|
45
|
+
*
|
|
46
|
+
* ```gleam
|
|
47
|
+
* assert new() |> is_empty
|
|
48
|
+
* ```
|
|
49
|
+
*
|
|
50
|
+
* ```gleam
|
|
51
|
+
* assert !{ new() |> insert(1) |> is_empty }
|
|
52
|
+
* ```
|
|
53
|
+
*/
|
|
54
|
+
export function is_empty(set) {
|
|
55
|
+
return isEqual(set, new$());
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* Checks whether a set contains a given member.
|
|
60
|
+
*
|
|
61
|
+
* This function runs in logarithmic time.
|
|
62
|
+
*
|
|
63
|
+
* ## Examples
|
|
64
|
+
*
|
|
65
|
+
* ```gleam
|
|
66
|
+
* assert new()
|
|
67
|
+
* |> insert(2)
|
|
68
|
+
* |> contains(2)
|
|
69
|
+
* ```
|
|
70
|
+
*
|
|
71
|
+
* ```gleam
|
|
72
|
+
* assert !{
|
|
73
|
+
* new()
|
|
74
|
+
* |> insert(2)
|
|
75
|
+
* |> contains(1)
|
|
76
|
+
* }
|
|
77
|
+
* ```
|
|
78
|
+
*/
|
|
79
|
+
export function contains(set, member) {
|
|
80
|
+
let _pipe = set.dict;
|
|
81
|
+
let _pipe$1 = $dict.get(_pipe, member);
|
|
82
|
+
return $result.is_ok(_pipe$1);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
/**
|
|
86
|
+
* Removes a member from a set. If the set does not contain the member then
|
|
87
|
+
* the set is returned unchanged.
|
|
88
|
+
*
|
|
89
|
+
* This function runs in logarithmic time.
|
|
90
|
+
*
|
|
91
|
+
* ## Examples
|
|
92
|
+
*
|
|
93
|
+
* ```gleam
|
|
94
|
+
* assert !{
|
|
95
|
+
* new()
|
|
96
|
+
* |> insert(2)
|
|
97
|
+
* |> delete(2)
|
|
98
|
+
* |> contains(2)
|
|
99
|
+
* }
|
|
100
|
+
* ```
|
|
101
|
+
*/
|
|
102
|
+
export function delete$(set, member) {
|
|
103
|
+
return new Set($dict.delete$(set.dict, member));
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
/**
|
|
107
|
+
* Converts the set into a list of the contained members.
|
|
108
|
+
*
|
|
109
|
+
* The list has no specific ordering, any unintentional ordering may change in
|
|
110
|
+
* future versions of Gleam or Erlang.
|
|
111
|
+
*
|
|
112
|
+
* This function runs in linear time.
|
|
113
|
+
*
|
|
114
|
+
* ## Examples
|
|
115
|
+
*
|
|
116
|
+
* ```gleam
|
|
117
|
+
* assert new() |> insert(2) |> to_list == [2]
|
|
118
|
+
* ```
|
|
119
|
+
*/
|
|
120
|
+
export function to_list(set) {
|
|
121
|
+
return $dict.keys(set.dict);
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
/**
|
|
125
|
+
* Combines all entries into a single value by calling a given function on each
|
|
126
|
+
* one.
|
|
127
|
+
*
|
|
128
|
+
* Sets are not ordered so the values are not returned in any specific order.
|
|
129
|
+
* Do not write code that relies on the order entries are used by this
|
|
130
|
+
* function as it may change in later versions of Gleam or Erlang.
|
|
131
|
+
*
|
|
132
|
+
* ## Examples
|
|
133
|
+
*
|
|
134
|
+
* ```gleam
|
|
135
|
+
* assert from_list([1, 3, 9])
|
|
136
|
+
* |> fold(0, fn(accumulator, member) { accumulator + member })
|
|
137
|
+
* == 13
|
|
138
|
+
* ```
|
|
139
|
+
*/
|
|
140
|
+
export function fold(set, initial, reducer) {
|
|
141
|
+
return $dict.fold(set.dict, initial, (a, k, _) => { return reducer(a, k); });
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
/**
|
|
145
|
+
* Creates a new set from an existing set, minus any members that a given
|
|
146
|
+
* function returns `False` for.
|
|
147
|
+
*
|
|
148
|
+
* This function runs in loglinear time.
|
|
149
|
+
*
|
|
150
|
+
* ## Examples
|
|
151
|
+
*
|
|
152
|
+
* ```gleam
|
|
153
|
+
* import gleam/int
|
|
154
|
+
*
|
|
155
|
+
* assert from_list([1, 4, 6, 3, 675, 44, 67])
|
|
156
|
+
* |> filter(keeping: int.is_even)
|
|
157
|
+
* |> to_list
|
|
158
|
+
* == [4, 6, 44]
|
|
159
|
+
* ```
|
|
160
|
+
*/
|
|
161
|
+
export function filter(set, predicate) {
|
|
162
|
+
return new Set($dict.filter(set.dict, (m, _) => { return predicate(m); }));
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
/**
|
|
166
|
+
* Creates a new set from a given set with all the same entries except any
|
|
167
|
+
* entry found on the given list.
|
|
168
|
+
*
|
|
169
|
+
* ## Examples
|
|
170
|
+
*
|
|
171
|
+
* ```gleam
|
|
172
|
+
* assert from_list([1, 2, 3, 4])
|
|
173
|
+
* |> drop([1, 3])
|
|
174
|
+
* |> to_list
|
|
175
|
+
* == [2, 4]
|
|
176
|
+
* ```
|
|
177
|
+
*/
|
|
178
|
+
export function drop(set, disallowed) {
|
|
179
|
+
return $list.fold(disallowed, set, delete$);
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
/**
|
|
183
|
+
* Creates a new set from a given set, only including any members which are in
|
|
184
|
+
* a given list.
|
|
185
|
+
*
|
|
186
|
+
* This function runs in loglinear time.
|
|
187
|
+
*
|
|
188
|
+
* ## Examples
|
|
189
|
+
*
|
|
190
|
+
* ```gleam
|
|
191
|
+
* assert from_list([1, 2, 3])
|
|
192
|
+
* |> take([1, 3, 5])
|
|
193
|
+
* |> to_list
|
|
194
|
+
* == [1, 3]
|
|
195
|
+
* ```
|
|
196
|
+
*/
|
|
197
|
+
export function take(set, desired) {
|
|
198
|
+
return new Set($dict.take(set.dict, desired));
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
function order(first, second) {
|
|
202
|
+
let $ = $dict.size(first.dict) > $dict.size(second.dict);
|
|
203
|
+
if ($) {
|
|
204
|
+
return [first, second];
|
|
205
|
+
} else {
|
|
206
|
+
return [second, first];
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
/**
|
|
211
|
+
* Creates a new set that contains members that are present in both given sets.
|
|
212
|
+
*
|
|
213
|
+
* This function runs in loglinear time.
|
|
214
|
+
*
|
|
215
|
+
* ## Examples
|
|
216
|
+
*
|
|
217
|
+
* ```gleam
|
|
218
|
+
* assert intersection(from_list([1, 2]), from_list([2, 3])) |> to_list
|
|
219
|
+
* == [2]
|
|
220
|
+
* ```
|
|
221
|
+
*/
|
|
222
|
+
export function intersection(first, second) {
|
|
223
|
+
let $ = order(first, second);
|
|
224
|
+
let larger;
|
|
225
|
+
let smaller;
|
|
226
|
+
larger = $[0];
|
|
227
|
+
smaller = $[1];
|
|
228
|
+
return take(larger, to_list(smaller));
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
/**
|
|
232
|
+
* Creates a new set that contains members that are present in the first set
|
|
233
|
+
* but not the second.
|
|
234
|
+
*
|
|
235
|
+
* ## Examples
|
|
236
|
+
*
|
|
237
|
+
* ```gleam
|
|
238
|
+
* assert difference(from_list([1, 2]), from_list([2, 3, 4])) |> to_list
|
|
239
|
+
* == [1]
|
|
240
|
+
* ```
|
|
241
|
+
*/
|
|
242
|
+
export function difference(first, second) {
|
|
243
|
+
return drop(first, to_list(second));
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
/**
|
|
247
|
+
* Determines if a set is fully contained by another.
|
|
248
|
+
*
|
|
249
|
+
* ## Examples
|
|
250
|
+
*
|
|
251
|
+
* ```gleam
|
|
252
|
+
* assert is_subset(from_list([1]), from_list([1, 2]))
|
|
253
|
+
* ```
|
|
254
|
+
*
|
|
255
|
+
* ```gleam
|
|
256
|
+
* assert !is_subset(from_list([1, 2, 3]), from_list([3, 4, 5]))
|
|
257
|
+
* ```
|
|
258
|
+
*/
|
|
259
|
+
export function is_subset(first, second) {
|
|
260
|
+
return isEqual(intersection(first, second), first);
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
/**
|
|
264
|
+
* Determines if two sets contain no common members
|
|
265
|
+
*
|
|
266
|
+
* ## Examples
|
|
267
|
+
*
|
|
268
|
+
* ```gleam
|
|
269
|
+
* assert is_disjoint(from_list([1, 2, 3]), from_list([4, 5, 6]))
|
|
270
|
+
* ```
|
|
271
|
+
*
|
|
272
|
+
* ```gleam
|
|
273
|
+
* assert !is_disjoint(from_list([1, 2, 3]), from_list([3, 4, 5]))
|
|
274
|
+
* ```
|
|
275
|
+
*/
|
|
276
|
+
export function is_disjoint(first, second) {
|
|
277
|
+
return isEqual(intersection(first, second), new$());
|
|
278
|
+
}
|
|
279
|
+
|
|
280
|
+
/**
|
|
281
|
+
* Calls a function for each member in a set, discarding the return
|
|
282
|
+
* value.
|
|
283
|
+
*
|
|
284
|
+
* Useful for producing a side effect for every item of a set.
|
|
285
|
+
*
|
|
286
|
+
* The order of elements in the iteration is an implementation detail that
|
|
287
|
+
* should not be relied upon.
|
|
288
|
+
*
|
|
289
|
+
* ## Examples
|
|
290
|
+
*
|
|
291
|
+
* ```gleam
|
|
292
|
+
* let set = from_list(["apple", "banana", "cherry"])
|
|
293
|
+
*
|
|
294
|
+
* assert each(set, io.println) == Nil
|
|
295
|
+
* // apple
|
|
296
|
+
* // banana
|
|
297
|
+
* // cherry
|
|
298
|
+
* ```
|
|
299
|
+
*/
|
|
300
|
+
export function each(set, fun) {
|
|
301
|
+
return fold(
|
|
302
|
+
set,
|
|
303
|
+
undefined,
|
|
304
|
+
(nil, member) => {
|
|
305
|
+
fun(member);
|
|
306
|
+
return nil;
|
|
307
|
+
},
|
|
308
|
+
);
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
/**
|
|
312
|
+
* Inserts a member into the set.
|
|
313
|
+
*
|
|
314
|
+
* This function runs in logarithmic time.
|
|
315
|
+
*
|
|
316
|
+
* ## Examples
|
|
317
|
+
*
|
|
318
|
+
* ```gleam
|
|
319
|
+
* assert new()
|
|
320
|
+
* |> insert(1)
|
|
321
|
+
* |> insert(2)
|
|
322
|
+
* |> size
|
|
323
|
+
* == 2
|
|
324
|
+
* ```
|
|
325
|
+
*/
|
|
326
|
+
export function insert(set, member) {
|
|
327
|
+
return new Set($dict.insert(set.dict, member, token));
|
|
328
|
+
}
|
|
329
|
+
|
|
330
|
+
/**
|
|
331
|
+
* Creates a new set of the members in a given list.
|
|
332
|
+
*
|
|
333
|
+
* This function runs in loglinear time.
|
|
334
|
+
*
|
|
335
|
+
* ## Examples
|
|
336
|
+
*
|
|
337
|
+
* ```gleam
|
|
338
|
+
* import gleam/int
|
|
339
|
+
* import gleam/list
|
|
340
|
+
*
|
|
341
|
+
* assert [1, 1, 2, 4, 3, 2]
|
|
342
|
+
* |> from_list
|
|
343
|
+
* |> to_list
|
|
344
|
+
* |> list.sort(by: int.compare)
|
|
345
|
+
* == [1, 2, 3, 4]
|
|
346
|
+
* ```
|
|
347
|
+
*/
|
|
348
|
+
export function from_list(members) {
|
|
349
|
+
let dict = $list.fold(
|
|
350
|
+
members,
|
|
351
|
+
$dict.new$(),
|
|
352
|
+
(m, k) => { return $dict.insert(m, k, token); },
|
|
353
|
+
);
|
|
354
|
+
return new Set(dict);
|
|
355
|
+
}
|
|
356
|
+
|
|
357
|
+
/**
|
|
358
|
+
* Creates a new set from a given set with the result of applying the given
|
|
359
|
+
* function to each member.
|
|
360
|
+
*
|
|
361
|
+
* ## Examples
|
|
362
|
+
*
|
|
363
|
+
* ```gleam
|
|
364
|
+
* assert from_list([1, 2, 3, 4])
|
|
365
|
+
* |> map(with: fn(x) { x * 2 })
|
|
366
|
+
* |> to_list
|
|
367
|
+
* == [2, 4, 6, 8]
|
|
368
|
+
* ```
|
|
369
|
+
*/
|
|
370
|
+
export function map(set, fun) {
|
|
371
|
+
return fold(
|
|
372
|
+
set,
|
|
373
|
+
new$(),
|
|
374
|
+
(acc, member) => { return insert(acc, fun(member)); },
|
|
375
|
+
);
|
|
376
|
+
}
|
|
377
|
+
|
|
378
|
+
/**
|
|
379
|
+
* Creates a new set that contains all members of both given sets.
|
|
380
|
+
*
|
|
381
|
+
* This function runs in loglinear time.
|
|
382
|
+
*
|
|
383
|
+
* ## Examples
|
|
384
|
+
*
|
|
385
|
+
* ```gleam
|
|
386
|
+
* assert union(from_list([1, 2]), from_list([2, 3])) |> to_list
|
|
387
|
+
* == [1, 2, 3]
|
|
388
|
+
* ```
|
|
389
|
+
*/
|
|
390
|
+
export function union(first, second) {
|
|
391
|
+
let $ = order(first, second);
|
|
392
|
+
let larger;
|
|
393
|
+
let smaller;
|
|
394
|
+
larger = $[0];
|
|
395
|
+
smaller = $[1];
|
|
396
|
+
return fold(smaller, larger, insert);
|
|
397
|
+
}
|
|
398
|
+
|
|
399
|
+
/**
|
|
400
|
+
* Creates a new set that contains members that are present in either set, but
|
|
401
|
+
* not both.
|
|
402
|
+
*
|
|
403
|
+
* ## Examples
|
|
404
|
+
*
|
|
405
|
+
* ```gleam
|
|
406
|
+
* assert symmetric_difference(from_list([1, 2, 3]), from_list([3, 4]))
|
|
407
|
+
* |> to_list
|
|
408
|
+
* == [1, 2, 4]
|
|
409
|
+
* ```
|
|
410
|
+
*/
|
|
411
|
+
export function symmetric_difference(first, second) {
|
|
412
|
+
return difference(union(first, second), intersection(first, second));
|
|
413
|
+
}
|