This is a regression from 6.2.2 caused by the deprecation of the Object method finalize as of Java 9.
This was not caught by the compiler because the finalize method is obtained by reflection.
One way to reproduce:
Open Models Library Arduino Example
Click setup [Do not need to have an arduino board attached, just click OK in the dialog that says "No available arduino ports were found."]
Re-Open Arduino Example
Error message will appear
java.lang.UnsatisfiedLinkError: Native Library /Users/aab1638/.jssc/mac_os_x/libjSSC-2.6_x86_64.jnilib already loaded in another classloader
at java.base/jdk.internal.loader.NativeLibraries.loadLibrary(Unknown Source)
at java.base/jdk.internal.loader.NativeLibraries.loadLibrary(Unknown Source)
at java.base/java.lang.ClassLoader.loadLibrary(Unknown Source)
at java.base/java.lang.Runtime.load0(Unknown Source)
at java.base/java.lang.System.load(Unknown Source)
at jssc.SerialNativeInterface.(SerialNativeInterface.java:172)
at jssc.SerialPortList.(SerialPortList.java:43)
at arduino.ArduinoExtension$Ports.report(ArduinoExtension.java:112)
at org.nlogo.prim._externreport.report(_externreport.java:31)
at org.nlogo.prim._asm_proceduresetup_setprocedurevariable_6.perform()
at org.nlogo.nvm.Context.stepConcurrent(Context.java:107)
at org.nlogo.nvm.ConcurrentJob.step(ConcurrentJob.scala:65)
at org.nlogo.job.JobThread.runPrimaryJobs(JobThread.scala:133)
at org.nlogo.job.JobThread.$anonfun$run$1(JobThread.scala:68)
at scala.runtime.java8.JFunction0$mcV$sp.apply(JFunction0$mcV$sp.java:23)
at scala.util.control.Exception$Catch.apply(Exception.scala:228)
at org.nlogo.api.Exceptions$.handling(Exceptions.scala:41)
at org.nlogo.job.JobThread.run(JobThread.scala:66)
NetLogo 6.3.0
main: org.nlogo.app.AppFrame
thread: AWT-EventQueue-0
OpenJDK 64-Bit Server VM 17.0.4 (BellSoft; 17.0.4+8-LTS)
operating system: Mac OS X 10.14.6 (x86_64 processor)
Scala version 2.12.16
JOGL: (3D View not initialized)
OpenGL Graphics: (3D View not initialized)
model: Arduino Example
This is a regression from 6.2.2 caused by the deprecation of the
Object
methodfinalize
as of Java 9. This was not caught by the compiler because thefinalize
method is obtained by reflection.One way to reproduce:
Error message will appear