* Sync to Wine 1.3.37.
svn path=/trunk/; revision=55257
WINE_DEFAULT_DEBUG_CHANNEL(mstask);
+struct ClassFactoryImpl
+{
+ IClassFactory IClassFactory_iface;
+ LONG ref;
+};
+
+static inline ClassFactoryImpl *impl_from_IClassFactory(IClassFactory *iface)
+{
+ return CONTAINING_RECORD(iface, ClassFactoryImpl, IClassFactory_iface);
+}
+
static HRESULT WINAPI MSTASK_IClassFactory_QueryInterface(
LPCLASSFACTORY iface,
REFIID riid,
LPVOID *ppvObj)
{
- ClassFactoryImpl *This = (ClassFactoryImpl *)iface;
+ ClassFactoryImpl *This = impl_from_IClassFactory(iface);
TRACE("IID: %s\n",debugstr_guid(riid));
if (ppvObj == NULL)
if (IsEqualGUID(riid, &IID_IUnknown) ||
IsEqualGUID(riid, &IID_IClassFactory))
{
- *ppvObj = &This->lpVtbl;
+ *ppvObj = &This->IClassFactory_iface;
IClassFactory_AddRef(iface);
return S_OK;
}
MSTASK_IClassFactory_LockServer
};
-ClassFactoryImpl MSTASK_ClassFactory = { &IClassFactory_Vtbl };
+ClassFactoryImpl MSTASK_ClassFactory = { { &IClassFactory_Vtbl } };
+++ /dev/null
-[version]
-Signature="$CHICAGO$"
-
-[RegisterDll]
-AddReg=Classes.Reg
-
-[UnregisterDll]
-DelReg=Classes.Reg
-
-[Classes.Reg]
-HKCR,"CLSID\%CLSID_CTaskScheduler%",,,"CTaskScheduler"
-HKCR,"CLSID\%CLSID_CTaskScheduler%\InProcServer32",,,"mstask.dll"
-HKCR,"CLSID\%CLSID_CTaskScheduler%\InProcServer32","ThreadingModel",,"Both"
-HKCR,"CLSID\%CLSID_CTask%",,,"CTask"
-HKCR,"CLSID\%CLSID_CTask%\InProcServer32",,,"mstask.dll"
-HKCR,"CLSID\%CLSID_CTask%\InProcServer32","ThreadingModel",,"Both"
--- /dev/null
+HKCR
+{
+ NoRemove Interface
+ {
+ }
+ NoRemove CLSID
+ {
+ '{148BD52A-A2AB-11CE-B11F-00AA00530503}' = s 'CTaskScheduler'
+ {
+ InprocServer32 = s '%MODULE%' { val ThreadingModel = s 'Both' }
+ }
+ '{148BD520-A2AB-11CE-B11F-00AA00530503}' = s 'CTask'
+ {
+ InprocServer32 = s '%MODULE%' { val ThreadingModel = s 'Both' }
+ }
+ }
+}
#include <stdio.h>
#include "mstask_private.h"
-#include "winreg.h"
-#include "advpub.h"
+#include "objbase.h"
+#include "rpcproxy.h"
#include "wine/debug.h"
return dll_ref != 0 ? S_FALSE : S_OK;
}
-static inline char *mstask_strdup(const char *s)
-{
- size_t n = strlen(s) + 1;
- char *d = HeapAlloc(GetProcessHeap(), 0, n);
- return d ? memcpy(d, s, n) : NULL;
-}
-
-static HRESULT init_register_strtable(STRTABLEA *strtable)
-{
-#define CLSID_EXPANSION_ENTRY(id) { "CLSID_" #id, &CLSID_ ## id }
- static const struct
- {
- const char *name;
- const CLSID *clsid;
- }
- expns[] =
- {
- CLSID_EXPANSION_ENTRY(CTaskScheduler),
- CLSID_EXPANSION_ENTRY(CTask)
- };
-#undef CLSID_EXPANSION_ENTRY
- static STRENTRYA pse[sizeof expns / sizeof expns[0]];
- unsigned int i;
-
- strtable->cEntries = sizeof pse / sizeof pse[0];
- strtable->pse = pse;
- for (i = 0; i < strtable->cEntries; i++)
- {
- static const char dummy_sample[] =
- "{12345678-1234-1234-1234-123456789012}";
- const CLSID *clsid = expns[i].clsid;
- pse[i].pszName = mstask_strdup(expns[i].name);
- pse[i].pszValue = HeapAlloc(GetProcessHeap(), 0, sizeof dummy_sample);
- if (!pse[i].pszName || !pse[i].pszValue)
- return E_OUTOFMEMORY;
- sprintf(pse[i].pszValue,
- "{%08X-%04X-%04X-%02X%02X-%02X%02X%02X%02X%02X%02X}",
- clsid->Data1, clsid->Data2, clsid->Data3, clsid->Data4[0],
- clsid->Data4[1], clsid->Data4[2], clsid->Data4[3],
- clsid->Data4[4], clsid->Data4[5], clsid->Data4[6],
- clsid->Data4[7]);
- }
-
- return S_OK;
-}
-
-static void cleanup_register_strtable(STRTABLEA *strtable)
-{
- unsigned int i;
- for (i = 0; i < strtable->cEntries; i++)
- {
- HeapFree(GetProcessHeap(), 0, strtable->pse[i].pszName);
- HeapFree(GetProcessHeap(), 0, strtable->pse[i].pszValue);
- if (!strtable->pse[i].pszName || !strtable->pse[i].pszValue)
- return;
- }
-}
-
-static HRESULT register_mstask(BOOL do_register)
-{
- HRESULT hr;
- STRTABLEA strtable;
- HMODULE hAdvpack;
- HRESULT (WINAPI *pRegInstall)(HMODULE hm,
- LPCSTR pszSection, const STRTABLEA* pstTable);
- static const WCHAR wszAdvpack[] =
- {'a','d','v','p','a','c','k','.','d','l','l',0};
-
- TRACE("(%x)\n", do_register);
-
- hAdvpack = LoadLibraryW(wszAdvpack);
- pRegInstall = (void *)GetProcAddress(hAdvpack, "RegInstall");
-
- hr = init_register_strtable(&strtable);
- if (SUCCEEDED(hr))
- hr = pRegInstall(hInst, do_register ? "RegisterDll" : "UnregisterDll",
- &strtable);
- cleanup_register_strtable(&strtable);
-
- if (FAILED(hr))
- WINE_ERR("RegInstall failed: %08x\n", hr);
-
- return hr;
-}
-
HRESULT WINAPI DllRegisterServer(void)
{
- return register_mstask(TRUE);
+ return __wine_register_resources( hInst );
}
HRESULT WINAPI DllUnregisterServer(void)
{
- return register_mstask(FALSE);
+ return __wine_unregister_resources( hInst );
}
#include "ole2.h"
#include "mstask.h"
-extern LONG dll_ref;
+extern LONG dll_ref DECLSPEC_HIDDEN;
-typedef struct
-{
- const IClassFactoryVtbl *lpVtbl;
- LONG ref;
-} ClassFactoryImpl;
-extern ClassFactoryImpl MSTASK_ClassFactory;
+typedef struct ClassFactoryImpl ClassFactoryImpl;
+extern ClassFactoryImpl MSTASK_ClassFactory DECLSPEC_HIDDEN;
-typedef struct
-{
- const ITaskTriggerVtbl *lpVtbl;
- LONG ref;
- TASK_TRIGGER triggerCond;
-} TaskTriggerImpl;
-extern HRESULT TaskTriggerConstructor(LPVOID *ppObj);
-
-typedef struct
-{
- const ITaskSchedulerVtbl *lpVtbl;
- LONG ref;
-} TaskSchedulerImpl;
-extern HRESULT TaskSchedulerConstructor(LPVOID *ppObj);
-
-typedef struct
-{
- const ITaskVtbl *lpVtbl;
- const IPersistFileVtbl *persistVtbl;
- LONG ref;
- LPWSTR taskName;
- LPWSTR applicationName;
- LPWSTR parameters;
- LPWSTR comment;
- DWORD maxRunTime;
- LPWSTR accountName;
-} TaskImpl;
-extern HRESULT TaskConstructor(LPCWSTR pwszTaskName, LPVOID *ppObj);
+extern HRESULT TaskTriggerConstructor(LPVOID *ppObj) DECLSPEC_HIDDEN;
+extern HRESULT TaskSchedulerConstructor(LPVOID *ppObj) DECLSPEC_HIDDEN;
+extern HRESULT TaskConstructor(LPCWSTR pwszTaskName, LPVOID *ppObj) DECLSPEC_HIDDEN;
#endif /* __MSTASK_PRIVATE_H__ */
-/*
- * Copyright 2008 Google (Roy Shea)
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2.1 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
- */
-
-/* @makedep: mstask.inf */
-REGINST REGINST mstask.inf
+1 WINE_REGISTRY mstask.rgs
WINE_DEFAULT_DEBUG_CHANNEL(mstask);
+typedef struct
+{
+ ITask ITask_iface;
+ IPersistFile IPersistFile_iface;
+ LONG ref;
+ LPWSTR taskName;
+ LPWSTR applicationName;
+ LPWSTR parameters;
+ LPWSTR comment;
+ DWORD maxRunTime;
+ LPWSTR accountName;
+} TaskImpl;
+
+static inline TaskImpl *impl_from_ITask(ITask *iface)
+{
+ return CONTAINING_RECORD(iface, TaskImpl, ITask_iface);
+}
+
static inline TaskImpl *impl_from_IPersistFile( IPersistFile *iface )
{
- return (TaskImpl*) ((char*)(iface) - FIELD_OFFSET(TaskImpl, persistVtbl));
+ return CONTAINING_RECORD(iface, TaskImpl, IPersistFile_iface);
}
static void TaskDestructor(TaskImpl *This)
REFIID riid,
void **ppvObject)
{
- TaskImpl * This = (TaskImpl *)iface;
+ TaskImpl * This = impl_from_ITask(iface);
TRACE("IID: %s\n", debugstr_guid(riid));
if (ppvObject == NULL)
if (IsEqualGUID(riid, &IID_IUnknown) ||
IsEqualGUID(riid, &IID_ITask))
{
- *ppvObject = &This->lpVtbl;
+ *ppvObject = &This->ITask_iface;
ITask_AddRef(iface);
return S_OK;
}
else if (IsEqualGUID(riid, &IID_IPersistFile))
{
- *ppvObject = &This->persistVtbl;
+ *ppvObject = &This->IPersistFile_iface;
ITask_AddRef(iface);
return S_OK;
}
static ULONG WINAPI MSTASK_ITask_AddRef(
ITask* iface)
{
- TaskImpl *This = (TaskImpl *)iface;
+ TaskImpl *This = impl_from_ITask(iface);
ULONG ref;
TRACE("\n");
ref = InterlockedIncrement(&This->ref);
static ULONG WINAPI MSTASK_ITask_Release(
ITask* iface)
{
- TaskImpl * This = (TaskImpl *)iface;
+ TaskImpl * This = impl_from_ITask(iface);
ULONG ref;
TRACE("\n");
ref = InterlockedDecrement(&This->ref);
LPCWSTR pwszComment)
{
DWORD n;
- TaskImpl *This = (TaskImpl *)iface;
+ TaskImpl *This = impl_from_ITask(iface);
LPWSTR tmp_comment;
TRACE("(%p, %s)\n", iface, debugstr_w(pwszComment));
LPWSTR *ppwszComment)
{
DWORD n;
- TaskImpl *This = (TaskImpl *)iface;
+ TaskImpl *This = impl_from_ITask(iface);
TRACE("(%p, %p)\n", iface, ppwszComment);
LPCWSTR pwszPassword)
{
DWORD n;
- TaskImpl *This = (TaskImpl *)iface;
+ TaskImpl *This = impl_from_ITask(iface);
LPWSTR tmp_account_name;
TRACE("(%p, %s, %s): partial stub\n", iface, debugstr_w(pwszAccountName),
LPWSTR *ppwszAccountName)
{
DWORD n;
- TaskImpl *This = (TaskImpl *)iface;
+ TaskImpl *This = impl_from_ITask(iface);
TRACE("(%p, %p): partial stub\n", iface, ppwszAccountName);
LPCWSTR pwszApplicationName)
{
DWORD n;
- TaskImpl *This = (TaskImpl *)iface;
+ TaskImpl *This = impl_from_ITask(iface);
LPWSTR tmp_name;
TRACE("(%p, %s)\n", iface, debugstr_w(pwszApplicationName));
LPWSTR *ppwszApplicationName)
{
DWORD n;
- TaskImpl *This = (TaskImpl *)iface;
+ TaskImpl *This = impl_from_ITask(iface);
TRACE("(%p, %p)\n", iface, ppwszApplicationName);
LPCWSTR pwszParameters)
{
DWORD n;
- TaskImpl *This = (TaskImpl *)iface;
+ TaskImpl *This = impl_from_ITask(iface);
LPWSTR tmp_parameters;
TRACE("(%p, %s)\n", iface, debugstr_w(pwszParameters));
LPWSTR *ppwszParameters)
{
DWORD n;
- TaskImpl *This = (TaskImpl *)iface;
+ TaskImpl *This = impl_from_ITask(iface);
TRACE("(%p, %p)\n", iface, ppwszParameters);
ITask* iface,
DWORD dwMaxRunTime)
{
- TaskImpl *This = (TaskImpl *)iface;
+ TaskImpl *This = impl_from_ITask(iface);
TRACE("(%p, %d)\n", iface, dwMaxRunTime);
ITask* iface,
DWORD *pdwMaxRunTime)
{
- TaskImpl *This = (TaskImpl *)iface;
+ TaskImpl *This = impl_from_ITask(iface);
TRACE("(%p, %p)\n", iface, pdwMaxRunTime);
{
TaskImpl *This = impl_from_IPersistFile(iface);
TRACE("(%p, %s, %p)\n", iface, debugstr_guid(riid), ppvObject);
- return ITask_QueryInterface((ITask *) This, riid, ppvObject);
+ return ITask_QueryInterface(&This->ITask_iface, riid, ppvObject);
}
static ULONG WINAPI MSTASK_IPersistFile_AddRef(
if (!This)
return E_OUTOFMEMORY;
- This->lpVtbl = &MSTASK_ITaskVtbl;
- This->persistVtbl = &MSTASK_IPersistFileVtbl;
+ This->ITask_iface.lpVtbl = &MSTASK_ITaskVtbl;
+ This->IPersistFile_iface.lpVtbl = &MSTASK_IPersistFileVtbl;
This->ref = 1;
n = (lstrlenW(pwszTaskName) + 1) * sizeof(WCHAR);
This->taskName = HeapAlloc(GetProcessHeap(), 0, n);
/* Default time is 3 days = 259200000 ms */
This->maxRunTime = 259200000;
- *ppObj = &This->lpVtbl;
+ *ppObj = &This->ITask_iface;
InterlockedIncrement(&dll_ref);
return S_OK;
}
WINE_DEFAULT_DEBUG_CHANNEL(mstask);
+typedef struct
+{
+ ITaskScheduler ITaskScheduler_iface;
+ LONG ref;
+} TaskSchedulerImpl;
+
+static inline TaskSchedulerImpl *impl_from_ITaskScheduler(ITaskScheduler *iface)
+{
+ return CONTAINING_RECORD(iface, TaskSchedulerImpl, ITaskScheduler_iface);
+}
+
static void TaskSchedulerDestructor(TaskSchedulerImpl *This)
{
TRACE("%p\n", This);
REFIID riid,
void **ppvObject)
{
- TaskSchedulerImpl * This = (TaskSchedulerImpl *)iface;
+ TaskSchedulerImpl * This = impl_from_ITaskScheduler(iface);
TRACE("IID: %s\n", debugstr_guid(riid));
if (IsEqualGUID(riid, &IID_IUnknown) ||
IsEqualGUID(riid, &IID_ITaskScheduler))
{
- *ppvObject = &This->lpVtbl;
+ *ppvObject = &This->ITaskScheduler_iface;
ITaskScheduler_AddRef(iface);
return S_OK;
}
static ULONG WINAPI MSTASK_ITaskScheduler_AddRef(
ITaskScheduler* iface)
{
- TaskSchedulerImpl *This = (TaskSchedulerImpl *)iface;
+ TaskSchedulerImpl *This = impl_from_ITaskScheduler(iface);
TRACE("\n");
return InterlockedIncrement(&This->ref);
}
static ULONG WINAPI MSTASK_ITaskScheduler_Release(
ITaskScheduler* iface)
{
- TaskSchedulerImpl * This = (TaskSchedulerImpl *)iface;
+ TaskSchedulerImpl * This = impl_from_ITaskScheduler(iface);
ULONG ref;
TRACE("\n");
ref = InterlockedDecrement(&This->ref);
if (!This)
return E_OUTOFMEMORY;
- This->lpVtbl = &MSTASK_ITaskSchedulerVtbl;
+ This->ITaskScheduler_iface.lpVtbl = &MSTASK_ITaskSchedulerVtbl;
This->ref = 1;
- *ppObj = &This->lpVtbl;
+ *ppObj = &This->ITaskScheduler_iface;
InterlockedIncrement(&dll_ref);
return S_OK;
}
WINE_DEFAULT_DEBUG_CHANNEL(mstask);
+typedef struct
+{
+ ITaskTrigger ITaskTrigger_iface;
+ LONG ref;
+ TASK_TRIGGER triggerCond;
+} TaskTriggerImpl;
+
+static inline TaskTriggerImpl *impl_from_ITaskTrigger(ITaskTrigger *iface)
+{
+ return CONTAINING_RECORD(iface, TaskTriggerImpl, ITaskTrigger_iface);
+}
+
static HRESULT WINAPI MSTASK_ITaskTrigger_QueryInterface(
ITaskTrigger* iface,
REFIID riid,
void **ppvObject)
{
- TaskTriggerImpl *This = (TaskTriggerImpl *)iface;
+ TaskTriggerImpl *This = impl_from_ITaskTrigger(iface);
TRACE("IID: %s\n", debugstr_guid(riid));
if (ppvObject == NULL)
if (IsEqualGUID(riid, &IID_IUnknown) ||
IsEqualGUID(riid, &IID_ITaskTrigger))
{
- *ppvObject = &This->lpVtbl;
+ *ppvObject = &This->ITaskTrigger_iface;
ITaskTrigger_AddRef(iface);
return S_OK;
}
static ULONG WINAPI MSTASK_ITaskTrigger_AddRef(
ITaskTrigger* iface)
{
- TaskTriggerImpl *This = (TaskTriggerImpl *)iface;
+ TaskTriggerImpl *This = impl_from_ITaskTrigger(iface);
ULONG ref;
TRACE("\n");
ref = InterlockedIncrement(&This->ref);
static ULONG WINAPI MSTASK_ITaskTrigger_Release(
ITaskTrigger* iface)
{
- TaskTriggerImpl *This = (TaskTriggerImpl *)iface;
+ TaskTriggerImpl *This = impl_from_ITaskTrigger(iface);
ULONG ref;
TRACE("\n");
ref = InterlockedDecrement(&This->ref);
ITaskTrigger* iface,
const PTASK_TRIGGER pTrigger)
{
- TaskTriggerImpl * This = (TaskTriggerImpl *)iface;
+ TaskTriggerImpl * This = impl_from_ITaskTrigger(iface);
TIME_FIELDS field_time;
LARGE_INTEGER sys_time;
TASK_TRIGGER tmp_trigger_cond;
ITaskTrigger* iface,
PTASK_TRIGGER pTrigger)
{
- TaskTriggerImpl * This = (TaskTriggerImpl *)iface;
+ TaskTriggerImpl * This = impl_from_ITaskTrigger(iface);
TRACE("(%p, %p)\n", iface, pTrigger);
if (!This)
return E_OUTOFMEMORY;
- This->lpVtbl = &MSTASK_ITaskTriggerVtbl;
+ This->ITaskTrigger_iface.lpVtbl = &MSTASK_ITaskTriggerVtbl;
This->ref = 1;
/* Most fields of triggerCond default to zero. Initialize other
This->triggerCond.TriggerType = TASK_TIME_TRIGGER_DAILY,
This->triggerCond.Type.Daily.DaysInterval = 1;
- *ppObj = &This->lpVtbl;
+ *ppObj = &This->ITaskTrigger_iface;
InterlockedIncrement(&dll_ref);
return S_OK;
}
reactos/dll/win32/msrle32 # Autosync
reactos/dll/win32/mssign32 # Autosync
reactos/dll/win32/mssip32 # Autosync
-reactos/dll/win32/mstask # Autosync
+reactos/dll/win32/mstask # Synced to Wine-1.3.37
reactos/dll/win32/msvcrt20 # Autosync
reactos/dll/win32/msvfw32 # Autosync
reactos/dll/win32/msvidc32 # Autosync