[jsscripting] Upgrade GraalJS from 22.0.0.2 to 24.1.1 (#17720)

* [jsscripting] Upgrade GraalJS to 23.0.6

Signed-off-by: Florian Hotze <dev@florianhotze.com>
This commit is contained in:
Florian Hotze 2024-12-22 08:09:09 +01:00 committed by GitHub
parent 62cdb14c74
commit 5e7d2fc5da
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 30 additions and 23 deletions

View File

@ -23,25 +23,37 @@
!jdk.vm.ci.services !jdk.vm.ci.services
</bnd.importpackage> </bnd.importpackage>
<!-- Remember to check if the fix https://github.com/openhab/openhab-core/pull/4437 still works when upgrading GraalJS --> <!-- Remember to check if the fix https://github.com/openhab/openhab-core/pull/4437 still works when upgrading GraalJS -->
<graal.version>22.0.0.2</graal.version> <!-- DO NOT UPGRADE: 22.0.0.2 is the latest version working on armv7l / OpenJDK 11.0.16 & armv7l / Zulu 17.0.5+8 --> <graaljs.version>24.1.1</graaljs.version>
<oh.version>${project.version}</oh.version> <oh.version>${project.version}</oh.version>
<ohjs.version>openhab@5.8.1</ohjs.version> <ohjs.version>openhab@5.8.1</ohjs.version>
</properties> </properties>
<build> <build>
<plugins> <plugins>
<!-- exclude META-INF/services/com.oracle.truffle.api.TruffleLanguage$Provider when unpacking dependencies --> <!-- bundle the modular dependencies into an uber-JAR -->
<plugin> <plugin>
<groupId>org.apache.maven.plugins</groupId> <groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId> <artifactId>maven-shade-plugin</artifactId>
<version>3.6.0</version>
<executions> <executions>
<execution> <execution>
<id>embed-dependencies</id> <phase>package</phase>
<goals> <goals>
<goal>unpack-dependencies</goal> <goal>shade</goal>
</goals> </goals>
<configuration> <configuration>
<excludes>META-INF/services/com.oracle.truffle.api.TruffleLanguage$Provider</excludes> <!-- we'll provide this --> <artifactSet>
<excludes>
<exclude>org.lastnpe.eea:eea-all</exclude>
<exclude>org.apache.karaf.features:framework</exclude>
</excludes>
</artifactSet>
<createDependencyReducedPom>false</createDependencyReducedPom>
<transformers>
<!-- Transformer to merge module-info.class files, if needed -->
<transformer
implementation="org.apache.maven.plugins.shade.resource.ServicesResourceTransformer"/>
</transformers>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>
@ -130,32 +142,29 @@
<dependencies> <dependencies>
<dependency> <dependency>
<groupId>org.graalvm.sdk</groupId> <groupId>org.graalvm.polyglot</groupId>
<artifactId>graal-sdk</artifactId> <artifactId>polyglot</artifactId>
<version>${graal.version}</version> <version>${graaljs.version}</version>
</dependency>
<dependency>
<groupId>org.graalvm.truffle</groupId>
<artifactId>truffle-api</artifactId>
<version>${graal.version}</version>
</dependency> </dependency>
<!-- Graal JavaScript ScriptEngine JSR 223 support --> <!-- Graal JavaScript ScriptEngine JSR 223 support -->
<dependency> <dependency>
<groupId>org.graalvm.js</groupId> <groupId>org.graalvm.js</groupId>
<artifactId>js-scriptengine</artifactId> <artifactId>js-scriptengine</artifactId>
<version>${graal.version}</version> <version>${graaljs.version}</version>
</dependency> </dependency>
<!-- Graal TRegex engine (internally used by Graal JavaScript engine) --> <!-- Graal TRegex engine (internally used by Graal JavaScript engine) -->
<dependency> <dependency>
<groupId>org.graalvm.regex</groupId> <groupId>org.graalvm.regex</groupId>
<artifactId>regex</artifactId> <artifactId>regex</artifactId>
<version>${graal.version}</version> <version>${graaljs.version}</version>
</dependency> </dependency>
<!-- Graal JavaScript engine (depends on Graal TRegex engine, must be added after it) --> <!-- Graal JavaScript engine (depends on Graal TRegex engine, must be added after it) -->
<dependency> <dependency>
<groupId>org.graalvm.js</groupId> <groupId>org.graalvm.polyglot</groupId>
<artifactId>js</artifactId> <artifactId>js-community</artifactId>
<version>${graal.version}</version> <version>${graaljs.version}</version>
<type>pom</type>
<scope>runtime</scope>
</dependency> </dependency>
</dependencies> </dependencies>
</project> </project>

View File

@ -163,8 +163,8 @@ public class OpenhabGraalJSScriptEngine
.option("js.nashorn-compat", "true") // Enable Nashorn compat mode as openhab-js relies on .option("js.nashorn-compat", "true") // Enable Nashorn compat mode as openhab-js relies on
// accessors, see // accessors, see
// https://github.com/oracle/graaljs/blob/master/docs/user/NashornMigrationGuide.md#accessors // https://github.com/oracle/graaljs/blob/master/docs/user/NashornMigrationGuide.md#accessors
.option("js.ecmascript-version", "2022") // If Nashorn compat is enabled, it will enforce ES5 .option("js.ecmascript-version", "2024") // If Nashorn compat is enabled, it will enforce ES5
// compatibility, we want ECMA2022 // compatibility, we want ECMA2024
.option("js.commonjs-require", "true") // Enable CommonJS module support .option("js.commonjs-require", "true") // Enable CommonJS module support
.hostClassLoader(getClass().getClassLoader()) .hostClassLoader(getClass().getClassLoader())
.fileSystem(new DelegatingFileSystem(FileSystems.getDefault().provider()) { .fileSystem(new DelegatingFileSystem(FileSystems.getDefault().provider()) {

View File

@ -1,2 +0,0 @@
com.oracle.truffle.regex.RegexLanguageProvider
com.oracle.truffle.js.lang.JavaScriptLanguageProvider