Merge branch 'develop' into ryzomclassic-develop

ryzomclassic-develop
kaetemi 4 years ago
commit c791fe5742

@ -87,7 +87,9 @@ namespace NLGUI
/// Get the ContextHelp for this control. Default is to return _ContextHelp /// Get the ContextHelp for this control. Default is to return _ContextHelp
virtual void getContextHelp(std::string &help) const {help= _ContextHelp;} virtual void getContextHelp(std::string &help) const {help= _ContextHelp;}
virtual void getContextHelpAsUtf16(ucstring &help) const {help.fromUtf8(_ContextHelp);} #ifdef RYZOM_LUA_UCSTRING
virtual void getContextHelpAsUtf16(ucstring &help) const {help.fromUtf8(_ContextHelp);} // Compatibility
#endif
/// Get the ContextHelp for this control, with tooltip specific code. Default behaviour is identical to getContextHelp. /// Get the ContextHelp for this control, with tooltip specific code. Default behaviour is identical to getContextHelp.
virtual void getContextHelpToolTip(std::string &help) const { getContextHelp(help); } virtual void getContextHelpToolTip(std::string &help) const { getContextHelp(help); }
// Get the name of the context help window. Default to "context_help" // Get the name of the context help window. Default to "context_help"
@ -127,8 +129,10 @@ namespace NLGUI
/// replace the default contextHelp /// replace the default contextHelp
std::string getDefaultContextHelp() const {return _ContextHelp;} std::string getDefaultContextHelp() const {return _ContextHelp;}
void setDefaultContextHelp(const std::string &help) {_ContextHelp= help;} void setDefaultContextHelp(const std::string &help) {_ContextHelp= help;}
ucstring getDefaultContextHelpAsUtf16() const {return ucstring::makeFromUtf8(_ContextHelp);} #ifdef RYZOM_LUA_UCSTRING
void setDefaultContextHelpAsUtf16(const ucstring &help) {_ContextHelp= help.toUtf8();} ucstring getDefaultContextHelpAsUtf16() const {return ucstring::makeFromUtf8(_ContextHelp);} // Compatibility
void setDefaultContextHelpAsUtf16(const ucstring &help) {_ContextHelp= help.toUtf8();} // Compatibility
#endif
void setOnContextHelp(const std::string &help) {_OnContextHelp= help;} void setOnContextHelp(const std::string &help) {_OnContextHelp= help;}
void setOnContextHelpAHParams(const std::string &p) {_OnContextHelpParams= p;} void setOnContextHelpAHParams(const std::string &p) {_OnContextHelpParams= p;}
@ -158,12 +162,18 @@ namespace NLGUI
// called when keyboard capture has been lost // called when keyboard capture has been lost
virtual void onKeyboardCaptureLost() {} virtual void onKeyboardCaptureLost() {}
#ifdef RYZOM_LUA_UCSTRING
// 'tooltip' property expects string to be ucstring or latin1 which is not possible from html page // 'tooltip' property expects string to be ucstring or latin1 which is not possible from html page
int luaSetTooltipUtf8(CLuaState &ls); int luaSetTooltipUtf8(CLuaState &ls); // Compatibility
#endif
REFLECT_EXPORT_START(CCtrlBase, CViewBase) REFLECT_EXPORT_START(CCtrlBase, CViewBase)
REFLECT_UCSTRING("tooltip", getDefaultContextHelpAsUtf16, setDefaultContextHelpAsUtf16); // FIXME: Lua UTF-8 #ifdef RYZOM_LUA_UCSTRING
REFLECT_LUA_METHOD("setTooltipUtf8", luaSetTooltipUtf8); REFLECT_UCSTRING("tooltip", getDefaultContextHelpAsUtf16, setDefaultContextHelpAsUtf16); // Compatibility
REFLECT_LUA_METHOD("setTooltipUtf8", luaSetTooltipUtf8); // Compatibility
#else
REFLECT_STRING("tooltip", getDefaultContextHelp, setDefaultContextHelp);
#endif
REFLECT_EXPORT_END REFLECT_EXPORT_END
// special for mouse over : return true and fill the name of the cursor to display // special for mouse over : return true and fill the name of the cursor to display

@ -99,8 +99,12 @@ namespace NLGUI
// Set text (noop if text id) // Set text (noop if text id)
void setText (const std::string &text); void setText (const std::string &text);
std::string getText () const; std::string getText () const;
void setTextAsUtf16 (const ucstring &text); #ifdef RYZOM_LUA_UCSTRING
ucstring getTextAsUtf16 () const; void setTextAsUtf16 (const ucstring &text); // Compatibility
ucstring getTextAsUtf16 () const; // Compatibility
#endif
void setLocalize (bool localize);
bool isLocalized () const;
void setHardText (const std::string &text); void setHardText (const std::string &text);
std::string getHardText () const; std::string getHardText () const;
@ -133,8 +137,12 @@ namespace NLGUI
int luaGetViewText(CLuaState &ls); int luaGetViewText(CLuaState &ls);
REFLECT_EXPORT_START(CCtrlTextButton, CCtrlBaseButton) REFLECT_EXPORT_START(CCtrlTextButton, CCtrlBaseButton)
REFLECT_UCSTRING("uc_hardtext", getTextAsUtf16, setTextAsUtf16); #ifdef RYZOM_LUA_UCSTRING
REFLECT_UCSTRING("uc_hardtext", getTextAsUtf16, setTextAsUtf16); // Compatibility
#endif
REFLECT_BOOL("localize", isLocalized, setLocalize);
REFLECT_STRING("hardtext", getHardText, setHardText); REFLECT_STRING("hardtext", getHardText, setHardText);
REFLECT_STRING("text", getText, setText);
REFLECT_SINT32("text_x", getTextX, setTextX) REFLECT_SINT32("text_x", getTextX, setTextX)
REFLECT_SINT32("wmargin", getWMargin, setWMargin) REFLECT_SINT32("wmargin", getWMargin, setWMargin)
REFLECT_SINT32("wmin", getWMin, setWMin) REFLECT_SINT32("wmin", getWMin, setWMin)

@ -64,11 +64,15 @@ namespace NLGUI
void setText(uint i, const std::string &text); void setText(uint i, const std::string &text);
void insertText(uint i, const std::string &text); void insertText(uint i, const std::string &text);
const std::string &getText(uint i) const; const std::string &getText(uint i) const;
ucstring getTextAsUtf16(uint i) const; #ifdef RYZOM_LUA_UCSTRING
ucstring getTextAsUtf16(uint i) const; // Compatibility
#endif
uint getTextId(uint i) const; uint getTextId(uint i) const;
uint getTextPos(uint nId) const; uint getTextPos(uint nId) const;
const std::string &getTexture(uint i) const; const std::string &getTexture(uint i) const;
ucstring getTextureAsUtf16(uint i) const; #ifdef RYZOM_LUA_UCSTRING
ucstring getTextureAsUtf16(uint i) const; // Compatibility
#endif
void setGrayed(uint i, bool g); void setGrayed(uint i, bool g);
bool getGrayed(uint i) const; bool getGrayed(uint i) const;
void removeText(uint nPos); void removeText(uint nPos);
@ -91,8 +95,10 @@ namespace NLGUI
// view text // view text
void setViewText(const std::string & text); void setViewText(const std::string & text);
std::string getViewText() const; std::string getViewText() const;
void setViewTextAsUtf16(const ucstring &text) { setViewText(text.toUtf8()); } #ifdef RYZOM_LUA_UCSTRING
ucstring getViewTextAsUtf16() const; void setViewTextAsUtf16(const ucstring &text) { setViewText(text.toUtf8()); } // Compatibility
ucstring getViewTextAsUtf16() const; // Compatibility
#endif
CViewText *getViewText(); CViewText *getViewText();
void setTexture(uint i, const std::string &texture); void setTexture(uint i, const std::string &texture);
@ -126,7 +132,11 @@ namespace NLGUI
REFLECT_LUA_METHOD("resetTexts", luaResetTexts) REFLECT_LUA_METHOD("resetTexts", luaResetTexts)
REFLECT_SINT32 ("selectionNb", getSelectionNb, setSelectionNb) REFLECT_SINT32 ("selectionNb", getSelectionNb, setSelectionNb)
REFLECT_STRING ("selection_text", getSelectionText, setSelectionText) REFLECT_STRING ("selection_text", getSelectionText, setSelectionText)
REFLECT_UCSTRING ("view_text", getViewTextAsUtf16, setViewTextAsUtf16) // FIXME: Better to have UTF-8 #ifdef RYZOM_LUA_UCSTRING
REFLECT_UCSTRING ("view_text", getViewTextAsUtf16, setViewTextAsUtf16) // Compatibility
#else
REFLECT_STRING ("view_text", getViewText, setViewText)
#endif
REFLECT_EXPORT_END REFLECT_EXPORT_END

@ -249,12 +249,14 @@ namespace NLGUI
// Get the header color draw. NB: depends if grayed, and if active. // Get the header color draw. NB: depends if grayed, and if active.
NLMISC::CRGBA getDrawnHeaderColor () const; NLMISC::CRGBA getDrawnHeaderColor () const;
ucstring getUCTitleOpened () const; #ifdef RYZOM_LUA_UCSTRING
void setUCTitleOpened (const ucstring &title); ucstring getUCTitleOpened () const; // Compatibility
ucstring getUCTitleClosed () const; void setUCTitleOpened (const ucstring &title); // Compatibility
void setUCTitleClosed (const ucstring &title); ucstring getUCTitleClosed () const; // Compatibility
ucstring getUCTitle () const; void setUCTitleClosed (const ucstring &title); // Compatibility
void setUCTitle (const ucstring &title); ucstring getUCTitle () const; // Compatibility
void setUCTitle (const ucstring &title); // Compatibility
#endif
void setPopable(bool popable) { _Popable = popable; } void setPopable(bool popable) { _Popable = popable; }
bool isPopable() const { return _Popable; } bool isPopable() const { return _Popable; }
@ -289,9 +291,11 @@ namespace NLGUI
REFLECT_STRING("title_opened", getTitleOpened, setTitleOpened); REFLECT_STRING("title_opened", getTitleOpened, setTitleOpened);
REFLECT_STRING("title_closed", getTitleClosed, setTitleClosed); REFLECT_STRING("title_closed", getTitleClosed, setTitleClosed);
REFLECT_UCSTRING("uc_title_opened", getUCTitleOpened, setUCTitleOpened); // FIXME: Lua UTF-8 #ifdef RYZOM_LUA_UCSTRING
REFLECT_UCSTRING("uc_title_closed", getUCTitleClosed, setUCTitleClosed); // FIXME: Lua UTF-8 REFLECT_UCSTRING("uc_title_opened", getUCTitleOpened, setUCTitleOpened); // Compatibility
REFLECT_UCSTRING("uc_title", getUCTitle, setUCTitle); // FIXME: Lua UTF-8 REFLECT_UCSTRING("uc_title_closed", getUCTitleClosed, setUCTitleClosed); // Compatibility
REFLECT_UCSTRING("uc_title", getUCTitle, setUCTitle); // Compatibility
#endif
REFLECT_STRING("title_color", getTitleColorAsString, setTitleColorAsString); REFLECT_STRING("title_color", getTitleColorAsString, setTitleColorAsString);
REFLECT_SINT32("pop_min_h", getPopupMinH, setPopupMinH); REFLECT_SINT32("pop_min_h", getPopupMinH, setPopupMinH);

@ -74,17 +74,19 @@ namespace NLGUI
*/ */
void setPrompt(const std::string &s); void setPrompt(const std::string &s);
void setInputString(const std::string &str); void setInputString(const std::string &str);
void setInputStringRef(const ::u32string &str) {_InputString = str; }; void setInputStringRef(const ::u32string &str);
void setInputStringAsInt(sint32 val); void setInputStringAsInt(sint32 val);
sint32 getInputStringAsInt() const; sint32 getInputStringAsInt() const;
void setInputStringAsInt64(sint64 val); void setInputStringAsInt64(sint64 val);
sint64 getInputStringAsInt64() const; sint64 getInputStringAsInt64() const;
void setInputStringAsFloat(float val); void setInputStringAsFloat(float val);
float getInputStringAsFloat() const; float getInputStringAsFloat() const;
void setInputStringAsUtf16(const ucstring &str); #ifdef RYZOM_LUA_UCSTRING
ucstring getInputStringAsUtf16() const; void setInputStringAsUtf16(const ucstring &str); // Compatibility
void setInputStringAsUtf32(const ::u32string &str); ucstring getInputStringAsUtf16() const; // Compatibility
::u32string getInputStringAsUtf32() const { return _InputString; } void setInputStringAsUtf32(const ::u32string &str) { setInputStringRef(str); } // Compatibility
::u32string getInputStringAsUtf32() const { return _InputString; } // Compatibility
#endif
void setColor(NLMISC::CRGBA col); void setColor(NLMISC::CRGBA col);
@ -192,7 +194,9 @@ namespace NLGUI
REFLECT_LUA_METHOD("setFocusOnText", luaSetFocusOnText); REFLECT_LUA_METHOD("setFocusOnText", luaSetFocusOnText);
REFLECT_LUA_METHOD("cancelFocusOnText", luaCancelFocusOnText); REFLECT_LUA_METHOD("cancelFocusOnText", luaCancelFocusOnText);
REFLECT_STRING("input_string", getInputString, setInputString); REFLECT_STRING("input_string", getInputString, setInputString);
REFLECT_UCSTRING("uc_input_string", getInputStringAsUtf16, setInputStringAsUtf16); #ifdef RYZOM_LUA_UCSTRING
REFLECT_UCSTRING("uc_input_string", getInputStringAsUtf16, setInputStringAsUtf16); // Compatibility
#endif
REFLECT_EXPORT_END REFLECT_EXPORT_END
/** Restore the original value of the edit box. /** Restore the original value of the edit box.
@ -217,6 +221,7 @@ namespace NLGUI
float _BlinkTime; float _BlinkTime;
sint32 _CursorPos; sint32 _CursorPos;
uint32 _MaxNumChar; uint32 _MaxNumChar;
uint32 _MaxNumBytes;
uint32 _MaxNumReturn; uint32 _MaxNumReturn;
uint32 _MaxFloatPrec; // used in setInputStringAsFloat() only uint32 _MaxFloatPrec; // used in setInputStringAsFloat() only
sint32 _MaxCharsSize; sint32 _MaxCharsSize;

@ -115,8 +115,10 @@ namespace NLGUI
bool getOpened() const { return Opened; } bool getOpened() const { return Opened; }
void setText(const std::string &text) { Text = text; } void setText(const std::string &text) { Text = text; }
const std::string& getText() const { return Text; } const std::string& getText() const { return Text; }
void setTextAsUtf16(const ucstring &text) { Text = text.toUtf8(); } #ifdef RYZOM_LUA_UCSTRING
ucstring getTextAsUtf16() const { return ucstring::makeFromUtf8(Text); } void setTextAsUtf16(const ucstring &text) { Text = text.toUtf8(); } // Compatibility
ucstring getTextAsUtf16() const { return ucstring::makeFromUtf8(Text); } // Compatibility
#endif
sint32 getFontSize() const { return FontSize; } sint32 getFontSize() const { return FontSize; }
void setFontSize(sint32 value) { FontSize = value; } void setFontSize(sint32 value) { FontSize = value; }
sint32 getYDecal() const { return YDecal; } sint32 getYDecal() const { return YDecal; }
@ -184,7 +186,11 @@ namespace NLGUI
REFLECT_STRING("AHParamsClose", getAHParamsClose, setAHParamsClose); REFLECT_STRING("AHParamsClose", getAHParamsClose, setAHParamsClose);
REFLECT_BOOL("Opened", getOpened, setOpened); REFLECT_BOOL("Opened", getOpened, setOpened);
REFLECT_BOOL("Show", getShow, setShow); REFLECT_BOOL("Show", getShow, setShow);
REFLECT_UCSTRING("Text", getTextAsUtf16, setTextAsUtf16); // FIXME: Lua UTF-8 #ifdef RYZOM_LUA_UCSTRING
REFLECT_UCSTRING("Text", getTextAsUtf16, setTextAsUtf16); // Compatibility
#else
REFLECT_STRING_REF("Text", getText, setText);
#endif
// lua // lua
REFLECT_LUA_METHOD("getNumChildren", luaGetNumChildren); REFLECT_LUA_METHOD("getNumChildren", luaGetNumChildren);
REFLECT_LUA_METHOD("getChild", luaGetChild); REFLECT_LUA_METHOD("getChild", luaGetChild);

@ -86,10 +86,12 @@ namespace NLGUI
// ucstring // ucstring
#ifdef RYZOM_LUA_UCSTRING
static bool pop(CLuaState &ls, ucstring &dest); static bool pop(CLuaState &ls, ucstring &dest);
static void push(CLuaState &ls, const ucstring &value); static void push(CLuaState &ls, const ucstring &value);
static bool isUCStringOnStack(CLuaState &ls, sint index); static bool isUCStringOnStack(CLuaState &ls, sint index);
static bool getUCStringOnStack(CLuaState &ls, sint index, ucstring &dest); static bool getUCStringOnStack(CLuaState &ls, sint index, ucstring &dest);
#endif
// RGBA // RGBA
@ -108,7 +110,9 @@ namespace NLGUI
static void check(CLuaState &ls, bool ok, const std::string &failReason); static void check(CLuaState &ls, bool ok, const std::string &failReason);
static void checkArgType(CLuaState &ls, const char *funcName, uint index, int argType); static void checkArgType(CLuaState &ls, const char *funcName, uint index, int argType);
static void checkArgTypeRGBA(CLuaState &ls, const char *funcName, uint index); static void checkArgTypeRGBA(CLuaState &ls, const char *funcName, uint index);
#ifdef RYZOM_LUA_UCSTRING
static void checkArgTypeUCString(CLuaState &ls, const char *funcName, uint index); static void checkArgTypeUCString(CLuaState &ls, const char *funcName, uint index);
#endif
/** throw a lua expection (inside a C function called from lua) with the given reason, and the current call stack /** throw a lua expection (inside a C function called from lua) with the given reason, and the current call stack
* The various check... function call this function when their test fails * The various check... function call this function when their test fails
*/ */
@ -154,10 +158,12 @@ namespace NLGUI
static uint32 getLocalTime(); static uint32 getLocalTime();
static double getPreciseLocalTime(); static double getPreciseLocalTime();
static std::string findReplaceAll(const std::string &str, const std::string &search, const std::string &replace); static std::string findReplaceAll(const std::string &str, const std::string &search, const std::string &replace);
#ifdef RYZOM_LUA_UCSTRING
static ucstring findReplaceAll(const ucstring &str, const ucstring &search, const ucstring &replace); static ucstring findReplaceAll(const ucstring &str, const ucstring &search, const ucstring &replace);
static ucstring findReplaceAll(const ucstring &str, const std::string &search, const std::string &replace); static ucstring findReplaceAll(const ucstring &str, const std::string &search, const std::string &replace);
static ucstring findReplaceAll(const ucstring &str, const std::string &search, const ucstring &replace); static ucstring findReplaceAll(const ucstring &str, const std::string &search, const ucstring &replace);
static ucstring findReplaceAll(const ucstring &str, const ucstring &search, const std::string &replace); static ucstring findReplaceAll(const ucstring &str, const ucstring &search, const std::string &replace);
#endif
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
@ -183,8 +189,10 @@ namespace NLGUI
static int runExpr(CLuaState &ls); // params: "expr". return: any of: nil,bool,string,number, RGBA, UCString static int runExpr(CLuaState &ls); // params: "expr". return: any of: nil,bool,string,number, RGBA, UCString
static int runFct(CLuaState &ls); // params: "expr", param1, param2.... return: any of: nil,bool,string,number, RGBA, UCString static int runFct(CLuaState &ls); // params: "expr", param1, param2.... return: any of: nil,bool,string,number, RGBA, UCString
static int runCommand(CLuaState &ls); // params: "command name", param1, param2 ... return true or false static int runCommand(CLuaState &ls); // params: "command name", param1, param2 ... return true or false
#ifdef RYZOM_LUA_UCSTRING
static int isUCString(CLuaState &ls); static int isUCString(CLuaState &ls);
static int concatUCString(CLuaState &ls); // workaround for + operator that don't work in luabind for ucstrings ... static int concatUCString(CLuaState &ls); // workaround for + operator that don't work in luabind for ucstrings ...
#endif
static int concatString(CLuaState &ls); // speedup concatenation of several strings static int concatString(CLuaState &ls); // speedup concatenation of several strings
static int tableToString(CLuaState &ls); // concat element of a table to build a string static int tableToString(CLuaState &ls); // concat element of a table to build a string
static int getPathContent(CLuaState &ls); static int getPathContent(CLuaState &ls);

@ -298,6 +298,7 @@ namespace NLGUI
props.push_back(prop); \ props.push_back(prop); \
} }
#ifdef RYZOM_LUA_UCSTRING
// export a unicode string value, by giving the name of the get and the set method // export a unicode string value, by giving the name of the get and the set method
#define REFLECT_UCSTRING(exportName, getMethod, setMethod) \ #define REFLECT_UCSTRING(exportName, getMethod, setMethod) \
{ \ { \
@ -308,6 +309,7 @@ namespace NLGUI
prop.SetMethod.SetUCString = (CReflectedProperty::TSetUCString) static_cast<TSetUCStringa>(&A::setMethod); \ prop.SetMethod.SetUCString = (CReflectedProperty::TSetUCString) static_cast<TSetUCStringa>(&A::setMethod); \
props.push_back(prop); \ props.push_back(prop); \
} }
#endif
// export a string value, by giving the name of the get and the set method // export a string value, by giving the name of the get and the set method
#define REFLECT_STRING_REF(exportName, getMethod, setMethod) \ #define REFLECT_STRING_REF(exportName, getMethod, setMethod) \
@ -320,6 +322,7 @@ namespace NLGUI
props.push_back(prop); \ props.push_back(prop); \
} }
#ifdef RYZOM_LUA_UCSTRING
// export a unicode string value, by giving the name of the get and the set method // export a unicode string value, by giving the name of the get and the set method
#define REFLECT_UCSTRING_REF(exportName, getMethod, setMethod) \ #define REFLECT_UCSTRING_REF(exportName, getMethod, setMethod) \
{ \ { \
@ -330,7 +333,7 @@ namespace NLGUI
prop.SetMethod.SetUCString = (CReflectedProperty::TSetUCString) static_cast<TSetUCStringa>(&A::setMethod); \ prop.SetMethod.SetUCString = (CReflectedProperty::TSetUCString) static_cast<TSetUCStringa>(&A::setMethod); \
props.push_back(prop); \ props.push_back(prop); \
} }
#endif
// export a color value, by giving the name of the get and the set method // export a color value, by giving the name of the get and the set method
#define REFLECT_RGBA(exportName, getMethod, setMethod) \ #define REFLECT_RGBA(exportName, getMethod, setMethod) \

@ -86,7 +86,9 @@ namespace NLGUI
void setText(const std::string &text); void setText(const std::string &text);
void setTextLocalized(const std::string &text, bool localized); void setTextLocalized(const std::string &text, bool localized);
void setTextAsUtf16 (const ucstring &text); #ifdef RYZOM_LUA_UCSTRING
void setTextAsUtf16 (const ucstring &text); // Compatibility
#endif
void setLocalized(bool localized); void setLocalized(bool localized);
void setFontName (const std::string &name); void setFontName (const std::string &name);
void setFontSize (sint nFontSize, bool coef = true); void setFontSize (sint nFontSize, bool coef = true);
@ -99,7 +101,9 @@ namespace NLGUI
void setShadowOffset (sint x, sint y); void setShadowOffset (sint x, sint y);
void setLineMaxW (sint nMaxW, bool invalidate=true); void setLineMaxW (sint nMaxW, bool invalidate=true);
void setOverflowText(const std::string &text) { _OverflowText = text; } void setOverflowText(const std::string &text) { _OverflowText = text; }
void setOverflowTextAsUtf16(const ucstring &text) { _OverflowText = text.toUtf8(); } #ifdef RYZOM_LUA_UCSTRING
void setOverflowTextAsUtf16(const ucstring &text) { _OverflowText = text.toUtf8(); } // Compatibility
#endif
void setMultiLine (bool bMultiLine); void setMultiLine (bool bMultiLine);
void setMultiLineSpace (sint nMultiLineSpace); void setMultiLineSpace (sint nMultiLineSpace);
void setMultiLineMaxWOnly (bool state); void setMultiLineMaxWOnly (bool state);
@ -117,8 +121,10 @@ namespace NLGUI
/// Get /// Get
std::string getText() const { return _HardText.empty() ? _Text : _HardText; } std::string getText() const { return _HardText.empty() ? _Text : _HardText; }
ucstring getTextAsUtf16() const; #ifdef RYZOM_LUA_UCSTRING
ucstring getHardTextAsUtf16() const; ucstring getTextAsUtf16() const; // Compatibility
ucstring getHardTextAsUtf16() const; // Compatibility
#endif
bool isLocalized() const { return _Localized; } bool isLocalized() const { return _Localized; }
sint getFontSize() const; sint getFontSize() const;
std::string getFontName() const { return _FontName; } std::string getFontName() const { return _FontName; }
@ -130,7 +136,9 @@ namespace NLGUI
NLMISC::CRGBA getShadowColor() { return _ShadowColor; } NLMISC::CRGBA getShadowColor() { return _ShadowColor; }
void getShadowOffset(sint &x, sint &y) { x = _ShadowX; y = _ShadowY; } void getShadowOffset(sint &x, sint &y) { x = _ShadowX; y = _ShadowY; }
sint getLineMaxW() const { return _LineMaxW; } sint getLineMaxW() const { return _LineMaxW; }
ucstring getOverflowTextAsUtf16() const { return _OverflowText; } #ifdef RYZOM_LUA_UCSTRING
ucstring getOverflowTextAsUtf16() const { return _OverflowText; } // Compatibility
#endif
bool getMultiLine() const { return _MultiLine; } bool getMultiLine() const { return _MultiLine; }
sint getMultiLineSpace() const { return _MultiLineSpace; } sint getMultiLineSpace() const { return _MultiLineSpace; }
bool getMultiLineMaxWOnly() const { return _MultiLineMaxWOnly; } bool getMultiLineMaxWOnly() const { return _MultiLineMaxWOnly; }
@ -182,7 +190,9 @@ namespace NLGUI
std::string getHardText() const { return _HardText.empty() ? _Text : _HardText; } std::string getHardText() const { return _HardText.empty() ? _Text : _HardText; }
void setHardText (const std::string &ht); //< Localizes strings starting with "ui" void setHardText (const std::string &ht); //< Localizes strings starting with "ui"
void setHardTextAsUtf16(const ucstring &ht); #ifdef RYZOM_LUA_UCSTRING
void setHardTextAsUtf16(const ucstring &ht); // Compatibility
#endif
std::string getColorAsString() const; std::string getColorAsString() const;
void setColorAsString(const std::string &ht); void setColorAsString(const std::string &ht);
@ -196,10 +206,14 @@ namespace NLGUI
/** Setup a Text with Format Tags. Text is store without color/format tags, and special array is allocated for Format association /** Setup a Text with Format Tags. Text is store without color/format tags, and special array is allocated for Format association
*/ */
void setTextFormatTaged(const std::string &text); void setTextFormatTaged(const std::string &text);
void setTextFormatTagedAsUtf16(const ucstring &text); #ifdef RYZOM_LUA_UCSTRING
void setTextFormatTagedAsUtf16(const ucstring &text); // Compatibility
#endif
void setSingleLineTextFormatTaged(const std::string &text); void setSingleLineTextFormatTaged(const std::string &text);
void setSingleLineTextFormatTagedAsUtf16(const ucstring &text); #ifdef RYZOM_LUA_UCSTRING
void setSingleLineTextFormatTagedAsUtf16(const ucstring &text); // Compatibility
#endif
// Remove end space // Remove end space
void removeEndSpaces(); void removeEndSpaces();
@ -225,13 +239,17 @@ namespace NLGUI
int luaSetLineMaxW(CLuaState &ls); int luaSetLineMaxW(CLuaState &ls);
REFLECT_EXPORT_START(CViewText, CViewBase) REFLECT_EXPORT_START(CViewText, CViewBase)
REFLECT_STRING("text_raw", getText, setText); REFLECT_BOOL("localize", isLocalized, setLocalized);
REFLECT_STRING("hardtext", getHardText, setHardText); REFLECT_STRING("hardtext", getHardText, setHardText); // Same as text, but localize is implicitly set true
REFLECT_BOOL ("localize", isLocalized, setLocalized); REFLECT_STRING("text", getText, setText);
REFLECT_STRING("text_format", getText, setTextFormatTaged);
REFLECT_STRING("text_single_line_format", getText, setSingleLineTextFormatTaged);
#ifdef RYZOM_LUA_UCSTRING
// REFLECT_UCSTRING("uc_text", getTextAsUtf16, setTextAsUtf16); // Deprecate uc_ functions // REFLECT_UCSTRING("uc_text", getTextAsUtf16, setTextAsUtf16); // Deprecate uc_ functions
REFLECT_UCSTRING("uc_hardtext", getHardTextAsUtf16, setHardTextAsUtf16); REFLECT_UCSTRING("uc_hardtext", getHardTextAsUtf16, setHardTextAsUtf16); // Compatibility
REFLECT_UCSTRING("uc_hardtext_format", getTextAsUtf16, setTextFormatTagedAsUtf16); // FIXME: Name doesn't make sense REFLECT_UCSTRING("uc_hardtext_format", getTextAsUtf16, setTextFormatTagedAsUtf16); // Compatibility
REFLECT_UCSTRING("uc_hardtext_single_line_format", getTextAsUtf16, setSingleLineTextFormatTagedAsUtf16); // FIXME: Name doesn't make sense REFLECT_UCSTRING("uc_hardtext_single_line_format", getTextAsUtf16, setSingleLineTextFormatTagedAsUtf16); // Compatibility
#endif
REFLECT_STRING ("color", getColorAsString, setColorAsString); REFLECT_STRING ("color", getColorAsString, setColorAsString);
REFLECT_RGBA ("color_rgba", getColorRGBA, setColorRGBA); REFLECT_RGBA ("color_rgba", getColorRGBA, setColorRGBA);
REFLECT_SINT32 ("alpha", getAlpha, setAlpha); REFLECT_SINT32 ("alpha", getAlpha, setAlpha);
@ -452,7 +470,7 @@ namespace NLGUI
void setStringSelectionSkipingSpace(uint stringId, const std::string &text, sint charStart, sint charEnd); void setStringSelectionSkipingSpace(uint stringId, const std::string &text, sint charStart, sint charEnd);
// void pushString(const ucstring &str, bool deleteSpaceAtStart = false); // void pushString(const ucstring &str, bool deleteSpaceAtStart = false); // OLD
/// \from CInterfaceElement /// \from CInterfaceElement
void onInvalidateContent(); void onInvalidateContent();

@ -145,7 +145,7 @@ namespace NLGUI
// If true, setTextFormatted() is used instead of setText() // If true, setTextFormatted() is used instead of setText()
bool _IsTextFormatTaged; bool _IsTextFormatTaged;
// Optional ucstring modifier // Optional utf-8 string modifier
IOnReceiveTextId *_StringModifier; IOnReceiveTextId *_StringModifier;
std::string _DBPath; std::string _DBPath;
static IViewTextProvider* getTextProvider(){ return textProvider; } static IViewTextProvider* getTextProvider(){ return textProvider; }

@ -20,6 +20,8 @@
#ifndef NL_UCSTRING_H #ifndef NL_UCSTRING_H
#define NL_UCSTRING_H #define NL_UCSTRING_H
#define RYZOM_LUA_UCSTRING
#include "types_nl.h" #include "types_nl.h"
#include "debug.h" #include "debug.h"

@ -573,6 +573,7 @@ namespace NLGUI
return itr2->second; return itr2->second;
} }
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
int CCtrlBase::luaSetTooltipUtf8(CLuaState &ls) int CCtrlBase::luaSetTooltipUtf8(CLuaState &ls)
{ {
@ -585,5 +586,6 @@ namespace NLGUI
return 0; return 0;
} }
#endif
} }

@ -1051,6 +1051,20 @@ namespace NLGUI
return std::string(); return std::string();
} }
void CCtrlTextButton::setLocalize(bool localize)
{
if (_ViewText && !_IsViewTextId)
_ViewText->setLocalized(localize);
}
bool CCtrlTextButton::isLocalized() const
{
if (_ViewText && !_IsViewTextId)
return _ViewText->isLocalized();
return true;
}
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
void CCtrlTextButton::setTextAsUtf16 (const ucstring &text) void CCtrlTextButton::setTextAsUtf16 (const ucstring &text)
{ {
@ -1065,6 +1079,7 @@ namespace NLGUI
return CUtfStringView(_ViewText->getText()).toUtf16(); return CUtfStringView(_ViewText->getText()).toUtf16();
return ucstring(""); return ucstring("");
} }
#endif
// *************************************************************************** // ***************************************************************************
void CCtrlTextButton::setHardText (const std::string &text) void CCtrlTextButton::setHardText (const std::string &text)

@ -361,11 +361,13 @@ namespace NLGUI
return empty; return empty;
} }
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
ucstring CDBGroupComboBox::getTextAsUtf16(uint i) const ucstring CDBGroupComboBox::getTextAsUtf16(uint i) const
{ {
return ucstring::makeFromUtf8(getText(i)); return ucstring::makeFromUtf8(getText(i));
} }
#endif
// *************************************************************************** // ***************************************************************************
uint CDBGroupComboBox::getTextId(uint i) const uint CDBGroupComboBox::getTextId(uint i) const
@ -402,12 +404,14 @@ namespace NLGUI
else else
return empty; return empty;
} }
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
ucstring CDBGroupComboBox::getTextureAsUtf16(uint i) const ucstring CDBGroupComboBox::getTextureAsUtf16(uint i) const
{ {
return ucstring::makeFromUtf8(getTexture(i)); return ucstring::makeFromUtf8(getTexture(i));
} }
#endif
// *************************************************************************** // ***************************************************************************
void CDBGroupComboBox::setSelection(sint32 val) void CDBGroupComboBox::setSelection(sint32 val)
@ -489,11 +493,13 @@ namespace NLGUI
return _ViewText->getText(); return _ViewText->getText();
} }
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
ucstring CDBGroupComboBox::getViewTextAsUtf16() const ucstring CDBGroupComboBox::getViewTextAsUtf16() const
{ {
return CUtfStringView(_ViewText->getText()).toUtf16(); return CUtfStringView(_ViewText->getText()).toUtf16();
} }
#endif
// *************************************************************************** // ***************************************************************************
CViewText *CDBGroupComboBox::getViewText() CViewText *CDBGroupComboBox::getViewText()
@ -576,10 +582,16 @@ namespace NLGUI
{ {
const char *funcName = "addText"; const char *funcName = "addText";
CLuaIHM::checkArgCount(ls, funcName, 1); CLuaIHM::checkArgCount(ls, funcName, 1);
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::checkArgTypeUCString(ls, funcName, 1); CLuaIHM::checkArgTypeUCString(ls, funcName, 1);
ucstring text; ucstring text; // Compatibility
nlverify(CLuaIHM::pop(ls, text)); nlverify(CLuaIHM::pop(ls, text));
addText(text.toUtf8()); // FIXME: Lua should just do UTF-8! addText(text.toUtf8());
#else
CLuaIHM::checkArgType(ls, funcName, 1, LUA_TSTRING);
string text = ls.toString(1);
addText(text);
#endif
return 0; return 0;
} }
@ -589,10 +601,16 @@ namespace NLGUI
const char *funcName = "setText"; const char *funcName = "setText";
CLuaIHM::checkArgCount(ls, funcName, 2); CLuaIHM::checkArgCount(ls, funcName, 2);
CLuaIHM::checkArgType(ls, funcName, 1, LUA_TNUMBER); CLuaIHM::checkArgType(ls, funcName, 1, LUA_TNUMBER);
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::checkArgTypeUCString(ls, funcName, 2); CLuaIHM::checkArgTypeUCString(ls, funcName, 2);
ucstring text; ucstring text; // Compatibility
nlverify(CLuaIHM::pop(ls, text)); nlverify(CLuaIHM::pop(ls, text));
setText((uint) ls.toInteger(1), text.toUtf8()); // FIXME: Lua should just do UTF-8! setText((uint) ls.toInteger(1), text.toUtf8());
#else
CLuaIHM::checkArgType(ls, funcName, 2, LUA_TSTRING);
string text = ls.toString(2);
setText((uint)ls.toInteger(1), text);
#endif
return 0; return 0;
} }
@ -602,10 +620,16 @@ namespace NLGUI
const char *funcName = "insertText"; const char *funcName = "insertText";
CLuaIHM::checkArgCount(ls, funcName, 2); CLuaIHM::checkArgCount(ls, funcName, 2);
CLuaIHM::checkArgType(ls, funcName, 1, LUA_TNUMBER); CLuaIHM::checkArgType(ls, funcName, 1, LUA_TNUMBER);
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::checkArgTypeUCString(ls, funcName, 2); CLuaIHM::checkArgTypeUCString(ls, funcName, 2);
ucstring text; ucstring text;
nlverify(CLuaIHM::pop(ls, text)); nlverify(CLuaIHM::pop(ls, text));
insertText((uint) ls.toInteger(1), text.toUtf8()); // FIXME: Lua should just do UTF-8! insertText((uint) ls.toInteger(1), text.toUtf8()); // FIXME: Lua should just do UTF-8!
#else
CLuaIHM::checkArgType(ls, funcName, 2, LUA_TSTRING);
string text = ls.toString(2);
insertText((uint)ls.toInteger(1), text);
#endif
return 0; return 0;
} }
@ -615,20 +639,30 @@ namespace NLGUI
const char *funcName = "setTexture"; const char *funcName = "setTexture";
CLuaIHM::checkArgCount(ls, funcName, 2); CLuaIHM::checkArgCount(ls, funcName, 2);
CLuaIHM::checkArgType(ls, funcName, 1, LUA_TNUMBER); CLuaIHM::checkArgType(ls, funcName, 1, LUA_TNUMBER);
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::checkArgTypeUCString(ls, funcName, 2); CLuaIHM::checkArgTypeUCString(ls, funcName, 2);
ucstring texture; ucstring texture;
nlverify(CLuaIHM::pop(ls, texture)); nlverify(CLuaIHM::pop(ls, texture));
setTexture((uint) ls.toInteger(1), texture.toUtf8()); // FIXME: Lua should just do UTF-8! setTexture((uint) ls.toInteger(1), texture.toUtf8()); // FIXME: Lua should just do UTF-8!
#else
CLuaIHM::checkArgType(ls, funcName, 2, LUA_TSTRING);
string texture = ls.toString(2);
setTexture((uint)ls.toInteger(1), texture);
#endif
return 0; return 0;
} }
// *************************************************************************** // ***************************************************************************
int CDBGroupComboBox::luaGetText(CLuaState &ls) int CDBGroupComboBox::luaGetText(CLuaState &ls)
{ {
const char *funcName = "setText"; const char *funcName = "getText";
CLuaIHM::checkArgCount(ls, funcName, 1); CLuaIHM::checkArgCount(ls, funcName, 1);
CLuaIHM::checkArgType(ls, funcName, 1, LUA_TNUMBER); CLuaIHM::checkArgType(ls, funcName, 1, LUA_TNUMBER);
CLuaIHM::push(ls, getText((uint) ls.toInteger(1))); #ifdef RYZOM_LUA_UCSTRING
CLuaIHM::push(ls, getTextAsUtf16((uint) ls.toInteger(1)));
#else
ls.push(getText((uint)ls.toInteger(1)));
#endif
return 1; return 1;
} }

@ -4016,6 +4016,7 @@ namespace NLGUI
} }
} }
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
void CGroupContainer::setUCTitleOpened(const ucstring &title) void CGroupContainer::setUCTitleOpened(const ucstring &title)
{ {
@ -4051,6 +4052,7 @@ namespace NLGUI
{ {
return ucstring::makeFromUtf8(getTitleClosed()); return ucstring::makeFromUtf8(getTitleClosed());
} }
#endif
// *************************************************************************** // ***************************************************************************
void CGroupContainer::launch () void CGroupContainer::launch ()

@ -63,6 +63,7 @@ namespace NLGUI
_BlinkTime(0.f), _BlinkTime(0.f),
_CursorPos(0), _CursorPos(0),
_MaxNumChar(std::numeric_limits<uint32>::max()), _MaxNumChar(std::numeric_limits<uint32>::max()),
_MaxNumBytes(0),
_MaxNumReturn(std::numeric_limits<uint32>::max()), _MaxNumReturn(std::numeric_limits<uint32>::max()),
_MaxFloatPrec(20), _MaxFloatPrec(20),
_MaxCharsSize(32768), _MaxCharsSize(32768),
@ -149,6 +150,11 @@ namespace NLGUI
return toString( _MaxNumChar ); return toString( _MaxNumChar );
} }
else else
if( name == "max_num_bytes" )
{
return toString( _MaxNumBytes );
}
else
if( name == "max_num_return" ) if( name == "max_num_return" )
{ {
return toString( _MaxNumReturn ); return toString( _MaxNumReturn );
@ -321,6 +327,14 @@ namespace NLGUI
return; return;
} }
else else
if( name == "max_num_bytes" )
{
uint32 i;
if( fromString( value, i ) )
_MaxNumBytes = i;
return;
}
else
if( name == "max_num_return" ) if( name == "max_num_return" )
{ {
uint32 i; uint32 i;
@ -474,6 +488,7 @@ namespace NLGUI
xmlSetProp( node, BAD_CAST "on_focus", BAD_CAST _AHOnFocus.c_str() ); xmlSetProp( node, BAD_CAST "on_focus", BAD_CAST _AHOnFocus.c_str() );
xmlSetProp( node, BAD_CAST "on_focus_params", BAD_CAST _AHOnFocusParams.c_str() ); xmlSetProp( node, BAD_CAST "on_focus_params", BAD_CAST _AHOnFocusParams.c_str() );
xmlSetProp( node, BAD_CAST "max_num_chars", BAD_CAST toString( _MaxNumChar ).c_str() ); xmlSetProp( node, BAD_CAST "max_num_chars", BAD_CAST toString( _MaxNumChar ).c_str() );
xmlSetProp( node, BAD_CAST "max_num_bytes", BAD_CAST toString( _MaxNumBytes ).c_str() );
xmlSetProp( node, BAD_CAST "max_num_return", BAD_CAST toString( _MaxNumReturn ).c_str() ); xmlSetProp( node, BAD_CAST "max_num_return", BAD_CAST toString( _MaxNumReturn ).c_str() );
xmlSetProp( node, BAD_CAST "max_chars_size", BAD_CAST toString( _MaxCharsSize ).c_str() ); xmlSetProp( node, BAD_CAST "max_chars_size", BAD_CAST toString( _MaxCharsSize ).c_str() );
xmlSetProp( node, BAD_CAST "enter_loose_focus", BAD_CAST toString( _LooseFocusOnEnter ).c_str() ); xmlSetProp( node, BAD_CAST "enter_loose_focus", BAD_CAST toString( _LooseFocusOnEnter ).c_str() );
@ -591,6 +606,9 @@ namespace NLGUI
prop = (char*) xmlGetProp( cur, (xmlChar*)"max_num_chars" ); prop = (char*) xmlGetProp( cur, (xmlChar*)"max_num_chars" );
if (prop) fromString((const char*)prop, _MaxNumChar); if (prop) fromString((const char*)prop, _MaxNumChar);
prop = (char*) xmlGetProp( cur, (xmlChar*)"max_num_bytes" );
if (prop) fromString((const char*)prop, _MaxNumBytes);
prop = (char*) xmlGetProp( cur, (xmlChar*)"max_num_return" ); prop = (char*) xmlGetProp( cur, (xmlChar*)"max_num_return" );
if (prop) fromString((const char*)prop, _MaxNumReturn); if (prop) fromString((const char*)prop, _MaxNumReturn);
@ -969,6 +987,17 @@ namespace NLGUI
length = _MaxNumChar - (sint)_InputString.length(); length = _MaxNumChar - (sint)_InputString.length();
} }
::u32string toAdd = toAppend.substr(0, length); ::u32string toAdd = toAppend.substr(0, length);
if (_MaxNumBytes && length)
{
sint baseBytes = CUtfStringView(_InputString).toUtf8().length();
sint bytes = baseBytes + CUtfStringView(toAdd).toUtf8().length();
while (bytes > _MaxNumBytes)
{
length -= std::max((int)(bytes - _MaxNumBytes) >> 2, 1);
toAdd = toAdd.substr(0, length);
bytes = baseBytes + CUtfStringView(toAdd).toUtf8().length();
}
}
sint32 minPos; sint32 minPos;
sint32 maxPos; sint32 maxPos;
if (_CurrSelection == this) if (_CurrSelection == this)
@ -1018,7 +1047,7 @@ namespace NLGUI
_CursorAtPreviousLineEnd = false; _CursorAtPreviousLineEnd = false;
if (_ClearOnEscape) if (_ClearOnEscape)
{ {
setInputStringAsUtf32(::u32string()); setInputStringRef(::u32string());
triggerOnChangeAH(); triggerOnChangeAH();
} }
CWidgetManager::getInstance()->setCaptureKeyboard(NULL); CWidgetManager::getInstance()->setCaptureKeyboard(NULL);
@ -1064,7 +1093,7 @@ namespace NLGUI
{ {
if (isKeyRETURN) if (isKeyRETURN)
{ {
//ucstring copyStr= _InputString; //u32string copyStr= _InputString;
//if ((uint) std::count(copyStr.begin(), copyStr.end(), '\n') >= _MaxNumReturn) //if ((uint) std::count(copyStr.begin(), copyStr.end(), '\n') >= _MaxNumReturn)
if ((uint)std::count(_InputString.begin(), _InputString.end(), '\n') >= _MaxNumReturn) if ((uint)std::count(_InputString.begin(), _InputString.end(), '\n') >= _MaxNumReturn)
break; break;
@ -1153,11 +1182,14 @@ namespace NLGUI
// verify max num char // verify max num char
if ((uint) _InputString.length() < _MaxNumChar) if ((uint) _InputString.length() < _MaxNumChar)
{ {
makeTopWindow(); if (!_MaxNumBytes || CUtfStringView(_InputString + c).toUtf8().size() <= _MaxNumBytes)
::u32string::iterator it = _InputString.begin() + _CursorPos; {
_InputString.insert(it, c); makeTopWindow();
++ _CursorPos; ::u32string::iterator it = _InputString.begin() + _CursorPos;
triggerOnChangeAH(); _InputString.insert(it, c);
++_CursorPos;
triggerOnChangeAH();
}
} }
if (isKeyRETURN) if (isKeyRETURN)
{ {
@ -1182,7 +1214,7 @@ namespace NLGUI
if (CWidgetManager::getInstance()->getCaptureKeyboard() != this) return false; if (CWidgetManager::getInstance()->getCaptureKeyboard() != this) return false;
if (!_CanUndo) return false; if (!_CanUndo) return false;
_ModifiedInputString = _InputString; _ModifiedInputString = _InputString;
setInputStringAsUtf32(_StartInputString); setInputStringRef(_StartInputString);
_CanUndo = false; _CanUndo = false;
_CanRedo = true; _CanRedo = true;
setCursorPos((sint32)_InputString.length()); setCursorPos((sint32)_InputString.length());
@ -1195,7 +1227,7 @@ namespace NLGUI
{ {
if (CWidgetManager::getInstance()->getCaptureKeyboard() != this) return false; if (CWidgetManager::getInstance()->getCaptureKeyboard() != this) return false;
if (!_CanRedo) return false; if (!_CanRedo) return false;
setInputStringAsUtf32(_ModifiedInputString); setInputStringRef(_ModifiedInputString);
_CanUndo = true; _CanUndo = true;
_CanRedo = false; _CanRedo = false;
setCursorPos((sint32)_InputString.length()); setCursorPos((sint32)_InputString.length());
@ -1306,7 +1338,7 @@ namespace NLGUI
default: break; default: break;
} }
// update the text // update the text
setInputStringAsUtf32(_InputString); setInputStringRef(_InputString);
// if event of type char or string, consider handle all of them // if event of type char or string, consider handle all of them
if( rEDK.getKeyEventType()==NLGUI::CEventDescriptorKey::keychar || rEDK.getKeyEventType()==NLGUI::CEventDescriptorKey::keystring ) if( rEDK.getKeyEventType()==NLGUI::CEventDescriptorKey::keychar || rEDK.getKeyEventType()==NLGUI::CEventDescriptorKey::keystring )
@ -1635,9 +1667,9 @@ namespace NLGUI
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
void CGroupEditBox::setInputString(const std::string &str) void CGroupEditBox::setInputString(const std::string &str)
{ {
setInputStringAsUtf32(CUtfStringView(str).toUtf32()); setInputStringRef(CUtfStringView(str).toUtf32());
} }
void CGroupEditBox::setInputStringAsUtf32(const ::u32string &str) void CGroupEditBox::setInputStringRef(const ::u32string &str)
{ {
_InputString = str; _InputString = str;
if (_CursorPos > (sint32) str.length()) if (_CursorPos > (sint32) str.length())
@ -1761,6 +1793,7 @@ namespace NLGUI
return NLMISC::CUtfStringView(_InputString).toUtf8(); return NLMISC::CUtfStringView(_InputString).toUtf8();
} }
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
void CGroupEditBox::setInputStringAsUtf16(const ucstring &str) void CGroupEditBox::setInputStringAsUtf16(const ucstring &str)
{ {
@ -1772,6 +1805,7 @@ namespace NLGUI
{ {
return CUtfStringView(_InputString).toUtf16(); return CUtfStringView(_InputString).toUtf16();
} }
#endif
// *************************************************************************** // ***************************************************************************
void CGroupEditBox::setCommand(const std::string &command, bool execute) void CGroupEditBox::setCommand(const std::string &command, bool execute)
@ -1844,7 +1878,7 @@ namespace NLGUI
} }
if (version < 1) if (version < 1)
{ {
ucstring str; ucstring str; // Compatibility
if (!f.isReading()) if (!f.isReading())
str = CUtfStringView(_InputString).toUtf16(); str = CUtfStringView(_InputString).toUtf16();
f.serial(str); f.serial(str);
@ -1864,7 +1898,7 @@ namespace NLGUI
f.serial(_PrevNumLine); f.serial(_PrevNumLine);
if (f.isReading()) if (f.isReading())
{ {
setInputStringAsUtf32(_InputString); setInputStringRef(_InputString);
} }
// serial selection // serial selection
@ -1881,7 +1915,7 @@ namespace NLGUI
void CGroupEditBox::onQuit() void CGroupEditBox::onQuit()
{ {
// clear the text and restore backup pos before final save // clear the text and restore backup pos before final save
setInputStringAsUtf32(::u32string()); setInputStringRef(::u32string());
_CurrSelection = NULL; _CurrSelection = NULL;
} }
@ -1889,7 +1923,7 @@ namespace NLGUI
void CGroupEditBox::onLoadConfig() void CGroupEditBox::onLoadConfig()
{ {
// config is not saved when there's an empty string, so restore that default state. // config is not saved when there's an empty string, so restore that default state.
setInputStringAsUtf32(::u32string()); setInputStringRef(::u32string());
_CurrSelection = NULL; _CurrSelection = NULL;
_PrevNumLine = 1; _PrevNumLine = 1;
} }
@ -1904,7 +1938,7 @@ namespace NLGUI
if (_DefaultInputString) if (_DefaultInputString)
{ {
_DefaultInputString= false; _DefaultInputString= false;
setInputStringAsUtf32(::u32string()); setInputStringRef(::u32string());
} }
_CanRedo = false; _CanRedo = false;
_CanUndo = false; _CanUndo = false;

@ -1272,7 +1272,6 @@ namespace NLGUI
return; return;
} }
// TODO: use ucstring / ucchar as content is utf8 chars
std::string::size_type pos = 0; std::string::size_type pos = 0;
while(pos < content.size()) while(pos < content.size())
{ {
@ -3695,7 +3694,7 @@ namespace NLGUI
{ {
// Text area ? // Text area ?
bool addEntry = false; bool addEntry = false;
ucstring entryData; string entryData;
if (form.Entries[i].TextArea) if (form.Entries[i].TextArea)
{ {
// Get the edit box view // Get the edit box view
@ -3706,7 +3705,7 @@ namespace NLGUI
CGroupEditBox *editBox = dynamic_cast<CGroupEditBox*>(group); CGroupEditBox *editBox = dynamic_cast<CGroupEditBox*>(group);
if (editBox) if (editBox)
{ {
entryData = CUtfStringView(editBox->getViewText()->getText()).toUtf16(); entryData = editBox->getViewText()->getText();
addEntry = true; addEntry = true;
} }
} }
@ -3723,7 +3722,7 @@ namespace NLGUI
else if (form.Entries[i].ComboBox) else if (form.Entries[i].ComboBox)
{ {
CDBGroupComboBox *cb = form.Entries[i].ComboBox; CDBGroupComboBox *cb = form.Entries[i].ComboBox;
entryData.fromUtf8(form.Entries[i].SelectValues[cb->getSelection()]); entryData = form.Entries[i].SelectValues[cb->getSelection()];
addEntry = true; addEntry = true;
} }
else if (form.Entries[i].SelectBox) else if (form.Entries[i].SelectBox)
@ -3754,7 +3753,7 @@ namespace NLGUI
// Add this entry // Add this entry
if (addEntry) if (addEntry)
{ {
formfields.add(form.Entries[i].Name, CI18N::encodeUTF8(entryData)); formfields.add(form.Entries[i].Name, entryData);
} }
} }

@ -1286,12 +1286,18 @@ namespace NLGUI
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
int CGroupList::luaAddTextChild(CLuaState &ls) int CGroupList::luaAddTextChild(CLuaState &ls)
{ {
CLuaIHM::checkArgCount(ls, "addTextChild", 1); const char *funcName = "addTextChild";
ucstring text; CLuaIHM::checkArgCount(ls, funcName, 1);
#ifdef RYZOM_LUA_UCSTRING
ucstring text; // Compatibility
if(CLuaIHM::pop(ls, text)) if(CLuaIHM::pop(ls, text))
{ {
addTextChild(text.toUtf8()); // FIXME: Lua UTF-8 addTextChild(text.toUtf8());
} }
#else
CLuaIHM::checkArgType(ls, funcName, 1, LUA_TSTRING);
addTextChild(ls.toString(1));
#endif
return 0; return 0;
} }
@ -1306,15 +1312,13 @@ namespace NLGUI
CLuaIHM::checkArgType(ls, funcName, 4, LUA_TNUMBER); CLuaIHM::checkArgType(ls, funcName, 4, LUA_TNUMBER);
CLuaIHM::checkArgType(ls, funcName, 5, LUA_TNUMBER); CLuaIHM::checkArgType(ls, funcName, 5, LUA_TNUMBER);
string text = ls.toString(1); string text = ls.toString(1);
ucstring ucText;
ucText.fromUtf8(text);
uint r = (uint) ls.toInteger(2); uint r = (uint) ls.toInteger(2);
uint g = (uint) ls.toInteger(3); uint g = (uint) ls.toInteger(3);
uint b = (uint) ls.toInteger(4); uint b = (uint) ls.toInteger(4);
uint a = (uint) ls.toInteger(5); uint a = (uint) ls.toInteger(5);
addTextChild(ucText.toUtf8(), CRGBA(r, g, b, a)); // FIXME: Lua UTF-8 addTextChild(text, CRGBA(r, g, b, a));
return 0; return 0;
} }

@ -1823,8 +1823,13 @@ namespace NLGUI
const char *funcName = "getLineId"; const char *funcName = "getLineId";
CLuaIHM::checkArgCount(ls, funcName, 1); CLuaIHM::checkArgCount(ls, funcName, 1);
CLuaIHM::checkArgType(ls, funcName, 1, LUA_TNUMBER); CLuaIHM::checkArgType(ls, funcName, 1, LUA_TNUMBER);
std::string id = getLineId((uint) ls.toInteger(1)); #ifdef RYZOM_LUA_UCSTRING
ucstring id = getLineId((uint) ls.toInteger(1)); // Compatibility
CLuaIHM::push(ls, id); CLuaIHM::push(ls, id);
#else
std::string id = getLineId((uint)ls.toInteger(1));
ls.push(id);
#endif
return 1; return 1;
} }
@ -1853,13 +1858,21 @@ namespace NLGUI
{ {
const char *funcName = "addLine"; const char *funcName = "addLine";
CLuaIHM::checkArgCount(ls, funcName, 4); CLuaIHM::checkArgCount(ls, funcName, 4);
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::checkArgTypeUCString(ls, funcName, 1); CLuaIHM::checkArgTypeUCString(ls, funcName, 1);
#else
CLuaIHM::checkArgType(ls, funcName, 1, LUA_TSTRING);
#endif
CLuaIHM::checkArgType(ls, funcName, 2, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 2, LUA_TSTRING);
CLuaIHM::checkArgType(ls, funcName, 3, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 3, LUA_TSTRING);
CLuaIHM::checkArgType(ls, funcName, 4, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 4, LUA_TSTRING);
ucstring arg1; #ifdef RYZOM_LUA_UCSTRING
nlverify(CLuaIHM::getUCStringOnStack(ls, 1, arg1)); // FIXME: Lua UTF-8 ucstring arg1; // Compatibility
nlverify(CLuaIHM::getUCStringOnStack(ls, 1, arg1));
addLine(arg1.toUtf8(), ls.toString(2), ls.toString(3), ls.toString(4)); addLine(arg1.toUtf8(), ls.toString(2), ls.toString(3), ls.toString(4));
#else
addLine(ls.toString(1), ls.toString(2), ls.toString(3), ls.toString(4));
#endif
return 0; return 0;
} }
@ -1868,14 +1881,22 @@ namespace NLGUI
{ {
const char *funcName = "addIconLine"; const char *funcName = "addIconLine";
CLuaIHM::checkArgCount(ls, funcName, 5); CLuaIHM::checkArgCount(ls, funcName, 5);
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::checkArgTypeUCString(ls, funcName, 1); CLuaIHM::checkArgTypeUCString(ls, funcName, 1);
#else
CLuaIHM::checkArgType(ls, funcName, 1, LUA_TSTRING);
#endif
CLuaIHM::checkArgType(ls, funcName, 2, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 2, LUA_TSTRING);
CLuaIHM::checkArgType(ls, funcName, 3, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 3, LUA_TSTRING);
CLuaIHM::checkArgType(ls, funcName, 4, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 4, LUA_TSTRING);
CLuaIHM::checkArgType(ls, funcName, 5, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 5, LUA_TSTRING);
ucstring arg1; #ifdef RYZOM_LUA_UCSTRING
nlverify(CLuaIHM::getUCStringOnStack(ls, 1, arg1)); // FIXME: Lua UTF-8 ucstring arg1; // Compatibility
nlverify(CLuaIHM::getUCStringOnStack(ls, 1, arg1));
addLine(arg1.toUtf8(), ls.toString(2), ls.toString(3), ls.toString(4), string(), ls.toString(5)); addLine(arg1.toUtf8(), ls.toString(2), ls.toString(3), ls.toString(4), string(), ls.toString(5));
#else
addLine(ls.toString(1), ls.toString(2), ls.toString(3), ls.toString(4), string(), ls.toString(5));
#endif
return 0; return 0;
} }
@ -1885,13 +1906,21 @@ namespace NLGUI
const char *funcName = "addLineAtIndex"; const char *funcName = "addLineAtIndex";
CLuaIHM::checkArgCount(ls, funcName, 5); CLuaIHM::checkArgCount(ls, funcName, 5);
CLuaIHM::checkArgType(ls, funcName, 1, LUA_TNUMBER); CLuaIHM::checkArgType(ls, funcName, 1, LUA_TNUMBER);
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::checkArgTypeUCString(ls, funcName, 2); CLuaIHM::checkArgTypeUCString(ls, funcName, 2);
#else
CLuaIHM::checkArgType(ls, funcName, 2, LUA_TSTRING);
#endif
CLuaIHM::checkArgType(ls, funcName, 3, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 3, LUA_TSTRING);
CLuaIHM::checkArgType(ls, funcName, 4, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 4, LUA_TSTRING);
CLuaIHM::checkArgType(ls, funcName, 5, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 5, LUA_TSTRING);
#ifdef RYZOM_LUA_UCSTRING
ucstring arg2; ucstring arg2;
nlverify(CLuaIHM::getUCStringOnStack(ls, 2, arg2)); // FIXME: Lua UTF-8 nlverify(CLuaIHM::getUCStringOnStack(ls, 2, arg2));
addLineAtIndex((uint) ls.toInteger(1), arg2.toUtf8(), ls.toString(3), ls.toString(4), ls.toString(5)); addLineAtIndex((uint) ls.toInteger(1), arg2.toUtf8(), ls.toString(3), ls.toString(4), ls.toString(5));
#else
addLineAtIndex((uint)ls.toInteger(1), ls.toString(2), ls.toString(3), ls.toString(4), ls.toString(5));
#endif
return 0; return 0;
} }

@ -119,13 +119,14 @@ namespace NLGUI
break; break;
case CReflectedProperty::UCString: case CReflectedProperty::UCString:
case CReflectedProperty::UCStringRef: case CReflectedProperty::UCStringRef:
#ifdef RYZOM_LUA_UCSTRING
if (valueToAffect.toString()) if (valueToAffect.toString())
{ {
(destElem.*(property.SetMethod.SetUCString))(ucstring::makeFromUtf8(valueToAffect.getString())); (destElem.*(property.SetMethod.SetUCString))(ucstring::makeFromUtf8(valueToAffect.getString()));
} }
else else
#endif
{ {
return false; return false;
} }
break; break;

@ -100,11 +100,13 @@ using namespace NLMISC;
#define new DEBUG_NEW #define new DEBUG_NEW
#endif #endif
#ifdef RYZOM_LUA_UCSTRING
// declare ostream << operator for ucstring -> registration of ucstring iin luabind will build a 'tostring' function from it // declare ostream << operator for ucstring -> registration of ucstring iin luabind will build a 'tostring' function from it
std::ostream &operator<<(std::ostream &str, const ucstring &value) std::ostream &operator<<(std::ostream &str, const ucstring &value)
{ {
return str << value.toString(); return str << value.toString();
} }
#endif
namespace NLGUI namespace NLGUI
{ {
@ -172,6 +174,7 @@ namespace NLGUI
return true; return true;
} }
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
bool CLuaIHM::pop(CLuaState &ls, ucstring &dest) bool CLuaIHM::pop(CLuaState &ls, ucstring &dest)
{ {
@ -224,6 +227,7 @@ namespace NLGUI
obj.pushvalue(); obj.pushvalue();
#endif #endif
} }
#endif
// *************************************************************************** // ***************************************************************************
// *************************************************************************** // ***************************************************************************
@ -689,6 +693,7 @@ namespace NLGUI
.def_readwrite("A", &NLMISC::CRGBA::A) .def_readwrite("A", &NLMISC::CRGBA::A)
]; ];
#ifdef RYZOM_LUA_UCSTRING
// ucstring // ucstring
module(L) module(L)
[ [
@ -709,6 +714,7 @@ namespace NLGUI
.def("toString", (std::string(ucstring::*)()const)&ucstring::toString) .def("toString", (std::string(ucstring::*)()const)&ucstring::toString)
//.def(self + other<ucstring>()) //.def(self + other<ucstring>())
]; ];
#endif
// CVector2f // CVector2f
module(L) module(L)
@ -1279,6 +1285,7 @@ namespace NLGUI
return 1; return 1;
} }
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
int CLuaIHM::isUCString(CLuaState &ls) int CLuaIHM::isUCString(CLuaState &ls)
{ {
@ -1313,6 +1320,7 @@ namespace NLGUI
CLuaIHM::push(ls, result); CLuaIHM::push(ls, result);
return 1; return 1;
} }
#endif
// *************************************************************************** // ***************************************************************************
int CLuaIHM::concatString(CLuaState &ls) int CLuaIHM::concatString(CLuaState &ls)
@ -1511,6 +1519,7 @@ namespace NLGUI
ls.toString(stackIndex, str); ls.toString(stackIndex, str);
val= str; val= str;
} }
#ifdef RYZOM_LUA_UCSTRING
else else
{ {
// else this should be a ucstring // else this should be a ucstring
@ -1519,6 +1528,7 @@ namespace NLGUI
throw ELuaIHMException("You must set a string, number or ucstring to UI property '%s'", property.Name.c_str()); throw ELuaIHMException("You must set a string, number or ucstring to UI property '%s'", property.Name.c_str());
} }
} }
#endif
(target.*(property.SetMethod.SetUCString))(val); (target.*(property.SetMethod.SetUCString))(val);
return; return;
} }
@ -1631,8 +1641,10 @@ namespace NLGUI
ls.registerFunc("getWindowSize", getWindowSize); ls.registerFunc("getWindowSize", getWindowSize);
ls.registerFunc("getTextureSize", getTextureSize); ls.registerFunc("getTextureSize", getTextureSize);
ls.registerFunc("disableModalWindow", disableModalWindow); ls.registerFunc("disableModalWindow", disableModalWindow);
#ifdef RYZOM_LUA_UCSTRING
ls.registerFunc("isUCString", isUCString); ls.registerFunc("isUCString", isUCString);
ls.registerFunc("concatUCString", concatUCString); ls.registerFunc("concatUCString", concatUCString);
#endif
ls.registerFunc("concatString", concatString); ls.registerFunc("concatString", concatString);
ls.registerFunc("tableToString", tableToString); ls.registerFunc("tableToString", tableToString);
ls.registerFunc("getCurrentWindowUnder", getCurrentWindowUnder); ls.registerFunc("getCurrentWindowUnder", getCurrentWindowUnder);
@ -1665,7 +1677,11 @@ namespace NLGUI
// inside i18n table // inside i18n table
luabind::module(L, "i18n") luabind::module(L, "i18n")
[ [
luabind::def("get", &CI18N::getAsUtf16), // FIXME: Lua UTF-8 #ifdef RYZOM_LUA_UCSTRING
luabind::def("get", &CI18N::getAsUtf16), // Compatibility
#else
luabind::def("get", &CI18N::get),
#endif
luabind::def("hasTranslation", &CI18N::hasTranslation) luabind::def("hasTranslation", &CI18N::hasTranslation)
]; ];
// inside 'nlfile' table // inside 'nlfile' table
@ -1843,6 +1859,7 @@ namespace NLGUI
return ret; return ret;
} }
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
ucstring CLuaIHM::findReplaceAll(const ucstring &str, const ucstring &search, const ucstring &replace) ucstring CLuaIHM::findReplaceAll(const ucstring &str, const ucstring &search, const ucstring &replace)
{ {
@ -1870,7 +1887,7 @@ namespace NLGUI
//H_AUTO(Lua_CLuaIHM_findReplaceAll) //H_AUTO(Lua_CLuaIHM_findReplaceAll)
return findReplaceAll(str, search, ucstring::makeFromUtf8(replace)); return findReplaceAll(str, search, ucstring::makeFromUtf8(replace));
} }
#endif
// *************************************************************************** // ***************************************************************************
void CLuaIHM::fails(CLuaState &ls, const char *format, ...) void CLuaIHM::fails(CLuaState &ls, const char *format, ...)
@ -1957,6 +1974,7 @@ namespace NLGUI
} }
} }
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
void CLuaIHM::checkArgTypeUCString(CLuaState &ls, const char *funcName, uint index) void CLuaIHM::checkArgTypeUCString(CLuaState &ls, const char *funcName, uint index)
{ {
@ -1973,7 +1991,7 @@ namespace NLGUI
fails(ls, "%s : argument %d of expected type ucstring has bad type : %s", funcName, index, ls.getTypename(ls.type(index)), ls.type(index)); fails(ls, "%s : argument %d of expected type ucstring has bad type : %s", funcName, index, ls.getTypename(ls.type(index)), ls.type(index));
} }
} }
#endif
// *************************************************************************** // ***************************************************************************

@ -1422,11 +1422,13 @@ namespace NLGUI
} }
} }
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
void CViewText::setTextAsUtf16(const ucstring &text) void CViewText::setTextAsUtf16(const ucstring &text)
{ {
setText(text.toUtf8()); setText(text.toUtf8());
} }
#endif
// *************************************************************************** // ***************************************************************************
void CViewText::setTextLocalized(const std::string &text, bool localized) void CViewText::setTextLocalized(const std::string &text, bool localized)
@ -2449,11 +2451,13 @@ namespace NLGUI
endOfPreviousLine = !_Lines[line]->getLF(); endOfPreviousLine = !_Lines[line]->getLF();
} }
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
void CViewText::setHardTextAsUtf16(const ucstring &ht) void CViewText::setHardTextAsUtf16(const ucstring &ht)
{ {
setHardText(ht.toUtf8()); setHardText(ht.toUtf8());
} }
#endif
// *************************************************************************** // ***************************************************************************
void CViewText::setHardText (const std::string &ht) void CViewText::setHardText (const std::string &ht)
@ -2466,6 +2470,7 @@ namespace NLGUI
setText(ht); setText(ht);
} }
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
ucstring CViewText::getTextAsUtf16() const ucstring CViewText::getTextAsUtf16() const
{ {
@ -2477,6 +2482,7 @@ namespace NLGUI
{ {
return CUtfStringView(getHardText()).toUtf16(); return CUtfStringView(getHardText()).toUtf16();
} }
#endif
// *************************************************************************** // ***************************************************************************
string CViewText::getColorAsString() const string CViewText::getColorAsString() const
@ -3383,11 +3389,13 @@ namespace NLGUI
} }
} }
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
void CViewText::setTextFormatTagedAsUtf16(const ucstring &text) void CViewText::setTextFormatTagedAsUtf16(const ucstring &text)
{ {
setTextFormatTaged(text.toUtf8()); setTextFormatTaged(text.toUtf8());
} }
#endif
// *************************************************************************** // ***************************************************************************
void CViewText::setTextFormatTaged(const std::string &text) void CViewText::setTextFormatTaged(const std::string &text)
@ -3481,10 +3489,12 @@ namespace NLGUI
nlwarning("ViewText isn't multilined : uc_hardtext_format will not act as wanted !\n%s", text.c_str()); nlwarning("ViewText isn't multilined : uc_hardtext_format will not act as wanted !\n%s", text.c_str());
} }
#ifdef RYZOM_LUA_UCSTRING
void CViewText::setSingleLineTextFormatTagedAsUtf16(const ucstring &text) void CViewText::setSingleLineTextFormatTagedAsUtf16(const ucstring &text)
{ {
setSingleLineTextFormatTaged(text.toUtf8()); setSingleLineTextFormatTaged(text.toUtf8());
} }
#endif
void CViewText::setSingleLineTextFormatTaged(const std::string &text) void CViewText::setSingleLineTextFormatTaged(const std::string &text)
{ {

@ -76,7 +76,7 @@ void CUtfStringView::append(IStream &s, u32char c)
std::string tmp; std::string tmp;
tmp.reserve(4); tmp.reserve(4);
append(tmp, c); append(tmp, c);
s.serialBuffer((uint8_t *)&tmp[0], tmp.size()); s.serialBuffer((uint8 *)&tmp[0], tmp.size());
} }
u32char CUtfStringView::get(IStream &s) u32char CUtfStringView::get(IStream &s)
@ -85,7 +85,7 @@ u32char CUtfStringView::get(IStream &s)
std::string tmp; std::string tmp;
tmp.reserve(4); tmp.reserve(4);
uint8_t c; uint8 c;
s.serial(c); s.serial(c);
// Single byte // Single byte
@ -101,7 +101,7 @@ u32char CUtfStringView::get(IStream &s)
// Read from stream // Read from stream
tmp.resize(len); tmp.resize(len);
s.serialBuffer((uint8_t *)&tmp[1], len - 1); s.serialBuffer((uint8 *)&tmp[1], len - 1);
// Decode // Decode
const void *str = tmp.c_str(); const void *str = tmp.c_str();

@ -340,7 +340,7 @@ namespace NLWEB
} }
else else
{ {
nldebug("Added certificate %s", entry.name.c_str()); // nldebug("Added certificate %s", entry.name.c_str());
} }
} }
} }

@ -2833,7 +2833,7 @@ class CAHScenarioControl : public IActionHandler
{ {
CGroupEditBox* editBox = dynamic_cast<CGroupEditBox*>(result); CGroupEditBox* editBox = dynamic_cast<CGroupEditBox*>(result);
if(editBox) if(editBox)
editBox->setInputStringAsUtf16(description); editBox->setInputString(description);
} }
} }
} }

@ -130,7 +130,7 @@ void CInterfaceItemEdition::CItemEditionWindow::infoReceived()
{ {
if ( pIS->Family == ITEMFAMILY::SCROLL) if ( pIS->Family == ITEMFAMILY::SCROLL)
{ {
editBoxLarge->setInputStringAsUtf16(itemInfo.CustomText); editBoxLarge->setInputString(itemInfo.CustomText.toUtf8()); // TODO: UTF-8 (serial)
editLarge->setActive(true); editLarge->setActive(true);
editBoxLarge->setActive(true); editBoxLarge->setActive(true);
@ -244,7 +244,7 @@ void CInterfaceItemEdition::CItemEditionWindow::begin()
// If we already have item info // If we already have item info
if ( pIS->Family == ITEMFAMILY::SCROLL) if ( pIS->Family == ITEMFAMILY::SCROLL)
{ {
editBoxLarge->setInputStringAsUtf16(itemInfo.CustomText); editBoxLarge->setInputString(itemInfo.CustomText.toUtf8()); // TODO: UTF-8 (serial)
editLarge->setActive(true); editLarge->setActive(true);
editBoxLarge->setActive(true); editBoxLarge->setActive(true);

@ -71,10 +71,10 @@ class CHandlerGuildCreate : public IActionHandler
CGroupEditBox *pDesc = dynamic_cast<CGroupEditBox*>(CWidgetManager::getInstance()->getElementFromId(guildDescWin)); CGroupEditBox *pDesc = dynamic_cast<CGroupEditBox*>(CWidgetManager::getInstance()->getElementFromId(guildDescWin));
ucstring guildName = pGEB->getInputStringAsUtf16(); // FIXME: UTF-8 (serial) ucstring guildName = ucstring::makeFromUtf8(pGEB->getInputString()); // FIXME: UTF-8 (serial)
ucstring guildDesc; // FIXME: UTF-8 (serial) ucstring guildDesc; // FIXME: UTF-8 (serial)
if (pDesc != NULL) guildDesc = pDesc->getInputStringAsUtf16(); // FIXME: UTF-8 (serial) if (pDesc != NULL) guildDesc.fromUtf8(pDesc->getInputString()); // FIXME: UTF-8 (serial)
uint64 icon = CGuildManager::iconMake((uint8)pCS->getGuildBack(), (uint8)pCS->getGuildSymbol(), uint64 icon = CGuildManager::iconMake((uint8)pCS->getGuildBack(), (uint8)pCS->getGuildSymbol(),
pCS->getInvertGuildSymbol(), pCS->getGuildColor1(), pCS->getGuildColor2()); pCS->getInvertGuildSymbol(), pCS->getGuildColor1(), pCS->getGuildColor2());

@ -104,7 +104,11 @@ void CControlSheetInfoWaiter::infoReceived()
string CControlSheetInfoWaiter::infoValidated() const string CControlSheetInfoWaiter::infoValidated() const
{ {
ucstring help; // FIXME: Lua UTF-8 #ifdef RYZOM_LUA_UCSTRING
ucstring help; // Compatibility
#else
string help;
#endif
if (CtrlSheet && !LuaMethodName.empty()) if (CtrlSheet && !LuaMethodName.empty())
{ {
// delegate setup of context he help ( & window ) to lua // delegate setup of context he help ( & window ) to lua
@ -122,7 +126,12 @@ string CControlSheetInfoWaiter::infoValidated() const
// retrieve result from stack // retrieve result from stack
if (!ls->empty()) if (!ls->empty())
{ {
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::pop(*ls, help); CLuaIHM::pop(*ls, help);
#else
help = ls->toString(-1);
ls->pop();
#endif
} }
else else
{ {
@ -131,7 +140,11 @@ string CControlSheetInfoWaiter::infoValidated() const
} }
} }
#ifdef RYZOM_LUA_UCSTRING
return help.toUtf8(); return help.toUtf8();
#else
return help;
#endif
} }
// *************************************************************************** // ***************************************************************************
@ -179,7 +192,11 @@ int CDBCtrlSheet::luaGetItemInfo(CLuaState &ls)
// *************************************************************************** // ***************************************************************************
int CDBCtrlSheet::luaGetName(CLuaState &ls) int CDBCtrlSheet::luaGetName(CLuaState &ls)
{ {
CLuaIHM::push(ls, getItemActualName()); #ifdef RYZOM_LUA_UCSTRING
CLuaIHM::push(ls, ucstring::makeFromUtf8(getItemActualName()));
#else
ls.push(getItemActualName());
#endif
return 1; return 1;
} }
@ -209,7 +226,11 @@ int CDBCtrlSheet::luaGetCreatorName(CLuaState &ls)
CClientItemInfo itemInfo = getInventory().getItemInfo(itemSlotId); CClientItemInfo itemInfo = getInventory().getItemInfo(itemSlotId);
string creatorName; string creatorName;
STRING_MANAGER::CStringManagerClient::instance()->getString(itemInfo.CreatorName, creatorName); STRING_MANAGER::CStringManagerClient::instance()->getString(itemInfo.CreatorName, creatorName);
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::push(ls, ucstring::makeFromUtf8(creatorName)); // FIXME: Lua UTF-8 CLuaIHM::push(ls, ucstring::makeFromUtf8(creatorName)); // FIXME: Lua UTF-8
#else
ls.push(creatorName);
#endif
return 1; return 1;
} }
@ -3507,11 +3528,16 @@ void CDBCtrlSheet::getContextHelp(std::string &help) const
game = game["game"]; game = game["game"];
game.callMethodByNameNoThrow("updatePhraseTooltip", 1, 1); game.callMethodByNameNoThrow("updatePhraseTooltip", 1, 1);
// retrieve result from stack // retrieve result from stack
ucstring tmpHelp; // FIXME: Lua UTF-8
if (!ls->empty()) if (!ls->empty())
{ {
CLuaIHM::pop(*ls, tmpHelp); // FIXME: Lua UTF-8 #ifdef RYZOM_LUA_UCSTRING
help = tmpHelp.toUtf8(); // FIXME: Lua UTF-8 ucstring tmpHelp; // Compatibility
CLuaIHM::pop(*ls, tmpHelp);
help = tmpHelp.toUtf8();
#else
help = ls->toString();
ls->pop();
#endif
} }
else else
{ {

@ -374,7 +374,7 @@ void CDBGroupBuildPhrase::startComposition(const CSPhraseCom &phrase)
// set the editable name. // set the editable name.
if(_UserSentenceName) if(_UserSentenceName)
_UserSentenceName->setInputStringAsUtf16(name); _UserSentenceName->setInputString(name);
} }
@ -1791,7 +1791,7 @@ void CDBGroupBuildPhrase::buildCurrentPhrase(CSPhraseCom &newPhrase)
// Set the Name // Set the Name
if(_UserSentenceName) if(_UserSentenceName)
{ {
newPhrase.Name= _UserSentenceName->getInputStringAsUtf16(); newPhrase.Name= ucstring::makeFromUtf8(_UserSentenceName->getInputString());
} }
} }

@ -399,7 +399,7 @@ void CEncyclopediaManager::rebuildThemaPage(uint32 themaName)
// setup task NPC name // setup task NPC name
CStringPostProcessNPCRemoveTitle *pSPPRT = new CStringPostProcessNPCRemoveTitle; CStringPostProcessNPCRemoveTitle *pSPPRT = new CStringPostProcessNPCRemoveTitle;
pIM->addServerID (sTmp+":npc:uc_hardtext", pThema->TaskNPCName[i], pSPPRT); pIM->addServerID (sTmp+":npc:hardtext", pThema->TaskNPCName[i], pSPPRT);
// If the task is not known gray it // If the task is not known gray it
if (pThema->getTaskState((uint8)i) == 0) if (pThema->getTaskState((uint8)i) == 0)

@ -141,7 +141,7 @@ static void popupLandMarkNameDialog()
const CUserLandMark userLM = map->getUserLandMark(LastSelectedLandMark); const CUserLandMark userLM = map->getUserLandMark(LastSelectedLandMark);
NLGUI::CDBManager::getInstance()->getDbProp( "UI:TEMP:LANDMARKTYPE" )->setValue8(cb->getTextPos(userLM.Type)); NLGUI::CDBManager::getInstance()->getDbProp( "UI:TEMP:LANDMARKTYPE" )->setValue8(cb->getTextPos(userLM.Type));
eb->setInputStringAsUtf16(userLM.Title); eb->setInputString(userLM.Title.toUtf8());
} }
else else
{ {
@ -3245,9 +3245,10 @@ CGroupMap::CLandMarkButton* CGroupMap::findClosestLandmark(const CVector2f &cent
closest = std::numeric_limits<float>::max(); closest = std::numeric_limits<float>::max();
for(TLandMarkButtonVect::const_iterator it = landmarks.begin(); it != landmarks.end(); ++it) for(TLandMarkButtonVect::const_iterator it = landmarks.begin(); it != landmarks.end(); ++it)
{ {
ucstring lc; std::string lc;
(*it)->getContextHelpAsUtf16(lc); (*it)->getContextHelp(lc);
if(filterLandmark(lc, keywords, startsWith)) { ucstring ulc = ucstring::makeFromUtf8(lc);
if(filterLandmark(ulc, keywords, startsWith)) {
CVector2f pos; CVector2f pos;
mapToWorld(pos, (*it)->Pos); mapToWorld(pos, (*it)->Pos);
float dist = distsqr(center, pos); float dist = distsqr(center, pos);
@ -3822,7 +3823,7 @@ class CAHValidateUserLandMarkName : public IActionHandler
CGroupMap *map = dynamic_cast<CGroupMap *>(LastSelectedLandMark->getParent()); CGroupMap *map = dynamic_cast<CGroupMap *>(LastSelectedLandMark->getParent());
if (!map) return; if (!map) return;
// update existing landmark // update existing landmark
map->updateUserLandMark(LastSelectedLandMark, eb->getInputStringAsUtf16(), landMarkType); map->updateUserLandMark(LastSelectedLandMark, ucstring::makeFromUtf8(eb->getInputString()), landMarkType);
} }
else else
{ {
@ -3830,11 +3831,11 @@ class CAHValidateUserLandMarkName : public IActionHandler
if (!LastClickedMap) return; if (!LastClickedMap) return;
if( UseUserPositionForLandMark ) if( UseUserPositionForLandMark )
{ {
LastClickedMap->addUserLandMark(LastClickedMap->getPlayerPos(), eb->getInputStringAsUtf16(), landMarkType); LastClickedMap->addUserLandMark(LastClickedMap->getPlayerPos(), ucstring::makeFromUtf8(eb->getInputString()), landMarkType);
} }
else else
{ {
LastClickedMap->addUserLandMark(LastClickedMap->getRightClickLastPos(), eb->getInputStringAsUtf16(), landMarkType); LastClickedMap->addUserLandMark(LastClickedMap->getRightClickLastPos(), ucstring::makeFromUtf8(eb->getInputString()), landMarkType);
} }
LastClickedMap->invalidateCoords(); LastClickedMap->invalidateCoords();
} }

@ -262,6 +262,7 @@ static DECLARE_INTERFACE_USER_FCT(lua)
// NB: the value is poped in obj.set() (no need to do ls.pop()); // NB: the value is poped in obj.set() (no need to do ls.pop());
// try with ucstring // try with ucstring
#ifdef RYZOM_LUA_UCSTRING
ucstring ucstrVal; ucstring ucstrVal;
if (CLuaIHM::pop(ls, ucstrVal)) if (CLuaIHM::pop(ls, ucstrVal))
@ -270,9 +271,10 @@ static DECLARE_INTERFACE_USER_FCT(lua)
ok = true; ok = true;
} }
// try with RGBA
if (!ok) if (!ok)
#endif
{ {
// try with RGBA
NLMISC::CRGBA rgbaVal; NLMISC::CRGBA rgbaVal;
if (CLuaIHM::pop(ls, rgbaVal)) if (CLuaIHM::pop(ls, rgbaVal))
@ -508,13 +510,17 @@ void CLuaIHMRyzom::RegisterRyzomFunctions(NLGUI::CLuaState &ls)
LUABIND_FUNC(dumpCallStack), LUABIND_FUNC(dumpCallStack),
LUABIND_FUNC(getDefine), LUABIND_FUNC(getDefine),
LUABIND_FUNC(setContextHelpText), LUABIND_FUNC(setContextHelpText),
#ifdef RYZOM_LUA_UCSTRING
luabind::def("messageBox", (void(*)(const ucstring &)) &messageBox), luabind::def("messageBox", (void(*)(const ucstring &)) &messageBox),
luabind::def("messageBox", (void(*)(const ucstring &, const std::string &)) &messageBox), luabind::def("messageBox", (void(*)(const ucstring &, const std::string &)) &messageBox),
luabind::def("messageBox", (void(*)(const ucstring &, const std::string &, int caseMode)) &messageBox), luabind::def("messageBox", (void(*)(const ucstring &, const std::string &, int caseMode)) &messageBox),
#endif
luabind::def("messageBox", (void(*)(const std::string &)) &messageBox), luabind::def("messageBox", (void(*)(const std::string &)) &messageBox),
#ifdef RYZOM_LUA_UCSTRING
luabind::def("messageBoxWithHelp", (void(*)(const ucstring &)) &messageBoxWithHelp), // TODO: Lua UTF-8 luabind::def("messageBoxWithHelp", (void(*)(const ucstring &)) &messageBoxWithHelp), // TODO: Lua UTF-8
luabind::def("messageBoxWithHelp", (void(*)(const ucstring &, const std::string &)) &messageBoxWithHelp), // TODO: Lua UTF-8 luabind::def("messageBoxWithHelp", (void(*)(const ucstring &, const std::string &)) &messageBoxWithHelp), // TODO: Lua UTF-8
luabind::def("messageBoxWithHelp", (void(*)(const ucstring &, const std::string &, int caseMode)) &messageBoxWithHelp), // TODO: Lua UTF-8 luabind::def("messageBoxWithHelp", (void(*)(const ucstring &, const std::string &, int caseMode)) &messageBoxWithHelp), // TODO: Lua UTF-8
#endif
luabind::def("messageBoxWithHelp", (void(*)(const std::string &)) &messageBoxWithHelp), luabind::def("messageBoxWithHelp", (void(*)(const std::string &)) &messageBoxWithHelp),
LUABIND_FUNC(replacePvpEffectParam), LUABIND_FUNC(replacePvpEffectParam),
LUABIND_FUNC(secondsSince1970ToHour), LUABIND_FUNC(secondsSince1970ToHour),
@ -798,16 +804,24 @@ int CLuaIHMRyzom::validMessageBox(CLuaState &ls)
//H_AUTO(Lua_CLuaIHM_validMessageBox) //H_AUTO(Lua_CLuaIHM_validMessageBox)
const char *funcName = "validMessageBox"; const char *funcName = "validMessageBox";
CLuaIHM::checkArgCount(ls, funcName, 6); CLuaIHM::checkArgCount(ls, funcName, 6);
#ifdef RYZOM_LUA_UCSTRING
ucstring msg; ucstring msg;
ls.pushValue(1); // copy ucstring at the end of stack to pop it ls.pushValue(1); // copy ucstring at the end of stack to pop it
CLuaIHM::check(ls, CLuaIHM::pop(ls, msg), "validMessageBox : ucstring wanted as first parameter"); CLuaIHM::check(ls, CLuaIHM::pop(ls, msg), "validMessageBox : ucstring wanted as first parameter");
#else
CLuaIHM::checkArgType(ls, funcName, 1, LUA_TSTRING);
#endif
CLuaIHM::checkArgType(ls, funcName, 2, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 2, LUA_TSTRING);
CLuaIHM::checkArgType(ls, funcName, 3, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 3, LUA_TSTRING);
CLuaIHM::checkArgType(ls, funcName, 4, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 4, LUA_TSTRING);
CLuaIHM::checkArgType(ls, funcName, 5, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 5, LUA_TSTRING);
CLuaIHM::checkArgType(ls, funcName, 6, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 6, LUA_TSTRING);
CInterfaceManager *im = CInterfaceManager::getInstance(); CInterfaceManager *im = CInterfaceManager::getInstance();
#ifdef RYZOM_LUA_UCSTRING
im->validMessageBox(CInterfaceManager::QuestionIconMsg, msg.toUtf8(), ls.toString(2), ls.toString(3), ls.toString(4), ls.toString(5), ls.toString(6)); im->validMessageBox(CInterfaceManager::QuestionIconMsg, msg.toUtf8(), ls.toString(2), ls.toString(3), ls.toString(4), ls.toString(5), ls.toString(6));
#else
im->validMessageBox(CInterfaceManager::QuestionIconMsg, ls.toString(1), ls.toString(2), ls.toString(3), ls.toString(4), ls.toString(5), ls.toString(6));
#endif
return 0; return 0;
} }
@ -843,6 +857,7 @@ int CLuaIHMRyzom::setTextFormatTaged(CLuaState &ls)
CInterfaceElement *pIE = CLuaIHM::getUIOnStack(ls, 1); CInterfaceElement *pIE = CLuaIHM::getUIOnStack(ls, 1);
// *** check and retrieve param 2. must be a string or a ucstring // *** check and retrieve param 2. must be a string or a ucstring
#ifdef RYZOM_LUA_UCSTRING
ucstring text; ucstring text;
if (ls.isString(2)) if (ls.isString(2))
@ -860,6 +875,13 @@ int CLuaIHMRyzom::setTextFormatTaged(CLuaState &ls)
CLuaIHM::check(ls, false, "setTextFormatTaged() requires a string or a ucstring in param 2"); CLuaIHM::check(ls, false, "setTextFormatTaged() requires a string or a ucstring in param 2");
} }
} }
#else
string text;
if (ls.isString(2))
{
ls.toString(2, text);
}
#endif
// must be a view text // must be a view text
CViewText *vt = dynamic_cast<CViewText*>(pIE); CViewText *vt = dynamic_cast<CViewText*>(pIE);
@ -868,7 +890,11 @@ int CLuaIHMRyzom::setTextFormatTaged(CLuaState &ls)
throw ELuaIHMException("setTextFormatTaged(): '%s' is not a CViewText", pIE->getId().c_str()); throw ELuaIHMException("setTextFormatTaged(): '%s' is not a CViewText", pIE->getId().c_str());
// Set the text as format // Set the text as format
#ifdef RYZOM_LUA_UCSTRING
vt->setTextFormatTaged(text.toUtf8()); vt->setTextFormatTaged(text.toUtf8());
#else
vt->setTextFormatTaged(text);
#endif
return 0; return 0;
} }
@ -891,8 +917,8 @@ struct CEmoteStruct
string::size_type pos1 = path1.find('|'); string::size_type pos1 = path1.find('|');
string::size_type pos2 = path2.find('|'); string::size_type pos2 = path2.find('|');
ucstring s1 = toUpper(CI18N::get(path1.substr(0, pos1))); std::string s1 = toUpper(CI18N::get(path1.substr(0, pos1)));
ucstring s2 = toUpper(CI18N::get(path2.substr(0, pos2))); std::string s2 = toUpper(CI18N::get(path2.substr(0, pos2)));
sint result = s1.compare(s2); sint result = s1.compare(s2);
@ -1664,12 +1690,22 @@ int CLuaIHMRyzom::displaySystemInfo(CLuaState &ls)
//H_AUTO(Lua_CLuaIHM_displaySystemInfo) //H_AUTO(Lua_CLuaIHM_displaySystemInfo)
const char *funcName = "displaySystemInfo"; const char *funcName = "displaySystemInfo";
CLuaIHM::checkArgCount(ls, funcName, 2); CLuaIHM::checkArgCount(ls, funcName, 2);
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::checkArgTypeUCString(ls, funcName, 1); CLuaIHM::checkArgTypeUCString(ls, funcName, 1);
#else
CLuaIHM::checkArgType(ls, funcName, 1, LUA_TSTRING);
#endif
CLuaIHM::checkArgType(ls, funcName, 2, LUA_TSTRING); CLuaIHM::checkArgType(ls, funcName, 2, LUA_TSTRING);
#ifdef RYZOM_LUA_UCSTRING
ucstring msg; ucstring msg;
nlverify(CLuaIHM::getUCStringOnStack(ls, 1, msg)); nlverify(CLuaIHM::getUCStringOnStack(ls, 1, msg));
#endif
CInterfaceManager *pIM = CInterfaceManager::getInstance(); CInterfaceManager *pIM = CInterfaceManager::getInstance();
#ifdef RYZOM_LUA_UCSTRING
pIM->displaySystemInfo(msg.toUtf8(), ls.toString(2)); pIM->displaySystemInfo(msg.toUtf8(), ls.toString(2));
#else
pIM->displaySystemInfo(ls.toString(1), ls.toString(2));
#endif
return 0; return 0;
} }
@ -2836,12 +2872,21 @@ std::string CLuaIHMRyzom::getDefine(const std::string &def)
return CWidgetManager::getInstance()->getParser()->getDefine(def); return CWidgetManager::getInstance()->getParser()->getDefine(def);
} }
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
void CLuaIHMRyzom::setContextHelpText(const ucstring &text) void CLuaIHMRyzom::setContextHelpText(const ucstring &text)
{ {
CWidgetManager::getInstance()->setContextHelpText(text.toUtf8()); CWidgetManager::getInstance()->setContextHelpText(text.toUtf8());
} }
#else
// ***************************************************************************
void CLuaIHMRyzom::setContextHelpText(const std::string &text)
{
CWidgetManager::getInstance()->setContextHelpText(text);
}
#endif
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
void CLuaIHMRyzom::messageBox(const ucstring &text) void CLuaIHMRyzom::messageBox(const ucstring &text)
{ {
@ -2870,6 +2915,7 @@ void CLuaIHMRyzom::messageBox(const ucstring &text, const std::string &masterGr
CInterfaceManager *pIM = CInterfaceManager::getInstance(); CInterfaceManager *pIM = CInterfaceManager::getInstance();
pIM->messageBox(text.toUtf8(), masterGroup, (TCaseMode) caseMode); pIM->messageBox(text.toUtf8(), masterGroup, (TCaseMode) caseMode);
} }
#endif
// *************************************************************************** // ***************************************************************************
void CLuaIHMRyzom::messageBox(const std::string &text) void CLuaIHMRyzom::messageBox(const std::string &text)
@ -2886,6 +2932,28 @@ void CLuaIHMRyzom::messageBox(const std::string &text)
pIM->messageBox(text); pIM->messageBox(text);
} }
// ***************************************************************************
void CLuaIHMRyzom::messageBox(const std::string &text, const std::string &masterGroup)
{
//H_AUTO(Lua_CLuaIHM_messageBox)
CInterfaceManager *pIM = CInterfaceManager::getInstance();
pIM->messageBox(text, masterGroup);
}
// ***************************************************************************
void CLuaIHMRyzom::messageBox(const std::string &text, const std::string &masterGroup, int caseMode)
{
if (caseMode < 0 || caseMode >= CaseCount)
{
throw ELuaIHMException("messageBox: case mode value is invalid.");
}
//H_AUTO(Lua_CLuaIHM_messageBox)
CInterfaceManager *pIM = CInterfaceManager::getInstance();
pIM->messageBox(text, masterGroup, (TCaseMode) caseMode);
}
#ifdef RYZOM_LUA_UCSTRING
// *************************************************************************** // ***************************************************************************
void CLuaIHMRyzom::messageBoxWithHelp(const ucstring &text) // TODO: Lua UTF-8 void CLuaIHMRyzom::messageBoxWithHelp(const ucstring &text) // TODO: Lua UTF-8
{ {
@ -2914,6 +2982,7 @@ void CLuaIHMRyzom::messageBoxWithHelp(const ucstring &text, const std::string &
CInterfaceManager *pIM = CInterfaceManager::getInstance(); CInterfaceManager *pIM = CInterfaceManager::getInstance();
pIM->messageBoxWithHelp(text.toUtf8(), masterGroup, "" , "", (TCaseMode) caseMode); pIM->messageBoxWithHelp(text.toUtf8(), masterGroup, "" , "", (TCaseMode) caseMode);
} }
#endif
// *************************************************************************** // ***************************************************************************
void CLuaIHMRyzom::messageBoxWithHelp(const std::string &text) void CLuaIHMRyzom::messageBoxWithHelp(const std::string &text)
@ -2930,6 +2999,27 @@ void CLuaIHMRyzom::messageBoxWithHelp(const std::string &text)
pIM->messageBoxWithHelp(text); pIM->messageBoxWithHelp(text);
} }
// ***************************************************************************
void CLuaIHMRyzom::messageBoxWithHelp(const std::string &text, const std::string &masterGroup)
{
//H_AUTO(Lua_CLuaIHM_messageBox)
CInterfaceManager *pIM = CInterfaceManager::getInstance();
pIM->messageBoxWithHelp(text, masterGroup);
}
// ***************************************************************************
void CLuaIHMRyzom::messageBoxWithHelp(const std::string &text, const std::string &masterGroup, int caseMode)
{
if (caseMode < 0 || caseMode >= CaseCount)
{
throw ELuaIHMException("messageBoxWithHelp: case mode value is invalid.");
}
//H_AUTO(Lua_CLuaIHM_messageBox)
CInterfaceManager *pIM = CInterfaceManager::getInstance();
pIM->messageBoxWithHelp(text, masterGroup, "" , "", (TCaseMode) caseMode);
}
// *************************************************************************** // ***************************************************************************
bool CLuaIHMRyzom::executeFunctionOnStack(CLuaState &ls, int numArgs, int numRet) bool CLuaIHMRyzom::executeFunctionOnStack(CLuaState &ls, int numArgs, int numRet)
{ {
@ -2972,11 +3062,20 @@ bool CLuaIHMRyzom::executeFunctionOnStack(CLuaState &ls, int numArgs, int nu
} }
// *************************************************************************** // ***************************************************************************
#ifdef RYZOM_LUA_UCSTRING
ucstring CLuaIHMRyzom::replacePvpEffectParam(const ucstring &str, sint32 parameter) ucstring CLuaIHMRyzom::replacePvpEffectParam(const ucstring &str, sint32 parameter)
#else
std::string CLuaIHMRyzom::replacePvpEffectParam(const std::string &str, sint32 parameter)
#endif
{ {
//H_AUTO(Lua_CLuaIHM_replacePvpEffectParam) //H_AUTO(Lua_CLuaIHM_replacePvpEffectParam)
#ifdef RYZOM_LUA_UCSTRING
ucstring result = str; ucstring result = str;
CSString s = str.toString(); CSString s = str.toString();
#else
std::string result = str;
CSString s = str;
#endif
std::string p, paramString; std::string p, paramString;
// Locate parameter and store it // Locate parameter and store it
@ -3014,7 +3113,11 @@ ucstring CLuaIHMRyzom::replacePvpEffectParam(const ucstring &str, sint32 paramet
break; break;
default: default:
#ifdef RYZOM_LUA_UCSTRING
debugInfo("Bad arguments in " + str.toString() + " : " + paramString); debugInfo("Bad arguments in " + str.toString() + " : " + paramString);
#else
debugInfo("Bad arguments in " + str + " : " + paramString);
#endif
} }
strFindReplace(result, paramString.c_str(), p); strFindReplace(result, paramString.c_str(), p);
@ -3080,7 +3183,11 @@ void CLuaIHMRyzom::loadBackground(const std::string &bg)
// *************************************************************************** // ***************************************************************************
#ifdef RYZOM_LUA_UCSTRING
ucstring CLuaIHMRyzom::getPatchLastErrorMessage() ucstring CLuaIHMRyzom::getPatchLastErrorMessage()
#else
std::string CLuaIHMRyzom::getPatchLastErrorMessage()
#endif
{ {
#ifdef RYZOM_BG_DOWNLOADER #ifdef RYZOM_BG_DOWNLOADER
if (isBGDownloadEnabled()) if (isBGDownloadEnabled())
@ -3133,11 +3240,19 @@ sint32 CLuaIHMRyzom::getSkillIdFromName(const std::string &def)
} }
// *************************************************************************** // ***************************************************************************
#ifdef RYZOM_LUA_UCSTRING
ucstring CLuaIHMRyzom::getSkillLocalizedName(sint32 skillId) ucstring CLuaIHMRyzom::getSkillLocalizedName(sint32 skillId)
{ {
//H_AUTO(Lua_CLuaIHM_getSkillLocalizedName) //H_AUTO(Lua_CLuaIHM_getSkillLocalizedName)
return ucstring(STRING_MANAGER::CStringManagerClient::getSkillLocalizedName((SKILLS::ESkills)skillId)); return ucstring(STRING_MANAGER::CStringManagerClient::getSkillLocalizedName((SKILLS::ESkills)skillId));
} }
#else
std::string CLuaIHMRyzom::getSkillLocalizedName(sint32 skillId)
{
//H_AUTO(Lua_CLuaIHM_getSkillLocalizedName)
return STRING_MANAGER::CStringManagerClient::getSkillLocalizedName((SKILLS::ESkills)skillId);
}
#endif
// *************************************************************************** // ***************************************************************************
sint32 CLuaIHMRyzom::getMaxSkillValue(sint32 skillId) sint32 CLuaIHMRyzom::getMaxSkillValue(sint32 skillId)
@ -3274,13 +3389,23 @@ void CLuaIHMRyzom::clearHtmlUndoRedo(const std::string &htmlId)
} }
// *************************************************************************** // ***************************************************************************
#ifdef RYZOM_LUA_UCSTRING
ucstring CLuaIHMRyzom::getDynString(sint32 dynStringId) ucstring CLuaIHMRyzom::getDynString(sint32 dynStringId)
{ {
//H_AUTO(Lua_CLuaIHM_getDynString) //H_AUTO(Lua_CLuaIHM_getDynString)
string result; string result;
STRING_MANAGER::CStringManagerClient::instance()->getDynString(dynStringId, result); STRING_MANAGER::CStringManagerClient::instance()->getDynString(dynStringId, result);
return ucstring::makeFromUtf8(result); // TODO: Lua UTF-8 return ucstring::makeFromUtf8(result); // Compatibility
}
#else
std::string CLuaIHMRyzom::getDynString(sint32 dynStringId)
{
//H_AUTO(Lua_CLuaIHM_getDynString)
string result;
STRING_MANAGER::CStringManagerClient::instance()->getDynString(dynStringId, result);
return result;
} }
#endif
// *************************************************************************** // ***************************************************************************
bool CLuaIHMRyzom::isDynStringAvailable(sint32 dynStringId) bool CLuaIHMRyzom::isDynStringAvailable(sint32 dynStringId)
@ -3560,7 +3685,11 @@ void setMouseCursor(const std::string &texture)
} }
// *************************************************************************** // ***************************************************************************
#ifdef RYZOM_LUA_UCSTRING
void CLuaIHMRyzom::tell(const ucstring &player, const ucstring &msg) void CLuaIHMRyzom::tell(const ucstring &player, const ucstring &msg)
#else
void CLuaIHMRyzom::tell(const std::string &player, const std::string &msg)
#endif
{ {
//H_AUTO(Lua_CLuaIHM_tell) //H_AUTO(Lua_CLuaIHM_tell)
// display a /tell command in the main chat // display a /tell command in the main chat
@ -3569,7 +3698,11 @@ void CLuaIHMRyzom::tell(const ucstring &player, const ucstring &msg)
if (!msg.empty()) if (!msg.empty())
{ {
// Parse any tokens in the message. // Parse any tokens in the message.
#ifdef RYZOM_LUA_UCSTRING
string msg_modified = msg.toUtf8(); string msg_modified = msg.toUtf8();
#else
string msg_modified = msg;
#endif
// Parse any tokens in the text // Parse any tokens in the text
if (! CInterfaceManager::parseTokens(msg_modified)) if (! CInterfaceManager::parseTokens(msg_modified))
@ -3577,7 +3710,11 @@ void CLuaIHMRyzom::tell(const ucstring &player, const ucstring &msg)
return; return;
} }
#ifdef RYZOM_LUA_UCSTRING
ChatMngr.tell(player.toUtf8(), msg_modified); ChatMngr.tell(player.toUtf8(), msg_modified);
#else
ChatMngr.tell(player, msg_modified);
#endif
} }
else else
{ {
@ -3588,7 +3725,11 @@ void CLuaIHMRyzom::tell(const ucstring &player, const ucstring &msg)
CInterfaceManager *im = CInterfaceManager::getInstance(); CInterfaceManager *im = CInterfaceManager::getInstance();
w->setKeyboardFocus(); w->setKeyboardFocus();
w->enableBlink(1); w->enableBlink(1);
#ifdef RYZOM_LUA_UCSTRING
w->setCommand("tell " + CEntityCL::removeTitleFromName(player.toUtf8()) + " ", false); w->setCommand("tell " + CEntityCL::removeTitleFromName(player.toUtf8()) + " ", false);
#else
w->setCommand("tell " + CEntityCL::removeTitleFromName(player) + " ", false);
#endif
CGroupEditBox *eb = w->getEditBox(); CGroupEditBox *eb = w->getEditBox();
if (eb != NULL) if (eb != NULL)
@ -3638,11 +3779,19 @@ bool CLuaIHMRyzom::isCtrlKeyDown()
} }
// *************************************************************************** // ***************************************************************************
#ifdef RYZOM_LUA_UCSTRING
std::string CLuaIHMRyzom::encodeURLUnicodeParam(const ucstring &text) std::string CLuaIHMRyzom::encodeURLUnicodeParam(const ucstring &text)
{ {
//H_AUTO(Lua_CLuaIHM_encodeURLUnicodeParam) //H_AUTO(Lua_CLuaIHM_encodeURLUnicodeParam)
return convertToHTML(text.toUtf8()); return convertToHTML(text.toUtf8());
} }
#else
std::string CLuaIHMRyzom::encodeURLUnicodeParam(const std::string &text)
{
//H_AUTO(Lua_CLuaIHM_encodeURLUnicodeParam)
return convertToHTML(text);
}
#endif
// *************************************************************************** // ***************************************************************************
sint32 CLuaIHMRyzom::getPlayerLevel() sint32 CLuaIHMRyzom::getPlayerLevel()
@ -3709,6 +3858,7 @@ sint32 CLuaIHMRyzom::getTargetLevel()
} }
// *************************************************************************** // ***************************************************************************
#ifdef RYZOM_LUA_UCSTRING
ucstring CLuaIHMRyzom::getTargetSheet() ucstring CLuaIHMRyzom::getTargetSheet()
{ {
CEntityCL *target = getTargetEntity(); CEntityCL *target = getTargetEntity();
@ -3716,6 +3866,15 @@ ucstring CLuaIHMRyzom::getTargetSheet()
return target->sheetId().toString(); return target->sheetId().toString();
} }
#else
std::string CLuaIHMRyzom::getTargetSheet()
{
CEntityCL *target = getTargetEntity();
if (!target) return std::string();
return target->sheetId().toString();
}
#endif
// *************************************************************************** // ***************************************************************************
sint64 CLuaIHMRyzom::getTargetVpa() sint64 CLuaIHMRyzom::getTargetVpa()

@ -156,19 +156,35 @@ private:
static void getCallStackAsString(int startStackLevel, std::string &result); static void getCallStackAsString(int startStackLevel, std::string &result);
static std::string getDefine(const std::string &def); static std::string getDefine(const std::string &def);
#ifdef RYZOM_LUA_UCSTRING
static void setContextHelpText(const ucstring &text); static void setContextHelpText(const ucstring &text);
#else
static void setContextHelpText(const std::string &text);
#endif
#ifdef RYZOM_LUA_UCSTRING
static void messageBox(const ucstring &text); static void messageBox(const ucstring &text);
static void messageBox(const ucstring &text, const std::string &masterGroup); static void messageBox(const ucstring &text, const std::string &masterGroup);
static void messageBox(const ucstring &text, const std::string &masterGroup, int caseMode); static void messageBox(const ucstring &text, const std::string &masterGroup, int caseMode);
#endif
static void messageBox(const std::string &text); static void messageBox(const std::string &text);
static void messageBox(const std::string &text, const std::string &masterGroup);
static void messageBox(const std::string &text, const std::string &masterGroup, int caseMode);
#ifdef RYZOM_LUA_UCSTRING
static void messageBoxWithHelp(const ucstring &text); static void messageBoxWithHelp(const ucstring &text);
static void messageBoxWithHelp(const ucstring &text, const std::string &masterGroup); static void messageBoxWithHelp(const ucstring &text, const std::string &masterGroup);
static void messageBoxWithHelp(const ucstring &text, const std::string &masterGroup, int caseMode); static void messageBoxWithHelp(const ucstring &text, const std::string &masterGroup, int caseMode);
#endif
static void messageBoxWithHelp(const std::string &text); static void messageBoxWithHelp(const std::string &text);
static void messageBoxWithHelp(const std::string &text, const std::string &masterGroup);
static void messageBoxWithHelp(const std::string &text, const std::string &masterGroup, int caseMode);
#ifdef RYZOM_LUA_UCSTRING
static ucstring replacePvpEffectParam(const ucstring &str, sint32 parameter); // TODO: UTF-8 Lua static ucstring replacePvpEffectParam(const ucstring &str, sint32 parameter); // TODO: UTF-8 Lua
#else
static std::string replacePvpEffectParam(const std::string &str, sint32 parameter); // TODO: UTF-8 Lua
#endif
static sint32 secondsSince1970ToHour(sint32 seconds); static sint32 secondsSince1970ToHour(sint32 seconds);
#ifdef RYZOM_BG_DOWNLOADER #ifdef RYZOM_BG_DOWNLOADER
static void pauseBGDownloader(); static void pauseBGDownloader();
@ -177,21 +193,33 @@ private:
static sint getBGDownloaderPriority(); static sint getBGDownloaderPriority();
#endif #endif
static void loadBackground(const std::string &bg); static void loadBackground(const std::string &bg);
#ifdef RYZOM_LUA_UCSTRING
static ucstring getPatchLastErrorMessage(); static ucstring getPatchLastErrorMessage();
#else
static std::string getPatchLastErrorMessage();
#endif
static bool isInGame(); static bool isInGame();
static uint32 getPlayerSelectedSlot(); static uint32 getPlayerSelectedSlot();
static bool isPlayerSlotNewbieLand(uint32 slot); // test if one of the player slot is a newbieland one, if not so, client must be patched in order to continue static bool isPlayerSlotNewbieLand(uint32 slot); // test if one of the player slot is a newbieland one, if not so, client must be patched in order to continue
// GameInfo // GameInfo
static sint32 getSkillIdFromName(const std::string &def); static sint32 getSkillIdFromName(const std::string &def);
#ifdef RYZOM_LUA_UCSTRING
static ucstring getSkillLocalizedName(sint32 skillId); static ucstring getSkillLocalizedName(sint32 skillId);
#else
static std::string getSkillLocalizedName(sint32 skillId);
#endif
static sint32 getMaxSkillValue(sint32 skillId); static sint32 getMaxSkillValue(sint32 skillId);
static sint32 getBaseSkillValueMaxChildren(sint32 skillId); static sint32 getBaseSkillValueMaxChildren(sint32 skillId);
static sint32 getMagicResistChance(bool elementalSpell, sint32 casterSpellLvl, sint32 victimResistLvl); static sint32 getMagicResistChance(bool elementalSpell, sint32 casterSpellLvl, sint32 victimResistLvl);
static sint32 getDodgeParryChance(sint32 attLvl, sint32 defLvl); static sint32 getDodgeParryChance(sint32 attLvl, sint32 defLvl);
static void browseNpcWebPage(const std::string &htmlId, const std::string &url, bool addParameters, double timeout); static void browseNpcWebPage(const std::string &htmlId, const std::string &url, bool addParameters, double timeout);
static void clearHtmlUndoRedo(const std::string &htmlId); static void clearHtmlUndoRedo(const std::string &htmlId);
#ifdef RYZOM_LUA_UCSTRING
static ucstring getDynString(sint32 dynStringId); static ucstring getDynString(sint32 dynStringId);
#else
static std::string getDynString(sint32 dynStringId);
#endif
static bool isDynStringAvailable(sint32 dynStringId); static bool isDynStringAvailable(sint32 dynStringId);
static bool isFullyPatched(); static bool isFullyPatched();
static std::string getSheetType(const std::string &sheet); static std::string getSheetType(const std::string &sheet);
@ -232,13 +260,21 @@ private:
static void setMouseCursor(const std::string &texture); static void setMouseCursor(const std::string &texture);
// open the window to do a tell to 'player', if 'msg' is not empty, then the message will be sent immediatly // open the window to do a tell to 'player', if 'msg' is not empty, then the message will be sent immediatly
// else, current command of the chat window will be replaced with tell 'player' // else, current command of the chat window will be replaced with tell 'player'
#ifdef RYZOM_LUA_UCSTRING
static void tell(const ucstring &player, const ucstring &msg); static void tell(const ucstring &player, const ucstring &msg);
#else
static void tell(const std::string &player, const std::string &msg);
#endif
static bool isRingAccessPointInReach(); static bool isRingAccessPointInReach();
static void updateTooltipCoords(); static void updateTooltipCoords();
// test if the ctrl key is down (NB nico : I didn't add other key, // test if the ctrl key is down (NB nico : I didn't add other key,
// because it would be too easy to write a key recorder ...) // because it would be too easy to write a key recorder ...)
static bool isCtrlKeyDown(); static bool isCtrlKeyDown();
#ifdef RYZOM_LUA_UCSTRING
static std::string encodeURLUnicodeParam(const ucstring &text); static std::string encodeURLUnicodeParam(const ucstring &text);
#else
static std::string encodeURLUnicodeParam(const std::string &text);
#endif
static sint32 getPlayerLevel(); // get max level among player skills (magi, combat, crafting ,foraging) static sint32 getPlayerLevel(); // get max level among player skills (magi, combat, crafting ,foraging)
static sint64 getPlayerVpa(); static sint64 getPlayerVpa();
@ -246,8 +282,12 @@ private:
static sint64 getPlayerVpc(); static sint64 getPlayerVpc();
static sint32 getTargetLevel(); // get current, precise level of the selected target, or -1 if there's no such selected target static sint32 getTargetLevel(); // get current, precise level of the selected target, or -1 if there's no such selected target
static sint32 getTargetForceRegion(); // get 'force region' for current target, or -1 if there's no selected target static sint32 getTargetForceRegion(); // get 'force region' for current target, or -1 if there's no selected target
static sint32 getTargetLevelForce(); // get 'level force' for current target, or -1 if there's no selected target static sint32 getTargetLevelForce(); // get 'level force' for current target, or -1 if there's no selected target
#ifdef RYZOM_LUA_UCSTRING
static ucstring getTargetSheet(); // get the name of the target sheet (like 'zoha2old.creature') static ucstring getTargetSheet(); // get the name of the target sheet (like 'zoha2old.creature')
#else
static std::string getTargetSheet(); // get the name of the target sheet (like 'zoha2old.creature')
#endif
static sint64 getTargetVpa(); static sint64 getTargetVpa();
static sint64 getTargetVpb(); static sint64 getTargetVpb();
static sint64 getTargetVpc(); static sint64 getTargetVpc();

@ -1677,7 +1677,10 @@ bool CPeopleInterraction::saveUserChatsInfos(NLMISC::IStream &f)
if (ver>=2) if (ver>=2)
{ {
CChatGroupWindow *pCGW = PeopleInterraction.getChatGroupWindow(); CChatGroupWindow *pCGW = PeopleInterraction.getChatGroupWindow();
pCGW->saveFreeTeller(f); if (pCGW)
{
pCGW->saveFreeTeller(f);
}
} }
} }
catch(const NLMISC::EStream &e) catch(const NLMISC::EStream &e)

@ -895,7 +895,7 @@ class CHandlerContactEntry : public IActionHandler
CGroupContainer *gc = static_cast< CGroupContainer* >( pCaller->getParent()->getEnclosingContainer() ); CGroupContainer *gc = static_cast< CGroupContainer* >( pCaller->getParent()->getEnclosingContainer() );
// title gives the name of the player // title gives the name of the player
string playerName = gc->getUCTitle().toUtf8(); string playerName = gc->getTitle();
// Simply do a tell on the player // Simply do a tell on the player
ChatMngr.tell(playerName, text); ChatMngr.tell(playerName, text);

@ -4675,7 +4675,11 @@ int CSPhraseComAdpater::luaGetStaCost(CLuaState &ls)
// *************************************************************************** // ***************************************************************************
int CSPhraseComAdpater::luaGetName(CLuaState &ls) int CSPhraseComAdpater::luaGetName(CLuaState &ls)
{ {
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::push(ls, this->Phrase.Name); CLuaIHM::push(ls, this->Phrase.Name);
#else
ls.push(this->Phrase.Name.toUtf8());
#endif
return 1; return 1;
} }
@ -4688,11 +4692,15 @@ int CSPhraseComAdpater::luaGetDesc(CLuaState &ls)
if (phraseSheetID != 0) if (phraseSheetID != 0)
{ {
// is it a built-in phrase? // is it a built-in phrase?
ucstring desc; // FIXME: UTF-8 Lua const char *desc = STRING_MANAGER::CStringManagerClient::getSPhraseLocalizedDescription(NLMISC::CSheetId(phraseSheetID));
desc.fromUtf8(STRING_MANAGER::CStringManagerClient::getSPhraseLocalizedDescription(NLMISC::CSheetId(phraseSheetID))); if (*desc)
if (!desc.empty())
{ {
#ifdef RYZOM_LUA_UCSTRING
ucstring desc = ucstring::makeFromUtf8(desc); // Compatibility
CLuaIHM::push(ls, desc); CLuaIHM::push(ls, desc);
#else
ls.push(desc);
#endif
return 1; return 1;
} }
} }

@ -586,7 +586,11 @@ void CActionHistoric::CRequestEraseNode::undo(IDynamicMapClient *dmc, CScenario
dmc->doRequestInsertNode(_ParentInstanceId, _AttrNameInParent, _PositionInParent, "", _OldValue); dmc->doRequestInsertNode(_ParentInstanceId, _AttrNameInParent, _PositionInParent, "", _OldValue);
_OldValue = NULL; _OldValue = NULL;
CLuaIHM::push(getEditor().getLua(), _InstanceId); #ifdef RYZOM_LUA_UCSTRING
CLuaIHM::push(getEditor().getLua(), ucstring::makeFromUtf8(_InstanceId));
#else
getEditor().getLua().push(_InstanceId);
#endif
getEditor().callEnvMethod("setUndoRedoInstances", 1, 0); getEditor().callEnvMethod("setUndoRedoInstances", 1, 0);
} }
//==================================================================================== //====================================================================================
@ -616,7 +620,11 @@ void CActionHistoric::CRequestInsertNode::redo(IDynamicMapClient *dmc, CScenario
dmc->doRequestInsertNode(_InstanceId, _AttrName, _Position, _Key, _Value); dmc->doRequestInsertNode(_InstanceId, _AttrName, _Position, _Key, _Value);
CObject* nodeId = _Value->findAttr("InstanceId"); CObject* nodeId = _Value->findAttr("InstanceId");
CLuaIHM::push(getEditor().getLua(), nodeId->toString()); #ifdef RYZOM_LUA_UCSTRING
CLuaIHM::push(getEditor().getLua(), ucstring::makeFromUtf8(nodeId->toString()));
#else
getEditor().getLua().push(nodeId->toString());
#endif
getEditor().callEnvMethod("setUndoRedoInstances", 1, 0); getEditor().callEnvMethod("setUndoRedoInstances", 1, 0);
} }
// //
@ -641,7 +649,11 @@ void CActionHistoric::CRequestInsertNode::undo(IDynamicMapClient *dmc, CScenario
// send to network // send to network
dmc->doRequestEraseNode(instanceId, attrName, position); dmc->doRequestEraseNode(instanceId, attrName, position);
CLuaIHM::push(getEditor().getLua(), instanceId); #ifdef RYZOM_LUA_UCSTRING
CLuaIHM::push(getEditor().getLua(), ucstring::makeFromUtf8(instanceId));
#else
getEditor().getLua().push(instanceId);
#endif
getEditor().callEnvMethod("setUndoRedoInstances", 1, 0); getEditor().callEnvMethod("setUndoRedoInstances", 1, 0);
} }
else else

@ -903,6 +903,7 @@ int CComLuaModule::luaRequestNewAction(lua_State* state, bool pending, uint coun
} }
else else
{ {
#ifdef RYZOM_LUA_UCSTRING
// try with ucstring // try with ucstring
CLuaState &ls = getEditor().getLua(); CLuaState &ls = getEditor().getLua();
nlassert(ls.getStatePointer() == state); nlassert(ls.getStatePointer() == state);
@ -911,6 +912,9 @@ int CComLuaModule::luaRequestNewAction(lua_State* state, bool pending, uint coun
nlwarning("<r2.%s> : ucstring or string expected as action name", funcName); nlwarning("<r2.%s> : ucstring or string expected as action name", funcName);
return 0; return 0;
} }
#else
return 0;
#endif
} }
} }
else else

@ -1191,10 +1191,15 @@ int CEditor::luaGenInstanceName(CLuaState &ls)
CHECK_EDITOR CHECK_EDITOR
const char *funcName = "genInstanceName"; const char *funcName = "genInstanceName";
CLuaIHM::checkArgCount(ls, funcName, 2); // this is a method CLuaIHM::checkArgCount(ls, funcName, 2); // this is a method
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::checkArgTypeUCString(ls, funcName, 2); // name CLuaIHM::checkArgTypeUCString(ls, funcName, 2); // name
ucstring baseName; ucstring baseName;
nlverify(CLuaIHM::getUCStringOnStack(ls, 2, baseName)); nlverify(CLuaIHM::getUCStringOnStack(ls, 2, baseName));
CLuaIHM::push(ls, getEditor().genInstanceName(baseName)); CLuaIHM::push(ls, getEditor().genInstanceName(baseName));
#else
CLuaIHM::checkArgType(ls, funcName, 2, LUA_TSTRING);
ls.push(getEditor().genInstanceName(ucstring::makeFromUtf8(ls.toString(2))).toUtf8()); // FIXME: Ring UTF-8
#endif
return 1; return 1;
} }
@ -1205,10 +1210,15 @@ int CEditor::luaIsPostFixedByNumber(CLuaState &ls)
CHECK_EDITOR CHECK_EDITOR
const char *funcName = "isPostFixedByNumber"; const char *funcName = "isPostFixedByNumber";
CLuaIHM::checkArgCount(ls, funcName, 2); // this is a method CLuaIHM::checkArgCount(ls, funcName, 2); // this is a method
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::checkArgTypeUCString(ls, funcName, 2); // name CLuaIHM::checkArgTypeUCString(ls, funcName, 2); // name
ucstring baseName; ucstring baseName;
nlverify(CLuaIHM::getUCStringOnStack(ls, 2, baseName)); nlverify(CLuaIHM::getUCStringOnStack(ls, 2, baseName));
ls.push(getEditor().isPostFixedByNumber(baseName)); ls.push(getEditor().isPostFixedByNumber(baseName));
#else
CLuaIHM::checkArgType(ls, funcName, 2, LUA_TSTRING);
ls.push(getEditor().isPostFixedByNumber(ucstring::makeFromUtf8(ls.toString(2)))); // FIXME: Ring UTF-8
#endif
return 1; return 1;
} }
@ -1326,9 +1336,15 @@ int CEditor::luaSetPlotItemInfos(CLuaState &ls)
const char *funcName = "setPlotItemInfos"; const char *funcName = "setPlotItemInfos";
CLuaIHM::checkArgCount(ls, funcName, 5); // a method with 4 args CLuaIHM::checkArgCount(ls, funcName, 5); // a method with 4 args
CLuaIHM::checkArgType(ls, funcName, 2, LUA_TNUMBER); CLuaIHM::checkArgType(ls, funcName, 2, LUA_TNUMBER);
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::checkArgTypeUCString(ls, funcName, 3); CLuaIHM::checkArgTypeUCString(ls, funcName, 3);
CLuaIHM::checkArgTypeUCString(ls, funcName, 4); CLuaIHM::checkArgTypeUCString(ls, funcName, 4);
CLuaIHM::checkArgTypeUCString(ls, funcName, 5); CLuaIHM::checkArgTypeUCString(ls, funcName, 5);
#else
CLuaIHM::checkArgType(ls, funcName, 3, LUA_TSTRING);
CLuaIHM::checkArgType(ls, funcName, 4, LUA_TSTRING);
CLuaIHM::checkArgType(ls, funcName, 5, LUA_TSTRING);
#endif
CItemSheet *item = dynamic_cast<CItemSheet *>(SheetMngr.get(CSheetId((uint32) ls.toInteger(2)))); CItemSheet *item = dynamic_cast<CItemSheet *>(SheetMngr.get(CSheetId((uint32) ls.toInteger(2))));
if (!item || item->Family != ITEMFAMILY::SCROLL_R2) if (!item || item->Family != ITEMFAMILY::SCROLL_R2)
{ {
@ -1336,9 +1352,15 @@ int CEditor::luaSetPlotItemInfos(CLuaState &ls)
} }
R2::TMissionItem mi; R2::TMissionItem mi;
mi.SheetId = (uint32) ls.toInteger(2); mi.SheetId = (uint32) ls.toInteger(2);
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::getUCStringOnStack(ls, 3, mi.Name); CLuaIHM::getUCStringOnStack(ls, 3, mi.Name);
CLuaIHM::getUCStringOnStack(ls, 4, mi.Description); CLuaIHM::getUCStringOnStack(ls, 4, mi.Description);
CLuaIHM::getUCStringOnStack(ls, 5, mi.Comment); CLuaIHM::getUCStringOnStack(ls, 5, mi.Comment);
#else
mi.Name = ucstring::makeFromUtf8(ls.toString(3));
mi.Description = ucstring::makeFromUtf8(ls.toString(4));
mi.Comment = ucstring::makeFromUtf8(ls.toString(5));
#endif
getEditor().setPlotItemInfos(mi); getEditor().setPlotItemInfos(mi);
return 0; return 0;
} }
@ -7622,7 +7644,11 @@ class CAHR2Undo : public IActionHandler
getEditor().setCurrentTool(NULL); getEditor().setCurrentTool(NULL);
const ucstring *actionName = historic.getPreviousActionName(); const ucstring *actionName = historic.getPreviousActionName();
nlassert(actionName); nlassert(actionName);
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::push(getEditor().getLua(), *actionName); CLuaIHM::push(getEditor().getLua(), *actionName);
#else
getEditor().getLua().push((*actionName).toUtf8());
#endif
historic.undo(); historic.undo();
getEditor().callEnvMethod("onUndo", 1, 0); getEditor().callEnvMethod("onUndo", 1, 0);
} }
@ -7651,7 +7677,11 @@ class CAHR2Redo : public IActionHandler
getEditor().setCurrentTool(NULL); getEditor().setCurrentTool(NULL);
const ucstring *actionName = historic.getNextActionName(); const ucstring *actionName = historic.getNextActionName();
nlassert(actionName); nlassert(actionName);
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::push(getEditor().getLua(), *actionName); CLuaIHM::push(getEditor().getLua(), *actionName);
#else
getEditor().getLua().push((*actionName).toUtf8());
#endif
historic.redo(); historic.redo();
getEditor().callEnvMethod("onRedo", 1, 0); getEditor().callEnvMethod("onRedo", 1, 0);
} }

@ -120,8 +120,14 @@ ucstring CInstance::getDisplayName()
} }
if (getLuaProjection().callMethodByNameNoThrow("getDisplayName", 0, 1)) if (getLuaProjection().callMethodByNameNoThrow("getDisplayName", 0, 1))
{ {
#ifdef RYZOM_LUA_UCSTRING
ucstring result; ucstring result;
if (CLuaIHM::pop(ls, result)) return result; if (CLuaIHM::pop(ls, result)) return result;
#else
std::string res = ls.toString();
ls.pop();
if (!res.empty()) return res;
#endif
} }
TEST_LUA_PROJ; TEST_LUA_PROJ;
return ucstring("Can't find display name"); return ucstring("Can't find display name");

@ -938,7 +938,11 @@ void CTool::setContextHelp(const ucstring &contextHelp)
// forward the call to lua (all ui handling done bye lua) // forward the call to lua (all ui handling done bye lua)
CLuaState &ls = getEditor().getLua(); CLuaState &ls = getEditor().getLua();
CLuaStackChecker lsc(&ls); CLuaStackChecker lsc(&ls);
#ifdef RYZOM_LUA_UCSTRING
CLuaIHM::push(ls, contextHelp); CLuaIHM::push(ls, contextHelp);
#else
ls.push(contextHelp.toUtf8());
#endif
getEditor().callEnvMethod("setToolContextHelp", 1, 0); getEditor().callEnvMethod("setToolContextHelp", 1, 0);
} }

Loading…
Cancel
Save