Merge remote-tracking branch 'jturney/master'
This commit is contained in:
commit
54a1d4db82
|
@ -15,7 +15,7 @@ if XWIN_GLX_WINDOWS
|
||||||
GLX_DIR = glx
|
GLX_DIR = glx
|
||||||
DEFS_GLX_WINDOWS = -DXWIN_GLX_WINDOWS
|
DEFS_GLX_WINDOWS = -DXWIN_GLX_WINDOWS
|
||||||
XWIN_GLX_LIBS = $(top_builddir)/hw/xwin/glx/libXwinGLX.la
|
XWIN_GLX_LIBS = $(top_builddir)/hw/xwin/glx/libXwinGLX.la
|
||||||
XWIN_GLX_LINK_FLAGS = -lopengl32
|
XWIN_GLX_SYS_LIBS = -lopengl32
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if XWIN_MULTIWINDOW
|
if XWIN_MULTIWINDOW
|
||||||
|
@ -27,7 +27,7 @@ SRCS_MULTIWINDOW = \
|
||||||
propertystore.h \
|
propertystore.h \
|
||||||
winSetAppUserModelID.c
|
winSetAppUserModelID.c
|
||||||
DEFS_MULTIWINDOW = -DXWIN_MULTIWINDOW
|
DEFS_MULTIWINDOW = -DXWIN_MULTIWINDOW
|
||||||
MULTIWINDOW_LIBS = -lshlwapi -lole32
|
MULTIWINDOW_SYS_LIBS = -lshlwapi -lole32
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if XWIN_MULTIWINDOWEXTWM
|
if XWIN_MULTIWINDOWEXTWM
|
||||||
|
@ -126,6 +126,8 @@ SRCS = InitInput.c \
|
||||||
winprefs.h \
|
winprefs.h \
|
||||||
winresource.h \
|
winresource.h \
|
||||||
winwindow.h \
|
winwindow.h \
|
||||||
|
windisplay.c \
|
||||||
|
windisplay.h \
|
||||||
XWin.rc \
|
XWin.rc \
|
||||||
$(top_srcdir)/mi/miinitext.c \
|
$(top_srcdir)/mi/miinitext.c \
|
||||||
$(SRCS_CLIPBOARD) \
|
$(SRCS_CLIPBOARD) \
|
||||||
|
@ -150,11 +152,28 @@ XWin_SOURCES = $(SRCS)
|
||||||
AM_CPPFLAGS = -I$(top_srcdir)/miext/rootless
|
AM_CPPFLAGS = -I$(top_srcdir)/miext/rootless
|
||||||
|
|
||||||
XWIN_SYS_LIBS += -ldxguid
|
XWIN_SYS_LIBS += -ldxguid
|
||||||
XWIN_LIBS += $(top_builddir)/pseudoramiX/libPseudoramiX.la \
|
|
||||||
|
XWIN_LIBS += \
|
||||||
|
$(top_builddir)/pseudoramiX/libPseudoramiX.la \
|
||||||
$(top_builddir)/Xext/libXextdpmsstubs.la \
|
$(top_builddir)/Xext/libXextdpmsstubs.la \
|
||||||
$(top_builddir)/Xi/libXistubs.la
|
$(top_builddir)/Xi/libXistubs.la
|
||||||
XWin_DEPENDENCIES = $(MULTIWINDOWEXTWM_LIBS) $(XWIN_GLX_LIBS) $(XWIN_LIBS) $(XSERVER_LIBS)
|
|
||||||
XWin_LDADD = $(MULTIWINDOW_LIBS) $(MULTIWINDOWEXTWM_LIBS) $(XWIN_GLX_LIBS) $(XWIN_GLX_LINK_FLAGS) $(XWIN_LIBS) $(MAIN_LIB) $(XSERVER_LIBS) $(XSERVER_SYS_LIBS) $(XWIN_SYS_LIBS)
|
XWin_DEPENDENCIES = \
|
||||||
|
$(MULTIWINDOWEXTWM_LIBS) \
|
||||||
|
$(XWIN_GLX_LIBS) \
|
||||||
|
$(XWIN_LIBS) \
|
||||||
|
$(XSERVER_LIBS)
|
||||||
|
|
||||||
|
XWin_LDADD = \
|
||||||
|
$(MULTIWINDOWEXTWM_LIBS) \
|
||||||
|
$(XWIN_GLX_LIBS) \
|
||||||
|
$(XWIN_LIBS) \
|
||||||
|
$(XSERVER_LIBS) \
|
||||||
|
$(XWIN_GLX_SYS_LIBS) \
|
||||||
|
$(XSERVER_SYS_LIBS) \
|
||||||
|
$(XWIN_SYS_LIBS) \
|
||||||
|
$(MULTIWINDOW_SYS_LIBS)
|
||||||
|
|
||||||
XWin_LDFLAGS = -mwindows -Wl,--disable-stdcall-fixup $(LD_EXPORT_SYMBOLS_FLAG)
|
XWin_LDFLAGS = -mwindows -Wl,--disable-stdcall-fixup $(LD_EXPORT_SYMBOLS_FLAG)
|
||||||
|
|
||||||
|
|
||||||
|
|
5
hw/xwin/glx/.gitignore
vendored
5
hw/xwin/glx/.gitignore
vendored
|
@ -1,3 +1,6 @@
|
||||||
# ignore generated files
|
# ignore generated files
|
||||||
generated_gl_wrappers.c
|
diag.txt
|
||||||
|
generated_gl_shim.c
|
||||||
|
generated_gl_thunks.c
|
||||||
|
generated_gl_thunks.def
|
||||||
generated_wgl_wrappers.c
|
generated_wgl_wrappers.c
|
||||||
|
|
|
@ -100,13 +100,16 @@ reg = Registry()
|
||||||
tree = etree.parse(regFilename)
|
tree = etree.parse(regFilename)
|
||||||
reg.loadElementTree(tree)
|
reg.loadElementTree(tree)
|
||||||
|
|
||||||
allVersions = '.*'
|
if shim:
|
||||||
|
versions = '1\.[012]'
|
||||||
|
else:
|
||||||
|
versions = '.*'
|
||||||
|
|
||||||
genOpts = CGeneratorOptions(
|
genOpts = CGeneratorOptions(
|
||||||
apiname = prefix,
|
apiname = prefix,
|
||||||
profile = 'compatibility',
|
profile = 'compatibility',
|
||||||
versions = allVersions,
|
versions = versions,
|
||||||
emitversions = allVersions,
|
emitversions = versions,
|
||||||
defaultExtensions = prefix, # Default extensions for GL
|
defaultExtensions = prefix, # Default extensions for GL
|
||||||
protectFile = protect,
|
protectFile = protect,
|
||||||
protectFeature = protect,
|
protectFeature = protect,
|
||||||
|
@ -257,7 +260,7 @@ class ThunkOutputGenerator(OutputGenerator):
|
||||||
pass
|
pass
|
||||||
def beginFeature(self, interface, emit):
|
def beginFeature(self, interface, emit):
|
||||||
OutputGenerator.beginFeature(self, interface, emit)
|
OutputGenerator.beginFeature(self, interface, emit)
|
||||||
self.OldVersion = self.featureName.startswith('GL_VERSION_1_0') or self.featureName.startswith('GL_VERSION_1_1')
|
self.OldVersion = (self.featureName in ['GL_VERSION_1_0', 'GL_VERSION_1_1'])
|
||||||
def endFeature(self):
|
def endFeature(self):
|
||||||
OutputGenerator.endFeature(self)
|
OutputGenerator.endFeature(self)
|
||||||
def genType(self, typeinfo, name):
|
def genType(self, typeinfo, name):
|
||||||
|
@ -355,7 +358,7 @@ class ShimOutputGenerator(OutputGenerator):
|
||||||
pass
|
pass
|
||||||
def beginFeature(self, interface, emit):
|
def beginFeature(self, interface, emit):
|
||||||
OutputGenerator.beginFeature(self, interface, emit)
|
OutputGenerator.beginFeature(self, interface, emit)
|
||||||
self.OldVersion = self.featureName.startswith('GL_VERSION_1_0') or self.featureName.startswith('GL_VERSION_1_1') or self.featureName.startswith('GL_VERSION_1_2') or self.featureName.startswith('GL_ARB_imaging') or self.featureName.startswith('GL_ARB_multitexture') or self.featureName.startswith('GL_ARB_texture_compression')
|
self.OldVersion = (self.featureName in ['GL_VERSION_1_0', 'GL_VERSION_1_1', 'GL_VERSION_1_2', 'GL_ARB_imaging', 'GL_ARB_multitexture', 'GL_ARB_texture_compression'])
|
||||||
def endFeature(self):
|
def endFeature(self):
|
||||||
OutputGenerator.endFeature(self)
|
OutputGenerator.endFeature(self)
|
||||||
def genType(self, typeinfo, name):
|
def genType(self, typeinfo, name):
|
||||||
|
|
|
@ -28,6 +28,9 @@
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifndef GLWINDOWS_H
|
||||||
|
#define GLWINDOWS_H
|
||||||
|
|
||||||
#include <GL/gl.h>
|
#include <GL/gl.h>
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -53,3 +56,5 @@ int glWinSelectImplementation(int native);
|
||||||
#define GLWIN_TRACE_MSG(a, ...)
|
#define GLWIN_TRACE_MSG(a, ...)
|
||||||
#define GLWIN_DEBUG_MSG(a, ...)
|
#define GLWIN_DEBUG_MSG(a, ...)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
|
@ -738,9 +738,6 @@ glxWinScreenProbe(ScreenPtr pScreen)
|
||||||
|
|
||||||
__glXScreenInit(&screen->base, pScreen);
|
__glXScreenInit(&screen->base, pScreen);
|
||||||
|
|
||||||
// Override the GL extensions string set by __glXScreenInit()
|
|
||||||
screen->base.GLextensions = strdup(gl_extensions);
|
|
||||||
|
|
||||||
// Generate the GLX extensions string (overrides that set by __glXScreenInit())
|
// Generate the GLX extensions string (overrides that set by __glXScreenInit())
|
||||||
{
|
{
|
||||||
unsigned int buffer_size =
|
unsigned int buffer_size =
|
||||||
|
@ -893,13 +890,6 @@ glxWinDrawableSwapBuffers(ClientPtr client, __GLXdrawable * base)
|
||||||
("glxWinSwapBuffers on drawable %p, last context %p (native ctx %p)",
|
("glxWinSwapBuffers on drawable %p, last context %p (native ctx %p)",
|
||||||
base, draw->drawContext, draw->drawContext->ctx);
|
base, draw->drawContext, draw->drawContext->ctx);
|
||||||
|
|
||||||
/*
|
|
||||||
draw->drawContext->base.drawPriv will not be set if the context is not current anymore,
|
|
||||||
but if it is, it should point to this drawable....
|
|
||||||
*/
|
|
||||||
assert((draw->drawContext->base.drawPriv == NULL) ||
|
|
||||||
(draw->drawContext->base.drawPriv == base));
|
|
||||||
|
|
||||||
dc = glxWinMakeDC(draw->drawContext, draw, &dc, &hwnd);
|
dc = glxWinMakeDC(draw->drawContext, draw, &dc, &hwnd);
|
||||||
if (dc == NULL)
|
if (dc == NULL)
|
||||||
return GL_FALSE;
|
return GL_FALSE;
|
||||||
|
@ -1123,7 +1113,6 @@ glxWinSetPixelFormat(__GLXWinContext * gc, HDC hdc, int bppOverride,
|
||||||
fbConfigToPixelFormatIndex(hdc, gc->base.config,
|
fbConfigToPixelFormatIndex(hdc, gc->base.config,
|
||||||
drawableTypeOverride, winScreen);
|
drawableTypeOverride, winScreen);
|
||||||
if (pixelFormat == 0) {
|
if (pixelFormat == 0) {
|
||||||
ErrorF("wglChoosePixelFormat error: %s\n", glxWinErrorMessage());
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1306,7 +1295,7 @@ glxWinDeferredCreateContext(__GLXWinContext * gc, __GLXWinDrawable * draw)
|
||||||
glxWinScreen *winScreen;
|
glxWinScreen *winScreen;
|
||||||
int pixelFormat;
|
int pixelFormat;
|
||||||
|
|
||||||
// XXX: which DC are supposed to use???
|
// XXX: which DC are we supposed to use???
|
||||||
HDC screenDC = GetDC(NULL);
|
HDC screenDC = GetDC(NULL);
|
||||||
|
|
||||||
if (!(gc->base.config->drawableType & GLX_PBUFFER_BIT)) {
|
if (!(gc->base.config->drawableType & GLX_PBUFFER_BIT)) {
|
||||||
|
@ -1319,10 +1308,8 @@ glxWinDeferredCreateContext(__GLXWinContext * gc, __GLXWinDrawable * draw)
|
||||||
|
|
||||||
pixelFormat =
|
pixelFormat =
|
||||||
fbConfigToPixelFormatIndex(screenDC, gc->base.config,
|
fbConfigToPixelFormatIndex(screenDC, gc->base.config,
|
||||||
GLX_DRAWABLE_PBUFFER, winScreen);
|
GLX_PBUFFER_BIT, winScreen);
|
||||||
if (pixelFormat == 0) {
|
if (pixelFormat == 0) {
|
||||||
ErrorF("wglChoosePixelFormat error: %s\n",
|
|
||||||
glxWinErrorMessage());
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1761,7 +1748,7 @@ fbConfigToPixelFormatIndex(HDC hdc, __GLXconfig * mode,
|
||||||
SET_ATTR_VALUE(WGL_SWAP_METHOD_ARB, WGL_SWAP_EXCHANGE_ARB);
|
SET_ATTR_VALUE(WGL_SWAP_METHOD_ARB, WGL_SWAP_EXCHANGE_ARB);
|
||||||
|
|
||||||
if (mode->swapMethod == GLX_SWAP_COPY_OML)
|
if (mode->swapMethod == GLX_SWAP_COPY_OML)
|
||||||
SET_ATTR_VALUE(WGL_SWAP_COPY_ARB, TRUE);
|
SET_ATTR_VALUE(WGL_SWAP_METHOD_ARB, WGL_SWAP_COPY_ARB);
|
||||||
|
|
||||||
// XXX: this should probably be the other way around, but that messes up drawableTypeOverride
|
// XXX: this should probably be the other way around, but that messes up drawableTypeOverride
|
||||||
if (mode->visualRating == GLX_SLOW_VISUAL_EXT)
|
if (mode->visualRating == GLX_SLOW_VISUAL_EXT)
|
||||||
|
|
|
@ -51,7 +51,7 @@ winGetWindowInfo(WindowPtr pWin)
|
||||||
|
|
||||||
if (pWinPriv->hWnd == NULL) {
|
if (pWinPriv->hWnd == NULL) {
|
||||||
winCreateWindowsWindow(pWin);
|
winCreateWindowsWindow(pWin);
|
||||||
ErrorF("winGetWindowInfo: forcing window to exist...\n");
|
winDebug("winGetWindowInfo: forcing window to exist\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pWinPriv->hWnd != NULL) {
|
if (pWinPriv->hWnd != NULL) {
|
||||||
|
|
|
@ -38,6 +38,7 @@
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#include "winclipboard.h"
|
#include "winclipboard.h"
|
||||||
|
#include "windisplay.h"
|
||||||
#ifdef __CYGWIN__
|
#ifdef __CYGWIN__
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#endif
|
#endif
|
||||||
|
@ -157,7 +158,7 @@ winClipboardProc(void *pvNotUsed)
|
||||||
* for all screens on the display. That is why there is only
|
* for all screens on the display. That is why there is only
|
||||||
* one clipboard client thread.
|
* one clipboard client thread.
|
||||||
*/
|
*/
|
||||||
snprintf(szDisplay, 512, "127.0.0.1:%s.0", display);
|
winGetDisplayName(szDisplay, 0);
|
||||||
|
|
||||||
/* Print the display connection string */
|
/* Print the display connection string */
|
||||||
ErrorF("winClipboardProc - DISPLAY=%s\n", szDisplay);
|
ErrorF("winClipboardProc - DISPLAY=%s\n", szDisplay);
|
||||||
|
|
64
hw/xwin/windisplay.c
Normal file
64
hw/xwin/windisplay.c
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
/*
|
||||||
|
* File: windisplay.c
|
||||||
|
* Purpose: Retrieve server display name
|
||||||
|
*
|
||||||
|
* Copyright (C) Jon TURNEY 2009
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
* copy of this software and associated documentation files (the "Software"),
|
||||||
|
* to deal in the Software without restriction, including without limitation
|
||||||
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
|
* and/or sell copies of the Software, and to permit persons to whom the
|
||||||
|
* Software is furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice (including the next
|
||||||
|
* paragraph) shall be included in all copies or substantial portions of the
|
||||||
|
* Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
|
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
|
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
|
* DEALINGS IN THE SOFTWARE.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_XWIN_CONFIG_H
|
||||||
|
#include <xwin-config.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <opaque.h> // for display
|
||||||
|
#include "windisplay.h"
|
||||||
|
#include "winmsg.h"
|
||||||
|
|
||||||
|
#define XSERV_t
|
||||||
|
#define TRANS_SERVER
|
||||||
|
#include <X11/Xtrans/Xtrans.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
Generate a display name string referring to the display of this server,
|
||||||
|
using a transport we know is enabled
|
||||||
|
*/
|
||||||
|
|
||||||
|
void
|
||||||
|
winGetDisplayName(char *szDisplay, unsigned int screen)
|
||||||
|
{
|
||||||
|
if (_XSERVTransIsListening("local")) {
|
||||||
|
snprintf(szDisplay, 512, ":%s.%d", display, screen);
|
||||||
|
}
|
||||||
|
else if (_XSERVTransIsListening("inet")) {
|
||||||
|
snprintf(szDisplay, 512, "127.0.0.1:%s.%d", display, screen);
|
||||||
|
}
|
||||||
|
else if (_XSERVTransIsListening("inet6")) {
|
||||||
|
snprintf(szDisplay, 512, "::1:%s.%d", display, screen);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// this can't happen!
|
||||||
|
ErrorF("winGetDisplay: Don't know what to use for DISPLAY\n");
|
||||||
|
snprintf(szDisplay, 512, "localhost:%s.%d", display, screen);
|
||||||
|
}
|
||||||
|
|
||||||
|
winDebug("winGetDisplay: DISPLAY=%s\n", szDisplay);
|
||||||
|
}
|
34
hw/xwin/windisplay.h
Normal file
34
hw/xwin/windisplay.h
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
/*
|
||||||
|
* File: windisplay.h
|
||||||
|
* Purpose: Interface to retrieve server display name
|
||||||
|
*
|
||||||
|
* Copyright (C) Jon TURNEY 2009
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
* copy of this software and associated documentation files (the "Software"),
|
||||||
|
* to deal in the Software without restriction, including without limitation
|
||||||
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
|
* and/or sell copies of the Software, and to permit persons to whom the
|
||||||
|
* Software is furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice (including the next
|
||||||
|
* paragraph) shall be included in all copies or substantial portions of the
|
||||||
|
* Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
|
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
|
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
|
* DEALINGS IN THE SOFTWARE.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef WINDISPLAY_H
|
||||||
|
#define WINDISPLAY_H
|
||||||
|
|
||||||
|
void
|
||||||
|
winGetDisplayName(char *szDisplay, unsigned int screen);
|
||||||
|
|
||||||
|
#endif /* !WINDISPLAY_H */
|
|
@ -30,6 +30,8 @@
|
||||||
* Authors: Alexander Gottwald
|
* Authors: Alexander Gottwald
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <X11/Xwindows.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Function prototypes
|
* Function prototypes
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -61,6 +61,7 @@
|
||||||
#include "pixmapstr.h"
|
#include "pixmapstr.h"
|
||||||
#include "windowstr.h"
|
#include "windowstr.h"
|
||||||
#include "winglobals.h"
|
#include "winglobals.h"
|
||||||
|
#include "windisplay.h"
|
||||||
|
|
||||||
#ifdef XWIN_MULTIWINDOWEXTWM
|
#ifdef XWIN_MULTIWINDOWEXTWM
|
||||||
#include <X11/extensions/windowswmstr.h>
|
#include <X11/extensions/windowswmstr.h>
|
||||||
|
@ -1053,8 +1054,7 @@ winMultiWindowXMsgProc(void *pArg)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Setup the display connection string x */
|
/* Setup the display connection string x */
|
||||||
snprintf(pszDisplay,
|
winGetDisplayName(pszDisplay, (int) pProcArg->dwScreen);
|
||||||
512, "127.0.0.1:%s.%d", display, (int) pProcArg->dwScreen);
|
|
||||||
|
|
||||||
/* Print the display connection string */
|
/* Print the display connection string */
|
||||||
ErrorF("winMultiWindowXMsgProc - DISPLAY=%s\n", pszDisplay);
|
ErrorF("winMultiWindowXMsgProc - DISPLAY=%s\n", pszDisplay);
|
||||||
|
@ -1446,8 +1446,7 @@ winInitMultiWindowWM(WMInfoPtr pWMInfo, WMProcArgPtr pProcArg)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Setup the display connection string x */
|
/* Setup the display connection string x */
|
||||||
snprintf(pszDisplay,
|
winGetDisplayName(pszDisplay, (int) pProcArg->dwScreen);
|
||||||
512, "127.0.0.1:%s.%d", display, (int) pProcArg->dwScreen);
|
|
||||||
|
|
||||||
/* Print the display connection string */
|
/* Print the display connection string */
|
||||||
ErrorF("winInitMultiWindowWM - DISPLAY=%s\n", pszDisplay);
|
ErrorF("winInitMultiWindowWM - DISPLAY=%s\n", pszDisplay);
|
||||||
|
|
|
@ -44,6 +44,7 @@
|
||||||
#include <shellapi.h>
|
#include <shellapi.h>
|
||||||
|
|
||||||
#include "winprefs.h"
|
#include "winprefs.h"
|
||||||
|
#include "windisplay.h"
|
||||||
#include "winmultiwindowclass.h"
|
#include "winmultiwindowclass.h"
|
||||||
|
|
||||||
/* Where will the custom menu commands start counting from? */
|
/* Where will the custom menu commands start counting from? */
|
||||||
|
@ -712,15 +713,14 @@ LoadPreferences(void)
|
||||||
|
|
||||||
/* Setup a DISPLAY environment variable, need to allocate on heap */
|
/* Setup a DISPLAY environment variable, need to allocate on heap */
|
||||||
/* because putenv doesn't copy the argument... */
|
/* because putenv doesn't copy the argument... */
|
||||||
snprintf(szDisplay, 512, "DISPLAY=127.0.0.1:%s.0", display);
|
winGetDisplayName(szDisplay, 0);
|
||||||
szEnvDisplay = (char *) (malloc(strlen(szDisplay) + 1));
|
szEnvDisplay = (char *) (malloc(strlen(szDisplay) + strlen("DISPLAY=") + 1));
|
||||||
if (szEnvDisplay) {
|
if (szEnvDisplay) {
|
||||||
strcpy(szEnvDisplay, szDisplay);
|
snprintf(szEnvDisplay, 512, "DISPLAY=%s", szDisplay);
|
||||||
putenv(szEnvDisplay);
|
putenv(szEnvDisplay);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Replace any "%display%" in menu commands with display string */
|
/* Replace any "%display%" in menu commands with display string */
|
||||||
snprintf(szDisplay, 512, "127.0.0.1:%s.0", display);
|
|
||||||
for (i = 0; i < pref.menuItems; i++) {
|
for (i = 0; i < pref.menuItems; i++) {
|
||||||
for (j = 0; j < pref.menu[i].menuItems; j++) {
|
for (j = 0; j < pref.menu[i].menuItems; j++) {
|
||||||
if (pref.menu[i].menuItem[j].cmd == CMD_EXEC) {
|
if (pref.menu[i].menuItem[j].cmd == CMD_EXEC) {
|
||||||
|
|
|
@ -986,6 +986,10 @@ winRedrawScreenShadowDDNL(ScreenPtr pScreen)
|
||||||
RECT rcSrc, rcDest;
|
RECT rcSrc, rcDest;
|
||||||
POINT ptOrigin;
|
POINT ptOrigin;
|
||||||
|
|
||||||
|
/* Return immediately if we didn't get needed surfaces */
|
||||||
|
if (!pScreenPriv->pddsPrimary4 || !pScreenPriv->pddsShadow4)
|
||||||
|
return;
|
||||||
|
|
||||||
/* Get the origin of the window in the screen coords */
|
/* Get the origin of the window in the screen coords */
|
||||||
ptOrigin.x = pScreenInfo->dwXOffset;
|
ptOrigin.x = pScreenInfo->dwXOffset;
|
||||||
ptOrigin.y = pScreenInfo->dwYOffset;
|
ptOrigin.y = pScreenInfo->dwYOffset;
|
||||||
|
|
Loading…
Reference in New Issue
Block a user