-
-
Notifications
You must be signed in to change notification settings - Fork 39.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add a better Docker build script + update Dockerfile (#4222)
* Add a Docker build script * Add usage and error messages * Add -r to reads Thanks mechmerlin * Add keyboard:keymap form, improve script * Add target argument, change usage forms in script * Add check for more than 3 args in keyboard:keymap:target form * Change Docker base image to debian, use community repo This matches what qmk_compiler uses (https://github.com/qmk/qmk_compiler/blob/master/Dockerfile#L1). I've removed the maintainer as we now have a community build on Docker Hub (https://hub.docker.com/r/qmkfm/qmk_firmware). This Dockerfile will also be maintained by the community. * Change build command format to keyboard:keymap * Call make directly in container run command * Simplify script, remove 3-arg form * Add COPY to Dockerfile so images are usable in and of themselves Also change WORKDIR from /qmk to /qmk_firmware * Add USB pass-through for Linux and docker-machine hosts * Read directly into variables instead of array * Alphabetically sort dependencies in Dockerfile * Set executable bit on util/docker_build.sh * Update Docker docs * Add warning about Docker on Windows * Expand comment in docs * Check docker-machine exit code instead of string * Only match --help with whole arguments * Make script POSIX-compliant * Convert script indentation to tabs
- Loading branch information
1 parent
2ad2b73
commit 13ad650
Showing
3 changed files
with
82 additions
and
29 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,28 +1,29 @@ | ||
FROM debian:jessie | ||
MAINTAINER Erik Dasque <[email protected]> | ||
FROM debian | ||
|
||
RUN apt-get update && apt-get install --no-install-recommends -y build-essential \ | ||
gcc \ | ||
unzip \ | ||
wget \ | ||
zip \ | ||
gcc-avr \ | ||
binutils-avr \ | ||
RUN apt-get update && apt-get install --no-install-recommends -y \ | ||
avr-libc \ | ||
avrdude \ | ||
binutils-arm-none-eabi \ | ||
binutils-avr \ | ||
build-essential \ | ||
dfu-programmer \ | ||
dfu-util \ | ||
gcc \ | ||
gcc-arm-none-eabi \ | ||
binutils-arm-none-eabi \ | ||
libnewlib-arm-none-eabi \ | ||
gcc-avr \ | ||
git \ | ||
libnewlib-arm-none-eabi \ | ||
software-properties-common \ | ||
avrdude \ | ||
unzip \ | ||
wget \ | ||
zip \ | ||
&& rm -rf /var/lib/apt/lists/* | ||
|
||
ENV keyboard=ergodox | ||
ENV subproject=ez | ||
ENV keymap=default | ||
ENV KEYBOARD=ergodox_ez | ||
ENV KEYMAP=default | ||
|
||
VOLUME /qmk_firmware | ||
WORKDIR /qmk_firmware | ||
COPY . . | ||
|
||
VOLUME /qmk | ||
WORKDIR /qmk | ||
CMD make clean ; make keyboard=${keyboard} subproject=${subproject} keymap=${keymap} | ||
CMD make $KEYBOARD:$KEYMAP |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -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}" |