Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add leather addon #1720

Draft
wants to merge 26 commits into
base: master
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
2b08623
Adding ware workflow, buildings and menus for leather addon
ottml Dec 1, 2024
327aba1
Fix formatting
ottml Dec 1, 2024
56790b6
Add distribution tab for ham and make gui more general
ottml Dec 1, 2024
131f464
Add compatibilty code
ottml Dec 1, 2024
dddc893
Add direct transport route
ottml Dec 1, 2024
94f5625
Add fixed animations from leather_bobs.lst
ottml Dec 1, 2024
4c45d10
Skinner goes out to get skins from carcass if he has no pigs (natural…
ottml Dec 7, 2024
245cb1b
LeatherAddon military (1): Add SetArmorAllowed game command
ottml Dec 8, 2024
f0adbcf
fixup! Skinner goes out to get skins from carcass if he has no pigs (…
ottml Dec 8, 2024
4173c08
LeatherAddon military (2): Add logic for armor in military building a…
ottml Dec 8, 2024
264b5d6
LeatherAddon military (3): Add armor gui elements to military building
ottml Dec 8, 2024
817e3c1
fixup! LeatherAddon military (2): Add logic for armor in military bui…
ottml Dec 8, 2024
727adb9
Add test for SetArmorAllowed
ottml Dec 8, 2024
c0546ba
fixup! Add compatibilty code
ottml Dec 8, 2024
70485bb
Add compatibility code for ChangeDistribution and increase game comma…
ottml Dec 8, 2024
fb8639d
fixup! Adding ware workflow, buildings and menus for leather addon
ottml Dec 8, 2024
ea18d5f
fixup! Adding ware workflow, buildings and menus for leather addon
ottml Dec 8, 2024
0340c20
fixup! Add fixed animations from leather_bobs.lst
ottml Dec 10, 2024
55c25c8
fixup! Skinner goes out to get skins from carcass if he has no pigs (…
ottml Dec 10, 2024
0ceb01c
fixup! LeatherAddon military (2): Add logic for armor in military bui…
ottml Dec 11, 2024
592231a
fixup! Adding ware workflow, buildings and menus for leather addon
ottml Dec 11, 2024
1e7cea9
fixup! LeatherAddon military (2): Add logic for armor in military bui…
ottml Dec 11, 2024
f5db3a7
fixup! Add fixed animations from leather_bobs.lst
ottml Dec 11, 2024
de07029
fixup! Adding ware workflow, buildings and menus for leather addon
ottml Dec 14, 2024
8d77cd3
fixup! Add fixed animations from leather_bobs.lst
ottml Dec 14, 2024
1b8743f
fixup! Adding ware workflow, buildings and menus for leather addon
ottml Dec 14, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Binary file added data/RTTR/assets/addons/0x01000001/AFR_ICON.LST
Binary file not shown.
Binary file added data/RTTR/assets/addons/0x01000001/AFR_Z.LST
Binary file not shown.
Binary file added data/RTTR/assets/addons/0x01000001/JAP_ICON.LST
Binary file not shown.
Binary file added data/RTTR/assets/addons/0x01000001/JAP_Z.LST
Binary file not shown.
Binary file added data/RTTR/assets/addons/0x01000001/ROM_ICON.LST
Binary file not shown.
Binary file added data/RTTR/assets/addons/0x01000001/ROM_Z.LST
Binary file not shown.
Binary file added data/RTTR/assets/addons/0x01000001/VIK_ICON.LST
Binary file not shown.
Binary file added data/RTTR/assets/addons/0x01000001/VIK_Z.LST
Binary file not shown.
Binary file added data/RTTR/assets/addons/0x01000001/WAFR_Z.LST
Binary file not shown.
Binary file added data/RTTR/assets/addons/0x01000001/WJAP_Z.LST
Binary file not shown.
Binary file added data/RTTR/assets/addons/0x01000001/WROM_Z.LST
Binary file not shown.
Binary file added data/RTTR/assets/addons/0x01000001/WVIK_Z.LST
Binary file not shown.
Binary file added data/RTTR/assets/addons/0x01000001/bab_icon.lst
Binary file not shown.
Binary file added data/RTTR/assets/addons/0x01000001/bab_z.lst
Binary file not shown.
Binary file added data/RTTR/assets/addons/0x01000001/wbab_z.lst
Binary file not shown.
Binary file added data/RTTR/assets/base/leather_bobs.lst
Binary file not shown.
3 changes: 2 additions & 1 deletion libs/s25main/GlobalGameSettings.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,8 @@ void GlobalGameSettings::registerAllAddons()
AddonToolOrdering,
AddonTrade,
AddonAutoFlags,
AddonWine
AddonWine,
AddonLeather
>;
// clang-format on
using namespace boost::mp11;
Expand Down
89 changes: 89 additions & 0 deletions libs/s25main/LeatherLoader.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
// Copyright (C) 2024 Settlers Freaks (sf-team at siedler25.org)
//
// SPDX-License-Identifier: GPL-2.0-or-later

///////////////////////////////////////////////////////////////////////////////

#include "LeatherLoader.h"
#include "GlobalGameSettings.h"
#include "Loader.h"
#include "addons/const_addons.h"
#include "ogl/glArchivItem_Bitmap.h"
#include "ogl/glTexturePacker.h"
#include "world/GameWorldBase.h"

namespace leatheraddon {

bool isLeatherAddonBuildingType(BuildingType bld)
{
return bld == BuildingType::Skinner || bld == BuildingType::Tannery || bld == BuildingType::LeatherWorks;
}

bool isLeatherAddonGoodType(GoodType good)
{
return good == GoodType::Skins || good == GoodType::Leather || good == GoodType::Armor;
}

bool isLeatherAddonJobType(Job job)
{
return job == Job::Skinner || job == Job::Tanner || job == Job::LeatherWorker;
}

helpers::EnumArray<unsigned, BobTypes> bobIndex = {0, 21, 69, 117, 125, 173, 189, 222, 270, 286, 293,
301, 307, 313, 336, 354, 355, 356, 356, 357, 357, 358,
359, 360, 361, 362, 363, 364, 365, 366, 367, 368, 369};

ITexture* GetWareTex(const GoodType good)
{
switch(good)
{
case GoodType::Skins: return LOADER.GetImageN("leather_bobs", bobIndex[BobTypes::SKINS_WARE_ICON]);
case GoodType::Leather: return LOADER.GetImageN("leather_bobs", bobIndex[BobTypes::LEATHER_WARE_ICON]);
case GoodType::Armor: return LOADER.GetImageN("leather_bobs", bobIndex[BobTypes::ARMOR_WARE_ICON]);
default: return nullptr;
}
}

ITexture* GetWareStackTex(const GoodType good)
{
switch(good)
{
case GoodType::Skins: return LOADER.GetImageN("leather_bobs", bobIndex[BobTypes::SKINS_WARE_ON_GROUND_OF_FLAG]);
case GoodType::Leather:
return LOADER.GetImageN("leather_bobs", bobIndex[BobTypes::LEATHER_WARE_ON_GROUND_OF_FLAG]);
case GoodType::Armor: return LOADER.GetImageN("leather_bobs", bobIndex[BobTypes::ARMOR_WARE_ON_GROUND_OF_FLAG]);
default: return nullptr;
}
}

ITexture* GetWareDonkeyTex(const GoodType good)
{
switch(good)
{
case GoodType::Skins:
return LOADER.GetImageN("leather_bobs", bobIndex[BobTypes::DONKEY_BOAT_CARRYING_SKINS_WARE]);
case GoodType::Leather:
return LOADER.GetImageN("leather_bobs", bobIndex[BobTypes::DONKEY_BOAT_CARRYING_LEATHER_WARE]);
case GoodType::Armor:
return LOADER.GetImageN("leather_bobs", bobIndex[BobTypes::DONKEY_BOAT_CARRYING_ARMOR_WARE]);
default: return nullptr;
}
}

ITexture* GetJobTex(Job job)
{
switch(job)
{
case Job::Skinner: return LOADER.GetImageN("leather_bobs", bobIndex[BobTypes::SKINNER_JOB_ICON]);
case Job::Tanner: return LOADER.GetImageN("leather_bobs", bobIndex[BobTypes::TANNER_JOB_ICON]);
case Job::LeatherWorker: return LOADER.GetImageN("leather_bobs", bobIndex[BobTypes::LEATHERWORKER_JOB_ICON]);
default: return nullptr;
}
}

bool isAddonActive(const GameWorldBase& gwb)
{
return gwb.GetGGS().isEnabled(AddonId::LEATHER);
}

} // namespace leatheraddon
74 changes: 74 additions & 0 deletions libs/s25main/LeatherLoader.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
// Copyright (C) 2024 Settlers Freaks (sf-team at siedler25.org)
//
// SPDX-License-Identifier: GPL-2.0-or-later

///////////////////////////////////////////////////////////////////////////////
#pragma once

#include "helpers/EnumArray.h"
#include "ogl/glSmartBitmap.h"
#include "gameTypes/BuildingType.h"
#include "gameTypes/GoodTypes.h"
#include "gameTypes/JobTypes.h"

class glArchivItem_Bitmap;
class glTexturePacker;
class GameWorldBase;

namespace leatheraddon {

bool isLeatherAddonBuildingType(BuildingType bld);
bool isLeatherAddonGoodType(GoodType good);
bool isLeatherAddonJobType(Job job);

enum class BobTypes
{
SKINNER_SKINNING_ANIMAL_CARCASS_ANIMATION,
SKINNER_WALKING,
SKINNER_CARRYING_SKINS,
TANNERY_WORK_WINDOW_ANIMATION,
TANNER_WALKING,
TANNER_CARRYING_LEATHER_IN_OUT,
LEATHERWORKS_WORK_WINDOW_ANIMATION,
LEATHERWORKER_WALKING,
LEATHERWORKER_CARRYING_ARMOR_IN_OUT,
THIN_CARRIER_CARRYING_SKINS,
FAT_CARRIER_CARRYING_SKINS,
THIN_CARRIER_CARRYING_LEATHER,
FAT_CARRIER_CARRYING_LEATHER,
THIN_CARRIER_CARRYING_ARMOR,
FAT_CARRIER_CARRYING_ARMOR,
DISTRIBUTION_OF_PIGS_ICON,
SKINS_WARE_ICON,
LEATHER_WARE_ICON,
LEATHERWORKING_WARES_TRANSPORT_PRIORITY_TREE_ICON,
ARMOR_WARE_ICON,
ARMOR_DELIVER_ICON,
DISABLE_DELIVERY_ARMOR_ICON,
SKINNER_JOB_ICON,
TANNER_JOB_ICON,
LEATHERWORKER_JOB_ICON,
SKINS_WARE_ON_GROUND_OF_FLAG,
DONKEY_BOAT_CARRYING_SKINS_WARE,
LEATHER_WARE_ON_GROUND_OF_FLAG,
DONKEY_BOAT_CARRYING_LEATHER_WARE,
ARMOR_WARE_ON_GROUND_OF_FLAG,
DONKEY_BOAT_CARRYING_ARMOR_WARE,
STOP_COINS_X_SIGN_OVERRIDE,
STOP_ARMOR_X_SIGN
};

constexpr auto maxEnumValue(BobTypes)
{
return BobTypes::STOP_ARMOR_X_SIGN;
}

extern helpers::EnumArray<unsigned, BobTypes> bobIndex;

ITexture* GetWareTex(GoodType good);
ITexture* GetWareStackTex(GoodType good);
ITexture* GetWareDonkeyTex(GoodType good);
ITexture* GetJobTex(Job job);
bool isAddonActive(const GameWorldBase& gwb);

} // namespace leatheraddon
31 changes: 31 additions & 0 deletions libs/s25main/Loader.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
///////////////////////////////////////////////////////////////////////////////

#include "Loader.h"
#include "LeatherLoader.h"
#include "ListDir.h"
#include "RttrConfig.h"
#include "Settings.h"
Expand Down Expand Up @@ -185,6 +186,8 @@ ITexture* Loader::GetWareTex(GoodType ware)
{
if(wineaddon::isWineAddonGoodType(ware))
return wineaddon::GetWareTex(ware);
else if(leatheraddon::isLeatherAddonGoodType(ware))
return leatheraddon::GetWareTex(ware);
else
return GetMapTexture(WARES_TEX_MAP_OFFSET + rttr::enum_cast(ware));
}
Expand All @@ -193,6 +196,8 @@ ITexture* Loader::GetWareStackTex(GoodType ware)
{
if(wineaddon::isWineAddonGoodType(ware))
return wineaddon::GetWareStackTex(ware);
else if(leatheraddon::isLeatherAddonGoodType(ware))
return leatheraddon::GetWareStackTex(ware);
else
return GetMapTexture(WARE_STACK_TEX_MAP_OFFSET + rttr::enum_cast(ware));
}
Expand All @@ -201,6 +206,8 @@ ITexture* Loader::GetWareDonkeyTex(GoodType ware)
{
if(wineaddon::isWineAddonGoodType(ware))
return wineaddon::GetWareDonkeyTex(ware);
if(leatheraddon::isLeatherAddonGoodType(ware))
return leatheraddon::GetWareDonkeyTex(ware);
else
return GetMapTexture(WARES_DONKEY_TEX_MAP_OFFSET + rttr::enum_cast(ware));
}
Expand All @@ -209,6 +216,8 @@ ITexture* Loader::GetJobTex(Job job)
{
if(wineaddon::isWineAddonJobType(job))
return wineaddon::GetJobTex(job);
else if(leatheraddon::isLeatherAddonJobType(job))
return leatheraddon::GetJobTex(job);
else
return (job == Job::CharBurner) ? GetTextureN("io_new", 5) : GetMapTexture(2300 + rttr::enum_cast(job));
}
Expand Down Expand Up @@ -512,6 +521,9 @@ bool Loader::LoadFilesAtGame(const std::string& mapGfxPath, bool isWinterGFX, co
if(!LoadResources({"wine_bobs"}))
return false;

if(!LoadResources({"leather_bobs"}))
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is it possible to condition those on the enabled addons? Feels wasteful but maybe the remaining code can't handle those to not be present?

The idea was also to integrate those with the "regular" files and have them be loaded automatically if the addon is enable (see the above TODO and initResourceFolders (addon argument)). Do you see any sensible archive for that?

return false;

const bfs::path mapGFXFile = config_.ExpandPath(mapGfxPath);
if(!Load(mapGFXFile, pal5))
return false;
Expand Down Expand Up @@ -875,6 +887,7 @@ void Loader::fillCaches()
throw std::runtime_error("carrier not found");

libsiedler2::Archiv wine_bob_carrier = GetArchive("wine_bobs");
libsiedler2::Archiv leather_bob_carrier = GetArchive("leather_bobs");

for(bool fat : {true, false})
{
Expand Down Expand Up @@ -907,6 +920,24 @@ void Loader::fillCaches()
wineaddon::bobIndex[fat ? wineaddon::BobTypes::FAT_CARRIER_CARRYING_WINE :
wineaddon::BobTypes::THIN_CARRIER_CARRYING_WINE]
+ static_cast<unsigned>(imgDir))));
} else if(leatheraddon::isLeatherAddonGoodType(ware))
{
leatheraddon::BobTypes carrierEnum;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Could this be an extra function (leather ware->leather bob index)? I'd also suggest an assertion as it currently isn't directly clear, that carrierEnum will always be initialized

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

done

if(ware == GoodType::Skins)
carrierEnum = fat ? leatheraddon::BobTypes::FAT_CARRIER_CARRYING_SKINS :
leatheraddon::BobTypes::THIN_CARRIER_CARRYING_SKINS;

if(ware == GoodType::Leather)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Those should be else-ifs for better readability

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

done

carrierEnum = fat ? leatheraddon::BobTypes::FAT_CARRIER_CARRYING_LEATHER :
leatheraddon::BobTypes::THIN_CARRIER_CARRYING_LEATHER;

if(ware == GoodType::Armor)
carrierEnum = fat ? leatheraddon::BobTypes::FAT_CARRIER_CARRYING_ARMOR :
leatheraddon::BobTypes::THIN_CARRIER_CARRYING_ARMOR;

bmp.add(dynamic_cast<glArchivItem_Bitmap_Player*>(bob_carrier->getBody(fat, imgDir, ani_step)));
bmp.add(dynamic_cast<glArchivItem_Bitmap_Player*>(leather_bob_carrier.get(
leatheraddon::bobIndex[carrierEnum] + static_cast<unsigned>(imgDir))));
} else
{
bmp.add(dynamic_cast<glArchivItem_Bitmap_Player*>(bob_carrier->getBody(fat, imgDir, ani_step)));
Expand Down
8 changes: 8 additions & 0 deletions libs/s25main/SerializedGameData.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@
#include "figures/nofGeologist.h"
#include "figures/nofHunter.h"
#include "figures/nofIronfounder.h"
#include "figures/nofLeatherWorker.h"
#include "figures/nofMetalworker.h"
#include "figures/nofMiller.h"
#include "figures/nofMiner.h"
Expand All @@ -51,7 +52,9 @@
#include "figures/nofScout_Free.h"
#include "figures/nofScout_LookoutTower.h"
#include "figures/nofShipWright.h"
#include "figures/nofSkinner.h"
#include "figures/nofStonemason.h"
#include "figures/nofTanner.h"
#include "figures/nofTempleServant.h"
#include "figures/nofTradeDonkey.h"
#include "figures/nofTradeLeader.h"
Expand Down Expand Up @@ -102,6 +105,7 @@
/// 9: Drop serialization of node BQ
/// 10: troop_limits state introduced to military buildings
/// 11:: wineaddon added, three new building types and two new goods
/// 12:: leatheraddon added, three new building types and three new goods
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Increase version below too

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Added compat code and increased version :)

static const unsigned currentGameDataVersion = 11;
// clang-format on

Expand Down Expand Up @@ -180,6 +184,10 @@ std::unique_ptr<GameObject> SerializedGameData::Create_GameObject(const GO_Type
RTTR_CREATE_GO(GO_Type::NofTempleservant, nofTempleServant);
RTTR_CREATE_GO(GO_Type::Grapefield, noGrapefield);
RTTR_CREATE_GO(GO_Type::NobTemple, nobTemple);
RTTR_CREATE_GO(GO_Type::NofSkinner, nofSkinner);
RTTR_CREATE_GO(GO_Type::NofTanner, nofTanner);
RTTR_CREATE_GO(GO_Type::NofLeatherWorker, nofLeatherWorker);

case GO_Type::Nothing: RTTR_Assert(false); break;
#undef RTTR_CREATE_GO
}
Expand Down
3 changes: 3 additions & 0 deletions libs/s25main/Ware.h
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,7 @@ class Ware : public GameObject
{
switch(value)
{
case GoodType::Armor: return ("GoodType::Armor");
case GoodType::Axe: return ("GoodType::Axe");
case GoodType::Beer: return ("GoodType::Beer");
case GoodType::Boards: return ("GoodType::Boards");
Expand All @@ -132,6 +133,7 @@ class Ware : public GameObject
case GoodType::Hammer: return ("GoodType::Hammer");
case GoodType::Iron: return ("GoodType::Iron");
case GoodType::IronOre: return ("GoodType::IronOre");
case GoodType::Leather: return ("GoodType::Leather");
case GoodType::Meat: return ("GoodType::Meat");
case GoodType::Nothing: return ("GoodType::Nothing");
case GoodType::PickAxe: return ("GoodType::PickAxe");
Expand All @@ -144,6 +146,7 @@ class Ware : public GameObject
case GoodType::ShieldRomans: return ("GoodType::ShieldRomans");
case GoodType::ShieldVikings: return ("GoodType::ShieldVikings");
case GoodType::Shovel: return ("GoodType::Shovel");
case GoodType::Skins: return ("GoodType::Skins");
case GoodType::Stones: return ("GoodType::Stones");
case GoodType::Sword: return ("GoodType::Sword");
case GoodType::Tongs: return ("GoodType::Tongs");
Expand Down
20 changes: 20 additions & 0 deletions libs/s25main/addons/AddonLeather.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
// Copyright (C) 2024 Settlers Freaks (sf-team at siedler25.org)
//
// SPDX-License-Identifier: GPL-2.0-or-later

#pragma once

#include "AddonBool.h"
#include "mygettext/mygettext.h"

/**
* Addon for a leather industry
*/
class AddonLeather : public AddonBool
{
public:
AddonLeather()
: AddonBool(AddonId::LEATHER, AddonGroup::Economy, _("Enable leather economy"),
_("Allows to build the leather economy buildings."))
{}
};
1 change: 1 addition & 0 deletions libs/s25main/addons/Addons.h
Original file line number Diff line number Diff line change
Expand Up @@ -61,4 +61,5 @@

#include "addons/AddonAutoFlags.h"

#include "addons/AddonLeather.h"
#include "addons/AddonWine.h"
2 changes: 1 addition & 1 deletion libs/s25main/addons/const_addons.h
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ ENUM_WITH_STRING(AddonId, LIMIT_CATAPULTS = 0x00000000, INEXHAUSTIBLE_MINES = 0x

AUTOFLAGS = 0x00F00000,

WINE = 0x01000000)
WINE = 0x01000000, LEATHER = 0x01000001)
//-V:AddonId:801

enum class AddonGroup : unsigned
Expand Down
14 changes: 9 additions & 5 deletions libs/s25main/ai/aijh/AIPlayerJH.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2112,12 +2112,16 @@ void AIPlayerJH::InitDistribution()
goodSettings[18] = 10; // boards new buildings
goodSettings[19] = 4; // boards metalworks
goodSettings[20] = 2; // boards shipyard
goodSettings[21] = 1; // boards tannery

goodSettings[21] = 10; // water bakery
goodSettings[22] = 10; // water brewery
goodSettings[23] = 10; // water pigfarm
goodSettings[24] = 10; // water donkeybreeder
goodSettings[25] = 2; // water vineyard
goodSettings[22] = 10; // water bakery
goodSettings[23] = 10; // water brewery
goodSettings[24] = 10; // water pigfarm
goodSettings[25] = 10; // water donkeybreeder
goodSettings[26] = 2; // water vineyard

goodSettings[27] = 8; // ham slaughterhouse
goodSettings[28] = 3; // ham skinner
aii.ChangeDistribution(goodSettings);
}

Expand Down
Loading
Loading