1
0
forked from 0ad/0ad
0ad/source/lib/wchar.h
Ykkrosh 48f0c9b5d7 Set svn:eol-style=native
This was SVN commit r7252.
2010-01-07 17:42:56 +00:00

48 lines
1.6 KiB
C++

/* Copyright (C) 2009 Wildfire Games.
* This file is part of 0 A.D.
*
* 0 A.D. 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.
*
* 0 A.D. 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 0 A.D. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef INCLUDED_WCHAR
#define INCLUDED_WCHAR
// note: error codes are returned via optional output parameter.
namespace ERR
{
const LibError WCHAR_SURROGATE = -100700;
const LibError WCHAR_OUTSIDE_BMP = -100701;
const LibError WCHAR_NONCHARACTER = -100702;
const LibError WCHAR_INVALID_UTF8 = -100703;
}
/**
* convert UTF-8 to a wide string (UTF-16 or UCS-4, depending on the
* platform's wchar_t).
*
* @param s input string (UTF-8)
* @param err if nonzero, this receives the first error encountered
* (the rest may be subsequent faults) or INFO::OK if all went well.
* otherwise, the function raises a warning dialog for every
* error/warning.
**/
LIB_API std::wstring wstring_from_utf8(const std::string& s, LibError* err = 0);
/**
* opposite of wstring_from_utf8
**/
LIB_API std::string utf8_from_wstring(const std::wstring& s, LibError* err = 0);
#endif // #ifndef INCLUDED_WCHAR