firefly-compiler 0.5.39 → 0.5.41

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 (129) hide show
  1. package/.hintrc +4 -4
  2. package/.vscode/settings.json +4 -4
  3. package/bin/Release.ff +158 -157
  4. package/bin/firefly.mjs +1 -1
  5. package/compiler/Builder.ff +275 -275
  6. package/compiler/Compiler.ff +234 -234
  7. package/compiler/Dependencies.ff +186 -186
  8. package/compiler/DependencyLock.ff +17 -17
  9. package/compiler/JsEmitter.ff +1437 -1437
  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.json +5 -5
  14. package/core/.firefly/package.ff +2 -2
  15. package/core/Any.ff +25 -25
  16. package/core/Array.ff +298 -298
  17. package/core/Atomic.ff +63 -63
  18. package/core/Box.ff +7 -7
  19. package/core/BrowserSystem.ff +40 -40
  20. package/core/BuildSystem.ff +156 -156
  21. package/core/Crypto.ff +94 -94
  22. package/core/Equal.ff +41 -41
  23. package/core/Error.ff +25 -25
  24. package/core/HttpClient.ff +142 -142
  25. package/core/Instant.ff +24 -24
  26. package/core/Js.ff +305 -305
  27. package/core/JsSystem.ff +135 -135
  28. package/core/Json.ff +423 -423
  29. package/core/List.ff +482 -482
  30. package/core/Lock.ff +108 -108
  31. package/core/NodeSystem.ff +198 -198
  32. package/core/Ordering.ff +160 -160
  33. package/core/Path.ff +377 -378
  34. package/core/Queue.ff +90 -90
  35. package/core/Random.ff +140 -140
  36. package/core/RbMap.ff +216 -216
  37. package/core/Show.ff +44 -44
  38. package/core/SourceLocation.ff +68 -68
  39. package/core/Task.ff +165 -165
  40. package/experimental/benchmarks/ListGrab.ff +23 -23
  41. package/experimental/benchmarks/ListGrab.java +55 -55
  42. package/experimental/benchmarks/Pyrotek45.ff +30 -30
  43. package/experimental/benchmarks/Pyrotek45.java +64 -64
  44. package/experimental/bidirectional/Bidi.ff +88 -88
  45. package/experimental/lines/Main.ff +40 -40
  46. package/experimental/random/Index.ff +53 -53
  47. package/experimental/random/Process.ff +120 -120
  48. package/experimental/random/RunLength.ff +65 -65
  49. package/experimental/random/Scrape.ff +51 -51
  50. package/experimental/random/Symbols.ff +73 -73
  51. package/experimental/random/Tensor.ff +52 -52
  52. package/experimental/random/Units.ff +36 -36
  53. package/experimental/s3/S3TestAuthorizationHeader.ff +39 -39
  54. package/experimental/s3/S3TestPut.ff +16 -16
  55. package/experimental/tests/TestJson.ff +26 -26
  56. package/firefly.sh +0 -0
  57. package/fireflysite/.firefly/package.ff +4 -4
  58. package/fireflysite/CommunityOverview.ff +20 -20
  59. package/fireflysite/CountingButtonDemo.ff +58 -58
  60. package/fireflysite/DocumentParser.ff +325 -325
  61. package/fireflysite/ExamplesOverview.ff +40 -40
  62. package/fireflysite/FrontPage.ff +344 -344
  63. package/fireflysite/GettingStarted.ff +45 -45
  64. package/fireflysite/Guide.ff +456 -456
  65. package/fireflysite/Main.ff +163 -163
  66. package/fireflysite/MatchingPasswordsDemo.ff +82 -82
  67. package/fireflysite/PackagesOverview.ff +49 -49
  68. package/fireflysite/PostgresqlDemo.ff +34 -34
  69. package/fireflysite/ReferenceAll.ff +18 -18
  70. package/fireflysite/ReferenceIntroduction.ff +11 -11
  71. package/fireflysite/Styles.ff +567 -567
  72. package/fireflysite/Test.ff +121 -121
  73. package/fireflysite/assets/markdown/reference/BaseTypes.md +209 -209
  74. package/fireflysite/assets/markdown/reference/EmittedJavascript.md +65 -65
  75. package/fireflysite/assets/markdown/reference/Exceptions.md +101 -101
  76. package/fireflysite/assets/markdown/reference/FunctionsAndMethods.md +364 -364
  77. package/fireflysite/assets/markdown/reference/JavascriptInterop.md +235 -235
  78. package/fireflysite/assets/markdown/reference/ModulesAndPackages.md +162 -162
  79. package/fireflysite/assets/markdown/reference/OldStructuredConcurrency.md +48 -48
  80. package/fireflysite/assets/markdown/reference/PatternMatching.md +224 -224
  81. package/fireflysite/assets/markdown/reference/StatementsAndExpressions.md +86 -86
  82. package/fireflysite/assets/markdown/reference/StructuredConcurrency.md +99 -99
  83. package/fireflysite/assets/markdown/reference/TraitsAndInstances.md +100 -100
  84. package/fireflysite/assets/markdown/reference/UserDefinedTypes.md +184 -184
  85. package/fireflysite/assets/markdown/scratch/ControlFlow.md +136 -136
  86. package/fireflysite/assets/markdown/scratch/Toc.md +40 -40
  87. package/lsp/.firefly/package.ff +1 -1
  88. package/lsp/CompletionHandler.ff +827 -827
  89. package/lsp/Handler.ff +714 -714
  90. package/lsp/HoverHandler.ff +79 -79
  91. package/lsp/LanguageServer.ff +272 -272
  92. package/lsp/SignatureHelpHandler.ff +55 -55
  93. package/lsp/SymbolHandler.ff +181 -181
  94. package/lsp/TestReferences.ff +17 -17
  95. package/lsp/TestReferencesCase.ff +7 -7
  96. package/lsp/stderr.txt +1 -1
  97. package/lsp/stdout.txt +34 -34
  98. package/lux/.firefly/package.ff +1 -1
  99. package/lux/Css.ff +648 -648
  100. package/lux/CssTest.ff +48 -48
  101. package/lux/Lux.ff +608 -608
  102. package/lux/LuxEvent.ff +79 -79
  103. package/lux/Main.ff +123 -123
  104. package/lux/Main2.ff +143 -143
  105. package/lux/TestDry.ff +28 -28
  106. package/output/js/ff/compiler/Builder.mjs +36 -36
  107. package/output/js/ff/core/Path.mjs +0 -2
  108. package/package.json +1 -1
  109. package/rpc/.firefly/package.ff +1 -1
  110. package/rpc/Rpc.ff +70 -70
  111. package/s3/.firefly/package.ff +1 -1
  112. package/s3/S3.ff +92 -92
  113. package/vscode/LICENSE.txt +21 -21
  114. package/vscode/Prepublish.ff +15 -15
  115. package/vscode/README.md +16 -16
  116. package/vscode/client/package-lock.json +544 -544
  117. package/vscode/client/package.json +22 -22
  118. package/vscode/client/src/extension.ts +104 -104
  119. package/vscode/icons/firefly-icon.svg +10 -10
  120. package/vscode/language-configuration.json +61 -61
  121. package/vscode/package-lock.json +3623 -3623
  122. package/vscode/package.json +1 -1
  123. package/vscode/snippets.json +241 -241
  124. package/vscode/syntaxes/firefly-markdown-injection.json +45 -45
  125. package/webserver/.firefly/include/package.json +5 -5
  126. package/webserver/.firefly/package.ff +2 -2
  127. package/webserver/WebServer.ff +647 -647
  128. package/websocket/.firefly/package.ff +1 -1
  129. package/websocket/WebSocket.ff +100 -100
package/core/Atomic.ff CHANGED
@@ -1,63 +1,63 @@
1
- class Atomic[T] {}
2
-
3
- new[T](value: T): Atomic[T] {
4
- Js->(value = value!)?
5
- }
6
-
7
- extend self[T]: Atomic[T] {
8
-
9
- modify(body: T => T): T {
10
- if(Js.inAsync()) {
11
- mutable currentValue = self!->value
12
- mutable newValue = body(self!->value?)
13
- while {currentValue !== self!->value} {
14
- currentValue = self!->value
15
- newValue = body(self!->value?)
16
- }
17
- self!->value = newValue!
18
- newValue
19
- } else {
20
- let newValue = body(self!->value?)
21
- self!->value = newValue!
22
- newValue
23
- }
24
- }
25
-
26
- getAndModify(body: T => T): T {
27
- mutable currentValue = self!->value
28
- if(Js.inAsync()) {
29
- mutable newValue = body(self!->value?)
30
- while {currentValue !== self!->value} {
31
- currentValue = self!->value
32
- newValue = body(self!->value?)
33
- }
34
- self!->value = newValue!
35
- currentValue?
36
- } else {
37
- let newValue = body(self!->value?)
38
- self!->value = newValue!
39
- currentValue?
40
- }
41
- }
42
-
43
- get(): T {
44
- self!->value?
45
- }
46
-
47
- set(value: T): Unit {
48
- self!->value = value!
49
- }
50
-
51
- getAndSet(newValue: T): T {
52
- let currentValue = self!->value
53
- self!->value = newValue!
54
- currentValue?
55
- }
56
-
57
- compareAndSet(currentValue: T, newValue: T): Bool {
58
- if(self!->value !== currentValue!) {False} else:
59
- self!->value = newValue!
60
- True
61
- }
62
-
63
- }
1
+ class Atomic[T] {}
2
+
3
+ new[T](value: T): Atomic[T] {
4
+ Js->(value = value!)?
5
+ }
6
+
7
+ extend self[T]: Atomic[T] {
8
+
9
+ modify(body: T => T): T {
10
+ if(Js.inAsync()) {
11
+ mutable currentValue = self!->value
12
+ mutable newValue = body(self!->value?)
13
+ while {currentValue !== self!->value} {
14
+ currentValue = self!->value
15
+ newValue = body(self!->value?)
16
+ }
17
+ self!->value = newValue!
18
+ newValue
19
+ } else {
20
+ let newValue = body(self!->value?)
21
+ self!->value = newValue!
22
+ newValue
23
+ }
24
+ }
25
+
26
+ getAndModify(body: T => T): T {
27
+ mutable currentValue = self!->value
28
+ if(Js.inAsync()) {
29
+ mutable newValue = body(self!->value?)
30
+ while {currentValue !== self!->value} {
31
+ currentValue = self!->value
32
+ newValue = body(self!->value?)
33
+ }
34
+ self!->value = newValue!
35
+ currentValue?
36
+ } else {
37
+ let newValue = body(self!->value?)
38
+ self!->value = newValue!
39
+ currentValue?
40
+ }
41
+ }
42
+
43
+ get(): T {
44
+ self!->value?
45
+ }
46
+
47
+ set(value: T): Unit {
48
+ self!->value = value!
49
+ }
50
+
51
+ getAndSet(newValue: T): T {
52
+ let currentValue = self!->value
53
+ self!->value = newValue!
54
+ currentValue?
55
+ }
56
+
57
+ compareAndSet(currentValue: T, newValue: T): Bool {
58
+ if(self!->value !== currentValue!) {False} else:
59
+ self!->value = newValue!
60
+ True
61
+ }
62
+
63
+ }
package/core/Box.ff CHANGED
@@ -1,7 +1,7 @@
1
- class Box[T](mutable value: T)
2
-
3
- extend self[T]: Box[T] {
4
- modify(body: T => T): Unit {
5
- self.value = body(self.value)
6
- }
7
- }
1
+ class Box[T](mutable value: T)
2
+
3
+ extend self[T]: Box[T] {
4
+ modify(body: T => T): Unit {
5
+ self.value = body(self.value)
6
+ }
7
+ }
@@ -1,40 +1,40 @@
1
- capability BrowserSystem {}
2
-
3
- extend self: BrowserSystem {
4
-
5
- httpClient(): HttpClient {
6
- Js.globalThis()?
7
- }
8
-
9
- mainTask(): Task {
10
- self!->"task_"?
11
- }
12
-
13
- crypto(): Crypto {
14
- Js->crypto?
15
- }
16
-
17
- js(): JsSystem {
18
- Js.globalThis()?
19
- }
20
-
21
- url(): String {
22
- Js->location->href?
23
- }
24
-
25
- urlPath(): String {
26
- Js->location->pathname?
27
- }
28
-
29
- urlQuery(name: String): Option[String] {
30
- let param = Js->URLSearchParams->(Js->location->search)->get(name)
31
- if(param.isNullOrUndefined()) {None} else:
32
- Some(param?)
33
- }
34
-
35
- urlFragment(): Option[String] {
36
- if(!Js->location->hash->startsWith("#")?) {None} else:
37
- Some(Js->location->hash->slice(1)?)
38
- }
39
-
40
- }
1
+ capability BrowserSystem {}
2
+
3
+ extend self: BrowserSystem {
4
+
5
+ httpClient(): HttpClient {
6
+ Js.globalThis()?
7
+ }
8
+
9
+ mainTask(): Task {
10
+ self!->"task_"?
11
+ }
12
+
13
+ crypto(): Crypto {
14
+ Js->crypto?
15
+ }
16
+
17
+ js(): JsSystem {
18
+ Js.globalThis()?
19
+ }
20
+
21
+ url(): String {
22
+ Js->location->href?
23
+ }
24
+
25
+ urlPath(): String {
26
+ Js->location->pathname?
27
+ }
28
+
29
+ urlQuery(name: String): Option[String] {
30
+ let param = Js->URLSearchParams->(Js->location->search)->get(name)
31
+ if(param.isNullOrUndefined()) {None} else:
32
+ Some(param?)
33
+ }
34
+
35
+ urlFragment(): Option[String] {
36
+ if(!Js->location->hash->startsWith("#")?) {None} else:
37
+ Some(Js->location->hash->slice(1)?)
38
+ }
39
+
40
+ }
@@ -1,156 +1,156 @@
1
- capability BuildSystem {}
2
- capability BrowserCode(packageGroup: String, packageName: String, mainFile: Path, assetSystem: AssetSystem)
3
- capability BrowserBundle(assetSystem: AssetSystem)
4
-
5
- extend self: BuildSystem {
6
-
7
- compileForBrowser(mainFile: String): BrowserCode {
8
- // TODO: Check that the mainFile is in the current package directory
9
- internalCompile(self, internalPath(self, mainFile), "browser")
10
- let streams = internalListDirectory(internalPath(self, ".firefly/output/browser"))
11
- let mainPackagePair = internalMainPackagePair(self)
12
- BrowserCode(
13
- packageGroup = mainPackagePair.first
14
- packageName = mainPackagePair.second
15
- mainFile = internalPath(self, mainFile)
16
- assetSystem = AssetSystem(streams.toMap())
17
- )
18
- }
19
-
20
- buildMode(): Bool {
21
- !!self!->"buildMode_"?
22
- }
23
-
24
- setAssets(assetSystem: AssetSystem): Unit {
25
- self!->"assets_" = assetSystem!
26
- }
27
-
28
- packageAssets(): AssetSystem {
29
- let streams = internalListDirectory(internalPath(self, "."))
30
- AssetSystem(streams.toMap())
31
- }
32
-
33
- dependencyAssets(user: String, package: String): AssetSystem {
34
- panic("dependencyAssets not yet implemented")
35
- }
36
-
37
- arguments(): List[String] {
38
- self!->"array_"?
39
- }
40
-
41
- mainTask(): Task {
42
- self!->"task_"?
43
- }
44
-
45
- crypto(): Crypto {
46
- Js->crypto?
47
- }
48
-
49
- }
50
-
51
- extend self: BrowserCode {
52
-
53
- assets(): AssetSystem {
54
- self.assetSystem
55
- }
56
-
57
- bundle(minify: Bool = True, sourceMap: Bool = False): BrowserBundle {
58
- let prefix = ".firefly/output/browser"
59
- let mainJsBaseFile = self.mainFile.base().removeLast(".ff").grab() + ".mjs"
60
- let mainJsFile = prefix + "/" + self.packageGroup + "/" + self.packageName + "/" + mainJsBaseFile
61
- let mainDirectory = self.mainFile.parent().grab()
62
- let file = prefix + "/Main.bundle.js"
63
- internalCallEsBuild(self, mainJsFile = mainJsFile, outputPath = file, minify = minify, sourceMap = sourceMap)
64
- let assets = AssetSystem([
65
- Pair(file.dropFirst(prefix.size()), {mainDirectory.path(file).readStream()})
66
- ...if(sourceMap) {[
67
- Pair(file.dropFirst(prefix.size()) + ".map", {mainDirectory.path(file + ".map").readStream()})
68
- ]} else {[]}
69
- ].toMap())
70
- BrowserBundle(assets)
71
- }
72
-
73
- }
74
-
75
- extend self: BrowserBundle {
76
-
77
- assets(): AssetSystem {
78
- self.assetSystem
79
- }
80
-
81
- }
82
-
83
-
84
- internalCallEsBuild(
85
- self: BrowserCode
86
- mainJsFile: String
87
- outputPath: String
88
- minify: Bool
89
- sourceMap: Bool
90
- ): Unit {
91
- let esbuild = Js.import("esbuild")
92
- esbuild->build(Js->(
93
- stdin = Js->(contents = "import {$run$} from './" + mainJsFile + "';", resolveDir = ".")
94
- bundle = True
95
- minify = minify
96
- sourcemap = sourceMap
97
- platform = "browser"
98
- target = "es2017"
99
- external = ["../../../node_modules/*"] // TODO
100
- outfile = outputPath
101
- ))
102
- }
103
-
104
- internalNodeCallEsBuild(
105
- self: NodeSystem
106
- mainJsFile: String
107
- outputPath: String
108
- minify: Bool
109
- ): Unit {
110
- let esbuild = Js.import("esbuild")
111
- esbuild->build(Js->(
112
- entryPoints = [mainJsFile]
113
- bundle = True
114
- minify = minify
115
- sourcemap = True
116
- platform = "node"
117
- target = "es2017"
118
- external = ["../../../node_modules/*"] // TODO
119
- outfile = outputPath
120
- ))
121
- }
122
-
123
- internalListDirectory(path: Path): List[Pair[String, () => Stream[Buffer]]] {
124
- function go(currentPath: Path): Stream[Path] {
125
- currentPath.entries().flatMap {file =>
126
- if(file.isDirectory()) {
127
- go(file.path())
128
- } else {
129
- [file.path()].toStream()
130
- }
131
- }
132
- }
133
- go(path).map {file =>
134
- Pair("/" + file.relativeTo(path).replace("\\", "/"), {file.readStream()})
135
- }.toList()
136
- }
137
-
138
- internalPath(buildSystem: BuildSystem, absoluteOrRelative: String): Path {
139
- let nodePath = Js.import("path")
140
- Path(nodePath->resolve(absoluteOrRelative)?)
141
- }
142
-
143
- internalCompile(buildSystem: BuildSystem, mainFile: Path, target: String): Unit {
144
- // Ported from the old FFI. It's quite fragile w.r.t. changes in code generation.
145
- Js.await(Js.rawIdentifier("$firefly_compiler")->"buildViaBuildSystem_$"(
146
- buildSystem!
147
- internalPath(buildSystem, buildSystem!->"fireflyPath_"?)!
148
- mainFile.base()
149
- target
150
- Js.currentTask()!
151
- ))
152
- }
153
-
154
- internalMainPackagePair(buildSystem: BuildSystem): Pair[String, String] {
155
- Pair(buildSystem!->"mainPackagePair_"->"group_"?, buildSystem!->"mainPackagePair_"->"name_"?)
156
- }
1
+ capability BuildSystem {}
2
+ capability BrowserCode(packageGroup: String, packageName: String, mainFile: Path, assetSystem: AssetSystem)
3
+ capability BrowserBundle(assetSystem: AssetSystem)
4
+
5
+ extend self: BuildSystem {
6
+
7
+ compileForBrowser(mainFile: String): BrowserCode {
8
+ // TODO: Check that the mainFile is in the current package directory
9
+ internalCompile(self, internalPath(self, mainFile), "browser")
10
+ let streams = internalListDirectory(internalPath(self, ".firefly/output/browser"))
11
+ let mainPackagePair = internalMainPackagePair(self)
12
+ BrowserCode(
13
+ packageGroup = mainPackagePair.first
14
+ packageName = mainPackagePair.second
15
+ mainFile = internalPath(self, mainFile)
16
+ assetSystem = AssetSystem(streams.toMap())
17
+ )
18
+ }
19
+
20
+ buildMode(): Bool {
21
+ !!self!->"buildMode_"?
22
+ }
23
+
24
+ setAssets(assetSystem: AssetSystem): Unit {
25
+ self!->"assets_" = assetSystem!
26
+ }
27
+
28
+ packageAssets(): AssetSystem {
29
+ let streams = internalListDirectory(internalPath(self, "."))
30
+ AssetSystem(streams.toMap())
31
+ }
32
+
33
+ dependencyAssets(user: String, package: String): AssetSystem {
34
+ panic("dependencyAssets not yet implemented")
35
+ }
36
+
37
+ arguments(): List[String] {
38
+ self!->"array_"?
39
+ }
40
+
41
+ mainTask(): Task {
42
+ self!->"task_"?
43
+ }
44
+
45
+ crypto(): Crypto {
46
+ Js->crypto?
47
+ }
48
+
49
+ }
50
+
51
+ extend self: BrowserCode {
52
+
53
+ assets(): AssetSystem {
54
+ self.assetSystem
55
+ }
56
+
57
+ bundle(minify: Bool = True, sourceMap: Bool = False): BrowserBundle {
58
+ let prefix = ".firefly/output/browser"
59
+ let mainJsBaseFile = self.mainFile.base().removeLast(".ff").grab() + ".mjs"
60
+ let mainJsFile = prefix + "/" + self.packageGroup + "/" + self.packageName + "/" + mainJsBaseFile
61
+ let mainDirectory = self.mainFile.parent().grab()
62
+ let file = prefix + "/Main.bundle.js"
63
+ internalCallEsBuild(self, mainJsFile = mainJsFile, outputPath = file, minify = minify, sourceMap = sourceMap)
64
+ let assets = AssetSystem([
65
+ Pair(file.dropFirst(prefix.size()), {mainDirectory.path(file).readStream()})
66
+ ...if(sourceMap) {[
67
+ Pair(file.dropFirst(prefix.size()) + ".map", {mainDirectory.path(file + ".map").readStream()})
68
+ ]} else {[]}
69
+ ].toMap())
70
+ BrowserBundle(assets)
71
+ }
72
+
73
+ }
74
+
75
+ extend self: BrowserBundle {
76
+
77
+ assets(): AssetSystem {
78
+ self.assetSystem
79
+ }
80
+
81
+ }
82
+
83
+
84
+ internalCallEsBuild(
85
+ self: BrowserCode
86
+ mainJsFile: String
87
+ outputPath: String
88
+ minify: Bool
89
+ sourceMap: Bool
90
+ ): Unit {
91
+ let esbuild = Js.import("esbuild")
92
+ esbuild->build(Js->(
93
+ stdin = Js->(contents = "import {$run$} from './" + mainJsFile + "';", resolveDir = ".")
94
+ bundle = True
95
+ minify = minify
96
+ sourcemap = sourceMap
97
+ platform = "browser"
98
+ target = "es2017"
99
+ external = ["../../../node_modules/*"] // TODO
100
+ outfile = outputPath
101
+ ))
102
+ }
103
+
104
+ internalNodeCallEsBuild(
105
+ self: NodeSystem
106
+ mainJsFile: String
107
+ outputPath: String
108
+ minify: Bool
109
+ ): Unit {
110
+ let esbuild = Js.import("esbuild")
111
+ esbuild->build(Js->(
112
+ entryPoints = [mainJsFile]
113
+ bundle = True
114
+ minify = minify
115
+ sourcemap = True
116
+ platform = "node"
117
+ target = "es2017"
118
+ external = ["../../../node_modules/*"] // TODO
119
+ outfile = outputPath
120
+ ))
121
+ }
122
+
123
+ internalListDirectory(path: Path): List[Pair[String, () => Stream[Buffer]]] {
124
+ function go(currentPath: Path): Stream[Path] {
125
+ currentPath.entries().flatMap {file =>
126
+ if(file.isDirectory()) {
127
+ go(file.path())
128
+ } else {
129
+ [file.path()].toStream()
130
+ }
131
+ }
132
+ }
133
+ go(path).map {file =>
134
+ Pair("/" + file.relativeTo(path).replace("\\", "/"), {file.readStream()})
135
+ }.toList()
136
+ }
137
+
138
+ internalPath(buildSystem: BuildSystem, absoluteOrRelative: String): Path {
139
+ let nodePath = Js.import("path")
140
+ Path(nodePath->resolve(absoluteOrRelative)?)
141
+ }
142
+
143
+ internalCompile(buildSystem: BuildSystem, mainFile: Path, target: String): Unit {
144
+ // Ported from the old FFI. It's quite fragile w.r.t. changes in code generation.
145
+ Js.await(Js.rawIdentifier("$firefly_compiler")->"buildViaBuildSystem_$"(
146
+ buildSystem!
147
+ internalPath(buildSystem, buildSystem!->"fireflyPath_"?)!
148
+ mainFile.base()
149
+ target
150
+ Js.currentTask()!
151
+ ))
152
+ }
153
+
154
+ internalMainPackagePair(buildSystem: BuildSystem): Pair[String, String] {
155
+ Pair(buildSystem!->"mainPackagePair_"->"group_"?, buildSystem!->"mainPackagePair_"->"name_"?)
156
+ }