Compare commits
14 Commits
4b4794e253
...
2.1.4
| Author | SHA1 | Date | |
|---|---|---|---|
| fa15e15758 | |||
| d60c86ec3b | |||
| 1576021cf7 | |||
| 646773f574 | |||
| 3b7f72c8b3 | |||
| 144b333b60 | |||
| 0b5eed8b4c | |||
| 5c1b063399 | |||
| c5f8f6ee09 | |||
| 91dfc8bc74 | |||
| d021389637 | |||
| 9c4959d51e | |||
| 4fc62f65b4 | |||
| f4c12e9b0e |
1
CBUILD_VERSION
Normal file
1
CBUILD_VERSION
Normal file
@@ -0,0 +1 @@
|
|||||||
|
2.1.4
|
||||||
17
CHANGELOG.md
17
CHANGELOG.md
@@ -1,7 +1,22 @@
|
|||||||
# NEXT: v2.1.0
|
# v2.1.4
|
||||||
|
+ added `-Wl,-rpath` argument generation in `link()`. It forces ld to link to local shared library in `OUTDIR`
|
||||||
|
|
||||||
|
# v2.1.3
|
||||||
|
+ added `DEP_OTHER_OUT_FILES` to dependency configs
|
||||||
|
+ if `PRESERVE_OUT_DIRECTORY_STRUCTURE=true` then `DEP_DYNAMIC_OUT_FILES` and `DEP_OTHER_OUT_FILES` are copied to `OUTDIR` preserving directory structure (example_dir/lib1.so -> $OUTDIR/example_dir/lib1.so)
|
||||||
|
|
||||||
|
# v2.1.2
|
||||||
|
+ changed compile_c and compile_cpp functions
|
||||||
|
+ bootstrap now can print help and list of installed versions
|
||||||
|
|
||||||
|
# v2.1.1
|
||||||
|
+ **config**: removed `TESTS_C` and `TESTS_CPP` compilation
|
||||||
|
|
||||||
|
# v2.1.0
|
||||||
+ **config**: no more `current.config` and `default.config`, just `project.config`
|
+ **config**: no more `current.config` and `default.config`, just `project.config`
|
||||||
+ improved version checking
|
+ improved version checking
|
||||||
+ `setup.sh` now installs each minor version in separate dicectory
|
+ `setup.sh` now installs each minor version in separate dicectory
|
||||||
|
+ added `bootstrap.sh` which automaticly selects cbuild version specified in project config
|
||||||
|
|
||||||
# v2.0.2
|
# v2.0.2
|
||||||
+ new dependency resolution system (see **config** and `example_dependency_configs`)
|
+ new dependency resolution system (see **config** and `example_dependency_configs`)
|
||||||
|
|||||||
22
README.md
22
README.md
@@ -1,23 +1,31 @@
|
|||||||
# cbuild
|
# cbuild
|
||||||
My C/C++ build system written in bash.
|
My C/C++ build system written in sh.
|
||||||
|
|
||||||
|
|
||||||
## Installation
|
## Installation
|
||||||
```bash
|
```sh
|
||||||
git clone https://timerix.ddns.net:3322/cbuild.git
|
git clone https://timerix.ddns.net:3322/Timerix/cbuild.git
|
||||||
cd cbuild
|
cd cbuild
|
||||||
sudo ./setup.sh
|
sudo ./setup.sh
|
||||||
```
|
```
|
||||||
|
Can be installed to `~/.local/` if you have no root rights.
|
||||||
|
- ```sh
|
||||||
|
./setup.sh --local
|
||||||
|
```
|
||||||
|
- Then add `~/.local/bin` to `PATH` in your shell config.
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
1. Initialize cbuild project in some directory:
|
1. Initialize cbuild project in some directory:
|
||||||
```bash
|
```sh
|
||||||
cd some_project
|
cd some_project
|
||||||
cbuild --new-project
|
cbuild --new-project
|
||||||
```
|
```
|
||||||
|
2. Edit `project.config`.
|
||||||
2. Edit `default.config`.
|
|
||||||
3. Call some tasks:
|
3. Call some tasks:
|
||||||
```bash
|
```sh
|
||||||
cbuild build_exec_dbg exec
|
cbuild build_exec_dbg exec
|
||||||
```
|
```
|
||||||
|
P.S. See help
|
||||||
|
```sh
|
||||||
|
cbuild -h
|
||||||
|
```
|
||||||
|
|||||||
124
bootstrap.sh
Normal file
124
bootstrap.sh
Normal file
@@ -0,0 +1,124 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
CBUILD_BOOTSTRAP_VERSION=1.0.1
|
||||||
|
set -eo pipefail
|
||||||
|
|
||||||
|
function version_parse {
|
||||||
|
local value="$1"
|
||||||
|
var_name="$2"
|
||||||
|
IFS_backup="$IFS"
|
||||||
|
IFS='.'
|
||||||
|
local v_array=($value)
|
||||||
|
IFS="$IFS_backup"
|
||||||
|
eval ${var_name}_version_major=${v_array[0]}
|
||||||
|
eval ${var_name}_version_minor=${v_array[1]}
|
||||||
|
eval ${var_name}_version_patch=${v_array[2]}
|
||||||
|
}
|
||||||
|
|
||||||
|
function safeprint {
|
||||||
|
printf "%s" "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
function exec_script_line {
|
||||||
|
local script="$1"
|
||||||
|
local line_num="$2"
|
||||||
|
local line_str="$(sed $line_num'!d' $script)"
|
||||||
|
if [ -z "$line_str" ]; then
|
||||||
|
echo "script line is empty"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
eval "$line_str"
|
||||||
|
}
|
||||||
|
|
||||||
|
function print_version_list {
|
||||||
|
dir_local="$HOME/.local/share/cbuild"
|
||||||
|
dir_global="/usr/local/share/cbuild"
|
||||||
|
files=""
|
||||||
|
if [ -d "$dir_local" ]; then
|
||||||
|
files+="$(find $dir_local -name 'CBUILD_VERSION')"
|
||||||
|
fi
|
||||||
|
if [ -d "$dir_global" ]; then
|
||||||
|
files+="$(find $dir_global -name 'CBUILD_VERSION')"
|
||||||
|
fi
|
||||||
|
for f in $files; do
|
||||||
|
cat $f | sed '$a\'
|
||||||
|
done | sort -V
|
||||||
|
}
|
||||||
|
|
||||||
|
function print_help {
|
||||||
|
echo "cbuild-bootstrap v$CBUILD_BOOTSTRAP_VERSION"
|
||||||
|
echo "Script that launches a specific cbuild version selected by user or defined in a project config."
|
||||||
|
echo "Usage: cbuild [OPTIONS]"
|
||||||
|
echo "Options:"
|
||||||
|
echo " -h, --help Show this message"
|
||||||
|
echo " -v, --version Shows version"
|
||||||
|
echo " -c, --config FILE Set project config file path (default=./project.config)"
|
||||||
|
echo " --list-versions Shows list of installed cbuild versions"
|
||||||
|
}
|
||||||
|
|
||||||
|
# parse command line arguments
|
||||||
|
project_config_path="./project.config"
|
||||||
|
args=($@)
|
||||||
|
args_count=${#args[@]}
|
||||||
|
i=0
|
||||||
|
if [ $args_count -eq 0 ]; then
|
||||||
|
print_help
|
||||||
|
fi
|
||||||
|
while [ $i -lt $args_count ]
|
||||||
|
do
|
||||||
|
case "${args[i]}" in
|
||||||
|
'-v' | '--version')
|
||||||
|
echo "cbuild-bootstrap v$CBUILD_BOOTSTRAP_VERSION"
|
||||||
|
;;
|
||||||
|
'-h' | '--help')
|
||||||
|
print_help
|
||||||
|
;;
|
||||||
|
'-c' | '--config')
|
||||||
|
i=$((i+1))
|
||||||
|
project_config_path="${args[i]}"
|
||||||
|
;;
|
||||||
|
'--list-versions')
|
||||||
|
print_version_list
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
i=$((i+1))
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ -z "$CBUILD_VERSION" ]; then
|
||||||
|
if [ -f "$project_config_path" ]; then
|
||||||
|
# read version from project config
|
||||||
|
exec_script_line "$project_config_path" 2
|
||||||
|
else
|
||||||
|
echo "project config not found"
|
||||||
|
echo "list of installed cbuild versions:"
|
||||||
|
versions=$(print_version_list)
|
||||||
|
|
||||||
|
echo "$versions"
|
||||||
|
latest_version=$(echo "$versions" | tail -n 1)
|
||||||
|
echo "select version (default=$latest_version):"
|
||||||
|
read -r CBUILD_VERSION
|
||||||
|
[ -z "$CBUILD_VERSION" ] && CBUILD_VERSION=$latest_version
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
version_parse "$CBUILD_VERSION"
|
||||||
|
cbuild_ommand="cbuild${_version_major}.${_version_minor} $@"
|
||||||
|
|
||||||
|
LOG_FILE="$(realpath cbuild.log)"
|
||||||
|
set +eo pipefail
|
||||||
|
# enable logging stdout and stderr to file
|
||||||
|
$cbuild_ommand 2>&1 | tee "$LOG_FILE"
|
||||||
|
# log file can be deleted by clean task
|
||||||
|
if [ -f "$LOG_FILE" ]; then
|
||||||
|
# remove terminal escape codes
|
||||||
|
sed -e 's/[^[:blank:][:print:]]//g' \
|
||||||
|
-e 's/\[0;[0-9][0-9]m//g' \
|
||||||
|
-e 's/\[0;[0-9]m//g' \
|
||||||
|
-e 's/\[[0-9][0-9]m//g' \
|
||||||
|
-e 's/\[[0-9]m//g' \
|
||||||
|
-e 's/ H //g' \
|
||||||
|
-e 's/\[3gH //g' \
|
||||||
|
-i "$LOG_FILE"
|
||||||
|
fi
|
||||||
41
cbuild.sh
41
cbuild.sh
@@ -1,27 +1,29 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
INSTALLED_CBUILD_VERSION=2.1.4
|
||||||
|
|
||||||
|
# set \t size to 4 spaces
|
||||||
tabs 4
|
tabs 4
|
||||||
|
|
||||||
# exit on errors
|
# exit on errors
|
||||||
set -eo pipefail
|
set -eo pipefail
|
||||||
INSTALLED_CBUILD_VERSION=2.1.0
|
|
||||||
|
|
||||||
function version_parse {
|
function version_parse {
|
||||||
local v="$1"
|
local value="$1"
|
||||||
|
var_name="$2"
|
||||||
IFS_backup="$IFS"
|
IFS_backup="$IFS"
|
||||||
IFS='.'
|
IFS='.'
|
||||||
v_array=($v)
|
local v_array=($value)
|
||||||
IFS="$IFS_backup"
|
IFS="$IFS_backup"
|
||||||
version_major=${v_array[0]}
|
eval ${var_name}_version_major=${v_array[0]}
|
||||||
version_minor=${v_array[1]}
|
eval ${var_name}_version_minor=${v_array[1]}
|
||||||
version_patch=${v_array[2]}
|
eval ${var_name}_version_patch=${v_array[2]}
|
||||||
}
|
}
|
||||||
|
|
||||||
version_parse $INSTALLED_CBUILD_VERSION
|
version_parse $INSTALLED_CBUILD_VERSION installed
|
||||||
if [ -z "$CBUILD_INSTALL_DIR" ]; then
|
if [ -z "$CBUILD_INSTALL_DIR" ]; then
|
||||||
CBUILD_INSTALL_DIR="~/.local/share/cbuild/${version_major}.${version_minor}"
|
CBUILD_INSTALL_DIR="$HOME/.local/share/cbuild/${installed_version_major}.${installed_version_minor}"
|
||||||
if [ ! -f "$CBUILD_INSTALL_DIR/cbuild.sh" ]; then
|
if [ ! -f "$CBUILD_INSTALL_DIR/cbuild.sh" ]; then
|
||||||
CBUILD_INSTALL_DIR="/usr/local/share/cbuild/${version_major}.${version_minor}"
|
CBUILD_INSTALL_DIR="/usr/local/share/cbuild/${installed_version_major}.${installed_version_minor}"
|
||||||
if [ ! -f "$CBUILD_INSTALL_DIR/cbuild.sh" ]; then
|
if [ ! -f "$CBUILD_INSTALL_DIR/cbuild.sh" ]; then
|
||||||
echo "CBUILD_INSTALL_DIR '$CBUILD_INSTALL_DIR' doesn't exist"
|
echo "CBUILD_INSTALL_DIR '$CBUILD_INSTALL_DIR' doesn't exist"
|
||||||
exit 1
|
exit 1
|
||||||
@@ -45,13 +47,15 @@ include "cbuild/config.sh"
|
|||||||
function print_help {
|
function print_help {
|
||||||
myprint "cbuild v$INSTALLED_CBUILD_VERSION"
|
myprint "cbuild v$INSTALLED_CBUILD_VERSION"
|
||||||
myprint "C/C++ project build system written in bash."
|
myprint "C/C++ project build system written in bash."
|
||||||
myprint "Usage: cbuild [OPTIONS] [TASK]"
|
myprint "Usage: cbuild [OPTIONS] [TASKS]"
|
||||||
|
myprint "Options:"
|
||||||
myprint " -h, --help Show this message"
|
myprint " -h, --help Show this message"
|
||||||
myprint " -v, --version Shows version"
|
myprint " -v, --version Shows version"
|
||||||
myprint " -n, --new-project [PROJ_DIR] Initialize new cbuild project directory (default=./)"
|
|
||||||
myprint " -c, --config FILE Set project config file path (default=./project.config)"
|
myprint " -c, --config FILE Set project config file path (default=./project.config)"
|
||||||
|
myprint " -n, --new-project [DIR] Initialize new cbuild project directory (default=./)"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# parse command line arguments
|
||||||
project_config_path="./project.config"
|
project_config_path="./project.config"
|
||||||
args=($@)
|
args=($@)
|
||||||
args_count=${#args[@]}
|
args_count=${#args[@]}
|
||||||
@@ -59,13 +63,9 @@ selected_tasks_array=()
|
|||||||
i=0
|
i=0
|
||||||
if [ $args_count -eq 0 ]; then
|
if [ $args_count -eq 0 ]; then
|
||||||
print_help
|
print_help
|
||||||
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
function get_next_arg {
|
|
||||||
i=$((i+1))
|
|
||||||
safeprint "${args[i]}"
|
|
||||||
}
|
|
||||||
|
|
||||||
while [ $i -lt $args_count ]
|
while [ $i -lt $args_count ]
|
||||||
do
|
do
|
||||||
case "${args[i]}" in
|
case "${args[i]}" in
|
||||||
@@ -74,19 +74,20 @@ do
|
|||||||
exit 0
|
exit 0
|
||||||
;;
|
;;
|
||||||
'-v' | '--version')
|
'-v' | '--version')
|
||||||
myprint $INSTALLED_CBUILD_VERSION
|
myprint "cbuild v$INSTALLED_CBUILD_VERSION"
|
||||||
exit 0
|
exit 0
|
||||||
;;
|
;;
|
||||||
'-c' | '--config')
|
'-c' | '--config')
|
||||||
i=$((i+1))
|
i=$((i+1))
|
||||||
project_config_path="${args[i]}"
|
project_config_path="${args[i]}"
|
||||||
myprint "<$project_config_path>"
|
|
||||||
exit 0
|
|
||||||
;;
|
;;
|
||||||
'-n' | '--new-project')
|
'-n' | '--new-project')
|
||||||
new_project_dir="$(get_next_arg)"
|
i=$((i+1))
|
||||||
|
new_project_dir="${args[i]}"
|
||||||
if [ -z "$new_project_dir" ]; then
|
if [ -z "$new_project_dir" ]; then
|
||||||
new_project_dir="."
|
new_project_dir="."
|
||||||
|
else
|
||||||
|
mkdir -p "$new_project_dir"
|
||||||
fi
|
fi
|
||||||
if ask_yn "create default cbuild project config?"; then
|
if ask_yn "create default cbuild project config?"; then
|
||||||
project_config_path="$new_project_dir/project.config"
|
project_config_path="$new_project_dir/project.config"
|
||||||
|
|||||||
20
config.sh
20
config.sh
@@ -4,20 +4,12 @@ include cbuild/myprint.sh
|
|||||||
include cbuild/functions.sh
|
include cbuild/functions.sh
|
||||||
include cbuild/detect_os.sh
|
include cbuild/detect_os.sh
|
||||||
|
|
||||||
function myprint_quiet {
|
|
||||||
local quiet=$1
|
|
||||||
local text="$2"
|
|
||||||
if [ "$quiet" != true ]; then
|
|
||||||
myprint "$text"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function load_config {
|
function load_config {
|
||||||
local project_config_path="$1"
|
local project_config_path="$1"
|
||||||
TASK="$2"
|
TASK="$2"
|
||||||
local quiet=$3
|
local quiet=$3
|
||||||
|
|
||||||
myprint "${BLUE}loading config '$(realpath $project_config_path)'"
|
myprint "${BLUE}loading config ${WHITE}'$(realpath $project_config_path)'"
|
||||||
|
|
||||||
if [ -z "$project_config_path" ]; then
|
if [ -z "$project_config_path" ]; then
|
||||||
error "config path is null"
|
error "config path is null"
|
||||||
@@ -44,14 +36,8 @@ function load_config {
|
|||||||
myprint_quiet $quiet "${WHITE}installed cbuild version: ${CYAN}$INSTALLED_CBUILD_VERSION"
|
myprint_quiet $quiet "${WHITE}installed cbuild version: ${CYAN}$INSTALLED_CBUILD_VERSION"
|
||||||
|
|
||||||
# checking versions
|
# checking versions
|
||||||
version_parse $INSTALLED_CBUILD_VERSION
|
version_parse $INSTALLED_CBUILD_VERSION installed
|
||||||
installed_version_major=$version_major
|
version_parse $CBUILD_VERSION config
|
||||||
installed_version_minor=$version_minor
|
|
||||||
installed_version_patch=$version_patch
|
|
||||||
version_parse $CBUILD_VERSION
|
|
||||||
config_version_major=$version_major
|
|
||||||
config_version_minor=$version_minor
|
|
||||||
config_version_patch=$version_patch
|
|
||||||
if [ "$installed_version_major.$installed_version_minor" != "$config_version_major.$config_version_minor" ]; then
|
if [ "$installed_version_major.$installed_version_minor" != "$config_version_major.$config_version_minor" ]; then
|
||||||
error "config was created for cbuild$config_version_major.$config_version_minor, but loaded whith cbuild$installed_version_major.$installed_version_minor which is incompatible"
|
error "config was created for cbuild$config_version_major.$config_version_minor, but loaded whith cbuild$installed_version_major.$installed_version_minor which is incompatible"
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
CBUILD_VERSION=2.1.0
|
CBUILD_VERSION=2.1.4
|
||||||
CONFIG_VERSION=1
|
CONFIG_VERSION=1
|
||||||
|
|
||||||
PROJECT="%PROJECT_NAME%"
|
PROJECT="%PROJECT_NAME%"
|
||||||
@@ -9,10 +9,8 @@ STD_C="c11"
|
|||||||
STD_CPP="c++11"
|
STD_CPP="c++11"
|
||||||
WARN_C="-Wall -Wno-discarded-qualifiers -Wextra -Wno-unused-parameter"
|
WARN_C="-Wall -Wno-discarded-qualifiers -Wextra -Wno-unused-parameter"
|
||||||
WARN_CPP="-Wall -Wextra -Wno-unused-parameter"
|
WARN_CPP="-Wall -Wextra -Wno-unused-parameter"
|
||||||
SRC_C="$( find src -name '*.c')"
|
SRC_C="$(find src -name '*.c')"
|
||||||
SRC_CPP="$( find src -name '*.cpp')"
|
SRC_CPP="$(find src -name '*.cpp')"
|
||||||
TESTS_C="$( find tests -name '*.c')"
|
|
||||||
TESTS_CPP="$(find tests -name '*.cpp')"
|
|
||||||
|
|
||||||
# Directory with dependency configs.
|
# Directory with dependency configs.
|
||||||
# See cbuild/example_dependency_configs
|
# See cbuild/example_dependency_configs
|
||||||
@@ -113,7 +111,7 @@ case "$TASK" in
|
|||||||
;;
|
;;
|
||||||
# executes $EXEC_FILE with valgrind memory checker
|
# executes $EXEC_FILE with valgrind memory checker
|
||||||
valgrind)
|
valgrind)
|
||||||
VALGRIND_ARGS="-s --read-var-info=yes --track-origins=yes --fullpath-after=$(pwd) --leak-check=full --show-leak-kinds=all"
|
VALGRIND_ARGS="-s --read-var-info=yes --track-origins=yes --fullpath-after=$(pwd)/ --leak-check=full --show-leak-kinds=all"
|
||||||
TASK_SCRIPT=cbuild/default_tasks/valgrind.sh
|
TASK_SCRIPT=cbuild/default_tasks/valgrind.sh
|
||||||
;;
|
;;
|
||||||
# generates profiling info
|
# generates profiling info
|
||||||
@@ -155,9 +153,9 @@ case "$TASK" in
|
|||||||
C_ARGS="-O2 -flto=auto -fuse-linker-plugin"
|
C_ARGS="-O2 -flto=auto -fuse-linker-plugin"
|
||||||
CPP_ARGS="$C_ARGS"
|
CPP_ARGS="$C_ARGS"
|
||||||
LINKER_ARGS="$CPP_ARGS"
|
LINKER_ARGS="$CPP_ARGS"
|
||||||
PRE_TASK_SCRIPT=tasks/pre_build.sh
|
PRE_TASK_SCRIPT=cbuild/default_tasks/build_exec.sh
|
||||||
TASK_SCRIPT=cbuild/default_tasks/build_exec.sh
|
TASK_SCRIPT=cbuild/default_tasks/callgrind.sh
|
||||||
POST_TASK_SCRIPT=cbuild/default_tasks/callgrind.sh
|
POST_TASK_SCRIPT=
|
||||||
;;
|
;;
|
||||||
# compiles executable with sanitizers and executes it to find errors and warnings
|
# compiles executable with sanitizers and executes it to find errors and warnings
|
||||||
sanitize)
|
sanitize)
|
||||||
|
|||||||
@@ -15,6 +15,6 @@ else
|
|||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
compile_c "$C_ARGS" "$SRC_C $TESTS_C"
|
[ ! -z "$SRC_C" ] && compile_c "$CMP_C" "$STD_C" "$WARN_C" "$C_ARGS" "$INCLUDE" "$SRC_C"
|
||||||
compile_cpp "$CPP_ARGS" "$SRC_CPP $TESTS_CPP"
|
[ ! -z "$SRC_CPP" ] && compile_cpp "$CMP_CPP" "$STD_CPP" "$WARN_CPP" "$CPP_ARGS" "$INCLUDE" "$SRC_CPP"
|
||||||
link "$LINKER_ARGS" "$EXEC_FILE"
|
link "$LINKER_ARGS" "$EXEC_FILE"
|
||||||
|
|||||||
@@ -2,6 +2,6 @@
|
|||||||
|
|
||||||
# delete old objects
|
# delete old objects
|
||||||
clean_dir "$OBJDIR/objects"
|
clean_dir "$OBJDIR/objects"
|
||||||
compile_c "$C_ARGS" "$SRC_C"
|
[ ! -z "$SRC_C" ] && compile_c "$CMP_C" "$STD_C" "$WARN_C" "$C_ARGS" "$INCLUDE" "$SRC_C"
|
||||||
compile_cpp "$CPP_ARGS" "$SRC_CPP"
|
[ ! -z "$SRC_CPP" ] && compile_cpp "$CMP_CPP" "$STD_CPP" "$WARN_CPP" "$CPP_ARGS" "$INCLUDE" "$SRC_CPP"
|
||||||
link "$LINKER_ARGS" "$SHARED_LIB_FILE"
|
link "$LINKER_ARGS" "$SHARED_LIB_FILE"
|
||||||
|
|||||||
@@ -2,6 +2,6 @@
|
|||||||
|
|
||||||
# delete old objects
|
# delete old objects
|
||||||
clean_dir "$OBJDIR/objects"
|
clean_dir "$OBJDIR/objects"
|
||||||
compile_c "$C_ARGS" "$SRC_C"
|
[ ! -z "$SRC_C" ] && compile_c "$CMP_C" "$STD_C" "$WARN_C" "$C_ARGS" "$INCLUDE" "$SRC_C"
|
||||||
compile_cpp "$CPP_ARGS" "$SRC_CPP"
|
[ ! -z "$SRC_CPP" ] && compile_cpp "$CMP_CPP" "$STD_CPP" "$WARN_CPP" "$CPP_ARGS" "$INCLUDE" "$SRC_CPP"
|
||||||
pack_static_lib "$STATIC_LIB_FILE"
|
pack_static_lib "$STATIC_LIB_FILE"
|
||||||
|
|||||||
@@ -6,5 +6,8 @@ DEP_POST_BUILD_COMMAND=''
|
|||||||
DEP_CLEAN_COMMAND='make clean'
|
DEP_CLEAN_COMMAND='make clean'
|
||||||
# won't be copied to project $OUTDIR
|
# won't be copied to project $OUTDIR
|
||||||
DEP_STATIC_OUT_FILES='libexample1.a libexample1_addon.a'
|
DEP_STATIC_OUT_FILES='libexample1.a libexample1_addon.a'
|
||||||
# will be copied tp project $OUTDIR
|
PRESERVE_OUT_DIRECTORY_STRUCTURE=false;
|
||||||
|
# will be copied to project $OUTDIR
|
||||||
DEP_DYNAMIC_OUT_FILES='libexample1.config.json'
|
DEP_DYNAMIC_OUT_FILES='libexample1.config.json'
|
||||||
|
# will be copied to project $OUTDIR
|
||||||
|
DEP_OTHER_OUT_FILES=''
|
||||||
|
|||||||
@@ -4,14 +4,17 @@ DEP_PRE_BUILD_COMMAND=''
|
|||||||
DEP_POST_BUILD_COMMAND=''
|
DEP_POST_BUILD_COMMAND=''
|
||||||
DEP_CLEAN_COMMAND='make clean'
|
DEP_CLEAN_COMMAND='make clean'
|
||||||
DEP_STATIC_OUT_FILES=''
|
DEP_STATIC_OUT_FILES=''
|
||||||
|
DEP_OTHER_OUT_FILES=''
|
||||||
case $OS in
|
case $OS in
|
||||||
WINDOWS)
|
WINDOWS)
|
||||||
DEP_BUILD_COMMAND='make libexample2.dll'
|
DEP_BUILD_COMMAND='make libexample2.dll && mkdir -p win-x64 && mv libexample.dll win-x64'
|
||||||
DEP_DYNAMIC_OUT_FILES='libexample2.dll'
|
DEP_DYNAMIC_OUT_FILES='win-x64/libexample2.dll'
|
||||||
|
PRESERVE_OUT_DIRECTORY_STRUCTURE=true # library will be copied to $OUTDIR/win-x64
|
||||||
;;
|
;;
|
||||||
LINUX)
|
LINUX)
|
||||||
DEP_BUILD_COMMAND='make libexample2.so'
|
DEP_BUILD_COMMAND='make libexample2.so && mkdir -p linux-x64 && mv libexample.so linux-x64'
|
||||||
DEP_DYNAMIC_OUT_FILES='libexample2.so'
|
DEP_DYNAMIC_OUT_FILES='linux-x64/libexample2.so'
|
||||||
|
PRESERVE_OUT_DIRECTORY_STRUCTURE=true # library will be copied to $OUTDIR/linux-x64
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
error "operating system $OS has no configuration variants"
|
error "operating system $OS has no configuration variants"
|
||||||
|
|||||||
104
functions.sh
104
functions.sh
@@ -8,6 +8,9 @@ function exec_script_line {
|
|||||||
local quiet=$3
|
local quiet=$3
|
||||||
myprint_quiet $quiet "${BLUE}reading line $line_num from $script"
|
myprint_quiet $quiet "${BLUE}reading line $line_num from $script"
|
||||||
local line_str="$(sed $line_num'!d' $script)"
|
local line_str="$(sed $line_num'!d' $script)"
|
||||||
|
if [ -z "$line_str" ]; then
|
||||||
|
error "script line is empty"
|
||||||
|
fi
|
||||||
myprint_quiet $quiet "$line_str"
|
myprint_quiet $quiet "$line_str"
|
||||||
eval "$line_str"
|
eval "$line_str"
|
||||||
}
|
}
|
||||||
@@ -61,7 +64,7 @@ function build_dependency {
|
|||||||
|
|
||||||
local build_needed="$force_build"
|
local build_needed="$force_build"
|
||||||
if [ "$build_needed" != true ]; then
|
if [ "$build_needed" != true ]; then
|
||||||
for file in $DEP_STATIC_OUT_FILES $DEP_DYNAMIC_OUT_FILES; do
|
for file in $DEP_STATIC_OUT_FILES $DEP_DYNAMIC_OUT_FILES $DEP_OTHER_OUT_FILES; do
|
||||||
if [ ! -f "$file" ]; then
|
if [ ! -f "$file" ]; then
|
||||||
myprint "${GRAY}missing file '$file'"
|
myprint "${GRAY}missing file '$file'"
|
||||||
local build_needed=true
|
local build_needed=true
|
||||||
@@ -79,21 +82,55 @@ function build_dependency {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -z "$DEP_DYNAMIC_OUT_FILES" ]; then
|
if [ ! -z "$DEP_DYNAMIC_OUT_FILES" ]; then
|
||||||
# copy each file to $OUTDIR
|
# copies each file to $OUTDIR and creates symbolic link in $OBJDIR/dynamic_libs
|
||||||
cp -rv $DEP_DYNAMIC_OUT_FILES "$proj_root_dir/$OUTDIR"
|
|
||||||
# symlink each file to $OBJDIR/dynamic_libs
|
|
||||||
for file in $DEP_DYNAMIC_OUT_FILES; do
|
for file in $DEP_DYNAMIC_OUT_FILES; do
|
||||||
ln -sfv $(realpath $file) "$proj_root_dir/$OBJDIR/dynamic_libs"
|
# doesnt return error if called not like this
|
||||||
|
real_file=$(realpath $file)
|
||||||
|
file_dir=$(dirname $file)
|
||||||
|
if [ "$PRESERVE_OUT_DIRECTORY_STRUCTURE" = true ] && [ "$file_dir" != '.' ]; then
|
||||||
|
mkdir -p "$proj_root_dir/$OUTDIR/$file_dir"
|
||||||
|
mkdir -p "$proj_root_dir/$OBJDIR/dynamic_libs/$file_dir"
|
||||||
|
cp -v "$file" "$proj_root_dir/$OUTDIR/$file"
|
||||||
|
ln -sfv "$real_file" "$proj_root_dir/$OBJDIR/dynamic_libs/$file"
|
||||||
|
else
|
||||||
|
cp -v "$file" "$proj_root_dir/$OUTDIR/"
|
||||||
|
ln -sfv "$real_file" "$proj_root_dir/$OBJDIR/dynamic_libs/"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
if [ ! -z "$DEP_OTHER_OUT_FILES" ]; then
|
||||||
|
# copies each file to $OUTDIR
|
||||||
|
for file in $DEP_OTHER_OUT_FILES; do
|
||||||
|
if [ "$PRESERVE_OUT_DIRECTORY_STRUCTURE" = true ]; then
|
||||||
|
file_dir=$(dirname $file)
|
||||||
|
mkdir -p "$proj_root_dir/$OUTDIR/$file_dir"
|
||||||
|
cp -v "$file" "$proj_root_dir/$OUTDIR/$file"
|
||||||
|
else
|
||||||
|
cp -v "$file" "$proj_root_dir/$OUTDIR/"
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
if [ ! -z "$DEP_STATIC_OUT_FILES" ]; then
|
if [ ! -z "$DEP_STATIC_OUT_FILES" ]; then
|
||||||
# symlink each file to $OBJDIR/static_libs
|
# creates symbolic link to each file in $OBJDIR/static_libs
|
||||||
for file in $DEP_STATIC_OUT_FILES; do
|
for file in $DEP_STATIC_OUT_FILES; do
|
||||||
ln -sfv $(realpath $file) "$proj_root_dir/$OBJDIR/static_libs"
|
# doesnt return error if called not like this
|
||||||
|
f=$(realpath $file)
|
||||||
|
ln -sfv $f "$proj_root_dir/$OBJDIR/static_libs"
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
cd "$proj_root_dir"
|
cd "$proj_root_dir"
|
||||||
|
|
||||||
|
# unsed all dependency config variables to not mess with next dependencies
|
||||||
|
unset DEP_WORKING_DIR
|
||||||
|
unset DEP_PRE_BUILD_COMMAND
|
||||||
|
unset DEP_BUILD_COMMAND
|
||||||
|
unset DEP_POST_BUILD_COMMAND
|
||||||
|
unset DEP_CLEAN_COMMAND
|
||||||
|
unset DEP_STATIC_OUT_FILES
|
||||||
|
unset PRESERVE_OUT_DIRECTORY_STRUCTURE
|
||||||
|
unset DEP_DYNAMIC_OUT_FILES
|
||||||
|
unset DEP_OTHER_OUT_FILES
|
||||||
}
|
}
|
||||||
|
|
||||||
function build_dependencies {
|
function build_dependencies {
|
||||||
@@ -113,16 +150,16 @@ function compile {
|
|||||||
print_hline "${BLUE}" "─"
|
print_hline "${BLUE}" "─"
|
||||||
|
|
||||||
local cmp="$1"
|
local cmp="$1"
|
||||||
myprint "${BLUE}compiler: ${GRAY}$cmp"
|
|
||||||
local std="$2"
|
local std="$2"
|
||||||
myprint "${BLUE}standard: ${GRAY}$std"
|
|
||||||
local warn="$3"
|
local warn="$3"
|
||||||
myprint "${BLUE}warnings: ${GRAY}$warn"
|
|
||||||
local args="$4"
|
local args="$4"
|
||||||
myprint "${BLUE}args: ${GRAY}$args"
|
|
||||||
local include="$5"
|
local include="$5"
|
||||||
myprint "${BLUE}include dirs: ${GRAY}$include"
|
|
||||||
local sources="$6"
|
local sources="$6"
|
||||||
|
myprint "${BLUE}compiler: ${GRAY}$cmp"
|
||||||
|
myprint "${BLUE}standard: ${GRAY}$std"
|
||||||
|
myprint "${BLUE}warnings: ${GRAY}$warn"
|
||||||
|
myprint "${BLUE}args: ${GRAY}$args"
|
||||||
|
myprint "${BLUE}include dirs: ${GRAY}$include"
|
||||||
myprint "${BLUE}sources: ${GRAY}$sources"
|
myprint "${BLUE}sources: ${GRAY}$sources"
|
||||||
for srcfile in $sources
|
for srcfile in $sources
|
||||||
do (
|
do (
|
||||||
@@ -138,14 +175,26 @@ function compile {
|
|||||||
|
|
||||||
# (args, sources)
|
# (args, sources)
|
||||||
function compile_c {
|
function compile_c {
|
||||||
|
local cmp="$1"
|
||||||
|
local std="$2"
|
||||||
|
local warn="$3"
|
||||||
|
local args="$4"
|
||||||
|
local include="$5"
|
||||||
|
local sources="$6"
|
||||||
print_header "${CYAN}" "─" "$PROJECT/$TASK/compile_c"
|
print_header "${CYAN}" "─" "$PROJECT/$TASK/compile_c"
|
||||||
compile "$CMP_C" "$STD_C" "$WARN_C" "$1" "$INCLUDE" "$2"
|
compile "$cmp" "$std" "$warn" "$args" "$include" "$sources"
|
||||||
}
|
}
|
||||||
|
|
||||||
# (args, sources)
|
# (args, sources)
|
||||||
function compile_cpp {
|
function compile_cpp {
|
||||||
|
local cmp="$1"
|
||||||
|
local std="$2"
|
||||||
|
local warn="$3"
|
||||||
|
local args="$4"
|
||||||
|
local include="$5"
|
||||||
|
local sources="$6"
|
||||||
print_header "${CYAN}" "─" "$PROJECT/$TASK/compile_cpp"
|
print_header "${CYAN}" "─" "$PROJECT/$TASK/compile_cpp"
|
||||||
compile "$CMP_CPP" "$STD_CPP" "$WARN_CPP" "$1" "$INCLUDE" "$2"
|
compile "$cmp" "$std" "$warn" "$args" "$include" "$sources"
|
||||||
}
|
}
|
||||||
|
|
||||||
# (outfile)
|
# (outfile)
|
||||||
@@ -153,8 +202,13 @@ function pack_static_lib {
|
|||||||
print_header "${CYAN}" "─" "$PROJECT/$TASK/pack_static_lib"
|
print_header "${CYAN}" "─" "$PROJECT/$TASK/pack_static_lib"
|
||||||
local outfile="$1"
|
local outfile="$1"
|
||||||
myprint "${BLUE}outfile: ${GRAY}$outfile"
|
myprint "${BLUE}outfile: ${GRAY}$outfile"
|
||||||
local objects="$(find $OBJDIR/objects -type f,l | tr '\n' ' ')"
|
|
||||||
|
local objects=$(find $OBJDIR/objects -type f,l | tr '\n' ' ')
|
||||||
myprint "${BLUE}objects: ${GRAY}$objects"
|
myprint "${BLUE}objects: ${GRAY}$objects"
|
||||||
|
if [ -z "$objects" ]; then
|
||||||
|
error "no compiled objects found"
|
||||||
|
fi
|
||||||
|
|
||||||
local command="ar rcs $OUTDIR/$outfile $objects"
|
local command="ar rcs $OUTDIR/$outfile $objects"
|
||||||
myprint "$command"
|
myprint "$command"
|
||||||
if $command
|
if $command
|
||||||
@@ -163,6 +217,7 @@ function pack_static_lib {
|
|||||||
else
|
else
|
||||||
error "some error happened"
|
error "some error happened"
|
||||||
fi
|
fi
|
||||||
|
clean_dir "$OBJDIR/objects"
|
||||||
}
|
}
|
||||||
|
|
||||||
function link {
|
function link {
|
||||||
@@ -171,16 +226,24 @@ function link {
|
|||||||
local outfile="$2"
|
local outfile="$2"
|
||||||
myprint "${BLUE}args: ${GRAY}$args"
|
myprint "${BLUE}args: ${GRAY}$args"
|
||||||
myprint "${BLUE}outfile: ${GRAY}$outfile"
|
myprint "${BLUE}outfile: ${GRAY}$outfile"
|
||||||
local objects="$(find $OBJDIR/objects -type f,l | tr '\n' ' ')"
|
|
||||||
|
local objects=$(find $OBJDIR/objects -type f,l | tr '\n' ' ')
|
||||||
myprint "${BLUE}objects: ${GRAY}$objects"
|
myprint "${BLUE}objects: ${GRAY}$objects"
|
||||||
local static_libs="$(find $OBJDIR/static_libs -type f,l | tr '\n' ' ')"
|
if [ -z "$objects" ]; then
|
||||||
|
error "no compiled objects found"
|
||||||
|
fi
|
||||||
|
|
||||||
|
local static_libs=$(find $OBJDIR/static_libs -type f,l | tr '\n' ' ')
|
||||||
myprint "${BLUE}static libraries: ${GRAY}$static_libs"
|
myprint "${BLUE}static libraries: ${GRAY}$static_libs"
|
||||||
local dynamic_libs="$(find $OBJDIR/dynamic_libs -type f,l | tr '\n' ' ')"
|
|
||||||
|
local dynamic_libs=$(find $OBJDIR/dynamic_libs -type f,l | tr '\n' ' '\
|
||||||
|
| sed "s,$OBJDIR/dynamic_libs/,,g")
|
||||||
myprint "${BLUE}dynamic libraries: ${GRAY}$dynamic_libs"
|
myprint "${BLUE}dynamic libraries: ${GRAY}$dynamic_libs"
|
||||||
local dynamic_libs_args="-L $OBJDIR/dynamic_libs"
|
local dynamic_libs_args="-L./$OBJDIR/dynamic_libs -Wl,-Bdynamic"
|
||||||
for lib in $dynamic_libs; do
|
for lib in $dynamic_libs; do
|
||||||
dynamic_libs_args="$dynamic_libs_args -l:$lib"
|
dynamic_libs_args="$dynamic_libs_args -Wl,-rpath=$(dirname $lib) -l:$lib"
|
||||||
done
|
done
|
||||||
|
|
||||||
local command="$CMP_CPP $objects $static_libs $args $dynamic_libs_args -o $OUTDIR/$outfile"
|
local command="$CMP_CPP $objects $static_libs $args $dynamic_libs_args -o $OUTDIR/$outfile"
|
||||||
myprint "$command"
|
myprint "$command"
|
||||||
if $command
|
if $command
|
||||||
@@ -189,4 +252,5 @@ function link {
|
|||||||
else
|
else
|
||||||
error "some error happened"
|
error "some error happened"
|
||||||
fi
|
fi
|
||||||
|
clean_dir "$OBJDIR/objects"
|
||||||
}
|
}
|
||||||
|
|||||||
34
myprint.sh
34
myprint.sh
@@ -21,6 +21,14 @@ function myprint {
|
|||||||
printf "${GRAY}$@${GRAY}\n"
|
printf "${GRAY}$@${GRAY}\n"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function myprint_quiet {
|
||||||
|
local quiet=$1
|
||||||
|
local text="$2"
|
||||||
|
if [ "$quiet" != true ]; then
|
||||||
|
myprint "$text"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
# print message and exit
|
# print message and exit
|
||||||
function error {
|
function error {
|
||||||
myprint "${RED}$@"
|
myprint "${RED}$@"
|
||||||
@@ -36,6 +44,16 @@ function ask_yn {
|
|||||||
return $([[ "$answ" = [Yy] ]]);
|
return $([[ "$answ" = [Yy] ]]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function char_multiply {
|
||||||
|
local character="$1"
|
||||||
|
local length="$2"
|
||||||
|
i=0
|
||||||
|
while [ $i -lt $length ]; do
|
||||||
|
printf $character
|
||||||
|
i=$((i+1))
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
# prints horizontal line occupying whole terminal row
|
# prints horizontal line occupying whole terminal row
|
||||||
# https://en.wikipedia.org/wiki/Box-drawing_characters
|
# https://en.wikipedia.org/wiki/Box-drawing_characters
|
||||||
function print_hline {
|
function print_hline {
|
||||||
@@ -47,7 +65,10 @@ function print_hline {
|
|||||||
if [ -z "$character" ]; then
|
if [ -z "$character" ]; then
|
||||||
character="-";
|
character="-";
|
||||||
fi
|
fi
|
||||||
printf "${color}%.s${character}" $(seq 2 $(tput cols))
|
local term_width=$(tput cols)
|
||||||
|
local line_length=$((term_width - 1))
|
||||||
|
printf "${color}"
|
||||||
|
char_multiply "$character" $line_length
|
||||||
printf "${GRAY}\n"
|
printf "${GRAY}\n"
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -65,10 +86,11 @@ function print_header {
|
|||||||
local term_width=$(tput cols)
|
local term_width=$(tput cols)
|
||||||
local label_length=${#label}
|
local label_length=${#label}
|
||||||
local line_characters_count=$((term_width - label_length - 2))
|
local line_characters_count=$((term_width - label_length - 2))
|
||||||
local letf_line_length=$(( line_characters_count / 2 ))
|
local left_line_length=$(( line_characters_count / 2 ))
|
||||||
local right_line_length=$(( letf_line_length + line_characters_count % 2 ))
|
local right_line_length=$(( left_line_length - 1 + line_characters_count % 2 ))
|
||||||
printf "${color}%.s${character}" $(seq 1 $letf_line_length)
|
printf "${color}"
|
||||||
printf "[${label}]"
|
char_multiply "$character" $left_line_length
|
||||||
printf "${color}%.s${character}" $(seq 2 $right_line_length)
|
printf "[${label}]${color}"
|
||||||
|
char_multiply "$character" $right_line_length
|
||||||
printf "${GRAY}\n"
|
printf "${GRAY}\n"
|
||||||
}
|
}
|
||||||
|
|||||||
65
setup.sh
65
setup.sh
@@ -1,33 +1,49 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
# USAGE: ./setup.sh install cbuild to /usr/local
|
# USAGE: ./setup.sh install cbuild to /usr/local
|
||||||
# ./setup.sh --local install cbuild to ~/.local
|
# ./setup.sh --local install cbuild to $HOME/.local
|
||||||
|
|
||||||
# exit on errors
|
# exit on errors
|
||||||
set -xeo pipefail
|
set -xeo pipefail
|
||||||
CBUILD_VERSION=2.1.0
|
CBUILD_VERSION=$(<CBUILD_VERSION)
|
||||||
|
|
||||||
function version_parse {
|
function version_parse {
|
||||||
local v="$1"
|
local value="$1"
|
||||||
|
var_name="$2"
|
||||||
IFS_backup="$IFS"
|
IFS_backup="$IFS"
|
||||||
IFS='.'
|
IFS='.'
|
||||||
v_array=($v)
|
local v_array=($value)
|
||||||
IFS="$IFS_backup"
|
IFS="$IFS_backup"
|
||||||
version_major=${v_array[0]}
|
eval ${var_name}_version_major=${v_array[0]}
|
||||||
version_minor=${v_array[1]}
|
eval ${var_name}_version_minor=${v_array[1]}
|
||||||
version_patch=${v_array[2]}
|
eval ${var_name}_version_patch=${v_array[2]}
|
||||||
}
|
}
|
||||||
|
|
||||||
version_parse $CBUILD_VERSION
|
function exec_script_line {
|
||||||
|
local script="$1"
|
||||||
|
local line_num="$2"
|
||||||
|
local line_str="$(sed $line_num'!d' $script)"
|
||||||
|
if [ -z "$line_str" ]; then
|
||||||
|
echo "script line is empty"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
eval "$line_str"
|
||||||
|
}
|
||||||
|
|
||||||
|
version_parse $CBUILD_VERSION local
|
||||||
if [ -z "$CBUILD_INSTALL_DIR" ]; then
|
if [ -z "$CBUILD_INSTALL_DIR" ]; then
|
||||||
if [ "$1" = "--local" ]; then
|
if [ "$1" = "--local" ]; then
|
||||||
CBUILD_INSTALL_DIR="~/.local/share/cbuild/${version_major}.${version_minor}"
|
if [ ! -d "$HOME" ]; then
|
||||||
CBUILD_BIN_DIR="~/.local/bin"
|
echo "ERROR: home directory '$HOME' doesn't exist"
|
||||||
mkdir -p "~/.local"
|
exit 1
|
||||||
mkdir -p "~/.local/share"
|
fi
|
||||||
mkdir -p "~/.local/share/cbuild"
|
CBUILD_INSTALL_DIR="$HOME/.local/share/cbuild/${local_version_major}.${local_version_minor}"
|
||||||
mkdir -p "~/.local/bin"
|
CBUILD_BIN_DIR="$HOME/.local/bin"
|
||||||
|
mkdir -p "$HOME/.local"
|
||||||
|
mkdir -p "$HOME/.local/share"
|
||||||
|
mkdir -p "$HOME/.local/share/cbuild"
|
||||||
|
mkdir -p "$HOME/.local/bin"
|
||||||
else
|
else
|
||||||
CBUILD_INSTALL_DIR="/usr/local/share/cbuild/${version_major}.${version_minor}"
|
CBUILD_INSTALL_DIR="/usr/local/share/cbuild/${local_version_major}.${local_version_minor}"
|
||||||
CBUILD_BIN_DIR="/usr/local/bin"
|
CBUILD_BIN_DIR="/usr/local/bin"
|
||||||
mkdir -p "/usr/local/share"
|
mkdir -p "/usr/local/share"
|
||||||
mkdir -p "/usr/local/share/cbuild"
|
mkdir -p "/usr/local/share/cbuild"
|
||||||
@@ -38,6 +54,21 @@ fi
|
|||||||
rm -rf "$CBUILD_INSTALL_DIR"
|
rm -rf "$CBUILD_INSTALL_DIR"
|
||||||
cp -r ./ "$CBUILD_INSTALL_DIR"
|
cp -r ./ "$CBUILD_INSTALL_DIR"
|
||||||
rm -rf "$CBUILD_INSTALL_DIR/.git"
|
rm -rf "$CBUILD_INSTALL_DIR/.git"
|
||||||
ln -sf "$(realpath $CBUILD_INSTALL_DIR/cbuild.sh)" -T "$CBUILD_BIN_DIR/cbuild${version_major}.${version_minor}"
|
ln -sf "$(realpath $CBUILD_INSTALL_DIR/cbuild.sh)" -T "$CBUILD_BIN_DIR/cbuild${local_version_major}.${local_version_minor}"
|
||||||
|
|
||||||
ln -sf "$(realpath $CBUILD_INSTALL_DIR/cbuild.sh)" -T "$CBUILD_BIN_DIR/cbuild"
|
bootstrap_install_path="$CBUILD_INSTALL_DIR/../bootstrap.sh"
|
||||||
|
if [ -f "$bootstrap_install_path" ]; then
|
||||||
|
exec_script_line "$bootstrap_install_path" 2
|
||||||
|
installed_bootstrap_version=$CBUILD_BOOTSTRAP_VERSION
|
||||||
|
installed_bootstrap_version_int=$(echo $installed_bootstrap_version | sed 's/\.//g')
|
||||||
|
exec_script_line "./bootstrap.sh" 2
|
||||||
|
local_bootstrap_version=$CBUILD_BOOTSTRAP_VERSION
|
||||||
|
local_bootstrap_version_int=$(echo $local_bootstrap_version | sed 's/\.//g')
|
||||||
|
|
||||||
|
if [[ $local_bootstrap_version_int > $installed_bootstrap_version_int ]]; then
|
||||||
|
ln -sf "$(realpath $CBUILD_INSTALL_DIR/bootstrap.sh)" -T "$bootstrap_install_path"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
ln -sf "$(realpath $CBUILD_INSTALL_DIR/bootstrap.sh)" -T "$bootstrap_install_path"
|
||||||
|
fi
|
||||||
|
ln -sf "$(realpath $bootstrap_install_path)" -T "$CBUILD_BIN_DIR/cbuild"
|
||||||
|
|||||||
Reference in New Issue
Block a user