2014-02-05 22:43:47 -05:00
|
|
|
//
|
|
|
|
// SuperTuxKart - a fun racing game with go-kart
|
|
|
|
// Copyright (C) 2012-2014 Joerg Henrichs
|
|
|
|
//
|
|
|
|
// 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 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 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
|
|
|
|
#include "config/player_manager.hpp"
|
|
|
|
|
2014-02-09 07:22:45 -05:00
|
|
|
#include "achievements/achievements_manager.hpp"
|
2014-02-17 04:10:29 -05:00
|
|
|
#include "config/player_profile.hpp"
|
2014-02-05 22:43:47 -05:00
|
|
|
#include "io/file_manager.hpp"
|
|
|
|
#include "io/utf_writer.hpp"
|
|
|
|
#include "io/xml_node.hpp"
|
2014-04-17 01:39:51 -04:00
|
|
|
#include "online/online_player_profile.hpp"
|
2014-02-05 22:43:47 -05:00
|
|
|
#include "utils/log.hpp"
|
|
|
|
#include "utils/translation.hpp"
|
|
|
|
|
|
|
|
PlayerManager *PlayerManager::m_player_manager = NULL;
|
|
|
|
|
2014-02-09 07:22:45 -05:00
|
|
|
|
2014-03-29 06:33:43 -04:00
|
|
|
/** Create the instance of the player manager.
|
2014-02-09 07:22:45 -05:00
|
|
|
* Also make sure that at least one player is defined (and if not,
|
|
|
|
* create a default player and a guest player).
|
|
|
|
*/
|
|
|
|
void PlayerManager::create()
|
|
|
|
{
|
|
|
|
assert(!m_player_manager);
|
|
|
|
m_player_manager = new PlayerManager();
|
|
|
|
} // create
|
|
|
|
|
2014-04-11 02:37:48 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
2014-04-11 02:20:04 -04:00
|
|
|
/** Adds the login credential to a http request. It sets the name of
|
|
|
|
* the script to invokce, token, and user id.
|
|
|
|
* \param request The http request.
|
|
|
|
* \param action If not empty, the action to be set.
|
|
|
|
*/
|
2014-04-10 02:32:58 -04:00
|
|
|
void PlayerManager::setUserDetails(Online::HTTPRequest *request,
|
|
|
|
const std::string &action,
|
|
|
|
const std::string &php_name)
|
|
|
|
{
|
2014-04-16 18:16:30 -04:00
|
|
|
get()->getCurrentPlayer()->setUserDetails(request, action, php_name);
|
2014-04-11 02:20:04 -04:00
|
|
|
} // setUserDetails
|
|
|
|
|
2014-04-11 02:37:48 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
2014-04-11 02:20:04 -04:00
|
|
|
/** Returns whether a user is signed in or not. */
|
|
|
|
bool PlayerManager::isCurrentLoggedIn()
|
|
|
|
{
|
2014-04-16 18:16:30 -04:00
|
|
|
return getCurrentPlayer()->isLoggedIn();
|
2014-04-11 02:20:04 -04:00
|
|
|
} // isCurrentLoggedIn
|
|
|
|
|
2014-04-11 02:37:48 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
2014-04-11 02:20:04 -04:00
|
|
|
/** Returns the online id of the current player.
|
|
|
|
* \pre User logged in (which is asserted in getID()).
|
|
|
|
*/
|
2014-04-11 02:06:51 -04:00
|
|
|
unsigned int PlayerManager::getCurrentOnlineId()
|
|
|
|
{
|
2014-04-16 18:16:30 -04:00
|
|
|
return getCurrentPlayer()->getOnlineId();
|
2014-04-11 02:06:51 -04:00
|
|
|
} // getCurrentOnlineId
|
2014-04-10 02:32:58 -04:00
|
|
|
|
2014-04-11 02:37:48 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
/** Returns the online state of the current player. It can be logged out,
|
|
|
|
* logging in, logged in, logging out, logged out, or guest.
|
|
|
|
*/
|
2014-04-16 18:16:30 -04:00
|
|
|
PlayerProfile::OnlineState PlayerManager::getCurrentOnlineState()
|
2014-04-11 02:37:48 -04:00
|
|
|
{
|
2014-04-16 18:16:30 -04:00
|
|
|
return getCurrentPlayer()->getOnlineState();
|
2014-04-11 02:37:48 -04:00
|
|
|
} // getCurrentOnlineState
|
2014-04-16 18:16:30 -04:00
|
|
|
|
2014-04-15 02:25:55 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
2014-04-15 21:13:35 -04:00
|
|
|
/** Returns the online name of this player.
|
|
|
|
*/
|
|
|
|
const irr::core::stringw& PlayerManager::getCurrentOnlineUserName()
|
|
|
|
{
|
2014-04-16 18:16:30 -04:00
|
|
|
if (getCurrentOnlineState() == PlayerProfile::OS_SIGNED_IN ||
|
|
|
|
getCurrentOnlineState() == PlayerProfile::OS_GUEST )
|
2014-04-15 21:13:35 -04:00
|
|
|
return getCurrentOnlineProfile()->getUserName();
|
|
|
|
|
|
|
|
static core::stringw not_signed_in = _("Currently not signed in");
|
|
|
|
return not_signed_in;
|
|
|
|
} // getCurrentOnlineUserName
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
/** Sends a request to the server to see if any new information is
|
|
|
|
* available. (online friends, notifications, etc.).
|
|
|
|
*/
|
|
|
|
void PlayerManager::requestOnlinePoll()
|
|
|
|
{
|
2014-04-16 18:16:30 -04:00
|
|
|
getCurrentPlayer()->requestPoll();
|
2014-04-15 21:13:35 -04:00
|
|
|
} // requestOnlinePoll
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
/** Reconnect to the server using the saved session data.
|
|
|
|
*/
|
|
|
|
void PlayerManager::resumeSavedSession()
|
|
|
|
{
|
2014-04-16 18:16:30 -04:00
|
|
|
getCurrentPlayer()->requestSavedSession();
|
2014-04-15 21:13:35 -04:00
|
|
|
} // resumeSavedSession
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
/** Sends a message to the server that the client has been closed, if a
|
|
|
|
* user is signed in.
|
|
|
|
*/
|
|
|
|
void PlayerManager::onSTKQuit()
|
|
|
|
{
|
2014-04-16 18:16:30 -04:00
|
|
|
getCurrentPlayer()->onSTKQuit();
|
2014-04-15 21:13:35 -04:00
|
|
|
} // onSTKQuit
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
/** Create a signin request.
|
|
|
|
* \param username Name of user.
|
|
|
|
* \param password Password.
|
|
|
|
* \param save_session If true, the login credential will be saved to
|
|
|
|
* allow a password-less login.
|
|
|
|
* \param request_now Immediately submit this request to the
|
|
|
|
* RequestManager.
|
|
|
|
*/
|
|
|
|
|
|
|
|
Online::XMLRequest *PlayerManager::requestSignIn(const irr::core::stringw &username,
|
|
|
|
const irr::core::stringw &password,
|
|
|
|
bool save_session,
|
|
|
|
bool request_now)
|
|
|
|
{
|
2014-04-16 18:16:30 -04:00
|
|
|
return getCurrentPlayer()->requestSignIn(username, password, save_session,
|
|
|
|
request_now);
|
2014-04-15 21:13:35 -04:00
|
|
|
} // requestSignIn
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
/** Signs the current user out.
|
|
|
|
*/
|
|
|
|
void PlayerManager::requestSignOut()
|
|
|
|
{
|
2014-04-16 18:16:30 -04:00
|
|
|
getCurrentPlayer()->requestSignOut();
|
2014-04-15 21:13:35 -04:00
|
|
|
} // requestSignOut
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
2014-04-15 02:25:55 -04:00
|
|
|
/** Returns the current online profile (which is the list of all achievements
|
|
|
|
* and friends).
|
|
|
|
*/
|
|
|
|
Online::OnlineProfile* PlayerManager::getCurrentOnlineProfile()
|
|
|
|
{
|
2014-04-16 18:16:30 -04:00
|
|
|
return getCurrentPlayer()->getProfile();
|
2014-04-15 02:25:55 -04:00
|
|
|
} // getCurrentOnlineProfile
|
2014-04-11 02:37:48 -04:00
|
|
|
|
2014-02-09 07:22:45 -05:00
|
|
|
// ============================================================================
|
2014-02-05 22:43:47 -05:00
|
|
|
/** Constructor.
|
|
|
|
*/
|
|
|
|
PlayerManager::PlayerManager()
|
|
|
|
{
|
2014-02-10 16:12:10 -05:00
|
|
|
m_current_player = NULL;
|
2014-02-09 07:22:45 -05:00
|
|
|
load();
|
2014-02-05 22:43:47 -05:00
|
|
|
} // PlayerManager
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
/** Destructor.
|
|
|
|
*/
|
|
|
|
PlayerManager::~PlayerManager()
|
|
|
|
{
|
|
|
|
save();
|
|
|
|
} // ~PlayerManager
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
2014-03-01 01:16:23 -05:00
|
|
|
/** Manages the loading of saved player data from the players.xml file.
|
|
|
|
* This function create the XML tree from the file, and then creates the
|
|
|
|
* instances of PlayerProfile which read each node.
|
|
|
|
*/
|
2014-02-05 22:43:47 -05:00
|
|
|
void PlayerManager::load()
|
|
|
|
{
|
|
|
|
std::string filename = file_manager->getUserConfigFile("players.xml");
|
|
|
|
|
2014-04-08 18:33:42 -04:00
|
|
|
m_player_data = file_manager->createXMLTree(filename);
|
|
|
|
if(!m_player_data)
|
2014-02-09 07:22:45 -05:00
|
|
|
{
|
|
|
|
Log::info("player_manager", "A new players.xml file will be created.");
|
|
|
|
return;
|
|
|
|
}
|
2014-04-08 18:33:42 -04:00
|
|
|
else if(m_player_data->getName()!="players")
|
2014-02-05 22:43:47 -05:00
|
|
|
{
|
|
|
|
Log::info("player_manager", "The players.xml file is invalid.");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-04-23 18:17:44 -04:00
|
|
|
const XMLNode *online = m_player_data->getNode("online-ids");
|
|
|
|
if (online)
|
|
|
|
{
|
|
|
|
for (unsigned int i = 0; i < online->getNumNodes(); i++)
|
|
|
|
{
|
|
|
|
core::stringw s;
|
|
|
|
online->getNode(i)->get("name", &s);
|
|
|
|
if (s.size()>0) m_all_online_ids.push_back(s);
|
|
|
|
} // for i<online->getNumNodes()
|
|
|
|
}
|
|
|
|
else
|
|
|
|
m_all_online_ids.clear();
|
|
|
|
|
2014-02-09 07:22:45 -05:00
|
|
|
m_current_player = NULL;
|
2014-04-27 17:54:09 -04:00
|
|
|
std::vector<XMLNode*> player_list;
|
|
|
|
m_player_data->getNodes("player", player_list);
|
|
|
|
for(unsigned int i=0; i<player_list.size(); i++)
|
2014-02-05 22:43:47 -05:00
|
|
|
{
|
2014-04-27 17:54:09 -04:00
|
|
|
const XMLNode *player_xml = player_list[i];
|
2014-04-17 01:39:51 -04:00
|
|
|
PlayerProfile *player = new Online::OnlinePlayerProfile(player_xml);
|
2014-02-09 07:22:45 -05:00
|
|
|
m_all_players.push_back(player);
|
2014-02-28 04:23:09 -05:00
|
|
|
if(player->isDefault())
|
2014-02-09 07:22:45 -05:00
|
|
|
m_current_player = player;
|
2014-02-05 22:43:47 -05:00
|
|
|
}
|
2014-02-09 07:22:45 -05:00
|
|
|
|
2014-02-05 22:43:47 -05:00
|
|
|
} // load
|
|
|
|
|
2014-04-08 18:33:42 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
/** The 2nd loading stage. During this stage achievements and story mode
|
2014-04-14 19:06:50 -04:00
|
|
|
* data is initialised for each player. In case of existing player (i.e. not
|
|
|
|
* first time start of stk) the data is read from the players.xml file,
|
|
|
|
* in case of a first time start new/empty data structures for the players
|
|
|
|
* (which were created by default) are created.
|
2014-04-08 18:33:42 -04:00
|
|
|
*/
|
2014-04-14 19:06:50 -04:00
|
|
|
void PlayerManager::initRemainingData()
|
2014-04-08 18:33:42 -04:00
|
|
|
{
|
2014-04-27 17:54:09 -04:00
|
|
|
// Filter the player nodes out (there is one additional node 'online-ids'
|
|
|
|
// which makes this necessary), otherwise the index of m_all_players
|
|
|
|
// is not identical with the index in the xml file.
|
|
|
|
std::vector<XMLNode*> player_nodes;
|
|
|
|
m_player_data->getNodes("player", player_nodes);
|
2014-04-14 19:06:50 -04:00
|
|
|
for (unsigned int i = 0; i<m_all_players.size(); i++)
|
2014-04-08 18:33:42 -04:00
|
|
|
{
|
2014-04-14 19:06:50 -04:00
|
|
|
// On the first time STK is run, there is no player data,
|
|
|
|
// so just initialise the story and achievement data
|
|
|
|
// structures
|
|
|
|
if (!m_player_data)
|
|
|
|
m_all_players[i].initRemainingData();
|
|
|
|
else // not a first time start, load remaining data
|
2014-04-27 17:54:09 -04:00
|
|
|
m_all_players[i].loadRemainingData(player_nodes[i]);
|
2014-04-08 18:33:42 -04:00
|
|
|
}
|
2014-04-14 19:06:50 -04:00
|
|
|
|
2014-04-08 18:33:42 -04:00
|
|
|
delete m_player_data;
|
|
|
|
m_player_data = NULL;
|
|
|
|
|
|
|
|
// Sort player by frequency
|
|
|
|
m_all_players.insertionSort(/*start*/0, /*desc*/true);
|
2014-04-14 19:06:50 -04:00
|
|
|
} // initRemainingData
|
2014-04-08 18:33:42 -04:00
|
|
|
|
2014-02-05 22:43:47 -05:00
|
|
|
// ----------------------------------------------------------------------------
|
2014-03-01 01:16:23 -05:00
|
|
|
/** Saves all player profiles to players.xml.
|
|
|
|
*/
|
2014-02-05 22:43:47 -05:00
|
|
|
void PlayerManager::save()
|
|
|
|
{
|
|
|
|
std::string filename = file_manager->getUserConfigFile("players.xml");
|
|
|
|
try
|
|
|
|
{
|
|
|
|
UTFWriter players_file(filename.c_str());
|
|
|
|
|
|
|
|
players_file << L"<?xml version=\"1.0\"?>\n";
|
|
|
|
players_file << L"<players version=\"1\" >\n";
|
|
|
|
|
2014-04-23 18:17:44 -04:00
|
|
|
players_file << L" <online-ids>\n";
|
|
|
|
for (unsigned int i = 0; i < m_all_online_ids.size(); i++)
|
|
|
|
{
|
|
|
|
players_file << L" <id name=\""<<m_all_online_ids[i]
|
|
|
|
<< "\"/>\n";
|
|
|
|
}
|
|
|
|
players_file << L" </online-ids>\n";
|
|
|
|
|
2014-02-05 22:43:47 -05:00
|
|
|
PlayerProfile *player;
|
|
|
|
for_in(player, m_all_players)
|
|
|
|
{
|
|
|
|
player->save(players_file);
|
|
|
|
}
|
|
|
|
players_file << L"</players>\n";
|
|
|
|
players_file.close();
|
|
|
|
}
|
|
|
|
catch (std::runtime_error& e)
|
|
|
|
{
|
|
|
|
Log::error("PlayerManager", "Failed to write config to %s.",
|
|
|
|
filename.c_str());
|
|
|
|
Log::error("PlayerManager", "Error: %s", e.what());
|
|
|
|
}
|
|
|
|
|
|
|
|
} // save
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
/** Adds a new player to the list of all players.
|
|
|
|
* \param name Name of the new player.
|
|
|
|
*/
|
|
|
|
void PlayerManager::addNewPlayer(const core::stringw& name)
|
|
|
|
{
|
2014-04-17 01:39:51 -04:00
|
|
|
m_all_players.push_back( new Online::OnlinePlayerProfile(name) );
|
2014-02-05 22:43:47 -05:00
|
|
|
} // addNewPlayer
|
|
|
|
|
2014-02-06 07:08:55 -05:00
|
|
|
// ----------------------------------------------------------------------------
|
2014-03-29 06:33:43 -04:00
|
|
|
/** Deletes a player profile from the list of all profiles.
|
2014-03-01 01:16:23 -05:00
|
|
|
*/
|
2014-02-06 07:08:55 -05:00
|
|
|
void PlayerManager::deletePlayer(PlayerProfile *player)
|
|
|
|
{
|
|
|
|
m_all_players.erase(player);
|
|
|
|
} // deletePlayer
|
|
|
|
|
2014-03-06 01:06:41 -05:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
/** This function makes sure that a current player is defined. This is called
|
2014-03-29 06:33:43 -04:00
|
|
|
* when a screen skipping command line option is given (-N, -R, ...), in
|
2014-03-06 01:06:41 -05:00
|
|
|
* which case there might not be a current player (if no default player is
|
|
|
|
* set in players.xml, i.e. the 'remember be' option was not picked ). Since
|
|
|
|
* a lot of code depends on having a local player, just set the most
|
|
|
|
* frequently used non-guest to be the current player.
|
|
|
|
*/
|
|
|
|
void PlayerManager::enforceCurrentPlayer()
|
|
|
|
{
|
|
|
|
if (m_current_player) return;
|
|
|
|
|
|
|
|
PlayerProfile *player;
|
|
|
|
for_in(player, m_all_players)
|
|
|
|
{
|
|
|
|
if (!player->isGuestAccount())
|
|
|
|
{
|
|
|
|
Log::info("PlayerManager", "Enfocring current player '%ls'.",
|
|
|
|
player->getName().c_str() );
|
|
|
|
m_current_player = player;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
} // for player in m_all_players
|
|
|
|
|
|
|
|
// This shouldn't happen - but just in case: add the default players
|
|
|
|
// again, and search again for a non-guest player.
|
|
|
|
addDefaultPlayer();
|
|
|
|
for_in(player, m_all_players)
|
|
|
|
{
|
|
|
|
if (!player->isGuestAccount())
|
|
|
|
{
|
|
|
|
Log::info("PlayerManager", "Enfocring current player '%s'.",
|
|
|
|
player->getName().c_str());
|
|
|
|
m_current_player = player;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
} // for player in m_all_players
|
|
|
|
|
|
|
|
// Now this really really should not happen.
|
|
|
|
Log::fatal("PlayerManager", "Failed to find a non-guest player.");
|
|
|
|
} // enforceCurrentPlayer
|
|
|
|
|
2014-02-05 22:43:47 -05:00
|
|
|
// ----------------------------------------------------------------------------
|
2014-03-01 01:16:23 -05:00
|
|
|
/** Called when no player profiles exists. It creates two players: one
|
|
|
|
* guest player, and one non-guest player for whic hit tries to guess a
|
|
|
|
* mame based on environment variables.
|
|
|
|
*/
|
2014-02-05 22:43:47 -05:00
|
|
|
void PlayerManager::addDefaultPlayer()
|
|
|
|
{
|
|
|
|
std::string username = "unnamed player";
|
|
|
|
|
|
|
|
if(getenv("USERNAME")!=NULL) // for windows
|
|
|
|
username = getenv("USERNAME");
|
|
|
|
else if(getenv("USER")!=NULL) // Linux, Macs
|
|
|
|
username = getenv("USER");
|
|
|
|
else if(getenv("LOGNAME")!=NULL) // Linux, Macs
|
|
|
|
username = getenv("LOGNAME");
|
|
|
|
|
2014-04-14 19:06:50 -04:00
|
|
|
// Set the name as the default name, but don't mark it as 'default'
|
|
|
|
// yet, since not having a default player forces the player selection
|
|
|
|
// screen to be shown.
|
2014-04-17 01:39:51 -04:00
|
|
|
m_all_players.push_back(new Online::OnlinePlayerProfile(username.c_str()) );
|
2014-02-05 22:43:47 -05:00
|
|
|
|
|
|
|
// add default guest player
|
2014-04-17 01:39:51 -04:00
|
|
|
m_all_players.push_back(new Online::OnlinePlayerProfile(_LTR("Guest"), /*guest*/true));
|
2014-02-05 22:43:47 -05:00
|
|
|
} // addDefaultPlayer
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
2014-03-01 01:16:23 -05:00
|
|
|
/** This returns a unique id. This is 1 + largest id used so far.
|
2014-02-05 22:43:47 -05:00
|
|
|
*/
|
|
|
|
unsigned int PlayerManager::getUniqueId() const
|
|
|
|
{
|
|
|
|
unsigned int max_id=0;
|
|
|
|
const PlayerProfile *player;
|
|
|
|
for_in(player, m_all_players)
|
|
|
|
{
|
|
|
|
if(player->getUniqueID()>max_id)
|
|
|
|
max_id = player->getUniqueID();
|
|
|
|
}
|
|
|
|
return max_id+1;
|
|
|
|
} // getUniqueId
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
2014-03-01 01:16:23 -05:00
|
|
|
/** Returns a PlayerProfile with a given id. It searches linearly through
|
|
|
|
* the list of all players.
|
|
|
|
* \returns The profile, or NULL if no such profile exists.
|
|
|
|
* \param id The id of the player to look for.
|
|
|
|
*/
|
2014-02-06 07:08:55 -05:00
|
|
|
const PlayerProfile *PlayerManager::getPlayerById(unsigned int id)
|
|
|
|
{
|
|
|
|
const PlayerProfile *player;
|
|
|
|
for_in(player, m_all_players)
|
|
|
|
{
|
|
|
|
if(player->getUniqueID()==id)
|
|
|
|
return player;
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
} // getPlayerById
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
2014-03-01 01:16:23 -05:00
|
|
|
/** Returns a player with a given name.
|
|
|
|
* \return The player profile or NULL if the name was not found.
|
|
|
|
* \param name The name to search for.
|
|
|
|
*/
|
2014-02-06 07:08:55 -05:00
|
|
|
PlayerProfile *PlayerManager::getPlayer(const irr::core::stringw &name)
|
|
|
|
{
|
|
|
|
PlayerProfile *player;
|
|
|
|
for_in(player, m_all_players)
|
|
|
|
{
|
|
|
|
if(player->getName()==name)
|
|
|
|
return player;
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
} // getPlayer
|
2014-02-05 22:43:47 -05:00
|
|
|
// ----------------------------------------------------------------------------
|
2014-03-01 01:16:23 -05:00
|
|
|
/** Sets the current player. This is the player that is used for story mode
|
|
|
|
* and achievements. If 'remember_me' is set, this information will be
|
|
|
|
* stored in the players.xml file, and automatically loaded next time
|
|
|
|
* STK is started.
|
|
|
|
* \param Player profile to be the current player.
|
|
|
|
* \param remember_me If this player should be marked as default
|
|
|
|
* player in players.xml
|
|
|
|
*/
|
2014-02-27 20:36:53 -05:00
|
|
|
void PlayerManager::setCurrentPlayer(PlayerProfile *player, bool remember_me)
|
2014-02-09 07:22:45 -05:00
|
|
|
{
|
|
|
|
// Reset current default player
|
|
|
|
if(m_current_player)
|
|
|
|
m_current_player->setDefault(false);
|
|
|
|
m_current_player = player;
|
2014-02-28 04:23:09 -05:00
|
|
|
if(m_current_player)
|
|
|
|
{
|
|
|
|
m_current_player->setDefault(remember_me);
|
|
|
|
m_current_player->computeActive();
|
|
|
|
}
|
2014-02-09 07:22:45 -05:00
|
|
|
} // setCurrentPlayer
|
|
|
|
|
2014-02-05 22:43:47 -05:00
|
|
|
// ----------------------------------------------------------------------------
|
2014-04-23 18:17:44 -04:00
|
|
|
/** Adds an online id to the list of all online ids, if that id is not already
|
|
|
|
* in the list. An added id is always moved to the front of the list, so that
|
|
|
|
* the list of online ids shown to the user is sorted by recently-used ids.
|
|
|
|
* \param online_id An online id.
|
|
|
|
*/
|
|
|
|
void PlayerManager::addOnlineId(const core::stringw &online_id)
|
|
|
|
{
|
|
|
|
std::vector<core::stringw>::iterator i = std::find(m_all_online_ids.begin(),
|
|
|
|
m_all_online_ids.end(),
|
|
|
|
online_id);
|
|
|
|
if (i == m_all_online_ids.end())
|
|
|
|
{
|
|
|
|
m_all_online_ids.insert(m_all_online_ids.begin(), online_id);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// If the online_id is not already at the front of the list,
|
|
|
|
// move it to the front.
|
|
|
|
if (i != m_all_online_ids.begin())
|
|
|
|
{
|
|
|
|
m_all_online_ids.erase(i);
|
|
|
|
m_all_online_ids.insert(m_all_online_ids.begin(), online_id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} // addOnlineId
|