2 * OpenGL function forwarding to the display driver
4 * Copyright (c) 1999 Lionel Ulmer
5 * Copyright (c) 2005 Raphael Junqueira
6 * Copyright (c) 2006 Roderick Colenbrander
8 * This library is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Lesser General Public
10 * License as published by the Free Software Foundation; either
11 * version 2.1 of the License, or (at your option) any later version.
13 * This library is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * Lesser General Public License for more details.
18 * You should have received a copy of the GNU Lesser General Public
19 * License along with this library; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
24 #include "wine/port.h"
37 #include "gdi_private.h"
38 #include "wine/debug.h"
40 WINE_DEFAULT_DEBUG_CHANNEL(wgl);
42 static HDC default_hdc = 0;
44 typedef struct opengl_context
49 /* We route all wgl functions from opengl32.dll through gdi32.dll to
50 * the display driver. Various wgl calls have a hDC as one of their parameters.
51 * Using DC_GetDCPtr we get access to the functions exported by the driver.
52 * Some functions don't receive a hDC. This function creates a global hdc and
53 * if there's already a global hdc, it returns it.
55 static DC* OPENGL_GetDefaultDC()
58 default_hdc = CreateDCA("DISPLAY", NULL, NULL, NULL);
60 return DC_GetDCPtr(default_hdc);
63 /***********************************************************************
64 * wglCreateContext (OPENGL32.@)
66 HGLRC WINAPI wglCreateContext(HDC hdc)
69 DC * dc = DC_GetDCPtr( hdc );
75 if (!dc->funcs->pwglCreateContext) FIXME(" :stub\n");
76 else ret = dc->funcs->pwglCreateContext(dc->physDev);
78 GDI_ReleaseObj( hdc );
83 /***********************************************************************
84 * wglDeleteContext (OPENGL32.@)
86 BOOL WINAPI wglDeleteContext(HGLRC hglrc)
90 OPENGL_Context ctx = (OPENGL_Context)hglrc;
92 TRACE("hglrc: (%p)\n", hglrc);
96 /* Retrieve the HDC associated with the context to access the display driver */
97 dc = DC_GetDCPtr(ctx->hdc);
98 if (!dc) return FALSE;
100 if (!dc->funcs->pwglDeleteContext) FIXME(" :stub\n");
101 else ret = dc->funcs->pwglDeleteContext(hglrc);
103 GDI_ReleaseObj(ctx->hdc);
107 /***********************************************************************
108 * wglGetCurrentContext (OPENGL32.@)
110 HGLRC WINAPI wglGetCurrentContext(void)
112 HGLRC ret = NtCurrentTeb()->glContext;
113 TRACE(" returning %p\n", ret);
117 /***********************************************************************
118 * wglGetCurrentDC (OPENGL32.@)
120 HDC WINAPI wglGetCurrentDC(void)
122 OPENGL_Context ctx = (OPENGL_Context)wglGetCurrentContext();
124 TRACE(" found context: %p\n", ctx);
128 /* Retrieve the current DC from the active context */
129 TRACE(" returning hdc: %p\n", ctx->hdc);
133 /***********************************************************************
136 static HDC WINAPI wglGetPbufferDCARB(void *pbuffer)
140 /* Create a device context to associate with the pbuffer */
141 HDC hdc = CreateDCA("DISPLAY", NULL, NULL, NULL);
142 DC *dc = DC_GetDCPtr(hdc);
144 TRACE("(%p)\n", pbuffer);
146 if (!dc) return FALSE;
148 /* The display driver has to do the rest of the work because
149 * we need access to lowlevel datatypes which we can't access here
151 if (!dc->funcs->pwglGetPbufferDCARB) FIXME(" :stub\n");
152 else ret = dc->funcs->pwglGetPbufferDCARB(dc->physDev, pbuffer);
154 TRACE("(%p), hdc=%p\n", pbuffer, ret);
160 /***********************************************************************
161 * wglMakeCurrent (OPENGL32.@)
163 BOOL WINAPI wglMakeCurrent(HDC hdc, HGLRC hglrc)
168 /* When the context hglrc is NULL, the HDC is ignored and can be NULL.
169 * In that case use the global hDC to get access to the driver. */
171 dc = OPENGL_GetDefaultDC();
173 dc = DC_GetDCPtr( hdc );
175 TRACE("hdc: (%p), hglrc: (%p)\n", hdc, hglrc);
177 if (!dc) return FALSE;
179 if (!dc->funcs->pwglMakeCurrent) FIXME(" :stub\n");
180 else ret = dc->funcs->pwglMakeCurrent(dc->physDev,hglrc);
183 GDI_ReleaseObj(default_hdc);
190 /***********************************************************************
191 * wglMakeContextCurrentARB
193 static BOOL WINAPI wglMakeContextCurrentARB(HDC hDrawDC, HDC hReadDC, HGLRC hglrc)
199 TRACE("hDrawDC: (%p), hReadDC: (%p) hglrc: (%p)\n", hDrawDC, hReadDC, hglrc);
201 /* Both hDrawDC and hReadDC need to be valid */
202 DrawDC = DC_GetDCPtr( hDrawDC);
203 if (!DrawDC) return FALSE;
205 ReadDC = DC_GetDCPtr( hReadDC);
207 GDI_ReleaseObj(hDrawDC);
211 if (!DrawDC->funcs->pwglMakeContextCurrentARB) FIXME(" :stub\n");
212 else ret = DrawDC->funcs->pwglMakeContextCurrentARB(DrawDC->physDev, ReadDC->physDev, hglrc);
214 GDI_ReleaseObj(hDrawDC);
215 GDI_ReleaseObj(hReadDC);
220 /***********************************************************************
221 * wglShareLists (OPENGL32.@)
223 BOOL WINAPI wglShareLists(HGLRC hglrc1, HGLRC hglrc2)
227 OPENGL_Context ctx = (OPENGL_Context)hglrc1;
229 TRACE("hglrc1: (%p); hglrc: (%p)\n", hglrc1, hglrc2);
233 /* Retrieve the HDC associated with the context to access the display driver */
234 dc = DC_GetDCPtr(ctx->hdc);
235 if (!dc) return FALSE;
237 if (!dc->funcs->pwglShareLists) FIXME(" :stub\n");
238 else ret = dc->funcs->pwglShareLists(hglrc1, hglrc2);
240 GDI_ReleaseObj(ctx->hdc);
244 /***********************************************************************
245 * wglUseFontBitmapsA (OPENGL32.@)
247 BOOL WINAPI wglUseFontBitmapsA(HDC hdc, DWORD first, DWORD count, DWORD listBase)
250 DC * dc = DC_GetDCPtr( hdc );
252 TRACE("(%p, %d, %d, %d)\n", hdc, first, count, listBase);
254 if (!dc) return FALSE;
256 if (!dc->funcs->pwglUseFontBitmapsA) FIXME(" :stub\n");
257 else ret = dc->funcs->pwglUseFontBitmapsA(dc->physDev, first, count, listBase);
259 GDI_ReleaseObj( hdc);
263 /***********************************************************************
264 * wglUseFontBitmapsW (OPENGL32.@)
266 BOOL WINAPI wglUseFontBitmapsW(HDC hdc, DWORD first, DWORD count, DWORD listBase)
269 DC * dc = DC_GetDCPtr( hdc );
271 TRACE("(%p, %d, %d, %d)\n", hdc, first, count, listBase);
273 if (!dc) return FALSE;
275 if (!dc->funcs->pwglUseFontBitmapsW) FIXME(" :stub\n");
276 else ret = dc->funcs->pwglUseFontBitmapsW(dc->physDev, first, count, listBase);
278 GDI_ReleaseObj( hdc);
282 /***********************************************************************
283 * Internal wglGetProcAddress for retrieving WGL extensions
285 PROC WINAPI wglGetProcAddress(LPCSTR func)
293 TRACE("func: '%p'\n", func);
295 /* Retrieve the global hDC to get access to the driver. */
296 dc = OPENGL_GetDefaultDC();
297 if (!dc) return FALSE;
299 if (!dc->funcs->pwglGetProcAddress) FIXME(" :stub\n");
300 else ret = dc->funcs->pwglGetProcAddress(func);
302 GDI_ReleaseObj(default_hdc);
304 /* At the moment we implement one WGL extension which requires a HDC. When we
305 * are looking up this call and when the Extension is available (that is the case
306 * when a non-NULL value is returned by wglGetProcAddress), we return the address
307 * of a wrapper function which will handle the HDC->PhysDev conversion.
309 if(ret && strcmp(func, "wglMakeContextCurrentARB") == 0)
310 return wglMakeContextCurrentARB;
311 else if(ret && strcmp(func, "wglGetPbufferDCARB") == 0)
312 return (PROC)wglGetPbufferDCARB;