diff options
Diffstat (limited to 'xorg-server/hw/xwin/InitOutput.c')
| -rw-r--r-- | xorg-server/hw/xwin/InitOutput.c | 113 | 
1 files changed, 67 insertions, 46 deletions
| diff --git a/xorg-server/hw/xwin/InitOutput.c b/xorg-server/hw/xwin/InitOutput.c index 4a601b222..2a1635c92 100644 --- a/xorg-server/hw/xwin/InitOutput.c +++ b/xorg-server/hw/xwin/InitOutput.c @@ -35,12 +35,10 @@ from The Open Group.  #include "winmsg.h"  #include "winconfig.h"  #include "winprefs.h" -#ifdef XWIN_CLIPBOARD -#include "X11/Xlocale.h" -#endif  #ifdef DPMSExtension  #include "dpmsproc.h"  #endif +#include <locale.h>  #ifdef __CYGWIN__  #include <mntent.h>  #endif @@ -48,13 +46,14 @@ from The Open Group.  #include "xkbsrv.h"  #endif  #ifdef RELOCATE_PROJECTROOT +#undef Status  #include <shlobj.h> -typedef WINAPI HRESULT (*SHGETFOLDERPATHPROC)( +typedef HRESULT  (__stdcall *  SHGETFOLDERPATHPROC)(      HWND hwndOwner,      int nFolder,      HANDLE hToken,      DWORD dwFlags, -    LPTSTR pszPath +    LPSTR pszPath  );  #endif @@ -136,6 +135,7 @@ winClipboardShutdown (void)        /* Synchronously destroy the clipboard window */        if (g_hwndClipboard != NULL)  	{ +	  g_fClipboardStarted=FALSE; /* This is to avoid dead-locls caused by the clipboard thread still doing some stuff */  	  SendMessage (g_hwndClipboard, WM_DESTROY, 0, 0);  	  /* NOTE: g_hwndClipboard is set to NULL in winclipboardthread.c */  	} @@ -145,25 +145,11 @@ winClipboardShutdown (void)        /* Wait for the clipboard thread to exit */        pthread_join (g_ptClipboardProc, NULL); -      g_fClipboardLaunched = FALSE; -      g_fClipboardStarted = FALSE; -        winDebug ("winClipboardShutdown - Clipboard thread has exited.\n");      }  }  #endif -void -ddxPushProviders(void) -{ -#ifdef XWIN_GLX_WINDOWS -  if (g_fNativeGl) -    { -      /* install the native GL provider */ -      glxWinPushNativeProvider(); -    } -#endif -}  #if defined(DDXBEFORERESET)  /* @@ -189,9 +175,7 @@ ddxGiveUp (enum ExitCode error)  {    int		i; -#if CYGDEBUG    winDebug ("ddxGiveUp\n"); -#endif    /* Perform per-screen deinitialization */    for (i = 0; i < g_iNumScreens; ++i) @@ -202,6 +186,9 @@ ddxGiveUp (enum ExitCode error)      }  #ifdef XWIN_MULTIWINDOW +  /* Unload libraries for taskbar grouping */ +  winTaskbarDestroy (); +    /* Notify the worker threads we're exiting */    winDeinitMultiWindowWM ();  #endif @@ -246,9 +233,7 @@ ddxGiveUp (enum ExitCode error)  void  AbortDDX (enum ExitCode error)  { -#if CYGDEBUG    winDebug ("AbortDDX\n"); -#endif    ddxGiveUp (error);  } @@ -333,8 +318,10 @@ winCheckMount(void)      return;    } - if (!binary)  -   winMsg(X_WARNING, "/tmp mounted in textmode\n"); +#ifdef WINDBG +  if (!binary)  +    winDebug("/tmp mounted in textmode\n"); +#endif  }  #else  static void @@ -386,7 +373,17 @@ winFixupPaths (void)  #ifdef READ_FONTDIRS      {          /* Open fontpath configuration file */ +#if defined WIN32 && defined __MINGW32__ +        static Bool once = False; +        char buffer[MAX_PATH]; +        snprintf(buffer, sizeof(buffer), "%s\\font-dirs", basedir); +        buffer[sizeof(buffer)-1] = 0; +        FILE *fontdirs = fopen(buffer, "rt"); +        if (once) fontdirs = NULL; +        else once = True; +#else          FILE *fontdirs = fopen(ETCX11DIR "/font-dirs", "rt"); +#endif          if (fontdirs != NULL)          {              char buffer[256]; @@ -559,7 +556,7 @@ winFixupPaths (void)      }  #endif /* RELOCATE_PROJECTROOT */      if (changed_fontpath) -        winMsg (font_from, "FontPath set to \"%s\"\n", defaultFontPath); +        winDebug ("FontPath set to \"%s\"\n", defaultFontPath);  #ifdef RELOCATE_PROJECTROOT      if (getenv("XKEYSYMDB") == NULL) @@ -586,6 +583,14 @@ winFixupPaths (void)          buffer[sizeof(buffer)-1] = 0;          putenv(buffer);      } +    if (getenv("XHOSTPREFIX") == NULL) +    { +        char buffer[MAX_PATH]; +        snprintf(buffer, sizeof(buffer), "XHOSTPREFIX=%s\\X", +                basedir); +        buffer[sizeof(buffer)-1] = 0; +        putenv(buffer); +    }      if (getenv("HOME") == NULL)      {          char buffer[MAX_PATH + 5]; @@ -597,7 +602,7 @@ winFixupPaths (void)              putenv(buffer);          } else          { -            winMsg (X_ERROR, "Can not determine HOME directory\n"); +            ErrorF ("Can not determine HOME directory\n");          }      }      if (!g_fLogFileChanged) { @@ -606,16 +611,17 @@ winFixupPaths (void)          if (size && size < sizeof(buffer))          {              snprintf(buffer + size, sizeof(buffer) - size,  -                    "XWin.%s.log", display);  +                    "VCXSrv.%s.log", display);               buffer[sizeof(buffer)-1] = 0;              g_pszLogFile = buffer; -            winMsg (X_DEFAULT, "Logfile set to \"%s\"\n", g_pszLogFile); +            GetLongPathName(buffer, buffer, MAX_PATH); +            winDebug ("Logfile set to \"%s\"\n", g_pszLogFile);          }      }      {          static char xkbbasedir[MAX_PATH]; -        snprintf(xkbbasedir, sizeof(xkbbasedir), "%s\\xkb", basedir); +        snprintf(xkbbasedir, sizeof(xkbbasedir), "%s\\xkbdata", basedir);          if (sizeof(xkbbasedir) > 0)              xkbbasedir[sizeof(xkbbasedir)-1] = 0;          XkbBaseDirectory = xkbbasedir; @@ -691,7 +697,7 @@ OsVendorInit (void)                  if (reportOnce)                    {                      reportOnce = FALSE; -                    winMsg(X_PROBED, "Windows reports only %d mouse buttons, defaulting to -emulate3buttons\n", mouseButtons); +                    winDebug("Windows reports only %d mouse buttons, defaulting to -emulate3buttons\n", mouseButtons);                    }                }              else @@ -703,6 +709,7 @@ OsVendorInit (void)    }  } +  static void  winUseMsg (void)  { @@ -714,6 +721,10 @@ winUseMsg (void)  #ifdef XWIN_CLIPBOARD    ErrorF ("-[no]clipboard\n"  	  "\tEnable [disable] the clipboard integration. Default is enabled.\n"); +  ErrorF ("-[no]clipboardprimary\n" +	  "\t[Do not] map the PRIMARY selection to the windows clipboard.\n" +          "\tThe CLIPBOARD selection is always mapped if -clipboard is enabled.\n" +          "\tDefault is mapped.\n");  #endif    ErrorF ("-clipupdates num_boxes\n" @@ -765,7 +776,7 @@ winUseMsg (void)    ErrorF ("-ignoreinput\n"  	  "\tIgnore keyboard and mouse input.\n"); -#ifdef XWIN_MULTIWINDOWEXTWM +#ifdef XWIN_MULTIWINDOWINTWM    ErrorF ("-internalwm\n"  	  "\tRun the internal window manager.\n");  #endif @@ -825,7 +836,7 @@ winUseMsg (void)    ErrorF ("-resize=none|scrollbars|randr"  	  "\tIn windowed mode, [don't] allow resizing of the window. 'scrollbars'\n"  	  "\tmode gives the window scrollbars as needed, 'randr' mode uses the RANR\n" -	  "\textension to resize the X screen.\n"); +	  "\textension to resize the X screen.  'randr' is the default.\n");    ErrorF ("-rootless\n"  	  "\tRun the server in rootless mode.\n"); @@ -857,10 +868,11 @@ winUseMsg (void)    ErrorF ("-[no]unixkill\n"            "\tCtrl+Alt+Backspace exits the X Server.\n"); -#ifdef XWIN_GLX_WINDOWS    ErrorF ("-[no]wgl\n"  	  "\tEnable the GLX extension to use the native Windows WGL interface for accelerated OpenGL\n"); -#endif + +  ErrorF ("-swrastwgl\n" +	  "\tEnable the GLX extension to use the native Windows WGL interface based on the swrast interface for accelerated OpenGL\n");    ErrorF ("-[no]winkill\n"            "\tAlt+F4 exits the X Server.\n"); @@ -922,9 +934,7 @@ InitOutput (ScreenInfo *screenInfo, int argc, char *argv[])    /* Log the command line */    winLogCommandLine (argc, argv); -#if CYGDEBUG    winDebug ("InitOutput\n"); -#endif    /* Validate command-line arguments */    if (serverGeneration == 1 && !winValidateArgs ()) @@ -945,11 +955,8 @@ InitOutput (ScreenInfo *screenInfo, int argc, char *argv[])  #ifdef XWIN_XF86CONFIG    /* Try to read the xorg.conf-style configuration file */    if (!winReadConfigfile ()) -    winErrorFVerb (1, "InitOutput - Error reading config file\n"); +    ErrorF ("InitOutput - Error reading config file\n");  #else -  winMsg(X_INFO, "xorg.conf is not supported\n"); -  winMsg(X_INFO, "See http://x.cygwin.com/docs/faq/cygwin-x-faq.html " -         "for more information\n");    winConfigFiles ();  #endif @@ -975,6 +982,11 @@ InitOutput (ScreenInfo *screenInfo, int argc, char *argv[])    /* Detect supported engines */    winDetectSupportedEngines (); +#ifdef XWIN_MULTIWINDOW +  /* Load libraries for taskbar grouping */ +  winTaskbarInit (); +#endif +    /* Store the instance handle */    g_hInstance = GetModuleHandle (NULL); @@ -1001,13 +1013,22 @@ InitOutput (ScreenInfo *screenInfo, int argc, char *argv[])         * setlocale applies to all threads in the current process.         * Apply locale specified in LANG environment variable.         */ -      setlocale (LC_ALL, ""); +      if (!setlocale (LC_ALL, "")) +        { +          ErrorF ("setlocale failed.\n"); +        } + +      /* See if X supports the current locale */ +      if (XSupportsLocale () == FALSE) +        { +          ErrorF ("Warning: Locale not supported by X, falling back to 'C' locale.\n"); +          setlocale(LC_ALL, "C"); +        } +      }  #endif -#if CYGDEBUG || YES    winDebug ("InitOutput - Returning.\n"); -#endif  } @@ -1030,7 +1051,7 @@ winCheckDisplayNumber (void)    /* Check display range */    nDisp = atoi (display); -  if (nDisp < 0 || nDisp > 65535) +  if (nDisp < 0 || nDisp > 59535)      {        ErrorF ("winCheckDisplayNumber - Bad display number: %d\n", nDisp);        return FALSE; @@ -1077,7 +1098,7 @@ winCheckDisplayNumber (void)    if (GetLastError () == ERROR_ALREADY_EXISTS)      {        ErrorF ("winCheckDisplayNumber - " -	      PROJECT_NAME " is already running on display %d\n", +	      "VCXsrv, Xming or Cygwin/X is already running on display %d\n",  	      nDisp);        return FALSE;      } | 
