From f2df5d523dd75910a47ca9bc08b5cef267f57dca Mon Sep 17 00:00:00 2001 From: lide Date: Thu, 22 Nov 2018 11:15:42 +0800 Subject: [PATCH] Fix compile issue of thirdparty library (#338) --- build.sh | 12 ++++++++++++ env.sh | 24 +++++++----------------- thirdparty/build-thirdparty.sh | 23 ++++++++++++----------- thirdparty/download-thirdparty.sh | 1 - 4 files changed, 31 insertions(+), 29 deletions(-) diff --git a/build.sh b/build.sh index da44d1bba81a47..1c1a168be3b8ad 100755 --- a/build.sh +++ b/build.sh @@ -35,6 +35,18 @@ export DORIS_HOME=${ROOT} . ${DORIS_HOME}/env.sh +# build thirdparty libraries if necessary +if [[ ! -f ${DORIS_THIRDPARTY}/installed/lib/librdkafka.a ]]; then + echo "Thirdparty libraries need to be build ..." + ${DORIS_THIRDPARTY}/build-thirdparty.sh +fi + +# check java home +if [[ -z ${JAVA_HOME} ]]; then + echo "Warning: JAVA_HOME is not set, use thirdparty/installed/jdk1.8.0_131" + export JAVA_HOME=${DORIS_THIRDPARTY}/installed/jdk1.8.0_131 +fi + PARALLEL=$[$(nproc)/4+1] # Check args diff --git a/env.sh b/env.sh index 6c817685b0051e..060a1071a5d9a6 100755 --- a/env.sh +++ b/env.sh @@ -1,4 +1,3 @@ -#!/usr/bin/env bash # Licensed to the Apache Software Foundation (ASF) under one # or more contributor license agreements. See the NOTICE file # distributed with this work for additional information @@ -32,23 +31,14 @@ if [[ -z ${DORIS_THIRDPARTY} ]]; then export DORIS_THIRDPARTY=${DORIS_HOME}/thirdparty fi -# build thirdparty libraries if necessary -if [[ ! -d ${DORIS_THIRDPARTY}/installed ]]; then - echo "Thirdparty libraries need to be build ..." - ${DORIS_THIRDPARTY}/build-thirdparty.sh -fi - # check java version -if [[ -z ${JAVA_HOME} ]]; then - echo "Error: JAVA_HOME is not set, use thirdparty/installed/jdk1.8.0_131" - export JAVA_HOME=${DORIS_THIRDPARTY}/installed/jdk1.8.0_131 -fi - -export JAVA=${JAVA_HOME}/bin/java -JAVA_VER=$(${JAVA} -version 2>&1 | sed 's/.* version "\(.*\)\.\(.*\)\..*"/\1\2/; 1q' | cut -f1 -d " ") -if [[ $JAVA_VER -lt 18 ]]; then - echo "Error: require JAVA with JDK version at least 1.8" - exit 1 +if [[ ! -z ${JAVA_HOME} ]]; then + export JAVA=${JAVA_HOME}/bin/java + JAVA_VER=$(${JAVA} -version 2>&1 | sed 's/.* version "\(.*\)\.\(.*\)\..*"/\1\2/; 1q' | cut -f1 -d " ") + if [[ $JAVA_VER -lt 18 ]]; then + echo "Error: require JAVA with JDK version at least 1.8" + return 1 + fi fi # check maven diff --git a/thirdparty/build-thirdparty.sh b/thirdparty/build-thirdparty.sh index ce56e5ac4f2e52..ba09b5e5271840 100755 --- a/thirdparty/build-thirdparty.sh +++ b/thirdparty/build-thirdparty.sh @@ -35,8 +35,8 @@ export DORIS_HOME=$curdir/.. export TP_DIR=$curdir # include custom environment variables -if [[ -f ${DORIS_HOME}/custom_env.sh ]]; then - . ${DORIS_HOME}/custom_env.sh +if [[ -f ${DORIS_HOME}/env.sh ]]; then + . ${DORIS_HOME}/env.sh fi if [[ ! -f ${TP_DIR}/download-thirdparty.sh ]]; then @@ -57,17 +57,19 @@ ${TP_DIR}/download-thirdparty.sh export LD_LIBRARY_PATH=$TP_DIR/installed/lib:$LD_LIBRARY_PATH -if [ -f ${DORIS_TOOLCHAIN}/gcc730/bin/gcc ]; then - GCC_HOME=${DORIS_TOOLCHAIN}/gcc730 - export CC=${GCC_HOME}/bin/gcc - export CPP=${GCC_HOME}/bin/cpp - export CXX=${GCC_HOME}/bin/g++ +# set COMPILER +if [[ -z ${DORIS_GCC_HOME} ]]; then + export CC=${DORIS_GCC_HOME}/bin/gcc + export CPP=${DORIS_GCC_HOME}/bin/cpp + export CXX=${DORIS_GCC_HOME}/bin/g++ else - export CC=gcc - export CPP=cpp - export CXX=g++ + echo "DORIS_GCC_HOME environment variable is not set" + exit 1 fi +# prepare installed prefix +mkdir -p ${TP_DIR}/installed + check_prerequest() { local CMD=$1 local NAME=$2 @@ -119,7 +121,6 @@ check_prerequest "libtoolize --version" "libtool" ######################### # build all thirdparties ######################### -GCC_VERSION="$($CC -dumpversion)" CMAKE_CMD=`which cmake` diff --git a/thirdparty/download-thirdparty.sh b/thirdparty/download-thirdparty.sh index 772dfb48c793be..8a8e436aab1036 100755 --- a/thirdparty/download-thirdparty.sh +++ b/thirdparty/download-thirdparty.sh @@ -47,7 +47,6 @@ fi . ${TP_DIR}/vars.sh mkdir -p ${TP_DIR}/src -mkdir -p ${TP_DIR}/installed download() { local FILENAME=$1