Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
ced71edb
Commit
ced71edb
authored
Mar 23, 2002
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added support for driver-specific escapes in the x11drv to retrieve
X11 information. Finished dll separation of opengl32.
parent
65dbf4f6
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
172 additions
and
116 deletions
+172
-116
Makefile.in
Makefile.in
+1
-4
Makefile.in
dlls/Makefile.in
+2
-6
Makefile.in
dlls/opengl32/Makefile.in
+4
-1
opengl32.spec
dlls/opengl32/opengl32.spec
+1
-1
wgl.c
dlls/opengl32/wgl.c
+119
-104
init.c
graphics/x11drv/init.c
+35
-0
x11drv.h
include/x11drv.h
+10
-0
No files found.
Makefile.in
View file @
ced71edb
...
@@ -40,7 +40,7 @@ LIBRARIES = \
...
@@ -40,7 +40,7 @@ LIBRARIES = \
unicode/libwine_unicode.
$(LIBEXT)
unicode/libwine_unicode.
$(LIBEXT)
# Dlls that we need to link against (should go away)
# Dlls that we need to link against (should go away)
LINKABLE_DLLS
=
winspool.drv
x11drv.dll
user32.dll gdi32.dll kernel32.dll ntdll.dll
LINKABLE_DLLS
=
winspool.drv user32.dll gdi32.dll kernel32.dll ntdll.dll
# Libraries symlinks to create at the top level
# Libraries symlinks to create at the top level
LIBSYMLINKS
=
\
LIBSYMLINKS
=
\
...
@@ -118,9 +118,6 @@ libwine_uuid.a: ole/libwine_uuid.a
...
@@ -118,9 +118,6 @@ libwine_uuid.a: ole/libwine_uuid.a
libwinspool.drv.$(LIBEXT)
:
dlls/winspool.drv$(DLLEXT)
libwinspool.drv.$(LIBEXT)
:
dlls/winspool.drv$(DLLEXT)
$(RM)
$@
&&
$(LN_S)
dlls/winspool.drv
$(DLLEXT)
$@
$(RM)
$@
&&
$(LN_S)
dlls/winspool.drv
$(DLLEXT)
$@
libx11drv.dll.$(LIBEXT)
:
dlls/x11drv.dll$(DLLEXT)
$(RM)
$@
&&
$(LN_S)
dlls/x11drv.dll
$(DLLEXT)
$@
libuser32.dll.$(LIBEXT)
:
dlls/user32.dll$(DLLEXT)
libuser32.dll.$(LIBEXT)
:
dlls/user32.dll$(DLLEXT)
$(RM)
$@
&&
$(LN_S)
dlls/user32.dll
$(DLLEXT)
$@
$(RM)
$@
&&
$(LN_S)
dlls/user32.dll
$(DLLEXT)
$@
...
...
dlls/Makefile.in
View file @
ced71edb
...
@@ -651,9 +651,8 @@ olepro32/olepro32.dll$(DLLEXT): dummy oleaut32.dll$(DLLEXT) ntdll.dll$(DLLEXT)
...
@@ -651,9 +651,8 @@ olepro32/olepro32.dll$(DLLEXT): dummy oleaut32.dll$(DLLEXT) ntdll.dll$(DLLEXT)
olesvr/olesvr32.dll$(DLLEXT)
:
dummy kernel32.dll$(DLLEXT) ntdll.dll$(DLLEXT)
olesvr/olesvr32.dll$(DLLEXT)
:
dummy kernel32.dll$(DLLEXT) ntdll.dll$(DLLEXT)
@
cd
olesvr
&&
$(MAKE)
olesvr32.dll
$(DLLEXT)
@
cd
olesvr
&&
$(MAKE)
olesvr32.dll
$(DLLEXT)
opengl32/opengl32.dll$(DLLEXT)
:
dummy user32.dll$(DLLEXT) x11drv.dll$(DLLEXT)
\
opengl32/opengl32.dll$(DLLEXT)
:
dummy user32.dll$(DLLEXT) gdi32.dll$(DLLEXT)
\
kernel32.dll$(DLLEXT) ntdll.dll$(DLLEXT) libx11drv.dll.$(LIBEXT) libkernel32.dll.$(LIBEXT)
\
kernel32.dll$(DLLEXT) ntdll.dll$(DLLEXT)
libntdll.dll.$(LIBEXT)
@
cd
opengl32
&&
$(MAKE)
opengl32.dll
$(DLLEXT)
@
cd
opengl32
&&
$(MAKE)
opengl32.dll
$(DLLEXT)
psapi/psapi.dll$(DLLEXT)
:
dummy kernel32.dll$(DLLEXT) ntdll.dll$(DLLEXT)
psapi/psapi.dll$(DLLEXT)
:
dummy kernel32.dll$(DLLEXT) ntdll.dll$(DLLEXT)
...
@@ -833,9 +832,6 @@ libntdll.dll.$(LIBEXT): ntdll/ntdll.dll$(DLLEXT)
...
@@ -833,9 +832,6 @@ libntdll.dll.$(LIBEXT): ntdll/ntdll.dll$(DLLEXT)
libgdi32.dll.$(LIBEXT)
:
gdi/gdi32.dll$(DLLEXT)
libgdi32.dll.$(LIBEXT)
:
gdi/gdi32.dll$(DLLEXT)
$(RM)
$@
&&
$(LN_S)
gdi/gdi32.dll
$(DLLEXT)
$@
$(RM)
$@
&&
$(LN_S)
gdi/gdi32.dll
$(DLLEXT)
$@
libx11drv.dll.$(LIBEXT)
:
x11drv/x11drv.dll$(DLLEXT)
$(RM)
$@
&&
$(LN_S)
x11drv/x11drv.dll
$(DLLEXT)
$@
libuser32.dll.$(LIBEXT)
:
user/user32.dll$(DLLEXT)
libuser32.dll.$(LIBEXT)
:
user/user32.dll$(DLLEXT)
$(RM)
$@
&&
$(LN_S)
user/user32.dll
$(DLLEXT)
$@
$(RM)
$@
&&
$(LN_S)
user/user32.dll
$(DLLEXT)
$@
...
...
dlls/opengl32/Makefile.in
View file @
ced71edb
...
@@ -3,7 +3,10 @@ TOPOBJDIR = ../..
...
@@ -3,7 +3,10 @@ TOPOBJDIR = ../..
SRCDIR
=
@srcdir@
SRCDIR
=
@srcdir@
VPATH
=
@srcdir@
VPATH
=
@srcdir@
MODULE
=
opengl32.dll
MODULE
=
opengl32.dll
IMPORTS
=
x11drv.dll kernel32.dll ntdll.dll
EXTRALIBS
=
$(LIBTSX11)
$(X_LIBS)
$(XLIB)
LDDLLFLAGS
=
@LDDLLFLAGS@
SYMBOLFILE
=
$(MODULE)
.tmp.o
C_SRCS
=
\
C_SRCS
=
\
wgl.c
\
wgl.c
\
...
...
dlls/opengl32/opengl32.spec
View file @
ced71edb
...
@@ -3,7 +3,7 @@ type win32
...
@@ -3,7 +3,7 @@ type win32
init OpenGL32_Init
init OpenGL32_Init
import user32.dll
import user32.dll
import
x11drv
.dll
import
gdi32
.dll
import kernel32.dll
import kernel32.dll
import ntdll.dll
import ntdll.dll
...
...
dlls/opengl32/wgl.c
View file @
ced71edb
...
@@ -22,70 +22,104 @@
...
@@ -22,70 +22,104 @@
#include <stdlib.h>
#include <stdlib.h>
#include <string.h>
#include <string.h>
#include "wine/exception.h"
#include "wine/debug.h"
#include "gdi.h"
#include "windef.h"
#include "windef.h"
#include "winbase.h"
#include "winuser.h"
#include "winerror.h"
#include "winerror.h"
#include "wine_gl.h"
#include "wine_gl.h"
#include "x11drv.h"
#include "x11drv.h"
#include "x11font.h"
#include "msvcrt/excpt.h"
#include "wgl.h"
#include "wgl.h"
#include "opengl_ext.h"
#include "opengl_ext.h"
#include "wine/debug.h"
WINE_DEFAULT_DEBUG_CHANNEL
(
opengl
);
WINE_DEFAULT_DEBUG_CHANNEL
(
opengl
);
static
GLXContext
default_cx
=
NULL
;
static
GLXContext
default_cx
=
NULL
;
static
Display
*
default_display
;
/* display to use for default context */
typedef
struct
wine_glcontext
{
typedef
struct
wine_glcontext
{
HDC
hdc
;
HDC
hdc
;
Display
*
display
;
GLXContext
ctx
;
GLXContext
ctx
;
XVisualInfo
*
vis
;
XVisualInfo
*
vis
;
struct
wine_glcontext
*
next
;
struct
wine_glcontext
*
next
;
struct
wine_glcontext
*
prev
;
struct
wine_glcontext
*
prev
;
}
Wine_GLContext
;
}
Wine_GLContext
;
static
Wine_GLContext
*
context_
array
;
static
Wine_GLContext
*
context_
list
;
static
inline
Wine_GLContext
*
get_context_from_GLXContext
(
GLXContext
ctx
)
{
static
inline
Wine_GLContext
*
get_context_from_GLXContext
(
GLXContext
ctx
)
Wine_GLContext
*
ret
=
context_array
;
{
while
(
ret
!=
NULL
)
if
(
ctx
==
ret
->
ctx
)
break
;
else
ret
=
ret
->
next
;
Wine_GLContext
*
ret
;
return
ret
;
for
(
ret
=
context_list
;
ret
;
ret
=
ret
->
next
)
if
(
ctx
==
ret
->
ctx
)
break
;
return
ret
;
}
}
static
inline
void
free_context
(
Wine_GLContext
*
context
)
{
static
inline
void
free_context
(
Wine_GLContext
*
context
)
{
if
(
context
->
next
!=
NULL
)
context
->
next
->
prev
=
context
->
prev
;
if
(
context
->
next
!=
NULL
)
context
->
next
->
prev
=
context
->
prev
;
if
(
context
->
prev
!=
NULL
)
context
->
prev
->
next
=
context
->
next
;
if
(
context
->
prev
!=
NULL
)
context
->
prev
->
next
=
context
->
next
;
else
context_array
=
context
->
next
;
else
context_list
=
context
->
next
;
HeapFree
(
GetProcessHeap
(),
0
,
context
);
HeapFree
(
GetProcessHeap
(),
0
,
context
);
}
}
static
inline
Wine_GLContext
*
alloc_context
(
void
)
{
static
inline
Wine_GLContext
*
alloc_context
(
void
)
{
Wine_GLContext
*
ret
;
Wine_GLContext
*
ret
;
ret
=
HeapAlloc
(
GetProcessHeap
(),
HEAP_ZERO_MEMORY
,
sizeof
(
Wine_GLContext
));
if
((
ret
=
HeapAlloc
(
GetProcessHeap
(),
HEAP_ZERO_MEMORY
,
sizeof
(
Wine_GLContext
))))
ret
->
next
=
context_array
;
{
if
(
context_array
!=
NULL
)
context_array
->
prev
=
ret
;
ret
->
next
=
context_list
;
else
context_array
=
ret
;
if
(
context_list
)
context_list
->
prev
=
ret
;
context_list
=
ret
;
}
return
ret
;
return
ret
;
}
}
inline
static
BOOL
is_valid_context
(
Wine_GLContext
*
ctx
)
{
Wine_GLContext
*
ptr
;
for
(
ptr
=
context_list
;
ptr
;
ptr
=
ptr
->
next
)
if
(
ptr
==
ctx
)
break
;
return
(
ptr
!=
NULL
);
}
static
int
XGLErrorFlag
=
0
;
/* retrieve the X display to use on a given DC */
static
int
XGLErrorHandler
(
Display
*
dpy
,
XErrorEvent
*
event
)
{
inline
static
Display
*
get_display
(
HDC
hdc
)
XGLErrorFlag
=
1
;
{
return
0
;
Display
*
display
;
enum
x11drv_escape_codes
escape
=
X11DRV_GET_DISPLAY
;
if
(
!
ExtEscape
(
hdc
,
X11DRV_ESCAPE
,
sizeof
(
escape
),
(
LPCSTR
)
&
escape
,
sizeof
(
display
),
(
LPSTR
)
&
display
))
display
=
NULL
;
return
display
;
}
/* retrieve the X drawable to use on a given DC */
inline
static
Drawable
get_drawable
(
HDC
hdc
)
{
Drawable
drawable
;
enum
x11drv_escape_codes
escape
=
X11DRV_GET_DRAWABLE
;
if
(
!
ExtEscape
(
hdc
,
X11DRV_ESCAPE
,
sizeof
(
escape
),
(
LPCSTR
)
&
escape
,
sizeof
(
drawable
),
(
LPSTR
)
&
drawable
))
drawable
=
0
;
return
drawable
;
}
}
/* filter for page-fault exceptions */
static
WINE_EXCEPTION_FILTER
(
page_fault
)
/* retrieve the X drawable to use on a given DC */
inline
static
Font
get_font
(
HDC
hdc
)
{
{
return
EXCEPTION_EXECUTE_HANDLER
;
Font
font
;
enum
x11drv_escape_codes
escape
=
X11DRV_GET_FONT
;
if
(
!
ExtEscape
(
hdc
,
X11DRV_ESCAPE
,
sizeof
(
escape
),
(
LPCSTR
)
&
escape
,
sizeof
(
font
),
(
LPSTR
)
&
font
))
font
=
0
;
return
font
;
}
}
/***********************************************************************
/***********************************************************************
* wglCreateContext (OPENGL32.@)
* wglCreateContext (OPENGL32.@)
*/
*/
...
@@ -95,12 +129,14 @@ HGLRC WINAPI wglCreateContext(HDC hdc)
...
@@ -95,12 +129,14 @@ HGLRC WINAPI wglCreateContext(HDC hdc)
Wine_GLContext
*
ret
;
Wine_GLContext
*
ret
;
int
num
;
int
num
;
XVisualInfo
template
;
XVisualInfo
template
;
Display
*
display
=
get_display
(
hdc
);
TRACE
(
"(%08x)
\n
"
,
hdc
);
TRACE
(
"(%08x)
\n
"
,
hdc
);
/* First, get the visual in use by the X11DRV */
/* First, get the visual in use by the X11DRV */
if
(
!
display
)
return
0
;
template
.
visualid
=
GetPropA
(
GetDesktopWindow
(),
"__wine_x11_visual_id"
);
template
.
visualid
=
GetPropA
(
GetDesktopWindow
(),
"__wine_x11_visual_id"
);
vis
=
XGetVisualInfo
(
gdi_
display
,
VisualIDMask
,
&
template
,
&
num
);
vis
=
XGetVisualInfo
(
display
,
VisualIDMask
,
&
template
,
&
num
);
if
(
vis
==
NULL
)
{
if
(
vis
==
NULL
)
{
ERR
(
"NULL visual !!!
\n
"
);
ERR
(
"NULL visual !!!
\n
"
);
...
@@ -113,6 +149,7 @@ HGLRC WINAPI wglCreateContext(HDC hdc)
...
@@ -113,6 +149,7 @@ HGLRC WINAPI wglCreateContext(HDC hdc)
ret
=
alloc_context
();
ret
=
alloc_context
();
LEAVE_GL
();
LEAVE_GL
();
ret
->
hdc
=
hdc
;
ret
->
hdc
=
hdc
;
ret
->
display
=
display
;
ret
->
vis
=
vis
;
ret
->
vis
=
vis
;
TRACE
(
" creating context %p (GL context creation delayed)
\n
"
,
ret
);
TRACE
(
" creating context %p (GL context creation delayed)
\n
"
,
ret
);
...
@@ -143,34 +180,23 @@ BOOL WINAPI wglCopyContext(HGLRC hglrcSrc,
...
@@ -143,34 +180,23 @@ BOOL WINAPI wglCopyContext(HGLRC hglrcSrc,
/***********************************************************************
/***********************************************************************
* wglDeleteContext (OPENGL32.@)
* wglDeleteContext (OPENGL32.@)
*/
*/
BOOL
WINAPI
wglDeleteContext
(
HGLRC
hglrc
)
{
BOOL
WINAPI
wglDeleteContext
(
HGLRC
hglrc
)
int
(
*
WineXHandler
)(
Display
*
,
XErrorEvent
*
);
{
Wine_GLContext
*
ctx
=
(
Wine_GLContext
*
)
hglrc
;
Wine_GLContext
*
ctx
=
(
Wine_GLContext
*
)
hglrc
;
BOOL
ret
;
BOOL
ret
=
TRUE
;
TRACE
(
"(%p)
\n
"
,
hglrc
);
TRACE
(
"(%p)
\n
"
,
hglrc
);
ENTER_GL
();
ENTER_GL
();
/* A game (Half Life not to name it) deletes twice the same context. To prevent
/* A game (Half Life not to name it) deletes twice the same context,
crashes, run with our own error function enabled */
* so make sure it is valid first */
XSync
(
gdi_display
,
False
);
if
(
is_valid_context
(
ctx
))
XGLErrorFlag
=
0
;
{
WineXHandler
=
XSetErrorHandler
(
XGLErrorHandler
);
if
(
ctx
->
ctx
)
glXDestroyContext
(
ctx
->
display
,
ctx
->
ctx
);
__TRY
{
free_context
(
ctx
);
glXDestroyContext
(
gdi_display
,
ctx
->
ctx
);
XSync
(
gdi_display
,
False
);
XFlush
(
gdi_display
);
if
(
XGLErrorHandler
==
0
)
free_context
(
ctx
);
}
__EXCEPT
(
page_fault
)
{
XGLErrorFlag
=
1
;
}
}
__ENDTRY
else
{
ret
=
TRUE
;
XSetErrorHandler
(
WineXHandler
);
if
(
XGLErrorFlag
)
{
WARN
(
"Error deleting context !
\n
"
);
WARN
(
"Error deleting context !
\n
"
);
SetLastError
(
ERROR_INVALID_HANDLE
);
SetLastError
(
ERROR_INVALID_HANDLE
);
ret
=
FALSE
;
ret
=
FALSE
;
...
@@ -331,39 +357,20 @@ BOOL WINAPI wglMakeCurrent(HDC hdc,
...
@@ -331,39 +357,20 @@ BOOL WINAPI wglMakeCurrent(HDC hdc,
TRACE
(
"(%08x,%p)
\n
"
,
hdc
,
hglrc
);
TRACE
(
"(%08x,%p)
\n
"
,
hdc
,
hglrc
);
ENTER_GL
();
if
(
hglrc
==
NULL
)
{
if
(
hglrc
==
NULL
)
{
ENTER_GL
();
ret
=
glXMakeCurrent
(
default_display
,
None
,
NULL
);
ret
=
glXMakeCurrent
(
gdi_display
,
None
,
NULL
);
LEAVE_GL
();
}
else
{
}
else
{
DC
*
dc
=
DC_GetDCPtr
(
hdc
);
if
(
dc
==
NULL
)
{
ERR
(
"Null DC !!!
\n
"
);
ret
=
FALSE
;
}
else
{
X11DRV_PDEVICE
*
physDev
;
Wine_GLContext
*
ctx
=
(
Wine_GLContext
*
)
hglrc
;
Wine_GLContext
*
ctx
=
(
Wine_GLContext
*
)
hglrc
;
Drawable
drawable
=
get_drawable
(
hdc
);
physDev
=
(
X11DRV_PDEVICE
*
)
dc
->
physDev
;
if
(
ctx
->
ctx
==
NULL
)
{
if
(
ctx
->
ctx
==
NULL
)
{
ENTER_GL
();
ctx
->
ctx
=
glXCreateContext
(
ctx
->
display
,
ctx
->
vis
,
NULL
,
True
);
ctx
->
ctx
=
glXCreateContext
(
gdi_display
,
ctx
->
vis
,
NULL
,
True
);
LEAVE_GL
();
TRACE
(
" created a delayed OpenGL context (%p)
\n
"
,
ctx
->
ctx
);
TRACE
(
" created a delayed OpenGL context (%p)
\n
"
,
ctx
->
ctx
);
}
}
ret
=
glXMakeCurrent
(
ctx
->
display
,
drawable
,
ctx
->
ctx
);
ENTER_GL
();
ret
=
glXMakeCurrent
(
gdi_display
,
physDev
->
drawable
,
ctx
->
ctx
);
LEAVE_GL
();
GDI_ReleaseObj
(
hdc
);
}
}
}
LEAVE_GL
();
TRACE
(
" returning %s
\n
"
,
(
ret
?
"True"
:
"False"
));
TRACE
(
" returning %s
\n
"
,
(
ret
?
"True"
:
"False"
));
return
ret
;
return
ret
;
}
}
...
@@ -408,14 +415,14 @@ BOOL WINAPI wglShareLists(HGLRC hglrc1,
...
@@ -408,14 +415,14 @@ BOOL WINAPI wglShareLists(HGLRC hglrc1,
}
else
{
}
else
{
if
(
org
->
ctx
==
NULL
)
{
if
(
org
->
ctx
==
NULL
)
{
ENTER_GL
();
ENTER_GL
();
org
->
ctx
=
glXCreateContext
(
gdi_
display
,
org
->
vis
,
NULL
,
True
);
org
->
ctx
=
glXCreateContext
(
org
->
display
,
org
->
vis
,
NULL
,
True
);
LEAVE_GL
();
LEAVE_GL
();
TRACE
(
" created a delayed OpenGL context (%p) for Wine context %p
\n
"
,
org
->
ctx
,
org
);
TRACE
(
" created a delayed OpenGL context (%p) for Wine context %p
\n
"
,
org
->
ctx
,
org
);
}
}
ENTER_GL
();
ENTER_GL
();
/* Create the destination context with display lists shared */
/* Create the destination context with display lists shared */
dest
->
ctx
=
glXCreateContext
(
gdi_
display
,
dest
->
vis
,
org
->
ctx
,
True
);
dest
->
ctx
=
glXCreateContext
(
org
->
display
,
dest
->
vis
,
org
->
ctx
,
True
);
LEAVE_GL
();
LEAVE_GL
();
TRACE
(
" created a delayed OpenGL context (%p) for Wine context %p sharing lists with OpenGL ctx %p
\n
"
,
dest
->
ctx
,
dest
,
org
->
ctx
);
TRACE
(
" created a delayed OpenGL context (%p) for Wine context %p sharing lists with OpenGL ctx %p
\n
"
,
dest
->
ctx
,
dest
,
org
->
ctx
);
}
}
...
@@ -439,11 +446,9 @@ BOOL WINAPI wglSwapLayerBuffers(HDC hdc,
...
@@ -439,11 +446,9 @@ BOOL WINAPI wglSwapLayerBuffers(HDC hdc,
BOOL
WINAPI
wglUseFontBitmapsA
(
HDC
hdc
,
BOOL
WINAPI
wglUseFontBitmapsA
(
HDC
hdc
,
DWORD
first
,
DWORD
first
,
DWORD
count
,
DWORD
count
,
DWORD
listBase
)
{
DWORD
listBase
)
DC
*
dc
=
DC_GetDCPtr
(
hdc
);
{
X11DRV_PDEVICE
*
physDev
=
(
X11DRV_PDEVICE
*
)
dc
->
physDev
;
Font
fid
=
get_font
(
hdc
);
fontObject
*
pfo
=
XFONT_GetFontObject
(
physDev
->
font
);
Font
fid
=
pfo
->
fs
->
fid
;
TRACE
(
"(%08x, %ld, %ld, %ld)
\n
"
,
hdc
,
first
,
count
,
listBase
);
TRACE
(
"(%08x, %ld, %ld, %ld)
\n
"
,
hdc
,
first
,
count
,
listBase
);
...
@@ -451,7 +456,6 @@ BOOL WINAPI wglUseFontBitmapsA(HDC hdc,
...
@@ -451,7 +456,6 @@ BOOL WINAPI wglUseFontBitmapsA(HDC hdc,
/* I assume that the glyphs are at the same position for X and for Windows */
/* I assume that the glyphs are at the same position for X and for Windows */
glXUseXFont
(
fid
,
first
,
count
,
listBase
);
glXUseXFont
(
fid
,
first
,
count
,
listBase
);
LEAVE_GL
();
LEAVE_GL
();
GDI_ReleaseObj
(
hdc
);
return
TRUE
;
return
TRUE
;
}
}
...
@@ -474,18 +478,29 @@ BOOL WINAPI wglUseFontOutlinesA(HDC hdc,
...
@@ -474,18 +478,29 @@ BOOL WINAPI wglUseFontOutlinesA(HDC hdc,
/* This is for brain-dead applications that use OpenGL functions before even
/* This is for brain-dead applications that use OpenGL functions before even
creating a rendering context.... */
creating a rendering context.... */
static
void
process_attach
(
void
)
{
static
BOOL
process_attach
(
void
)
{
XWindowAttributes
win_attr
;
XWindowAttributes
win_attr
;
Visual
*
rootVisual
;
Visual
*
rootVisual
;
int
num
;
int
num
;
XVisualInfo
template
;
XVisualInfo
template
;
HDC
hdc
;
XVisualInfo
*
vis
=
NULL
;
XVisualInfo
*
vis
=
NULL
;
Window
root
=
(
Window
)
GetPropA
(
GetDesktopWindow
(),
"__wine_x11_whole_window"
);
Window
root
=
(
Window
)
GetPropA
(
GetDesktopWindow
(),
"__wine_x11_whole_window"
);
if
(
!
root
)
if
(
!
root
)
{
{
ERR
(
"X11DRV not loaded. Cannot create default context.
\n
"
);
ERR
(
"X11DRV not loaded. Cannot create default context.
\n
"
);
return
;
return
FALSE
;
}
hdc
=
GetDC
(
0
);
default_display
=
get_display
(
hdc
);
ReleaseDC
(
0
,
hdc
);
if
(
!
default_display
)
{
ERR
(
"X11DRV not loaded. Cannot get display for screen DC.
\n
"
);
return
FALSE
;
}
}
ENTER_GL
();
ENTER_GL
();
...
@@ -495,7 +510,7 @@ static void process_attach(void) {
...
@@ -495,7 +510,7 @@ static void process_attach(void) {
Window was created using the standard X11DRV visual, and glXMakeCurrent can't deal
Window was created using the standard X11DRV visual, and glXMakeCurrent can't deal
with mismatched visuals. Note that the Root Window visual may not be double
with mismatched visuals. Note that the Root Window visual may not be double
buffered, so apps actually attempting to render this way may flicker */
buffered, so apps actually attempting to render this way may flicker */
if
(
XGetWindowAttributes
(
gdi
_display
,
root
,
&
win_attr
))
if
(
XGetWindowAttributes
(
default
_display
,
root
,
&
win_attr
))
{
{
rootVisual
=
win_attr
.
visual
;
rootVisual
=
win_attr
.
visual
;
}
}
...
@@ -503,25 +518,25 @@ static void process_attach(void) {
...
@@ -503,25 +518,25 @@ static void process_attach(void) {
{
{
/* Get the default visual, since we can't seem to get the attributes from the
/* Get the default visual, since we can't seem to get the attributes from the
Root Window. Let's hope that the Root Window Visual matches the DefaultVisual */
Root Window. Let's hope that the Root Window Visual matches the DefaultVisual */
rootVisual
=
DefaultVisual
(
gdi_display
,
DefaultScreen
(
gdi
_display
)
);
rootVisual
=
DefaultVisual
(
default_display
,
DefaultScreen
(
default
_display
)
);
}
}
template
.
visualid
=
XVisualIDFromVisual
(
rootVisual
);
template
.
visualid
=
XVisualIDFromVisual
(
rootVisual
);
vis
=
XGetVisualInfo
(
gdi
_display
,
VisualIDMask
,
&
template
,
&
num
);
vis
=
XGetVisualInfo
(
default
_display
,
VisualIDMask
,
&
template
,
&
num
);
if
(
vis
!=
NULL
)
default_cx
=
glXCreateContext
(
gdi
_display
,
vis
,
0
,
GL_TRUE
);
if
(
vis
!=
NULL
)
default_cx
=
glXCreateContext
(
default
_display
,
vis
,
0
,
GL_TRUE
);
if
(
default_cx
!=
NULL
)
glXMakeCurrent
(
gdi
_display
,
root
,
default_cx
);
if
(
default_cx
!=
NULL
)
glXMakeCurrent
(
default
_display
,
root
,
default_cx
);
XFree
(
vis
);
XFree
(
vis
);
LEAVE_GL
();
LEAVE_GL
();
if
(
default_cx
==
NULL
)
{
if
(
default_cx
==
NULL
)
{
ERR
(
"Could not create default context.
\n
"
);
ERR
(
"Could not create default context.
\n
"
);
}
}
return
TRUE
;
context_array
=
NULL
;
}
}
static
void
process_detach
(
void
)
{
static
void
process_detach
(
void
)
glXDestroyContext
(
gdi_display
,
default_cx
);
{
glXDestroyContext
(
default_display
,
default_cx
);
}
}
/***********************************************************************
/***********************************************************************
...
@@ -529,13 +544,13 @@ static void process_detach(void) {
...
@@ -529,13 +544,13 @@ static void process_detach(void) {
*/
*/
BOOL
WINAPI
OpenGL32_Init
(
HINSTANCE
hinst
,
DWORD
reason
,
LPVOID
reserved
)
BOOL
WINAPI
OpenGL32_Init
(
HINSTANCE
hinst
,
DWORD
reason
,
LPVOID
reserved
)
{
{
switch
(
reason
)
{
switch
(
reason
)
case
DLL_PROCESS_ATTACH
:
{
process_attach
();
case
DLL_PROCESS_ATTACH
:
break
;
return
process_attach
()
;
case
DLL_PROCESS_DETACH
:
case
DLL_PROCESS_DETACH
:
process_detach
();
process_detach
();
break
;
break
;
}
}
return
TRUE
;
return
TRUE
;
}
}
graphics/x11drv/init.c
View file @
ced71edb
...
@@ -29,6 +29,7 @@
...
@@ -29,6 +29,7 @@
#include "wine/debug.h"
#include "wine/debug.h"
#include "winnt.h"
#include "winnt.h"
#include "x11drv.h"
#include "x11drv.h"
#include "x11font.h"
#include "ddrawi.h"
#include "ddrawi.h"
WINE_DEFAULT_DEBUG_CHANNEL
(
x11drv
);
WINE_DEFAULT_DEBUG_CHANNEL
(
x11drv
);
...
@@ -286,6 +287,8 @@ INT X11DRV_GetDeviceCaps( DC *dc, INT cap )
...
@@ -286,6 +287,8 @@ INT X11DRV_GetDeviceCaps( DC *dc, INT cap )
INT
X11DRV_ExtEscape
(
DC
*
dc
,
INT
escape
,
INT
in_count
,
LPCVOID
in_data
,
INT
X11DRV_ExtEscape
(
DC
*
dc
,
INT
escape
,
INT
in_count
,
LPCVOID
in_data
,
INT
out_count
,
LPVOID
out_data
)
INT
out_count
,
LPVOID
out_data
)
{
{
X11DRV_PDEVICE
*
physDev
=
(
X11DRV_PDEVICE
*
)
dc
->
physDev
;
switch
(
escape
)
switch
(
escape
)
{
{
case
QUERYESCSUPPORT
:
case
QUERYESCSUPPORT
:
...
@@ -295,6 +298,8 @@ INT X11DRV_ExtEscape( DC *dc, INT escape, INT in_count, LPCVOID in_data,
...
@@ -295,6 +298,8 @@ INT X11DRV_ExtEscape( DC *dc, INT escape, INT in_count, LPCVOID in_data,
{
{
case
DCICOMMAND
:
case
DCICOMMAND
:
return
DD_HAL_VERSION
;
return
DD_HAL_VERSION
;
case
X11DRV_ESCAPE
:
return
TRUE
;
}
}
}
}
break
;
break
;
...
@@ -307,6 +312,36 @@ INT X11DRV_ExtEscape( DC *dc, INT escape, INT in_count, LPCVOID in_data,
...
@@ -307,6 +312,36 @@ INT X11DRV_ExtEscape( DC *dc, INT escape, INT in_count, LPCVOID in_data,
return
X11DRV_DCICommand
(
in_count
,
lpCmd
,
out_data
);
return
X11DRV_DCICommand
(
in_count
,
lpCmd
,
out_data
);
}
}
break
;
break
;
case
X11DRV_ESCAPE
:
if
(
in_data
&&
in_count
>=
sizeof
(
enum
x11drv_escape_codes
))
{
switch
(
*
(
enum
x11drv_escape_codes
*
)
in_data
)
{
case
X11DRV_GET_DISPLAY
:
if
(
out_count
>=
sizeof
(
Display
*
))
{
*
(
Display
**
)
out_data
=
gdi_display
;
return
TRUE
;
}
break
;
case
X11DRV_GET_DRAWABLE
:
if
(
out_count
>=
sizeof
(
Drawable
))
{
*
(
Drawable
*
)
out_data
=
physDev
->
drawable
;
return
TRUE
;
}
break
;
case
X11DRV_GET_FONT
:
if
(
out_count
>=
sizeof
(
Font
))
{
fontObject
*
pfo
=
XFONT_GetFontObject
(
physDev
->
font
);
*
(
Font
*
)
out_data
=
pfo
->
fs
->
fid
;
return
TRUE
;
}
}
}
break
;
}
}
return
0
;
return
0
;
}
}
include/x11drv.h
View file @
ced71edb
...
@@ -329,6 +329,16 @@ extern int X11DRV_PALETTE_SetMapping(struct tagPALETTEOBJ *palPtr, UINT uStart,
...
@@ -329,6 +329,16 @@ extern int X11DRV_PALETTE_SetMapping(struct tagPALETTEOBJ *palPtr, UINT uStart,
extern
int
X11DRV_PALETTE_UpdateMapping
(
struct
tagPALETTEOBJ
*
palPtr
);
extern
int
X11DRV_PALETTE_UpdateMapping
(
struct
tagPALETTEOBJ
*
palPtr
);
extern
BOOL
X11DRV_PALETTE_IsDark
(
int
pixel
);
extern
BOOL
X11DRV_PALETTE_IsDark
(
int
pixel
);
/* GDI escapes */
#define X11DRV_ESCAPE 6789
enum
x11drv_escape_codes
{
X11DRV_GET_DISPLAY
,
/* get X11 display for a DC */
X11DRV_GET_DRAWABLE
,
/* get current drawable for a DC */
X11DRV_GET_FONT
,
/* get current X font for a DC */
};
/**************************************************************************
/**************************************************************************
* X11 USER driver
* X11 USER driver
*/
*/
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment