diff options
author | kaotisk <kaotisk@arching-kaos.org> | 2024-12-07 04:01:14 +0200 |
---|---|---|
committer | kaotisk <kaotisk@arching-kaos.org> | 2024-12-07 04:01:14 +0200 |
commit | 290a499b3ac03cd241255880e3176d2656741ca1 (patch) | |
tree | 8618021d01fbab8106c429cd1be838161fbb76c2 /src/new_lib.sh | |
parent | fbf8c1d3cf60bf620b1535a0af523ff23ae3a200 (diff) | |
download | arching-kaos-tools-290a499b3ac03cd241255880e3176d2656741ca1.tar.gz arching-kaos-tools-290a499b3ac03cd241255880e3176d2656741ca1.tar.bz2 arching-kaos-tools-290a499b3ac03cd241255880e3176d2656741ca1.zip |
Updating build system
Diffstat (limited to 'src/new_lib.sh')
-rwxr-xr-x | src/new_lib.sh | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/src/new_lib.sh b/src/new_lib.sh new file mode 100755 index 0000000..94dd695 --- /dev/null +++ b/src/new_lib.sh @@ -0,0 +1,83 @@ +#!/bin/bash + +library="${1}" +library_capitals="$(echo ${library} | tr '[:lower:]' '[:upper:]')" +include_file="include/ak${library}.h" +test_file="tests/test_ak${library}.c" +implementation_file="ak${library}.c" +build_file="build_tree/ak_${library}_build.sh" + +include_template(){ + cat > ${include_file} << EOF +#ifndef AK_${library_capitals}_H +#define AK_${library_capitals}_H + +int ak_${library}(); + +#endif // AK_${library_capitals}_H +EOF + +} + +implementation_template(){ + cat > ${implementation_file} << EOF +#include <ak${library}.h> +#include <stdio.h> + +int ak_${library}() +{ + printf("Testing: %s\n", __func__); + return 0; +} +EOF +} + +test_template(){ + cat > ${test_file} << EOF +#include <ak${library}.h> + +int main() +{ + ak_${library}(); + return 0; +} +EOF +} + +build_template(){ + cat > ${build_file} << EOF +echo "Building lib/ak${library}.so" && \ +gcc -c -shared -Wextra -Wall -Werror -pedantic -ggdb -fPIC -I./include ak${library}.c -o lib/ak${library}.so && \ +echo "Building tests/test_ak${library}" && \ +gcc -Wextra -Wall -Werror -pedantic -ggdb -Wl,-rpath=lib -I./include tests/test_ak${library}.c lib/ak${library}.so -o tests/test_ak${library} && \ +echo "Running test_ak${library}" && \ +time ./tests/test_ak${library} +rm ./tests/test_ak${library} +EOF + chmod +x ${build_file} +} + +if [ ! -f ${include_file} ] +then + include_template +else + echo "ERROR: ${include_file} exists" +fi +if [ ! -f ${test_file} ] +then + test_template +else + echo "ERROR: ${test_file} exists" +fi +if [ ! -f ${implementation_file} ] +then +implementation_template +else + echo "ERROR: ${implementation_file} exists" +fi +if [ ! -f ${build_file} ] +then +build_template +else + echo "ERROR: ${build_file} exists" +fi |