Move git root from Client/ to src/ to track all source code: - Client: Game client source (moved to Client/Client/) - Server: Game server source - GameTools: Development tools - CryptoSource: Encryption utilities - database: Database scripts - Script: Game scripts - rylCoder_16.02.2008_src: Legacy coder tools - GMFont, Game: Additional resources 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
598 lines
16 KiB
C++
598 lines
16 KiB
C++
#include "stdafx.h"
|
|
#include "CastleDB.h"
|
|
|
|
#include <Creature/Siege/SiegeObjectDB.h>
|
|
#include <Creature/Siege/CastleGateDB.h>
|
|
|
|
#include <Community/Guild/GuildDB.h>
|
|
#include <Community/Guild/GuildDBMgr.h>
|
|
|
|
#include <DB/DBComponent.h>
|
|
#include <Castle/CastleDBComponent.h>
|
|
#include <Castle/CastleDBMgr.h>
|
|
#include <GameTime/GameTimeDBMgr.h>
|
|
|
|
#include <Network/Packet/WrapPacket.h>
|
|
#include <Network/Packet/PacketCommand.h>
|
|
#include <Network/Packet/PacketStruct/ServerInfo.h>
|
|
#include <Network/Dispatch/GameDispatch.h>
|
|
|
|
#include <Utility/Setup/ServerSetup.h>
|
|
#include <Log/ServerLog.h>
|
|
|
|
|
|
CCastleDB::CCastleDB(CDBComponent& DBComponent, const CastleInfoDB& CastleInfo)
|
|
: m_dwCastleID(Castle::CASTLE_BIT | CastleInfo.m_dwCastleID),
|
|
m_cNation(CastleInfo.m_cNation),
|
|
m_cZone(CastleInfo.m_cZone),
|
|
m_cChannel(CastleInfo.m_cChannel),
|
|
m_cNameID(CastleInfo.m_cNameID),
|
|
m_cSiegeCount(CastleInfo.m_cSiegeCount),
|
|
m_cInvincibleCount(CastleInfo.m_cInvincibleCount),
|
|
m_wTotalSiegeCount(CastleInfo.m_wTotalSiegeCount),
|
|
m_dwTotalTaxMoney(CastleInfo.m_dwTotalTaxMoney),
|
|
m_wItemID(CastleInfo.m_wItemID),
|
|
m_cItemNum(CastleInfo.m_cItemNum),
|
|
m_bEnableSiege(false),
|
|
m_DBComponent(DBComponent)
|
|
{
|
|
::memcpy(&m_CastleRight, CastleInfo.m_szRight, sizeof(CastleRight));
|
|
|
|
m_BackDoorPos[0] = CastleInfo.m_InPos;
|
|
m_BackDoorPos[1] = CastleInfo.m_OutPos;
|
|
|
|
::memset(&m_CastleTax, 0, sizeof(CastleTaxInfo) * Castle::MAX_TAX_TYPE);
|
|
|
|
CheckEnableSiege( CGameTimeDBMgr::GetInstance().IsSiegeWarTime() );
|
|
}
|
|
|
|
CCastleDB::~CCastleDB()
|
|
{
|
|
|
|
}
|
|
|
|
bool CCastleDB::ChangeCastleMaster(unsigned char cNation)
|
|
{
|
|
m_cNation = cNation;
|
|
m_cSiegeCount = 0;
|
|
m_cInvincibleCount = Castle::INVINCIBLE_COUNT;
|
|
m_wTotalSiegeCount = 0;
|
|
m_dwTotalTaxMoney = 0;
|
|
m_wItemID = 0;
|
|
m_cItemNum = 0;
|
|
|
|
m_bEnableSiege = (m_cInvincibleCount > 0) ? false : true;
|
|
|
|
m_CastleRight = CastleRight();
|
|
::memset(&m_CastleTax, 0, sizeof(CastleTaxInfo) * Castle::MAX_TAX_TYPE);
|
|
m_AccumulatedMineralMap.clear();
|
|
m_TemporaryMineralMap.clear();
|
|
|
|
// DB ¿¡ Á¤º¸ ÀúÀå
|
|
DBComponent::CastleDB::UpdateCastleInfo(m_DBComponent, m_dwCastleID, m_cNation, m_cSiegeCount, m_cInvincibleCount,
|
|
m_wTotalSiegeCount, m_dwTotalTaxMoney, m_wItemID, m_cItemNum);
|
|
DBComponent::CastleDB::DeleteCastleTaxInfo(m_DBComponent, m_dwCastleID);
|
|
DBComponent::CastleDB::DeleteCastleMineralInfo(m_DBComponent, m_dwCastleID);
|
|
DBComponent::CastleDB::UpdateCastleRight(m_DBComponent, m_dwCastleID, reinterpret_cast<char *>(&m_CastleRight), sizeof(CastleRight));
|
|
|
|
// ¼º ¿ÀºêÁ§Æ®µéÀÇ ¼ÒÀ¯ ±¹°¡µéÀ» ¸ðµÎ º¯°æÇÑ´Ù.
|
|
ChangeCastleObjectNation(cNation);
|
|
|
|
// ¼ö¼º º´±â¸¦ º´±â °ü¸® NPC ·Î µ¹·Á³õ´Â´Ù.
|
|
DestroyAllCastleArms();
|
|
|
|
// °ø¼º °¡´É Á¤º¸ º¯°æ Àü¼Û
|
|
CGameTimeDBMgr::GetInstance().SendGameTimeInfo( GetCastleID() );
|
|
return true;
|
|
}
|
|
|
|
bool CCastleDB::InsertCastleObject(CSiegeObjectDB* lpCastleObject)
|
|
{
|
|
if (lpCastleObject)
|
|
{
|
|
lpCastleObject->SetNation(m_cNation);
|
|
lpCastleObject->SetZoneChannel(m_cZone, m_cChannel);
|
|
|
|
return m_CastleObjectMap.insert(std::make_pair(lpCastleObject->GetCID(), lpCastleObject)).second;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
|
|
bool CCastleDB::DeleteCastleObject(unsigned long dwCID)
|
|
{
|
|
return true;
|
|
}
|
|
|
|
bool CCastleDB::DeleteCastleObject(CSiegeObjectDB* lpSiegeObject)
|
|
{
|
|
return true;
|
|
}
|
|
|
|
void CCastleDB::LoseOwnership()
|
|
{
|
|
m_cNation = 0;
|
|
m_cSiegeCount = 0;
|
|
m_cInvincibleCount = 0;
|
|
m_wTotalSiegeCount = 0;
|
|
m_dwTotalTaxMoney = 0;
|
|
m_wItemID = 0;
|
|
m_cItemNum = 0;
|
|
m_bEnableSiege = true;
|
|
|
|
m_CastleRight = CastleRight();
|
|
::memset(&m_CastleTax, 0, sizeof(CastleTaxInfo) * Castle::MAX_TAX_TYPE);
|
|
m_AccumulatedMineralMap.clear();
|
|
m_TemporaryMineralMap.clear();
|
|
|
|
// DB ¾÷µ¥ÀÌÆ®..
|
|
DBComponent::CastleDB::UpdateCastleInfo(m_DBComponent, m_dwCastleID, m_cNation, m_cSiegeCount, m_cInvincibleCount,
|
|
m_wTotalSiegeCount, m_dwTotalTaxMoney, m_wItemID, m_cItemNum);
|
|
DBComponent::CastleDB::DeleteCastleTaxInfo(m_DBComponent, m_dwCastleID);
|
|
DBComponent::CastleDB::DeleteCastleMineralInfo(m_DBComponent, m_dwCastleID);
|
|
DBComponent::CastleDB::UpdateCastleRight(m_DBComponent, m_dwCastleID, reinterpret_cast<char *>(&m_CastleRight), sizeof(CastleRight));
|
|
|
|
// ¼º ¿ÀºêÁ§Æ® Á߸³È
|
|
ChangeCastleObjectNation(0);
|
|
|
|
// ¼ö¼º º´±â¸¦ º´±â °ü¸® NPC ·Î µ¹·Á³õ´Â´Ù.
|
|
DestroyAllCastleArms();
|
|
|
|
// ¼º ¼ÒÀ¯ Á߸³È ¸í·É Àü¼Û
|
|
CSiegeObjectDB* lpEmblem = GetCastleEmblem();
|
|
if (lpEmblem)
|
|
{
|
|
lpEmblem->SendCastleCmd(0, PktCastleCmd::CASTLE_LOSE_OWNERSHIP);
|
|
}
|
|
|
|
// °ø¼º °¡´É Á¤º¸ º¯°æ Àü¼Û
|
|
CGameTimeDBMgr::GetInstance().SendGameTimeInfo( GetCastleID() );
|
|
}
|
|
|
|
void CCastleDB::CloseCastleGate()
|
|
{
|
|
CSiegeObjectDB* lpGate = GetCastleGate();
|
|
if (lpGate)
|
|
{
|
|
// HP ¸¦ Full ·Î Çϴ°ÍÀº °ÔÀÓ ¼¹ö¿¡¼ ¾ó¸¶·Î ä¿ï°ÍÀÎÁö º¸³»ÁØ´Ù.
|
|
static_cast<CCastleGateDB* >(lpGate)->ForceClose();
|
|
}
|
|
}
|
|
|
|
void CCastleDB::OpenCastleGate()
|
|
{
|
|
CSiegeObjectDB* lpGate = GetCastleGate();
|
|
if (lpGate)
|
|
{
|
|
// HP ¸¦ Full ·Î Çϴ°ÍÀº °ÔÀÓ ¼¹ö¿¡¼ ¾ó¸¶·Î ä¿ï°ÍÀÎÁö º¸³»ÁØ´Ù.
|
|
static_cast<CCastleGateDB* >(lpGate)->ForceOpen();
|
|
}
|
|
}
|
|
|
|
void CCastleDB::ChangeCastleObjectNation(unsigned char cNation)
|
|
{
|
|
CastleObjectMap::iterator itr = m_CastleObjectMap.begin();
|
|
CastleObjectMap::iterator end = m_CastleObjectMap.end();
|
|
|
|
CSiegeObjectDB* lpCastleObject = NULL;
|
|
while (itr != end)
|
|
{
|
|
lpCastleObject = itr->second;
|
|
if (lpCastleObject)
|
|
{
|
|
lpCastleObject->SetNation(cNation);
|
|
}
|
|
|
|
++itr;
|
|
}
|
|
}
|
|
|
|
void CCastleDB::DestroyAllCastleArms()
|
|
{
|
|
CastleObjectMap::iterator itr = m_CastleObjectMap.begin();
|
|
CastleObjectMap::iterator end = m_CastleObjectMap.end();
|
|
|
|
CSiegeObjectDB* lpCastleObject = NULL;
|
|
while (itr != end)
|
|
{
|
|
lpCastleObject = itr->second;
|
|
if (lpCastleObject && lpCastleObject->IsCastleArms())
|
|
{
|
|
lpCastleObject->Destroy(); // ¼ö¼º º´±âµéÀº º´±â °ü¸® NPC ·Î µ¹·Á³õ´Â´Ù.
|
|
|
|
// Áß°è¼¹ö¿¡¼ ÆÄ±«µÈ °¢ÀÚÀÇ ÆÐŶÀ» º¸³»Áö ¾Ê°í,
|
|
// Áß°è¼¹ö¿Í °ÔÀÓ¼¹ö°¡ °¢ÀÚ Ã³¸®Çϵµ·Ï ÇØ³õ¾ÒÀ½..
|
|
//lpCastleObject->SendCastleCmd(0, PktCastleCmd::CASTLE_DESTROY_ARMS);
|
|
}
|
|
|
|
++itr;
|
|
}
|
|
}
|
|
|
|
CSiegeObjectDB* CCastleDB::GetCastleEmblem()
|
|
{
|
|
CastleObjectMap::iterator itr = m_CastleObjectMap.begin();
|
|
CSiegeObjectDB* lpCastleObject = NULL;
|
|
|
|
while (itr != m_CastleObjectMap.end())
|
|
{
|
|
lpCastleObject = itr->second;
|
|
if (lpCastleObject && lpCastleObject->IsEmblem())
|
|
{
|
|
return lpCastleObject;
|
|
}
|
|
|
|
++itr;
|
|
}
|
|
|
|
return NULL;
|
|
}
|
|
|
|
CSiegeObjectDB* CCastleDB::GetCastleGate()
|
|
{
|
|
CastleObjectMap::iterator itr = m_CastleObjectMap.begin();
|
|
CSiegeObjectDB* lpCastleObject = NULL;
|
|
|
|
while (itr != m_CastleObjectMap.end())
|
|
{
|
|
lpCastleObject = itr->second;
|
|
if (lpCastleObject && lpCastleObject->IsGate())
|
|
{
|
|
return lpCastleObject;
|
|
}
|
|
|
|
++itr;
|
|
}
|
|
|
|
return NULL;
|
|
}
|
|
|
|
CSiegeObjectDB* CCastleDB::GetCastleObject(unsigned long dwCastleObjectID)
|
|
{
|
|
CastleObjectMap::iterator itr = m_CastleObjectMap.find(dwCastleObjectID);
|
|
if (itr != m_CastleObjectMap.end()) return itr->second;
|
|
|
|
return NULL;
|
|
}
|
|
|
|
void CCastleDB::CheckEnableSiege(bool bIsSiegeTime)
|
|
{
|
|
if (bIsSiegeTime == m_bEnableSiege)
|
|
{
|
|
return;
|
|
}
|
|
|
|
m_bEnableSiege = false;
|
|
if (bIsSiegeTime && 0 == m_cInvincibleCount)
|
|
{
|
|
m_bEnableSiege = true;
|
|
}
|
|
}
|
|
|
|
|
|
void CCastleDB::UpdateSiegeCount()
|
|
{
|
|
SERVER_ID serverID;
|
|
serverID.sID.Type = CServerSetup::GameServer;
|
|
serverID.sID.Group = CServerSetup::GetInstance().GetServerGroup();
|
|
serverID.sID.Channel = m_cChannel;
|
|
serverID.sID.ID = m_cZone;
|
|
|
|
GET_MULTI_DISPATCH(lpGameDispatch, serverID.dwID,
|
|
DBAgent::CGameDispatch, DBAgent::CGameDispatch::GetDispatchTable());
|
|
|
|
if (m_bEnableSiege)
|
|
{
|
|
++m_wTotalSiegeCount;
|
|
}
|
|
|
|
if (m_cInvincibleCount)
|
|
{
|
|
--m_cInvincibleCount;
|
|
}
|
|
|
|
++m_cSiegeCount;
|
|
if (m_cSiegeCount >= Castle::TEMP_TAX_GAIN_COUNT)
|
|
{
|
|
m_cSiegeCount = 0;
|
|
unsigned long dwMoveTempMoney[ Castle::MAX_TAX_TYPE ] = { 0, };
|
|
|
|
for (int i=0; i<Castle::MAX_TAX_TYPE; ++i)
|
|
{
|
|
dwMoveTempMoney[ i ] = m_CastleTax[ i ].m_dwTempTaxMoney;
|
|
m_CastleTax[ i ].m_dwTaxMoney += m_CastleTax[ i ].m_dwTempTaxMoney;
|
|
m_CastleTax[ i ].m_dwTempTaxMoney = 0;
|
|
|
|
// DB ¾÷µ¥ÀÌÆ®
|
|
DBComponent::CastleDB::UpdateCastleTaxMoney(m_DBComponent, m_dwCastleID, i, m_CastleTax[ i ].m_dwTempTaxMoney, m_CastleTax[ i ].m_dwTaxMoney);
|
|
}
|
|
|
|
// ´©Àû ¼¼±Ý Á¤º¸ Àü¼Û
|
|
if (NULL != lpGameDispatch)
|
|
{
|
|
CSendStream& SendStream = lpGameDispatch->GetSendStream();
|
|
|
|
char* lpBuffer = SendStream.GetBuffer(sizeof(PktCastleTaxMove));
|
|
if (NULL != lpBuffer)
|
|
{
|
|
PktCastleTaxMove* lpPktCastleTaxMove = reinterpret_cast<PktCastleTaxMove*>(lpBuffer);
|
|
|
|
lpPktCastleTaxMove->m_dwCastleID = m_dwCastleID;
|
|
for (int j=0; j<Castle::MAX_TAX_TYPE; ++j)
|
|
{
|
|
lpPktCastleTaxMove->m_dwMoveTempMoney[ j ] = dwMoveTempMoney[ j ];
|
|
lpPktCastleTaxMove->m_dwResultTaxMoney[ j ] = m_CastleTax[ j ].m_dwTaxMoney;
|
|
}
|
|
|
|
SendStream.WrapHeader(sizeof(PktCastleTaxMove), CmdCastleTaxMove, 0, 0);
|
|
}
|
|
}
|
|
}
|
|
|
|
// DB ¾÷µ¥ÀÌÆ®
|
|
DBComponent::CastleDB::UpdateCastleSiegeCount(m_DBComponent, m_dwCastleID, m_cSiegeCount, m_cInvincibleCount, m_wTotalSiegeCount);
|
|
|
|
// °ø¼º Ƚ¼ö Á¤º¸ Àü¼Û
|
|
if (NULL != lpGameDispatch)
|
|
{
|
|
CSendStream& SendStream = lpGameDispatch->GetSendStream();
|
|
|
|
char* lpBuffer = SendStream.GetBuffer(sizeof(PktCastleSiegeCount));
|
|
if (NULL != lpBuffer)
|
|
{
|
|
PktCastleSiegeCount* lpPktCastleSiegeCount = reinterpret_cast<PktCastleSiegeCount*>(lpBuffer);
|
|
|
|
lpPktCastleSiegeCount->m_dwCastleID = m_dwCastleID;
|
|
lpPktCastleSiegeCount->m_cSiegeCount = m_cSiegeCount;
|
|
lpPktCastleSiegeCount->m_cInvincibleCount = m_cInvincibleCount;
|
|
lpPktCastleSiegeCount->m_wTotalSiegeCount = m_wTotalSiegeCount;
|
|
|
|
SendStream.WrapHeader(sizeof(PktCastleSiegeCount), CmdCastleSiegeCount, 0, 0);
|
|
}
|
|
}
|
|
|
|
// ¼¼À² Á¶Á¤ °¡´É º¯¼ö ÃʱâÈ
|
|
for (int i=0; i<Castle::MAX_TAX_TYPE; ++i)
|
|
{
|
|
m_CastleTax[ i ].m_cTaxChangable = Castle::TAX_ENABLE;
|
|
|
|
// DB ¾÷µ¥ÀÌÆ®
|
|
DBComponent::CastleDB::UpdateCastleTaxChangable(m_DBComponent, m_dwCastleID, i, Castle::TAX_ENABLE);
|
|
}
|
|
}
|
|
|
|
// °ÅµÎ¾î µéÀÎ ¼¼±ÝÀ» ±æµå ±Ý°í·Î
|
|
void CCastleDB::TakeTaxMoney(unsigned char cType, unsigned long dwTakeTaxMoney)
|
|
{
|
|
// CASTLE_TODO : ¼ºÀÌ ±æµå ¼ÒÀ¯°¡ ¾Æ´Ï¹Ç·Î ÀÏ´Ü ±¸ÇöºÎºÐÀ» ÁÖ¼® ó¸® ÇØµÐ´Ù.
|
|
/*
|
|
// edith ¼¼±Ý ºÎºÐ Ãß°¡ (ÁÖ¼®Ã³¸® »°À½)
|
|
Guild::CGuildDB* lpGuild = static_cast<Guild::CGuildDB*>(
|
|
Guild::CGuildDBMgr::GetInstance().GetGuild(m_dwGID));
|
|
|
|
if (lpGuild)
|
|
{
|
|
if (Castle::CAMP_MINERAL_TAX == cType)
|
|
{
|
|
m_dwTotalTaxMoney += dwTakeTaxMoney;
|
|
|
|
// DB ¾÷µ¥ÀÌÆ®
|
|
DBComponent::CastleDB::UpdateCastleTotalTaxMoney(m_DBComponent, m_dwCastleID, m_dwTotalTaxMoney);
|
|
}
|
|
else
|
|
{
|
|
lpGuild->AddGold(dwTakeTaxMoney);
|
|
m_CastleTax[ cType ].m_dwTaxMoney -= dwTakeTaxMoney;
|
|
m_dwTotalTaxMoney += dwTakeTaxMoney;
|
|
|
|
// DB ¾÷µ¥ÀÌÆ®
|
|
DBComponent::CastleDB::UpdateCastleTaxMoney(m_DBComponent, m_dwCastleID, cType,
|
|
m_CastleTax[cType].m_dwTempTaxMoney, m_CastleTax[cType].m_dwTaxMoney);
|
|
|
|
DBComponent::CastleDB::UpdateCastleTotalTaxMoney(m_DBComponent, m_dwCastleID, m_dwTotalTaxMoney);
|
|
}
|
|
}
|
|
*/
|
|
}
|
|
|
|
// ±¤¹° ¼¼±Ý ȸ¼ö
|
|
bool CCastleDB::GainMineral(unsigned short wMineralID, unsigned short wAmount)
|
|
{
|
|
MineralInfoMap::iterator itr = m_AccumulatedMineralMap.find(wMineralID);
|
|
|
|
if (itr != m_AccumulatedMineralMap.end())
|
|
{
|
|
if (itr->second < wAmount)
|
|
{
|
|
ERRLOG4(g_Log, "ȹµæÇÒ·Á´Â ¾ÆÀÌÅÛ ¼öº¸´Ù ÇöÀç ´©ÀûµÈ ¾ÆÀÌÅÛ ¼ö°¡ ´õ Àû½À´Ï´Ù.( CastleID : 0x%08x, MineralID : %d, CurrentAmount : %d, GainAmount : %d )",
|
|
m_dwCastleID, wMineralID, itr->second, wAmount);
|
|
return false;
|
|
}
|
|
else
|
|
{
|
|
if (itr->second == wAmount)
|
|
{
|
|
DBComponent::CastleDB::DeleteCastleMineralInfo(m_DBComponent, m_dwCastleID, Siege::ACCUMULATED_MINERAL, wMineralID);
|
|
m_AccumulatedMineralMap.erase(itr);
|
|
}
|
|
else
|
|
{
|
|
itr->second -= wAmount;
|
|
DBComponent::CastleDB::UpdateCastleMineralInfo(m_DBComponent, m_dwCastleID, Siege::ACCUMULATED_MINERAL, wMineralID, itr->second);
|
|
}
|
|
|
|
return true;
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
// °ÔÀÓ ¼¹ö·ÎºÎÅÍ Àӽà ¼¼±ÝÁ¤º¸ ¾÷µ¥ÀÌÆ®
|
|
bool CCastleDB::SetTempTaxMoney(unsigned long* dwTempTaxMoney, unsigned long* dwTaxMoney)
|
|
{
|
|
if (NULL == dwTempTaxMoney || NULL == dwTaxMoney)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
for (int i=0; i<Castle::MAX_TAX_TYPE; ++i)
|
|
{
|
|
// ´©Àû ¼¼±Ý Á¤º¸°¡ °°À» ¶§¸¸ ¾÷µ¥ÀÌÆ®ÇÑ´Ù.!!
|
|
// (GS -> DBA : Àӽà ¼¼±Ý Á¤º¸ ÆÐŶÀü¼Û, DBA -> GS : Àӽà ¼¼±Ý -> ´©Àû¼¼±Ý ÆÐŶÀü¼Û °£ÀÇ ½Ã°£Â÷·Î ÀÎÇÑ ¹®Á¦°¡ ¾ø°ÔÇϱâ À§ÇØ)
|
|
if (m_CastleTax[ i ].m_dwTaxMoney == dwTaxMoney[ i ])
|
|
{
|
|
m_CastleTax[ i ].m_dwTempTaxMoney = dwTempTaxMoney[ i ];
|
|
|
|
// DB ¾÷µ¥ÀÌÆ®
|
|
DBComponent::CastleDB::UpdateCastleTaxMoney(m_DBComponent, m_dwCastleID, i,
|
|
m_CastleTax[i].m_dwTempTaxMoney, m_CastleTax[i].m_dwTaxMoney);
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
// °ÔÀÓ ¼¹ö·ÎºÎÅÍ ±¤¹° ¼¼±ÝÁ¤º¸ ¾÷µ¥ÀÌÆ®
|
|
bool CCastleDB::SetMineralInfo(unsigned char cMineralType, unsigned char cNum, CastleMineral* lpMineralInfo)
|
|
{
|
|
switch (cMineralType)
|
|
{
|
|
case Siege::TEMPORARY_MINERAL :
|
|
{
|
|
DBComponent::CastleDB::DeleteCastleMineralInfo(m_DBComponent, m_dwCastleID, cMineralType);
|
|
m_TemporaryMineralMap.clear();
|
|
|
|
for (int i=0; i<cNum; ++i)
|
|
{
|
|
DBComponent::CastleDB::InsertCastleMineralInfo(m_DBComponent, m_dwCastleID, cMineralType,
|
|
lpMineralInfo->m_wMineralID, lpMineralInfo->m_wAmount);
|
|
|
|
InsertMineralInfo(cMineralType, *lpMineralInfo);
|
|
++lpMineralInfo;
|
|
}
|
|
}
|
|
break;
|
|
|
|
case Siege::ACCUMULATED_MINERAL :
|
|
{
|
|
DBComponent::CastleDB::DeleteCastleMineralInfo(m_DBComponent, m_dwCastleID, cMineralType);
|
|
m_AccumulatedMineralMap.clear();
|
|
|
|
for (int i=0; i<cNum; ++i)
|
|
{
|
|
DBComponent::CastleDB::InsertCastleMineralInfo(m_DBComponent, m_dwCastleID, cMineralType,
|
|
lpMineralInfo->m_wMineralID, lpMineralInfo->m_wAmount);
|
|
|
|
InsertMineralInfo(cMineralType, *lpMineralInfo);
|
|
++lpMineralInfo;
|
|
}
|
|
}
|
|
break;
|
|
|
|
default: return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
|
|
void CCastleDB::SetTax(unsigned char cType, unsigned char cTax) // ¼¼À² º¯°æ
|
|
{
|
|
if (cType < Castle::MAX_TAX_TYPE)
|
|
{
|
|
m_CastleTax[ cType ].m_cTax = cTax;
|
|
m_CastleTax[ cType ].m_cTaxChangable = Castle::TAX_DISABLE;
|
|
|
|
DBComponent::CastleDB::UpdateCastleTax(m_DBComponent, m_dwCastleID, cType, cTax);
|
|
DBComponent::CastleDB::UpdateCastleTaxChangable(m_DBComponent, m_dwCastleID, cType, Castle::TAX_DISABLE);
|
|
}
|
|
}
|
|
|
|
|
|
bool CCastleDB::SetTaxInfo(const CastleTaxInfoDB& taxInfo)
|
|
{
|
|
if (taxInfo.m_cTaxType < Castle::MAX_TAX_TYPE)
|
|
{
|
|
m_CastleTax[ taxInfo.m_cTaxType ].m_cTaxType = taxInfo.m_cTaxType;
|
|
m_CastleTax[ taxInfo.m_cTaxType ].m_cTax = taxInfo.m_cTax;
|
|
m_CastleTax[ taxInfo.m_cTaxType ].m_dwTempTaxMoney = taxInfo.m_dwTempTaxMoney;
|
|
m_CastleTax[ taxInfo.m_cTaxType ].m_dwTaxMoney = taxInfo.m_dwTaxMoney;
|
|
m_CastleTax[ taxInfo.m_cTaxType ].m_cTaxChangable = taxInfo.m_cTaxChangable;
|
|
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
// TODO : Log
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
bool CCastleDB::SetMineralInfo(const CastleMineralInfoDB& mineralInfo)
|
|
{
|
|
if (mineralInfo.m_wAmount > 0)
|
|
{
|
|
switch (mineralInfo.m_cFlag)
|
|
{
|
|
case Siege::ACCUMULATED_MINERAL :
|
|
{
|
|
m_AccumulatedMineralMap.insert( std::make_pair(mineralInfo.m_wMineralID, mineralInfo.m_wAmount) ).second;
|
|
}
|
|
break;
|
|
|
|
case Siege::TEMPORARY_MINERAL :
|
|
{
|
|
m_TemporaryMineralMap.insert( std::make_pair(mineralInfo.m_wMineralID, mineralInfo.m_wAmount) ).second;
|
|
}
|
|
break;
|
|
|
|
default: return false;
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
bool CCastleDB::InsertMineralInfo(unsigned char cMineralType, const CastleMineral& mineralInfo)
|
|
{
|
|
if (mineralInfo.m_wAmount > 0)
|
|
{
|
|
switch (cMineralType)
|
|
{
|
|
case Siege::ACCUMULATED_MINERAL :
|
|
{
|
|
m_AccumulatedMineralMap.insert( std::make_pair(mineralInfo.m_wMineralID, mineralInfo.m_wAmount) ).second;
|
|
}
|
|
break;
|
|
|
|
case Siege::TEMPORARY_MINERAL :
|
|
{
|
|
m_TemporaryMineralMap.insert( std::make_pair(mineralInfo.m_wMineralID, mineralInfo.m_wAmount) ).second;
|
|
}
|
|
break;
|
|
|
|
default: return false;
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
void CCastleDB::SetRight(CastleRight castleRight) // °ü¸® ±ÇÇÑ º¯°æ
|
|
{
|
|
m_CastleRight = castleRight;
|
|
|
|
DBComponent::CastleDB::UpdateCastleRight(m_DBComponent, m_dwCastleID, reinterpret_cast<char*>(&m_CastleRight), sizeof(CastleRight));
|
|
}
|
|
|
|
void CCastleDB::SetUpgradeItemInfo(unsigned short wItemID, unsigned char cItemNum)
|
|
{
|
|
m_wItemID = wItemID;
|
|
m_cItemNum = cItemNum;
|
|
|
|
DBComponent::CastleDB::UpdateCastleUpgradeItemInfo(m_DBComponent, m_dwCastleID, m_wItemID, m_cItemNum);
|
|
}
|