diff options
Diffstat (limited to 'xorg-server/hw/xwin/windialogs.c')
| -rw-r--r-- | xorg-server/hw/xwin/windialogs.c | 52 | 
1 files changed, 23 insertions, 29 deletions
| diff --git a/xorg-server/hw/xwin/windialogs.c b/xorg-server/hw/xwin/windialogs.c index c62b5dbe9..bc6715066 100644 --- a/xorg-server/hw/xwin/windialogs.c +++ b/xorg-server/hw/xwin/windialogs.c @@ -192,8 +192,8 @@ winInitDialog(HWND hwndDlg)       */      if (GetSystemMetrics(SM_CMONITORS) > 1) {          /* Still need to refresh the frame change. */ -        SetWindowPos(hwndDlg, HWND_TOPMOST, 0, 0, 0, 0, -                     SWP_NOMOVE | SWP_NOSIZE | SWP_FRAMECHANGED); +    SetWindowPos (hwndDlg, HWND_TOP, 0,0,0,0, +		  SWP_NOMOVE | SWP_NOSIZE | SWP_NOZORDER | SWP_FRAMECHANGED);      }      else {          GetWindowRect(hwndDesk, &rcDesk); @@ -232,12 +232,8 @@ winInitDialog(HWND hwndDlg)      PostMessage(hwndDlg, WM_SETICON, ICON_SMALL, (LPARAM) hIconSmall);  } -/* - * Display the Exit dialog box - */ - -void -winDisplayExitDialog(winPrivScreenPtr pScreenPriv) +int +GetLiveClients (winPrivScreenPtr pScreenPriv)  {      int i;      int liveClients = 0; @@ -260,6 +256,20 @@ winDisplayExitDialog(winPrivScreenPtr pScreenPriv)      if (liveClients < 0)          liveClients = 0; +  pScreenPriv->iConnectedClients = liveClients; + +  return liveClients; +} + +/* + * Display the Exit dialog box + */ + +void +winDisplayExitDialog (winPrivScreenPtr pScreenPriv) +{ +  int liveClients = GetLiveClients(pScreenPriv); +      /* Don't show the exit confirmation dialog if SilentExit & no clients,         or ForceExit, is enabled */      if ((pref.fSilentExit && liveClients <= 0) || pref.fForceExit) { @@ -271,8 +281,6 @@ winDisplayExitDialog(winPrivScreenPtr pScreenPriv)          return;      } -    pScreenPriv->iConnectedClients = liveClients; -      /* Check if dialog already exists */      if (g_hDlgExit != NULL) {          /* Dialog box already exists, display it */ @@ -411,9 +419,9 @@ winDisplayDepthChangeDialog(winPrivScreenPtr pScreenPriv)      /* Show the dialog box */      ShowWindow(g_hDlgDepthChange, SW_SHOW); -    ErrorF("winDisplayDepthChangeDialog - DialogBox returned: %d\n", +    winDebug ("winDisplayDepthChangeDialog - DialogBox returned: %d\n",             (int) g_hDlgDepthChange); -    ErrorF("winDisplayDepthChangeDialog - GetLastError: %d\n", +    winDebug ("winDisplayDepthChangeDialog - GetLastError: %d\n",             (int) GetLastError());      /* Minimize the display window */ @@ -433,51 +441,41 @@ winChangeDepthDlgProc(HWND hwndDialog, UINT message,      static winScreenInfo *s_pScreenInfo = NULL;      static ScreenPtr s_pScreen = NULL; -#if CYGDEBUG      winDebug("winChangeDepthDlgProc\n"); -#endif      /* Branch on message type */      switch (message) {      case WM_INITDIALOG: -#if CYGDEBUG          winDebug("winChangeDepthDlgProc - WM_INITDIALOG\n"); -#endif          /* Store pointers to private structures for future use */          s_pScreenPriv = (winPrivScreenPtr) lParam;          s_pScreenInfo = s_pScreenPriv->pScreenInfo;          s_pScreen = s_pScreenInfo->pScreen; -#if CYGDEBUG          winDebug("winChangeDepthDlgProc - WM_INITDIALOG - s_pScreenPriv: %08x, "                   "s_pScreenInfo: %08x, s_pScreen: %08x\n",                   s_pScreenPriv, s_pScreenInfo, s_pScreen); -#endif -#if CYGDEBUG          winDebug("winChangeDepthDlgProc - WM_INITDIALOG - orig bpp: %d, "                   "current bpp: %d\n",                   s_pScreenInfo->dwBPP,                   GetDeviceCaps(s_pScreenPriv->hdcScreen, BITSPIXEL)); -#endif          winInitDialog(hwndDialog);          return TRUE;      case WM_DISPLAYCHANGE: -#if CYGDEBUG          winDebug("winChangeDepthDlgProc - WM_DISPLAYCHANGE - orig bpp: %d, "                   "new bpp: %d\n",                   s_pScreenInfo->dwBPP,                   GetDeviceCaps(s_pScreenPriv->hdcScreen, BITSPIXEL)); -#endif          /* Dismiss the dialog if the display returns to the original depth */          if (GetDeviceCaps(s_pScreenPriv->hdcScreen, BITSPIXEL) ==              s_pScreenInfo->dwBPP) { -            ErrorF("winChangeDelthDlgProc - wParam == s_pScreenInfo->dwBPP\n"); +        	  winDebug ("winChangeDelthDlgProc - wParam == s_pScreenInfo->dwBPP\n");              /* Depth has been restored, dismiss dialog */              DestroyWindow(g_hDlgDepthChange); @@ -504,7 +502,7 @@ winChangeDepthDlgProc(HWND hwndDialog, UINT message,          break;      case WM_CLOSE: -        ErrorF("winChangeDepthDlgProc - WM_CLOSE\n"); +        winDebug ("winChangeDepthDlgProc - WM_CLOSE\n");          DestroyWindow(g_hDlgAbout);          g_hDlgAbout = NULL; @@ -565,16 +563,12 @@ winAboutDlgProc(HWND hwndDialog, UINT message, WPARAM wParam, LPARAM lParam)      static winScreenInfo *s_pScreenInfo = NULL;      static ScreenPtr s_pScreen = NULL; -#if CYGDEBUG      winDebug("winAboutDlgProc\n"); -#endif      /* Branch on message type */      switch (message) {      case WM_INITDIALOG: -#if CYGDEBUG          winDebug("winAboutDlgProc - WM_INITDIALOG\n"); -#endif          /* Store pointers to private structures for future use */          s_pScreenPriv = (winPrivScreenPtr) lParam; @@ -609,7 +603,7 @@ winAboutDlgProc(HWND hwndDialog, UINT message, WPARAM wParam, LPARAM lParam)          switch (LOWORD(wParam)) {          case IDOK:          case IDCANCEL: -            ErrorF("winAboutDlgProc - WM_COMMAND - IDOK or IDCANCEL\n"); +        	  winDebug ("winAboutDlgProc - WM_COMMAND - IDOK or IDCANCEL\n");              DestroyWindow(g_hDlgAbout);              g_hDlgAbout = NULL; | 
