From 8e62b03217c78e78eddf3ff8dbd5948dd4831aa6 Mon Sep 17 00:00:00 2001 From: guowenxue <guowenxue@gmail.com> Date: Fri, 23 Aug 2024 10:48:29 +0800 Subject: [PATCH] update build shell script form openlibs --- openlibs/sqlite/build.sh | 192 ++++++++++++++++++++++++++++++++++------------- 1 files changed, 138 insertions(+), 54 deletions(-) diff --git a/openlibs/sqlite/build.sh b/openlibs/sqlite/build.sh index ce0682e..a7c2fa5 100755 --- a/openlibs/sqlite/build.sh +++ b/openlibs/sqlite/build.sh @@ -1,43 +1,120 @@ #!/bin/bash -#+-------------------------------------------------------------------------------------------- -#|Description: This shell script used download and compile sqlite for ARM -#| Author: GuoWenxue <guowenxue@gmail.com> -#| ChangeLog: -#| 1, Initialize 1.0.0 on 2011.04.12 -#+-------------------------------------------------------------------------------------------- +# library name and version +# Official: https://www.sqlite.org/download.html +LIB_NAME=sqlite-autoconf-3420000 +PACK_SUFIX=tar.gz -PREFIX_PATH=`pwd`/../install/ - +# LingYun source code FTP server LYFTP_SRC=http://master.weike-iot.com:2211/src/ +# library download URL address +LIB_URL=$LYFTP_SRC + +# Cross compiler for cross compile on Linux server CROSS_COMPILE=/opt/gcc-aarch32-10.3-2021.07/bin/arm-none-linux-gnueabihf- -function msg_banner() -{ - echo "" - echo "+-----------------------------------------------------------------------" - echo "| $1 " - echo "+-----------------------------------------------------------------------" - echo "" +# compile jobs +JOBS=`cat /proc/cpuinfo |grep "processor"|wc -l` + +# this project absolute path +PRJ_PATH=$(cd $(dirname "${BASH_SOURCE[0]}") && pwd) + +# top project absolute path +TOP_PATH=$(realpath $PRJ_PATH/..) + +# binaries install path +PREFIX_PATH=$TOP_PATH/install +BIN_PATH=$PREFIX_PATH/bin +LIB_PATH=$PREFIX_PATH/lib +INC_PATH=$PREFIX_PATH/include + +# check installed or not file +INST_FILE=$PREFIX_PATH/bin/sqlite3 + +# shell script will exit once get command error +set -e + +#+-------------------------+ +#| Shell script functions | +#+-------------------------+ + +function pr_error() { + echo -e "\033[40;31m $1 \033[0m" +} + +function pr_warn() { + echo -e "\033[40;33m $1 \033[0m" +} + +function pr_info() { + echo -e "\033[40;32m $1 \033[0m" } function check_result() { if [ $? != 0 ] ; then - echo "" - echo "+-----------------------------------------------------------------------" - echo "| $1 " - echo "+-----------------------------------------------------------------------" - echo "" - exit ; + pr_error "$1" fi } - -function export_cross() +# decompress a packet to destination path +function do_unpack() { + tarball=$1 + dstpath=`pwd` + + if [[ $# == 2 ]] ; then + dstpath=$2 + fi + + pr_info "decompress $tarball => $dstpath" + + mkdir -p $dstpath + case $tarball in + *.tar.gz) + tar -xzf $tarball -C $dstpath + ;; + + *.tar.bz2) + tar -xjf $tarball -C $dstpath + ;; + + *.tar.xz) + tar -xJf $tarball -C $dstpath + ;; + + *.tar.zst) + tar -I zstd -xf $tarball -C $dstpath + ;; + + *.tar) + tar -xf $tarball -C $dstpath + ;; + + *.zip) + unzip -qo $tarball -d $dstpath + ;; + + *) + pr_error "decompress Unsupport packet: $tarball" + return 1; + ;; + esac +} + +function do_export() +{ + BUILD_ARCH=$(uname -m) + if [[ $BUILD_ARCH =~ "arm" ]] ; then + pr_warn "local($BUILD_ARCH) compile $LIB_NAME" + return ; + fi + + pr_warn "cross(${CROSS_COMPILE}) compile $LIB_NAME" + # export cross toolchain export CC=${CROSS_COMPILE}gcc + export CXX=${CROSS_COMPILE}g++ export AS=${CROSS_COMPILE}as export AR=${CROSS_COMPILE}ar export LD=${CROSS_COMPILE}ld @@ -46,7 +123,7 @@ export OBJDUMP=${CROSS_COMPILE}objdump export STRIP=${CROSS_COMPILE}strip - # export cross configure + # export cross configure export CONFIG_CROSS=" --build=i686-pc-linux --host=arm-linux " # Clear LDFLAGS and CFLAGS @@ -54,44 +131,51 @@ export CFLAGS= } - -function compile_sqlite() +function do_fetch() { - SRC_NAME=sqlite-autoconf-3290000 - PACK_SUFIX=tar.gz - - if [ -f ${PREFIX_PATH}/bin/sqlite3 ] ; then - msg_banner "$SRC_NAME already compile and installed" - return 0; + if [ -e ${INST_FILE} ] ; then + pr_warn "$LIB_NAME compile and installed alredy" + exit ; fi - msg_banner "Start donwload $SRC_NAME " - if [ ! -f ${SRC_NAME}.${PACK_SUFIX} ] ; then - #wget https://www.sqlite.org/2019/${SRC_NAME}.${PACK_SUFIX} - wget ${LYFTP_SRC}/${SRC_NAME}.${PACK_SUFIX} - check_result "ERROR: download ${SRC_NAME} failure" + if [ -d $LIB_NAME ] ; then + pr_warn "$LIB_NAME fetch already" + return ; fi - tar -xzf ${SRC_NAME}.${PACK_SUFIX} - cd ${SRC_NAME} + if [ ! -f ${LIB_NAME}.${PACK_SUFIX} ] ; then + wget ${LIB_URL}/${LIB_NAME}.${PACK_SUFIX} + check_result "ERROR: download ${LIB_NAME} failure" + fi - msg_banner "Start cross compile $SRC_NAME " - - ./configure --prefix=${PREFIX_PATH} ${CONFIG_CROSS} --enable-static - - check_result "ERROR: configure ${SRC_NAME} failure" - - make && make install - check_result "ERROR: compile ${SRC_NAME} failure" - - - ${STRIP} ${PREFIX_PATH}/bin/sqlite3 - - cd - + do_unpack ${LIB_NAME}.${PACK_SUFIX} } -export_cross +function do_build() +{ + cd $LIB_NAME -compile_sqlite + do_export + ./configure --prefix=${PREFIX_PATH} ${CONFIG_CROSS} --enable-static + check_result "ERROR: configure ${LIB_NAME} failure" + + make && make install + check_result "ERROR: compile ${LIB_NAME} failure" +} + +function do_clean() +{ + rm -rf *${LIB_NAME}* +} + +if [[ $# == 1 && $1 == -c ]] ;then + pr_warn "start clean ${LIB_NAME}" + do_clean + exit; +fi + +do_fetch + +do_build -- Gitblit v1.9.1