From 487fbf7f8175ce091ff42afe3e3828f7f91c0493 Mon Sep 17 00:00:00 2001 From: Marcin Kostrzewa Date: Wed, 15 Jun 2022 19:48:53 +0200 Subject: [PATCH 1/6] introduce a micro stdlib --- .../test/instrument/RuntimeErrorsTest.scala | 2 +- .../instrument/RuntimeInstrumentTest.scala | 2 +- .../RuntimeProjectContextTest.scala | 2 +- .../test/instrument/RuntimeServerTest.scala | 2 +- .../RuntimeSuggestionUpdatesTest.scala | 2 +- .../interpreter/test/InterpreterTest.scala | 2 +- .../enso/interpreter/test/PackageTest.scala | 2 +- .../interpreter/test/semantic/TextTest.scala | 7 +++-- .../editions/0.0.0-dev.yaml | 8 ++++++ .../lib/Standard/Base/0.0.0-dev/manifest.yaml | 3 +++ .../lib/Standard/Base/0.0.0-dev/package.yaml | 10 +++++++ .../Standard/Base/0.0.0-dev/src/Data/Any.enso | 3 +++ .../Base/0.0.0-dev/src/Data/Array.enso | 7 +++++ .../Base/0.0.0-dev/src/Data/Boolean.enso | 11 ++++++++ .../Base/0.0.0-dev/src/Data/List.enso | 3 +++ .../Base/0.0.0-dev/src/Data/Numbers.enso | 7 +++++ .../Base/0.0.0-dev/src/Data/Text.enso | 3 +++ .../Base/0.0.0-dev/src/Data/Time/Date.enso | 11 ++++++++ .../Base/0.0.0-dev/src/Error/Common.enso | 27 +++++++++++++++++++ .../lib/Standard/Base/0.0.0-dev/src/IO.enso | 3 +++ .../lib/Standard/Base/0.0.0-dev/src/Main.enso | 20 ++++++++++++++ .../Standard/Base/0.0.0-dev/src/Nothing.enso | 3 +++ .../Standard/Base/0.0.0-dev/src/Polyglot.enso | 13 +++++++++ .../Base/0.0.0-dev/src/Polyglot/Java.enso | 1 + .../Base/0.0.0-dev/src/Runtime/Debug.enso | 2 ++ .../Base/0.0.0-dev/src/Runtime/Resource.enso | 10 +++++++ .../Base/0.0.0-dev/src/Runtime/State.enso | 3 +++ .../Base/0.0.0-dev/src/Runtime/Thread.enso | 1 + .../Standard/Base/0.0.0-dev/src/System.enso | 4 +++ 29 files changed, 163 insertions(+), 11 deletions(-) create mode 100644 test/micro-distribution/editions/0.0.0-dev.yaml create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/manifest.yaml create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/package.yaml create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Any.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Array.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Boolean.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/List.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Numbers.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Text.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Time/Date.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Error/Common.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/IO.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Main.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Nothing.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Polyglot.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Polyglot/Java.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/Debug.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/Resource.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/State.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/Thread.enso create mode 100644 test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/System.enso diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala index 20c99d0a1fa0..93d75f4a3204 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala @@ -69,7 +69,7 @@ class RuntimeErrorsTest .option(RuntimeOptions.INTERACTIVE_MODE, "true") .option( RuntimeOptions.LANGUAGE_HOME_OVERRIDE, - Paths.get("../../distribution/component").toFile.getAbsolutePath + Paths.get("../../test/micro-distribution/component").toFile.getAbsolutePath ) .out(out) .serverTransport(runtimeServerEmulator.makeServerTransport) diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala index 5883a7fbc52d..96e8a2ec64b5 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala @@ -62,7 +62,7 @@ class RuntimeInstrumentTest .option(RuntimeOptions.INTERACTIVE_MODE, "true") .option( RuntimeOptions.LANGUAGE_HOME_OVERRIDE, - Paths.get("../../distribution/component").toFile.getAbsolutePath + Paths.get("../../test/micro-distribution/component").toFile.getAbsolutePath ) .out(out) .serverTransport(runtimeServerEmulator.makeServerTransport) diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala index c3ee990c7e38..bb81be1ea50e 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala @@ -22,7 +22,7 @@ class RuntimeProjectContextTest extends AnyWordSpec with Matchers { ) .option( RuntimeOptions.LANGUAGE_HOME_OVERRIDE, - Paths.get("../../distribution/component").toFile.getAbsolutePath + Paths.get("../../test/micro-distribution/component").toFile.getAbsolutePath ) .option(RuntimeOptions.LOG_LEVEL, "WARNING") .build() diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala index 8e6613d59a6c..6e358e044eee 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala @@ -67,7 +67,7 @@ class RuntimeServerTest .option(RuntimeOptions.INTERACTIVE_MODE, "true") .option( RuntimeOptions.LANGUAGE_HOME_OVERRIDE, - Paths.get("../../distribution/component").toFile.getAbsolutePath + Paths.get("../../test/micro-distribution/component").toFile.getAbsolutePath ) .logHandler(logOut) .out(out) diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala index 4285fcb162a8..04125ac5c3cd 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala @@ -55,7 +55,7 @@ class RuntimeSuggestionUpdatesTest .option(RuntimeOptions.INTERACTIVE_MODE, "true") .option( RuntimeOptions.LANGUAGE_HOME_OVERRIDE, - Paths.get("../../distribution/component").toFile.getAbsolutePath + Paths.get("../../test/micro-distribution/component").toFile.getAbsolutePath ) .out(out) .serverTransport(runtimeServerEmulator.makeServerTransport) diff --git a/engine/runtime/src/test/scala/org/enso/interpreter/test/InterpreterTest.scala b/engine/runtime/src/test/scala/org/enso/interpreter/test/InterpreterTest.scala index 1f2e651f5903..23b13687d1fd 100644 --- a/engine/runtime/src/test/scala/org/enso/interpreter/test/InterpreterTest.scala +++ b/engine/runtime/src/test/scala/org/enso/interpreter/test/InterpreterTest.scala @@ -109,7 +109,7 @@ class InterpreterContext( .in(in) .option( RuntimeOptions.LANGUAGE_HOME_OVERRIDE, - Paths.get("../../distribution/component").toFile.getAbsolutePath + Paths.get("../../test/micro-distribution/component").toFile.getAbsolutePath ) .serverTransport { (uri, peer) => if (uri.toString == DebugServerInfo.URI) { diff --git a/engine/runtime/src/test/scala/org/enso/interpreter/test/PackageTest.scala b/engine/runtime/src/test/scala/org/enso/interpreter/test/PackageTest.scala index aa2c5fb1aaef..fb44f8c968d0 100644 --- a/engine/runtime/src/test/scala/org/enso/interpreter/test/PackageTest.scala +++ b/engine/runtime/src/test/scala/org/enso/interpreter/test/PackageTest.scala @@ -25,7 +25,7 @@ trait PackageTest extends AnyFlatSpec with Matchers with ValueEquality { .option(RuntimeOptions.PROJECT_ROOT, pkgPath.getAbsolutePath) .option( RuntimeOptions.LANGUAGE_HOME_OVERRIDE, - Paths.get("../../distribution/component").toFile.getAbsolutePath + Paths.get("../../test/micro-distribution/component").toFile.getAbsolutePath ) .option(RuntimeOptions.STRICT_ERRORS, "true") .option(RuntimeOptions.DISABLE_IR_CACHES, "true") diff --git a/engine/runtime/src/test/scala/org/enso/interpreter/test/semantic/TextTest.scala b/engine/runtime/src/test/scala/org/enso/interpreter/test/semantic/TextTest.scala index c92ea4bbb975..6cedc163591a 100644 --- a/engine/runtime/src/test/scala/org/enso/interpreter/test/semantic/TextTest.scala +++ b/engine/runtime/src/test/scala/org/enso/interpreter/test/semantic/TextTest.scala @@ -105,16 +105,15 @@ class TextTest extends InterpreterTest { "support converting values to display texts" in { val code = """ - |from Standard.Base.Data.List import Cons + |from Standard.Base.Data.List import Cons, Nil |from Standard.Base.Error.Common import all - |import Standard.Base.Data.Text |import Standard.Base.IO |import Standard.Base.Nothing | |main = | IO.println (Cons Nothing Nothing).to_display_text | IO.println (Syntax_Error "foo").to_display_text - | IO.println (Type_Error Nothing Text "myvar").to_display_text + | IO.println (Type_Error Nothing Nil "myvar").to_display_text | IO.println (Compile_Error "error :(").to_display_text | IO.println (Inexhaustive_Pattern_Match_Error 32).to_display_text | IO.println (Arithmetic_Error "cannot frobnicate quaternions").to_display_text @@ -126,7 +125,7 @@ class TextTest extends InterpreterTest { consumeOut shouldEqual List( "Cons", "Syntax error: foo", - "Type error: expected `myvar` to be Nothing, but got Text.", + "Type error: expected `myvar` to be Nothing, but got Nil.", "Compile error: error :(", "Inexhaustive pattern match: no branch matches 32 (Integer).", "Arithmetic error: cannot frobnicate quaternions", diff --git a/test/micro-distribution/editions/0.0.0-dev.yaml b/test/micro-distribution/editions/0.0.0-dev.yaml new file mode 100644 index 000000000000..cfbefa0d4cc7 --- /dev/null +++ b/test/micro-distribution/editions/0.0.0-dev.yaml @@ -0,0 +1,8 @@ +engine-version: 0.0.0-dev +repositories: + - name: main + url: https://libraries.release.enso.org/libraries +libraries: + - name: Standard.Base + repository: main + version: 0.0.0-dev diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/manifest.yaml b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/manifest.yaml new file mode 100644 index 000000000000..8069a32f679c --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/manifest.yaml @@ -0,0 +1,3 @@ +archives: +- main.tgz +dependencies: [] diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/package.yaml b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/package.yaml new file mode 100644 index 000000000000..6f3c3d6279d5 --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/package.yaml @@ -0,0 +1,10 @@ +name: Base +namespace: Standard +version: 0.0.0-dev +license: APLv2 +authors: + - name: Enso Team + email: contact@enso.org +maintainers: + - name: Enso Team + email: contact@enso.org diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Any.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Any.enso new file mode 100644 index 000000000000..3ecca84d2874 --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Any.enso @@ -0,0 +1,3 @@ +type Any + @Builtin_Type + type Any diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Array.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Array.enso new file mode 100644 index 000000000000..d0ea4bed7534 --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Array.enso @@ -0,0 +1,7 @@ +type Array + @Builtin_Type + type Array + +new_1 item_1 = @Builtin_Method "Array.new_1" +new_2 item_1 item_2 = @Builtin_Method "Array.new_2" +empty = @Builtin_Method "Array.empty" diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Boolean.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Boolean.enso new file mode 100644 index 000000000000..104dbe50555a --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Boolean.enso @@ -0,0 +1,11 @@ +type Boolean + @Builtin_Type + type Boolean + + if_then_else ~on_true ~on_false = @Builtin_Method "Boolean.if_then_else" + +@Builtin_Type +type True + +@Builtin_Type +type False diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/List.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/List.enso new file mode 100644 index 000000000000..4a3a918b2d61 --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/List.enso @@ -0,0 +1,3 @@ +type List + type Nil + type Cons x xs diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Numbers.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Numbers.enso new file mode 100644 index 000000000000..6d7bd76076f2 --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Numbers.enso @@ -0,0 +1,7 @@ +type Number + @Builtin_Type + type Number + +type Integer + @Builtin_Type + type Integer diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Text.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Text.enso new file mode 100644 index 000000000000..67444c677b4d --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Text.enso @@ -0,0 +1,3 @@ +type Text + @Builtin_Type + type Text diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Time/Date.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Time/Date.enso new file mode 100644 index 000000000000..2d7e171fa8dd --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Data/Time/Date.enso @@ -0,0 +1,11 @@ +polyglot java import java.time.LocalDate +polyglot java import java.time.format.DateTimeFormatter + +new year (month = 1) (day = 1) = LocalDate.of year month day + +type Date + type Date internal_local_date + year = this . internal_local_date . getYear + month = this . internal_local_date . getMonthValue + day = this . internal_local_date . getDayOfMonth + to_text = DateTimeFormatter.ISO_LOCAL_DATE.format this.internal_local_date diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Error/Common.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Error/Common.enso new file mode 100644 index 000000000000..410aed727416 --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Error/Common.enso @@ -0,0 +1,27 @@ +type Panic + @Builtin_Type + type Panic + throw payload = @Builtin_Method "Panic.throw" + catch_primitive ~action handler = @Builtin_Method "Panic.catch_primitive" + +@Builtin_Type +type Syntax_Error message +@Builtin_Type +type Polyglot_Error cause +@Builtin_Type +type Arithmetic_Error message +@Builtin_Type +type Type_Error expected actual name +@Builtin_Type +type Compile_Error message +@Builtin_Type +type Inexhaustive_Pattern_Match_Error scrutinee +@Builtin_Type +type Arity_Error expected_min expected_max actual + +type Error + @Builtin_Type + type Error + throw payload = @Builtin_Method "Error.throw" + catch_primitive handler = @Builtin_Method "Error.catch_primitive" + catch (handler = x->x) = this.catch_primitive handler diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/IO.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/IO.enso new file mode 100644 index 000000000000..cdf1d068b965 --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/IO.enso @@ -0,0 +1,3 @@ +print_err message = @Builtin_Method "IO.print_err" +println message = @Builtin_Method "IO.println" +readln = @Builtin_Method "IO.readln" diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Main.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Main.enso new file mode 100644 index 000000000000..d377423e5911 --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Main.enso @@ -0,0 +1,20 @@ +import project.IO +export project.IO + +import project.Data.List +from project.Data.List export Nil, Cons, List + +import project.Polyglot +from project.Polyglot export all + +export project.Polyglot.Java +import project.Polyglot.Java + +import project.Data.Array +from project.Data.Array export Array + +import project.Error.Common +from project.Error.Common export all + +import project.Data.Numbers +from project.Data.Numbers export Number diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Nothing.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Nothing.enso new file mode 100644 index 000000000000..45f26b23b6a5 --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Nothing.enso @@ -0,0 +1,3 @@ +type Nothing + @Builtin_Type + type Nothing diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Polyglot.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Polyglot.enso new file mode 100644 index 000000000000..78a4b2a4de39 --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Polyglot.enso @@ -0,0 +1,13 @@ +type Polyglot + @Builtin_Type + type Polyglot +get_array_size array = @Builtin_Method "Polyglot.get_array_size" +execute callable arguments = @Builtin_Method "Polyglot.execute" +get_member object member_name = @Builtin_Method "Polyglot.get_member" +get_members object = @Builtin_Method "Polyglot.get_members" +new constructor arguments = @Builtin_Method "Polyglot.new" +invoke target name arguments = @Builtin_Method "Polyglot.invoke" +has_source_location value = @Builtin_Method "Polyglot.has_source_location" +get_source_location value = @Builtin_Method "Polyglot.get_source_location" +is_language_installed language_name = @Builtin_Method "Polyglot.is_language_installed" +get_executable_name = @Builtin_Method "Polyglot.get_executable_name" diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Polyglot/Java.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Polyglot/Java.enso new file mode 100644 index 000000000000..3109a2c05c88 --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Polyglot/Java.enso @@ -0,0 +1 @@ +lookup_class name = @Builtin_Method "Java.lookup_class" diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/Debug.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/Debug.enso new file mode 100644 index 000000000000..6200fe7acccf --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/Debug.enso @@ -0,0 +1,2 @@ +eval expression = @Builtin_Method "Debug.eval" +breakpoint = @Builtin_Method "Debug.breakpoint" diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/Resource.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/Resource.enso new file mode 100644 index 000000000000..b4b41e846658 --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/Resource.enso @@ -0,0 +1,10 @@ +bracket : Any -> (Any -> Nothing) -> (Any -> Any) -> Any +bracket ~constructor ~destructor ~action = @Builtin_Method "Resource.bracket" + +type Managed_Resource + @Builtin_Type + type Managed_Resource + register resource function = @Builtin_Method "Managed_Resource.register" + finalize = @Builtin_Method "Managed_Resource.finalize" + with ~action = @Builtin_Method "Managed_Resource.with" + take = @Builtin_Method "Managed_Resource.take" diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/State.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/State.enso new file mode 100644 index 000000000000..2edbda00b77a --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/State.enso @@ -0,0 +1,3 @@ +run key local_state ~computation = @Builtin_Method "State.run" +get key = @Builtin_Method "State.get" +put key new_state = @Builtin_Method "State.put" diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/Thread.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/Thread.enso new file mode 100644 index 000000000000..e8200caecae4 --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/Runtime/Thread.enso @@ -0,0 +1 @@ +with_interrupt_handler ~action ~interrupt_handler = @Builtin_Method "Thread.with_interrupt_handler" diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/System.enso b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/System.enso new file mode 100644 index 000000000000..5677608c602d --- /dev/null +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/src/System.enso @@ -0,0 +1,4 @@ +create_process command arguments input redirect_in redirect_out redirect_err = @Builtin_Method "System.create_process" + +@Builtin_Type +type System_Process_Result exit_code stdout stderr From bdd3015c1e6280345f3b6e350dafc35fd7016e81 Mon Sep 17 00:00:00 2001 From: Marcin Kostrzewa Date: Wed, 15 Jun 2022 20:15:58 +0200 Subject: [PATCH 2/6] you throw a yak at me, I'll shave it --- CHANGELOG.md | 2 ++ .../enso/interpreter/test/instrument/RuntimeErrorsTest.scala | 5 ++++- .../interpreter/test/instrument/RuntimeInstrumentTest.scala | 5 ++++- .../test/instrument/RuntimeProjectContextTest.scala | 5 ++++- .../enso/interpreter/test/instrument/RuntimeServerTest.scala | 5 ++++- .../test/instrument/RuntimeSuggestionUpdatesTest.scala | 5 ++++- .../scala/org/enso/interpreter/test/InterpreterTest.scala | 5 ++++- .../test/scala/org/enso/interpreter/test/PackageTest.scala | 5 ++++- 8 files changed, 30 insertions(+), 7 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 2027a0b53a2c..a56c3b19ea61 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -246,6 +246,7 @@ - [Added a full-blown DSL for builtins][3471] - [Lazy evaluation of RHS argument for || and &&][3492] - [Drop Core implementation of IR][3512] +- [Introduce a smaller version of the standard library, just for testing][3531] [3227]: https://github.com/enso-org/enso/pull/3227 [3248]: https://github.com/enso-org/enso/pull/3248 @@ -273,6 +274,7 @@ [3493]: https://github.com/enso-org/enso/pull/3493 [3505]: https://github.com/enso-org/enso/pull/3505 [3512]: https://github.com/enso-org/enso/pull/3512 +[3531]: https://github.com/enso-org/enso/pull/3531 # Enso 2.0.0-alpha.18 (2021-10-12) diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala index 93d75f4a3204..a8889d23c522 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala @@ -69,7 +69,10 @@ class RuntimeErrorsTest .option(RuntimeOptions.INTERACTIVE_MODE, "true") .option( RuntimeOptions.LANGUAGE_HOME_OVERRIDE, - Paths.get("../../test/micro-distribution/component").toFile.getAbsolutePath + Paths + .get("../../test/micro-distribution/component") + .toFile + .getAbsolutePath ) .out(out) .serverTransport(runtimeServerEmulator.makeServerTransport) diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala index 96e8a2ec64b5..21d54f990650 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala @@ -62,7 +62,10 @@ class RuntimeInstrumentTest .option(RuntimeOptions.INTERACTIVE_MODE, "true") .option( RuntimeOptions.LANGUAGE_HOME_OVERRIDE, - Paths.get("../../test/micro-distribution/component").toFile.getAbsolutePath + Paths + .get("../../test/micro-distribution/component") + .toFile + .getAbsolutePath ) .out(out) .serverTransport(runtimeServerEmulator.makeServerTransport) diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala index bb81be1ea50e..17333bc5753c 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala @@ -22,7 +22,10 @@ class RuntimeProjectContextTest extends AnyWordSpec with Matchers { ) .option( RuntimeOptions.LANGUAGE_HOME_OVERRIDE, - Paths.get("../../test/micro-distribution/component").toFile.getAbsolutePath + Paths + .get("../../test/micro-distribution/component") + .toFile + .getAbsolutePath ) .option(RuntimeOptions.LOG_LEVEL, "WARNING") .build() diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala index 6e358e044eee..20881dd96915 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala @@ -67,7 +67,10 @@ class RuntimeServerTest .option(RuntimeOptions.INTERACTIVE_MODE, "true") .option( RuntimeOptions.LANGUAGE_HOME_OVERRIDE, - Paths.get("../../test/micro-distribution/component").toFile.getAbsolutePath + Paths + .get("../../test/micro-distribution/component") + .toFile + .getAbsolutePath ) .logHandler(logOut) .out(out) diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala index 04125ac5c3cd..bcb7d3b5f2f0 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala @@ -55,7 +55,10 @@ class RuntimeSuggestionUpdatesTest .option(RuntimeOptions.INTERACTIVE_MODE, "true") .option( RuntimeOptions.LANGUAGE_HOME_OVERRIDE, - Paths.get("../../test/micro-distribution/component").toFile.getAbsolutePath + Paths + .get("../../test/micro-distribution/component") + .toFile + .getAbsolutePath ) .out(out) .serverTransport(runtimeServerEmulator.makeServerTransport) diff --git a/engine/runtime/src/test/scala/org/enso/interpreter/test/InterpreterTest.scala b/engine/runtime/src/test/scala/org/enso/interpreter/test/InterpreterTest.scala index 23b13687d1fd..db739244ca65 100644 --- a/engine/runtime/src/test/scala/org/enso/interpreter/test/InterpreterTest.scala +++ b/engine/runtime/src/test/scala/org/enso/interpreter/test/InterpreterTest.scala @@ -109,7 +109,10 @@ class InterpreterContext( .in(in) .option( RuntimeOptions.LANGUAGE_HOME_OVERRIDE, - Paths.get("../../test/micro-distribution/component").toFile.getAbsolutePath + Paths + .get("../../test/micro-distribution/component") + .toFile + .getAbsolutePath ) .serverTransport { (uri, peer) => if (uri.toString == DebugServerInfo.URI) { diff --git a/engine/runtime/src/test/scala/org/enso/interpreter/test/PackageTest.scala b/engine/runtime/src/test/scala/org/enso/interpreter/test/PackageTest.scala index fb44f8c968d0..a0b90e8bb566 100644 --- a/engine/runtime/src/test/scala/org/enso/interpreter/test/PackageTest.scala +++ b/engine/runtime/src/test/scala/org/enso/interpreter/test/PackageTest.scala @@ -25,7 +25,10 @@ trait PackageTest extends AnyFlatSpec with Matchers with ValueEquality { .option(RuntimeOptions.PROJECT_ROOT, pkgPath.getAbsolutePath) .option( RuntimeOptions.LANGUAGE_HOME_OVERRIDE, - Paths.get("../../test/micro-distribution/component").toFile.getAbsolutePath + Paths + .get("../../test/micro-distribution/component") + .toFile + .getAbsolutePath ) .option(RuntimeOptions.STRICT_ERRORS, "true") .option(RuntimeOptions.DISABLE_IR_CACHES, "true") From a61e4f61c4682f2c06047fcca955c04ec45b46fc Mon Sep 17 00:00:00 2001 From: Marcin Kostrzewa Date: Wed, 15 Jun 2022 20:26:31 +0200 Subject: [PATCH 3/6] formatit --- .../lib/Standard/Base/0.0.0-dev/manifest.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/manifest.yaml b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/manifest.yaml index 8069a32f679c..b58a01c9803c 100644 --- a/test/micro-distribution/lib/Standard/Base/0.0.0-dev/manifest.yaml +++ b/test/micro-distribution/lib/Standard/Base/0.0.0-dev/manifest.yaml @@ -1,3 +1,3 @@ archives: -- main.tgz + - main.tgz dependencies: [] From 0312191b35702b2ab67da7d6bef52b840edebd8d Mon Sep 17 00:00:00 2001 From: Marcin Kostrzewa Date: Wed, 15 Jun 2022 23:02:14 +0200 Subject: [PATCH 4/6] does it fix anything? --- .../main/java/org/enso/polyglot/RuntimeOptions.java | 6 ++++++ .../test/instrument/RuntimeErrorsTest.scala | 1 + .../test/instrument/RuntimeInstrumentTest.scala | 1 + .../test/instrument/RuntimeProjectContextTest.scala | 1 + .../test/instrument/RuntimeServerTest.scala | 1 + .../instrument/RuntimeSuggestionUpdatesTest.scala | 1 + .../java/org/enso/interpreter/OptionsHelper.java | 8 ++++++++ .../java/org/enso/interpreter/runtime/Context.java | 2 ++ .../scala/org/enso/compiler/PackageRepository.scala | 12 ++++++++---- .../org/enso/interpreter/test/InterpreterTest.scala | 1 + .../org/enso/interpreter/test/PackageTest.scala | 1 + 11 files changed, 31 insertions(+), 4 deletions(-) diff --git a/engine/polyglot-api/src/main/java/org/enso/polyglot/RuntimeOptions.java b/engine/polyglot-api/src/main/java/org/enso/polyglot/RuntimeOptions.java index 08e5af0fcc18..2cca1f686669 100644 --- a/engine/polyglot-api/src/main/java/org/enso/polyglot/RuntimeOptions.java +++ b/engine/polyglot-api/src/main/java/org/enso/polyglot/RuntimeOptions.java @@ -66,6 +66,11 @@ public class RuntimeOptions { private static final OptionDescriptor LANGUAGE_HOME_OVERRIDE_DESCRIPTOR = OptionDescriptor.newBuilder(LANGUAGE_HOME_OVERRIDE_KEY, LANGUAGE_HOME_OVERRIDE).build(); + public static final String EDITION_OVERRIDE = optionName("editionOverride"); + public static final OptionKey EDITION_OVERRIDE_KEY = new OptionKey<>(""); + private static final OptionDescriptor EDITION_OVERRIDE_DESCRIPTOR = + OptionDescriptor.newBuilder(EDITION_OVERRIDE_KEY, EDITION_OVERRIDE).build(); + public static final String DISABLE_IR_CACHES = optionName("disableIrCaches"); public static final OptionKey DISABLE_IR_CACHES_KEY = new OptionKey<>(false); private static final OptionDescriptor DISABLE_IR_CACHES_DESCRIPTOR = @@ -98,6 +103,7 @@ public class RuntimeOptions { ENABLE_GLOBAL_SUGGESTIONS_DESCRIPTOR, INTERACTIVE_MODE_DESCRIPTOR, LANGUAGE_HOME_OVERRIDE_DESCRIPTOR, + EDITION_OVERRIDE_DESCRIPTOR, INTERPRETER_SEQUENTIAL_COMMAND_EXECUTION_DESCRIPTOR, DISABLE_IR_CACHES_DESCRIPTOR, WAIT_FOR_PENDING_SERIALIZATION_JOBS_DESCRIPTOR, diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala index a8889d23c522..31903c5cece5 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala @@ -74,6 +74,7 @@ class RuntimeErrorsTest .toFile .getAbsolutePath ) + .options(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") .out(out) .serverTransport(runtimeServerEmulator.makeServerTransport) .build() diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala index 21d54f990650..32d76fa77aee 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala @@ -67,6 +67,7 @@ class RuntimeInstrumentTest .toFile .getAbsolutePath ) + .options(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") .out(out) .serverTransport(runtimeServerEmulator.makeServerTransport) .build() diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala index 17333bc5753c..9fca9292382f 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala @@ -27,6 +27,7 @@ class RuntimeProjectContextTest extends AnyWordSpec with Matchers { .toFile .getAbsolutePath ) + .options(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") .option(RuntimeOptions.LOG_LEVEL, "WARNING") .build() context.initialize(LanguageInfo.ID) diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala index 20881dd96915..e6d6c970927e 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala @@ -72,6 +72,7 @@ class RuntimeServerTest .toFile .getAbsolutePath ) + .options(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") .logHandler(logOut) .out(out) .serverTransport(runtimeServerEmulator.makeServerTransport) diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala index bcb7d3b5f2f0..be2664a819e7 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala @@ -60,6 +60,7 @@ class RuntimeSuggestionUpdatesTest .toFile .getAbsolutePath ) + .options(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") .out(out) .serverTransport(runtimeServerEmulator.makeServerTransport) .build() diff --git a/engine/runtime/src/main/java/org/enso/interpreter/OptionsHelper.java b/engine/runtime/src/main/java/org/enso/interpreter/OptionsHelper.java index d7f719dd4972..9dd7ea973d08 100644 --- a/engine/runtime/src/main/java/org/enso/interpreter/OptionsHelper.java +++ b/engine/runtime/src/main/java/org/enso/interpreter/OptionsHelper.java @@ -34,4 +34,12 @@ public static Optional getLanguageHomeOverride(TruffleLanguage.Env env) return Optional.of(option); } } + public static Optional getEditionOverride(TruffleLanguage.Env env) { + String option = env.getOptions().get(RuntimeOptions.EDITION_OVERRIDE_KEY); + if (option.equals("")) { + return Optional.empty(); + } else { + return Optional.of(option); + } + } } diff --git a/engine/runtime/src/main/java/org/enso/interpreter/runtime/Context.java b/engine/runtime/src/main/java/org/enso/interpreter/runtime/Context.java index 151879d1dcc7..b02cb9322df0 100644 --- a/engine/runtime/src/main/java/org/enso/interpreter/runtime/Context.java +++ b/engine/runtime/src/main/java/org/enso/interpreter/runtime/Context.java @@ -128,12 +128,14 @@ public void initialize() { Optional languageHome = OptionsHelper.getLanguageHomeOverride(environment).or(() -> Optional.ofNullable(home)); + var editionOverride = OptionsHelper.getEditionOverride(environment); var resourceManager = new org.enso.distribution.locking.ResourceManager(lockManager); packageRepository = PackageRepository.initializeRepository( OptionConverters.toScala(projectPackage), OptionConverters.toScala(languageHome), + OptionConverters.toScala(editionOverride), distributionManager, resourceManager, this, diff --git a/engine/runtime/src/main/scala/org/enso/compiler/PackageRepository.scala b/engine/runtime/src/main/scala/org/enso/compiler/PackageRepository.scala index 8db042efc169..fc7f1a324d10 100644 --- a/engine/runtime/src/main/scala/org/enso/compiler/PackageRepository.scala +++ b/engine/runtime/src/main/scala/org/enso/compiler/PackageRepository.scala @@ -5,7 +5,7 @@ import com.typesafe.scalalogging.Logger import org.enso.distribution.locking.ResourceManager import org.enso.distribution.{DistributionManager, LanguageHome} import org.enso.editions.updater.EditionManager -import org.enso.editions.{DefaultEdition, LibraryName, LibraryVersion} +import org.enso.editions.{DefaultEdition, Editions, LibraryName, LibraryVersion} import org.enso.interpreter.instrument.NotificationHandler import org.enso.interpreter.runtime.builtin.Builtins import org.enso.interpreter.runtime.util.TruffleFileSystem @@ -27,7 +27,6 @@ import org.enso.pkg.{ } import java.nio.file.Path - import scala.collection.immutable.ListSet import scala.util.Try @@ -537,14 +536,19 @@ object PackageRepository { def initializeRepository( projectPackage: Option[Package[TruffleFile]], languageHome: Option[String], + editionOverride: Option[String], distributionManager: DistributionManager, resourceManager: ResourceManager, context: Context, builtins: Builtins, notificationHandler: NotificationHandler ): PackageRepository = { - val rawEdition = projectPackage - .flatMap(_.config.edition) + val rawEdition = editionOverride + .map(v => Editions.Raw.Edition(parent = Some(v))) + .orElse( + projectPackage + .flatMap(_.config.edition) + ) .getOrElse(DefaultEdition.getDefaultEdition) val homeManager = languageHome.map { home => LanguageHome(Path.of(home)) } diff --git a/engine/runtime/src/test/scala/org/enso/interpreter/test/InterpreterTest.scala b/engine/runtime/src/test/scala/org/enso/interpreter/test/InterpreterTest.scala index db739244ca65..9fa139cac076 100644 --- a/engine/runtime/src/test/scala/org/enso/interpreter/test/InterpreterTest.scala +++ b/engine/runtime/src/test/scala/org/enso/interpreter/test/InterpreterTest.scala @@ -114,6 +114,7 @@ class InterpreterContext( .toFile .getAbsolutePath ) + .option(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") .serverTransport { (uri, peer) => if (uri.toString == DebugServerInfo.URI) { new DebuggerSessionManagerEndpoint(sessionManager, peer) diff --git a/engine/runtime/src/test/scala/org/enso/interpreter/test/PackageTest.scala b/engine/runtime/src/test/scala/org/enso/interpreter/test/PackageTest.scala index a0b90e8bb566..839ca627bf74 100644 --- a/engine/runtime/src/test/scala/org/enso/interpreter/test/PackageTest.scala +++ b/engine/runtime/src/test/scala/org/enso/interpreter/test/PackageTest.scala @@ -30,6 +30,7 @@ trait PackageTest extends AnyFlatSpec with Matchers with ValueEquality { .toFile .getAbsolutePath ) + .option(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") .option(RuntimeOptions.STRICT_ERRORS, "true") .option(RuntimeOptions.DISABLE_IR_CACHES, "true") .out(output) From 77ccbd5821d011a76df529fbfd08531d548cd517 Mon Sep 17 00:00:00 2001 From: Marcin Kostrzewa Date: Wed, 15 Jun 2022 23:05:28 +0200 Subject: [PATCH 5/6] not if it doesnt compile --- .../enso/interpreter/test/instrument/RuntimeErrorsTest.scala | 2 +- .../interpreter/test/instrument/RuntimeInstrumentTest.scala | 2 +- .../interpreter/test/instrument/RuntimeProjectContextTest.scala | 2 +- .../enso/interpreter/test/instrument/RuntimeServerTest.scala | 2 +- .../test/instrument/RuntimeSuggestionUpdatesTest.scala | 2 +- 5 files changed, 5 insertions(+), 5 deletions(-) diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala index 31903c5cece5..a9e1c668b161 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeErrorsTest.scala @@ -74,7 +74,7 @@ class RuntimeErrorsTest .toFile .getAbsolutePath ) - .options(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") + .option(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") .out(out) .serverTransport(runtimeServerEmulator.makeServerTransport) .build() diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala index 32d76fa77aee..5d46a806e99f 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeInstrumentTest.scala @@ -67,7 +67,7 @@ class RuntimeInstrumentTest .toFile .getAbsolutePath ) - .options(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") + .option(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") .out(out) .serverTransport(runtimeServerEmulator.makeServerTransport) .build() diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala index 9fca9292382f..86f0b8d8a190 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeProjectContextTest.scala @@ -27,7 +27,7 @@ class RuntimeProjectContextTest extends AnyWordSpec with Matchers { .toFile .getAbsolutePath ) - .options(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") + .option(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") .option(RuntimeOptions.LOG_LEVEL, "WARNING") .build() context.initialize(LanguageInfo.ID) diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala index e6d6c970927e..f3cb191f235f 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeServerTest.scala @@ -72,7 +72,7 @@ class RuntimeServerTest .toFile .getAbsolutePath ) - .options(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") + .option(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") .logHandler(logOut) .out(out) .serverTransport(runtimeServerEmulator.makeServerTransport) diff --git a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala index be2664a819e7..83baed18192a 100644 --- a/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala +++ b/engine/runtime-with-instruments/src/test/scala/org/enso/interpreter/test/instrument/RuntimeSuggestionUpdatesTest.scala @@ -60,7 +60,7 @@ class RuntimeSuggestionUpdatesTest .toFile .getAbsolutePath ) - .options(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") + .option(RuntimeOptions.EDITION_OVERRIDE, "0.0.0-dev") .out(out) .serverTransport(runtimeServerEmulator.makeServerTransport) .build() From 805d8ba61e290e599876dff261df65e5eef5165a Mon Sep 17 00:00:00 2001 From: Marcin Kostrzewa Date: Wed, 15 Jun 2022 23:23:59 +0200 Subject: [PATCH 6/6] ... --- .../src/main/java/org/enso/interpreter/OptionsHelper.java | 1 + 1 file changed, 1 insertion(+) diff --git a/engine/runtime/src/main/java/org/enso/interpreter/OptionsHelper.java b/engine/runtime/src/main/java/org/enso/interpreter/OptionsHelper.java index 9dd7ea973d08..0ef341a6ee76 100644 --- a/engine/runtime/src/main/java/org/enso/interpreter/OptionsHelper.java +++ b/engine/runtime/src/main/java/org/enso/interpreter/OptionsHelper.java @@ -34,6 +34,7 @@ public static Optional getLanguageHomeOverride(TruffleLanguage.Env env) return Optional.of(option); } } + public static Optional getEditionOverride(TruffleLanguage.Env env) { String option = env.getOptions().get(RuntimeOptions.EDITION_OVERRIDE_KEY); if (option.equals("")) {