Windows2003-3790/admin/services/sched/folderui/util.cxx
2020-09-30 16:53:55 +02:00

383 lines
9.0 KiB
C++

//____________________________________________________________________________
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1995 - 1996.
//
// File: util.cxx
//
// Contents:
//
// Classes:
//
// Functions:
//
// History: 1/8/1996 RaviR Created (Copied from BruceFo's lmshare)
//
//____________________________________________________________________________
#include "..\pch\headers.hxx"
#pragma hdrstop
#include "dbg.h"
#include <mstask.h> // Necessary for util.hxx
#include "jobidl.hxx"
#include "util.hxx"
#include "resource.h"
#include "commdlg.h"
#include "..\inc\sadat.hxx"
extern HINSTANCE g_hInstance;
HRESULT
GetSchSvcState(
DWORD &dwCurrState);
//___________________________________________________________________________
//___________________________________________________________________________
//___________________________________________________________________________
//___________________________________________________________________________
//
// Menu merging routines
//___________________________________________________________________________
//___________________________________________________________________________
//___________________________________________________________________________
//___________________________________________________________________________
HMENU
LoadPopupMenu(
HINSTANCE hinst,
UINT id)
{
HMENU hmParent = LoadMenu(hinst, MAKEINTRESOURCE(id));
if (NULL == hmParent)
{
return NULL;
}
HMENU hmPopup = GetSubMenu(hmParent, 0);
RemoveMenu(hmParent, 0, MF_BYPOSITION);
DestroyMenu(hmParent);
return hmPopup;
}
HMENU
UtGetMenuFromID(
HMENU hmMain,
UINT uID
)
{
MENUITEMINFO mii;
mii.cbSize = sizeof(mii);
mii.fMask = MIIM_SUBMENU;
mii.cch = 0; // just in case
if (!GetMenuItemInfo(hmMain, uID, FALSE, &mii))
{
return NULL;
}
return mii.hSubMenu;
}
int
UtMergePopupMenus(
HMENU hmMain,
HMENU hmMerge,
int idCmdFirst,
int idCmdLast)
{
int i;
int idTemp;
int idMax = idCmdFirst;
for (i = GetMenuItemCount(hmMerge) - 1; i >= 0; --i)
{
MENUITEMINFO mii;
mii.cbSize = sizeof(mii);
mii.fMask = MIIM_ID | MIIM_SUBMENU;
mii.cch = 0; // just in case
if (!GetMenuItemInfo(hmMerge, i, TRUE, &mii))
{
continue;
}
idTemp = Shell_MergeMenus(
UtGetMenuFromID(hmMain, mii.wID),
mii.hSubMenu,
0,
idCmdFirst,
idCmdLast,
MM_ADDSEPARATOR | MM_SUBMENUSHAVEIDS);
if (idMax < idTemp)
{
idMax = idTemp;
}
}
return idMax;
}
void
UtMergeMenu(
HINSTANCE hinst,
UINT idMainMerge,
UINT idPopupMerge,
LPQCMINFO pqcm)
{
HMENU hmMerge;
UINT idMax = pqcm->idCmdFirst;
UINT idTemp;
if (idMainMerge
&& (hmMerge = LoadPopupMenu(hinst, idMainMerge)) != NULL)
{
idMax = Shell_MergeMenus(
pqcm->hmenu,
hmMerge,
pqcm->indexMenu,
pqcm->idCmdFirst,
pqcm->idCmdLast,
MM_SUBMENUSHAVEIDS);
DestroyMenu(hmMerge);
}
if (idPopupMerge
&& (hmMerge = LoadMenu(hinst, MAKEINTRESOURCE(idPopupMerge))) != NULL)
{
idTemp = UtMergePopupMenus(
pqcm->hmenu,
hmMerge,
pqcm->idCmdFirst,
pqcm->idCmdLast);
if (idMax < idTemp)
{
idMax = idTemp;
}
DestroyMenu(hmMerge);
}
pqcm->idCmdFirst = idMax;
}
//+--------------------------------------------------------------------------
//
// Function: ContainsTemplateObject
//
// Synopsis: Return TRUE if [apidl] contains a CJobID object which is
// marked as a template object.
//
// Arguments: [cidl] - number of item id lists in [apidl]
// [apidl] - array of item id lists, each of which can contain
// only one itemid.
//
// History: 5-09-1997 DavidMun Created
//
//---------------------------------------------------------------------------
BOOL
ContainsTemplateObject(
UINT cidl,
LPCITEMIDLIST *apidl)
{
UINT i;
for (i = 0; i < cidl; i++)
{
if (JF_IsValidID(apidl[i]))
{
if (ID_TEMPLATE == ((PJOBID) apidl[i])->_id )
{
return TRUE;
}
}
else
{
DEBUG_OUT((DEB_WARN, "ContainsTemplateObject: item %u not jobid\n", i));
}
}
return FALSE;
}
//____________________________________________________________________________
//
// Function: EnsureUniquenessOfFileName
//
// Synopsis: Internal function. pszFile's buffer size assumed to be
// greater than MAX_PATH.
//
// Arguments: [pszFile] -- IN, OUT
//
// Returns: void
//
// History: 2/8/1996 RaviR Created
//
//____________________________________________________________________________
void
EnsureUniquenessOfFileName(
LPTSTR pszFile,
size_t bufLen)
{
Win4Assert( NULL != pszFile );
int iPostFix = 2;
LPTSTR pszName = PathFindFileName(pszFile);
LPTSTR pszExt = PathFindExtension(pszName);
TCHAR szBufExt[10];
StringCchCopy(szBufExt, 10, pszExt);
int lenUpToExt = (int)(pszExt - pszFile); // lstrlen(pszFile) - lstrlen(pszExt)
Win4Assert(lenUpToExt >= 0);
//
// Ensure uniqueness of the file
//
while (1)
{
HANDLE hFile = CreateFile(pszFile, GENERIC_READ,
FILE_SHARE_READ, NULL, OPEN_EXISTING,
FILE_FLAG_SEQUENTIAL_SCAN, NULL);
if (hFile == INVALID_HANDLE_VALUE)
{
DWORD dwErr = GetLastError();
if (dwErr == ERROR_FILE_NOT_FOUND)
{
//
// No file with this name exists. So this name is unique.
//
break;
}
}
else
{
CloseHandle(hFile);
}
// post fix a number to make the file name unique
TCHAR szBufPostFix[10];
StringCchPrintf(szBufPostFix, 10, TEXT(" %d"), iPostFix++);
StringCchCopy(&pszFile[lenUpToExt], (bufLen - lenUpToExt), szBufPostFix);
StringCchCat(&pszFile[lenUpToExt], (bufLen - lenUpToExt), szBufExt);
}
}
//+--------------------------------------------------------------------------
//
// Function: CheckSaDat
//
// Synopsis: Update or create the sa.dat file if it is missing or its
// waitable timer support flag disagrees with what the system
// reports.
//
// Arguments: [tszFolderPath] - path to tasks folder
//
// History: 11-12-1997 DavidMun Created
//
// Notes: Call only with [tszFolderPath] a path on the local machine.
//
//---------------------------------------------------------------------------
VOID
CheckSaDat(
LPCTSTR tszFolderPath)
{
HRESULT hr;
DWORD dwVersion;
BYTE bSvcFlags;
BYTE bPlatformId;
hr = SADatGetData(tszFolderPath,
&dwVersion,
&bPlatformId,
&bSvcFlags);
BOOL fNeedUpdate = FALSE;
if (SUCCEEDED(hr))
{
BOOL fSaDatTimersFlag = bSvcFlags & SA_DAT_SVCFLAG_RESUME_TIMERS;
BOOL fTimers = ResumeTimersSupported();
if (fSaDatTimersFlag && !fTimers || !fSaDatTimersFlag && fTimers)
{
fNeedUpdate = TRUE;
}
}
else
{
fNeedUpdate = TRUE;
}
if (fNeedUpdate)
{
DWORD dwState;
hr = GetSchSvcState(dwState);
if (SUCCEEDED(hr))
{
BOOL fRunning = (dwState != SERVICE_STOPPED &&
dwState != SERVICE_STOP_PENDING);
SADatCreate(tszFolderPath, fRunning);
}
}
}
#if DBG==1
LPTSTR DbgGetTimeStr(FILETIME &ft)
{
SYSTEMTIME st;
FileTimeToSystemTime(&ft, &st);
return DbgGetTimeStr(st);
}
LPTSTR DbgGetTimeStr(SYSTEMTIME &st)
{
static WCHAR s_szTimeStamp[20]; // space for time & date in format below
StringCchPrintf(s_szTimeStamp,
20,
TEXT("%02d:%02d:%02d %d/%02d/%d"),
st.wHour,
st.wMinute,
st.wSecond,
st.wMonth,
st.wDay,
st.wYear);
return s_szTimeStamp;
}
#endif