Piotr Caban : vbscript: Add UBound implementation.

Alexandre Julliard julliard at winehq.org
Tue Nov 7 15:30:20 CST 2017


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

Author: Piotr Caban <piotr at codeweavers.com>
Date:   Mon Nov  6 16:53:08 2017 +0100

vbscript: Add UBound implementation.

Signed-off-by: Piotr Caban <piotr at codeweavers.com>
Signed-off-by: Jacek Caban <jacek at codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>

---

 dlls/vbscript/global.c      | 38 +++++++++++++++++++++++++++++++++++---
 dlls/vbscript/tests/api.vbs | 10 ++++++++++
 2 files changed, 45 insertions(+), 3 deletions(-)

diff --git a/dlls/vbscript/global.c b/dlls/vbscript/global.c
index f523820..a5df54a 100644
--- a/dlls/vbscript/global.c
+++ b/dlls/vbscript/global.c
@@ -822,8 +822,40 @@ static HRESULT Global_LBound(vbdisp_t *This, VARIANT *arg, unsigned args_cnt, VA
 
 static HRESULT Global_UBound(vbdisp_t *This, VARIANT *arg, unsigned args_cnt, VARIANT *res)
 {
-    FIXME("\n");
-    return E_NOTIMPL;
+    SAFEARRAY *sa;
+    HRESULT hres;
+    LONG ubound;
+    int dim;
+
+    assert(args_cnt == 1 || args_cnt == 2);
+
+    TRACE("%s %s\n", debugstr_variant(arg), args_cnt == 2 ? debugstr_variant(arg + 1) : "1");
+
+    switch(V_VT(arg)) {
+    case VT_VARIANT|VT_ARRAY:
+        sa = V_ARRAY(arg);
+        break;
+    case VT_VARIANT|VT_ARRAY|VT_BYREF:
+        sa = *V_ARRAYREF(arg);
+        break;
+    default:
+        FIXME("arg %s not supported\n", debugstr_variant(arg));
+        return E_NOTIMPL;
+    }
+
+    if(args_cnt == 2) {
+        hres = to_int(arg + 1, &dim);
+        if(FAILED(hres))
+            return hres;
+    }else {
+        dim = 1;
+    }
+
+    hres = SafeArrayGetUBound(sa, dim, &ubound);
+    if(FAILED(hres))
+        return hres;
+
+    return return_int(res, ubound);
 }
 
 static HRESULT Global_RGB(vbdisp_t *This, VARIANT *arg, unsigned args_cnt, VARIANT *res)
@@ -2256,7 +2288,7 @@ static const builtin_prop_t global_props[] = {
     {DISPID_GLOBAL_RND,                       Global_Rnd, 0, 1},
     {DISPID_GLOBAL_TIMER,                     Global_Timer, 0, 0},
     {DISPID_GLOBAL_LBOUND,                    Global_LBound, 0, 1},
-    {DISPID_GLOBAL_UBOUND,                    Global_UBound, 0, 1},
+    {DISPID_GLOBAL_UBOUND,                    Global_UBound, 0, 1, 2},
     {DISPID_GLOBAL_RGB,                       Global_RGB, 0, 3},
     {DISPID_GLOBAL_LEN,                       Global_Len, 0, 1},
     {DISPID_GLOBAL_LENB,                      Global_LenB, 0, 1},
diff --git a/dlls/vbscript/tests/api.vbs b/dlls/vbscript/tests/api.vbs
index baa0553..8ebbfb6 100644
--- a/dlls/vbscript/tests/api.vbs
+++ b/dlls/vbscript/tests/api.vbs
@@ -227,6 +227,16 @@ new_array = x
 x(0) = "new value"
 Call ok(new_array(0) = "a1", "new_array(0) = " & new_array(0))
 
+Call ok(getVT(UBound(x)) = "VT_I4", "getVT(UBound(x)) = " & getVT(UBound(x)))
+Call ok(UBound(x) = 2, "UBound(x) = " & UBound(x))
+Call ok(getVT(UBound(x, 1)) = "VT_I4", "getVT(UBound(x, 1)) = " & getVT(UBound(x, 1)))
+Call ok(UBound(x, 1) = 2, "UBound(x) = " & UBound(x, 1))
+
+Dim arr2(2, 4)
+Call ok(UBound(arr2) = 2, "UBound(x) = " & UBound(x))
+Call ok(UBound(arr2, 1) = 2, "UBound(x) = " & UBound(x))
+Call ok(UBound(arr2, 2) = 4, "UBound(x) = " & UBound(x))
+
 Dim newObject
 Set newObject = New ValClass
 newObject.myval = 1




More information about the wine-cvs mailing list