[snappy-java] 39/51: Stupidly inject missing file LoadSnappy.java as quilt patch for the purpose of testing.
Emmanuel Bourg
ebourg-guest at moszumanska.debian.org
Tue Nov 25 17:16:46 GMT 2014
This is an automated email from the git hooks/post-receive script.
ebourg-guest pushed a commit to branch master
in repository snappy-java.
commit dea7d6c30158a2df79a90512c1dc9bd0aa11f6c5
Author: Andreas Tille <tille at debian.org>
Date: Wed Aug 8 09:23:45 2012 +0200
Stupidly inject missing file LoadSnappy.java as quilt patch for the purpose of testing.
---
debian/changelog | 7 +
debian/patches/add_missing_file.patch | 247 ++++++++++++++++++++++++++++++++++
debian/patches/series | 1 +
3 files changed, 255 insertions(+)
diff --git a/debian/changelog b/debian/changelog
index 71ae04e..bca9aa4 100644
--- a/debian/changelog
+++ b/debian/changelog
@@ -1,3 +1,10 @@
+snappy-java (1.0.4.1~dfsg-2) UNRELEASED; urgency=low
+
+ * Stupidly inject missing file LoadSnappy.java as quilt patch for
+ the purpose of testing.
+
+ -- Andreas Tille <tille at debian.org> Wed, 08 Aug 2012 09:21:35 +0200
+
snappy-java (1.0.4.1~dfsg-1) unstable; urgency=low
* Initial release. (Closes: #636181)
diff --git a/debian/patches/add_missing_file.patch b/debian/patches/add_missing_file.patch
new file mode 100644
index 0000000..4a4c245
--- /dev/null
+++ b/debian/patches/add_missing_file.patch
@@ -0,0 +1,247 @@
+--- /dev/null
++++ snappy-java/src/main/java/org/xerial/snappy/LoadSnappy.java
+@@ -0,0 +1,244 @@
++/*--------------------------------------------------------------------------
++ * Copyright 2011 Taro L. Saito
++ *
++ * Licensed under the Apache License, Version 2.0 (the "License");
++ * you may not use this file except in compliance with the License.
++ * You may obtain a copy of the License at
++ *
++ * http://www.apache.org/licenses/LICENSE-2.0
++ *
++ * Unless required by applicable law or agreed to in writing, software
++ * distributed under the License is distributed on an "AS IS" BASIS,
++ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
++ * See the License for the specific language governing permissions and
++ * limitations under the License.
++ *--------------------------------------------------------------------------*/
++//--------------------------------------
++// snappy-java Project
++//
++// LoadSnappy.java
++// Since: 2011/03/29
++//
++// $URL$
++// $Author$
++//--------------------------------------
++package org.xerial.snappy;
++
++import java.io.BufferedInputStream;
++import java.io.ByteArrayOutputStream;
++import java.io.File;
++import java.io.FileInputStream;
++import java.io.FileOutputStream;
++import java.io.IOException;
++import java.io.InputStream;
++import java.net.URL;
++import java.security.DigestInputStream;
++import java.security.MessageDigest;
++import java.security.NoSuchAlgorithmException;
++import java.util.Properties;
++
++/**
++ * This class loads a native library of Snappy according to the platform of the
++ * user.
++ *
++ * @author leo
++ *
++ */
++public class LoadSnappy
++{
++ private static boolean isLoaded = false;
++
++ public static boolean load() {
++ if (!isLoaded) {
++ loadSnappyNativeLibrary();
++ }
++ return isLoaded;
++ }
++
++ /**
++ * Computes the MD5 value of the input stream
++ *
++ * @param input
++ * @return
++ * @throws IOException
++ * @throws NoSuchAlgorithmException
++ */
++ static String md5sum(InputStream input) throws IOException {
++ BufferedInputStream in = new BufferedInputStream(input);
++
++ try {
++ MessageDigest digest = java.security.MessageDigest.getInstance("MD5");
++ DigestInputStream digestInputStream = new DigestInputStream(in, digest);
++ for (; digestInputStream.read() >= 0;) {
++
++ }
++ ByteArrayOutputStream md5out = new ByteArrayOutputStream();
++ md5out.write(digest.digest());
++ return md5out.toString();
++ }
++ catch (NoSuchAlgorithmException e) {
++ throw new IllegalStateException("MD5 algorithm is not available: " + e);
++ }
++ finally {
++ in.close();
++ }
++ }
++
++ /**
++ * Extract the specified library file to the target folder
++ *
++ * @param libFolderForCurrentOS
++ * @param libraryFileName
++ * @param targetFolder
++ * @return
++ */
++ private static boolean extractAndLoadLibraryFile(String libFolderForCurrentOS, String libraryFileName,
++ String targetFolder) {
++ String nativeLibraryFilePath = libFolderForCurrentOS + "/" + libraryFileName;
++ final String prefix = "snappy-" + getVersion() + "-";
++
++ String extractedLibFileName = prefix + libraryFileName;
++ File extractedLibFile = new File(targetFolder, extractedLibFileName);
++
++ try {
++ if (extractedLibFile.exists()) {
++ // test md5sum value
++ String md5sum1 = md5sum(LoadSnappy.class.getResourceAsStream(nativeLibraryFilePath));
++ String md5sum2 = md5sum(new FileInputStream(extractedLibFile));
++
++ if (md5sum1.equals(md5sum2)) {
++ return loadNativeLibrary(targetFolder, extractedLibFileName);
++ }
++ else {
++ // remove old native library file
++ boolean deletionSucceeded = extractedLibFile.delete();
++ if (!deletionSucceeded) {
++ throw new IOException("failed to remove existing native library file: "
++ + extractedLibFile.getAbsolutePath());
++ }
++ }
++ }
++
++ // extract file into the current directory
++ InputStream reader = LoadSnappy.class.getResourceAsStream(nativeLibraryFilePath);
++ FileOutputStream writer = new FileOutputStream(extractedLibFile);
++ byte[] buffer = new byte[1024];
++ int bytesRead = 0;
++ while ((bytesRead = reader.read(buffer)) != -1) {
++ writer.write(buffer, 0, bytesRead);
++ }
++
++ writer.close();
++ reader.close();
++
++ if (!System.getProperty("os.name").contains("Windows")) {
++ try {
++ Runtime.getRuntime().exec(new String[] { "chmod", "755", extractedLibFile.getAbsolutePath() })
++ .waitFor();
++ }
++ catch (Throwable e) {}
++ }
++
++ return loadNativeLibrary(targetFolder, extractedLibFileName);
++ }
++ catch (IOException e) {
++ System.err.println(e.getMessage());
++ return false;
++ }
++
++ }
++
++ private static synchronized boolean loadNativeLibrary(String path, String name) {
++ File libPath = new File(path, name);
++ if (libPath.exists()) {
++
++ try {
++ System.load(new File(path, name).getAbsolutePath());
++ return true;
++ }
++ catch (UnsatisfiedLinkError e) {
++ throw new SnappyError(SnappyErrorCode.FAILED_TO_LOAD_NATIVE_LIBRARY, e);
++ }
++
++ }
++ else
++ return false;
++ }
++
++ private static void loadSnappyNativeLibrary() {
++ if (isLoaded)
++ return;
++
++ // Try loading the library from org.xerial.snappy.lib.path library path */
++ String snappyNativeLibraryPath = System.getProperty("org.xerial.snappy.lib.path");
++ String snappyNativeLibraryName = System.getProperty("org.xerial.snappy.lib.name");
++
++ // Resolve the library file name with a suffix (e.g., dll, .so, etc.)
++ if (snappyNativeLibraryName == null)
++ snappyNativeLibraryName = System.mapLibraryName("snappy");
++
++ if (snappyNativeLibraryPath != null) {
++ if (loadNativeLibrary(snappyNativeLibraryPath, snappyNativeLibraryName)) {
++ isLoaded = true;
++ return;
++ }
++ }
++
++ // Load the os-dependent library from a jar file
++ snappyNativeLibraryPath = "/org/xerial/snappy/native/" + OSInfo.getNativeLibFolderPathForCurrentOS();
++
++ if (LoadSnappy.class.getResource(snappyNativeLibraryPath + "/" + snappyNativeLibraryName) == null) {
++ // use nested VM version
++ return;
++ }
++
++ // Temporary library folder. Use the value of java.io.tmpdir
++ String tempFolder = new File(System.getProperty("java.io.tmpdir")).getAbsolutePath();
++ // Try extracting the library from jar
++ if (extractAndLoadLibraryFile(snappyNativeLibraryPath, snappyNativeLibraryName, tempFolder)) {
++ isLoaded = true;
++ return;
++ }
++
++ isLoaded = false;
++ return;
++ }
++
++ private static void getNativeLibraryFolderForTheCurrentOS() {
++ String osName = OSInfo.getOSName();
++ String archName = OSInfo.getArchName();
++
++ }
++
++ public static int getMajorVersion() {
++ String[] c = getVersion().split("\\.");
++ return (c.length > 0) ? Integer.parseInt(c[0]) : 1;
++ }
++
++ public static int getMinorVersion() {
++ String[] c = getVersion().split("\\.");
++ return (c.length > 1) ? Integer.parseInt(c[1]) : 0;
++ }
++
++ public static String getVersion() {
++
++ URL versionFile = LoadSnappy.class.getResource("/META-INF/maven/org.xerial.snappy/snappy-java/pom.properties");
++ if (versionFile == null)
++ versionFile = LoadSnappy.class.getResource("/META-INF/maven/org.xerial.snappy/snappy-java/VERSION");
++
++ String version = "unknown";
++ try {
++ if (versionFile != null) {
++ Properties versionData = new Properties();
++ versionData.load(versionFile.openStream());
++ version = versionData.getProperty("version", version);
++ version = version.trim().replaceAll("[^0-9\\.]", "");
++ }
++ }
++ catch (IOException e) {
++ System.err.println(e);
++ }
++ return version;
++ }
++
++}
diff --git a/debian/patches/series b/debian/patches/series
index b9d996f..4625ea1 100644
--- a/debian/patches/series
+++ b/debian/patches/series
@@ -1,3 +1,4 @@
replace_silk-weaver_by_xml_grep.patch
replace_OSInfo_by_dpkg-architecture.patch
use_debian_packaged_libsnappy.patch
+add_missing_file.patch
--
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-java/snappy-java.git
More information about the pkg-java-commits
mailing list