diff options
Diffstat (limited to 'xorg-server/hw/xwin/InitOutput.c')
| -rw-r--r-- | xorg-server/hw/xwin/InitOutput.c | 116 | 
1 files changed, 77 insertions, 39 deletions
| diff --git a/xorg-server/hw/xwin/InitOutput.c b/xorg-server/hw/xwin/InitOutput.c index b1bc551c2..d86711100 100644 --- a/xorg-server/hw/xwin/InitOutput.c +++ b/xorg-server/hw/xwin/InitOutput.c @@ -47,14 +47,16 @@ from The Open Group.  #if defined(WIN32)
  #include "xkbsrv.h"
  #endif
 +
  #ifdef RELOCATE_PROJECTROOT
 +#undef Status
  #include <shlobj.h>
 -typedef HRESULT (*SHGETFOLDERPATHPROC)(
 +typedef HRESULT  (__stdcall *  SHGETFOLDERPATHPROC)(
      HWND hwndOwner,
      int nFolder,
      HANDLE hToken,
      DWORD dwFlags,
 -    LPTSTR pszPath
 +    LPSTR pszPath
  );
  #endif
 @@ -69,7 +71,7 @@ extern int			g_iLastScreen;  extern char *			g_pszCommandLine;
  extern Bool			g_fSilentFatalError;
 -extern char *			g_pszLogFile;
 +extern const char *			g_pszLogFile;
  extern Bool			g_fLogFileChanged;
  extern int			g_iLogVerbose;
  Bool				g_fLogInited;
 @@ -99,8 +101,8 @@ extern HMODULE			g_hmodCommonControls;  extern FARPROC			g_fpTrackMouseEvent;
  extern Bool			g_fNoHelpMessageBox;                     
  extern Bool			g_fSilentDupError;                     
 -  
 -  
 +extern Bool                     g_fNativeGl;
 +
  /*
   * Function prototypes
   */
 @@ -135,6 +137,9 @@ const char *  winGetBaseDir(void);
  #endif
 +static
 +void glx_debugging(void);
 +
  /*
   * For the depth 24 pixmap we default to 32 bits per pixel, but
   * we change this pixmap format later if we detect that the display
 @@ -181,9 +186,6 @@ 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");
      }
  }
 @@ -214,9 +216,7 @@ ddxGiveUp (void)  {
    int		i;
 -#if CYGDEBUG
    winDebug ("ddxGiveUp\n");
 -#endif
    /* Perform per-screen deinitialization */
    for (i = 0; i < g_iNumScreens; ++i)
 @@ -244,7 +244,7 @@ ddxGiveUp (void)  #endif
    if (!g_fLogInited) {
 -    LogInit (g_pszLogFile, NULL);
 +    g_pszLogFile = LogInit (g_pszLogFile, NULL);
      g_fLogInited = TRUE;
    }  
    LogClose ();
 @@ -288,9 +288,7 @@ ddxGiveUp (void)  void
  AbortDDX (void)
  {
 -#if CYGDEBUG
    winDebug ("AbortDDX\n");
 -#endif
    ddxGiveUp ();
  }
 @@ -375,8 +373,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
 @@ -428,7 +428,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];
 @@ -601,7 +611,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)
 @@ -628,6 +638,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)
      {
          HMODULE shfolder;
 @@ -654,7 +672,7 @@ winFixupPaths (void)              putenv(buffer);
          } else
          {
 -            winMsg (X_ERROR, "Can not determine HOME directory\n");
 +            ErrorF ("Can not determine HOME directory\n");
          } 
          if (shfolder != NULL)
              FreeLibrary(shfolder);
 @@ -665,16 +683,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;
 @@ -689,9 +708,6 @@ OsVendorInit (void)    /* Re-initialize global variables on server reset */
    winInitializeGlobals ();
 -  LogInit (NULL, NULL);
 -  LogSetParameter (XLOG_VERBOSITY, g_iLogVerbose);
 -
    winFixupPaths();
  #ifdef DDXOSVERRORF
 @@ -706,7 +722,7 @@ OsVendorInit (void)       * avoid the second call 
       */  
      g_fLogInited = TRUE;
 -    LogInit (g_pszLogFile, NULL);
 +    g_pszLogFile = LogInit (g_pszLogFile, NULL);
    } 
    LogSetParameter (XLOG_FLUSH, 1);
    LogSetParameter (XLOG_VERBOSITY, g_iLogVerbose);
 @@ -792,6 +808,9 @@ winUseMsg (void)  	  "\t\t1 - Shadow GDI\n"
  	  "\t\t2 - Shadow DirectDraw\n"
  	  "\t\t4 - Shadow DirectDraw4 Non-Locking\n"
 +#ifdef XWIN_PRIMARYFB
 +	  "\t\t8 - Primary DirectDraw\n"
 +#endif
  #ifdef XWIN_NATIVEGDI
  	  "\t\t16 - Native GDI - experimental\n"
  #endif
 @@ -914,6 +933,11 @@ winUseMsg (void)    ErrorF ("-xkbvariant XKBVariant\n"
  	  "\tEquivalent to XKBVariant in XF86Config files.\n"
  	  "\tFor example: -xkbvariant nodeadkeys\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
  }
  /* See Porting Layer Definition - p. 57 */
 @@ -927,7 +951,7 @@ ddxUseMsg(void)    /* Log file will not be opened for UseMsg unless we open it now */
    if (!g_fLogInited) {
 -    LogInit (g_pszLogFile, NULL);
 +    g_pszLogFile = LogInit (g_pszLogFile, NULL);
      g_fLogInited = TRUE;
    }  
    LogClose ();
 @@ -935,9 +959,9 @@ ddxUseMsg(void)    /* Notify user where UseMsg text can be found.*/
    if (!g_fNoHelpMessageBox)
      winMessageBoxF ("The " PROJECT_NAME " help text has been printed to "
 -		  "/tmp/XWin.log.\n"
 -		  "Please open /tmp/XWin.log to read the help text.\n",
 -		  MB_ICONINFORMATION);
 +		  "%s.\n"
 +		  "Please open %s to read the help text.\n",
 +		  MB_ICONINFORMATION, g_pszLogFile, g_pszLogFile);
  }
  /* See Porting Layer Definition - p. 20 */
 @@ -955,9 +979,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 ())
 @@ -978,11 +1000,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
 @@ -1016,7 +1035,7 @@ InitOutput (ScreenInfo *screenInfo, int argc, char *argv[])  					 "_TrackMouseEvent");
    if (g_fpTrackMouseEvent == NULL)
      {
 -      winErrorFVerb (1, "InitOutput - Could not get pointer to function\n"
 +      ErrorF ("InitOutput - Could not get pointer to function\n"
  	      "\t_TrackMouseEvent in comctl32.dll.  Try installing\n"
  	      "\tInternet Explorer 3.0 or greater if you have not\n"
  	      "\talready.\n");
 @@ -1056,12 +1075,12 @@ InitOutput (ScreenInfo *screenInfo, int argc, char *argv[])         * Apply locale specified in LANG environment variable.
         */
        setlocale (LC_ALL, "");
 +
 +      glx_debugging();
      }
  #endif
 -#if CYGDEBUG || YES
    winDebug ("InitOutput - Returning.\n");
 -#endif
  }
 @@ -1084,7 +1103,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;
 @@ -1131,10 +1150,29 @@ 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;
      }
    return TRUE;
  }
 +
 +/* GLX debugging helpers */
 +#include <../glx/glapi.h>
 +
 +static
 +void warn_func(void * p1, const char *format, ...) {
 +  va_list v;
 +  va_start(v, format);
 +  vfprintf(stderr, format, v);
 +  va_end(v);
 +  fprintf(stderr,"\n");
 +}
 +
 +static
 +void glx_debugging(void)
 +{
 +  _glapi_set_warning_func(warn_func);
 +  _glapi_noop_enable_warnings(TRUE);
 +}
 | 
