Gabriel Ivăncescu : msscript.ocx: Implement ScriptProcedure::get_Name.
Alexandre Julliard
julliard at winehq.org
Thu Aug 13 15:11:51 CDT 2020
Module: wine
Branch: master
Commit: 28228b3914a2f0d084f1eae0fde7857efd6065d7
URL: https://source.winehq.org/git/wine.git/?a=commit;h=28228b3914a2f0d084f1eae0fde7857efd6065d7
Author: Gabriel Ivăncescu <gabrielopcode at gmail.com>
Date: Wed Aug 12 17:13:42 2020 +0300
msscript.ocx: Implement ScriptProcedure::get_Name.
Signed-off-by: Gabriel Ivăncescu <gabrielopcode at gmail.com>
Signed-off-by: Jacek Caban <jacek at codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>
---
dlls/msscript.ocx/msscript.c | 7 +++++--
dlls/msscript.ocx/tests/msscript.c | 22 ++++++++++++++++++++++
2 files changed, 27 insertions(+), 2 deletions(-)
diff --git a/dlls/msscript.ocx/msscript.c b/dlls/msscript.ocx/msscript.c
index ccdbba43c2..173e04ab98 100644
--- a/dlls/msscript.ocx/msscript.c
+++ b/dlls/msscript.ocx/msscript.c
@@ -876,9 +876,12 @@ static HRESULT WINAPI ScriptProcedure_get_Name(IScriptProcedure *iface, BSTR *pb
{
ScriptProcedure *This = impl_from_IScriptProcedure(iface);
- FIXME("(%p)->(%p)\n", This, pbstrName);
+ TRACE("(%p)->(%p)\n", This, pbstrName);
- return E_NOTIMPL;
+ if (!pbstrName) return E_POINTER;
+
+ *pbstrName = SysAllocString(This->name);
+ return *pbstrName ? S_OK : E_OUTOFMEMORY;
}
static HRESULT WINAPI ScriptProcedure_get_NumArgs(IScriptProcedure *iface, LONG *pcArgs)
diff --git a/dlls/msscript.ocx/tests/msscript.c b/dlls/msscript.ocx/tests/msscript.c
index c56e2d52a7..d08f30c074 100644
--- a/dlls/msscript.ocx/tests/msscript.c
+++ b/dlls/msscript.ocx/tests/msscript.c
@@ -3352,6 +3352,12 @@ static void test_IScriptControl_get_Procedures(void)
IScriptProcedureCollection_AddRef(procs);
ok(i == IScriptProcedureCollection_Release(procs),
"IScriptProcedureCollection_get_Item should not have added a ref to the collection.\n");
+ hr = IScriptProcedure_get_Name(proc, NULL);
+ ok(hr == E_POINTER, "IScriptProcedure_get_Name returned: 0x%08x.\n", hr);
+ hr = IScriptProcedure_get_Name(proc, &str);
+ ok(hr == S_OK, "IScriptProcedure_get_Name failed: 0x%08x.\n", hr);
+ ok(!lstrcmpW(str, L"add"), "Wrong name, got %s.\n", wine_dbgstr_w(str));
+ SysFreeString(str);
IScriptProcedure_Release(proc);
V_VT(&var) = VT_BSTR;
@@ -3360,12 +3366,20 @@ static void test_IScriptControl_get_Procedures(void)
ok(hr == S_OK, "IScriptProcedureCollection_get_Item failed: 0x%08x.\n", hr);
ok(V_VT(&var) == VT_BSTR, "var type not BSTR, got %d.\n", V_VT(&var));
VariantClear(&var);
+ hr = IScriptProcedure_get_Name(proc, &str);
+ ok(hr == S_OK, "IScriptProcedure_get_Name failed: 0x%08x.\n", hr);
+ ok(!lstrcmpW(str, L"nop"), "Wrong name, got %s.\n", wine_dbgstr_w(str));
+ SysFreeString(str);
IScriptProcedure_Release(proc);
V_VT(&var) = VT_R8;
V_R8(&var) = 3.0;
hr = IScriptProcedureCollection_get_Item(procs, var, &proc);
ok(hr == S_OK, "IScriptProcedureCollection_get_Item failed: 0x%08x.\n", hr);
+ hr = IScriptProcedure_get_Name(proc, &str);
+ ok(hr == S_OK, "IScriptProcedure_get_Name failed: 0x%08x.\n", hr);
+ ok(!lstrcmpW(str, L"muladd"), "Wrong name, got %s.\n", wine_dbgstr_w(str));
+ SysFreeString(str);
IScriptProcedure_Release(proc);
IScriptProcedureCollection_Release(procs);
@@ -3548,6 +3562,14 @@ static void test_IScriptControl_get_Procedures(void)
CHECK_CALLED(Bind);
CHECK_CALLED(GetNames);
CHECK_CALLED(ReleaseFuncDesc);
+
+ /* Verify the properties */
+ hr = IScriptProcedure_get_Name(proc, &str);
+ ok(hr == S_OK, "get_Name for %s failed: 0x%08x.\n", wine_dbgstr_w(custom_engine_funcs[i].name), hr);
+ ok(!lstrcmpW(str, custom_engine_funcs[i].name), "Name is not %s, got %s.\n",
+ wine_dbgstr_w(custom_engine_funcs[i].name), wine_dbgstr_w(str));
+ SysFreeString(str);
+
IScriptProcedure_Release(proc);
}
More information about the wine-cvs
mailing list