summaryrefslogtreecommitdiffstats
path: root/util/docker_build.sh
diff options
context:
space:
mode:
authorAlex Ong <the.onga@gmail.com>2019-01-04 09:39:14 +0100
committerAlex Ong <the.onga@gmail.com>2019-01-04 09:39:14 +0100
commit47c91fc7f75ae0a477e55b687aa0fc30da0a283c (patch)
tree65ad39452748ff2e6d4a83ce54ede6ca22c9ada9 /util/docker_build.sh
parentac9b88e8ccbbf38762871504cd827ff0d941c426 (diff)
parent563ce3f225d981ce460c12ca5130dfe47af41df0 (diff)
downloadqmk_firmware-47c91fc7f75ae0a477e55b687aa0fc30da0a283c.tar.gz
qmk_firmware-47c91fc7f75ae0a477e55b687aa0fc30da0a283c.tar.xz
Merge branch 'master' of https://github.com/qmk/qmk_firmware
Diffstat (limited to 'util/docker_build.sh')
-rwxr-xr-xutil/docker_build.sh49
1 files changed, 49 insertions, 0 deletions
diff --git a/util/docker_build.sh b/util/docker_build.sh
new file mode 100755
index 000000000..26075cc90
--- /dev/null
+++ b/util/docker_build.sh
@@ -0,0 +1,49 @@
+#!/bin/sh
+# NOTE: This script uses tabs for indentation
+
+USAGE="Usage: $0 [keyboard[:keymap[:target]]]"
+
+# Check preconditions
+for arg; do
+ if [ "$arg" = "--help" ]; then
+ echo "$USAGE"
+ exit 0
+ fi
+done
+if [ $# -gt 1 ]; then
+ echo "$USAGE" >&2
+ exit 1
+elif ! command -v docker >/dev/null 2>&1; then
+ echo "Error: docker not found" >&2
+ echo "See https://docs.docker.com/install/#supported-platforms for installation instructions" >&2
+ exit 2
+fi
+
+# Determine arguments
+if [ $# -eq 0 ]; then
+ printf "keyboard=" && read -r keyboard
+ [ -n "$keyboard" ] && printf "keymap=" && read -r keymap
+ [ -n "$keymap" ] && printf "target=" && read -r target
+else
+ IFS=':' read -r keyboard keymap target x <<-EOF
+ $1
+ EOF
+ if [ -n "$x" ]; then
+ echo "$USAGE" >&2
+ exit 1
+ fi
+fi
+if [ -n "$target" ]; then
+ if [ "$(uname)" = "Linux" ] || docker-machine active >/dev/null 2>&1; then
+ usb_args="--privileged -v /dev/bus/usb:/dev/bus/usb"
+ else
+ echo "Error: target requires docker-machine to work on your platform" >&2
+ echo "See http://gw.tnode.com/docker/docker-machine-with-usb-support-on-windows-macos" >&2
+ exit 3
+ fi
+fi
+dir=$(pwd -W 2>/dev/null) || dir=$PWD # Use Windows path if on Windows
+
+# Run container and build firmware
+docker run --rm $usb_args -v "$dir":/qmk_firmware qmkfm/qmk_firmware \
+ make "$keyboard${keymap:+:$keymap}${target:+:$target}"