Merge remote-tracking branch 'jturney/master'
This commit is contained in:
commit
54a1d4db82
|
@ -15,7 +15,7 @@ if XWIN_GLX_WINDOWS
|
|||
GLX_DIR = glx
|
||||
DEFS_GLX_WINDOWS = -DXWIN_GLX_WINDOWS
|
||||
XWIN_GLX_LIBS = $(top_builddir)/hw/xwin/glx/libXwinGLX.la
|
||||
XWIN_GLX_LINK_FLAGS = -lopengl32
|
||||
XWIN_GLX_SYS_LIBS = -lopengl32
|
||||
endif
|
||||
|
||||
if XWIN_MULTIWINDOW
|
||||
|
@ -27,7 +27,7 @@ SRCS_MULTIWINDOW = \
|
|||
propertystore.h \
|
||||
winSetAppUserModelID.c
|
||||
DEFS_MULTIWINDOW = -DXWIN_MULTIWINDOW
|
||||
MULTIWINDOW_LIBS = -lshlwapi -lole32
|
||||
MULTIWINDOW_SYS_LIBS = -lshlwapi -lole32
|
||||
endif
|
||||
|
||||
if XWIN_MULTIWINDOWEXTWM
|
||||
|
@ -126,6 +126,8 @@ SRCS = InitInput.c \
|
|||
winprefs.h \
|
||||
winresource.h \
|
||||
winwindow.h \
|
||||
windisplay.c \
|
||||
windisplay.h \
|
||||
XWin.rc \
|
||||
$(top_srcdir)/mi/miinitext.c \
|
||||
$(SRCS_CLIPBOARD) \
|
||||
|
@ -150,11 +152,28 @@ XWin_SOURCES = $(SRCS)
|
|||
AM_CPPFLAGS = -I$(top_srcdir)/miext/rootless
|
||||
|
||||
XWIN_SYS_LIBS += -ldxguid
|
||||
XWIN_LIBS += $(top_builddir)/pseudoramiX/libPseudoramiX.la \
|
||||
$(top_builddir)/Xext/libXextdpmsstubs.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_LIBS += \
|
||||
$(top_builddir)/pseudoramiX/libPseudoramiX.la \
|
||||
$(top_builddir)/Xext/libXextdpmsstubs.la \
|
||||
$(top_builddir)/Xi/libXistubs.la
|
||||
|
||||
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)
|
||||
|
||||
|
||||
|
|
5
hw/xwin/glx/.gitignore
vendored
5
hw/xwin/glx/.gitignore
vendored
|
@ -1,3 +1,6 @@
|
|||
# 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
|
||||
|
|
|
@ -100,13 +100,16 @@ reg = Registry()
|
|||
tree = etree.parse(regFilename)
|
||||
reg.loadElementTree(tree)
|
||||
|
||||
allVersions = '.*'
|
||||
if shim:
|
||||
versions = '1\.[012]'
|
||||
else:
|
||||
versions = '.*'
|
||||
|
||||
genOpts = CGeneratorOptions(
|
||||
apiname = prefix,
|
||||
profile = 'compatibility',
|
||||
versions = allVersions,
|
||||
emitversions = allVersions,
|
||||
versions = versions,
|
||||
emitversions = versions,
|
||||
defaultExtensions = prefix, # Default extensions for GL
|
||||
protectFile = protect,
|
||||
protectFeature = protect,
|
||||
|
@ -257,7 +260,7 @@ class ThunkOutputGenerator(OutputGenerator):
|
|||
pass
|
||||
def 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):
|
||||
OutputGenerator.endFeature(self)
|
||||
def genType(self, typeinfo, name):
|
||||
|
@ -355,7 +358,7 @@ class ShimOutputGenerator(OutputGenerator):
|
|||
pass
|
||||
def 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):
|
||||
OutputGenerator.endFeature(self)
|
||||
def genType(self, typeinfo, name):
|
||||
|
|
|
@ -28,6 +28,9 @@
|
|||
* DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
#ifndef GLWINDOWS_H
|
||||
#define GLWINDOWS_H
|
||||
|
||||
#include <GL/gl.h>
|
||||
|
||||
typedef struct {
|
||||
|
@ -53,3 +56,5 @@ int glWinSelectImplementation(int native);
|
|||
#define GLWIN_TRACE_MSG(a, ...)
|
||||
#define GLWIN_DEBUG_MSG(a, ...)
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
|
|
@ -738,9 +738,6 @@ glxWinScreenProbe(ScreenPtr 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())
|
||||
{
|
||||
unsigned int buffer_size =
|
||||
|
@ -893,13 +890,6 @@ glxWinDrawableSwapBuffers(ClientPtr client, __GLXdrawable * base)
|
|||
("glxWinSwapBuffers on drawable %p, last context %p (native ctx %p)",
|
||||
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);
|
||||
if (dc == NULL)
|
||||
return GL_FALSE;
|
||||
|
@ -1123,7 +1113,6 @@ glxWinSetPixelFormat(__GLXWinContext * gc, HDC hdc, int bppOverride,
|
|||
fbConfigToPixelFormatIndex(hdc, gc->base.config,
|
||||
drawableTypeOverride, winScreen);
|
||||
if (pixelFormat == 0) {
|
||||
ErrorF("wglChoosePixelFormat error: %s\n", glxWinErrorMessage());
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
|
@ -1306,7 +1295,7 @@ glxWinDeferredCreateContext(__GLXWinContext * gc, __GLXWinDrawable * draw)
|
|||
glxWinScreen *winScreen;
|
||||
int pixelFormat;
|
||||
|
||||
// XXX: which DC are supposed to use???
|
||||
// XXX: which DC are we supposed to use???
|
||||
HDC screenDC = GetDC(NULL);
|
||||
|
||||
if (!(gc->base.config->drawableType & GLX_PBUFFER_BIT)) {
|
||||
|
@ -1319,10 +1308,8 @@ glxWinDeferredCreateContext(__GLXWinContext * gc, __GLXWinDrawable * draw)
|
|||
|
||||
pixelFormat =
|
||||
fbConfigToPixelFormatIndex(screenDC, gc->base.config,
|
||||
GLX_DRAWABLE_PBUFFER, winScreen);
|
||||
GLX_PBUFFER_BIT, winScreen);
|
||||
if (pixelFormat == 0) {
|
||||
ErrorF("wglChoosePixelFormat error: %s\n",
|
||||
glxWinErrorMessage());
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -1761,7 +1748,7 @@ fbConfigToPixelFormatIndex(HDC hdc, __GLXconfig * mode,
|
|||
SET_ATTR_VALUE(WGL_SWAP_METHOD_ARB, WGL_SWAP_EXCHANGE_ARB);
|
||||
|
||||
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
|
||||
if (mode->visualRating == GLX_SLOW_VISUAL_EXT)
|
||||
|
|
|
@ -51,7 +51,7 @@ winGetWindowInfo(WindowPtr pWin)
|
|||
|
||||
if (pWinPriv->hWnd == NULL) {
|
||||
winCreateWindowsWindow(pWin);
|
||||
ErrorF("winGetWindowInfo: forcing window to exist...\n");
|
||||
winDebug("winGetWindowInfo: forcing window to exist\n");
|
||||
}
|
||||
|
||||
if (pWinPriv->hWnd != NULL) {
|
||||
|
|
|
@ -38,6 +38,7 @@
|
|||
#include <sys/types.h>
|
||||
#include <signal.h>
|
||||
#include "winclipboard.h"
|
||||
#include "windisplay.h"
|
||||
#ifdef __CYGWIN__
|
||||
#include <errno.h>
|
||||
#endif
|
||||
|
@ -157,7 +158,7 @@ winClipboardProc(void *pvNotUsed)
|
|||
* for all screens on the display. That is why there is only
|
||||
* one clipboard client thread.
|
||||
*/
|
||||
snprintf(szDisplay, 512, "127.0.0.1:%s.0", display);
|
||||
winGetDisplayName(szDisplay, 0);
|
||||
|
||||
/* Print the display connection string */
|
||||
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
|
||||
*/
|
||||
|
||||
#include <X11/Xwindows.h>
|
||||
|
||||
/*
|
||||
* Function prototypes
|
||||
*/
|
||||
|
|
|
@ -61,6 +61,7 @@
|
|||
#include "pixmapstr.h"
|
||||
#include "windowstr.h"
|
||||
#include "winglobals.h"
|
||||
#include "windisplay.h"
|
||||
|
||||
#ifdef XWIN_MULTIWINDOWEXTWM
|
||||
#include <X11/extensions/windowswmstr.h>
|
||||
|
@ -1053,8 +1054,7 @@ winMultiWindowXMsgProc(void *pArg)
|
|||
}
|
||||
|
||||
/* Setup the display connection string x */
|
||||
snprintf(pszDisplay,
|
||||
512, "127.0.0.1:%s.%d", display, (int) pProcArg->dwScreen);
|
||||
winGetDisplayName(pszDisplay, (int) pProcArg->dwScreen);
|
||||
|
||||
/* Print the display connection string */
|
||||
ErrorF("winMultiWindowXMsgProc - DISPLAY=%s\n", pszDisplay);
|
||||
|
@ -1446,8 +1446,7 @@ winInitMultiWindowWM(WMInfoPtr pWMInfo, WMProcArgPtr pProcArg)
|
|||
}
|
||||
|
||||
/* Setup the display connection string x */
|
||||
snprintf(pszDisplay,
|
||||
512, "127.0.0.1:%s.%d", display, (int) pProcArg->dwScreen);
|
||||
winGetDisplayName(pszDisplay, (int) pProcArg->dwScreen);
|
||||
|
||||
/* Print the display connection string */
|
||||
ErrorF("winInitMultiWindowWM - DISPLAY=%s\n", pszDisplay);
|
||||
|
|
|
@ -44,6 +44,7 @@
|
|||
#include <shellapi.h>
|
||||
|
||||
#include "winprefs.h"
|
||||
#include "windisplay.h"
|
||||
#include "winmultiwindowclass.h"
|
||||
|
||||
/* 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 */
|
||||
/* because putenv doesn't copy the argument... */
|
||||
snprintf(szDisplay, 512, "DISPLAY=127.0.0.1:%s.0", display);
|
||||
szEnvDisplay = (char *) (malloc(strlen(szDisplay) + 1));
|
||||
winGetDisplayName(szDisplay, 0);
|
||||
szEnvDisplay = (char *) (malloc(strlen(szDisplay) + strlen("DISPLAY=") + 1));
|
||||
if (szEnvDisplay) {
|
||||
strcpy(szEnvDisplay, szDisplay);
|
||||
snprintf(szEnvDisplay, 512, "DISPLAY=%s", szDisplay);
|
||||
putenv(szEnvDisplay);
|
||||
}
|
||||
|
||||
/* 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 (j = 0; j < pref.menu[i].menuItems; j++) {
|
||||
if (pref.menu[i].menuItem[j].cmd == CMD_EXEC) {
|
||||
|
|
|
@ -986,6 +986,10 @@ winRedrawScreenShadowDDNL(ScreenPtr pScreen)
|
|||
RECT rcSrc, rcDest;
|
||||
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 */
|
||||
ptOrigin.x = pScreenInfo->dwXOffset;
|
||||
ptOrigin.y = pScreenInfo->dwYOffset;
|
||||
|
|
Loading…
Reference in New Issue
Block a user