From d45069dd84a99f72e1f04428b185b5b224de8b36 Mon Sep 17 00:00:00 2001 From: MaybeMaru <97055307+MaybeMaru@users.noreply.github.com> Date: Mon, 15 Apr 2024 18:16:05 +0200 Subject: [PATCH] make runEvent start event scripts automatically --- source/funkin/util/modding/FunkScript.hx | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/source/funkin/util/modding/FunkScript.hx b/source/funkin/util/modding/FunkScript.hx index a8b68328..5abdc4b9 100644 --- a/source/funkin/util/modding/FunkScript.hx +++ b/source/funkin/util/modding/FunkScript.hx @@ -1,5 +1,7 @@ package funkin.util.modding; +import funkin.objects.NotesGroup; +import funkin.objects.NotesGroup; import hscript.Script; import flixel.util.FlxDestroyUtil.IFlxDestroyable; @@ -8,7 +10,8 @@ enum abstract HscriptFunctionCallback(Int) from Int to Int { var STOP_FUNCTION = 1; } -class FunkScript extends hscript.Script implements IFlxDestroyable { +class FunkScript extends hscript.Script implements IFlxDestroyable +{ public static var globalVariables:Map = []; public var active:Bool = true; public var scriptID:String = ''; @@ -321,7 +324,18 @@ class FunkScript extends hscript.Script implements IFlxDestroyable { if (name == "runCode") // why would you- return false; - return ModdingUtil.getCall('eventHit', [tempEvent.set(-1, name, values)]); + if (NotesGroup.instance != null) + { + var curEvents = NotesGroup.instance.songEvents; + if (!curEvents.contains(name)) { + var script = ModdingUtil.addScript(Paths.script('events/$name')); + curEvents.push(name); + } + } + + tempEvent.name = name; + tempEvent.values = values ?? []; + return ModdingUtil.getCall('eventHit', [tempEvent]); }); // Script functions