2023-05-16 22:09:53 -04:00
|
|
|
package funkin.data.level;
|
|
|
|
|
|
|
|
import funkin.ui.story.Level;
|
|
|
|
import funkin.data.level.LevelData;
|
|
|
|
import funkin.ui.story.ScriptedLevel;
|
|
|
|
|
|
|
|
class LevelRegistry extends BaseRegistry<Level, LevelData>
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The current version string for the stage data format.
|
|
|
|
* Handle breaking changes by incrementing this value
|
|
|
|
* and adding migration to the `migrateStageData()` function.
|
|
|
|
*/
|
2023-08-22 04:27:30 -04:00
|
|
|
public static final LEVEL_DATA_VERSION:thx.semver.Version = "1.0.0";
|
|
|
|
|
|
|
|
public static final LEVEL_DATA_VERSION_RULE:thx.semver.VersionRule = "1.0.x";
|
2023-05-16 22:09:53 -04:00
|
|
|
|
|
|
|
public static final instance:LevelRegistry = new LevelRegistry();
|
|
|
|
|
|
|
|
public function new()
|
|
|
|
{
|
2023-08-22 04:27:30 -04:00
|
|
|
super('LEVEL', 'levels', LEVEL_DATA_VERSION_RULE);
|
2023-05-16 22:09:53 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Read, parse, and validate the JSON data and produce the corresponding data object.
|
|
|
|
*/
|
|
|
|
public function parseEntryData(id:String):Null<LevelData>
|
|
|
|
{
|
|
|
|
// JsonParser does not take type parameters,
|
|
|
|
// otherwise this function would be in BaseRegistry.
|
|
|
|
var parser = new json2object.JsonParser<LevelData>();
|
|
|
|
var jsonStr:String = loadEntryFile(id);
|
|
|
|
|
|
|
|
parser.fromJson(jsonStr);
|
|
|
|
|
|
|
|
if (parser.errors.length > 0)
|
|
|
|
{
|
2023-08-22 04:27:30 -04:00
|
|
|
trace('[${registryId}] Failed to parse entry data: ${id}');
|
2023-05-16 22:09:53 -04:00
|
|
|
for (error in parser.errors)
|
|
|
|
{
|
|
|
|
trace(error);
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
return parser.value;
|
|
|
|
}
|
|
|
|
|
|
|
|
function createScriptedEntry(clsName:String):Level
|
|
|
|
{
|
|
|
|
return ScriptedLevel.init(clsName, "unknown");
|
|
|
|
}
|
|
|
|
|
|
|
|
function getScriptedClassNames():Array<String>
|
|
|
|
{
|
|
|
|
return ScriptedLevel.listScriptClasses();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2023-05-17 16:42:58 -04:00
|
|
|
* A list of all the story weeks from the base game, in order.
|
2023-05-16 22:09:53 -04:00
|
|
|
* TODO: Should this be hardcoded?
|
|
|
|
*/
|
2023-05-17 16:42:58 -04:00
|
|
|
public function listBaseGameLevelIds():Array<String>
|
2023-05-16 22:09:53 -04:00
|
|
|
{
|
|
|
|
return [
|
|
|
|
"tutorial",
|
|
|
|
"week1",
|
|
|
|
"week2",
|
|
|
|
"week3",
|
|
|
|
"week4",
|
|
|
|
"week5",
|
|
|
|
"week6",
|
|
|
|
"week7",
|
|
|
|
"weekend1"
|
2023-05-17 16:42:58 -04:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A list of all installed story weeks that are not from the base game.
|
|
|
|
*/
|
|
|
|
public function listModdedLevelIds():Array<String>
|
|
|
|
{
|
|
|
|
return listEntryIds().filter(function(id:String):Bool {
|
|
|
|
return listBaseGameLevelIds().indexOf(id) == -1;
|
|
|
|
});
|
2023-05-16 22:09:53 -04:00
|
|
|
}
|
|
|
|
}
|