Roy Shea : mstask: Implement (Set|Get)Parameters.
Alexandre Julliard
julliard at winehq.org
Fri Aug 22 04:43:59 CDT 2008
Module: wine
Branch: master
Commit: 2f95e5123be7b967d261a75a69ca27f7cfe03970
URL: http://source.winehq.org/git/wine.git/?a=commit;h=2f95e5123be7b967d261a75a69ca27f7cfe03970
Author: Roy Shea <royshea at gmail.com>
Date: Thu Aug 21 13:05:07 2008 -0700
mstask: Implement (Set|Get)Parameters.
---
dlls/mstask/mstask_private.h | 1 +
dlls/mstask/task.c | 45 ++++++++++++++++++++++++++++++++++++++---
dlls/mstask/tests/task.c | 22 ++++++++++----------
3 files changed, 53 insertions(+), 15 deletions(-)
diff --git a/dlls/mstask/mstask_private.h b/dlls/mstask/mstask_private.h
index b0892fe..8920707 100644
--- a/dlls/mstask/mstask_private.h
+++ b/dlls/mstask/mstask_private.h
@@ -59,6 +59,7 @@ typedef struct
LONG ref;
LPWSTR taskName;
LPWSTR applicationName;
+ LPWSTR parameters;
} TaskImpl;
extern HRESULT TaskConstructor(LPCWSTR pwszTaskName, LPVOID *ppObj);
diff --git a/dlls/mstask/task.c b/dlls/mstask/task.c
index 5cef29f..235c5fc 100644
--- a/dlls/mstask/task.c
+++ b/dlls/mstask/task.c
@@ -29,6 +29,7 @@ static inline TaskImpl *impl_from_IPersistFile( IPersistFile *iface )
static void TaskDestructor(TaskImpl *This)
{
TRACE("%p\n", This);
+ HeapFree(GetProcessHeap(), 0, This->parameters);
HeapFree(GetProcessHeap(), 0, This->taskName);
HeapFree(GetProcessHeap(), 0, This);
InterlockedDecrement(&dll_ref);
@@ -403,16 +404,51 @@ static HRESULT WINAPI MSTASK_ITask_SetParameters(
ITask* iface,
LPCWSTR pwszParameters)
{
- FIXME("(%p, %s): stub\n", iface, debugstr_w(pwszParameters));
- return E_NOTIMPL;
+ DWORD n;
+ TaskImpl *This = (TaskImpl *)iface;
+ LPWSTR tmp_parameters;
+
+ TRACE("(%p, %s)\n", iface, debugstr_w(pwszParameters));
+
+ /* Empty parameter list */
+ if (pwszParameters[0] == 0)
+ {
+ HeapFree(GetProcessHeap(), 0, This->parameters);
+ This->parameters = NULL;
+ return S_OK;
+ }
+
+ /* Set to pwszParameters */
+ n = (lstrlenW(pwszParameters) + 1);
+ tmp_parameters = HeapAlloc(GetProcessHeap(), 0, n * sizeof(WCHAR));
+ if (!tmp_parameters)
+ return E_OUTOFMEMORY;
+ lstrcpyW(tmp_parameters, pwszParameters);
+ HeapFree(GetProcessHeap(), 0, This->parameters);
+ This->parameters = tmp_parameters;
+ return S_OK;
}
static HRESULT WINAPI MSTASK_ITask_GetParameters(
ITask* iface,
LPWSTR *ppwszParameters)
{
- FIXME("(%p, %p): stub\n", iface, ppwszParameters);
- return E_NOTIMPL;
+ DWORD n;
+ TaskImpl *This = (TaskImpl *)iface;
+
+ TRACE("(%p, %p)\n", iface, ppwszParameters);
+
+ n = This->parameters ? lstrlenW(This->parameters) + 1 : 1;
+ *ppwszParameters = CoTaskMemAlloc(n * sizeof(WCHAR));
+ if (!*ppwszParameters)
+ return E_OUTOFMEMORY;
+
+ if (!This->parameters)
+ *ppwszParameters[0] = 0;
+ else
+ lstrcpyW(*ppwszParameters, This->parameters);
+
+ return S_OK;
}
static HRESULT WINAPI MSTASK_ITask_SetWorkingDirectory(
@@ -645,6 +681,7 @@ HRESULT TaskConstructor(LPCWSTR pwszTaskName, LPVOID *ppObj)
}
lstrcpyW(This->taskName, pwszTaskName);
This->applicationName = NULL;
+ This->parameters = NULL;
*ppObj = &This->lpVtbl;
InterlockedIncrement(&dll_ref);
diff --git a/dlls/mstask/tests/task.c b/dlls/mstask/tests/task.c
index ff35f52..7d1b44d 100644
--- a/dlls/mstask/tests/task.c
+++ b/dlls/mstask/tests/task.c
@@ -249,49 +249,49 @@ static void test_SetParameters_GetParameters(void)
/* Get parameters before setting them */
hres = ITask_GetParameters(test_task, ¶meters);
- todo_wine ok(hres == S_OK, "GetParameters failed: %08x\n", hres);
+ ok(hres == S_OK, "GetParameters failed: %08x\n", hres);
if (hres == S_OK)
{
- todo_wine ok(!lstrcmpW(parameters, empty),
+ ok(!lstrcmpW(parameters, empty),
"Got %s, expected empty string\n", dbgstr_w(parameters));
CoTaskMemFree(parameters);
}
/* Set parameters to a simple string */
hres = ITask_SetParameters(test_task, parameters_a);
- todo_wine ok(hres == S_OK, "Failed setting parameters %s: %08x\n",
+ ok(hres == S_OK, "Failed setting parameters %s: %08x\n",
dbgstr_w(parameters_a), hres);
hres = ITask_GetParameters(test_task, ¶meters);
- todo_wine ok(hres == S_OK, "GetParameters failed: %08x\n", hres);
+ ok(hres == S_OK, "GetParameters failed: %08x\n", hres);
if (hres == S_OK)
{
- todo_wine ok(!lstrcmpW(parameters, parameters_a), "Got %s, expected %s\n",
+ ok(!lstrcmpW(parameters, parameters_a), "Got %s, expected %s\n",
dbgstr_w(parameters), dbgstr_w(parameters_a));
CoTaskMemFree(parameters);
}
/* Update parameters to a different simple string */
hres = ITask_SetParameters(test_task, parameters_b);
- todo_wine ok(hres == S_OK, "Failed setting parameters %s: %08x\n",
+ ok(hres == S_OK, "Failed setting parameters %s: %08x\n",
dbgstr_w(parameters_b), hres);
hres = ITask_GetParameters(test_task, ¶meters);
- todo_wine ok(hres == S_OK, "GetParameters failed: %08x\n", hres);
+ ok(hres == S_OK, "GetParameters failed: %08x\n", hres);
if (hres == S_OK)
{
- todo_wine ok(!lstrcmpW(parameters, parameters_b), "Got %s, expected %s\n",
+ ok(!lstrcmpW(parameters, parameters_b), "Got %s, expected %s\n",
dbgstr_w(parameters), dbgstr_w(parameters_b));
CoTaskMemFree(parameters);
}
/* Clear parameters */
hres = ITask_SetParameters(test_task, empty);
- todo_wine ok(hres == S_OK, "Failed setting parameters %s: %08x\n",
+ ok(hres == S_OK, "Failed setting parameters %s: %08x\n",
dbgstr_w(empty), hres);
hres = ITask_GetParameters(test_task, ¶meters);
- todo_wine ok(hres == S_OK, "GetParameters failed: %08x\n", hres);
+ ok(hres == S_OK, "GetParameters failed: %08x\n", hres);
if (hres == S_OK)
{
- todo_wine ok(!lstrcmpW(parameters, empty),
+ ok(!lstrcmpW(parameters, empty),
"Got %s, expected empty string\n", dbgstr_w(parameters));
CoTaskMemFree(parameters);
}
More information about the wine-cvs
mailing list