Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

222 lines
6.1 KiB

/****************************************************************************\
* Module Name: minmax.c
*
* Copyright (c) 1985 - 1999, Microsoft Corporation
*
* Misc util functions
*
* 10-25-90 MikeHar Ported from Windows.
* 14-Feb-1991 mikeke Added Revalidation code (None)
\****************************************************************************/
#include "precomp.h"
#pragma hdrstop
VOID ZapActiveAndFocus(
VOID)
{
PQ pq = PtiCurrent()->pq;
Unlock(&pq->spwndActive);
Unlock(&pq->spwndFocus);
}
VOID SetDialogPointer(
PWND pwnd,
LONG_PTR lPtr)
{
if (pwnd->cbwndExtra < DLGWINDOWEXTRA ||
TestWF(pwnd, WFSERVERSIDEPROC) ||
PpiCurrent() != GETPTI(pwnd)->ppi) {
RIPMSG1(RIP_WARNING, "SetDialogPointer: Unexpected pwnd 0x%p", pwnd);
return;
}
((PDIALOG)pwnd)->pdlg = (PDLG)lPtr;
if (lPtr == 0) {
pwnd->fnid |= FNID_CLEANEDUP_BIT;
ClrWF(pwnd, WFDIALOGWINDOW);
} else {
if (pwnd->fnid == 0) {
pwnd->fnid = FNID_DIALOG;
}
SetWF(pwnd, WFDIALOGWINDOW);
}
}
BOOL _SetProgmanWindow(
PWND pwnd)
{
PDESKTOPINFO pdeskinfo = GETDESKINFO(PtiCurrent());
if (pwnd != NULL) {
/*
* Fail the call if another progman window exists.
*/
if (pdeskinfo->spwndProgman != NULL) {
RIPERR0(ERROR_ACCESS_DENIED,
RIP_WARNING,
"Progman window already set");
return FALSE;
}
}
Lock(&pdeskinfo->spwndProgman, pwnd);
return TRUE;
}
BOOL _SetTaskmanWindow(
PWND pwnd)
{
PDESKTOPINFO pdeskinfo = GETDESKINFO(PtiCurrent());
if (pwnd != NULL) {
/*
* Fail the call if another taskman window exists.
*/
if (pdeskinfo->spwndTaskman != NULL) {
RIPERR0(ERROR_ACCESS_DENIED,
RIP_WARNING,
"Taskman window already set");
return FALSE;
}
}
Lock(&pdeskinfo->spwndTaskman, pwnd);
return TRUE;
}
/***************************************************************************\
* SetShellWindow
*
* Returns true if shell window is successfully set. Note that we return
* FALSE if a shell window already exists. I.E., this works on a first come,
* first served basis.
*
* We also do NOT allow child windows to be shell windows. Other than that,
* it's up to the caller to size the window appropriately.
*
* The pwndBkGnd is provided for the explorer shell. Since the shellwnd and
* the window which does the drawing of background wallpapers are different,
* we need to provide means by which we can draw directly on the background
* window during hung-app drawing. The pwnd and pwndBkGnd will be identical
* if called through the SetShellWindow() api.
\***************************************************************************/
BOOL xxxSetShellWindow(
PWND pwnd,
PWND pwndBkGnd)
{
PTHREADINFO ptiCurrent = PtiCurrent();
PDESKTOPINFO pdeskinfo = GETDESKINFO(ptiCurrent);
PPROCESSINFO ppiShellProcess;
UserAssert(pwnd);
/*
* Fail the call if another shell window exists.
*/
if (pdeskinfo->spwndShell != NULL) {
RIPERR0(ERROR_ACCESS_DENIED,
RIP_WARNING,
"A shellwindow has already been set");
return FALSE;
}
/*
* The shell window must be
* (1) Top-level
* (2) Unowned
* (3) Not topmost
*/
if (TestwndChild(pwnd) ||
pwnd->spwndOwner != NULL ||
TestWF(pwnd, WEFTOPMOST)) {
RIPERR0(ERROR_INVALID_PARAMETER,
RIP_WARNING,
"xxxSetShellWindow: Invalid type of window");
return FALSE;
}
/*
* Chicago has a totally different input model which has special code
* that checks for Ctrl-Esc and sends it to the shell. We can get
* the same functionality, without totally re-writing our input model
* by just automatically installing the Ctrl-Esc as a hotkey for the
* shell window. The hotkey delivery code has a special case which
* turns this into a WM_SYSCOMMAND message instead of a WM_HOTKEY
* message.
*
* We don't both checking for failure. Somebody could already have
* a Ctrl-Esc handler installed.
*/
_RegisterHotKey(pwnd,SC_TASKLIST,MOD_CONTROL,VK_ESCAPE);
/*
* This is the shell window wright.
* So get the process id for the shell.
*/
ppiShellProcess = GETPTI(pwnd)->ppi;
/*
* Set the shell process id to the desktop only if it's the first instance
*/
if ((ppiShellProcess != NULL) && (pdeskinfo->ppiShellProcess == NULL)) {
pdeskinfo->ppiShellProcess = ppiShellProcess;
}
Lock(&pdeskinfo->spwndShell, pwnd);
Lock(&pdeskinfo->spwndBkGnd, pwndBkGnd);
/*
* Push window to bottom of stack.
*/
SetWF(pdeskinfo->spwndShell, WFBOTTOMMOST);
xxxSetWindowPos(pdeskinfo->spwndShell,
PWND_BOTTOM,
0,
0,
0,
0,
SWP_NOMOVE | SWP_NOSIZE | SWP_NOACTIVATE);
return TRUE;
}
/***************************************************************************\
* _InitPwSB
*
* History:
* 10-23-90 MikeHar Ported from WaWaWaWindows.
* 11-28-90 JimA Changed to int *
* 01-21-91 IanJa Prefix '_' denoting exported function (although not API)
\***************************************************************************/
PSBINFO _InitPwSB(
PWND pwnd)
{
if (pwnd->pSBInfo) {
/*
* If memory is already allocated, don't bother to do it again.
*/
return pwnd->pSBInfo;
}
pwnd->pSBInfo = (PSBINFO)DesktopAlloc(pwnd->head.rpdesk,
sizeof(SBINFO),
DTAG_SBINFO);
if (pwnd->pSBInfo != NULL) {
pwnd->pSBInfo->Vert.posMax = 100;
pwnd->pSBInfo->Horz.posMax = 100;
}
return pwnd->pSBInfo;
}