Module: wine Branch: master Commit: 0fae85fc63d0bdee5435a3ff03fefc50eafaea3e URL: http://source.winehq.org/git/wine.git/?a=commit;h=0fae85fc63d0bdee5435a3ff03...
Author: Piotr Caban piotr.caban@gmail.com Date: Sun Jul 12 19:50:50 2009 +0200
jscript: Make String_charAt generic.
---
dlls/jscript/string.c | 46 +++++++++++++++++++++++++++++++++------------- 1 files changed, 33 insertions(+), 13 deletions(-)
diff --git a/dlls/jscript/string.c b/dlls/jscript/string.c index 4c58eff..4c83d68 100644 --- a/dlls/jscript/string.c +++ b/dlls/jscript/string.c @@ -271,26 +271,42 @@ static HRESULT String_bold(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS static HRESULT String_charAt(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp, VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp) { - StringInstance *strobj; - BSTR str; + const WCHAR *str; + DWORD length; + BSTR ret, val_str = NULL; INT pos = 0; HRESULT hres;
TRACE("\n");
- if(dispex->builtin_info->class != JSCLASS_STRING) { - FIXME("not string this not supported\n"); - return E_NOTIMPL; + if(!is_class(dispex, JSCLASS_STRING)) { + VARIANT this; + + V_VT(&this) = VT_DISPATCH; + V_DISPATCH(&this) = (IDispatch*)_IDispatchEx_(dispex); + + hres = to_string(dispex->ctx, &this, ei, &val_str); + if(FAILED(hres)) + return hres; + + str = val_str; + length = SysStringLen(val_str); } + else { + StringInstance *this = (StringInstance*)dispex;
- strobj = (StringInstance*)dispex; + str = this->str; + length = this->length; + }
if(arg_cnt(dp)) { VARIANT num;
hres = to_integer(dispex->ctx, get_arg(dp, 0), ei, &num); - if(FAILED(hres)) + if(FAILED(hres)) { + SysFreeString(val_str); return hres; + }
if(V_VT(&num) == VT_I4) { pos = V_I4(&num); @@ -300,18 +316,22 @@ static HRESULT String_charAt(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARA } }
- if(!retv) + if(!retv) { + SysFreeString(val_str); return S_OK; + }
- if(0 <= pos && pos < strobj->length) - str = SysAllocStringLen(strobj->str+pos, 1); + if(0 <= pos && pos < length) + ret = SysAllocStringLen(str+pos, 1); else - str = SysAllocStringLen(NULL, 0); - if(!str) + ret = SysAllocStringLen(NULL, 0); + SysFreeString(val_str); + if(!ret) { return E_OUTOFMEMORY; + }
V_VT(retv) = VT_BSTR; - V_BSTR(retv) = str; + V_BSTR(retv) = ret; return S_OK; }