firefly-compiler 0.4.40 → 0.4.48

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.
Files changed (109) hide show
  1. package/.hintrc +4 -4
  2. package/.vscode/settings.json +4 -4
  3. package/bin/Release.ff +136 -71
  4. package/bin/firefly.mjs +1 -1
  5. package/compiler/Builder.ff +257 -257
  6. package/compiler/Compiler.ff +227 -227
  7. package/compiler/Dependencies.ff +186 -186
  8. package/compiler/DependencyLock.ff +17 -17
  9. package/compiler/JsEmitter.ff +946 -946
  10. package/compiler/LspHook.ff +202 -202
  11. package/compiler/ModuleCache.ff +178 -178
  12. package/compiler/Workspace.ff +88 -88
  13. package/core/.firefly/include/package-lock.json +394 -394
  14. package/core/.firefly/include/package.json +5 -5
  15. package/core/.firefly/include/prepare.sh +1 -1
  16. package/core/.firefly/package.ff +2 -2
  17. package/core/Array.ff +265 -265
  18. package/core/Atomic.ff +64 -64
  19. package/core/Box.ff +7 -7
  20. package/core/BrowserSystem.ff +40 -40
  21. package/core/BuildSystem.ff +148 -148
  22. package/core/Crypto.ff +96 -102
  23. package/core/Equal.ff +36 -36
  24. package/core/HttpClient.ff +87 -87
  25. package/core/JsSystem.ff +69 -69
  26. package/core/Json.ff +434 -434
  27. package/core/List.ff +486 -415
  28. package/core/Lock.ff +144 -144
  29. package/core/NodeSystem.ff +189 -189
  30. package/core/Ordering.ff +161 -161
  31. package/core/Path.ff +401 -401
  32. package/core/Random.ff +134 -134
  33. package/core/RbMap.ff +216 -216
  34. package/core/Show.ff +43 -43
  35. package/core/SourceLocation.ff +68 -68
  36. package/core/Task.ff +141 -141
  37. package/experimental/benchmarks/ListGrab.ff +23 -23
  38. package/experimental/benchmarks/ListGrab.java +55 -55
  39. package/experimental/benchmarks/Pyrotek45.ff +30 -30
  40. package/experimental/benchmarks/Pyrotek45.java +64 -64
  41. package/experimental/bidirectional/Bidi.ff +88 -88
  42. package/experimental/random/Index.ff +53 -53
  43. package/experimental/random/Process.ff +120 -120
  44. package/experimental/random/Scrape.ff +51 -51
  45. package/experimental/random/Symbols.ff +73 -73
  46. package/experimental/random/Tensor.ff +52 -52
  47. package/experimental/random/Units.ff +36 -36
  48. package/experimental/s3/S3TestAuthorizationHeader.ff +38 -38
  49. package/experimental/s3/S3TestPut.ff +15 -15
  50. package/experimental/tests/TestJson.ff +26 -26
  51. package/firefly.sh +0 -0
  52. package/fireflysite/Main.ff +13 -13
  53. package/lsp/.firefly/package.ff +1 -1
  54. package/lsp/CompletionHandler.ff +808 -811
  55. package/lsp/Handler.ff +714 -714
  56. package/lsp/HoverHandler.ff +79 -79
  57. package/lsp/LanguageServer.ff +272 -272
  58. package/lsp/SignatureHelpHandler.ff +55 -55
  59. package/lsp/SymbolHandler.ff +181 -181
  60. package/lsp/TestReferences.ff +16 -16
  61. package/lsp/TestReferencesCase.ff +7 -7
  62. package/lsp/stderr.txt +1 -1
  63. package/lsp/stdin.txt +10 -10
  64. package/lsp/stdout.txt +40 -40
  65. package/lux/.firefly/package.ff +1 -1
  66. package/lux/Css.ff +648 -648
  67. package/lux/CssTest.ff +48 -48
  68. package/lux/Lux.ff +487 -487
  69. package/lux/LuxEvent.ff +116 -116
  70. package/lux/Main.ff +128 -128
  71. package/lux/Main2.ff +144 -144
  72. package/output/js/ff/compiler/Builder.mjs +43 -43
  73. package/output/js/ff/compiler/Dependencies.mjs +3 -3
  74. package/output/js/ff/core/Array.mjs +59 -59
  75. package/output/js/ff/core/Atomic.mjs +36 -36
  76. package/output/js/ff/core/BrowserSystem.mjs +11 -11
  77. package/output/js/ff/core/BuildSystem.mjs +30 -30
  78. package/output/js/ff/core/Crypto.mjs +58 -62
  79. package/output/js/ff/core/HttpClient.mjs +24 -24
  80. package/output/js/ff/core/Json.mjs +147 -147
  81. package/output/js/ff/core/List.mjs +196 -50
  82. package/output/js/ff/core/Lock.mjs +97 -97
  83. package/output/js/ff/core/NodeSystem.mjs +77 -77
  84. package/output/js/ff/core/Ordering.mjs +8 -8
  85. package/output/js/ff/core/Path.mjs +231 -231
  86. package/output/js/ff/core/Random.mjs +56 -56
  87. package/output/js/ff/core/Task.mjs +31 -31
  88. package/package.json +29 -29
  89. package/rpc/.firefly/package.ff +1 -1
  90. package/rpc/Rpc.ff +69 -69
  91. package/s3/.firefly/package.ff +1 -1
  92. package/s3/S3.ff +93 -93
  93. package/unsafejs/UnsafeJs.ff +19 -19
  94. package/vscode/LICENSE.txt +21 -21
  95. package/vscode/Prepublish.ff +15 -15
  96. package/vscode/README.md +16 -16
  97. package/vscode/client/package.json +22 -22
  98. package/vscode/client/src/extension.ts +104 -104
  99. package/vscode/icons/firefly-icon.svg +10 -10
  100. package/vscode/language-configuration.json +61 -61
  101. package/vscode/package-lock.json +3623 -3623
  102. package/vscode/package.json +160 -160
  103. package/vscode/snippets.json +241 -241
  104. package/webserver/.firefly/include/package-lock.json +16 -16
  105. package/webserver/.firefly/include/package.json +5 -5
  106. package/webserver/.firefly/package.ff +2 -2
  107. package/webserver/WebServer.ff +685 -685
  108. package/websocket/.firefly/package.ff +1 -1
  109. package/websocket/WebSocket.ff +131 -131
@@ -1,88 +1,88 @@
1
- data Expression {
2
- EVariable(name: String)
3
- EApply(function: Expression, argument: Expression)
4
- ELambda(variable: String, body: Expression)
5
- EAnnotate(type: Type, expression: Expression)
6
- }
7
-
8
- data Type(name: String, typeArguments: List[Type])
9
-
10
- data Context(variables: Map[String, Type])
11
-
12
- data TypeError(message: String)
13
-
14
-
15
- check(c0: Context, t0: Type, e0: Expression): Unit {
16
- e0.{
17
- | ELambda(x1, e1) =>
18
- t0.{
19
- | Type("Function", [t2, t3]) =>
20
- let c2 = c0.Context(variables = c0.variables.add(x1, t2))
21
- check(c2, t3, e1)
22
- t3
23
- | _ =>
24
- throw(TypeError("Function type not expected here"))
25
- }
26
- | _ =>
27
- let t1 = infer(c0, e0)
28
- checkSame(t0, t1)
29
- }
30
- }
31
-
32
-
33
- infer(c0: Context, e0: Expression): Type {
34
- e0.{
35
- | EVariable(x1) =>
36
- c0.variables.get(x1).{
37
- | None =>
38
- throw(TypeError("Variable not in scope: " + x1))
39
- | Some(t1) =>
40
- t1
41
- }
42
- | EApply(e1, e2) =>
43
- let t1 = infer(c0, e1)
44
- t1.{
45
- | Type("Function", [t2, t3]) =>
46
- check(c0, t2, e2)
47
- t3
48
- | _ =>
49
- throw(TypeError("Can't call non-functions"))
50
- }
51
- | ELambda _ =>
52
- throw(TypeError("Lambda functions must be explicitly typed"))
53
- | EAnnotate(t1, e1) =>
54
- checkType(t1)
55
- check(c0, t1, e1)
56
- t1
57
- }
58
- }
59
-
60
-
61
- checkSame(t1: Type, t2: Type): Unit {
62
- if(t1.name != t2.name) {throw(TypeError("Type mismatch: " + t1.name + " vs. " + t2.name + ""))}
63
- if(t1.typeArguments.size() != t2.typeArguments.size()) {
64
- throw(TypeError(
65
- "Type mismatch: " + t1.name + " with " +
66
- t1.typeArguments.size() + " vs. " + t2.typeArguments.size() +
67
- " type arguments"
68
- ))
69
- }
70
- t1.typeArguments.zip(t2.typeArguments).each {| Pair(t3, t4) =>
71
- checkSame(t3, t4)
72
- }
73
- }
74
-
75
-
76
- checkType(t0: Type): Unit {
77
- t0.{
78
- | Type("Function", [t1, t2]) =>
79
- checkType(t1)
80
- checkType(t2)
81
- | Type("Bool", []) =>
82
- | Type("Int", []) =>
83
- | Type("List", [t1]) =>
84
- checkType(t1)
85
- | _ =>
86
- throw(TypeError("Type is not well formed"))
87
- }
88
- }
1
+ data Expression {
2
+ EVariable(name: String)
3
+ EApply(function: Expression, argument: Expression)
4
+ ELambda(variable: String, body: Expression)
5
+ EAnnotate(type: Type, expression: Expression)
6
+ }
7
+
8
+ data Type(name: String, typeArguments: List[Type])
9
+
10
+ data Context(variables: Map[String, Type])
11
+
12
+ data TypeError(message: String)
13
+
14
+
15
+ check(c0: Context, t0: Type, e0: Expression): Unit {
16
+ e0.{
17
+ | ELambda(x1, e1) =>
18
+ t0.{
19
+ | Type("Function", [t2, t3]) =>
20
+ let c2 = c0.Context(variables = c0.variables.add(x1, t2))
21
+ check(c2, t3, e1)
22
+ t3
23
+ | _ =>
24
+ throw(TypeError("Function type not expected here"))
25
+ }
26
+ | _ =>
27
+ let t1 = infer(c0, e0)
28
+ checkSame(t0, t1)
29
+ }
30
+ }
31
+
32
+
33
+ infer(c0: Context, e0: Expression): Type {
34
+ e0.{
35
+ | EVariable(x1) =>
36
+ c0.variables.get(x1).{
37
+ | None =>
38
+ throw(TypeError("Variable not in scope: " + x1))
39
+ | Some(t1) =>
40
+ t1
41
+ }
42
+ | EApply(e1, e2) =>
43
+ let t1 = infer(c0, e1)
44
+ t1.{
45
+ | Type("Function", [t2, t3]) =>
46
+ check(c0, t2, e2)
47
+ t3
48
+ | _ =>
49
+ throw(TypeError("Can't call non-functions"))
50
+ }
51
+ | ELambda _ =>
52
+ throw(TypeError("Lambda functions must be explicitly typed"))
53
+ | EAnnotate(t1, e1) =>
54
+ checkType(t1)
55
+ check(c0, t1, e1)
56
+ t1
57
+ }
58
+ }
59
+
60
+
61
+ checkSame(t1: Type, t2: Type): Unit {
62
+ if(t1.name != t2.name) {throw(TypeError("Type mismatch: " + t1.name + " vs. " + t2.name + ""))}
63
+ if(t1.typeArguments.size() != t2.typeArguments.size()) {
64
+ throw(TypeError(
65
+ "Type mismatch: " + t1.name + " with " +
66
+ t1.typeArguments.size() + " vs. " + t2.typeArguments.size() +
67
+ " type arguments"
68
+ ))
69
+ }
70
+ t1.typeArguments.zip(t2.typeArguments).each {| Pair(t3, t4) =>
71
+ checkSame(t3, t4)
72
+ }
73
+ }
74
+
75
+
76
+ checkType(t0: Type): Unit {
77
+ t0.{
78
+ | Type("Function", [t1, t2]) =>
79
+ checkType(t1)
80
+ checkType(t2)
81
+ | Type("Bool", []) =>
82
+ | Type("Int", []) =>
83
+ | Type("List", [t1]) =>
84
+ checkType(t1)
85
+ | _ =>
86
+ throw(TypeError("Type is not well formed"))
87
+ }
88
+ }
@@ -1,53 +1,53 @@
1
- data Index[K, R]()
2
-
3
- extend self[K, R]: Index[K, R] {
4
-
5
- get(key: K): Option[R] {
6
- panic("Oops")
7
- }
8
-
9
- getUnique(key: K): Option[R] {
10
- panic("Oops")
11
- }
12
-
13
- getOnly(): Option[R] {
14
- panic("Oops")
15
- }
16
-
17
- grab(key: K): R {
18
- panic("Oops")
19
- }
20
-
21
- grabUnique(key: K): R {
22
- panic("Oops")
23
- }
24
-
25
- grabOnly(key: K): R {
26
- panic("Oops")
27
- }
28
-
29
- getAll(key: K): List[R] {
30
- panic("Oops")
31
- }
32
-
33
- range(from: K, until: K): Index[K, R] {
34
- panic("Oops")
35
- }
36
-
37
- join[R1](that: Index[K, R1]): Index[K, Pair[R, R1]] {
38
- panic("Oops")
39
- }
40
-
41
- keep(only: Set[K]): Index[K, R] {
42
- panic("Oops")
43
- }
44
-
45
- filter(body: (K, R) => Bool): Index[K, R] {
46
- panic("Oops")
47
- }
48
-
49
- withKeys[K1](body: (K, R) => K1): Index[K1, R] {
50
- panic("Oops")
51
- }
52
-
53
- }
1
+ data Index[K, R]()
2
+
3
+ extend self[K, R]: Index[K, R] {
4
+
5
+ get(key: K): Option[R] {
6
+ panic("Oops")
7
+ }
8
+
9
+ getUnique(key: K): Option[R] {
10
+ panic("Oops")
11
+ }
12
+
13
+ getOnly(): Option[R] {
14
+ panic("Oops")
15
+ }
16
+
17
+ grab(key: K): R {
18
+ panic("Oops")
19
+ }
20
+
21
+ grabUnique(key: K): R {
22
+ panic("Oops")
23
+ }
24
+
25
+ grabOnly(key: K): R {
26
+ panic("Oops")
27
+ }
28
+
29
+ getAll(key: K): List[R] {
30
+ panic("Oops")
31
+ }
32
+
33
+ range(from: K, until: K): Index[K, R] {
34
+ panic("Oops")
35
+ }
36
+
37
+ join[R1](that: Index[K, R1]): Index[K, Pair[R, R1]] {
38
+ panic("Oops")
39
+ }
40
+
41
+ keep(only: Set[K]): Index[K, R] {
42
+ panic("Oops")
43
+ }
44
+
45
+ filter(body: (K, R) => Bool): Index[K, R] {
46
+ panic("Oops")
47
+ }
48
+
49
+ withKeys[K1](body: (K, R) => K1): Index[K1, R] {
50
+ panic("Oops")
51
+ }
52
+
53
+ }
@@ -1,120 +1,120 @@
1
- capability Process {}
2
-
3
- data ProcessException(exitCode: Int)
4
-
5
- extend self: Process {
6
-
7
- readStream(): Stream[Buffer] {
8
-
9
- }
10
-
11
- readErrorStream(): Stream[Buffer] {
12
-
13
- }
14
-
15
- readBothStreams(): Stream[Pair[Bool, Buffer]] {
16
-
17
- }
18
-
19
- readBuffer(): Buffer {
20
-
21
- }
22
-
23
- readErrorBuffer(): Buffer {
24
-
25
- }
26
-
27
- readBothBuffers(): Pair[Buffer, Buffer] {
28
-
29
- }
30
-
31
- readText(): String {
32
-
33
- }
34
-
35
- readErrorText(): String {
36
-
37
- }
38
-
39
- readBothTexts(): Pair[String, String] {
40
-
41
- }
42
-
43
- writeStream(stream: Stream[Buffer]) {
44
-
45
- }
46
-
47
- writeBuffer(buffer: Buffer) {
48
-
49
- }
50
-
51
- writeText(text: String) {
52
-
53
- }
54
-
55
- writeLine(text: String) {
56
-
57
- }
58
-
59
- closeStandardIn() {
60
-
61
- }
62
-
63
- running(): Bool {
64
-
65
- }
66
-
67
- exitCode(): Int {
68
-
69
- }
70
-
71
- setEnvironment(environment: Map[String, String]) {
72
-
73
- }
74
-
75
- setEnvironmentVariable(name: String, value: String) {
76
-
77
- }
78
-
79
- setWorkingDirectory(path: Path) {
80
-
81
- }
82
-
83
- setArgumentZero(commandName: String) {
84
-
85
- }
86
-
87
- setRedirection(in: Bool = False, out: Bool = False, error: Bool = False) {
88
-
89
- }
90
-
91
- setCloseAfterWrite(close: Bool) {
92
-
93
- }
94
-
95
- }
96
-
97
- internalExecute[T](system: NodeSystem, command: String, arguments: List[String], body: Process => T): T {
98
- throw(GrabException) // TODO
99
- }
100
-
101
- main(system: NodeSystem) {
102
- let initialize = ""
103
- let hoverRequest = ""
104
- function parseInitializeResponse(stream: Stream[Buffer]) {
105
-
106
- }
107
- function parseHoverResponse(stream: Stream[Buffer]) {
108
-
109
- }
110
-
111
- system.execute("my-lsp", []) {process =>
112
- process.setCloseAfterWrite(False)
113
- let stream = process.readStream()
114
- process.writeText(initialize)
115
- let config = parseInitializeResponse(stream)
116
- process.writeText(hoverRequest)
117
- let hover = parseHoverResponse(stream)
118
- // ...
119
- }
120
- }
1
+ capability Process {}
2
+
3
+ data ProcessException(exitCode: Int)
4
+
5
+ extend self: Process {
6
+
7
+ readStream(): Stream[Buffer] {
8
+
9
+ }
10
+
11
+ readErrorStream(): Stream[Buffer] {
12
+
13
+ }
14
+
15
+ readBothStreams(): Stream[Pair[Bool, Buffer]] {
16
+
17
+ }
18
+
19
+ readBuffer(): Buffer {
20
+
21
+ }
22
+
23
+ readErrorBuffer(): Buffer {
24
+
25
+ }
26
+
27
+ readBothBuffers(): Pair[Buffer, Buffer] {
28
+
29
+ }
30
+
31
+ readText(): String {
32
+
33
+ }
34
+
35
+ readErrorText(): String {
36
+
37
+ }
38
+
39
+ readBothTexts(): Pair[String, String] {
40
+
41
+ }
42
+
43
+ writeStream(stream: Stream[Buffer]) {
44
+
45
+ }
46
+
47
+ writeBuffer(buffer: Buffer) {
48
+
49
+ }
50
+
51
+ writeText(text: String) {
52
+
53
+ }
54
+
55
+ writeLine(text: String) {
56
+
57
+ }
58
+
59
+ closeStandardIn() {
60
+
61
+ }
62
+
63
+ running(): Bool {
64
+
65
+ }
66
+
67
+ exitCode(): Int {
68
+
69
+ }
70
+
71
+ setEnvironment(environment: Map[String, String]) {
72
+
73
+ }
74
+
75
+ setEnvironmentVariable(name: String, value: String) {
76
+
77
+ }
78
+
79
+ setWorkingDirectory(path: Path) {
80
+
81
+ }
82
+
83
+ setArgumentZero(commandName: String) {
84
+
85
+ }
86
+
87
+ setRedirection(in: Bool = False, out: Bool = False, error: Bool = False) {
88
+
89
+ }
90
+
91
+ setCloseAfterWrite(close: Bool) {
92
+
93
+ }
94
+
95
+ }
96
+
97
+ internalExecute[T](system: NodeSystem, command: String, arguments: List[String], body: Process => T): T {
98
+ throw(GrabException) // TODO
99
+ }
100
+
101
+ main(system: NodeSystem) {
102
+ let initialize = ""
103
+ let hoverRequest = ""
104
+ function parseInitializeResponse(stream: Stream[Buffer]) {
105
+
106
+ }
107
+ function parseHoverResponse(stream: Stream[Buffer]) {
108
+
109
+ }
110
+
111
+ system.execute("my-lsp", []) {process =>
112
+ process.setCloseAfterWrite(False)
113
+ let stream = process.readStream()
114
+ process.writeText(initialize)
115
+ let config = parseInitializeResponse(stream)
116
+ process.writeText(hoverRequest)
117
+ let hover = parseHoverResponse(stream)
118
+ // ...
119
+ }
120
+ }
@@ -1,51 +1,51 @@
1
-
2
- nodeMain(system: NodeSystem) {
3
-
4
- let urlFile = system.arguments().grab(0)
5
- let urls = system.path(urlFile).readText().lines()
6
-
7
- let urlChannel = system.mainTask().channel(urls.size())
8
- let htmlChannel = system.mainTask().channel(urls.size())
9
- let resultChannel = system.mainTask().channel(urls.size())
10
-
11
- 1.to(1000).each {_ =>
12
- system.mainTask().spawn {task =>
13
- let url = urlChannel.read()
14
- let html = system.httpClient().fetch(url).readText()
15
- htmlChannel.write(html)
16
- }
17
- }
18
-
19
- 1.to(10).each {_ =>
20
- system.mainTask().spawn {task =>
21
- let html = htmlChannel.read()
22
- let result = scrape(html)
23
- resultChannel.write(result)
24
- }
25
- }
26
-
27
- urls.each {url => urlChannel.write(url)}
28
- let results = urls.map {_ => resultChannel.read()}
29
- system.writeText(results.join("\n"))
30
-
31
- }
32
-
33
- scrape(html: String): String {
34
- html // Uhm...
35
- }
36
-
37
- foo() {
38
-
39
- let result = urls.toStream()
40
- .parallelMap(threads = 1000) {url => download(url)}
41
- .parallelMap(threads = 10) {result => result.map(scrape)}
42
-
43
- let result = urls.toStream()
44
- .parallelMap(threads = 1000) {task, url => task.timeout(Duration(5)) {download(url)}}
45
- .parallelMap(threads = 10) {_, result => result.map(scrape)}
46
-
47
- let result = urls.toStream()
48
- .parallelMap(1000) {task, url => task.deadline(task.now().add(Duration(5))) {download(url)}}
49
- .parallelMap(10) {_, result => result.map(scrape)}
50
-
51
- }
1
+
2
+ nodeMain(system: NodeSystem) {
3
+
4
+ let urlFile = system.arguments().grab(0)
5
+ let urls = system.path(urlFile).readText().lines()
6
+
7
+ let urlChannel = system.mainTask().channel(urls.size())
8
+ let htmlChannel = system.mainTask().channel(urls.size())
9
+ let resultChannel = system.mainTask().channel(urls.size())
10
+
11
+ 1.to(1000).each {_ =>
12
+ system.mainTask().spawn {task =>
13
+ let url = urlChannel.read()
14
+ let html = system.httpClient().fetch(url).readText()
15
+ htmlChannel.write(html)
16
+ }
17
+ }
18
+
19
+ 1.to(10).each {_ =>
20
+ system.mainTask().spawn {task =>
21
+ let html = htmlChannel.read()
22
+ let result = scrape(html)
23
+ resultChannel.write(result)
24
+ }
25
+ }
26
+
27
+ urls.each {url => urlChannel.write(url)}
28
+ let results = urls.map {_ => resultChannel.read()}
29
+ system.writeText(results.join("\n"))
30
+
31
+ }
32
+
33
+ scrape(html: String): String {
34
+ html // Uhm...
35
+ }
36
+
37
+ foo() {
38
+
39
+ let result = urls.toStream()
40
+ .parallelMap(threads = 1000) {url => download(url)}
41
+ .parallelMap(threads = 10) {result => result.map(scrape)}
42
+
43
+ let result = urls.toStream()
44
+ .parallelMap(threads = 1000) {task, url => task.timeout(Duration(5)) {download(url)}}
45
+ .parallelMap(threads = 10) {_, result => result.map(scrape)}
46
+
47
+ let result = urls.toStream()
48
+ .parallelMap(1000) {task, url => task.deadline(task.now().add(Duration(5))) {download(url)}}
49
+ .parallelMap(10) {_, result => result.map(scrape)}
50
+
51
+ }