forked from 0ad/0ad
Corrected string conversion slightly
This was SVN commit r2034.
This commit is contained in:
parent
6d792365aa
commit
5b11dbb6b0
@ -7,43 +7,42 @@
|
|||||||
|
|
||||||
#include <jsapi.h>
|
#include <jsapi.h>
|
||||||
|
|
||||||
// Make JS debugging a little easier by automatically naming GC roots
|
|
||||||
#ifndef NDEBUG
|
|
||||||
// Don't simply #define NAME_ALL_GC_ROOTS, because jsapi.h is horridly broken
|
|
||||||
# define JS_AddRoot(cx, rp) JS_AddNamedRoot((cx), (rp), __FILE__)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#if SDL_BYTE_ORDER == SDL_BIG_ENDIAN
|
#if SDL_BYTE_ORDER == SDL_BIG_ENDIAN
|
||||||
#define ucs2le_to_wchart(ptr) (wchar_t)( (u16) ((u8*)ptr)[0] | (u16) ( ((u8*)ptr)[1] << 8) )
|
#define ucs2le_to_wchart(ptr) (wchar_t)( (u16) ((u8*)ptr)[0] | (u16) ( ((u8*)ptr)[1] << 8) )
|
||||||
#else
|
#else
|
||||||
#define ucs2le_to_wchart(ptr) (wchar_t)(*ptr);
|
#define ucs2le_to_wchart(ptr) (wchar_t)(*ptr);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
JSString* StringConvert::wstring_to_jsstring(JSContext* cx, const std::wstring& str)
|
|
||||||
|
JSString* StringConvert::wchars_to_jsstring(JSContext* cx, const wchar_t* chars, size_t len)
|
||||||
{
|
{
|
||||||
size_t len = str.length();
|
if (len == 0)
|
||||||
|
return JSVAL_TO_STRING(JS_GetEmptyStringValue(cx));
|
||||||
|
|
||||||
jschar* data = (jschar*)JS_malloc(cx, len*sizeof(jschar));
|
jschar* data = (jschar*)JS_malloc(cx, len*sizeof(jschar));
|
||||||
|
|
||||||
if (!data)
|
if (!data)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
// Copy the string data, doing wchar_t->jschar conversion (since they're not equal in GCC)
|
||||||
for (size_t i=0; i<len; ++i)
|
for (size_t i=0; i<len; ++i)
|
||||||
data[i] = str[i];
|
data[i] = chars[i];
|
||||||
|
|
||||||
return JS_NewUCString(cx, data, len);
|
return JS_NewUCString(cx, data, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
JSString* StringConvert::wchars_to_jsstring(JSContext* cx, const wchar_t* chars)
|
JSString* StringConvert::wchars_to_jsstring(JSContext* cx, const wchar_t* chars)
|
||||||
{
|
{
|
||||||
size_t len = wcslen(chars);
|
return wchars_to_jsstring(cx, chars, wcslen(chars));
|
||||||
if( !len )
|
|
||||||
return( JSVAL_TO_STRING( JS_GetEmptyStringValue( cx ) ) );
|
|
||||||
jschar* data = (jschar*)JS_malloc(cx, len*sizeof(jschar));
|
|
||||||
if (!data)
|
|
||||||
return NULL;
|
|
||||||
for (size_t i=0; i<len; ++i)
|
|
||||||
data[i] = chars[i];
|
|
||||||
return JS_NewUCString(cx, data, len);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
JSString* StringConvert::wstring_to_jsstring(JSContext* cx, const std::wstring& str)
|
||||||
|
{
|
||||||
|
return wchars_to_jsstring(cx, str.data(), str.length());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void StringConvert::jsstring_to_wstring(JSString* str, std::wstring& result)
|
void StringConvert::jsstring_to_wstring(JSString* str, std::wstring& result)
|
||||||
{
|
{
|
||||||
jschars_to_wstring(JS_GetStringChars(str), JS_GetStringLength(str), result);
|
jschars_to_wstring(JS_GetStringChars(str), JS_GetStringLength(str), result);
|
||||||
@ -52,18 +51,19 @@ void StringConvert::jsstring_to_wstring(JSString* str, std::wstring& result)
|
|||||||
void StringConvert::jschars_to_wstring(const jschar* chars, size_t len, std::wstring& result)
|
void StringConvert::jschars_to_wstring(const jschar* chars, size_t len, std::wstring& result)
|
||||||
{
|
{
|
||||||
assert(result.empty());
|
assert(result.empty());
|
||||||
result.reserve(len);
|
result.resize(len);
|
||||||
|
|
||||||
for (size_t i = 0; i < len; ++i)
|
for (size_t i = 0; i < len; ++i)
|
||||||
result += chars[i];
|
result[i] = chars[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void StringConvert::ucs2le_to_wstring(const char* start, const char* end, std::wstring& result)
|
void StringConvert::ucs2le_to_wstring(const char* start, const char* end, std::wstring& result)
|
||||||
{
|
{
|
||||||
assert(result.empty());
|
assert(result.empty());
|
||||||
result.reserve(end-start);
|
result.resize((end-start)/2);
|
||||||
|
|
||||||
|
size_t i = 0;
|
||||||
for (const char* pos = start; pos < end; pos += 2)
|
for (const char* pos = start; pos < end; pos += 2)
|
||||||
result += ucs2le_to_wchart(pos);
|
result[i++] = ucs2le_to_wchart(pos);
|
||||||
}
|
}
|
||||||
|
@ -12,6 +12,7 @@ namespace StringConvert
|
|||||||
|
|
||||||
JSString* wstring_to_jsstring(JSContext* cx, const std::wstring& str);
|
JSString* wstring_to_jsstring(JSContext* cx, const std::wstring& str);
|
||||||
JSString* wchars_to_jsstring(JSContext* cx, const wchar_t* chars);
|
JSString* wchars_to_jsstring(JSContext* cx, const wchar_t* chars);
|
||||||
|
JSString* wchars_to_jsstring(JSContext* cx, const wchar_t* chars, size_t len);
|
||||||
|
|
||||||
void jsstring_to_wstring(JSString* str, std::wstring& result);
|
void jsstring_to_wstring(JSString* str, std::wstring& result);
|
||||||
void jschars_to_wstring(const jschar* chars, size_t len, std::wstring& result);
|
void jschars_to_wstring(const jschar* chars, size_t len, std::wstring& result);
|
||||||
|
Loading…
Reference in New Issue
Block a user