1
0

make peelz brew a parameter in the config, refactor brew

This commit is contained in:
GenZmeY 2022-09-01 12:25:37 +03:00
parent 8c03149e22
commit 55bdd154ba

97
builder
View File

@ -91,7 +91,6 @@ KFEditorConfBackup="$KFEditorConf.backup"
ArgInit="false" ArgInit="false"
ArgCompile="false" ArgCompile="false"
ArgBrew="false" ArgBrew="false"
ArgBrewManual="false"
ArgUpload="false" ArgUpload="false"
ArgTest="false" ArgTest="false"
ArgVersion="false" ArgVersion="false"
@ -204,7 +203,6 @@ ${BLD}Available options:${DEF}
-i, --init generate $(basename "$MutBuilderConfig") and $(basename "$MutPubContent") -i, --init generate $(basename "$MutBuilderConfig") and $(basename "$MutPubContent")
-c, --compile compile package(s) -c, --compile compile package(s)
-b, --brew compress *.upk and place inside *.u -b, --brew compress *.upk and place inside *.u
-bm, --brew-manual the same (almost) as above, but with patched kfeditor by @notpeelz
-u, --upload upload package(s) to the Steam Workshop -u, --upload upload package(s) to the Steam Workshop
-t, --test run local single player test -t, --test run local single player test
-f, --force overwrites existing files when used with --init -f, --force overwrites existing files when used with --init
@ -216,8 +214,8 @@ ${BLD}Available options:${DEF}
-h, --help show this help -h, --help show this help
${BLD}Short options can be combined, examples:${DEF} ${BLD}Short options can be combined, examples:${DEF}
-if recreate build.cfg and PublicationContent, replace old ones
-cbu compile, brew, upload -cbu compile, brew, upload
-cbmt compile, brew_manual, run_test
-cbhe compile and brew without closing kf2editor -cbhe compile and brew without closing kf2editor
etc... etc...
EOF EOF
@ -340,6 +338,16 @@ StripSource="True"
PackageBuildOrder="$PackageList" PackageBuildOrder="$PackageList"
### Brew parameters ###
# Packages you want to brew using @peelz's patched KFEditor.
# Useful for cases where regular brew doesn't put *.upk inside the package.
# Specify them with a space as a separator,
# The order doesn't matter
PackagePeelzBrew=""
### Steam Workshop upload parameters ### ### Steam Workshop upload parameters ###
# Mutators that will be uploaded to the workshop # Mutators that will be uploaded to the workshop
@ -686,9 +694,9 @@ function publish_common ()
fi fi
} }
function brewed () function brewed () # $1: Wait for packages
{ {
for Package in $PackageUpload for Package in $1
do do
if ! test -f "$KFPublishBrewedPC/$Package.u"; then if ! test -f "$KFPublishBrewedPC/$Package.u"; then
return 1 return 1
@ -705,12 +713,11 @@ function brew_cleanup ()
find "$MutSource/$Package" -type f -name '*.upk' -printf "%f\n" | xargs -I{} find "$KFPublishBrewedPC" -type f -name {} -delete find "$MutSource/$Package" -type f -name '*.upk' -printf "%f\n" | xargs -I{} find "$KFPublishBrewedPC" -type f -name {} -delete
fi fi
done done
rm -f "$KFPublishBrewedPC"/*.tmp
} }
function brew () function brew ()
{ {
local PackageBrew=""
local PID="" local PID=""
msg "brewing" msg "brewing"
@ -721,71 +728,66 @@ function brew ()
die "You must compile packages before brewing. Use --compile option for this." 2 die "You must compile packages before brewing. Use --compile option for this." 2
fi fi
if [[ -z "$PackagePeelzBrew" ]]; then
PackageBrew="$PackageBuildOrder"
else
for Package in $PackageBuildOrder
do
if ! echo "$PackagePeelzBrew" | grep -Pq "(^|\s+)$Package(\s+|$)"; then
PackageBrew="$Package "
fi
done
fi
rm -rf "$KFPublish" rm -rf "$KFPublish"
mkdir -p "$KFPublishBrewedPC" mkdir -p "$KFPublishBrewedPC"
if is_true "$ArgHoldEditor"; then if is_true "$ArgHoldEditor"; then
CMD //C "cd /D $(cygpath -w "$KFWin64") && $(basename "$KFEditor") brewcontent -platform=PC $PackageUpload -useunpublished" CMD //C "cd /D $(cygpath -w "$KFWin64") && $(basename "$KFEditor") brewcontent -platform=PC $PackageBrew -useunpublished"
if ! brewed; then if ! brewed "$PackageBrew"; then
brew_cleanup brew_cleanup
die "brewing failed" die "brewing failed"
fi fi
msg "${GRN}successfully brewed${DEF}"
else else
CMD //C "cd /D $(cygpath -w "$KFWin64") && $(basename "$KFEditor") brewcontent -platform=PC $PackageUpload -useunpublished" & CMD //C "cd /D $(cygpath -w "$KFWin64") && $(basename "$KFEditor") brewcontent -platform=PC $PackageBrew -useunpublished" &
PID="$!" PID="$!"
while ps -p "$PID" &> /dev/null while ps -p "$PID" &> /dev/null
do do
if brewed; then if brewed "$PackageBrew"; then
kill "$PID" kill "$PID"
msg "${GRN}successfully brewed${DEF}"
break break
fi fi
sleep 1 sleep 1
done done
if ! brewed; then if ! brewed "$PackageBrew"; then
brew_cleanup brew_cleanup
die "brewing failed" die "brewing failed"
fi fi
fi fi
publish_common if [[ -n "$PackagePeelzBrew" ]]; then
brew_cleanup msg "peelz brewing"
find "$KFPublish" -type d -empty -delete if ! [[ -x "$KFEditorPatcher" ]]; then
} get_latest_kfeditor_patcher "$KFEditorPatcher"
fi
function brew_manual () msg "patching $(basename "$KFEditor")"
{ CMD //C "cd /D $(cygpath -w "$KFWin64") && $(basename "$KFEditorPatcher")"
msg "manual brewing" msg "${GRN}successfully patched${DEF}"
read_settings for Package in $PackagePeelzBrew
do
if ! compiled; then merge_packages "$Package"
die "You must compile packages before brewing. Use --compile option for this." 2 mv "$KFWin64/$Package.u" "$KFPublishBrewedPC"
find "$MutSource/$Package" -type f -name '*.upk' -printf "%f\n" | xargs -I{} find "$KFPublishBrewedPC" -type f -name {} -delete
done
fi fi
rm -rf "$KFPublish"
mkdir -p "$KFPublishBrewedPC"
if ! [[ -x "$KFEditorPatcher" ]]; then
get_latest_kfeditor_patcher "$KFEditorPatcher"
fi
msg "patching $(basename "$KFEditor")"
CMD //C "cd /D $(cygpath -w "$KFWin64") && $(basename "$KFEditorPatcher")"
msg "${GRN}successfully patched${DEF}"
for Package in $PackageUpload
do
merge_packages "$Package"
mv "$KFWin64/$Package.u" "$KFPublishBrewedPC"
done
msg "${GRN}successfully brewed${DEF}" msg "${GRN}successfully brewed${DEF}"
rm -f "$KFPublishBrewedPC"/*.tmp
publish_common publish_common
find "$KFPublish" -type d -empty -delete find "$KFPublish" -type d -empty -delete
@ -820,7 +822,9 @@ function upload ()
die "You must compile packages before uploading. Use --compile option for this." 2 die "You must compile packages before uploading. Use --compile option for this." 2
fi fi
if ! [[ -d "$KFPublish" ]]; then if [[ -d "$KFPublish" ]]; then
brew_cleanup
else
publish_unpublished publish_unpublished
fi fi
@ -874,7 +878,7 @@ function run_test ()
read_settings read_settings
if brewed; then if brewed "$PackageBuildOrder"; then
msg "run test (brewed)" msg "run test (brewed)"
else else
UseUnpublished="-useunpublished" UseUnpublished="-useunpublished"
@ -894,7 +898,6 @@ function parse_combined_params () # $1: Combined short parameters
do do
if [[ "$Position" -ge "$Length" ]]; then break; fi if [[ "$Position" -ge "$Length" ]]; then break; fi
case "${Param:$Position:2}" in case "${Param:$Position:2}" in
bm ) ((Position+=2)); ArgBrewManual="true" ;;
he ) ((Position+=2)); ArgHoldEditor="true" ;; he ) ((Position+=2)); ArgHoldEditor="true" ;;
nc ) ((Position+=2)); ArgNoColors="true" ;; nc ) ((Position+=2)); ArgNoColors="true" ;;
esac esac
@ -926,7 +929,6 @@ function parse_params () # $@: Args
-i | --init ) ArgInit="true" ;; -i | --init ) ArgInit="true" ;;
-c | --compile ) ArgCompile="true" ;; -c | --compile ) ArgCompile="true" ;;
-b | --brew ) ArgBrew="true" ;; -b | --brew ) ArgBrew="true" ;;
-bm | --brew-manual ) ArgBrewManual="true" ;;
-u | --upload ) ArgUpload="true" ;; -u | --upload ) ArgUpload="true" ;;
-t | --test ) ArgTest="true" ;; -t | --test ) ArgTest="true" ;;
-d | --debug ) ArgDebug="true" ;; -d | --debug ) ArgDebug="true" ;;
@ -964,7 +966,6 @@ function main ()
if is_true "$ArgInit"; then init; fi if is_true "$ArgInit"; then init; fi
if is_true "$ArgCompile"; then compile; fi if is_true "$ArgCompile"; then compile; fi
if is_true "$ArgBrew"; then brew; fi if is_true "$ArgBrew"; then brew; fi
if is_true "$ArgBrewManual"; then brew_manual; fi
if is_true "$ArgUpload"; then upload; fi if is_true "$ArgUpload"; then upload; fi
if is_true "$ArgTest"; then run_test; fi if is_true "$ArgTest"; then run_test; fi