mirror of
https://github.com/xerial/snappy-java.git
synced 2025-07-28 00:14:15 +02:00
Fix build dependencies
This commit is contained in:
parent
9be2ff56d1
commit
5b9633251a
28
Makefile
28
Makefile
@ -5,33 +5,41 @@ MVN:=mvn
|
|||||||
|
|
||||||
all: snappy
|
all: snappy
|
||||||
|
|
||||||
|
SNAPPY_OUT:=$(TARGET)/$(snappy)-$(os_arch)
|
||||||
SNAPPY_ARCHIVE:=$(TARGET)/snappy-$(VERSION).tar.gz
|
SNAPPY_ARCHIVE:=$(TARGET)/snappy-$(VERSION).tar.gz
|
||||||
SNAPPY_CC:=snappy-sinksource.cc snappy-stubs-internal.cc snappy.cc
|
SNAPPY_CC:=snappy-sinksource.cc snappy-stubs-internal.cc snappy.cc
|
||||||
|
SNAPPY_SRC_DIR:=$(TARGET)/snappy-$(VERSION)
|
||||||
|
SNAPPY_SRC:=$(addprefix $(SNAPPY_SRC_DIR)/,$(SNAPPY_CC))
|
||||||
SNAPPY_OBJ:=$(addprefix $(SNAPPY_OUT)/,$(patsubst %.cc,%.o,$(SNAPPY_CC)) SnappyNative.o)
|
SNAPPY_OBJ:=$(addprefix $(SNAPPY_OUT)/,$(patsubst %.cc,%.o,$(SNAPPY_CC)) SnappyNative.o)
|
||||||
|
|
||||||
|
SNAPPY_UNPACKED:=$(TARGET)/snappy-extracted.log
|
||||||
|
|
||||||
|
CXXFLAGS:=$(CXXFLAGS) -I$(SNAPPY_SRC_DIR)
|
||||||
|
|
||||||
$(SNAPPY_ARCHIVE):
|
$(SNAPPY_ARCHIVE):
|
||||||
@mkdir -p $(@D)
|
@mkdir -p $(@D)
|
||||||
curl -o$@ http://snappy.googlecode.com/files/snappy-$(VERSION).tar.gz
|
curl -o$@ http://snappy.googlecode.com/files/snappy-$(VERSION).tar.gz
|
||||||
|
|
||||||
|
$(SNAPPY_UNPACKED): $(SNAPPY_ARCHIVE)
|
||||||
$(TARGET)/snappy-$(VERSION): $(SNAPPY_ARCHIVE)
|
|
||||||
tar xvfz $< -C $(TARGET)
|
tar xvfz $< -C $(TARGET)
|
||||||
|
touch $@
|
||||||
|
|
||||||
jni-header: $(SRC)/org/xerial/snappy/SnappyNative.h
|
jni-header: $(SRC)/org/xerial/snappy/SnappyNative.h
|
||||||
|
|
||||||
|
|
||||||
$(SRC)/org/xerial/snappy/SnappyNative.h: $(SRC)/org/xerial/snappy/SnappyNative.java
|
$(SRC)/org/xerial/snappy/SnappyNative.h: $(SRC)/org/xerial/snappy/SnappyNative.java
|
||||||
$(JAVAH) -classpath $(TARGET)/classes -o $@ org.xerial.snappy.SnappyNative
|
$(JAVAH) -classpath $(TARGET)/classes -o $@ org.xerial.snappy.SnappyNative
|
||||||
|
|
||||||
|
$(SNAPPY_SRC): $(SNAPPY_UNPACKED)
|
||||||
|
|
||||||
$(SNAPPY_OUT)/%.o : $(TARGET)/snappy-$(VERSION)/%.cc
|
$(SNAPPY_OUT)/%.o : $(SNAPPY_SRC_DIR)/%.cc
|
||||||
@mkdir -p $(@D)
|
@mkdir -p $(@D)
|
||||||
$(CXX) $(CXXFLAGS) -c -o $@ $<
|
$(CXX) $(CXXFLAGS) -c $< -o $@
|
||||||
|
|
||||||
$(SNAPPY_OUT)/%.o : $(SRC)/org/xerial/snappy/SnappyNative.cpp $(SRC)/org/xerial/snappy/SnappyNative.h
|
$(SNAPPY_OUT)/SnappyNative.o : $(SRC)/org/xerial/snappy/SnappyNative.cpp $(SRC)/org/xerial/snappy/SnappyNative.h
|
||||||
@mkdir -p $(@D)
|
@mkdir -p $(@D)
|
||||||
$(CXX) $(CXXFLAGS) -c -o $@ $<
|
$(CXX) $(CXXFLAGS) -c $< -o $@
|
||||||
|
|
||||||
|
|
||||||
$(SNAPPY_OUT)/$(LIBNAME): $(SNAPPY_OBJ)
|
$(SNAPPY_OUT)/$(LIBNAME): $(SNAPPY_OBJ)
|
||||||
$(CXX) $(CXXFLAGS) $(LINKFLAGS) $+ -o $@
|
$(CXX) $(CXXFLAGS) $(LINKFLAGS) $+ -o $@
|
||||||
@ -40,6 +48,8 @@ $(SNAPPY_OUT)/$(LIBNAME): $(SNAPPY_OBJ)
|
|||||||
clean-native:
|
clean-native:
|
||||||
rm -rf $(SNAPPY_OUT)
|
rm -rf $(SNAPPY_OUT)
|
||||||
|
|
||||||
|
clean:
|
||||||
|
rm -rf $(TARGET)
|
||||||
|
|
||||||
NATIVE_DIR:=src/main/resources/org/xerial/snappy/native/$(OS_NAME)/$(OS_ARCH)
|
NATIVE_DIR:=src/main/resources/org/xerial/snappy/native/$(OS_NAME)/$(OS_ARCH)
|
||||||
NATIVE_TARGET_DIR:=$(TARGET)/classes/org/xerial/snappy/native/$(OS_NAME)/$(OS_ARCH)
|
NATIVE_TARGET_DIR:=$(TARGET)/classes/org/xerial/snappy/native/$(OS_NAME)/$(OS_ARCH)
|
||||||
@ -47,7 +57,7 @@ NATIVE_DLL:=$(NATIVE_DIR)/$(LIBNAME)
|
|||||||
|
|
||||||
snappy-jar-version:=snappy-java-$(shell $(JAVA) -jar lib/silk-weaver.jar find 'project(artifactId, version)' pom.xml | grep snappy-java | awk '{ print $$2; }')
|
snappy-jar-version:=snappy-java-$(shell $(JAVA) -jar lib/silk-weaver.jar find 'project(artifactId, version)' pom.xml | grep snappy-java | awk '{ print $$2; }')
|
||||||
|
|
||||||
native: $(TARGET)/snappy-$(VERSION) $(NATIVE_DLL)
|
native: $(SNAPPY_UNPACKED) $(NATIVE_DLL)
|
||||||
snappy: $(TARGET)/$(snappy-jar-version).jar
|
snappy: $(TARGET)/$(snappy-jar-version).jar
|
||||||
|
|
||||||
$(NATIVE_DLL): $(SNAPPY_OUT)/$(LIBNAME)
|
$(NATIVE_DLL): $(SNAPPY_OUT)/$(LIBNAME)
|
||||||
@ -60,7 +70,7 @@ $(NATIVE_DLL): $(SNAPPY_OUT)/$(LIBNAME)
|
|||||||
$(TARGET)/$(snappy-jar-version).jar: native $(NATIVE_DLL)
|
$(TARGET)/$(snappy-jar-version).jar: native $(NATIVE_DLL)
|
||||||
$(MVN) package -Dmaven.test.skip=true
|
$(MVN) package -Dmaven.test.skip=true
|
||||||
|
|
||||||
test: snappy
|
test: $(NATIVE_DLL)
|
||||||
$(MVN) test
|
$(MVN) test
|
||||||
|
|
||||||
win32:
|
win32:
|
||||||
|
@ -31,7 +31,7 @@ else
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
snappy := snappy-$(VERSION)
|
snappy := snappy-$(VERSION)
|
||||||
SNAPPY_SRC:=$(TARGET)/snappy-$(VERSION)
|
|
||||||
|
|
||||||
jni_md := $(shell find -L "$(JAVA_HOME)" -name jni_md.h)
|
jni_md := $(shell find -L "$(JAVA_HOME)" -name jni_md.h)
|
||||||
ifneq ($(jni_md),)
|
ifneq ($(jni_md),)
|
||||||
@ -105,9 +105,9 @@ LINKFLAGS := $($(os_arch)_LINKFLAGS)
|
|||||||
LIBNAME := $($(os_arch)_LIBNAME)
|
LIBNAME := $($(os_arch)_LIBNAME)
|
||||||
SNAPPY_FLAGS := $($(os_arch)_SNAPPY_FLAGS)
|
SNAPPY_FLAGS := $($(os_arch)_SNAPPY_FLAGS)
|
||||||
|
|
||||||
SNAPPY_OUT:=$(TARGET)/$(snappy)-$(os_arch)
|
|
||||||
|
|
||||||
CXXFLAGS := $(CXXFLAGS) -Ilib/include -I$(SNAPPY_OUT) -I$(SNAPPY_SRC)
|
|
||||||
|
CXXFLAGS := $(CXXFLAGS) -Ilib/include
|
||||||
ifneq ($(jni_include),)
|
ifneq ($(jni_include),)
|
||||||
CXXFLAGS := $(CXXFLAGS) -I"$(jni_include)"
|
CXXFLAGS := $(CXXFLAGS) -I"$(jni_include)"
|
||||||
endif
|
endif
|
||||||
|
103
Makefile.package
Executable file
103
Makefile.package
Executable file
@ -0,0 +1,103 @@
|
|||||||
|
# Makefile for building and collecting native libraries in Win/Mac/Linux (32/64bit).
|
||||||
|
|
||||||
|
include Makefile.common
|
||||||
|
|
||||||
|
RESOURCE_DIR=src/main/resources
|
||||||
|
NATIVE_DIR=$(RESOURCE_DIR)/native
|
||||||
|
RSYNC=rsync -av -e ssh --exclude=".hg"
|
||||||
|
|
||||||
|
WIN_SERVER=192.168.11.10
|
||||||
|
WIN_WORK=work/hg/snappy-java
|
||||||
|
|
||||||
|
WIN64_SERVER=localhost
|
||||||
|
WIN64_WORK=work/hg/snappy-java
|
||||||
|
|
||||||
|
MAC_SERVER=192.168.11.11
|
||||||
|
MAC_WORK=work/hg/snappy-java
|
||||||
|
|
||||||
|
MAC_TIGER_SERVER=192.168.11.12
|
||||||
|
MAC_TIGER_WORK=work/hg/snappy-java
|
||||||
|
|
||||||
|
LINUX_SERVER=sprite
|
||||||
|
LINUX_WORK=work/hg/snappy-java
|
||||||
|
|
||||||
|
AMD_SERVER=utgb01
|
||||||
|
AMD_WORK=work/hg/snappy-java
|
||||||
|
|
||||||
|
BUILD_CMD = hg pull -u && make clean-native && make native
|
||||||
|
TEST_CMD = mvn test
|
||||||
|
|
||||||
|
all: compile test
|
||||||
|
|
||||||
|
.PHONY: compile test native clean
|
||||||
|
|
||||||
|
include VERSION
|
||||||
|
sqlite-version := sqlite-$(version)
|
||||||
|
|
||||||
|
LIB_DIR=target/dll/$(sqlite-version)
|
||||||
|
DLL_DIR=$(LIB_DIR)/native
|
||||||
|
|
||||||
|
DLL_WIN=$(DLL_DIR)/Windows/x86/snappy.dll
|
||||||
|
DLL_WIN64=$(DLL_DIR)/Windows/amd64/snappy.dll
|
||||||
|
DLL_MAC=$(DLL_DIR)/Mac/x86_64/libsnappy.jnilib
|
||||||
|
DLL_TIGER_MAC=$(DLL_DIR)/Mac/i386/libsnappy.jnilib
|
||||||
|
DLL_LINUX=$(DLL_DIR)/Linux/i386/libsnappy.so
|
||||||
|
DLL_AMD64=$(DLL_DIR)/Linux/amd64/libsnappy.so
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
$(DLL_WIN):
|
||||||
|
ssh $(WIN_SERVER) "source .zprofile && cd $(WIN_WORK) && $(BUILD_CMD)"
|
||||||
|
mkdir -p $(DLL_DIR)/Windows
|
||||||
|
$(RSYNC) $(WIN_SERVER):./$(WIN_WORK)/$(DLL_DIR)/Windows/ $(DLL_DIR)/Windows/
|
||||||
|
|
||||||
|
$(DLL_WIN64):
|
||||||
|
ssh $(WIN64_SERVER) "source .zprofile && cd $(WIN64_WORK) && $(BUILD_CMD)"
|
||||||
|
mkdir -p $(DLL_DIR)/Windows
|
||||||
|
$(RSYNC) $(WIN64_SERVER):./$(WIN64_WORK)/$(DLL_DIR)/Windows/ $(DLL_DIR)/Windows/
|
||||||
|
|
||||||
|
$(DLL_MAC):
|
||||||
|
ssh $(MAC_SERVER) "source .zprofile && cd $(MAC_WORK) && $(BUILD_CMD)"
|
||||||
|
mkdir -p $(DLL_DIR)/Mac
|
||||||
|
$(RSYNC) $(MAC_SERVER):./$(MAC_WORK)/$(DLL_DIR)/Mac/ $(DLL_DIR)/Mac/
|
||||||
|
|
||||||
|
$(DLL_TIGER_MAC):
|
||||||
|
ssh $(MAC_TIGER_SERVER) "source .zprofile && cd $(MAC_TIGER_WORK) && $(BUILD_CMD)"
|
||||||
|
mkdir -p $(DLL_DIR)/Mac
|
||||||
|
$(RSYNC) $(MAC_TIGER_SERVER):./$(MAC_TIGER_WORK)/$(DLL_DIR)/Mac/ $(DLL_DIR)/Mac/
|
||||||
|
|
||||||
|
|
||||||
|
$(DLL_LINUX):
|
||||||
|
ssh $(LINUX_SERVER) "source .zprofile && source /etc/profile.d/java.sh && cd $(LINUX_WORK) && $(BUILD_CMD)"
|
||||||
|
mkdir -p $(DLL_DIR)/Linux/i386
|
||||||
|
$(RSYNC) $(LINUX_SERVER):./$(LINUX_WORK)/$(DLL_DIR)/Linux/i386/ $(DLL_DIR)/Linux/i386/
|
||||||
|
|
||||||
|
$(DLL_AMD64):
|
||||||
|
ssh $(AMD_SERVER) "source .zprofile && cd $(AMD_WORK) && $(BUILD_CMD)"
|
||||||
|
mkdir -p $(DLL_DIR)/Linux/amd64
|
||||||
|
$(RSYNC) $(AMD_SERVER):./$(AMD_WORK)/$(DLL_DIR)/Linux/amd64/ $(DLL_DIR)/Linux/amd64/
|
||||||
|
|
||||||
|
$(DLL_DIR):
|
||||||
|
mkdir -p $@
|
||||||
|
|
||||||
|
native: $(DLL_DIR) $(DLL_WIN) $(DLL_WIN64) $(DLL_MAC) $(DLL_TIGER_MAC) $(DLL_LINUX) $(DLL_AMD64)
|
||||||
|
|
||||||
|
compile: native
|
||||||
|
cp -r $(DLL_DIR)/ $(RESOURCE_DIR)/native/
|
||||||
|
|
||||||
|
test:
|
||||||
|
ssh $(WIN_SERVER) "source .zprofile && cd $(WIN_WORK) && $(TEST_CMD)"
|
||||||
|
ssh $(MAC_SERVER) "source .zprofile && cd $(MAC_WORK) && $(TEST_CMD)"
|
||||||
|
ssh $(MAC_TIGER_SERVER) "source .zprofile && cd $(MAC_WORK) && $(TEST_CMD)"
|
||||||
|
ssh $(LINUX_SERVER) "source .zprofile && source /etc/profile.d/java.sh && cd $(LINUX_WORK) && $(TEST_CMD)"
|
||||||
|
ssh $(AMD_SERVER) "source .zprofile && cd $(AMD_WORK) && $(TEST_CMD)"
|
||||||
|
|
||||||
|
release:
|
||||||
|
mvn release:prepare
|
||||||
|
mvn release:perform
|
||||||
|
|
||||||
|
release-xerial:
|
||||||
|
mvn release:perform -Dtag=snappy-java-$(version)
|
||||||
|
|
||||||
|
release-sourceforge:
|
||||||
|
mvn release:perform -Darguments="-P sourceforge" -Dtag=snappy-java-$(version)
|
Binary file not shown.
Loading…
x
Reference in New Issue
Block a user