library manifest fixes, cleanup
This commit is contained in:
parent
4cbbde9894
commit
7801686d03
29
README.md
29
README.md
|
@ -1,30 +1,35 @@
|
||||||
# mcl
|
# mcl
|
||||||
|
|
||||||
minecraft launcher for linux and maybe macos
|
minecraft launcher for linux
|
||||||
|
|
||||||
## what does it do
|
## what does it do
|
||||||
|
|
||||||
- download many versions
|
- download all versions (works with tested modded versions)
|
||||||
- download assets
|
- run versions from downloaded json/jar pairs
|
||||||
- download libraries
|
- download assets and libraries
|
||||||
- set up natives
|
- set up natives
|
||||||
- select the correct libraries for the version
|
- select the correct libraries for the version (may only work on linux)
|
||||||
- get an authentication token (microsoft auth only)
|
- get an authentication token (microsoft auth only, i no longer have a mojang account)
|
||||||
- instances
|
- instance support
|
||||||
|
- multiple account support
|
||||||
- launch the game
|
- launch the game
|
||||||
|
|
||||||
## what does it *not* do
|
## what does it *not* do
|
||||||
|
|
||||||
- optifine, forge, etc
|
- import minecraft launcher profiles - you will have to manually create profiles for optifine, forge, etc after installation
|
||||||
- support external natives (openbsd, freebsd, etc)
|
- support external natives (openbsd, freebsd, etc) with the exception of aarch64 linux
|
||||||
- windows support. i will not be adding this
|
|
||||||
|
## what will it *never* do
|
||||||
|
- support windows. it is not a very command line centric operating system
|
||||||
|
|
||||||
## why not use the regular launcher
|
## why not use the regular launcher
|
||||||
|
|
||||||
- closed source
|
- closed source
|
||||||
- really buggy for some reason
|
- really buggy for some reason
|
||||||
- i would call it bloated but honestly this is probably slower
|
- much slower in practice
|
||||||
|
- it is more fun to write one
|
||||||
|
|
||||||
## why not a third party launcher
|
## why not a third party launcher
|
||||||
|
|
||||||
theyre all too complex and weird and have Discourse
|
- too complex (heavy guis and such)
|
||||||
|
- they all have Discourse
|
||||||
|
|
87
main
87
main
|
@ -1,11 +1,16 @@
|
||||||
[ -z "$EDITOR" ] && echo '$EDITOR not set' && exit
|
[ -z "$EDITOR" ] && echo '$EDITOR not set' && exit
|
||||||
BROWSER=firefox
|
BROWSER=firefox
|
||||||
|
|
||||||
# im not multimc who cares if you dont rename this
|
# rename this if youre making a fork. or dont. im not multimc
|
||||||
PNAME=mcl
|
PNAME=mcl
|
||||||
MDIR=~/.$PNAME
|
MDIR=~/.$PNAME
|
||||||
CACHE=/tmp/$PNAME\cache
|
CACHE=/tmp/$PNAME\cache
|
||||||
PLAT=linux
|
|
||||||
|
|
||||||
|
PLAT=''
|
||||||
|
[ `uname -s` = Linux ] && PLAT=linux
|
||||||
|
[ `uname -s` = Darwin ] && PLAT=osx
|
||||||
|
#TODO other unixlikes, figure out m1 support
|
||||||
|
|
||||||
login() {
|
login() {
|
||||||
$1 'https://login.microsoftonline.com/consumers/oauth2/v2.0/authorize?client_id=ed8c593c-4c7f-4484-8dc4-d2ce60bf62a4&response_type=code&response_mode=query&scope=XboxLive.signin&redirect_uri=https%3A%2F%2Fmothcompute.lilylenora.net%2Fmcl_auth.php'
|
$1 'https://login.microsoftonline.com/consumers/oauth2/v2.0/authorize?client_id=ed8c593c-4c7f-4484-8dc4-d2ce60bf62a4&response_type=code&response_mode=query&scope=XboxLive.signin&redirect_uri=https%3A%2F%2Fmothcompute.lilylenora.net%2Fmcl_auth.php'
|
||||||
|
@ -21,6 +26,8 @@ login() {
|
||||||
[ $(date -d "$(jq -r .exp.mc "$MDIR/account$2")" +%s) -le $(date +%s) ] && if [ $(date -d "$(jq -r .exp.xb "$MDIR/account$2")" +%s) -le $(date +%s) ]; then
|
[ $(date -d "$(jq -r .exp.mc "$MDIR/account$2")" +%s) -le $(date +%s) ] && if [ $(date -d "$(jq -r .exp.xb "$MDIR/account$2")" +%s) -le $(date +%s) ]; then
|
||||||
login "$BROWSER" "$2"
|
login "$BROWSER" "$2"
|
||||||
else
|
else
|
||||||
|
jq -r .tok.xb "$MDIR/account$2"
|
||||||
|
[ $? = 0 ] && login "$BROWSER" "$2"
|
||||||
curl 'https://mothcompute.lilylenora.net/mcl_auth.php?xb='$(jq -r .tok.xb "$MDIR/account$2")'&u='$(jq -r .xb_usr "$MDIR/account$2")'&e='$(jq -r .exp.xb "$MDIR/account$2") > "$MDIR/swp.account$2"
|
curl 'https://mothcompute.lilylenora.net/mcl_auth.php?xb='$(jq -r .tok.xb "$MDIR/account$2")'&u='$(jq -r .xb_usr "$MDIR/account$2")'&e='$(jq -r .exp.xb "$MDIR/account$2") > "$MDIR/swp.account$2"
|
||||||
mv "$MDIR/swp.account$2" "$MDIR/account$2"
|
mv "$MDIR/swp.account$2" "$MDIR/account$2"
|
||||||
fi
|
fi
|
||||||
|
@ -50,7 +57,7 @@ JAVA_LATEST=/bin/java
|
||||||
game_directory=~/mclinstance
|
game_directory=~/mclinstance
|
||||||
VERSION="$(jq -r .latest.$CHANNEL $CACHE/version_manifest.json)"
|
VERSION="$(jq -r .latest.$CHANNEL $CACHE/version_manifest.json)"
|
||||||
jvm=""
|
jvm=""
|
||||||
VIRTP=""
|
export VIRTP=""
|
||||||
|
|
||||||
[ ! -z "$1" ] && . "$MDIR/profile/$1"
|
[ ! -z "$1" ] && . "$MDIR/profile/$1"
|
||||||
mkdir -p "$game_directory"
|
mkdir -p "$game_directory"
|
||||||
|
@ -59,10 +66,8 @@ mkdir -p "$game_directory"
|
||||||
|
|
||||||
echo ver $VERSION
|
echo ver $VERSION
|
||||||
|
|
||||||
# create directory structure for version if missing
|
|
||||||
mkdir -p $MDIR/versions/$VERSION
|
mkdir -p $MDIR/versions/$VERSION
|
||||||
|
|
||||||
# get json file for version
|
|
||||||
VERSION_MANIFEST=$(jq ".versions[] | select(.id==\"$VERSION\")" $CACHE/version_manifest.json | jq -r .url)
|
VERSION_MANIFEST=$(jq ".versions[] | select(.id==\"$VERSION\")" $CACHE/version_manifest.json | jq -r .url)
|
||||||
[ ! -z "$VERSION_MANIFEST" ] && [ ! -f "$MDIR/versions/$VERSION/$(basename $VERSION_MANIFEST)" ] && wget $VERSION_MANIFEST -qO "$MDIR/versions/$VERSION/$(basename $VERSION_MANIFEST)"
|
[ ! -z "$VERSION_MANIFEST" ] && [ ! -f "$MDIR/versions/$VERSION/$(basename $VERSION_MANIFEST)" ] && wget $VERSION_MANIFEST -qO "$MDIR/versions/$VERSION/$(basename $VERSION_MANIFEST)"
|
||||||
|
|
||||||
|
@ -78,9 +83,11 @@ echo json $VERJSON
|
||||||
VERSION_ASSETS="$(jq -r .assetIndex.url $VERJSON)"
|
VERSION_ASSETS="$(jq -r .assetIndex.url $VERJSON)"
|
||||||
[ ! -f "$MDIR/assets/indexes/$(basename $VERSION_ASSETS)" ] && wget $VERSION_ASSETS -qO "$MDIR/assets/indexes/$(basename $VERSION_ASSETS)"
|
[ ! -f "$MDIR/assets/indexes/$(basename $VERSION_ASSETS)" ] && wget $VERSION_ASSETS -qO "$MDIR/assets/indexes/$(basename $VERSION_ASSETS)"
|
||||||
|
|
||||||
|
export rsrc=''
|
||||||
|
|
||||||
# download objects TODO unwrapped filename
|
# download objects TODO unwrapped filename
|
||||||
if [ "$(jq .map_to_resources $MDIR/assets/indexes/$(basename $VERSION_ASSETS))" = true -o "$(jq .virtual $MDIR/assets/indexes/$(basename $VERSION_ASSETS))" = true ]; then
|
if [ "$(jq .map_to_resources $MDIR/assets/indexes/$(basename $VERSION_ASSETS))" = true -o "$(jq .virtual $MDIR/assets/indexes/$(basename $VERSION_ASSETS))" = true ]; then
|
||||||
rsrc=1
|
export rsrc=1
|
||||||
[ "$(jq .virtual $MDIR/assets/indexes/$(basename $VERSION_ASSETS))" = true ] && VIRTP=virtual/
|
[ "$(jq .virtual $MDIR/assets/indexes/$(basename $VERSION_ASSETS))" = true ] && VIRTP=virtual/
|
||||||
OLDIFS="$IFS"
|
OLDIFS="$IFS"
|
||||||
IFS=$'\n'
|
IFS=$'\n'
|
||||||
|
@ -104,84 +111,108 @@ echo object download complete
|
||||||
|
|
||||||
export classpath="$MDIR/versions/$VERSION/$VERSION.jar"
|
export classpath="$MDIR/versions/$VERSION/$VERSION.jar"
|
||||||
|
|
||||||
# get non-native libs
|
shortdl() {
|
||||||
|
echo shortdl \"$1\" \"$2\" \"$3\"
|
||||||
|
|
||||||
|
CPATH="`echo $1 | sed 's/\./\//g'`/$2/$3/$2-$3"
|
||||||
|
FCPATH="$MDIR/libraries/$CPATH.jar"
|
||||||
|
mkdir -p "$(dirname $FCPATH)"
|
||||||
|
|
||||||
|
[ ! -f "$FCPATH" ] && wget "https://libraries.minecraft.net/$CPATH.jar" -O "$FCPATH"
|
||||||
|
classpath="$classpath:$FCPATH"
|
||||||
|
[ ! -z "$4" ] && eval wget "https://libraries.minecraft.net/$CPATH-$4.jar" -O "$CPATH-$4.jar" && unzip "$CPATH-$4.jar" -d "$CACHE/natives/$VERSION"
|
||||||
|
}
|
||||||
|
|
||||||
fetchlib() {
|
fetchlib() {
|
||||||
LIBJSON="$1"
|
LIBJSON="$1"
|
||||||
for LIBINDEX in `seq 0 $(($(jq '.libraries|length' "$LIBJSON")-1))`; do
|
for LIBINDEX in `seq 0 $(($(jq '.libraries|length' "$LIBJSON")-1))`; do
|
||||||
echo lib $LIBINDEX
|
echo -n "lib $LIBINDEX "
|
||||||
LIBPATH="$MDIR/libraries/"`jq -r ".libraries[$LIBINDEX].downloads.artifact.path" "$LIBJSON"`
|
LIBPATH="$MDIR/libraries/"`jq -r ".libraries[$LIBINDEX].downloads.artifact.path" "$LIBJSON"`
|
||||||
LIBURL=`jq -r ".libraries[$LIBINDEX].downloads.artifact.url" "$LIBJSON"`
|
LIBURL=`jq -r ".libraries[$LIBINDEX].downloads.artifact.url" "$LIBJSON"`
|
||||||
LIBNAME=`jq -r ".libraries[$LIBINDEX].name" "$LIBJSON"`
|
LIBNAME=`jq -r ".libraries[$LIBINDEX].name" "$LIBJSON"`
|
||||||
|
|
||||||
|
ALLOW=1
|
||||||
|
PALLOW=1
|
||||||
|
|
||||||
|
if [ ! "`jq -r \".libraries[$LIBINDEX].rules\" \"$LIBJSON\"`" = null ]; then
|
||||||
|
ALLOW=0
|
||||||
|
for RULEINDEX in `seq 0 $(($(jq '.libraries['$LIBINDEX'].rules|length' "$LIBJSON")-1))`; do
|
||||||
|
action=`jq -r ".libraries[$LIBINDEX].rules[$RULEINDEX].action" "$LIBJSON"`
|
||||||
|
os=`jq -r ".libraries[$LIBINDEX].rules[$RULEINDEX].os.name" "$LIBJSON"`
|
||||||
|
[ "$os" = $PLAT -a "$action" = disallow ] && ALLOW=0 && PALLOW=0
|
||||||
|
[ "$os" = $PLAT -a "$action" = allow ] && ALLOW=1
|
||||||
|
[ "$os" = null -a "$action" = allow -a "$PALLOW" = 1 ] && ALLOW=1
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "$ALLOW $LIBNAME"
|
||||||
|
if [ $ALLOW = 1 ]; then
|
||||||
mkdir -p "$(dirname $LIBPATH)"
|
mkdir -p "$(dirname $LIBPATH)"
|
||||||
[ ! -f "$LIBPATH" ] && echo $LIBURL '=>' "$LIBPATH" && wget $LIBURL -qO "$LIBPATH"
|
[ ! -f "$LIBPATH" ] && [ ! "$LIBURL" = null ] && echo $LIBURL '=>' "$LIBPATH" && wget $LIBURL -qO "$LIBPATH"
|
||||||
QNATIVE=`jq -r .libraries[$LIBINDEX].downloads.classifiers."\"natives-$PLAT\"" "$LIBJSON"`
|
QNATIVE=`jq -r .libraries[$LIBINDEX].downloads.classifiers."\"natives-$PLAT\"" "$LIBJSON"`
|
||||||
# TODO create natives for game
|
# TODO linux centric
|
||||||
[ ! "$QNATIVE" = "null" ] &&
|
[ ! "$QNATIVE" = "null" ] &&
|
||||||
echo HAS NATIVE &&
|
echo HAS NATIVE &&
|
||||||
LIBPATH="$MDIR/libs/$VERSION/"`jq -r .libraries[$LIBINDEX].downloads.classifiers."\"natives-$PLAT\"".path "$LIBJSON"` &&
|
LIBPATH="$MDIR/libraries/"`jq -r .libraries[$LIBINDEX].downloads.classifiers."\"natives-$PLAT\"".path "$LIBJSON"` &&
|
||||||
LIBURL=`jq -r .libraries[$LIBINDEX].downloads.classifiers.'"natives-linux"'.url "$LIBJSON"` &&
|
LIBURL=`jq -r .libraries[$LIBINDEX].downloads.classifiers.'"natives-linux"'.url "$LIBJSON"` &&
|
||||||
mkdir -p "$(dirname $LIBPATH)" &&
|
mkdir -p "$(dirname $LIBPATH)" &&
|
||||||
echo $LIBURL '=>' "$LIBPATH" &&
|
echo $LIBURL '=>' "$LIBPATH" &&
|
||||||
[ ! -f "$LIBPATH" ] && wget $LIBURL -qO "$LIBPATH" &&
|
[ ! -f "$LIBPATH" ] && wget $LIBURL -qO "$LIBPATH" &&
|
||||||
unzip -o "$LIBPATH" -d $CACHE/natives/$VERSION
|
unzip -o "$LIBPATH" -d "$CACHE/natives/$VERSION"
|
||||||
|
|
||||||
if [ ! "$LIBURL" = null ]; then
|
if [ ! "$LIBURL" = null ]; then
|
||||||
classpath="$classpath:$LIBPATH"
|
classpath="$classpath:$LIBPATH"
|
||||||
else
|
else
|
||||||
classpath="$classpath:$(find `echo $MDIR/libraries/$LIBNAME | sed 's/:/\//g'` | grep -E '\.jar$')"
|
QNATIVE=''
|
||||||
|
[ ! "`jq -r \".libraries[$LIBINDEX].natives\" \"$LIBJSON\"`" = null ] && QNATIVE=`jq -r ".libraries[$LIBINDEX].natives.$PLAT" "$LIBJSON"`
|
||||||
|
shortdl `echo $LIBNAME | sed 's/:/ /g'` $QNATIVE
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
[ ! -z "$IVER" ] && fetchlib "$MDIR/versions/$IVER/$IVER.json"
|
[ ! "$IVER" = null ] && fetchlib "$MDIR/versions/$IVER/$IVER.json"
|
||||||
fetchlib "$MDIR/versions/$VERSION/$VERSION.json"
|
fetchlib "$MDIR/versions/$VERSION/$VERSION.json"
|
||||||
|
|
||||||
# all the libs in the classpath, minus the version jar
|
|
||||||
# find /home/NAME/.minecraft/libraries/ | grep jar | sed 's/^\/home\/NAME\/.minecraft\/libraries\///g' | grep -v natives | wc -l
|
|
||||||
|
|
||||||
library_directory="$MDIR/libraries"
|
library_directory="$MDIR/libraries"
|
||||||
classpath_separator=":"
|
classpath_separator=":"
|
||||||
natives_directory=$CACHE/natives/$VERSION
|
natives_directory=$CACHE/natives/$VERSION
|
||||||
mkdir -p $natives_directory
|
mkdir -p $natives_directory
|
||||||
#classpath=`find $CLASSPT | grep -v "natives-" | grep -E '.jar$' | xargs | sed 's/ /:/g'`:"$MDIR/versions/$VERSION/$VERSION.jar"
|
|
||||||
version_name=$VERSION
|
version_name=$VERSION
|
||||||
assets_root="$MDIR/assets"
|
assets_root="$MDIR/assets"
|
||||||
game_assets="$MDIR/assets"
|
game_assets="$MDIR/assets"
|
||||||
[ "$rsrc" = 1 ] && game_assets="$MDIR/resources/$VIRTP"
|
[ "$rsrc" = 1 ] && game_assets="$MDIR/resources/$VIRTP"
|
||||||
|
[ $(date -d $(jq -r ".releaseTime" $VERJSON) +%s) -lt 1382454245 ] && game_assets="$MDIR/resources/$VIRTP"
|
||||||
#game_assets="$assets_root/virtual/pre-1.6" ???
|
#game_assets="$assets_root/virtual/pre-1.6" ???
|
||||||
assets_index_name=`jq -r .assetIndex.id "$VERJSON"`
|
assets_index_name=`jq -r .assetIndex.id "$VERJSON"`
|
||||||
version_type=`jq -r .type "$VERJSON"`
|
version_type=`jq -r .type "$VERJSON"`
|
||||||
|
|
||||||
# TODO natives
|
|
||||||
mkdir -p $CACHE/natives/$VERSION $game_directory
|
mkdir -p $CACHE/natives/$VERSION $game_directory
|
||||||
for i in `find "$MDIR/libs/$VERSION" | grep natives-$PLAT`; do unzip -o $i -d $CACHE/natives/$VERSION; done
|
for i in `find "$MDIR/libs/$VERSION" | grep natives-$PLAT`; do unzip -o $i -d $CACHE/natives/$VERSION; done
|
||||||
|
|
||||||
jvm="-Xss1M -XX:+UnlockExperimentalVMOptions -XX:+UseG1GC -XX:G1NewSizePercent=20 -XX:G1ReservePercent=20 -XX:MaxGCPauseMillis=50 -XX:G1HeapRegionSize=32M $jvm "`jq -r .arguments.jvm "$MDIR/versions/$VERSION/$VERSION.json" --indent 1 | grep -E '^ "' | sed 's/,$//' | xargs`
|
jvm="-Xss1M -XX:+UnlockExperimentalVMOptions -XX:+UseG1GC -XX:G1NewSizePercent=20 -XX:G1ReservePercent=20 -XX:MaxGCPauseMillis=50 -XX:G1HeapRegionSize=32M $jvm "`jq -r .arguments.jvm "$MDIR/versions/$VERSION/$VERSION.json" --indent 1 | grep -E '^ "' | sed 's/,$//' | xargs`
|
||||||
[ ! -z "$IVER" ] && jvm="$jvm "`jq -r .arguments.jvm "$MDIR/versions/$IVER/$IVER.json" --indent 1 | grep -E '^ "' | sed 's/,$//' | xargs`
|
[ ! "$IVER" = null ] && jvm="$jvm "`jq -r .arguments.jvm "$MDIR/versions/$IVER/$IVER.json" --indent 1 | grep -E '^ "' | sed 's/,$//' | xargs`
|
||||||
|
|
||||||
# TODO determine correct java version for old release versions
|
# TODO determine correct java version for old release versions
|
||||||
JAVAV=$JAVA_LATEST
|
JAVAV=$JAVA_LATEST
|
||||||
|
|
||||||
|
GAMEARGS=`jq -r .arguments.game "$MDIR/versions/$VERSION/$VERSION.json" --indent 1 | grep -E '^ "' | sed 's/,$//' | xargs`
|
||||||
|
[ ! "$IVER" = null ] && GAMEARGS="$GAMEARGS "`jq -r .arguments.game "$MDIR/versions/$IVER/$IVER.json" --indent 1 | grep -E '^ "' | sed 's/,$//' | xargs`
|
||||||
|
|
||||||
setleg() {
|
setleg() {
|
||||||
echo legacy version detected
|
echo legacy version detected
|
||||||
JAVAV=$JAVA8
|
JAVAV=$JAVA8
|
||||||
#legacygame="--tweakClass net.minecraft.launchwrapper.AlphaVanillaTweaker --gameDir ${game_directory} --assetsDir ${assets_root}"
|
jvm="-Djava.library.path=${natives_directory}:$ -cp $classpath $jvm"
|
||||||
jvm="-Djava.library.path=${natives_directory} -cp $classpath $jvm"
|
GAMEARGS=''
|
||||||
}
|
}
|
||||||
|
|
||||||
[ "$version_type" = "old_alpha" -o "$version_type" = "old_beta" -o "$(echo $VERSION | sed 's/^[^\.]*\.//;s/\.[^\.]*$//')" -lt '13' ] && setleg
|
[ $(date -d $(jq -r ".releaseTime" $VERJSON) +%s) -lt 1505723986 ] && setleg
|
||||||
#TODO optifine
|
|
||||||
#[ $? = 2 ] && echo $VERSION | grep -v w && setleg
|
|
||||||
|
|
||||||
dbrun() {
|
dbrun() {
|
||||||
echo $@ | sed 's/:/\n/g'
|
echo $@ | sed 's/:/\n/g'
|
||||||
$@
|
$@
|
||||||
}
|
}
|
||||||
|
|
||||||
GAMEARGS=`jq -r .arguments.game "$MDIR/versions/$VERSION/$VERSION.json" --indent 1 | grep -E '^ "' | sed 's/,$//' | xargs`
|
|
||||||
[ ! -z "$IVER" ] && GAMEARGS="$GAMEARGS "`jq -r .arguments.game "$MDIR/versions/$IVER/$IVER.json" --indent 1 | grep -E '^ "' | sed 's/,$//' | xargs`
|
|
||||||
|
|
||||||
cd $MDIR
|
cd $MDIR
|
||||||
eval dbrun $JAVAV \
|
eval dbrun $JAVAV \
|
||||||
$jvm \
|
$jvm \
|
||||||
|
|
Loading…
Reference in New Issue