sqlite-jdbc/sqlite-jdbc-3.15.1-build.patch
2020-08-10 15:47:55 +08:00

239 lines
9.2 KiB
Diff

diff -Nru sqlite-jdbc-3.15.1/Makefile sqlite-jdbc-3.15.1.build/Makefile
--- sqlite-jdbc-3.15.1/Makefile 2016-11-04 21:42:29.000000000 +0100
+++ sqlite-jdbc-3.15.1.build/Makefile 2016-11-06 12:15:06.926445700 +0100
@@ -3,45 +3,37 @@
RESOURCE_DIR = src/main/resources
-.phony: all package win32 win64 mac32 linux32 linux64 linux-arm linux-armhf native native-all deploy
+.phony: all package win32 win64 mac32 linux native native-all deploy
all: jni-header package
deploy:
- mvn package deploy -DperformRelease=true
-MVN:=mvn
+
+MVN:=xmvn -o
SRC:=src/main/java
SQLITE_OUT:=$(TARGET)/$(sqlite)-$(OS_NAME)-$(OS_ARCH)
-SQLITE_ARCHIVE:=$(TARGET)/$(sqlite)-amal.zip
-SQLITE_UNPACKED:=$(TARGET)/sqlite-unpack.log
-SQLITE_AMAL_DIR=$(TARGET)/$(SQLITE_AMAL_PREFIX)
+#SQLITE_ARCHIVE:=$(TARGET)/$(sqlite)-amal.zip
+#SQLITE_UNPACKED:=$(TARGET)/sqlite-unpack.log
+#SQLITE_AMAL_DIR=$(TARGET)/$(SQLITE_AMAL_PREFIX)
-CCFLAGS:= -I$(SQLITE_OUT) -I$(SQLITE_AMAL_DIR) $(CCFLAGS)
+CCFLAGS:= -I$(SQLITE_OUT) $(CCFLAGS) -lsqlite3
$(SQLITE_ARCHIVE):
- @mkdir -p $(@D)
- curl -L --max-redirs 0 -f -o$@ http://www.sqlite.org/2016/$(SQLITE_AMAL_PREFIX).zip || \
- curl -L --max-redirs 0 -f -o$@ http://www.sqlite.org/2015/$(SQLITE_AMAL_PREFIX).zip || \
- curl -L --max-redirs 0 -f -o$@ http://www.sqlite.org/2014/$(SQLITE_AMAL_PREFIX).zip || \
- curl -L --max-redirs 0 -f -o$@ http://www.sqlite.org/2013/$(SQLITE_AMAL_PREFIX).zip || \
- curl -L --max-redirs 0 -f -o$@ http://www.sqlite.org/$(SQLITE_AMAL_PREFIX).zip || \
- curl -L --max-redirs 0 -f -o$@ http://www.sqlite.org/$(SQLITE_OLD_AMAL_PREFIX).zip
+
$(SQLITE_UNPACKED): $(SQLITE_ARCHIVE)
- unzip -qo $< -d $(TARGET)/tmp.$(version)
- (mv $(TARGET)/tmp.$(version)/$(SQLITE_AMAL_PREFIX) $(TARGET) && rmdir $(TARGET)/tmp.$(version)) || mv $(TARGET)/tmp.$(version)/ $(TARGET)/$(SQLITE_AMAL_PREFIX)
- touch $@
-$(TARGET)/common-lib/org/sqlite/%.class: src/main/java/org/sqlite/%.java
+
+$(SQLITE_OUT)/org/sqlite/%.class: src/main/java/org/sqlite/%.java
@mkdir -p $(@D)
- $(JAVAC) -source 1.5 -target 1.5 -sourcepath $(SRC) -d $(TARGET)/common-lib $<
+ $(JAVAC) -source 1.6 -target 1.6 -sourcepath $(SRC) -d $(SQLITE_OUT) $<
-jni-header: $(TARGET)/common-lib/NativeDB.h
+jni-header: $(SQLITE_OUT)/NativeDB.h
-$(TARGET)/common-lib/NativeDB.h: $(TARGET)/common-lib/org/sqlite/core/NativeDB.class
- $(JAVAH) -classpath $(TARGET)/common-lib -jni -o $@ org.sqlite.core.NativeDB
+$(SQLITE_OUT)/NativeDB.h: $(SQLITE_OUT)/org/sqlite/core/NativeDB.class
+ $(JAVAH) -classpath $(SQLITE_OUT) -jni -o $@ org.sqlite.core.NativeDB
test:
mvn test
@@ -50,35 +42,11 @@
$(SQLITE_OUT)/sqlite3.o : $(SQLITE_UNPACKED)
- @mkdir -p $(@D)
- perl -p -e "s/sqlite3_api;/sqlite3_api = 0;/g" \
- $(SQLITE_AMAL_DIR)/sqlite3ext.h > $(SQLITE_OUT)/sqlite3ext.h
-# insert a code for loading extension functions
- perl -p -e "s/^opendb_out:/ if(!db->mallocFailed && rc==SQLITE_OK){ rc = RegisterExtensionFunctions(db); }\nopendb_out:/;" \
- $(SQLITE_AMAL_DIR)/sqlite3.c > $(SQLITE_OUT)/sqlite3.c
- cat src/main/ext/*.c >> $(SQLITE_OUT)/sqlite3.c
- $(CC) -o $@ -c $(CCFLAGS) \
- -DSQLITE_ENABLE_LOAD_EXTENSION=1 \
- -DSQLITE_HAVE_ISNAN \
- -DSQLITE_HAVE_USLEEP \
- -DSQLITE_ENABLE_UPDATE_DELETE_LIMIT \
- -DSQLITE_ENABLE_COLUMN_METADATA \
- -DSQLITE_CORE \
- -DSQLITE_ENABLE_FTS3 \
- -DSQLITE_ENABLE_FTS3_PARENTHESIS \
- -DSQLITE_ENABLE_FTS5 \
- -DSQLITE_ENABLE_JSON1 \
- -DSQLITE_ENABLE_RTREE \
- -DSQLITE_ENABLE_STAT2 \
- -DSQLITE_THREADSAFE=1 \
- -DSQLITE_DEFAULT_MEMSTATUS=0 \
- -DSQLITE_MAX_VARIABLE_NUMBER=250000 \
- $(SQLITE_FLAGS) \
- $(SQLITE_OUT)/sqlite3.c
-$(SQLITE_OUT)/$(LIBNAME): $(SQLITE_OUT)/sqlite3.o $(SRC)/org/sqlite/core/NativeDB.c
+
+$(SQLITE_OUT)/$(LIBNAME): $(SQLITE_OUT)/sqlite3.o $(SRC)/org/sqlite/core/NativeDB.c $(SQLITE_OUT)/NativeDB.h
@mkdir -p $(@D)
- $(CC) $(CCFLAGS) -I $(TARGET)/common-lib -c -o $(SQLITE_OUT)/NativeDB.o $(SRC)/org/sqlite/core/NativeDB.c
+ $(CC) $(CCFLAGS) -I $(SQLITE_OUT) -c -o $(SQLITE_OUT)/NativeDB.o $(SRC)/org/sqlite/core/NativeDB.c
$(CC) $(CCFLAGS) -o $@ $(SQLITE_OUT)/*.o $(LINKFLAGS)
$(STRIP) $@
@@ -88,7 +56,7 @@
NATIVE_DLL:=$(NATIVE_DIR)/$(LIBNAME)
# For cross-compilation, install docker. See also https://github.com/dockcross/dockcross
-native-all: native win32 win64 linux32 linux64 linux-arm linux-armhf
+native-all: native linux
native: $(SQLITE_UNPACKED) $(NATIVE_DLL)
@@ -99,33 +67,23 @@
cp $< $(NATIVE_TARGET_DIR)/$(LIBNAME)
win32: $(SQLITE_UNPACKED) jni-header
- ./docker/dockcross-windows-x86 bash -c 'make clean-native native CROSS_PREFIX=i686-w64-mingw32.static- OS_NAME=Windows OS_ARCH=x86'
-
-win64: $(SQLITE_UNPACKED) jni-header
- ./docker/dockcross-windows-x64 bash -c 'make clean-native native CROSS_PREFIX=x86_64-w64-mingw32.static- OS_NAME=Windows OS_ARCH=x86_64'
-linux32: $(SQLITE_UNPACKED) jni-header
- docker run -ti -v $$PWD:/work xerial/centos5-linux-x86 bash -c 'make clean-native native OS_NAME=Linux OS_ARCH=x86'
-linux64: $(SQLITE_UNPACKED) jni-header
- docker run -ti -v $$PWD:/work xerial/centos5-linux-x86_64 bash -c 'make clean-native native OS_NAME=Linux OS_ARCH=x86_64'
+win64: $(SQLITE_UNPACKED) jni-header
-linux-arm: $(SQLITE_UNPACKED) jni-header
- ./docker/dockcross-armv5 bash -c 'make clean-native native CROSS_PREFIX=arm-linux-gnueabi- OS_NAME=Linux OS_ARCH=arm'
-linux-armhf: $(SQLITE_UNPACKED) jni-header
- ./docker/dockcross-armv6 bash -c 'make clean-native native CROSS_PREFIX=arm-linux-gnueabihf- OS_NAME=Linux OS_ARCH=armhf'
+linux: $(SQLITE_UNPACKED) jni-header
+ $(MAKE) native OS_NAME=Linux OS_ARCH=$(OS_ARCH)
sparcv9:
- $(MAKE) native OS_NAME=SunOS OS_ARCH=sparcv9
+
# deprecated
mac32:
- $(MAKE) native OS_NAME=Mac OS_ARCH=x86
+
package: native-all
- rm -rf target/dependency-maven-plugin-markers
- $(MVN) package
+
clean-native:
rm -rf $(SQLITE_OUT)
@@ -138,7 +96,7 @@
rm -rf $(TARGET)/{surefire*,testdb.jar*}
docker-linux64:
- docker build -f docker/Dockerfile.linux_x86_64 -t xerial/centos5-linux-x86-64 .
+
docker-linux32:
- docker build -f docker/Dockerfile.linux_x86 -t xerial/centos5-linux-x86 .
+
diff -Nru sqlite-jdbc-3.15.1/Makefile.common sqlite-jdbc-3.15.1.build/Makefile.common
--- sqlite-jdbc-3.15.1/Makefile.common 2016-11-04 21:42:29.000000000 +0100
+++ sqlite-jdbc-3.15.1.build/Makefile.common 2016-11-06 11:58:31.575085824 +0100
@@ -47,50 +47,24 @@
# os=Default is meant to be generic unix/linux
-known_targets := Linux-x86 Linux-x86_64 Linux-arm Linux-armhf Mac-x86 Mac-x86_64 FreeBSD-x86_64 OpenBSD-x86_64 Windows-x86 Windows-x86_64 SunOS-sparcv9
+known_targets := Linux Mac-x86 Mac-x86_64 FreeBSD-x86_64 OpenBSD-x86_64 Windows-x86 Windows-x86_64 SunOS-sparcv9
target := $(OS_NAME)-$(OS_ARCH)
-ifeq (,$(findstring $(strip $(target)),$(known_targets)))
- target := Default
+ifeq ($(OS_NAME),Linux)
+ target := $(OS_NAME)
+else
+ target := $(OS_NAME)-$(OS_ARCH)
endif
# cross-compilation toolchain prefix (e.g. "arm-linux-gnueabi-")
CROSS_PREFIX :=
-Default_CC := $(CROSS_PREFIX)gcc
-Default_STRIP := $(CROSS_PREFIX)strip
-Default_CCFLAGS := -I$(JAVA_HOME)/include -Ilib/inc_linux -Os -fPIC -fvisibility=hidden
-Default_LINKFLAGS := -shared
-Default_LIBNAME := libsqlitejdbc.so
-Default_SQLITE_FLAGS :=
-
-Linux-x86_CC := $(CROSS_PREFIX)gcc
-Linux-x86_STRIP := $(CROSS_PREFIX)strip
-Linux-x86_CCFLAGS := -I$(JAVA_HOME)/include -Ilib/inc_linux -O2 -fPIC -m32 -fvisibility=hidden
-Linux-x86_LINKFLAGS := -shared -static-libgcc
-Linux-x86_LIBNAME := libsqlitejdbc.so
-Linux-x86_SQLITE_FLAGS :=
-
-Linux-x86_64_CC := $(CROSS_PREFIX)gcc
-Linux-x86_64_STRIP := $(CROSS_PREFIX)strip
-Linux-x86_64_CCFLAGS := -Ilib/inc_linux -I$(JAVA_HOME)/include -O2 -fPIC -m64 -fvisibility=hidden
-Linux-x86_64_LINKFLAGS := -shared -static-libgcc
-Linux-x86_64_LIBNAME := libsqlitejdbc.so
-Linux-x86_64_SQLITE_FLAGS :=
-
-Linux-arm_CC := $(CROSS_PREFIX)gcc
-Linux-arm_STRIP := $(CROSS_PREFIX)strip
-Linux-arm_CCFLAGS := -I$(JAVA_HOME)/include -Ilib/inc_linux -O2 -fPIC -mfloat-abi=softfp -mfpu=vfp -fvisibility=hidden
-Linux-arm_LINKFLAGS := -shared -static-libgcc
-Linux-arm_LIBNAME := libsqlitejdbc.so
-Linux-arm_SQLITE_FLAGS :=
-
-Linux-armhf_CC := $(CROSS_PREFIX)gcc
-Linux-armhf_STRIP := $(CROSS_PREFIX)strip
-Linux-armhf_CCFLAGS := -I$(JAVA_HOME)/include -Ilib/inc_linux -O2 -mfloat-abi=hard -mfpu=vfp -fPIC -fvisibility=hidden
-Linux-armhf_LINKFLAGS := -shared -static-libgcc
-Linux-armhf_LIBNAME := libsqlitejdbc.so
-Linux-armhf_SQLITE_FLAGS :=
+Linux_CC := gcc
+Linux_STRIP := strip
+Linux_CCFLAGS := -I$(JAVA_HOME)/include $(CCFLAGS) -fPIC -fvisibility=hidden
+Linux_LINKFLAGS := -shared -static-libgcc
+Linux_LIBNAME := libsqlitejdbc.so
+Linux_SQLITE_FLAGS :=
FreeBSD-x86_64_CC := $(CROSS_PREFIX)cc
FreeBSD-x86_64_STRIP := $(CROSS_PREFIX)strip
diff -Nru sqlite-jdbc-3.15.1/pom.xml sqlite-jdbc-3.15.1.build/pom.xml
--- sqlite-jdbc-3.15.1/pom.xml 2016-11-04 21:42:29.000000000 +0100
+++ sqlite-jdbc-3.15.1.build/pom.xml 2016-11-06 11:54:16.840693425 +0100
@@ -84,7 +84,7 @@
<artifactId>maven-compiler-plugin</artifactId>
<version>3.1</version>
<configuration>
- <source>1.5</source>
+ <source>1.6</source>
<target>1.6</target>
</configuration>
</plugin>