You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The ImageJ Launcher builds up a java_library_path with (on Linux) LD_LIBRARY_PATH or (on macOS) DYLD_LIBRARY_PATH, and then lib/<platform>.
And on all platforms, it recursively adds all dirs under ${app-dir}/lib that contain at least one native library for that platform. (It even checks the contents of every candidate to make sure it really is a native library structurally...)
And on Windows, it appends the java_library_path to PATH.
On macOS and Linux, it uses execvp to re-execute the native launcher when the original LD_LIBRARY_PATH/DYLD_LIBRARY_PATH does not match the built-up one.
And of course it passes -Djava.library.path=${java-library-path} to the JVM.
Should Jaunch do any/all of this? It hinges on whether the following comment is still true: "Unfortunately, ld.so only looks at LD_LIBRARY_PATH at startup, so we have to reexec after setting that variable."
*PreviouslythelaunchermodifiedtheLD_LIBRARY_PATHappropriatelyforthe*desireddatamodelpath, regardlessifdatamodelsmatchedornot. The*launchersubsequentlyexec'ed the desired executable, in order to make the*LD_LIBRARY_PATHpathavailable, fortheruntimelinker.
**Now, inmostcases,thelauncherwilldlopenthetargetlibjvm.so. All*requiredlibrariesareloadedbytheruntimelinker, usingthe*$RPATH/$ORIGINbakedintothesharedlibrariesatcompiletime. Therefore,
*inmostcases, thelauncherwillonlyexec, ifthedatamodelsare*mismatched, andwillnotsetanyenvironmentvariables, regardlessofthe*datamodels.
**However, iftheenvironmentcontainsaLD_LIBRARY_PATH, thiswillcausethe*launchertoinspecttheLD_LIBRARY_PATH. Thelauncherwillcheck*a. iftheLD_LIBRARY_PATH's first component is the path to the desired*libjvm.so*b. ifanyotherlibjvm.soisfoundinanyofthepaths.
*Ifcasebis true, thenthelauncherwillsettheLD_LIBRARY_PATHtothe*desiredJREandreexec, inordertopropagatetheenvironment.
The text was updated successfully, but these errors were encountered:
macOS dyld documents that it only looks at the env vars at process launch (not sure about Linux ld.so). So it would probably be useful to be able to relaunch with an altered environment (especially for ImageJ plugins that expect the current environment). On the other hand, if I were shipping an app with a fixed set of JNI libraries, I would probably want to have total control over all these paths (and may not necessarily want java.library.path to equal LD_LIBRARY_PATH; neither is necessary if the Java class knows where to find the JNI library and the JNI library contains the paths of its dependencies). Also because these paths can have security implications.
The ImageJ Launcher builds up a
java_library_path
with (on Linux)LD_LIBRARY_PATH
or (on macOS)DYLD_LIBRARY_PATH
, and thenlib/<platform>
.${app-dir}/lib
that contain at least one native library for that platform. (It even checks the contents of every candidate to make sure it really is a native library structurally...)java_library_path
toPATH
.execvp
to re-execute the native launcher when the originalLD_LIBRARY_PATH
/DYLD_LIBRARY_PATH
does not match the built-up one.-Djava.library.path=${java-library-path}
to the JVM.Should Jaunch do any/all of this? It hinges on whether the following comment is still true: "Unfortunately,
ld.so
only looks atLD_LIBRARY_PATH
at startup, so we have to reexec after setting that variable."From the ImageJ Launcher source code:
The text was updated successfully, but these errors were encountered: