Support MUSIC and AESTHETICS sections

This commit is contained in:
Trysdyn Black 2024-10-11 21:38:46 -07:00
parent e4af5dcf3b
commit ae9451f336
2 changed files with 79 additions and 4 deletions

View file

@ -34,14 +34,12 @@ BCCE is in active development and this may break at any time; see the first para
These sections in the BCEX/BCCE spoiler logs currently have no logic and I'm aware of it. That doesn't mean sections *not* listed here have support; they may not and I'm not aware of them.
- AESTHETICS
- MAGITEK
- DANCES
- ESPERS
- ITEM MAGIC
- ITEM EFFECTS
- COLOSSEUM
- MUSIC
- SHOPS
- TREASURE CHESTS
- JUNCTIONS

81
main.py
View file

@ -15,14 +15,12 @@ class Parser:
BCEX/BCCE spoiler logfile parser.
Sections missing support:
- AESTHETICS
- MAGITEK
- DANCES
- ESPERS
- ITEM MAGIC
- ITEM EFFECTS
- COLOSSEUM
- MUSIC
- SHOPS
- TREASURE CHESTS
- JUNCTIONS
@ -288,6 +286,85 @@ class Parser:
# I have no idea what this is lol, dump it to a list for now
return [line for line in data.split("\n") if not line.startswith("---")]
@staticmethod
def parse_MUSIC(data: str) -> dict[str, dict]:
"""
Parse the MUSIC section.
This differs significantly between BCEX and BCCE: Numbers and data are split
with a period in BCCE and a colon in BCEX. BCEX puts arranger on the same line
as composer, split with --, BCEX lacks the Jukebox Title section entirely.
"""
music_sections = data.split("\n\n")
replacements = {}
for section in music_sections[1:]:
if not section.strip():
continue
# BCEX and BCCE divide numbers from data differently
if ":" in section[:6]:
_, info = section.split(":", 1)
else:
_, info = section.split(".", 1)
# The name of the song being replaced preceeds a ->
old_name, info = info.split("->", 1)
old_name = old_name.strip()
replacements[old_name] = {}
# Info is, mostly, one item per line, so let's go by line
tok_info = info.split("\n")
for k in ("name", "title", "composer", "arranger", "jukebox_title"):
# Not every song has all the data
if not len(tok_info):
break
line = tok_info.pop(0).strip()
# BCCE puts arranger on its own line. BCEX puts it on the same line as
# composed, split by "--". So we have to handle both
if "-- Arranged by " in line:
line, arranger = line.split("-- Arranged by ", 1)
replacements[old_name]["arranger"] = arranger
# Jukebox Title is in prens with extra stuff to chomp
if "Jukebox title" in line:
line = line[16:-1]
# These strings are fluff but should only appear in compose/arranger lines
# so it's safe to just blindly chomp them
line = line.split("Composed by ", 1)[-1].strip()
line = line.replace("Ripped and/or arranged by ", "")
replacements[old_name][k] = line
return replacements
@staticmethod
def parse_AESTHETICS(data: str) -> dict[str, str]:
"""
Parse the BCCE-only AESTHETICS section.
This is just a k=v list we split up and strip.
"""
replacements = {}
for line in data.split("\n"):
if ":" not in line:
continue
old, new = line.split(":")
old = old.strip()
new = new.strip()
replacements[old] = new
return replacements
@staticmethod
def cleanup_STATS(data: dict) -> bool:
"""