forked from Bananymous/banan-os
BuildSystem: Fix bugs in new build system
I had not tested the new build system with clean toolchain build but it seems to work now.
This commit is contained in:
102
script/build.sh
102
script/build.sh
@@ -1,24 +1,20 @@
|
||||
#!/bin/bash
|
||||
set -e
|
||||
|
||||
if [[ -z $BANAN_ARCH ]]; then
|
||||
export BANAN_ARCH=x86_64
|
||||
fi
|
||||
|
||||
export BANAN_SCRIPT_DIR=$(dirname $(realpath $0))
|
||||
source $BANAN_SCRIPT_DIR/config.sh
|
||||
|
||||
make_build_dir () {
|
||||
if ! [[ -d $BANAN_BUILD_DIR ]]; then
|
||||
mkdir -p $BANAN_BUILD_DIR
|
||||
cd $BANAN_BUILD_DIR
|
||||
cmake --toolchain=$BANAN_TOOLCHAIN_DIR/Toolchain.txt -G Ninja $BANAN_ROOT_DIR $BANAN_CMAKE_ARGS
|
||||
mkdir -p $BANAN_BUILD_DIR
|
||||
cd $BANAN_BUILD_DIR
|
||||
if ! [[ -f "build.ninja" ]]; then
|
||||
cmake --toolchain=$BANAN_TOOLCHAIN_DIR/Toolchain.txt -G Ninja $BANAN_ROOT_DIR
|
||||
fi
|
||||
}
|
||||
|
||||
build_target () {
|
||||
make_build_dir
|
||||
if [[ -z $1 ]]; then
|
||||
if [[ $# -eq 0 ]]; then
|
||||
echo "No target provided"
|
||||
exit 1
|
||||
fi
|
||||
@@ -27,6 +23,15 @@ build_target () {
|
||||
}
|
||||
|
||||
build_toolchain () {
|
||||
if [[ -f $BANAN_TOOLCHAIN_PREFIX/bin/$BANAN_TOOLCHAIN_TRIPLE_PREFIX-gcc ]]; then
|
||||
echo "You already seem to have a toolchain."
|
||||
read -e -p "Do you want to rebuild it [y/N]? " choice
|
||||
if ! [[ "$choice" == [Yy]* ]]; then
|
||||
echo "Aborting toolchain rebuild"
|
||||
exit 0
|
||||
fi
|
||||
fi
|
||||
|
||||
$BANAN_TOOLCHAIN_DIR/build.sh
|
||||
build_target libc-install
|
||||
$BANAN_TOOLCHAIN_DIR/build.sh libstdc++
|
||||
@@ -51,57 +56,42 @@ run_bochs () {
|
||||
$BANAN_SCRIPT_DIR/bochs.sh $@
|
||||
}
|
||||
|
||||
if [[ "$1" == "toolchain" ]]; then
|
||||
if [[ -f $BANAN_TOOLCHAIN_PREFIX/bin/$BANAN_TOOLCHAIN_TRIPLE_PREFIX-gcc ]]; then
|
||||
echo "You already seem to have build toolchain."
|
||||
read -e -p "Do you want to rebuild it [y/N]? " choice
|
||||
if ! [[ "$choice" == [Yy]* ]]; then
|
||||
echo "Aborting toolchain rebuild"
|
||||
exit 0
|
||||
fi
|
||||
fi
|
||||
|
||||
build_toolchain
|
||||
exit 0
|
||||
fi
|
||||
|
||||
if [[ "$1" == "image" ]]; then
|
||||
create_image
|
||||
exit 0
|
||||
fi
|
||||
|
||||
if [[ "$1" == "image-full" ]]; then
|
||||
create_image full
|
||||
exit 0
|
||||
fi
|
||||
|
||||
if [[ "$(uname)" == "Linux" ]]; then
|
||||
QEMU_ACCEL="-accel kvm"
|
||||
fi
|
||||
|
||||
if [[ "$1" == "qemu" ]]; then
|
||||
run_qemu -serial stdio $QEMU_ACCEL
|
||||
exit 0
|
||||
if [[ $# -eq 0 ]]; then
|
||||
echo "No argument given"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [[ "$1" == "qemu-nographic" ]]; then
|
||||
run_qemu -nographic $QEMU_ACCEL
|
||||
exit 0
|
||||
fi
|
||||
case $1 in
|
||||
toolchain)
|
||||
build_toolchain
|
||||
;;
|
||||
image)
|
||||
create_image
|
||||
;;
|
||||
image-full)
|
||||
create_image full
|
||||
;;
|
||||
qemu)
|
||||
run_qemu -serial stdio $QEMU_ACCEL
|
||||
;;
|
||||
qemu-nographic)
|
||||
run_qemu -nographic $QEMU_ACCEL
|
||||
;;
|
||||
qemu-debug)
|
||||
run_qemu -serial stdio -d int -no-reboot
|
||||
;;
|
||||
bochs)
|
||||
run_bochs
|
||||
;;
|
||||
check-fs)
|
||||
$BANAN_SCRIPT_DIR/check-fs.sh
|
||||
;;
|
||||
*)
|
||||
build_target $1
|
||||
;;
|
||||
esac
|
||||
|
||||
if [[ "$1" == "qemu-debug" ]]; then
|
||||
run_qemu -serial stdio -d int -no-reboot
|
||||
exit 0
|
||||
fi
|
||||
|
||||
if [[ "$1" == "bochs" ]]; then
|
||||
run_bochs
|
||||
exit 0
|
||||
fi
|
||||
|
||||
if [[ "$1" == "check-fs" ]]; then
|
||||
$BANAN_SCRIPT_DIR/check-fs.sh
|
||||
exit 0
|
||||
fi
|
||||
|
||||
build_target $1
|
||||
|
||||
Reference in New Issue
Block a user