[PATCH] mlang: Implement IMultiLanguage_GetNumberOfCodePageInfo, with test
Detlef Riekenberg
wine.dev at web.de
Thu Jun 18 15:52:56 CDT 2009
---
dlls/mlang/mlang.c | 12 +++++++++---
dlls/mlang/tests/mlang.c | 36 +++++++++++++++++++++++++++++++++---
2 files changed, 42 insertions(+), 6 deletions(-)
diff --git a/dlls/mlang/mlang.c b/dlls/mlang/mlang.c
index 4d3c2e5..d762bac 100644
--- a/dlls/mlang/mlang.c
+++ b/dlls/mlang/mlang.c
@@ -2141,8 +2141,14 @@ static HRESULT WINAPI fnIMultiLanguage_GetNumberOfCodePageInfo(
IMultiLanguage* iface,
UINT* pcCodePage)
{
- FIXME("\n");
- return E_NOTIMPL;
+ MLang_impl *This = impl_from_IMultiLanguage( iface );
+
+ TRACE("(%p, %p)\n", This, pcCodePage);
+
+ if (!pcCodePage) return E_INVALIDARG;
+
+ *pcCodePage = This->total_cp;
+ return S_OK;
}
static HRESULT WINAPI fnIMultiLanguage_GetCodePageInfo(
@@ -2640,7 +2646,7 @@ static HRESULT WINAPI fnIMultiLanguage2_GetNumberOfCodePageInfo(
TRACE("%p, %p\n", This, pcCodePage);
- if (!pcCodePage) return S_FALSE;
+ if (!pcCodePage) return E_INVALIDARG;
*pcCodePage = This->total_cp;
return S_OK;
diff --git a/dlls/mlang/tests/mlang.c b/dlls/mlang/tests/mlang.c
index 1f317f4..d4e3941 100644
--- a/dlls/mlang/tests/mlang.c
+++ b/dlls/mlang/tests/mlang.c
@@ -1158,6 +1158,20 @@ static void test_Rfc1766ToLcid(void)
}
+static void test_GetNumberOfCodePageInfo(IMultiLanguage2 *iML2)
+{
+ HRESULT hr;
+ UINT value;
+
+ value = 0xdeadbeef;
+ hr = IMultiLanguage2_GetNumberOfCodePageInfo(iML2, &value);
+ ok( (hr == S_OK) && value,
+ "got 0x%x with %d (expected S_OK with '!= 0')\n", hr, value);
+
+ hr = IMultiLanguage2_GetNumberOfCodePageInfo(iML2, NULL);
+ ok(hr == E_INVALIDARG, "got 0x%x (expected E_INVALIDARG)\n", hr);
+
+}
static void test_GetRfc1766FromLcid(IMultiLanguage2 *iML2)
{
@@ -1858,6 +1872,7 @@ static void test_GetScriptFontInfo(IMLangFontLink2 *font_link)
START_TEST(mlang)
{
+ IMultiLanguage *iML = NULL;
IMultiLanguage2 *iML2 = NULL;
IMLangFontLink *iMLFL = NULL;
IMLangFontLink2 *iMLFL2 = NULL;
@@ -1870,6 +1885,21 @@ START_TEST(mlang)
test_Rfc1766ToLcid();
test_LcidToRfc1766();
+ test_ConvertINetUnicodeToMultiByte();
+ test_JapaneseConversion();
+
+
+ trace("IMultiLanguage\n");
+ ret = CoCreateInstance(&CLSID_CMultiLanguage, NULL, CLSCTX_INPROC_SERVER,
+ &IID_IMultiLanguage, (void **)&iML);
+ if (ret != S_OK || !iML) return;
+
+ test_GetNumberOfCodePageInfo((IMultiLanguage2 *)iML);
+ IMultiLanguage_Release(iML);
+
+
+ /* IMultiLanguage2 (IE5.0 and above) */
+ trace("IMultiLanguage2\n");
ret = CoCreateInstance(&CLSID_CMultiLanguage, NULL, CLSCTX_INPROC_SERVER,
&IID_IMultiLanguage2, (void **)&iML2);
if (ret != S_OK || !iML2) return;
@@ -1878,6 +1908,7 @@ START_TEST(mlang)
test_GetLcidFromRfc1766(iML2);
test_GetRfc1766FromLcid(iML2);
test_GetRfc1766Info(iML2);
+ test_GetNumberOfCodePageInfo(iML2);
test_EnumCodePages(iML2, 0);
test_EnumCodePages(iML2, MIMECONTF_MIME_LATEST);
@@ -1901,10 +1932,8 @@ START_TEST(mlang)
IMultiLanguage2_Release(iML2);
- test_ConvertINetUnicodeToMultiByte();
-
- test_JapaneseConversion();
+ /* IMLangFontLink */
ret = CoCreateInstance(&CLSID_CMultiLanguage, NULL, CLSCTX_INPROC_SERVER,
&IID_IMLangFontLink, (void **)&iMLFL);
if (ret != S_OK || !iMLFL) return;
@@ -1912,6 +1941,7 @@ START_TEST(mlang)
IMLangFontLink_Test(iMLFL);
IMLangFontLink_Release(iMLFL);
+ /* IMLangFontLink2 */
ret = CoCreateInstance(&CLSID_CMultiLanguage, NULL, CLSCTX_INPROC_SERVER,
&IID_IMLangFontLink2, (void **)&iMLFL2);
if (ret != S_OK || !iMLFL2) return;
--
1.5.4.3
--=-CRzLg4sXjz8NTHeNZLF/--
More information about the wine-patches
mailing list