scummvm/common/achievements.h

194 lines
5.4 KiB
C
Raw Normal View History

2020-03-16 00:47:21 +00:00
/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
*/
#ifndef COMMON_ACHIEVEMENTS_H
#define COMMON_ACHIEVEMENTS_H
#include "common/array.h"
#include "common/ini-file.h"
2020-03-16 00:47:21 +00:00
#include "common/singleton.h"
#include "common/str.h"
namespace Common {
/**
* @defgroup common_achieve Achievements
* @ingroup common
*
* @brief API related to in-game achievements.
*
* @{
*/
2020-03-16 00:47:21 +00:00
/**
* List of game achievements provider platforms.
* Possible candidates are XBOX Gamerscore, PSN Trophies, Kongregate Badges, etc...
*/
enum AchievementsPlatform {
STEAM_ACHIEVEMENTS,
GALAXY_ACHIEVEMENTS,
UNK_ACHIEVEMENTS = -1
};
/**
* Information structure for game-specific achievements.
2020-03-16 00:47:21 +00:00
*/
struct AchievementDescription {
2021-03-13 12:22:48 +00:00
const char *id; //!< Achievement internal ID, such as "ACHIEVEMENT_TIMING".
bool isHidden; //!< Whether the achievement is hidden.
const char *title; //!< Achievement displayed text, such as "Marathon Runner".
const char *comment; //!< Optional achievement hint or comment, such as "Finish the game in less than 4 hours".
2020-03-16 00:47:21 +00:00
};
/**
* Information structure for platform-specific achievements.
2020-03-16 00:47:21 +00:00
*/
struct AchievementsInfo {
Common::AchievementsPlatform platform; //!< Achievements platform, such as "STEAM_ACHIEVEMENTS".
Common::String appId; //!< Achievements application ID of the given platform.
Common::Array<AchievementDescription> descriptions; //!< Descriptions of all game achievements.
2020-03-16 00:47:21 +00:00
2021-03-13 12:22:48 +00:00
AchievementsInfo() { platform = Common::UNK_ACHIEVEMENTS; }
2020-03-16 00:47:21 +00:00
};
/**
* Class for manipulating the achievements.
*
* Use the Achievements Manager class to edit the in-game achievements.
*/
2020-03-16 00:47:21 +00:00
class AchievementsManager : public Singleton<AchievementsManager> {
public:
AchievementsManager();
~AchievementsManager();
2021-03-13 12:22:48 +00:00
/**
* (DEPRECATED) Set a platform and application ID as active domain.
2021-03-13 12:22:48 +00:00
*
* @param[in] platform Achievements platform.
* @param[in] appId Achievements application ID of the given platform.
*/
2020-03-16 00:47:21 +00:00
bool setActiveDomain(AchievementsPlatform platform, const String &appId);
/**
* Set a platform and application ID as active domain, store messages texts.
*
* @param[in] info Achievements platform, application ID and messages information.
*/
bool setActiveDomain(const AchievementsInfo &info);
2021-03-13 12:22:48 +00:00
bool unsetActiveDomain(); //!< Unset the current active domain.
bool isReady() const { return _iniFile != nullptr; } //!< Check whether the domain is ready.
/**
2021-03-13 12:22:48 +00:00
* @name Methods for manipulating individual achievements
* @{
*/
2020-03-16 00:47:21 +00:00
/** (DEPRECATED) Set an achievement.
2021-03-13 12:22:48 +00:00
*
* @param[in] id Internal ID of the achievement.
* @param[in] displayedMessage Message displayed when the achievement is achieved.
*/
2020-03-16 00:47:21 +00:00
bool setAchievement(const String &id, const String &displayedMessage);
2021-03-13 12:22:48 +00:00
/** Set an achievement. Message is automatically displayed with text from active domain.
*
* @param[in] id Internal ID of the achievement.
*/
bool setAchievement(const String &id);
2021-03-13 12:22:48 +00:00
/**
* Set an achievement as achieved.
*
* @param[in] id Internal ID of the achievement.
*/
bool isAchieved(const String &id) const;
2021-03-13 12:22:48 +00:00
/**
* Clear an achieved achievement.
*
* @param[in] id Internal ID of the achievement.
*/
2020-03-16 00:47:21 +00:00
bool clearAchievement(const String &id);
2021-03-13 12:22:48 +00:00
/** @} */
/**
* @name Methods for manipulating individual statistics
* @{
*/
/**
* Get a statistic (integer).
*
* @param[in] id Internal ID of the achievement.
*/
2020-03-16 00:47:21 +00:00
int getStatInt(const String &id);
2021-03-13 12:22:48 +00:00
/**
* Set a statistic to an integer number.
*
* @param[in] id Internal ID of the achievement.
* @param[in] value Value to which the statistic is set.
*/
2020-03-16 00:47:21 +00:00
bool setStatInt(const String &id, int value);
2021-03-13 12:22:48 +00:00
/**
* Get a statistic (float).
*
* @param[in] id Internal ID of the achievement.
*/
2020-03-16 00:47:21 +00:00
float getStatFloat(const String &id);
2021-03-13 12:22:48 +00:00
/**
* Set a statistic to a float number.
*
* @param[in] id Internal ID of the achievement.
* @param[in] value Value to which the statistic is set.
*/
2020-03-16 00:47:21 +00:00
bool setStatFloat(const String &id, float value);
2021-03-13 12:22:48 +00:00
/** @} */
2021-03-13 12:22:48 +00:00
/**
* @name Methods for resetting achievements and statistics
* @{
*/
bool resetAllAchievements(); //!< Reset all achievements.
bool resetAllStats(); //!< Reset all statistics.
2021-03-13 12:22:48 +00:00
/** @} */
2020-03-16 00:47:21 +00:00
private:
2020-04-29 08:32:23 +00:00
INIFile *_iniFile;
String _iniFileName;
Common::Array<AchievementDescription> _descriptions;
2020-03-16 00:47:21 +00:00
};
/** Shortcut for accessing the Achievements Manager. */
2020-03-16 00:47:21 +00:00
#define AchMan Common::AchievementsManager::instance()
/** @} */
2020-03-16 00:47:21 +00:00
} // End of namespace Common
2020-04-29 08:32:23 +00:00
#endif // #ifndef COMMON_ACHIEVEMENTS_MANAGER_H