/*++ Copyright (c) 1999-2002 Microsoft Corporation Module Name: cwcreate.cpp Abstract: This module contains the code for the new window architecture. --*/ #include "precomp.hxx" #pragma hdrstop HWND New_CreateWindow( HWND hwndParent, WIN_TYPES Type, UINT uClassId, UINT uWinTitle, PRECT pRect ) /*++ Description Generic rotuine to create a child window. Arguments hwndParent - handle to parent window uClassId - resource string ID containing class name uWinTitle - resource string ID containing window title pRect - Rect describing the position of the window. If NULL, CW_USEDEFAULT is used to specify the location of the window. --*/ { TCHAR szClassName[MAX_MSG_TXT]; TCHAR szWinTitle[MAX_MSG_TXT]; int nX = CW_USEDEFAULT; int nY = CW_USEDEFAULT; int nWidth = CW_USEDEFAULT; int nHeight = CW_USEDEFAULT; COMMONWIN_CREATE_DATA Data; if (pRect) { nX = pRect->left; nY = pRect->top; nWidth = pRect->right; nHeight = pRect->bottom; } // get class name and tile Dbg(LoadString(g_hInst, uClassId, szClassName, _tsizeof(szClassName))); Dbg(LoadString(g_hInst, uWinTitle, szWinTitle, _tsizeof(szWinTitle))); Data.Type = Type; BOOL TopMax; MDIGetActive(g_hwndMDIClient, &TopMax); HWND Win = CreateWindowEx( WS_EX_MDICHILD | WS_EX_CONTROLPARENT, // Extended style szClassName, // class name szWinTitle, // title WS_CLIPCHILDREN | WS_CLIPSIBLINGS | WS_OVERLAPPEDWINDOW | WS_VISIBLE | (TopMax ? WS_MAXIMIZE : 0), // style nX, // x nY, // y nWidth, // width nHeight, // height hwndParent, // parent NULL, // menu g_hInst, // hInstance &Data // user defined data ); // Creation is considered an automatic operation in // order to distinguish things occuring during creation // from normal user operations. Now that create is // finished, decrement to indicate the create op is over. if (Win != NULL) { COMMONWIN_DATA* CmnWin = GetCommonWinData(Win); if (CmnWin != NULL) { CmnWin->m_InAutoOp--; } } return Win; } HWND NewWatch_CreateWindow( HWND hwndParent ) { return New_CreateWindow(hwndParent, WATCH_WINDOW, SYS_CommonWin_wClass, SYS_WatchWin_Title, NULL ); } HWND NewLocals_CreateWindow( HWND hwndParent ) { return New_CreateWindow(hwndParent, LOCALS_WINDOW, SYS_CommonWin_wClass, SYS_LocalsWin_Title, NULL ); } HWND NewDisasm_CreateWindow( HWND hwndParent ) { RECT Rect; SetRect(&Rect, CW_USEDEFAULT, CW_USEDEFAULT, DISASM_WIDTH, DISASM_HEIGHT); return New_CreateWindow(hwndParent, DISASM_WINDOW, SYS_CommonWin_wClass, SYS_DisasmWin_Title, &Rect ); } HWND NewQuickWatch_CreateWindow( HWND hwndParent ) { return New_CreateWindow(hwndParent, QUICKW_WINDOW, SYS_CommonWin_wClass, SYS_QuickWatchWin_Title, NULL ); } HWND NewMemory_CreateWindow( HWND hwndParent ) { return New_CreateWindow(hwndParent, MEM_WINDOW, SYS_CommonWin_wClass, SYS_MemoryWin_Title, NULL ); } HWND NewCalls_CreateWindow( HWND hwndParent ) { RECT Rect; SetRect(&Rect, CW_USEDEFAULT, CW_USEDEFAULT, CALLS_WIDTH, CALLS_HEIGHT); return New_CreateWindow(hwndParent, CALLS_WINDOW, SYS_CommonWin_wClass, SYS_CallsWin_Title, &Rect ); } HWND NewCmd_CreateWindow( HWND hwndParent ) { RECT Rect; SetRect(&Rect, CW_USEDEFAULT, CW_USEDEFAULT, CMD_WIDTH, CMD_HEIGHT); return New_CreateWindow(hwndParent, CMD_WINDOW, SYS_CommonWin_wClass, SYS_CmdWin_Title, &Rect ); } HWND NewCpu_CreateWindow( HWND hwndParent ) { RECT Rect; SetRect(&Rect, CW_USEDEFAULT, CW_USEDEFAULT, g_Ptr64 ? CPU_WIDTH_64 : CPU_WIDTH_32, CPU_HEIGHT); return New_CreateWindow(hwndParent, CPU_WINDOW, SYS_CommonWin_wClass, SYS_CpuWin_Title, &Rect ); } HWND NewDoc_CreateWindow( HWND hwndParent ) /*++ Routine Description: Create the command window. Arguments: hwndParent - The parent window to the command window. In an MDI document, this is usually the handle to the MDI client window: g_hwndMDIClient Return Value: If successful, creates a valid window handle to the new command window. NULL if the window was not created. --*/ { RECT Rect; // Set default geometry. SetRect(&Rect, CW_USEDEFAULT, CW_USEDEFAULT, DOC_WIDTH, DOC_HEIGHT); if (g_WinOptions & WOPT_OVERLAY_SOURCE) { PLIST_ENTRY Entry; PCOMMONWIN_DATA WinData; // If we're stacking up document windows go // find the first one and use it as a template. for (Entry = g_ActiveWin.Flink; Entry != &g_ActiveWin; Entry = Entry->Flink) { WinData = ACTIVE_WIN_ENTRY(Entry); if (WinData->m_enumType == DOC_WINDOW && !IsIconic(WinData->m_Win)) { GetWindowRect(WinData->m_Win, &Rect); MapWindowPoints(GetDesktopWindow(), g_hwndMDIClient, (LPPOINT)&Rect, 2); Rect.right -= Rect.left; Rect.bottom -= Rect.top; } } } return New_CreateWindow(hwndParent, DOC_WINDOW, SYS_CommonWin_wClass, SYS_DocWin_Title, &Rect ); } HWND NewScratch_CreateWindow( HWND hwndParent ) { return New_CreateWindow(hwndParent, SCRATCH_PAD_WINDOW, SYS_CommonWin_wClass, SYS_Scratch_Pad_Title, NULL ); } HWND NewProcessThread_CreateWindow( HWND hwndParent ) { return New_CreateWindow(hwndParent, PROCESS_THREAD_WINDOW, SYS_CommonWin_wClass, SYS_Process_Thread_Title, NULL ); } HWND New_OpenDebugWindow( WIN_TYPES winType, BOOL bUserActivated, ULONG Nth ) /*++ Routine Description: Opens Cpu, Watch, Locals, Calls, or Memory Window under MDI Handles special case for memory win's Arguments: winType - Supplies Type of debug window to be openned bUserActivated - Indicates whether this action was initiated by the user or by windbg. The value is to determine the Z order of any windows that are opened. Return Value: Window handle. NULL if an error occurs. --*/ { HWND hwndActivate = NULL; PCOMMONWIN_DATA CmnWin; switch (winType) { default: Assert(!_T("Invalid window type. Ignorable error.")); break; case CMD_WINDOW: if (GetCmdHwnd()) { hwndActivate = GetCmdHwnd(); } else { return NewCmd_CreateWindow(g_hwndMDIClient); } break; case WATCH_WINDOW: if (GetWatchHwnd()) { hwndActivate = GetWatchHwnd(); } else { return NewWatch_CreateWindow(g_hwndMDIClient); } break; case LOCALS_WINDOW: if (GetLocalsHwnd()) { hwndActivate = GetLocalsHwnd(); } else { return NewLocals_CreateWindow(g_hwndMDIClient); } break; case CPU_WINDOW: if (GetCpuHwnd()) { hwndActivate = GetCpuHwnd(); } else { return NewCpu_CreateWindow(g_hwndMDIClient); } break; case SCRATCH_PAD_WINDOW: if (GetScratchHwnd()) { hwndActivate = GetScratchHwnd(); } else { return NewScratch_CreateWindow(g_hwndMDIClient); } break; case DISASM_WINDOW: if (!bUserActivated && GetSrcMode_StatusBar() && NULL == GetDisasmHwnd() && (g_WinOptions & WOPT_AUTO_DISASM) == 0) { return NULL; } if (GetDisasmHwnd()) { hwndActivate = GetDisasmHwnd(); } else { return NewDisasm_CreateWindow(g_hwndMDIClient); } break; case MEM_WINDOW: // Memory windows normally open a fresh window // whenever an open request occurs, but when applying // workspaces we don't want to continually add // new memory windows. In the workspace case we // reuse existing memory windows as much as possible. if (Nth != NTH_OPEN_ALWAYS && (CmnWin = FindNthWindow(Nth, 1 << winType)) != NULL) { hwndActivate = CmnWin->m_Win; break; } hwndActivate = NewMemory_CreateWindow(g_hwndMDIClient); if (hwndActivate) { MEMWIN_DATA * pMemWinData = GetMemWinData(hwndActivate); Assert(pMemWinData); // If this window is being created from a workspace // don't pop up the properties dialog. if ( Nth == NTH_OPEN_ALWAYS && pMemWinData->HasEditableProperties() ) { pMemWinData->EditProperties(); pMemWinData->UiRequestRead(); } } break; case DOC_WINDOW: return NewDoc_CreateWindow(g_hwndMDIClient); case QUICKW_WINDOW: if (GetQuickWatchHwnd()) { hwndActivate = GetQuickWatchHwnd(); } else { return NewQuickWatch_CreateWindow(g_hwndMDIClient); } break; case CALLS_WINDOW: if (GetCallsHwnd()) { hwndActivate = GetCallsHwnd(); } else { return NewCalls_CreateWindow(g_hwndMDIClient); } break; case PROCESS_THREAD_WINDOW: if (GetProcessThreadHwnd()) { hwndActivate = GetProcessThreadHwnd(); } else { return NewProcessThread_CreateWindow(g_hwndMDIClient); } break; } if (hwndActivate) { if (GetKeyState(VK_SHIFT) < 0 && GetKeyState(VK_CONTROL) >= 0) { SendMessage(g_hwndMDIClient, WM_MDIDESTROY, (WPARAM)hwndActivate, 0); } else { if (IsIconic(hwndActivate)) { OpenIcon(hwndActivate); } ActivateMDIChild(hwndActivate, bUserActivated); } } return hwndActivate; }