2021-01-06 10:16:37 +00:00
#!/usr/bin/env bash
SOURCE = " ${ BASH_SOURCE [0] } "
while [ -h " $SOURCE " ] ; do # resolve $SOURCE until the file is no longer a symlink
DIR = " $( cd -P " $( dirname " $SOURCE " ) " && pwd ) "
SOURCE = " $( readlink " $SOURCE " ) "
[ [ $SOURCE != /* ] ] && SOURCE = " $DIR / $SOURCE " # if $SOURCE was a relative symlink, we need to resolve it relative to the path where the symlink file was located
done
ROOT_DIR = " $( cd -P " $( dirname " $SOURCE " ) /.. " && pwd ) "
2021-07-08 07:43:45 +00:00
export OS_NAME = " ${ OS_NAME :- ubuntu18 .04 } "
2021-01-12 10:03:24 +00:00
unameOut = " $( uname -s) "
case " ${ unameOut } " in
Linux*) machine = Linux; ;
Darwin*) machine = Mac; ;
CYGWIN*) machine = Cygwin; ;
MINGW*) machine = MinGw; ;
*) machine = " UNKNOWN: ${ unameOut } "
esac
2021-01-06 10:16:37 +00:00
# Attempt to run in the container with the same UID/GID as we have on the host,
# as this results in the correct permissions on files created in the shared
# volumes. This isn't always possible, however, as IDs less than 100 are
# reserved by Debian, and IDs in the low 100s are dynamically assigned to
# various system users and groups. To be safe, if we see a UID/GID less than
# 500, promote it to 501. This is notably necessary on macOS Lion and later,
# where administrator accounts are created with a GID of 20. This solution is
# not foolproof, but it works well in practice.
uid = $( id -u)
gid = $( id -g)
[ " $uid " -lt 500 ] && uid = 501
[ " $gid " -lt 500 ] && gid = $uid
2021-02-26 03:37:03 +00:00
if [ " ${ 1 - } " = "build" ] ; then
CHECK_BUILDER = 1
fi
2021-02-25 11:22:21 +00:00
if [ " ${ CHECK_BUILDER :- } " = = "1" ] ; then
awk 'c&&c--{sub(/^/,"#")} /# Command/{c=3} 1' $ROOT_DIR /docker-compose.yml > $ROOT_DIR /docker-compose-devcontainer.yml
else
awk 'c&&c--{sub(/^/,"#")} /# Build devcontainer/{c=5} 1' $ROOT_DIR /docker-compose.yml > $ROOT_DIR /docker-compose-devcontainer.yml.tmp
awk 'c&&c--{sub(/^/,"#")} /# Command/{c=3} 1' $ROOT_DIR /docker-compose-devcontainer.yml.tmp > $ROOT_DIR /docker-compose-devcontainer.yml
rm $ROOT_DIR /docker-compose-devcontainer.yml.tmp
fi
2021-01-08 07:00:58 +00:00
2021-01-12 10:03:24 +00:00
if [ " ${ machine } " = = "Mac" ] ; then
2021-01-15 10:03:16 +00:00
sed -i '' " s/# user: {{ CURRENT_ID }}/user: \" $uid : $gid \"/g " $ROOT_DIR /docker-compose-devcontainer.yml
2021-01-12 10:03:24 +00:00
else
2021-01-15 10:03:16 +00:00
sed -i " s/# user: {{ CURRENT_ID }}/user: \" $uid : $gid \"/g " $ROOT_DIR /docker-compose-devcontainer.yml
fi
2021-05-22 01:20:41 +00:00
pushd " $ROOT_DIR "
2021-07-08 07:43:45 +00:00
mkdir -p " ${ DOCKER_VOLUME_DIRECTORY :- .docker } /amd64- ${ OS_NAME } -ccache "
mkdir -p " ${ DOCKER_VOLUME_DIRECTORY :- .docker } /amd64- ${ OS_NAME } -go-mod "
2021-07-09 03:59:09 +00:00
mkdir -p " ${ DOCKER_VOLUME_DIRECTORY :- .docker } /thirdparty "
2021-07-08 07:43:45 +00:00
mkdir -p " ${ DOCKER_VOLUME_DIRECTORY :- .docker } /amd64- ${ OS_NAME } -vscode-extensions "
2021-05-22 01:20:41 +00:00
chmod -R 777 " ${ DOCKER_VOLUME_DIRECTORY :- .docker } "
2021-02-26 03:37:03 +00:00
if [ " ${ 1 - } " = "build" ] ; then
2021-07-08 07:43:45 +00:00
docker-compose -f $ROOT_DIR /docker-compose-devcontainer.yml pull --ignore-pull-failures builder
docker-compose -f $ROOT_DIR /docker-compose-devcontainer.yml build builder
2021-02-26 03:37:03 +00:00
fi
2021-01-15 10:03:16 +00:00
if [ " ${ 1 - } " = "up" ] ; then
docker-compose -f $ROOT_DIR /docker-compose-devcontainer.yml up -d
fi
if [ " ${ 1 - } " = "down" ] ; then
docker-compose -f $ROOT_DIR /docker-compose-devcontainer.yml down
fi
2021-05-22 01:20:41 +00:00
popd