More flexible build routine

This commit is contained in:
urob 2023-01-14 22:54:28 -05:00
parent c07fe00213
commit 8e5ebef8c3
2 changed files with 142 additions and 40 deletions

View file

@ -1,17 +1,82 @@
#!/usr/bin/env bash #!/usr/bin/env bash
WEST_OPTS="$@"
OUTPUT_DIR="$WINHOME/Downloads"
HOST_ZMK_DIR="$HOME/zmk"
HOST_CONFIG_DIR="$HOME/zmk-config"
RUNWITH_DOCKER=true RUNWITH_DOCKER=true
DOCKER_SUDO="sudo" # leave empty if user is in docker group
DOCKER_VERSION="zmkfirmware/zmk-dev-arm:3.0"
DOCKER_ZMK_DIR="/workspace/zmk" while [[ $# -gt 0 ]]; do
DOCKER_CONFIG_DIR="/workspace/zmk-config" case $1 in
# needed when user isn't in docker group
-s|--su)
DOCKER_SUDO="sudo"
;;
-l|--local)
RUNWITH_DOCKER="false"
;;
# comma or space separated list of boards (use quotes if space separated)
# if ommitted, will compile list of boards in build.yaml
-b|--board)
BOARDS="$2"
shift
;;
-v|--version)
WEST_VERSION="$2"
shift
;;
-o|--output-dir)
OUTPUT_DIR="$2"
shift
;;
--host-config-dir)
HOST_CONFIG_DIR="$2"
shift
;;
--host-zmk-dir)
HOST_ZMK_DIR="$2"
shift
;;
--docker-config-dir)
DOCKER_CONFIG_DIR="$2"
shift
;;
--docker-zmk-dir)
DOCKER_ZMK_DIR="$2"
shift
;;
--)
WEST_OPTS="${@:2}"
break
;;
*)
echo "Unknown option $1"
exit 1
;;
esac
shift
done
# Set defaults
[[ -z $WEST_VERSION ]] && WEST_VERSION="3.0"
[[ -z $OUTPUT_DIR ]] && OUTPUT_DIR="$WINHOME/Downloads"
[[ -z $HOST_ZMK_DIR ]] && HOST_ZMK_DIR="$HOME/zmk"
[[ -z $HOST_CONFIG_DIR ]] && HOST_CONFIG_DIR="$HOME/zmk-config"
[[ -z $DOCKER_ZMK_DIR ]] && DOCKER_ZMK_DIR="/workspace/zmk"
[[ -z $DOCKER_CONFIG_DIR ]] && DOCKER_CONFIG_DIR="/workspace/zmk-config"
[[ -z $BOARDS ]] && BOARDS="$(grep '^[[:space:]]*\-[[:space:]]*board:' $HOST_CONFIG_DIR/build.yaml | sed 's/^.*: *//')"
DOCKER_IMG="zmkfirmware/zmk-dev-arm:$WEST_VERSION"
# +-------------------------+ # +-------------------------+
# | AUTOMATE CONFIG OPTIONS | # | AUTOMATE CONFIG OPTIONS |
@ -49,41 +114,46 @@ then
DOCKER_CMD="$DOCKER_SUDO docker run --name zmk --rm -w $DOCKER_ZMK_DIR/app \ DOCKER_CMD="$DOCKER_SUDO docker run --name zmk --rm -w $DOCKER_ZMK_DIR/app \
--mount type=bind,source=$HOST_ZMK_DIR,target=$DOCKER_ZMK_DIR \ --mount type=bind,source=$HOST_ZMK_DIR,target=$DOCKER_ZMK_DIR \
--mount type=bind,source=$HOST_CONFIG_DIR,target=$DOCKER_CONFIG_DIR,readonly \ --mount type=bind,source=$HOST_CONFIG_DIR,target=$DOCKER_CONFIG_DIR,readonly \
--mount type=volume,source=zmk-root-user,target=/root \ --mount type=volume,source=zmk-root-user-$WEST_VERSION,target=/root \
--mount type=volume,source=zmk-zephyr,target=$DOCKER_ZMK_DIR/zephyr \ --mount type=volume,source=zmk-zephyr-$WEST_VERSION,target=$DOCKER_ZMK_DIR/zephyr \
--mount type=volume,source=zmk-zephyr-modules,target=$DOCKER_ZMK_DIR/modules \ --mount type=volume,source=zmk-zephyr-modules-$WEST_VERSION,target=$DOCKER_ZMK_DIR/modules \
--mount type=volume,source=zmk-zephyr-tools,target=$DOCKER_ZMK_DIR/tools \ --mount type=volume,source=zmk-zephyr-tools-$WEST_VERSION,target=$DOCKER_ZMK_DIR/tools \
$DOCKER_VERSION" $DOCKER_IMG"
SUFFIX="_docker" SUFFIX="${WEST_VERSION}_docker"
CONFIG_DIR="$DOCKER_CONFIG_DIR/config" CONFIG_DIR="$DOCKER_CONFIG_DIR/config"
else else
echo "Build mode: local" echo "Build mode: local"
DOCKER_CMD= SUFFIX="${WEST_VERSION}"
SUFFIX=
CONFIG_DIR="$HOST_CONFIG_DIR/config" CONFIG_DIR="$HOST_CONFIG_DIR/config"
fi fi
# usage: compile_board [board] [bin|uf2] # usage: compile_board board
compile_board () { compile_board () {
echo -e "\n$(tput setaf 4)Building $1$(tput sgr0)" echo -e "\n$(tput setaf 4)Building $1$(tput sgr0)"
$DOCKER_CMD west build -d "build/$1$SUFFIX" -b $1 $WEST_OPTS \ BUILD_DIR="${1}_$SUFFIX"
$DOCKER_CMD west build -d "build/$BUILD_DIR" -b $1 $WEST_OPTS \
-- -DZMK_CONFIG="$CONFIG_DIR" -Wno-dev -- -DZMK_CONFIG="$CONFIG_DIR" -Wno-dev
if [[ $? -eq 0 ]] if [[ $? -eq 0 ]]
then then
echo "$(tput setaf 4)Success: $1 done$(tput sgr0)" echo "$(tput setaf 4)Success: $1 done$(tput sgr0)"
OUTPUT="$OUTPUT_DIR/$1-zmk.$2" if [[ -f $HOST_ZMK_DIR/app/build/$BUILD_DIR/zephyr/zmk.uf2 ]]
then
TYPE="uf2"
else
TYPE="bin"
fi
OUTPUT="$OUTPUT_DIR/$1-zmk.$TYPE"
[[ -f $OUTPUT ]] && [[ ! -L $OUTPUT ]] && mv "$OUTPUT" "$OUTPUT.bak" [[ -f $OUTPUT ]] && [[ ! -L $OUTPUT ]] && mv "$OUTPUT" "$OUTPUT.bak"
cp "$HOST_ZMK_DIR/app/build/$1/zephyr/zmk.$2" "$OUTPUT" cp "$HOST_ZMK_DIR/app/build/$BUILD_DIR/zephyr/zmk.$TYPE" "$OUTPUT"
else else
echo "$(tput setaf 1)Error: $1 failed$(tput sgr0)" echo "$(tput setaf 1)Error: $1 failed$(tput sgr0)"
fi fi
} }
cd "$HOST_ZMK_DIR/app" cd "$HOST_ZMK_DIR/app"
compile_board planck_rev6 bin for board in $(echo $BOARDS | sed 's/,/ /g')
compile_board corneish_zen_v2_left uf2 do
compile_board corneish_zen_v2_right uf2 compile_board $board
compile_board adv360pro_left uf2 done
compile_board adv360pro_right uf2

View file

@ -1,25 +1,57 @@
#!/usr/bin/env bash #!/usr/bin/env bash
HOST_ZMK_DIR="$HOME/zmk" # Parse input arguments
DOCKER_ZMK_DIR="/workspace/zmk" while [[ $# -gt 0 ]]; do
case $1 in
# needed when user isn't in docker group
-s|--sudu)
SUDO="sudo"
;;
DOCKER_VERSION="zmkfirmware/zmk-dev-arm:3.0" -v|--version)
WEST_VERSION="$2"
shift
;;
DOCKER_SUDO="sudo" # leave empty if user is in docker group --host-zmk-dir)
DOCKER_CMD="$DOCKER_SUDO docker run --name zmk --rm \ HOST_ZMK_DIR="$2"
shift
;;
--docker-zmk-dir)
DOCKER_ZMK_DIR="$2"
shift
;;
*)
echo "Unknown option $1"
exit 1
;;
esac
shift
done
# Set defaults
[[ -z $WEST_VERSION ]] && WEST_VERSION="3.0"
[[ -z $HOST_ZMK_DIR ]] && HOST_ZMK_DIR="$HOME/zmk"
[[ -z $DOCKER_ZMK_DIR ]] && DOCKER_ZMK_DIR="/workspace/zmk"
DOCKER_IMG="zmkfirmware/zmk-dev-arm:$WEST_VERSION"
DOCKER_CMD="$SUDO docker run --name zmk-$WEST_VERSION --rm \
--mount type=bind,source=$HOST_ZMK_DIR,target=$DOCKER_ZMK_DIR \ --mount type=bind,source=$HOST_ZMK_DIR,target=$DOCKER_ZMK_DIR \
--mount type=volume,source=zmk-root-user,target=/root \ --mount type=volume,source=zmk-root-user-$WEST_VERSION,target=/root \
--mount type=volume,source=zmk-zephyr,target=$DOCKER_ZMK_DIR/zephyr \ --mount type=volume,source=zmk-zephyr-$WEST_VERSION,target=$DOCKER_ZMK_DIR/zephyr \
--mount type=volume,source=zmk-zephyr-modules,target=$DOCKER_ZMK_DIR/modules \ --mount type=volume,source=zmk-zephyr-modules-$WEST_VERSION,target=$DOCKER_ZMK_DIR/modules \
--mount type=volume,source=zmk-zephyr-tools,target=$DOCKER_ZMK_DIR/tools" --mount type=volume,source=zmk-zephyr-tools-$WEST_VERSION,target=$DOCKER_ZMK_DIR/tools"
# Reset volumes # Reset volumes
$DOCKER_SUDO docker volume rm $(sudo docker volume ls -q | grep zmk-) $SUDO docker volume rm $(sudo docker volume ls -q | grep "^zmk-.*-$WEST_VERSION$")
# Install west # Install west
$DOCKER_CMD -w "$DOCKER_ZMK_DIR" "$DOCKER_VERSION" west init -l app/ $DOCKER_CMD -w "$DOCKER_ZMK_DIR" "$DOCKER_IMG" west init -l app/
$DOCKER_CMD -w "$DOCKER_ZMK_DIR" "$DOCKER_VERSION" west update $DOCKER_CMD -w "$DOCKER_ZMK_DIR" "$DOCKER_IMG" west update
# Install docosaurus # Install docosaurus
$DOCKER_CMD -w "$DOCKER_ZMK_DIR/docs" "$DOCKER_VERSION" npm ci $DOCKER_CMD -w "$DOCKER_ZMK_DIR/docs" "$DOCKER_IMG" npm ci