glfw/src/internal.h

709 lines
22 KiB
C
Raw Normal View History

2010-09-07 17:34:51 +02:00
//========================================================================
// GLFW - An OpenGL library
2010-09-07 17:34:51 +02:00
// Platform: Any
2010-09-07 17:41:26 +02:00
// API version: 3.0
2010-09-07 17:34:51 +02:00
// WWW: http://www.glfw.org/
//------------------------------------------------------------------------
// Copyright (c) 2002-2006 Marcus Geelnard
// Copyright (c) 2006-2010 Camilla Berglund <elmindreda@elmindreda.org>
//
// This software is provided 'as-is', without any express or implied
// warranty. In no event will the authors be held liable for any damages
// arising from the use of this software.
//
// Permission is granted to anyone to use this software for any purpose,
// including commercial applications, and to alter it and redistribute it
// freely, subject to the following restrictions:
//
// 1. The origin of this software must not be misrepresented; you must not
// claim that you wrote the original software. If you use this software
// in a product, an acknowledgment in the product documentation would
// be appreciated but is not required.
//
// 2. Altered source versions must be plainly marked as such, and must not
// be misrepresented as being the original software.
//
// 3. This notice may not be removed or altered from any source
// distribution.
//
//========================================================================
#ifndef _internal_h_
#define _internal_h_
2013-01-15 22:43:44 +01:00
#include "config.h"
#if defined(_GLFW_USE_OPENGL)
// This is the default for glfw3.h
#elif defined(_GLFW_USE_GLESV1)
2013-01-15 22:43:44 +01:00
#define GLFW_INCLUDE_ES1
#elif defined(_GLFW_USE_GLESV2)
#define GLFW_INCLUDE_ES2
#else
#error "No supported client library selected"
2013-01-15 22:43:44 +01:00
#endif
// Disable the inclusion of the platform glext.h by gl.h to allow proper
// inclusion of our own, newer glext.h below
#define GL_GLEXT_LEGACY
#include "../include/GL/glfw3.h"
#if defined(_GLFW_USE_OPENGL)
// This path may need to be changed if you build GLFW using your own setup
// GLFW comes with its own copy of glext.h since it uses fairly new extensions
// and not all development environments come with an up-to-date version
#include "../support/GL/glext.h"
#endif
typedef struct _GLFWhints _GLFWhints;
typedef struct _GLFWwndconfig _GLFWwndconfig;
typedef struct _GLFWfbconfig _GLFWfbconfig;
typedef struct _GLFWwindow _GLFWwindow;
typedef struct _GLFWlibrary _GLFWlibrary;
typedef struct _GLFWmonitor _GLFWmonitor;
#if defined(_GLFW_COCOA)
#include "cocoa_platform.h"
#elif defined(_GLFW_WIN32)
#include "win32_platform.h"
#elif defined(_GLFW_X11)
#include "x11_platform.h"
#else
#error "No supported window creation API selected"
#endif
//========================================================================
// Doxygen group definitions
//========================================================================
/*! @defgroup platform Platform interface
* @brief The interface implemented by the platform-specific code.
*
* The platform API is the interface exposed by the platform-specific code for
* each platform and is called by the shared code of the public API It mirrors
* the public API except it uses objects instead of handles.
*/
/*! @defgroup event Event interface
* @brief The interface used by the platform-specific code to report events.
*
* The event API is used by the platform-specific code to notify the shared
* code of events that can be translated into state changes and/or callback
* calls.
*/
/*! @defgroup utility Utility functions
* @brief Various utility functions for internal use.
*
* These functions are shared code and may be used by any part of GLFW
* Each platform may add its own utility functions, but those may only be
* called by the platform-specific code
*/
2010-09-07 17:34:51 +02:00
//========================================================================
2013-01-15 22:43:44 +01:00
// Helper macros
2010-09-07 17:34:51 +02:00
//========================================================================
2013-01-15 22:43:44 +01:00
// Internal key state used for sticky keys
2013-01-12 17:06:35 +01:00
#define _GLFW_STICK 3
2010-09-07 17:34:51 +02:00
// Checks for whether the library has been intitalized
#define _GLFW_REQUIRE_INIT() \
if (!_glfwInitialized) \
{ \
_glfwInputError(GLFW_NOT_INITIALIZED, NULL); \
return; \
}
#define _GLFW_REQUIRE_INIT_OR_RETURN(x) \
if (!_glfwInitialized) \
{ \
_glfwInputError(GLFW_NOT_INITIALIZED, NULL); \
return x; \
}
2010-09-07 17:34:51 +02:00
2012-04-22 21:49:38 +02:00
//========================================================================
2013-01-15 22:43:44 +01:00
// Internal types
//========================================================================
/*! @brief Window, framebuffer and context hints.
*
* It is used only by shared code and only to store parameters passed to us by
* @ref glfwWindowHint for use by @ref glfwCreateWindow.
*/
2010-10-04 18:17:53 +02:00
struct _GLFWhints
2010-09-09 20:18:10 +02:00
{
int redBits;
int greenBits;
int blueBits;
int alphaBits;
int depthBits;
int stencilBits;
2010-09-07 17:34:51 +02:00
int accumRedBits;
int accumGreenBits;
int accumBlueBits;
int accumAlphaBits;
int auxBuffers;
2010-10-25 12:36:14 +02:00
GLboolean stereo;
GLboolean resizable;
GLboolean visible;
2010-09-07 17:34:51 +02:00
int samples;
GLboolean sRGB;
int clientAPI;
2010-09-07 17:34:51 +02:00
int glMajor;
int glMinor;
2010-10-25 12:36:14 +02:00
GLboolean glForward;
GLboolean glDebug;
2010-09-07 17:34:51 +02:00
int glProfile;
2011-03-07 20:51:34 +01:00
int glRobustness;
2010-10-04 18:17:53 +02:00
};
2010-09-07 17:34:51 +02:00
/*! @brief Window and context configuration.
*
* Parameters relating to the creation of the context and window but not
* directly related to the framebuffer. This is used to pass window and
* context creation parameters from shared code to the platform API.
*/
2010-10-04 18:17:53 +02:00
struct _GLFWwndconfig
2010-09-09 20:18:10 +02:00
{
int width;
int height;
2010-10-04 18:17:53 +02:00
const char* title;
GLboolean resizable;
GLboolean visible;
int clientAPI;
2010-10-04 18:17:53 +02:00
int glMajor;
int glMinor;
2010-10-25 12:36:14 +02:00
GLboolean glForward;
GLboolean glDebug;
2010-10-04 18:17:53 +02:00
int glProfile;
2011-03-07 20:51:34 +01:00
int glRobustness;
2012-09-27 21:37:36 +02:00
_GLFWmonitor* monitor;
2010-10-04 18:17:53 +02:00
_GLFWwindow* share;
};
2010-09-07 17:34:51 +02:00
/*! @brief Framebuffer configuration.
*
* This describes buffers and their sizes. It is used to pass framebuffer
* parameters from shared code to the platform API.
*/
2010-10-04 18:17:53 +02:00
struct _GLFWfbconfig
2010-09-09 20:18:10 +02:00
{
2010-09-07 17:34:51 +02:00
int redBits;
int greenBits;
int blueBits;
int alphaBits;
int depthBits;
int stencilBits;
int accumRedBits;
int accumGreenBits;
int accumBlueBits;
int accumAlphaBits;
int auxBuffers;
2010-10-25 12:36:14 +02:00
GLboolean stereo;
2010-09-07 17:34:51 +02:00
int samples;
GLboolean sRGB;
2010-10-04 18:17:53 +02:00
};
2010-09-07 17:34:51 +02:00
/*! @brief Window and context structure.
*/
2010-10-04 18:17:53 +02:00
struct _GLFWwindow
2010-09-09 20:18:10 +02:00
{
2010-09-10 00:06:23 +02:00
struct _GLFWwindow* next;
2010-09-09 20:18:10 +02:00
// Window settings and state
2013-01-02 16:48:02 +01:00
GLboolean iconified;
GLboolean resizable;
GLboolean visible;
2013-01-17 20:31:16 +01:00
GLboolean closed;
2013-01-02 16:48:02 +01:00
void* userPointer;
GLFWvidmode videoMode;
2013-01-02 16:48:02 +01:00
_GLFWmonitor* monitor;
2010-09-09 18:15:32 +02:00
2010-09-09 20:18:10 +02:00
// Window input state
2013-01-02 16:48:02 +01:00
GLboolean stickyKeys;
GLboolean stickyMouseButtons;
int cursorPosX, cursorPosY;
int cursorMode;
char mouseButton[GLFW_MOUSE_BUTTON_LAST + 1];
char key[GLFW_KEY_LAST + 1];
2010-09-09 18:15:32 +02:00
// OpenGL extensions and context attributes
2013-01-02 16:48:02 +01:00
int clientAPI;
int glMajor, glMinor, glRevision;
GLboolean glForward, glDebug;
int glProfile;
int glRobustness;
#if defined(_GLFW_USE_OPENGL)
2010-09-09 18:15:32 +02:00
PFNGLGETSTRINGIPROC GetStringi;
#endif
2010-09-09 18:15:32 +02:00
2013-01-15 21:34:26 +01:00
struct {
GLFWwindowposfun pos;
GLFWwindowsizefun size;
GLFWwindowclosefun close;
GLFWwindowrefreshfun refresh;
GLFWwindowfocusfun focus;
GLFWwindowiconifyfun iconify;
GLFWmousebuttonfun mouseButton;
GLFWcursorposfun cursorPos;
GLFWcursorenterfun cursorEnter;
GLFWscrollfun scroll;
GLFWkeyfun key;
GLFWcharfun character;
} callbacks;
// This is defined in the window API's platform.h
2010-09-09 18:15:32 +02:00
_GLFW_PLATFORM_WINDOW_STATE;
// This is defined in the context API's platform.h
_GLFW_PLATFORM_CONTEXT_STATE;
2010-10-04 18:17:53 +02:00
};
2010-09-09 18:15:32 +02:00
/*! @brief Monitor structure.
*/
struct _GLFWmonitor
{
2013-01-02 16:48:02 +01:00
char* name;
2012-09-13 17:46:40 +02:00
2013-01-02 16:48:02 +01:00
// Physical dimensions in millimeters.
int widthMM, heightMM;
// Logical orientation of the screen on the desktop
int positionX, positionY;
2013-01-02 16:48:02 +01:00
GLFWvidmode* modes;
int modeCount;
2013-02-12 13:50:41 +01:00
GLFWgammaramp originalRamp;
GLboolean rampChanged;
// This is defined in the window API's platform.h
_GLFW_PLATFORM_MONITOR_STATE;
};
/*! @brief Library global data.
*/
2010-10-04 18:17:53 +02:00
struct _GLFWlibrary
2010-09-09 20:18:10 +02:00
{
2013-01-02 16:48:02 +01:00
_GLFWhints hints;
2010-09-10 00:06:23 +02:00
2013-01-02 16:48:02 +01:00
_GLFWwindow* windowListHead;
_GLFWwindow* focusedWindow;
2012-09-12 19:35:52 +02:00
2013-01-02 16:48:02 +01:00
_GLFWmonitor** monitors;
int monitorCount;
GLFWmonitorfun monitorCallback;
2010-10-24 18:28:55 +02:00
// This is defined in the window API's platform.h
2012-04-22 15:53:02 +02:00
_GLFW_PLATFORM_LIBRARY_WINDOW_STATE;
// This is defined in the context API's platform.h
2012-04-22 15:53:02 +02:00
_GLFW_PLATFORM_LIBRARY_OPENGL_STATE;
2010-10-04 18:17:53 +02:00
};
2010-09-09 18:15:32 +02:00
//========================================================================
2012-08-26 20:11:32 +02:00
// Global state shared between compilation units of GLFW
//========================================================================
/*! @brief Flag indicating whether GLFW has been successfully initialized.
*/
extern GLboolean _glfwInitialized;
/*! @brief All global data protected by @ref _glfwInitialized.
* This should only be touched after a call to @ref glfwInit that has not been
* followed by a call to @ref glfwTerminate.
*/
extern _GLFWlibrary _glfw;
2010-09-09 18:15:32 +02:00
2010-09-07 17:34:51 +02:00
//========================================================================
// Platform API functions
2010-09-07 17:34:51 +02:00
//========================================================================
/*! @brief Initializes the platform-specific part of the library.
* @return @c GL_TRUE if successful, or @c GL_FALSE if an error occurred.
* @ingroup platform
*/
2010-09-08 17:30:21 +02:00
int _glfwPlatformInit(void);
/*! @brief Terminates the platform-specific part of the library.
* @ingroup platform
*/
void _glfwPlatformTerminate(void);
/*! @copydoc glfwGetVersionString
* @ingroup platform
*
* @note The returned string must be available for the duration of the program.
*
* @note The returned string must not change for the duration of the program.
*/
2010-09-13 18:05:59 +02:00
const char* _glfwPlatformGetVersionString(void);
/*! @copydoc glfwSetCursorPos
* @ingroup platform
*/
void _glfwPlatformSetCursorPos(_GLFWwindow* window, int xpos, int ypos);
/*! @brief Sets up the specified cursor mode for the specified window.
* @param[in] window The window whose cursor mode to change.
* @param[in] mode The desired cursor mode.
* @ingroup platform
*/
void _glfwPlatformSetCursorMode(_GLFWwindow* window, int mode);
2010-09-07 17:34:51 +02:00
/*! @copydoc glfwGetMonitors
* @ingroup platform
*/
2012-09-12 19:35:52 +02:00
_GLFWmonitor** _glfwPlatformGetMonitors(int* count);
/*! @copydoc glfwGetVideoModes
* @ingroup platform
*/
GLFWvidmode* _glfwPlatformGetVideoModes(_GLFWmonitor* monitor, int* count);
/*! @ingroup platform
*/
void _glfwPlatformGetVideoMode(_GLFWmonitor* monitor, GLFWvidmode* mode);
2010-09-07 17:34:51 +02:00
/*! @copydoc glfwGetGammaRamp
* @ingroup platform
*/
2013-02-12 13:50:41 +01:00
void _glfwPlatformGetGammaRamp(_GLFWmonitor* monitor, GLFWgammaramp* ramp);
/*! @copydoc glfwSetGammaRamp
* @ingroup platform
*/
2013-02-12 13:50:41 +01:00
void _glfwPlatformSetGammaRamp(_GLFWmonitor* monitor, const GLFWgammaramp* ramp);
/*! @copydoc glfwSetClipboardString
* @ingroup platform
*/
void _glfwPlatformSetClipboardString(_GLFWwindow* window, const char* string);
/*! @copydoc glfwGetClipboardString
* @ingroup platform
*
* @note The returned string must be valid until the next call to @ref
* _glfwPlatformGetClipboardString or @ref _glfwPlatformSetClipboardString.
*/
2012-04-12 00:51:58 +02:00
const char* _glfwPlatformGetClipboardString(_GLFWwindow* window);
2011-09-21 11:09:47 +02:00
/*! @copydoc glfwGetJoystickParam
* @ingroup platform
*/
2010-09-08 17:30:21 +02:00
int _glfwPlatformGetJoystickParam(int joy, int param);
/*! @copydoc glfwGetJoystickAxes
* @ingroup platform
*/
int _glfwPlatformGetJoystickAxes(int joy, float* axes, int numaxes);
/*! @copydoc glfwGetJoystickButtons
* @ingroup platform
*/
2010-09-08 17:30:21 +02:00
int _glfwPlatformGetJoystickButtons(int joy, unsigned char* buttons, int numbuttons);
/*! @copydoc glfwGetJoystickName
* @ingroup platform
*/
const char* _glfwPlatformGetJoystickName(int joy);
2010-09-07 17:34:51 +02:00
/*! @copydoc glfwGetTime
* @ingroup platform
*/
2010-09-08 17:30:21 +02:00
double _glfwPlatformGetTime(void);
/*! @copydoc glfwSetTime
* @ingroup platform
*/
2010-09-08 17:30:21 +02:00
void _glfwPlatformSetTime(double time);
2010-09-07 17:34:51 +02:00
/*! @ingroup platform
*/
int _glfwPlatformCreateWindow(_GLFWwindow* window,
const _GLFWwndconfig* wndconfig,
const _GLFWfbconfig* fbconfig);
/*! @ingroup platform
*/
void _glfwPlatformDestroyWindow(_GLFWwindow* window);
/*! @copydoc glfwSetWindowTitle
* @ingroup platform
*/
2010-09-09 18:15:32 +02:00
void _glfwPlatformSetWindowTitle(_GLFWwindow* window, const char* title);
/*! @copydoc glfwGetWindowPos
* @ingroup platform
*/
void _glfwPlatformGetWindowPos(_GLFWwindow* window, int* xpos, int* ypos);
/*! @copydoc glfwSetWindowPos
* @ingroup platform
*/
void _glfwPlatformSetWindowPos(_GLFWwindow* window, int xpos, int ypos);
/*! @copydoc glfwGetWindowSize
* @ingroup platform
*/
void _glfwPlatformGetWindowSize(_GLFWwindow* window, int* width, int* height);
/*! @copydoc glfwSetWindowSize
* @ingroup platform
*/
2010-09-09 18:15:32 +02:00
void _glfwPlatformSetWindowSize(_GLFWwindow* window, int width, int height);
/*! @copydoc glfwIconifyWindow
* @ingroup platform
*/
2010-09-09 18:15:32 +02:00
void _glfwPlatformIconifyWindow(_GLFWwindow* window);
/*! @copydoc glfwRestoreWindow
* @ingroup platform
*/
2010-09-09 18:15:32 +02:00
void _glfwPlatformRestoreWindow(_GLFWwindow* window);
/*! @copydoc glfwShowWindow
* @ingroup platform
*/
void _glfwPlatformShowWindow(_GLFWwindow* window);
/*! @copydoc glfwHideWindow
* @ingroup platform
*/
void _glfwPlatformHideWindow(_GLFWwindow* window);
2010-09-09 18:15:32 +02:00
/*! @copydoc glfwPollEvents
* @ingroup platform
*/
2010-09-09 18:15:32 +02:00
void _glfwPlatformPollEvents(void);
/*! @copydoc glfwWaitEvents
* @ingroup platform
*/
2010-09-09 18:15:32 +02:00
void _glfwPlatformWaitEvents(void);
/*! @copydoc glfwMakeContextCurrent
* @ingroup platform
*/
void _glfwPlatformMakeContextCurrent(_GLFWwindow* window);
/*! @copydoc glfwGetCurrentContext
* @ingroup platform
*/
_GLFWwindow* _glfwPlatformGetCurrentContext(void);
/*! @copydoc glfwSwapBuffers
* @ingroup platform
*/
void _glfwPlatformSwapBuffers(_GLFWwindow* window);
/*! @copydoc glfwSwapInterval
* @ingroup platform
*/
2010-09-08 17:30:21 +02:00
void _glfwPlatformSwapInterval(int interval);
/*! @ingroup platform
*/
int _glfwPlatformExtensionSupported(const char* extension);
/*! @copydoc glfwGetProcAddress
* @ingroup platform
*/
GLFWglproc _glfwPlatformGetProcAddress(const char* procname);
2010-09-07 17:34:51 +02:00
//========================================================================
// Event API functions
2010-09-07 17:34:51 +02:00
//========================================================================
/*! @brief Notifies shared code of a window focus event.
* @param[in] window The window that received the event.
* @param[in] focused @c GL_TRUE if the window received focus, or @c GL_FALSE
* if it lost focus.
* @ingroup event
*/
void _glfwInputWindowFocus(_GLFWwindow* window, GLboolean focused);
/*! @brief Notifies shared code of a window movement event.
* @param[in] window The window that received the event.
* @param[in] xpos The new x-coordinate of the client area of the window.
* @param[in] ypos The new y-coordinate of the client area of the window.
* @ingroup event
*/
void _glfwInputWindowPos(_GLFWwindow* window, int xpos, int ypos);
/*! @brief Notifies shared code of a window resize event.
* @param[in] window The window that received the event.
* @param[in] width The new width of the client area of the window.
* @param[in] height The new height of the client area of the window.
* @ingroup event
*/
void _glfwInputWindowSize(_GLFWwindow* window, int width, int height);
/*! @brief Notifies shared code of a window iconification event.
* @param[in] window The window that received the event.
* @param[in] iconified @c GL_TRUE if the window was iconified, or @c GL_FALSE
* if it was restored.
* @ingroup event
*/
void _glfwInputWindowIconify(_GLFWwindow* window, int iconified);
/*! @brief Notifies shared code of a window show/hide event.
* @param[in] window The window that received the event.
* @param[in] visible @c GL_TRUE if the window was shown, or @c GL_FALSE if it
* was hidden.
* @ingroup event
*/
void _glfwInputWindowVisibility(_GLFWwindow* window, int visible);
/*! @brief Notifies shared code of a window damage event.
* @param[in] window The window that received the event.
*/
void _glfwInputWindowDamage(_GLFWwindow* window);
/*! @brief Notifies shared code of a window close request event
* @param[in] window The window that received the event.
* @ingroup event
*/
void _glfwInputWindowCloseRequest(_GLFWwindow* window);
/*! @brief Notifies shared code of a physical key event.
* @param[in] window The window that received the event.
* @param[in] key The key that was pressed or released.
* @param[in] action @ref GLFW_PRESS or @ref GLFW_RELEASE.
* @ingroup event
*/
2010-09-09 18:15:32 +02:00
void _glfwInputKey(_GLFWwindow* window, int key, int action);
/*! @brief Notifies shared code of a Unicode character input event.
* @param[in] window The window that received the event.
* @param[in] character The Unicode code point of the input character.
* @ingroup event
*/
void _glfwInputChar(_GLFWwindow* window, int character);
/*! @brief Notifies shared code of a scroll event.
* @param[in] window The window that received the event.
* @param[in] x The scroll offset along the x-axis.
* @param[in] y The scroll offset along the y-axis.
* @ingroup event
*/
2012-03-28 21:54:09 +02:00
void _glfwInputScroll(_GLFWwindow* window, double x, double y);
/*! @brief Notifies shared code of a mouse button click event.
* @param[in] window The window that received the event.
* @param[in] button The button that was pressed or released.
* @param[in] action @ref GLFW_PRESS or @ref GLFW_RELEASE.
* @ingroup event
*/
2010-09-09 18:15:32 +02:00
void _glfwInputMouseClick(_GLFWwindow* window, int button, int action);
/*! @brief Notifies shared code of a cursor motion event.
* @param[in] window The window that received the event.
* @param[in] x The new x-coordinate of the cursor, relative to the left edge
* of the client area of the window.
* @param[in] y The new y-coordinate of the cursor, relative to the top edge
* of the client area of the window.
* @ingroup event
*/
void _glfwInputCursorMotion(_GLFWwindow* window, int x, int y);
/*! @brief Notifies shared code of a cursor enter/leave event.
* @param[in] window The window that received the event.
* @param[in] entered @c GL_TRUE if the cursor entered the client area of the
* window, or @c GL_FALSE if it left it.
* @ingroup event
*/
2012-01-30 22:59:38 +01:00
void _glfwInputCursorEnter(_GLFWwindow* window, int entered);
2010-09-07 17:34:51 +02:00
/*! @ingroup event
*/
2012-09-12 19:35:52 +02:00
void _glfwInputMonitorChange(void);
/*! @brief Notifies shared code of an error.
* @param[in] error The error code most suitable for the error.
* @param[in] format The @c printf style format string of the error
* description.
* @ingroup event
*/
void _glfwInputError(int error, const char* format, ...);
2012-08-27 03:25:58 +02:00
//========================================================================
// Utility functions
2012-08-27 03:25:58 +02:00
//========================================================================
/*! @ingroup utility
*/
const GLFWvidmode* _glfwChooseVideoMode(_GLFWmonitor* monitor,
const GLFWvidmode* desired);
/*! @brief Performs lexical comparison between two @ref GLFWvidmode structures.
* @ingroup utility
*/
2012-08-27 03:25:58 +02:00
int _glfwCompareVideoModes(const GLFWvidmode* first, const GLFWvidmode* second);
/*! @brief Splits a color depth into red, green and blue bit depths.
* @ingroup utility
*/
2012-08-27 03:25:58 +02:00
void _glfwSplitBPP(int bpp, int* red, int* green, int* blue);
/*! @brief Searches an extension string for the specified extension.
* @param[in] string The extension string to search.
* @param[in] extensions The extension to search for.
* @return @c GL_TRUE if the extension was found, or @c GL_FALSE otherwise.
* @ingroup utility
*/
2010-09-08 17:30:21 +02:00
int _glfwStringInExtensionString(const char* string, const GLubyte* extensions);
/*! @brief Checks and reads back properties from the current context.
* @return @c GL_TRUE if successful, or @c GL_FALSE if the context is unusable.
* @ingroup utility
*/
2012-08-02 14:42:24 +02:00
GLboolean _glfwRefreshContextParams(void);
/*! @brief Checks whether the desired context properties are valid.
* @param[in] wndconfig The context properties to check.
* @return @c GL_TRUE if the context properties are valid, or @c GL_FALSE
* otherwise.
* @ingroup utility
*
* This function checks things like whether the specified client API version
* exists and whether all relevant options have supported and non-conflicting
* values.
*/
2011-03-07 14:55:11 +01:00
GLboolean _glfwIsValidContextConfig(_GLFWwndconfig* wndconfig);
/*! @brief Checks whether the current context fulfils the specified hard
* constraints.
* @param[in] wndconfig The desired context properties.
* @return @c GL_TRUE if the context fulfils the hard constraints, or @c
* GL_FALSE otherwise.
* @ingroup utility
*/
2012-08-02 14:42:24 +02:00
GLboolean _glfwIsValidContext(_GLFWwndconfig* wndconfig);
2010-09-07 17:34:51 +02:00
/*! @ingroup utility
*/
2012-09-12 19:35:52 +02:00
_GLFWmonitor* _glfwCreateMonitor(const char* name,
2013-01-02 16:48:02 +01:00
int widthMM, int heightMM,
int x, int y);
/*! @ingroup utility
*/
2012-09-12 19:35:52 +02:00
void _glfwDestroyMonitor(_GLFWmonitor* monitor);
/*! @ingroup utility
*/
2012-09-12 19:35:52 +02:00
void _glfwDestroyMonitors(void);
2010-09-07 17:34:51 +02:00
#endif // _internal_h_