docker/build-pb: Add --interactive flag
authorGeoff Levand <geoff@infradead.org>
Mon, 21 May 2018 19:59:39 +0000 (19:59 +0000)
committerSamuel Mendoza-Jonas <sam@mendozajonas.com>
Wed, 23 May 2018 01:11:39 +0000 (11:11 +1000)
Signed-off-by: Geoff Levand <geoff@infradead.org>
Signed-off-by: Samuel Mendoza-Jonas <sam@mendozajonas.com>
docker/README.md
docker/build-pb

index 7e3966da26575bf139ac8159db197d817cccb773..d806ba1e7ce687fabd51e7f3261278d5acadd643 100644 (file)
 
 ### Run an interactive pb-builder container
 
-As current user:
+As root:
 
-    docker run --rm -it --user $(id -u):$(id -g) -v /etc/group:/etc/group:ro -v /etc/passwd:/etc/passwd:ro -v $(pwd):/opt/pb -w /opt/pb $(./docker/build-pb -t) bash
+    ./build-pb --interactive
 
-As root:
 
-    docker run --rm -it -v /etc/group:/etc/group:ro -v /etc/passwd:/etc/passwd:ro -v $(pwd):/opt/pb -w /opt/pb $(./docker/build-pb -t) bash
+As current user:
+
+    docker run --rm -it --user $(id -u):$(id -g) -v /etc/group:/etc/group:ro -v /etc/passwd:/etc/passwd:ro -v $(pwd):/opt/pb -w /opt/pb $(./docker/build-pb -t) bash
index ce6c41fc9aa207f78d07ca74503f6528be46c690..ad08ef9e3cd586e5addd320fffc21df1944b8260 100755 (executable)
@@ -12,20 +12,21 @@ usage () {
        echo "${name} - Builds the petitboot programs using a pb-builder container." >&2
        echo "Usage: ${name} [flags]" >&2
        echo "Option flags:" >&2
-       echo "  -c --check    - Run 'make check'." >&2
-       echo "  -d --dry-run  - Do not run docker commands." >&2
-       echo "  -h --help     - Show this help and exit." >&2
-       echo "  -t --tag      - Print Docker tag to stdout and exit." >&2
-       echo "  -v --verbose  - Verbose execution." >&2
+       echo "  -c --check       - Run 'make check'." >&2
+       echo "  -d --dry-run     - Do not run docker commands." >&2
+       echo "  -h --help        - Show this help and exit." >&2
+       echo "  -i --interactive - Run an interactive pb-builder container." >&2
+       echo "  -t --tag         - Print Docker tag to stdout and exit." >&2
+       echo "  -v --verbose     - Verbose execution." >&2
        echo "Environment:" >&2
-       echo "  DOCKER_TAG    - Default: '${DOCKER_TAG}'" >&2
+       echo "  DOCKER_TAG       - Default: '${DOCKER_TAG}'" >&2
        echo "Examples:" >&2
        echo "  ${name} -vc"
        echo "  ${name} -v"
 }
 
-short_opts="cdhtv"
-long_opts="check,dry-run,help,tag,verbose"
+short_opts="cdhitv"
+long_opts="check,dry-run,help,interactive,tag,verbose"
 
 opts=$(getopt --options ${short_opts} --long ${long_opts} -n "${name}" -- "$@")
 
@@ -50,6 +51,10 @@ while true ; do
                usage=1
                shift
                ;;
+       -i | --interactive)
+               interactive=1
+               shift
+               ;;
        -t | --tag)
                tag=1
                shift
@@ -80,15 +85,24 @@ if [[ -n "${tag}" ]]; then
        exit 0
 fi
 
-docker_args="--rm \
-       -u $(id -u):$(id -g) \
+docker_base_args="\
+       --rm \
        -v /etc/group:/etc/group:ro \
        -v /etc/passwd:/etc/passwd:ro \
        -v ${TOP_DIR}:/opt/pb \
        -w /opt/pb \
 "
 
-if [[ -n "$verbose}" ]]; then
+docker_user_args="-u $(id -u):$(id -g)"
+
+if [[ -n "${interactive}" ]]; then
+       cd "${TOP_DIR}"
+       docker_args="${docker_base_args}"
+       run_cmd "docker run -it ${docker_args} ${DOCKER_TAG} /bin/bash"
+       exit
+fi
+
+if [[ -n "${verbose}" ]]; then
        bash_debug="-x"
 fi
 
@@ -99,6 +113,7 @@ else
 fi
 
 cd "${TOP_DIR}"
+docker_args="${docker_base_args} ${docker_user_args}"
 run_cmd "docker run ${docker_args} ${DOCKER_TAG} /bin/bash \
        -e ${bash_debug} \
        -c './bootstrap && ./configure --with-ncurses && make && ${docker_extra}'"