make peelz brew a parameter in the config, refactor brew
This commit is contained in:
parent
8c03149e22
commit
55bdd154ba
97
builder
97
builder
@ -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
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user