package funkin.data.dialogue; import funkin.play.cutscene.dialogue.Speaker; import funkin.data.dialogue.SpeakerData; import funkin.play.cutscene.dialogue.ScriptedSpeaker; class SpeakerRegistry extends BaseRegistry { /** * The current version string for the speaker data format. * Handle breaking changes by incrementing this value * and adding migration to the `migrateSpeakerData()` function. */ public static final SPEAKER_DATA_VERSION:thx.semver.Version = "1.0.0"; public static final SPEAKER_DATA_VERSION_RULE:thx.semver.VersionRule = "1.0.x"; public static final instance:SpeakerRegistry = new SpeakerRegistry(); public function new() { super('SPEAKER', 'dialogue/speakers', SPEAKER_DATA_VERSION_RULE); } /** * Read, parse, and validate the JSON data and produce the corresponding data object. */ public function parseEntryData(id:String):Null { // JsonParser does not take type parameters, // otherwise this function would be in BaseRegistry. var parser = new json2object.JsonParser(); parser.ignoreUnknownVariables = false; switch (loadEntryFile(id)) { case {fileName: fileName, contents: contents}: parser.fromJson(contents, fileName); default: return null; } if (parser.errors.length > 0) { printErrors(parser.errors, id); return null; } return parser.value; } /** * Parse and validate the JSON data and produce the corresponding data object. * * NOTE: Must be implemented on the implementation class. * @param contents The JSON as a string. * @param fileName An optional file name for error reporting. */ public function parseEntryDataRaw(contents:String, ?fileName:String):Null { var parser = new json2object.JsonParser(); parser.ignoreUnknownVariables = false; parser.fromJson(contents, fileName); if (parser.errors.length > 0) { printErrors(parser.errors, fileName); return null; } return parser.value; } function createScriptedEntry(clsName:String):Speaker { return ScriptedSpeaker.init(clsName, "unknown"); } function getScriptedClassNames():Array { return ScriptedSpeaker.listScriptClasses(); } }