oledb32: Implement DataConvert DBTYPE_BYTES->DBTYPE_BYTES
Alistair Leslie-Hughes
leslie_alistair at hotmail.com
Tue May 14 05:12:06 CDT 2013
Hi,
Changelog:
oledb32: Implement DataConvert DBTYPE_BYTES->DBTYPE_BYTES
Best Regards
Alistair Leslie-Hughes
-------------- next part --------------
>From ad54fdd30ee1bc76a11c27eac906e9c5b0add836 Mon Sep 17 00:00:00 2001
From: Alistair Leslie-Hughes <leslie_alistair at hotmail.com>
Date: Thu, 18 Apr 2013 11:22:47 +1000
Subject: [PATCH] Implement DataConvert DBTYPE_BYTES->DBTYPE_BYTES
To: wine-patches <wine-patches at winehq.org>
---
dlls/oledb32/convert.c | 21 +++++++++++++++++++++
dlls/oledb32/tests/convert.c | 24 ++++++++++++++++++++++++
2 files changed, 45 insertions(+)
diff --git a/dlls/oledb32/convert.c b/dlls/oledb32/convert.c
index 65a2bf6..05a24a3 100644
--- a/dlls/oledb32/convert.c
+++ b/dlls/oledb32/convert.c
@@ -794,6 +794,27 @@ static HRESULT WINAPI convert_DataConvert(IDataConvert* iface,
}
break;
}
+ case DBTYPE_BYTES:
+ {
+ BYTE *d = dst;
+
+ switch(src_type)
+ {
+ case DBTYPE_BYTES:
+ if( src_len > dst_max_len)
+ *dst_status = DBSTATUS_S_TRUNCATED;
+ else
+ *dst_status = DBSTATUS_S_OK;
+
+ *dst_len = src_len;
+ memcpy(d, src, min(src_len, dst_max_len));
+
+ return S_OK;
+ break;
+ default: FIXME("Unimplemented conversion %04x -> DBTYPE_BYTES\n", src_type); return E_NOTIMPL;
+ }
+ break;
+ }
default:
FIXME("Unimplemented conversion %04x -> %04x\n", src_type, dst_type);
diff --git a/dlls/oledb32/tests/convert.c b/dlls/oledb32/tests/convert.c
index 64562b1..b4331b1 100644
--- a/dlls/oledb32/tests/convert.c
+++ b/dlls/oledb32/tests/convert.c
@@ -2424,6 +2424,29 @@ static void test_getconversionsize(void)
}
+static void test_converttobytes(void)
+{
+ DBLENGTH dst_len;
+ HRESULT hr;
+ BYTE byte_src[] = {0, 1, 2, 4, 5};
+ BYTE dst[10] = {0};
+ DBSTATUS dst_status;
+
+ dst_len = 0;
+ hr = IDataConvert_DataConvert(convert, DBTYPE_BYTES, DBTYPE_BYTES, sizeof(byte_src), &dst_len, byte_src, &dst, sizeof(dst), 0, &dst_status, 0, 0, 0);
+ ok(hr == S_OK, "got %08x\n", hr);
+ ok(dst_status == DBSTATUS_S_OK, "got %08x\n", dst_status);
+ ok(dst_len == sizeof(byte_src), "got %ld\n", dst_len);
+ ok(!memcmp(byte_src, dst, dst_len ), "bytes differ\n");
+
+ dst_len = 0;
+ hr = IDataConvert_DataConvert(convert, DBTYPE_BYTES, DBTYPE_BYTES, sizeof(byte_src), &dst_len, byte_src, &dst, 2, 0, &dst_status, 0, 0, 0);
+ ok(hr == S_OK, "got %08x\n", hr);
+ ok(dst_status == DBSTATUS_S_TRUNCATED, "got %08x\n", dst_status);
+ ok(dst_len == sizeof(byte_src), "got %ld\n", dst_len);
+ ok(!memcmp(byte_src, dst, 2 ), "bytes differ\n");
+}
+
static void test_converttovar(void)
{
static WCHAR strW[] = {'t','e','s','t',0};
@@ -2559,6 +2582,7 @@ START_TEST(convert)
test_converttocy();
test_converttoui8();
test_converttovar();
+ test_converttobytes();
test_getconversionsize();
IDataConvert_Release(convert);
--
1.8.1.2
More information about the wine-patches
mailing list