2020-09-30 16:53:55 +02:00

226 lines
5.7 KiB
C++

//+----------------------------------------------------------------------------
//
// Job Schedule Application Job Object Handler
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1992 - 1996.
//
// File: dllmisc.cxx
//
// Contents: job scheduler class objects handler DLL fcns
//
// History: 25-Sep-95 EricB created
// 23-Feb-01 JBenton added code to clean up debug crit sections
//
//-----------------------------------------------------------------------------
#include "..\pch\headers.hxx"
#pragma hdrstop
DECLARE_INFOLEVEL(Sched);
#include <job_cls.hxx>
#include <sch_cls.hxx>
#include <debug.hxx>
//
// JobFolder related stuff
//
BOOL JFOnProcessAttach(void);
HRESULT JFGetClassObject(REFCLSID cid, REFIID riid, LPVOID *ppvObj);
HRESULT AllocFolderCFs(void);
void FreeFolderCFs(void);
extern HANDLE g_hActCtx;
//+----------------------------------------------------------------------------
//
// DLL functions
//
//-----------------------------------------------------------------------------
//+----------------------------------------------------------------------------
//
// Function: DllMain
//
// Synopsis: Provide a DllMain for Win32
//
// Arguments: hInstance - HANDLE to this dll
// dwReason - Reason this function was called. Can be
// Process/Thread Attach/Detach.
//
// Returns: BOOL - TRUE if no error, FALSE otherwise
//
// History: 24-May-95 EricB created.
//
//-----------------------------------------------------------------------------
extern "C" BOOL
DllMain(HINSTANCE hInstance, DWORD dwReason, LPVOID lpReserved)
{
switch (dwReason)
{
case DLL_PROCESS_ATTACH:
schDebugOut((DEB_ITRACE, "DllMain: DLL_PROCESS_ATTACH\n"));
//
// Get instance handle
//
g_hInstance = hInstance;
// init common controls and get activation context
InitCommonControls();
if (!GetCurrentActCtx(&g_hActCtx))
{
ERR_OUT("GetCurrentActCtx", 0);
return FALSE;
}
//
// Disable thread notification from OS
//
DisableThreadLibraryCalls(hInstance);
HRESULT hr;
//
// Init the folder class factory objects.
//
hr = AllocFolderCFs();
if (FAILED(hr))
{
ERR_OUT("AllocFolderCFs", hr);
return FALSE;
}
//
// Initialize the global service values. These are globals that
// live in common\globals.cxx, and are used in both the service
// (mstask.exe) and client (mstask.dll).
//
hr = InitGlobals();
if (FAILED(hr))
{
ERR_OUT("InitGlobals", hr);
FreeFolderCFs();
return FALSE;
}
//
// Init job folder stuff
//
if (JFOnProcessAttach() == FALSE)
{
FreeGlobals();
FreeFolderCFs();
return FALSE;
}
break;
case DLL_PROCESS_DETACH:
schDebugOut((DEB_ITRACE, "DllMain: DLL_PROCESS_DETACH\n"));
#if DBG == 1
CleanUpDebugging();
#endif
FreeGlobals();
FreeFolderCFs();
break;
}
return(TRUE);
}
//+----------------------------------------------------------------------------
//
// Function: DllGetClassObject
//
// Synopsis: Creates a class factory for the requested object.
//
// Arguments: [cid] - the requested class object
// [iid] - the requested interface
// [ppvObj] - returned pointer to class object
//
// Returns: HRESULTS
//
//-----------------------------------------------------------------------------
STDAPI
DllGetClassObject(REFCLSID cid, REFIID iid, void **ppvObj)
{
IUnknown *pUnk = NULL;
HRESULT hr = S_OK;
if (CLSID_CTask == cid)
{
pUnk = CJobCF::Create();
if (pUnk != NULL)
{
hr = pUnk->QueryInterface(iid, ppvObj);
pUnk->Release();
}
else
{
return E_OUTOFMEMORY;
}
}
else if (CLSID_CTaskScheduler == cid)
{
pUnk = CScheduleCF::Create();
if (pUnk != NULL)
{
hr = pUnk->QueryInterface(iid, ppvObj);
pUnk->Release();
}
else
{
return E_OUTOFMEMORY;
}
}
else
{
return JFGetClassObject(cid, iid, ppvObj);
}
return hr;
}
//+----------------------------------------------------------------------------
//
// Function: DllCanUnloadNow
//
// Synopsis: Indicates whether the DLL can be removed if there are no
// objects in existence.
//
// Returns: S_OK or S_FALSE
//
//-----------------------------------------------------------------------------
STDAPI
DllCanUnloadNow(void)
{
return CDll::CanUnloadNow();
}
//+----------------------------------------------------------------------------
//
// Function: AddAtJobWithHash
//
// Synopsis: Client-side stub for this API to make things compile. Only
// supported/called on the server side
//
// Returns: E_NOTIMPL
//
//-----------------------------------------------------------------------------
STDAPI
CSchedule::AddAtJobWithHash(
const AT_INFO &At,
DWORD * pID)
{
return E_NOTIMPL;
}