oledb32: Implement GetConversionSize DBTYPE_VARIANT->DBTYPE_WSTR

Alistair Leslie-Hughes leslie_alistair at hotmail.com
Mon May 13 05:14:41 CDT 2013


Hi,


Changelog:
     oledb32: Implement GetConversionSize DBTYPE_VARIANT->DBTYPE_WSTR


Best Regards
  Alistair Leslie-Hughes
-------------- next part --------------
>From 1a65101906abdd348b8bc7ae968e64fc28b9ea02 Mon Sep 17 00:00:00 2001
From: Alistair Leslie-Hughes <leslie_alistair at hotmail.com>
Date: Mon, 13 May 2013 12:29:22 +1000
Subject: [PATCH] Implment GetConversionSize DBTYPE_VARIANT->DBTYPE_WSTR
To: wine-patches <wine-patches at winehq.org>

---
 dlls/oledb32/convert.c       | 14 ++++++++++++++
 dlls/oledb32/tests/convert.c | 28 ++++++++++++++++++++++++++++
 2 files changed, 42 insertions(+)

diff --git a/dlls/oledb32/convert.c b/dlls/oledb32/convert.c
index 3d7d23d..65a2bf6 100644
--- a/dlls/oledb32/convert.c
+++ b/dlls/oledb32/convert.c
@@ -1113,6 +1113,20 @@ static HRESULT WINAPI convert_GetConversionSize(IDataConvert* iface,
     {
         switch (src_type)
         {
+        case DBTYPE_VARIANT:
+        {
+            VARIANT v;
+
+            VariantInit(&v);
+            if ((hr = VariantChangeType(&v, (VARIANT*)src, 0, VT_BSTR)) == S_OK)
+            {
+                *dst_len = (SysStringLen(V_BSTR(&v)) + 1) * sizeof(WCHAR);
+                VariantClear(&v);
+            }
+            else
+                return hr;
+        }
+        break;
         case DBTYPE_STR:
             if(src_len)
                 *dst_len = (*src_len + 1) * sizeof(WCHAR);
diff --git a/dlls/oledb32/tests/convert.c b/dlls/oledb32/tests/convert.c
index 7f3e3ee..64562b1 100644
--- a/dlls/oledb32/tests/convert.c
+++ b/dlls/oledb32/tests/convert.c
@@ -2339,6 +2339,7 @@ static void test_getconversionsize(void)
     BSTR str;
     static WCHAR strW[] = {'t','e','s','t',0};
     static char strTest[] = "test";
+    VARIANT var;
 
     /* same way as CanConvert fails here */
     dst_len = 0;
@@ -2394,6 +2395,33 @@ static void test_getconversionsize(void)
     hr = IDataConvert_GetConversionSize(convert, DBTYPE_STR, DBTYPE_WSTR, &src_len, &dst_len, strTest);
     ok(hr == S_OK, "got 0x%08x\n", hr);
     ok(dst_len == 42, "%ld\n", dst_len);
+
+    dst_len = 0;
+    V_VT(&var) = VT_BSTR;
+    V_BSTR(&var) = SysAllocString(strW);
+    hr = IDataConvert_GetConversionSize(convert, DBTYPE_VARIANT, DBTYPE_WSTR, NULL, &dst_len, &var);
+    ok(hr == S_OK, "got 0x%08x\n", hr);
+    ok(dst_len == 10, "%ld\n", dst_len);
+    VariantClear(&var);
+
+    dst_len = 0;
+    src_len = 20;
+    V_VT(&var) = VT_BSTR;
+    V_BSTR(&var) = SysAllocString(strW);
+    hr = IDataConvert_GetConversionSize(convert, DBTYPE_VARIANT, DBTYPE_WSTR, &src_len, &dst_len, &var);
+    ok(hr == S_OK, "got 0x%08x\n", hr);
+    ok(dst_len == 10, "%ld\n", dst_len);
+    VariantClear(&var);
+
+    dst_len = 0;
+    src_len = 20;
+    V_VT(&var) = VT_I4;
+    V_I4(&var) = 4;
+    hr = IDataConvert_GetConversionSize(convert, DBTYPE_VARIANT, DBTYPE_WSTR, &src_len, &dst_len, &var);
+    ok(hr == S_OK, "got 0x%08x\n", hr);
+    todo_wine ok(dst_len == 110, "%ld\n", dst_len);
+    VariantClear(&var);
+
 }
 
 static void test_converttovar(void)
-- 
1.8.1.2



More information about the wine-patches mailing list