Fix wide-string player names (only if irrlicht 1.8 is used)
git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/trunk@8060 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
parent
c4660216fd
commit
de743669f8
@ -23,8 +23,51 @@
|
|||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
using namespace irr;
|
using namespace irr;
|
||||||
|
|
||||||
|
#if IRRLICHT_VERSION_MAJOR > 1 || (IRRLICHT_VERSION_MAJOR == 1 && IRRLICHT_VERSION_MINOR >= 8)
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
XMLWriter::XMLWriter(const char* dest) : m_base(dest, std::ios::out | std::ios::binary)
|
||||||
|
{
|
||||||
|
if (!m_base.is_open())
|
||||||
|
{
|
||||||
|
throw std::runtime_error("Failed to open file for writing : " + std::string(dest));
|
||||||
|
}
|
||||||
|
|
||||||
|
// FIXME: make sure to properly handle endianness
|
||||||
|
wchar_t BOM = 0xFEFF; // UTF-16 BOM is 0xFEFF; UTF-32 BOM is 0x0000FEFF. So this works in either case
|
||||||
|
|
||||||
|
m_base.write((char *) &BOM, sizeof(wchar_t));
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
XMLWriter& XMLWriter::operator<< (const irr::core::stringw& txt)
|
||||||
|
{
|
||||||
|
m_base.write((char *) txt.c_str(), txt.size() * sizeof(wchar_t));
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
XMLWriter& XMLWriter::operator<< (const wchar_t*txt)
|
||||||
|
{
|
||||||
|
m_base.write((char *) txt, wcslen(txt) * sizeof(wchar_t));
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
void XMLWriter::close()
|
||||||
|
{
|
||||||
|
m_base.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#else // Non-unicode version for irrlicht 1.7 and before
|
||||||
|
|
||||||
XMLWriter::XMLWriter(const char* dest) : m_base(dest, std::ios::out | std::ios::binary)
|
XMLWriter::XMLWriter(const char* dest) : m_base(dest, std::ios::out | std::ios::binary)
|
||||||
{
|
{
|
||||||
if (!m_base.is_open())
|
if (!m_base.is_open())
|
||||||
@ -60,47 +103,4 @@ void XMLWriter::close()
|
|||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
// UNICODE version below, deactivated until irrlicht devs fix their XML reading bug...
|
|
||||||
#if 0
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
XMLWriter::XMLWriter(const char* dest) : m_base(dest, std::ios::out | std::ios::binary)
|
|
||||||
{
|
|
||||||
if (!m_base.is_open())
|
|
||||||
{
|
|
||||||
throw std::runtime_error("Failed to open file for writing : " + std::string(dest));
|
|
||||||
}
|
|
||||||
|
|
||||||
// FIXME: make sure the BOM makes sense on platforms where sizeof(wchar_t) is 32 bits
|
|
||||||
// FIXME: make sure to properly handle endianness
|
|
||||||
wchar_t BOM = 0xFEFF;
|
|
||||||
|
|
||||||
m_base.write((char *) &BOM, sizeof(wchar_t));
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
XMLWriter& XMLWriter::operator<< (const irr::core::stringw& txt)
|
|
||||||
{
|
|
||||||
m_base.write((char *) txt.c_str(), txt.size() * sizeof(wchar_t));
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
XMLWriter& XMLWriter::operator<< (const wchar_t*txt)
|
|
||||||
{
|
|
||||||
m_base.write((char *) txt, wcslen(txt) * sizeof(wchar_t));
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
void XMLWriter::close()
|
|
||||||
{
|
|
||||||
m_base.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -85,7 +85,11 @@ void OptionsScreenPlayers::init()
|
|||||||
|
|
||||||
bool OptionsScreenPlayers::gotNewPlayerName(const stringw& newName, PlayerProfile* player)
|
bool OptionsScreenPlayers::gotNewPlayerName(const stringw& newName, PlayerProfile* player)
|
||||||
{
|
{
|
||||||
|
// FIXME: Using a truncated ASCII string for internal ID. Let's cross our fingers
|
||||||
|
// and hope no one enters two player names that, when stripped down to ASCII,
|
||||||
|
// give the same identifier...
|
||||||
stringc newNameC( newName );
|
stringc newNameC( newName );
|
||||||
|
|
||||||
ListWidget* players = this->getWidget<ListWidget>("players");
|
ListWidget* players = this->getWidget<ListWidget>("players");
|
||||||
if (players == NULL) return false;
|
if (players == NULL) return false;
|
||||||
|
|
||||||
@ -102,20 +106,18 @@ bool OptionsScreenPlayers::gotNewPlayerName(const stringw& newName, PlayerProfil
|
|||||||
// add new player
|
// add new player
|
||||||
UserConfigParams::m_all_players.push_back( new PlayerProfile(newName) );
|
UserConfigParams::m_all_players.push_back( new PlayerProfile(newName) );
|
||||||
|
|
||||||
players->addItem( newNameC.c_str(), newNameC.c_str() );
|
players->addItem( newNameC.c_str(), newName );
|
||||||
}
|
}
|
||||||
else // ---- Rename existing player
|
else // ---- Rename existing player
|
||||||
{
|
{
|
||||||
player->setName( newNameC.c_str() );
|
player->setName( newName );
|
||||||
|
|
||||||
// refresh list display
|
// refresh list display
|
||||||
players->clear();
|
players->clear();
|
||||||
const int playerAmount = UserConfigParams::m_all_players.size();
|
const int playerAmount = UserConfigParams::m_all_players.size();
|
||||||
for(int n=0; n<playerAmount; n++)
|
for(int n=0; n<playerAmount; n++)
|
||||||
{
|
{
|
||||||
// FIXME: encoding issues
|
players->addItem(newNameC.c_str(), UserConfigParams::m_all_players[n].getName());
|
||||||
players->addItem(core::stringc(UserConfigParams::m_all_players[n].getName().c_str()).c_str(),
|
|
||||||
UserConfigParams::m_all_players[n].getName());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user