]> git.localhorst.tv Git - l2e.git/blobdiff - src/menu/Resources.cpp
added fallback for string resources
[l2e.git] / src / menu / Resources.cpp
index 79aecf6ea1f424df934a2118cf87631f46f908fa..f7df71e61ee31264f6393d6e456a06e6e114e7cc 100644 (file)
@@ -1,5 +1,6 @@
 #include "Resources.h"
 
+#include "../graphics/CharSelect.h"
 #include "../graphics/Font.h"
 #include "../graphics/Frame.h"
 #include "../graphics/Menu.h"
@@ -8,6 +9,7 @@
 #include "../loader/Interpreter.h"
 #include "../loader/TypeDescription.h"
 
+using graphics::CharSelect;
 using graphics::Font;
 using graphics::Frame;
 using graphics::MenuProperties;
@@ -29,46 +31,49 @@ Resources::Resources()
 , statusFrame(0)
 
 , mainMenuProperties(0)
-, mainMenuItemText(0)
-, mainMenuSpellText(0)
-, mainMenuCapsuleText(0)
-, mainMenuEquipmentText(0)
-, mainMenuStatusText(0)
-, mainMenuChangeText(0)
-, mainMenuConfigText(0)
-, mainMenuScenarioText(0)
-
-, mainMenuTimeText(0)
-, mainMenuGoldText(0)
+, mainMenuItemText("MISSING TRANSLATION")
+, mainMenuSpellText("MISSING TRANSLATION")
+, mainMenuCapsuleText("MISSING TRANSLATION")
+, mainMenuEquipmentText("MISSING TRANSLATION")
+, mainMenuStatusText("MISSING TRANSLATION")
+, mainMenuChangeText("MISSING TRANSLATION")
+, mainMenuConfigText("MISSING TRANSLATION")
+, mainMenuScenarioText("MISSING TRANSLATION")
+
+, mainMenuTimeText("MISSING TRANSLATION")
+, mainMenuGoldText("MISSING TRANSLATION")
 
 , heroCursor(0)
 , heroCursorBlinkTime(0)
 
-, noEquipmentText(0)
+, noEquipmentText("MISSING TRANSLATION")
 
 , shoulderNav(0)
 
-, atpLabel(0)
-, dfpLabel(0)
-, strLabel(0)
-, aglLabel(0)
-, intLabel(0)
-, gutLabel(0)
-, mgrLabel(0)
+, atpLabel("MISSING TRANSLATION")
+, dfpLabel("MISSING TRANSLATION")
+, strLabel("MISSING TRANSLATION")
+, aglLabel("MISSING TRANSLATION")
+, intLabel("MISSING TRANSLATION")
+, gutLabel("MISSING TRANSLATION")
+, mgrLabel("MISSING TRANSLATION")
 
-, ipLabel(0)
-, experienceLabel(0)
-, nextLevelLabel(0)
+, hpLabel("MISSING TRANSLATION")
+, ipLabel("MISSING TRANSLATION")
+, levelLabel("MISSING TRANSLATION")
+, experienceLabel("MISSING TRANSLATION")
+, nextLevelLabel("MISSING TRANSLATION")
 
 , statusMenuProperties(0)
 
-, nextLabel(0)
-, returnLabel(0)
+, nextLabel("MISSING TRANSLATION")
+, returnLabel("MISSING TRANSLATION")
 
 , itemMenuProperties(0)
-, itemMenuUseText(0)
-, itemMenuSortText(0)
-, itemMenuDropText(0)
+, itemMenuUseText("MISSING TRANSLATION")
+, itemMenuSortText("MISSING TRANSLATION")
+, itemMenuDropText("MISSING TRANSLATION")
+, itemMenuSelectText("MISSING TRANSLATION")
 
 , inventoryMenuProperties(0)
 
@@ -76,27 +81,64 @@ Resources::Resources()
 
 , equipmentActionMenuProperties(0)
 , equipmentMenuProperties(0)
-, equipMenuEquipLabel(0)
-, equipMenuStrongestLabel(0)
-, equipMenuRemoveLabel(0)
-, equipMenuRemoveAllLabel(0)
-, equipMenuDropLabel(0)
+, equipMenuEquipLabel("MISSING TRANSLATION")
+, equipMenuStrongestLabel("MISSING TRANSLATION")
+, equipMenuRemoveLabel("MISSING TRANSLATION")
+, equipMenuRemoveAllLabel("MISSING TRANSLATION")
+, equipMenuDropLabel("MISSING TRANSLATION")
 
 , configMenuProperties(0)
-, configMessageSpeedLabel(0)
-, configMessageSpeedFast(0)
-, configMessageSpeedNormal(0)
-, configMessageSpeedSlow(0)
-, configBattleCursorLabel(0)
-, configStatusCursorLabel(0)
-, configCursorClear(0)
-, configCursorMemory(0)
-, configMusicLabel(0)
-, configMusicStereo(0)
-, configMusicMono(0)
+, configMessageSpeedLabel("MISSING TRANSLATION")
+, configMessageSpeedFast("MISSING TRANSLATION")
+, configMessageSpeedNormal("MISSING TRANSLATION")
+, configMessageSpeedSlow("MISSING TRANSLATION")
+, configBattleCursorLabel("MISSING TRANSLATION")
+, configStatusCursorLabel("MISSING TRANSLATION")
+, configCursorClear("MISSING TRANSLATION")
+, configCursorMemory("MISSING TRANSLATION")
+, configMusicLabel("MISSING TRANSLATION")
+, configMusicStereo("MISSING TRANSLATION")
+, configMusicMono("MISSING TRANSLATION")
 
 , scenarioMenuProperties(0)
-, scenarioMenuHeadline(0)
+, scenarioMenuHeadline("MISSING TRANSLATION")
+
+, capsulebg(0)
+
+, capsuleMenuProperties(0)
+, capsuleFeedMenuProperties(0)
+
+, capsuleFeedLabel("MISSING TRANSLATION")
+, capsuleChangeLabel("MISSING TRANSLATION")
+, capsuleNameLabel("MISSING TRANSLATION")
+, capsuleClassLabel("MISSING TRANSLATION")
+, capsuleAlignmentLabel("MISSING TRANSLATION")
+, capsuleTribeLabel("MISSING TRANSLATION")
+, capsuleAttack1Label("MISSING TRANSLATION")
+, capsuleAttack2Label("MISSING TRANSLATION")
+, capsuleAttack3Label("MISSING TRANSLATION")
+, capsuleNoAttackText("MISSING TRANSLATION")
+, capsuleNotHungryText("MISSING TRANSLATION")
+
+, capsuleNameCharSelectTemplate(0)
+
+, capsuleSelectTopLeft(0)
+, capsuleSelectTopRight(0)
+, capsuleSelectTopRepeat(0)
+, capsuleSelectBottomLeft(0)
+, capsuleSelectBottomRight(0)
+, capsuleSelectBottomRepeat(0)
+, capsuleSelectLeftRepeat(0)
+, capsuleSelectRightRepeat(0)
+, capsuleSelectLadder(0)
+, capsuleSelectCursor(0)
+
+, capsuleAlignmentWheel(0)
+, capsuleAlignmentCursor(0)
+
+, capsuleGrowthLabel(0)
+, capsuleGrowthBar(0)
+, capsuleGrowthBarFilled(0)
 
 { }
 
@@ -145,7 +187,9 @@ void Resources::CreateTypeDescription() {
        td.AddField("gutLabel", FieldDescription(((char *)&r.gutLabel) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
        td.AddField("mgrLabel", FieldDescription(((char *)&r.mgrLabel) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
 
+       td.AddField("hpLabel", FieldDescription(((char *)&r.hpLabel) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
        td.AddField("ipLabel", FieldDescription(((char *)&r.ipLabel) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
+       td.AddField("levelLabel", FieldDescription(((char *)&r.levelLabel) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
        td.AddField("experienceLabel", FieldDescription(((char *)&r.experienceLabel) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
        td.AddField("nextLevelLabel", FieldDescription(((char *)&r.nextLevelLabel) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
 
@@ -158,6 +202,7 @@ void Resources::CreateTypeDescription() {
        td.AddField("itemMenuUseText", FieldDescription(((char *)&r.itemMenuUseText) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
        td.AddField("itemMenuSortText", FieldDescription(((char *)&r.itemMenuSortText) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
        td.AddField("itemMenuDropText", FieldDescription(((char *)&r.itemMenuDropText) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
+       td.AddField("itemMenuSelectText", FieldDescription(((char *)&r.itemMenuSelectText) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
 
        td.AddField("inventoryMenu", FieldDescription(((char *)&r.inventoryMenuProperties) - ((char *)&r), MenuProperties::TYPE_ID).SetReferenced().SetDescription("properties of the inventory menu"));
        td.AddField("spellMenu", FieldDescription(((char *)&r.spellMenuProperties) - ((char *)&r), MenuProperties::TYPE_ID).SetReferenced().SetDescription("properties of the spell menu"));
@@ -185,6 +230,43 @@ void Resources::CreateTypeDescription() {
 
        td.AddField("scenarioMenu", FieldDescription(((char *)&r.scenarioMenuProperties) - ((char *)&r), MenuProperties::TYPE_ID).SetReferenced().SetDescription("properties of the scenario menu"));
        td.AddField("scenarioMenuHeadline", FieldDescription(((char *)&r.scenarioMenuHeadline) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
+
+       td.AddField("capsulebg", FieldDescription(((char *)&r.capsulebg) - ((char *)&r), Texture::TYPE_ID).SetReferenced().SetDescription("background texture for the capsule menus"));
+
+       td.AddField("capsuleMenu", FieldDescription(((char *)&r.capsuleMenuProperties) - ((char *)&r), MenuProperties::TYPE_ID).SetReferenced().SetDescription("properties of the capsule main menu (the bottom bar)"));
+       td.AddField("capsuleFeedMenu", FieldDescription(((char *)&r.capsuleFeedMenuProperties) - ((char *)&r), MenuProperties::TYPE_ID).SetReferenced().SetDescription("properties of the capsule feed menu (above the inventory)"));
+
+       td.AddField("capsuleFeedLabel", FieldDescription(((char *)&r.capsuleFeedLabel) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
+       td.AddField("capsuleChangeLabel", FieldDescription(((char *)&r.capsuleChangeLabel) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
+       td.AddField("capsuleNameLabel", FieldDescription(((char *)&r.capsuleNameLabel) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
+       td.AddField("capsuleClassLabel", FieldDescription(((char *)&r.capsuleClassLabel) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
+       td.AddField("capsuleAlignmentLabel", FieldDescription(((char *)&r.capsuleAlignmentLabel) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
+       td.AddField("capsuleTribeLabel", FieldDescription(((char *)&r.capsuleTribeLabel) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
+       td.AddField("capsuleAttack1Label", FieldDescription(((char *)&r.capsuleAttack1Label) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
+       td.AddField("capsuleAttack2Label", FieldDescription(((char *)&r.capsuleAttack2Label) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
+       td.AddField("capsuleAttack3Label", FieldDescription(((char *)&r.capsuleAttack3Label) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
+       td.AddField("capsuleNoAttackText", FieldDescription(((char *)&r.capsuleNoAttackText) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
+       td.AddField("capsuleNotHungryText", FieldDescription(((char *)&r.capsuleNotHungryText) - ((char *)&r), Interpreter::STRING_ID).SetReferenced());
+
+       td.AddField("capsuleNameSelect", FieldDescription(((char *)&r.capsuleNameCharSelectTemplate) - ((char *)&r), CharSelect::TYPE_ID).SetReferenced().SetDescription("properties of the letter array for changing the capsule name"));
+
+       td.AddField("capsuleSelectTopLeft", FieldDescription(((char *)&r.capsuleSelectTopLeft) - ((char *)&r), Sprite::TYPE_ID).SetReferenced());
+       td.AddField("capsuleSelectTopRight", FieldDescription(((char *)&r.capsuleSelectTopRight) - ((char *)&r), Sprite::TYPE_ID).SetReferenced());
+       td.AddField("capsuleSelectTopRepeat", FieldDescription(((char *)&r.capsuleSelectTopRepeat) - ((char *)&r), Sprite::TYPE_ID).SetReferenced());
+       td.AddField("capsuleSelectBottomLeft", FieldDescription(((char *)&r.capsuleSelectBottomLeft) - ((char *)&r), Sprite::TYPE_ID).SetReferenced());
+       td.AddField("capsuleSelectBottomRight", FieldDescription(((char *)&r.capsuleSelectBottomRight) - ((char *)&r), Sprite::TYPE_ID).SetReferenced());
+       td.AddField("capsuleSelectBottomRepeat", FieldDescription(((char *)&r.capsuleSelectBottomRepeat) - ((char *)&r), Sprite::TYPE_ID).SetReferenced());
+       td.AddField("capsuleSelectLeftRepeat", FieldDescription(((char *)&r.capsuleSelectLeftRepeat) - ((char *)&r), Texture::TYPE_ID).SetReferenced());
+       td.AddField("capsuleSelectRightRepeat", FieldDescription(((char *)&r.capsuleSelectRightRepeat) - ((char *)&r), Texture::TYPE_ID).SetReferenced());
+       td.AddField("capsuleSelectLadder", FieldDescription(((char *)&r.capsuleSelectLadder) - ((char *)&r), Sprite::TYPE_ID).SetReferenced());
+       td.AddField("capsuleSelectCursor", FieldDescription(((char *)&r.capsuleSelectCursor) - ((char *)&r), Sprite::TYPE_ID).SetReferenced());
+
+       td.AddField("capsuleAlignmentWheel", FieldDescription(((char *)&r.capsuleAlignmentWheel) - ((char *)&r), Sprite::TYPE_ID).SetReferenced());
+       td.AddField("capsuleAlignmentCursor", FieldDescription(((char *)&r.capsuleAlignmentCursor) - ((char *)&r), Sprite::TYPE_ID).SetReferenced());
+
+       td.AddField("capsuleGrowthLabel", FieldDescription(((char *)&r.capsuleGrowthLabel) - ((char *)&r), Sprite::TYPE_ID).SetReferenced());
+       td.AddField("capsuleGrowthBar", FieldDescription(((char *)&r.capsuleGrowthBar) - ((char *)&r), Sprite::TYPE_ID).SetReferenced());
+       td.AddField("capsuleGrowthBarFilled", FieldDescription(((char *)&r.capsuleGrowthBarFilled) - ((char *)&r), Sprite::TYPE_ID).SetReferenced());
 }
 
 void Resources::Construct(void *data) {