Skip to content

Commit 7b30eda

Browse files
committed
Updated mill and millw
1 parent 79676af commit 7b30eda

File tree

5 files changed

+81
-44
lines changed

5 files changed

+81
-44
lines changed

.bloop/bloop.settings.json

Lines changed: 21 additions & 20 deletions
Original file line numberDiff line numberDiff line change
@@ -1,22 +1,23 @@
11
{
2-
"semanticDBVersion": "4.4.30",
3-
"supportedScalaVersions": [
4-
"2.13.7",
5-
"2.12.15",
6-
"2.12.14",
7-
"2.12.13",
8-
"2.12.12",
9-
"2.12.11",
10-
"2.13.4",
11-
"2.13.5",
12-
"2.13.6",
13-
"2.11.12",
14-
"2.12.8",
15-
"2.12.9",
16-
"2.12.10",
17-
"2.13.0",
18-
"2.13.1",
19-
"2.13.2",
20-
"2.13.3"
21-
]
2+
"javaSemanticDBVersion": "0.7.4",
3+
"semanticDBVersion": "4.5.0",
4+
"supportedScalaVersions": [
5+
"2.13.8",
6+
"2.12.15",
7+
"2.12.14",
8+
"2.12.13",
9+
"2.12.12",
10+
"2.12.11",
11+
"2.13.5",
12+
"2.13.6",
13+
"2.13.7",
14+
"2.11.12",
15+
"2.12.8",
16+
"2.12.9",
17+
"2.12.10",
18+
"2.13.1",
19+
"2.13.2",
20+
"2.13.3",
21+
"2.13.4"
22+
]
2223
}

.gitignore

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -3,4 +3,4 @@
33
/.idea_modules/
44
/.metals
55
/.vscode
6-
/.bloop/
6+
/.bloop

mill

Lines changed: 6 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -3,14 +3,14 @@
33
# This is a wrapper script, that automatically download mill from GitHub release pages
44
# You can give the required mill version with MILL_VERSION env variable
55
# If no version is given, it falls back to the value of DEFAULT_MILL_VERSION
6-
DEFAULT_MILL_VERSION=0.5.6
6+
DEFAULT_MILL_VERSION=0.10.2
77

88
set -e
99

1010
if [ -z "$MILL_VERSION" ] ; then
1111
if [ -f ".mill-version" ] ; then
1212
MILL_VERSION="$(head -n 1 .mill-version 2> /dev/null)"
13-
elif [ -f "mill" ] && [ "$BASH_SOURCE" != "mill" ] ; then
13+
elif [ -f "mill" ] && [ "$0" != "mill" ] ; then
1414
MILL_VERSION=$(grep -F "DEFAULT_MILL_VERSION=" "mill" | head -n 1 | cut -d= -f2)
1515
else
1616
MILL_VERSION=$DEFAULT_MILL_VERSION
@@ -28,13 +28,14 @@ version_remainder="$MILL_VERSION"
2828
MILL_MAJOR_VERSION="${version_remainder%%.*}"; version_remainder="${version_remainder#*.}"
2929
MILL_MINOR_VERSION="${version_remainder%%.*}"; version_remainder="${version_remainder#*.}"
3030

31-
if [ ! -x "$MILL_EXEC_PATH" ] ; then
32-
mkdir -p $MILL_DOWNLOAD_PATH
31+
if [ ! -s "$MILL_EXEC_PATH" ] ; then
32+
mkdir -p "$MILL_DOWNLOAD_PATH"
3333
if [ "$MILL_MAJOR_VERSION" -gt 0 ] || [ "$MILL_MINOR_VERSION" -ge 5 ] ; then
3434
ASSEMBLY="-assembly"
3535
fi
3636
DOWNLOAD_FILE=$MILL_EXEC_PATH-tmp-download
37-
MILL_DOWNLOAD_URL="https://github.com/lihaoyi/mill/releases/download/${MILL_VERSION%%-*}/$MILL_VERSION${ASSEMBLY}"
37+
MILL_VERSION_TAG=$(echo $MILL_VERSION | sed -E 's/([^-]+)(-M[0-9]+)?(-.*)?/\1\2/')
38+
MILL_DOWNLOAD_URL="https://github.com/lihaoyi/mill/releases/download/${MILL_VERSION_TAG}/$MILL_VERSION${ASSEMBLY}"
3839
curl --fail -L -o "$DOWNLOAD_FILE" "$MILL_DOWNLOAD_URL"
3940
chmod +x "$DOWNLOAD_FILE"
4041
mv "$DOWNLOAD_FILE" "$MILL_EXEC_PATH"

millw

Lines changed: 51 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -5,25 +5,25 @@
55
# If no version is given, it falls back to the value of DEFAULT_MILL_VERSION
66
#
77
# Project page: https://github.com/lefou/millw
8-
# Script Version: 0.4.0
8+
# Script Version: 0.4.2
99
#
1010
# If you want to improve this script, please also contribute your changes back!
1111
#
1212
# Licensed under the Apache License, Version 2.0
1313

1414

15-
DEFAULT_MILL_VERSION=0.9.10
15+
DEFAULT_MILL_VERSION=0.10.0
1616

1717
set -e
1818

1919
MILL_REPO_URL="https://github.com/com-lihaoyi/mill"
2020

21-
if [ "x${CURL_CMD}" = "x" ] ; then
21+
if [ -z "${CURL_CMD}" ] ; then
2222
CURL_CMD=curl
2323
fi
2424

2525
# Explicit commandline argument takes precedence over all other methods
26-
if [ "x$1" = "x--mill-version" ] ; then
26+
if [ "$1" = "--mill-version" ] ; then
2727
shift
2828
if [ "x$1" != "x" ] ; then
2929
MILL_VERSION="$1"
@@ -40,20 +40,20 @@ fi
4040
# We reuse it's value and skip searching for a value.
4141

4242
# If not already set, read .mill-version file
43-
if [ "x${MILL_VERSION}" = "x" ] ; then
43+
if [ -z "${MILL_VERSION}" ] ; then
4444
if [ -f ".mill-version" ] ; then
4545
MILL_VERSION="$(head -n 1 .mill-version 2> /dev/null)"
4646
fi
4747
fi
4848

49-
if [ "x${XDG_CACHE_HOME}" != "x" ] ; then
49+
if [ -n "${XDG_CACHE_HOME}" ] ; then
5050
MILL_DOWNLOAD_PATH="${XDG_CACHE_HOME}/mill/download"
5151
else
5252
MILL_DOWNLOAD_PATH="${HOME}/.cache/mill/download"
5353
fi
5454

5555
# If not already set, try to fetch newest from Github
56-
if [ "x${MILL_VERSION}" = "x" ] ; then
56+
if [ -z "${MILL_VERSION}" ] ; then
5757
# TODO: try to load latest version from release page
5858
echo "No mill version specified." 1>&2
5959
echo "You should provide a version via '.mill-version' file or --mill-version option." 1>&2
@@ -68,20 +68,22 @@ if [ "x${MILL_VERSION}" = "x" ] ; then
6868
# to show the (previously suppressed) error message
6969
LANG=C touch -d '1 hour ago' "${MILL_DOWNLOAD_PATH}/.expire_latest"
7070
)
71-
72-
if [ "${MILL_DOWNLOAD_PATH}/.latest" -nt "${MILL_DOWNLOAD_PATH}/.expire_latest" ] ; then
71+
72+
# POSIX shell variant of bash's -nt operator, see https://unix.stackexchange.com/a/449744/6993
73+
# if [ "${MILL_DOWNLOAD_PATH}/.latest" -nt "${MILL_DOWNLOAD_PATH}/.expire_latest" ] ; then
74+
if [ -n "$(find -L "${MILL_DOWNLOAD_PATH}/.latest" -prune -newer "${MILL_DOWNLOAD_PATH}/.expire_latest")" ]; then
7375
# we know a current latest version
74-
MILL_VERSION="$(head -n 1 ${MILL_DOWNLOAD_PATH}/.latest 2> /dev/null)"
76+
MILL_VERSION=$(head -n 1 "${MILL_DOWNLOAD_PATH}"/.latest 2> /dev/null)
7577
fi
7678

77-
if [ "x${MILL_VERSION}" = "x" ] ; then
79+
if [ -z "${MILL_VERSION}" ] ; then
7880
# we don't know a current latest version
7981
echo "Retrieving latest mill version ..." 1>&2
8082
LANG=C ${CURL_CMD} -s -i -f -I ${MILL_REPO_URL}/releases/latest 2> /dev/null | grep --ignore-case Location: | sed s'/^.*tag\///' | tr -d '\r\n' > "${MILL_DOWNLOAD_PATH}/.latest"
81-
MILL_VERSION="$(head -n 1 ${MILL_DOWNLOAD_PATH}/.latest 2> /dev/null)"
83+
MILL_VERSION=$(head -n 1 "${MILL_DOWNLOAD_PATH}"/.latest 2> /dev/null)
8284
fi
8385

84-
if [ "x${MILL_VERSION}" = "x" ] ; then
86+
if [ -z "${MILL_VERSION}" ] ; then
8587
# Last resort
8688
MILL_VERSION="${DEFAULT_MILL_VERSION}"
8789
echo "Falling back to hardcoded mill version ${MILL_VERSION}" 1>&2
@@ -92,16 +94,49 @@ fi
9294

9395
MILL="${MILL_DOWNLOAD_PATH}/${MILL_VERSION}"
9496

97+
try_to_use_system_mill() {
98+
MILL_IN_PATH="$(command -v mill || true)"
99+
100+
if [ -z "${MILL_IN_PATH}" ]; then
101+
return
102+
fi
103+
104+
UNIVERSAL_SCRIPT_MAGIC="@ 2>/dev/null # 2>nul & echo off & goto BOF"
105+
106+
if ! head -c 128 "${MILL_IN_PATH}" | grep -qF "${UNIVERSAL_SCRIPT_MAGIC}"; then
107+
if [ -n "${MILLW_VERBOSE}" ]; then
108+
echo "Could not determine mill version of ${MILL_IN_PATH}, as it does not start with the universal script magic2" 1>&2
109+
fi
110+
return
111+
fi
112+
113+
# Roughly the size of the universal script.
114+
MILL_VERSION_SEARCH_RANGE="2403"
115+
MILL_IN_PATH_VERSION=$(head -c "${MILL_VERSION_SEARCH_RANGE}" "${MILL_IN_PATH}" |\
116+
sed -n 's/^.*-DMILL_VERSION=\([^\s]*\) .*$/\1/p' |\
117+
head -n 1)
118+
119+
if [ -z "${MILL_IN_PATH_VERSION}" ]; then
120+
echo "Could not determine mill version, even though ${MILL_IN_PATH} has the universal script magic" 1>&2
121+
return
122+
fi
123+
124+
if [ "${MILL_IN_PATH_VERSION}" = "${MILL_VERSION}" ]; then
125+
MILL="${MILL_IN_PATH}"
126+
fi
127+
}
128+
try_to_use_system_mill
129+
95130
# If not already downloaded, download it
96131
if [ ! -s "${MILL}" ] ; then
97-
132+
98133
# support old non-XDG download dir
99134
MILL_OLD_DOWNLOAD_PATH="${HOME}/.mill/download"
100135
OLD_MILL="${MILL_OLD_DOWNLOAD_PATH}/${MILL_VERSION}"
101136
if [ -x "${OLD_MILL}" ] ; then
102137
MILL="${OLD_MILL}"
103138
else
104-
VERSION_PREFIX="$(echo -n $MILL_VERSION | cut -b -4)"
139+
VERSION_PREFIX="$(echo $MILL_VERSION | cut -b -4)"
105140
case $VERSION_PREFIX in
106141
0.0. | 0.1. | 0.2. | 0.3. | 0.4. )
107142
DOWNLOAD_SUFFIX=""
@@ -133,4 +168,4 @@ unset MILL_VERSION
133168
unset MILL_VERSION_TAG
134169
unset MILL_REPO_URL
135170

136-
exec $MILL "$@"
171+
exec "${MILL}" "$@"

millw.bat

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@ rem You can give the required mill version with --mill-version parameter
55
rem If no version is given, it falls back to the value of DEFAULT_MILL_VERSION
66
rem
77
rem Project page: https://github.com/lefou/millw
8-
rem Script Version: 0.4.0
8+
rem Script Version: 0.4.2
99
rem
1010
rem If you want to improve this script, please also contribute your changes back!
1111
rem
@@ -15,7 +15,7 @@ rem setlocal seems to be unavailable on Windows 95/98/ME
1515
rem but I don't think we need to support them in 2019
1616
setlocal enabledelayedexpansion
1717

18-
set "DEFAULT_MILL_VERSION=0.9.10"
18+
set "DEFAULT_MILL_VERSION=0.10.0"
1919

2020
set "MILL_REPO_URL=https://github.com/com-lihaoyi/mill"
2121

0 commit comments

Comments
 (0)