From cc8f613fe0563aa76bdfb63ff46bd8feefb7edc8 Mon Sep 17 00:00:00 2001 From: Matthew Fioravante Date: Wed, 14 Oct 2020 02:03:07 -0400 Subject: [PATCH] rpg::Actor Add unknown 3A and 40 chunks found in DynRPG --- generator/csv/fields.csv | 2 ++ src/generated/lcf/ldb/chunks.h | 4 ++++ src/generated/lcf/rpg/actor.h | 12 ++++++++---- src/generated/ldb_actor.cpp | 16 ++++++++++++++++ src/generated/rpg_actor.cpp | 2 ++ 5 files changed, 32 insertions(+), 4 deletions(-) diff --git a/generator/csv/fields.csv b/generator/csv/fields.csv index df5079644..fddec28c7 100644 --- a/generator/csv/fields.csv +++ b/generator/csv/fields.csv @@ -23,10 +23,12 @@ Actor,exp_correction,f,Int32,0x2B,0,0,0,Integer Actor,initial_equipment,f,Equipment,0x33,,1,0,Integer x 5 Actor,unarmed_animation,f,Ref,0x38,1,0,0,Integer Actor,class_id,f,Ref,0x39,0,0,1,Integer - RPG2003 +Actor,unknown3A,f,Int32,0x3A,0,0,1,Unknown chunk - only present in RPG2003 Actor,battle_x,f,Int32,0x3B,220,0,1,Integer - RPG2003 Actor,battle_y,f,Int32,0x3C,120,0,1,Integer - RPG2003 Actor,battler_animation,f,Ref,0x3E,1,0,1,Integer - RPG2003 Actor,skills,f,Array,0x3F,,1,0,Array - rpg::Learning +Actor,unknown40,f,Int32,0x40,0,0,1,Unknown chunk - only present in RPG2003 Actor,rename_skill,f,Boolean,0x42,False,0,0,Flag Actor,skill_name,f,DBString,0x43,,0,0,String Actor,state_ranks,t,Vector,0x47,,0,0,Integer diff --git a/src/generated/lcf/ldb/chunks.h b/src/generated/lcf/ldb/chunks.h index a578cb0ae..5f1e57feb 100644 --- a/src/generated/lcf/ldb/chunks.h +++ b/src/generated/lcf/ldb/chunks.h @@ -72,6 +72,8 @@ namespace LDB_Reader { unarmed_animation = 0x38, /** Integer - RPG2003 */ class_id = 0x39, + /** Unknown chunk - only present in RPG2003 */ + unknown3A = 0x3A, /** Integer - RPG2003 */ battle_x = 0x3B, /** Integer - RPG2003 */ @@ -80,6 +82,8 @@ namespace LDB_Reader { battler_animation = 0x3E, /** Array - rpg::Learning */ skills = 0x3F, + /** Unknown chunk - only present in RPG2003 */ + unknown40 = 0x40, /** Flag */ rename_skill = 0x42, /** String */ diff --git a/src/generated/lcf/rpg/actor.h b/src/generated/lcf/rpg/actor.h index 8aa0dcd11..dc4f8cea9 100644 --- a/src/generated/lcf/rpg/actor.h +++ b/src/generated/lcf/rpg/actor.h @@ -54,10 +54,12 @@ namespace rpg { Equipment initial_equipment; int32_t unarmed_animation = 1; int32_t class_id = 0; + int32_t unknown3A = 0; int32_t battle_x = 220; int32_t battle_y = 120; int32_t battler_animation = 1; std::vector skills; + int32_t unknown40 = 0; bool rename_skill = false; DBString skill_name; std::vector state_ranks; @@ -88,10 +90,12 @@ namespace rpg { && l.initial_equipment == r.initial_equipment && l.unarmed_animation == r.unarmed_animation && l.class_id == r.class_id + && l.unknown3A == r.unknown3A && l.battle_x == r.battle_x && l.battle_y == r.battle_y && l.battler_animation == r.battler_animation && l.skills == r.skills + && l.unknown40 == r.unknown40 && l.rename_skill == r.rename_skill && l.skill_name == r.skill_name && l.state_ranks == r.state_ranks @@ -120,11 +124,11 @@ namespace rpg { const auto ctx20 = Context{ "initial_equipment", -1, &obj, parent_ctx }; ForEachString(obj.initial_equipment, f, &ctx20); for (int i = 0; i < static_cast(obj.skills.size()); ++i) { - const auto ctx26 = Context{ "skills", i, &obj, parent_ctx }; - ForEachString(obj.skills[i], f, &ctx26); + const auto ctx27 = Context{ "skills", i, &obj, parent_ctx }; + ForEachString(obj.skills[i], f, &ctx27); } - const auto ctx28 = Context{ "skill_name", -1, &obj, parent_ctx }; - f(obj.skill_name, ctx28); + const auto ctx30 = Context{ "skill_name", -1, &obj, parent_ctx }; + f(obj.skill_name, ctx30); (void)obj; (void)f; (void)parent_ctx; diff --git a/src/generated/ldb_actor.cpp b/src/generated/ldb_actor.cpp index 7f167322f..2806d6450 100644 --- a/src/generated/ldb_actor.cpp +++ b/src/generated/ldb_actor.cpp @@ -174,6 +174,13 @@ static TypedField static_class_id( 0, 1 ); +static TypedField static_unknown3A( + &rpg::Actor::unknown3A, + LDB_Reader::ChunkActor::unknown3A, + "unknown3A", + 0, + 1 +); static TypedField static_battle_x( &rpg::Actor::battle_x, LDB_Reader::ChunkActor::battle_x, @@ -202,6 +209,13 @@ static TypedField> static_skills( 1, 0 ); +static TypedField static_unknown40( + &rpg::Actor::unknown40, + LDB_Reader::ChunkActor::unknown40, + "unknown40", + 0, + 1 +); static TypedField static_rename_skill( &rpg::Actor::rename_skill, LDB_Reader::ChunkActor::rename_skill, @@ -275,10 +289,12 @@ Field const* Struct::fields[] = { &static_initial_equipment, &static_unarmed_animation, &static_class_id, + &static_unknown3A, &static_battle_x, &static_battle_y, &static_battler_animation, &static_skills, + &static_unknown40, &static_rename_skill, &static_skill_name, &static_size_state_ranks, diff --git a/src/generated/rpg_actor.cpp b/src/generated/rpg_actor.cpp index e2c155471..5566db32b 100644 --- a/src/generated/rpg_actor.cpp +++ b/src/generated/rpg_actor.cpp @@ -39,6 +39,7 @@ std::ostream& operator<<(std::ostream& os, const Actor& obj) { os << ", initial_equipment="<< obj.initial_equipment; os << ", unarmed_animation="<< obj.unarmed_animation; os << ", class_id="<< obj.class_id; + os << ", unknown3A="<< obj.unknown3A; os << ", battle_x="<< obj.battle_x; os << ", battle_y="<< obj.battle_y; os << ", battler_animation="<< obj.battler_animation; @@ -47,6 +48,7 @@ std::ostream& operator<<(std::ostream& os, const Actor& obj) { os << (i == 0 ? "[" : ", ") << obj.skills[i]; } os << "]"; + os << ", unknown40="<< obj.unknown40; os << ", rename_skill="<< obj.rename_skill; os << ", skill_name="<< obj.skill_name; os << ", state_ranks=";