Add support for userspace to docker build commands. (#23988)
This commit is contained in:
		
							parent
							
								
									d5e0562a70
								
							
						
					
					
						commit
						03e688e91f
					
				| @ -86,6 +86,7 @@ subcommands = [ | |||||||
|     'qmk.cli.userspace.compile', |     'qmk.cli.userspace.compile', | ||||||
|     'qmk.cli.userspace.doctor', |     'qmk.cli.userspace.doctor', | ||||||
|     'qmk.cli.userspace.list', |     'qmk.cli.userspace.list', | ||||||
|  |     'qmk.cli.userspace.path', | ||||||
|     'qmk.cli.userspace.remove', |     'qmk.cli.userspace.remove', | ||||||
|     'qmk.cli.via2json', |     'qmk.cli.via2json', | ||||||
| ] | ] | ||||||
|  | |||||||
							
								
								
									
										8
									
								
								lib/python/qmk/cli/userspace/path.py
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										8
									
								
								lib/python/qmk/cli/userspace/path.py
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,8 @@ | |||||||
|  | from milc import cli | ||||||
|  | from qmk.constants import QMK_USERSPACE | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | @cli.subcommand('Detected path to QMK Userspace.', hidden=True) | ||||||
|  | def userspace_path(cli): | ||||||
|  |     print(QMK_USERSPACE) | ||||||
|  |     return | ||||||
| @ -249,7 +249,7 @@ def test_c2json_nocpp_stdin(): | |||||||
| def test_clean(): | def test_clean(): | ||||||
|     result = check_subcommand('clean', '-a') |     result = check_subcommand('clean', '-a') | ||||||
|     check_returncode(result) |     check_returncode(result) | ||||||
|     assert result.stdout.count('done') == 2 |     assert (result.stdout.count('done') == 2 and 'userspace' not in result.stdout) or (result.stdout.count('done') == 3 and 'userspace' in result.stdout) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def test_generate_api(): | def test_generate_api(): | ||||||
|  | |||||||
| @ -1,85 +1,3 @@ | |||||||
| #!/bin/sh | #!/bin/sh | ||||||
| # NOTE: This script uses tabs for indentation |  | ||||||
| 
 | 
 | ||||||
| errcho() { | ./util/docker_cmd.sh make "$@" | ||||||
| 	echo "$@" >&2 |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| 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 |  | ||||||
| 	errcho "$USAGE" |  | ||||||
| 	exit 1 |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| # Allow $RUNTIME to be overridden by the user as an environment variable |  | ||||||
| # Else check if either podman or docker exit and set them as runtime |  | ||||||
| # if none are found error out |  | ||||||
| if [ -z "$RUNTIME" ]; then |  | ||||||
| 	if command -v podman >/dev/null 2>&1; then |  | ||||||
| 		RUNTIME="podman" |  | ||||||
| 	elif command -v docker >/dev/null 2>&1; then |  | ||||||
| 		RUNTIME="docker" |  | ||||||
| 	else |  | ||||||
| 		errcho "Error: no compatible container runtime found." |  | ||||||
| 		errcho "Either podman or docker are required." |  | ||||||
| 		errcho "See https://podman.io/getting-started/installation" |  | ||||||
| 		errcho "or https://docs.docker.com/install/#supported-platforms" |  | ||||||
| 		errcho "for installation instructions." |  | ||||||
| 		exit 2 |  | ||||||
| 	fi |  | ||||||
| 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 |  | ||||||
| 		errcho "$USAGE" |  | ||||||
| 		exit 1 |  | ||||||
| 	fi |  | ||||||
| fi |  | ||||||
| if [ -z "$keyboard" ]; then |  | ||||||
| 	keyboard=all |  | ||||||
| fi |  | ||||||
| if [ -n "$target" ]; then |  | ||||||
| 	# IF we are using docker on non Linux and docker-machine isn't working print an error |  | ||||||
| 	# ELSE set usb_args |  | ||||||
| 	if [ ! "$(uname)" = "Linux" ] && [ "$RUNTIME" = "docker" ] && ! docker-machine active >/dev/null 2>&1; then |  | ||||||
| 		errcho "Error: target requires docker-machine to work on your platform" |  | ||||||
| 		errcho "See http://gw.tnode.com/docker/docker-machine-with-usb-support-on-windows-macos" |  | ||||||
| 		errcho "Consider flashing with QMK Toolbox (https://github.com/qmk/qmk_toolbox) instead" |  | ||||||
| 		exit 3 |  | ||||||
| 	else |  | ||||||
| 		usb_args="--privileged -v /dev:/dev" |  | ||||||
| 	fi |  | ||||||
| fi |  | ||||||
| dir=$(pwd -W 2>/dev/null) || dir=$PWD  # Use Windows path if on Windows |  | ||||||
| 
 |  | ||||||
| if [ "$RUNTIME" = "docker" ]; then |  | ||||||
| 	uid_arg="--user $(id -u):$(id -g)" |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| # Run container and build firmware |  | ||||||
| "$RUNTIME" run --rm -it $usb_args \ |  | ||||||
| 	$uid_arg \ |  | ||||||
| 	-w /qmk_firmware \ |  | ||||||
| 	-v "$dir":/qmk_firmware \ |  | ||||||
| 	-e ALT_GET_KEYBOARDS=true \ |  | ||||||
| 	-e SKIP_GIT="$SKIP_GIT" \ |  | ||||||
| 	-e MAKEFLAGS="$MAKEFLAGS" \ |  | ||||||
| 	ghcr.io/qmk/qmk_cli \ |  | ||||||
| 	make "$keyboard${keymap:+:$keymap}${target:+:$target}" |  | ||||||
|  | |||||||
| @ -1,4 +1,5 @@ | |||||||
| #!/bin/sh | #!/bin/sh | ||||||
|  | # vim: set ft=sh ts=4 sw=4 noexpandtab | ||||||
| # NOTE: This script uses tabs for indentation | # NOTE: This script uses tabs for indentation | ||||||
| 
 | 
 | ||||||
| errcho() { | errcho() { | ||||||
| @ -37,13 +38,26 @@ fi | |||||||
| # IF we are using docker on non Linux and docker-machine isn't working print an error | # IF we are using docker on non Linux and docker-machine isn't working print an error | ||||||
| # ELSE set usb_args | # ELSE set usb_args | ||||||
| if [ ! "$(uname)" = "Linux" ] && [ "$RUNTIME" = "docker" ] && ! docker-machine active >/dev/null 2>&1; then | if [ ! "$(uname)" = "Linux" ] && [ "$RUNTIME" = "docker" ] && ! docker-machine active >/dev/null 2>&1; then | ||||||
|     errcho "Error: target requires docker-machine to work on your platform" | 	errcho "Error: target requires docker-machine to work on your platform" | ||||||
|     errcho "See http://gw.tnode.com/docker/docker-machine-with-usb-support-on-windows-macos" | 	errcho "See http://gw.tnode.com/docker/docker-machine-with-usb-support-on-windows-macos" | ||||||
|     exit 3 | 	exit 3 | ||||||
| else | else | ||||||
|     usb_args="--privileged -v /dev:/dev" | 	usb_args="--privileged -v /dev:/dev" | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | qmk_firmware_dir=$(pwd -W 2>/dev/null) || qmk_firmware_dir=$PWD  # Use Windows path if on Windows | ||||||
|  | qmk_userspace_dir="" | ||||||
|  | userspace_docker_args="" | ||||||
|  | 
 | ||||||
|  | if [ -n "$QMK_USERSPACE" ] && [ -e "$QMK_USERSPACE/qmk.json" ]; then | ||||||
|  | 	qmk_userspace_dir=$(cd "$QMK_USERSPACE" && pwd -W 2>/dev/null) || qmk_userspace_dir=$QMK_USERSPACE  # Use Windows path if on Windows | ||||||
|  | elif [ -n "$(which qmk 2>/dev/null)" ] && [ -n "$(qmk userspace-path)" ]; then | ||||||
|  | 	qmk_userspace_dir=$(cd "$(qmk userspace-path)" && pwd -W 2>/dev/null) || qmk_userspace_dir=$(qmk userspace-path)  # Use Windows path if on Windows | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | if [ -n "$qmk_userspace_dir" ]; then | ||||||
|  | 	userspace_docker_args="-v $qmk_userspace_dir:/qmk_userspace:z -e QMK_USERSPACE=/qmk_userspace" | ||||||
| fi | fi | ||||||
| dir=$(pwd -W 2>/dev/null) || dir=$PWD  # Use Windows path if on Windows |  | ||||||
| 
 | 
 | ||||||
| if [ "$RUNTIME" = "docker" ]; then | if [ "$RUNTIME" = "docker" ]; then | ||||||
| 	uid_arg="--user $(id -u):$(id -g)" | 	uid_arg="--user $(id -u):$(id -g)" | ||||||
| @ -54,6 +68,10 @@ fi | |||||||
| 	$usb_args \ | 	$usb_args \ | ||||||
| 	$uid_arg \ | 	$uid_arg \ | ||||||
| 	-w /qmk_firmware \ | 	-w /qmk_firmware \ | ||||||
| 	-v "$dir":/qmk_firmware \ | 	-v "$qmk_firmware_dir":/qmk_firmware:z \ | ||||||
|  | 	$userspace_docker_args \ | ||||||
|  | 	-e SKIP_GIT="$SKIP_GIT" \ | ||||||
|  | 	-e SKIP_VERSION="$SKIP_VERSION" \ | ||||||
|  | 	-e MAKEFLAGS="$MAKEFLAGS" \ | ||||||
| 	ghcr.io/qmk/qmk_cli \ | 	ghcr.io/qmk/qmk_cli \ | ||||||
| 	"$@" | 	"$@" | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user