Piotr Caban : jscript: Make do_attribute_tag_format generic.

Alexandre Julliard julliard at winehq.org
Mon Jul 13 07:56:30 CDT 2009


Module: wine
Branch: master
Commit: 16b38c457d569c7202ec558b75981c1eff485012
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=16b38c457d569c7202ec558b75981c1eff485012

Author: Piotr Caban <piotr.caban at gmail.com>
Date:   Sun Jul 12 22:05:00 2009 +0200

jscript: Make do_attribute_tag_format generic.

---

 dlls/jscript/string.c |   38 +++++++++++++++++++++++++++++---------
 1 files changed, 29 insertions(+), 9 deletions(-)

diff --git a/dlls/jscript/string.c b/dlls/jscript/string.c
index 56048fb..4c58eff 100644
--- a/dlls/jscript/string.c
+++ b/dlls/jscript/string.c
@@ -177,43 +177,63 @@ static HRESULT do_attribute_tag_format(DispatchEx *dispex, LCID lcid, WORD flags
         = {'<','%','s',' ','%','s','=','\"','%','s','\"','>','%','s','<','/','%','s','>',0};
     static const WCHAR undefinedW[] = {'u','n','d','e','f','i','n','e','d',0};
 
-    StringInstance *string;
-    BSTR ret, attr_value;
+    const WCHAR *str;
+    DWORD length;
+    BSTR attr_value, val_str = NULL;
     HRESULT hres;
 
     if(!is_class(dispex, JSCLASS_STRING)) {
-        WARN("this is not a string object\n");
-        return E_NOTIMPL;
+        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;
 
-    string = (StringInstance*) dispex;
+        str = this->str;
+        length = this->length;
+    }
 
     if(arg_cnt(dp)) {
         hres = to_string(dispex->ctx, get_arg(dp, 0), ei, &attr_value);
-        if(FAILED(hres))
+        if(FAILED(hres)) {
+            SysFreeString(val_str);
             return hres;
+        }
     }
     else {
         attr_value = SysAllocString(undefinedW);
-        if(!attr_value)
+        if(!attr_value) {
+            SysFreeString(val_str);
             return E_OUTOFMEMORY;
+        }
     }
 
     if(retv) {
-        ret = SysAllocStringLen(NULL, string->length + 2*strlenW(tagname)
+        BSTR ret = SysAllocStringLen(NULL, length + 2*strlenW(tagname)
                 + strlenW(attr) + SysStringLen(attr_value) + 9);
         if(!ret) {
             SysFreeString(attr_value);
+            SysFreeString(val_str);
             return E_OUTOFMEMORY;
         }
 
-        sprintfW(ret, tagfmtW, tagname, attr, attr_value, string->str, tagname);
+        sprintfW(ret, tagfmtW, tagname, attr, attr_value, str, tagname);
 
         V_VT(retv) = VT_BSTR;
         V_BSTR(retv) = ret;
     }
 
     SysFreeString(attr_value);
+    SysFreeString(val_str);
     return S_OK;
 }
 




More information about the wine-cvs mailing list