mirror of
https://github.com/facebook/rocksdb.git
synced 2024-11-27 11:43:49 +00:00
Merge pull request #471 from fyrz/RocksJava-Fix-NativeLibraryLoader
[RocksJava] Fix native library loader
This commit is contained in:
commit
b08b2fe732
|
@ -13,6 +13,7 @@ import org.rocksdb.util.Environment;
|
||||||
public class NativeLibraryLoader {
|
public class NativeLibraryLoader {
|
||||||
//singleton
|
//singleton
|
||||||
private static final NativeLibraryLoader instance = new NativeLibraryLoader();
|
private static final NativeLibraryLoader instance = new NativeLibraryLoader();
|
||||||
|
private static boolean initialized = false;
|
||||||
|
|
||||||
private static final String sharedLibraryName = Environment.getJniLibraryName("rocksdb");
|
private static final String sharedLibraryName = Environment.getJniLibraryName("rocksdb");
|
||||||
private static final String tempFilePrefix = "librocksdbjni";
|
private static final String tempFilePrefix = "librocksdbjni";
|
||||||
|
@ -41,31 +42,35 @@ public class NativeLibraryLoader {
|
||||||
*
|
*
|
||||||
* @throws java.io.IOException if a filesystem operation fails.
|
* @throws java.io.IOException if a filesystem operation fails.
|
||||||
*/
|
*/
|
||||||
public void loadLibraryFromJar(final String tmpDir)
|
public synchronized void loadLibraryFromJar(final String tmpDir)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
final File temp;
|
if (!initialized) {
|
||||||
if(tmpDir == null || tmpDir.equals("")) {
|
final File temp;
|
||||||
temp = File.createTempFile(tempFilePrefix, tempFileSuffix);
|
if (tmpDir == null || tmpDir.equals("")) {
|
||||||
} else {
|
temp = File.createTempFile(tempFilePrefix, tempFileSuffix);
|
||||||
temp = new File(tmpDir, sharedLibraryName);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!temp.exists()) {
|
|
||||||
throw new RuntimeException("File " + temp.getAbsolutePath() + " does not exist.");
|
|
||||||
} else {
|
|
||||||
temp.deleteOnExit();
|
|
||||||
}
|
|
||||||
|
|
||||||
// attempt to copy the library from the Jar file to the temp destination
|
|
||||||
try(final InputStream is = getClass().getClassLoader().getResourceAsStream(sharedLibraryName)) {
|
|
||||||
if (is == null) {
|
|
||||||
throw new RuntimeException(sharedLibraryName + " was not found inside JAR.");
|
|
||||||
} else {
|
} else {
|
||||||
Files.copy(is, temp.toPath(), StandardCopyOption.REPLACE_EXISTING);
|
temp = new File(tmpDir, sharedLibraryName);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
System.load(temp.getAbsolutePath());
|
if (!temp.exists()) {
|
||||||
|
throw new RuntimeException("File " + temp.getAbsolutePath() + " does not exist.");
|
||||||
|
} else {
|
||||||
|
temp.deleteOnExit();
|
||||||
|
}
|
||||||
|
|
||||||
|
// attempt to copy the library from the Jar file to the temp destination
|
||||||
|
try (final InputStream is = getClass().getClassLoader().
|
||||||
|
getResourceAsStream(sharedLibraryName)) {
|
||||||
|
if (is == null) {
|
||||||
|
throw new RuntimeException(sharedLibraryName + " was not found inside JAR.");
|
||||||
|
} else {
|
||||||
|
Files.copy(is, temp.toPath(), StandardCopyOption.REPLACE_EXISTING);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
System.load(temp.getAbsolutePath());
|
||||||
|
initialized = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* Private constructor to disallow instantiation
|
* Private constructor to disallow instantiation
|
||||||
|
|
Loading…
Reference in a new issue