1
0
Fork 0
mirror of https://github.com/zeldaret/oot.git synced 2024-12-26 14:46:16 +00:00

Improve actorfixer.py (2nd round) and rename to namefixer.py (#942)

* Merge animfixer and mathfixer into actorfixer

* Allow "custom behavior" for `wordReplace` entries

* Rename `actorfixer.py` to `namefixer.py`
This commit is contained in:
Dragorn421 2021-09-07 21:29:40 +02:00 committed by GitHub
parent 9c7d3688ac
commit b12dd3d980
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 68 additions and 146 deletions

View file

@ -1,76 +0,0 @@
#!/usr/bin/env python3
import os
import argparse
animdict ={
"SkelAnime_FrameUpdateMatrix":"SkelAnime_Update",
"SkelAnime_ChangeAnimTransitionRepeat":"Animation_MorphToLoop",
"SkelAnime_ChangeAnimDefaultRepeat":"Animation_PlayLoop",
"SkelAnime_ChangeAnimPlaybackRepeat":"Animation_PlayLoopSetSpeed",
"SkelAnime_ChangeAnimTransitionStop":"Animation_MorphToPlayOnce",
"SkelAnime_ChangeAnimDefaultStop":"Animation_PlayOnce",
"SkelAnime_ChangeAnimPlaybackStop":"Animation_PlayOnceSetSpeed",
"SkelAnime_ChangeAnimImpl":"Animation_ChangeImpl",
"SkelAnime_ChangeAnim":"Animation_Change",
"SkelAnime_GetFrameCount":"Animation_GetLastFrame",
"func_800A56C8":"Animation_OnFrame",
"skelAnime.animCurrentFrame":"skelAnime.curFrame",
"skelAnime.animPlaybackSpeed":"skelAnime.playSpeed",
"skelAnime.initialFrame":"skelAnime.startFrame",
"skelAnime.animFrameCount":"skelAnime.endFrame",
"skelAnime.totalFrames":"skelAnime.animLength",
"skelAnime.limbDrawTbl":"skelAnime.jointTable",
"skelAnime.transitionDrawTbl":"skelAnime.morphTable",
"skelAnime.transCurrentFrame":"skelAnime.morphWeight",
"skelAnime.transitionStep":"skelAnime.morphRate",
"skelAnime.flags":"skelAnime.moveFlags",
"skelAnime.prevFrameRot":"skelAnime.prevRot",
"skelAnime.prevFramePos":"skelAnime.prevTransl",
"skelAnime.unk_3E":"skelAnime.baseTransl",
"skelAnime.unk_03":"skelAnime.taper"
}
def replace_anim(file):
with open(file,'r',encoding = 'utf-8') as infile:
srcdata = infile.read()
funcs = list(animdict.keys())
fixes = 0
for func in funcs:
newfunc = animdict.get(func)
if(newfunc is None):
print("How did this happen?")
return -1
if(func in srcdata):
fixes += 1
srcdata = srcdata.replace(func, newfunc)
if(fixes > 0):
print('Changed', fixes,'entr' + ('y' if fixes == 1 else 'ies') + ' in',file)
with open(file, 'w', encoding = 'utf-8', newline = '\n') as outfile:
outfile.write(srcdata)
return 1
def replace_anim_all(repo):
for subdir, dirs, files in os.walk(repo + os.sep + 'src'):
for filename in files:
if(filename.endswith('.c')):
file = subdir + os.sep + filename
replace_anim(file)
for subdir, dirs, files in os.walk(repo + os.sep + 'asm' + os.sep + 'non_matchings'):
for filename in files:
if(filename.endswith('.s')):
file = subdir + os.sep + filename
replace_anim(file)
return 1
parser = argparse.ArgumentParser(description='Update to the new animation names')
parser.add_argument('file', help="source file to be processed. use '.' to process the whole repo", default = None)
if __name__ == "__main__":
args = parser.parse_args()
if(args.file is '.'):
replace_anim_all(os.curdir)
else:
replace_anim(args.file)

View file

@ -1,69 +0,0 @@
#!/usr/bin/env python3
import os
import argparse
mathdict ={"Math_Rand_":"Rand_",
"func_800CA540(":"Math_FactorialF(",
"func_800CA63C(":"Math_Factorial(",
"func_800CA6FC(":"Math_PowF(",
"func_800CA720(":"Math_SinF(",
"func_800CA774(":"Math_CosF(",
"Math_atan2f(":"Math_FAtan2F(",
"atan2f(":"Math_Atan2F(",
"atan2s(":"Math_Atan2S(",
"Math_Coss(":"Math_CosS(",
"Math_Sins(":"Math_SinS(",
"Math_ApproxUpdateScaledS(":"Math_ScaledStepToS(",
"Math_ApproxS(":"Math_StepToS(",
"Math_ApproxF(":"Math_StepToF(",
"func_80077A90(":"Math_StepUntilAngleS(",
"func_80077AF8(":"Math_StepUntilS(",
"func_80077B58(":"Math_StepToAngleS(",
"func_80077C1C(":"Math_StepUntilF(",
"func_80077C6C(":"Math_AsymStepToF(",
"Math_SmoothScaleMaxMinF(":"Math_SmoothStepToF(",
"Math_SmoothScaleMaxF(":"Math_ApproachF(",
"Math_SmoothDownscaleMaxF(":"Math_ApproachZeroF(",
"func_800784D8(":"Math_SmoothStepToDegF(",
"Math_SmoothScaleMaxMinS(":"Math_SmoothStepToS(",
"Math_SmoothScaleMaxS(":"Math_ApproachS("}
def replace_math(file):
with open(file,'r',encoding = 'utf-8') as infile:
srcdata = infile.read()
funcs = list(mathdict.keys())
fixes = 0
for func in funcs:
newfunc = mathdict.get(func)
if(newfunc is None):
print("How did this happen?")
return -1
if(func in srcdata):
fixes += 1
srcdata = srcdata.replace(func, newfunc)
if(fixes > 0):
print('Changed', fixes,'function' + ('' if fixes == 1 else 's') + ' in',file)
with open(file, 'w', encoding = 'utf-8', newline = '\n') as outfile:
outfile.write(srcdata)
return 1
def replace_math_all(repo):
for subdir, dirs, files in os.walk(repo + os.sep + 'src'):
for filename in files:
if(filename.endswith('.c')):
file = subdir + os.sep + filename
replace_math(file)
for subdir, dirs, files in os.walk(repo + os.sep + 'asm' + os.sep + 'non_matchings'):
for filename in files:
if(filename.endswith('.c')):
file = subdir + os.sep + filename
replace_math(file)
return 1
if __name__ == "__main__":
repo = os.curdir
replace_math_all(repo)

View file

@ -5,6 +5,7 @@ import argparse
# all occurrences of keys will be replaced by associated value
simpleReplace = {
"Math_Rand_":"Rand_",
"ACTORTYPE":"ACTORCAT",
"DistToLink":"DistToPlayer",
"HitItem":"HitInfo",
@ -15,6 +16,55 @@ simpleReplace = {
# for example, if there is a space before and an open parenthesis after,
# like for a function call: ` func_8002E4B4(`
wordReplace = {
"SkelAnime_FrameUpdateMatrix":"SkelAnime_Update",
"SkelAnime_ChangeAnimTransitionRepeat":"Animation_MorphToLoop",
"SkelAnime_ChangeAnimDefaultRepeat":"Animation_PlayLoop",
"SkelAnime_ChangeAnimPlaybackRepeat":"Animation_PlayLoopSetSpeed",
"SkelAnime_ChangeAnimTransitionStop":"Animation_MorphToPlayOnce",
"SkelAnime_ChangeAnimDefaultStop":"Animation_PlayOnce",
"SkelAnime_ChangeAnimPlaybackStop":"Animation_PlayOnceSetSpeed",
"SkelAnime_ChangeAnimImpl":"Animation_ChangeImpl",
"SkelAnime_ChangeAnim":"Animation_Change",
"SkelAnime_GetFrameCount":"Animation_GetLastFrame",
"func_800A56C8":"Animation_OnFrame",
"skelAnime.animCurrentFrame":"skelAnime.curFrame",
"skelAnime.animPlaybackSpeed":"skelAnime.playSpeed",
"skelAnime.initialFrame":"skelAnime.startFrame",
"skelAnime.animFrameCount":"skelAnime.endFrame",
"skelAnime.totalFrames":"skelAnime.animLength",
"skelAnime.limbDrawTbl":"skelAnime.jointTable",
"skelAnime.transitionDrawTbl":"skelAnime.morphTable",
"skelAnime.transCurrentFrame":"skelAnime.morphWeight",
"skelAnime.transitionStep":"skelAnime.morphRate",
"skelAnime.flags":"skelAnime.moveFlags",
"skelAnime.prevFrameRot":"skelAnime.prevRot",
"skelAnime.prevFramePos":"skelAnime.prevTransl",
"skelAnime.unk_3E":"skelAnime.baseTransl",
"skelAnime.unk_03":"skelAnime.taper",
"func_800CA540(":"Math_FactorialF(",
"func_800CA63C(":"Math_Factorial(",
"func_800CA6FC(":"Math_PowF(",
"func_800CA720(":"Math_SinF(",
"func_800CA774(":"Math_CosF(",
"Math_atan2f(":"Math_FAtan2F(",
"atan2f(":"Math_Atan2F(",
"atan2s(":"Math_Atan2S(",
"Math_Coss(":"Math_CosS(",
"Math_Sins(":"Math_SinS(",
"Math_ApproxUpdateScaledS(":"Math_ScaledStepToS(",
"Math_ApproxS(":"Math_StepToS(",
"Math_ApproxF(":"Math_StepToF(",
"func_80077A90(":"Math_StepUntilAngleS(",
"func_80077AF8(":"Math_StepUntilS(",
"func_80077B58(":"Math_StepToAngleS(",
"func_80077C1C(":"Math_StepUntilF(",
"func_80077C6C(":"Math_AsymStepToF(",
"Math_SmoothScaleMaxMinF(":"Math_SmoothStepToF(",
"Math_SmoothScaleMaxF(":"Math_ApproachF(",
"Math_SmoothDownscaleMaxF(":"Math_ApproachZeroF(",
"func_800784D8(":"Math_SmoothStepToDegF(",
"Math_SmoothScaleMaxMinS(":"Math_SmoothStepToS(",
"Math_SmoothScaleMaxS(":"Math_ApproachS(",
"Actor_SetHeight":"Actor_SetFocus",
"func_8002E4B4":"Actor_UpdateBgCheckInfo",
"func_8002BDB0":"Actor_SetFeetPos",
@ -103,7 +153,7 @@ wordReplace = {
"func_800D20CC": "Matrix_MtxFToYXZRotS",
"func_800D2264": "Matrix_MtxFToZYXRotS",
"func_800D23FC": "Matrix_RotateAxis",
"PLAYER": "GET_PLAYER(globalCtx)",
"PLAYER": ("GET_PLAYER(globalCtx)", {"ignore": (-1, '"PLAYER"')}), # ignore "PLAYER" in sSoundBankNames
"ACTIVE_CAM": "GET_ACTIVE_CAM(globalCtx)",
}
@ -125,6 +175,20 @@ def replace_single(file):
srcdata = srcdata.replace(old, new)
for old, new in wordReplace.items():
# `new` can be a tuple where the first element is what to replace `old` with,
# and the second element is a dict containing "custom behavior" properties.
if isinstance(new, tuple):
custom_behavior = True
new, custom_behavior_data = new
# The "ignore" data is a tuple where the first element is an offset relative to
# where `old` was found, and the string from that index must differ from the
# tuple's second element for the replacement to be done.
custom_behavior_ignore_data = custom_behavior_data.get("ignore")
custom_behavior_ignore = custom_behavior_ignore_data is not None
if custom_behavior_ignore:
custom_behavior_ignore_offset, custom_behavior_ignore_match = custom_behavior_ignore_data
else:
custom_behavior = False
# replace `old` with `new` if the occurence of `old` is the whole word
oldStartIdx = srcdata.find(old)
if oldStartIdx >= 0:
@ -144,6 +208,9 @@ def replace_single(file):
pass
elif is_word_char(srcdata[oldEndIdx]):
replace = False
if replace and custom_behavior and custom_behavior_ignore:
if srcdata[oldStartIdx + custom_behavior_ignore_offset:].startswith(custom_behavior_ignore_match):
replace = False
if replace:
srcdata = srcdata[:oldStartIdx] + new + srcdata[oldEndIdx:]
replaceCount += 1