From be4c0af110dcb56e146b3526b8b848380d1dd9f8 Mon Sep 17 00:00:00 2001 From: Natalie Fearnley Date: Sat, 2 Dec 2023 01:13:14 -0500 Subject: [PATCH] fixed scale stuff --- sizebot/lib/proportions.py | 22 +++++++++++++++------- 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/sizebot/lib/proportions.py b/sizebot/lib/proportions.py index c07ea33a..43a50562 100644 --- a/sizebot/lib/proportions.py +++ b/sizebot/lib/proportions.py @@ -71,17 +71,21 @@ def __init__(self, stat: Stat, value: Any): self.value = value def scale(self, scale: Decimal, found: dict): + # None * 2 is None if self.value is None: - return StatValue(self, None) # None * 2 is None - if self.stat.power is not None: - value = self.value * (scale ** self.stat.power) - else: + value = None + elif self.stat.power is not None: + T = type(self.value) + value = T(self.value * (scale ** self.stat.power)) + elif self.stat.default_from: if any(r not in found for r in self.stat.requires): return value = self.stat.default_from(found) + else: + value = self.value if self.stat.sets: found[self.stat.sets] = value - return StatValue(self, value) + return StatValue(self.stat, value) def __str__(self): return f"{self.stat.name}: {self.value}" @@ -139,6 +143,10 @@ def __str__(self): Stat("Visibility", sets="visibility", requires=["height"], default_from=lambda s: calcVisibility(s["height"])) ] +# Example display code +# display_stats = [ +# DisplayStat(key="width", name="Width", statout="You're a {} wide chonker!", embedname="Width:", embedvalue="{} :widthicon:") +# ] class StatBox: def __init__(self, stats: list[StatValue] = None): @@ -164,7 +172,7 @@ def load(cls, playerStats: PlayerStats) -> StatBox: processed.append(sv) # If no progress if len(queued) == len(processing): - raise errors.UnfoundStatException(["Load"] + [s.name for s in queued]) + raise errors.UnfoundStatException([s.name for s in queued]) return cls(processed) def scale(self, scale_value: Decimal) -> StatBox: @@ -186,7 +194,7 @@ def scale(self, scale_value: Decimal) -> StatBox: processed.append(sv) # If no progress if len(queued) == len(processing): - raise errors.UnfoundStatException(["Scale"] + [s.stat.name for s in queued]) + raise errors.UnfoundStatException([s.stat.name for s in queued]) return StatBox(processed) def get(self, stat_name: str) -> StatValue | None: