mirror of
https://github.com/xerial/snappy-java.git
synced 2025-04-08 19:35:08 +02:00
Separate a source file for BitShuffleNative
This commit is contained in:
parent
4fbfa72ebd
commit
f9520f9d19
9
Makefile
9
Makefile
@ -47,7 +47,7 @@ $(SNAPPY_OUT)/%.o : $(BITSHUFFLE_SRC_DIR)/%.c
|
|||||||
@mkdir -p $(@D)
|
@mkdir -p $(@D)
|
||||||
$(CXX) $(CXXFLAGS) -c $< -o $@
|
$(CXX) $(CXXFLAGS) -c $< -o $@
|
||||||
|
|
||||||
SNAPPY_OBJ:=$(addprefix $(SNAPPY_OUT)/,$(patsubst %.cc,%.o,$(SNAPPY_CC)) $(patsubst %.c,%.o,$(BITSHUFFLE_C)) SnappyNative.o)
|
SNAPPY_OBJ:=$(addprefix $(SNAPPY_OUT)/,$(patsubst %.cc,%.o,$(SNAPPY_CC)) $(patsubst %.c,%.o,$(BITSHUFFLE_C)) SnappyNative.o BitShuffleNative.o)
|
||||||
|
|
||||||
ifndef UNIVERSAL_BITSHUFFLE
|
ifndef UNIVERSAL_BITSHUFFLE
|
||||||
# Undefined macros to generate a platform-independent binary
|
# Undefined macros to generate a platform-independent binary
|
||||||
@ -102,8 +102,11 @@ $(SNAPPY_OUT)/%.o : $(SNAPPY_SRC_DIR)/%.cc
|
|||||||
@mkdir -p $(@D)
|
@mkdir -p $(@D)
|
||||||
$(CXX) $(CXXFLAGS) -c $< -o $@
|
$(CXX) $(CXXFLAGS) -c $< -o $@
|
||||||
|
|
||||||
#$(SNAPPY_OUT)/SnappyNative.o : $(SRC)/org/xerial/snappy/SnappyNative.cpp $(SRC)/org/xerial/snappy/SnappyNative.h $(SRC)/org/xerial/snappy/BitShufflenative.h
|
$(SNAPPY_OUT)/SnappyNative.o: $(SRC)/org/xerial/snappy/SnappyNative.cpp $(SRC)/org/xerial/snappy/SnappyNative.h
|
||||||
$(SNAPPY_OUT)/SnappyNative.o : $(SRC)/org/xerial/snappy/SnappyNative.cpp jni-header
|
@mkdir -p $(@D)
|
||||||
|
$(CXX) $(CXXFLAGS) -c $< -o $@
|
||||||
|
|
||||||
|
$(SNAPPY_OUT)/BitShuffleNative.o: $(SRC)/org/xerial/snappy/BitShuffleNative.cpp $(SRC)/org/xerial/snappy/BitShuffleNative.h
|
||||||
@mkdir -p $(@D)
|
@mkdir -p $(@D)
|
||||||
$(CXX) $(CXXFLAGS) -c $< -o $@
|
$(CXX) $(CXXFLAGS) -c $< -o $@
|
||||||
|
|
||||||
|
91
src/main/java/org/xerial/snappy/BitShuffleNative.cpp
Executable file
91
src/main/java/org/xerial/snappy/BitShuffleNative.cpp
Executable file
@ -0,0 +1,91 @@
|
|||||||
|
/*--------------------------------------------------------------------------
|
||||||
|
* 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.
|
||||||
|
*--------------------------------------------------------------------------*/
|
||||||
|
#include <bitshuffle.h>
|
||||||
|
#include "BitShuffleNative.h"
|
||||||
|
|
||||||
|
inline void throw_exception(JNIEnv *env, jobject self, int errorCode)
|
||||||
|
{
|
||||||
|
jclass c = env->FindClass("org/xerial/snappy/SnappyNative");
|
||||||
|
if(c==0)
|
||||||
|
return;
|
||||||
|
jmethodID mth_throwex = env->GetMethodID(c, "throw_error", "(I)V");
|
||||||
|
if(mth_throwex == 0)
|
||||||
|
return;
|
||||||
|
env->CallVoidMethod(self, mth_throwex, (jint) errorCode);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_xerial_snappy_SnappyNative
|
||||||
|
* Method: bitShuffle
|
||||||
|
* Signature: (Ljava/lang/Object;IIILjava/lang/Object;I)I
|
||||||
|
*/
|
||||||
|
JNIEXPORT jint JNICALL Java_org_xerial_snappy_BitShuffleNative_bitShuffle
|
||||||
|
(JNIEnv * env, jobject self, jobject input, jint inputOffset, jint typeSize, jint length, jobject output, jint outputOffset)
|
||||||
|
{
|
||||||
|
char* in = (char*) env->GetPrimitiveArrayCritical((jarray) input, 0);
|
||||||
|
char* out = (char*) env->GetPrimitiveArrayCritical((jarray) output, 0);
|
||||||
|
if(in == 0 || out == 0) {
|
||||||
|
// out of memory
|
||||||
|
if(in != 0) {
|
||||||
|
env->ReleasePrimitiveArrayCritical((jarray) input, in, 0);
|
||||||
|
}
|
||||||
|
if(out != 0) {
|
||||||
|
env->ReleasePrimitiveArrayCritical((jarray) output, out, 0);
|
||||||
|
}
|
||||||
|
throw_exception(env, self, 4);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int64_t processedBytes = bshuf_bitshuffle(
|
||||||
|
in + inputOffset, out + outputOffset, (size_t) (length / typeSize), (size_t) typeSize, 0);
|
||||||
|
|
||||||
|
env->ReleasePrimitiveArrayCritical((jarray) input, in, 0);
|
||||||
|
env->ReleasePrimitiveArrayCritical((jarray) output, out, 0);
|
||||||
|
|
||||||
|
return (jint) processedBytes;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_xerial_snappy_SnappyNative
|
||||||
|
* Method: bitUnShuffle
|
||||||
|
* Signature: (Ljava/lang/Object;IIILjava/lang/Object;I)I
|
||||||
|
*/
|
||||||
|
JNIEXPORT jint JNICALL Java_org_xerial_snappy_BitShuffleNative_bitUnShuffle
|
||||||
|
(JNIEnv * env, jobject self, jobject input, jint inputOffset, jint typeSize, jint length, jobject output, jint outputOffset)
|
||||||
|
{
|
||||||
|
char* in = (char*) env->GetPrimitiveArrayCritical((jarray) input, 0);
|
||||||
|
char* out = (char*) env->GetPrimitiveArrayCritical((jarray) output, 0);
|
||||||
|
if(in == 0 || out == 0) {
|
||||||
|
// out of memory
|
||||||
|
if(in != 0) {
|
||||||
|
env->ReleasePrimitiveArrayCritical((jarray) input, in, 0);
|
||||||
|
}
|
||||||
|
if(out != 0) {
|
||||||
|
env->ReleasePrimitiveArrayCritical((jarray) output, out, 0);
|
||||||
|
}
|
||||||
|
throw_exception(env, self, 4);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int64_t processedBytes = bshuf_bitunshuffle(
|
||||||
|
in + inputOffset, out + outputOffset, (size_t) (length / typeSize), (size_t) typeSize, 0);
|
||||||
|
|
||||||
|
env->ReleasePrimitiveArrayCritical((jarray) input, in, 0);
|
||||||
|
env->ReleasePrimitiveArrayCritical((jarray) output, out, 0);
|
||||||
|
|
||||||
|
return (jint) processedBytes;
|
||||||
|
}
|
||||||
|
|
@ -15,22 +15,18 @@
|
|||||||
*--------------------------------------------------------------------------*/
|
*--------------------------------------------------------------------------*/
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
#include <stdint.h>
|
|
||||||
#include <snappy.h>
|
#include <snappy.h>
|
||||||
#include <bitshuffle.h>
|
|
||||||
|
|
||||||
#include "SnappyNative.h"
|
#include "SnappyNative.h"
|
||||||
#include "BitShuffleNative.h"
|
|
||||||
|
|
||||||
void throw_exception(JNIEnv *env, jobject self, int errorCode)
|
inline void throw_exception(JNIEnv *env, jobject self, int errorCode)
|
||||||
{
|
{
|
||||||
jclass c = env->FindClass("org/xerial/snappy/SnappyNative");
|
jclass c = env->FindClass("org/xerial/snappy/SnappyNative");
|
||||||
if(c==0)
|
if(c==0)
|
||||||
return;
|
return;
|
||||||
jmethodID mth_throwex = env->GetMethodID(c, "throw_error", "(I)V");
|
jmethodID mth_throwex = env->GetMethodID(c, "throw_error", "(I)V");
|
||||||
if(mth_throwex == 0)
|
if(mth_throwex == 0)
|
||||||
return;
|
return;
|
||||||
env->CallVoidMethod(self, mth_throwex, (jint) errorCode);
|
env->CallVoidMethod(self, mth_throwex, (jint) errorCode);
|
||||||
}
|
}
|
||||||
|
|
||||||
JNIEXPORT jstring JNICALL Java_org_xerial_snappy_SnappyNative_nativeLibraryVersion
|
JNIEXPORT jstring JNICALL Java_org_xerial_snappy_SnappyNative_nativeLibraryVersion
|
||||||
@ -300,65 +296,3 @@ JNIEXPORT void JNICALL Java_org_xerial_snappy_SnappyNative_arrayCopy
|
|||||||
env->ReleasePrimitiveArrayCritical((jarray) output, dest, 0);
|
env->ReleasePrimitiveArrayCritical((jarray) output, dest, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: org_xerial_snappy_SnappyNative
|
|
||||||
* Method: bitShuffle
|
|
||||||
* Signature: (Ljava/lang/Object;IIILjava/lang/Object;I)I
|
|
||||||
*/
|
|
||||||
JNIEXPORT jint JNICALL Java_org_xerial_snappy_BitShuffleNative_bitShuffle
|
|
||||||
(JNIEnv * env, jobject self, jobject input, jint inputOffset, jint typeSize, jint length, jobject output, jint outputOffset)
|
|
||||||
{
|
|
||||||
char* in = (char*) env->GetPrimitiveArrayCritical((jarray) input, 0);
|
|
||||||
char* out = (char*) env->GetPrimitiveArrayCritical((jarray) output, 0);
|
|
||||||
if(in == 0 || out == 0) {
|
|
||||||
// out of memory
|
|
||||||
if(in != 0) {
|
|
||||||
env->ReleasePrimitiveArrayCritical((jarray) input, in, 0);
|
|
||||||
}
|
|
||||||
if(out != 0) {
|
|
||||||
env->ReleasePrimitiveArrayCritical((jarray) output, out, 0);
|
|
||||||
}
|
|
||||||
throw_exception(env, self, 4);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int64_t processedBytes = bshuf_bitshuffle(
|
|
||||||
in + inputOffset, out + outputOffset, (size_t) (length / typeSize), (size_t) typeSize, 0);
|
|
||||||
|
|
||||||
env->ReleasePrimitiveArrayCritical((jarray) input, in, 0);
|
|
||||||
env->ReleasePrimitiveArrayCritical((jarray) output, out, 0);
|
|
||||||
|
|
||||||
return (jint) processedBytes;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: org_xerial_snappy_SnappyNative
|
|
||||||
* Method: bitUnShuffle
|
|
||||||
* Signature: (Ljava/lang/Object;IIILjava/lang/Object;I)I
|
|
||||||
*/
|
|
||||||
JNIEXPORT jint JNICALL Java_org_xerial_snappy_BitShuffleNative_bitUnShuffle
|
|
||||||
(JNIEnv * env, jobject self, jobject input, jint inputOffset, jint typeSize, jint length, jobject output, jint outputOffset)
|
|
||||||
{
|
|
||||||
char* in = (char*) env->GetPrimitiveArrayCritical((jarray) input, 0);
|
|
||||||
char* out = (char*) env->GetPrimitiveArrayCritical((jarray) output, 0);
|
|
||||||
if(in == 0 || out == 0) {
|
|
||||||
// out of memory
|
|
||||||
if(in != 0) {
|
|
||||||
env->ReleasePrimitiveArrayCritical((jarray) input, in, 0);
|
|
||||||
}
|
|
||||||
if(out != 0) {
|
|
||||||
env->ReleasePrimitiveArrayCritical((jarray) output, out, 0);
|
|
||||||
}
|
|
||||||
throw_exception(env, self, 4);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int64_t processedBytes = bshuf_bitunshuffle(
|
|
||||||
in + inputOffset, out + outputOffset, (size_t) (length / typeSize), (size_t) typeSize, 0);
|
|
||||||
|
|
||||||
env->ReleasePrimitiveArrayCritical((jarray) input, in, 0);
|
|
||||||
env->ReleasePrimitiveArrayCritical((jarray) output, out, 0);
|
|
||||||
|
|
||||||
return (jint) processedBytes;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user