summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGary Sneed <gary@getcobalt.org>2024-10-25 22:43:28 -0700
committerGary Sneed <gary@getcobalt.org>2024-10-25 22:43:28 -0700
commita799b160834d9278735abe0fc6679bfaf2e9f695 (patch)
tree4366f88a10f1bd251d9615a44dc73604ee31f016
parente38c87eab91ba6dfa1c8ac0d3096fbb7fb2d0e6e (diff)
POSIX compliancev1.2
-rwxr-xr-xget_version.sh52
-rwxr-xr-xlaunch.sh10
-rw-r--r--profiles/1.02
-rw-r--r--profiles/1.12
-rw-r--r--profiles/1.2.52
-rw-r--r--profiles/1.3.22
-rw-r--r--profiles/1.4.72
-rw-r--r--profiles/1.5.22
-rw-r--r--profiles/a1.1.2_012
-rw-r--r--profiles/a1.2.62
-rw-r--r--profiles/b1.3_012
-rw-r--r--profiles/b1.42
-rw-r--r--profiles/b1.4_012
-rw-r--r--profiles/b1.5_012
-rw-r--r--profiles/b1.6.62
-rw-r--r--profiles/b1.7.32
-rw-r--r--profiles/b1.8.12
17 files changed, 47 insertions, 45 deletions
diff --git a/get_version.sh b/get_version.sh
index c413459..1bcb2a4 100755
--- a/get_version.sh
+++ b/get_version.sh
@@ -1,8 +1,10 @@
#!/usr/bin/env sh
+JQ=${JQ:=jq}
+
# Check for packages
-JQ_VERSION=$(jq --version 2>/dev/null)
-if [[ ${JQ_VERSION} == 'jq-1.3' || ${JQ_VERSION} == 'jq-1.4' || ${JQ_VERSION} == 'jq-1.5' || ${JQ_VERSION} == 'jq-1.6' ]]; then
+JQ_VERSION=$("${JQ}" --version 2>/dev/null)
+if [ "${JQ_VERSION}" = 'jq-1.3' ] || [ "${JQ_VERSION}" = 'jq-1.4' ] || [ "${JQ_VERSION}" = 'jq-1.5' ] || [ "${JQ_VERSION}" = 'jq-1.6' ]; then
echo 'ERROR: installed jq version is too old; must be at least 1.7'
exit 1
elif [ -z ${JQ_VERSION} ]; then
@@ -39,7 +41,7 @@ MANIFEST_LIST_URL='https://launchermeta.mojang.com/mc/game/version_manifest.json
mkdir -p assets/indexes
echo 'Retrieving version manifest...'
-VERSION_MANIFEST_URL=$(curl "${MANIFEST_LIST_URL}" 2>/dev/null | jq -r "(.versions.[] | select(.id==\"${LOOKING_FOR}\")).url")
+VERSION_MANIFEST_URL=$(curl "${MANIFEST_LIST_URL}" 2>/dev/null | "${JQ}" -r "(.versions.[] | select(.id==\"${LOOKING_FOR}\")).url")
if [ -z "${VERSION_MANIFEST_URL}" ]; then
echo "ERROR: Unable to find requested version"
@@ -47,56 +49,56 @@ if [ -z "${VERSION_MANIFEST_URL}" ]; then
fi
mkdir -p manifests
-VERSION_MANIFEST=$(curl ${VERSION_MANIFEST_URL} 2>/dev/null | sed -e 's/\\/\\\\/g' | tee "manifests/${LOOKING_FOR}.json") # Some versions contain illegal escape sequences which will crash some shells such as Ksh; double-escape it just to be safe
+VERSION_MANIFEST=$(curl ${VERSION_MANIFEST_URL} 2>/dev/null | sed -e 's/\\//g' | tee "manifests/${LOOKING_FOR}.json") # Some versions contain illegal escape sequences which will crash some shells such as Ksh; double-escape it just to be safe
# 1.12 and earlier, natives and regular libraries are contained in different elements. For 1.13 and later, an element may contain both.
echo 'Downloading libraries...'
-for I in $(echo "${VERSION_MANIFEST}" | jq -c .libraries.[]); do
- if [[ $(echo "${I}" | jq .downloads.artifact) != 'null' ]]; then
- echo "Library '$(echo ${I} | jq -r .name )' found - downloading..."
- mkdir -p libraries/$(dirname $(echo ${I} | jq -r .downloads.artifact.path))
- curl $(echo ${I} | jq -r .downloads.artifact.url) > libraries/$(echo "${I}" | jq -r .downloads.artifact.path) 2>/dev/null
+for I in $(echo "${VERSION_MANIFEST}" | "${JQ}" -c .libraries.[]); do
+ if [ "$(echo "${I}" | "${JQ}" .downloads.artifact)" != 'null' ]; then
+ echo "Library '$(echo ${I} | "${JQ}" -r .name )' found - downloading..."
+ mkdir -p libraries/$(dirname $(echo ${I} | "${JQ}" -r .downloads.artifact.path))
+ curl $(echo ${I} | "${JQ}" -r .downloads.artifact.url) > libraries/$(echo "${I}" | "${JQ}" -r .downloads.artifact.path) 2>/dev/null
fi
- if [[ $(echo "${I}" | jq .natives) != 'null' ]]; then
+ if [ "$(echo "${I}" | "${JQ}" .natives)" != 'null' ]; then
echo "Downloading native for platform '${PLATFORM}'..."
- if [[ $(echo ${I} | jq -r ".downloads.classifiers.\"natives-${PLATFORM}\"") == 'null' ]]; then
- echo "WARNING: Mojang does not distribute a '$(echo ${I} | jq -r .name)' native for this platform. This is probably not an issue unless you are using an obscure platform."
+ if [ "$(echo ${I} | "${JQ}" -r ".downloads.classifiers.\"natives-${PLATFORM}\"")" = 'null' ]; then
+ echo "WARNING: Mojang does not distribute a '$(echo ${I} | "${JQ}" -r .name)' native for this platform. This is probably not an issue unless you are using an obscure platform."
else
- mkdir -p libraries/$(dirname $(echo ${I} | jq -r ".downloads.classifiers.\"natives-${PLATFORM}\".path"))
- curl $(echo ${I} | jq -r ".downloads.classifiers.\"natives-${PLATFORM}\".url") > libraries/$(echo "${I}" | jq -r ".downloads.classifiers.\"natives-${PLATFORM}\".path") 2>/dev/null
+ mkdir -p libraries/$(dirname $(echo ${I} | "${JQ}" -r ".downloads.classifiers.\"natives-${PLATFORM}\".path"))
+ curl $(echo ${I} | "${JQ}" -r ".downloads.classifiers.\"natives-${PLATFORM}\".url") > libraries/$(echo "${I}" | "${JQ}" -r ".downloads.classifiers.\"natives-${PLATFORM}\".path") 2>/dev/null
fi
fi
done
echo 'Retrieving asset index...'
-ASSET_INDEX=$(echo "${VERSION_MANIFEST}" | jq .assetIndex)
+ASSET_INDEX=$(echo "${VERSION_MANIFEST}" | "${JQ}" .assetIndex)
echo 'Retrieving object list...'
-OBJECT_LIST=$(curl $(echo ${ASSET_INDEX} | jq -r .url) 2>/dev/null | tee assets/indexes/$(echo ${ASSET_INDEX} | jq -r .id).json)
+OBJECT_LIST=$(curl $(echo ${ASSET_INDEX} | "${JQ}" -r .url) 2>/dev/null | tee assets/indexes/$(echo ${ASSET_INDEX} | "${JQ}" -r .id).json)
-HASH_COUNT=$(echo ${OBJECT_LIST} | jq '.objects | length')
+HASH_COUNT=$(echo ${OBJECT_LIST} | "${JQ}" '.objects | length')
echo 'Downloading required assets. This may take a few minutes.'
MCRESOURCES='https://resources.download.minecraft.net/'
-if [[ "$(echo "${ASSET_INDEX}" | jq -r .id)" == 'pre-1.6' || "$(echo "${ASSET_INDEX}" | jq -r .id)" == 'legacy' ]]; then # Release 1.6 and prior use a different asset layout
- while read -r LINE; do
- H=$(echo ${OBJECT_LIST} | jq -r ".objects.[\"${LINE}\"].hash")
- DIR="${H[0]}${H[1]}/"
+if [ "$(echo "${ASSET_INDEX}" | "${JQ}" -r .id)" = 'pre-1.6' ] || [ "$(echo "${ASSET_INDEX}" | "${JQ}" -r .id)" = 'legacy' ]; then # Release 1.6 and prior use a different asset layout
+ echo "${OBJECT_LIST}" | "${JQ}" -r '.objects | keys[]' | while read -r LINE; do
+ H=$(echo ${OBJECT_LIST} | "${JQ}" -r ".objects.[\"${LINE}\"].hash")
+ DIR="$(echo "${H}" | cut -c1-2)/"
mkdir -p "$(dirname "assets/virtual/legacy/${LINE}")"
curl "${MCRESOURCES}${DIR}${H}" > "assets/virtual/legacy/${LINE}" 2>/dev/null
echo "Downloaded: assets/virtual/legacy/${LINE}"
- done <<< "$(echo "${OBJECT_LIST}" | jq -r '.objects | keys[]')"
+ done
else
IND=0
- for I in $(echo "${OBJECT_LIST}" | jq -r .objects.[].hash); do
+ for I in $(echo "${OBJECT_LIST}" | "${JQ}" -r .objects.[].hash); do
IND=$(echo "${IND}" + 1 | nickle)
DIR="$(echo "${I}" | cut -c1-2)/"
mkdir -p "assets/objects/${DIR}"
# If file exists, check its integrity with hash and skip if it's good
- if [[ -f assets/objects/${DIR}${I} && $(cat "assets/objects/${DIR}${I}" | sha1sum | sed -e 's/ (stdin)//') == "${I}" ]]; then # Removing (stdin) is not needed for most sha1sum implementations
+ if [ -f assets/objects/${DIR}${I} ] && [ "$(cat "assets/objects/${DIR}${I}" | sha1sum | sed -e 's/ (stdin)//')" = "${I}" ]; then # Removing (stdin) is not needed for most sha1sum implementations
echo "${IND}/${HASH_COUNT} (${DIR}${I}) is already downloaded; skipping. ($(echo "printf(\"%5l\", ${IND} / ${HASH_COUNT} * 100)" | nickle)%)"
continue;
fi
@@ -107,7 +109,7 @@ else
fi
echo 'Downloading minecraft jar...'
-CLIENT_URL=$(echo "${VERSION_MANIFEST}" | jq -r .downloads.client.url)
+CLIENT_URL=$(echo "${VERSION_MANIFEST}" | "${JQ}" -r .downloads.client.url)
mkdir -p "libraries/com/mojang/minecraft/${LOOKING_FOR}"
curl "${CLIENT_URL}" > "libraries/com/mojang/minecraft/${LOOKING_FOR}/minecraft-${LOOKING_FOR}-client.jar" 2>/dev/null
diff --git a/launch.sh b/launch.sh
index 596990b..1b3421b 100755
--- a/launch.sh
+++ b/launch.sh
@@ -56,13 +56,13 @@ VERSION_MANIFEST=$(cat "manifests/${VERSION}.json")
# 1.12 and earlier, natives and regular libraries are contained in different elements. For 1.13 and later, an element may contain both.
CLASSPATH=
for I in $(echo "${VERSION_MANIFEST}" | jq -c .libraries.[]); do
- if [[ $(echo "${I}" | jq .downloads.artifact) != 'null' ]]; then
+ if [ "$(echo "${I}" | jq .downloads.artifact)" != 'null' ]; then
for J in ${BLACKLISTED_LIBRARIES}; do
if [ ${J} == $(basename $(echo ${I} | jq -r .downloads.artifact.path)) ]; then
SKIP=1
fi
done
- if [[ ${SKIP} -eq 1 ]]; then
+ if [ "${SKIP}" = '1' ]; then
SKIP=
continue
fi
@@ -71,13 +71,13 @@ for I in $(echo "${VERSION_MANIFEST}" | jq -c .libraries.[]); do
CLASSPATH="${PWD}/libraries/${JAR}:${CLASSPATH}"
fi
fi
- if [[ $(echo "${I}" | jq .natives) != 'null' ]]; then
+ if [ "$(echo "${I}" | jq .natives)" != 'null' ]; then
for J in ${BLACKLISTED_NATIVES}; do
if [ ${J} == $(basename $(echo ${I} | jq ".downloads.classifiers.\"natives-${PLATFORM}\".path")) ]; then
SKIP=1
fi
done
- if [[ ${SKIP} -eq 1 ]]; then
+ if [ "${SKIP}" = '1' ]; then
SKIP=
continue
fi
@@ -94,7 +94,7 @@ done
CLASSPATH="${CLASSPATH}:${PWD}/${MINECRAFT_JAR}"
-if [[ $(echo "${VERSION_MANIFEST}" | jq -r .minecraftArguments) != 'null' ]]; then
+if [ "$(echo "${VERSION_MANIFEST}" | jq -r .minecraftArguments)" != 'null' ]; then
ARGUMENT_LIST=$(echo ${VERSION_MANIFEST} | jq -r .minecraftArguments)
else
for I in $(echo ${VERSION_MANIFEST} | jq -r '.arguments.game[] | select(type=="string")'); do
diff --git a/profiles/1.0 b/profiles/1.0
index 2eb5453..e607c71 100644
--- a/profiles/1.0
+++ b/profiles/1.0
@@ -1,5 +1,5 @@
VERSION=1.0
mkdir -p instances/${INAME}
-[[ ! -L "instances/${INAME}/resources" ]] && rmdir "instances/${INAME}/resources" 2>/dev/null
+[ ! -L "instances/${INAME}/resources" ] && rmdir "instances/${INAME}/resources" 2>/dev/null
ln -sf ../../assets/virtual/legacy "instances/${INAME}/resources"
diff --git a/profiles/1.1 b/profiles/1.1
index be6bf66..7431175 100644
--- a/profiles/1.1
+++ b/profiles/1.1
@@ -1,5 +1,5 @@
VERSION=1.1
mkdir -p instances/${INAME}
-[[ ! -L "instances/${INAME}/resources" ]] && rmdir "instances/${INAME}/resources" 2>/dev/null
+[ ! -L "instances/${INAME}/resources" ] && rmdir "instances/${INAME}/resources" 2>/dev/null
ln -sf ../../assets/virtual/legacy "instances/${INAME}/resources"
diff --git a/profiles/1.2.5 b/profiles/1.2.5
index 9305282..c9c64af 100644
--- a/profiles/1.2.5
+++ b/profiles/1.2.5
@@ -1,5 +1,5 @@
VERSION=1.2.5
mkdir -p instances/${INAME}
-[[ ! -L "instances/${INAME}/resources" ]] && rmdir "instances/${INAME}/resources" 2>/dev/null
+[ ! -L "instances/${INAME}/resources" ] && rmdir "instances/${INAME}/resources" 2>/dev/null
ln -sf ../../assets/virtual/legacy "instances/${INAME}/resources"
diff --git a/profiles/1.3.2 b/profiles/1.3.2
index 69c3dfb..22874eb 100644
--- a/profiles/1.3.2
+++ b/profiles/1.3.2
@@ -1,5 +1,5 @@
VERSION=1.3.2
mkdir -p instances/${INAME}
-[[ ! -L "instances/${INAME}/resources" ]] && rmdir "instances/${INAME}/resources" 2>/dev/null
+[ ! -L "instances/${INAME}/resources" ] && rmdir "instances/${INAME}/resources" 2>/dev/null
ln -sf ../../assets/virtual/legacy "instances/${INAME}/resources"
diff --git a/profiles/1.4.7 b/profiles/1.4.7
index de61f75..59ba9ee 100644
--- a/profiles/1.4.7
+++ b/profiles/1.4.7
@@ -1,5 +1,5 @@
VERSION=1.4.7
mkdir -p instances/${INAME}
-[[ ! -L "instances/${INAME}/resources" ]] && rmdir "instances/${INAME}/resources" 2>/dev/null
+[ ! -L "instances/${INAME}/resources" ] && rmdir "instances/${INAME}/resources" 2>/dev/null
ln -sf ../../assets/virtual/legacy "instances/${INAME}/resources"
diff --git a/profiles/1.5.2 b/profiles/1.5.2
index b51df4f..8c39699 100644
--- a/profiles/1.5.2
+++ b/profiles/1.5.2
@@ -1,5 +1,5 @@
VERSION=1.5.2
mkdir -p instances/${INAME}
-[[ ! -L "instances/${INAME}/resources" ]] && rmdir "instances/${INAME}/resources" 2>/dev/null
+[ ! -L "instances/${INAME}/resources" ] && rmdir "instances/${INAME}/resources" 2>/dev/null
ln -sf ../../assets/virtual/legacy "instances/${INAME}/resources"
diff --git a/profiles/a1.1.2_01 b/profiles/a1.1.2_01
index 29fc500..a83bb36 100644
--- a/profiles/a1.1.2_01
+++ b/profiles/a1.1.2_01
@@ -1,5 +1,5 @@
VERSION=a1.1.2_01
mkdir -p instances/${INAME}
-[[ ! -L "instances/${INAME}/resources" ]] && rmdir "instances/${INAME}/resources" 2>/dev/null
+[ ! -L "instances/${INAME}/resources" ] && rmdir "instances/${INAME}/resources" 2>/dev/null
ln -sf ../../assets/virtual/legacy "instances/${INAME}/resources"
diff --git a/profiles/a1.2.6 b/profiles/a1.2.6
index 65ab2c6..87a18b9 100644
--- a/profiles/a1.2.6
+++ b/profiles/a1.2.6
@@ -1,5 +1,5 @@
VERSION=a1.2.6
mkdir -p instances/${INAME}
-[[ ! -L "instances/${INAME}/resources" ]] && rmdir "instances/${INAME}/resources" 2>/dev/null
+[ ! -L "instances/${INAME}/resources" ] && rmdir "instances/${INAME}/resources" 2>/dev/null
ln -sf ../../assets/virtual/legacy "instances/${INAME}/resources"
diff --git a/profiles/b1.3_01 b/profiles/b1.3_01
index f27593e..8f3bc7c 100644
--- a/profiles/b1.3_01
+++ b/profiles/b1.3_01
@@ -1,5 +1,5 @@
VERSION=b1.3_01
mkdir -p instances/${INAME}
-[[ ! -L "instances/${INAME}/resources" ]] && rmdir "instances/${INAME}/resources" 2>/dev/null
+[ ! -L "instances/${INAME}/resources" ] && rmdir "instances/${INAME}/resources" 2>/dev/null
ln -sf ../../assets/virtual/legacy "instances/${INAME}/resources"
diff --git a/profiles/b1.4 b/profiles/b1.4
index a900d9d..84e9d91 100644
--- a/profiles/b1.4
+++ b/profiles/b1.4
@@ -1,5 +1,5 @@
VERSION=b1.4
mkdir -p instances/${INAME}
-[[ ! -L "instances/${INAME}/resources" ]] && rmdir "instances/${INAME}/resources" 2>/dev/null
+[ ! -L "instances/${INAME}/resources" ] && rmdir "instances/${INAME}/resources" 2>/dev/null
ln -sf ../../assets/virtual/legacy "instances/${INAME}/resources"
diff --git a/profiles/b1.4_01 b/profiles/b1.4_01
index 8fbf29e..1787f9b 100644
--- a/profiles/b1.4_01
+++ b/profiles/b1.4_01
@@ -1,5 +1,5 @@
VERSION=b1.4_01
mkdir -p instances/${INAME}
-[[ ! -L "instances/${INAME}/resources" ]] && rmdir "instances/${INAME}/resources" 2>/dev/null
+[ ! -L "instances/${INAME}/resources" ] && rmdir "instances/${INAME}/resources" 2>/dev/null
ln -sf ../../assets/virtual/legacy "instances/${INAME}/resources"
diff --git a/profiles/b1.5_01 b/profiles/b1.5_01
index a041de0..f0055b6 100644
--- a/profiles/b1.5_01
+++ b/profiles/b1.5_01
@@ -1,5 +1,5 @@
VERSION=b1.5_01
mkdir -p instances/${INAME}
-[[ ! -L "instances/${INAME}/resources" ]] && rmdir "instances/${INAME}/resources" 2>/dev/null
+[ ! -L "instances/${INAME}/resources" ] && rmdir "instances/${INAME}/resources" 2>/dev/null
ln -sf ../../assets/virtual/legacy "instances/${INAME}/resources"
diff --git a/profiles/b1.6.6 b/profiles/b1.6.6
index 15f66eb..321b104 100644
--- a/profiles/b1.6.6
+++ b/profiles/b1.6.6
@@ -1,5 +1,5 @@
VERSION=b1.6.6
mkdir -p instances/${INAME}
-[[ ! -L "instances/${INAME}/resources" ]] && rmdir "instances/${INAME}/resources" 2>/dev/null
+[ ! -L "instances/${INAME}/resources" ] && rmdir "instances/${INAME}/resources" 2>/dev/null
ln -sf ../../assets/virtual/legacy "instances/${INAME}/resources"
diff --git a/profiles/b1.7.3 b/profiles/b1.7.3
index b05257d..56a5fb8 100644
--- a/profiles/b1.7.3
+++ b/profiles/b1.7.3
@@ -1,5 +1,5 @@
VERSION=b1.7.3
mkdir -p instances/${INAME}
-[[ ! -L "instances/${INAME}/resources" ]] && rmdir "instances/${INAME}/resources" 2>/dev/null
+[ ! -L "instances/${INAME}/resources" ] && rmdir "instances/${INAME}/resources" 2>/dev/null
ln -sf ../../assets/virtual/legacy "instances/${INAME}/resources"
diff --git a/profiles/b1.8.1 b/profiles/b1.8.1
index 5e8060b..fd60816 100644
--- a/profiles/b1.8.1
+++ b/profiles/b1.8.1
@@ -1,5 +1,5 @@
VERSION=b1.8.1
mkdir -p instances/${INAME}
-[[ ! -L "instances/${INAME}/resources" ]] && rmdir "instances/${INAME}/resources" 2>/dev/null
+[ ! -L "instances/${INAME}/resources" ] && rmdir "instances/${INAME}/resources" 2>/dev/null
ln -sf ../../assets/virtual/legacy "instances/${INAME}/resources"