8 Commits

Author SHA1 Message Date
fa15e15758 fixed valgrind sources path trimming 2025-04-21 18:46:12 +05:00
d60c86ec3b readme fix 2024-09-13 21:12:25 +05:00
1576021cf7 v2.1.4 2024-08-09 22:05:34 +03:00
646773f574 rpath 2024-08-09 21:05:30 +03:00
3b7f72c8b3 2.1.3 2024-08-09 05:59:19 +03:00
144b333b60 v2.1.2 2024-07-21 06:35:00 +03:00
0b5eed8b4c bootstrap help and version list 2024-07-21 05:01:40 +03:00
5c1b063399 objects deletion after link and pack_static_lib 2024-07-21 02:49:42 +03:00
11 changed files with 156 additions and 50 deletions

1
CBUILD_VERSION Normal file
View File

@@ -0,0 +1 @@
2.1.4

View File

@@ -1,5 +1,16 @@
# 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
+ removed `TESTS_C` and `TESTS_CPP`
+ **config**: removed `TESTS_C` and `TESTS_CPP` compilation
# v2.1.0
+ **config**: no more `current.config` and `default.config`, just `project.config`

View File

@@ -1,23 +1,31 @@
# cbuild
My C/C++ build system written in bash.
My C/C++ build system written in sh.
## Installation
```bash
git clone https://timerix.ddns.net:3322/cbuild.git
```sh
git clone https://timerix.ddns.net:3322/Timerix/cbuild.git
cd cbuild
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
1. Initialize cbuild project in some directory:
```bash
```sh
cd some_project
cbuild --new-project
```
2. Edit `default.config`.
2. Edit `project.config`.
3. Call some tasks:
```bash
```sh
cbuild build_exec_dbg exec
```
P.S. See help
```sh
cbuild -h
```

View File

@@ -1,5 +1,5 @@
#!/usr/bin/env bash
CBUILD_BOOTSTRAP_VERSION=1.0.0
CBUILD_BOOTSTRAP_VERSION=1.0.1
set -eo pipefail
function version_parse {
@@ -29,29 +29,56 @@ function exec_script_line {
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
function get_next_arg {
i=$((i+1))
safeprint "${args[i]}"
}
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"
;;
'-c' | '--config')
project_config_path="$(get_next_arg)"
'-h' | '--help')
print_help
;;
'-n' | '--new-project')
echo "enter project cbuild version (example: 2.1.0)"
read -r CBUILD_VERSION
'-c' | '--config')
i=$((i+1))
project_config_path="${args[i]}"
;;
'--list-versions')
print_version_list
exit 0
;;
*)
;;
@@ -59,9 +86,21 @@ do
i=$((i+1))
done
# read version from project config if not specified
if [ -z "$CBUILD_VERSION" ]; then
exec_script_line "$project_config_path" 2
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"

View File

@@ -1,5 +1,5 @@
#!/usr/bin/env bash
INSTALLED_CBUILD_VERSION=2.1.1
INSTALLED_CBUILD_VERSION=2.1.4
# set \t size to 4 spaces
tabs 4
@@ -47,11 +47,12 @@ include "cbuild/config.sh"
function print_help {
myprint "cbuild v$INSTALLED_CBUILD_VERSION"
myprint "C/C++ project build system written in bash."
myprint "Usage: cbuild [OPTIONS] [TASK]"
myprint " -h, --help Show this message"
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 "Usage: cbuild [OPTIONS] [TASKS]"
myprint "Options:"
myprint " -h, --help Show this message"
myprint " -v, --version Shows version"
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
@@ -62,6 +63,7 @@ selected_tasks_array=()
i=0
if [ $args_count -eq 0 ]; then
print_help
exit 1
fi
while [ $i -lt $args_count ]
@@ -84,6 +86,8 @@ do
new_project_dir="${args[i]}"
if [ -z "$new_project_dir" ]; then
new_project_dir="."
else
mkdir -p "$new_project_dir"
fi
if ask_yn "create default cbuild project config?"; then
project_config_path="$new_project_dir/project.config"

View File

@@ -9,7 +9,7 @@ function load_config {
TASK="$2"
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
error "config path is null"

View File

@@ -1,5 +1,5 @@
#!/usr/bin/env bash
CBUILD_VERSION=2.1.1
CBUILD_VERSION=2.1.4
CONFIG_VERSION=1
PROJECT="%PROJECT_NAME%"
@@ -111,7 +111,7 @@ case "$TASK" in
;;
# executes $EXEC_FILE with valgrind memory checker
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
;;
# generates profiling info

View File

@@ -6,5 +6,8 @@ DEP_POST_BUILD_COMMAND=''
DEP_CLEAN_COMMAND='make clean'
# won't be copied to project $OUTDIR
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'
# will be copied to project $OUTDIR
DEP_OTHER_OUT_FILES=''

View File

@@ -4,14 +4,17 @@ DEP_PRE_BUILD_COMMAND=''
DEP_POST_BUILD_COMMAND=''
DEP_CLEAN_COMMAND='make clean'
DEP_STATIC_OUT_FILES=''
DEP_OTHER_OUT_FILES=''
case $OS in
WINDOWS)
DEP_BUILD_COMMAND='make libexample2.dll'
DEP_DYNAMIC_OUT_FILES='libexample2.dll'
DEP_BUILD_COMMAND='make libexample2.dll && mkdir -p win-x64 && mv libexample.dll win-x64'
DEP_DYNAMIC_OUT_FILES='win-x64/libexample2.dll'
PRESERVE_OUT_DIRECTORY_STRUCTURE=true # library will be copied to $OUTDIR/win-x64
;;
LINUX)
DEP_BUILD_COMMAND='make libexample2.so'
DEP_DYNAMIC_OUT_FILES='libexample2.so'
DEP_BUILD_COMMAND='make libexample2.so && mkdir -p linux-x64 && mv libexample.so linux-x64'
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"

View File

@@ -64,7 +64,7 @@ function build_dependency {
local build_needed="$force_build"
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
myprint "${GRAY}missing file '$file'"
local build_needed=true
@@ -82,21 +82,55 @@ function build_dependency {
fi
if [ ! -z "$DEP_DYNAMIC_OUT_FILES" ]; then
# copy each file to $OUTDIR
cp -rv $DEP_DYNAMIC_OUT_FILES "$proj_root_dir/$OUTDIR"
# symlink each file to $OBJDIR/dynamic_libs
# copies each file to $OUTDIR and creates symbolic link in $OBJDIR/dynamic_libs
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
fi
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
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
fi
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 {
@@ -169,7 +203,7 @@ function pack_static_lib {
local outfile="$1"
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"
if [ -z "$objects" ]; then
error "no compiled objects found"
@@ -183,6 +217,7 @@ function pack_static_lib {
else
error "some error happened"
fi
clean_dir "$OBJDIR/objects"
}
function link {
@@ -192,20 +227,21 @@ function link {
myprint "${BLUE}args: ${GRAY}$args"
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"
if [ -z "$objects" ]; then
error "no compiled objects found"
fi
local static_libs="$(find $OBJDIR/static_libs -type f,l | tr '\n' ' ')"
local static_libs=$(find $OBJDIR/static_libs -type f,l | tr '\n' ' ')
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"
local dynamic_libs_args="-L $OBJDIR/dynamic_libs"
local dynamic_libs_args="-L./$OBJDIR/dynamic_libs -Wl,-Bdynamic"
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
local command="$CMP_CPP $objects $static_libs $args $dynamic_libs_args -o $OUTDIR/$outfile"
@@ -216,4 +252,5 @@ function link {
else
error "some error happened"
fi
clean_dir "$OBJDIR/objects"
}

View File

@@ -4,7 +4,7 @@
# exit on errors
set -xeo pipefail
CBUILD_VERSION=2.1.1
CBUILD_VERSION=$(<CBUILD_VERSION)
function version_parse {
local value="$1"