// Ryzom - MMORPG Framework
// Copyright (C) 2010 Winch Gate Property Limited
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see .
#ifndef RY_SKILL_MANAGER_H
#define RY_SKILL_MANAGER_H
#include "nel/misc/types_nl.h"
#include "game_share/skills.h"
//#include "game_share/jobs.h"
#include "game_share/roles.h"
#include "nel/misc/cdb.h"
#include "brick_learned_callback.h"
#include "skill_change_callback.h"
#include "game_share/skills.h"
#include "game_share/memorization_set_types.h"
#include "../client_sheets/skills_tree_sheet.h"
#include "../client_sheets/unblock_titles_sheet.h"
// ***************************************************************************
/**
* class used to manage the skill tree
* \author Matthieu 'TrapII' Besson
* \author Nevrax France
* \date 2003 September
*/
class CSkillManager
{
public:
/// The singleton's instance
static CSkillManager* getInstance()
{
if (!_Instance)
_Instance = new CSkillManager;
return _Instance;
}
// release singleton
static void releaseInstance()
{
delete _Instance;
_Instance = NULL;
}
/// Destructor
virtual ~CSkillManager();
// Initialize by loading skills (load the skill_tree stuffs) and organize so in the vector skill == index
void initInGame();
void uninitInGame();
bool isUnknown (SKILLS::ESkills eSkill);
SKILLS::ESkills getParent (SKILLS::ESkills eSkill);
const std::vector &getChildren (SKILLS::ESkills eSkill);
/// return true if 2 skills are on the same Branch (ie compatible). NB: return false if one is unknown
bool areSkillOnSameBranch(SKILLS::ESkills s0, SKILLS::ESkills s1);
/// return true if the skill s0 is an ancestor of skill s1 (true if s0==s1)
bool isSkillAncestor(SKILLS::ESkills s0, SKILLS::ESkills s1);
/// Get the MinSkillValue (ie the max skill value of the parent)
uint32 getMinSkillValue(SKILLS::ESkills eSkill);
/// Get the MaxSkillValue
uint32 getMaxSkillValue(SKILLS::ESkills eSkill);
/// Get the SkillValue in the database (BUFFED one)
uint32 getSkillValue(SKILLS::ESkills eSkill);
/// Get the SkillValue in the database (unBUFFED one)
uint32 getBaseSkillValue(SKILLS::ESkills eSkill);
/// Get the SkillValue in the database (BUFFED one). Get the max of the skill and its parent
uint32 getSkillValueMaxBranch(SKILLS::ESkills eSkill);
/// Get the SkillValue in the database (unBUFFED one). Get the max of the skill and its parent
uint32 getBaseSkillValueMaxBranch(SKILLS::ESkills eSkill);
/// Get the SkillValue in the database (BUFFED one). Get the max of the skill and its children
/// NB: warning: slow since recursive
uint32 getSkillValueMaxChildren(SKILLS::ESkills eSkill);
/// Get the MaxSkillValue in the branch (from parent to children) (BUFFED one)
/// NB: warning: slow since use getSkillValueMaxChildren
uint32 getBestSkillValue(SKILLS::ESkills eSkill);
/// Get the BaseSkillValue in the database (unBUFFED one). Get the max of the skill and its children
/// NB: fast O(1) since BaseSkillValue
uint32 getBaseSkillValueMaxChildren(SKILLS::ESkills eSkill);
/// return true if base skill max branch value is > required skill value
bool checkBaseSkillMetRequirement(SKILLS::ESkills eSkill, uint32 value);
/// Callback called when any skill change
void appendSkillChangeCallback(ISkillChangeCallback *cb);
void removeSkillChangeCallback(ISkillChangeCallback *cb);
/// CHARACTER TITLE
/// Append the brick learned callback to the brick manager
void initTitles();
/// Remove the callback
void uninitTitles();
/// Called when a skill change to look if we can unblock a title
void tryToUnblockTitleFromSkill(SKILLS::ESkills eSkill, sint32 value);
/// The same but with parsing all bricks wanted
void tryToUnblockTitleFromBricks(bool show_message = true);
/// The same but with civ allegiance
void tryToUnblockTitleFromCiv(bool show_message = true);
/// The same but with cult allegiance
void tryToUnblockTitleFromCult(bool show_message = true);
/// The same but with parsing all items wanted
void tryToUnblockTitleFromItems(bool show_message = true);
/// Called when a fame changes to look if we can unblock a title
void tryToUnblockTitleFromMinFames(uint32 factionIndex, sint32 fameValue);
void tryToUnblockTitleFromMaxFames(uint32 factionIndex, sint32 fameValue);
/// called after user chose a char, unblock titles from char time properties
void tryToUnblockTitleFromCharOldness( uint32 firstConnectedTime );
void tryToUnblockTitleFromCharPlayedTime( uint32 playedTime );
void tryToUnblockTitleFromAccountOldness( uint32 accountCreationTime );
/// called when ring ratings change
void tryToUnblockTitleFromRingRatings(uint32 authorRating, uint32 amRating, uint32 masterlessRating);
/// Unblock a reserved title from the server
void unblockTitleFromServer(CHARACTER_TITLE::ECharacterTitle ct);
/// Block a reserved title from the server
void blockTitleFromServer(CHARACTER_TITLE::ECharacterTitle ct);
/// Is the title unblocked and accessible to the player ?
bool isTitleUnblocked(CHARACTER_TITLE::ECharacterTitle ct) { return _TitlesUnblocked[ct].Unblocked; }
/// Is the title reserved (can be unblocked only by a server message)
bool isTitleReserved(CHARACTER_TITLE::ECharacterTitle ct) { return _UnblockTitle->TitlesUnblock[ct].Reserved; }
void setPlayerTitle(const std::string &name);
uint8 getPlayerTitle() const { return _CurrentTitle; }
protected:
void setCurrentTitle(uint8 title);
private:
// update parent skills max child value for given skill
void updateParentSkillsMaxChildValue(SKILLS::ESkills eSkill);
/// compute parent skills max child value for all skill tree
void computeMaxChildValues();
/// Constructor
CSkillManager();
/// Singleton's instance
static CSkillManager *_Instance;
CSkillsTreeSheet *_Tree;
// Minimum skills values
uint32 _MinSkillValue[SKILLS::NUM_SKILLS];
/// Nodes on skill values and base values
NLMISC::CCDBNodeLeaf *_SkillValues[SKILLS::NUM_SKILLS];
NLMISC::CCDBNodeLeaf *_SkillBaseValues[SKILLS::NUM_SKILLS];
// Max child baseskill value (used when checking requirements)
uint32 _MaxChildBaseSkillValue[SKILLS::NUM_SKILLS];
// CallBack set for skill changes
struct CSkillChangeObs : public NLMISC::ICDBNode::IPropertyObserver
{
virtual void update (NLMISC::ICDBNode * /* node */)
{
CSkillManager *pSM= CSkillManager::getInstance();
pSM->onSkillChange();
}
};
friend struct CSkillChangeObs;
CSkillChangeObs _SkillChangeObs;
typedef std::set TSCCBSet;
TSCCBSet _SkillChangeCallbackSet;
void onSkillChange();
// Cache to know if skill really changed (not PROGRESS_BAR)
sint32 _CacheSkillValues[SKILLS::NUM_SKILLS];
sint32 _CacheSkillBaseValues[SKILLS::NUM_SKILLS];
// A node incremented at each change of skill (the number is not relevant)
NLMISC::CCDBNodeLeaf *_TrackSkillChange;
// "Title of the player" Management
// -----------------------------------------------------------------------------
friend class CHandlerTitleInit;
friend class CHandlerTitleButton;
friend class CHandlerTitleChanged;
struct SUnblockingTitle
{
bool Unblocked;
std::vector UnblockedSkillLists;
std::vector UnblockedBricks;
std::vector UnblockedMinFames;
std::vector UnblockedMaxFames;
std::vector UnblockedItemLists;
bool UnblockedCiv;
bool UnblockedCult;
bool UnblockedCharOldness;
bool UnblockedCharPlayedTime;
bool UnblockedAccountOldness;
bool UnblockedAuthorRating;
bool UnblockedAMRating;
bool UnblockedOrganizerRating;
};
std::vector _TitlesUnblocked;
void checkTitleUnblocked(CHARACTER_TITLE::ECharacterTitle i, bool show_message = true);
uint8 _CurrentTitle;
std::vector _UIUnblockedTitles;
CUnblockTitlesSheet *_UnblockTitle;
class CBrickLearnedCB : public IBrickLearnedCallback
{
public:
virtual void onBrickLearned()
{
CSkillManager::getInstance()->tryToUnblockTitleFromBricks();
}
};
CBrickLearnedCB BrickLearnedCB;
};
#define WIN_FAME_LIST "ui:interface:fame:content:fame_list:list"
#define TEMPLATE_FAME "fame_charac"
#endif // RY_SKILL_MANAGER_H
/* End of skill_manager.h */