Compare commits

..

8 Commits

Author SHA1 Message Date
4658a97b4a Bug fixes and improvements
* Improved skipping performance by delaying the call to render functions until after skipping ends
* Fixed skipping not refreshing the doll image
* Fixed skipping callback handler being affected by rollback
* Refactored doll show method
2023-07-25 17:54:34 +01:00
148d2fcac5 Bug fixes
* Fixed updater logo issues
* Fixed modpath getting 'mods' subpath appended to it recursively with each clone
2023-07-25 17:54:34 +01:00
6b8c9adb7f Bug fixes
* Fixed updater (AGAIN!!)
* Disabled the 'server not responding' hint because it doesn't really match what's happening in the server code
* Version bump
2023-07-25 17:54:34 +01:00
71c2c3fd8f Bug fix
* Fixed mods warning for compatible mods due to old var reference
2023-07-25 17:54:34 +01:00
699f68742f Bug fixes
* Fixed cardgame TypeError crash during random matches
* Fixed mistakenly excluded ExampleMod from releases
2023-07-25 17:54:33 +01:00
316aea6a5a Bug fixes and autosaves
* Added autosave toggle
* Fixed achievements being granted in replay scope
2023-07-25 17:54:33 +01:00
962cc2f695 Bug fixes
* Fixed outfit deletion tab not updating the list of items
* Fixed Tonks' public requests menu crashing due to an omitted result type
* Removed manual image rebuilding in wardrobe (superseded)
2023-07-25 17:54:33 +01:00
ebc865b798 Bug fix
* Fixed stale images being displayed when threading is enabled and no image was called in a while
2023-07-25 17:54:33 +01:00
23 changed files with 84 additions and 63 deletions

5
game/mods/.gitignore vendored Normal file

@ -0,0 +1,5 @@
# Ignore everything in this directory
*
# Except this file and ExampleMod
!.gitignore
!ExampleMod/

@ -38,7 +38,7 @@ init python:
emote=None, xpos=None, ypos=None, pos=None, flip=None, trans=None, animation=False, **kwargs):
def show():
astoria.show()
astoria.show(force=True)
if not renpy.in_rollback():
renpy.with_statement(trans or d2)

@ -36,7 +36,7 @@ init python in character:
emote=None, face=None, xpos=None, ypos=None, pos=None, flip=None, trans=None, animation=False, **kwargs):
def show():
renpy.store.cho.show()
renpy.store.cho.show(force=True)
if not renpy.in_rollback():
renpy.with_statement(trans or renpy.store.d2)

@ -31,7 +31,7 @@ init python:
emote=None, face=None, xpos=None, ypos=None, pos=None, flip=None, trans=None, animation=False, **kwargs):
def show():
hermione.show()
hermione.show(force=True)
if not renpy.in_rollback():
renpy.with_statement(trans or d2)

@ -22,7 +22,7 @@ init python:
emote=None, face=None, xpos=None, ypos=None, pos=None, flip=None, trans=None, animation=False, **kwargs):
def show():
hooch.show()
hooch.show(force=True)
if not renpy.in_rollback():
renpy.with_statement(trans or d2)

@ -34,7 +34,7 @@ init python:
emote=None, face=None, xpos=None, ypos=None, pos=None, flip=None, trans=None, animation=False, **kwargs):
def show():
luna.show()
luna.show(force=True)
if not renpy.in_rollback():
renpy.with_statement(trans or d2)

@ -33,7 +33,7 @@ init python:
emote=None, face=None, xpos=None, ypos=None, pos=None, flip=None, trans=None, animation=False, **kwargs):
def show():
susan.show()
susan.show(force=True)
if not renpy.in_rollback():
renpy.with_statement(trans or d2)

@ -44,7 +44,7 @@ init python:
emote=None, face=None, xpos=None, ypos=None, pos=None, flip=None, trans=None, animation=False, **kwargs):
def show():
tonks.show()
tonks.show(force=True)
if not renpy.in_rollback():
renpy.with_statement(trans or d2)

@ -126,7 +126,7 @@ label tonks_favor_menu:
$ result = show_events_menu(tonks_requests)
if result == "disabled":
if result in ("disabled", "noncompliant"):
"You haven't unlocked this request opportunity yet."
jump .requests
elif result == "exit":

@ -383,7 +383,8 @@ init python:
def clone(self):
"""Creates a clone of this cloth object. Since it requires a parent object it should be used internally only to avoid object depth issue."""
return DollCloth(self.name, self.categories, self.type, self.id, [x for x in self.color] if self.color else None, self.zorder, self.unlocked, self.level, self.blacklist, self.modpath, self)
modpath = self.modpath.lstrip("mods/")
return DollCloth(self.name, self.categories, self.type, self.id, [x for x in self.color] if self.color else None, self.zorder, self.unlocked, self.level, self.blacklist, modpath, self)
def is_modded(self):
"""Returns True if item comes from a mod."""

@ -183,4 +183,5 @@ init python:
def clone(self):
"""Creates a clone of this cloth object. Since it requires a parent object it should be used internally only to avoid object depth issue."""
return DollClothDynamic(self.name, self.categories, self.type, self.id, [x for x in self.color] if self.color else None, self.zorder, self.unlocked, self.level, self.blacklist, self.modpath, self._tracking, self)
modpath = self.modpath.lstrip("mods/")
return DollClothDynamic(self.name, self.categories, self.type, self.id, [x for x in self.color] if self.color else None, self.zorder, self.unlocked, self.level, self.blacklist, modpath, self._tracking, self)

@ -78,8 +78,11 @@ init -1 python:
def DollRebuild():
for i in states.dolls:
doll = getattr(store, i)
doll.build_image()
if doll.is_stale() and not settings.get("multithreading"):
doll.show(ignore_skipping=True)
renpy.restart_interaction()
config.after_load_callbacks.append(DollRebuild)
# end_skip_callbacks.append(DollRebuild)
end_skip_callbacks.append(DollRebuild)

File diff suppressed because it is too large Load Diff

@ -62,4 +62,5 @@ init python:
def clone(self):
"""Creates a clone of this cloth object. Since it requires a parent object it should be used internally only to avoid object depth issue."""
return DollMakeup(self.name, self.categories, self.type, self.id, [x for x in self.color] if self.color else None, self.zorder, self.unlocked, self.level, self.blacklist, self.modpath, self, self.tracking)
modpath = self.modpath.lstrip("mods/")
return DollMakeup(self.name, self.categories, self.type, self.id, [x for x in self.color] if self.color else None, self.zorder, self.unlocked, self.level, self.blacklist, modpath, self, self.tracking)

@ -255,7 +255,7 @@ screen navigation(title=None):
if not title:
if not renpy.mobile:
if version_float(UPDATE_VER) < version_float():
if version_float(UPDATE_VER) > version_float():
textbutton "Install updates" action InstallUpdates() style_prefix "update_available" sensitive (not prerelease)
else:
textbutton "Check for updates" action CheckUpdates(300) sensitive (not prerelease)

@ -63,7 +63,7 @@ screen mods():
text "[name]":
style "mods_text"
size 16
if not compat >= compatible_version:
if not compat >= mods_compatible:
color "#ff8000"
text "[version]":
@ -101,7 +101,7 @@ screen mods():
add logo xalign 0.5 size (320, 240)
text "[name]\n[version]" offset (6, 6)
if not compat >= compatible_version:
if not compat >= mods_compatible:
text "{color=#ff8000}[compat]{/color}" align (1.0, 1.0) offset (-6, -3)
else:
text "{color=#228B22}[compat]{/color}" align (1.0, 1.0) offset (-6, -3)

@ -63,6 +63,7 @@ screen preferences_general():
textbutton _("Tooltips") action settings.Toggle("tooltip")
textbutton _("System Cursor") action Preference("system cursor", "toggle")
textbutton _("Automatic Updates") action settings.Toggle("updates")
textbutton _("Autosave") action ToggleField(store, "_autosave")
default trans = config.intra_transition

@ -83,6 +83,9 @@ init python:
return self.achievements.get(id)[3]
def unlock(self, id, silent=False):
if _in_replay:
return
if persistent.achievements[id][3] == False:
self.achievements[id][3] = True
persistent.achievements[id][3] = True

@ -579,7 +579,7 @@ init python:
while min > get_deck_score(new_deck) or max < get_deck_score(new_deck):
replace_index = 0
if new_deck < min:
if get_deck_score(new_deck) < min:
replace_index = find_index_func(temp_pool, smalles_func)
else:
replace_index = find_index_func(temp_pool, gretest_func)

@ -38,7 +38,7 @@ define config.debug = config.developer or prerelease
define config.console = True
# Game version and naming
define config.version = "1.45.2"
define config.version = "1.45.3"
define compatible_version = 1.451
define config.name = "Witch Trainer Silver"
@ -167,7 +167,8 @@ init python:
build.classify("icon.ico", "windows")
build.classify("game/presplash_*.png", "renpy")
build.classify("game/outfits/**", "all")
build.classify("game/mods/MyMod/**", "all")
build.classify("game/mods/ExampleMod/**", "all")
build.classify("update/generic.webp", "pc mac")
build.classify("**.py", None)
build.classify("**.txt", None)

Some files were not shown because too many files have changed in this diff Show More