3.1 KiB
FOSS-VG Build System
Yeah, I was annoyed at make. Sorry. -BodgeMaster
Aliases
The shell environment provided in the project's base directory contains
aliases that can be invoked from anywhere.
This is useful if you, for example, cd src/lib
and want to do a quick
rebuild, you can just run build
and it will take care of switching
directories back and forth.
Where necessary, the "aliases" are shell functions instead of literal aliases to accommodate for inline environment variables.
Provided aliases:
setup_project
runsscripts/setup_project.sh
build
runsscripts/build.sh
run_tests
runsscripts/test.sh
(we can't aliastest
because that's an actual POSIX command and it would break a lot of things)clean
runsscripts/clean.sh
clean_dependencies
runsscripts/clean_dependencies.sh
setup_project
Cleans the project and its dependencies first (see below), ensuring the project is in a known state, then sets up dependencies.
This includes downloading (and caching) of files that are not yet locally cached and compiling dependencies that need to be compiled.
This script’s intended purpose is setting up a development environment but it can also be used to update the locally set-up dependencies to the ones that the project is using.
build
Builds the project. This will compile all the things in src/
except for
what is in src/test/
.
Checks for endianness if endianness header is missing. Builds the endianness check if that is missing as well.
Accepted environment variables:
CXX
: override the default compilerCXXFLAGS
: override the default compiler flags, must at least specify the C++ versionSINGLE
: if set toyes
, causes the build script to run in single-threaded mode
test / run_tests
Builds and runs the unit tests.
Accepted environment variables:
CXX
: override the default compilerCXXFLAGS
: override the default compiler flags, must at least specify the C++ versionSINGLE
: if set toyes
, causes the test script to compile the tests in single-threaded mode¹
¹Unit tests are always run one after the other.
clean
Removes and re-creates bin/
and include/
, then re-creates symlinks to
shared object and header files as needed for the build process.
Also removes the endianness header and the endianness check binary.
clean_dependencies
Removes and re-creates dependencies/
and prunes the download cache of files
that either have been corrupted or are no longer used.
lib
This is not a script you are supposed to run. It's a library that contains some functions for the other scripts to work properly on all platforms.
Features it provides:
$WAIT_ANYWAY
: a variable containing thewait
command ifSINGLE=yes
is set.$CXX_WITH_FLAGS
: deals withCXX
andCXXFLAGS
environment variables so it can be used as a generic compiler command- function
check_sha256
: deals withsha256sum
and NetBSD'ssha256
- function
remove
: better verbosity - function
create_directory
: alternative tomkdir -v
because that's not available on some systems - function
create_file
: the same but for files