forked from SilverStudioGames/WTS
Bug fixes
* Fixed missing 'whore collar' unlock method call * Fixed gallery not working correctly by extending call_replay funcionality by adding support for nested stores
This commit is contained in:
parent
f5ef31c88b
commit
13608b6cfa
@ -652,6 +652,7 @@ label whore_scene: #(locked behind public reputation and last sex event)
|
|||||||
with d3
|
with d3
|
||||||
|
|
||||||
if not her_neckwear_whore_collar.unlocked:
|
if not her_neckwear_whore_collar.unlocked:
|
||||||
|
$ her_neckwear_whore_collar.unlock()
|
||||||
gen "Well then... Seeing as how you said thank you... I have a present for you." ("base", xpos="far_left", ypos="head")
|
gen "Well then... Seeing as how you said thank you... I have a present for you." ("base", xpos="far_left", ypos="head")
|
||||||
her @ cheeks blush "A present?" ("soft", "wink", "worried", "mid_soft", trans=d3)
|
her @ cheeks blush "A present?" ("soft", "wink", "worried", "mid_soft", trans=d3)
|
||||||
gen "Yes, it's a lovely piece of jewellery to commemorate your self-acceptance." ("base", xpos="far_left", ypos="head")
|
gen "Yes, it's a lovely piece of jewellery to commemorate your self-acceptance." ("base", xpos="far_left", ypos="head")
|
||||||
|
@ -248,9 +248,9 @@ screen ui_menu():
|
|||||||
label scene_gallery:
|
label scene_gallery:
|
||||||
menu:
|
menu:
|
||||||
"-Watch Ball Ending 1-" if persistent.ending_01:
|
"-Watch Ball Ending 1-" if persistent.ending_01:
|
||||||
$ renpy.call_replay("ball_ending_E2", { "states.her.ev.yule_ball.variant": "personal" })
|
$ renpy.call_replay("ball_ending_E2", scope={ "states.her.ev.yule_ball.variant": "personal" })
|
||||||
"-Watch Ball Ending 2-" if persistent.ending_02:
|
"-Watch Ball Ending 2-" if persistent.ending_02:
|
||||||
$ renpy.call_replay("ball_ending_E2", { "states.her.ev.yule_ball.variant": "public" })
|
$ renpy.call_replay("ball_ending_E2", scope={ "states.her.ev.yule_ball.variant": "public" })
|
||||||
"-Never mind-":
|
"-Never mind-":
|
||||||
pass
|
pass
|
||||||
jump main_room_menu
|
jump main_room_menu
|
||||||
|
@ -336,3 +336,70 @@ init -100 python:
|
|||||||
expression = expression()
|
expression = expression()
|
||||||
|
|
||||||
return true if expression else false
|
return true if expression else false
|
||||||
|
|
||||||
|
# Adds support for nested stores for replay scope
|
||||||
|
def _call_replay(label, scope={}):
|
||||||
|
renpy.display.focus.clear_focus()
|
||||||
|
|
||||||
|
renpy.game.log.complete()
|
||||||
|
|
||||||
|
old_log = renpy.game.log
|
||||||
|
renpy.game.log = renpy.python.RollbackLog()
|
||||||
|
|
||||||
|
sb = renpy.python.StoreBackup()
|
||||||
|
renpy.python.clean_stores()
|
||||||
|
|
||||||
|
context = renpy.execution.Context(True)
|
||||||
|
renpy.game.contexts.append(context)
|
||||||
|
|
||||||
|
if renpy.display.interface is not None:
|
||||||
|
renpy.display.interface.enter_context()
|
||||||
|
|
||||||
|
# This has to be here, to ensure the scope stuff works.
|
||||||
|
renpy.exports.execute_default_statement()
|
||||||
|
|
||||||
|
for k, v in renpy.config.replay_scope.items():
|
||||||
|
stores = k.split(".")
|
||||||
|
current_obj = renpy.store
|
||||||
|
|
||||||
|
for store in stores[:-1]:
|
||||||
|
current_obj = getattr(current_obj, store)
|
||||||
|
|
||||||
|
setattr(current_obj, stores[-1], v)
|
||||||
|
|
||||||
|
for k, v in scope.items():
|
||||||
|
stores = k.split(".")
|
||||||
|
current_obj = renpy.store
|
||||||
|
|
||||||
|
for store in stores[:-1]:
|
||||||
|
current_obj = getattr(current_obj, store)
|
||||||
|
|
||||||
|
setattr(current_obj, stores[-1], v)
|
||||||
|
|
||||||
|
renpy.store._in_replay = label
|
||||||
|
|
||||||
|
try:
|
||||||
|
|
||||||
|
context.goto_label("_start_replay")
|
||||||
|
renpy.execution.run_context(False)
|
||||||
|
|
||||||
|
except renpy.game.EndReplay:
|
||||||
|
pass
|
||||||
|
|
||||||
|
finally:
|
||||||
|
|
||||||
|
context.pop_all_dynamic()
|
||||||
|
|
||||||
|
renpy.game.contexts.pop()
|
||||||
|
renpy.game.log = old_log
|
||||||
|
sb.restore()
|
||||||
|
|
||||||
|
if renpy.game.interface and renpy.game.interface.restart_interaction and renpy.game.contexts:
|
||||||
|
renpy.game.contexts[-1].scene_lists.focused = None
|
||||||
|
|
||||||
|
renpy.config.skipping = None
|
||||||
|
|
||||||
|
if renpy.config.after_replay_callback:
|
||||||
|
renpy.config.after_replay_callback()
|
||||||
|
|
||||||
|
renpy.call_replay = _call_replay
|
||||||
|
Loading…
Reference in New Issue
Block a user