com.github.luben.zstd.util.Native Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pulsar-flink-connector_2.11 Show documentation
Show all versions of pulsar-flink-connector_2.11 Show documentation
Elastic data processing with Apache Pulsar and Apache Flink
The newest version!
package com.github.luben.zstd.util;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.lang.UnsatisfiedLinkError;
public enum Native {
;
private static final String libnameShort = "zstd-jni";
private static final String libname = "lib" + libnameShort;
private static final String errorMsg = "Unsupported OS/arch, cannot find " +
resourceName() + " or load " + libnameShort + " from system libraries. Please " +
"try building from source the jar or providing " + libname + " in you system.";
private static String osName() {
String os = System.getProperty("os.name").toLowerCase().replace(' ', '_');
if (os.startsWith("win")){
return "win";
} else if (os.startsWith("mac")) {
return "darwin";
} else {
return os;
}
}
private static String osArch() {
return System.getProperty("os.arch");
}
private static String libExtension() {
if (osName().contains("os_x") || osName().contains("darwin")) {
return "dylib";
} else if (osName().contains("win")) {
return "dll";
} else {
return "so";
}
}
private static String resourceName() {
return "/" + osName() + "/" + osArch() + "/" + libname + "." + libExtension();
}
private static boolean loaded = false;
public static synchronized boolean isLoaded() {
return loaded;
}
private static UnsatisfiedLinkError linkError(UnsatisfiedLinkError e) {
UnsatisfiedLinkError err = new UnsatisfiedLinkError(e.getMessage() + "\n" + errorMsg);
err.setStackTrace(e.getStackTrace());
return err;
}
public static synchronized void load() {
load(null);
}
public static synchronized void load(final File tempFolder) {
if (loaded) {
return;
}
String resourceName = resourceName();
InputStream is = Native.class.getResourceAsStream(resourceName);
if (is == null) {
// fall-back to loading the zstd-jni from the system library path
try {
System.loadLibrary(libnameShort);
loaded = true;
return;
} catch (UnsatisfiedLinkError e) {
throw linkError(e);
}
}
File tempLib = null;
FileOutputStream out = null;
try {
tempLib = File.createTempFile(libname, "." + libExtension(), tempFolder);
// try to delete on exit, does not work on Windows
tempLib.deleteOnExit();
// copy to tempLib
out = new FileOutputStream(tempLib);
byte[] buf = new byte[4096];
while (true) {
int read = is.read(buf);
if (read == -1) {
break;
}
out.write(buf, 0, read);
}
try {
out.flush();
out.close();
out = null;
} catch (IOException e) {
// ignore
}
try {
System.load(tempLib.getAbsolutePath());
} catch (UnsatisfiedLinkError e) {
// fall-back to loading the zstd-jni from the system library path
try {
System.loadLibrary(libnameShort);
} catch (UnsatisfiedLinkError e1) {
// display error in case problem with loading from temp folder
throw linkError(e1);
}
}
loaded = true;
} catch (IOException e) {
throw new ExceptionInInitializerError("Cannot unpack " + libname);
}
finally {
try {
is.close();
if (out != null) {
out.close();
}
if (tempLib != null && tempLib.exists()) {
tempLib.delete();
}
} catch (IOException e) {
// ignore
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy