On 07/29/2014 01:17 PM, Jiri Vanek wrote:
On 07/29/2014 01:05 PM, Florian Weimer wrote:
As far as I can tell, currently, System.loadLibrary() is mostly
unusable for Java libraries because
they cannot influence the library search path. If you want to
transparently load a DSO, you need to
use System.load() and hard-code the path. This probably means
patching upstream sources.
Debian patches the default search path so that System.loadLibrary()
searches /usr/lib/jni for DSOs
with native code. This means that classes which call
System.loadLibrary() just work, assuming that
the Debian package installs its DSOs into /usr/lib/jni.
Can we do something similar in Fedora? We probably want /usr/lib/jni
and /usr/lib64/jni, for
consistency with the rest of the system.
Then the most simple way is to provide symlinks in
java-1.{7,8}.0-openjdk spec
from /usr/lib/jni | /usr/lib64/jni, -to> /usr/lib/jvm/java..../... ?
(Cc:ing the mailing list again.)
Is it a good idea to install files from RPMs through a symbolic link? I
suspect it's not, which would mean we'd have to use the upstream default
"/usr/java/packages/lib/amd64" in spec files (probably using a macro).
If that path is acceptable, it would be fine with me as well, but it
looks a bit ugly to me. It certainly has the advantage of being
compatible with both the proprietary JDKs and the Debian packaging
(which keeps this search path entry, it only adds /usr/lib/jni).
--
Florian Weimer / Red Hat Product Security
--
java-devel mailing list
java-devel@xxxxxxxxxxxxxxxxxxxxxxx
https://admin.fedoraproject.org/mailman/listinfo/java-devel