Alistair Leslie-Hughes : oledb32: Add DBTYPE_UI2 support to DataConvert.
Alexandre Julliard
julliard at winehq.org
Thu Jul 7 13:33:47 CDT 2011
Module: wine
Branch: master
Commit: d911374b9c009a389c19d1d618c21db6e3a99abc
URL: http://source.winehq.org/git/wine.git/?a=commit;h=d911374b9c009a389c19d1d618c21db6e3a99abc
Author: Alistair Leslie-Hughes <leslie_alistair at hotmail.com>
Date: Tue Jun 28 20:41:04 2011 +1000
oledb32: Add DBTYPE_UI2 support to DataConvert.
---
dlls/oledb32/convert.c | 25 ++++++++++++++++++++++++
dlls/oledb32/tests/convert.c | 43 ++++++++++++++++++++++++++++++++++++++++++
2 files changed, 68 insertions(+), 0 deletions(-)
diff --git a/dlls/oledb32/convert.c b/dlls/oledb32/convert.c
index 3bb663f..1691792 100644
--- a/dlls/oledb32/convert.c
+++ b/dlls/oledb32/convert.c
@@ -533,6 +533,31 @@ static HRESULT WINAPI convert_DataConvert(IDataConvert* iface,
}
break;
}
+ case DBTYPE_UI2:
+ {
+ WORD *d = dst;
+ switch(src_type)
+ {
+ case DBTYPE_EMPTY: *d = 0; hr = S_OK; break;
+ case DBTYPE_I2: hr = VarUI2FromI2(*(signed short*)src, d); break;
+ case DBTYPE_I4: hr = VarUI2FromI4(*(signed int*)src, d); break;
+ case DBTYPE_R4: hr = VarUI2FromR4(*(FLOAT*)src, d); break;
+ case DBTYPE_R8: hr = VarUI2FromR8(*(double*)src, d); break;
+ case DBTYPE_CY: hr = VarUI2FromCy(*(CY*)src, d); break;
+ case DBTYPE_DATE: hr = VarUI2FromDate(*(DATE*)src, d); break;
+ case DBTYPE_BSTR: hr = VarUI2FromStr(*(WCHAR**)src, LOCALE_USER_DEFAULT, 0, d); break;
+ case DBTYPE_BOOL: hr = VarUI2FromBool(*(VARIANT_BOOL*)src, d); break;
+ case DBTYPE_DECIMAL: hr = VarUI2FromDec((DECIMAL*)src, d); break;
+ case DBTYPE_I1: hr = VarUI2FromI1(*(signed char*)src, d); break;
+ case DBTYPE_UI1: hr = VarUI2FromUI1(*(BYTE*)src, d); break;
+ case DBTYPE_UI2: *d = *(WORD*)src; hr = S_OK; break;
+ case DBTYPE_UI4: hr = VarUI2FromUI4(*(DWORD*)src, d); break;
+ case DBTYPE_I8: hr = VarUI2FromI8(*(LONGLONG*)src, d); break;
+ case DBTYPE_UI8: hr = VarUI2FromUI8(*(ULONGLONG*)src, d); break;
+ default: FIXME("Unimplemented conversion %04x -> UI2\n", src_type); return E_NOTIMPL;
+ }
+ break;
+ }
case DBTYPE_UI4:
{
diff --git a/dlls/oledb32/tests/convert.c b/dlls/oledb32/tests/convert.c
index a5ccdb9..1a1ea9a 100644
--- a/dlls/oledb32/tests/convert.c
+++ b/dlls/oledb32/tests/convert.c
@@ -610,6 +610,49 @@ todo_wine
ok(dst_len == sizeof(dst), "got %ld\n", dst_len);
ok(dst == 10, "got %08x\n", dst);
+ /* */
+ dst_len = dst = 0x1234;
+ *(WORD*)src = 0x4321;
+ hr = IDataConvert_DataConvert(convert, DBTYPE_UI2, DBTYPE_UI2, 0, &dst_len, 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(dst), "got %ld\n", dst_len);
+ ok(dst == 0x4321, "got %08x\n", dst);
+
+ dst_len = dst = 0x1234;
+ *(DWORD*)src = 0xabcd1234;
+ hr = IDataConvert_DataConvert(convert, DBTYPE_UI4, DBTYPE_UI2, 0, &dst_len, src, &dst, sizeof(dst), 0, &dst_status, 0, 0, 0);
+todo_wine
+ ok(hr == DB_E_DATAOVERFLOW, "got %08x\n", hr);
+ ok(dst_status == DBSTATUS_E_DATAOVERFLOW, "got %08x\n", dst_status);
+ ok(dst_len == sizeof(dst), "got %ld\n", dst_len);
+ ok(dst == 0x1234, "got %08x\n", dst);
+
+ dst_len = dst = 0x1234;
+ *(DWORD*)src = 0x1234abcd;
+ hr = IDataConvert_DataConvert(convert, DBTYPE_UI4, DBTYPE_UI2, 0, &dst_len, src, &dst, sizeof(dst), 0, &dst_status, 0, 0, 0);
+todo_wine
+ ok(hr == DB_E_DATAOVERFLOW, "got %08x\n", hr);
+ ok(dst_status == DBSTATUS_E_DATAOVERFLOW, "got %08x\n", dst_status);
+ ok(dst_len == sizeof(dst), "got %ld\n", dst_len);
+ ok(dst == 0x1234, "got %08x\n", dst);
+
+ dst_len = dst = 0x1234;
+ *(DWORD*)src = 0x4321;
+ hr = IDataConvert_DataConvert(convert, DBTYPE_UI4, DBTYPE_UI2, 0, &dst_len, 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(dst), "got %ld\n", dst_len);
+ ok(dst == 0x4321, "got %08x\n", dst);
+
+ dst_len = dst = 0x1234;
+ memcpy(src, ten, sizeof(ten));
+ hr = IDataConvert_DataConvert(convert, DBTYPE_WSTR, DBTYPE_UI2, 0, &dst_len, src, &dst, sizeof(dst), 0, &dst_status, 0, 0, DBDATACONVERT_LENGTHFROMNTS);
+ ok(hr == S_OK, "got %08x\n", hr);
+ ok(dst_status == DBSTATUS_S_OK, "got %08x\n", dst_status);
+ ok(dst_len == sizeof(dst), "got %ld\n", dst_len);
+ ok(dst == 10, "got %08x\n", dst);
+
IDataConvert_Release(convert);
}
More information about the wine-cvs
mailing list