diff --git a/build/Makefile.linux b/build/Makefile.linux index 86ca140..ac2ed04 100644 --- a/build/Makefile.linux +++ b/build/Makefile.linux @@ -6,7 +6,10 @@ SQLITE:=$(ROOT)/sqlite # Directories ARROW=$(HERE)/arrow ARROW_RELEASE=$(ARROW)/cpp/release +BOOST_ROOT=$(ARROW_RELEASE)/boost_ep-prefix/src/boost_ep +BOOST=$(BOOST_ROOT)/stage/lib BROTLI=$(ARROW_RELEASE)/brotli_ep/src/brotli_ep-install/lib/x86_64-linux-gnu +ICU=$(HERE)/icu LZ4=$(ARROW_RELEASE)/lz4_ep-prefix/src/lz4_ep/lib PARQUET_CPP=$(HERE)/parquet-cpp SNAPPY=$(ARROW_RELEASE)/snappy_ep/src/snappy_ep-install/lib @@ -15,12 +18,15 @@ ZSTD=$(ARROW_RELEASE)/zstd_ep-prefix/src/zstd_ep/lib # Libraries ARROW_LIB = $(ARROW_RELEASE)/release/libarrow.a -BOOST_FILESYSTEM_LIB = /usr/lib/x86_64-linux-gnu/libboost_filesystem.so -BOOST_LIB = /usr/lib/x86_64-linux-gnu/libboost_regex.so -BOOST_SYSTEM_LIB = /usr/lib/x86_64-linux-gnu/libboost_system.so +BOOST_FILESYSTEM_LIB = $(BOOST)/libboost_filesystem.a +BOOST_REGEX_LIB = $(BOOST)/libboost_regex.a +BOOST_SYSTEM_LIB = $(BOOST)/libboost_system.a BROTLI_COMMON_LIB = $(BROTLI)/libbrotlicommon.a BROTLI_DEC_LIB = $(BROTLI)/libbrotlidec.a BROTLI_ENC_LIB = $(BROTLI)/libbrotlienc.a +ICU_I18N_LIB=$(ICU)/source/lib/libicui18n.a +ICU_UC_LIB=$(ICU)/source/lib/libicuuc.a +ICU_DATA_LIB=$(ICU)/source/lib/libicudata.a LZ4_LIB = $(LZ4)/liblz4.a PARQUET_CPP_LIB = $(PARQUET_CPP)/build/release/libparquet.a SNAPPY_LIB = $(SNAPPY)/libsnappy.a @@ -36,11 +42,11 @@ CFLAGS = -I $(SQLITE) -I $(PARQUET_CPP)/src -I $(ARROW)/cpp/src -O3 -std=c++11 - LDFLAGS = -O3 \ -Wl,--whole-archive $(PARQUET_CPP_LIB) $(LZ4_LIB) $(ZSTD_LIB) $(THRIFT_LIB) $(SNAPPY_LIB) $(ARROW_LIB) \ - $(BROTLI_ENC_LIB) $(BROTLI_COMMON_LIB) $(BROTLI_DEC_LIB) \ - -Wl,--no-whole-archive -lz -lcrypto -lssl $(BOOST_LIB) $(BOOST_SYSTEM_LIB) $(BOOST_FILESYSTEM_LIB) + $(ICU_I18N_LIB) $(ICU_UC_LIB) $(ICU_DATA_LIB) \ + $(BROTLI_ENC_LIB) $(BROTLI_COMMON_LIB) $(BROTLI_DEC_LIB) $(BOOST_REGEX_LIB) $(BOOST_SYSTEM_LIB) $(BOOST_FILESYSTEM_LIB) \ + -Wl,--no-whole-archive -lz -lcrypto -lssl OBJ = parquet.o parquet_filter.o parquet_table.o parquet_cursor.o -LIBS = $(ARROW_LIB) \ - $(PARQUET_CPP_LIB) +LIBS = $(ARROW_LIB) $(PARQUET_CPP_LIB) $(ICU_I18N_LIB) libparquet.so: $(LIBS) $(OBJ) $(CC) -shared -o $@ $(OBJ) $(LDFLAGS) @@ -62,20 +68,29 @@ $(ARROW_LIB): git clone https://github.com/apache/arrow.git $(ARROW) cd $(ARROW) && git checkout apache-arrow-0.9.0 mkdir $(ARROW)/cpp/release - cd $(ARROW)/cpp/release && cmake .. -DCMAKE_BUILD_TYPE=Release + cd $(ARROW)/cpp/release && cmake -DCMAKE_BUILD_TYPE=Release -DARROW_BOOST_VENDORED=ON -DARROW_BOOST_USE_SHARED=OFF .. cd $(ARROW)/cpp/release && make -j$(CPUS) unittest +# This is pretty gross. I'm sure someone who knows what they're doing could do this more cleanly. +$(ICU_I18N_LIB): + rm -rf $(ICU) + mkdir $(ICU) + cd $(ICU) && wget http://download.icu-project.org/files/icu4c/55.1/icu4c-55_1-src.tgz + cd $(ICU) && tar xf icu4c-55_1-src.tgz --strip-components=1 + cd $(ICU)/source && ./configure --enable-static + cd $(ICU)/source && make -j$(CPUS) LIBCFLAGS='-fPIC' LIBCXXFLAGS='-fPIC' + $(PARQUET_CPP_LIB): $(ARROW_LIB) rm -rf $(PARQUET_CPP) git clone https://github.com/apache/parquet-cpp.git $(PARQUET_CPP) cd $(PARQUET_CPP) && git checkout apache-parquet-cpp-1.4.0 - cd $(PARQUET_CPP) && SNAPPY_STATIC_LIB=$(SNAPPY_LIB) BROTLI_STATIC_LIB_ENC=$(BROTLI_ENC_LIB) BROTLI_STATIC_LIB_DEC=$(BROTLI_DEC_LIB) BROTLI_STATIC_LIB_COMMON=$(BROTLI_COMMON_LIB) ZLIB_STATIC_LIB=$(ZLIB_LIB) LZ4_STATIC_LIB=$(LZ4_LIB) ZSTD_STATIC_LIB=$(ZSTD_LIB) cmake -DCMAKE_BUILD_TYPE=Release -DPARQUET_MINIMAL_DEPENDENCY=ON -DPARQUET_ARROW_LINKAGE=static . + cd $(PARQUET_CPP) && BOOST_ROOT=$(BOOST_ROOT) BOOST_STATIC_REGEX_LIBRARY=$(BOOST_REGEX_LIB) SNAPPY_STATIC_LIB=$(SNAPPY_LIB) BROTLI_STATIC_LIB_ENC=$(BROTLI_ENC_LIB) BROTLI_STATIC_LIB_DEC=$(BROTLI_DEC_LIB) BROTLI_STATIC_LIB_COMMON=$(BROTLI_COMMON_LIB) ZLIB_STATIC_LIB=$(ZLIB_LIB) LZ4_STATIC_LIB=$(LZ4_LIB) ZSTD_STATIC_LIB=$(ZSTD_LIB) cmake -DCMAKE_BUILD_TYPE=Release -DPARQUET_MINIMAL_DEPENDENCY=ON -DPARQUET_ARROW_LINKAGE=static -DPARQUET_BOOST_USE_SHARED=OFF . cd $(PARQUET_CPP) && make -j$(CPUS) $(SQLITE3_LIB): cd $(ROOT) && ./build-sqlite -.PHONY: clean arrow parquet sqlite +.PHONY: clean arrow icu parquet sqlite clean: rm -f *.o *.so @@ -86,6 +101,8 @@ distclean: arrow: $(ARROW_LIB) +icu: $(ICU_I18N_LIB) + parquet: $(PARQUET_CPP_LIB) sqlite: $(SQLITE3_LIB)