From 0045402c995fefa515bd56f07b64140ed6d54e59 Mon Sep 17 00:00:00 2001 From: Ray Date: Mon, 23 Apr 2018 20:59:10 +0200 Subject: [PATCH 01/53] Corrected patreon link! --- HELPME.md | 4 ++-- README.md | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/HELPME.md b/HELPME.md index e8b4fe484..eb0fe9ea8 100644 --- a/HELPME.md +++ b/HELPME.md @@ -13,7 +13,7 @@ The following help is highly appreciated: - Testers of current features and multiple systems - Can you find some bug on raylib? If you can not help on any of the above points but you still want to contribute in some way... please, consider helping -with a small [donation](http://www.raylib.com/helpme.html) or contributing with [raylib patreon](https://www.patreon.com/raysan5). It will really motivate to continue improving this project... +with a small [donation](http://www.raylib.com/helpme.html) or contributing with [raylib patreon](https://www.patreon.com/raylib). It will really motivate to continue improving this project... raylib philosophy ------------------ @@ -32,6 +32,6 @@ contact * Facebook: [http://www.facebook.com/raylibgames](http://www.facebook.com/raylibgames) * Reddit: [https://www.reddit.com/r/raylib](https://www.reddit.com/r/raylib) * Twitch: [http://www.twitch.tv/raysan5](http://www.twitch.tv/raysan5) - * Patreon: [https://www.patreon.com/raysan5](https://www.patreon.com/raysan5) + * Patreon: [https://www.patreon.com/raylib](https://www.patreon.com/raylib) [raysan5]: mailto:ray@raylib.com "Ramon Santamaria - Ray San" diff --git a/README.md b/README.md index 46b80ada7..da604004f 100644 --- a/README.md +++ b/README.md @@ -67,7 +67,7 @@ contact * Facebook: [http://www.facebook.com/raylibgames](http://www.facebook.com/raylibgames) * Reddit: [https://www.reddit.com/r/raylib](https://www.reddit.com/r/raylib) * Twitch: [http://www.twitch.tv/raysan5](http://www.twitch.tv/raysan5) - * Patreon: [https://www.patreon.com/raysan5](https://www.patreon.com/raysan5) + * Patreon: [https://www.patreon.com/raylib](https://www.patreon.com/raylib) * YouTube: [https://www.youtube.com/channel/raylib](https://www.youtube.com/channel/UC8WIBkhYb5sBNqXO1mZ7WSQ) If you are using raylib and you enjoy it, please, [let me know][raysan5]. From ca5f7ebd102656f8451a4cf99638bb94c9d00264 Mon Sep 17 00:00:00 2001 From: raysan5 Date: Sun, 29 Apr 2018 11:37:39 +0200 Subject: [PATCH 02/53] Added compile flag: SUPPORT_SCREEN_CAPTURE Allow compiling the library with support for automatic screen capture (KEY_F12) --- src/config.h | 2 ++ src/core.c | 7 +++++++ 2 files changed, 9 insertions(+) diff --git a/src/config.h b/src/config.h index a8b5ea195..5f8adcff5 100644 --- a/src/config.h +++ b/src/config.h @@ -44,6 +44,8 @@ #define SUPPORT_MOUSE_GESTURES 1 // Use busy wait loop for timing sync, if not defined, a high-resolution timer is setup and used #define SUPPORT_BUSY_WAIT_LOOP 1 +// Allow automatic screen capture of current screen pressing F12, defined in KeyCallback() +#define SUPPORT_SCREEN_CAPTURE 1 // Allow automatic gif recording of current screen pressing CTRL+F12, defined in KeyCallback() #define SUPPORT_GIF_RECORDING 1 diff --git a/src/core.c b/src/core.c index 7772027b1..86b7b8b42 100644 --- a/src/core.c +++ b/src/core.c @@ -50,6 +50,9 @@ * #define SUPPORT_BUSY_WAIT_LOOP * Use busy wait loop for timing sync, if not defined, a high-resolution timer is setup and used * +* #define SUPPORT_SCREEN_CAPTURE +* Allow automatic screen capture of current screen pressing F12, defined in KeyCallback() +* * #define SUPPORT_GIF_RECORDING * Allow automatic gif recording of current screen pressing CTRL+F12, defined in KeyCallback() * @@ -2791,10 +2794,12 @@ static void KeyCallback(GLFWwindow *window, int key, int scancode, int action, i } else #endif // SUPPORT_GIF_RECORDING + #if defined(SUPPORT_SCREEN_CAPTURE) { TakeScreenshot(FormatText("screenshot%03i.png", screenshotCounter)); screenshotCounter++; } + #endif // SUPPORT_SCREEN_CAPTURE } #endif // PLATFORM_DESKTOP else @@ -3456,12 +3461,14 @@ static void ProcessKeyboard(void) // Check exit key (same functionality as GLFW3 KeyCallback()) if (currentKeyState[exitKey] == 1) windowShouldClose = true; +#if defined(SUPPORT_SCREEN_CAPTURE) // Check screen capture key (raylib key: KEY_F12) if (currentKeyState[301] == 1) { TakeScreenshot(FormatText("screenshot%03i.png", screenshotCounter)); screenshotCounter++; } +#endif } // Restore default keyboard input From ada6668b2458f0e58e588611b2e0d70a90970827 Mon Sep 17 00:00:00 2001 From: raysan5 Date: Sun, 29 Apr 2018 11:49:10 +0200 Subject: [PATCH 03/53] Expose file-dropping functions symbols --- src/core.c | 34 +++++++++++++++++++++------------- 1 file changed, 21 insertions(+), 13 deletions(-) diff --git a/src/core.c b/src/core.c index 86b7b8b42..d1ef6522f 100644 --- a/src/core.c +++ b/src/core.c @@ -84,9 +84,8 @@ * **********************************************************************************************/ -#include "config.h" - -#include "raylib.h" +#include "config.h" // Defines module configuration flags +#include "raylib.h" // Declares module functions #if (defined(__linux__) || defined(PLATFORM_WEB)) && _POSIX_C_SOURCE < 199309L #undef _POSIX_C_SOURCE @@ -96,8 +95,8 @@ #define RAYMATH_IMPLEMENTATION // Define external out-of-line implementation of raymath here #include "raymath.h" // Required for: Vector3 and Matrix functions -#include "rlgl.h" // raylib OpenGL abstraction layer to OpenGL 1.1, 3.3+ or ES2 -#include "utils.h" // Required for: fopen() Android mapping +#include "rlgl.h" // raylib OpenGL abstraction layer to OpenGL 1.1, 3.3+ or ES2 +#include "utils.h" // Required for: fopen() Android mapping #if defined(SUPPORT_GESTURES_SYSTEM) #define GESTURES_IMPLEMENTATION @@ -111,7 +110,7 @@ #if defined(SUPPORT_GIF_RECORDING) #define RGIF_IMPLEMENTATION - #include "external/rgif.h" // Support GIF recording + #include "external/rgif.h" // Support GIF recording #endif #include // Standard input / output lib @@ -295,8 +294,6 @@ static bool cursorHidden = false; // Track if cursor is hidden static bool cursorOnScreen = false; // Tracks if cursor is inside client area #if defined(PLATFORM_DESKTOP) || defined(PLATFORM_RPI) || defined(PLATFORM_WEB) || defined(PLATFORM_UWP) -static int screenshotCounter = 0; // Screenshots counter - // Register mouse states static char previousMouseState[3] = { 0 }; // Registers previous mouse button state static char currentMouseState[3] = { 0 }; // Registers current mouse button state @@ -345,9 +342,13 @@ static double targetTime = 0.0; // Desired time for one frame, if 0 static unsigned char configFlags = 0; // Configuration flags (bit based) static bool showLogo = false; // Track if showing logo at init is enabled +#if defined(SUPPORT_SCREEN_CAPTURE) +static int screenshotCounter = 0; // Screenshots counter +#endif + #if defined(SUPPORT_GIF_RECORDING) -static int gifFramesCounter = 0; -static bool gifRecording = false; +static int gifFramesCounter = 0; // GIF frames counter +static bool gifRecording = false; // GIF recording state #endif //---------------------------------------------------------------------------------- @@ -748,7 +749,6 @@ void SetWindowSize(int width, int height) #endif } - // Get current screen width int GetScreenWidth(void) { @@ -1376,24 +1376,32 @@ bool ChangeDirectory(const char *dir) return (CHDIR(dir) == 0); } -#if defined(PLATFORM_DESKTOP) // Check if a file has been dropped into window bool IsFileDropped(void) { +#if defined(PLATFORM_DESKTOP) if (dropFilesCount > 0) return true; else return false; +#else + return false; +#endif } // Get dropped files names char **GetDroppedFiles(int *count) { +#if defined(PLATFORM_DESKTOP) *count = dropFilesCount; return dropFilesPath; +#else + return NULL; +#endif } // Clear dropped files paths buffer void ClearDroppedFiles(void) { +#if defined(PLATFORM_DESKTOP) if (dropFilesCount > 0) { for (int i = 0; i < dropFilesCount; i++) free(dropFilesPath[i]); @@ -1402,8 +1410,8 @@ void ClearDroppedFiles(void) dropFilesCount = 0; } -} #endif +} // Save integer value to storage file (to defined position) // NOTE: Storage positions is directly related to file memory layout (4 bytes each integer) From 8d81b6e4e40ea8ad01acea8bfbda38840eb7027f Mon Sep 17 00:00:00 2001 From: raysan5 Date: Sun, 29 Apr 2018 12:53:32 +0200 Subject: [PATCH 04/53] Support shapes drawing using only QUADS Also added new compilation FLAGS for that pourpose --- src/CMakeOptions.txt | 16 ++- src/config.h | 10 ++ src/config.h.in | 69 +++++----- src/shapes.c | 317 +++++++++++++++++++++++-------------------- 4 files changed, 225 insertions(+), 187 deletions(-) diff --git a/src/CMakeOptions.txt b/src/CMakeOptions.txt index 7fc7a9154..00fc79043 100644 --- a/src/CMakeOptions.txt +++ b/src/CMakeOptions.txt @@ -25,6 +25,7 @@ set_property(CACHE OPENGL_VERSION PROPERTY STRINGS "3.3" "2.1" "1.1" "ES 2.0") option(SUPPORT_BUSY_WAIT_LOOP "Use busy wait loop for timing sync instead of a high-resolution timer" ON) option(SUPPORT_CAMERA_SYSTEM "Provide camera module (camera.h) with multiple predefined cameras: free, 1st/3rd person, orbital" ON) option(SUPPORT_DEFAULT_FONT "Default font is loaded on window initialization to be available for the user to render simple text. If enabled, uses external module functions to load default raylib font (module: text)" ON) +option(SUPPORT_SCREEN_CAPTURE "Allow automatic screen capture of current screen pressing F12, defined in KeyCallback()" ON) option(SUPPORT_GIF_RECORDING "Allow automatic gif recording of current screen pressing CTRL+F12, defined in KeyCallback()" ON) option(SUPPORT_GESTURES_SYSTEM "Gestures module is included (gestures.h) to support gestures detection: tap, hold, swipe, drag" ON) option(SUPPORT_MOUSE_GESTURES "Mouse gestures are directly mapped like touches and processed by gestures system" ON) @@ -33,10 +34,9 @@ option(SUPPORT_MOUSE_GESTURES "Mouse gestures are directly mapped like touches a option(SUPPORT_VR_SIMULATOR "Support VR simulation functionality (stereo rendering)" ON) option(SUPPORT_DISTORTION_SHADER "Include stereo rendering distortion shader (shader_distortion.h)" ON) -# models.c -option(SUPPORT_FILEFORMAT_OBJ "Support loading OBJ file format" ON) -option(SUPPORT_FILEFORMAT_MTL "Support loading MTL file format" ON) -option(SUPPORT_MESH_GENERATION "Support procedural mesh generation functions, uses external par_shapes.h library. NOTE: Some generated meshes DO NOT include generated texture coordinates" ON) +# shapes.c +option(SUPPORT_FONT_TEXTURE "Draw rectangle shapes using font texture white character instead of default white texture. Allows drawing rectangles and text with a single draw call, very useful for GUI systems!" ON) +option(SUPPORT_QUADS_DRAW_MODE "Use QUADS instead of TRIANGLES for drawing when possible. Some lines-based shapes could still use lines" ON) # textures.c option(SUPPORT_IMAGE_GENERATION "Support proedural image generation functionality (gradient, spot, perlin-noise, cellular)" ON) @@ -53,6 +53,11 @@ option(SUPPORT_FILEFORMAT_PSD "Support loading PSD as textures" OFF) option(SUPPORT_FILEFORMAT_PKM "Support loading PKM as textures" OFF) option(SUPPORT_FILEFORMAT_PVR "Support loading PVR as textures" OFF) +# models.c +option(SUPPORT_FILEFORMAT_OBJ "Support loading OBJ file format" ON) +option(SUPPORT_FILEFORMAT_MTL "Support loading MTL file format" ON) +option(SUPPORT_MESH_GENERATION "Support procedural mesh generation functions, uses external par_shapes.h library. NOTE: Some generated meshes DO NOT include generated texture coordinates" ON) + # audio.c option(SUPPORT_FILEFORMAT_WAV "Support loading WAV for sound" ON) option(SUPPORT_FILEFORMAT_OGG "Support loading OGG for sound" ON) @@ -60,9 +65,6 @@ option(SUPPORT_FILEFORMAT_XM "Support loading XM for sound" ON) option(SUPPORT_FILEFORMAT_MOD "Support loading MOD for sound" ON) option(SUPPORT_FILEFORMAT_FLAC "Support loading FLAC for sound" OFF) -# shapes.c -option(USE_DEFAULT_FONT_TEXTURE "Draw rectangle shapes using font texture white character instead of default white texture. Allows drawing rectangles and text with a single draw call, very useful for GUI systems!" ON) - # utils.c option(SUPPORT_SAVE_PNG "Support saving image data in PNG file format" ON) option(SUPPORT_SAVE_BMP "Support saving image data in BMP file format" OFF) diff --git a/src/config.h b/src/config.h index 5f8adcff5..d094e6b17 100644 --- a/src/config.h +++ b/src/config.h @@ -59,6 +59,16 @@ #define SUPPORT_DISTORTION_SHADER 1 +//------------------------------------------------------------------------------------ +// Module: shapes - Configuration Flags +//------------------------------------------------------------------------------------ +// Draw rectangle shapes using font texture white character instead of default white texture +// Allows drawing rectangles and text with a single draw call, very useful for GUI systems! +#define SUPPORT_FONT_TEXTURE +// Use QUADS instead of TRIANGLES for drawing when possible +// Some lines-based shapes could still use lines +#define SUPPORT_QUADS_DRAW_MODE + //------------------------------------------------------------------------------------ // Module: textures - Configuration Flags //------------------------------------------------------------------------------------ diff --git a/src/config.h.in b/src/config.h.in index 5b6ed0546..651024c19 100644 --- a/src/config.h.in +++ b/src/config.h.in @@ -1,11 +1,28 @@ /* config.h.in */ -// text.c -/* Default font is loaded on window initialization to be available for the user to render simple text. NOTE: If enabled, uses external module functions to load default raylib font (module: text) */ -#cmakedefine SUPPORT_DEFAULT_FONT 1 -/* Selected desired fileformats to be supported for loading. */ -#cmakedefine SUPPORT_FILEFORMAT_FNT 1 -#cmakedefine SUPPORT_FILEFORMAT_TTF 1 +// core.c +/* Camera module is included (camera.h) and multiple predefined cameras are available: free, 1st/3rd person, orbital */ +#cmakedefine SUPPORT_CAMERA_SYSTEM 1 +/* Gestures module is included (gestures.h) to support gestures detection: tap, hold, swipe, drag */ +#cmakedefine SUPPORT_GESTURES_SYSTEM 1 +/* Mouse gestures are directly mapped like touches and processed by gestures system. */ +#cmakedefine SUPPORT_MOUSE_GESTURES 1 +/* Use busy wait loop for timing sync, if not defined, a high-resolution timer is setup and used */ +#cmakedefine SUPPORT_BUSY_WAIT_LOOP 1 +/* Allow automatic screen capture of current screen pressing F12, defined in KeyCallback() */ +#cmakedefine SUPPORT_SCREEN_CAPTURE 1 +/* Allow automatic gif recording of current screen pressing CTRL+F12, defined in KeyCallback() */ +#cmakedefine SUPPORT_GIF_RECORDING 1 + +// rlgl.c +/* Support VR simulation functionality (stereo rendering) */ +#cmakedefine SUPPORT_VR_SIMULATOR 1 +/* Include stereo rendering distortion shader (shader_distortion.h) */ +#cmakedefine SUPPORT_DISTORTION_SHADER 1 + +// shapes.c +#cmakedefine SUPPORT_FONT_TEXTURE 1 +#cmakedefine SUPPORT_QUADS_DRAW_MODE 1 // textures.c /* Selecte desired fileformats to be supported for image data loading. */ @@ -28,23 +45,20 @@ /* Support proedural image generation functionality (gradient, spot, perlin-noise, cellular) */ #cmakedefine SUPPORT_IMAGE_GENERATION 1 -// rlgl.c -/* Support VR simulation functionality (stereo rendering) */ -#cmakedefine SUPPORT_VR_SIMULATOR 1 -/* Include stereo rendering distortion shader (shader_distortion.h) */ -#cmakedefine SUPPORT_DISTORTION_SHADER 1 +// text.c +/* Default font is loaded on window initialization to be available for the user to render simple text. NOTE: If enabled, uses external module functions to load default raylib font (module: text) */ +#cmakedefine SUPPORT_DEFAULT_FONT 1 +/* Selected desired fileformats to be supported for loading. */ +#cmakedefine SUPPORT_FILEFORMAT_FNT 1 +#cmakedefine SUPPORT_FILEFORMAT_TTF 1 -// core.c -/* Camera module is included (camera.h) and multiple predefined cameras are available: free, 1st/3rd person, orbital */ -#cmakedefine SUPPORT_CAMERA_SYSTEM 1 -/* Gestures module is included (gestures.h) to support gestures detection: tap, hold, swipe, drag */ -#cmakedefine SUPPORT_GESTURES_SYSTEM 1 -/* Mouse gestures are directly mapped like touches and processed by gestures system. */ -#cmakedefine SUPPORT_MOUSE_GESTURES 1 -/* Use busy wait loop for timing sync, if not defined, a high-resolution timer is setup and used */ -#cmakedefine SUPPORT_BUSY_WAIT_LOOP 1 -/* Allow automatic gif recording of current screen pressing CTRL+F12, defined in KeyCallback() */ -#cmakedefine SUPPORT_GIF_RECORDING 1 +// models.c +/* Selected desired fileformats to be supported for loading. */ +#cmakedefine SUPPORT_FILEFORMAT_OBJ 1 +#cmakedefine SUPPORT_FILEFORMAT_MTL 1 +/* Support procedural mesh generation functions, uses external par_shapes.h library + * NOTE: Some generated meshes DO NOT include generated texture coordinates */ +#cmakedefine SUPPORT_MESH_GENERATION 1 // audio.c /* Desired fileformats to be supported for loading. */ @@ -54,20 +68,9 @@ #cmakedefine SUPPORT_FILEFORMAT_MOD 1 #cmakedefine SUPPORT_FILEFORMAT_FLAC 1 -// models.c -/* Selected desired fileformats to be supported for loading. */ -#cmakedefine SUPPORT_FILEFORMAT_OBJ 1 -#cmakedefine SUPPORT_FILEFORMAT_MTL 1 - -/* Support procedural mesh generation functions, uses external par_shapes.h library - * NOTE: Some generated meshes DO NOT include generated texture coordinates - */ -#cmakedefine SUPPORT_MESH_GENERATION 1 - // utils.c /* Show TraceLog() output messages. NOTE: By default LOG_DEBUG traces not shown */ #cmakedefine SUPPORT_TRACELOG 1 - /* Support saving image data as PNG fileformat. NOTE: Requires stb_image_write library */ #cmakedefine SUPPORT_SAVE_PNG 1 /* Support saving image data as PMP fileformat. NOTE: Requires stb_image_write library */ diff --git a/src/shapes.c b/src/shapes.c index a1bc7098c..d8e52b044 100644 --- a/src/shapes.c +++ b/src/shapes.c @@ -4,10 +4,13 @@ * * CONFIGURATION: * -* #define USE_DEFAULT_FONT_TEXTURE +* #define SUPPORT_FONT_TEXTURE * Draw rectangle shapes using font texture white character instead of default white texture * Allows drawing rectangles and text with a single draw call, very useful for GUI systems! * +* #define SUPPORT_QUADS_DRAW_MODE +* Use QUADS instead of TRIANGLES for drawing when possible. +* Some lines-based shapes could still use lines * * LICENSE: zlib/libpng * @@ -30,13 +33,12 @@ * **********************************************************************************************/ -#include "config.h" - -#include "raylib.h" +#include "config.h" // Defines module configuration flags +#include "raylib.h" // Declares module functions #include "rlgl.h" // raylib OpenGL abstraction layer to OpenGL 1.1, 2.1, 3.3+ or ES2 -#include // Required for: abs() +#include // Required for: abs(), fabs() #include // Required for: sinf(), cosf(), sqrtf() //---------------------------------------------------------------------------------- @@ -188,37 +190,34 @@ void DrawCircleGradient(int centerX, int centerY, float radius, Color color1, Co // NOTE: On OpenGL 3.3 and ES2 we use QUADS to avoid drawing order issues (view rlglDraw) void DrawCircleV(Vector2 center, float radius, Color color) { - if (rlGetVersion() == OPENGL_11) - { - rlBegin(RL_TRIANGLES); - for (int i = 0; i < 360; i += 10) - { - rlColor4ub(color.r, color.g, color.b, color.a); - - rlVertex2f(center.x, center.y); - rlVertex2f(center.x + sinf(DEG2RAD*i)*radius, center.y + cosf(DEG2RAD*i)*radius); - rlVertex2f(center.x + sinf(DEG2RAD*(i + 10))*radius, center.y + cosf(DEG2RAD*(i + 10))*radius); - } - rlEnd(); - } - else if ((rlGetVersion() == OPENGL_21) || (rlGetVersion() == OPENGL_33) || (rlGetVersion() == OPENGL_ES_20)) - { - rlEnableTexture(GetTextureDefault().id); // Default white texture +#if defined(SUPPORT_QUADS_DRAW_MODE) + rlEnableTexture(GetTextureDefault().id); // Default white texture - rlBegin(RL_QUADS); - for (int i = 0; i < 360; i += 20) - { - rlColor4ub(color.r, color.g, color.b, color.a); - - rlVertex2f(center.x, center.y); - rlVertex2f(center.x + sinf(DEG2RAD*i)*radius, center.y + cosf(DEG2RAD*i)*radius); - rlVertex2f(center.x + sinf(DEG2RAD*(i + 10))*radius, center.y + cosf(DEG2RAD*(i + 10))*radius); - rlVertex2f(center.x + sinf(DEG2RAD*(i + 20))*radius, center.y + cosf(DEG2RAD*(i + 20))*radius); - } - rlEnd(); + rlBegin(RL_QUADS); + for (int i = 0; i < 360; i += 20) + { + rlColor4ub(color.r, color.g, color.b, color.a); + + rlVertex2f(center.x, center.y); + rlVertex2f(center.x + sinf(DEG2RAD*i)*radius, center.y + cosf(DEG2RAD*i)*radius); + rlVertex2f(center.x + sinf(DEG2RAD*(i + 10))*radius, center.y + cosf(DEG2RAD*(i + 10))*radius); + rlVertex2f(center.x + sinf(DEG2RAD*(i + 20))*radius, center.y + cosf(DEG2RAD*(i + 20))*radius); + } + rlEnd(); - rlDisableTexture(); - } + rlDisableTexture(); +#else + rlBegin(RL_TRIANGLES); + for (int i = 0; i < 360; i += 10) + { + rlColor4ub(color.r, color.g, color.b, color.a); + + rlVertex2f(center.x, center.y); + rlVertex2f(center.x + sinf(DEG2RAD*i)*radius, center.y + cosf(DEG2RAD*i)*radius); + rlVertex2f(center.x + sinf(DEG2RAD*(i + 10))*radius, center.y + cosf(DEG2RAD*(i + 10))*radius); + } + rlEnd(); +#endif } // Draw circle outline @@ -249,72 +248,69 @@ void DrawRectangle(int posX, int posY, int width, int height, Color color) // NOTE: On OpenGL 3.3 and ES2 we use QUADS to avoid drawing order issues (view rlglDraw) void DrawRectangleV(Vector2 position, Vector2 size, Color color) { - if (rlGetVersion() == OPENGL_11) - { - rlBegin(RL_TRIANGLES); - rlColor4ub(color.r, color.g, color.b, color.a); +#if defined(SUPPORT_QUADS_DRAW_MODE) + #if defined(SUPPORT_FONT_TEXTURE) + // Draw rectangle using font texture white character + rlEnableTexture(GetDefaultFont().texture.id); - rlVertex2i(position.x, position.y); - rlVertex2i(position.x, position.y + size.y); - rlVertex2i(position.x + size.x, position.y + size.y); + rlBegin(RL_QUADS); + rlColor4ub(color.r, color.g, color.b, color.a); + rlNormal3f(0.0f, 0.0f, 1.0f); - rlVertex2i(position.x, position.y); - rlVertex2i(position.x + size.x, position.y + size.y); - rlVertex2i(position.x + size.x, position.y); - rlEnd(); - } - else if ((rlGetVersion() == OPENGL_21) || (rlGetVersion() == OPENGL_33) || (rlGetVersion() == OPENGL_ES_20)) - { -#if defined(USE_DEFAULT_FONT_TEXTURE) - // Draw rectangle using font texture white character - rlEnableTexture(GetDefaultFont().texture.id); - - rlBegin(RL_QUADS); - rlColor4ub(color.r, color.g, color.b, color.a); - rlNormal3f(0.0f, 0.0f, 1.0f); - - // NOTE: Default raylib font character 95 is a white square - rlTexCoord2f((float)GetDefaultFont().chars[95].rec.x/GetDefaultFont().texture.width, - (float)GetDefaultFont().chars[95].rec.y/GetDefaultFont().texture.height); - rlVertex2f(position.x, position.y); - - rlTexCoord2f((float)GetDefaultFont().chars[95].rec.x/GetDefaultFont().texture.width, - (float)(GetDefaultFont().chars[95].rec.y + GetDefaultFont().chars[95].rec.height)/GetDefaultFont().texture.height); - rlVertex2f(position.x, position.y + size.y); - - rlTexCoord2f((float)(GetDefaultFont().chars[95].rec.x + GetDefaultFont().chars[95].rec.width)/GetDefaultFont().texture.width, - (float)(GetDefaultFont().chars[95].rec.y + GetDefaultFont().chars[95].rec.height)/GetDefaultFont().texture.height); - rlVertex2f(position.x + size.x, position.y + size.y); - - rlTexCoord2f((float)(GetDefaultFont().chars[95].rec.x + GetDefaultFont().chars[95].rec.width)/GetDefaultFont().texture.width, - (float)GetDefaultFont().chars[95].rec.y/GetDefaultFont().texture.height); - rlVertex2f(position.x + size.x, position.y); - rlEnd(); + // NOTE: Default raylib font character 95 is a white square + rlTexCoord2f((float)GetDefaultFont().chars[95].rec.x/GetDefaultFont().texture.width, + (float)GetDefaultFont().chars[95].rec.y/GetDefaultFont().texture.height); + rlVertex2f(position.x, position.y); - rlDisableTexture(); + rlTexCoord2f((float)GetDefaultFont().chars[95].rec.x/GetDefaultFont().texture.width, + (float)(GetDefaultFont().chars[95].rec.y + GetDefaultFont().chars[95].rec.height)/GetDefaultFont().texture.height); + rlVertex2f(position.x, position.y + size.y); + + rlTexCoord2f((float)(GetDefaultFont().chars[95].rec.x + GetDefaultFont().chars[95].rec.width)/GetDefaultFont().texture.width, + (float)(GetDefaultFont().chars[95].rec.y + GetDefaultFont().chars[95].rec.height)/GetDefaultFont().texture.height); + rlVertex2f(position.x + size.x, position.y + size.y); + + rlTexCoord2f((float)(GetDefaultFont().chars[95].rec.x + GetDefaultFont().chars[95].rec.width)/GetDefaultFont().texture.width, + (float)GetDefaultFont().chars[95].rec.y/GetDefaultFont().texture.height); + rlVertex2f(position.x + size.x, position.y); + rlEnd(); + + rlDisableTexture(); + #else + rlEnableTexture(GetTextureDefault().id); // Default white texture + + rlBegin(RL_QUADS); + rlColor4ub(color.r, color.g, color.b, color.a); + rlNormal3f(0.0f, 0.0f, 1.0f); + + rlTexCoord2f(0.0f, 0.0f); + rlVertex2f(position.x, position.y); + + rlTexCoord2f(0.0f, 1.0f); + rlVertex2f(position.x, position.y + size.y); + + rlTexCoord2f(1.0f, 1.0f); + rlVertex2f(position.x + size.x, position.y + size.y); + + rlTexCoord2f(1.0f, 0.0f); + rlVertex2f(position.x + size.x, position.y); + rlEnd(); + + rlDisableTexture(); + #endif // SUPPORT_FONT_TEXTURE #else - rlEnableTexture(GetTextureDefault().id); // Default white texture + rlBegin(RL_TRIANGLES); + rlColor4ub(color.r, color.g, color.b, color.a); - rlBegin(RL_QUADS); - rlColor4ub(color.r, color.g, color.b, color.a); - rlNormal3f(0.0f, 0.0f, 1.0f); + rlVertex2i(position.x, position.y); + rlVertex2i(position.x, position.y + size.y); + rlVertex2i(position.x + size.x, position.y + size.y); - rlTexCoord2f(0.0f, 0.0f); - rlVertex2f(position.x, position.y); - - rlTexCoord2f(0.0f, 1.0f); - rlVertex2f(position.x, position.y + size.y); - - rlTexCoord2f(1.0f, 1.0f); - rlVertex2f(position.x + size.x, position.y + size.y); - - rlTexCoord2f(1.0f, 0.0f); - rlVertex2f(position.x + size.x, position.y); - rlEnd(); - - rlDisableTexture(); -#endif - } + rlVertex2i(position.x, position.y); + rlVertex2i(position.x + size.x, position.y + size.y); + rlVertex2i(position.x + size.x, position.y); + rlEnd(); +#endif // SUPPORT_QUADS_DRAW_MODE } // Draw a color-filled rectangle @@ -364,7 +360,7 @@ void DrawRectangleGradientH(int posX, int posY, int width, int height, Color col // NOTE: Colors refer to corners, starting at top-lef corner and counter-clockwise void DrawRectangleGradientEx(Rectangle rec, Color col1, Color col2, Color col3, Color col4) { -#if defined(USE_DEFAULT_FONT_TEXTURE) +#if defined(SUPPORT_FONT_TEXTURE) // Draw rectangle using font texture white character rlEnableTexture(GetDefaultFont().texture.id); @@ -425,30 +421,27 @@ void DrawRectangleGradientEx(Rectangle rec, Color col1, Color col2, Color col3, // NOTE: On OpenGL 3.3 and ES2 we use QUADS to avoid drawing order issues (view rlglDraw) void DrawRectangleLines(int posX, int posY, int width, int height, Color color) { - if (rlGetVersion() == OPENGL_11) - { - rlBegin(RL_LINES); - rlColor4ub(color.r, color.g, color.b, color.a); - rlVertex2i(posX + 1, posY + 1); - rlVertex2i(posX + width, posY + 1); +#if defined(SUPPORT_QUADS_DRAW_MODE) + DrawRectangle(posX, posY, width, 1, color); + DrawRectangle(posX + width - 1, posY + 1, 1, height - 2, color); + DrawRectangle(posX, posY + height - 1, width, 1, color); + DrawRectangle(posX, posY + 1, 1, height - 2, color); +#else + rlBegin(RL_LINES); + rlColor4ub(color.r, color.g, color.b, color.a); + rlVertex2i(posX + 1, posY + 1); + rlVertex2i(posX + width, posY + 1); - rlVertex2i(posX + width, posY + 1); - rlVertex2i(posX + width, posY + height); + rlVertex2i(posX + width, posY + 1); + rlVertex2i(posX + width, posY + height); - rlVertex2i(posX + width, posY + height); - rlVertex2i(posX + 1, posY + height); + rlVertex2i(posX + width, posY + height); + rlVertex2i(posX + 1, posY + height); - rlVertex2i(posX + 1, posY + height); - rlVertex2i(posX + 1, posY + 1); - rlEnd(); - } - else if ((rlGetVersion() == OPENGL_21) || (rlGetVersion() == OPENGL_33) || (rlGetVersion() == OPENGL_ES_20)) - { - DrawRectangle(posX, posY, width, 1, color); - DrawRectangle(posX + width - 1, posY + 1, 1, height - 2, color); - DrawRectangle(posX, posY + height - 1, width, 1, color); - DrawRectangle(posX, posY + 1, 1, height - 2, color); - } + rlVertex2i(posX + 1, posY + height); + rlVertex2i(posX + 1, posY + 1); + rlEnd(); +#endif } // Draw rectangle outline with extended parameters @@ -469,31 +462,29 @@ void DrawRectangleLinesEx(Rectangle rec, int lineThick, Color color) // Draw a triangle void DrawTriangle(Vector2 v1, Vector2 v2, Vector2 v3, Color color) { - if (rlGetVersion() == OPENGL_11) - { - rlBegin(RL_TRIANGLES); - rlColor4ub(color.r, color.g, color.b, color.a); - rlVertex2f(v1.x, v1.y); - rlVertex2f(v2.x, v2.y); - rlVertex2f(v3.x, v3.y); - rlEnd(); - } - else if ((rlGetVersion() == OPENGL_21) || (rlGetVersion() == OPENGL_33) || (rlGetVersion() == OPENGL_ES_20)) - { - rlEnableTexture(GetTextureDefault().id); // Default white texture +#if defined(SUPPORT_QUADS_DRAW_MODE) + rlEnableTexture(GetTextureDefault().id); // Default white texture - rlBegin(RL_QUADS); - rlColor4ub(color.r, color.g, color.b, color.a); - rlVertex2f(v1.x, v1.y); - rlVertex2f(v2.x, v2.y); - rlVertex2f(v2.x, v2.y); - rlVertex2f(v3.x, v3.y); - rlEnd(); - - rlDisableTexture(); - } + rlBegin(RL_QUADS); + rlColor4ub(color.r, color.g, color.b, color.a); + rlVertex2f(v1.x, v1.y); + rlVertex2f(v2.x, v2.y); + rlVertex2f(v2.x, v2.y); + rlVertex2f(v3.x, v3.y); + rlEnd(); + + rlDisableTexture(); +#else + rlBegin(RL_TRIANGLES); + rlColor4ub(color.r, color.g, color.b, color.a); + rlVertex2f(v1.x, v1.y); + rlVertex2f(v2.x, v2.y); + rlVertex2f(v3.x, v3.y); + rlEnd(); +#endif } +// Draw a triangle using lines void DrawTriangleLines(Vector2 v1, Vector2 v2, Vector2 v3, Color color) { rlBegin(RL_LINES); @@ -517,7 +508,23 @@ void DrawPoly(Vector2 center, int sides, float radius, float rotation, Color col rlPushMatrix(); rlTranslatef(center.x, center.y, 0.0); rlRotatef(rotation, 0, 0, 1); + + #if defined(SUPPORT_QUADS_DRAW_MODE) + rlEnableTexture(GetTextureDefault().id); // Default white texture + rlBegin(RL_QUADS); + for (int i = 0; i < 360; i += 360/sides) + { + rlColor4ub(color.r, color.g, color.b, color.a); + + rlVertex2f(0, 0); + rlVertex2f(sinf(DEG2RAD*i)*radius, cosf(DEG2RAD*i)*radius); + rlVertex2f(sinf(DEG2RAD*i)*radius, cosf(DEG2RAD*i)*radius); + rlVertex2f(sinf(DEG2RAD*(i + 360/sides))*radius, cosf(DEG2RAD*(i + 360/sides))*radius); + } + rlEnd(); + rlDisableTexture(); + #else rlBegin(RL_TRIANGLES); for (int i = 0; i < 360; i += 360/sides) { @@ -528,38 +535,54 @@ void DrawPoly(Vector2 center, int sides, float radius, float rotation, Color col rlVertex2f(sinf(DEG2RAD*(i + 360/sides))*radius, cosf(DEG2RAD*(i + 360/sides))*radius); } rlEnd(); + #endif rlPopMatrix(); } // Draw a closed polygon defined by points -// NOTE: Array num elements MUST be passed as parameter to function -void DrawPolyEx(Vector2 *points, int numPoints, Color color) +void DrawPolyEx(Vector2 *points, int pointsCount, Color color) { - if (numPoints >= 3) + if (pointsCount >= 3) { + #if defined(SUPPORT_QUADS_DRAW_MODE) + rlEnableTexture(GetTextureDefault().id); // Default white texture + + rlBegin(RL_QUADS); + rlColor4ub(color.r, color.g, color.b, color.a); + + for (int i = 1; i < pointsCount - 1; i++) + { + rlVertex2f(points[0].x, points[0].y); + rlVertex2f(points[i].x, points[i].y); + rlVertex2f(points[i].x, points[i].y); + rlVertex2f(points[i + 1].x, points[i + 1].y); + } + rlEnd(); + rlDisableTexture(); + #else rlBegin(RL_TRIANGLES); rlColor4ub(color.r, color.g, color.b, color.a); - for (int i = 1; i < numPoints - 1; i++) + for (int i = 1; i < pointsCount - 1; i++) { rlVertex2f(points[0].x, points[0].y); rlVertex2f(points[i].x, points[i].y); rlVertex2f(points[i + 1].x, points[i + 1].y); } rlEnd(); + #endif } } -// Draw polygon lines -// NOTE: Array num elements MUST be passed as parameter to function -void DrawPolyExLines(Vector2 *points, int numPoints, Color color) +// Draw polygon using lines +void DrawPolyExLines(Vector2 *points, int pointsCount, Color color) { - if (numPoints >= 2) + if (pointsCount >= 2) { rlBegin(RL_LINES); rlColor4ub(color.r, color.g, color.b, color.a); - for (int i = 0; i < numPoints - 1; i++) + for (int i = 0; i < pointsCount - 1; i++) { rlVertex2f(points[i].x, points[i].y); rlVertex2f(points[i + 1].x, points[i + 1].y); From dff10284666ad30823fa88ec57d0ae8eac7e7fad Mon Sep 17 00:00:00 2001 From: raysan5 Date: Sun, 29 Apr 2018 18:39:46 +0200 Subject: [PATCH 05/53] Replaced ColorToFloat() by ColorNormalize() --- src/core.c | 26 +++++++++++++------------- src/raylib.h | 2 +- 2 files changed, 14 insertions(+), 14 deletions(-) diff --git a/src/core.c b/src/core.c index d1ef6522f..3f071fc6f 100644 --- a/src/core.c +++ b/src/core.c @@ -1156,25 +1156,25 @@ double GetTime(void) #endif } -// Returns normalized float array for a Color -float *ColorToFloat(Color color) -{ - static float buffer[4]; - - buffer[0] = (float)color.r/255; - buffer[1] = (float)color.g/255; - buffer[2] = (float)color.b/255; - buffer[3] = (float)color.a/255; - - return buffer; -} - // Returns hexadecimal value for a Color int ColorToInt(Color color) { return (((int)color.r << 24) | ((int)color.g << 16) | ((int)color.b << 8) | (int)color.a); } +// Returns color normalized as float [0..1] +Vector4 ColorNormalize(Color color) +{ + Vector4 result; + + result.x = (float)color.r/255.0f; + result.y = (float)color.g/255.0f; + result.z = (float)color.b/255.0f; + result.w = (float)color.a/255.0f; + + return result; +} + // Returns HSV values for a Color // NOTE: Hue is returned as degrees [0..360] Vector3 ColorToHSV(Color color) diff --git a/src/raylib.h b/src/raylib.h index 4315afc56..b03a93f30 100644 --- a/src/raylib.h +++ b/src/raylib.h @@ -745,8 +745,8 @@ RLAPI float GetFrameTime(void); // Returns tim RLAPI double GetTime(void); // Returns elapsed time in seconds since InitWindow() // Color-related functions -RLAPI float *ColorToFloat(Color color); // Returns normalized float array for a Color RLAPI int ColorToInt(Color color); // Returns hexadecimal value for a Color +RLAPI Vector4 ColorNormalize(Color color); // Returns color normalized as float [0..1] RLAPI Vector3 ColorToHSV(Color color); // Returns HSV values for a Color RLAPI Color GetColor(int hexValue); // Returns a Color struct from hexadecimal value RLAPI Color Fade(Color color, float alpha); // Color fade-in or fade-out, alpha goes from 0.0f to 1.0f From c51203ae7e7aefac5fa95097d424aefdbe9c759c Mon Sep 17 00:00:00 2001 From: raysan5 Date: Sun, 29 Apr 2018 18:39:57 +0200 Subject: [PATCH 06/53] Corrected alpha blending on ImageDraw() --- src/textures.c | 52 ++++++++++++++++++++++---------------------------- 1 file changed, 23 insertions(+), 29 deletions(-) diff --git a/src/textures.c b/src/textures.c index 43453f73b..eadb0c593 100644 --- a/src/textures.c +++ b/src/textures.c @@ -1312,44 +1312,38 @@ void ImageDraw(Image *dst, Image src, Rectangle srcRec, Rectangle dstRec) UnloadImage(srcCopy); // Source copy not required any more... - Color srcCol, dstCol; - + Vector4 fsrc, fdst, fout; // float based versions of pixel data + // Blit pixels, copy source image into destination // TODO: Probably out-of-bounds blitting could be considered here instead of so much cropping... for (int j = dstRec.y; j < (dstRec.y + dstRec.height); j++) { for (int i = dstRec.x; i < (dstRec.x + dstRec.width); i++) { - // Alpha blending implementation - dstCol = dstPixels[j*dst->width + i]; - srcCol = srcPixels[(j - dstRec.y)*dstRec.width + (i - dstRec.x)]; + // Alpha blending (https://en.wikipedia.org/wiki/Alpha_compositing) - /* - // Pre-multiply alpha - Vector3 dstColf = { (float)dstCol.r/255.0f, (float)dstCol.g/255.0f, (float)dstCol.b/255.0f }; - dstColf = Vector3Multiply(dstColf, (float)dstCol.a/255.0f); - Vector3 srcColf = { (float)srcCol.r/255.0f, (float)srcCol.g/255.0f, (float)srcCol.b/255.0f }; - srcColf = Vector3Multiply(srcColf, (float)srcCol.a/255.0f); - - dstColf = Vector3Add(dstColf, srcColf); - - if (dstColf.x > 1.0f) dstColf.x = 1.0f; - if (dstColf.y > 1.0f) dstColf.y = 1.0f; - if (dstColf.z > 1.0f) dstColf.z = 1.0f; - - dstCol.r = (unsigned char)(dstColf.x*255.0f); - dstCol.g = (unsigned char)(dstColf.y*255.0f); - dstCol.b = (unsigned char)(dstColf.z*255.0f); - dstCol.a = srcCol.a; - */ + fdst = ColorNormalize(dstPixels[j*dst->width + i]); + fsrc = ColorNormalize(srcPixels[(j - dstRec.y)*dstRec.width + (i - dstRec.x)]); - dstCol.r = ((srcCol.a*(srcCol.r - dstCol.r)) >> 8) + dstCol.r; - dstCol.g = ((srcCol.a*(srcCol.g - dstCol.g)) >> 8) + dstCol.g; - dstCol.b = ((srcCol.a*(srcCol.b - dstCol.b)) >> 8) + dstCol.b; - //dstCol.a = ((srcCol.a*(srcCol.a - dstCol.a)) >> 8) + dstCol.a; - dstCol.a = srcCol.a; + fout.w = fsrc.w + fdst.w*(1.0f - fsrc.w); + + if (fout.w <= 0.0f) + { + fout.x = 0.0f; + fout.y = 0.0f; + fout.z = 0.0f; + } + else + { + fout.x = (fsrc.x*fsrc.w + fdst.x*fdst.w*(1 - fsrc.w))/fout.w; + fout.y = (fsrc.y*fsrc.w + fdst.y*fdst.w*(1 - fsrc.w))/fout.w; + fout.z = (fsrc.z*fsrc.w + fdst.z*fdst.w*(1 - fsrc.w))/fout.w; + } - dstPixels[j*dst->width + i] = dstCol; + dstPixels[j*dst->width + i] = (Color){ (unsigned char)(fout.x*255.0f), + (unsigned char)(fout.y*255.0f), + (unsigned char)(fout.z*255.0f), + (unsigned char)(fout.w*255.0f) }; // TODO: Support other blending options } From 23e335d93355a948adeb8d10ee6277939aaab43e Mon Sep 17 00:00:00 2001 From: raysan5 Date: Mon, 30 Apr 2018 02:47:48 +0200 Subject: [PATCH 07/53] Implemented MeshTangents() - Added Vector3OrthoNormalize() to raymath.h - not sure if it is correct - Implemented MeshBinormals() - Mesh struct has not a place for them... - Updated model_material_pbr example - tested but not working on my GPU (old Intel HD), actually, it never worked on it... --- examples/models/models_material_pbr.c | 1 + src/models.c | 83 +++++++++++++++++++++++++-- src/raymath.h | 11 ++++ 3 files changed, 91 insertions(+), 4 deletions(-) diff --git a/examples/models/models_material_pbr.c b/examples/models/models_material_pbr.c index 4ad2c9e75..ee13fddf1 100644 --- a/examples/models/models_material_pbr.c +++ b/examples/models/models_material_pbr.c @@ -38,6 +38,7 @@ int main() // Load model and PBR material Model model = LoadModel("resources/pbr/trooper.obj"); + MeshTangents(&model.mesh); model.material = LoadMaterialPBR((Color){ 255, 255, 255, 255 }, 1.0f, 1.0f); // Define lights attributes diff --git a/src/models.c b/src/models.c index 4793ee0a6..3ed3678e6 100644 --- a/src/models.c +++ b/src/models.c @@ -2119,16 +2119,91 @@ BoundingBox MeshBoundingBox(Mesh mesh) return box; } -// Compute mesh tangents +// Compute mesh tangents +// NOTE: To calculate mesh tangents and binormals we need mesh vertex positions and texture coordinates +// Implementation base don: https://answers.unity.com/questions/7789/calculating-tangents-vector4.html void MeshTangents(Mesh *mesh) { - // TODO: Compute mesh tangents + if (mesh->tangents == NULL) mesh->tangents = (float *)malloc(mesh->vertexCount*4*sizeof(float)); + else TraceLog(LOG_WARNING, "Mesh tangents already exist"); + + Vector3 *tan1 = (Vector3 *)malloc(mesh->vertexCount*sizeof(Vector3)); + Vector3 *tan2 = (Vector3 *)malloc(mesh->vertexCount*sizeof(Vector3)); + + for (int i = 0; i < mesh->vertexCount; i += 3) + { + // Get triangle vertices + Vector3 v1 = { mesh->vertices[(i + 0)*3 + 0], mesh->vertices[(i + 0)*3 + 1], mesh->vertices[(i + 0)*3 + 2] }; + Vector3 v2 = { mesh->vertices[(i + 1)*3 + 0], mesh->vertices[(i + 1)*3 + 1], mesh->vertices[(i + 1)*3 + 2] }; + Vector3 v3 = { mesh->vertices[(i + 2)*3 + 0], mesh->vertices[(i + 2)*3 + 1], mesh->vertices[(i + 2)*3 + 2] }; + + // Get triangle texcoords + Vector2 uv1 = { mesh->texcoords[(i + 0)*2 + 0], mesh->texcoords[(i + 0)*2 + 1] }; + Vector2 uv2 = { mesh->texcoords[(i + 1)*2 + 0], mesh->texcoords[(i + 1)*2 + 1] }; + Vector2 uv3 = { mesh->texcoords[(i + 2)*2 + 0], mesh->texcoords[(i + 2)*2 + 1] }; + + float x1 = v2.x - v1.x; + float y1 = v2.y - v1.y; + float z1 = v2.z - v1.z; + float x2 = v3.x - v1.x; + float y2 = v3.y - v1.y; + float z2 = v3.z - v1.z; + + float s1 = uv2.x - uv1.x; + float t1 = uv2.y - uv1.y; + float s2 = uv3.x - uv1.x; + float t2 = uv3.y - uv1.y; + + float div = s1*t2 - s2*t1; + float r = (div == 0.0f) ? 0.0f : 1.0f/div; + + Vector3 sdir = { (t2*x1 - t1*x2)*r, (t2*y1 - t1*y2)*r, (t2*z1 - t1*z2)*r }; + Vector3 tdir = { (s1*x2 - s2*x1)*r, (s1*y2 - s2*y1)*r, (s1*z2 - s2*z1)*r }; + + tan1[i + 0] = sdir; + tan1[i + 1] = sdir; + tan1[i + 2] = sdir; + + tan2[i + 0] = tdir; + tan2[i + 1] = tdir; + tan2[i + 2] = tdir; + } + + // Compute tangents considering normals + for (int i = 0; i < mesh->vertexCount; ++i) + { + Vector3 normal = { mesh->normals[i*3 + 0], mesh->normals[i*3 + 1], mesh->normals[i*3 + 2] }; + Vector3 tangent = tan1[i]; + + //Vector3 tmp = (t - n * Vector3.Dot(n, t)).normalized; + //tangents[i] = (Vector4){ tmp.x, tmp.y, tmp.z }; + Vector3OrthoNormalize(&normal, &tangent); + + mesh->tangents[i*4 + 0] = tangent.x; + mesh->tangents[i*4 + 1] = tangent.y; + mesh->tangents[i*4 + 2] = tangent.z; + mesh->tangents[i*4 + 3] = (Vector3DotProduct(Vector3CrossProduct(normal, tangent), tan2[i]) < 0.0f) ? -1.0f : 1.0f; + } + + free(tan1); + free(tan2); + + TraceLog(LOG_INFO, "Tangents computed for mesh"); } -// Compute mesh binormals +// Compute mesh binormals (aka bitangent) void MeshBinormals(Mesh *mesh) { - // TODO: Compute mesh binormals + for (int i = 0; i < mesh->vertexCount; i++) + { + Vector3 normal = { mesh->normals[i*3 + 0], mesh->normals[i*3 + 1], mesh->normals[i*3 + 2] }; + Vector3 tangent = { mesh->tangents[i*4 + 0], mesh->tangents[i*4 + 1], mesh->tangents[i*4 + 2] }; + float tangentW = mesh->tangents[i*4 + 3]; + + Vector3 binormal = Vector3Multiply(Vector3CrossProduct(normal, tangent), tangentW); + + // TODO: Register computed binormal in mesh->binormal ? + } } //---------------------------------------------------------------------------------- diff --git a/src/raymath.h b/src/raymath.h index d49f36226..b0046522f 100644 --- a/src/raymath.h +++ b/src/raymath.h @@ -372,6 +372,17 @@ RMDEF Vector3 Vector3Normalize(Vector3 v) return result; } +// Orthonormalize provided vectors +// Makes vectors normalized and orthogonal to each other +// Gram-Schmidt function implementation +RMDEF void Vector3OrthoNormalize(Vector3 *v1, Vector3 *v2) +{ + *v1 = Vector3Normalize(*v1); + Vector3 vn = Vector3CrossProduct(*v1, *v2); + vn = Vector3Normalize(vn); + *v2 = Vector3CrossProduct(vn, *v1); +} + // Transforms a Vector3 by a given Matrix RMDEF Vector3 Vector3Transform(Vector3 v, Matrix mat) { From 400c345f96538299b5c40078c4e4d25a1b958408 Mon Sep 17 00:00:00 2001 From: raysan5 Date: Mon, 30 Apr 2018 11:21:44 +0200 Subject: [PATCH 08/53] Added tangent computation alternative method As stated in the note, I'm not sure if math is right, just followed a reference implementation... --- src/models.c | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/src/models.c b/src/models.c index 3ed3678e6..387917473 100644 --- a/src/models.c +++ b/src/models.c @@ -2175,14 +2175,21 @@ void MeshTangents(Mesh *mesh) Vector3 normal = { mesh->normals[i*3 + 0], mesh->normals[i*3 + 1], mesh->normals[i*3 + 2] }; Vector3 tangent = tan1[i]; - //Vector3 tmp = (t - n * Vector3.Dot(n, t)).normalized; - //tangents[i] = (Vector4){ tmp.x, tmp.y, tmp.z }; + // TODO: Review, not sure if tangent computation is right, just used reference proposed maths... + #if defined(COMPUTE_TANGENTS_METHOD_01) + Vector3 tmp = Vector3Subtract(tangent, Vector3Multiply(normal, Vector3DotProduct(normal, tangent))); + tmp = Vector3Normalize(tmp); + mesh->tangents[i*4 + 0] = tmp.x; + mesh->tangents[i*4 + 1] = tmp.y; + mesh->tangents[i*4 + 2] = tmp.z; + mesh->tangents[i*4 + 3] = 1.0f; + #else Vector3OrthoNormalize(&normal, &tangent); - mesh->tangents[i*4 + 0] = tangent.x; mesh->tangents[i*4 + 1] = tangent.y; mesh->tangents[i*4 + 2] = tangent.z; mesh->tangents[i*4 + 3] = (Vector3DotProduct(Vector3CrossProduct(normal, tangent), tan2[i]) < 0.0f) ? -1.0f : 1.0f; + #endif } free(tan1); From 198d7392560d1eb0dc7b9c8801a19492f753e734 Mon Sep 17 00:00:00 2001 From: raysan5 Date: Tue, 1 May 2018 12:31:03 +0200 Subject: [PATCH 09/53] BREAKING CHANGE: Renamed Camera -> Camera3D Just added a fallback in the meantime... --- examples/core/core_3d_mode.c | 2 +- src/raylib.h | 6 ++++-- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/examples/core/core_3d_mode.c b/examples/core/core_3d_mode.c index 5f7616557..a94ec648a 100644 --- a/examples/core/core_3d_mode.c +++ b/examples/core/core_3d_mode.c @@ -21,7 +21,7 @@ int main() InitWindow(screenWidth, screenHeight, "raylib [core] example - 3d mode"); // Define the camera to look into our 3d world - Camera camera; + Camera3D camera; camera.position = (Vector3){ 0.0f, 10.0f, 10.0f }; // Camera position camera.target = (Vector3){ 0.0f, 0.0f, 0.0f }; // Camera looking at point camera.up = (Vector3){ 0.0f, 1.0f, 0.0f }; // Camera up vector (rotation towards target) diff --git a/src/raylib.h b/src/raylib.h index b03a93f30..7949b103a 100644 --- a/src/raylib.h +++ b/src/raylib.h @@ -400,13 +400,15 @@ typedef struct SpriteFont { } SpriteFont; // Camera type, defines a camera position/orientation in 3d space -typedef struct Camera { +typedef struct Camera3D { Vector3 position; // Camera position Vector3 target; // Camera target it looks-at Vector3 up; // Camera up vector (rotation over its axis) float fovy; // Camera field-of-view apperture in Y (degrees) in perspective, used as near plane width in orthographic int type; // Camera type, defines projection type: CAMERA_PERSPECTIVE or CAMERA_ORTHOGRAPHIC -} Camera; +} Camera3D; + +#define Camera Camera3D // Camera type fallback, defaults to Camera3D // Camera2D type, defines a 2d camera typedef struct Camera2D { From 9d103b7c2faeb11d1dded450b138a590d476b0cf Mon Sep 17 00:00:00 2001 From: Ray San Date: Thu, 3 May 2018 19:19:35 +0200 Subject: [PATCH 10/53] Removed line breaks from functions Useful to parse raylib.h to generate raylib-lua and Notepad++ intellisense XML info --- src/raylib.h | 34 ++++++++++++---------------------- 1 file changed, 12 insertions(+), 22 deletions(-) diff --git a/src/raylib.h b/src/raylib.h index 7949b103a..7afb9fe11 100644 --- a/src/raylib.h +++ b/src/raylib.h @@ -190,7 +190,7 @@ #define MOUSE_MIDDLE_BUTTON 2 // Touch points registered -#define MAX_TOUCH_POINTS 2 +#define MAX_TOUCH_POINTS 2 // Gamepad Number #define GAMEPAD_PLAYER1 0 @@ -736,7 +736,7 @@ RLAPI void BeginTextureMode(RenderTexture2D target); // Initializes RLAPI void EndTextureMode(void); // Ends drawing to render texture // Screen-space-related functions -RLAPI Ray GetMouseRay(Vector2 mousePosition, Camera camera); // Returns a ray trace from mouse position +RLAPI Ray GetMouseRay(Vector2 mousePosition, Camera camera); // Returns a ray trace from mouse position RLAPI Vector2 GetWorldToScreen(Vector3 position, Camera camera); // Returns the screen space position for a 3d world space position RLAPI Matrix GetCameraMatrix(Camera camera); // Returns camera transform matrix (view matrix) @@ -839,9 +839,7 @@ RLAPI void UpdateCamera(Camera *camera); // Update came RLAPI void SetCameraPanControl(int panKey); // Set camera pan key to combine with mouse movement (free camera) RLAPI void SetCameraAltControl(int altKey); // Set camera alt key to combine with mouse movement (free camera) RLAPI void SetCameraSmoothZoomControl(int szKey); // Set camera smooth zoom key to combine with mouse (free camera) -RLAPI void SetCameraMoveControls(int frontKey, int backKey, - int rightKey, int leftKey, - int upKey, int downKey); // Set camera move controls (1st person and 3rd person cameras) +RLAPI void SetCameraMoveControls(int frontKey, int backKey, int rightKey, int leftKey, int upKey, int downKey); // Set camera move controls (1st person and 3rd person cameras) //------------------------------------------------------------------------------------ // Basic Shapes Drawing Functions (Module: shapes) @@ -903,7 +901,6 @@ RLAPI int GetPixelDataSize(int width, int height, int format); RLAPI Image GetTextureData(Texture2D texture); // Get pixel data from GPU texture and return an Image RLAPI void UpdateTexture(Texture2D texture, const void *pixels); // Update GPU texture with new data - // Image manipulation functions RLAPI Image ImageCopy(Image image); // Create an image duplicate (useful for transformations) RLAPI void ImageToPOT(Image *image, Color fillColor); // Convert image to POT (power-of-two) @@ -922,8 +919,7 @@ RLAPI Image ImageTextEx(SpriteFont font, const char *text, float fontSize, int s RLAPI void ImageDraw(Image *dst, Image src, Rectangle srcRec, Rectangle dstRec); // Draw a source image within a destination image RLAPI void ImageDrawRectangle(Image *dst, Vector2 position, Rectangle rec, Color color); // Draw rectangle within an image RLAPI void ImageDrawText(Image *dst, Vector2 position, const char *text, int fontSize, Color color); // Draw text (default font) within an image (destination) -RLAPI void ImageDrawTextEx(Image *dst, Vector2 position, SpriteFont font, const char *text, - float fontSize, int spacing, Color color); // Draw text (custom sprite font) within an image (destination) +RLAPI void ImageDrawTextEx(Image *dst, Vector2 position, SpriteFont font, const char *text, float fontSize, int spacing, Color color); // Draw text (custom sprite font) within an image (destination) RLAPI void ImageFlipVertical(Image *image); // Flip image vertically RLAPI void ImageFlipHorizontal(Image *image); // Flip image horizontally RLAPI void ImageColorTint(Image *image, Color color); // Modify image color: tint @@ -952,8 +948,8 @@ RLAPI void DrawTexture(Texture2D texture, int posX, int posY, Color tint); RLAPI void DrawTextureV(Texture2D texture, Vector2 position, Color tint); // Draw a Texture2D with position defined as Vector2 RLAPI void DrawTextureEx(Texture2D texture, Vector2 position, float rotation, float scale, Color tint); // Draw a Texture2D with extended parameters RLAPI void DrawTextureRec(Texture2D texture, Rectangle sourceRec, Vector2 position, Color tint); // Draw a part of a texture defined by a rectangle -RLAPI void DrawTexturePro(Texture2D texture, Rectangle sourceRec, Rectangle destRec, Vector2 origin, // Draw a part of a texture defined by a rectangle with 'pro' parameters - float rotation, Color tint); +RLAPI void DrawTexturePro(Texture2D texture, Rectangle sourceRec, Rectangle destRec, Vector2 origin, float rotation, Color tint); // Draw a part of a texture defined by a rectangle with 'pro' parameters + //------------------------------------------------------------------------------------ // Font Loading and Text Drawing Functions (Module: text) @@ -968,8 +964,7 @@ RLAPI void UnloadSpriteFont(SpriteFont font); // Text drawing functions RLAPI void DrawFPS(int posX, int posY); // Shows current FPS RLAPI void DrawText(const char *text, int posX, int posY, int fontSize, Color color); // Draw text (using default font) -RLAPI void DrawTextEx(SpriteFont font, const char* text, Vector2 position, // Draw text using SpriteFont and additional parameters - float fontSize, int spacing, Color tint); +RLAPI void DrawTextEx(SpriteFont font, const char* text, Vector2 position, float fontSize, int spacing, Color tint); // Draw text using SpriteFont and additional parameters // Text misc. functions RLAPI int MeasureText(const char *text, int fontSize); // Measure string width for default font @@ -1037,23 +1032,19 @@ RLAPI void UnloadMaterial(Material material); // Model drawing functions RLAPI void DrawModel(Model model, Vector3 position, float scale, Color tint); // Draw a model (with texture if set) -RLAPI void DrawModelEx(Model model, Vector3 position, Vector3 rotationAxis, - float rotationAngle, Vector3 scale, Color tint); // Draw a model with extended parameters +RLAPI void DrawModelEx(Model model, Vector3 position, Vector3 rotationAxis, float rotationAngle, Vector3 scale, Color tint); // Draw a model with extended parameters RLAPI void DrawModelWires(Model model, Vector3 position, float scale, Color tint); // Draw a model wires (with texture if set) -RLAPI void DrawModelWiresEx(Model model, Vector3 position, Vector3 rotationAxis, - float rotationAngle, Vector3 scale, Color tint); // Draw a model wires (with texture if set) with extended parameters +RLAPI void DrawModelWiresEx(Model model, Vector3 position, Vector3 rotationAxis, float rotationAngle, Vector3 scale, Color tint); // Draw a model wires (with texture if set) with extended parameters RLAPI void DrawBoundingBox(BoundingBox box, Color color); // Draw bounding box (wires) RLAPI void DrawBillboard(Camera camera, Texture2D texture, Vector3 center, float size, Color tint); // Draw a billboard texture -RLAPI void DrawBillboardRec(Camera camera, Texture2D texture, Rectangle sourceRec, - Vector3 center, float size, Color tint); // Draw a billboard texture defined by sourceRec +RLAPI void DrawBillboardRec(Camera camera, Texture2D texture, Rectangle sourceRec, Vector3 center, float size, Color tint); // Draw a billboard texture defined by sourceRec // Collision detection functions RLAPI bool CheckCollisionSpheres(Vector3 centerA, float radiusA, Vector3 centerB, float radiusB); // Detect collision between two spheres RLAPI bool CheckCollisionBoxes(BoundingBox box1, BoundingBox box2); // Detect collision between two bounding boxes RLAPI bool CheckCollisionBoxSphere(BoundingBox box, Vector3 centerSphere, float radiusSphere); // Detect collision between box and sphere RLAPI bool CheckCollisionRaySphere(Ray ray, Vector3 spherePosition, float sphereRadius); // Detect collision between ray and sphere -RLAPI bool CheckCollisionRaySphereEx(Ray ray, Vector3 spherePosition, float sphereRadius, - Vector3 *collisionPoint); // Detect collision between ray and sphere, returns collision point +RLAPI bool CheckCollisionRaySphereEx(Ray ray, Vector3 spherePosition, float sphereRadius, Vector3 *collisionPoint); // Detect collision between ray and sphere, returns collision point RLAPI bool CheckCollisionRayBox(Ray ray, BoundingBox box); // Detect collision between ray and box RLAPI RayHitInfo GetCollisionRayModel(Ray ray, Model *model); // Get collision info between ray and model RLAPI RayHitInfo GetCollisionRayTriangle(Ray ray, Vector3 p1, Vector3 p2, Vector3 p3); // Get collision info between ray and triangle @@ -1154,8 +1145,7 @@ RLAPI float GetMusicTimeLength(Music music); // Get mus RLAPI float GetMusicTimePlayed(Music music); // Get current music time played (in seconds) // AudioStream management functions -RLAPI AudioStream InitAudioStream(unsigned int sampleRate, unsigned int sampleSize, - unsigned int channels); // Init audio stream (to stream raw audio pcm data) +RLAPI AudioStream InitAudioStream(unsigned int sampleRate, unsigned int sampleSize, unsigned int channels); // Init audio stream (to stream raw audio pcm data) RLAPI void UpdateAudioStream(AudioStream stream, const void *data, int samplesCount); // Update audio stream buffers with data RLAPI void CloseAudioStream(AudioStream stream); // Close audio stream and free memory RLAPI bool IsAudioBufferProcessed(AudioStream stream); // Check if any audio stream buffers requires refill From 6324697ffd7fd410274599457dd9f85119510898 Mon Sep 17 00:00:00 2001 From: Ray San Date: Fri, 4 May 2018 16:25:31 +0200 Subject: [PATCH 11/53] Rectangle parameters changed to float - Some examples tweaks - Reviewed ImageFormat() - Use float for text fontSize --- examples/core/core_3d_camera_free.c | 2 +- examples/textures/textures_image_generation.c | 2 +- examples/textures/textures_image_processing.c | 17 ++--- src/raylib.h | 16 ++--- src/shapes.c | 36 +++++----- src/text.c | 8 +-- src/textures.c | 70 +++++++++---------- 7 files changed, 71 insertions(+), 80 deletions(-) diff --git a/examples/core/core_3d_camera_free.c b/examples/core/core_3d_camera_free.c index d446e14a3..a583e7067 100644 --- a/examples/core/core_3d_camera_free.c +++ b/examples/core/core_3d_camera_free.c @@ -21,7 +21,7 @@ int main() InitWindow(screenWidth, screenHeight, "raylib [core] example - 3d camera free"); // Define the camera to look into our 3d world - Camera camera; + Camera3D camera; camera.position = (Vector3){ 10.0f, 10.0f, 10.0f }; // Camera position camera.target = (Vector3){ 0.0f, 0.0f, 0.0f }; // Camera looking at point camera.up = (Vector3){ 0.0f, 1.0f, 0.0f }; // Camera up vector (rotation towards target) diff --git a/examples/textures/textures_image_generation.c b/examples/textures/textures_image_generation.c index 790c34f1c..b9608c89a 100644 --- a/examples/textures/textures_image_generation.c +++ b/examples/textures/textures_image_generation.c @@ -58,7 +58,7 @@ int main() { // Update //---------------------------------------------------------------------------------- - if (IsMouseButtonPressed(MOUSE_LEFT_BUTTON)) + if (IsMouseButtonPressed(MOUSE_LEFT_BUTTON) || IsKeyPressed(KEY_RIGHT)) { currentTexture = (currentTexture + 1)%NUM_TEXTURES; // Cycle between the textures } diff --git a/examples/textures/textures_image_processing.c b/examples/textures/textures_image_processing.c index 58b746e01..427faa602 100644 --- a/examples/textures/textures_image_processing.c +++ b/examples/textures/textures_image_processing.c @@ -51,7 +51,7 @@ int main() // NOTE: Textures MUST be loaded after Window initialization (OpenGL context is required) Image image = LoadImage("resources/parrots.png"); // Loaded in CPU memory (RAM) - ImageFormat(&image, UNCOMPRESSED_R8G8B8A8); // Format image to RGBA 32bit (required for texture update) + ImageFormat(&image, UNCOMPRESSED_R8G8B8A8); // Format image to RGBA 32bit (required for texture update) <-- ISSUE Texture2D texture = LoadTextureFromImage(image); // Image converted to texture, GPU memory (VRAM) int currentProcess = NONE; @@ -121,18 +121,9 @@ int main() // Draw rectangles for (int i = 0; i < NUM_PROCESSES; i++) { - if (i == currentProcess) - { - DrawRectangleRec(selectRecs[i], SKYBLUE); - DrawRectangleLines(selectRecs[i].x, selectRecs[i].y, selectRecs[i].width, selectRecs[i].height, BLUE); - DrawText(processText[i], selectRecs[i].x + selectRecs[i].width/2 - MeasureText(processText[i], 10)/2, selectRecs[i].y + 11, 10, DARKBLUE); - } - else - { - DrawRectangleRec(selectRecs[i], LIGHTGRAY); - DrawRectangleLines(selectRecs[i].x, selectRecs[i].y, selectRecs[i].width, selectRecs[i].height, GRAY); - DrawText(processText[i], selectRecs[i].x + selectRecs[i].width/2 - MeasureText(processText[i], 10)/2, selectRecs[i].y + 11, 10, DARKGRAY); - } + DrawRectangleRec(selectRecs[i], (i == currentProcess) ? SKYBLUE : LIGHTGRAY); + DrawRectangleLines(selectRecs[i].x, selectRecs[i].y, selectRecs[i].width, selectRecs[i].height, (i == currentProcess) ? BLUE : GRAY); + DrawText(processText[i], selectRecs[i].x + selectRecs[i].width/2 - MeasureText(processText[i], 10)/2, selectRecs[i].y + 11, 10, (i == currentProcess) ? DARKBLUE : DARKGRAY); } DrawTexture(texture, screenWidth - texture.width - 60, screenHeight/2 - texture.height/2, WHITE); diff --git a/src/raylib.h b/src/raylib.h index 7afb9fe11..6d3aaaf96 100644 --- a/src/raylib.h +++ b/src/raylib.h @@ -349,10 +349,10 @@ typedef struct Color { // Rectangle type typedef struct Rectangle { - int x; - int y; - int width; - int height; + float x; + float y; + float width; + float height; } Rectangle; // Image type, bpp always RGBA (32bit) @@ -915,11 +915,11 @@ RLAPI void ImageResizeNN(Image *image,int newWidth,int newHeight); RLAPI void ImageMipmaps(Image *image); // Generate all mipmap levels for a provided image RLAPI void ImageDither(Image *image, int rBpp, int gBpp, int bBpp, int aBpp); // Dither image data to 16bpp or lower (Floyd-Steinberg dithering) RLAPI Image ImageText(const char *text, int fontSize, Color color); // Create an image from text (default font) -RLAPI Image ImageTextEx(SpriteFont font, const char *text, float fontSize, int spacing, Color tint); // Create an image from text (custom sprite font) +RLAPI Image ImageTextEx(SpriteFont font, const char *text, float fontSize, float spacing, Color tint); // Create an image from text (custom sprite font) RLAPI void ImageDraw(Image *dst, Image src, Rectangle srcRec, Rectangle dstRec); // Draw a source image within a destination image RLAPI void ImageDrawRectangle(Image *dst, Vector2 position, Rectangle rec, Color color); // Draw rectangle within an image RLAPI void ImageDrawText(Image *dst, Vector2 position, const char *text, int fontSize, Color color); // Draw text (default font) within an image (destination) -RLAPI void ImageDrawTextEx(Image *dst, Vector2 position, SpriteFont font, const char *text, float fontSize, int spacing, Color color); // Draw text (custom sprite font) within an image (destination) +RLAPI void ImageDrawTextEx(Image *dst, Vector2 position, SpriteFont font, const char *text, float fontSize, float spacing, Color color); // Draw text (custom sprite font) within an image (destination) RLAPI void ImageFlipVertical(Image *image); // Flip image vertically RLAPI void ImageFlipHorizontal(Image *image); // Flip image horizontally RLAPI void ImageColorTint(Image *image, Color color); // Modify image color: tint @@ -964,11 +964,11 @@ RLAPI void UnloadSpriteFont(SpriteFont font); // Text drawing functions RLAPI void DrawFPS(int posX, int posY); // Shows current FPS RLAPI void DrawText(const char *text, int posX, int posY, int fontSize, Color color); // Draw text (using default font) -RLAPI void DrawTextEx(SpriteFont font, const char* text, Vector2 position, float fontSize, int spacing, Color tint); // Draw text using SpriteFont and additional parameters +RLAPI void DrawTextEx(SpriteFont font, const char* text, Vector2 position, float fontSize, float spacing, Color tint); // Draw text using SpriteFont and additional parameters // Text misc. functions RLAPI int MeasureText(const char *text, int fontSize); // Measure string width for default font -RLAPI Vector2 MeasureTextEx(SpriteFont font, const char *text, float fontSize, int spacing); // Measure string size for SpriteFont +RLAPI Vector2 MeasureTextEx(SpriteFont font, const char *text, float fontSize, float spacing); // Measure string size for SpriteFont RLAPI const char *FormatText(const char *text, ...); // Formatting of text with variables to 'embed' RLAPI const char *SubText(const char *text, int position, int length); // Get a piece of a text string RLAPI int GetGlyphIndex(SpriteFont font, int character); // Returns index position for a unicode character on sprite font diff --git a/src/shapes.c b/src/shapes.c index d8e52b044..ed911b263 100644 --- a/src/shapes.c +++ b/src/shapes.c @@ -324,7 +324,7 @@ void DrawRectanglePro(Rectangle rec, Vector2 origin, float rotation, Color color rlEnableTexture(GetTextureDefault().id); rlPushMatrix(); - rlTranslatef((float)rec.x, (float)rec.y, 0); + rlTranslatef(rec.x, rec.y, 0); rlRotatef(rotation, 0, 0, 1); rlTranslatef(-origin.x, -origin.y, 0); @@ -333,9 +333,9 @@ void DrawRectanglePro(Rectangle rec, Vector2 origin, float rotation, Color color rlNormal3f(0.0f, 0.0f, 1.0f); // Normal vector pointing towards viewer rlVertex2f(0.0f, 0.0f); - rlVertex2f(0.0f, (float)rec.height); - rlVertex2f((float)rec.width, (float)rec.height); - rlVertex2f((float)rec.width, 0.0f); + rlVertex2f(0.0f, rec.height); + rlVertex2f(rec.width, rec.height); + rlVertex2f(rec.width, 0.0f); rlEnd(); rlPopMatrix(); @@ -369,23 +369,23 @@ void DrawRectangleGradientEx(Rectangle rec, Color col1, Color col2, Color col3, // NOTE: Default raylib font character 95 is a white square rlColor4ub(col1.r, col1.g, col1.b, col1.a); - rlTexCoord2f((float)GetDefaultFont().chars[95].rec.x/GetDefaultFont().texture.width, - (float)GetDefaultFont().chars[95].rec.y/GetDefaultFont().texture.height); + rlTexCoord2f(GetDefaultFont().chars[95].rec.x/GetDefaultFont().texture.width, + GetDefaultFont().chars[95].rec.y/GetDefaultFont().texture.height); rlVertex2f(rec.x, rec.y); rlColor4ub(col2.r, col2.g, col2.b, col2.a); - rlTexCoord2f((float)GetDefaultFont().chars[95].rec.x/GetDefaultFont().texture.width, - (float)(GetDefaultFont().chars[95].rec.y + GetDefaultFont().chars[95].rec.height)/GetDefaultFont().texture.height); + rlTexCoord2f(GetDefaultFont().chars[95].rec.x/GetDefaultFont().texture.width, + (GetDefaultFont().chars[95].rec.y + GetDefaultFont().chars[95].rec.height)/GetDefaultFont().texture.height); rlVertex2f(rec.x, rec.y + rec.height); rlColor4ub(col3.r, col3.g, col3.b, col3.a); - rlTexCoord2f((float)(GetDefaultFont().chars[95].rec.x + GetDefaultFont().chars[95].rec.width)/GetDefaultFont().texture.width, - (float)(GetDefaultFont().chars[95].rec.y + GetDefaultFont().chars[95].rec.height)/GetDefaultFont().texture.height); + rlTexCoord2f((GetDefaultFont().chars[95].rec.x + GetDefaultFont().chars[95].rec.width)/GetDefaultFont().texture.width, + (GetDefaultFont().chars[95].rec.y + GetDefaultFont().chars[95].rec.height)/GetDefaultFont().texture.height); rlVertex2f(rec.x + rec.width, rec.y + rec.height); rlColor4ub(col4.r, col4.g, col4.b, col4.a); - rlTexCoord2f((float)(GetDefaultFont().chars[95].rec.x + GetDefaultFont().chars[95].rec.width)/GetDefaultFont().texture.width, - (float)GetDefaultFont().chars[95].rec.y/GetDefaultFont().texture.height); + rlTexCoord2f((GetDefaultFont().chars[95].rec.x + GetDefaultFont().chars[95].rec.width)/GetDefaultFont().texture.width, + GetDefaultFont().chars[95].rec.y/GetDefaultFont().texture.height); rlVertex2f(rec.x + rec.width, rec.y); rlEnd(); @@ -667,14 +667,14 @@ bool CheckCollisionCircleRec(Vector2 center, float radius, Rectangle rec) float dx = fabsf(center.x - recCenterX); float dy = fabsf(center.y - recCenterY); - if (dx > ((float)rec.width/2.0f + radius)) { return false; } - if (dy > ((float)rec.height/2.0f + radius)) { return false; } + if (dx > (rec.width/2.0f + radius)) { return false; } + if (dy > (rec.height/2.0f + radius)) { return false; } - if (dx <= ((float)rec.width/2.0f)) { return true; } - if (dy <= ((float)rec.height/2.0f)) { return true; } + if (dx <= (rec.width/2.0f)) { return true; } + if (dy <= (rec.height/2.0f)) { return true; } - float cornerDistanceSq = (dx - (float)rec.width/2.0f)*(dx - (float)rec.width/2.0f) + - (dy - (float)rec.height/2.0f)*(dy - (float)rec.height/2.0f); + float cornerDistanceSq = (dx - rec.width/2.0f)*(dx - rec.width/2.0f) + + (dy - rec.height/2.0f)*(dy - rec.height/2.0f); return (cornerDistanceSq <= (radius*radius)); } diff --git a/src/text.c b/src/text.c index 1a9d386a2..7cc091bc3 100644 --- a/src/text.c +++ b/src/text.c @@ -364,13 +364,13 @@ void DrawText(const char *text, int posX, int posY, int fontSize, Color color) if (fontSize < defaultFontSize) fontSize = defaultFontSize; int spacing = fontSize/defaultFontSize; - DrawTextEx(GetDefaultFont(), text, position, (float)fontSize, spacing, color); + DrawTextEx(GetDefaultFont(), text, position, (float)fontSize, (float)spacing, color); } } // Draw text using SpriteFont // NOTE: chars spacing is NOT proportional to fontSize -void DrawTextEx(SpriteFont font, const char *text, Vector2 position, float fontSize, int spacing, Color tint) +void DrawTextEx(SpriteFont font, const char *text, Vector2 position, float fontSize, float spacing, Color tint) { int length = strlen(text); int textOffsetX = 0; // Offset between characters @@ -476,14 +476,14 @@ int MeasureText(const char *text, int fontSize) if (fontSize < defaultFontSize) fontSize = defaultFontSize; int spacing = fontSize/defaultFontSize; - vec = MeasureTextEx(GetDefaultFont(), text, (float)fontSize, spacing); + vec = MeasureTextEx(GetDefaultFont(), text, (float)fontSize, (float)spacing); } return (int)vec.x; } // Measure string size for SpriteFont -Vector2 MeasureTextEx(SpriteFont font, const char *text, float fontSize, int spacing) +Vector2 MeasureTextEx(SpriteFont font, const char *text, float fontSize, float spacing) { int len = strlen(text); int tempLen = 0; // Used to count longer text line num chars diff --git a/src/textures.c b/src/textures.c index eadb0c593..726257b8f 100644 --- a/src/textures.c +++ b/src/textures.c @@ -713,7 +713,7 @@ void ImageFormat(Image *image, int newFormat) { image->data = (unsigned char *)malloc(image->width*image->height*3*sizeof(unsigned char)); - for (int i = 0; i < image->width*image->height*3; i += 3, k++) + for (int i = 0, k = 0; i < image->width*image->height*3; i += 3, k++) { ((unsigned char *)image->data)[i] = pixels[k].r; ((unsigned char *)image->data)[i + 1] = pixels[k].g; @@ -766,7 +766,7 @@ void ImageFormat(Image *image, int newFormat) { image->data = (unsigned char *)malloc(image->width*image->height*4*sizeof(unsigned char)); - for (int i = 0; i < image->width*image->height*3; i += 3, k++) + for (int i = 0, k = 0; i < image->width*image->height*4; i += 4, k++) { ((unsigned char *)image->data)[i] = pixels[k].r; ((unsigned char *)image->data)[i + 1] = pixels[k].g; @@ -787,7 +787,7 @@ void ImageFormat(Image *image, int newFormat) { image->data = (float *)malloc(image->width*image->height*3*sizeof(float)); - for (int i = 0; i < image->width*image->height*3; i += 3, k++) + for (int i = 0, k = 0; i < image->width*image->height*3; i += 3, k++) { ((float *)image->data)[i] = (float)pixels[k].r/255.0f; ((float *)image->data)[i + 1] = (float)pixels[k].g/255.0f; @@ -798,7 +798,7 @@ void ImageFormat(Image *image, int newFormat) { image->data = (float *)malloc(image->width*image->height*4*sizeof(float)); - for (int i = 0; i < image->width*image->height*4; i += 4, k++) + for (int i = 0, k = 0; i < image->width*image->height*4; i += 4, k++) { ((float *)image->data)[i] = (float)pixels[k].r/255.0f; ((float *)image->data)[i + 1] = (float)pixels[k].g/255.0f; @@ -977,13 +977,13 @@ void ImageCrop(Image *image, Rectangle crop) { // Start the cropping process Color *pixels = GetImageData(*image); // Get data as Color pixels array - Color *cropPixels = (Color *)malloc(crop.width*crop.height*sizeof(Color)); + Color *cropPixels = (Color *)malloc((int)crop.width*(int)crop.height*sizeof(Color)); - for (int j = crop.y; j < (crop.y + crop.height); j++) + for (int j = (int)crop.y; j < (int)(crop.y + crop.height); j++) { - for (int i = crop.x; i < (crop.x + crop.width); i++) + for (int i = (int)crop.x; i < (int)(crop.x + crop.width); i++) { - cropPixels[(j - crop.y)*crop.width + (i - crop.x)] = pixels[j*image->width + i]; + cropPixels[(j - (int)crop.y)*(int)crop.width + (i - (int)crop.x)] = pixels[j*image->width + i]; } } @@ -993,7 +993,7 @@ void ImageCrop(Image *image, Rectangle crop) UnloadImage(*image); - *image = LoadImageEx(cropPixels, crop.width, crop.height); + *image = LoadImageEx(cropPixels, (int)crop.width, (int)crop.height); free(cropPixels); @@ -1316,14 +1316,14 @@ void ImageDraw(Image *dst, Image src, Rectangle srcRec, Rectangle dstRec) // Blit pixels, copy source image into destination // TODO: Probably out-of-bounds blitting could be considered here instead of so much cropping... - for (int j = dstRec.y; j < (dstRec.y + dstRec.height); j++) + for (int j = (int)dstRec.y; j < (int)(dstRec.y + dstRec.height); j++) { - for (int i = dstRec.x; i < (dstRec.x + dstRec.width); i++) + for (int i = (int)dstRec.x; i < (int)(dstRec.x + dstRec.width); i++) { // Alpha blending (https://en.wikipedia.org/wiki/Alpha_compositing) - fdst = ColorNormalize(dstPixels[j*dst->width + i]); - fsrc = ColorNormalize(srcPixels[(j - dstRec.y)*dstRec.width + (i - dstRec.x)]); + fdst = ColorNormalize(dstPixels[j*(int)dst->width + i]); + fsrc = ColorNormalize(srcPixels[(j - (int)dstRec.y)*(int)dstRec.width + (i - (int)dstRec.x)]); fout.w = fsrc.w + fdst.w*(1.0f - fsrc.w); @@ -1340,10 +1340,10 @@ void ImageDraw(Image *dst, Image src, Rectangle srcRec, Rectangle dstRec) fout.z = (fsrc.z*fsrc.w + fdst.z*fdst.w*(1 - fsrc.w))/fout.w; } - dstPixels[j*dst->width + i] = (Color){ (unsigned char)(fout.x*255.0f), - (unsigned char)(fout.y*255.0f), - (unsigned char)(fout.z*255.0f), - (unsigned char)(fout.w*255.0f) }; + dstPixels[j*(int)dst->width + i] = (Color){ (unsigned char)(fout.x*255.0f), + (unsigned char)(fout.y*255.0f), + (unsigned char)(fout.z*255.0f), + (unsigned char)(fout.w*255.0f) }; // TODO: Support other blending options } @@ -1351,7 +1351,7 @@ void ImageDraw(Image *dst, Image src, Rectangle srcRec, Rectangle dstRec) UnloadImage(*dst); // NOTE: Only dst->data is unloaded - *dst = LoadImageEx(dstPixels, dst->width, dst->height); + *dst = LoadImageEx(dstPixels, (int)dst->width, (int)dst->height); ImageFormat(dst, dst->format); free(srcPixels); @@ -1363,15 +1363,15 @@ Image ImageText(const char *text, int fontSize, Color color) { int defaultFontSize = 10; // Default Font chars height in pixel if (fontSize < defaultFontSize) fontSize = defaultFontSize; - int spacing = fontSize/defaultFontSize; + int spacing = (float)fontSize/defaultFontSize; - Image imText = ImageTextEx(GetDefaultFont(), text, (float)fontSize, spacing, color); + Image imText = ImageTextEx(GetDefaultFont(), text, (float)fontSize, (float)spacing, color); return imText; } // Create an image from text (custom sprite font) -Image ImageTextEx(SpriteFont font, const char *text, float fontSize, int spacing, Color tint) +Image ImageTextEx(SpriteFont font, const char *text, float fontSize, float spacing, Color tint) { int length = strlen(text); int posX = 0; @@ -1451,7 +1451,7 @@ void ImageDrawRectangle(Image *dst, Vector2 position, Rectangle rec, Color color { Image imRec = GenImageColor(rec.width, rec.height, color); - Rectangle dstRec = { (int)position.x, (int)position.y, imRec.width, imRec.height }; + Rectangle dstRec = { position.x, position.y, imRec.width, imRec.height }; ImageDraw(dst, imRec, rec, dstRec); @@ -1462,16 +1462,16 @@ void ImageDrawRectangle(Image *dst, Vector2 position, Rectangle rec, Color color void ImageDrawText(Image *dst, Vector2 position, const char *text, int fontSize, Color color) { // NOTE: For default font, sapcing is set to desired font size / default font size (10) - ImageDrawTextEx(dst, position, GetDefaultFont(), text, (float)fontSize, fontSize/10, color); + ImageDrawTextEx(dst, position, GetDefaultFont(), text, (float)fontSize, (float)fontSize/10, color); } // Draw text (custom sprite font) within an image (destination) -void ImageDrawTextEx(Image *dst, Vector2 position, SpriteFont font, const char *text, float fontSize, int spacing, Color color) +void ImageDrawTextEx(Image *dst, Vector2 position, SpriteFont font, const char *text, float fontSize, float spacing, Color color) { Image imText = ImageTextEx(font, text, fontSize, spacing, color); Rectangle srcRec = { 0, 0, imText.width, imText.height }; - Rectangle dstRec = { (int)position.x, (int)position.y, imText.width, imText.height }; + Rectangle dstRec = { position.x, position.y, imText.width, imText.height }; ImageDraw(dst, imText, srcRec, dstRec); @@ -2020,7 +2020,7 @@ void DrawTextureV(Texture2D texture, Vector2 position, Color tint) void DrawTextureEx(Texture2D texture, Vector2 position, float rotation, float scale, Color tint) { Rectangle sourceRec = { 0, 0, texture.width, texture.height }; - Rectangle destRec = { (int)position.x, (int)position.y, texture.width*scale, texture.height*scale }; + Rectangle destRec = { position.x, position.y, texture.width*scale, texture.height*scale }; Vector2 origin = { 0, 0 }; DrawTexturePro(texture, sourceRec, destRec, origin, rotation, tint); @@ -2029,7 +2029,7 @@ void DrawTextureEx(Texture2D texture, Vector2 position, float rotation, float sc // Draw a part of a texture (defined by a rectangle) void DrawTextureRec(Texture2D texture, Rectangle sourceRec, Vector2 position, Color tint) { - Rectangle destRec = { (int)position.x, (int)position.y, abs(sourceRec.width), abs(sourceRec.height) }; + Rectangle destRec = { position.x, position.y, sourceRec.width, sourceRec.height }; Vector2 origin = { 0, 0 }; DrawTexturePro(texture, sourceRec, destRec, origin, 0.0f, tint); @@ -2048,7 +2048,7 @@ void DrawTexturePro(Texture2D texture, Rectangle sourceRec, Rectangle destRec, V rlEnableTexture(texture.id); rlPushMatrix(); - rlTranslatef((float)destRec.x, (float)destRec.y, 0); + rlTranslatef(destRec.x, destRec.y, 0); rlRotatef(rotation, 0, 0, 1); rlTranslatef(-origin.x, -origin.y, 0); @@ -2057,20 +2057,20 @@ void DrawTexturePro(Texture2D texture, Rectangle sourceRec, Rectangle destRec, V rlNormal3f(0.0f, 0.0f, 1.0f); // Normal vector pointing towards viewer // Bottom-left corner for texture and quad - rlTexCoord2f((float)sourceRec.x/texture.width, (float)sourceRec.y/texture.height); + rlTexCoord2f(sourceRec.x/texture.width, sourceRec.y/texture.height); rlVertex2f(0.0f, 0.0f); // Bottom-right corner for texture and quad - rlTexCoord2f((float)sourceRec.x/texture.width, (float)(sourceRec.y + sourceRec.height)/texture.height); - rlVertex2f(0.0f, (float)destRec.height); + rlTexCoord2f(sourceRec.x/texture.width, (sourceRec.y + sourceRec.height)/texture.height); + rlVertex2f(0.0f, destRec.height); // Top-right corner for texture and quad - rlTexCoord2f((float)(sourceRec.x + sourceRec.width)/texture.width, (float)(sourceRec.y + sourceRec.height)/texture.height); - rlVertex2f((float)destRec.width, (float)destRec.height); + rlTexCoord2f((sourceRec.x + sourceRec.width)/texture.width, (sourceRec.y + sourceRec.height)/texture.height); + rlVertex2f(destRec.width, destRec.height); // Top-left corner for texture and quad - rlTexCoord2f((float)(sourceRec.x + sourceRec.width)/texture.width, (float)sourceRec.y/texture.height); - rlVertex2f((float)destRec.width, 0.0f); + rlTexCoord2f((sourceRec.x + sourceRec.width)/texture.width, sourceRec.y/texture.height); + rlVertex2f(destRec.width, 0.0f); rlEnd(); rlPopMatrix(); From 6045062a05a0cc5bd654ad2c2e7d88f94579cd73 Mon Sep 17 00:00:00 2001 From: Ray San Date: Fri, 4 May 2018 16:54:05 +0200 Subject: [PATCH 12/53] Renamed some functions - Renamed Begin3dMode() --> BeginMode3D() - Renamed Begin2dMode() --> BeginMode2D() - Renamed End3dMode() --> EndMode3D() - Renamed End2dMode() --> EndMode2D() --- examples/core/core_2d_camera.c | 4 ++-- examples/core/core_3d_camera_first_person.c | 4 ++-- examples/core/core_3d_camera_free.c | 4 ++-- examples/core/core_3d_mode.c | 4 ++-- examples/core/core_3d_picking.c | 4 ++-- examples/core/core_vr_simulator.c | 4 ++-- examples/core/core_world_screen.c | 4 ++-- examples/models/models_billboard.c | 4 ++-- examples/models/models_box_collisions.c | 4 ++-- examples/models/models_cubicmap.c | 4 ++-- examples/models/models_geometric_shapes.c | 4 ++-- examples/models/models_heightmap.c | 4 ++-- examples/models/models_material_pbr.c | 4 ++-- examples/models/models_mesh_generation.c | 4 ++-- examples/models/models_mesh_picking.c | 4 ++-- examples/models/models_obj_loading.c | 4 ++-- examples/models/models_orthographic_projection.c | 4 ++-- examples/models/models_skybox.c | 4 ++-- examples/models/models_yaw_pitch_roll.c | 4 ++-- examples/others/oculus_rift.c | 4 ++-- examples/others/standard_lighting.c | 4 ++-- examples/shaders/shaders_custom_uniform.c | 4 ++-- examples/shaders/shaders_model_shader.c | 4 ++-- examples/shaders/shaders_postprocessing.c | 4 ++-- src/core.c | 12 ++++++------ src/raylib.h | 10 +++++----- src/rlgl.c | 2 +- 27 files changed, 60 insertions(+), 60 deletions(-) diff --git a/examples/core/core_2d_camera.c b/examples/core/core_2d_camera.c index f2f219ef4..7c35c9070 100644 --- a/examples/core/core_2d_camera.c +++ b/examples/core/core_2d_camera.c @@ -97,7 +97,7 @@ int main() ClearBackground(RAYWHITE); - Begin2dMode(camera); + BeginMode2D(camera); DrawRectangle(-6000, 320, 13000, 8000, DARKGRAY); @@ -108,7 +108,7 @@ int main() DrawRectangle(camera.target.x, -500, 1, screenHeight*4, GREEN); DrawRectangle(-500, camera.target.y, screenWidth*4, 1, GREEN); - End2dMode(); + EndMode2D(); DrawText("SCREEN AREA", 640, 10, 20, RED); diff --git a/examples/core/core_3d_camera_first_person.c b/examples/core/core_3d_camera_first_person.c index 775e6c573..d3a8f2e4b 100644 --- a/examples/core/core_3d_camera_first_person.c +++ b/examples/core/core_3d_camera_first_person.c @@ -61,7 +61,7 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); DrawPlane((Vector3){ 0.0f, 0.0f, 0.0f }, (Vector2){ 32.0f, 32.0f }, LIGHTGRAY); // Draw ground DrawCube((Vector3){ -16.0f, 2.5f, 0.0f }, 1.0f, 5.0f, 32.0f, BLUE); // Draw a blue wall @@ -75,7 +75,7 @@ int main() DrawCubeWires(positions[i], 2.0f, heights[i], 2.0f, MAROON); } - End3dMode(); + EndMode3D(); DrawRectangle( 10, 10, 220, 70, Fade(SKYBLUE, 0.5f)); DrawRectangleLines( 10, 10, 220, 70, BLUE); diff --git a/examples/core/core_3d_camera_free.c b/examples/core/core_3d_camera_free.c index a583e7067..81f04c139 100644 --- a/examples/core/core_3d_camera_free.c +++ b/examples/core/core_3d_camera_free.c @@ -50,14 +50,14 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); DrawCube(cubePosition, 2.0f, 2.0f, 2.0f, RED); DrawCubeWires(cubePosition, 2.0f, 2.0f, 2.0f, MAROON); DrawGrid(10, 1.0f); - End3dMode(); + EndMode3D(); DrawRectangle( 10, 10, 320, 133, Fade(SKYBLUE, 0.5f)); DrawRectangleLines( 10, 10, 320, 133, BLUE); diff --git a/examples/core/core_3d_mode.c b/examples/core/core_3d_mode.c index a94ec648a..705bcb7a4 100644 --- a/examples/core/core_3d_mode.c +++ b/examples/core/core_3d_mode.c @@ -46,14 +46,14 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); DrawCube(cubePosition, 2.0f, 2.0f, 2.0f, RED); DrawCubeWires(cubePosition, 2.0f, 2.0f, 2.0f, MAROON); DrawGrid(10, 1.0f); - End3dMode(); + EndMode3D(); DrawText("Welcome to the third dimension!", 10, 40, 20, DARKGRAY); diff --git a/examples/core/core_3d_picking.c b/examples/core/core_3d_picking.c index 56e80f2ae..cd390d917 100644 --- a/examples/core/core_3d_picking.c +++ b/examples/core/core_3d_picking.c @@ -63,7 +63,7 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); if (collision) { @@ -81,7 +81,7 @@ int main() DrawRay(ray, MAROON); DrawGrid(10, 1.0f); - End3dMode(); + EndMode3D(); DrawText("Try selecting the box with mouse!", 240, 10, 20, DARKGRAY); diff --git a/examples/core/core_vr_simulator.c b/examples/core/core_vr_simulator.c index d919c4107..351361146 100644 --- a/examples/core/core_vr_simulator.c +++ b/examples/core/core_vr_simulator.c @@ -57,14 +57,14 @@ int main() BeginVrDrawing(); - Begin3dMode(camera); + BeginMode3D(camera); DrawCube(cubePosition, 2.0f, 2.0f, 2.0f, RED); DrawCubeWires(cubePosition, 2.0f, 2.0f, 2.0f, MAROON); DrawGrid(40, 1.0f); - End3dMode(); + EndMode3D(); EndVrDrawing(); diff --git a/examples/core/core_world_screen.c b/examples/core/core_world_screen.c index 78ca6eb4e..460f6b85e 100644 --- a/examples/core/core_world_screen.c +++ b/examples/core/core_world_screen.c @@ -54,14 +54,14 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); DrawCube(cubePosition, 2.0f, 2.0f, 2.0f, RED); DrawCubeWires(cubePosition, 2.0f, 2.0f, 2.0f, MAROON); DrawGrid(10, 1.0f); - End3dMode(); + EndMode3D(); DrawText("Enemy: 100 / 100", cubeScreenPosition.x - MeasureText("Enemy: 100 / 100", 20) / 2, cubeScreenPosition.y, 20, BLACK); DrawText("Text is always on top of the cube", (screenWidth - MeasureText("Text is always on top of the cube", 20)) / 2, 25, 20, GRAY); diff --git a/examples/models/models_billboard.c b/examples/models/models_billboard.c index 3b3efc477..8ce6a44fd 100644 --- a/examples/models/models_billboard.c +++ b/examples/models/models_billboard.c @@ -51,13 +51,13 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); DrawBillboard(camera, bill, billPosition, 2.0f, WHITE); DrawGrid(10, 1.0f); // Draw a grid - End3dMode(); + EndMode3D(); DrawFPS(10, 10); diff --git a/examples/models/models_box_collisions.c b/examples/models/models_box_collisions.c index eb72c54ca..41f6056c0 100644 --- a/examples/models/models_box_collisions.c +++ b/examples/models/models_box_collisions.c @@ -87,7 +87,7 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); // Draw enemy-box DrawCube(enemyBoxPos, enemyBoxSize.x, enemyBoxSize.y, enemyBoxSize.z, GRAY); @@ -102,7 +102,7 @@ int main() DrawGrid(10, 1.0f); // Draw a grid - End3dMode(); + EndMode3D(); DrawText("Move player with cursors to collide", 220, 40, 20, GRAY); diff --git a/examples/models/models_cubicmap.c b/examples/models/models_cubicmap.c index 47b887482..c8d62c46f 100644 --- a/examples/models/models_cubicmap.c +++ b/examples/models/models_cubicmap.c @@ -56,11 +56,11 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); DrawModel(model, mapPosition, 1.0f, WHITE); - End3dMode(); + EndMode3D(); DrawTextureEx(cubicmap, (Vector2){ screenWidth - cubicmap.width*4 - 20, 20 }, 0.0f, 4.0f, WHITE); DrawRectangleLines(screenWidth - cubicmap.width*4 - 20, 20, cubicmap.width*4, cubicmap.height*4, GREEN); diff --git a/examples/models/models_geometric_shapes.c b/examples/models/models_geometric_shapes.c index 7a1e7e48c..82ca4c605 100644 --- a/examples/models/models_geometric_shapes.c +++ b/examples/models/models_geometric_shapes.c @@ -45,7 +45,7 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); DrawCube((Vector3){-4.0f, 0.0f, 2.0f}, 2.0f, 5.0f, 2.0f, RED); DrawCubeWires((Vector3){-4.0f, 0.0f, 2.0f}, 2.0f, 5.0f, 2.0f, GOLD); @@ -63,7 +63,7 @@ int main() DrawGrid(10, 1.0f); // Draw a grid - End3dMode(); + EndMode3D(); DrawFPS(10, 10); diff --git a/examples/models/models_heightmap.c b/examples/models/models_heightmap.c index 55474185f..d131b127d 100644 --- a/examples/models/models_heightmap.c +++ b/examples/models/models_heightmap.c @@ -53,13 +53,13 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); DrawModel(model, mapPosition, 1.0f, RED); DrawGrid(20, 1.0f); - End3dMode(); + EndMode3D(); DrawTexture(texture, screenWidth - texture.width - 20, 20, WHITE); DrawRectangleLines(screenWidth - texture.width - 20, 20, texture.width, texture.height, GREEN); diff --git a/examples/models/models_material_pbr.c b/examples/models/models_material_pbr.c index ee13fddf1..33f13e2ce 100644 --- a/examples/models/models_material_pbr.c +++ b/examples/models/models_material_pbr.c @@ -73,13 +73,13 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); DrawModel(model, Vector3Zero(), 1.0f, WHITE); DrawGrid(10, 1.0f); - End3dMode(); + EndMode3D(); DrawFPS(10, 10); diff --git a/examples/models/models_mesh_generation.c b/examples/models/models_mesh_generation.c index d9c28ac27..c02bd91a8 100644 --- a/examples/models/models_mesh_generation.c +++ b/examples/models/models_mesh_generation.c @@ -72,13 +72,13 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); DrawModel(models[currentModel], position, 1.0f, WHITE); DrawGrid(10, 1.0); - End3dMode(); + EndMode3D(); DrawRectangle(30, 400, 310, 30, Fade(SKYBLUE, 0.5f)); DrawRectangleLines(30, 400, 310, 30, Fade(DARKBLUE, 0.5f)); diff --git a/examples/models/models_mesh_picking.c b/examples/models/models_mesh_picking.c index e09f9860c..17b8812d6 100644 --- a/examples/models/models_mesh_picking.c +++ b/examples/models/models_mesh_picking.c @@ -120,7 +120,7 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); // Draw the tower DrawModel(tower, towerPos, 1.0, WHITE); @@ -151,7 +151,7 @@ int main() DrawGrid(100, 1.0f); - End3dMode(); + EndMode3D(); // Draw some debug GUI text DrawText(FormatText("Hit Object: %s", hitObjectName), 10, 50, 10, BLACK); diff --git a/examples/models/models_obj_loading.c b/examples/models/models_obj_loading.c index 4f89130f0..4e9b29864 100644 --- a/examples/models/models_obj_loading.c +++ b/examples/models/models_obj_loading.c @@ -50,7 +50,7 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); DrawModel(dwarf, position, 2.0f, WHITE); // Draw 3d model with texture @@ -58,7 +58,7 @@ int main() DrawGizmo(position); // Draw gizmo - End3dMode(); + EndMode3D(); DrawText("(c) Dwarf 3D model by David Moreno", screenWidth - 200, screenHeight - 20, 10, GRAY); diff --git a/examples/models/models_orthographic_projection.c b/examples/models/models_orthographic_projection.c index cb5ea053f..f9b54b6d0 100644 --- a/examples/models/models_orthographic_projection.c +++ b/examples/models/models_orthographic_projection.c @@ -57,7 +57,7 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); DrawCube((Vector3){-4.0f, 0.0f, 2.0f}, 2.0f, 5.0f, 2.0f, RED); DrawCubeWires((Vector3){-4.0f, 0.0f, 2.0f}, 2.0f, 5.0f, 2.0f, GOLD); @@ -75,7 +75,7 @@ int main() DrawGrid(10, 1.0f); // Draw a grid - End3dMode(); + EndMode3D(); DrawText("Press Spacebar to switch camera type", 10, GetScreenHeight() - 30, 20, DARKGRAY); diff --git a/examples/models/models_skybox.c b/examples/models/models_skybox.c index 700824d34..589f139b6 100644 --- a/examples/models/models_skybox.c +++ b/examples/models/models_skybox.c @@ -60,13 +60,13 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); DrawModel(skybox, (Vector3){0, 0, 0}, 1.0f, WHITE); DrawGrid(10, 1.0f); - End3dMode(); + EndMode3D(); DrawFPS(10, 10); diff --git a/examples/models/models_yaw_pitch_roll.c b/examples/models/models_yaw_pitch_roll.c index c559e67b7..0dcf8c70f 100644 --- a/examples/models/models_yaw_pitch_roll.c +++ b/examples/models/models_yaw_pitch_roll.c @@ -137,12 +137,12 @@ int main() EndTextureMode(); // Draw 3D model (recomended to draw 3D always before 2D) - Begin3dMode(camera); + BeginMode3D(camera); DrawModel(model, (Vector3){ 0, 6.0f, 0 }, 1.0f, WHITE); // Draw 3d model with texture DrawGrid(10, 10.0f); - End3dMode(); + EndMode3D(); // Draw 2D GUI stuff DrawAngleGauge(texAngleGauge, 80, 70, roll, "roll", RED); diff --git a/examples/others/oculus_rift.c b/examples/others/oculus_rift.c index af2a87c17..cdfa5f11e 100644 --- a/examples/others/oculus_rift.c +++ b/examples/others/oculus_rift.c @@ -151,14 +151,14 @@ int main() if (vrDeviceReady) BeginOculusDrawing(); else BeginVrDrawing(); - Begin3dMode(camera); + BeginMode3D(camera); DrawCube(cubePosition, 2.0f, 2.0f, 2.0f, RED); DrawCubeWires(cubePosition, 2.0f, 2.0f, 2.0f, MAROON); DrawGrid(40, 1.0f); - End3dMode(); + EndMode3D(); if (vrDeviceReady) EndOculusDrawing(); else EndVrDrawing(); diff --git a/examples/others/standard_lighting.c b/examples/others/standard_lighting.c index a7f634e2a..f450a2a5e 100644 --- a/examples/others/standard_lighting.c +++ b/examples/others/standard_lighting.c @@ -159,7 +159,7 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); DrawModel(dwarf, position, 2.0f, WHITE); // Draw 3d model with texture @@ -169,7 +169,7 @@ int main() DrawGrid(10, 1.0f); // Draw a grid - End3dMode(); + EndMode3D(); DrawText("(c) Dwarf 3D model by David Moreno", screenWidth - 200, screenHeight - 20, 10, GRAY); diff --git a/examples/shaders/shaders_custom_uniform.c b/examples/shaders/shaders_custom_uniform.c index 4e160455a..ddee4187f 100644 --- a/examples/shaders/shaders_custom_uniform.c +++ b/examples/shaders/shaders_custom_uniform.c @@ -85,13 +85,13 @@ int main() BeginTextureMode(target); // Enable drawing to texture - Begin3dMode(camera); + BeginMode3D(camera); DrawModel(dwarf, position, 2.0f, WHITE); // Draw 3d model with texture DrawGrid(10, 1.0f); // Draw a grid - End3dMode(); + EndMode3D(); DrawText("TEXT DRAWN IN RENDER TEXTURE", 200, 10, 30, RED); diff --git a/examples/shaders/shaders_model_shader.c b/examples/shaders/shaders_model_shader.c index 51acc8368..3ce9c6a32 100644 --- a/examples/shaders/shaders_model_shader.c +++ b/examples/shaders/shaders_model_shader.c @@ -66,13 +66,13 @@ int main() ClearBackground(RAYWHITE); - Begin3dMode(camera); + BeginMode3D(camera); DrawModel(dwarf, position, 2.0f, WHITE); // Draw 3d model with texture DrawGrid(10, 1.0f); // Draw a grid - End3dMode(); + EndMode3D(); DrawText("(c) Dwarf 3D model by David Moreno", screenWidth - 200, screenHeight - 20, 10, GRAY); diff --git a/examples/shaders/shaders_postprocessing.c b/examples/shaders/shaders_postprocessing.c index 5eeda8968..80660d689 100644 --- a/examples/shaders/shaders_postprocessing.c +++ b/examples/shaders/shaders_postprocessing.c @@ -130,13 +130,13 @@ int main() BeginTextureMode(target); // Enable drawing to texture - Begin3dMode(camera); + BeginMode3D(camera); DrawModel(dwarf, position, 2.0f, WHITE); // Draw 3d model with texture DrawGrid(10, 1.0f); // Draw a grid - End3dMode(); + EndMode3D(); EndTextureMode(); // End drawing to texture (now we have a texture available for next passes) diff --git a/src/core.c b/src/core.c index 3f071fc6f..5587f82b5 100644 --- a/src/core.c +++ b/src/core.c @@ -117,7 +117,7 @@ #include // Required for: malloc(), free(), rand(), atexit() #include // Required for: typedef unsigned long long int uint64_t, used by hi-res timer #include // Required for: time() - Android/RPI hi-res timer (NOTE: Linux only!) -#include // Required for: tan() [Used in Begin3dMode() to set perspective] +#include // Required for: tan() [Used in BeginMode3D() to set perspective] #include // Required for: strrchr(), strcmp() //#include // Macros for reporting and retrieving error conditions through error codes #include // Required for: tolower() [Used in IsFileExtension()] @@ -888,7 +888,7 @@ void EndDrawing(void) } // Initialize 2D mode with custom camera (2D) -void Begin2dMode(Camera2D camera) +void BeginMode2D(Camera2D camera) { rlglDraw(); // Draw Buffers (Only OpenGL 3+ and ES2) @@ -906,7 +906,7 @@ void Begin2dMode(Camera2D camera) } // Ends 2D mode with custom camera -void End2dMode(void) +void EndMode2D(void) { rlglDraw(); // Draw Buffers (Only OpenGL 3+ and ES2) @@ -914,7 +914,7 @@ void End2dMode(void) } // Initializes 3D mode with custom camera (3D) -void Begin3dMode(Camera camera) +void BeginMode3D(Camera3D camera) { rlglDraw(); // Draw Buffers (Only OpenGL 3+ and ES2) @@ -954,7 +954,7 @@ void Begin3dMode(Camera camera) } // Ends 3D mode and returns to default 2D orthographic mode -void End3dMode(void) +void EndMode3D(void) { rlglDraw(); // Process internal buffers (update + draw) @@ -2912,7 +2912,7 @@ static void WindowSizeCallback(GLFWwindow *window, int width, int height) rlLoadIdentity(); // Reset current matrix (MODELVIEW) rlClearScreenBuffers(); // Clear screen buffers (color and depth) - // Window size must be updated to be used on 3D mode to get new aspect ratio (Begin3dMode()) + // Window size must be updated to be used on 3D mode to get new aspect ratio (BeginMode3D()) // NOTE: Be careful! GLFW3 will choose the closest fullscreen resolution supported by current monitor, // for example, if reescaling back to 800x450 (desired), it could set 720x480 (closest fullscreen supported) screenWidth = width; diff --git a/src/raylib.h b/src/raylib.h index 6d3aaaf96..b5a6a1914 100644 --- a/src/raylib.h +++ b/src/raylib.h @@ -6,7 +6,7 @@ * - Written in plain C code (C99) in PascalCase/camelCase notation * - Hardware accelerated with OpenGL (1.1, 2.1, 3.3 or ES2 - choose at compile) * - Unique OpenGL abstraction layer (usable as standalone module): [rlgl] -* - Powerful fonts module with SpriteFonts support (XNA fonts, AngelCode fonts, TTF) +* - Powerful fonts module with Fonts support (XNA fonts, AngelCode fonts, TTF) * - Outstanding texture formats support, including compressed formats (DXT, ETC, ASTC) * - Full 3d support for 3d Shapes, Models, Billboards, Heightmaps and more! * - Flexible Materials system, supporting classic maps and PBR maps @@ -728,10 +728,10 @@ RLAPI void DisableCursor(void); // Disables cu RLAPI void ClearBackground(Color color); // Set background color (framebuffer clear color) RLAPI void BeginDrawing(void); // Setup canvas (framebuffer) to start drawing RLAPI void EndDrawing(void); // End canvas drawing and swap buffers (double buffering) -RLAPI void Begin2dMode(Camera2D camera); // Initialize 2D mode with custom camera (2D) -RLAPI void End2dMode(void); // Ends 2D mode with custom camera -RLAPI void Begin3dMode(Camera camera); // Initializes 3D mode with custom camera (3D) -RLAPI void End3dMode(void); // Ends 3D mode and returns to default 2D orthographic mode +RLAPI void BeginMode2D(Camera2D camera); // Initialize 2D mode with custom camera (2D) +RLAPI void EndMode2D(void); // Ends 2D mode with custom camera +RLAPI void BeginMode3D(Camera3D camera); // Initializes 3D mode with custom camera (3D) +RLAPI void EndMode3D(void); // Ends 3D mode and returns to default 2D orthographic mode RLAPI void BeginTextureMode(RenderTexture2D target); // Initializes render texture for drawing RLAPI void EndTextureMode(void); // Ends drawing to render texture diff --git a/src/rlgl.c b/src/rlgl.c index 68bd36701..93a0b0f84 100644 --- a/src/rlgl.c +++ b/src/rlgl.c @@ -1947,7 +1947,7 @@ void rlDrawMesh(Mesh mesh, Material material, Matrix transform) if (material.shader.locs[LOC_MATRIX_PROJECTION] != -1) SetShaderValueMatrix(material.shader, material.shader.locs[LOC_MATRIX_PROJECTION], projection); // At this point the modelview matrix just contains the view matrix (camera) - // That's because Begin3dMode() sets it an no model-drawing function modifies it, all use rlPushMatrix() and rlPopMatrix() + // That's because BeginMode3D() sets it an no model-drawing function modifies it, all use rlPushMatrix() and rlPopMatrix() Matrix matView = modelview; // View matrix (camera) Matrix matProjection = projection; // Projection matrix (perspective) From ec33e7d705e301eb2b74a841e823907295caa37a Mon Sep 17 00:00:00 2001 From: Ray San Date: Fri, 4 May 2018 16:59:48 +0200 Subject: [PATCH 13/53] BREAKING CHANGE: Renamed SpriteFont type to Font - Preparing MP3 files support - Jumped version to raylib 2.0-dev (too many breaking changes...) --- examples/text/text_bmfont_ttf.c | 10 +- examples/text/text_bmfont_unordered.c | 4 +- examples/text/text_raylib_fonts.c | 22 +- examples/text/text_sprite_fonts.c | 14 +- examples/text/text_ttf_loading.c | 12 +- examples/textures/textures_image_drawing.c | 4 +- examples/textures/textures_image_text.c | 6 +- games/drturtle/04_drturtle_gui.c | 4 +- games/drturtle/05_drturtle_audio.c | 4 +- games/drturtle/06_drturtle_final.c | 4 +- games/drturtle/drturtle_final_web.c | 6 +- games/koala_seasons/koala_seasons.c | 4 +- games/koala_seasons/screens/screens.h | 2 +- games/light_my_ritual/light_my_ritual.c | 4 +- games/light_my_ritual/screens/screens.h | 2 +- games/skully_escape/screens/screens.h | 2 +- games/skully_escape/skully_escape.c | 4 +- games/transmission/screens/screen_ending.c | 6 +- games/transmission/screens/screen_gameplay.c | 4 +- games/transmission/screens/screen_title.c | 6 +- games/transmission/screens/screens.h | 2 +- games/transmission/transmission.c | 4 +- games/wave_collector/screens/screens.h | 2 +- games/wave_collector/wave_collector.c | 4 +- release/include/raylib.h | 110 +- release/libs/win32/mingw32/libraylib.a | Bin 1056510 -> 1218614 bytes src/audio.c | 6 + src/config.h | 3 +- src/external/dr_mp3.h | 2841 ++++++++++++++++++ src/raylib.h | 30 +- src/text.c | 68 +- src/textures.c | 6 +- templates/advance_game/advance_game.c | 4 +- templates/advance_game/screens/screens.h | 2 +- 34 files changed, 3027 insertions(+), 179 deletions(-) create mode 100644 src/external/dr_mp3.h diff --git a/examples/text/text_bmfont_ttf.c b/examples/text/text_bmfont_ttf.c index 0778fd11a..f71f5ddb1 100644 --- a/examples/text/text_bmfont_ttf.c +++ b/examples/text/text_bmfont_ttf.c @@ -1,6 +1,6 @@ /******************************************************************************************* * -* raylib [text] example - BMFont and TTF SpriteFonts loading +* raylib [text] example - BMFont and TTF Fonts loading * * This example has been created using raylib 1.4 (www.raylib.com) * raylib is licensed under an unmodified zlib/libpng license (View raylib.h for details) @@ -24,8 +24,8 @@ int main() const char msgTtf[64] = "THIS SPRITE FONT has been GENERATED from a TTF"; // NOTE: Textures/Fonts MUST be loaded after Window initialization (OpenGL context is required) - SpriteFont fontBm = LoadSpriteFont("resources/bmfont.fnt"); // BMFont (AngelCode) - SpriteFont fontTtf = LoadSpriteFont("resources/pixantiqua.ttf"); // TTF font + Font fontBm = LoadFont("resources/bmfont.fnt"); // BMFont (AngelCode) + Font fontTtf = LoadFont("resources/pixantiqua.ttf"); // TTF font Vector2 fontPosition; @@ -58,8 +58,8 @@ int main() // De-Initialization //-------------------------------------------------------------------------------------- - UnloadSpriteFont(fontBm); // AngelCode SpriteFont unloading - UnloadSpriteFont(fontTtf); // TTF SpriteFont unloading + UnloadFont(fontBm); // AngelCode Font unloading + UnloadFont(fontTtf); // TTF Font unloading CloseWindow(); // Close window and OpenGL context //-------------------------------------------------------------------------------------- diff --git a/examples/text/text_bmfont_unordered.c b/examples/text/text_bmfont_unordered.c index 01561bec3..a51476198 100644 --- a/examples/text/text_bmfont_unordered.c +++ b/examples/text/text_bmfont_unordered.c @@ -25,7 +25,7 @@ int main() const char msg[256] = "ASCII extended characters:\n¡¢£¤¥¦§¨©ª«¬®¯°±²³´µ¶·¸¹º»¼½¾¿ÀÁÂÃÄÅÆ\nÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖרÙÚÛÜÝÞßàáâãäåæ\nçèéêëìíîïðñòóôõö÷øùúûüýþÿ"; // NOTE: Loaded font has an unordered list of characters (chars in the range 32..255) - SpriteFont font = LoadSpriteFont("resources/pixantiqua.fnt"); // BMFont (AngelCode) + Font font = LoadFont("resources/pixantiqua.fnt"); // BMFont (AngelCode) SetTargetFPS(60); //-------------------------------------------------------------------------------------- @@ -56,7 +56,7 @@ int main() // De-Initialization //-------------------------------------------------------------------------------------- - UnloadSpriteFont(font); // AngelCode SpriteFont unloading + UnloadFont(font); // AngelCode Font unloading CloseWindow(); // Close window and OpenGL context //-------------------------------------------------------------------------------------- diff --git a/examples/text/text_raylib_fonts.c b/examples/text/text_raylib_fonts.c index 6d8ef2b62..3c930ac2b 100644 --- a/examples/text/text_raylib_fonts.c +++ b/examples/text/text_raylib_fonts.c @@ -26,16 +26,16 @@ int main() InitWindow(screenWidth, screenHeight, "raylib [text] example - raylib fonts"); // NOTE: Textures MUST be loaded after Window initialization (OpenGL context is required) - SpriteFont fonts[MAX_FONTS]; + Font fonts[MAX_FONTS]; - fonts[0] = LoadSpriteFont("resources/fonts/alagard.png"); - fonts[1] = LoadSpriteFont("resources/fonts/pixelplay.png"); - fonts[2] = LoadSpriteFont("resources/fonts/mecha.png"); - fonts[3] = LoadSpriteFont("resources/fonts/setback.png"); - fonts[4] = LoadSpriteFont("resources/fonts/romulus.png"); - fonts[5] = LoadSpriteFont("resources/fonts/pixantiqua.png"); - fonts[6] = LoadSpriteFont("resources/fonts/alpha_beta.png"); - fonts[7] = LoadSpriteFont("resources/fonts/jupiter_crash.png"); + fonts[0] = LoadFont("resources/fonts/alagard.png"); + fonts[1] = LoadFont("resources/fonts/pixelplay.png"); + fonts[2] = LoadFont("resources/fonts/mecha.png"); + fonts[3] = LoadFont("resources/fonts/setback.png"); + fonts[4] = LoadFont("resources/fonts/romulus.png"); + fonts[5] = LoadFont("resources/fonts/pixantiqua.png"); + fonts[6] = LoadFont("resources/fonts/alpha_beta.png"); + fonts[7] = LoadFont("resources/fonts/jupiter_crash.png"); const char *messages[MAX_FONTS] = { "ALAGARD FONT designed by Hewett Tsoi", "PIXELPLAY FONT designed by Aleksander Shevchuk", @@ -93,8 +93,8 @@ int main() // De-Initialization //-------------------------------------------------------------------------------------- - // SpriteFonts unloading - for (int i = 0; i < MAX_FONTS; i++) UnloadSpriteFont(fonts[i]); + // Fonts unloading + for (int i = 0; i < MAX_FONTS; i++) UnloadFont(fonts[i]); CloseWindow(); // Close window and OpenGL context //-------------------------------------------------------------------------------------- diff --git a/examples/text/text_sprite_fonts.c b/examples/text/text_sprite_fonts.c index aefbfd1f8..7ce2fef5f 100644 --- a/examples/text/text_sprite_fonts.c +++ b/examples/text/text_sprite_fonts.c @@ -1,6 +1,6 @@ /******************************************************************************************* * -* raylib [text] example - SpriteFont loading and usage +* raylib [text] example - Font loading and usage * * This example has been created using raylib 1.0 (www.raylib.com) * raylib is licensed under an unmodified zlib/libpng license (View raylib.h for details) @@ -25,9 +25,9 @@ int main() const char msg3[50] = "...and a THIRD one! GREAT! :D"; // NOTE: Textures/Fonts MUST be loaded after Window initialization (OpenGL context is required) - SpriteFont font1 = LoadSpriteFont("resources/custom_mecha.png"); // SpriteFont loading - SpriteFont font2 = LoadSpriteFont("resources/custom_alagard.png"); // SpriteFont loading - SpriteFont font3 = LoadSpriteFont("resources/custom_jupiter_crash.png"); // SpriteFont loading + Font font1 = LoadFont("resources/custom_mecha.png"); // Font loading + Font font2 = LoadFont("resources/custom_alagard.png"); // Font loading + Font font3 = LoadFont("resources/custom_jupiter_crash.png"); // Font loading Vector2 fontPosition1, fontPosition2, fontPosition3; @@ -66,9 +66,9 @@ int main() // De-Initialization //-------------------------------------------------------------------------------------- - UnloadSpriteFont(font1); // SpriteFont unloading - UnloadSpriteFont(font2); // SpriteFont unloading - UnloadSpriteFont(font3); // SpriteFont unloading + UnloadFont(font1); // Font unloading + UnloadFont(font2); // Font unloading + UnloadFont(font3); // Font unloading CloseWindow(); // Close window and OpenGL context //-------------------------------------------------------------------------------------- diff --git a/examples/text/text_ttf_loading.c b/examples/text/text_ttf_loading.c index fedfbfb8e..42fb58bfb 100644 --- a/examples/text/text_ttf_loading.c +++ b/examples/text/text_ttf_loading.c @@ -20,12 +20,12 @@ int main() InitWindow(screenWidth, screenHeight, "raylib [text] example - ttf loading"); - const char msg[50] = "TTF SpriteFont"; + const char msg[50] = "TTF Font"; // NOTE: Textures/Fonts MUST be loaded after Window initialization (OpenGL context is required) - // TTF SpriteFont loading with custom generation parameters - SpriteFont font = LoadSpriteFontEx("resources/KAISG.ttf", 96, 0, 0); + // TTF Font loading with custom generation parameters + Font font = LoadFontEx("resources/KAISG.ttf", 96, 0, 0); // Generate mipmap levels to use trilinear filtering // NOTE: On 2D drawing it won't be noticeable, it looks like FILTER_BILINEAR @@ -85,8 +85,8 @@ int main() if (count == 1) // Only support one ttf file dropped { - UnloadSpriteFont(font); - font = LoadSpriteFontEx(droppedFiles[0], fontSize, 0, 0); + UnloadFont(font); + font = LoadFontEx(droppedFiles[0], fontSize, 0, 0); ClearDroppedFiles(); } } @@ -127,7 +127,7 @@ int main() #if defined(PLATFORM_DESKTOP) ClearDroppedFiles(); // Clear internal buffers #endif - UnloadSpriteFont(font); // SpriteFont unloading + UnloadFont(font); // Font unloading CloseWindow(); // Close window and OpenGL context //-------------------------------------------------------------------------------------- diff --git a/examples/textures/textures_image_drawing.c b/examples/textures/textures_image_drawing.c index ac128af97..b179612d4 100644 --- a/examples/textures/textures_image_drawing.c +++ b/examples/textures/textures_image_drawing.c @@ -38,12 +38,12 @@ int main() UnloadImage(cat); // Unload image from RAM // Load custom font for frawing on image - SpriteFont font = LoadSpriteFont("resources/custom_jupiter_crash.png"); + Font font = LoadFont("resources/custom_jupiter_crash.png"); // Draw over image using custom font ImageDrawTextEx(&parrots, (Vector2){ 300, 230 }, font, "PARROTS & CAT", font.baseSize, -2, WHITE); - UnloadSpriteFont(font); // Unload custom spritefont (already drawn used on image) + UnloadFont(font); // Unload custom spritefont (already drawn used on image) Texture2D texture = LoadTextureFromImage(parrots); // Image converted to texture, uploaded to GPU memory (VRAM) UnloadImage(parrots); // Once image has been converted to texture and uploaded to VRAM, it can be unloaded from RAM diff --git a/examples/textures/textures_image_text.c b/examples/textures/textures_image_text.c index 1d4231f74..0a939b8d2 100644 --- a/examples/textures/textures_image_text.c +++ b/examples/textures/textures_image_text.c @@ -20,8 +20,8 @@ int main() InitWindow(screenWidth, screenHeight, "raylib [texture] example - image text drawing"); - // TTF SpriteFont loading with custom generation parameters - SpriteFont font = LoadSpriteFontEx("resources/KAISG.ttf", 64, 0, 0); + // TTF Font loading with custom generation parameters + Font font = LoadFontEx("resources/KAISG.ttf", 64, 0, 0); Image parrots = LoadImage("resources/parrots.png"); // Load image in CPU memory (RAM) @@ -74,7 +74,7 @@ int main() //-------------------------------------------------------------------------------------- UnloadTexture(texture); // Texture unloading - UnloadSpriteFont(font); // Unload custom spritefont + UnloadFont(font); // Unload custom spritefont CloseWindow(); // Close window and OpenGL context //-------------------------------------------------------------------------------------- diff --git a/games/drturtle/04_drturtle_gui.c b/games/drturtle/04_drturtle_gui.c index 5be8f1f14..0ec06fb68 100644 --- a/games/drturtle/04_drturtle_gui.c +++ b/games/drturtle/04_drturtle_gui.c @@ -49,7 +49,7 @@ int main() Texture2D gframe = LoadTexture("resources/gframe.png"); // Load game resources: fonts - SpriteFont font = LoadSpriteFont("resources/komika.png"); + Font font = LoadFont("resources/komika.png"); // Define scrolling variables int backScrolling = 0; @@ -438,7 +438,7 @@ int main() UnloadTexture(gamera); // Unload font texture - UnloadSpriteFont(font); + UnloadFont(font); CloseWindow(); // Close window and OpenGL context //-------------------------------------------------------------------------------------- diff --git a/games/drturtle/05_drturtle_audio.c b/games/drturtle/05_drturtle_audio.c index 3645c657a..4c3ce4add 100644 --- a/games/drturtle/05_drturtle_audio.c +++ b/games/drturtle/05_drturtle_audio.c @@ -52,7 +52,7 @@ int main() Texture2D gframe = LoadTexture("resources/gframe.png"); // Load game resources: fonts - SpriteFont font = LoadSpriteFont("resources/komika.png"); + Font font = LoadFont("resources/komika.png"); // Load game resources: sounds Sound eat = LoadSound("resources/eat.wav"); @@ -454,7 +454,7 @@ int main() UnloadTexture(gamera); // Unload font texture - UnloadSpriteFont(font); + UnloadFont(font); // Unload sounds UnloadSound(eat); diff --git a/games/drturtle/06_drturtle_final.c b/games/drturtle/06_drturtle_final.c index 2edebe877..a74d4f7e3 100644 --- a/games/drturtle/06_drturtle_final.c +++ b/games/drturtle/06_drturtle_final.c @@ -55,7 +55,7 @@ int main() Texture2D gframe = LoadTexture("resources/gframe.png"); // Load game resources: fonts - SpriteFont font = LoadSpriteFont("resources/komika.png"); + Font font = LoadFont("resources/komika.png"); // Load game resources: sounds Sound eat = LoadSound("resources/eat.wav"); @@ -479,7 +479,7 @@ int main() UnloadTexture(gamera); // Unload font texture - UnloadSpriteFont(font); + UnloadFont(font); // Unload sounds UnloadSound(eat); diff --git a/games/drturtle/drturtle_final_web.c b/games/drturtle/drturtle_final_web.c index 84f3b1c20..0b639e38b 100644 --- a/games/drturtle/drturtle_final_web.c +++ b/games/drturtle/drturtle_final_web.c @@ -48,7 +48,7 @@ Texture2D swhale; Texture2D fish; Texture2D gframe; -SpriteFont font; +Font font; Sound eat; Sound die; @@ -119,7 +119,7 @@ int main() gframe = LoadTexture("resources/gframe.png"); // Load game resources: fonts - font = LoadSpriteFont("resources/komika.png"); + font = LoadFont("resources/komika.png"); // Load game resources: sounds eat = LoadSound("resources/eat.wav"); @@ -186,7 +186,7 @@ int main() UnloadTexture(gamera); // Unload font texture - UnloadSpriteFont(font); + UnloadFont(font); // Unload sounds UnloadSound(eat); diff --git a/games/koala_seasons/koala_seasons.c b/games/koala_seasons/koala_seasons.c index 8657d3d56..479fab854 100644 --- a/games/koala_seasons/koala_seasons.c +++ b/games/koala_seasons/koala_seasons.c @@ -57,7 +57,7 @@ int main(void) { InitWindow(screenWidth, screenHeight, windowTitle); // Load global data here (assets that must be available in all screens, i.e. fonts) - font = LoadSpriteFont("resources/graphics/mainfont.png"); + font = LoadFont("resources/graphics/mainfont.png"); atlas01 = LoadTexture("resources/graphics/atlas01.png"); atlas02 = LoadTexture("resources/graphics/atlas02.png"); @@ -114,7 +114,7 @@ int main(void) { UnloadTexture(atlas01); UnloadTexture(atlas02); - UnloadSpriteFont(font); + UnloadFont(font); UnloadShader(colorBlend); // Unload color overlay blending shader diff --git a/games/koala_seasons/screens/screens.h b/games/koala_seasons/screens/screens.h index ba62aa27c..36d308404 100644 --- a/games/koala_seasons/screens/screens.h +++ b/games/koala_seasons/screens/screens.h @@ -42,7 +42,7 @@ typedef enum GameScreen { LOGO, TITLE, OPTIONS, GAMEPLAY, ENDING } GameScreen; GameScreen currentScreen; // NOTE: This is all the data used in the game -SpriteFont font; +Font font; Shader colorBlend; Texture2D atlas01; Texture2D atlas02; diff --git a/games/light_my_ritual/light_my_ritual.c b/games/light_my_ritual/light_my_ritual.c index 985baa049..ece51997b 100644 --- a/games/light_my_ritual/light_my_ritual.c +++ b/games/light_my_ritual/light_my_ritual.c @@ -68,7 +68,7 @@ int main(void) UnloadImage(image); // Unload image from CPU memory (RAM) - font = LoadSpriteFont("resources/font_arcadian.png"); + font = LoadFont("resources/font_arcadian.png"); //doors = LoadTexture("resources/textures/doors.png"); //sndDoor = LoadSound("resources/audio/door.ogg"); @@ -106,7 +106,7 @@ int main(void) } // Unload all global loaded data (i.e. fonts) here! - UnloadSpriteFont(font); + UnloadFont(font); //UnloadSound(sndDoor); UnloadMusicStream(music); diff --git a/games/light_my_ritual/screens/screens.h b/games/light_my_ritual/screens/screens.h index ff12a01c0..fc17c268d 100644 --- a/games/light_my_ritual/screens/screens.h +++ b/games/light_my_ritual/screens/screens.h @@ -35,7 +35,7 @@ typedef enum GameScreen { LOGO_RL = 0, TITLE, GAMEPLAY } GameScreen; // Global Variables Definition //---------------------------------------------------------------------------------- GameScreen currentScreen; -SpriteFont font; +Font font; Color *lightsMap; int lightsMapWidth, lightsMapHeight; diff --git a/games/skully_escape/screens/screens.h b/games/skully_escape/screens/screens.h index ce35ae70f..eed0138cc 100644 --- a/games/skully_escape/screens/screens.h +++ b/games/skully_escape/screens/screens.h @@ -47,7 +47,7 @@ typedef struct Door { // Global Variables Definition //---------------------------------------------------------------------------------- GameScreen currentScreen; -SpriteFont font; +Font font; Texture2D doors; Sound sndDoor; diff --git a/games/skully_escape/skully_escape.c b/games/skully_escape/skully_escape.c index dc545117f..e2e7007bb 100644 --- a/games/skully_escape/skully_escape.c +++ b/games/skully_escape/skully_escape.c @@ -60,7 +60,7 @@ int main(void) music = LoadMusicStream("resources/audio/come_play_with_me.ogg"); PlayMusicStream(music); - font = LoadSpriteFont("resources/textures/alagard.png"); + font = LoadFont("resources/textures/alagard.png"); doors = LoadTexture("resources/textures/doors.png"); sndDoor = LoadSound("resources/audio/door.ogg"); sndScream = LoadSound("resources/audio/scream.ogg"); @@ -89,7 +89,7 @@ int main(void) // Unload all global loaded data (i.e. fonts) here! UnloadPlayer(); - UnloadSpriteFont(font); + UnloadFont(font); UnloadTexture(doors); UnloadSound(sndDoor); UnloadSound(sndScream); diff --git a/games/transmission/screens/screen_ending.c b/games/transmission/screens/screen_ending.c index e6ab3518c..0aba5f014 100644 --- a/games/transmission/screens/screen_ending.c +++ b/games/transmission/screens/screen_ending.c @@ -68,7 +68,7 @@ static Mission *missions = NULL; static char headline[MAX_TITLE_CHAR] = "\0"; -SpriteFont fontNews; +Font fontNews; // String (const char *) replacement function static char *StringReplace(char *orig, char *rep, char *with); @@ -121,11 +121,11 @@ void InitEndingScreen(void) // Generate newspaper with title and subtitle Image imNewspaper = LoadImage("resources/textures/ending_newspaper.png"); - fontNews = LoadSpriteFontEx("resources/fonts/Lora-Bold.ttf", 32, 250, 0); + fontNews = LoadFontEx("resources/fonts/Lora-Bold.ttf", 32, 250, 0); ImageDrawTextEx(&imNewspaper, (Vector2){ 50, 220 }, fontNews, headline, fontNews.baseSize, 0, DARKGRAY); texNewspaper = LoadTextureFromImage(imNewspaper); - //UnloadSpriteFont(fontNews); + //UnloadFont(fontNews); UnloadImage(imNewspaper); } diff --git a/games/transmission/screens/screen_gameplay.c b/games/transmission/screens/screen_gameplay.c index 00c451fc8..0594e10fc 100644 --- a/games/transmission/screens/screen_gameplay.c +++ b/games/transmission/screens/screen_gameplay.c @@ -95,7 +95,7 @@ static int framesCounter; static int finishScreen; static Texture2D texBackground; -static SpriteFont fontMessage; +static Font fontMessage; static Texture2D texWordsAtlas; static Texture2D texVignette; @@ -126,7 +126,7 @@ void InitGameplayScreen(void) framesCounter = 0; finishScreen = 0; - fontMessage = LoadSpriteFontEx("resources/fonts/traveling_typewriter.ttf", 30, 250, 0); + fontMessage = LoadFontEx("resources/fonts/traveling_typewriter.ttf", 30, 250, 0); texBackground = LoadTexture("resources/textures/message_background.png"); texVignette = LoadTexture("resources/textures/message_vignette.png"); diff --git a/games/transmission/screens/screen_title.c b/games/transmission/screens/screen_title.c index a5ad0a847..22efadb1a 100644 --- a/games/transmission/screens/screen_title.c +++ b/games/transmission/screens/screen_title.c @@ -36,7 +36,7 @@ static int framesCounter; static int finishScreen; static Texture2D texBackground; -static SpriteFont fontTitle; +static Font fontTitle; static Sound fxTyping; static float titleSize; @@ -71,7 +71,7 @@ void InitTitleScreen(void) texBackground = LoadTexture("resources/textures/title_background.png"); fxTyping = LoadSound("resources/audio/fx_typing.ogg"); - fontTitle = LoadSpriteFontEx("resources/fonts/mom_typewritter.ttf", 96, 0, 0); + fontTitle = LoadFontEx("resources/fonts/mom_typewritter.ttf", 96, 0, 0); titleSize = 44; transmissionPosition = (Vector2){519, 221}; @@ -148,7 +148,7 @@ void UnloadTitleScreen(void) { UnloadTexture(texBackground); UnloadSound(fxTyping); - UnloadSpriteFont(fontTitle); + UnloadFont(fontTitle); } // Title Screen should finish? diff --git a/games/transmission/screens/screens.h b/games/transmission/screens/screens.h index 27560d8b7..be5e31d92 100644 --- a/games/transmission/screens/screens.h +++ b/games/transmission/screens/screens.h @@ -76,7 +76,7 @@ Color textColorButton; int currentMission; int totalMissions; -SpriteFont fontMission; +Font fontMission; Word messageWords[MAX_MISSION_WORDS]; diff --git a/games/transmission/transmission.c b/games/transmission/transmission.c index 37824a7b6..d4298e346 100644 --- a/games/transmission/transmission.c +++ b/games/transmission/transmission.c @@ -70,7 +70,7 @@ int main(void) SetMusicVolume(music, 1.0f); PlayMusicStream(music); - fontMission = LoadSpriteFontEx("resources/fonts/traveling_typewriter.ttf", 64, 250, 0); + fontMission = LoadFontEx("resources/fonts/traveling_typewriter.ttf", 64, 250, 0); texButton = LoadTexture("resources/textures/title_ribbon.png"); // UI BUTTON @@ -122,7 +122,7 @@ int main(void) UnloadMusicStream(music); UnloadSound(fxButton); - UnloadSpriteFont(fontMission); + UnloadFont(fontMission); UnloadTexture(texButton); CloseAudioDevice(); // Close audio context diff --git a/games/wave_collector/screens/screens.h b/games/wave_collector/screens/screens.h index 3e4d062f2..6e896d58b 100644 --- a/games/wave_collector/screens/screens.h +++ b/games/wave_collector/screens/screens.h @@ -35,7 +35,7 @@ typedef enum GameScreen { LOGO = 0, TITLE, GAMEPLAY, ENDING } GameScreen; // Global Variables Definition //---------------------------------------------------------------------------------- GameScreen currentScreen; -SpriteFont font; +Font font; Music music; int endingStatus; // 1 - Win, 2 - Lose diff --git a/games/wave_collector/wave_collector.c b/games/wave_collector/wave_collector.c index 2099b74c1..0a04310d4 100644 --- a/games/wave_collector/wave_collector.c +++ b/games/wave_collector/wave_collector.c @@ -90,7 +90,7 @@ int main(int argc, char *argv[]) // Global data loading (assets that must be available in all screens, i.e. fonts) InitAudioDevice(); - font = LoadSpriteFont("resources/font.fnt"); + font = LoadFont("resources/font.fnt"); music = LoadMusicStream("resources/audio/wave.ogg"); SetMusicVolume(music, 1.0f); @@ -127,7 +127,7 @@ int main(int argc, char *argv[]) } // Unload all global loaded data (i.e. fonts) here! - UnloadSpriteFont(font); + UnloadFont(font); UnloadMusicStream(music); CloseAudioDevice(); // Close audio context diff --git a/release/include/raylib.h b/release/include/raylib.h index acca46bdc..e83650e6c 100644 --- a/release/include/raylib.h +++ b/release/include/raylib.h @@ -1,14 +1,12 @@ /********************************************************************************************** * -* raylib v1.9.6-dev -* -* A simple and easy-to-use library to learn videogames programming (www.raylib.com) +* raylib - A simple and easy-to-use library to learn videogames programming (www.raylib.com) * * FEATURES: * - Written in plain C code (C99) in PascalCase/camelCase notation * - Hardware accelerated with OpenGL (1.1, 2.1, 3.3 or ES2 - choose at compile) * - Unique OpenGL abstraction layer (usable as standalone module): [rlgl] -* - Powerful fonts module with SpriteFonts support (XNA fonts, AngelCode fonts, TTF) +* - Powerful fonts module with Fonts support (XNA fonts, AngelCode fonts, TTF) * - Outstanding texture formats support, including compressed formats (DXT, ETC, ASTC) * - Full 3d support for 3d Shapes, Models, Billboards, Heightmaps and more! * - Flexible Materials system, supporting classic maps and PBR maps @@ -138,6 +136,9 @@ #define KEY_RIGHT_SHIFT 344 #define KEY_RIGHT_CONTROL 345 #define KEY_RIGHT_ALT 346 +#define KEY_GRAVE 96 +#define KEY_SLASH 47 +#define KEY_BACKSLASH 92 // Keyboard Alpha Numeric Keys #define KEY_ZERO 48 @@ -189,7 +190,7 @@ #define MOUSE_MIDDLE_BUTTON 2 // Touch points registered -#define MAX_TOUCH_POINTS 2 +#define MAX_TOUCH_POINTS 2 // Gamepad Number #define GAMEPAD_PLAYER1 0 @@ -348,10 +349,10 @@ typedef struct Color { // Rectangle type typedef struct Rectangle { - int x; - int y; - int width; - int height; + float x; + float y; + float width; + float height; } Rectangle; // Image type, bpp always RGBA (32bit) @@ -381,7 +382,7 @@ typedef struct RenderTexture2D { Texture2D depth; // Depth buffer attachment texture } RenderTexture2D; -// SpriteFont character info +// Font character info typedef struct CharInfo { int value; // Character value (Unicode) Rectangle rec; // Character rectangle in sprite font @@ -390,28 +391,26 @@ typedef struct CharInfo { int advanceX; // Character advance position X } CharInfo; -// SpriteFont type, includes texture and charSet array data -typedef struct SpriteFont { +// Font type, includes texture and charSet array data +typedef struct Font { Texture2D texture; // Font texture int baseSize; // Base size (default chars height) int charsCount; // Number of characters CharInfo *chars; // Characters info data -} SpriteFont; +} Font; -// Camera projection modes -typedef enum { - CAMERA_PERSPECTIVE = 0, - CAMERA_ORTHOGRAPHIC -} CameraType; +#define SpriteFont Font // SpriteFont type fallback, defaults to Font // Camera type, defines a camera position/orientation in 3d space -typedef struct Camera { +typedef struct Camera3D { Vector3 position; // Camera position Vector3 target; // Camera target it looks-at Vector3 up; // Camera up vector (rotation over its axis) float fovy; // Camera field-of-view apperture in Y (degrees) in perspective, used as near plane width in orthographic - CameraType type; // Camera type, controlling projection type, either CAMERA_PERSPECTIVE or CAMERA_ORTHOGRAPHIC. -} Camera; + int type; // Camera type, defines projection type: CAMERA_PERSPECTIVE or CAMERA_ORTHOGRAPHIC +} Camera3D; + +#define Camera Camera3D // Camera type fallback, defaults to Camera3D // Camera2D type, defines a 2d camera typedef struct Camera2D { @@ -675,6 +674,12 @@ typedef enum { CAMERA_THIRD_PERSON } CameraMode; +// Camera projection modes +typedef enum { + CAMERA_PERSPECTIVE = 0, + CAMERA_ORTHOGRAPHIC +} CameraType; + // Head Mounted Display devices typedef enum { HMD_DEFAULT_DEVICE = 0, @@ -725,15 +730,15 @@ RLAPI void DisableCursor(void); // Disables cu RLAPI void ClearBackground(Color color); // Set background color (framebuffer clear color) RLAPI void BeginDrawing(void); // Setup canvas (framebuffer) to start drawing RLAPI void EndDrawing(void); // End canvas drawing and swap buffers (double buffering) -RLAPI void Begin2dMode(Camera2D camera); // Initialize 2D mode with custom camera (2D) -RLAPI void End2dMode(void); // Ends 2D mode with custom camera -RLAPI void Begin3dMode(Camera camera); // Initializes 3D mode with custom camera (3D) -RLAPI void End3dMode(void); // Ends 3D mode and returns to default 2D orthographic mode +RLAPI void BeginMode2D(Camera2D camera); // Initialize 2D mode with custom camera (2D) +RLAPI void EndMode2D(void); // Ends 2D mode with custom camera +RLAPI void BeginMode3D(Camera3D camera); // Initializes 3D mode with custom camera (3D) +RLAPI void EndMode3D(void); // Ends 3D mode and returns to default 2D orthographic mode RLAPI void BeginTextureMode(RenderTexture2D target); // Initializes render texture for drawing RLAPI void EndTextureMode(void); // Ends drawing to render texture // Screen-space-related functions -RLAPI Ray GetMouseRay(Vector2 mousePosition, Camera camera); // Returns a ray trace from mouse position +RLAPI Ray GetMouseRay(Vector2 mousePosition, Camera camera); // Returns a ray trace from mouse position RLAPI Vector2 GetWorldToScreen(Vector3 position, Camera camera); // Returns the screen space position for a 3d world space position RLAPI Matrix GetCameraMatrix(Camera camera); // Returns camera transform matrix (view matrix) @@ -744,8 +749,8 @@ RLAPI float GetFrameTime(void); // Returns tim RLAPI double GetTime(void); // Returns elapsed time in seconds since InitWindow() // Color-related functions -RLAPI float *ColorToFloat(Color color); // Returns normalized float array for a Color RLAPI int ColorToInt(Color color); // Returns hexadecimal value for a Color +RLAPI Vector4 ColorNormalize(Color color); // Returns color normalized as float [0..1] RLAPI Vector3 ColorToHSV(Color color); // Returns HSV values for a Color RLAPI Color GetColor(int hexValue); // Returns a Color struct from hexadecimal value RLAPI Color Fade(Color color, float alpha); // Color fade-in or fade-out, alpha goes from 0.0f to 1.0f @@ -836,9 +841,7 @@ RLAPI void UpdateCamera(Camera *camera); // Update came RLAPI void SetCameraPanControl(int panKey); // Set camera pan key to combine with mouse movement (free camera) RLAPI void SetCameraAltControl(int altKey); // Set camera alt key to combine with mouse movement (free camera) RLAPI void SetCameraSmoothZoomControl(int szKey); // Set camera smooth zoom key to combine with mouse (free camera) -RLAPI void SetCameraMoveControls(int frontKey, int backKey, - int rightKey, int leftKey, - int upKey, int downKey); // Set camera move controls (1st person and 3rd person cameras) +RLAPI void SetCameraMoveControls(int frontKey, int backKey, int rightKey, int leftKey, int upKey, int downKey); // Set camera move controls (1st person and 3rd person cameras) //------------------------------------------------------------------------------------ // Basic Shapes Drawing Functions (Module: shapes) @@ -888,6 +891,7 @@ RLAPI Image LoadImage(const char *fileName); RLAPI Image LoadImageEx(Color *pixels, int width, int height); // Load image from Color array data (RGBA - 32bit) RLAPI Image LoadImagePro(void *data, int width, int height, int format); // Load image from raw data with parameters RLAPI Image LoadImageRaw(const char *fileName, int width, int height, int format, int headerSize); // Load image from RAW file data +RLAPI void ExportImage(const char *fileName, Image image); // Export image as a PNG file RLAPI Texture2D LoadTexture(const char *fileName); // Load texture from file into GPU memory (VRAM) RLAPI Texture2D LoadTextureFromImage(Image image); // Load texture from image data RLAPI RenderTexture2D LoadRenderTexture(int width, int height); // Load texture for rendering (framebuffer) @@ -898,7 +902,6 @@ RLAPI Color *GetImageData(Image image); RLAPI int GetPixelDataSize(int width, int height, int format); // Get pixel data size in bytes (image or texture) RLAPI Image GetTextureData(Texture2D texture); // Get pixel data from GPU texture and return an Image RLAPI void UpdateTexture(Texture2D texture, const void *pixels); // Update GPU texture with new data -RLAPI void SaveImageAs(const char *fileName, Image image); // Save image to a PNG file // Image manipulation functions RLAPI Image ImageCopy(Image image); // Create an image duplicate (useful for transformations) @@ -914,11 +917,11 @@ RLAPI void ImageResizeNN(Image *image,int newWidth,int newHeight); RLAPI void ImageMipmaps(Image *image); // Generate all mipmap levels for a provided image RLAPI void ImageDither(Image *image, int rBpp, int gBpp, int bBpp, int aBpp); // Dither image data to 16bpp or lower (Floyd-Steinberg dithering) RLAPI Image ImageText(const char *text, int fontSize, Color color); // Create an image from text (default font) -RLAPI Image ImageTextEx(SpriteFont font, const char *text, float fontSize, int spacing, Color tint); // Create an image from text (custom sprite font) +RLAPI Image ImageTextEx(Font font, const char *text, float fontSize, float spacing, Color tint); // Create an image from text (custom sprite font) RLAPI void ImageDraw(Image *dst, Image src, Rectangle srcRec, Rectangle dstRec); // Draw a source image within a destination image +RLAPI void ImageDrawRectangle(Image *dst, Vector2 position, Rectangle rec, Color color); // Draw rectangle within an image RLAPI void ImageDrawText(Image *dst, Vector2 position, const char *text, int fontSize, Color color); // Draw text (default font) within an image (destination) -RLAPI void ImageDrawTextEx(Image *dst, Vector2 position, SpriteFont font, const char *text, - float fontSize, int spacing, Color color); // Draw text (custom sprite font) within an image (destination) +RLAPI void ImageDrawTextEx(Image *dst, Vector2 position, Font font, const char *text, float fontSize, float spacing, Color color); // Draw text (custom sprite font) within an image (destination) RLAPI void ImageFlipVertical(Image *image); // Flip image vertically RLAPI void ImageFlipHorizontal(Image *image); // Flip image horizontally RLAPI void ImageColorTint(Image *image, Color color); // Modify image color: tint @@ -947,31 +950,30 @@ RLAPI void DrawTexture(Texture2D texture, int posX, int posY, Color tint); RLAPI void DrawTextureV(Texture2D texture, Vector2 position, Color tint); // Draw a Texture2D with position defined as Vector2 RLAPI void DrawTextureEx(Texture2D texture, Vector2 position, float rotation, float scale, Color tint); // Draw a Texture2D with extended parameters RLAPI void DrawTextureRec(Texture2D texture, Rectangle sourceRec, Vector2 position, Color tint); // Draw a part of a texture defined by a rectangle -RLAPI void DrawTexturePro(Texture2D texture, Rectangle sourceRec, Rectangle destRec, Vector2 origin, // Draw a part of a texture defined by a rectangle with 'pro' parameters - float rotation, Color tint); +RLAPI void DrawTexturePro(Texture2D texture, Rectangle sourceRec, Rectangle destRec, Vector2 origin, float rotation, Color tint); // Draw a part of a texture defined by a rectangle with 'pro' parameters + //------------------------------------------------------------------------------------ // Font Loading and Text Drawing Functions (Module: text) //------------------------------------------------------------------------------------ -// SpriteFont loading/unloading functions -RLAPI SpriteFont GetDefaultFont(void); // Get the default SpriteFont -RLAPI SpriteFont LoadSpriteFont(const char *fileName); // Load SpriteFont from file into GPU memory (VRAM) -RLAPI SpriteFont LoadSpriteFontEx(const char *fileName, int fontSize, int charsCount, int *fontChars); // Load SpriteFont from file with extended parameters -RLAPI void UnloadSpriteFont(SpriteFont font); // Unload SpriteFont from GPU memory (VRAM) +// Font loading/unloading functions +RLAPI Font GetDefaultFont(void); // Get the default Font +RLAPI Font LoadFont(const char *fileName); // Load Font from file into GPU memory (VRAM) +RLAPI Font LoadFontEx(const char *fileName, int fontSize, int charsCount, int *fontChars); // Load Font from file with extended parameters +RLAPI void UnloadFont(Font font); // Unload Font from GPU memory (VRAM) // Text drawing functions RLAPI void DrawFPS(int posX, int posY); // Shows current FPS RLAPI void DrawText(const char *text, int posX, int posY, int fontSize, Color color); // Draw text (using default font) -RLAPI void DrawTextEx(SpriteFont font, const char* text, Vector2 position, // Draw text using SpriteFont and additional parameters - float fontSize, int spacing, Color tint); +RLAPI void DrawTextEx(Font font, const char* text, Vector2 position, float fontSize, float spacing, Color tint); // Draw text using Font and additional parameters // Text misc. functions RLAPI int MeasureText(const char *text, int fontSize); // Measure string width for default font -RLAPI Vector2 MeasureTextEx(SpriteFont font, const char *text, float fontSize, int spacing); // Measure string size for SpriteFont +RLAPI Vector2 MeasureTextEx(Font font, const char *text, float fontSize, float spacing); // Measure string size for Font RLAPI const char *FormatText(const char *text, ...); // Formatting of text with variables to 'embed' RLAPI const char *SubText(const char *text, int position, int length); // Get a piece of a text string -RLAPI int GetGlyphIndex(SpriteFont font, int character); // Returns index position for a unicode character on sprite font +RLAPI int GetGlyphIndex(Font font, int character); // Returns index position for a unicode character on sprite font //------------------------------------------------------------------------------------ // Basic 3d Shapes Drawing Functions (Module: models) @@ -1007,6 +1009,7 @@ RLAPI void UnloadModel(Model model); // Mesh loading/unloading functions RLAPI Mesh LoadMesh(const char *fileName); // Load mesh from file RLAPI void UnloadMesh(Mesh *mesh); // Unload mesh from memory (RAM and/or VRAM) +RLAPI void ExportMesh(const char *fileName, Mesh mesh); // Export mesh as an OBJ file // Mesh manipulation functions RLAPI BoundingBox MeshBoundingBox(Mesh mesh); // Compute mesh bounding box limits @@ -1031,25 +1034,21 @@ RLAPI void UnloadMaterial(Material material); // Model drawing functions RLAPI void DrawModel(Model model, Vector3 position, float scale, Color tint); // Draw a model (with texture if set) -RLAPI void DrawModelEx(Model model, Vector3 position, Vector3 rotationAxis, - float rotationAngle, Vector3 scale, Color tint); // Draw a model with extended parameters +RLAPI void DrawModelEx(Model model, Vector3 position, Vector3 rotationAxis, float rotationAngle, Vector3 scale, Color tint); // Draw a model with extended parameters RLAPI void DrawModelWires(Model model, Vector3 position, float scale, Color tint); // Draw a model wires (with texture if set) -RLAPI void DrawModelWiresEx(Model model, Vector3 position, Vector3 rotationAxis, - float rotationAngle, Vector3 scale, Color tint); // Draw a model wires (with texture if set) with extended parameters +RLAPI void DrawModelWiresEx(Model model, Vector3 position, Vector3 rotationAxis, float rotationAngle, Vector3 scale, Color tint); // Draw a model wires (with texture if set) with extended parameters RLAPI void DrawBoundingBox(BoundingBox box, Color color); // Draw bounding box (wires) RLAPI void DrawBillboard(Camera camera, Texture2D texture, Vector3 center, float size, Color tint); // Draw a billboard texture -RLAPI void DrawBillboardRec(Camera camera, Texture2D texture, Rectangle sourceRec, - Vector3 center, float size, Color tint); // Draw a billboard texture defined by sourceRec +RLAPI void DrawBillboardRec(Camera camera, Texture2D texture, Rectangle sourceRec, Vector3 center, float size, Color tint); // Draw a billboard texture defined by sourceRec // Collision detection functions RLAPI bool CheckCollisionSpheres(Vector3 centerA, float radiusA, Vector3 centerB, float radiusB); // Detect collision between two spheres RLAPI bool CheckCollisionBoxes(BoundingBox box1, BoundingBox box2); // Detect collision between two bounding boxes RLAPI bool CheckCollisionBoxSphere(BoundingBox box, Vector3 centerSphere, float radiusSphere); // Detect collision between box and sphere RLAPI bool CheckCollisionRaySphere(Ray ray, Vector3 spherePosition, float sphereRadius); // Detect collision between ray and sphere -RLAPI bool CheckCollisionRaySphereEx(Ray ray, Vector3 spherePosition, float sphereRadius, - Vector3 *collisionPoint); // Detect collision between ray and sphere, returns collision point +RLAPI bool CheckCollisionRaySphereEx(Ray ray, Vector3 spherePosition, float sphereRadius, Vector3 *collisionPoint); // Detect collision between ray and sphere, returns collision point RLAPI bool CheckCollisionRayBox(Ray ray, BoundingBox box); // Detect collision between ray and box -RLAPI RayHitInfo GetCollisionRayMesh(Ray ray, Mesh *mesh); // Get collision info between ray and mesh +RLAPI RayHitInfo GetCollisionRayModel(Ray ray, Model *model); // Get collision info between ray and model RLAPI RayHitInfo GetCollisionRayTriangle(Ray ray, Vector3 p1, Vector3 p2, Vector3 p3); // Get collision info between ray and triangle RLAPI RayHitInfo GetCollisionRayGround(Ray ray, float groundHeight); // Get collision info between ray and ground plane (Y-normal plane) @@ -1148,8 +1147,7 @@ RLAPI float GetMusicTimeLength(Music music); // Get mus RLAPI float GetMusicTimePlayed(Music music); // Get current music time played (in seconds) // AudioStream management functions -RLAPI AudioStream InitAudioStream(unsigned int sampleRate, unsigned int sampleSize, - unsigned int channels); // Init audio stream (to stream raw audio pcm data) +RLAPI AudioStream InitAudioStream(unsigned int sampleRate, unsigned int sampleSize, unsigned int channels); // Init audio stream (to stream raw audio pcm data) RLAPI void UpdateAudioStream(AudioStream stream, const void *data, int samplesCount); // Update audio stream buffers with data RLAPI void CloseAudioStream(AudioStream stream); // Close audio stream and free memory RLAPI bool IsAudioBufferProcessed(AudioStream stream); // Check if any audio stream buffers requires refill diff --git a/release/libs/win32/mingw32/libraylib.a b/release/libs/win32/mingw32/libraylib.a index 361aa73c2bcd5bf4e97a01a5e53e061a46c03991..b188e3298a57733d17614b3ad06a1e11e2179a83 100644 GIT binary patch literal 1218614 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

LAr$PLoZwp97_$XJ6|%KR}K2W>WX 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%0A&Tn&aW5fCF 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∓(1=)&kS{y2KWXqRJ_)H@mndx1zyYS*I>@i)(%A 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 z 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 z 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

aONLq1mJ1Pc4w3$o>+FCvBIdEFh@ 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

4%h4ZNhGiK38C#9h$^60r>| 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�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­ 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 + +#if defined(_MSC_VER) && _MSC_VER < 1600 +typedef signed char drmp3_int8; +typedef unsigned char drmp3_uint8; +typedef signed short drmp3_int16; +typedef unsigned short drmp3_uint16; +typedef signed int drmp3_int32; +typedef unsigned int drmp3_uint32; +typedef signed __int64 drmp3_int64; +typedef unsigned __int64 drmp3_uint64; +#else +#include +typedef int8_t drmp3_int8; +typedef uint8_t drmp3_uint8; +typedef int16_t drmp3_int16; +typedef uint16_t drmp3_uint16; +typedef int32_t drmp3_int32; +typedef uint32_t drmp3_uint32; +typedef int64_t drmp3_int64; +typedef uint64_t drmp3_uint64; +#endif +typedef drmp3_uint8 drmp3_bool8; +typedef drmp3_uint32 drmp3_bool32; +#define DRMP3_TRUE 1 +#define DRMP3_FALSE 0 + +#define DRMP3_MAX_SAMPLES_PER_FRAME (1152*2) + + +// Low Level Push API +// ================== +typedef struct +{ + int frame_bytes; + int channels; + int hz; + int layer; + int bitrate_kbps; +} drmp3dec_frame_info; + +typedef struct +{ + float mdct_overlap[2][9*32]; + float qmf_state[15*2*32]; + int reserv; + int free_format_bytes; + unsigned char header[4]; + unsigned char reserv_buf[511]; +} drmp3dec; + +// Initializes a low level decoder. +void drmp3dec_init(drmp3dec *dec); + +// Reads a frame from a low level decoder. +int drmp3dec_decode_frame(drmp3dec *dec, const unsigned char *mp3, int mp3_bytes, short *pcm, drmp3dec_frame_info *info); + + +// Main API (Pull API) +// =================== + +typedef struct drmp3_src drmp3_src; +typedef drmp3_uint64 (* drmp3_src_read_proc)(drmp3_src* pSRC, drmp3_uint64 frameCount, void* pFramesOut, void* pUserData); // Returns the number of frames that were read. + +typedef enum +{ + drmp3_src_algorithm_none, + drmp3_src_algorithm_linear +} drmp3_src_algorithm; + +#define DRMP3_SRC_CACHE_SIZE_IN_FRAMES 512 +typedef struct +{ + drmp3_src* pSRC; + float pCachedFrames[2 * DRMP3_SRC_CACHE_SIZE_IN_FRAMES]; + drmp3_uint32 cachedFrameCount; + drmp3_uint32 iNextFrame; +} drmp3_src_cache; + +typedef struct +{ + drmp3_uint32 sampleRateIn; + drmp3_uint32 sampleRateOut; + drmp3_uint32 channels; + drmp3_src_algorithm algorithm; + drmp3_uint32 cacheSizeInFrames; // The number of frames to read from the client at a time. +} drmp3_src_config; + +struct drmp3_src +{ + drmp3_src_config config; + drmp3_src_read_proc onRead; + void* pUserData; + float bin[256]; + drmp3_src_cache cache; // <-- For simplifying and optimizing client -> memory reading. + union + { + struct + { + float alpha; + drmp3_bool32 isPrevFramesLoaded : 1; + drmp3_bool32 isNextFramesLoaded : 1; + } linear; + } algo; +}; + +typedef enum +{ + drmp3_seek_origin_start, + drmp3_seek_origin_current +} drmp3_seek_origin; + +// Callback for when data is read. Return value is the number of bytes actually read. +// +// pUserData [in] The user data that was passed to drmp3_init(), drmp3_open() and family. +// pBufferOut [out] The output buffer. +// bytesToRead [in] The number of bytes to read. +// +// Returns the number of bytes actually read. +// +// A return value of less than bytesToRead indicates the end of the stream. Do _not_ return from this callback until +// either the entire bytesToRead is filled or you have reached the end of the stream. +typedef size_t (* drmp3_read_proc)(void* pUserData, void* pBufferOut, size_t bytesToRead); + +// Callback for when data needs to be seeked. +// +// pUserData [in] The user data that was passed to drmp3_init(), drmp3_open() and family. +// offset [in] The number of bytes to move, relative to the origin. Will never be negative. +// origin [in] The origin of the seek - the current position or the start of the stream. +// +// Returns whether or not the seek was successful. +// +// Whether or not it is relative to the beginning or current position is determined by the "origin" parameter which +// will be either drmp3_seek_origin_start or drmp3_seek_origin_current. +typedef drmp3_bool32 (* drmp3_seek_proc)(void* pUserData, int offset, drmp3_seek_origin origin); + +typedef struct +{ + drmp3_uint32 outputChannels; + drmp3_uint32 outputSampleRate; +} drmp3_config; + +typedef struct +{ + drmp3dec decoder; + drmp3dec_frame_info frameInfo; + drmp3_uint32 channels; + drmp3_uint32 sampleRate; + drmp3_read_proc onRead; + drmp3_seek_proc onSeek; + void* pUserData; + drmp3_uint32 frameChannels; // The number of channels in the currently loaded MP3 frame. Internal use only. + drmp3_uint32 frameSampleRate; // The sample rate of the currently loaded MP3 frame. Internal use only. + drmp3_uint32 framesConsumed; + drmp3_uint32 framesRemaining; + drmp3_int16 frames[DRMP3_MAX_SAMPLES_PER_FRAME]; + drmp3_src src; + size_t dataSize; + size_t dataCapacity; + drmp3_uint8* pData; + drmp3_bool32 atEnd : 1; + struct + { + const drmp3_uint8* pData; + size_t dataSize; + size_t currentReadPos; + } memory; // Only used for decoders that were opened against a block of memory. +} drmp3; + +// Initializes an MP3 decoder. +// +// onRead [in] The function to call when data needs to be read from the client. +// onSeek [in] The function to call when the read position of the client data needs to move. +// pUserData [in, optional] A pointer to application defined data that will be passed to onRead and onSeek. +// +// Returns true if successful; false otherwise. +// +// Close the loader with drmp3_uninit(). +// +// See also: drmp3_init_file(), drmp3_init_memory(), drmp3_uninit() +drmp3_bool32 drmp3_init(drmp3* pMP3, drmp3_read_proc onRead, drmp3_seek_proc onSeek, void* pUserData, const drmp3_config* pConfig); + +// Initializes an MP3 decoder from a block of memory. +// +// This does not create a copy of the data. It is up to the application to ensure the buffer remains valid for +// the lifetime of the drmp3 object. +// +// The buffer should contain the contents of the entire MP3 file. +drmp3_bool32 drmp3_init_memory(drmp3* pMP3, const void* pData, size_t dataSize, const drmp3_config* pConfig); + +#ifndef DR_MP3_NO_STDIO +// Initializes an MP3 decoder from a file. +// +// This holds the internal FILE object until drmp3_uninit() is called. Keep this in mind if you're caching drmp3 +// objects because the operating system may restrict the number of file handles an application can have open at +// any given time. +drmp3_bool32 drmp3_init_file(drmp3* pMP3, const char* filePath, const drmp3_config* pConfig); +#endif + +// Uninitializes an MP3 decoder. +void drmp3_uninit(drmp3* pMP3); + +// Reads PCM frames as interleaved 32-bit IEEE floating point PCM. +// +// Note that framesToRead specifies the number of PCM frames to read, _not_ the number of MP3 frames. +drmp3_uint64 drmp3_read_f32(drmp3* pMP3, drmp3_uint64 framesToRead, float* pBufferOut); + +// Seeks to a specific frame. +// +// Note that this is _not_ an MP3 frame, but rather a PCM frame. +drmp3_bool32 drmp3_seek_to_frame(drmp3* pMP3, drmp3_uint64 frameIndex); + + +// Opens an decodes an entire MP3 stream as a single operation. +// +// pConfig is both an input and output. On input it contains what you want. On output it contains what you got. +// +// Free the returned pointer with drmp3_free(). +float* drmp3_open_and_decode_f32(drmp3_read_proc onRead, drmp3_seek_proc onSeek, void* pUserData, drmp3_config* pConfig, drmp3_uint64* pTotalFrameCount); +float* drmp3_open_and_decode_memory_f32(const void* pData, size_t dataSize, drmp3_config* pConfig, drmp3_uint64* pTotalFrameCount); +#ifndef DR_MP3_NO_STDIO +float* drmp3_open_and_decode_file_f32(const char* filePath, drmp3_config* pConfig, drmp3_uint64* pTotalFrameCount); +#endif + +// Frees any memory that was allocated by a public drmp3 API. +void drmp3_free(void* p); + +#ifdef __cplusplus +} +#endif +#endif // dr_mp3_h + + +///////////////////////////////////////////////////// +// +// IMPLEMENTATION +// +///////////////////////////////////////////////////// +#ifdef DR_MP3_IMPLEMENTATION +#include +#include +#include +#include // For INT_MAX + +// Disable SIMD when compiling with TCC for now. +#if defined(__TINYC__) +#define DR_MP3_NO_SIMD +#endif + +#define DRMP3_MAX_FREE_FORMAT_FRAME_SIZE 2304 /* more than ISO spec's */ +#define DRMP3_MAX_FRAME_SYNC_MATCHES 10 + +#define DRMP3_MAX_L3_FRAME_PAYLOAD_BYTES DRMP3_MAX_FREE_FORMAT_FRAME_SIZE /* MUST be >= 320000/8/32000*1152 = 1440 */ + +#define DRMP3_MAX_BITRESERVOIR_BYTES 511 +#define DRMP3_SHORT_BLOCK_TYPE 2 +#define DRMP3_STOP_BLOCK_TYPE 3 +#define DRMP3_MODE_MONO 3 +#define DRMP3_MODE_JOINT_STEREO 1 +#define DRMP3_HDR_SIZE 4 +#define DRMP3_HDR_IS_MONO(h) (((h[3]) & 0xC0) == 0xC0) +#define DRMP3_HDR_IS_MS_STEREO(h) (((h[3]) & 0xE0) == 0x60) +#define DRMP3_HDR_IS_FREE_FORMAT(h) (((h[2]) & 0xF0) == 0) +#define DRMP3_HDR_IS_CRC(h) (!((h[1]) & 1)) +#define DRMP3_HDR_TEST_PADDING(h) ((h[2]) & 0x2) +#define DRMP3_HDR_TEST_MPEG1(h) ((h[1]) & 0x8) +#define DRMP3_HDR_TEST_NOT_MPEG25(h) ((h[1]) & 0x10) +#define DRMP3_HDR_TEST_I_STEREO(h) ((h[3]) & 0x10) +#define DRMP3_HDR_TEST_MS_STEREO(h) ((h[3]) & 0x20) +#define DRMP3_HDR_GET_STEREO_MODE(h) (((h[3]) >> 6) & 3) +#define DRMP3_HDR_GET_STEREO_MODE_EXT(h) (((h[3]) >> 4) & 3) +#define DRMP3_HDR_GET_LAYER(h) (((h[1]) >> 1) & 3) +#define DRMP3_HDR_GET_BITRATE(h) ((h[2]) >> 4) +#define DRMP3_HDR_GET_SAMPLE_RATE(h) (((h[2]) >> 2) & 3) +#define DRMP3_HDR_GET_MY_SAMPLE_RATE(h) (DRMP3_HDR_GET_SAMPLE_RATE(h) + (((h[1] >> 3) & 1) + ((h[1] >> 4) & 1))*3) +#define DRMP3_HDR_IS_FRAME_576(h) ((h[1] & 14) == 2) +#define DRMP3_HDR_IS_LAYER_1(h) ((h[1] & 6) == 6) + +#define DRMP3_BITS_DEQUANTIZER_OUT -1 +#define DRMP3_MAX_SCF (255 + DRMP3_BITS_DEQUANTIZER_OUT*4 - 210) +#define DRMP3_MAX_SCFI ((DRMP3_MAX_SCF + 3) & ~3) + +#define DRMP3_MIN(a, b) ((a) > (b) ? (b) : (a)) +#define DRMP3_MAX(a, b) ((a) < (b) ? (b) : (a)) + +#if !defined(DR_MP3_NO_SIMD) + +#if !defined(DR_MP3_ONLY_SIMD) && (defined(_M_X64) || defined(_M_ARM64) || defined(__x86_64__) || defined(__aarch64__)) +/* x64 always have SSE2, arm64 always have neon, no need for generic code */ +#define DR_MP3_ONLY_SIMD +#endif + +#if (defined(_MSC_VER) && (defined(_M_IX86) || defined(_M_X64))) || ((defined(__i386__) || defined(__x86_64__)) && defined(__SSE2__)) +#if defined(_MSC_VER) +#include +#endif +#include +#define DRMP3_HAVE_SSE 1 +#define DRMP3_HAVE_SIMD 1 +#define DRMP3_VSTORE _mm_storeu_ps +#define DRMP3_VLD _mm_loadu_ps +#define DRMP3_VSET _mm_set1_ps +#define DRMP3_VADD _mm_add_ps +#define DRMP3_VSUB _mm_sub_ps +#define DRMP3_VMUL _mm_mul_ps +#define DRMP3_VMAC(a, x, y) _mm_add_ps(a, _mm_mul_ps(x, y)) +#define DRMP3_VMSB(a, x, y) _mm_sub_ps(a, _mm_mul_ps(x, y)) +#define DRMP3_VMUL_S(x, s) _mm_mul_ps(x, _mm_set1_ps(s)) +#define DRMP3_VREV(x) _mm_shuffle_ps(x, x, _MM_SHUFFLE(0, 1, 2, 3)) +typedef __m128 drmp3_f4; +#if defined(_MSC_VER) || defined(DR_MP3_ONLY_SIMD) +#define drmp3_cpuid __cpuid +#else +static __inline__ __attribute__((always_inline)) void drmp3_cpuid(int CPUInfo[], const int InfoType) +{ +#if defined(__PIC__) + __asm__ __volatile__( +#if defined(__x86_64__) + "push %%rbx\n" + "cpuid\n" + "xchgl %%ebx, %1\n" + "pop %%rbx\n" +#else + "xchgl %%ebx, %1\n" + "cpuid\n" + "xchgl %%ebx, %1\n" +#endif + : "=a" (CPUInfo[0]), "=r" (CPUInfo[1]), "=c" (CPUInfo[2]), "=d" (CPUInfo[3]) + : "a" (InfoType)); +#else + __asm__ __volatile__( + "cpuid" + : "=a" (CPUInfo[0]), "=b" (CPUInfo[1]), "=c" (CPUInfo[2]), "=d" (CPUInfo[3]) + : "a" (InfoType)); +#endif +} +#endif +static int drmp3_have_simd() +{ +#ifdef DR_MP3_ONLY_SIMD + return 1; +#else + static int g_have_simd; + int CPUInfo[4]; +#ifdef MINIMP3_TEST + static int g_counter; + if (g_counter++ > 100) + goto test_nosimd; +#endif + if (g_have_simd) + return g_have_simd - 1; + drmp3_cpuid(CPUInfo, 0); + if (CPUInfo[0] > 0) + { + drmp3_cpuid(CPUInfo, 1); + g_have_simd = (CPUInfo[3] & (1 << 26)) + 1; /* SSE2 */ + return g_have_simd - 1; + } +#ifdef MINIMP3_TEST +test_nosimd: +#endif + g_have_simd = 1; + return 0; +#endif +} +#elif defined(__ARM_NEON) || defined(__aarch64__) +#include +#define DRMP3_HAVE_SIMD 1 +#define DRMP3_VSTORE vst1q_f32 +#define DRMP3_VLD vld1q_f32 +#define DRMP3_VSET vmovq_n_f32 +#define DRMP3_VADD vaddq_f32 +#define DRMP3_VSUB vsubq_f32 +#define DRMP3_VMUL vmulq_f32 +#define DRMP3_VMAC(a, x, y) vmlaq_f32(a, x, y) +#define DRMP3_VMSB(a, x, y) vmlsq_f32(a, x, y) +#define DRMP3_VMUL_S(x, s) vmulq_f32(x, vmovq_n_f32(s)) +#define DRMP3_VREV(x) vcombine_f32(vget_high_f32(vrev64q_f32(x)), vget_low_f32(vrev64q_f32(x))) +typedef float32x4_t drmp3_f4; +static int drmp3_have_simd() +{ /* TODO: detect neon for !DR_MP3_ONLY_SIMD */ + return 1; +} +#else +#define DRMP3_HAVE_SIMD 0 +#ifdef DR_MP3_ONLY_SIMD +#error DR_MP3_ONLY_SIMD used, but SSE/NEON not enabled +#endif +#endif + +#else + +#define DRMP3_HAVE_SIMD 0 + +#endif + +typedef struct +{ + const drmp3_uint8 *buf; + int pos; + int limit; +} drmp3_bs; + +typedef struct +{ + drmp3_uint8 total_bands; + drmp3_uint8 stereo_bands; + drmp3_uint8 bitalloc[64]; + drmp3_uint8 scfcod[64]; + float scf[3*64]; +} drmp3_L12_scale_info; + +typedef struct +{ + drmp3_uint8 tab_offset; + drmp3_uint8 code_tab_width; + drmp3_uint8 band_count; +} drmp3_L12_subband_alloc; + +typedef struct +{ + const drmp3_uint8 *sfbtab; + drmp3_uint16 part_23_length; + drmp3_uint16 big_values; + drmp3_uint16 scalefac_compress; + drmp3_uint8 global_gain; + drmp3_uint8 block_type; + drmp3_uint8 mixed_block_flag; + drmp3_uint8 n_long_sfb; + drmp3_uint8 n_short_sfb; + drmp3_uint8 table_select[3]; + drmp3_uint8 region_count[3]; + drmp3_uint8 subblock_gain[3]; + drmp3_uint8 preflag; + drmp3_uint8 scalefac_scale; + drmp3_uint8 count1_table; + drmp3_uint8 scfsi; +} drmp3_L3_gr_info; + +typedef struct +{ + drmp3_bs bs; + drmp3_uint8 maindata[DRMP3_MAX_BITRESERVOIR_BYTES + DRMP3_MAX_L3_FRAME_PAYLOAD_BYTES]; + drmp3_L3_gr_info gr_info[4]; + float grbuf[2][576]; + float scf[40]; + drmp3_uint8 ist_pos[2][39]; + float syn[18 + 15][2*32]; +} drmp3dec_scratch; + +static void drmp3_bs_init(drmp3_bs *bs, const drmp3_uint8 *data, int bytes) +{ + bs->buf = data; + bs->pos = 0; + bs->limit = bytes*8; +} + +static drmp3_uint32 drmp3_bs_get_bits(drmp3_bs *bs, int n) +{ + drmp3_uint32 next, cache = 0, s = bs->pos & 7; + int shl = n + s; + const drmp3_uint8 *p = bs->buf + (bs->pos >> 3); + if ((bs->pos += n) > bs->limit) + return 0; + next = *p++ & (255 >> s); + while ((shl -= 8) > 0) + { + cache |= next << shl; + next = *p++; + } + return cache | (next >> -shl); +} + +static int drmp3_hdr_valid(const drmp3_uint8 *h) +{ + return h[0] == 0xff && + ((h[1] & 0xF0) == 0xf0 || (h[1] & 0xFE) == 0xe2) && + (DRMP3_HDR_GET_LAYER(h) != 0) && + (DRMP3_HDR_GET_BITRATE(h) != 15) && + (DRMP3_HDR_GET_SAMPLE_RATE(h) != 3); +} + +static int drmp3_hdr_compare(const drmp3_uint8 *h1, const drmp3_uint8 *h2) +{ + return drmp3_hdr_valid(h2) && + ((h1[1] ^ h2[1]) & 0xFE) == 0 && + ((h1[2] ^ h2[2]) & 0x0C) == 0 && + !(DRMP3_HDR_IS_FREE_FORMAT(h1) ^ DRMP3_HDR_IS_FREE_FORMAT(h2)); +} + +static unsigned drmp3_hdr_bitrate_kbps(const drmp3_uint8 *h) +{ + static const drmp3_uint8 halfrate[2][3][15] = { + { { 0,4,8,12,16,20,24,28,32,40,48,56,64,72,80 }, { 0,4,8,12,16,20,24,28,32,40,48,56,64,72,80 }, { 0,16,24,28,32,40,48,56,64,72,80,88,96,112,128 } }, + { { 0,16,20,24,28,32,40,48,56,64,80,96,112,128,160 }, { 0,16,24,28,32,40,48,56,64,80,96,112,128,160,192 }, { 0,16,32,48,64,80,96,112,128,144,160,176,192,208,224 } }, + }; + return 2*halfrate[!!DRMP3_HDR_TEST_MPEG1(h)][DRMP3_HDR_GET_LAYER(h) - 1][DRMP3_HDR_GET_BITRATE(h)]; +} + +static unsigned drmp3_hdr_sample_rate_hz(const drmp3_uint8 *h) +{ + static const unsigned g_hz[3] = { 44100, 48000, 32000 }; + return g_hz[DRMP3_HDR_GET_SAMPLE_RATE(h)] >> (int)!DRMP3_HDR_TEST_MPEG1(h) >> (int)!DRMP3_HDR_TEST_NOT_MPEG25(h); +} + +static unsigned drmp3_hdr_frame_samples(const drmp3_uint8 *h) +{ + return DRMP3_HDR_IS_LAYER_1(h) ? 384 : (1152 >> (int)DRMP3_HDR_IS_FRAME_576(h)); +} + +static int drmp3_hdr_frame_bytes(const drmp3_uint8 *h, int free_format_size) +{ + int frame_bytes = drmp3_hdr_frame_samples(h)*drmp3_hdr_bitrate_kbps(h)*125/drmp3_hdr_sample_rate_hz(h); + if (DRMP3_HDR_IS_LAYER_1(h)) + { + frame_bytes &= ~3; /* slot align */ + } + return frame_bytes ? frame_bytes : free_format_size; +} + +static int drmp3_hdr_padding(const drmp3_uint8 *h) +{ + return DRMP3_HDR_TEST_PADDING(h) ? (DRMP3_HDR_IS_LAYER_1(h) ? 4 : 1) : 0; +} + +#ifndef DR_MP3_ONLY_MP3 +static const drmp3_L12_subband_alloc *drmp3_L12_subband_alloc_table(const drmp3_uint8 *hdr, drmp3_L12_scale_info *sci) +{ + const drmp3_L12_subband_alloc *alloc; + int mode = DRMP3_HDR_GET_STEREO_MODE(hdr); + int nbands, stereo_bands = (mode == DRMP3_MODE_MONO) ? 0 : (mode == DRMP3_MODE_JOINT_STEREO) ? (DRMP3_HDR_GET_STEREO_MODE_EXT(hdr) << 2) + 4 : 32; + + if (DRMP3_HDR_IS_LAYER_1(hdr)) + { + static const drmp3_L12_subband_alloc g_alloc_L1[] = { { 76, 4, 32 } }; + alloc = g_alloc_L1; + nbands = 32; + } else if (!DRMP3_HDR_TEST_MPEG1(hdr)) + { + static const drmp3_L12_subband_alloc g_alloc_L2M2[] = { { 60, 4, 4 }, { 44, 3, 7 }, { 44, 2, 19 } }; + alloc = g_alloc_L2M2; + nbands = 30; + } else + { + static const drmp3_L12_subband_alloc g_alloc_L2M1[] = { { 0, 4, 3 }, { 16, 4, 8 }, { 32, 3, 12 }, { 40, 2, 7 } }; + int sample_rate_idx = DRMP3_HDR_GET_SAMPLE_RATE(hdr); + unsigned kbps = drmp3_hdr_bitrate_kbps(hdr) >> (int)(mode != DRMP3_MODE_MONO); + if (!kbps) /* free-format */ + { + kbps = 192; + } + + alloc = g_alloc_L2M1; + nbands = 27; + if (kbps < 56) + { + static const drmp3_L12_subband_alloc g_alloc_L2M1_lowrate[] = { { 44, 4, 2 }, { 44, 3, 10 } }; + alloc = g_alloc_L2M1_lowrate; + nbands = sample_rate_idx == 2 ? 12 : 8; + } else if (kbps >= 96 && sample_rate_idx != 1) + { + nbands = 30; + } + } + + sci->total_bands = (drmp3_uint8)nbands; + sci->stereo_bands = (drmp3_uint8)DRMP3_MIN(stereo_bands, nbands); + + return alloc; +} + +static void drmp3_L12_read_scalefactors(drmp3_bs *bs, drmp3_uint8 *pba, drmp3_uint8 *scfcod, int bands, float *scf) +{ + static const float g_deq_L12[18*3] = { +#define DRMP3_DQ(x) 9.53674316e-07f/x, 7.56931807e-07f/x, 6.00777173e-07f/x + DRMP3_DQ(3),DRMP3_DQ(7),DRMP3_DQ(15),DRMP3_DQ(31),DRMP3_DQ(63),DRMP3_DQ(127),DRMP3_DQ(255),DRMP3_DQ(511),DRMP3_DQ(1023),DRMP3_DQ(2047),DRMP3_DQ(4095),DRMP3_DQ(8191),DRMP3_DQ(16383),DRMP3_DQ(32767),DRMP3_DQ(65535),DRMP3_DQ(3),DRMP3_DQ(5),DRMP3_DQ(9) + }; + int i, m; + for (i = 0; i < bands; i++) + { + float s = 0; + int ba = *pba++; + int mask = ba ? 4 + ((19 >> scfcod[i]) & 3) : 0; + for (m = 4; m; m >>= 1) + { + if (mask & m) + { + int b = drmp3_bs_get_bits(bs, 6); + s = g_deq_L12[ba*3 - 6 + b % 3]*(1 << 21 >> b/3); + } + *scf++ = s; + } + } +} + +static void drmp3_L12_read_scale_info(const drmp3_uint8 *hdr, drmp3_bs *bs, drmp3_L12_scale_info *sci) +{ + static const drmp3_uint8 g_bitalloc_code_tab[] = { + 0,17, 3, 4, 5,6,7, 8,9,10,11,12,13,14,15,16, + 0,17,18, 3,19,4,5, 6,7, 8, 9,10,11,12,13,16, + 0,17,18, 3,19,4,5,16, + 0,17,18,16, + 0,17,18,19, 4,5,6, 7,8, 9,10,11,12,13,14,15, + 0,17,18, 3,19,4,5, 6,7, 8, 9,10,11,12,13,14, + 0, 2, 3, 4, 5,6,7, 8,9,10,11,12,13,14,15,16 + }; + const drmp3_L12_subband_alloc *subband_alloc = drmp3_L12_subband_alloc_table(hdr, sci); + + int i, k = 0, ba_bits = 0; + const drmp3_uint8 *ba_code_tab = g_bitalloc_code_tab; + + for (i = 0; i < sci->total_bands; i++) + { + drmp3_uint8 ba; + if (i == k) + { + k += subband_alloc->band_count; + ba_bits = subband_alloc->code_tab_width; + ba_code_tab = g_bitalloc_code_tab + subband_alloc->tab_offset; + subband_alloc++; + } + ba = ba_code_tab[drmp3_bs_get_bits(bs, ba_bits)]; + sci->bitalloc[2*i] = ba; + if (i < sci->stereo_bands) + { + ba = ba_code_tab[drmp3_bs_get_bits(bs, ba_bits)]; + } + sci->bitalloc[2*i + 1] = sci->stereo_bands ? ba : 0; + } + + for (i = 0; i < 2*sci->total_bands; i++) + { + sci->scfcod[i] = (drmp3_uint8)(sci->bitalloc[i] ? DRMP3_HDR_IS_LAYER_1(hdr) ? 2 : drmp3_bs_get_bits(bs, 2) : 6); + } + + drmp3_L12_read_scalefactors(bs, sci->bitalloc, sci->scfcod, sci->total_bands*2, sci->scf); + + for (i = sci->stereo_bands; i < sci->total_bands; i++) + { + sci->bitalloc[2*i + 1] = 0; + } +} + +static int drmp3_L12_dequantize_granule(float *grbuf, drmp3_bs *bs, drmp3_L12_scale_info *sci, int group_size) +{ + int i, j, k, choff = 576; + for (j = 0; j < 4; j++) + { + float *dst = grbuf + group_size*j; + for (i = 0; i < 2*sci->total_bands; i++) + { + int ba = sci->bitalloc[i]; + if (ba != 0) + { + if (ba < 17) + { + int half = (1 << (ba - 1)) - 1; + for (k = 0; k < group_size; k++) + { + dst[k] = (float)((int)drmp3_bs_get_bits(bs, ba) - half); + } + } else + { + unsigned mod = (2 << (ba - 17)) + 1; /* 3, 5, 9 */ + unsigned code = drmp3_bs_get_bits(bs, mod + 2 - (mod >> 3)); /* 5, 7, 10 */ + for (k = 0; k < group_size; k++, code /= mod) + { + dst[k] = (float)((int)(code % mod - mod/2)); + } + } + } + dst += choff; + choff = 18 - choff; + } + } + return group_size*4; +} + +static void drmp3_L12_apply_scf_384(drmp3_L12_scale_info *sci, const float *scf, float *dst) +{ + int i, k; + memcpy(dst + 576 + sci->stereo_bands*18, dst + sci->stereo_bands*18, (sci->total_bands - sci->stereo_bands)*18*sizeof(float)); + for (i = 0; i < sci->total_bands; i++, dst += 18, scf += 6) + { + for (k = 0; k < 12; k++) + { + dst[k + 0] *= scf[0]; + dst[k + 576] *= scf[3]; + } + } +} +#endif + +static int drmp3_L3_read_side_info(drmp3_bs *bs, drmp3_L3_gr_info *gr, const drmp3_uint8 *hdr) +{ + static const drmp3_uint8 g_scf_long[9][23] = { + { 6,6,6,6,6,6,8,10,12,14,16,20,24,28,32,38,46,52,60,68,58,54,0 }, + { 6,6,6,6,6,6,8,10,12,14,16,20,24,28,32,38,46,52,60,68,58,54,0 }, + { 12,12,12,12,12,12,16,20,24,28,32,40,48,56,64,76,90,2,2,2,2,2,0 }, + { 6,6,6,6,6,6,8,10,12,14,16,20,24,28,32,38,46,52,60,68,58,54,0 }, + { 6,6,6,6,6,6,8,10,12,14,16,18,22,26,32,38,46,54,62,70,76,36,0 }, + { 6,6,6,6,6,6,8,10,12,14,16,20,24,28,32,38,46,52,60,68,58,54,0 }, + { 4,4,4,4,4,4,6,6,8,8,10,12,16,20,24,28,34,42,50,54,76,158,0 }, + { 4,4,4,4,4,4,6,6,6,8,10,12,16,18,22,28,34,40,46,54,54,192,0 }, + { 4,4,4,4,4,4,6,6,8,10,12,16,20,24,30,38,46,56,68,84,102,26,0 } + }; + static const drmp3_uint8 g_scf_short[9][40] = { + { 4,4,4,4,4,4,4,4,4,6,6,6,8,8,8,10,10,10,12,12,12,14,14,14,18,18,18,24,24,24,30,30,30,40,40,40,18,18,18,0 }, + { 4,4,4,4,4,4,4,4,4,6,6,6,8,8,8,10,10,10,12,12,12,14,14,14,18,18,18,24,24,24,30,30,30,40,40,40,18,18,18,0 }, + { 8,8,8,8,8,8,8,8,8,12,12,12,16,16,16,20,20,20,24,24,24,28,28,28,36,36,36,2,2,2,2,2,2,2,2,2,26,26,26,0 }, + { 4,4,4,4,4,4,4,4,4,6,6,6,6,6,6,8,8,8,10,10,10,14,14,14,18,18,18,26,26,26,32,32,32,42,42,42,18,18,18,0 }, + { 4,4,4,4,4,4,4,4,4,6,6,6,8,8,8,10,10,10,12,12,12,14,14,14,18,18,18,24,24,24,32,32,32,44,44,44,12,12,12,0 }, + { 4,4,4,4,4,4,4,4,4,6,6,6,8,8,8,10,10,10,12,12,12,14,14,14,18,18,18,24,24,24,30,30,30,40,40,40,18,18,18,0 }, + { 4,4,4,4,4,4,4,4,4,4,4,4,6,6,6,8,8,8,10,10,10,12,12,12,14,14,14,18,18,18,22,22,22,30,30,30,56,56,56,0 }, + { 4,4,4,4,4,4,4,4,4,4,4,4,6,6,6,6,6,6,10,10,10,12,12,12,14,14,14,16,16,16,20,20,20,26,26,26,66,66,66,0 }, + { 4,4,4,4,4,4,4,4,4,4,4,4,6,6,6,8,8,8,12,12,12,16,16,16,20,20,20,26,26,26,34,34,34,42,42,42,12,12,12,0 } + }; + static const drmp3_uint8 g_scf_mixed[9][40] = { + { 6,6,6,6,6,6,6,6,6,8,8,8,10,10,10,12,12,12,14,14,14,18,18,18,24,24,24,30,30,30,40,40,40,18,18,18,0 }, + { 6,6,6,6,6,6,6,6,6,8,8,8,10,10,10,12,12,12,14,14,14,18,18,18,24,24,24,30,30,30,40,40,40,18,18,18,0 }, + { 12,12,12,4,4,4,8,8,8,12,12,12,16,16,16,20,20,20,24,24,24,28,28,28,36,36,36,2,2,2,2,2,2,2,2,2,26,26,26,0 }, + { 6,6,6,6,6,6,6,6,6,6,6,6,8,8,8,10,10,10,14,14,14,18,18,18,26,26,26,32,32,32,42,42,42,18,18,18,0 }, + { 6,6,6,6,6,6,6,6,6,8,8,8,10,10,10,12,12,12,14,14,14,18,18,18,24,24,24,32,32,32,44,44,44,12,12,12,0 }, + { 6,6,6,6,6,6,6,6,6,8,8,8,10,10,10,12,12,12,14,14,14,18,18,18,24,24,24,30,30,30,40,40,40,18,18,18,0 }, + { 4,4,4,4,4,4,6,6,4,4,4,6,6,6,8,8,8,10,10,10,12,12,12,14,14,14,18,18,18,22,22,22,30,30,30,56,56,56,0 }, + { 4,4,4,4,4,4,6,6,4,4,4,6,6,6,6,6,6,10,10,10,12,12,12,14,14,14,16,16,16,20,20,20,26,26,26,66,66,66,0 }, + { 4,4,4,4,4,4,6,6,4,4,4,6,6,6,8,8,8,12,12,12,16,16,16,20,20,20,26,26,26,34,34,34,42,42,42,12,12,12,0 } + }; + + unsigned tables, scfsi = 0; + int main_data_begin, part_23_sum = 0; + int sr_idx = DRMP3_HDR_GET_MY_SAMPLE_RATE(hdr); + int gr_count = DRMP3_HDR_IS_MONO(hdr) ? 1 : 2; + + if (DRMP3_HDR_TEST_MPEG1(hdr)) + { + gr_count *= 2; + main_data_begin = drmp3_bs_get_bits(bs, 9); + scfsi = drmp3_bs_get_bits(bs, 7 + gr_count); + } else + { + main_data_begin = drmp3_bs_get_bits(bs, 8 + gr_count) >> gr_count; + } + + do + { + if (DRMP3_HDR_IS_MONO(hdr)) + { + scfsi <<= 4; + } + gr->part_23_length = (drmp3_uint16)drmp3_bs_get_bits(bs, 12); + part_23_sum += gr->part_23_length; + gr->big_values = (drmp3_uint16)drmp3_bs_get_bits(bs, 9); + if (gr->big_values > 288) + { + return -1; + } + gr->global_gain = (drmp3_uint8)drmp3_bs_get_bits(bs, 8); + gr->scalefac_compress = (drmp3_uint16)drmp3_bs_get_bits(bs, DRMP3_HDR_TEST_MPEG1(hdr) ? 4 : 9); + gr->sfbtab = g_scf_long[sr_idx]; + gr->n_long_sfb = 22; + gr->n_short_sfb = 0; + if (drmp3_bs_get_bits(bs, 1)) + { + gr->block_type = (drmp3_uint8)drmp3_bs_get_bits(bs, 2); + if (!gr->block_type) + { + return -1; + } + gr->mixed_block_flag = (drmp3_uint8)drmp3_bs_get_bits(bs, 1); + gr->region_count[0] = 7; + gr->region_count[1] = 255; + if (gr->block_type == DRMP3_SHORT_BLOCK_TYPE) + { + scfsi &= 0x0F0F; + if (!gr->mixed_block_flag) + { + gr->region_count[0] = 8; + gr->sfbtab = g_scf_short[sr_idx]; + gr->n_long_sfb = 0; + gr->n_short_sfb = 39; + } else + { + gr->sfbtab = g_scf_mixed[sr_idx]; + gr->n_long_sfb = DRMP3_HDR_TEST_MPEG1(hdr) ? 8 : 6; + gr->n_short_sfb = 30; + } + } + tables = drmp3_bs_get_bits(bs, 10); + tables <<= 5; + gr->subblock_gain[0] = (drmp3_uint8)drmp3_bs_get_bits(bs, 3); + gr->subblock_gain[1] = (drmp3_uint8)drmp3_bs_get_bits(bs, 3); + gr->subblock_gain[2] = (drmp3_uint8)drmp3_bs_get_bits(bs, 3); + } else + { + gr->block_type = 0; + gr->mixed_block_flag = 0; + tables = drmp3_bs_get_bits(bs, 15); + gr->region_count[0] = (drmp3_uint8)drmp3_bs_get_bits(bs, 4); + gr->region_count[1] = (drmp3_uint8)drmp3_bs_get_bits(bs, 3); + gr->region_count[2] = 255; + } + gr->table_select[0] = (drmp3_uint8)(tables >> 10); + gr->table_select[1] = (drmp3_uint8)((tables >> 5) & 31); + gr->table_select[2] = (drmp3_uint8)((tables) & 31); + gr->preflag = (drmp3_uint8)(DRMP3_HDR_TEST_MPEG1(hdr) ? drmp3_bs_get_bits(bs, 1) : (gr->scalefac_compress >= 500)); + gr->scalefac_scale = (drmp3_uint8)drmp3_bs_get_bits(bs, 1); + gr->count1_table = (drmp3_uint8)drmp3_bs_get_bits(bs, 1); + gr->scfsi = (drmp3_uint8)((scfsi >> 12) & 15); + scfsi <<= 4; + gr++; + } while(--gr_count); + + if (part_23_sum + bs->pos > bs->limit + main_data_begin*8) + { + return -1; + } + + return main_data_begin; +} + +static void drmp3_L3_read_scalefactors(drmp3_uint8 *scf, drmp3_uint8 *ist_pos, const drmp3_uint8 *scf_size, const drmp3_uint8 *scf_count, drmp3_bs *bitbuf, int scfsi) +{ + int i, k; + for (i = 0; i < 4 && scf_count[i]; i++, scfsi *= 2) + { + int cnt = scf_count[i]; + if (scfsi & 8) + { + memcpy(scf, ist_pos, cnt); + } else + { + int bits = scf_size[i]; + if (!bits) + { + memset(scf, 0, cnt); + memset(ist_pos, 0, cnt); + } else + { + int max_scf = (scfsi < 0) ? (1 << bits) - 1 : -1; + for (k = 0; k < cnt; k++) + { + int s = drmp3_bs_get_bits(bitbuf, bits); + ist_pos[k] = (drmp3_uint8)(s == max_scf ? -1 : s); + scf[k] = (drmp3_uint8)s; + } + } + } + ist_pos += cnt; + scf += cnt; + } + scf[0] = scf[1] = scf[2] = 0; +} + +static float drmp3_L3_ldexp_q2(float y, int exp_q2) +{ + static const float g_expfrac[4] = { 9.31322575e-10f,7.83145814e-10f,6.58544508e-10f,5.53767716e-10f }; + int e; + do + { + e = DRMP3_MIN(30*4, exp_q2); + y *= g_expfrac[e & 3]*(1 << 30 >> (e >> 2)); + } while ((exp_q2 -= e) > 0); + return y; +} + +static void drmp3_L3_decode_scalefactors(const drmp3_uint8 *hdr, drmp3_uint8 *ist_pos, drmp3_bs *bs, const drmp3_L3_gr_info *gr, float *scf, int ch) +{ + static const drmp3_uint8 g_scf_partitions[3][28] = { + { 6,5,5, 5,6,5,5,5,6,5, 7,3,11,10,0,0, 7, 7, 7,0, 6, 6,6,3, 8, 8,5,0 }, + { 8,9,6,12,6,9,9,9,6,9,12,6,15,18,0,0, 6,15,12,0, 6,12,9,6, 6,18,9,0 }, + { 9,9,6,12,9,9,9,9,9,9,12,6,18,18,0,0,12,12,12,0,12, 9,9,6,15,12,9,0 } + }; + const drmp3_uint8 *scf_partition = g_scf_partitions[!!gr->n_short_sfb + !gr->n_long_sfb]; + drmp3_uint8 scf_size[4], iscf[40]; + int i, scf_shift = gr->scalefac_scale + 1, gain_exp, scfsi = gr->scfsi; + float gain; + + if (DRMP3_HDR_TEST_MPEG1(hdr)) + { + static const drmp3_uint8 g_scfc_decode[16] = { 0,1,2,3, 12,5,6,7, 9,10,11,13, 14,15,18,19 }; + int part = g_scfc_decode[gr->scalefac_compress]; + scf_size[1] = scf_size[0] = (drmp3_uint8)(part >> 2); + scf_size[3] = scf_size[2] = (drmp3_uint8)(part & 3); + } else + { + static const drmp3_uint8 g_mod[6*4] = { 5,5,4,4,5,5,4,1,4,3,1,1,5,6,6,1,4,4,4,1,4,3,1,1 }; + int k, modprod, sfc, ist = DRMP3_HDR_TEST_I_STEREO(hdr) && ch; + sfc = gr->scalefac_compress >> ist; + for (k = ist*3*4; sfc >= 0; sfc -= modprod, k += 4) + { + for (modprod = 1, i = 3; i >= 0; i--) + { + scf_size[i] = (drmp3_uint8)(sfc / modprod % g_mod[k + i]); + modprod *= g_mod[k + i]; + } + } + scf_partition += k; + scfsi = -16; + } + drmp3_L3_read_scalefactors(iscf, ist_pos, scf_size, scf_partition, bs, scfsi); + + if (gr->n_short_sfb) + { + int sh = 3 - scf_shift; + for (i = 0; i < gr->n_short_sfb; i += 3) + { + iscf[gr->n_long_sfb + i + 0] += gr->subblock_gain[0] << sh; + iscf[gr->n_long_sfb + i + 1] += gr->subblock_gain[1] << sh; + iscf[gr->n_long_sfb + i + 2] += gr->subblock_gain[2] << sh; + } + } else if (gr->preflag) + { + static const drmp3_uint8 g_preamp[10] = { 1,1,1,1,2,2,3,3,3,2 }; + for (i = 0; i < 10; i++) + { + iscf[11 + i] += g_preamp[i]; + } + } + + gain_exp = gr->global_gain + DRMP3_BITS_DEQUANTIZER_OUT*4 - 210 - (DRMP3_HDR_IS_MS_STEREO(hdr) ? 2 : 0); + gain = drmp3_L3_ldexp_q2(1 << (DRMP3_MAX_SCFI/4), DRMP3_MAX_SCFI - gain_exp); + for (i = 0; i < (int)(gr->n_long_sfb + gr->n_short_sfb); i++) + { + scf[i] = drmp3_L3_ldexp_q2(gain, iscf[i] << scf_shift); + } +} + +static float drmp3_L3_pow_43(int x) +{ + static const float g_pow43[129] = { + 0,1,2.519842f,4.326749f,6.349604f,8.549880f,10.902724f,13.390518f,16.000000f,18.720754f,21.544347f,24.463781f,27.473142f,30.567351f,33.741992f,36.993181f,40.317474f,43.711787f,47.173345f,50.699631f,54.288352f,57.937408f,61.644865f,65.408941f,69.227979f,73.100443f,77.024898f,81.000000f,85.024491f,89.097188f,93.216975f,97.382800f,101.593667f,105.848633f,110.146801f,114.487321f,118.869381f,123.292209f,127.755065f,132.257246f,136.798076f,141.376907f,145.993119f,150.646117f,155.335327f,160.060199f,164.820202f,169.614826f,174.443577f,179.305980f,184.201575f,189.129918f,194.090580f,199.083145f,204.107210f,209.162385f,214.248292f,219.364564f,224.510845f,229.686789f,234.892058f,240.126328f,245.389280f,250.680604f,256.000000f,261.347174f,266.721841f,272.123723f,277.552547f,283.008049f,288.489971f,293.998060f,299.532071f,305.091761f,310.676898f,316.287249f,321.922592f,327.582707f,333.267377f,338.976394f,344.709550f,350.466646f,356.247482f,362.051866f,367.879608f,373.730522f,379.604427f,385.501143f,391.420496f,397.362314f,403.326427f,409.312672f,415.320884f,421.350905f,427.402579f,433.475750f,439.570269f,445.685987f,451.822757f,457.980436f,464.158883f,470.357960f,476.577530f,482.817459f,489.077615f,495.357868f,501.658090f,507.978156f,514.317941f,520.677324f,527.056184f,533.454404f,539.871867f,546.308458f,552.764065f,559.238575f,565.731879f,572.243870f,578.774440f,585.323483f,591.890898f,598.476581f,605.080431f,611.702349f,618.342238f,625.000000f,631.675540f,638.368763f,645.079578f + }; + float frac; + int sign, mult = 256; + + if (x < 129) + { + return g_pow43[x]; + } + + if (x < 1024) + { + mult = 16; + x <<= 3; + } + + sign = 2*x & 64; + frac = (float)((x & 63) - sign) / ((x & ~63) + sign); + return g_pow43[(x + sign) >> 6]*(1.f + frac*((4.f/3) + frac*(2.f/9)))*mult; +} + +static void drmp3_L3_huffman(float *dst, drmp3_bs *bs, const drmp3_L3_gr_info *gr_info, const float *scf, int layer3gr_limit) +{ + static const float g_pow43_signed[32] = { 0,0,1,-1,2.519842f,-2.519842f,4.326749f,-4.326749f,6.349604f,-6.349604f,8.549880f,-8.549880f,10.902724f,-10.902724f,13.390518f,-13.390518f,16.000000f,-16.000000f,18.720754f,-18.720754f,21.544347f,-21.544347f,24.463781f,-24.463781f,27.473142f,-27.473142f,30.567351f,-30.567351f,33.741992f,-33.741992f,36.993181f,-36.993181f }; + static const drmp3_int16 tab0[32] = { 0, }; + static const drmp3_int16 tab1[] = { 785,785,785,785,784,784,784,784,513,513,513,513,513,513,513,513,256,256,256,256,256,256,256,256,256,256,256,256,256,256,256,256 }; + static const drmp3_int16 tab2[] = { -255,1313,1298,1282,785,785,785,785,784,784,784,784,769,769,769,769,256,256,256,256,256,256,256,256,256,256,256,256,256,256,256,256,290,288 }; + static const drmp3_int16 tab3[] = { -255,1313,1298,1282,769,769,769,769,529,529,529,529,529,529,529,529,528,528,528,528,528,528,528,528,512,512,512,512,512,512,512,512,290,288 }; + static const drmp3_int16 tab5[] = { -253,-318,-351,-367,785,785,785,785,784,784,784,784,769,769,769,769,256,256,256,256,256,256,256,256,256,256,256,256,256,256,256,256,819,818,547,547,275,275,275,275,561,560,515,546,289,274,288,258 }; + static const drmp3_int16 tab6[] = { -254,-287,1329,1299,1314,1312,1057,1057,1042,1042,1026,1026,784,784,784,784,529,529,529,529,529,529,529,529,769,769,769,769,768,768,768,768,563,560,306,306,291,259 }; + static const drmp3_int16 tab7[] = { -252,-413,-477,-542,1298,-575,1041,1041,784,784,784,784,769,769,769,769,256,256,256,256,256,256,256,256,256,256,256,256,256,256,256,256,-383,-399,1107,1092,1106,1061,849,849,789,789,1104,1091,773,773,1076,1075,341,340,325,309,834,804,577,577,532,532,516,516,832,818,803,816,561,561,531,531,515,546,289,289,288,258 }; + static const drmp3_int16 tab8[] = { -252,-429,-493,-559,1057,1057,1042,1042,529,529,529,529,529,529,529,529,784,784,784,784,769,769,769,769,512,512,512,512,512,512,512,512,-382,1077,-415,1106,1061,1104,849,849,789,789,1091,1076,1029,1075,834,834,597,581,340,340,339,324,804,833,532,532,832,772,818,803,817,787,816,771,290,290,290,290,288,258 }; + static const drmp3_int16 tab9[] = { -253,-349,-414,-447,-463,1329,1299,-479,1314,1312,1057,1057,1042,1042,1026,1026,785,785,785,785,784,784,784,784,769,769,769,769,768,768,768,768,-319,851,821,-335,836,850,805,849,341,340,325,336,533,533,579,579,564,564,773,832,578,548,563,516,321,276,306,291,304,259 }; + static const drmp3_int16 tab10[] = { -251,-572,-733,-830,-863,-879,1041,1041,784,784,784,784,769,769,769,769,256,256,256,256,256,256,256,256,256,256,256,256,256,256,256,256,-511,-527,-543,1396,1351,1381,1366,1395,1335,1380,-559,1334,1138,1138,1063,1063,1350,1392,1031,1031,1062,1062,1364,1363,1120,1120,1333,1348,881,881,881,881,375,374,359,373,343,358,341,325,791,791,1123,1122,-703,1105,1045,-719,865,865,790,790,774,774,1104,1029,338,293,323,308,-799,-815,833,788,772,818,803,816,322,292,307,320,561,531,515,546,289,274,288,258 }; + static const drmp3_int16 tab11[] = { -251,-525,-605,-685,-765,-831,-846,1298,1057,1057,1312,1282,785,785,785,785,784,784,784,784,769,769,769,769,512,512,512,512,512,512,512,512,1399,1398,1383,1367,1382,1396,1351,-511,1381,1366,1139,1139,1079,1079,1124,1124,1364,1349,1363,1333,882,882,882,882,807,807,807,807,1094,1094,1136,1136,373,341,535,535,881,775,867,822,774,-591,324,338,-671,849,550,550,866,864,609,609,293,336,534,534,789,835,773,-751,834,804,308,307,833,788,832,772,562,562,547,547,305,275,560,515,290,290 }; + static const drmp3_int16 tab12[] = { -252,-397,-477,-557,-622,-653,-719,-735,-750,1329,1299,1314,1057,1057,1042,1042,1312,1282,1024,1024,785,785,785,785,784,784,784,784,769,769,769,769,-383,1127,1141,1111,1126,1140,1095,1110,869,869,883,883,1079,1109,882,882,375,374,807,868,838,881,791,-463,867,822,368,263,852,837,836,-543,610,610,550,550,352,336,534,534,865,774,851,821,850,805,593,533,579,564,773,832,578,578,548,548,577,577,307,276,306,291,516,560,259,259 }; + static const drmp3_int16 tab13[] = { -250,-2107,-2507,-2764,-2909,-2974,-3007,-3023,1041,1041,1040,1040,769,769,769,769,256,256,256,256,256,256,256,256,256,256,256,256,256,256,256,256,-767,-1052,-1213,-1277,-1358,-1405,-1469,-1535,-1550,-1582,-1614,-1647,-1662,-1694,-1726,-1759,-1774,-1807,-1822,-1854,-1886,1565,-1919,-1935,-1951,-1967,1731,1730,1580,1717,-1983,1729,1564,-1999,1548,-2015,-2031,1715,1595,-2047,1714,-2063,1610,-2079,1609,-2095,1323,1323,1457,1457,1307,1307,1712,1547,1641,1700,1699,1594,1685,1625,1442,1442,1322,1322,-780,-973,-910,1279,1278,1277,1262,1276,1261,1275,1215,1260,1229,-959,974,974,989,989,-943,735,478,478,495,463,506,414,-1039,1003,958,1017,927,942,987,957,431,476,1272,1167,1228,-1183,1256,-1199,895,895,941,941,1242,1227,1212,1135,1014,1014,490,489,503,487,910,1013,985,925,863,894,970,955,1012,847,-1343,831,755,755,984,909,428,366,754,559,-1391,752,486,457,924,997,698,698,983,893,740,740,908,877,739,739,667,667,953,938,497,287,271,271,683,606,590,712,726,574,302,302,738,736,481,286,526,725,605,711,636,724,696,651,589,681,666,710,364,467,573,695,466,466,301,465,379,379,709,604,665,679,316,316,634,633,436,436,464,269,424,394,452,332,438,363,347,408,393,448,331,422,362,407,392,421,346,406,391,376,375,359,1441,1306,-2367,1290,-2383,1337,-2399,-2415,1426,1321,-2431,1411,1336,-2447,-2463,-2479,1169,1169,1049,1049,1424,1289,1412,1352,1319,-2495,1154,1154,1064,1064,1153,1153,416,390,360,404,403,389,344,374,373,343,358,372,327,357,342,311,356,326,1395,1394,1137,1137,1047,1047,1365,1392,1287,1379,1334,1364,1349,1378,1318,1363,792,792,792,792,1152,1152,1032,1032,1121,1121,1046,1046,1120,1120,1030,1030,-2895,1106,1061,1104,849,849,789,789,1091,1076,1029,1090,1060,1075,833,833,309,324,532,532,832,772,818,803,561,561,531,560,515,546,289,274,288,258 }; + static const drmp3_int16 tab15[] = { -250,-1179,-1579,-1836,-1996,-2124,-2253,-2333,-2413,-2477,-2542,-2574,-2607,-2622,-2655,1314,1313,1298,1312,1282,785,785,785,785,1040,1040,1025,1025,768,768,768,768,-766,-798,-830,-862,-895,-911,-927,-943,-959,-975,-991,-1007,-1023,-1039,-1055,-1070,1724,1647,-1103,-1119,1631,1767,1662,1738,1708,1723,-1135,1780,1615,1779,1599,1677,1646,1778,1583,-1151,1777,1567,1737,1692,1765,1722,1707,1630,1751,1661,1764,1614,1736,1676,1763,1750,1645,1598,1721,1691,1762,1706,1582,1761,1566,-1167,1749,1629,767,766,751,765,494,494,735,764,719,749,734,763,447,447,748,718,477,506,431,491,446,476,461,505,415,430,475,445,504,399,460,489,414,503,383,474,429,459,502,502,746,752,488,398,501,473,413,472,486,271,480,270,-1439,-1455,1357,-1471,-1487,-1503,1341,1325,-1519,1489,1463,1403,1309,-1535,1372,1448,1418,1476,1356,1462,1387,-1551,1475,1340,1447,1402,1386,-1567,1068,1068,1474,1461,455,380,468,440,395,425,410,454,364,467,466,464,453,269,409,448,268,432,1371,1473,1432,1417,1308,1460,1355,1446,1459,1431,1083,1083,1401,1416,1458,1445,1067,1067,1370,1457,1051,1051,1291,1430,1385,1444,1354,1415,1400,1443,1082,1082,1173,1113,1186,1066,1185,1050,-1967,1158,1128,1172,1097,1171,1081,-1983,1157,1112,416,266,375,400,1170,1142,1127,1065,793,793,1169,1033,1156,1096,1141,1111,1155,1080,1126,1140,898,898,808,808,897,897,792,792,1095,1152,1032,1125,1110,1139,1079,1124,882,807,838,881,853,791,-2319,867,368,263,822,852,837,866,806,865,-2399,851,352,262,534,534,821,836,594,594,549,549,593,593,533,533,848,773,579,579,564,578,548,563,276,276,577,576,306,291,516,560,305,305,275,259 }; + static const drmp3_int16 tab16[] = { -251,-892,-2058,-2620,-2828,-2957,-3023,-3039,1041,1041,1040,1040,769,769,769,769,256,256,256,256,256,256,256,256,256,256,256,256,256,256,256,256,-511,-527,-543,-559,1530,-575,-591,1528,1527,1407,1526,1391,1023,1023,1023,1023,1525,1375,1268,1268,1103,1103,1087,1087,1039,1039,1523,-604,815,815,815,815,510,495,509,479,508,463,507,447,431,505,415,399,-734,-782,1262,-815,1259,1244,-831,1258,1228,-847,-863,1196,-879,1253,987,987,748,-767,493,493,462,477,414,414,686,669,478,446,461,445,474,429,487,458,412,471,1266,1264,1009,1009,799,799,-1019,-1276,-1452,-1581,-1677,-1757,-1821,-1886,-1933,-1997,1257,1257,1483,1468,1512,1422,1497,1406,1467,1496,1421,1510,1134,1134,1225,1225,1466,1451,1374,1405,1252,1252,1358,1480,1164,1164,1251,1251,1238,1238,1389,1465,-1407,1054,1101,-1423,1207,-1439,830,830,1248,1038,1237,1117,1223,1148,1236,1208,411,426,395,410,379,269,1193,1222,1132,1235,1221,1116,976,976,1192,1162,1177,1220,1131,1191,963,963,-1647,961,780,-1663,558,558,994,993,437,408,393,407,829,978,813,797,947,-1743,721,721,377,392,844,950,828,890,706,706,812,859,796,960,948,843,934,874,571,571,-1919,690,555,689,421,346,539,539,944,779,918,873,932,842,903,888,570,570,931,917,674,674,-2575,1562,-2591,1609,-2607,1654,1322,1322,1441,1441,1696,1546,1683,1593,1669,1624,1426,1426,1321,1321,1639,1680,1425,1425,1305,1305,1545,1668,1608,1623,1667,1592,1638,1666,1320,1320,1652,1607,1409,1409,1304,1304,1288,1288,1664,1637,1395,1395,1335,1335,1622,1636,1394,1394,1319,1319,1606,1621,1392,1392,1137,1137,1137,1137,345,390,360,375,404,373,1047,-2751,-2767,-2783,1062,1121,1046,-2799,1077,-2815,1106,1061,789,789,1105,1104,263,355,310,340,325,354,352,262,339,324,1091,1076,1029,1090,1060,1075,833,833,788,788,1088,1028,818,818,803,803,561,561,531,531,816,771,546,546,289,274,288,258 }; + static const drmp3_int16 tab24[] = { -253,-317,-381,-446,-478,-509,1279,1279,-811,-1179,-1451,-1756,-1900,-2028,-2189,-2253,-2333,-2414,-2445,-2511,-2526,1313,1298,-2559,1041,1041,1040,1040,1025,1025,1024,1024,1022,1007,1021,991,1020,975,1019,959,687,687,1018,1017,671,671,655,655,1016,1015,639,639,758,758,623,623,757,607,756,591,755,575,754,559,543,543,1009,783,-575,-621,-685,-749,496,-590,750,749,734,748,974,989,1003,958,988,973,1002,942,987,957,972,1001,926,986,941,971,956,1000,910,985,925,999,894,970,-1071,-1087,-1102,1390,-1135,1436,1509,1451,1374,-1151,1405,1358,1480,1420,-1167,1507,1494,1389,1342,1465,1435,1450,1326,1505,1310,1493,1373,1479,1404,1492,1464,1419,428,443,472,397,736,526,464,464,486,457,442,471,484,482,1357,1449,1434,1478,1388,1491,1341,1490,1325,1489,1463,1403,1309,1477,1372,1448,1418,1433,1476,1356,1462,1387,-1439,1475,1340,1447,1402,1474,1324,1461,1371,1473,269,448,1432,1417,1308,1460,-1711,1459,-1727,1441,1099,1099,1446,1386,1431,1401,-1743,1289,1083,1083,1160,1160,1458,1445,1067,1067,1370,1457,1307,1430,1129,1129,1098,1098,268,432,267,416,266,400,-1887,1144,1187,1082,1173,1113,1186,1066,1050,1158,1128,1143,1172,1097,1171,1081,420,391,1157,1112,1170,1142,1127,1065,1169,1049,1156,1096,1141,1111,1155,1080,1126,1154,1064,1153,1140,1095,1048,-2159,1125,1110,1137,-2175,823,823,1139,1138,807,807,384,264,368,263,868,838,853,791,867,822,852,837,866,806,865,790,-2319,851,821,836,352,262,850,805,849,-2399,533,533,835,820,336,261,578,548,563,577,532,532,832,772,562,562,547,547,305,275,560,515,290,290,288,258 }; + static const drmp3_uint8 tab32[] = { 130,162,193,209,44,28,76,140,9,9,9,9,9,9,9,9,190,254,222,238,126,94,157,157,109,61,173,205}; + static const drmp3_uint8 tab33[] = { 252,236,220,204,188,172,156,140,124,108,92,76,60,44,28,12 }; + static const drmp3_int16 * const tabindex[2*16] = { tab0,tab1,tab2,tab3,tab0,tab5,tab6,tab7,tab8,tab9,tab10,tab11,tab12,tab13,tab0,tab15,tab16,tab16,tab16,tab16,tab16,tab16,tab16,tab16,tab24,tab24,tab24,tab24,tab24,tab24,tab24,tab24 }; + static const drmp3_uint8 g_linbits[] = { 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,2,3,4,6,8,10,13,4,5,6,7,8,9,11,13 }; + +#define DRMP3_PEEK_BITS(n) (bs_cache >> (32 - n)) +#define DRMP3_FLUSH_BITS(n) { bs_cache <<= (n); bs_sh += (n); } +#define DRMP3_CHECK_BITS while (bs_sh >= 0) { bs_cache |= (drmp3_uint32)*bs_next_ptr++ << bs_sh; bs_sh -= 8; } +#define DRMP3_BSPOS ((bs_next_ptr - bs->buf)*8 - 24 + bs_sh) + + float one = 0.0f; + int ireg = 0, big_val_cnt = gr_info->big_values; + const drmp3_uint8 *sfb = gr_info->sfbtab; + const drmp3_uint8 *bs_next_ptr = bs->buf + bs->pos/8; + drmp3_uint32 bs_cache = (((bs_next_ptr[0]*256u + bs_next_ptr[1])*256u + bs_next_ptr[2])*256u + bs_next_ptr[3]) << (bs->pos & 7); + int pairs_to_decode, np, bs_sh = (bs->pos & 7) - 8; + bs_next_ptr += 4; + + while (big_val_cnt > 0) + { + int tab_num = gr_info->table_select[ireg]; + int sfb_cnt = gr_info->region_count[ireg++]; + const short *codebook = tabindex[tab_num]; + int linbits = g_linbits[tab_num]; + do + { + np = *sfb++ / 2; + pairs_to_decode = DRMP3_MIN(big_val_cnt, np); + one = *scf++; + do + { + int j, w = 5; + int leaf = codebook[DRMP3_PEEK_BITS(w)]; + while (leaf < 0) + { + DRMP3_FLUSH_BITS(w); + w = leaf & 7; + leaf = codebook[DRMP3_PEEK_BITS(w) - (leaf >> 3)]; + } + DRMP3_FLUSH_BITS(leaf >> 8); + + for (j = 0; j < 2; j++, dst++, leaf >>= 4) + { + int lsb = leaf & 0x0F; + if (lsb == 15 && linbits) + { + lsb += DRMP3_PEEK_BITS(linbits); + DRMP3_FLUSH_BITS(linbits); + DRMP3_CHECK_BITS; + *dst = one*drmp3_L3_pow_43(lsb)*((int32_t)bs_cache < 0 ? -1: 1); + } else + { + *dst = g_pow43_signed[lsb*2 + (bs_cache >> 31)]*one; + } + DRMP3_FLUSH_BITS(lsb ? 1 : 0); + } + DRMP3_CHECK_BITS; + } while (--pairs_to_decode); + } while ((big_val_cnt -= np) > 0 && --sfb_cnt >= 0); + } + + for (np = 1 - big_val_cnt;; dst += 4) + { + const drmp3_uint8 *codebook_count1 = (gr_info->count1_table) ? tab33 : tab32; + int leaf = codebook_count1[DRMP3_PEEK_BITS(4)]; + if (!(leaf & 8)) + { + leaf = codebook_count1[(leaf >> 3) + (bs_cache << 4 >> (32 - (leaf & 3)))]; + } + DRMP3_FLUSH_BITS(leaf & 7); + if (DRMP3_BSPOS > layer3gr_limit) + { + break; + } +#define DRMP3_RELOAD_SCALEFACTOR if (!--np) { np = *sfb++/2; if (!np) break; one = *scf++; } +#define DRMP3_DEQ_COUNT1(s) if (leaf & (128 >> s)) { dst[s] = ((drmp3_int32)bs_cache < 0) ? -one : one; DRMP3_FLUSH_BITS(1) } + DRMP3_RELOAD_SCALEFACTOR; + DRMP3_DEQ_COUNT1(0); + DRMP3_DEQ_COUNT1(1); + DRMP3_RELOAD_SCALEFACTOR; + DRMP3_DEQ_COUNT1(2); + DRMP3_DEQ_COUNT1(3); + DRMP3_CHECK_BITS; + } + + bs->pos = layer3gr_limit; +} + +static void drmp3_L3_midside_stereo(float *left, int n) +{ + int i = 0; + float *right = left + 576; +#if DRMP3_HAVE_SIMD + if (drmp3_have_simd()) for (; i < n - 3; i += 4) + { + drmp3_f4 vl = DRMP3_VLD(left + i); + drmp3_f4 vr = DRMP3_VLD(right + i); + DRMP3_VSTORE(left + i, DRMP3_VADD(vl, vr)); + DRMP3_VSTORE(right + i, DRMP3_VSUB(vl, vr)); + } +#endif + for (; i < n; i++) + { + float a = left[i]; + float b = right[i]; + left[i] = a + b; + right[i] = a - b; + } +} + +static void drmp3_L3_intensity_stereo_band(float *left, int n, float kl, float kr) +{ + int i; + for (i = 0; i < n; i++) + { + left[i + 576] = left[i]*kr; + left[i] = left[i]*kl; + } +} + +static void drmp3_L3_stereo_top_band(const float *right, const drmp3_uint8 *sfb, int nbands, int max_band[3]) +{ + int i, k; + + max_band[0] = max_band[1] = max_band[2] = -1; + + for (i = 0; i < nbands; i++) + { + for (k = 0; k < sfb[i]; k += 2) + { + if (right[k] != 0 || right[k + 1] != 0) + { + max_band[i % 3] = i; + break; + } + } + right += sfb[i]; + } +} + +static void drmp3_L3_stereo_process(float *left, const drmp3_uint8 *ist_pos, const drmp3_uint8 *sfb, const drmp3_uint8 *hdr, int max_band[3], int mpeg2_sh) +{ + static const float g_pan[7*2] = { 0,1,0.21132487f,0.78867513f,0.36602540f,0.63397460f,0.5f,0.5f,0.63397460f,0.36602540f,0.78867513f,0.21132487f,1,0 }; + unsigned i, max_pos = DRMP3_HDR_TEST_MPEG1(hdr) ? 7 : 64; + + for (i = 0; sfb[i]; i++) + { + unsigned ipos = ist_pos[i]; + if ((int)i > max_band[i % 3] && ipos < max_pos) + { + float kl, kr, s = DRMP3_HDR_TEST_MS_STEREO(hdr) ? 1.41421356f : 1; + if (DRMP3_HDR_TEST_MPEG1(hdr)) + { + kl = g_pan[2*ipos]; + kr = g_pan[2*ipos + 1]; + } else + { + kl = 1; + kr = drmp3_L3_ldexp_q2(1, (ipos + 1) >> 1 << mpeg2_sh); + if (ipos & 1) + { + kl = kr; + kr = 1; + } + } + drmp3_L3_intensity_stereo_band(left, sfb[i], kl*s, kr*s); + } else if (DRMP3_HDR_TEST_MS_STEREO(hdr)) + { + drmp3_L3_midside_stereo(left, sfb[i]); + } + left += sfb[i]; + } +} + +static void drmp3_L3_intensity_stereo(float *left, drmp3_uint8 *ist_pos, const drmp3_L3_gr_info *gr, const drmp3_uint8 *hdr) +{ + int max_band[3], n_sfb = gr->n_long_sfb + gr->n_short_sfb; + int i, max_blocks = gr->n_short_sfb ? 3 : 1; + + drmp3_L3_stereo_top_band(left + 576, gr->sfbtab, n_sfb, max_band); + if (gr->n_long_sfb) + { + max_band[0] = max_band[1] = max_band[2] = DRMP3_MAX(DRMP3_MAX(max_band[0], max_band[1]), max_band[2]); + } + for (i = 0; i < max_blocks; i++) + { + int default_pos = DRMP3_HDR_TEST_MPEG1(hdr) ? 3 : 0; + int itop = n_sfb - max_blocks + i; + int prev = itop - max_blocks; + ist_pos[itop] = (drmp3_uint8)(max_band[i] >= prev ? default_pos : ist_pos[prev]); + } + drmp3_L3_stereo_process(left, ist_pos, gr->sfbtab, hdr, max_band, gr[1].scalefac_compress&1); +} + +static void drmp3_L3_reorder(float *grbuf, float *scratch, const drmp3_uint8 *sfb) +{ + int i, len; + float *src = grbuf, *dst = scratch; + + for (;0 != (len = *sfb); sfb += 3, src += 2*len) + { + for (i = 0; i < len; i++, src++) + { + *dst++ = src[0*len]; + *dst++ = src[1*len]; + *dst++ = src[2*len]; + } + } + memcpy(grbuf, scratch, (dst - scratch)*sizeof(float)); +} + +static void drmp3_L3_antialias(float *grbuf, int nbands) +{ + static const float g_aa[2][8] = { + {0.85749293f,0.88174200f,0.94962865f,0.98331459f,0.99551782f,0.99916056f,0.99989920f,0.99999316f}, + {0.51449576f,0.47173197f,0.31337745f,0.18191320f,0.09457419f,0.04096558f,0.01419856f,0.00369997f} + }; + + for (; nbands > 0; nbands--, grbuf += 18) + { + int i = 0; +#if DRMP3_HAVE_SIMD + if (drmp3_have_simd()) for (; i < 8; i += 4) + { + drmp3_f4 vu = DRMP3_VLD(grbuf + 18 + i); + drmp3_f4 vd = DRMP3_VLD(grbuf + 14 - i); + drmp3_f4 vc0 = DRMP3_VLD(g_aa[0] + i); + drmp3_f4 vc1 = DRMP3_VLD(g_aa[1] + i); + vd = DRMP3_VREV(vd); + DRMP3_VSTORE(grbuf + 18 + i, DRMP3_VSUB(DRMP3_VMUL(vu, vc0), DRMP3_VMUL(vd, vc1))); + vd = DRMP3_VADD(DRMP3_VMUL(vu, vc1), DRMP3_VMUL(vd, vc0)); + DRMP3_VSTORE(grbuf + 14 - i, DRMP3_VREV(vd)); + } +#endif +#ifndef DR_MP3_ONLY_SIMD + for(; i < 8; i++) + { + float u = grbuf[18 + i]; + float d = grbuf[17 - i]; + grbuf[18 + i] = u*g_aa[0][i] - d*g_aa[1][i]; + grbuf[17 - i] = u*g_aa[1][i] + d*g_aa[0][i]; + } +#endif + } +} + +static void drmp3_L3_dct3_9(float *y) +{ + float s0, s1, s2, s3, s4, s5, s6, s7, s8, t0, t2, t4; + + s0 = y[0]; s2 = y[2]; s4 = y[4]; s6 = y[6]; s8 = y[8]; + t0 = s0 + s6*0.5f; + s0 -= s6; + t4 = (s4 + s2)*0.93969262f; + t2 = (s8 + s2)*0.76604444f; + s6 = (s4 - s8)*0.17364818f; + s4 += s8 - s2; + + s2 = s0 - s4*0.5f; + y[4] = s4 + s0; + s8 = t0 - t2 + s6; + s0 = t0 - t4 + t2; + s4 = t0 + t4 - s6; + + s1 = y[1]; s3 = y[3]; s5 = y[5]; s7 = y[7]; + + s3 *= 0.86602540f; + t0 = (s5 + s1)*0.98480775f; + t4 = (s5 - s7)*0.34202014f; + t2 = (s1 + s7)*0.64278761f; + s1 = (s1 - s5 - s7)*0.86602540f; + + s5 = t0 - s3 - t2; + s7 = t4 - s3 - t0; + s3 = t4 + s3 - t2; + + y[0] = s4 - s7; + y[1] = s2 + s1; + y[2] = s0 - s3; + y[3] = s8 + s5; + y[5] = s8 - s5; + y[6] = s0 + s3; + y[7] = s2 - s1; + y[8] = s4 + s7; +} + +static void drmp3_L3_imdct36(float *grbuf, float *overlap, const float *window, int nbands) +{ + int i, j; + static const float g_twid9[18] = { + 0.73727734f,0.79335334f,0.84339145f,0.88701083f,0.92387953f,0.95371695f,0.97629601f,0.99144486f,0.99904822f,0.67559021f,0.60876143f,0.53729961f,0.46174861f,0.38268343f,0.30070580f,0.21643961f,0.13052619f,0.04361938f + }; + + for (j = 0; j < nbands; j++, grbuf += 18, overlap += 9) + { + float co[9], si[9]; + co[0] = -grbuf[0]; + si[0] = grbuf[17]; + for (i = 0; i < 4; i++) + { + si[8 - 2*i] = grbuf[4*i + 1] - grbuf[4*i + 2]; + co[1 + 2*i] = grbuf[4*i + 1] + grbuf[4*i + 2]; + si[7 - 2*i] = grbuf[4*i + 4] - grbuf[4*i + 3]; + co[2 + 2*i] = -(grbuf[4*i + 3] + grbuf[4*i + 4]); + } + drmp3_L3_dct3_9(co); + drmp3_L3_dct3_9(si); + + si[1] = -si[1]; + si[3] = -si[3]; + si[5] = -si[5]; + si[7] = -si[7]; + + i = 0; + +#if DRMP3_HAVE_SIMD + if (drmp3_have_simd()) for (; i < 8; i += 4) + { + drmp3_f4 vovl = DRMP3_VLD(overlap + i); + drmp3_f4 vc = DRMP3_VLD(co + i); + drmp3_f4 vs = DRMP3_VLD(si + i); + drmp3_f4 vr0 = DRMP3_VLD(g_twid9 + i); + drmp3_f4 vr1 = DRMP3_VLD(g_twid9 + 9 + i); + drmp3_f4 vw0 = DRMP3_VLD(window + i); + drmp3_f4 vw1 = DRMP3_VLD(window + 9 + i); + drmp3_f4 vsum = DRMP3_VADD(DRMP3_VMUL(vc, vr1), DRMP3_VMUL(vs, vr0)); + DRMP3_VSTORE(overlap + i, DRMP3_VSUB(DRMP3_VMUL(vc, vr0), DRMP3_VMUL(vs, vr1))); + DRMP3_VSTORE(grbuf + i, DRMP3_VSUB(DRMP3_VMUL(vovl, vw0), DRMP3_VMUL(vsum, vw1))); + vsum = DRMP3_VADD(DRMP3_VMUL(vovl, vw1), DRMP3_VMUL(vsum, vw0)); + DRMP3_VSTORE(grbuf + 14 - i, DRMP3_VREV(vsum)); + } +#endif + for (; i < 9; i++) + { + float ovl = overlap[i]; + float sum = co[i]*g_twid9[9 + i] + si[i]*g_twid9[0 + i]; + overlap[i] = co[i]*g_twid9[0 + i] - si[i]*g_twid9[9 + i]; + grbuf[i] = ovl*window[0 + i] - sum*window[9 + i]; + grbuf[17 - i] = ovl*window[9 + i] + sum*window[0 + i]; + } + } +} + +static void drmp3_L3_idct3(float x0, float x1, float x2, float *dst) +{ + float m1 = x1*0.86602540f; + float a1 = x0 - x2*0.5f; + dst[1] = x0 + x2; + dst[0] = a1 + m1; + dst[2] = a1 - m1; +} + +static void drmp3_L3_imdct12(float *x, float *dst, float *overlap) +{ + static const float g_twid3[6] = { 0.79335334f,0.92387953f,0.99144486f, 0.60876143f,0.38268343f,0.13052619f }; + float co[3], si[3]; + int i; + + drmp3_L3_idct3(-x[0], x[6] + x[3], x[12] + x[9], co); + drmp3_L3_idct3(x[15], x[12] - x[9], x[6] - x[3], si); + si[1] = -si[1]; + + for (i = 0; i < 3; i++) + { + float ovl = overlap[i]; + float sum = co[i]*g_twid3[3 + i] + si[i]*g_twid3[0 + i]; + overlap[i] = co[i]*g_twid3[0 + i] - si[i]*g_twid3[3 + i]; + dst[i] = ovl*g_twid3[2 - i] - sum*g_twid3[5 - i]; + dst[5 - i] = ovl*g_twid3[5 - i] + sum*g_twid3[2 - i]; + } +} + +static void drmp3_L3_imdct_short(float *grbuf, float *overlap, int nbands) +{ + for (;nbands > 0; nbands--, overlap += 9, grbuf += 18) + { + float tmp[18]; + memcpy(tmp, grbuf, sizeof(tmp)); + memcpy(grbuf, overlap, 6*sizeof(float)); + drmp3_L3_imdct12(tmp, grbuf + 6, overlap + 6); + drmp3_L3_imdct12(tmp + 1, grbuf + 12, overlap + 6); + drmp3_L3_imdct12(tmp + 2, overlap, overlap + 6); + } +} + +static void drmp3_L3_change_sign(float *grbuf) +{ + int b, i; + for (b = 0, grbuf += 18; b < 32; b += 2, grbuf += 36) + for (i = 1; i < 18; i += 2) + grbuf[i] = -grbuf[i]; +} + +static void drmp3_L3_imdct_gr(float *grbuf, float *overlap, unsigned block_type, unsigned n_long_bands) +{ + static const float g_mdct_window[2][18] = { + { 0.99904822f,0.99144486f,0.97629601f,0.95371695f,0.92387953f,0.88701083f,0.84339145f,0.79335334f,0.73727734f,0.04361938f,0.13052619f,0.21643961f,0.30070580f,0.38268343f,0.46174861f,0.53729961f,0.60876143f,0.67559021f }, + { 1,1,1,1,1,1,0.99144486f,0.92387953f,0.79335334f,0,0,0,0,0,0,0.13052619f,0.38268343f,0.60876143f } + }; + if (n_long_bands) + { + drmp3_L3_imdct36(grbuf, overlap, g_mdct_window[0], n_long_bands); + grbuf += 18*n_long_bands; + overlap += 9*n_long_bands; + } + if (block_type == DRMP3_SHORT_BLOCK_TYPE) + drmp3_L3_imdct_short(grbuf, overlap, 32 - n_long_bands); + else + drmp3_L3_imdct36(grbuf, overlap, g_mdct_window[block_type == DRMP3_STOP_BLOCK_TYPE], 32 - n_long_bands); +} + +static void drmp3_L3_save_reservoir(drmp3dec *h, drmp3dec_scratch *s) +{ + int pos = (s->bs.pos + 7)/8u; + int remains = s->bs.limit/8u - pos; + if (remains > DRMP3_MAX_BITRESERVOIR_BYTES) + { + pos += remains - DRMP3_MAX_BITRESERVOIR_BYTES; + remains = DRMP3_MAX_BITRESERVOIR_BYTES; + } + if (remains > 0) + { + memmove(h->reserv_buf, s->maindata + pos, remains); + } + h->reserv = remains; +} + +static int drmp3_L3_restore_reservoir(drmp3dec *h, drmp3_bs *bs, drmp3dec_scratch *s, int main_data_begin) +{ + int frame_bytes = (bs->limit - bs->pos)/8; + int bytes_have = DRMP3_MIN(h->reserv, main_data_begin); + memcpy(s->maindata, h->reserv_buf + DRMP3_MAX(0, h->reserv - main_data_begin), DRMP3_MIN(h->reserv, main_data_begin)); + memcpy(s->maindata + bytes_have, bs->buf + bs->pos/8, frame_bytes); + drmp3_bs_init(&s->bs, s->maindata, bytes_have + frame_bytes); + return h->reserv >= main_data_begin; +} + +static void drmp3_L3_decode(drmp3dec *h, drmp3dec_scratch *s, drmp3_L3_gr_info *gr_info, int nch) +{ + int ch; + + for (ch = 0; ch < nch; ch++) + { + int layer3gr_limit = s->bs.pos + gr_info[ch].part_23_length; + drmp3_L3_decode_scalefactors(h->header, s->ist_pos[ch], &s->bs, gr_info + ch, s->scf, ch); + drmp3_L3_huffman(s->grbuf[ch], &s->bs, gr_info + ch, s->scf, layer3gr_limit); + } + + if (DRMP3_HDR_TEST_I_STEREO(h->header)) + { + drmp3_L3_intensity_stereo(s->grbuf[0], s->ist_pos[1], gr_info, h->header); + } else if (DRMP3_HDR_IS_MS_STEREO(h->header)) + { + drmp3_L3_midside_stereo(s->grbuf[0], 576); + } + + for (ch = 0; ch < nch; ch++, gr_info++) + { + int aa_bands = 31; + int n_long_bands = (gr_info->mixed_block_flag ? 2 : 0) << (int)(DRMP3_HDR_GET_MY_SAMPLE_RATE(h->header) == 2); + + if (gr_info->n_short_sfb) + { + aa_bands = n_long_bands - 1; + drmp3_L3_reorder(s->grbuf[ch] + n_long_bands*18, s->syn[0], gr_info->sfbtab + gr_info->n_long_sfb); + } + + drmp3_L3_antialias(s->grbuf[ch], aa_bands); + drmp3_L3_imdct_gr(s->grbuf[ch], h->mdct_overlap[ch], gr_info->block_type, n_long_bands); + drmp3_L3_change_sign(s->grbuf[ch]); + } +} + +static void drmp3d_DCT_II(float *grbuf, int n) +{ + static const float g_sec[24] = { + 10.19000816f,0.50060302f,0.50241929f,3.40760851f,0.50547093f,0.52249861f,2.05778098f,0.51544732f,0.56694406f,1.48416460f,0.53104258f,0.64682180f,1.16943991f,0.55310392f,0.78815460f,0.97256821f,0.58293498f,1.06067765f,0.83934963f,0.62250412f,1.72244716f,0.74453628f,0.67480832f,5.10114861f + }; + int i, k = 0; +#if DRMP3_HAVE_SIMD + if (drmp3_have_simd()) for (; k < n; k += 4) + { + drmp3_f4 t[4][8], *x; + float *y = grbuf + k; + + for (x = t[0], i = 0; i < 8; i++, x++) + { + drmp3_f4 x0 = DRMP3_VLD(&y[i*18]); + drmp3_f4 x1 = DRMP3_VLD(&y[(15 - i)*18]); + drmp3_f4 x2 = DRMP3_VLD(&y[(16 + i)*18]); + drmp3_f4 x3 = DRMP3_VLD(&y[(31 - i)*18]); + drmp3_f4 t0 = DRMP3_VADD(x0, x3); + drmp3_f4 t1 = DRMP3_VADD(x1, x2); + drmp3_f4 t2 = DRMP3_VMUL_S(DRMP3_VSUB(x1, x2), g_sec[3*i + 0]); + drmp3_f4 t3 = DRMP3_VMUL_S(DRMP3_VSUB(x0, x3), g_sec[3*i + 1]); + x[0] = DRMP3_VADD(t0, t1); + x[8] = DRMP3_VMUL_S(DRMP3_VSUB(t0, t1), g_sec[3*i + 2]); + x[16] = DRMP3_VADD(t3, t2); + x[24] = DRMP3_VMUL_S(DRMP3_VSUB(t3, t2), g_sec[3*i + 2]); + } + for (x = t[0], i = 0; i < 4; i++, x += 8) + { + drmp3_f4 x0 = x[0], x1 = x[1], x2 = x[2], x3 = x[3], x4 = x[4], x5 = x[5], x6 = x[6], x7 = x[7], xt; + xt = DRMP3_VSUB(x0, x7); x0 = DRMP3_VADD(x0, x7); + x7 = DRMP3_VSUB(x1, x6); x1 = DRMP3_VADD(x1, x6); + x6 = DRMP3_VSUB(x2, x5); x2 = DRMP3_VADD(x2, x5); + x5 = DRMP3_VSUB(x3, x4); x3 = DRMP3_VADD(x3, x4); + x4 = DRMP3_VSUB(x0, x3); x0 = DRMP3_VADD(x0, x3); + x3 = DRMP3_VSUB(x1, x2); x1 = DRMP3_VADD(x1, x2); + x[0] = DRMP3_VADD(x0, x1); + x[4] = DRMP3_VMUL_S(DRMP3_VSUB(x0, x1), 0.70710677f); + x5 = DRMP3_VADD(x5, x6); + x6 = DRMP3_VMUL_S(DRMP3_VADD(x6, x7), 0.70710677f); + x7 = DRMP3_VADD(x7, xt); + x3 = DRMP3_VMUL_S(DRMP3_VADD(x3, x4), 0.70710677f); + x5 = DRMP3_VSUB(x5, DRMP3_VMUL_S(x7, 0.198912367f)); /* rotate by PI/8 */ + x7 = DRMP3_VADD(x7, DRMP3_VMUL_S(x5, 0.382683432f)); + x5 = DRMP3_VSUB(x5, DRMP3_VMUL_S(x7, 0.198912367f)); + x0 = DRMP3_VSUB(xt, x6); xt = DRMP3_VADD(xt, x6); + x[1] = DRMP3_VMUL_S(DRMP3_VADD(xt, x7), 0.50979561f); + x[2] = DRMP3_VMUL_S(DRMP3_VADD(x4, x3), 0.54119611f); + x[3] = DRMP3_VMUL_S(DRMP3_VSUB(x0, x5), 0.60134488f); + x[5] = DRMP3_VMUL_S(DRMP3_VADD(x0, x5), 0.89997619f); + x[6] = DRMP3_VMUL_S(DRMP3_VSUB(x4, x3), 1.30656302f); + x[7] = DRMP3_VMUL_S(DRMP3_VSUB(xt, x7), 2.56291556f); + } + + if (k > n - 3) + { +#if DRMP3_HAVE_SSE +#define DRMP3_VSAVE2(i, v) _mm_storel_pi((__m64 *)(void*)&y[i*18], v) +#else +#define DRMP3_VSAVE2(i, v) vst1_f32((float32_t *)&y[i*18], vget_low_f32(v)) +#endif + for (i = 0; i < 7; i++, y += 4*18) + { + drmp3_f4 s = DRMP3_VADD(t[3][i], t[3][i + 1]); + DRMP3_VSAVE2(0, t[0][i]); + DRMP3_VSAVE2(1, DRMP3_VADD(t[2][i], s)); + DRMP3_VSAVE2(2, DRMP3_VADD(t[1][i], t[1][i + 1])); + DRMP3_VSAVE2(3, DRMP3_VADD(t[2][1 + i], s)); + } + DRMP3_VSAVE2(0, t[0][7]); + DRMP3_VSAVE2(1, DRMP3_VADD(t[2][7], t[3][7])); + DRMP3_VSAVE2(2, t[1][7]); + DRMP3_VSAVE2(3, t[3][7]); + } else + { +#define DRMP3_VSAVE4(i, v) DRMP3_VSTORE(&y[i*18], v) + for (i = 0; i < 7; i++, y += 4*18) + { + drmp3_f4 s = DRMP3_VADD(t[3][i], t[3][i + 1]); + DRMP3_VSAVE4(0, t[0][i]); + DRMP3_VSAVE4(1, DRMP3_VADD(t[2][i], s)); + DRMP3_VSAVE4(2, DRMP3_VADD(t[1][i], t[1][i + 1])); + DRMP3_VSAVE4(3, DRMP3_VADD(t[2][1 + i], s)); + } + DRMP3_VSAVE4(0, t[0][7]); + DRMP3_VSAVE4(1, DRMP3_VADD(t[2][7], t[3][7])); + DRMP3_VSAVE4(2, t[1][7]); + DRMP3_VSAVE4(3, t[3][7]); + } + } else +#endif +#ifdef DR_MP3_ONLY_SIMD + {} +#else + for (; k < n; k++) + { + float t[4][8], *x, *y = grbuf + k; + + for (x = t[0], i = 0; i < 8; i++, x++) + { + float x0 = y[i*18]; + float x1 = y[(15 - i)*18]; + float x2 = y[(16 + i)*18]; + float x3 = y[(31 - i)*18]; + float t0 = x0 + x3; + float t1 = x1 + x2; + float t2 = (x1 - x2)*g_sec[3*i + 0]; + float t3 = (x0 - x3)*g_sec[3*i + 1]; + x[0] = t0 + t1; + x[8] = (t0 - t1)*g_sec[3*i + 2]; + x[16] = t3 + t2; + x[24] = (t3 - t2)*g_sec[3*i + 2]; + } + for (x = t[0], i = 0; i < 4; i++, x += 8) + { + float x0 = x[0], x1 = x[1], x2 = x[2], x3 = x[3], x4 = x[4], x5 = x[5], x6 = x[6], x7 = x[7], xt; + xt = x0 - x7; x0 += x7; + x7 = x1 - x6; x1 += x6; + x6 = x2 - x5; x2 += x5; + x5 = x3 - x4; x3 += x4; + x4 = x0 - x3; x0 += x3; + x3 = x1 - x2; x1 += x2; + x[0] = x0 + x1; + x[4] = (x0 - x1)*0.70710677f; + x5 = x5 + x6; + x6 = (x6 + x7)*0.70710677f; + x7 = x7 + xt; + x3 = (x3 + x4)*0.70710677f; + x5 -= x7*0.198912367f; /* rotate by PI/8 */ + x7 += x5*0.382683432f; + x5 -= x7*0.198912367f; + x0 = xt - x6; xt += x6; + x[1] = (xt + x7)*0.50979561f; + x[2] = (x4 + x3)*0.54119611f; + x[3] = (x0 - x5)*0.60134488f; + x[5] = (x0 + x5)*0.89997619f; + x[6] = (x4 - x3)*1.30656302f; + x[7] = (xt - x7)*2.56291556f; + + } + for (i = 0; i < 7; i++, y += 4*18) + { + y[0*18] = t[0][i]; + y[1*18] = t[2][i] + t[3][i] + t[3][i + 1]; + y[2*18] = t[1][i] + t[1][i + 1]; + y[3*18] = t[2][i + 1] + t[3][i] + t[3][i + 1]; + } + y[0*18] = t[0][7]; + y[1*18] = t[2][7] + t[3][7]; + y[2*18] = t[1][7]; + y[3*18] = t[3][7]; + } +#endif +} + +static short drmp3d_scale_pcm(float sample) +{ + if (sample > 32767.0) return (short) 32767; + if (sample < -32768.0) return (short)-32768; + int s = (int)(sample + .5f); + s -= (s < 0); /* away from zero, to be compliant */ + if (s > 32767) return (short) 32767; + if (s < -32768) return (short)-32768; + return (short)s; +} + +static void drmp3d_synth_pair(short *pcm, int nch, const float *z) +{ + float a; + a = (z[14*64] - z[ 0]) * 29; + a += (z[ 1*64] + z[13*64]) * 213; + a += (z[12*64] - z[ 2*64]) * 459; + a += (z[ 3*64] + z[11*64]) * 2037; + a += (z[10*64] - z[ 4*64]) * 5153; + a += (z[ 5*64] + z[ 9*64]) * 6574; + a += (z[ 8*64] - z[ 6*64]) * 37489; + a += z[ 7*64] * 75038; + pcm[0] = drmp3d_scale_pcm(a); + + z += 2; + a = z[14*64] * 104; + a += z[12*64] * 1567; + a += z[10*64] * 9727; + a += z[ 8*64] * 64019; + a += z[ 6*64] * -9975; + a += z[ 4*64] * -45; + a += z[ 2*64] * 146; + a += z[ 0*64] * -5; + pcm[16*nch] = drmp3d_scale_pcm(a); +} + +static void drmp3d_synth(float *xl, short *dstl, int nch, float *lins) +{ + int i; + float *xr = xl + 576*(nch - 1); + short *dstr = dstl + (nch - 1); + + static const float g_win[] = { + -1,26,-31,208,218,401,-519,2063,2000,4788,-5517,7134,5959,35640,-39336,74992, + -1,24,-35,202,222,347,-581,2080,1952,4425,-5879,7640,5288,33791,-41176,74856, + -1,21,-38,196,225,294,-645,2087,1893,4063,-6237,8092,4561,31947,-43006,74630, + -1,19,-41,190,227,244,-711,2085,1822,3705,-6589,8492,3776,30112,-44821,74313, + -1,17,-45,183,228,197,-779,2075,1739,3351,-6935,8840,2935,28289,-46617,73908, + -1,16,-49,176,228,153,-848,2057,1644,3004,-7271,9139,2037,26482,-48390,73415, + -2,14,-53,169,227,111,-919,2032,1535,2663,-7597,9389,1082,24694,-50137,72835, + -2,13,-58,161,224,72,-991,2001,1414,2330,-7910,9592,70,22929,-51853,72169, + -2,11,-63,154,221,36,-1064,1962,1280,2006,-8209,9750,-998,21189,-53534,71420, + -2,10,-68,147,215,2,-1137,1919,1131,1692,-8491,9863,-2122,19478,-55178,70590, + -3,9,-73,139,208,-29,-1210,1870,970,1388,-8755,9935,-3300,17799,-56778,69679, + -3,8,-79,132,200,-57,-1283,1817,794,1095,-8998,9966,-4533,16155,-58333,68692, + -4,7,-85,125,189,-83,-1356,1759,605,814,-9219,9959,-5818,14548,-59838,67629, + -4,7,-91,117,177,-106,-1428,1698,402,545,-9416,9916,-7154,12980,-61289,66494, + -5,6,-97,111,163,-127,-1498,1634,185,288,-9585,9838,-8540,11455,-62684,65290 + }; + float *zlin = lins + 15*64; + const float *w = g_win; + + zlin[4*15] = xl[18*16]; + zlin[4*15 + 1] = xr[18*16]; + zlin[4*15 + 2] = xl[0]; + zlin[4*15 + 3] = xr[0]; + + zlin[4*31] = xl[1 + 18*16]; + zlin[4*31 + 1] = xr[1 + 18*16]; + zlin[4*31 + 2] = xl[1]; + zlin[4*31 + 3] = xr[1]; + + drmp3d_synth_pair(dstr, nch, lins + 4*15 + 1); + drmp3d_synth_pair(dstr + 32*nch, nch, lins + 4*15 + 64 + 1); + drmp3d_synth_pair(dstl, nch, lins + 4*15); + drmp3d_synth_pair(dstl + 32*nch, nch, lins + 4*15 + 64); + +#if DRMP3_HAVE_SIMD + if (drmp3_have_simd()) for (i = 14; i >= 0; i--) + { +#define DRMP3_VLOAD(k) drmp3_f4 w0 = DRMP3_VSET(*w++); drmp3_f4 w1 = DRMP3_VSET(*w++); drmp3_f4 vz = DRMP3_VLD(&zlin[4*i - 64*k]); drmp3_f4 vy = DRMP3_VLD(&zlin[4*i - 64*(15 - k)]); +#define DRMP3_V0(k) { DRMP3_VLOAD(k) b = DRMP3_VADD(DRMP3_VMUL(vz, w1), DRMP3_VMUL(vy, w0)) ; a = DRMP3_VSUB(DRMP3_VMUL(vz, w0), DRMP3_VMUL(vy, w1)); } +#define DRMP3_V1(k) { DRMP3_VLOAD(k) b = DRMP3_VADD(b, DRMP3_VADD(DRMP3_VMUL(vz, w1), DRMP3_VMUL(vy, w0))); a = DRMP3_VADD(a, DRMP3_VSUB(DRMP3_VMUL(vz, w0), DRMP3_VMUL(vy, w1))); } +#define DRMP3_V2(k) { DRMP3_VLOAD(k) b = DRMP3_VADD(b, DRMP3_VADD(DRMP3_VMUL(vz, w1), DRMP3_VMUL(vy, w0))); a = DRMP3_VADD(a, DRMP3_VSUB(DRMP3_VMUL(vy, w1), DRMP3_VMUL(vz, w0))); } + drmp3_f4 a, b; + zlin[4*i] = xl[18*(31 - i)]; + zlin[4*i + 1] = xr[18*(31 - i)]; + zlin[4*i + 2] = xl[1 + 18*(31 - i)]; + zlin[4*i + 3] = xr[1 + 18*(31 - i)]; + zlin[4*i + 64] = xl[1 + 18*(1 + i)]; + zlin[4*i + 64 + 1] = xr[1 + 18*(1 + i)]; + zlin[4*i - 64 + 2] = xl[18*(1 + i)]; + zlin[4*i - 64 + 3] = xr[18*(1 + i)]; + + DRMP3_V0(0) DRMP3_V2(1) DRMP3_V1(2) DRMP3_V2(3) DRMP3_V1(4) DRMP3_V2(5) DRMP3_V1(6) DRMP3_V2(7) + + { +#if DRMP3_HAVE_SSE + static const drmp3_f4 g_max = { 32767.0f, 32767.0f, 32767.0f, 32767.0f }; + static const drmp3_f4 g_min = { -32768.0f, -32768.0f, -32768.0f, -32768.0f }; + __m128i pcm8 = _mm_packs_epi32(_mm_cvtps_epi32(_mm_max_ps(_mm_min_ps(a, g_max), g_min)), + _mm_cvtps_epi32(_mm_max_ps(_mm_min_ps(b, g_max), g_min))); + dstr[(15 - i)*nch] = (short)_mm_extract_epi16(pcm8, 1); + dstr[(17 + i)*nch] = (short)_mm_extract_epi16(pcm8, 5); + dstl[(15 - i)*nch] = (short)_mm_extract_epi16(pcm8, 0); + dstl[(17 + i)*nch] = (short)_mm_extract_epi16(pcm8, 4); + dstr[(47 - i)*nch] = (short)_mm_extract_epi16(pcm8, 3); + dstr[(49 + i)*nch] = (short)_mm_extract_epi16(pcm8, 7); + dstl[(47 - i)*nch] = (short)_mm_extract_epi16(pcm8, 2); + dstl[(49 + i)*nch] = (short)_mm_extract_epi16(pcm8, 6); +#else + int16x4_t pcma, pcmb; + a = DRMP3_VADD(a, DRMP3_VSET(0.5f)); + b = DRMP3_VADD(b, DRMP3_VSET(0.5f)); + pcma = vqmovn_s32(vqaddq_s32(vcvtq_s32_f32(a), vreinterpretq_s32_u32(vcltq_f32(a, DRMP3_VSET(0))))); + pcmb = vqmovn_s32(vqaddq_s32(vcvtq_s32_f32(b), vreinterpretq_s32_u32(vcltq_f32(b, DRMP3_VSET(0))))); + vst1_lane_s16(dstr + (15 - i)*nch, pcma, 1); + vst1_lane_s16(dstr + (17 + i)*nch, pcmb, 1); + vst1_lane_s16(dstl + (15 - i)*nch, pcma, 0); + vst1_lane_s16(dstl + (17 + i)*nch, pcmb, 0); + vst1_lane_s16(dstr + (47 - i)*nch, pcma, 3); + vst1_lane_s16(dstr + (49 + i)*nch, pcmb, 3); + vst1_lane_s16(dstl + (47 - i)*nch, pcma, 2); + vst1_lane_s16(dstl + (49 + i)*nch, pcmb, 2); +#endif + } + } else +#endif +#ifdef DR_MP3_ONLY_SIMD + {} +#else + for (i = 14; i >= 0; i--) + { +#define DRMP3_LOAD(k) float w0 = *w++; float w1 = *w++; float *vz = &zlin[4*i - k*64]; float *vy = &zlin[4*i - (15 - k)*64]; +#define DRMP3_S0(k) { int j; DRMP3_LOAD(k); for (j = 0; j < 4; j++) b[j] = vz[j]*w1 + vy[j]*w0, a[j] = vz[j]*w0 - vy[j]*w1; } +#define DRMP3_S1(k) { int j; DRMP3_LOAD(k); for (j = 0; j < 4; j++) b[j] += vz[j]*w1 + vy[j]*w0, a[j] += vz[j]*w0 - vy[j]*w1; } +#define DRMP3_S2(k) { int j; DRMP3_LOAD(k); for (j = 0; j < 4; j++) b[j] += vz[j]*w1 + vy[j]*w0, a[j] += vy[j]*w1 - vz[j]*w0; } + float a[4], b[4]; + + zlin[4*i] = xl[18*(31 - i)]; + zlin[4*i + 1] = xr[18*(31 - i)]; + zlin[4*i + 2] = xl[1 + 18*(31 - i)]; + zlin[4*i + 3] = xr[1 + 18*(31 - i)]; + zlin[4*(i + 16)] = xl[1 + 18*(1 + i)]; + zlin[4*(i + 16) + 1] = xr[1 + 18*(1 + i)]; + zlin[4*(i - 16) + 2] = xl[18*(1 + i)]; + zlin[4*(i - 16) + 3] = xr[18*(1 + i)]; + + DRMP3_S0(0) DRMP3_S2(1) DRMP3_S1(2) DRMP3_S2(3) DRMP3_S1(4) DRMP3_S2(5) DRMP3_S1(6) DRMP3_S2(7) + + dstr[(15 - i)*nch] = drmp3d_scale_pcm(a[1]); + dstr[(17 + i)*nch] = drmp3d_scale_pcm(b[1]); + dstl[(15 - i)*nch] = drmp3d_scale_pcm(a[0]); + dstl[(17 + i)*nch] = drmp3d_scale_pcm(b[0]); + dstr[(47 - i)*nch] = drmp3d_scale_pcm(a[3]); + dstr[(49 + i)*nch] = drmp3d_scale_pcm(b[3]); + dstl[(47 - i)*nch] = drmp3d_scale_pcm(a[2]); + dstl[(49 + i)*nch] = drmp3d_scale_pcm(b[2]); + } +#endif +} + +static void drmp3d_synth_granule(float *qmf_state, float *grbuf, int nbands, int nch, short *pcm, float *lins) +{ + int i; + for (i = 0; i < nch; i++) + { + drmp3d_DCT_II(grbuf + 576*i, nbands); + } + + memcpy(lins, qmf_state, sizeof(float)*15*64); + + for (i = 0; i < nbands; i += 2) + { + drmp3d_synth(grbuf + i, pcm + 32*nch*i, nch, lins + i*64); + } +#ifndef DR_MP3_NONSTANDARD_BUT_LOGICAL + if (nch == 1) + { + for (i = 0; i < 15*64; i += 2) + { + qmf_state[i] = lins[nbands*64 + i]; + } + } else +#endif + { + memcpy(qmf_state, lins + nbands*64, sizeof(float)*15*64); + } +} + +static int drmp3d_match_frame(const drmp3_uint8 *hdr, int mp3_bytes, int frame_bytes) +{ + int i, nmatch; + for (i = 0, nmatch = 0; nmatch < DRMP3_MAX_FRAME_SYNC_MATCHES; nmatch++) + { + i += drmp3_hdr_frame_bytes(hdr + i, frame_bytes) + drmp3_hdr_padding(hdr + i); + if (i + DRMP3_HDR_SIZE > mp3_bytes) + return nmatch > 0; + if (!drmp3_hdr_compare(hdr, hdr + i)) + return 0; + } + return 1; +} + +static int drmp3d_find_frame(const drmp3_uint8 *mp3, int mp3_bytes, int *free_format_bytes, int *ptr_frame_bytes) +{ + int i, k; + for (i = 0; i < mp3_bytes - DRMP3_HDR_SIZE; i++, mp3++) + { + if (drmp3_hdr_valid(mp3)) + { + int frame_bytes = drmp3_hdr_frame_bytes(mp3, *free_format_bytes); + int frame_and_padding = frame_bytes + drmp3_hdr_padding(mp3); + + for (k = DRMP3_HDR_SIZE; !frame_bytes && k < DRMP3_MAX_FREE_FORMAT_FRAME_SIZE && i + 2*k < mp3_bytes - DRMP3_HDR_SIZE; k++) + { + if (drmp3_hdr_compare(mp3, mp3 + k)) + { + int fb = k - drmp3_hdr_padding(mp3); + int nextfb = fb + drmp3_hdr_padding(mp3 + k); + if (i + k + nextfb + DRMP3_HDR_SIZE > mp3_bytes || !drmp3_hdr_compare(mp3, mp3 + k + nextfb)) + continue; + frame_and_padding = k; + frame_bytes = fb; + *free_format_bytes = fb; + } + } + + if ((frame_bytes && i + frame_and_padding <= mp3_bytes && + drmp3d_match_frame(mp3, mp3_bytes - i, frame_bytes)) || + (!i && frame_and_padding == mp3_bytes)) + { + *ptr_frame_bytes = frame_and_padding; + return i; + } + *free_format_bytes = 0; + } + } + *ptr_frame_bytes = 0; + return i; +} + +void drmp3dec_init(drmp3dec *dec) +{ + dec->header[0] = 0; +} + +int drmp3dec_decode_frame(drmp3dec *dec, const unsigned char *mp3, int mp3_bytes, short *pcm, drmp3dec_frame_info *info) +{ + int i = 0, igr, frame_size = 0, success = 1; + const drmp3_uint8 *hdr; + drmp3_bs bs_frame[1]; + drmp3dec_scratch scratch; + + if (mp3_bytes > 4 && dec->header[0] == 0xff && drmp3_hdr_compare(dec->header, mp3)) + { + frame_size = drmp3_hdr_frame_bytes(mp3, dec->free_format_bytes) + drmp3_hdr_padding(mp3); + if (frame_size != mp3_bytes && (frame_size + DRMP3_HDR_SIZE > mp3_bytes || !drmp3_hdr_compare(mp3, mp3 + frame_size))) + { + frame_size = 0; + } + } + if (!frame_size) + { + memset(dec, 0, sizeof(drmp3dec)); + i = drmp3d_find_frame(mp3, mp3_bytes, &dec->free_format_bytes, &frame_size); + if (!frame_size || i + frame_size > mp3_bytes) + { + info->frame_bytes = i; + return 0; + } + } + + hdr = mp3 + i; + memcpy(dec->header, hdr, DRMP3_HDR_SIZE); + info->frame_bytes = i + frame_size; + info->channels = DRMP3_HDR_IS_MONO(hdr) ? 1 : 2; + info->hz = drmp3_hdr_sample_rate_hz(hdr); + info->layer = 4 - DRMP3_HDR_GET_LAYER(hdr); + info->bitrate_kbps = drmp3_hdr_bitrate_kbps(hdr); + + drmp3_bs_init(bs_frame, hdr + DRMP3_HDR_SIZE, frame_size - DRMP3_HDR_SIZE); + if (DRMP3_HDR_IS_CRC(hdr)) + { + drmp3_bs_get_bits(bs_frame, 16); + } + + if (info->layer == 3) + { + int main_data_begin = drmp3_L3_read_side_info(bs_frame, scratch.gr_info, hdr); + if (main_data_begin < 0 || bs_frame->pos > bs_frame->limit) + { + drmp3dec_init(dec); + return 0; + } + success = drmp3_L3_restore_reservoir(dec, bs_frame, &scratch, main_data_begin); + if (success) + { + for (igr = 0; igr < (DRMP3_HDR_TEST_MPEG1(hdr) ? 2 : 1); igr++, pcm += 576*info->channels) + { + memset(scratch.grbuf[0], 0, 576*2*sizeof(float)); + drmp3_L3_decode(dec, &scratch, scratch.gr_info + igr*info->channels, info->channels); + drmp3d_synth_granule(dec->qmf_state, scratch.grbuf[0], 18, info->channels, pcm, scratch.syn[0]); + } + } + drmp3_L3_save_reservoir(dec, &scratch); + } else + { +#ifdef DR_MP3_ONLY_MP3 + return 0; +#else + drmp3_L12_scale_info sci[1]; + drmp3_L12_read_scale_info(hdr, bs_frame, sci); + + memset(scratch.grbuf[0], 0, 576*2*sizeof(float)); + for (i = 0, igr = 0; igr < 3; igr++) + { + if (12 == (i += drmp3_L12_dequantize_granule(scratch.grbuf[0] + i, bs_frame, sci, info->layer | 1))) + { + i = 0; + drmp3_L12_apply_scf_384(sci, sci->scf + igr, scratch.grbuf[0]); + drmp3d_synth_granule(dec->qmf_state, scratch.grbuf[0], 12, info->channels, pcm, scratch.syn[0]); + memset(scratch.grbuf[0], 0, 576*2*sizeof(float)); + pcm += 384*info->channels; + } + if (bs_frame->pos > bs_frame->limit) + { + drmp3dec_init(dec); + return 0; + } + } +#endif + } + return success*drmp3_hdr_frame_samples(dec->header); +} + + + + +/////////////////////////////////////////////////////////////////////////////// +// +// Main Public API +// +/////////////////////////////////////////////////////////////////////////////// + +// Options. +#ifndef DR_MP3_DEFAULT_CHANNELS +#define DR_MP3_DEFAULT_CHANNELS 2 +#endif +#ifndef DR_MP3_DEFAULT_SAMPLE_RATE +#define DR_MP3_DEFAULT_SAMPLE_RATE 44100 +#endif + + +// Standard library stuff. +#ifndef DRMP3_ASSERT +#include +#define DRMP3_ASSERT(expression) assert(expression) +#endif +#ifndef DRMP3_COPY_MEMORY +#define DRMP3_COPY_MEMORY(dst, src, sz) memcpy((dst), (src), (sz)) +#endif +#ifndef DRMP3_ZERO_MEMORY +#define DRMP3_ZERO_MEMORY(p, sz) memset((p), 0, (sz)) +#endif +#define DRMP3_ZERO_OBJECT(p) DRMP3_ZERO_MEMORY((p), sizeof(*(p))) +#ifndef DRMP3_MALLOC +#define DRMP3_MALLOC(sz) malloc((sz)) +#endif +#ifndef DRMP3_REALLOC +#define DRMP3_REALLOC(p, sz) realloc((p), (sz)) +#endif +#ifndef DRMP3_FREE +#define DRMP3_FREE(p) free((p)) +#endif + +#define drmp3_assert DRMP3_ASSERT +#define drmp3_copy_memory DRMP3_COPY_MEMORY +#define drmp3_zero_memory DRMP3_ZERO_MEMORY +#define drmp3_zero_object DRMP3_ZERO_OBJECT +#define drmp3_malloc DRMP3_MALLOC +#define drmp3_realloc DRMP3_REALLOC + +#define drmp3_countof(x) (sizeof(x) / sizeof(x[0])) +#define drmp3_max(x, y) (((x) > (y)) ? (x) : (y)) +#define drmp3_min(x, y) (((x) < (y)) ? (x) : (y)) + +#define DRMP3_DATA_CHUNK_SIZE 16384 // The size in bytes of each chunk of data to read from the MP3 stream. minimp3 recommends 16K. + +static inline float drmp3_mix_f32(float x, float y, float a) +{ + return x*(1-a) + y*a; +} + +static void drmp3_blend_f32(float* pOut, float* pInA, float* pInB, float factor, drmp3_uint32 channels) +{ + for (drmp3_uint32 i = 0; i < channels; ++i) { + pOut[i] = drmp3_mix_f32(pInA[i], pInB[i], factor); + } +} + +void drmp3_src_cache_init(drmp3_src* pSRC, drmp3_src_cache* pCache) +{ + drmp3_assert(pSRC != NULL); + drmp3_assert(pCache != NULL); + + pCache->pSRC = pSRC; + pCache->cachedFrameCount = 0; + pCache->iNextFrame = 0; +} + +drmp3_uint64 drmp3_src_cache_read_frames(drmp3_src_cache* pCache, drmp3_uint64 frameCount, float* pFramesOut) +{ + drmp3_assert(pCache != NULL); + drmp3_assert(pCache->pSRC != NULL); + drmp3_assert(pCache->pSRC->onRead != NULL); + drmp3_assert(frameCount > 0); + drmp3_assert(pFramesOut != NULL); + + drmp3_uint32 channels = pCache->pSRC->config.channels; + + drmp3_uint64 totalFramesRead = 0; + while (frameCount > 0) { + // If there's anything in memory go ahead and copy that over first. + drmp3_uint64 framesRemainingInMemory = pCache->cachedFrameCount - pCache->iNextFrame; + drmp3_uint64 framesToReadFromMemory = frameCount; + if (framesToReadFromMemory > framesRemainingInMemory) { + framesToReadFromMemory = framesRemainingInMemory; + } + + drmp3_copy_memory(pFramesOut, pCache->pCachedFrames + pCache->iNextFrame*channels, (drmp3_uint32)(framesToReadFromMemory * channels * sizeof(float))); + pCache->iNextFrame += (drmp3_uint32)framesToReadFromMemory; + + totalFramesRead += framesToReadFromMemory; + frameCount -= framesToReadFromMemory; + if (frameCount == 0) { + break; + } + + + // At this point there are still more frames to read from the client, so we'll need to reload the cache with fresh data. + drmp3_assert(frameCount > 0); + pFramesOut += framesToReadFromMemory * channels; + + pCache->iNextFrame = 0; + pCache->cachedFrameCount = 0; + + drmp3_uint32 framesToReadFromClient = drmp3_countof(pCache->pCachedFrames) / pCache->pSRC->config.channels; + if (framesToReadFromClient > pCache->pSRC->config.cacheSizeInFrames) { + framesToReadFromClient = pCache->pSRC->config.cacheSizeInFrames; + } + + pCache->cachedFrameCount = (drmp3_uint32)pCache->pSRC->onRead(pCache->pSRC, framesToReadFromClient, pCache->pCachedFrames, pCache->pSRC->pUserData); + + + // Get out of this loop if nothing was able to be retrieved. + if (pCache->cachedFrameCount == 0) { + break; + } + } + + return totalFramesRead; +} + + +drmp3_uint64 drmp3_src_read_frames_passthrough(drmp3_src* pSRC, drmp3_uint64 frameCount, void* pFramesOut, drmp3_bool32 flush); +drmp3_uint64 drmp3_src_read_frames_linear(drmp3_src* pSRC, drmp3_uint64 frameCount, void* pFramesOut, drmp3_bool32 flush); + +drmp3_bool32 drmp3_src_init(const drmp3_src_config* pConfig, drmp3_src_read_proc onRead, void* pUserData, drmp3_src* pSRC) +{ + if (pSRC == NULL) return DRMP3_FALSE; + drmp3_zero_object(pSRC); + + if (pConfig == NULL || onRead == NULL) return DRMP3_FALSE; + if (pConfig->channels == 0 || pConfig->channels > 2) return DRMP3_FALSE; + + pSRC->config = *pConfig; + pSRC->onRead = onRead; + pSRC->pUserData = pUserData; + + if (pSRC->config.cacheSizeInFrames > DRMP3_SRC_CACHE_SIZE_IN_FRAMES || pSRC->config.cacheSizeInFrames == 0) { + pSRC->config.cacheSizeInFrames = DRMP3_SRC_CACHE_SIZE_IN_FRAMES; + } + + drmp3_src_cache_init(pSRC, &pSRC->cache); + return DRMP3_TRUE; +} + +drmp3_bool32 drmp3_src_set_input_sample_rate(drmp3_src* pSRC, drmp3_uint32 sampleRateIn) +{ + if (pSRC == NULL) return DRMP3_FALSE; + + // Must have a sample rate of > 0. + if (sampleRateIn == 0) { + return DRMP3_FALSE; + } + + pSRC->config.sampleRateIn = sampleRateIn; + return DRMP3_TRUE; +} + +drmp3_bool32 drmp3_src_set_output_sample_rate(drmp3_src* pSRC, drmp3_uint32 sampleRateOut) +{ + if (pSRC == NULL) return DRMP3_FALSE; + + // Must have a sample rate of > 0. + if (sampleRateOut == 0) { + return DRMP3_FALSE; + } + + pSRC->config.sampleRateOut = sampleRateOut; + return DRMP3_TRUE; +} + +drmp3_uint64 drmp3_src_read_frames_ex(drmp3_src* pSRC, drmp3_uint64 frameCount, void* pFramesOut, drmp3_bool32 flush) +{ + if (pSRC == NULL || frameCount == 0 || pFramesOut == NULL) return 0; + + drmp3_src_algorithm algorithm = pSRC->config.algorithm; + + // Always use passthrough if the sample rates are the same. + if (pSRC->config.sampleRateIn == pSRC->config.sampleRateOut) { + algorithm = drmp3_src_algorithm_none; + } + + // Could just use a function pointer instead of a switch for this... + switch (algorithm) + { + case drmp3_src_algorithm_none: return drmp3_src_read_frames_passthrough(pSRC, frameCount, pFramesOut, flush); + case drmp3_src_algorithm_linear: return drmp3_src_read_frames_linear(pSRC, frameCount, pFramesOut, flush); + default: return 0; + } +} + +drmp3_uint64 drmp3_src_read_frames(drmp3_src* pSRC, drmp3_uint64 frameCount, void* pFramesOut) +{ + return drmp3_src_read_frames_ex(pSRC, frameCount, pFramesOut, DRMP3_FALSE); +} + +drmp3_uint64 drmp3_src_read_frames_passthrough(drmp3_src* pSRC, drmp3_uint64 frameCount, void* pFramesOut, drmp3_bool32 flush) +{ + drmp3_assert(pSRC != NULL); + drmp3_assert(frameCount > 0); + drmp3_assert(pFramesOut != NULL); + + (void)flush; // Passthrough need not care about flushing. + return pSRC->onRead(pSRC, frameCount, pFramesOut, pSRC->pUserData); +} + +drmp3_uint64 drmp3_src_read_frames_linear(drmp3_src* pSRC, drmp3_uint64 frameCount, void* pFramesOut, drmp3_bool32 flush) +{ + drmp3_assert(pSRC != NULL); + drmp3_assert(frameCount > 0); + drmp3_assert(pFramesOut != NULL); + + // For linear SRC, the bin is only 2 frames: 1 prior, 1 future. + + // Load the bin if necessary. + if (!pSRC->algo.linear.isPrevFramesLoaded) { + drmp3_uint64 framesRead = drmp3_src_cache_read_frames(&pSRC->cache, 1, pSRC->bin); + if (framesRead == 0) { + return 0; + } + pSRC->algo.linear.isPrevFramesLoaded = DRMP3_TRUE; + } + if (!pSRC->algo.linear.isNextFramesLoaded) { + drmp3_uint64 framesRead = drmp3_src_cache_read_frames(&pSRC->cache, 1, pSRC->bin + pSRC->config.channels); + if (framesRead == 0) { + return 0; + } + pSRC->algo.linear.isNextFramesLoaded = DRMP3_TRUE; + } + + float factor = (float)pSRC->config.sampleRateIn / pSRC->config.sampleRateOut; + + drmp3_uint64 totalFramesRead = 0; + while (frameCount > 0) { + // The bin is where the previous and next frames are located. + float* pPrevFrame = pSRC->bin; + float* pNextFrame = pSRC->bin + pSRC->config.channels; + + drmp3_blend_f32((float*)pFramesOut, pPrevFrame, pNextFrame, pSRC->algo.linear.alpha, pSRC->config.channels); + + pSRC->algo.linear.alpha += factor; + + // The new alpha value is how we determine whether or not we need to read fresh frames. + drmp3_uint32 framesToReadFromClient = (drmp3_uint32)pSRC->algo.linear.alpha; + pSRC->algo.linear.alpha = pSRC->algo.linear.alpha - framesToReadFromClient; + + for (drmp3_uint32 i = 0; i < framesToReadFromClient; ++i) { + for (drmp3_uint32 j = 0; j < pSRC->config.channels; ++j) { + pPrevFrame[j] = pNextFrame[j]; + } + + drmp3_uint64 framesRead = drmp3_src_cache_read_frames(&pSRC->cache, 1, pNextFrame); + if (framesRead == 0) { + for (drmp3_uint32 j = 0; j < pSRC->config.channels; ++j) { + pNextFrame[j] = 0; + } + + if (pSRC->algo.linear.isNextFramesLoaded) { + pSRC->algo.linear.isNextFramesLoaded = DRMP3_FALSE; + } else { + if (flush) { + pSRC->algo.linear.isPrevFramesLoaded = DRMP3_FALSE; + } + } + + break; + } + } + + pFramesOut = (drmp3_uint8*)pFramesOut + (1 * pSRC->config.channels * sizeof(float)); + frameCount -= 1; + totalFramesRead += 1; + + // If there's no frames available we need to get out of this loop. + if (!pSRC->algo.linear.isNextFramesLoaded && (!flush || !pSRC->algo.linear.isPrevFramesLoaded)) { + break; + } + } + + return totalFramesRead; +} + + + +static drmp3_bool32 drmp3_decode_next_frame(drmp3* pMP3) +{ + drmp3_assert(pMP3 != NULL); + drmp3_assert(pMP3->onRead != NULL); + + if (pMP3->atEnd) { + return DRMP3_FALSE; + } + + do + { + // minimp3 recommends doing data submission in 16K chunks. If we don't have at least 16K bytes available, get more. + if (pMP3->dataSize < DRMP3_DATA_CHUNK_SIZE) { + if (pMP3->dataCapacity < DRMP3_DATA_CHUNK_SIZE) { + pMP3->dataCapacity = DRMP3_DATA_CHUNK_SIZE; + drmp3_uint8* pNewData = (drmp3_uint8*)drmp3_realloc(pMP3->pData, pMP3->dataCapacity); + if (pNewData == NULL) { + return DRMP3_FALSE; // Out of memory. + } + + pMP3->pData = pNewData; + } + + size_t bytesRead = pMP3->onRead(pMP3->pUserData, pMP3->pData + pMP3->dataSize, (pMP3->dataCapacity - pMP3->dataSize)); + if (bytesRead == 0) { + pMP3->atEnd = DRMP3_TRUE; + return DRMP3_FALSE; // No data. + } + + pMP3->dataSize += bytesRead; + } + + if (pMP3->dataSize > INT_MAX) { + pMP3->atEnd = DRMP3_TRUE; + return DRMP3_FALSE; // File too big. + } + + drmp3dec_frame_info info; + drmp3_uint32 samplesRead = drmp3dec_decode_frame(&pMP3->decoder, pMP3->pData, (int)pMP3->dataSize, pMP3->frames, &info); // <-- Safe size_t -> int conversion thanks to the check above. + if (samplesRead != 0) { + size_t leftoverDataSize = (pMP3->dataSize - (size_t)info.frame_bytes); + for (size_t i = 0; i < leftoverDataSize; ++i) { + pMP3->pData[i] = pMP3->pData[i + (size_t)info.frame_bytes]; + } + + pMP3->dataSize = leftoverDataSize; + pMP3->framesConsumed = 0; + pMP3->framesRemaining = samplesRead; + pMP3->frameChannels = info.channels; + pMP3->frameSampleRate = info.hz; + drmp3_src_set_input_sample_rate(&pMP3->src, pMP3->frameSampleRate); + break; + } else { + // Need more data. minimp3 recommends doing data submission in 16K chunks. + if (pMP3->dataCapacity == pMP3->dataSize) { + // No room. Expand. + pMP3->dataCapacity += DRMP3_DATA_CHUNK_SIZE; + drmp3_uint8* pNewData = (drmp3_uint8*)drmp3_realloc(pMP3->pData, pMP3->dataCapacity); + if (pNewData == NULL) { + return DRMP3_FALSE; // Out of memory. + } + + pMP3->pData = pNewData; + } + + // Fill in a chunk. + size_t bytesRead = pMP3->onRead(pMP3->pUserData, pMP3->pData + pMP3->dataSize, (pMP3->dataCapacity - pMP3->dataSize)); + if (bytesRead == 0) { + pMP3->atEnd = DRMP3_TRUE; + return DRMP3_FALSE; // Error reading more data. + } + + pMP3->dataSize += bytesRead; + } + } while (DRMP3_TRUE); + + return DRMP3_TRUE; +} + +static drmp3_uint64 drmp3_read_src(drmp3_src* pSRC, drmp3_uint64 frameCount, void* pFramesOut, void* pUserData) +{ + drmp3* pMP3 = (drmp3*)pUserData; + drmp3_assert(pMP3 != NULL); + drmp3_assert(pMP3->onRead != NULL); + + float* pFramesOutF = (float*)pFramesOut; + drmp3_uint32 totalFramesRead = 0; + + while (frameCount > 0) { + // Read from the in-memory buffer first. + while (pMP3->framesRemaining > 0 && frameCount > 0) { + if (pMP3->frameChannels == 1) { + if (pMP3->channels == 1) { + // Mono -> Mono. + pFramesOutF[0] = pMP3->frames[pMP3->framesConsumed] / 32768.0f; + } else { + // Mono -> Stereo. + pFramesOutF[0] = pMP3->frames[pMP3->framesConsumed] / 32768.0f; + pFramesOutF[1] = pMP3->frames[pMP3->framesConsumed] / 32768.0f; + } + } else { + if (pMP3->channels == 1) { + // Stereo -> Mono + float sample = 0; + sample += pMP3->frames[(pMP3->framesConsumed*pMP3->frameChannels)+0] / 32768.0f; + sample += pMP3->frames[(pMP3->framesConsumed*pMP3->frameChannels)+1] / 32768.0f; + pFramesOutF[0] = sample * 0.5f; + } else { + // Stereo -> Stereo + pFramesOutF[0] = pMP3->frames[(pMP3->framesConsumed*pMP3->frameChannels)+0] / 32768.0f; + pFramesOutF[1] = pMP3->frames[(pMP3->framesConsumed*pMP3->frameChannels)+1] / 32768.0f; + } + } + + pMP3->framesConsumed += 1; + pMP3->framesRemaining -= 1; + frameCount -= 1; + totalFramesRead += 1; + pFramesOutF += pSRC->config.channels; + } + + if (frameCount == 0) { + break; + } + + drmp3_assert(pMP3->framesRemaining == 0); + + // At this point we have exhausted our in-memory buffer so we need to re-fill. Note that the sample rate may have changed + // at this point which means we'll also need to update our sample rate conversion pipeline. + if (!drmp3_decode_next_frame(pMP3)) { + break; + } + } + + return totalFramesRead; +} + +drmp3_bool32 drmp3_init_internal(drmp3* pMP3, drmp3_read_proc onRead, drmp3_seek_proc onSeek, void* pUserData, const drmp3_config* pConfig) +{ + drmp3_assert(pMP3 != NULL); + drmp3_assert(onRead != NULL); + + // This function assumes the output object has already been reset to 0. Do not do that here, otherwise things will break. + drmp3dec_init(&pMP3->decoder); + + // The config can be null in which case we use defaults. + drmp3_config config; + if (pConfig != NULL) { + config = *pConfig; + } else { + drmp3_zero_object(&config); + } + + pMP3->channels = config.outputChannels; + if (pMP3->channels == 0) { + pMP3->channels = DR_MP3_DEFAULT_CHANNELS; + } + + // Cannot have more than 2 channels. + if (pMP3->channels > 2) { + pMP3->channels = 2; + } + + pMP3->sampleRate = config.outputSampleRate; + if (pMP3->sampleRate == 0) { + pMP3->sampleRate = DR_MP3_DEFAULT_SAMPLE_RATE; + } + + pMP3->onRead = onRead; + pMP3->onSeek = onSeek; + pMP3->pUserData = pUserData; + + // We need a sample rate converter for converting the sample rate from the MP3 frames to the requested output sample rate. + drmp3_src_config srcConfig; + drmp3_zero_object(&srcConfig); + srcConfig.sampleRateIn = DR_MP3_DEFAULT_SAMPLE_RATE; + srcConfig.sampleRateOut = pMP3->sampleRate; + srcConfig.channels = pMP3->channels; + srcConfig.algorithm = drmp3_src_algorithm_linear; + if (!drmp3_src_init(&srcConfig, drmp3_read_src, pMP3, &pMP3->src)) { + return DRMP3_FALSE; + } + + // Decode the first frame to confirm that it is indeed a valid MP3 stream. + if (!drmp3_decode_next_frame(pMP3)) { + return DRMP3_FALSE; // Not a valid MP3 stream. + } + + return DRMP3_TRUE; +} + +drmp3_bool32 drmp3_init(drmp3* pMP3, drmp3_read_proc onRead, drmp3_seek_proc onSeek, void* pUserData, const drmp3_config* pConfig) +{ + if (pMP3 == NULL || onRead == NULL) { + return DRMP3_FALSE; + } + + drmp3_zero_object(pMP3); + return drmp3_init_internal(pMP3, onRead, onSeek, pUserData, pConfig); +} + + +static size_t drmp3__on_read_memory(void* pUserData, void* pBufferOut, size_t bytesToRead) +{ + drmp3* pMP3 = (drmp3*)pUserData; + drmp3_assert(pMP3 != NULL); + drmp3_assert(pMP3->memory.dataSize >= pMP3->memory.currentReadPos); + + size_t bytesRemaining = pMP3->memory.dataSize - pMP3->memory.currentReadPos; + if (bytesToRead > bytesRemaining) { + bytesToRead = bytesRemaining; + } + + if (bytesToRead > 0) { + drmp3_copy_memory(pBufferOut, pMP3->memory.pData + pMP3->memory.currentReadPos, bytesToRead); + pMP3->memory.currentReadPos += bytesToRead; + } + + return bytesToRead; +} + +static drmp3_bool32 drmp3__on_seek_memory(void* pUserData, int byteOffset, drmp3_seek_origin origin) +{ + drmp3* pMP3 = (drmp3*)pUserData; + drmp3_assert(pMP3 != NULL); + + if (origin == drmp3_seek_origin_current) { + if (byteOffset > 0) { + if (pMP3->memory.currentReadPos + byteOffset > pMP3->memory.dataSize) { + byteOffset = (int)(pMP3->memory.dataSize - pMP3->memory.currentReadPos); // Trying to seek too far forward. + } + } else { + if (pMP3->memory.currentReadPos < (size_t)-byteOffset) { + byteOffset = -(int)pMP3->memory.currentReadPos; // Trying to seek too far backwards. + } + } + + // This will never underflow thanks to the clamps above. + pMP3->memory.currentReadPos += byteOffset; + } else { + if ((drmp3_uint32)byteOffset <= pMP3->memory.dataSize) { + pMP3->memory.currentReadPos = byteOffset; + } else { + pMP3->memory.currentReadPos = pMP3->memory.dataSize; // Trying to seek too far forward. + } + } + + return DRMP3_TRUE; +} + +drmp3_bool32 drmp3_init_memory(drmp3* pMP3, const void* pData, size_t dataSize, const drmp3_config* pConfig) +{ + if (pMP3 == NULL) { + return DRMP3_FALSE; + } + + drmp3_zero_object(pMP3); + + if (pData == NULL || dataSize == 0) { + return DRMP3_FALSE; + } + + pMP3->memory.pData = (const drmp3_uint8*)pData; + pMP3->memory.dataSize = dataSize; + pMP3->memory.currentReadPos = 0; + + return drmp3_init_internal(pMP3, drmp3__on_read_memory, drmp3__on_seek_memory, pMP3, pConfig); +} + + +#ifndef DR_MP3_NO_STDIO +#include + +static size_t drmp3__on_read_stdio(void* pUserData, void* pBufferOut, size_t bytesToRead) +{ + return fread(pBufferOut, 1, bytesToRead, (FILE*)pUserData); +} + +static drmp3_bool32 drmp3__on_seek_stdio(void* pUserData, int offset, drmp3_seek_origin origin) +{ + return fseek((FILE*)pUserData, offset, (origin == drmp3_seek_origin_current) ? SEEK_CUR : SEEK_SET) == 0; +} + +drmp3_bool32 drmp3_init_file(drmp3* pMP3, const char* filePath, const drmp3_config* pConfig) +{ + FILE* pFile; +#if defined(_MSC_VER) && _MSC_VER >= 1400 + if (fopen_s(&pFile, filePath, "rb") != 0) { + return DRMP3_FALSE; + } +#else + pFile = fopen(filePath, "rb"); + if (pFile == NULL) { + return DRMP3_FALSE; + } +#endif + + return drmp3_init(pMP3, drmp3__on_read_stdio, drmp3__on_seek_stdio, (void*)pFile, pConfig); +} +#endif + +void drmp3_uninit(drmp3* pMP3) +{ + if (pMP3 == NULL) return; + +#ifndef DR_MP3_NO_STDIO + if (pMP3->onRead == drmp3__on_read_stdio) { + fclose((FILE*)pMP3->pUserData); + } +#endif + + drmp3_free(pMP3->pData); +} + +drmp3_uint64 drmp3_read_f32(drmp3* pMP3, drmp3_uint64 framesToRead, float* pBufferOut) +{ + if (pMP3 == NULL || pMP3->onRead == NULL) return 0; + + drmp3_uint64 totalFramesRead = 0; + + if (pBufferOut == NULL) { + float temp[4096]; + while (framesToRead > 0) { + drmp3_uint64 framesToReadRightNow = sizeof(temp)/sizeof(temp[0]) / pMP3->channels; + if (framesToReadRightNow > framesToRead) { + framesToReadRightNow = framesToRead; + } + + drmp3_uint64 framesJustRead = drmp3_read_f32(pMP3, framesToReadRightNow, temp); + if (framesJustRead == 0) { + break; + } + + framesToRead -= framesJustRead; + totalFramesRead += framesJustRead; + } + } else { + totalFramesRead = drmp3_src_read_frames_ex(&pMP3->src, framesToRead, pBufferOut, DRMP3_TRUE); + } + + return totalFramesRead; +} + +drmp3_bool32 drmp3_seek_to_frame(drmp3* pMP3, drmp3_uint64 frameIndex) +{ + if (pMP3 == NULL || pMP3->onSeek == NULL) return DRMP3_FALSE; + + // Seek to the start of the stream to begin with. + if (!pMP3->onSeek(pMP3->pUserData, 0, drmp3_seek_origin_start)) { + return DRMP3_FALSE; + } + + // Clear any cached data. + pMP3->framesConsumed = 0; + pMP3->framesRemaining = 0; + pMP3->dataSize = 0; + pMP3->atEnd = DRMP3_FALSE; + + // TODO: Optimize. + // + // This is inefficient. We simply read frames from the start of the stream. + drmp3_uint64 framesRead = drmp3_read_f32(pMP3, frameIndex, NULL); + if (framesRead != frameIndex) { + return DRMP3_FALSE; + } + + return DRMP3_TRUE; +} + + + +float* drmp3__full_decode_and_close_f32(drmp3* pMP3, drmp3_config* pConfig, drmp3_uint64* pTotalFrameCount) +{ + drmp3_assert(pMP3 != NULL); + + drmp3_uint64 totalFramesRead = 0; + drmp3_uint64 framesCapacity = 0; + float* pFrames = NULL; + + float temp[4096]; + for (;;) { + drmp3_uint64 framesToReadRightNow = drmp3_countof(temp) / pMP3->channels; + drmp3_uint64 framesJustRead = drmp3_read_f32(pMP3, framesToReadRightNow, temp); + if (framesJustRead == 0) { + break; + } + + // Reallocate the output buffer if there's not enough room. + if (framesCapacity < totalFramesRead + framesJustRead) { + framesCapacity *= 2; + if (framesCapacity < totalFramesRead + framesJustRead) { + framesCapacity = totalFramesRead + framesJustRead; + } + + drmp3_uint64 newFramesBufferSize = framesCapacity*pMP3->channels*sizeof(float); + if (newFramesBufferSize > SIZE_MAX) { + break; + } + + float* pNewFrames = (float*)drmp3_realloc(pFrames, (size_t)newFramesBufferSize); + if (pNewFrames == NULL) { + drmp3_free(pFrames); + break; + } + + pFrames = pNewFrames; + } + + drmp3_copy_memory(pFrames + totalFramesRead*pMP3->channels, temp, (size_t)(framesJustRead*pMP3->channels*sizeof(float))); + totalFramesRead += framesJustRead; + + // If the number of frames we asked for is less that what we actually read it means we've reached the end. + if (framesJustRead != framesToReadRightNow) { + break; + } + } + + if (pConfig != NULL) { + pConfig->outputChannels = pMP3->channels; + pConfig->outputSampleRate = pMP3->sampleRate; + } + + drmp3_uninit(pMP3); + + if (pTotalFrameCount) *pTotalFrameCount = totalFramesRead; + return pFrames; +} + +float* drmp3_open_and_decode_f32(drmp3_read_proc onRead, drmp3_seek_proc onSeek, void* pUserData, drmp3_config* pConfig, drmp3_uint64* pTotalFrameCount) +{ + drmp3 mp3; + if (!drmp3_init(&mp3, onRead, onSeek, pUserData, pConfig)) { + return NULL; + } + + return drmp3__full_decode_and_close_f32(&mp3, pConfig, pTotalFrameCount); +} + +float* drmp3_open_and_decode_memory_f32(const void* pData, size_t dataSize, drmp3_config* pConfig, drmp3_uint64* pTotalFrameCount) +{ + drmp3 mp3; + if (!drmp3_init_memory(&mp3, pData, dataSize, pConfig)) { + return NULL; + } + + return drmp3__full_decode_and_close_f32(&mp3, pConfig, pTotalFrameCount); +} + +#ifndef DR_MP3_NO_STDIO +float* drmp3_open_and_decode_file_f32(const char* filePath, drmp3_config* pConfig, drmp3_uint64* pTotalFrameCount) +{ + drmp3 mp3; + if (!drmp3_init_file(&mp3, filePath, pConfig)) { + return NULL; + } + + return drmp3__full_decode_and_close_f32(&mp3, pConfig, pTotalFrameCount); +} +#endif + +void drmp3_free(void* p) +{ + DRMP3_FREE(p); +} + +#endif /*DR_MP3_IMPLEMENTATION*/ + + +// DIFFERENCES BETWEEN minimp3 AND dr_mp3 +// ====================================== +// - First, keep in mind that minimp3 (https://github.com/lieff/minimp3) is where all the real work was done. All of the +// code relating to the actual decoding remains mostly unmodified, apart from some namespacing changes. +// - dr_mp3 adds a pulling style API which allows you to deliver raw data via callbacks. So, rather than pushing data +// to the decoder, the decoder _pulls_ data from your callbacks. +// - In addition to callbacks, a decoder can be initialized from a block of memory and a file. +// - The dr_mp3 pull API reads PCM frames rather than whole MP3 frames. +// - dr_mp3 adds convenience APIs for opening and decoding entire files in one go. +// - dr_mp3 is fully namespaced, including the implementation section, which is more suitable when compiling projects +// as a single translation unit (aka unity builds). At the time of writing this, a unity build is not possible when +// using minimp3 in conjunction with stb_vorbis. dr_mp3 addresses this. + + +// REVISION HISTORY +// =============== +// +// v0.2.3 - 2018-04-29 +// - Fix TCC build. +// +// v0.2.2 - 2018-04-28 +// - Fix bug when opening a decoder from memory. +// +// v0.2.1 - 2018-04-27 +// - Efficiency improvements when the decoder reaches the end of the stream. +// +// v0.2 - 2018-04-21 +// - Bring up to date with minimp3. +// - Start using major.minor.revision versioning. +// +// v0.1d - 2018-03-30 +// - Bring up to date with minimp3. +// +// v0.1c - 2018-03-11 +// - Fix C++ build error. +// +// v0.1b - 2018-03-07 +// - Bring up to date with minimp3. +// +// v0.1a - 2018-02-28 +// - Fix compilation error on GCC/Clang. +// - Fix some warnings. +// +// v0.1 - 2018-02-xx +// - Initial versioned release. + + +/* +This is free and unencumbered software released into the public domain. + +Anyone is free to copy, modify, publish, use, compile, sell, or +distribute this software, either in source code form or as a compiled +binary, for any purpose, commercial or non-commercial, and by any +means. + +In jurisdictions that recognize copyright laws, the author or authors +of this software dedicate any and all copyright interest in the +software to the public domain. We make this dedication for the benefit +of the public at large and to the detriment of our heirs and +successors. We intend this dedication to be an overt act of +relinquishment in perpetuity of all present and future rights to this +software under copyright law. + +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 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. + +For more information, please refer to +*/ + +/* + https://github.com/lieff/minimp3 + To the extent possible under law, the author(s) have dedicated all copyright and related and neighboring rights to this software to the public domain worldwide. + This software is distributed without any warranty. + See . +*/ diff --git a/src/raylib.h b/src/raylib.h index b5a6a1914..e83650e6c 100644 --- a/src/raylib.h +++ b/src/raylib.h @@ -382,7 +382,7 @@ typedef struct RenderTexture2D { Texture2D depth; // Depth buffer attachment texture } RenderTexture2D; -// SpriteFont character info +// Font character info typedef struct CharInfo { int value; // Character value (Unicode) Rectangle rec; // Character rectangle in sprite font @@ -391,13 +391,15 @@ typedef struct CharInfo { int advanceX; // Character advance position X } CharInfo; -// SpriteFont type, includes texture and charSet array data -typedef struct SpriteFont { +// Font type, includes texture and charSet array data +typedef struct Font { Texture2D texture; // Font texture int baseSize; // Base size (default chars height) int charsCount; // Number of characters CharInfo *chars; // Characters info data -} SpriteFont; +} Font; + +#define SpriteFont Font // SpriteFont type fallback, defaults to Font // Camera type, defines a camera position/orientation in 3d space typedef struct Camera3D { @@ -915,11 +917,11 @@ RLAPI void ImageResizeNN(Image *image,int newWidth,int newHeight); RLAPI void ImageMipmaps(Image *image); // Generate all mipmap levels for a provided image RLAPI void ImageDither(Image *image, int rBpp, int gBpp, int bBpp, int aBpp); // Dither image data to 16bpp or lower (Floyd-Steinberg dithering) RLAPI Image ImageText(const char *text, int fontSize, Color color); // Create an image from text (default font) -RLAPI Image ImageTextEx(SpriteFont font, const char *text, float fontSize, float spacing, Color tint); // Create an image from text (custom sprite font) +RLAPI Image ImageTextEx(Font font, const char *text, float fontSize, float spacing, Color tint); // Create an image from text (custom sprite font) RLAPI void ImageDraw(Image *dst, Image src, Rectangle srcRec, Rectangle dstRec); // Draw a source image within a destination image RLAPI void ImageDrawRectangle(Image *dst, Vector2 position, Rectangle rec, Color color); // Draw rectangle within an image RLAPI void ImageDrawText(Image *dst, Vector2 position, const char *text, int fontSize, Color color); // Draw text (default font) within an image (destination) -RLAPI void ImageDrawTextEx(Image *dst, Vector2 position, SpriteFont font, const char *text, float fontSize, float spacing, Color color); // Draw text (custom sprite font) within an image (destination) +RLAPI void ImageDrawTextEx(Image *dst, Vector2 position, Font font, const char *text, float fontSize, float spacing, Color color); // Draw text (custom sprite font) within an image (destination) RLAPI void ImageFlipVertical(Image *image); // Flip image vertically RLAPI void ImageFlipHorizontal(Image *image); // Flip image horizontally RLAPI void ImageColorTint(Image *image, Color color); // Modify image color: tint @@ -955,23 +957,23 @@ RLAPI void DrawTexturePro(Texture2D texture, Rectangle sourceRec, Rectangle dest // Font Loading and Text Drawing Functions (Module: text) //------------------------------------------------------------------------------------ -// SpriteFont loading/unloading functions -RLAPI SpriteFont GetDefaultFont(void); // Get the default SpriteFont -RLAPI SpriteFont LoadSpriteFont(const char *fileName); // Load SpriteFont from file into GPU memory (VRAM) -RLAPI SpriteFont LoadSpriteFontEx(const char *fileName, int fontSize, int charsCount, int *fontChars); // Load SpriteFont from file with extended parameters -RLAPI void UnloadSpriteFont(SpriteFont font); // Unload SpriteFont from GPU memory (VRAM) +// Font loading/unloading functions +RLAPI Font GetDefaultFont(void); // Get the default Font +RLAPI Font LoadFont(const char *fileName); // Load Font from file into GPU memory (VRAM) +RLAPI Font LoadFontEx(const char *fileName, int fontSize, int charsCount, int *fontChars); // Load Font from file with extended parameters +RLAPI void UnloadFont(Font font); // Unload Font from GPU memory (VRAM) // Text drawing functions RLAPI void DrawFPS(int posX, int posY); // Shows current FPS RLAPI void DrawText(const char *text, int posX, int posY, int fontSize, Color color); // Draw text (using default font) -RLAPI void DrawTextEx(SpriteFont font, const char* text, Vector2 position, float fontSize, float spacing, Color tint); // Draw text using SpriteFont and additional parameters +RLAPI void DrawTextEx(Font font, const char* text, Vector2 position, float fontSize, float spacing, Color tint); // Draw text using Font and additional parameters // Text misc. functions RLAPI int MeasureText(const char *text, int fontSize); // Measure string width for default font -RLAPI Vector2 MeasureTextEx(SpriteFont font, const char *text, float fontSize, float spacing); // Measure string size for SpriteFont +RLAPI Vector2 MeasureTextEx(Font font, const char *text, float fontSize, float spacing); // Measure string size for Font RLAPI const char *FormatText(const char *text, ...); // Formatting of text with variables to 'embed' RLAPI const char *SubText(const char *text, int position, int length); // Get a piece of a text string -RLAPI int GetGlyphIndex(SpriteFont font, int character); // Returns index position for a unicode character on sprite font +RLAPI int GetGlyphIndex(Font font, int character); // Returns index position for a unicode character on sprite font //------------------------------------------------------------------------------------ // Basic 3d Shapes Drawing Functions (Module: models) diff --git a/src/text.c b/src/text.c index 7cc091bc3..aa22c3082 100644 --- a/src/text.c +++ b/src/text.c @@ -1,6 +1,6 @@ /********************************************************************************************** * -* raylib.text - Basic functions to load SpriteFonts and draw Text +* raylib.text - Basic functions to load Fonts and draw Text * * CONFIGURATION: * @@ -73,7 +73,7 @@ // Global variables //---------------------------------------------------------------------------------- #if defined(SUPPORT_DEFAULT_FONT) -static SpriteFont defaultFont; // Default font provided by raylib +static Font defaultFont; // Default font provided by raylib // NOTE: defaultFont is loaded on InitWindow and disposed on CloseWindow [module: core] #endif @@ -85,12 +85,12 @@ static SpriteFont defaultFont; // Default font provided by raylib //---------------------------------------------------------------------------------- // Module specific Functions Declaration //---------------------------------------------------------------------------------- -static SpriteFont LoadImageFont(Image image, Color key, int firstChar); // Load a Image font file (XNA style) +static Font LoadImageFont(Image image, Color key, int firstChar); // Load a Image font file (XNA style) #if defined(SUPPORT_FILEFORMAT_FNT) -static SpriteFont LoadBMFont(const char *fileName); // Load a BMFont file (AngelCode font file) +static Font LoadBMFont(const char *fileName); // Load a BMFont file (AngelCode font file) #endif #if defined(SUPPORT_FILEFORMAT_TTF) -static SpriteFont LoadTTF(const char *fileName, int fontSize, int charsCount, int *fontChars); // Load spritefont from TTF data +static Font LoadTTF(const char *fileName, int fontSize, int charsCount, int *fontChars); // Load spritefont from TTF data #endif #if defined(SUPPORT_DEFAULT_FONT) @@ -114,7 +114,7 @@ extern void LoadDefaultFont(void) defaultFont.charsCount = 224; // Number of chars included in our default font // Default font is directly defined here (data generated from a sprite font image) - // This way, we reconstruct SpriteFont without creating large global variables + // This way, we reconstruct Font without creating large global variables // This data is automatically allocated to Stack and automatically deallocated at the end of this function int defaultFontData[512] = { 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00200020, 0x0001b000, 0x00000000, 0x00000000, 0x8ef92520, 0x00020a00, 0x7dbe8000, 0x1f7df45f, @@ -261,28 +261,28 @@ extern void UnloadDefaultFont(void) #endif // SUPPORT_DEFAULT_FONT // Get the default font, useful to be used with extended parameters -SpriteFont GetDefaultFont() +Font GetDefaultFont() { #if defined(SUPPORT_DEFAULT_FONT) return defaultFont; #else - SpriteFont font = { 0 }; + Font font = { 0 }; return font; #endif } -// Load SpriteFont from file into GPU memory (VRAM) -SpriteFont LoadSpriteFont(const char *fileName) +// Load Font from file into GPU memory (VRAM) +Font LoadFont(const char *fileName) { // Default hardcoded values for ttf file loading #define DEFAULT_TTF_FONTSIZE 32 // Font first character (32 - space) #define DEFAULT_TTF_NUMCHARS 95 // ASCII 32..126 is 95 glyphs #define DEFAULT_FIRST_CHAR 32 // Expected first char for image spritefont - SpriteFont spriteFont = { 0 }; + Font spriteFont = { 0 }; #if defined(SUPPORT_FILEFORMAT_TTF) - if (IsFileExtension(fileName, ".ttf")) spriteFont = LoadSpriteFontEx(fileName, DEFAULT_TTF_FONTSIZE, 0, NULL); + if (IsFileExtension(fileName, ".ttf")) spriteFont = LoadFontEx(fileName, DEFAULT_TTF_FONTSIZE, 0, NULL); else #endif #if defined(SUPPORT_FILEFORMAT_FNT) @@ -297,7 +297,7 @@ SpriteFont LoadSpriteFont(const char *fileName) if (spriteFont.texture.id == 0) { - TraceLog(LOG_WARNING, "[%s] SpriteFont could not be loaded, using default font", fileName); + TraceLog(LOG_WARNING, "[%s] Font could not be loaded, using default font", fileName); spriteFont = GetDefaultFont(); } else SetTextureFilter(spriteFont.texture, FILTER_POINT); // By default we set point filter (best performance) @@ -305,12 +305,12 @@ SpriteFont LoadSpriteFont(const char *fileName) return spriteFont; } -// Load SpriteFont from TTF font file with generation parameters +// Load Font from TTF font file with generation parameters // NOTE: You can pass an array with desired characters, those characters should be available in the font // if array is NULL, default char set is selected 32..126 -SpriteFont LoadSpriteFontEx(const char *fileName, int fontSize, int charsCount, int *fontChars) +Font LoadFontEx(const char *fileName, int fontSize, int charsCount, int *fontChars) { - SpriteFont spriteFont = { 0 }; + Font spriteFont = { 0 }; int totalChars = 95; // Default charset [32..126] #if defined(SUPPORT_FILEFORMAT_TTF) @@ -330,15 +330,15 @@ SpriteFont LoadSpriteFontEx(const char *fileName, int fontSize, int charsCount, if (spriteFont.texture.id == 0) { - TraceLog(LOG_WARNING, "[%s] SpriteFont could not be generated, using default font", fileName); + TraceLog(LOG_WARNING, "[%s] Font could not be generated, using default font", fileName); spriteFont = GetDefaultFont(); } return spriteFont; } -// Unload SpriteFont from GPU memory (VRAM) -void UnloadSpriteFont(SpriteFont font) +// Unload Font from GPU memory (VRAM) +void UnloadFont(Font font) { // NOTE: Make sure spriteFont is not default font (fallback) if (font.texture.id != GetDefaultFont().texture.id) @@ -368,9 +368,9 @@ void DrawText(const char *text, int posX, int posY, int fontSize, Color color) } } -// Draw text using SpriteFont +// Draw text using Font // NOTE: chars spacing is NOT proportional to fontSize -void DrawTextEx(SpriteFont font, const char *text, Vector2 position, float fontSize, float spacing, Color tint) +void DrawTextEx(Font font, const char *text, Vector2 position, float fontSize, float spacing, Color tint) { int length = strlen(text); int textOffsetX = 0; // Offset between characters @@ -482,8 +482,8 @@ int MeasureText(const char *text, int fontSize) return (int)vec.x; } -// Measure string size for SpriteFont -Vector2 MeasureTextEx(SpriteFont font, const char *text, float fontSize, float spacing) +// Measure string size for Font +Vector2 MeasureTextEx(Font font, const char *text, float fontSize, float spacing) { int len = strlen(text); int tempLen = 0; // Used to count longer text line num chars @@ -527,7 +527,7 @@ Vector2 MeasureTextEx(SpriteFont font, const char *text, float fontSize, float s } // Returns index position for a unicode character on spritefont -int GetGlyphIndex(SpriteFont font, int character) +int GetGlyphIndex(Font font, int character) { #define UNORDERED_CHARSET #if defined(UNORDERED_CHARSET) @@ -575,7 +575,7 @@ void DrawFPS(int posX, int posY) //---------------------------------------------------------------------------------- // Load an Image font file (XNA style) -static SpriteFont LoadImageFont(Image image, Color key, int firstChar) +static Font LoadImageFont(Image image, Color key, int firstChar) { #define COLOR_EQUAL(col1, col2) ((col1.r == col2.r)&&(col1.g == col2.g)&&(col1.b == col2.b)&&(col1.a == col2.a)) @@ -648,7 +648,7 @@ static SpriteFont LoadImageFont(Image image, Color key, int firstChar) xPosToRead = charSpacing; } - TraceLog(LOG_DEBUG, "SpriteFont data parsed correctly from image"); + TraceLog(LOG_DEBUG, "Font data parsed correctly from image"); // NOTE: We need to remove key color borders from image to avoid weird // artifacts on texture scaling when using FILTER_BILINEAR or FILTER_TRILINEAR @@ -660,7 +660,7 @@ static SpriteFont LoadImageFont(Image image, Color key, int firstChar) free(pixels); // Free pixels array memory // Create spritefont with all data parsed from image - SpriteFont spriteFont = { 0 }; + Font spriteFont = { 0 }; spriteFont.texture = LoadTextureFromImage(fontClear); // Convert processed image to OpenGL texture spriteFont.charsCount = index; @@ -684,18 +684,18 @@ static SpriteFont LoadImageFont(Image image, Color key, int firstChar) spriteFont.baseSize = spriteFont.chars[0].rec.height; - TraceLog(LOG_INFO, "Image file loaded correctly as SpriteFont"); + TraceLog(LOG_INFO, "Image file loaded correctly as Font"); return spriteFont; } #if defined(SUPPORT_FILEFORMAT_FNT) // Load a BMFont file (AngelCode font file) -static SpriteFont LoadBMFont(const char *fileName) +static Font LoadBMFont(const char *fileName) { #define MAX_BUFFER_SIZE 256 - SpriteFont font = { 0 }; + Font font = { 0 }; font.texture.id = 0; char buffer[MAX_BUFFER_SIZE]; @@ -800,10 +800,10 @@ static SpriteFont LoadBMFont(const char *fileName) if (font.texture.id == 0) { - UnloadSpriteFont(font); + UnloadFont(font); font = GetDefaultFont(); } - else TraceLog(LOG_INFO, "[%s] SpriteFont loaded successfully", fileName); + else TraceLog(LOG_INFO, "[%s] Font loaded successfully", fileName); return font; } @@ -812,7 +812,7 @@ static SpriteFont LoadBMFont(const char *fileName) #if defined(SUPPORT_FILEFORMAT_TTF) // Generate a sprite font from TTF file data (font size required) // TODO: Review texture packing method and generation (use oversampling) -static SpriteFont LoadTTF(const char *fileName, int fontSize, int charsCount, int *fontChars) +static Font LoadTTF(const char *fileName, int fontSize, int charsCount, int *fontChars) { #define MAX_TTF_SIZE 16 // Maximum ttf file size in MB @@ -830,7 +830,7 @@ static SpriteFont LoadTTF(const char *fileName, int fontSize, int charsCount, in unsigned char *dataBitmap = (unsigned char *)malloc(textureSize*textureSize*sizeof(unsigned char)); // One channel bitmap returned! stbtt_bakedchar *charData = (stbtt_bakedchar *)malloc(sizeof(stbtt_bakedchar)*charsCount); - SpriteFont font = { 0 }; + Font font = { 0 }; FILE *ttfFile = fopen(fileName, "rb"); diff --git a/src/textures.c b/src/textures.c index 726257b8f..56d2aa867 100644 --- a/src/textures.c +++ b/src/textures.c @@ -1371,7 +1371,7 @@ Image ImageText(const char *text, int fontSize, Color color) } // Create an image from text (custom sprite font) -Image ImageTextEx(SpriteFont font, const char *text, float fontSize, float spacing, Color tint) +Image ImageTextEx(Font font, const char *text, float fontSize, float spacing, Color tint) { int length = strlen(text); int posX = 0; @@ -1385,7 +1385,7 @@ Image ImageTextEx(SpriteFont font, const char *text, float fontSize, float spaci // NOTE: glGetTexImage() not available in OpenGL ES // TODO: This is horrible, retrieving font texture from GPU!!! - // Define ImageFont struct? or include Image spritefont in SpriteFont struct? + // Define ImageFont struct? or include Image spritefont in Font struct? Image imFont = GetTextureData(font.texture); ImageColorTint(&imFont, tint); // Apply color tint to font @@ -1466,7 +1466,7 @@ void ImageDrawText(Image *dst, Vector2 position, const char *text, int fontSize, } // Draw text (custom sprite font) within an image (destination) -void ImageDrawTextEx(Image *dst, Vector2 position, SpriteFont font, const char *text, float fontSize, float spacing, Color color) +void ImageDrawTextEx(Image *dst, Vector2 position, Font font, const char *text, float fontSize, float spacing, Color color) { Image imText = ImageTextEx(font, text, fontSize, spacing, color); diff --git a/templates/advance_game/advance_game.c b/templates/advance_game/advance_game.c index 768b2f940..48a34f6d7 100644 --- a/templates/advance_game/advance_game.c +++ b/templates/advance_game/advance_game.c @@ -58,7 +58,7 @@ int main(void) // Global data loading (assets that must be available in all screens, i.e. fonts) InitAudioDevice(); - font = LoadSpriteFont("resources/mecha.png"); + font = LoadFont("resources/mecha.png"); music = LoadMusicStream("resources/ambient.ogg"); fxCoin = LoadSound("resources/coin.wav"); @@ -96,7 +96,7 @@ int main(void) } // Unload all global loaded data (i.e. fonts) here! - UnloadSpriteFont(font); + UnloadFont(font); UnloadMusicStream(music); UnloadSound(fxCoin); diff --git a/templates/advance_game/screens/screens.h b/templates/advance_game/screens/screens.h index adfc87f53..4d7f9b538 100644 --- a/templates/advance_game/screens/screens.h +++ b/templates/advance_game/screens/screens.h @@ -35,7 +35,7 @@ typedef enum GameScreen { LOGO = 0, TITLE, OPTIONS, GAMEPLAY, ENDING } GameScree // Global Variables Definition //---------------------------------------------------------------------------------- GameScreen currentScreen; -SpriteFont font; +Font font; Music music; Sound fxCoin; From f14492432d590cef90cb747a2063f6998a61f108 Mon Sep 17 00:00:00 2001 From: Ray Date: Fri, 4 May 2018 23:03:56 +0200 Subject: [PATCH 14/53] Avoid exposing native GLFW3 functionality Try to avoid types conflict with Font --- src/core.c | 8 +------- 1 file changed, 1 insertion(+), 7 deletions(-) diff --git a/src/core.c b/src/core.c index 5587f82b5..ece76138d 100644 --- a/src/core.c +++ b/src/core.c @@ -141,13 +141,7 @@ #if defined(PLATFORM_DESKTOP) || defined(PLATFORM_WEB) //#define GLFW_INCLUDE_NONE // Disable the standard OpenGL header inclusion on GLFW3 #include // GLFW3 library: Windows, OpenGL context and Input management - - #if defined(__linux__) - #define GLFW_EXPOSE_NATIVE_X11 // Linux specific definitions for getting - #define GLFW_EXPOSE_NATIVE_GLX // native functions like glfwGetX11Window - #include // which are required for hiding mouse - #endif - //#include // OpenGL functions (GLFW3 already includes gl.h) + // NOTE: GLFW3 already includes gl.h (OpenGL) headers #if !defined(SUPPORT_BUSY_WAIT_LOOP) && defined(_WIN32) // NOTE: Those functions require linking with winmm library From 04db494db0d8bd6b645c941a9920925531d6ad5e Mon Sep 17 00:00:00 2001 From: Ray Date: Sun, 6 May 2018 00:44:59 +0200 Subject: [PATCH 15/53] Renamed shader variable --- examples/models/models_material_pbr.c | 2 +- examples/models/resources/shaders/pbr.vs | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/examples/models/models_material_pbr.c b/examples/models/models_material_pbr.c index 33f13e2ce..d50ef3daf 100644 --- a/examples/models/models_material_pbr.c +++ b/examples/models/models_material_pbr.c @@ -122,7 +122,7 @@ static Material LoadMaterialPBR(Color albedo, float metalness, float roughness) mat.shader.locs[LOC_MAP_BRDF] = GetShaderLocation(mat.shader, "brdfLUT"); // Set view matrix location - mat.shader.locs[LOC_MATRIX_MODEL] = GetShaderLocation(mat.shader, "mMatrix"); + mat.shader.locs[LOC_MATRIX_MODEL] = GetShaderLocation(mat.shader, "matModel"); mat.shader.locs[LOC_MATRIX_VIEW] = GetShaderLocation(mat.shader, "view"); mat.shader.locs[LOC_VECTOR_VIEW] = GetShaderLocation(mat.shader, "viewPos"); diff --git a/examples/models/resources/shaders/pbr.vs b/examples/models/resources/shaders/pbr.vs index 885cb199b..8bd3faa14 100644 --- a/examples/models/resources/shaders/pbr.vs +++ b/examples/models/resources/shaders/pbr.vs @@ -16,7 +16,7 @@ in vec4 vertexTangent; // Input uniform values uniform mat4 mvp; -uniform mat4 mMatrix; +uniform mat4 matModel; // Output vertex attributes (to fragment shader) out vec3 fragPosition; @@ -31,10 +31,10 @@ void main() vec3 vertexBinormal = cross(vertexNormal, vec3(vertexTangent)); // Calculate fragment normal based on normal transformations - mat3 normalMatrix = transpose(inverse(mat3(mMatrix))); + mat3 normalMatrix = transpose(inverse(mat3(matModel))); // Calculate fragment position based on model transformations - fragPosition = vec3(mMatrix*vec4(vertexPosition, 1.0f)); + fragPosition = vec3(matModel*vec4(vertexPosition, 1.0f)); // Send vertex attributes to fragment shader fragTexCoord = vertexTexCoord; From 8e9ff75f1c634d9db0ea0c04ea76b25a9ccf86ab Mon Sep 17 00:00:00 2001 From: Sherjil Ozair Date: Sun, 6 May 2018 12:43:05 -0400 Subject: [PATCH 16/53] Use fabsf for floats, and avoid implicit type casting --- src/shapes.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/shapes.c b/src/shapes.c index ed911b263..361fb9c7a 100644 --- a/src/shapes.c +++ b/src/shapes.c @@ -634,8 +634,8 @@ bool CheckCollisionRecs(Rectangle rec1, Rectangle rec2) { bool collision = false; - int dx = abs((rec1.x + rec1.width/2) - (rec2.x + rec2.width/2)); - int dy = abs((rec1.y + rec1.height/2) - (rec2.y + rec2.height/2)); + float dx = fabsf((rec1.x + rec1.width/2) - (rec2.x + rec2.width/2)); + float dy = fabsf((rec1.y + rec1.height/2) - (rec2.y + rec2.height/2)); if ((dx <= (rec1.width/2 + rec2.width/2)) && ((dy <= (rec1.height/2 + rec2.height/2)))) collision = true; @@ -686,8 +686,8 @@ Rectangle GetCollisionRec(Rectangle rec1, Rectangle rec2) if (CheckCollisionRecs(rec1, rec2)) { - int dxx = abs(rec1.x - rec2.x); - int dyy = abs(rec1.y - rec2.y); + float dxx = fabsf(rec1.x - rec2.x); + float dyy = fabsf(rec1.y - rec2.y); if (rec1.x <= rec2.x) { From 3a803ac95ea979727e77dea29daccabfd350e057 Mon Sep 17 00:00:00 2001 From: Ray Date: Tue, 8 May 2018 23:04:13 +0200 Subject: [PATCH 17/53] Removed unnecesary define --- src/utils.h | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/utils.h b/src/utils.h index ed75eb68a..dfdb0c2ae 100644 --- a/src/utils.h +++ b/src/utils.h @@ -58,14 +58,12 @@ extern "C" { // Prevents name mangling of functions //---------------------------------------------------------------------------------- // Module Functions Declaration //---------------------------------------------------------------------------------- -#if defined(PLATFORM_DESKTOP) || defined(PLATFORM_RPI) #if defined(SUPPORT_SAVE_BMP) void SaveBMP(const char *fileName, unsigned char *imgData, int width, int height, int compSize); #endif #if defined(SUPPORT_SAVE_PNG) void SavePNG(const char *fileName, unsigned char *imgData, int width, int height, int compSize); #endif -#endif #if defined(PLATFORM_ANDROID) void InitAssetManager(AAssetManager *manager); // Initialize asset manager from android app From ac2dbba5b7a6e3727209f23769443e363a751528 Mon Sep 17 00:00:00 2001 From: Ray Date: Tue, 8 May 2018 23:35:21 +0200 Subject: [PATCH 18/53] Update CHANGELOG --- CHANGELOG | 98 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 98 insertions(+) diff --git a/CHANGELOG b/CHANGELOG index 10e28b832..269c5db8c 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -3,6 +3,104 @@ changelog Current Release: raylib 1.8.0 (Oct 2017) +----------------------------------------------- +Release: raylib 2.0 (June 2017 ?) +----------------------------------------------- +KEY CHANGES: + - Removed external dependencies (GLFW3 and OpenAL) + - Complete redesign of audio module to use mini_al audio library + - Support AppVeyor and Travis CI (continuous integration) build + - Reviewed raymath.h for better consistency and performance (inlining) + - Refactor all #define SUPPORT_* into a single config.h + - Support TCC compiler + +Detailed changes: +[build] REMOVED: GitHub develop branch +[build] ADDED: FreeBSD OS support +[build] ADDED: Universal Windows Platform (UWP) support +[build] ADDED: Wayland Linux desktop support +[build] REMOVED: External dependencies GLFW and OpenAL +[build] ADDED: AppVeyor CI for automatic Windows builds +[build] ADDED: Travis CI for automatic Linux/macOS builds +[build] ADDED: rglfw (GLFW3 module) to avoid external dependency +[build] ADDED: VS2017 UWP project +[build] ADDED: Builder project template +[build] REVIEWED: VS2015 and VS2017 projects +[build] ADDED: Compiler memory sanitizer for better debug +[build] Setup CMake package target and CI auto-deploy tags +[build] Support DEBUG library building +[core] Unified InitWindow() between platforms +[core] Export Android main entry point +[core] RENAMED: Begin3dMode() to BeginMode3D() +[core] RENAMED: End3dMode() to EndMode3D() +[core] RENAMED: Begin2dMode() to BeginMode2D() +[core] RENAMED: End2dMode() to EndMode2D() +[core] RENAMED: struct Camera to Camera3D +[core] RENAMED: struct SpriteFont to Font -> plus all required functions! +[core] RENAMED: enum TextureFormat to PixelFormat +[core] REVIEWED: Rectangle params int to float +[core] REVIEWED: timming system for macOS +[core] REMOVED: ColorToFloat() +[core] ADDED: GetCurrentTime() on macOS +[core] ADDED: GetTime() +[core] ADDED: struct Vector4 +[core] ADDED: SetTraceLog() to define trace log messages type +[core] ADDED: GetFileName() to get filename from path string +[core] ADDED: ColorToHSV() +[core] ADDED: ColorNormalize() +[core] ADDED: SetWindowSize() to scale Windows in runtime +[core] ADDED: SetMouseScale() to scale mouse input +[core] ADDED: key definitions - KEY_GRAVE, KEY_SLASH, KEY_BACKSLASH +[core] RENAMED: GetHexValue() to ColorToInt() +[core] REVIEWED: Fade() +[core] REVIEWED: InitWindow() to avoid void pointer (safety) +[core] Support camera 3d orthographic projection mode +[shapes] ADDED: DrawRectangleLinesEx() +[textures] Improved pixel formats support (32bit channels) +[textures] Improved textures support for OpenGL 2.1 +[textures] REMOVED: DrawRectangleT() --> Added support to DrawRectangle() +[textures] ADDED: GetPixelDataSize(); pixel data size in bytes (image or texture) +[textures] ADDED: ImageAlphaClear() --> Clear alpha channel to desired color +[textures] ADDED: ImageAlphaCrop() --> Crop image depending on alpha value +[textures] ADDED: ImageAlphaPremultiply() --> Premultiply alpha channel +[textures] ADDED: ImageDrawRectangle() +[textures] ADDED: ImageMipmaps() +[textures] ADDED: GenImageColor() +[textures] ADDED: GetPixelDataSize() +[textures] REVIEWED: GenImagePerlinNoise() +[textures] REVIEWED: ImageTextEx() to support UTF8 basic characters +[textures] REVIEWED: GetTextureData() for RPI - requires some work +[textures] Added new example: text drawing on image +[text] Corrected issue with ttf font y-offset +[text] REVIEWED: DrawTextEx() - avoid rendering SPACE character! +[rlgl] ADDED: LoadShaderCode() +[rlgl] ADDED: GetMatrixModelview() +[rlgl] ADDED: SetVrDistortionShader(Shader shader) +[rlgl] REVIEWED: rlLoadTexture() - added mipmaps support, improved compressed textures loading +[rlgl] REVIEWED: rlReadTexturePixels() +[models] Support 4 components mesh.tangent data +[models] Removed tangents generation from LoadOBJ() +[models] ADDED: MeshTangents() +[models] ADDED: MeshBinormals() +[models] ADDED: ExportMesh() +[models] ADDED: GetCollisionRayModel() +[models] RENAMED: CalculateBoundingBox() to MeshBoundingBox() +[models] REMOVED: GetCollisionRayMesh() - does not consider model transform +[models] REVIEWED: LoadMesh() - fallback to default cube mesh if loading fails +[audio] ADDED: IsAudioStreamPlaying() +[audio] ADDED: SetAudioStreamVolume() +[audio] ADDED: SetAudioStreamPitch() +[utils] Corrected issue with SaveImageAs() +[utils] RENAMED: SaveImageAs() to ExportImage() +[utils] REMOVED: rres support - moved to external library (rres.h) +[shaders] REVIEWED: GLSL 120 shaders +[raymath] REVIEWED: math usage to reduce temp variables +[raymath] REVIEWED: Avoid pointer-based parameters for API consistency +[physac] REVIEWED: physac.h timming system +[games] ADDED: GGJ18 game - transmission mission +[*] Updated external libraries to latest version +[*] Multiple bugs corrected (check github issues) + ----------------------------------------------- Release: raylib 1.8.0 (Oct 2017) ----------------------------------------------- From 9ea2a69bfdc6ffd12bf27c1e9003cd8bc0837549 Mon Sep 17 00:00:00 2001 From: Ray Date: Wed, 9 May 2018 00:23:56 +0200 Subject: [PATCH 19/53] Corrected issue on rectangle drawing --- src/textures.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/textures.c b/src/textures.c index 56d2aa867..cb566c5e8 100644 --- a/src/textures.c +++ b/src/textures.c @@ -2029,7 +2029,7 @@ void DrawTextureEx(Texture2D texture, Vector2 position, float rotation, float sc // Draw a part of a texture (defined by a rectangle) void DrawTextureRec(Texture2D texture, Rectangle sourceRec, Vector2 position, Color tint) { - Rectangle destRec = { position.x, position.y, sourceRec.width, sourceRec.height }; + Rectangle destRec = { position.x, position.y, sourceRec.width, fabsf(sourceRec.height) }; Vector2 origin = { 0, 0 }; DrawTexturePro(texture, sourceRec, destRec, origin, 0.0f, tint); From 8ae8d3ac782825d732a0680bd1ad80db420718a9 Mon Sep 17 00:00:00 2001 From: Ray Date: Thu, 10 May 2018 17:35:02 +0200 Subject: [PATCH 20/53] Reorganized project templates folder --- .../raylib.App.UWP/raylib.App.UWP.vcxproj | 145 -- project/vs2015.UWP/raylib.UWP.sln | 50 - project/vs2015.UWP/raylib/raylib.vcxproj | 186 -- .../vs2015/examples/core_basic_window.vcxproj | 182 -- .../examples/core_basic_window_cpp.vcxproj | 180 -- project/vs2015/raylib.sln | 54 - project/vs2015/raylib/raylib.vcxproj | 198 -- .../vs2017/examples/core_basic_window.vcxproj | 182 -- .../examples/core_basic_window_cpp.vcxproj | 180 -- project/vs2017/raylib.sln | 57 - project/vs2017/raylib/raylib.vcxproj | 197 -- {project => projects}/Builder/README.md | 0 .../Builder/examples/README.md | 0 .../Builder/examples/meson.build | 0 {project => projects}/Builder/meson.build | 0 projects/CodeBlocks/HELPME | 0 projects/Geany/HELPME | 0 projects/KDevelop/HELPME | 0 projects/Notepad++/README.md | 19 + projects/Notepad++/c_raylib.xml | 2067 +++++++++++++++++ projects/Notepad++/npes_saved.txt | Bin 0 -> 11872 bytes .../raylib_npp_parser/raylib_npp.xml | 2030 ++++++++++++++++ .../raylib_npp_parser/raylib_npp_parser.c | 148 ++ .../raylib_npp_parser/raylib_to_parse.h | 459 ++++ .../VS2015.UWP}/raylib.App.UWP/App.cpp | 0 .../VS2015.UWP}/raylib.App.UWP/App.h | 0 .../raylib.App.UWP/Assets/Logo.scale-100.png | Bin .../Assets/SmallLogo.scale-100.png | Bin .../Assets/SplashScreen.scale-100.png | Bin .../Assets/StoreLogo.scale-100.png | Bin .../Assets/WideLogo.scale-100.png | Bin .../raylib.App.UWP/Package.appxmanifest | 0 .../raylib.App.UWP/packages.config | 0 .../VS2015.UWP}/raylib.App.UWP/pch.cpp | 0 .../VS2015.UWP}/raylib.App.UWP/pch.h | 0 .../raylib.App.UWP.TemporaryKey.pfx | Bin .../raylib.App.UWP/raylib.App.UWP.filters | 0 .../raylib.App.UWP/raylib.App.UWP.user | 0 .../VS2017}/raylib.App.UWP/App.cpp | 0 .../VS2017}/raylib.App.UWP/App.h | 0 .../raylib.App.UWP/Assets/Logo.scale-100.png | Bin .../Assets/SmallLogo.scale-100.png | Bin .../Assets/SplashScreen.scale-100.png | Bin .../Assets/StoreLogo.scale-100.png | Bin .../Assets/WideLogo.scale-100.png | Bin .../raylib.App.UWP/Package.appxmanifest | 0 .../VS2017}/raylib.App.UWP/packages.config | 0 .../VS2017}/raylib.App.UWP/pch.cpp | 0 .../VS2017}/raylib.App.UWP/pch.h | 0 .../raylib.App.UWP.TemporaryKey.pfx | Bin .../raylib.App.UWP/raylib.App.UWP.filters | 0 .../raylib.App.UWP/raylib.App.UWP.user | 0 projects/VSCode/HELPME | 0 53 files changed, 4723 insertions(+), 1611 deletions(-) delete mode 100644 project/vs2015.UWP/raylib.App.UWP/raylib.App.UWP.vcxproj delete mode 100644 project/vs2015.UWP/raylib.UWP.sln delete mode 100644 project/vs2015.UWP/raylib/raylib.vcxproj delete mode 100644 project/vs2015/examples/core_basic_window.vcxproj delete mode 100644 project/vs2015/examples/core_basic_window_cpp.vcxproj delete mode 100644 project/vs2015/raylib.sln delete mode 100644 project/vs2015/raylib/raylib.vcxproj delete mode 100644 project/vs2017/examples/core_basic_window.vcxproj delete mode 100644 project/vs2017/examples/core_basic_window_cpp.vcxproj delete mode 100644 project/vs2017/raylib.sln delete mode 100644 project/vs2017/raylib/raylib.vcxproj rename {project => projects}/Builder/README.md (100%) rename {project => projects}/Builder/examples/README.md (100%) rename {project => projects}/Builder/examples/meson.build (100%) rename {project => projects}/Builder/meson.build (100%) create mode 100644 projects/CodeBlocks/HELPME create mode 100644 projects/Geany/HELPME create mode 100644 projects/KDevelop/HELPME create mode 100644 projects/Notepad++/README.md create mode 100644 projects/Notepad++/c_raylib.xml create mode 100644 projects/Notepad++/npes_saved.txt create mode 100644 projects/Notepad++/raylib_npp_parser/raylib_npp.xml create mode 100644 projects/Notepad++/raylib_npp_parser/raylib_npp_parser.c create mode 100644 projects/Notepad++/raylib_npp_parser/raylib_to_parse.h rename {project/vs2015.UWP => projects/VS2015.UWP}/raylib.App.UWP/App.cpp (100%) rename {project/vs2015.UWP => projects/VS2015.UWP}/raylib.App.UWP/App.h (100%) rename {project/vs2015.UWP => projects/VS2015.UWP}/raylib.App.UWP/Assets/Logo.scale-100.png (100%) rename {project/vs2015.UWP => projects/VS2015.UWP}/raylib.App.UWP/Assets/SmallLogo.scale-100.png (100%) rename {project/vs2015.UWP => projects/VS2015.UWP}/raylib.App.UWP/Assets/SplashScreen.scale-100.png (100%) rename {project/vs2015.UWP => projects/VS2015.UWP}/raylib.App.UWP/Assets/StoreLogo.scale-100.png (100%) rename {project/vs2015.UWP => projects/VS2015.UWP}/raylib.App.UWP/Assets/WideLogo.scale-100.png (100%) rename {project/vs2015.UWP => projects/VS2015.UWP}/raylib.App.UWP/Package.appxmanifest (100%) rename {project/vs2015.UWP => projects/VS2015.UWP}/raylib.App.UWP/packages.config (100%) rename {project/vs2015.UWP => projects/VS2015.UWP}/raylib.App.UWP/pch.cpp (100%) rename {project/vs2015.UWP => projects/VS2015.UWP}/raylib.App.UWP/pch.h (100%) rename {project/vs2015.UWP => projects/VS2015.UWP}/raylib.App.UWP/raylib.App.UWP.TemporaryKey.pfx (100%) rename {project/vs2015.UWP => projects/VS2015.UWP}/raylib.App.UWP/raylib.App.UWP.filters (100%) rename {project/vs2015.UWP => projects/VS2015.UWP}/raylib.App.UWP/raylib.App.UWP.user (100%) rename {project/vs2017.UWP => projects/VS2017}/raylib.App.UWP/App.cpp (100%) rename {project/vs2017.UWP => projects/VS2017}/raylib.App.UWP/App.h (100%) rename {project/vs2017.UWP => projects/VS2017}/raylib.App.UWP/Assets/Logo.scale-100.png (100%) rename {project/vs2017.UWP => projects/VS2017}/raylib.App.UWP/Assets/SmallLogo.scale-100.png (100%) rename {project/vs2017.UWP => projects/VS2017}/raylib.App.UWP/Assets/SplashScreen.scale-100.png (100%) rename {project/vs2017.UWP => projects/VS2017}/raylib.App.UWP/Assets/StoreLogo.scale-100.png (100%) rename {project/vs2017.UWP => projects/VS2017}/raylib.App.UWP/Assets/WideLogo.scale-100.png (100%) rename {project/vs2017.UWP => projects/VS2017}/raylib.App.UWP/Package.appxmanifest (100%) rename {project/vs2017.UWP => projects/VS2017}/raylib.App.UWP/packages.config (100%) rename {project/vs2017.UWP => projects/VS2017}/raylib.App.UWP/pch.cpp (100%) rename {project/vs2017.UWP => projects/VS2017}/raylib.App.UWP/pch.h (100%) rename {project/vs2017.UWP => projects/VS2017}/raylib.App.UWP/raylib.App.UWP.TemporaryKey.pfx (100%) rename {project/vs2017.UWP => projects/VS2017}/raylib.App.UWP/raylib.App.UWP.filters (100%) rename {project/vs2017.UWP => projects/VS2017}/raylib.App.UWP/raylib.App.UWP.user (100%) create mode 100644 projects/VSCode/HELPME diff --git a/project/vs2015.UWP/raylib.App.UWP/raylib.App.UWP.vcxproj b/project/vs2015.UWP/raylib.App.UWP/raylib.App.UWP.vcxproj deleted file mode 100644 index 6af9db604..000000000 --- a/project/vs2015.UWP/raylib.App.UWP/raylib.App.UWP.vcxproj +++ /dev/null @@ -1,145 +0,0 @@ - - - - - Debug - Win32 - - - Release - Win32 - - - Debug - x64 - - - Release - x64 - - - Debug - ARM - - - Release - ARM - - - - {b842558c-c034-4e4b-9457-a286f26e83cc} - raylibUWP - en-US - 14.0 - true - Windows Store - 10.0.14393.0 - 10.0.14393.0 - 10.0 - raylib.App.UWP - - - - Application - true - v140 - - - Application - false - true - v140 - - - - - - - - raylib.App.UWP.TemporaryKey.pfx - - - C:\Users\Sam\Documents\GitHub\raylib\release\include;$(IncludePath) - C:\Users\Sam\Documents\GitHub\raylib\project\vs2015.UWP\raylib\Debug;$(LibraryPath) - - - - mincore.lib;raylib.lib;%(AdditionalDependencies) - %(AdditionalLibraryDirectories);$(VCInstallDir)\lib\store\arm;$(VCInstallDir)\lib\arm - - - - - mincore.lib;raylib.lib;%(AdditionalDependencies) - $(SolutionDir)raylib\Debug;%(AdditionalLibraryDirectories); $(VCInstallDir)\lib\store; $(VCInstallDir)\lib - - - - - mincore.lib;raylib.lib;%(AdditionalDependencies) - C:\Users\Sam\Documents\GitHub\raylib\project\vs2015.UWP\x64\Debug;C:\Users\Alumno\Downloads\angle\UWP_OpenGLES2\raylib;%(AdditionalLibraryDirectories);$(VCInstallDir)\lib\store\amd64;$(VCInstallDir)\lib\amd64 - - - - - pch.h - $(IntDir)pch.pch - $(SolutionDir)..\..\src;$(ProjectDir);$(IntermediateOutputPath);%(AdditionalIncludeDirectories) - /bigobj %(AdditionalOptions) - 4453;28204 - _DEBUG;%(PreprocessorDefinitions) - - - true - - - - - pch.h - $(IntDir)pch.pch - $(SolutionDir)..\..\src;$(ProjectDir);$(IntermediateOutputPath);%(AdditionalIncludeDirectories) - /bigobj %(AdditionalOptions) - 4453;28204 - NDEBUG;%(PreprocessorDefinitions) - Default - false - - - /NODEFAULTLIB %(AdditionalOptions) - - - - - - - - - - - - - - - - - Create - - - - - Designer - - - - - - - - - - - This project references NuGet package(s) that are missing on this computer. Use NuGet Package Restore to download them. For more information, see http://go.microsoft.com/fwlink/?LinkID=322105. The missing file is {0}. - - - - \ No newline at end of file diff --git a/project/vs2015.UWP/raylib.UWP.sln b/project/vs2015.UWP/raylib.UWP.sln deleted file mode 100644 index b2f95ca2a..000000000 --- a/project/vs2015.UWP/raylib.UWP.sln +++ /dev/null @@ -1,50 +0,0 @@ - -Microsoft Visual Studio Solution File, Format Version 12.00 -# Visual Studio 14 -VisualStudioVersion = 14.0.25420.1 -MinimumVisualStudioVersion = 10.0.40219.1 -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "raylib.App.UWP", "raylib.App.UWP\raylib.App.UWP.vcxproj", "{B842558C-C034-4E4B-9457-A286F26E83CC}" -EndProject -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "raylib", "raylib\raylib.vcxproj", "{E89D61AC-55DE-4482-AFD4-DF7242EBC859}" -EndProject -Global - GlobalSection(SolutionConfigurationPlatforms) = preSolution - Debug|ARM = Debug|ARM - Debug|x64 = Debug|x64 - Debug|x86 = Debug|x86 - Release|ARM = Release|ARM - Release|x64 = Release|x64 - Release|x86 = Release|x86 - EndGlobalSection - GlobalSection(ProjectConfigurationPlatforms) = postSolution - {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|ARM.ActiveCfg = Debug|ARM - {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|ARM.Build.0 = Debug|ARM - {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|ARM.Deploy.0 = Debug|ARM - {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|x64.ActiveCfg = Debug|x64 - {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|x64.Build.0 = Debug|x64 - {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|x64.Deploy.0 = Debug|x64 - {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|x86.ActiveCfg = Debug|Win32 - {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|x86.Build.0 = Debug|Win32 - {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|x86.Deploy.0 = Debug|Win32 - {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|ARM.ActiveCfg = Release|ARM - {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|ARM.Build.0 = Release|ARM - {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|ARM.Deploy.0 = Release|ARM - {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|x64.ActiveCfg = Release|x64 - {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|x64.Build.0 = Release|x64 - {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|x64.Deploy.0 = Release|x64 - {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|x86.ActiveCfg = Release|Win32 - {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|x86.Build.0 = Release|Win32 - {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|x86.Deploy.0 = Release|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|ARM.ActiveCfg = Debug|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|x64.ActiveCfg = Debug|x64 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|x86.ActiveCfg = Debug|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|x86.Build.0 = Debug|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|ARM.ActiveCfg = Release|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|x64.ActiveCfg = Release|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|x86.ActiveCfg = Release|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|x86.Build.0 = Release|Win32 - EndGlobalSection - GlobalSection(SolutionProperties) = preSolution - HideSolutionNode = FALSE - EndGlobalSection -EndGlobal diff --git a/project/vs2015.UWP/raylib/raylib.vcxproj b/project/vs2015.UWP/raylib/raylib.vcxproj deleted file mode 100644 index c1fbca500..000000000 --- a/project/vs2015.UWP/raylib/raylib.vcxproj +++ /dev/null @@ -1,186 +0,0 @@ - - - - - Debug - Win32 - - - Debug - x64 - - - Release - Win32 - - - Release - x64 - - - - {E89D61AC-55DE-4482-AFD4-DF7242EBC859} - Win32Proj - raylib - 10.0.16299.0 - - - - StaticLibrary - true - v140 - Unicode - - - StaticLibrary - true - v140 - Unicode - - - StaticLibrary - false - v140 - true - Unicode - - - StaticLibrary - false - v140 - true - Unicode - - - - - - - - - - - - - - - - - - - - - $(SolutionDir)$(ProjectName)\$(Configuration)\ - - - - $(SolutionDir)$(ProjectName)\$(Configuration)\ - $(SolutionDir)$(ProjectName)\$(Configuration)\temp - - - - - - Level3 - Disabled - WIN32;_DEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_ES2;PLATFORM_UWP - CompileAsC - $(SolutionDir)..\..\release\include;$(SolutionDir)..\..\src\external\ANGLE - - - Windows - - - %(AdditionalLibraryDirectories) - - - - - - - Level3 - Disabled - WIN32;_DEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_ES2;PLATFORM_UWP - CompileAsC - $(SolutionDir)..\..\release\include;$(SolutionDir)..\..\src\external\include\ANGLE - - - Windows - - - %(AdditionalLibraryDirectories) - - - - - Level3 - - - MaxSpeed - true - true - WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_ES2;PLATFORM_UWP - $(SolutionDir)..\..\src\external\ANGLE;$(SolutionDir)..\..\release\include - CompileAsC - - - Windows - true - true - - - - - Level3 - - - MaxSpeed - true - true - WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_ES2;PLATFORM_UWP - $(SolutionDir)..\..\src\external\include\ANGLE;$(SolutionDir)..\..\release\include - CompileAsC - - - Windows - true - true - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/project/vs2015/examples/core_basic_window.vcxproj b/project/vs2015/examples/core_basic_window.vcxproj deleted file mode 100644 index a5b484954..000000000 --- a/project/vs2015/examples/core_basic_window.vcxproj +++ /dev/null @@ -1,182 +0,0 @@ - - - - - Debug_DLL - Win32 - - - Debug - Win32 - - - Release_DLL - Win32 - - - Release - Win32 - - - - {0981CA98-E4A5-4DF1-987F-A41D09131EFC} - Win32Proj - core_basic_window - 8.1 - core_basic_window - - - - Application - true - v140 - Unicode - - - Application - true - v140 - Unicode - - - Application - false - v140 - true - Unicode - - - Application - false - v140 - true - Unicode - - - - - - - - - - - - - - - - - - - - - true - $(ProjectDir)$(ProjectName)\$(Configuration)\ - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - true - $(ProjectDir)$(ProjectName)\$(Configuration)\ - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - false - $(ProjectDir)$(ProjectName)\$(Configuration)\ - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - false - $(ProjectDir)$(ProjectName)\$(Configuration)\ - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - - - - Level3 - Disabled - WIN32;_DEBUG;_CONSOLE;PLATFORM_DESKTOP;%(PreprocessorDefinitions) - CompileAsC - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - - - Console - true - $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) - kernel32.lib;user32.lib;gdi32.lib;opengl32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - - - - - - - Level3 - Disabled - WIN32;_DEBUG;_CONSOLE;PLATFORM_DESKTOP;%(PreprocessorDefinitions) - CompileAsC - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - - - Console - true - $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) - kernel32.lib;user32.lib;gdi32.lib;opengl32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - - - - - Level3 - - - MaxSpeed - true - true - WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions);PLATFORM_DESKTOP - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - CompileAsC - true - - - Console - true - true - true - kernel32.lib;user32.lib;gdi32.lib;opengl32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) - - - - - Level3 - - - MaxSpeed - true - true - WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions);PLATFORM_DESKTOP - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - CompileAsC - true - - - Console - true - true - true - kernel32.lib;user32.lib;gdi32.lib;opengl32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) - - - - - - - - {e89d61ac-55de-4482-afd4-df7242ebc859} - - - - - - \ No newline at end of file diff --git a/project/vs2015/examples/core_basic_window_cpp.vcxproj b/project/vs2015/examples/core_basic_window_cpp.vcxproj deleted file mode 100644 index 90379fe5f..000000000 --- a/project/vs2015/examples/core_basic_window_cpp.vcxproj +++ /dev/null @@ -1,180 +0,0 @@ - - - - - Debug_DLL - Win32 - - - Debug - Win32 - - - Release_DLL - Win32 - - - Release - Win32 - - - - {B655E850-3322-42F7-941D-6AC18FD66CA1} - Win32Proj - raylib_example_cpp - 8.1 - core_basic_window_cpp - - - - Application - true - v140 - Unicode - - - Application - true - v140 - Unicode - - - Application - false - v140 - true - Unicode - - - Application - false - v140 - true - Unicode - - - - - - - - - - - - - - - - - - - - - true - $(ProjectDir)$(ProjectName)\$(Configuration) - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - true - $(ProjectDir)$(ProjectName)\$(Configuration) - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - false - $(ProjectDir)$(ProjectName)\$(Configuration) - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - false - $(ProjectDir)$(ProjectName)\$(Configuration) - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - - - - Level3 - Disabled - WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - CompileAsCpp - - - Console - true - kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) - - - - - - - Level3 - Disabled - WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - CompileAsCpp - - - Console - true - kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) - - - - - Level3 - - - MaxSpeed - true - true - WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) - CompileAsCpp - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - - - Console - true - true - true - $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) - kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - - - - - Level3 - - - MaxSpeed - true - true - WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) - CompileAsCpp - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - - - Console - true - true - true - $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) - kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - - - - - {e89d61ac-55de-4482-afd4-df7242ebc859} - - - - - - - - - \ No newline at end of file diff --git a/project/vs2015/raylib.sln b/project/vs2015/raylib.sln deleted file mode 100644 index 2ea3c9c24..000000000 --- a/project/vs2015/raylib.sln +++ /dev/null @@ -1,54 +0,0 @@ - -Microsoft Visual Studio Solution File, Format Version 12.00 -# Visual Studio 14 -VisualStudioVersion = 14.0.25420.1 -MinimumVisualStudioVersion = 10.0.40219.1 -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "core_basic_window", "examples\core_basic_window.vcxproj", "{0981CA98-E4A5-4DF1-987F-A41D09131EFC}" -EndProject -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "raylib", "raylib\raylib.vcxproj", "{E89D61AC-55DE-4482-AFD4-DF7242EBC859}" -EndProject -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "core_basic_window_cpp", "examples\core_basic_window_cpp.vcxproj", "{B655E850-3322-42F7-941D-6AC18FD66CA1}" -EndProject -Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "examples", "examples", "{8716DC0F-4FDE-4F57-8E25-5F78DFB80FE1}" -EndProject -Global - GlobalSection(SolutionConfigurationPlatforms) = preSolution - Debug_DLL|x86 = Debug_DLL|x86 - Debug|x86 = Debug|x86 - Release_DLL|x86 = Release_DLL|x86 - Release|x86 = Release|x86 - EndGlobalSection - GlobalSection(ProjectConfigurationPlatforms) = postSolution - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug_DLL|x86.ActiveCfg = Debug_DLL|Win32 - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug_DLL|x86.Build.0 = Debug_DLL|Win32 - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug|x86.ActiveCfg = Debug|Win32 - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug|x86.Build.0 = Debug|Win32 - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release_DLL|x86.ActiveCfg = Release_DLL|Win32 - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release_DLL|x86.Build.0 = Release_DLL|Win32 - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release|x86.ActiveCfg = Release|Win32 - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release|x86.Build.0 = Release|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug_DLL|x86.ActiveCfg = Debug_DLL|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug_DLL|x86.Build.0 = Debug_DLL|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|x86.ActiveCfg = Debug|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|x86.Build.0 = Debug|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release_DLL|x86.ActiveCfg = Release_DLL|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release_DLL|x86.Build.0 = Release_DLL|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|x86.ActiveCfg = Release|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|x86.Build.0 = Release|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug_DLL|x86.ActiveCfg = Debug_DLL|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug_DLL|x86.Build.0 = Debug_DLL|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug|x86.ActiveCfg = Debug|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug|x86.Build.0 = Debug|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release_DLL|x86.ActiveCfg = Release_DLL|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release_DLL|x86.Build.0 = Release_DLL|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release|x86.ActiveCfg = Release|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release|x86.Build.0 = Release|Win32 - EndGlobalSection - GlobalSection(SolutionProperties) = preSolution - HideSolutionNode = FALSE - EndGlobalSection - GlobalSection(NestedProjects) = preSolution - {0981CA98-E4A5-4DF1-987F-A41D09131EFC} = {8716DC0F-4FDE-4F57-8E25-5F78DFB80FE1} - {B655E850-3322-42F7-941D-6AC18FD66CA1} = {8716DC0F-4FDE-4F57-8E25-5F78DFB80FE1} - EndGlobalSection -EndGlobal diff --git a/project/vs2015/raylib/raylib.vcxproj b/project/vs2015/raylib/raylib.vcxproj deleted file mode 100644 index 97ce13e6d..000000000 --- a/project/vs2015/raylib/raylib.vcxproj +++ /dev/null @@ -1,198 +0,0 @@ - - - - - Debug_DLL - Win32 - - - Debug - Win32 - - - Release_DLL - Win32 - - - Release - Win32 - - - - {E89D61AC-55DE-4482-AFD4-DF7242EBC859} - Win32Proj - raylib - 8.1 - - - - StaticLibrary - true - v140 - Unicode - - - DynamicLibrary - true - v140 - Unicode - - - StaticLibrary - false - v140 - true - Unicode - - - DynamicLibrary - false - v140 - true - Unicode - - - - - - - - - - - - - - - - - - - - - $(SolutionDir)$(ProjectName)\$(Configuration)\ - - - $(SolutionDir)$(ProjectName)\$(Configuration)\ - - - $(SolutionDir)$(ProjectName)\$(Configuration)\ - $(SolutionDir)$(ProjectName)\$(Configuration)\temp - - - $(SolutionDir)$(ProjectName)\$(Configuration)\ - $(SolutionDir)$(ProjectName)\$(Configuration)\temp - - - - - - Level3 - Disabled - WIN32;_DEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP - CompileAsC - $(SolutionDir)..\..\src\external\glfw\include;$(SolutionDir)..\..\release\include - MultiThreadedDebug - - - Windows - - - %(AdditionalLibraryDirectories) - - - - - - - Level3 - Disabled - WIN32;_DEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP;BUILD_LIBTYPE_SHARED - CompileAsC - $(SolutionDir)..\..\src\external\glfw\include;$(SolutionDir)..\..\release\include - MultiThreadedDebug - - - Windows - - - %(AdditionalLibraryDirectories) - - - - - Level3 - - - MaxSpeed - true - true - WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP - $(SolutionDir)..\..\src\external\glfw\include;$(SolutionDir)..\..\release\include - CompileAsC - MultiThreaded - - - Windows - true - true - - - - - Level3 - - - MaxSpeed - true - true - WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP;BUILD_LIBTYPE_SHARED - $(SolutionDir)..\..\src\external\glfw\include;$(SolutionDir)..\..\release\include - CompileAsC - MultiThreaded - - - Windows - true - true - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/project/vs2017/examples/core_basic_window.vcxproj b/project/vs2017/examples/core_basic_window.vcxproj deleted file mode 100644 index 7b4d4a8cd..000000000 --- a/project/vs2017/examples/core_basic_window.vcxproj +++ /dev/null @@ -1,182 +0,0 @@ - - - - - Debug_DLL - Win32 - - - Debug - Win32 - - - Release_DLL - Win32 - - - Release - Win32 - - - - {0981CA98-E4A5-4DF1-987F-A41D09131EFC} - Win32Proj - core_basic_window - 10.0.14393.0 - core_basic_window - - - - Application - true - v141 - Unicode - - - Application - true - v141 - Unicode - - - Application - false - v141 - true - Unicode - - - Application - false - v141 - true - Unicode - - - - - - - - - - - - - - - - - - - - - true - $(ProjectDir)$(ProjectName)\$(Configuration)\ - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - true - $(ProjectDir)$(ProjectName)\$(Configuration)\ - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - false - $(ProjectDir)$(ProjectName)\$(Configuration)\ - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - false - $(ProjectDir)$(ProjectName)\$(Configuration)\ - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - - - - Level3 - Disabled - WIN32;_DEBUG;_CONSOLE;PLATFORM_DESKTOP;%(PreprocessorDefinitions) - CompileAsC - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - - - Console - true - %(AdditionalLibraryDirectories) - kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - - - - - - - Level3 - Disabled - WIN32;_DEBUG;_CONSOLE;PLATFORM_DESKTOP;%(PreprocessorDefinitions) - CompileAsC - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - - - Console - true - %(AdditionalLibraryDirectories) - kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - - - - - Level3 - - - MaxSpeed - true - true - WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions);PLATFORM_DESKTOP - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - CompileAsC - true - - - Console - true - true - true - kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - %(AdditionalLibraryDirectories) - - - - - Level3 - - - MaxSpeed - true - true - WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions);PLATFORM_DESKTOP - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - CompileAsC - true - - - Console - true - true - true - kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - %(AdditionalLibraryDirectories) - - - - - - - - {e89d61ac-55de-4482-afd4-df7242ebc859} - - - - - - \ No newline at end of file diff --git a/project/vs2017/examples/core_basic_window_cpp.vcxproj b/project/vs2017/examples/core_basic_window_cpp.vcxproj deleted file mode 100644 index a015690cd..000000000 --- a/project/vs2017/examples/core_basic_window_cpp.vcxproj +++ /dev/null @@ -1,180 +0,0 @@ - - - - - Debug_DLL - Win32 - - - Debug - Win32 - - - Release_DLL - Win32 - - - Release - Win32 - - - - {B655E850-3322-42F7-941D-6AC18FD66CA1} - Win32Proj - raylib_example_cpp - 10.0.14393.0 - core_basic_window_cpp - - - - Application - true - v141 - Unicode - - - Application - true - v141 - Unicode - - - Application - false - v141 - true - Unicode - - - Application - false - v141 - true - Unicode - - - - - - - - - - - - - - - - - - - - - true - $(ProjectDir)$(ProjectName)\$(Configuration) - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - true - $(ProjectDir)$(ProjectName)\$(Configuration) - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - false - $(ProjectDir)$(ProjectName)\$(Configuration) - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - false - $(ProjectDir)$(ProjectName)\$(Configuration) - $(ProjectDir)$(ProjectName)\$(Configuration)\temp - - - - - - Level3 - Disabled - WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - CompileAsCpp - - - Console - true - kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) - - - - - - - Level3 - Disabled - WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - CompileAsCpp - - - Console - true - kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) - - - - - Level3 - - - MaxSpeed - true - true - WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) - CompileAsCpp - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - - - Console - true - true - true - $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) - kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - - - - - Level3 - - - MaxSpeed - true - true - WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) - CompileAsCpp - $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) - - - Console - true - true - true - %(AdditionalLibraryDirectories) - kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) - - - - - {e89d61ac-55de-4482-afd4-df7242ebc859} - - - - - - - - - \ No newline at end of file diff --git a/project/vs2017/raylib.sln b/project/vs2017/raylib.sln deleted file mode 100644 index 77378c847..000000000 --- a/project/vs2017/raylib.sln +++ /dev/null @@ -1,57 +0,0 @@ - -Microsoft Visual Studio Solution File, Format Version 12.00 -# Visual Studio 15 -VisualStudioVersion = 15.0.27130.2024 -MinimumVisualStudioVersion = 10.0.40219.1 -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "core_basic_window", "examples\core_basic_window.vcxproj", "{0981CA98-E4A5-4DF1-987F-A41D09131EFC}" -EndProject -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "raylib", "raylib\raylib.vcxproj", "{E89D61AC-55DE-4482-AFD4-DF7242EBC859}" -EndProject -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "core_basic_window_cpp", "examples\core_basic_window_cpp.vcxproj", "{B655E850-3322-42F7-941D-6AC18FD66CA1}" -EndProject -Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "examples", "examples", "{8716DC0F-4FDE-4F57-8E25-5F78DFB80FE1}" -EndProject -Global - GlobalSection(SolutionConfigurationPlatforms) = preSolution - Debug_DLL|x86 = Debug_DLL|x86 - Debug|x86 = Debug|x86 - Release_DLL|x86 = Release_DLL|x86 - Release|x86 = Release|x86 - EndGlobalSection - GlobalSection(ProjectConfigurationPlatforms) = postSolution - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug_DLL|x86.ActiveCfg = Debug_DLL|Win32 - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug_DLL|x86.Build.0 = Debug_DLL|Win32 - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug|x86.ActiveCfg = Debug|Win32 - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug|x86.Build.0 = Debug|Win32 - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release_DLL|x86.ActiveCfg = Release_DLL|Win32 - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release_DLL|x86.Build.0 = Release_DLL|Win32 - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release|x86.ActiveCfg = Release|Win32 - {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release|x86.Build.0 = Release|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug_DLL|x86.ActiveCfg = Debug_DLL|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug_DLL|x86.Build.0 = Debug_DLL|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|x86.ActiveCfg = Debug|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|x86.Build.0 = Debug|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release_DLL|x86.ActiveCfg = Release_DLL|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release_DLL|x86.Build.0 = Release_DLL|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|x86.ActiveCfg = Release|Win32 - {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|x86.Build.0 = Release|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug_DLL|x86.ActiveCfg = Debug_DLL|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug_DLL|x86.Build.0 = Debug_DLL|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug|x86.ActiveCfg = Debug|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug|x86.Build.0 = Debug|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release_DLL|x86.ActiveCfg = Release_DLL|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release_DLL|x86.Build.0 = Release_DLL|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release|x86.ActiveCfg = Release|Win32 - {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release|x86.Build.0 = Release|Win32 - EndGlobalSection - GlobalSection(SolutionProperties) = preSolution - HideSolutionNode = FALSE - EndGlobalSection - GlobalSection(NestedProjects) = preSolution - {0981CA98-E4A5-4DF1-987F-A41D09131EFC} = {8716DC0F-4FDE-4F57-8E25-5F78DFB80FE1} - {B655E850-3322-42F7-941D-6AC18FD66CA1} = {8716DC0F-4FDE-4F57-8E25-5F78DFB80FE1} - EndGlobalSection - GlobalSection(ExtensibilityGlobals) = postSolution - SolutionGuid = {E926C768-6307-4423-A1EC-57E95B1FAB29} - EndGlobalSection -EndGlobal diff --git a/project/vs2017/raylib/raylib.vcxproj b/project/vs2017/raylib/raylib.vcxproj deleted file mode 100644 index 582067933..000000000 --- a/project/vs2017/raylib/raylib.vcxproj +++ /dev/null @@ -1,197 +0,0 @@ - - - - - Debug_DLL - Win32 - - - Debug - Win32 - - - Release_DLL - Win32 - - - Release - Win32 - - - - {E89D61AC-55DE-4482-AFD4-DF7242EBC859} - Win32Proj - raylib - 10.0.14393.0 - - - - StaticLibrary - true - v141 - Unicode - - - DynamicLibrary - true - v141 - Unicode - - - StaticLibrary - false - v141 - true - Unicode - - - DynamicLibrary - false - v141 - true - Unicode - - - - - - - - - - - - - - - - - - - - - $(SolutionDir)$(ProjectName)\$(Configuration)\ - - - $(SolutionDir)$(ProjectName)\$(Configuration)\ - - - $(SolutionDir)$(ProjectName)\$(Configuration)\ - $(SolutionDir)$(ProjectName)\$(Configuration)\temp - - - $(SolutionDir)$(ProjectName)\$(Configuration)\ - $(SolutionDir)$(ProjectName)\$(Configuration)\temp - - - - - - Level3 - Disabled - WIN32;_DEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP - CompileAsC - $(SolutionDir)..\..\release\include;$(SolutionDir)..\..\src\external\glfw\include - - - Windows - - - %(AdditionalLibraryDirectories) - - - - - - - Level3 - Disabled - WIN32;_DEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP;BUILD_LIBTYPE_SHARED - CompileAsC - $(SolutionDir)..\..\release\include;$(SolutionDir)..\..\src\external\glfw\include - MultiThreadedDebug - - - Windows - - - %(AdditionalLibraryDirectories) - - - - - Level3 - - - MaxSpeed - true - true - WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP - $(SolutionDir)..\..\release\include;$(SolutionDir)..\..\src\external\glfw\include - CompileAsC - - - Windows - true - true - - - - - Level3 - - - MaxSpeed - true - true - WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP;BUILD_LIBTYPE_SHARED - $(SolutionDir)..\..\release\include;$(SolutionDir)..\..\src\external\glfw\include - CompileAsC - MultiThreaded - - - Windows - true - true - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/project/Builder/README.md b/projects/Builder/README.md similarity index 100% rename from project/Builder/README.md rename to projects/Builder/README.md diff --git a/project/Builder/examples/README.md b/projects/Builder/examples/README.md similarity index 100% rename from project/Builder/examples/README.md rename to projects/Builder/examples/README.md diff --git a/project/Builder/examples/meson.build b/projects/Builder/examples/meson.build similarity index 100% rename from project/Builder/examples/meson.build rename to projects/Builder/examples/meson.build diff --git a/project/Builder/meson.build b/projects/Builder/meson.build similarity index 100% rename from project/Builder/meson.build rename to projects/Builder/meson.build diff --git a/projects/CodeBlocks/HELPME b/projects/CodeBlocks/HELPME new file mode 100644 index 000000000..e69de29bb diff --git a/projects/Geany/HELPME b/projects/Geany/HELPME new file mode 100644 index 000000000..e69de29bb diff --git a/projects/KDevelop/HELPME b/projects/KDevelop/HELPME new file mode 100644 index 000000000..e69de29bb diff --git a/projects/Notepad++/README.md b/projects/Notepad++/README.md new file mode 100644 index 000000000..7a2e261ed --- /dev/null +++ b/projects/Notepad++/README.md @@ -0,0 +1,19 @@ +### Notepad++ raylib config files + +This folder includes some useful files to config Notepad++ for raylib. + +#### raylib functions autocomplete - c_raylib.xml + +Autocomplete information for Notepad++. The contents of this file should be copied inside raylib\Notepad++\plugins\APIs\c.xml file. + +This file has been automatically generated using the provided tool: `raylib_npp_parser` + +This simple tool basically parses raylib.h header for functions starting by RLAPI, extracts all required information and generates de Notepad++ autocomplete XML equivalent. + +To use the tool, just drag and drop raylib.h over raylib_npp_parser program. + +#### Notepad++ NppExec compilation scripts - npes_saved.txt + +A series of scripts for Notepad++ NppExec plugin to compile raylib library and examples. + + diff --git a/projects/Notepad++/c_raylib.xml b/projects/Notepad++/c_raylib.xml new file mode 100644 index 000000000..4ad114100 --- /dev/null +++ b/projects/Notepad++/c_raylib.xml @@ -0,0 +1,2067 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/projects/Notepad++/npes_saved.txt b/projects/Notepad++/npes_saved.txt new file mode 100644 index 0000000000000000000000000000000000000000..ecc5c524bfb909141e7dd742fa5c6f5da164a585 GIT binary patch literal 11872 zcmeHNZBH9V5T4JK`XBB?Ka{Grl~6@(Bq}AgL#z-$hBQS&vdocCtA3%jN!mZ3^m%qz z-;VDNpWrT-#EKkt_jYG?=jEB1z5D#>sXUc4>B~$85=-y;H<6KCVq}OXbNrpiSiYC< zg@y33xB(^BTbz26uaxoe>m3wr{!V1iEJ5ZSjkYnO-S17;T`(a5&J{P zl20Rfj}i9l+S|&MR4#CW7?f*H%RI+EB=Q=k=m}-h#qPJH4xazIU2w(=NO;f9@N>5u zg}0FP5dTPR2Hl@SsCpO>CXQ*Hj;KW&q6M8fR2stitZr`SC8QC<3+d$z=P4c7 zKkf8Sc)^jwpVeM-j@{8O8gA{X`Qg69wt7p55?%tAu-OTGnU*^$;oRg}CNj)$cE#ge zXl)L>y@H-BI-f#+Q%IPj)a3+o*k_xF(g6z9Awm6L=ju4IiTa9fGu0O=n zBoc7O5F9SCinu;>xUQoY(Dfkbe{^;>f?Pe_hlXoDil=Rml6(LQoE;xnRI37(apkky7pjR>|!drz{eLqu9;C@)+N z@fs(Lkm0m}Jg;0{aVS4yq>EVHajj>FZ7uW<&~Lesx0wCh?L3KjmgWvt+Yx3_A&+pc zVf!KFg-ND&_sr1K`f|Bp=&7{Ro9#NWvLY>N)MmJ~1^p;x8=5IETa0FaYG?U)v)-9r z7;~2MzO>ahU1hYcxN&eD+jimE5fFs<5TQO}lq9~eMkAIyLOgxsaN_ZzwT;%cL5y7> z3TeCql_n|!rMDw?{Alr{2mCn%g6w0)9!9sX>E&C-CTmV-%?+1v`uZ}f$|e4Ud5zDZ zXszW|ruUn3+x+<_*yqIAr_C(vEUo!N>C}-6gnk^h)44TKHe5~2oghA6AzNgOwyTTa zY~CDFO0w+(+%PcHWZpV;x#@e{JJemjCSi@ujF>Y!*pJPC8;f-fm%YZ=^Oegj@_8}y zVdm{Q*$SR~Ebrnxxwe&xBUw2{o)m`eJjHg_alNyZH4d$*=-HOzZgDAkj@5HgKVilDCC=4%md%J({mIfcPcJz`g!|yUhxdZXnXSLn z9b#nLUYf4vV*^lTMe9#ioFZ?hcvqP0=4O8`X3P2Udlyzb#*c_eOIyay1dXS-k1ZEF z``}7`F;2_dAl~(c$W7eW%1-f(_t_z`YTsiFdlm~g;=L#F*Km~a$j1k7_Z$grQ)jTs zPPEFgYzyL(P=^}t^5x$FT~g8;SYOMBQV1nerVgk}8;2Q5E}>;>19jl5-jwHMGPVXe zg`A$qulUsv|DMP%_?w + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/projects/Notepad++/raylib_npp_parser/raylib_npp_parser.c b/projects/Notepad++/raylib_npp_parser/raylib_npp_parser.c new file mode 100644 index 000000000..7ab551891 --- /dev/null +++ b/projects/Notepad++/raylib_npp_parser/raylib_npp_parser.c @@ -0,0 +1,148 @@ +/********************************************************************************************** + + raylib_npp_parser - raylib header parser to generate Notepad++ autocompletion data + + This parser scans raylib.h for functions that start with RLAPI and generates Notepad++ + autocompletion xml equivalent for function and parameters. + + Converts: + RLAPI Color Fade(Color color, float alpha); // Color fade-in or fade-out, alpha goes from 0.0f to 1.0f + + To: + + + + + + + + NOTE: Generated XML text should be copied inside raylib\Notepad++\plugins\APIs\c.xml + + LICENSE: zlib/libpng + + raylib is licensed under an unmodified zlib/libpng license, which is an OSI-certified, + BSD-like license that allows static linking with closed source software: + + Copyright (c) 2018 Ramon Santamaria (@raysan5) + +**********************************************************************************************/ + +#include +#include +#include +#include + +#define MAX_BUFFER_SIZE 512 + +int main(int argc, char *argv[]) +{ + if (argc > 1) + { + FILE *rFile = fopen(argv[1], "rt"); + FILE *rxmlFile = fopen("raylib_npp.xml", "wt"); + + if ((rFile == NULL) || (rxmlFile == NULL)) + { + printf("File could not be opened.\n"); + return 0; + } + + char *buffer = (char *)calloc(MAX_BUFFER_SIZE, 1); + int count = 0; + + while (!feof(rFile)) + { + // Read one full line + fgets(buffer, MAX_BUFFER_SIZE, rFile); + + if (buffer[0] == '/') fprintf(rxmlFile, " \n", strlen(buffer) - 3, buffer + 2); + else if (buffer[0] == '\n') fprintf(rxmlFile, "%s", buffer); // Direct copy of code comments + else if (strncmp(buffer, "RLAPI", 5) == 0) // raylib function declaration + { + char funcType[64]; + char funcTypeAux[64]; + char funcName[64]; + char funcDesc[256]; + + char params[128]; + char paramType[8][16]; + char paramName[8][32]; + + int index = 0; + char *ptr = NULL; + + sscanf(buffer, "RLAPI %s %[^(]s", funcType, funcName); + + if (strcmp(funcType, "const") == 0) + { + sscanf(buffer, "RLAPI %s %s %[^(]s", funcType, funcTypeAux, funcName); + strcat(funcType, " "); + strcat(funcType, funcTypeAux); + } + + ptr = strchr(buffer, '/'); + index = (int)(ptr - buffer); + + sscanf(buffer + index, "%[^\n]s", funcDesc); // Read function comment after declaration + + ptr = strchr(buffer, '('); + + if (ptr != NULL) index = (int)(ptr - buffer); + else printf("Character not found!\n"); + + sscanf(buffer + (index + 1), "%[^)]s", params); // Read what's inside '(' and ')' + + // Scan params string for number of func params, type and name + char *paramPtr[16]; // Allocate 16 pointers for possible parameters + int paramsCount = 0; + paramPtr[paramsCount] = strtok(params, ","); + + if ((funcName[0] == '*') && (funcName[1] == '*')) fprintf(rxmlFile, " \n", funcName + 2); + else if (funcName[0] == '*') fprintf(rxmlFile, " \n", funcName + 1); + else fprintf(rxmlFile, " \n", funcName); + + fprintf(rxmlFile, " ", funcType, funcDesc + 3); + + bool paramsVoid = false; + + char paramConst[8][16]; + + while (paramPtr[paramsCount] != NULL) + { + sscanf(paramPtr[paramsCount], "%s %s\n", paramType[paramsCount], paramName[paramsCount]); + + if (strcmp(paramType[paramsCount], "void") == 0) + { + paramsVoid = true; + break; + } + + if ((strcmp(paramType[paramsCount], "const") == 0) || (strcmp(paramType[paramsCount], "unsigned") == 0)) + { + sscanf(paramPtr[paramsCount], "%s %s %s\n", paramConst[paramsCount], paramType[paramsCount], paramName[paramsCount]); + fprintf(rxmlFile, "\n ", paramConst[paramsCount], paramType[paramsCount], paramName[paramsCount]); + } + else if (strcmp(paramType[paramsCount], "...") == 0) fprintf(rxmlFile, "\n "); + else fprintf(rxmlFile, "\n ", paramType[paramsCount], paramName[paramsCount]); + + paramsCount++; + paramPtr[paramsCount] = strtok(NULL, ","); + } + + fprintf(rxmlFile, "%s\n", paramsVoid ? "" : "\n "); + fprintf(rxmlFile, " \n"); + + count++; + printf("Function processed %02i: %s\n", count, funcName); + + memset(buffer, 0, MAX_BUFFER_SIZE); + } + } + + free(buffer); + fclose(rFile); + fclose(rxmlFile); + } + + return 0; +} \ No newline at end of file diff --git a/projects/Notepad++/raylib_npp_parser/raylib_to_parse.h b/projects/Notepad++/raylib_npp_parser/raylib_to_parse.h new file mode 100644 index 000000000..004faeafb --- /dev/null +++ b/projects/Notepad++/raylib_npp_parser/raylib_to_parse.h @@ -0,0 +1,459 @@ +//------------------------------------------------------------------------------------ +// Window and Graphics Device Functions (Module: core) +//------------------------------------------------------------------------------------ + +// Window-related functions +RLAPI void InitWindow(int width, int height, const char *title); // Initialize window and OpenGL context +RLAPI void CloseWindow(void); // Close window and unload OpenGL context +RLAPI bool IsWindowReady(void); // Check if window has been initialized successfully +RLAPI bool WindowShouldClose(void); // Check if KEY_ESCAPE pressed or Close icon pressed +RLAPI bool IsWindowMinimized(void); // Check if window has been minimized (or lost focus) +RLAPI void ToggleFullscreen(void); // Toggle fullscreen mode (only PLATFORM_DESKTOP) +RLAPI void SetWindowIcon(Image image); // Set icon for window (only PLATFORM_DESKTOP) +RLAPI void SetWindowTitle(const char *title); // Set title for window (only PLATFORM_DESKTOP) +RLAPI void SetWindowPosition(int x, int y); // Set window position on screen (only PLATFORM_DESKTOP) +RLAPI void SetWindowMonitor(int monitor); // Set monitor for the current window (fullscreen mode) +RLAPI void SetWindowMinSize(int width, int height); // Set window minimum dimensions (for FLAG_WINDOW_RESIZABLE) +RLAPI void SetWindowSize(int width, int height); // Set window dimensions +RLAPI int GetScreenWidth(void); // Get current screen width +RLAPI int GetScreenHeight(void); // Get current screen height + +// Cursor-related functions +RLAPI void ShowCursor(void); // Shows cursor +RLAPI void HideCursor(void); // Hides cursor +RLAPI bool IsCursorHidden(void); // Check if cursor is not visible +RLAPI void EnableCursor(void); // Enables cursor (unlock cursor) +RLAPI void DisableCursor(void); // Disables cursor (lock cursor) + +// Drawing-related functions +RLAPI void ClearBackground(Color color); // Set background color (framebuffer clear color) +RLAPI void BeginDrawing(void); // Setup canvas (framebuffer) to start drawing +RLAPI void EndDrawing(void); // End canvas drawing and swap buffers (double buffering) +RLAPI void BeginMode2D(Camera2D camera); // Initialize 2D mode with custom camera (2D) +RLAPI void EndMode2D(void); // Ends 2D mode with custom camera +RLAPI void BeginMode3D(Camera3D camera); // Initializes 3D mode with custom camera (3D) +RLAPI void EndMode3D(void); // Ends 3D mode and returns to default 2D orthographic mode +RLAPI void BeginTextureMode(RenderTexture2D target); // Initializes render texture for drawing +RLAPI void EndTextureMode(void); // Ends drawing to render texture + +// Screen-space-related functions +RLAPI Ray GetMouseRay(Vector2 mousePosition, Camera camera); // Returns a ray trace from mouse position +RLAPI Vector2 GetWorldToScreen(Vector3 position, Camera camera); // Returns the screen space position for a 3d world space position +RLAPI Matrix GetCameraMatrix(Camera camera); // Returns camera transform matrix (view matrix) + +// Timming-related functions +RLAPI void SetTargetFPS(int fps); // Set target FPS (maximum) +RLAPI int GetFPS(void); // Returns current FPS +RLAPI float GetFrameTime(void); // Returns time in seconds for last frame drawn +RLAPI double GetTime(void); // Returns elapsed time in seconds since InitWindow() + +// Color-related functions +RLAPI int ColorToInt(Color color); // Returns hexadecimal value for a Color +RLAPI Vector4 ColorNormalize(Color color); // Returns color normalized as float [0..1] +RLAPI Vector3 ColorToHSV(Color color); // Returns HSV values for a Color +RLAPI Color GetColor(int hexValue); // Returns a Color struct from hexadecimal value +RLAPI Color Fade(Color color, float alpha); // Color fade-in or fade-out, alpha goes from 0.0f to 1.0f + +// Misc. functions +RLAPI void ShowLogo(void); // Activate raylib logo at startup (can be done with flags) +RLAPI void SetConfigFlags(unsigned char flags); // Setup window configuration flags (view FLAGS) +RLAPI void SetTraceLog(unsigned char types); // Enable trace log message types (bit flags based) +RLAPI void TraceLog(int logType, const char *text, ...); // Show trace log messages (LOG_INFO, LOG_WARNING, LOG_ERROR, LOG_DEBUG) +RLAPI void TakeScreenshot(const char *fileName); // Takes a screenshot of current screen (saved a .png) +RLAPI int GetRandomValue(int min, int max); // Returns a random value between min and max (both included) + +// Files management functions +RLAPI bool IsFileExtension(const char *fileName, const char *ext);// Check file extension +RLAPI const char *GetExtension(const char *fileName); // Get pointer to extension for a filename string +RLAPI const char *GetFileName(const char *filePath); // Get pointer to filename for a path string +RLAPI const char *GetDirectoryPath(const char *fileName); // Get full path for a given fileName (uses static string) +RLAPI const char *GetWorkingDirectory(void); // Get current working directory (uses static string) +RLAPI bool ChangeDirectory(const char *dir); // Change working directory, returns true if success +RLAPI bool IsFileDropped(void); // Check if a file has been dropped into window +RLAPI char **GetDroppedFiles(int *count); // Get dropped files names +RLAPI void ClearDroppedFiles(void); // Clear dropped files paths buffer + +// Persistent storage management +RLAPI void StorageSaveValue(int position, int value); // Save integer value to storage file (to defined position) +RLAPI int StorageLoadValue(int position); // Load integer value from storage file (from defined position) + +//------------------------------------------------------------------------------------ +// Input Handling Functions (Module: core) +//------------------------------------------------------------------------------------ + +// Input-related functions: keyboard +RLAPI bool IsKeyPressed(int key); // Detect if a key has been pressed once +RLAPI bool IsKeyDown(int key); // Detect if a key is being pressed +RLAPI bool IsKeyReleased(int key); // Detect if a key has been released once +RLAPI bool IsKeyUp(int key); // Detect if a key is NOT being pressed +RLAPI int GetKeyPressed(void); // Get latest key pressed +RLAPI void SetExitKey(int key); // Set a custom key to exit program (default is ESC) + +// Input-related functions: gamepads +RLAPI bool IsGamepadAvailable(int gamepad); // Detect if a gamepad is available +RLAPI bool IsGamepadName(int gamepad, const char *name); // Check gamepad name (if available) +RLAPI const char *GetGamepadName(int gamepad); // Return gamepad internal name id +RLAPI bool IsGamepadButtonPressed(int gamepad, int button); // Detect if a gamepad button has been pressed once +RLAPI bool IsGamepadButtonDown(int gamepad, int button); // Detect if a gamepad button is being pressed +RLAPI bool IsGamepadButtonReleased(int gamepad, int button); // Detect if a gamepad button has been released once +RLAPI bool IsGamepadButtonUp(int gamepad, int button); // Detect if a gamepad button is NOT being pressed +RLAPI int GetGamepadButtonPressed(void); // Get the last gamepad button pressed +RLAPI int GetGamepadAxisCount(int gamepad); // Return gamepad axis count for a gamepad +RLAPI float GetGamepadAxisMovement(int gamepad, int axis); // Return axis movement value for a gamepad axis + +// Input-related functions: mouse +RLAPI bool IsMouseButtonPressed(int button); // Detect if a mouse button has been pressed once +RLAPI bool IsMouseButtonDown(int button); // Detect if a mouse button is being pressed +RLAPI bool IsMouseButtonReleased(int button); // Detect if a mouse button has been released once +RLAPI bool IsMouseButtonUp(int button); // Detect if a mouse button is NOT being pressed +RLAPI int GetMouseX(void); // Returns mouse position X +RLAPI int GetMouseY(void); // Returns mouse position Y +RLAPI Vector2 GetMousePosition(void); // Returns mouse position XY +RLAPI void SetMousePosition(Vector2 position); // Set mouse position XY +RLAPI void SetMouseScale(float scale); // Set mouse scaling +RLAPI int GetMouseWheelMove(void); // Returns mouse wheel movement Y + +// Input-related functions: touch +RLAPI int GetTouchX(void); // Returns touch position X for touch point 0 (relative to screen size) +RLAPI int GetTouchY(void); // Returns touch position Y for touch point 0 (relative to screen size) +RLAPI Vector2 GetTouchPosition(int index); // Returns touch position XY for a touch point index (relative to screen size) + +//------------------------------------------------------------------------------------ +// Gestures and Touch Handling Functions (Module: gestures) +//------------------------------------------------------------------------------------ +RLAPI void SetGesturesEnabled(unsigned int gestureFlags); // Enable a set of gestures using flags +RLAPI bool IsGestureDetected(int gesture); // Check if a gesture have been detected +RLAPI int GetGestureDetected(void); // Get latest detected gesture +RLAPI int GetTouchPointsCount(void); // Get touch points count +RLAPI float GetGestureHoldDuration(void); // Get gesture hold time in milliseconds +RLAPI Vector2 GetGestureDragVector(void); // Get gesture drag vector +RLAPI float GetGestureDragAngle(void); // Get gesture drag angle +RLAPI Vector2 GetGesturePinchVector(void); // Get gesture pinch delta +RLAPI float GetGesturePinchAngle(void); // Get gesture pinch angle + +//------------------------------------------------------------------------------------ +// Camera System Functions (Module: camera) +//------------------------------------------------------------------------------------ +RLAPI void SetCameraMode(Camera camera, int mode); // Set camera mode (multiple camera modes available) +RLAPI void UpdateCamera(Camera *camera); // Update camera position for selected mode + +RLAPI void SetCameraPanControl(int panKey); // Set camera pan key to combine with mouse movement (free camera) +RLAPI void SetCameraAltControl(int altKey); // Set camera alt key to combine with mouse movement (free camera) +RLAPI void SetCameraSmoothZoomControl(int szKey); // Set camera smooth zoom key to combine with mouse (free camera) +RLAPI void SetCameraMoveControls(int frontKey, int backKey, int rightKey, int leftKey, int upKey, int downKey); // Set camera move controls (1st person and 3rd person cameras) + +//------------------------------------------------------------------------------------ +// Basic Shapes Drawing Functions (Module: shapes) +//------------------------------------------------------------------------------------ + +// Basic shapes drawing functions +RLAPI void DrawPixel(int posX, int posY, Color color); // Draw a pixel +RLAPI void DrawPixelV(Vector2 position, Color color); // Draw a pixel (Vector version) +RLAPI void DrawLine(int startPosX, int startPosY, int endPosX, int endPosY, Color color); // Draw a line +RLAPI void DrawLineV(Vector2 startPos, Vector2 endPos, Color color); // Draw a line (Vector version) +RLAPI void DrawLineEx(Vector2 startPos, Vector2 endPos, float thick, Color color); // Draw a line defining thickness +RLAPI void DrawLineBezier(Vector2 startPos, Vector2 endPos, float thick, Color color); // Draw a line using cubic-bezier curves in-out +RLAPI void DrawCircle(int centerX, int centerY, float radius, Color color); // Draw a color-filled circle +RLAPI void DrawCircleGradient(int centerX, int centerY, float radius, Color color1, Color color2); // Draw a gradient-filled circle +RLAPI void DrawCircleV(Vector2 center, float radius, Color color); // Draw a color-filled circle (Vector version) +RLAPI void DrawCircleLines(int centerX, int centerY, float radius, Color color); // Draw circle outline +RLAPI void DrawRectangle(int posX, int posY, int width, int height, Color color); // Draw a color-filled rectangle +RLAPI void DrawRectangleV(Vector2 position, Vector2 size, Color color); // Draw a color-filled rectangle (Vector version) +RLAPI void DrawRectangleRec(Rectangle rec, Color color); // Draw a color-filled rectangle +RLAPI void DrawRectanglePro(Rectangle rec, Vector2 origin, float rotation, Color color); // Draw a color-filled rectangle with pro parameters +RLAPI void DrawRectangleGradientV(int posX, int posY, int width, int height, Color color1, Color color2);// Draw a vertical-gradient-filled rectangle +RLAPI void DrawRectangleGradientH(int posX, int posY, int width, int height, Color color1, Color color2);// Draw a horizontal-gradient-filled rectangle +RLAPI void DrawRectangleGradientEx(Rectangle rec, Color col1, Color col2, Color col3, Color col4); // Draw a gradient-filled rectangle with custom vertex colors +RLAPI void DrawRectangleLines(int posX, int posY, int width, int height, Color color); // Draw rectangle outline +RLAPI void DrawRectangleLinesEx(Rectangle rec, int lineThick, Color color); // Draw rectangle outline with extended parameters +RLAPI void DrawTriangle(Vector2 v1, Vector2 v2, Vector2 v3, Color color); // Draw a color-filled triangle +RLAPI void DrawTriangleLines(Vector2 v1, Vector2 v2, Vector2 v3, Color color); // Draw triangle outline +RLAPI void DrawPoly(Vector2 center, int sides, float radius, float rotation, Color color); // Draw a regular polygon (Vector version) +RLAPI void DrawPolyEx(Vector2 *points, int numPoints, Color color); // Draw a closed polygon defined by points +RLAPI void DrawPolyExLines(Vector2 *points, int numPoints, Color color); // Draw polygon lines + +// Basic shapes collision detection functions +RLAPI bool CheckCollisionRecs(Rectangle rec1, Rectangle rec2); // Check collision between two rectangles +RLAPI bool CheckCollisionCircles(Vector2 center1, float radius1, Vector2 center2, float radius2); // Check collision between two circles +RLAPI bool CheckCollisionCircleRec(Vector2 center, float radius, Rectangle rec); // Check collision between circle and rectangle +RLAPI Rectangle GetCollisionRec(Rectangle rec1, Rectangle rec2); // Get collision rectangle for two rectangles collision +RLAPI bool CheckCollisionPointRec(Vector2 point, Rectangle rec); // Check if point is inside rectangle +RLAPI bool CheckCollisionPointCircle(Vector2 point, Vector2 center, float radius); // Check if point is inside circle +RLAPI bool CheckCollisionPointTriangle(Vector2 point, Vector2 p1, Vector2 p2, Vector2 p3); // Check if point is inside a triangle + +//------------------------------------------------------------------------------------ +// Texture Loading and Drawing Functions (Module: textures) +//------------------------------------------------------------------------------------ + +// Image/Texture2D data loading/unloading/saving functions +RLAPI Image LoadImage(const char *fileName); // Load image from file into CPU memory (RAM) +RLAPI Image LoadImageEx(Color *pixels, int width, int height); // Load image from Color array data (RGBA - 32bit) +RLAPI Image LoadImagePro(void *data, int width, int height, int format); // Load image from raw data with parameters +RLAPI Image LoadImageRaw(const char *fileName, int width, int height, int format, int headerSize); // Load image from RAW file data +RLAPI void ExportImage(const char *fileName, Image image); // Export image as a PNG file +RLAPI Texture2D LoadTexture(const char *fileName); // Load texture from file into GPU memory (VRAM) +RLAPI Texture2D LoadTextureFromImage(Image image); // Load texture from image data +RLAPI RenderTexture2D LoadRenderTexture(int width, int height); // Load texture for rendering (framebuffer) +RLAPI void UnloadImage(Image image); // Unload image from CPU memory (RAM) +RLAPI void UnloadTexture(Texture2D texture); // Unload texture from GPU memory (VRAM) +RLAPI void UnloadRenderTexture(RenderTexture2D target); // Unload render texture from GPU memory (VRAM) +RLAPI Color *GetImageData(Image image); // Get pixel data from image as a Color struct array +RLAPI int GetPixelDataSize(int width, int height, int format); // Get pixel data size in bytes (image or texture) +RLAPI Image GetTextureData(Texture2D texture); // Get pixel data from GPU texture and return an Image +RLAPI void UpdateTexture(Texture2D texture, const void *pixels); // Update GPU texture with new data + +// Image manipulation functions +RLAPI Image ImageCopy(Image image); // Create an image duplicate (useful for transformations) +RLAPI void ImageToPOT(Image *image, Color fillColor); // Convert image to POT (power-of-two) +RLAPI void ImageFormat(Image *image, int newFormat); // Convert image data to desired format +RLAPI void ImageAlphaMask(Image *image, Image alphaMask); // Apply alpha mask to image +RLAPI void ImageAlphaClear(Image *image, Color color, float threshold); // Clear alpha channel to desired color +RLAPI void ImageAlphaCrop(Image *image, float threshold); // Crop image depending on alpha value +RLAPI void ImageAlphaPremultiply(Image *image); // Premultiply alpha channel +RLAPI void ImageCrop(Image *image, Rectangle crop); // Crop an image to a defined rectangle +RLAPI void ImageResize(Image *image, int newWidth, int newHeight); // Resize and image (bilinear filtering) +RLAPI void ImageResizeNN(Image *image,int newWidth,int newHeight); // Resize and image (Nearest-Neighbor scaling algorithm) +RLAPI void ImageMipmaps(Image *image); // Generate all mipmap levels for a provided image +RLAPI void ImageDither(Image *image, int rBpp, int gBpp, int bBpp, int aBpp); // Dither image data to 16bpp or lower (Floyd-Steinberg dithering) +RLAPI Image ImageText(const char *text, int fontSize, Color color); // Create an image from text (default font) +RLAPI Image ImageTextEx(Font font, const char *text, float fontSize, float spacing, Color tint); // Create an image from text (custom sprite font) +RLAPI void ImageDraw(Image *dst, Image src, Rectangle srcRec, Rectangle dstRec); // Draw a source image within a destination image +RLAPI void ImageDrawRectangle(Image *dst, Vector2 position, Rectangle rec, Color color); // Draw rectangle within an image +RLAPI void ImageDrawText(Image *dst, Vector2 position, const char *text, int fontSize, Color color); // Draw text (default font) within an image (destination) +RLAPI void ImageDrawTextEx(Image *dst, Vector2 position, Font font, const char *text, float fontSize, float spacing, Color color); // Draw text (custom sprite font) within an image (destination) +RLAPI void ImageFlipVertical(Image *image); // Flip image vertically +RLAPI void ImageFlipHorizontal(Image *image); // Flip image horizontally +RLAPI void ImageColorTint(Image *image, Color color); // Modify image color: tint +RLAPI void ImageColorInvert(Image *image); // Modify image color: invert +RLAPI void ImageColorGrayscale(Image *image); // Modify image color: grayscale +RLAPI void ImageColorContrast(Image *image, float contrast); // Modify image color: contrast (-100 to 100) +RLAPI void ImageColorBrightness(Image *image, int brightness); // Modify image color: brightness (-255 to 255) + +// Image generation functions +RLAPI Image GenImageColor(int width, int height, Color color); // Generate image: plain color +RLAPI Image GenImageGradientV(int width, int height, Color top, Color bottom); // Generate image: vertical gradient +RLAPI Image GenImageGradientH(int width, int height, Color left, Color right); // Generate image: horizontal gradient +RLAPI Image GenImageGradientRadial(int width, int height, float density, Color inner, Color outer); // Generate image: radial gradient +RLAPI Image GenImageChecked(int width, int height, int checksX, int checksY, Color col1, Color col2); // Generate image: checked +RLAPI Image GenImageWhiteNoise(int width, int height, float factor); // Generate image: white noise +RLAPI Image GenImagePerlinNoise(int width, int height, int offsetX, int offsetY, float scale); // Generate image: perlin noise +RLAPI Image GenImageCellular(int width, int height, int tileSize); // Generate image: cellular algorithm. Bigger tileSize means bigger cells + +// Texture2D configuration functions +RLAPI void GenTextureMipmaps(Texture2D *texture); // Generate GPU mipmaps for a texture +RLAPI void SetTextureFilter(Texture2D texture, int filterMode); // Set texture scaling filter mode +RLAPI void SetTextureWrap(Texture2D texture, int wrapMode); // Set texture wrapping mode + +// Texture2D drawing functions +RLAPI void DrawTexture(Texture2D texture, int posX, int posY, Color tint); // Draw a Texture2D +RLAPI void DrawTextureV(Texture2D texture, Vector2 position, Color tint); // Draw a Texture2D with position defined as Vector2 +RLAPI void DrawTextureEx(Texture2D texture, Vector2 position, float rotation, float scale, Color tint); // Draw a Texture2D with extended parameters +RLAPI void DrawTextureRec(Texture2D texture, Rectangle sourceRec, Vector2 position, Color tint); // Draw a part of a texture defined by a rectangle +RLAPI void DrawTexturePro(Texture2D texture, Rectangle sourceRec, Rectangle destRec, Vector2 origin, float rotation, Color tint); // Draw a part of a texture defined by a rectangle with 'pro' parameters + + +//------------------------------------------------------------------------------------ +// Font Loading and Text Drawing Functions (Module: text) +//------------------------------------------------------------------------------------ + +// Font loading/unloading functions +RLAPI Font GetDefaultFont(void); // Get the default Font +RLAPI Font LoadFont(const char *fileName); // Load Font from file into GPU memory (VRAM) +RLAPI Font LoadFontEx(const char *fileName, int fontSize, int charsCount, int *fontChars); // Load Font from file with extended parameters +RLAPI void UnloadFont(Font font); // Unload Font from GPU memory (VRAM) + +// Text drawing functions +RLAPI void DrawFPS(int posX, int posY); // Shows current FPS +RLAPI void DrawText(const char *text, int posX, int posY, int fontSize, Color color); // Draw text (using default font) +RLAPI void DrawTextEx(Font font, const char* text, Vector2 position, float fontSize, float spacing, Color tint); // Draw text using Font and additional parameters + +// Text misc. functions +RLAPI int MeasureText(const char *text, int fontSize); // Measure string width for default font +RLAPI Vector2 MeasureTextEx(Font font, const char *text, float fontSize, float spacing); // Measure string size for Font +RLAPI const char *FormatText(const char *text, ...); // Formatting of text with variables to 'embed' +RLAPI const char *SubText(const char *text, int position, int length); // Get a piece of a text string +RLAPI int GetGlyphIndex(Font font, int character); // Returns index position for a unicode character on sprite font + +//------------------------------------------------------------------------------------ +// Basic 3d Shapes Drawing Functions (Module: models) +//------------------------------------------------------------------------------------ + +// Basic geometric 3D shapes drawing functions +RLAPI void DrawLine3D(Vector3 startPos, Vector3 endPos, Color color); // Draw a line in 3D world space +RLAPI void DrawCircle3D(Vector3 center, float radius, Vector3 rotationAxis, float rotationAngle, Color color); // Draw a circle in 3D world space +RLAPI void DrawCube(Vector3 position, float width, float height, float length, Color color); // Draw cube +RLAPI void DrawCubeV(Vector3 position, Vector3 size, Color color); // Draw cube (Vector version) +RLAPI void DrawCubeWires(Vector3 position, float width, float height, float length, Color color); // Draw cube wires +RLAPI void DrawCubeTexture(Texture2D texture, Vector3 position, float width, float height, float length, Color color); // Draw cube textured +RLAPI void DrawSphere(Vector3 centerPos, float radius, Color color); // Draw sphere +RLAPI void DrawSphereEx(Vector3 centerPos, float radius, int rings, int slices, Color color); // Draw sphere with extended parameters +RLAPI void DrawSphereWires(Vector3 centerPos, float radius, int rings, int slices, Color color); // Draw sphere wires +RLAPI void DrawCylinder(Vector3 position, float radiusTop, float radiusBottom, float height, int slices, Color color); // Draw a cylinder/cone +RLAPI void DrawCylinderWires(Vector3 position, float radiusTop, float radiusBottom, float height, int slices, Color color); // Draw a cylinder/cone wires +RLAPI void DrawPlane(Vector3 centerPos, Vector2 size, Color color); // Draw a plane XZ +RLAPI void DrawRay(Ray ray, Color color); // Draw a ray line +RLAPI void DrawGrid(int slices, float spacing); // Draw a grid (centered at (0, 0, 0)) +RLAPI void DrawGizmo(Vector3 position); // Draw simple gizmo +//DrawTorus(), DrawTeapot() could be useful? + +//------------------------------------------------------------------------------------ +// Model 3d Loading and Drawing Functions (Module: models) +//------------------------------------------------------------------------------------ + +// Model loading/unloading functions +RLAPI Model LoadModel(const char *fileName); // Load model from files (mesh and material) +RLAPI Model LoadModelFromMesh(Mesh mesh); // Load model from generated mesh +RLAPI void UnloadModel(Model model); // Unload model from memory (RAM and/or VRAM) + +// Mesh loading/unloading functions +RLAPI Mesh LoadMesh(const char *fileName); // Load mesh from file +RLAPI void UnloadMesh(Mesh *mesh); // Unload mesh from memory (RAM and/or VRAM) +RLAPI void ExportMesh(const char *fileName, Mesh mesh); // Export mesh as an OBJ file + +// Mesh manipulation functions +RLAPI BoundingBox MeshBoundingBox(Mesh mesh); // Compute mesh bounding box limits +RLAPI void MeshTangents(Mesh *mesh); // Compute mesh tangents +RLAPI void MeshBinormals(Mesh *mesh); // Compute mesh binormals + +// Mesh generation functions +RLAPI Mesh GenMeshPlane(float width, float length, int resX, int resZ); // Generate plane mesh (with subdivisions) +RLAPI Mesh GenMeshCube(float width, float height, float length); // Generate cuboid mesh +RLAPI Mesh GenMeshSphere(float radius, int rings, int slices); // Generate sphere mesh (standard sphere) +RLAPI Mesh GenMeshHemiSphere(float radius, int rings, int slices); // Generate half-sphere mesh (no bottom cap) +RLAPI Mesh GenMeshCylinder(float radius, float height, int slices); // Generate cylinder mesh +RLAPI Mesh GenMeshTorus(float radius, float size, int radSeg, int sides); // Generate torus mesh +RLAPI Mesh GenMeshKnot(float radius, float size, int radSeg, int sides); // Generate trefoil knot mesh +RLAPI Mesh GenMeshHeightmap(Image heightmap, Vector3 size); // Generate heightmap mesh from image data +RLAPI Mesh GenMeshCubicmap(Image cubicmap, Vector3 cubeSize); // Generate cubes-based map mesh from image data + +// Material loading/unloading functions +RLAPI Material LoadMaterial(const char *fileName); // Load material from file +RLAPI Material LoadMaterialDefault(void); // Load default material (Supports: DIFFUSE, SPECULAR, NORMAL maps) +RLAPI void UnloadMaterial(Material material); // Unload material from GPU memory (VRAM) + +// Model drawing functions +RLAPI void DrawModel(Model model, Vector3 position, float scale, Color tint); // Draw a model (with texture if set) +RLAPI void DrawModelEx(Model model, Vector3 position, Vector3 rotationAxis, float rotationAngle, Vector3 scale, Color tint); // Draw a model with extended parameters +RLAPI void DrawModelWires(Model model, Vector3 position, float scale, Color tint); // Draw a model wires (with texture if set) +RLAPI void DrawModelWiresEx(Model model, Vector3 position, Vector3 rotationAxis, float rotationAngle, Vector3 scale, Color tint); // Draw a model wires (with texture if set) with extended parameters +RLAPI void DrawBoundingBox(BoundingBox box, Color color); // Draw bounding box (wires) +RLAPI void DrawBillboard(Camera camera, Texture2D texture, Vector3 center, float size, Color tint); // Draw a billboard texture +RLAPI void DrawBillboardRec(Camera camera, Texture2D texture, Rectangle sourceRec, Vector3 center, float size, Color tint); // Draw a billboard texture defined by sourceRec + +// Collision detection functions +RLAPI bool CheckCollisionSpheres(Vector3 centerA, float radiusA, Vector3 centerB, float radiusB); // Detect collision between two spheres +RLAPI bool CheckCollisionBoxes(BoundingBox box1, BoundingBox box2); // Detect collision between two bounding boxes +RLAPI bool CheckCollisionBoxSphere(BoundingBox box, Vector3 centerSphere, float radiusSphere); // Detect collision between box and sphere +RLAPI bool CheckCollisionRaySphere(Ray ray, Vector3 spherePosition, float sphereRadius); // Detect collision between ray and sphere +RLAPI bool CheckCollisionRaySphereEx(Ray ray, Vector3 spherePosition, float sphereRadius, Vector3 *collisionPoint); // Detect collision between ray and sphere, returns collision point +RLAPI bool CheckCollisionRayBox(Ray ray, BoundingBox box); // Detect collision between ray and box +RLAPI RayHitInfo GetCollisionRayModel(Ray ray, Model *model); // Get collision info between ray and model +RLAPI RayHitInfo GetCollisionRayTriangle(Ray ray, Vector3 p1, Vector3 p2, Vector3 p3); // Get collision info between ray and triangle +RLAPI RayHitInfo GetCollisionRayGround(Ray ray, float groundHeight); // Get collision info between ray and ground plane (Y-normal plane) + +//------------------------------------------------------------------------------------ +// Shaders System Functions (Module: rlgl) +// NOTE: This functions are useless when using OpenGL 1.1 +//------------------------------------------------------------------------------------ + +// Shader loading/unloading functions +RLAPI char *LoadText(const char *fileName); // Load chars array from text file +RLAPI Shader LoadShader(const char *vsFileName, const char *fsFileName); // Load shader from files and bind default locations +RLAPI Shader LoadShaderCode(char *vsCode, char *fsCode); // Load shader from code strings and bind default locations +RLAPI void UnloadShader(Shader shader); // Unload shader from GPU memory (VRAM) + +RLAPI Shader GetShaderDefault(void); // Get default shader +RLAPI Texture2D GetTextureDefault(void); // Get default texture + +// Shader configuration functions +RLAPI int GetShaderLocation(Shader shader, const char *uniformName); // Get shader uniform location +RLAPI void SetShaderValue(Shader shader, int uniformLoc, const float *value, int size); // Set shader uniform value (float) +RLAPI void SetShaderValuei(Shader shader, int uniformLoc, const int *value, int size); // Set shader uniform value (int) +RLAPI void SetShaderValueMatrix(Shader shader, int uniformLoc, Matrix mat); // Set shader uniform value (matrix 4x4) +RLAPI void SetMatrixProjection(Matrix proj); // Set a custom projection matrix (replaces internal projection matrix) +RLAPI void SetMatrixModelview(Matrix view); // Set a custom modelview matrix (replaces internal modelview matrix) +RLAPI Matrix GetMatrixModelview(); // Get internal modelview matrix + +// Texture maps generation (PBR) +// NOTE: Required shaders should be provided +RLAPI Texture2D GenTextureCubemap(Shader shader, Texture2D skyHDR, int size); // Generate cubemap texture from HDR texture +RLAPI Texture2D GenTextureIrradiance(Shader shader, Texture2D cubemap, int size); // Generate irradiance texture using cubemap data +RLAPI Texture2D GenTexturePrefilter(Shader shader, Texture2D cubemap, int size); // Generate prefilter texture using cubemap data +RLAPI Texture2D GenTextureBRDF(Shader shader, Texture2D cubemap, int size); // Generate BRDF texture using cubemap data + +// Shading begin/end functions +RLAPI void BeginShaderMode(Shader shader); // Begin custom shader drawing +RLAPI void EndShaderMode(void); // End custom shader drawing (use default shader) +RLAPI void BeginBlendMode(int mode); // Begin blending mode (alpha, additive, multiplied) +RLAPI void EndBlendMode(void); // End blending mode (reset to default: alpha blending) + +// VR control functions +RLAPI VrDeviceInfo GetVrDeviceInfo(int vrDeviceType); // Get VR device information for some standard devices +RLAPI void InitVrSimulator(VrDeviceInfo info); // Init VR simulator for selected device parameters +RLAPI void CloseVrSimulator(void); // Close VR simulator for current device +RLAPI bool IsVrSimulatorReady(void); // Detect if VR simulator is ready +RLAPI void SetVrDistortionShader(Shader shader); // Set VR distortion shader for stereoscopic rendering +RLAPI void UpdateVrTracking(Camera *camera); // Update VR tracking (position and orientation) and camera +RLAPI void ToggleVrMode(void); // Enable/Disable VR experience +RLAPI void BeginVrDrawing(void); // Begin VR simulator stereo rendering +RLAPI void EndVrDrawing(void); // End VR simulator stereo rendering + +//------------------------------------------------------------------------------------ +// Audio Loading and Playing Functions (Module: audio) +//------------------------------------------------------------------------------------ + +// Audio device management functions +RLAPI void InitAudioDevice(void); // Initialize audio device and context +RLAPI void CloseAudioDevice(void); // Close the audio device and context +RLAPI bool IsAudioDeviceReady(void); // Check if audio device has been initialized successfully +RLAPI void SetMasterVolume(float volume); // Set master volume (listener) + +// Wave/Sound loading/unloading functions +RLAPI Wave LoadWave(const char *fileName); // Load wave data from file +RLAPI Wave LoadWaveEx(void *data, int sampleCount, int sampleRate, int sampleSize, int channels); // Load wave data from raw array data +RLAPI Sound LoadSound(const char *fileName); // Load sound from file +RLAPI Sound LoadSoundFromWave(Wave wave); // Load sound from wave data +RLAPI void UpdateSound(Sound sound, const void *data, int samplesCount);// Update sound buffer with new data +RLAPI void UnloadWave(Wave wave); // Unload wave data +RLAPI void UnloadSound(Sound sound); // Unload sound + +// Wave/Sound management functions +RLAPI void PlaySound(Sound sound); // Play a sound +RLAPI void PauseSound(Sound sound); // Pause a sound +RLAPI void ResumeSound(Sound sound); // Resume a paused sound +RLAPI void StopSound(Sound sound); // Stop playing a sound +RLAPI bool IsSoundPlaying(Sound sound); // Check if a sound is currently playing +RLAPI void SetSoundVolume(Sound sound, float volume); // Set volume for a sound (1.0 is max level) +RLAPI void SetSoundPitch(Sound sound, float pitch); // Set pitch for a sound (1.0 is base level) +RLAPI void WaveFormat(Wave *wave, int sampleRate, int sampleSize, int channels); // Convert wave data to desired format +RLAPI Wave WaveCopy(Wave wave); // Copy a wave to a new wave +RLAPI void WaveCrop(Wave *wave, int initSample, int finalSample); // Crop a wave to defined samples range +RLAPI float *GetWaveData(Wave wave); // Get samples data from wave as a floats array + +// Music management functions +RLAPI Music LoadMusicStream(const char *fileName); // Load music stream from file +RLAPI void UnloadMusicStream(Music music); // Unload music stream +RLAPI void PlayMusicStream(Music music); // Start music playing +RLAPI void UpdateMusicStream(Music music); // Updates buffers for music streaming +RLAPI void StopMusicStream(Music music); // Stop music playing +RLAPI void PauseMusicStream(Music music); // Pause music playing +RLAPI void ResumeMusicStream(Music music); // Resume playing paused music +RLAPI bool IsMusicPlaying(Music music); // Check if music is playing +RLAPI void SetMusicVolume(Music music, float volume); // Set volume for music (1.0 is max level) +RLAPI void SetMusicPitch(Music music, float pitch); // Set pitch for a music (1.0 is base level) +RLAPI void SetMusicLoopCount(Music music, int count); // Set music loop count (loop repeats) +RLAPI float GetMusicTimeLength(Music music); // Get music time length (in seconds) +RLAPI float GetMusicTimePlayed(Music music); // Get current music time played (in seconds) + +// AudioStream management functions +RLAPI AudioStream InitAudioStream(unsigned int sampleRate, unsigned int sampleSize, unsigned int channels); // Init audio stream (to stream raw audio pcm data) +RLAPI void UpdateAudioStream(AudioStream stream, const void *data, int samplesCount); // Update audio stream buffers with data +RLAPI void CloseAudioStream(AudioStream stream); // Close audio stream and free memory +RLAPI bool IsAudioBufferProcessed(AudioStream stream); // Check if any audio stream buffers requires refill +RLAPI void PlayAudioStream(AudioStream stream); // Play audio stream +RLAPI void PauseAudioStream(AudioStream stream); // Pause audio stream +RLAPI void ResumeAudioStream(AudioStream stream); // Resume audio stream +RLAPI bool IsAudioStreamPlaying(AudioStream stream); // Check if audio stream is playing +RLAPI void StopAudioStream(AudioStream stream); // Stop audio stream +RLAPI void SetAudioStreamVolume(AudioStream stream, float volume); // Set volume for audio stream (1.0 is max level) +RLAPI void SetAudioStreamPitch(AudioStream stream, float pitch); // Set pitch for audio stream (1.0 is base level) \ No newline at end of file diff --git a/project/vs2015.UWP/raylib.App.UWP/App.cpp b/projects/VS2015.UWP/raylib.App.UWP/App.cpp similarity index 100% rename from project/vs2015.UWP/raylib.App.UWP/App.cpp rename to projects/VS2015.UWP/raylib.App.UWP/App.cpp diff --git a/project/vs2015.UWP/raylib.App.UWP/App.h b/projects/VS2015.UWP/raylib.App.UWP/App.h similarity index 100% rename from project/vs2015.UWP/raylib.App.UWP/App.h rename to projects/VS2015.UWP/raylib.App.UWP/App.h diff --git a/project/vs2015.UWP/raylib.App.UWP/Assets/Logo.scale-100.png b/projects/VS2015.UWP/raylib.App.UWP/Assets/Logo.scale-100.png similarity index 100% rename from project/vs2015.UWP/raylib.App.UWP/Assets/Logo.scale-100.png rename to projects/VS2015.UWP/raylib.App.UWP/Assets/Logo.scale-100.png diff --git a/project/vs2015.UWP/raylib.App.UWP/Assets/SmallLogo.scale-100.png b/projects/VS2015.UWP/raylib.App.UWP/Assets/SmallLogo.scale-100.png similarity index 100% rename from project/vs2015.UWP/raylib.App.UWP/Assets/SmallLogo.scale-100.png rename to projects/VS2015.UWP/raylib.App.UWP/Assets/SmallLogo.scale-100.png diff --git a/project/vs2015.UWP/raylib.App.UWP/Assets/SplashScreen.scale-100.png b/projects/VS2015.UWP/raylib.App.UWP/Assets/SplashScreen.scale-100.png similarity index 100% rename from project/vs2015.UWP/raylib.App.UWP/Assets/SplashScreen.scale-100.png rename to projects/VS2015.UWP/raylib.App.UWP/Assets/SplashScreen.scale-100.png diff --git a/project/vs2015.UWP/raylib.App.UWP/Assets/StoreLogo.scale-100.png b/projects/VS2015.UWP/raylib.App.UWP/Assets/StoreLogo.scale-100.png similarity index 100% rename from project/vs2015.UWP/raylib.App.UWP/Assets/StoreLogo.scale-100.png rename to projects/VS2015.UWP/raylib.App.UWP/Assets/StoreLogo.scale-100.png diff --git a/project/vs2015.UWP/raylib.App.UWP/Assets/WideLogo.scale-100.png b/projects/VS2015.UWP/raylib.App.UWP/Assets/WideLogo.scale-100.png similarity index 100% rename from project/vs2015.UWP/raylib.App.UWP/Assets/WideLogo.scale-100.png rename to projects/VS2015.UWP/raylib.App.UWP/Assets/WideLogo.scale-100.png diff --git a/project/vs2015.UWP/raylib.App.UWP/Package.appxmanifest b/projects/VS2015.UWP/raylib.App.UWP/Package.appxmanifest similarity index 100% rename from project/vs2015.UWP/raylib.App.UWP/Package.appxmanifest rename to projects/VS2015.UWP/raylib.App.UWP/Package.appxmanifest diff --git a/project/vs2015.UWP/raylib.App.UWP/packages.config b/projects/VS2015.UWP/raylib.App.UWP/packages.config similarity index 100% rename from project/vs2015.UWP/raylib.App.UWP/packages.config rename to projects/VS2015.UWP/raylib.App.UWP/packages.config diff --git a/project/vs2015.UWP/raylib.App.UWP/pch.cpp b/projects/VS2015.UWP/raylib.App.UWP/pch.cpp similarity index 100% rename from project/vs2015.UWP/raylib.App.UWP/pch.cpp rename to projects/VS2015.UWP/raylib.App.UWP/pch.cpp diff --git a/project/vs2015.UWP/raylib.App.UWP/pch.h b/projects/VS2015.UWP/raylib.App.UWP/pch.h similarity index 100% rename from project/vs2015.UWP/raylib.App.UWP/pch.h rename to projects/VS2015.UWP/raylib.App.UWP/pch.h diff --git a/project/vs2015.UWP/raylib.App.UWP/raylib.App.UWP.TemporaryKey.pfx b/projects/VS2015.UWP/raylib.App.UWP/raylib.App.UWP.TemporaryKey.pfx similarity index 100% rename from project/vs2015.UWP/raylib.App.UWP/raylib.App.UWP.TemporaryKey.pfx rename to projects/VS2015.UWP/raylib.App.UWP/raylib.App.UWP.TemporaryKey.pfx diff --git a/project/vs2015.UWP/raylib.App.UWP/raylib.App.UWP.filters b/projects/VS2015.UWP/raylib.App.UWP/raylib.App.UWP.filters similarity index 100% rename from project/vs2015.UWP/raylib.App.UWP/raylib.App.UWP.filters rename to projects/VS2015.UWP/raylib.App.UWP/raylib.App.UWP.filters diff --git a/project/vs2015.UWP/raylib.App.UWP/raylib.App.UWP.user b/projects/VS2015.UWP/raylib.App.UWP/raylib.App.UWP.user similarity index 100% rename from project/vs2015.UWP/raylib.App.UWP/raylib.App.UWP.user rename to projects/VS2015.UWP/raylib.App.UWP/raylib.App.UWP.user diff --git a/project/vs2017.UWP/raylib.App.UWP/App.cpp b/projects/VS2017/raylib.App.UWP/App.cpp similarity index 100% rename from project/vs2017.UWP/raylib.App.UWP/App.cpp rename to projects/VS2017/raylib.App.UWP/App.cpp diff --git a/project/vs2017.UWP/raylib.App.UWP/App.h b/projects/VS2017/raylib.App.UWP/App.h similarity index 100% rename from project/vs2017.UWP/raylib.App.UWP/App.h rename to projects/VS2017/raylib.App.UWP/App.h diff --git a/project/vs2017.UWP/raylib.App.UWP/Assets/Logo.scale-100.png b/projects/VS2017/raylib.App.UWP/Assets/Logo.scale-100.png similarity index 100% rename from project/vs2017.UWP/raylib.App.UWP/Assets/Logo.scale-100.png rename to projects/VS2017/raylib.App.UWP/Assets/Logo.scale-100.png diff --git a/project/vs2017.UWP/raylib.App.UWP/Assets/SmallLogo.scale-100.png b/projects/VS2017/raylib.App.UWP/Assets/SmallLogo.scale-100.png similarity index 100% rename from project/vs2017.UWP/raylib.App.UWP/Assets/SmallLogo.scale-100.png rename to projects/VS2017/raylib.App.UWP/Assets/SmallLogo.scale-100.png diff --git a/project/vs2017.UWP/raylib.App.UWP/Assets/SplashScreen.scale-100.png b/projects/VS2017/raylib.App.UWP/Assets/SplashScreen.scale-100.png similarity index 100% rename from project/vs2017.UWP/raylib.App.UWP/Assets/SplashScreen.scale-100.png rename to projects/VS2017/raylib.App.UWP/Assets/SplashScreen.scale-100.png diff --git a/project/vs2017.UWP/raylib.App.UWP/Assets/StoreLogo.scale-100.png b/projects/VS2017/raylib.App.UWP/Assets/StoreLogo.scale-100.png similarity index 100% rename from project/vs2017.UWP/raylib.App.UWP/Assets/StoreLogo.scale-100.png rename to projects/VS2017/raylib.App.UWP/Assets/StoreLogo.scale-100.png diff --git a/project/vs2017.UWP/raylib.App.UWP/Assets/WideLogo.scale-100.png b/projects/VS2017/raylib.App.UWP/Assets/WideLogo.scale-100.png similarity index 100% rename from project/vs2017.UWP/raylib.App.UWP/Assets/WideLogo.scale-100.png rename to projects/VS2017/raylib.App.UWP/Assets/WideLogo.scale-100.png diff --git a/project/vs2017.UWP/raylib.App.UWP/Package.appxmanifest b/projects/VS2017/raylib.App.UWP/Package.appxmanifest similarity index 100% rename from project/vs2017.UWP/raylib.App.UWP/Package.appxmanifest rename to projects/VS2017/raylib.App.UWP/Package.appxmanifest diff --git a/project/vs2017.UWP/raylib.App.UWP/packages.config b/projects/VS2017/raylib.App.UWP/packages.config similarity index 100% rename from project/vs2017.UWP/raylib.App.UWP/packages.config rename to projects/VS2017/raylib.App.UWP/packages.config diff --git a/project/vs2017.UWP/raylib.App.UWP/pch.cpp b/projects/VS2017/raylib.App.UWP/pch.cpp similarity index 100% rename from project/vs2017.UWP/raylib.App.UWP/pch.cpp rename to projects/VS2017/raylib.App.UWP/pch.cpp diff --git a/project/vs2017.UWP/raylib.App.UWP/pch.h b/projects/VS2017/raylib.App.UWP/pch.h similarity index 100% rename from project/vs2017.UWP/raylib.App.UWP/pch.h rename to projects/VS2017/raylib.App.UWP/pch.h diff --git a/project/vs2017.UWP/raylib.App.UWP/raylib.App.UWP.TemporaryKey.pfx b/projects/VS2017/raylib.App.UWP/raylib.App.UWP.TemporaryKey.pfx similarity index 100% rename from project/vs2017.UWP/raylib.App.UWP/raylib.App.UWP.TemporaryKey.pfx rename to projects/VS2017/raylib.App.UWP/raylib.App.UWP.TemporaryKey.pfx diff --git a/project/vs2017.UWP/raylib.App.UWP/raylib.App.UWP.filters b/projects/VS2017/raylib.App.UWP/raylib.App.UWP.filters similarity index 100% rename from project/vs2017.UWP/raylib.App.UWP/raylib.App.UWP.filters rename to projects/VS2017/raylib.App.UWP/raylib.App.UWP.filters diff --git a/project/vs2017.UWP/raylib.App.UWP/raylib.App.UWP.user b/projects/VS2017/raylib.App.UWP/raylib.App.UWP.user similarity index 100% rename from project/vs2017.UWP/raylib.App.UWP/raylib.App.UWP.user rename to projects/VS2017/raylib.App.UWP/raylib.App.UWP.user diff --git a/projects/VSCode/HELPME b/projects/VSCode/HELPME new file mode 100644 index 000000000..e69de29bb From b8ca51fd01a68b9b6040f8c3c631eedefd7d7735 Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Thu, 10 May 2018 21:03:43 +0200 Subject: [PATCH 21/53] CMake: Don't create symlinks on unsupporting file systems (#539) Panders to the idiosyncrasies of my work flow: I have my raylib build directory mounted as a VirtualBox vboxfs for use with my Linux VM, but vboxfs doesn't support symlinks, while raylib shared library versioning on Unix expects symlinks to work. If this happens, library versioning is now disabled on Unix with an error message instead of just failing the build. --- .gitignore | 3 ++- CMakeLists.txt | 12 ++++++++++++ src/CMakeLists.txt | 10 ++++++++-- 3 files changed, 22 insertions(+), 3 deletions(-) mode change 100755 => 100644 CMakeLists.txt diff --git a/.gitignore b/.gitignore index d22e46efb..1b4d5e411 100644 --- a/.gitignore +++ b/.gitignore @@ -98,7 +98,7 @@ project/vs2015.UWP/*.db !project/vs2015.UWP/*.sln !project/vs2015.UWP/raylib.App.UWP/*.vcxproj -# Web examples +# Web examples docs/examples/web/*.html docs/examples/web/*/*.html !docs/examples/web/loader.html @@ -116,6 +116,7 @@ CMakeCache.txt CMakeFiles CMakeScripts Testing +TestingIfSymlinkWorks cmake_install.cmake install_manifest.txt compile_commands.json diff --git a/CMakeLists.txt b/CMakeLists.txt old mode 100755 new mode 100644 index 6d5994f4f..a2f14088c --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -33,6 +33,18 @@ add_if_flag_works(-Werror=implicit-function-declaration CMAKE_C_FLAGS) # src/external/jar_xm.h does shady stuff add_if_flag_works(-fno-strict-aliasing CMAKE_C_FLAGS) +message(STATUS "Check for symlink support in file system") +execute_process( + COMMAND ${CMAKE_COMMAND} -E create_symlink CMakeLists.txt "${CMAKE_CURRENT_BINARY_DIR}/TestingIfSymlinkWorks" + WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} + RESULT_VARIABLE FILESYSTEM_LACKS_SYMLINKS +) +If (FILESYSTEM_LACKS_SYMLINKS) + message(STATUS "Testing if file system supports symlinks -- unsupported") +else() + message(STATUS "Testing if file system supports symlinks -- supported") +endif() + if (ENABLE_ASAN) add_if_flag_works(-fno-omit-frame-pointer CMAKE_C_FLAGS CMAKE_LINKER_FLAGS) add_if_flag_works(-fsanitize=address CMAKE_C_FLAGS CMAKE_LINKER_FLAGS) diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 64d7f1fdf..f04e88f34 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -101,9 +101,15 @@ if(${PLATFORM} MATCHES "PLATFORM_DESKTOP") set(CMAKE_MACOSX_RPATH ON) target_link_libraries(${RAYLIB}_shared ${LIBS_PRIVATE}) + if (UNIX AND ${FILESYSTEM_LACKS_SYMLINKS}) + MESSAGE(WARNING "Can't version UNIX shared library on file system without symlink support") + else() + set_target_properties(${RAYLIB}_shared PROPERTIES + VERSION ${PROJECT_VERSION} + SOVERSION ${API_VERSION} + ) + endif() set_target_properties(${RAYLIB}_shared PROPERTIES - VERSION ${PROJECT_VERSION} - SOVERSION ${API_VERSION} PUBLIC_HEADER "raylib.h" ) if(WIN32) From f11fe801809f5697c96010e0f08e26dc87c85b1b Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Thu, 10 May 2018 23:06:24 +0200 Subject: [PATCH 22/53] CMake: Use same message for symlink check and result --- CMakeLists.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index a2f14088c..38d98c355 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -33,7 +33,7 @@ add_if_flag_works(-Werror=implicit-function-declaration CMAKE_C_FLAGS) # src/external/jar_xm.h does shady stuff add_if_flag_works(-fno-strict-aliasing CMAKE_C_FLAGS) -message(STATUS "Check for symlink support in file system") +message(STATUS "Testing if file system supports symlinks") execute_process( COMMAND ${CMAKE_COMMAND} -E create_symlink CMakeLists.txt "${CMAKE_CURRENT_BINARY_DIR}/TestingIfSymlinkWorks" WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} From 0df501be91a09af6b4b06bf44df86d8d06cdcada Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Thu, 10 May 2018 22:40:41 +0200 Subject: [PATCH 23/53] Add GLFW source tree to src/external We need the CMake stuff for wayland configuration. Otherwise, we would have to replicate that ourselves. This is the full 7ef34eb06de54dd9186d3d21a401b2ef819b59e7 tree except for tests/ examples/ and docs/ --- src/external/glfw/.appveyor.yml | 23 + src/external/glfw/.gitattributes | 1 + src/external/glfw/.gitignore | 84 + src/external/glfw/.travis.yml | 78 + .../glfw/CMake/GenerateMappings.cmake | 33 + .../glfw/CMake/MacOSXBundleInfo.plist.in | 38 + .../glfw/CMake/amd64-mingw32msvc.cmake | 13 + .../glfw/CMake/i586-mingw32msvc.cmake | 13 + src/external/glfw/CMake/i686-pc-mingw32.cmake | 13 + .../glfw/CMake/i686-w64-mingw32.cmake | 13 + .../glfw/CMake/modules/FindEpollShim.cmake | 17 + src/external/glfw/CMake/modules/FindMir.cmake | 34 + .../glfw/CMake/modules/FindOSMesa.cmake | 18 + .../glfw/CMake/modules/FindVulkan.cmake | 46 + .../CMake/modules/FindWaylandProtocols.cmake | 26 + .../glfw/CMake/modules/FindXKBCommon.cmake | 34 + .../glfw/CMake/x86_64-w64-mingw32.cmake | 13 + src/external/glfw/CMakeLists.txt | 402 + src/external/glfw/cmake_uninstall.cmake.in | 29 + src/external/glfw/deps/getopt.c | 230 + src/external/glfw/deps/getopt.h | 57 + src/external/glfw/deps/glad.c | 1678 ++ src/external/glfw/deps/glad/glad.h | 3680 +++ src/external/glfw/deps/linmath.h | 574 + src/external/glfw/deps/nuklear.h | 23717 ++++++++++++++++ src/external/glfw/deps/nuklear_glfw_gl2.h | 381 + src/external/glfw/deps/stb_image_write.h | 1048 + src/external/glfw/deps/tinycthread.c | 594 + src/external/glfw/deps/tinycthread.h | 443 + src/external/glfw/deps/vulkan/vk_platform.h | 212 +- src/external/glfw/deps/vulkan/vulkan.h | 4842 +--- src/external/glfw/deps/vulkan/vulkan_core.h | 7334 +++++ src/external/glfw/include/GLFW/glfw3.h | 6 +- src/external/glfw/src/CMakeLists.txt | 22 +- src/external/glfw/src/cocoa_window.m | 56 +- src/external/glfw/src/init.c | 56 +- src/external/glfw/src/input.c | 4 +- src/external/glfw/src/internal.h | 2 +- src/external/glfw/src/nsgl_context.m | 2 +- src/external/glfw/src/win32_platform.h | 2 + src/external/glfw/src/win32_window.c | 130 +- src/external/glfw/src/wl_init.c | 4 + src/external/glfw/src/wl_platform.h | 4 + src/external/glfw/src/x11_init.c | 42 + src/external/glfw/src/x11_window.c | 110 +- 45 files changed, 41098 insertions(+), 5060 deletions(-) create mode 100644 src/external/glfw/.appveyor.yml create mode 100644 src/external/glfw/.gitattributes create mode 100644 src/external/glfw/.gitignore create mode 100644 src/external/glfw/.travis.yml create mode 100644 src/external/glfw/CMake/GenerateMappings.cmake create mode 100644 src/external/glfw/CMake/MacOSXBundleInfo.plist.in create mode 100644 src/external/glfw/CMake/amd64-mingw32msvc.cmake create mode 100644 src/external/glfw/CMake/i586-mingw32msvc.cmake create mode 100644 src/external/glfw/CMake/i686-pc-mingw32.cmake create mode 100644 src/external/glfw/CMake/i686-w64-mingw32.cmake create mode 100644 src/external/glfw/CMake/modules/FindEpollShim.cmake create mode 100644 src/external/glfw/CMake/modules/FindMir.cmake create mode 100644 src/external/glfw/CMake/modules/FindOSMesa.cmake create mode 100644 src/external/glfw/CMake/modules/FindVulkan.cmake create mode 100644 src/external/glfw/CMake/modules/FindWaylandProtocols.cmake create mode 100644 src/external/glfw/CMake/modules/FindXKBCommon.cmake create mode 100644 src/external/glfw/CMake/x86_64-w64-mingw32.cmake create mode 100644 src/external/glfw/CMakeLists.txt create mode 100644 src/external/glfw/cmake_uninstall.cmake.in create mode 100644 src/external/glfw/deps/getopt.c create mode 100644 src/external/glfw/deps/getopt.h create mode 100644 src/external/glfw/deps/glad.c create mode 100644 src/external/glfw/deps/glad/glad.h create mode 100644 src/external/glfw/deps/linmath.h create mode 100644 src/external/glfw/deps/nuklear.h create mode 100644 src/external/glfw/deps/nuklear_glfw_gl2.h create mode 100644 src/external/glfw/deps/stb_image_write.h create mode 100644 src/external/glfw/deps/tinycthread.c create mode 100644 src/external/glfw/deps/tinycthread.h create mode 100644 src/external/glfw/deps/vulkan/vulkan_core.h diff --git a/src/external/glfw/.appveyor.yml b/src/external/glfw/.appveyor.yml new file mode 100644 index 000000000..4a002500c --- /dev/null +++ b/src/external/glfw/.appveyor.yml @@ -0,0 +1,23 @@ +branches: + only: + - ci + - master +skip_tags: true +environment: + CFLAGS: /WX + matrix: + - BUILD_SHARED_LIBS: ON + - BUILD_SHARED_LIBS: OFF +matrix: + fast_finish: true +build_script: + - mkdir build + - cd build + - cmake -DCMAKE_VERBOSE_MAKEFILE=ON -DBUILD_SHARED_LIBS=%BUILD_SHARED_LIBS% .. + - cmake --build . +notifications: + - provider: Email + to: + - ci@glfw.org + on_build_failure: true + on_build_success: false diff --git a/src/external/glfw/.gitattributes b/src/external/glfw/.gitattributes new file mode 100644 index 000000000..64a3446f6 --- /dev/null +++ b/src/external/glfw/.gitattributes @@ -0,0 +1 @@ +*.m linguist-language=Objective-C diff --git a/src/external/glfw/.gitignore b/src/external/glfw/.gitignore new file mode 100644 index 000000000..f6103c222 --- /dev/null +++ b/src/external/glfw/.gitignore @@ -0,0 +1,84 @@ +# External junk +.DS_Store +_ReSharper* +*.opensdf +*.sdf +*.suo +*.dir +*.vcxproj* +*.sln +Win32 +x64 +Debug +Release +MinSizeRel +RelWithDebInfo +*.xcodeproj + +# CMake files +Makefile +CMakeCache.txt +CMakeFiles +CMakeScripts +cmake_install.cmake +cmake_uninstall.cmake + +# Generated files +docs/Doxyfile +docs/html +docs/warnings.txt +docs/doxygen_sqlite3.db +src/glfw_config.h +src/glfw3.pc +src/glfw3Config.cmake +src/glfw3ConfigVersion.cmake +src/wayland-pointer-constraints-unstable-v1-client-protocol.h +src/wayland-pointer-constraints-unstable-v1-protocol.c +src/wayland-relative-pointer-unstable-v1-client-protocol.h +src/wayland-relative-pointer-unstable-v1-protocol.c + +# Compiled binaries +src/libglfw.so +src/libglfw.so.3 +src/libglfw.so.3.3 +src/libglfw.dylib +src/libglfw.dylib +src/libglfw.3.dylib +src/libglfw.3.3.dylib +src/libglfw3.a +src/glfw3.lib +src/glfw3.dll +src/glfw3dll.lib +src/libglfw3dll.a +examples/*.app +examples/*.exe +examples/boing +examples/gears +examples/heightmap +examples/offscreen +examples/particles +examples/splitview +examples/sharing +examples/simple +examples/wave +tests/*.app +tests/*.exe +tests/clipboard +tests/cursor +tests/empty +tests/events +tests/gamma +tests/glfwinfo +tests/icon +tests/iconify +tests/joysticks +tests/monitors +tests/msaa +tests/reopen +tests/tearing +tests/threads +tests/timeout +tests/title +tests/vulkan +tests/windows + diff --git a/src/external/glfw/.travis.yml b/src/external/glfw/.travis.yml new file mode 100644 index 000000000..f7ce408cd --- /dev/null +++ b/src/external/glfw/.travis.yml @@ -0,0 +1,78 @@ +language: c +compiler: clang +branches: + only: + - ci + - master +sudo: false +dist: trusty +addons: + apt: + packages: + - cmake + - libxrandr-dev + - libxinerama-dev + - libxcursor-dev + - libxi-dev +matrix: + include: + - os: linux + env: + - BUILD_SHARED_LIBS=ON + - CFLAGS=-Werror + - os: linux + env: + - BUILD_SHARED_LIBS=OFF + - CFLAGS=-Werror + - os: linux + sudo: required + addons: + apt: + packages: + - libwayland-dev + - libxkbcommon-dev + - libegl1-mesa-dev + env: + - USE_WAYLAND=ON + - BUILD_SHARED_LIBS=ON + - CFLAGS=-Werror + - os: linux + sudo: required + addons: + apt: + packages: + - libwayland-dev + - libxkbcommon-dev + - libegl1-mesa-dev + env: + - USE_WAYLAND=ON + - BUILD_SHARED_LIBS=OFF + - CFLAGS=-Werror + - os: osx + env: + - BUILD_SHARED_LIBS=ON + - CFLAGS=-Werror + - os: osx + env: + - BUILD_SHARED_LIBS=OFF + - CFLAGS=-Werror +script: + - if grep -Inr '\s$' src include docs tests examples CMake *.md .gitattributes .gitignore; then echo Trailing whitespace found, aborting.; exit 1; fi + - mkdir build + - cd build + - if test -n "${USE_WAYLAND}"; + then wget https://mirrors.kernel.org/ubuntu/pool/universe/e/extra-cmake-modules/extra-cmake-modules_5.38.0a-0ubuntu1_amd64.deb; + sudo dpkg -i extra-cmake-modules_5.38.0a-0ubuntu1_amd64.deb; + git clone git://anongit.freedesktop.org/wayland/wayland-protocols; + pushd wayland-protocols; + git checkout 1.12 && ./autogen.sh --prefix=/usr && make && sudo make install; + popd; + fi + - cmake -DCMAKE_VERBOSE_MAKEFILE=ON -DBUILD_SHARED_LIBS=${BUILD_SHARED_LIBS} -DGLFW_USE_WAYLAND=${USE_WAYLAND} .. + - cmake --build . +notifications: + email: + recipients: + - ci@glfw.org + on_success: never + on_failure: always diff --git a/src/external/glfw/CMake/GenerateMappings.cmake b/src/external/glfw/CMake/GenerateMappings.cmake new file mode 100644 index 000000000..7a88e3d44 --- /dev/null +++ b/src/external/glfw/CMake/GenerateMappings.cmake @@ -0,0 +1,33 @@ +# Usage: +# cmake -P GenerateMappings.cmake + +set(source_url "https://raw.githubusercontent.com/gabomdq/SDL_GameControllerDB/master/gamecontrollerdb.txt") +set(source_path "${CMAKE_CURRENT_BINARY_DIR}/gamecontrollerdb.txt") +set(template_path "${CMAKE_ARGV3}") +set(target_path "${CMAKE_ARGV4}") + +if (NOT EXISTS "${template_path}") + message(FATAL_ERROR "Failed to find template file ${template_path}") +endif() + +file(DOWNLOAD "${source_url}" "${source_path}" + STATUS download_status + TLS_VERIFY on) + +list(GET download_status 0 status_code) +list(GET download_status 1 status_message) + +if (status_code) + message(FATAL_ERROR "Failed to download ${source_url}: ${status_message}") +endif() + +file(STRINGS "${source_path}" lines) +foreach(line ${lines}) + if ("${line}" MATCHES "^[0-9a-fA-F].*$") + set(GLFW_GAMEPAD_MAPPINGS "${GLFW_GAMEPAD_MAPPINGS}\"${line}\",\n") + endif() +endforeach() + +configure_file("${template_path}" "${target_path}" @ONLY NEWLINE_STYLE UNIX) +file(REMOVE "${source_path}") + diff --git a/src/external/glfw/CMake/MacOSXBundleInfo.plist.in b/src/external/glfw/CMake/MacOSXBundleInfo.plist.in new file mode 100644 index 000000000..684ad7908 --- /dev/null +++ b/src/external/glfw/CMake/MacOSXBundleInfo.plist.in @@ -0,0 +1,38 @@ + + + + + CFBundleDevelopmentRegion + English + CFBundleExecutable + ${MACOSX_BUNDLE_EXECUTABLE_NAME} + CFBundleGetInfoString + ${MACOSX_BUNDLE_INFO_STRING} + CFBundleIconFile + ${MACOSX_BUNDLE_ICON_FILE} + CFBundleIdentifier + ${MACOSX_BUNDLE_GUI_IDENTIFIER} + CFBundleInfoDictionaryVersion + 6.0 + CFBundleLongVersionString + ${MACOSX_BUNDLE_LONG_VERSION_STRING} + CFBundleName + ${MACOSX_BUNDLE_BUNDLE_NAME} + CFBundlePackageType + APPL + CFBundleShortVersionString + ${MACOSX_BUNDLE_SHORT_VERSION_STRING} + CFBundleSignature + ???? + CFBundleVersion + ${MACOSX_BUNDLE_BUNDLE_VERSION} + CSResourcesFileMapped + + LSRequiresCarbon + + NSHumanReadableCopyright + ${MACOSX_BUNDLE_COPYRIGHT} + NSHighResolutionCapable + + + diff --git a/src/external/glfw/CMake/amd64-mingw32msvc.cmake b/src/external/glfw/CMake/amd64-mingw32msvc.cmake new file mode 100644 index 000000000..c264ff0da --- /dev/null +++ b/src/external/glfw/CMake/amd64-mingw32msvc.cmake @@ -0,0 +1,13 @@ +# Define the environment for cross compiling from Linux to Win64 +SET(CMAKE_SYSTEM_NAME Windows) +SET(CMAKE_SYSTEM_VERSION 1) +SET(CMAKE_C_COMPILER "amd64-mingw32msvc-gcc") +SET(CMAKE_CXX_COMPILER "amd64-mingw32msvc-g++") +SET(CMAKE_RC_COMPILER "amd64-mingw32msvc-windres") +SET(CMAKE_RANLIB "amd64-mingw32msvc-ranlib") + +# Configure the behaviour of the find commands +SET(CMAKE_FIND_ROOT_PATH "/usr/amd64-mingw32msvc") +SET(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) +SET(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) +SET(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY) diff --git a/src/external/glfw/CMake/i586-mingw32msvc.cmake b/src/external/glfw/CMake/i586-mingw32msvc.cmake new file mode 100644 index 000000000..c871e5be5 --- /dev/null +++ b/src/external/glfw/CMake/i586-mingw32msvc.cmake @@ -0,0 +1,13 @@ +# Define the environment for cross compiling from Linux to Win32 +SET(CMAKE_SYSTEM_NAME Windows) +SET(CMAKE_SYSTEM_VERSION 1) +SET(CMAKE_C_COMPILER "i586-mingw32msvc-gcc") +SET(CMAKE_CXX_COMPILER "i586-mingw32msvc-g++") +SET(CMAKE_RC_COMPILER "i586-mingw32msvc-windres") +SET(CMAKE_RANLIB "i586-mingw32msvc-ranlib") + +# Configure the behaviour of the find commands +SET(CMAKE_FIND_ROOT_PATH "/usr/i586-mingw32msvc") +SET(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) +SET(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) +SET(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY) diff --git a/src/external/glfw/CMake/i686-pc-mingw32.cmake b/src/external/glfw/CMake/i686-pc-mingw32.cmake new file mode 100644 index 000000000..b657d9448 --- /dev/null +++ b/src/external/glfw/CMake/i686-pc-mingw32.cmake @@ -0,0 +1,13 @@ +# Define the environment for cross compiling from Linux to Win32 +SET(CMAKE_SYSTEM_NAME Windows) # Target system name +SET(CMAKE_SYSTEM_VERSION 1) +SET(CMAKE_C_COMPILER "i686-pc-mingw32-gcc") +SET(CMAKE_CXX_COMPILER "i686-pc-mingw32-g++") +SET(CMAKE_RC_COMPILER "i686-pc-mingw32-windres") +SET(CMAKE_RANLIB "i686-pc-mingw32-ranlib") + +#Configure the behaviour of the find commands +SET(CMAKE_FIND_ROOT_PATH "/opt/mingw/usr/i686-pc-mingw32") +SET(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) +SET(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) +SET(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY) diff --git a/src/external/glfw/CMake/i686-w64-mingw32.cmake b/src/external/glfw/CMake/i686-w64-mingw32.cmake new file mode 100644 index 000000000..bbd9f8956 --- /dev/null +++ b/src/external/glfw/CMake/i686-w64-mingw32.cmake @@ -0,0 +1,13 @@ +# Define the environment for cross compiling from Linux to Win32 +SET(CMAKE_SYSTEM_NAME Windows) # Target system name +SET(CMAKE_SYSTEM_VERSION 1) +SET(CMAKE_C_COMPILER "i686-w64-mingw32-gcc") +SET(CMAKE_CXX_COMPILER "i686-w64-mingw32-g++") +SET(CMAKE_RC_COMPILER "i686-w64-mingw32-windres") +SET(CMAKE_RANLIB "i686-w64-mingw32-ranlib") + +# Configure the behaviour of the find commands +SET(CMAKE_FIND_ROOT_PATH "/usr/i686-w64-mingw32") +SET(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) +SET(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) +SET(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY) diff --git a/src/external/glfw/CMake/modules/FindEpollShim.cmake b/src/external/glfw/CMake/modules/FindEpollShim.cmake new file mode 100644 index 000000000..2facb4192 --- /dev/null +++ b/src/external/glfw/CMake/modules/FindEpollShim.cmake @@ -0,0 +1,17 @@ +# Find EpollShim +# Once done, this will define +# +# EPOLLSHIM_FOUND - System has EpollShim +# EPOLLSHIM_INCLUDE_DIRS - The EpollShim include directories +# EPOLLSHIM_LIBRARIES - The libraries needed to use EpollShim + +find_path(EPOLLSHIM_INCLUDE_DIRS NAMES sys/epoll.h sys/timerfd.h HINTS /usr/local/include/libepoll-shim) +find_library(EPOLLSHIM_LIBRARIES NAMES epoll-shim libepoll-shim HINTS /usr/local/lib) + +if (EPOLLSHIM_INCLUDE_DIRS AND EPOLLSHIM_LIBRARIES) + set(EPOLLSHIM_FOUND TRUE) +endif (EPOLLSHIM_INCLUDE_DIRS AND EPOLLSHIM_LIBRARIES) + +include(FindPackageHandleStandardArgs) +find_package_handle_standard_args(EPOLLSHIM DEFAULT_MSG EPOLLSHIM_LIBRARIES EPOLLSHIM_INCLUDE_DIRS) +mark_as_advanced(EPOLLSHIM_INCLUDE_DIRS EPOLLSHIM_LIBRARIES) diff --git a/src/external/glfw/CMake/modules/FindMir.cmake b/src/external/glfw/CMake/modules/FindMir.cmake new file mode 100644 index 000000000..2104df8a3 --- /dev/null +++ b/src/external/glfw/CMake/modules/FindMir.cmake @@ -0,0 +1,34 @@ +# FindMir +# ------- +# Finds the Mir library +# +# This will will define the following variables:: +# +# MIR_FOUND - the system has Mir +# MIR_INCLUDE_DIRS - the Mir include directory +# MIR_LIBRARIES - the Mir libraries +# MIR_DEFINITIONS - the Mir definitions + + +find_package (PkgConfig) +if(PKG_CONFIG_FOUND) + pkg_check_modules (PC_MIR mirclient>=0.26.2 QUIET) + + find_path(MIR_INCLUDE_DIR NAMES mir_toolkit/mir_client_library.h + PATHS ${PC_MIR_INCLUDE_DIRS}) + + find_library(MIR_LIBRARY NAMES mirclient + PATHS ${PC_MIR_LIBRARIES} ${PC_MIR_LIBRARY_DIRS}) + + include (FindPackageHandleStandardArgs) + find_package_handle_standard_args (MIR + REQUIRED_VARS MIR_LIBRARY MIR_INCLUDE_DIR) + + if (MIR_FOUND) + set(MIR_LIBRARIES ${MIR_LIBRARY}) + set(MIR_INCLUDE_DIRS ${PC_MIR_INCLUDE_DIRS}) + set(MIR_DEFINITIONS -DHAVE_MIR=1) + endif() + + mark_as_advanced (MIR_LIBRARY MIR_INCLUDE_DIR) +endif() diff --git a/src/external/glfw/CMake/modules/FindOSMesa.cmake b/src/external/glfw/CMake/modules/FindOSMesa.cmake new file mode 100644 index 000000000..3194bd91a --- /dev/null +++ b/src/external/glfw/CMake/modules/FindOSMesa.cmake @@ -0,0 +1,18 @@ +# Try to find OSMesa on a Unix system +# +# This will define: +# +# OSMESA_LIBRARIES - Link these to use OSMesa +# OSMESA_INCLUDE_DIR - Include directory for OSMesa +# +# Copyright (c) 2014 Brandon Schaefer + +if (NOT WIN32) + + find_package (PkgConfig) + pkg_check_modules (PKG_OSMESA QUIET osmesa) + + set (OSMESA_INCLUDE_DIR ${PKG_OSMESA_INCLUDE_DIRS}) + set (OSMESA_LIBRARIES ${PKG_OSMESA_LIBRARIES}) + +endif () diff --git a/src/external/glfw/CMake/modules/FindVulkan.cmake b/src/external/glfw/CMake/modules/FindVulkan.cmake new file mode 100644 index 000000000..103554bb7 --- /dev/null +++ b/src/external/glfw/CMake/modules/FindVulkan.cmake @@ -0,0 +1,46 @@ +# Find Vulkan +# +# VULKAN_INCLUDE_DIR +# VULKAN_LIBRARY +# VULKAN_FOUND + +if (WIN32) + find_path(VULKAN_INCLUDE_DIR NAMES vulkan/vulkan.h HINTS + "$ENV{VULKAN_SDK}/Include" + "$ENV{VK_SDK_PATH}/Include") + if (CMAKE_SIZEOF_VOID_P EQUAL 8) + find_library(VULKAN_LIBRARY NAMES vulkan-1 HINTS + "$ENV{VULKAN_SDK}/Lib" + "$ENV{VULKAN_SDK}/Bin" + "$ENV{VK_SDK_PATH}/Bin") + find_library(VULKAN_STATIC_LIBRARY NAMES vkstatic.1 HINTS + "$ENV{VULKAN_SDK}/Lib" + "$ENV{VULKAN_SDK}/Bin" + "$ENV{VK_SDK_PATH}/Bin") + else() + find_library(VULKAN_LIBRARY NAMES vulkan-1 HINTS + "$ENV{VULKAN_SDK}/Lib32" + "$ENV{VULKAN_SDK}/Bin32" + "$ENV{VK_SDK_PATH}/Bin32") + find_library(VULKAN_STATIC_LIBRARY NAMES vkstatic.1 HINTS + "$ENV{VULKAN_SDK}/Lib32" + "$ENV{VULKAN_SDK}/Bin32" + "$ENV{VK_SDK_PATH}/Bin32") + endif() +elseif (APPLE) + find_library(VULKAN_LIBRARY vulkan.1 HINTS + "$ENV{VULKAN_SDK}/macOS/lib") + find_path(VULKAN_INCLUDE_DIR NAMES vulkan/vulkan.h HINTS + "$ENV{VULKAN_SDK}/macOS/include") +else() + find_path(VULKAN_INCLUDE_DIR NAMES vulkan/vulkan.h HINTS + "$ENV{VULKAN_SDK}/include") + find_library(VULKAN_LIBRARY NAMES vulkan HINTS + "$ENV{VULKAN_SDK}/lib") +endif() + +include(FindPackageHandleStandardArgs) +find_package_handle_standard_args(Vulkan DEFAULT_MSG VULKAN_LIBRARY VULKAN_INCLUDE_DIR) + +mark_as_advanced(VULKAN_INCLUDE_DIR VULKAN_LIBRARY VULKAN_STATIC_LIBRARY) + diff --git a/src/external/glfw/CMake/modules/FindWaylandProtocols.cmake b/src/external/glfw/CMake/modules/FindWaylandProtocols.cmake new file mode 100644 index 000000000..8eb83f27e --- /dev/null +++ b/src/external/glfw/CMake/modules/FindWaylandProtocols.cmake @@ -0,0 +1,26 @@ +find_package(PkgConfig) + +pkg_check_modules(WaylandProtocols QUIET wayland-protocols>=${WaylandProtocols_FIND_VERSION}) + +execute_process(COMMAND ${PKG_CONFIG_EXECUTABLE} --variable=pkgdatadir wayland-protocols + OUTPUT_VARIABLE WaylandProtocols_PKGDATADIR + RESULT_VARIABLE _pkgconfig_failed) +if (_pkgconfig_failed) + message(FATAL_ERROR "Missing wayland-protocols pkgdatadir") +endif() + +string(REGEX REPLACE "[\r\n]" "" WaylandProtocols_PKGDATADIR "${WaylandProtocols_PKGDATADIR}") + +find_package_handle_standard_args(WaylandProtocols + FOUND_VAR + WaylandProtocols_FOUND + REQUIRED_VARS + WaylandProtocols_PKGDATADIR + VERSION_VAR + WaylandProtocols_VERSION + HANDLE_COMPONENTS +) + +set(WAYLAND_PROTOCOLS_FOUND ${WaylandProtocols_FOUND}) +set(WAYLAND_PROTOCOLS_PKGDATADIR ${WaylandProtocols_PKGDATADIR}) +set(WAYLAND_PROTOCOLS_VERSION ${WaylandProtocols_VERSION}) diff --git a/src/external/glfw/CMake/modules/FindXKBCommon.cmake b/src/external/glfw/CMake/modules/FindXKBCommon.cmake new file mode 100644 index 000000000..0f571eeac --- /dev/null +++ b/src/external/glfw/CMake/modules/FindXKBCommon.cmake @@ -0,0 +1,34 @@ +# - Try to find XKBCommon +# Once done, this will define +# +# XKBCOMMON_FOUND - System has XKBCommon +# XKBCOMMON_INCLUDE_DIRS - The XKBCommon include directories +# XKBCOMMON_LIBRARIES - The libraries needed to use XKBCommon +# XKBCOMMON_DEFINITIONS - Compiler switches required for using XKBCommon + +find_package(PkgConfig) +pkg_check_modules(PC_XKBCOMMON QUIET xkbcommon) +set(XKBCOMMON_DEFINITIONS ${PC_XKBCOMMON_CFLAGS_OTHER}) + +find_path(XKBCOMMON_INCLUDE_DIR + NAMES xkbcommon/xkbcommon.h + HINTS ${PC_XKBCOMMON_INCLUDE_DIR} ${PC_XKBCOMMON_INCLUDE_DIRS} +) + +find_library(XKBCOMMON_LIBRARY + NAMES xkbcommon + HINTS ${PC_XKBCOMMON_LIBRARY} ${PC_XKBCOMMON_LIBRARY_DIRS} +) + +set(XKBCOMMON_LIBRARIES ${XKBCOMMON_LIBRARY}) +set(XKBCOMMON_LIBRARY_DIRS ${XKBCOMMON_LIBRARY_DIRS}) +set(XKBCOMMON_INCLUDE_DIRS ${XKBCOMMON_INCLUDE_DIR}) + +include(FindPackageHandleStandardArgs) +find_package_handle_standard_args(XKBCommon DEFAULT_MSG + XKBCOMMON_LIBRARY + XKBCOMMON_INCLUDE_DIR +) + +mark_as_advanced(XKBCOMMON_LIBRARY XKBCOMMON_INCLUDE_DIR) + diff --git a/src/external/glfw/CMake/x86_64-w64-mingw32.cmake b/src/external/glfw/CMake/x86_64-w64-mingw32.cmake new file mode 100644 index 000000000..e629e4573 --- /dev/null +++ b/src/external/glfw/CMake/x86_64-w64-mingw32.cmake @@ -0,0 +1,13 @@ +# Define the environment for cross compiling from Linux to Win32 +SET(CMAKE_SYSTEM_NAME Windows) # Target system name +SET(CMAKE_SYSTEM_VERSION 1) +SET(CMAKE_C_COMPILER "x86_64-w64-mingw32-gcc") +SET(CMAKE_CXX_COMPILER "x86_64-w64-mingw32-g++") +SET(CMAKE_RC_COMPILER "x86_64-w64-mingw32-windres") +SET(CMAKE_RANLIB "x86_64-w64-mingw32-ranlib") + +# Configure the behaviour of the find commands +SET(CMAKE_FIND_ROOT_PATH "/usr/x86_64-w64-mingw32") +SET(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) +SET(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) +SET(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY) diff --git a/src/external/glfw/CMakeLists.txt b/src/external/glfw/CMakeLists.txt new file mode 100644 index 000000000..4f9dbcf7f --- /dev/null +++ b/src/external/glfw/CMakeLists.txt @@ -0,0 +1,402 @@ +cmake_minimum_required(VERSION 3.0) + +project(GLFW C) + +set(CMAKE_LEGACY_CYGWIN_WIN32 OFF) + +if (NOT CMAKE_VERSION VERSION_LESS "3.1") + cmake_policy(SET CMP0054 NEW) +endif() + +set(GLFW_VERSION_MAJOR "3") +set(GLFW_VERSION_MINOR "3") +set(GLFW_VERSION_PATCH "0") +set(GLFW_VERSION_EXTRA "") +set(GLFW_VERSION "${GLFW_VERSION_MAJOR}.${GLFW_VERSION_MINOR}") +set(GLFW_VERSION_FULL "${GLFW_VERSION}.${GLFW_VERSION_PATCH}${GLFW_VERSION_EXTRA}") +set(LIB_SUFFIX "" CACHE STRING "Takes an empty string or 64. Directory where lib will be installed: lib or lib64") + +set_property(GLOBAL PROPERTY USE_FOLDERS ON) + +option(BUILD_SHARED_LIBS "Build shared libraries" OFF) +option(GLFW_BUILD_EXAMPLES "Build the GLFW example programs" ON) +option(GLFW_BUILD_TESTS "Build the GLFW test programs" ON) +option(GLFW_BUILD_DOCS "Build the GLFW documentation" ON) +option(GLFW_INSTALL "Generate installation target" ON) +option(GLFW_VULKAN_STATIC "Use the Vulkan loader statically linked into application" OFF) + +if (UNIX) + option(GLFW_USE_OSMESA "Use OSMesa for offscreen context creation" OFF) +endif() + +if (WIN32) + option(GLFW_USE_HYBRID_HPG "Force use of high-performance GPU on hybrid systems" OFF) +endif() + +if (UNIX AND NOT APPLE) + option(GLFW_USE_WAYLAND "Use Wayland for window creation" OFF) + option(GLFW_USE_MIR "Use Mir for window creation" OFF) +endif() + +if (MSVC) + option(USE_MSVC_RUNTIME_LIBRARY_DLL "Use MSVC runtime library DLL" ON) +endif() + +if (BUILD_SHARED_LIBS) + set(_GLFW_BUILD_DLL 1) +endif() + +if (BUILD_SHARED_LIBS AND UNIX) + # On Unix-like systems, shared libraries can use the soname system. + set(GLFW_LIB_NAME glfw) +else() + set(GLFW_LIB_NAME glfw3) +endif() + +if (GLFW_VULKAN_STATIC) + set(_GLFW_VULKAN_STATIC 1) +endif() + +list(APPEND CMAKE_MODULE_PATH "${GLFW_SOURCE_DIR}/CMake/modules") + +find_package(Threads REQUIRED) +find_package(Vulkan) + +if (GLFW_BUILD_DOCS) + set(DOXYGEN_SKIP_DOT TRUE) + find_package(Doxygen) +endif() + +#-------------------------------------------------------------------- +# Set compiler specific flags +#-------------------------------------------------------------------- +if (MSVC) + if (MSVC90) + # Workaround for VS 2008 not shipping with the DirectX 9 SDK + include(CheckIncludeFile) + check_include_file(dinput.h DINPUT_H_FOUND) + if (NOT DINPUT_H_FOUND) + message(FATAL_ERROR "DirectX 9 SDK not found") + endif() + # Workaround for VS 2008 not shipping with stdint.h + list(APPEND glfw_INCLUDE_DIRS "${GLFW_SOURCE_DIR}/deps/vs2008") + endif() + + if (NOT USE_MSVC_RUNTIME_LIBRARY_DLL) + foreach (flag CMAKE_C_FLAGS + CMAKE_C_FLAGS_DEBUG + CMAKE_C_FLAGS_RELEASE + CMAKE_C_FLAGS_MINSIZEREL + CMAKE_C_FLAGS_RELWITHDEBINFO) + + if (${flag} MATCHES "/MD") + string(REGEX REPLACE "/MD" "/MT" ${flag} "${${flag}}") + endif() + if (${flag} MATCHES "/MDd") + string(REGEX REPLACE "/MDd" "/MTd" ${flag} "${${flag}}") + endif() + + endforeach() + endif() +endif() + +if (MINGW) + # Workaround for legacy MinGW not providing XInput and DirectInput + include(CheckIncludeFile) + + check_include_file(dinput.h DINPUT_H_FOUND) + check_include_file(xinput.h XINPUT_H_FOUND) + if (NOT DINPUT_H_FOUND OR NOT XINPUT_H_FOUND) + list(APPEND glfw_INCLUDE_DIRS "${GLFW_SOURCE_DIR}/deps/mingw") + endif() + + # Enable link-time exploit mitigation features enabled by default on MSVC + include(CheckCCompilerFlag) + + # Compatibility with data execution prevention (DEP) + set(CMAKE_REQUIRED_FLAGS "-Wl,--nxcompat") + check_c_compiler_flag("" _GLFW_HAS_DEP) + if (_GLFW_HAS_DEP) + set(CMAKE_SHARED_LINKER_FLAGS "-Wl,--nxcompat ${CMAKE_SHARED_LINKER_FLAGS}") + endif() + + # Compatibility with address space layout randomization (ASLR) + set(CMAKE_REQUIRED_FLAGS "-Wl,--dynamicbase") + check_c_compiler_flag("" _GLFW_HAS_ASLR) + if (_GLFW_HAS_ASLR) + set(CMAKE_SHARED_LINKER_FLAGS "-Wl,--dynamicbase ${CMAKE_SHARED_LINKER_FLAGS}") + endif() + + # Compatibility with 64-bit address space layout randomization (ASLR) + set(CMAKE_REQUIRED_FLAGS "-Wl,--high-entropy-va") + check_c_compiler_flag("" _GLFW_HAS_64ASLR) + if (_GLFW_HAS_64ASLR) + set(CMAKE_SHARED_LINKER_FLAGS "-Wl,--high-entropy-va ${CMAKE_SHARED_LINKER_FLAGS}") + endif() +endif() + +#-------------------------------------------------------------------- +# Detect and select backend APIs +#-------------------------------------------------------------------- +if (GLFW_USE_WAYLAND) + set(_GLFW_WAYLAND 1) + message(STATUS "Using Wayland for window creation") +elseif (GLFW_USE_MIR) + set(_GLFW_MIR 1) + message(STATUS "Using Mir for window creation") +elseif (GLFW_USE_OSMESA) + set(_GLFW_OSMESA 1) + message(STATUS "Using OSMesa for headless context creation") +elseif (WIN32) + set(_GLFW_WIN32 1) + message(STATUS "Using Win32 for window creation") +elseif (APPLE) + set(_GLFW_COCOA 1) + message(STATUS "Using Cocoa for window creation") +elseif (UNIX) + set(_GLFW_X11 1) + message(STATUS "Using X11 for window creation") +else() + message(FATAL_ERROR "No supported platform was detected") +endif() + +#-------------------------------------------------------------------- +# Add Vulkan static library if requested +#-------------------------------------------------------------------- +if (GLFW_VULKAN_STATIC) + if (VULKAN_FOUND AND VULKAN_STATIC_LIBRARY) + list(APPEND glfw_LIBRARIES "${VULKAN_STATIC_LIBRARY}") + if (BUILD_SHARED_LIBS) + message(WARNING "Linking Vulkan loader static library into GLFW") + endif() + else() + if (BUILD_SHARED_LIBS OR GLFW_BUILD_EXAMPLES OR GLFW_BUILD_TESTS) + message(FATAL_ERROR "Vulkan loader static library not found") + else() + message(WARNING "Vulkan loader static library not found") + endif() + endif() +endif() + +#-------------------------------------------------------------------- +# Find and add Unix math and time libraries +#-------------------------------------------------------------------- +if (UNIX AND NOT APPLE) + find_library(RT_LIBRARY rt) + mark_as_advanced(RT_LIBRARY) + if (RT_LIBRARY) + list(APPEND glfw_LIBRARIES "${RT_LIBRARY}") + list(APPEND glfw_PKG_LIBS "-lrt") + endif() + + find_library(MATH_LIBRARY m) + mark_as_advanced(MATH_LIBRARY) + if (MATH_LIBRARY) + list(APPEND glfw_LIBRARIES "${MATH_LIBRARY}") + list(APPEND glfw_PKG_LIBS "-lm") + endif() + + if (CMAKE_DL_LIBS) + list(APPEND glfw_LIBRARIES "${CMAKE_DL_LIBS}") + list(APPEND glfw_PKG_LIBS "-l${CMAKE_DL_LIBS}") + endif() +endif() + +#-------------------------------------------------------------------- +# Use Win32 for window creation +#-------------------------------------------------------------------- +if (_GLFW_WIN32) + + list(APPEND glfw_PKG_LIBS "-lgdi32") + + if (GLFW_USE_HYBRID_HPG) + set(_GLFW_USE_HYBRID_HPG 1) + endif() +endif() + +#-------------------------------------------------------------------- +# Use X11 for window creation +#-------------------------------------------------------------------- +if (_GLFW_X11) + + find_package(X11 REQUIRED) + + list(APPEND glfw_PKG_DEPS "x11") + + # Set up library and include paths + list(APPEND glfw_INCLUDE_DIRS "${X11_X11_INCLUDE_PATH}") + list(APPEND glfw_LIBRARIES "${X11_X11_LIB}" "${CMAKE_THREAD_LIBS_INIT}") + + # Check for XRandR (modern resolution switching and gamma control) + if (NOT X11_Xrandr_FOUND) + message(FATAL_ERROR "The RandR headers were not found") + endif() + + # Check for Xinerama (legacy multi-monitor support) + if (NOT X11_Xinerama_FOUND) + message(FATAL_ERROR "The Xinerama headers were not found") + endif() + + # Check for Xkb (X keyboard extension) + if (NOT X11_Xkb_FOUND) + message(FATAL_ERROR "The X keyboard extension headers were not found") + endif() + + # Check for Xcursor (cursor creation from RGBA images) + if (NOT X11_Xcursor_FOUND) + message(FATAL_ERROR "The Xcursor headers were not found") + endif() + + list(APPEND glfw_INCLUDE_DIRS "${X11_Xrandr_INCLUDE_PATH}" + "${X11_Xinerama_INCLUDE_PATH}" + "${X11_Xkb_INCLUDE_PATH}" + "${X11_Xcursor_INCLUDE_PATH}") +endif() + +#-------------------------------------------------------------------- +# Use Wayland for window creation +#-------------------------------------------------------------------- +if (_GLFW_WAYLAND) + find_package(ECM REQUIRED NO_MODULE) + list(APPEND CMAKE_MODULE_PATH "${ECM_MODULE_PATH}") + + find_package(Wayland REQUIRED Client Cursor Egl) + find_package(WaylandScanner REQUIRED) + find_package(WaylandProtocols 1.12 REQUIRED) + + list(APPEND glfw_PKG_DEPS "wayland-egl") + + list(APPEND glfw_INCLUDE_DIRS "${Wayland_INCLUDE_DIRS}") + list(APPEND glfw_LIBRARIES "${Wayland_LIBRARIES}" "${CMAKE_THREAD_LIBS_INIT}") + + find_package(XKBCommon REQUIRED) + list(APPEND glfw_INCLUDE_DIRS "${XKBCOMMON_INCLUDE_DIRS}") + + include(CheckIncludeFiles) + check_include_files(xkbcommon/xkbcommon-compose.h HAVE_XKBCOMMON_COMPOSE_H) + + if (NOT ("${CMAKE_SYSTEM_NAME}" STREQUAL "Linux")) + find_package(EpollShim) + if (EPOLLSHIM_FOUND) + list(APPEND glfw_INCLUDE_DIRS "${EPOLLSHIM_INCLUDE_DIRS}") + list(APPEND glfw_LIBRARIES "${EPOLLSHIM_LIBRARIES}") + endif() + endif() +endif() + +#-------------------------------------------------------------------- +# Use Mir for window creation +#-------------------------------------------------------------------- +if (_GLFW_MIR) + find_package(Mir REQUIRED) + list(APPEND glfw_PKG_DEPS "mirclient") + + list(APPEND glfw_INCLUDE_DIRS "${MIR_INCLUDE_DIRS}") + list(APPEND glfw_LIBRARIES "${MIR_LIBRARIES}" "${CMAKE_THREAD_LIBS_INIT}") + + find_package(XKBCommon REQUIRED) + list(APPEND glfw_PKG_DEPS "xkbcommon") + list(APPEND glfw_INCLUDE_DIRS "${XKBCOMMON_INCLUDE_DIRS}") + list(APPEND glfw_LIBRARIES "${XKBCOMMON_LIBRARY}") +endif() + +#-------------------------------------------------------------------- +# Use OSMesa for offscreen context creation +#-------------------------------------------------------------------- +if (_GLFW_OSMESA) + find_package(OSMesa REQUIRED) + list(APPEND glfw_LIBRARIES "${CMAKE_THREAD_LIBS_INIT}") +endif() + +#-------------------------------------------------------------------- +# Use Cocoa for window creation and NSOpenGL for context creation +#-------------------------------------------------------------------- +if (_GLFW_COCOA) + + list(APPEND glfw_LIBRARIES + "-framework Cocoa" + "-framework IOKit" + "-framework CoreFoundation" + "-framework CoreVideo") + + set(glfw_PKG_DEPS "") + set(glfw_PKG_LIBS "-framework Cocoa -framework IOKit -framework CoreFoundation -framework CoreVideo") +endif() + +#-------------------------------------------------------------------- +# Export GLFW library dependencies +#-------------------------------------------------------------------- +foreach(arg ${glfw_PKG_DEPS}) + set(GLFW_PKG_DEPS "${GLFW_PKG_DEPS} ${arg}") +endforeach() +foreach(arg ${glfw_PKG_LIBS}) + set(GLFW_PKG_LIBS "${GLFW_PKG_LIBS} ${arg}") +endforeach() + +#-------------------------------------------------------------------- +# Create generated files +#-------------------------------------------------------------------- +include(CMakePackageConfigHelpers) + +set(GLFW_CONFIG_PATH "lib${LIB_SUFFIX}/cmake/glfw3") + +configure_package_config_file(src/glfw3Config.cmake.in + src/glfw3Config.cmake + INSTALL_DESTINATION "${GLFW_CONFIG_PATH}" + NO_CHECK_REQUIRED_COMPONENTS_MACRO) + +write_basic_package_version_file(src/glfw3ConfigVersion.cmake + VERSION ${GLFW_VERSION_FULL} + COMPATIBILITY SameMajorVersion) + +configure_file(src/glfw_config.h.in src/glfw_config.h @ONLY) + +configure_file(src/glfw3.pc.in src/glfw3.pc @ONLY) + +#-------------------------------------------------------------------- +# Add subdirectories +#-------------------------------------------------------------------- +add_subdirectory(src) + +if (GLFW_BUILD_EXAMPLES) + add_subdirectory(examples) +endif() + +if (GLFW_BUILD_TESTS) + add_subdirectory(tests) +endif() + +if (DOXYGEN_FOUND AND GLFW_BUILD_DOCS) + add_subdirectory(docs) +endif() + +#-------------------------------------------------------------------- +# Install files other than the library +# The library is installed by src/CMakeLists.txt +#-------------------------------------------------------------------- +if (GLFW_INSTALL) + install(DIRECTORY include/GLFW DESTINATION include + FILES_MATCHING PATTERN glfw3.h PATTERN glfw3native.h) + + install(FILES "${GLFW_BINARY_DIR}/src/glfw3Config.cmake" + "${GLFW_BINARY_DIR}/src/glfw3ConfigVersion.cmake" + DESTINATION "${GLFW_CONFIG_PATH}") + + install(EXPORT glfwTargets FILE glfw3Targets.cmake + EXPORT_LINK_INTERFACE_LIBRARIES + DESTINATION "${GLFW_CONFIG_PATH}") + install(FILES "${GLFW_BINARY_DIR}/src/glfw3.pc" + DESTINATION "lib${LIB_SUFFIX}/pkgconfig") + + # Only generate this target if no higher-level project already has + if (NOT TARGET uninstall) + configure_file(cmake_uninstall.cmake.in + cmake_uninstall.cmake IMMEDIATE @ONLY) + + add_custom_target(uninstall + "${CMAKE_COMMAND}" -P + "${GLFW_BINARY_DIR}/cmake_uninstall.cmake") + set_target_properties(uninstall PROPERTIES FOLDER "GLFW3") + endif() +endif() + diff --git a/src/external/glfw/cmake_uninstall.cmake.in b/src/external/glfw/cmake_uninstall.cmake.in new file mode 100644 index 000000000..4ea57b1cf --- /dev/null +++ b/src/external/glfw/cmake_uninstall.cmake.in @@ -0,0 +1,29 @@ + +if (NOT EXISTS "@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt") + message(FATAL_ERROR "Cannot find install manifest: \"@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt\"") +endif() + +file(READ "@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt" files) +string(REGEX REPLACE "\n" ";" files "${files}") + +foreach (file ${files}) + message(STATUS "Uninstalling \"$ENV{DESTDIR}${file}\"") + if (EXISTS "$ENV{DESTDIR}${file}") + exec_program("@CMAKE_COMMAND@" ARGS "-E remove \"$ENV{DESTDIR}${file}\"" + OUTPUT_VARIABLE rm_out + RETURN_VALUE rm_retval) + if (NOT "${rm_retval}" STREQUAL 0) + MESSAGE(FATAL_ERROR "Problem when removing \"$ENV{DESTDIR}${file}\"") + endif() + elseif (IS_SYMLINK "$ENV{DESTDIR}${file}") + EXEC_PROGRAM("@CMAKE_COMMAND@" ARGS "-E remove \"$ENV{DESTDIR}${file}\"" + OUTPUT_VARIABLE rm_out + RETURN_VALUE rm_retval) + if (NOT "${rm_retval}" STREQUAL 0) + message(FATAL_ERROR "Problem when removing symlink \"$ENV{DESTDIR}${file}\"") + endif() + else() + message(STATUS "File \"$ENV{DESTDIR}${file}\" does not exist.") + endif() +endforeach() + diff --git a/src/external/glfw/deps/getopt.c b/src/external/glfw/deps/getopt.c new file mode 100644 index 000000000..9743046f9 --- /dev/null +++ b/src/external/glfw/deps/getopt.c @@ -0,0 +1,230 @@ +/* Copyright (c) 2012, Kim Gräsman + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are met: + * * Redistributions of source code must retain the above copyright notice, + * this list of conditions and the following disclaimer. + * * Redistributions in binary form must reproduce the above copyright notice, + * this list of conditions and the following disclaimer in the documentation + * and/or other materials provided with the distribution. + * * Neither the name of Kim Gräsman nor the names of contributors may be used + * to endorse or promote products derived from this software without specific + * prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL KIM GRÄSMAN BE LIABLE FOR ANY DIRECT, + * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND + * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#include "getopt.h" + +#include +#include + +const int no_argument = 0; +const int required_argument = 1; +const int optional_argument = 2; + +char* optarg; +int optopt; +/* The variable optind [...] shall be initialized to 1 by the system. */ +int optind = 1; +int opterr; + +static char* optcursor = NULL; + +/* Implemented based on [1] and [2] for optional arguments. + optopt is handled FreeBSD-style, per [3]. + Other GNU and FreeBSD extensions are purely accidental. + +[1] http://pubs.opengroup.org/onlinepubs/000095399/functions/getopt.html +[2] http://www.kernel.org/doc/man-pages/online/pages/man3/getopt.3.html +[3] http://www.freebsd.org/cgi/man.cgi?query=getopt&sektion=3&manpath=FreeBSD+9.0-RELEASE +*/ +int getopt(int argc, char* const argv[], const char* optstring) { + int optchar = -1; + const char* optdecl = NULL; + + optarg = NULL; + opterr = 0; + optopt = 0; + + /* Unspecified, but we need it to avoid overrunning the argv bounds. */ + if (optind >= argc) + goto no_more_optchars; + + /* If, when getopt() is called argv[optind] is a null pointer, getopt() + shall return -1 without changing optind. */ + if (argv[optind] == NULL) + goto no_more_optchars; + + /* If, when getopt() is called *argv[optind] is not the character '-', + getopt() shall return -1 without changing optind. */ + if (*argv[optind] != '-') + goto no_more_optchars; + + /* If, when getopt() is called argv[optind] points to the string "-", + getopt() shall return -1 without changing optind. */ + if (strcmp(argv[optind], "-") == 0) + goto no_more_optchars; + + /* If, when getopt() is called argv[optind] points to the string "--", + getopt() shall return -1 after incrementing optind. */ + if (strcmp(argv[optind], "--") == 0) { + ++optind; + goto no_more_optchars; + } + + if (optcursor == NULL || *optcursor == '\0') + optcursor = argv[optind] + 1; + + optchar = *optcursor; + + /* FreeBSD: The variable optopt saves the last known option character + returned by getopt(). */ + optopt = optchar; + + /* The getopt() function shall return the next option character (if one is + found) from argv that matches a character in optstring, if there is + one that matches. */ + optdecl = strchr(optstring, optchar); + if (optdecl) { + /* [I]f a character is followed by a colon, the option takes an + argument. */ + if (optdecl[1] == ':') { + optarg = ++optcursor; + if (*optarg == '\0') { + /* GNU extension: Two colons mean an option takes an + optional arg; if there is text in the current argv-element + (i.e., in the same word as the option name itself, for example, + "-oarg"), then it is returned in optarg, otherwise optarg is set + to zero. */ + if (optdecl[2] != ':') { + /* If the option was the last character in the string pointed to by + an element of argv, then optarg shall contain the next element + of argv, and optind shall be incremented by 2. If the resulting + value of optind is greater than argc, this indicates a missing + option-argument, and getopt() shall return an error indication. + + Otherwise, optarg shall point to the string following the + option character in that element of argv, and optind shall be + incremented by 1. + */ + if (++optind < argc) { + optarg = argv[optind]; + } else { + /* If it detects a missing option-argument, it shall return the + colon character ( ':' ) if the first character of optstring + was a colon, or a question-mark character ( '?' ) otherwise. + */ + optarg = NULL; + optchar = (optstring[0] == ':') ? ':' : '?'; + } + } else { + optarg = NULL; + } + } + + optcursor = NULL; + } + } else { + /* If getopt() encounters an option character that is not contained in + optstring, it shall return the question-mark ( '?' ) character. */ + optchar = '?'; + } + + if (optcursor == NULL || *++optcursor == '\0') + ++optind; + + return optchar; + +no_more_optchars: + optcursor = NULL; + return -1; +} + +/* Implementation based on [1]. + +[1] http://www.kernel.org/doc/man-pages/online/pages/man3/getopt.3.html +*/ +int getopt_long(int argc, char* const argv[], const char* optstring, + const struct option* longopts, int* longindex) { + const struct option* o = longopts; + const struct option* match = NULL; + int num_matches = 0; + size_t argument_name_length = 0; + const char* current_argument = NULL; + int retval = -1; + + optarg = NULL; + optopt = 0; + + if (optind >= argc) + return -1; + + if (strlen(argv[optind]) < 3 || strncmp(argv[optind], "--", 2) != 0) + return getopt(argc, argv, optstring); + + /* It's an option; starts with -- and is longer than two chars. */ + current_argument = argv[optind] + 2; + argument_name_length = strcspn(current_argument, "="); + for (; o->name; ++o) { + if (strncmp(o->name, current_argument, argument_name_length) == 0) { + match = o; + ++num_matches; + } + } + + if (num_matches == 1) { + /* If longindex is not NULL, it points to a variable which is set to the + index of the long option relative to longopts. */ + if (longindex) + *longindex = (int) (match - longopts); + + /* If flag is NULL, then getopt_long() shall return val. + Otherwise, getopt_long() returns 0, and flag shall point to a variable + which shall be set to val if the option is found, but left unchanged if + the option is not found. */ + if (match->flag) + *(match->flag) = match->val; + + retval = match->flag ? 0 : match->val; + + if (match->has_arg != no_argument) { + optarg = strchr(argv[optind], '='); + if (optarg != NULL) + ++optarg; + + if (match->has_arg == required_argument) { + /* Only scan the next argv for required arguments. Behavior is not + specified, but has been observed with Ubuntu and Mac OSX. */ + if (optarg == NULL && ++optind < argc) { + optarg = argv[optind]; + } + + if (optarg == NULL) + retval = ':'; + } + } else if (strchr(argv[optind], '=')) { + /* An argument was provided to a non-argument option. + I haven't seen this specified explicitly, but both GNU and BSD-based + implementations show this behavior. + */ + retval = '?'; + } + } else { + /* Unknown option or ambiguous match. */ + retval = '?'; + } + + ++optind; + return retval; +} diff --git a/src/external/glfw/deps/getopt.h b/src/external/glfw/deps/getopt.h new file mode 100644 index 000000000..e1eb540fd --- /dev/null +++ b/src/external/glfw/deps/getopt.h @@ -0,0 +1,57 @@ +/* Copyright (c) 2012, Kim Gräsman + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are met: + * * Redistributions of source code must retain the above copyright notice, + * this list of conditions and the following disclaimer. + * * Redistributions in binary form must reproduce the above copyright notice, + * this list of conditions and the following disclaimer in the documentation + * and/or other materials provided with the distribution. + * * Neither the name of Kim Gräsman nor the names of contributors may be used + * to endorse or promote products derived from this software without specific + * prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL KIM GRÄSMAN BE LIABLE FOR ANY DIRECT, + * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND + * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#ifndef INCLUDED_GETOPT_PORT_H +#define INCLUDED_GETOPT_PORT_H + +#if defined(__cplusplus) +extern "C" { +#endif + +extern const int no_argument; +extern const int required_argument; +extern const int optional_argument; + +extern char* optarg; +extern int optind, opterr, optopt; + +struct option { + const char* name; + int has_arg; + int* flag; + int val; +}; + +int getopt(int argc, char* const argv[], const char* optstring); + +int getopt_long(int argc, char* const argv[], + const char* optstring, const struct option* longopts, int* longindex); + +#if defined(__cplusplus) +} +#endif + +#endif // INCLUDED_GETOPT_PORT_H diff --git a/src/external/glfw/deps/glad.c b/src/external/glfw/deps/glad.c new file mode 100644 index 000000000..10b0a00e1 --- /dev/null +++ b/src/external/glfw/deps/glad.c @@ -0,0 +1,1678 @@ +/* + + OpenGL loader generated by glad 0.1.12a0 on Fri Sep 23 13:36:15 2016. + + Language/Generator: C/C++ + Specification: gl + APIs: gl=3.2 + Profile: compatibility + Extensions: + GL_ARB_multisample, + GL_ARB_robustness, + GL_KHR_debug + Loader: False + Local files: False + Omit khrplatform: False + + Commandline: + --profile="compatibility" --api="gl=3.2" --generator="c" --spec="gl" --no-loader --extensions="GL_ARB_multisample,GL_ARB_robustness,GL_KHR_debug" + Online: + http://glad.dav1d.de/#profile=compatibility&language=c&specification=gl&api=gl%3D3.2&extensions=GL_ARB_multisample&extensions=GL_ARB_robustness&extensions=GL_KHR_debug +*/ + +#include +#include +#include +#include + +struct gladGLversionStruct GLVersion; + +#if defined(GL_ES_VERSION_3_0) || defined(GL_VERSION_3_0) +#define _GLAD_IS_SOME_NEW_VERSION 1 +#endif + +static int max_loaded_major; +static int max_loaded_minor; + +static const char *exts = NULL; +static int num_exts_i = 0; +static const char **exts_i = NULL; + +static int get_exts(void) { +#ifdef _GLAD_IS_SOME_NEW_VERSION + if(max_loaded_major < 3) { +#endif + exts = (const char *)glGetString(GL_EXTENSIONS); +#ifdef _GLAD_IS_SOME_NEW_VERSION + } else { + int index; + + num_exts_i = 0; + glGetIntegerv(GL_NUM_EXTENSIONS, &num_exts_i); + if (num_exts_i > 0) { + exts_i = (const char **)realloc((void *)exts_i, num_exts_i * sizeof *exts_i); + } + + if (exts_i == NULL) { + return 0; + } + + for(index = 0; index < num_exts_i; index++) { + exts_i[index] = (const char*)glGetStringi(GL_EXTENSIONS, index); + } + } +#endif + return 1; +} + +static void free_exts(void) { + if (exts_i != NULL) { + free((char **)exts_i); + exts_i = NULL; + } +} + +static int has_ext(const char *ext) { +#ifdef _GLAD_IS_SOME_NEW_VERSION + if(max_loaded_major < 3) { +#endif + const char *extensions; + const char *loc; + const char *terminator; + extensions = exts; + if(extensions == NULL || ext == NULL) { + return 0; + } + + while(1) { + loc = strstr(extensions, ext); + if(loc == NULL) { + return 0; + } + + terminator = loc + strlen(ext); + if((loc == extensions || *(loc - 1) == ' ') && + (*terminator == ' ' || *terminator == '\0')) { + return 1; + } + extensions = terminator; + } +#ifdef _GLAD_IS_SOME_NEW_VERSION + } else { + int index; + + for(index = 0; index < num_exts_i; index++) { + const char *e = exts_i[index]; + + if(strcmp(e, ext) == 0) { + return 1; + } + } + } +#endif + + return 0; +} +int GLAD_GL_VERSION_1_0; +int GLAD_GL_VERSION_1_1; +int GLAD_GL_VERSION_1_2; +int GLAD_GL_VERSION_1_3; +int GLAD_GL_VERSION_1_4; +int GLAD_GL_VERSION_1_5; +int GLAD_GL_VERSION_2_0; +int GLAD_GL_VERSION_2_1; +int GLAD_GL_VERSION_3_0; +int GLAD_GL_VERSION_3_1; +int GLAD_GL_VERSION_3_2; +PFNGLCOPYTEXIMAGE1DPROC glad_glCopyTexImage1D; +PFNGLVERTEXATTRIBI3UIPROC glad_glVertexAttribI3ui; +PFNGLWINDOWPOS2SPROC glad_glWindowPos2s; +PFNGLWINDOWPOS2IPROC glad_glWindowPos2i; +PFNGLWINDOWPOS2FPROC glad_glWindowPos2f; +PFNGLWINDOWPOS2DPROC glad_glWindowPos2d; +PFNGLVERTEX2FVPROC glad_glVertex2fv; +PFNGLINDEXIPROC glad_glIndexi; +PFNGLFRAMEBUFFERRENDERBUFFERPROC glad_glFramebufferRenderbuffer; +PFNGLRECTDVPROC glad_glRectdv; +PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC glad_glCompressedTexSubImage3D; +PFNGLEVALCOORD2DPROC glad_glEvalCoord2d; +PFNGLEVALCOORD2FPROC glad_glEvalCoord2f; +PFNGLINDEXDPROC glad_glIndexd; +PFNGLVERTEXATTRIB1SVPROC glad_glVertexAttrib1sv; +PFNGLINDEXFPROC glad_glIndexf; +PFNGLLINEWIDTHPROC glad_glLineWidth; +PFNGLGETINTEGERI_VPROC glad_glGetIntegeri_v; +PFNGLGETMAPFVPROC glad_glGetMapfv; +PFNGLINDEXSPROC glad_glIndexs; +PFNGLCOMPILESHADERPROC glad_glCompileShader; +PFNGLGETTRANSFORMFEEDBACKVARYINGPROC glad_glGetTransformFeedbackVarying; +PFNGLWINDOWPOS2IVPROC glad_glWindowPos2iv; +PFNGLINDEXFVPROC glad_glIndexfv; +PFNGLFOGIVPROC glad_glFogiv; +PFNGLSTENCILMASKSEPARATEPROC glad_glStencilMaskSeparate; +PFNGLRASTERPOS2FVPROC glad_glRasterPos2fv; +PFNGLLIGHTMODELIVPROC glad_glLightModeliv; +PFNGLCOLOR4UIPROC glad_glColor4ui; +PFNGLSECONDARYCOLOR3FVPROC glad_glSecondaryColor3fv; +PFNGLFOGFVPROC glad_glFogfv; +PFNGLENABLEIPROC glad_glEnablei; +PFNGLVERTEX4IVPROC glad_glVertex4iv; +PFNGLEVALCOORD1FVPROC glad_glEvalCoord1fv; +PFNGLWINDOWPOS2SVPROC glad_glWindowPos2sv; +PFNGLCREATESHADERPROC glad_glCreateShader; +PFNGLISBUFFERPROC glad_glIsBuffer; +PFNGLGETMULTISAMPLEFVPROC glad_glGetMultisamplefv; +PFNGLGENRENDERBUFFERSPROC glad_glGenRenderbuffers; +PFNGLCOPYTEXSUBIMAGE2DPROC glad_glCopyTexSubImage2D; +PFNGLCOMPRESSEDTEXIMAGE2DPROC glad_glCompressedTexImage2D; +PFNGLVERTEXATTRIB1FPROC glad_glVertexAttrib1f; +PFNGLBLENDFUNCSEPARATEPROC glad_glBlendFuncSeparate; +PFNGLVERTEX4FVPROC glad_glVertex4fv; +PFNGLBINDTEXTUREPROC glad_glBindTexture; +PFNGLVERTEXATTRIB1SPROC glad_glVertexAttrib1s; +PFNGLTEXCOORD2FVPROC glad_glTexCoord2fv; +PFNGLSAMPLEMASKIPROC glad_glSampleMaski; +PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC glad_glDrawRangeElementsBaseVertex; +PFNGLTEXCOORD4FVPROC glad_glTexCoord4fv; +PFNGLUNIFORMMATRIX3X2FVPROC glad_glUniformMatrix3x2fv; +PFNGLPOINTSIZEPROC glad_glPointSize; +PFNGLVERTEXATTRIB2DVPROC glad_glVertexAttrib2dv; +PFNGLDELETEPROGRAMPROC glad_glDeleteProgram; +PFNGLCOLOR4BVPROC glad_glColor4bv; +PFNGLRASTERPOS2FPROC glad_glRasterPos2f; +PFNGLRASTERPOS2DPROC glad_glRasterPos2d; +PFNGLLOADIDENTITYPROC glad_glLoadIdentity; +PFNGLRASTERPOS2IPROC glad_glRasterPos2i; +PFNGLRENDERBUFFERSTORAGEPROC glad_glRenderbufferStorage; +PFNGLUNIFORMMATRIX4X3FVPROC glad_glUniformMatrix4x3fv; +PFNGLCOLOR3BPROC glad_glColor3b; +PFNGLCLEARBUFFERFVPROC glad_glClearBufferfv; +PFNGLEDGEFLAGPROC glad_glEdgeFlag; +PFNGLVERTEX3DPROC glad_glVertex3d; +PFNGLVERTEX3FPROC glad_glVertex3f; +PFNGLVERTEX3IPROC glad_glVertex3i; +PFNGLCOLOR3IPROC glad_glColor3i; +PFNGLUNIFORM3FPROC glad_glUniform3f; +PFNGLVERTEXATTRIB4UBVPROC glad_glVertexAttrib4ubv; +PFNGLCOLOR3SPROC glad_glColor3s; +PFNGLVERTEX3SPROC glad_glVertex3s; +PFNGLCOLORMASKIPROC glad_glColorMaski; +PFNGLCLEARBUFFERFIPROC glad_glClearBufferfi; +PFNGLTEXCOORD1IVPROC glad_glTexCoord1iv; +PFNGLBLITFRAMEBUFFERPROC glad_glBlitFramebuffer; +PFNGLVERTEXATTRIB3FPROC glad_glVertexAttrib3f; +PFNGLVERTEX2IVPROC glad_glVertex2iv; +PFNGLCOLOR3SVPROC glad_glColor3sv; +PFNGLGETVERTEXATTRIBDVPROC glad_glGetVertexAttribdv; +PFNGLUNIFORMMATRIX3X4FVPROC glad_glUniformMatrix3x4fv; +PFNGLNORMALPOINTERPROC glad_glNormalPointer; +PFNGLVERTEX4SVPROC glad_glVertex4sv; +PFNGLPASSTHROUGHPROC glad_glPassThrough; +PFNGLFOGIPROC glad_glFogi; +PFNGLBEGINPROC glad_glBegin; +PFNGLEVALCOORD2DVPROC glad_glEvalCoord2dv; +PFNGLCOLOR3UBVPROC glad_glColor3ubv; +PFNGLVERTEXPOINTERPROC glad_glVertexPointer; +PFNGLSECONDARYCOLOR3UIVPROC glad_glSecondaryColor3uiv; +PFNGLDELETEFRAMEBUFFERSPROC glad_glDeleteFramebuffers; +PFNGLDRAWARRAYSPROC glad_glDrawArrays; +PFNGLUNIFORM1UIPROC glad_glUniform1ui; +PFNGLMULTITEXCOORD1DPROC glad_glMultiTexCoord1d; +PFNGLMULTITEXCOORD1FPROC glad_glMultiTexCoord1f; +PFNGLLIGHTFVPROC glad_glLightfv; +PFNGLVERTEXATTRIB3DPROC glad_glVertexAttrib3d; +PFNGLCLEARPROC glad_glClear; +PFNGLMULTITEXCOORD1IPROC glad_glMultiTexCoord1i; +PFNGLGETACTIVEUNIFORMNAMEPROC glad_glGetActiveUniformName; +PFNGLMULTITEXCOORD1SPROC glad_glMultiTexCoord1s; +PFNGLISENABLEDPROC glad_glIsEnabled; +PFNGLSTENCILOPPROC glad_glStencilOp; +PFNGLGETQUERYOBJECTUIVPROC glad_glGetQueryObjectuiv; +PFNGLFRAMEBUFFERTEXTURE2DPROC glad_glFramebufferTexture2D; +PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVPROC glad_glGetFramebufferAttachmentParameteriv; +PFNGLTRANSLATEFPROC glad_glTranslatef; +PFNGLVERTEXATTRIB4NUBPROC glad_glVertexAttrib4Nub; +PFNGLTRANSLATEDPROC glad_glTranslated; +PFNGLTEXCOORD3SVPROC glad_glTexCoord3sv; +PFNGLGETFRAGDATALOCATIONPROC glad_glGetFragDataLocation; +PFNGLTEXIMAGE1DPROC glad_glTexImage1D; +PFNGLTEXPARAMETERIVPROC glad_glTexParameteriv; +PFNGLSECONDARYCOLOR3BVPROC glad_glSecondaryColor3bv; +PFNGLGETMATERIALFVPROC glad_glGetMaterialfv; +PFNGLGETTEXIMAGEPROC glad_glGetTexImage; +PFNGLFOGCOORDFVPROC glad_glFogCoordfv; +PFNGLPIXELMAPUIVPROC glad_glPixelMapuiv; +PFNGLGETSHADERINFOLOGPROC glad_glGetShaderInfoLog; +PFNGLGENFRAMEBUFFERSPROC glad_glGenFramebuffers; +PFNGLINDEXSVPROC glad_glIndexsv; +PFNGLGETATTACHEDSHADERSPROC glad_glGetAttachedShaders; +PFNGLISRENDERBUFFERPROC glad_glIsRenderbuffer; +PFNGLVERTEX3IVPROC glad_glVertex3iv; +PFNGLBITMAPPROC glad_glBitmap; +PFNGLMATERIALIPROC glad_glMateriali; +PFNGLISVERTEXARRAYPROC glad_glIsVertexArray; +PFNGLDISABLEVERTEXATTRIBARRAYPROC glad_glDisableVertexAttribArray; +PFNGLGETQUERYIVPROC glad_glGetQueryiv; +PFNGLTEXCOORD4FPROC glad_glTexCoord4f; +PFNGLTEXCOORD4DPROC glad_glTexCoord4d; +PFNGLTEXCOORD4IPROC glad_glTexCoord4i; +PFNGLMATERIALFPROC glad_glMaterialf; +PFNGLTEXCOORD4SPROC glad_glTexCoord4s; +PFNGLGETUNIFORMINDICESPROC glad_glGetUniformIndices; +PFNGLISSHADERPROC glad_glIsShader; +PFNGLMULTITEXCOORD2SPROC glad_glMultiTexCoord2s; +PFNGLVERTEXATTRIBI4UBVPROC glad_glVertexAttribI4ubv; +PFNGLVERTEX3DVPROC glad_glVertex3dv; +PFNGLGETINTEGER64VPROC glad_glGetInteger64v; +PFNGLPOINTPARAMETERIVPROC glad_glPointParameteriv; +PFNGLENABLEPROC glad_glEnable; +PFNGLGETACTIVEUNIFORMSIVPROC glad_glGetActiveUniformsiv; +PFNGLCOLOR4FVPROC glad_glColor4fv; +PFNGLTEXCOORD1FVPROC glad_glTexCoord1fv; +PFNGLTEXCOORD2SVPROC glad_glTexCoord2sv; +PFNGLVERTEXATTRIB4DVPROC glad_glVertexAttrib4dv; +PFNGLMULTITEXCOORD1DVPROC glad_glMultiTexCoord1dv; +PFNGLMULTITEXCOORD2IPROC glad_glMultiTexCoord2i; +PFNGLTEXCOORD3FVPROC glad_glTexCoord3fv; +PFNGLSECONDARYCOLOR3USVPROC glad_glSecondaryColor3usv; +PFNGLTEXGENFPROC glad_glTexGenf; +PFNGLGETPOINTERVPROC glad_glGetPointerv; +PFNGLPOLYGONOFFSETPROC glad_glPolygonOffset; +PFNGLGETUNIFORMUIVPROC glad_glGetUniformuiv; +PFNGLNORMAL3FVPROC glad_glNormal3fv; +PFNGLSECONDARYCOLOR3SPROC glad_glSecondaryColor3s; +PFNGLDEPTHRANGEPROC glad_glDepthRange; +PFNGLFRUSTUMPROC glad_glFrustum; +PFNGLMULTITEXCOORD4SVPROC glad_glMultiTexCoord4sv; +PFNGLDRAWBUFFERPROC glad_glDrawBuffer; +PFNGLPUSHMATRIXPROC glad_glPushMatrix; +PFNGLRASTERPOS3FVPROC glad_glRasterPos3fv; +PFNGLORTHOPROC glad_glOrtho; +PFNGLDRAWELEMENTSINSTANCEDPROC glad_glDrawElementsInstanced; +PFNGLWINDOWPOS3SVPROC glad_glWindowPos3sv; +PFNGLCLEARINDEXPROC glad_glClearIndex; +PFNGLMAP1DPROC glad_glMap1d; +PFNGLMAP1FPROC glad_glMap1f; +PFNGLFLUSHPROC glad_glFlush; +PFNGLGETRENDERBUFFERPARAMETERIVPROC glad_glGetRenderbufferParameteriv; +PFNGLINDEXIVPROC glad_glIndexiv; +PFNGLRASTERPOS3SVPROC glad_glRasterPos3sv; +PFNGLGETVERTEXATTRIBPOINTERVPROC glad_glGetVertexAttribPointerv; +PFNGLPIXELZOOMPROC glad_glPixelZoom; +PFNGLFENCESYNCPROC glad_glFenceSync; +PFNGLDELETEVERTEXARRAYSPROC glad_glDeleteVertexArrays; +PFNGLVERTEXATTRIB3SVPROC glad_glVertexAttrib3sv; +PFNGLBEGINCONDITIONALRENDERPROC glad_glBeginConditionalRender; +PFNGLDRAWELEMENTSBASEVERTEXPROC glad_glDrawElementsBaseVertex; +PFNGLGETTEXLEVELPARAMETERIVPROC glad_glGetTexLevelParameteriv; +PFNGLLIGHTIPROC glad_glLighti; +PFNGLLIGHTFPROC glad_glLightf; +PFNGLGETATTRIBLOCATIONPROC glad_glGetAttribLocation; +PFNGLSTENCILFUNCSEPARATEPROC glad_glStencilFuncSeparate; +PFNGLCLAMPCOLORPROC glad_glClampColor; +PFNGLUNIFORM4IVPROC glad_glUniform4iv; +PFNGLCLEARSTENCILPROC glad_glClearStencil; +PFNGLMULTITEXCOORD3FVPROC glad_glMultiTexCoord3fv; +PFNGLGETPIXELMAPUIVPROC glad_glGetPixelMapuiv; +PFNGLGENTEXTURESPROC glad_glGenTextures; +PFNGLTEXCOORD4IVPROC glad_glTexCoord4iv; +PFNGLGETTEXPARAMETERIUIVPROC glad_glGetTexParameterIuiv; +PFNGLINDEXPOINTERPROC glad_glIndexPointer; +PFNGLVERTEXATTRIB4NBVPROC glad_glVertexAttrib4Nbv; +PFNGLISSYNCPROC glad_glIsSync; +PFNGLVERTEX2FPROC glad_glVertex2f; +PFNGLVERTEX2DPROC glad_glVertex2d; +PFNGLDELETERENDERBUFFERSPROC glad_glDeleteRenderbuffers; +PFNGLUNIFORM2IPROC glad_glUniform2i; +PFNGLMAPGRID2DPROC glad_glMapGrid2d; +PFNGLMAPGRID2FPROC glad_glMapGrid2f; +PFNGLVERTEX2IPROC glad_glVertex2i; +PFNGLVERTEXATTRIBPOINTERPROC glad_glVertexAttribPointer; +PFNGLFRAMEBUFFERTEXTURELAYERPROC glad_glFramebufferTextureLayer; +PFNGLVERTEX2SPROC glad_glVertex2s; +PFNGLNORMAL3BVPROC glad_glNormal3bv; +PFNGLVERTEXATTRIB4NUIVPROC glad_glVertexAttrib4Nuiv; +PFNGLFLUSHMAPPEDBUFFERRANGEPROC glad_glFlushMappedBufferRange; +PFNGLSECONDARYCOLOR3SVPROC glad_glSecondaryColor3sv; +PFNGLVERTEX3SVPROC glad_glVertex3sv; +PFNGLGENQUERIESPROC glad_glGenQueries; +PFNGLGETPIXELMAPFVPROC glad_glGetPixelMapfv; +PFNGLTEXENVFPROC glad_glTexEnvf; +PFNGLTEXSUBIMAGE3DPROC glad_glTexSubImage3D; +PFNGLGETINTEGER64I_VPROC glad_glGetInteger64i_v; +PFNGLFOGCOORDDPROC glad_glFogCoordd; +PFNGLFOGCOORDFPROC glad_glFogCoordf; +PFNGLCOPYTEXIMAGE2DPROC glad_glCopyTexImage2D; +PFNGLTEXENVIPROC glad_glTexEnvi; +PFNGLMULTITEXCOORD1IVPROC glad_glMultiTexCoord1iv; +PFNGLISENABLEDIPROC glad_glIsEnabledi; +PFNGLVERTEXATTRIBI2IPROC glad_glVertexAttribI2i; +PFNGLMULTITEXCOORD2DVPROC glad_glMultiTexCoord2dv; +PFNGLUNIFORM2IVPROC glad_glUniform2iv; +PFNGLVERTEXATTRIB1FVPROC glad_glVertexAttrib1fv; +PFNGLUNIFORM4UIVPROC glad_glUniform4uiv; +PFNGLMATRIXMODEPROC glad_glMatrixMode; +PFNGLFEEDBACKBUFFERPROC glad_glFeedbackBuffer; +PFNGLGETMAPIVPROC glad_glGetMapiv; +PFNGLFRAMEBUFFERTEXTURE1DPROC glad_glFramebufferTexture1D; +PFNGLGETSHADERIVPROC glad_glGetShaderiv; +PFNGLMULTITEXCOORD2DPROC glad_glMultiTexCoord2d; +PFNGLMULTITEXCOORD2FPROC glad_glMultiTexCoord2f; +PFNGLBINDFRAGDATALOCATIONPROC glad_glBindFragDataLocation; +PFNGLPRIORITIZETEXTURESPROC glad_glPrioritizeTextures; +PFNGLCALLLISTPROC glad_glCallList; +PFNGLSECONDARYCOLOR3UBVPROC glad_glSecondaryColor3ubv; +PFNGLGETDOUBLEVPROC glad_glGetDoublev; +PFNGLMULTITEXCOORD3IVPROC glad_glMultiTexCoord3iv; +PFNGLVERTEXATTRIB1DPROC glad_glVertexAttrib1d; +PFNGLLIGHTMODELFPROC glad_glLightModelf; +PFNGLGETUNIFORMIVPROC glad_glGetUniformiv; +PFNGLVERTEX2SVPROC glad_glVertex2sv; +PFNGLLIGHTMODELIPROC glad_glLightModeli; +PFNGLWINDOWPOS3IVPROC glad_glWindowPos3iv; +PFNGLUNIFORM3FVPROC glad_glUniform3fv; +PFNGLPIXELSTOREIPROC glad_glPixelStorei; +PFNGLCALLLISTSPROC glad_glCallLists; +PFNGLMAPBUFFERPROC glad_glMapBuffer; +PFNGLSECONDARYCOLOR3DPROC glad_glSecondaryColor3d; +PFNGLTEXCOORD3IPROC glad_glTexCoord3i; +PFNGLMULTITEXCOORD4FVPROC glad_glMultiTexCoord4fv; +PFNGLRASTERPOS3IPROC glad_glRasterPos3i; +PFNGLSECONDARYCOLOR3BPROC glad_glSecondaryColor3b; +PFNGLRASTERPOS3DPROC glad_glRasterPos3d; +PFNGLRASTERPOS3FPROC glad_glRasterPos3f; +PFNGLCOMPRESSEDTEXIMAGE3DPROC glad_glCompressedTexImage3D; +PFNGLTEXCOORD3FPROC glad_glTexCoord3f; +PFNGLDELETESYNCPROC glad_glDeleteSync; +PFNGLCOPYTEXSUBIMAGE3DPROC glad_glCopyTexSubImage3D; +PFNGLTEXIMAGE2DMULTISAMPLEPROC glad_glTexImage2DMultisample; +PFNGLGETVERTEXATTRIBIVPROC glad_glGetVertexAttribiv; +PFNGLMULTIDRAWELEMENTSPROC glad_glMultiDrawElements; +PFNGLVERTEXATTRIB3FVPROC glad_glVertexAttrib3fv; +PFNGLTEXCOORD3SPROC glad_glTexCoord3s; +PFNGLUNIFORM3IVPROC glad_glUniform3iv; +PFNGLRASTERPOS3SPROC glad_glRasterPos3s; +PFNGLPOLYGONMODEPROC glad_glPolygonMode; +PFNGLDRAWBUFFERSPROC glad_glDrawBuffers; +PFNGLGETACTIVEUNIFORMBLOCKIVPROC glad_glGetActiveUniformBlockiv; +PFNGLARETEXTURESRESIDENTPROC glad_glAreTexturesResident; +PFNGLISLISTPROC glad_glIsList; +PFNGLRASTERPOS2SVPROC glad_glRasterPos2sv; +PFNGLRASTERPOS4SVPROC glad_glRasterPos4sv; +PFNGLCOLOR4SPROC glad_glColor4s; +PFNGLUSEPROGRAMPROC glad_glUseProgram; +PFNGLLINESTIPPLEPROC glad_glLineStipple; +PFNGLMULTITEXCOORD1SVPROC glad_glMultiTexCoord1sv; +PFNGLGETPROGRAMINFOLOGPROC glad_glGetProgramInfoLog; +PFNGLGETBUFFERPARAMETERIVPROC glad_glGetBufferParameteriv; +PFNGLMULTITEXCOORD2IVPROC glad_glMultiTexCoord2iv; +PFNGLUNIFORMMATRIX2X4FVPROC glad_glUniformMatrix2x4fv; +PFNGLBINDVERTEXARRAYPROC glad_glBindVertexArray; +PFNGLCOLOR4BPROC glad_glColor4b; +PFNGLSECONDARYCOLOR3FPROC glad_glSecondaryColor3f; +PFNGLCOLOR4FPROC glad_glColor4f; +PFNGLCOLOR4DPROC glad_glColor4d; +PFNGLCOLOR4IPROC glad_glColor4i; +PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC glad_glMultiDrawElementsBaseVertex; +PFNGLRASTERPOS3IVPROC glad_glRasterPos3iv; +PFNGLVERTEX2DVPROC glad_glVertex2dv; +PFNGLTEXCOORD4SVPROC glad_glTexCoord4sv; +PFNGLUNIFORM2UIVPROC glad_glUniform2uiv; +PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC glad_glCompressedTexSubImage1D; +PFNGLFINISHPROC glad_glFinish; +PFNGLGETBOOLEANVPROC glad_glGetBooleanv; +PFNGLDELETESHADERPROC glad_glDeleteShader; +PFNGLDRAWELEMENTSPROC glad_glDrawElements; +PFNGLRASTERPOS2SPROC glad_glRasterPos2s; +PFNGLGETMAPDVPROC glad_glGetMapdv; +PFNGLVERTEXATTRIB4NSVPROC glad_glVertexAttrib4Nsv; +PFNGLMATERIALFVPROC glad_glMaterialfv; +PFNGLVIEWPORTPROC glad_glViewport; +PFNGLUNIFORM1UIVPROC glad_glUniform1uiv; +PFNGLTRANSFORMFEEDBACKVARYINGSPROC glad_glTransformFeedbackVaryings; +PFNGLINDEXDVPROC glad_glIndexdv; +PFNGLTEXCOORD3DPROC glad_glTexCoord3d; +PFNGLTEXCOORD3IVPROC glad_glTexCoord3iv; +PFNGLVERTEXATTRIBI3IPROC glad_glVertexAttribI3i; +PFNGLCLEARDEPTHPROC glad_glClearDepth; +PFNGLVERTEXATTRIBI4USVPROC glad_glVertexAttribI4usv; +PFNGLTEXPARAMETERFPROC glad_glTexParameterf; +PFNGLTEXPARAMETERIPROC glad_glTexParameteri; +PFNGLGETSHADERSOURCEPROC glad_glGetShaderSource; +PFNGLTEXBUFFERPROC glad_glTexBuffer; +PFNGLPOPNAMEPROC glad_glPopName; +PFNGLVALIDATEPROGRAMPROC glad_glValidateProgram; +PFNGLPIXELSTOREFPROC glad_glPixelStoref; +PFNGLUNIFORM3UIVPROC glad_glUniform3uiv; +PFNGLRASTERPOS4FVPROC glad_glRasterPos4fv; +PFNGLEVALCOORD1DVPROC glad_glEvalCoord1dv; +PFNGLRECTIPROC glad_glRecti; +PFNGLCOLOR4UBPROC glad_glColor4ub; +PFNGLMULTTRANSPOSEMATRIXFPROC glad_glMultTransposeMatrixf; +PFNGLRECTFPROC glad_glRectf; +PFNGLRECTDPROC glad_glRectd; +PFNGLNORMAL3SVPROC glad_glNormal3sv; +PFNGLNEWLISTPROC glad_glNewList; +PFNGLCOLOR4USPROC glad_glColor4us; +PFNGLLINKPROGRAMPROC glad_glLinkProgram; +PFNGLHINTPROC glad_glHint; +PFNGLRECTSPROC glad_glRects; +PFNGLTEXCOORD2DVPROC glad_glTexCoord2dv; +PFNGLRASTERPOS4IVPROC glad_glRasterPos4iv; +PFNGLGETSTRINGPROC glad_glGetString; +PFNGLEDGEFLAGVPROC glad_glEdgeFlagv; +PFNGLDETACHSHADERPROC glad_glDetachShader; +PFNGLSCALEFPROC glad_glScalef; +PFNGLENDQUERYPROC glad_glEndQuery; +PFNGLSCALEDPROC glad_glScaled; +PFNGLEDGEFLAGPOINTERPROC glad_glEdgeFlagPointer; +PFNGLCOPYPIXELSPROC glad_glCopyPixels; +PFNGLVERTEXATTRIBI2UIPROC glad_glVertexAttribI2ui; +PFNGLPOPATTRIBPROC glad_glPopAttrib; +PFNGLDELETETEXTURESPROC glad_glDeleteTextures; +PFNGLSTENCILOPSEPARATEPROC glad_glStencilOpSeparate; +PFNGLDELETEQUERIESPROC glad_glDeleteQueries; +PFNGLVERTEXATTRIB4FPROC glad_glVertexAttrib4f; +PFNGLVERTEXATTRIB4DPROC glad_glVertexAttrib4d; +PFNGLINITNAMESPROC glad_glInitNames; +PFNGLGETBUFFERPARAMETERI64VPROC glad_glGetBufferParameteri64v; +PFNGLCOLOR3DVPROC glad_glColor3dv; +PFNGLVERTEXATTRIBI1IPROC glad_glVertexAttribI1i; +PFNGLGETTEXPARAMETERIVPROC glad_glGetTexParameteriv; +PFNGLWAITSYNCPROC glad_glWaitSync; +PFNGLVERTEXATTRIB4SPROC glad_glVertexAttrib4s; +PFNGLCOLORMATERIALPROC glad_glColorMaterial; +PFNGLSAMPLECOVERAGEPROC glad_glSampleCoverage; +PFNGLUNIFORM1FPROC glad_glUniform1f; +PFNGLGETVERTEXATTRIBFVPROC glad_glGetVertexAttribfv; +PFNGLRENDERMODEPROC glad_glRenderMode; +PFNGLGETCOMPRESSEDTEXIMAGEPROC glad_glGetCompressedTexImage; +PFNGLWINDOWPOS2DVPROC glad_glWindowPos2dv; +PFNGLUNIFORM1IPROC glad_glUniform1i; +PFNGLGETACTIVEATTRIBPROC glad_glGetActiveAttrib; +PFNGLUNIFORM3IPROC glad_glUniform3i; +PFNGLPIXELTRANSFERIPROC glad_glPixelTransferi; +PFNGLTEXSUBIMAGE2DPROC glad_glTexSubImage2D; +PFNGLDISABLEPROC glad_glDisable; +PFNGLLOGICOPPROC glad_glLogicOp; +PFNGLEVALPOINT2PROC glad_glEvalPoint2; +PFNGLPIXELTRANSFERFPROC glad_glPixelTransferf; +PFNGLSECONDARYCOLOR3IPROC glad_glSecondaryColor3i; +PFNGLUNIFORM4UIPROC glad_glUniform4ui; +PFNGLCOLOR3FPROC glad_glColor3f; +PFNGLBINDFRAMEBUFFERPROC glad_glBindFramebuffer; +PFNGLGETTEXENVFVPROC glad_glGetTexEnvfv; +PFNGLRECTFVPROC glad_glRectfv; +PFNGLCULLFACEPROC glad_glCullFace; +PFNGLGETLIGHTFVPROC glad_glGetLightfv; +PFNGLCOLOR3DPROC glad_glColor3d; +PFNGLTEXGENDPROC glad_glTexGend; +PFNGLTEXGENIPROC glad_glTexGeni; +PFNGLMULTITEXCOORD3SPROC glad_glMultiTexCoord3s; +PFNGLGETSTRINGIPROC glad_glGetStringi; +PFNGLMULTITEXCOORD3IPROC glad_glMultiTexCoord3i; +PFNGLMULTITEXCOORD3FPROC glad_glMultiTexCoord3f; +PFNGLMULTITEXCOORD3DPROC glad_glMultiTexCoord3d; +PFNGLATTACHSHADERPROC glad_glAttachShader; +PFNGLFOGCOORDDVPROC glad_glFogCoorddv; +PFNGLUNIFORMMATRIX2X3FVPROC glad_glUniformMatrix2x3fv; +PFNGLGETTEXGENFVPROC glad_glGetTexGenfv; +PFNGLFOGCOORDPOINTERPROC glad_glFogCoordPointer; +PFNGLPROVOKINGVERTEXPROC glad_glProvokingVertex; +PFNGLFRAMEBUFFERTEXTURE3DPROC glad_glFramebufferTexture3D; +PFNGLTEXGENIVPROC glad_glTexGeniv; +PFNGLRASTERPOS2DVPROC glad_glRasterPos2dv; +PFNGLSECONDARYCOLOR3DVPROC glad_glSecondaryColor3dv; +PFNGLCLIENTACTIVETEXTUREPROC glad_glClientActiveTexture; +PFNGLVERTEXATTRIBI4SVPROC glad_glVertexAttribI4sv; +PFNGLSECONDARYCOLOR3USPROC glad_glSecondaryColor3us; +PFNGLTEXENVFVPROC glad_glTexEnvfv; +PFNGLREADBUFFERPROC glad_glReadBuffer; +PFNGLTEXPARAMETERIUIVPROC glad_glTexParameterIuiv; +PFNGLDRAWARRAYSINSTANCEDPROC glad_glDrawArraysInstanced; +PFNGLGENERATEMIPMAPPROC glad_glGenerateMipmap; +PFNGLWINDOWPOS3FVPROC glad_glWindowPos3fv; +PFNGLLIGHTMODELFVPROC glad_glLightModelfv; +PFNGLDELETELISTSPROC glad_glDeleteLists; +PFNGLGETCLIPPLANEPROC glad_glGetClipPlane; +PFNGLVERTEX4DVPROC glad_glVertex4dv; +PFNGLTEXCOORD2DPROC glad_glTexCoord2d; +PFNGLPOPMATRIXPROC glad_glPopMatrix; +PFNGLTEXCOORD2FPROC glad_glTexCoord2f; +PFNGLCOLOR4IVPROC glad_glColor4iv; +PFNGLINDEXUBVPROC glad_glIndexubv; +PFNGLUNMAPBUFFERPROC glad_glUnmapBuffer; +PFNGLTEXCOORD2IPROC glad_glTexCoord2i; +PFNGLRASTERPOS4DPROC glad_glRasterPos4d; +PFNGLRASTERPOS4FPROC glad_glRasterPos4f; +PFNGLVERTEXATTRIB3SPROC glad_glVertexAttrib3s; +PFNGLTEXCOORD2SPROC glad_glTexCoord2s; +PFNGLBINDRENDERBUFFERPROC glad_glBindRenderbuffer; +PFNGLVERTEX3FVPROC glad_glVertex3fv; +PFNGLTEXCOORD4DVPROC glad_glTexCoord4dv; +PFNGLMATERIALIVPROC glad_glMaterialiv; +PFNGLISPROGRAMPROC glad_glIsProgram; +PFNGLVERTEXATTRIB4BVPROC glad_glVertexAttrib4bv; +PFNGLVERTEX4SPROC glad_glVertex4s; +PFNGLVERTEXATTRIB4FVPROC glad_glVertexAttrib4fv; +PFNGLNORMAL3DVPROC glad_glNormal3dv; +PFNGLUNIFORM4IPROC glad_glUniform4i; +PFNGLACTIVETEXTUREPROC glad_glActiveTexture; +PFNGLENABLEVERTEXATTRIBARRAYPROC glad_glEnableVertexAttribArray; +PFNGLROTATEDPROC glad_glRotated; +PFNGLROTATEFPROC glad_glRotatef; +PFNGLVERTEX4IPROC glad_glVertex4i; +PFNGLREADPIXELSPROC glad_glReadPixels; +PFNGLVERTEXATTRIBI3IVPROC glad_glVertexAttribI3iv; +PFNGLLOADNAMEPROC glad_glLoadName; +PFNGLUNIFORM4FPROC glad_glUniform4f; +PFNGLRENDERBUFFERSTORAGEMULTISAMPLEPROC glad_glRenderbufferStorageMultisample; +PFNGLGENVERTEXARRAYSPROC glad_glGenVertexArrays; +PFNGLSHADEMODELPROC glad_glShadeModel; +PFNGLMAPGRID1DPROC glad_glMapGrid1d; +PFNGLGETUNIFORMFVPROC glad_glGetUniformfv; +PFNGLMAPGRID1FPROC glad_glMapGrid1f; +PFNGLDISABLECLIENTSTATEPROC glad_glDisableClientState; +PFNGLMULTITEXCOORD3SVPROC glad_glMultiTexCoord3sv; +PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC glad_glDrawElementsInstancedBaseVertex; +PFNGLSECONDARYCOLORPOINTERPROC glad_glSecondaryColorPointer; +PFNGLALPHAFUNCPROC glad_glAlphaFunc; +PFNGLUNIFORM1IVPROC glad_glUniform1iv; +PFNGLMULTITEXCOORD4IVPROC glad_glMultiTexCoord4iv; +PFNGLGETQUERYOBJECTIVPROC glad_glGetQueryObjectiv; +PFNGLSTENCILFUNCPROC glad_glStencilFunc; +PFNGLMULTITEXCOORD1FVPROC glad_glMultiTexCoord1fv; +PFNGLUNIFORMBLOCKBINDINGPROC glad_glUniformBlockBinding; +PFNGLCOLOR4UIVPROC glad_glColor4uiv; +PFNGLRECTIVPROC glad_glRectiv; +PFNGLRASTERPOS3DVPROC glad_glRasterPos3dv; +PFNGLEVALMESH2PROC glad_glEvalMesh2; +PFNGLEVALMESH1PROC glad_glEvalMesh1; +PFNGLTEXCOORDPOINTERPROC glad_glTexCoordPointer; +PFNGLVERTEXATTRIB4NUBVPROC glad_glVertexAttrib4Nubv; +PFNGLVERTEXATTRIBI4IVPROC glad_glVertexAttribI4iv; +PFNGLEVALCOORD2FVPROC glad_glEvalCoord2fv; +PFNGLCOLOR4UBVPROC glad_glColor4ubv; +PFNGLLOADTRANSPOSEMATRIXDPROC glad_glLoadTransposeMatrixd; +PFNGLLOADTRANSPOSEMATRIXFPROC glad_glLoadTransposeMatrixf; +PFNGLVERTEXATTRIBI4IPROC glad_glVertexAttribI4i; +PFNGLRASTERPOS2IVPROC glad_glRasterPos2iv; +PFNGLGETBUFFERSUBDATAPROC glad_glGetBufferSubData; +PFNGLTEXENVIVPROC glad_glTexEnviv; +PFNGLBLENDEQUATIONSEPARATEPROC glad_glBlendEquationSeparate; +PFNGLVERTEXATTRIBI1UIPROC glad_glVertexAttribI1ui; +PFNGLGENBUFFERSPROC glad_glGenBuffers; +PFNGLSELECTBUFFERPROC glad_glSelectBuffer; +PFNGLVERTEXATTRIB2SVPROC glad_glVertexAttrib2sv; +PFNGLPUSHATTRIBPROC glad_glPushAttrib; +PFNGLVERTEXATTRIBIPOINTERPROC glad_glVertexAttribIPointer; +PFNGLBLENDFUNCPROC glad_glBlendFunc; +PFNGLCREATEPROGRAMPROC glad_glCreateProgram; +PFNGLTEXIMAGE3DPROC glad_glTexImage3D; +PFNGLISFRAMEBUFFERPROC glad_glIsFramebuffer; +PFNGLLIGHTIVPROC glad_glLightiv; +PFNGLPRIMITIVERESTARTINDEXPROC glad_glPrimitiveRestartIndex; +PFNGLTEXGENFVPROC glad_glTexGenfv; +PFNGLENDPROC glad_glEnd; +PFNGLDELETEBUFFERSPROC glad_glDeleteBuffers; +PFNGLSCISSORPROC glad_glScissor; +PFNGLCLIPPLANEPROC glad_glClipPlane; +PFNGLPUSHNAMEPROC glad_glPushName; +PFNGLTEXGENDVPROC glad_glTexGendv; +PFNGLINDEXUBPROC glad_glIndexub; +PFNGLSECONDARYCOLOR3IVPROC glad_glSecondaryColor3iv; +PFNGLRASTERPOS4IPROC glad_glRasterPos4i; +PFNGLMULTTRANSPOSEMATRIXDPROC glad_glMultTransposeMatrixd; +PFNGLCLEARCOLORPROC glad_glClearColor; +PFNGLVERTEXATTRIB4UIVPROC glad_glVertexAttrib4uiv; +PFNGLNORMAL3SPROC glad_glNormal3s; +PFNGLVERTEXATTRIB4NIVPROC glad_glVertexAttrib4Niv; +PFNGLCLEARBUFFERIVPROC glad_glClearBufferiv; +PFNGLPOINTPARAMETERIPROC glad_glPointParameteri; +PFNGLBLENDCOLORPROC glad_glBlendColor; +PFNGLWINDOWPOS3DPROC glad_glWindowPos3d; +PFNGLVERTEXATTRIBI2UIVPROC glad_glVertexAttribI2uiv; +PFNGLUNIFORM3UIPROC glad_glUniform3ui; +PFNGLCOLOR4DVPROC glad_glColor4dv; +PFNGLVERTEXATTRIBI4UIVPROC glad_glVertexAttribI4uiv; +PFNGLPOINTPARAMETERFVPROC glad_glPointParameterfv; +PFNGLUNIFORM2FVPROC glad_glUniform2fv; +PFNGLSECONDARYCOLOR3UBPROC glad_glSecondaryColor3ub; +PFNGLSECONDARYCOLOR3UIPROC glad_glSecondaryColor3ui; +PFNGLTEXCOORD3DVPROC glad_glTexCoord3dv; +PFNGLBINDBUFFERRANGEPROC glad_glBindBufferRange; +PFNGLNORMAL3IVPROC glad_glNormal3iv; +PFNGLWINDOWPOS3SPROC glad_glWindowPos3s; +PFNGLPOINTPARAMETERFPROC glad_glPointParameterf; +PFNGLGETVERTEXATTRIBIUIVPROC glad_glGetVertexAttribIuiv; +PFNGLWINDOWPOS3IPROC glad_glWindowPos3i; +PFNGLMULTITEXCOORD4SPROC glad_glMultiTexCoord4s; +PFNGLWINDOWPOS3FPROC glad_glWindowPos3f; +PFNGLCOLOR3USPROC glad_glColor3us; +PFNGLCOLOR3UIVPROC glad_glColor3uiv; +PFNGLVERTEXATTRIB4NUSVPROC glad_glVertexAttrib4Nusv; +PFNGLGETLIGHTIVPROC glad_glGetLightiv; +PFNGLDEPTHFUNCPROC glad_glDepthFunc; +PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC glad_glCompressedTexSubImage2D; +PFNGLLISTBASEPROC glad_glListBase; +PFNGLMULTITEXCOORD4FPROC glad_glMultiTexCoord4f; +PFNGLCOLOR3UBPROC glad_glColor3ub; +PFNGLMULTITEXCOORD4DPROC glad_glMultiTexCoord4d; +PFNGLVERTEXATTRIBI4BVPROC glad_glVertexAttribI4bv; +PFNGLGETTEXPARAMETERFVPROC glad_glGetTexParameterfv; +PFNGLCOLOR3UIPROC glad_glColor3ui; +PFNGLMULTITEXCOORD4IPROC glad_glMultiTexCoord4i; +PFNGLGETPOLYGONSTIPPLEPROC glad_glGetPolygonStipple; +PFNGLCLIENTWAITSYNCPROC glad_glClientWaitSync; +PFNGLVERTEXATTRIBI4UIPROC glad_glVertexAttribI4ui; +PFNGLMULTITEXCOORD4DVPROC glad_glMultiTexCoord4dv; +PFNGLCOLORMASKPROC glad_glColorMask; +PFNGLTEXPARAMETERIIVPROC glad_glTexParameterIiv; +PFNGLBLENDEQUATIONPROC glad_glBlendEquation; +PFNGLGETUNIFORMLOCATIONPROC glad_glGetUniformLocation; +PFNGLRASTERPOS4SPROC glad_glRasterPos4s; +PFNGLENDTRANSFORMFEEDBACKPROC glad_glEndTransformFeedback; +PFNGLVERTEXATTRIB4USVPROC glad_glVertexAttrib4usv; +PFNGLMULTITEXCOORD3DVPROC glad_glMultiTexCoord3dv; +PFNGLCOLOR4SVPROC glad_glColor4sv; +PFNGLPOPCLIENTATTRIBPROC glad_glPopClientAttrib; +PFNGLBEGINTRANSFORMFEEDBACKPROC glad_glBeginTransformFeedback; +PFNGLFOGFPROC glad_glFogf; +PFNGLVERTEXATTRIBI1IVPROC glad_glVertexAttribI1iv; +PFNGLCOLOR3IVPROC glad_glColor3iv; +PFNGLCOMPRESSEDTEXIMAGE1DPROC glad_glCompressedTexImage1D; +PFNGLCOPYTEXSUBIMAGE1DPROC glad_glCopyTexSubImage1D; +PFNGLTEXCOORD1IPROC glad_glTexCoord1i; +PFNGLCHECKFRAMEBUFFERSTATUSPROC glad_glCheckFramebufferStatus; +PFNGLTEXCOORD1DPROC glad_glTexCoord1d; +PFNGLTEXCOORD1FPROC glad_glTexCoord1f; +PFNGLENDCONDITIONALRENDERPROC glad_glEndConditionalRender; +PFNGLENABLECLIENTSTATEPROC glad_glEnableClientState; +PFNGLBINDATTRIBLOCATIONPROC glad_glBindAttribLocation; +PFNGLUNIFORMMATRIX4X2FVPROC glad_glUniformMatrix4x2fv; +PFNGLMULTITEXCOORD2SVPROC glad_glMultiTexCoord2sv; +PFNGLVERTEXATTRIB1DVPROC glad_glVertexAttrib1dv; +PFNGLDRAWRANGEELEMENTSPROC glad_glDrawRangeElements; +PFNGLTEXCOORD1SPROC glad_glTexCoord1s; +PFNGLBINDBUFFERBASEPROC glad_glBindBufferBase; +PFNGLBUFFERSUBDATAPROC glad_glBufferSubData; +PFNGLVERTEXATTRIB4IVPROC glad_glVertexAttrib4iv; +PFNGLGENLISTSPROC glad_glGenLists; +PFNGLCOLOR3BVPROC glad_glColor3bv; +PFNGLMAPBUFFERRANGEPROC glad_glMapBufferRange; +PFNGLFRAMEBUFFERTEXTUREPROC glad_glFramebufferTexture; +PFNGLGETTEXGENDVPROC glad_glGetTexGendv; +PFNGLMULTIDRAWARRAYSPROC glad_glMultiDrawArrays; +PFNGLENDLISTPROC glad_glEndList; +PFNGLUNIFORM2UIPROC glad_glUniform2ui; +PFNGLVERTEXATTRIBI2IVPROC glad_glVertexAttribI2iv; +PFNGLCOLOR3USVPROC glad_glColor3usv; +PFNGLWINDOWPOS2FVPROC glad_glWindowPos2fv; +PFNGLDISABLEIPROC glad_glDisablei; +PFNGLINDEXMASKPROC glad_glIndexMask; +PFNGLPUSHCLIENTATTRIBPROC glad_glPushClientAttrib; +PFNGLSHADERSOURCEPROC glad_glShaderSource; +PFNGLGETACTIVEUNIFORMBLOCKNAMEPROC glad_glGetActiveUniformBlockName; +PFNGLVERTEXATTRIBI3UIVPROC glad_glVertexAttribI3uiv; +PFNGLCLEARACCUMPROC glad_glClearAccum; +PFNGLGETSYNCIVPROC glad_glGetSynciv; +PFNGLUNIFORM2FPROC glad_glUniform2f; +PFNGLBEGINQUERYPROC glad_glBeginQuery; +PFNGLGETUNIFORMBLOCKINDEXPROC glad_glGetUniformBlockIndex; +PFNGLBINDBUFFERPROC glad_glBindBuffer; +PFNGLMAP2DPROC glad_glMap2d; +PFNGLMAP2FPROC glad_glMap2f; +PFNGLVERTEX4DPROC glad_glVertex4d; +PFNGLUNIFORMMATRIX2FVPROC glad_glUniformMatrix2fv; +PFNGLTEXCOORD1SVPROC glad_glTexCoord1sv; +PFNGLBUFFERDATAPROC glad_glBufferData; +PFNGLEVALPOINT1PROC glad_glEvalPoint1; +PFNGLGETTEXPARAMETERIIVPROC glad_glGetTexParameterIiv; +PFNGLTEXCOORD1DVPROC glad_glTexCoord1dv; +PFNGLGETERRORPROC glad_glGetError; +PFNGLGETTEXENVIVPROC glad_glGetTexEnviv; +PFNGLGETPROGRAMIVPROC glad_glGetProgramiv; +PFNGLGETFLOATVPROC glad_glGetFloatv; +PFNGLTEXSUBIMAGE1DPROC glad_glTexSubImage1D; +PFNGLMULTITEXCOORD2FVPROC glad_glMultiTexCoord2fv; +PFNGLVERTEXATTRIB2FVPROC glad_glVertexAttrib2fv; +PFNGLEVALCOORD1DPROC glad_glEvalCoord1d; +PFNGLGETTEXLEVELPARAMETERFVPROC glad_glGetTexLevelParameterfv; +PFNGLEVALCOORD1FPROC glad_glEvalCoord1f; +PFNGLPIXELMAPFVPROC glad_glPixelMapfv; +PFNGLGETPIXELMAPUSVPROC glad_glGetPixelMapusv; +PFNGLGETINTEGERVPROC glad_glGetIntegerv; +PFNGLACCUMPROC glad_glAccum; +PFNGLGETBUFFERPOINTERVPROC glad_glGetBufferPointerv; +PFNGLGETVERTEXATTRIBIIVPROC glad_glGetVertexAttribIiv; +PFNGLRASTERPOS4DVPROC glad_glRasterPos4dv; +PFNGLTEXCOORD2IVPROC glad_glTexCoord2iv; +PFNGLISQUERYPROC glad_glIsQuery; +PFNGLVERTEXATTRIB4SVPROC glad_glVertexAttrib4sv; +PFNGLWINDOWPOS3DVPROC glad_glWindowPos3dv; +PFNGLTEXIMAGE2DPROC glad_glTexImage2D; +PFNGLSTENCILMASKPROC glad_glStencilMask; +PFNGLDRAWPIXELSPROC glad_glDrawPixels; +PFNGLMULTMATRIXDPROC glad_glMultMatrixd; +PFNGLMULTMATRIXFPROC glad_glMultMatrixf; +PFNGLISTEXTUREPROC glad_glIsTexture; +PFNGLGETMATERIALIVPROC glad_glGetMaterialiv; +PFNGLUNIFORM1FVPROC glad_glUniform1fv; +PFNGLLOADMATRIXFPROC glad_glLoadMatrixf; +PFNGLLOADMATRIXDPROC glad_glLoadMatrixd; +PFNGLTEXPARAMETERFVPROC glad_glTexParameterfv; +PFNGLUNIFORMMATRIX3FVPROC glad_glUniformMatrix3fv; +PFNGLVERTEX4FPROC glad_glVertex4f; +PFNGLRECTSVPROC glad_glRectsv; +PFNGLCOLOR4USVPROC glad_glColor4usv; +PFNGLPOLYGONSTIPPLEPROC glad_glPolygonStipple; +PFNGLINTERLEAVEDARRAYSPROC glad_glInterleavedArrays; +PFNGLNORMAL3IPROC glad_glNormal3i; +PFNGLNORMAL3FPROC glad_glNormal3f; +PFNGLNORMAL3DPROC glad_glNormal3d; +PFNGLNORMAL3BPROC glad_glNormal3b; +PFNGLPIXELMAPUSVPROC glad_glPixelMapusv; +PFNGLGETTEXGENIVPROC glad_glGetTexGeniv; +PFNGLARRAYELEMENTPROC glad_glArrayElement; +PFNGLCOPYBUFFERSUBDATAPROC glad_glCopyBufferSubData; +PFNGLVERTEXATTRIBI1UIVPROC glad_glVertexAttribI1uiv; +PFNGLVERTEXATTRIB2DPROC glad_glVertexAttrib2d; +PFNGLVERTEXATTRIB2FPROC glad_glVertexAttrib2f; +PFNGLVERTEXATTRIB3DVPROC glad_glVertexAttrib3dv; +PFNGLDEPTHMASKPROC glad_glDepthMask; +PFNGLVERTEXATTRIB2SPROC glad_glVertexAttrib2s; +PFNGLCOLOR3FVPROC glad_glColor3fv; +PFNGLTEXIMAGE3DMULTISAMPLEPROC glad_glTexImage3DMultisample; +PFNGLUNIFORMMATRIX4FVPROC glad_glUniformMatrix4fv; +PFNGLUNIFORM4FVPROC glad_glUniform4fv; +PFNGLGETACTIVEUNIFORMPROC glad_glGetActiveUniform; +PFNGLCOLORPOINTERPROC glad_glColorPointer; +PFNGLFRONTFACEPROC glad_glFrontFace; +PFNGLGETBOOLEANI_VPROC glad_glGetBooleani_v; +PFNGLCLEARBUFFERUIVPROC glad_glClearBufferuiv; +int GLAD_GL_KHR_debug; +int GLAD_GL_ARB_robustness; +int GLAD_GL_ARB_multisample; +PFNGLSAMPLECOVERAGEARBPROC glad_glSampleCoverageARB; +PFNGLGETGRAPHICSRESETSTATUSARBPROC glad_glGetGraphicsResetStatusARB; +PFNGLGETNTEXIMAGEARBPROC glad_glGetnTexImageARB; +PFNGLREADNPIXELSARBPROC glad_glReadnPixelsARB; +PFNGLGETNCOMPRESSEDTEXIMAGEARBPROC glad_glGetnCompressedTexImageARB; +PFNGLGETNUNIFORMFVARBPROC glad_glGetnUniformfvARB; +PFNGLGETNUNIFORMIVARBPROC glad_glGetnUniformivARB; +PFNGLGETNUNIFORMUIVARBPROC glad_glGetnUniformuivARB; +PFNGLGETNUNIFORMDVARBPROC glad_glGetnUniformdvARB; +PFNGLGETNMAPDVARBPROC glad_glGetnMapdvARB; +PFNGLGETNMAPFVARBPROC glad_glGetnMapfvARB; +PFNGLGETNMAPIVARBPROC glad_glGetnMapivARB; +PFNGLGETNPIXELMAPFVARBPROC glad_glGetnPixelMapfvARB; +PFNGLGETNPIXELMAPUIVARBPROC glad_glGetnPixelMapuivARB; +PFNGLGETNPIXELMAPUSVARBPROC glad_glGetnPixelMapusvARB; +PFNGLGETNPOLYGONSTIPPLEARBPROC glad_glGetnPolygonStippleARB; +PFNGLGETNCOLORTABLEARBPROC glad_glGetnColorTableARB; +PFNGLGETNCONVOLUTIONFILTERARBPROC glad_glGetnConvolutionFilterARB; +PFNGLGETNSEPARABLEFILTERARBPROC glad_glGetnSeparableFilterARB; +PFNGLGETNHISTOGRAMARBPROC glad_glGetnHistogramARB; +PFNGLGETNMINMAXARBPROC glad_glGetnMinmaxARB; +PFNGLDEBUGMESSAGECONTROLPROC glad_glDebugMessageControl; +PFNGLDEBUGMESSAGEINSERTPROC glad_glDebugMessageInsert; +PFNGLDEBUGMESSAGECALLBACKPROC glad_glDebugMessageCallback; +PFNGLGETDEBUGMESSAGELOGPROC glad_glGetDebugMessageLog; +PFNGLPUSHDEBUGGROUPPROC glad_glPushDebugGroup; +PFNGLPOPDEBUGGROUPPROC glad_glPopDebugGroup; +PFNGLOBJECTLABELPROC glad_glObjectLabel; +PFNGLGETOBJECTLABELPROC glad_glGetObjectLabel; +PFNGLOBJECTPTRLABELPROC glad_glObjectPtrLabel; +PFNGLGETOBJECTPTRLABELPROC glad_glGetObjectPtrLabel; +PFNGLDEBUGMESSAGECONTROLKHRPROC glad_glDebugMessageControlKHR; +PFNGLDEBUGMESSAGEINSERTKHRPROC glad_glDebugMessageInsertKHR; +PFNGLDEBUGMESSAGECALLBACKKHRPROC glad_glDebugMessageCallbackKHR; +PFNGLGETDEBUGMESSAGELOGKHRPROC glad_glGetDebugMessageLogKHR; +PFNGLPUSHDEBUGGROUPKHRPROC glad_glPushDebugGroupKHR; +PFNGLPOPDEBUGGROUPKHRPROC glad_glPopDebugGroupKHR; +PFNGLOBJECTLABELKHRPROC glad_glObjectLabelKHR; +PFNGLGETOBJECTLABELKHRPROC glad_glGetObjectLabelKHR; +PFNGLOBJECTPTRLABELKHRPROC glad_glObjectPtrLabelKHR; +PFNGLGETOBJECTPTRLABELKHRPROC glad_glGetObjectPtrLabelKHR; +PFNGLGETPOINTERVKHRPROC glad_glGetPointervKHR; +static void load_GL_VERSION_1_0(GLADloadproc load) { + if(!GLAD_GL_VERSION_1_0) return; + glad_glCullFace = (PFNGLCULLFACEPROC)load("glCullFace"); + glad_glFrontFace = (PFNGLFRONTFACEPROC)load("glFrontFace"); + glad_glHint = (PFNGLHINTPROC)load("glHint"); + glad_glLineWidth = (PFNGLLINEWIDTHPROC)load("glLineWidth"); + glad_glPointSize = (PFNGLPOINTSIZEPROC)load("glPointSize"); + glad_glPolygonMode = (PFNGLPOLYGONMODEPROC)load("glPolygonMode"); + glad_glScissor = (PFNGLSCISSORPROC)load("glScissor"); + glad_glTexParameterf = (PFNGLTEXPARAMETERFPROC)load("glTexParameterf"); + glad_glTexParameterfv = (PFNGLTEXPARAMETERFVPROC)load("glTexParameterfv"); + glad_glTexParameteri = (PFNGLTEXPARAMETERIPROC)load("glTexParameteri"); + glad_glTexParameteriv = (PFNGLTEXPARAMETERIVPROC)load("glTexParameteriv"); + glad_glTexImage1D = (PFNGLTEXIMAGE1DPROC)load("glTexImage1D"); + glad_glTexImage2D = (PFNGLTEXIMAGE2DPROC)load("glTexImage2D"); + glad_glDrawBuffer = (PFNGLDRAWBUFFERPROC)load("glDrawBuffer"); + glad_glClear = (PFNGLCLEARPROC)load("glClear"); + glad_glClearColor = (PFNGLCLEARCOLORPROC)load("glClearColor"); + glad_glClearStencil = (PFNGLCLEARSTENCILPROC)load("glClearStencil"); + glad_glClearDepth = (PFNGLCLEARDEPTHPROC)load("glClearDepth"); + glad_glStencilMask = (PFNGLSTENCILMASKPROC)load("glStencilMask"); + glad_glColorMask = (PFNGLCOLORMASKPROC)load("glColorMask"); + glad_glDepthMask = (PFNGLDEPTHMASKPROC)load("glDepthMask"); + glad_glDisable = (PFNGLDISABLEPROC)load("glDisable"); + glad_glEnable = (PFNGLENABLEPROC)load("glEnable"); + glad_glFinish = (PFNGLFINISHPROC)load("glFinish"); + glad_glFlush = (PFNGLFLUSHPROC)load("glFlush"); + glad_glBlendFunc = (PFNGLBLENDFUNCPROC)load("glBlendFunc"); + glad_glLogicOp = (PFNGLLOGICOPPROC)load("glLogicOp"); + glad_glStencilFunc = (PFNGLSTENCILFUNCPROC)load("glStencilFunc"); + glad_glStencilOp = (PFNGLSTENCILOPPROC)load("glStencilOp"); + glad_glDepthFunc = (PFNGLDEPTHFUNCPROC)load("glDepthFunc"); + glad_glPixelStoref = (PFNGLPIXELSTOREFPROC)load("glPixelStoref"); + glad_glPixelStorei = (PFNGLPIXELSTOREIPROC)load("glPixelStorei"); + glad_glReadBuffer = (PFNGLREADBUFFERPROC)load("glReadBuffer"); + glad_glReadPixels = (PFNGLREADPIXELSPROC)load("glReadPixels"); + glad_glGetBooleanv = (PFNGLGETBOOLEANVPROC)load("glGetBooleanv"); + glad_glGetDoublev = (PFNGLGETDOUBLEVPROC)load("glGetDoublev"); + glad_glGetError = (PFNGLGETERRORPROC)load("glGetError"); + glad_glGetFloatv = (PFNGLGETFLOATVPROC)load("glGetFloatv"); + glad_glGetIntegerv = (PFNGLGETINTEGERVPROC)load("glGetIntegerv"); + glad_glGetString = (PFNGLGETSTRINGPROC)load("glGetString"); + glad_glGetTexImage = (PFNGLGETTEXIMAGEPROC)load("glGetTexImage"); + glad_glGetTexParameterfv = (PFNGLGETTEXPARAMETERFVPROC)load("glGetTexParameterfv"); + glad_glGetTexParameteriv = (PFNGLGETTEXPARAMETERIVPROC)load("glGetTexParameteriv"); + glad_glGetTexLevelParameterfv = (PFNGLGETTEXLEVELPARAMETERFVPROC)load("glGetTexLevelParameterfv"); + glad_glGetTexLevelParameteriv = (PFNGLGETTEXLEVELPARAMETERIVPROC)load("glGetTexLevelParameteriv"); + glad_glIsEnabled = (PFNGLISENABLEDPROC)load("glIsEnabled"); + glad_glDepthRange = (PFNGLDEPTHRANGEPROC)load("glDepthRange"); + glad_glViewport = (PFNGLVIEWPORTPROC)load("glViewport"); + glad_glNewList = (PFNGLNEWLISTPROC)load("glNewList"); + glad_glEndList = (PFNGLENDLISTPROC)load("glEndList"); + glad_glCallList = (PFNGLCALLLISTPROC)load("glCallList"); + glad_glCallLists = (PFNGLCALLLISTSPROC)load("glCallLists"); + glad_glDeleteLists = (PFNGLDELETELISTSPROC)load("glDeleteLists"); + glad_glGenLists = (PFNGLGENLISTSPROC)load("glGenLists"); + glad_glListBase = (PFNGLLISTBASEPROC)load("glListBase"); + glad_glBegin = (PFNGLBEGINPROC)load("glBegin"); + glad_glBitmap = (PFNGLBITMAPPROC)load("glBitmap"); + glad_glColor3b = (PFNGLCOLOR3BPROC)load("glColor3b"); + glad_glColor3bv = (PFNGLCOLOR3BVPROC)load("glColor3bv"); + glad_glColor3d = (PFNGLCOLOR3DPROC)load("glColor3d"); + glad_glColor3dv = (PFNGLCOLOR3DVPROC)load("glColor3dv"); + glad_glColor3f = (PFNGLCOLOR3FPROC)load("glColor3f"); + glad_glColor3fv = (PFNGLCOLOR3FVPROC)load("glColor3fv"); + glad_glColor3i = (PFNGLCOLOR3IPROC)load("glColor3i"); + glad_glColor3iv = (PFNGLCOLOR3IVPROC)load("glColor3iv"); + glad_glColor3s = (PFNGLCOLOR3SPROC)load("glColor3s"); + glad_glColor3sv = (PFNGLCOLOR3SVPROC)load("glColor3sv"); + glad_glColor3ub = (PFNGLCOLOR3UBPROC)load("glColor3ub"); + glad_glColor3ubv = (PFNGLCOLOR3UBVPROC)load("glColor3ubv"); + glad_glColor3ui = (PFNGLCOLOR3UIPROC)load("glColor3ui"); + glad_glColor3uiv = (PFNGLCOLOR3UIVPROC)load("glColor3uiv"); + glad_glColor3us = (PFNGLCOLOR3USPROC)load("glColor3us"); + glad_glColor3usv = (PFNGLCOLOR3USVPROC)load("glColor3usv"); + glad_glColor4b = (PFNGLCOLOR4BPROC)load("glColor4b"); + glad_glColor4bv = (PFNGLCOLOR4BVPROC)load("glColor4bv"); + glad_glColor4d = (PFNGLCOLOR4DPROC)load("glColor4d"); + glad_glColor4dv = (PFNGLCOLOR4DVPROC)load("glColor4dv"); + glad_glColor4f = (PFNGLCOLOR4FPROC)load("glColor4f"); + glad_glColor4fv = (PFNGLCOLOR4FVPROC)load("glColor4fv"); + glad_glColor4i = (PFNGLCOLOR4IPROC)load("glColor4i"); + glad_glColor4iv = (PFNGLCOLOR4IVPROC)load("glColor4iv"); + glad_glColor4s = (PFNGLCOLOR4SPROC)load("glColor4s"); + glad_glColor4sv = (PFNGLCOLOR4SVPROC)load("glColor4sv"); + glad_glColor4ub = (PFNGLCOLOR4UBPROC)load("glColor4ub"); + glad_glColor4ubv = (PFNGLCOLOR4UBVPROC)load("glColor4ubv"); + glad_glColor4ui = (PFNGLCOLOR4UIPROC)load("glColor4ui"); + glad_glColor4uiv = (PFNGLCOLOR4UIVPROC)load("glColor4uiv"); + glad_glColor4us = (PFNGLCOLOR4USPROC)load("glColor4us"); + glad_glColor4usv = (PFNGLCOLOR4USVPROC)load("glColor4usv"); + glad_glEdgeFlag = (PFNGLEDGEFLAGPROC)load("glEdgeFlag"); + glad_glEdgeFlagv = (PFNGLEDGEFLAGVPROC)load("glEdgeFlagv"); + glad_glEnd = (PFNGLENDPROC)load("glEnd"); + glad_glIndexd = (PFNGLINDEXDPROC)load("glIndexd"); + glad_glIndexdv = (PFNGLINDEXDVPROC)load("glIndexdv"); + glad_glIndexf = (PFNGLINDEXFPROC)load("glIndexf"); + glad_glIndexfv = (PFNGLINDEXFVPROC)load("glIndexfv"); + glad_glIndexi = (PFNGLINDEXIPROC)load("glIndexi"); + glad_glIndexiv = (PFNGLINDEXIVPROC)load("glIndexiv"); + glad_glIndexs = (PFNGLINDEXSPROC)load("glIndexs"); + glad_glIndexsv = (PFNGLINDEXSVPROC)load("glIndexsv"); + glad_glNormal3b = (PFNGLNORMAL3BPROC)load("glNormal3b"); + glad_glNormal3bv = (PFNGLNORMAL3BVPROC)load("glNormal3bv"); + glad_glNormal3d = (PFNGLNORMAL3DPROC)load("glNormal3d"); + glad_glNormal3dv = (PFNGLNORMAL3DVPROC)load("glNormal3dv"); + glad_glNormal3f = (PFNGLNORMAL3FPROC)load("glNormal3f"); + glad_glNormal3fv = (PFNGLNORMAL3FVPROC)load("glNormal3fv"); + glad_glNormal3i = (PFNGLNORMAL3IPROC)load("glNormal3i"); + glad_glNormal3iv = (PFNGLNORMAL3IVPROC)load("glNormal3iv"); + glad_glNormal3s = (PFNGLNORMAL3SPROC)load("glNormal3s"); + glad_glNormal3sv = (PFNGLNORMAL3SVPROC)load("glNormal3sv"); + glad_glRasterPos2d = (PFNGLRASTERPOS2DPROC)load("glRasterPos2d"); + glad_glRasterPos2dv = (PFNGLRASTERPOS2DVPROC)load("glRasterPos2dv"); + glad_glRasterPos2f = (PFNGLRASTERPOS2FPROC)load("glRasterPos2f"); + glad_glRasterPos2fv = (PFNGLRASTERPOS2FVPROC)load("glRasterPos2fv"); + glad_glRasterPos2i = (PFNGLRASTERPOS2IPROC)load("glRasterPos2i"); + glad_glRasterPos2iv = (PFNGLRASTERPOS2IVPROC)load("glRasterPos2iv"); + glad_glRasterPos2s = (PFNGLRASTERPOS2SPROC)load("glRasterPos2s"); + glad_glRasterPos2sv = (PFNGLRASTERPOS2SVPROC)load("glRasterPos2sv"); + glad_glRasterPos3d = (PFNGLRASTERPOS3DPROC)load("glRasterPos3d"); + glad_glRasterPos3dv = (PFNGLRASTERPOS3DVPROC)load("glRasterPos3dv"); + glad_glRasterPos3f = (PFNGLRASTERPOS3FPROC)load("glRasterPos3f"); + glad_glRasterPos3fv = (PFNGLRASTERPOS3FVPROC)load("glRasterPos3fv"); + glad_glRasterPos3i = (PFNGLRASTERPOS3IPROC)load("glRasterPos3i"); + glad_glRasterPos3iv = (PFNGLRASTERPOS3IVPROC)load("glRasterPos3iv"); + glad_glRasterPos3s = (PFNGLRASTERPOS3SPROC)load("glRasterPos3s"); + glad_glRasterPos3sv = (PFNGLRASTERPOS3SVPROC)load("glRasterPos3sv"); + glad_glRasterPos4d = (PFNGLRASTERPOS4DPROC)load("glRasterPos4d"); + glad_glRasterPos4dv = (PFNGLRASTERPOS4DVPROC)load("glRasterPos4dv"); + glad_glRasterPos4f = (PFNGLRASTERPOS4FPROC)load("glRasterPos4f"); + glad_glRasterPos4fv = (PFNGLRASTERPOS4FVPROC)load("glRasterPos4fv"); + glad_glRasterPos4i = (PFNGLRASTERPOS4IPROC)load("glRasterPos4i"); + glad_glRasterPos4iv = (PFNGLRASTERPOS4IVPROC)load("glRasterPos4iv"); + glad_glRasterPos4s = (PFNGLRASTERPOS4SPROC)load("glRasterPos4s"); + glad_glRasterPos4sv = (PFNGLRASTERPOS4SVPROC)load("glRasterPos4sv"); + glad_glRectd = (PFNGLRECTDPROC)load("glRectd"); + glad_glRectdv = (PFNGLRECTDVPROC)load("glRectdv"); + glad_glRectf = (PFNGLRECTFPROC)load("glRectf"); + glad_glRectfv = (PFNGLRECTFVPROC)load("glRectfv"); + glad_glRecti = (PFNGLRECTIPROC)load("glRecti"); + glad_glRectiv = (PFNGLRECTIVPROC)load("glRectiv"); + glad_glRects = (PFNGLRECTSPROC)load("glRects"); + glad_glRectsv = (PFNGLRECTSVPROC)load("glRectsv"); + glad_glTexCoord1d = (PFNGLTEXCOORD1DPROC)load("glTexCoord1d"); + glad_glTexCoord1dv = (PFNGLTEXCOORD1DVPROC)load("glTexCoord1dv"); + glad_glTexCoord1f = (PFNGLTEXCOORD1FPROC)load("glTexCoord1f"); + glad_glTexCoord1fv = (PFNGLTEXCOORD1FVPROC)load("glTexCoord1fv"); + glad_glTexCoord1i = (PFNGLTEXCOORD1IPROC)load("glTexCoord1i"); + glad_glTexCoord1iv = (PFNGLTEXCOORD1IVPROC)load("glTexCoord1iv"); + glad_glTexCoord1s = (PFNGLTEXCOORD1SPROC)load("glTexCoord1s"); + glad_glTexCoord1sv = (PFNGLTEXCOORD1SVPROC)load("glTexCoord1sv"); + glad_glTexCoord2d = (PFNGLTEXCOORD2DPROC)load("glTexCoord2d"); + glad_glTexCoord2dv = (PFNGLTEXCOORD2DVPROC)load("glTexCoord2dv"); + glad_glTexCoord2f = (PFNGLTEXCOORD2FPROC)load("glTexCoord2f"); + glad_glTexCoord2fv = (PFNGLTEXCOORD2FVPROC)load("glTexCoord2fv"); + glad_glTexCoord2i = (PFNGLTEXCOORD2IPROC)load("glTexCoord2i"); + glad_glTexCoord2iv = (PFNGLTEXCOORD2IVPROC)load("glTexCoord2iv"); + glad_glTexCoord2s = (PFNGLTEXCOORD2SPROC)load("glTexCoord2s"); + glad_glTexCoord2sv = (PFNGLTEXCOORD2SVPROC)load("glTexCoord2sv"); + glad_glTexCoord3d = (PFNGLTEXCOORD3DPROC)load("glTexCoord3d"); + glad_glTexCoord3dv = (PFNGLTEXCOORD3DVPROC)load("glTexCoord3dv"); + glad_glTexCoord3f = (PFNGLTEXCOORD3FPROC)load("glTexCoord3f"); + glad_glTexCoord3fv = (PFNGLTEXCOORD3FVPROC)load("glTexCoord3fv"); + glad_glTexCoord3i = (PFNGLTEXCOORD3IPROC)load("glTexCoord3i"); + glad_glTexCoord3iv = (PFNGLTEXCOORD3IVPROC)load("glTexCoord3iv"); + glad_glTexCoord3s = (PFNGLTEXCOORD3SPROC)load("glTexCoord3s"); + glad_glTexCoord3sv = (PFNGLTEXCOORD3SVPROC)load("glTexCoord3sv"); + glad_glTexCoord4d = (PFNGLTEXCOORD4DPROC)load("glTexCoord4d"); + glad_glTexCoord4dv = (PFNGLTEXCOORD4DVPROC)load("glTexCoord4dv"); + glad_glTexCoord4f = (PFNGLTEXCOORD4FPROC)load("glTexCoord4f"); + glad_glTexCoord4fv = (PFNGLTEXCOORD4FVPROC)load("glTexCoord4fv"); + glad_glTexCoord4i = (PFNGLTEXCOORD4IPROC)load("glTexCoord4i"); + glad_glTexCoord4iv = (PFNGLTEXCOORD4IVPROC)load("glTexCoord4iv"); + glad_glTexCoord4s = (PFNGLTEXCOORD4SPROC)load("glTexCoord4s"); + glad_glTexCoord4sv = (PFNGLTEXCOORD4SVPROC)load("glTexCoord4sv"); + glad_glVertex2d = (PFNGLVERTEX2DPROC)load("glVertex2d"); + glad_glVertex2dv = (PFNGLVERTEX2DVPROC)load("glVertex2dv"); + glad_glVertex2f = (PFNGLVERTEX2FPROC)load("glVertex2f"); + glad_glVertex2fv = (PFNGLVERTEX2FVPROC)load("glVertex2fv"); + glad_glVertex2i = (PFNGLVERTEX2IPROC)load("glVertex2i"); + glad_glVertex2iv = (PFNGLVERTEX2IVPROC)load("glVertex2iv"); + glad_glVertex2s = (PFNGLVERTEX2SPROC)load("glVertex2s"); + glad_glVertex2sv = (PFNGLVERTEX2SVPROC)load("glVertex2sv"); + glad_glVertex3d = (PFNGLVERTEX3DPROC)load("glVertex3d"); + glad_glVertex3dv = (PFNGLVERTEX3DVPROC)load("glVertex3dv"); + glad_glVertex3f = (PFNGLVERTEX3FPROC)load("glVertex3f"); + glad_glVertex3fv = (PFNGLVERTEX3FVPROC)load("glVertex3fv"); + glad_glVertex3i = (PFNGLVERTEX3IPROC)load("glVertex3i"); + glad_glVertex3iv = (PFNGLVERTEX3IVPROC)load("glVertex3iv"); + glad_glVertex3s = (PFNGLVERTEX3SPROC)load("glVertex3s"); + glad_glVertex3sv = (PFNGLVERTEX3SVPROC)load("glVertex3sv"); + glad_glVertex4d = (PFNGLVERTEX4DPROC)load("glVertex4d"); + glad_glVertex4dv = (PFNGLVERTEX4DVPROC)load("glVertex4dv"); + glad_glVertex4f = (PFNGLVERTEX4FPROC)load("glVertex4f"); + glad_glVertex4fv = (PFNGLVERTEX4FVPROC)load("glVertex4fv"); + glad_glVertex4i = (PFNGLVERTEX4IPROC)load("glVertex4i"); + glad_glVertex4iv = (PFNGLVERTEX4IVPROC)load("glVertex4iv"); + glad_glVertex4s = (PFNGLVERTEX4SPROC)load("glVertex4s"); + glad_glVertex4sv = (PFNGLVERTEX4SVPROC)load("glVertex4sv"); + glad_glClipPlane = (PFNGLCLIPPLANEPROC)load("glClipPlane"); + glad_glColorMaterial = (PFNGLCOLORMATERIALPROC)load("glColorMaterial"); + glad_glFogf = (PFNGLFOGFPROC)load("glFogf"); + glad_glFogfv = (PFNGLFOGFVPROC)load("glFogfv"); + glad_glFogi = (PFNGLFOGIPROC)load("glFogi"); + glad_glFogiv = (PFNGLFOGIVPROC)load("glFogiv"); + glad_glLightf = (PFNGLLIGHTFPROC)load("glLightf"); + glad_glLightfv = (PFNGLLIGHTFVPROC)load("glLightfv"); + glad_glLighti = (PFNGLLIGHTIPROC)load("glLighti"); + glad_glLightiv = (PFNGLLIGHTIVPROC)load("glLightiv"); + glad_glLightModelf = (PFNGLLIGHTMODELFPROC)load("glLightModelf"); + glad_glLightModelfv = (PFNGLLIGHTMODELFVPROC)load("glLightModelfv"); + glad_glLightModeli = (PFNGLLIGHTMODELIPROC)load("glLightModeli"); + glad_glLightModeliv = (PFNGLLIGHTMODELIVPROC)load("glLightModeliv"); + glad_glLineStipple = (PFNGLLINESTIPPLEPROC)load("glLineStipple"); + glad_glMaterialf = (PFNGLMATERIALFPROC)load("glMaterialf"); + glad_glMaterialfv = (PFNGLMATERIALFVPROC)load("glMaterialfv"); + glad_glMateriali = (PFNGLMATERIALIPROC)load("glMateriali"); + glad_glMaterialiv = (PFNGLMATERIALIVPROC)load("glMaterialiv"); + glad_glPolygonStipple = (PFNGLPOLYGONSTIPPLEPROC)load("glPolygonStipple"); + glad_glShadeModel = (PFNGLSHADEMODELPROC)load("glShadeModel"); + glad_glTexEnvf = (PFNGLTEXENVFPROC)load("glTexEnvf"); + glad_glTexEnvfv = (PFNGLTEXENVFVPROC)load("glTexEnvfv"); + glad_glTexEnvi = (PFNGLTEXENVIPROC)load("glTexEnvi"); + glad_glTexEnviv = (PFNGLTEXENVIVPROC)load("glTexEnviv"); + glad_glTexGend = (PFNGLTEXGENDPROC)load("glTexGend"); + glad_glTexGendv = (PFNGLTEXGENDVPROC)load("glTexGendv"); + glad_glTexGenf = (PFNGLTEXGENFPROC)load("glTexGenf"); + glad_glTexGenfv = (PFNGLTEXGENFVPROC)load("glTexGenfv"); + glad_glTexGeni = (PFNGLTEXGENIPROC)load("glTexGeni"); + glad_glTexGeniv = (PFNGLTEXGENIVPROC)load("glTexGeniv"); + glad_glFeedbackBuffer = (PFNGLFEEDBACKBUFFERPROC)load("glFeedbackBuffer"); + glad_glSelectBuffer = (PFNGLSELECTBUFFERPROC)load("glSelectBuffer"); + glad_glRenderMode = (PFNGLRENDERMODEPROC)load("glRenderMode"); + glad_glInitNames = (PFNGLINITNAMESPROC)load("glInitNames"); + glad_glLoadName = (PFNGLLOADNAMEPROC)load("glLoadName"); + glad_glPassThrough = (PFNGLPASSTHROUGHPROC)load("glPassThrough"); + glad_glPopName = (PFNGLPOPNAMEPROC)load("glPopName"); + glad_glPushName = (PFNGLPUSHNAMEPROC)load("glPushName"); + glad_glClearAccum = (PFNGLCLEARACCUMPROC)load("glClearAccum"); + glad_glClearIndex = (PFNGLCLEARINDEXPROC)load("glClearIndex"); + glad_glIndexMask = (PFNGLINDEXMASKPROC)load("glIndexMask"); + glad_glAccum = (PFNGLACCUMPROC)load("glAccum"); + glad_glPopAttrib = (PFNGLPOPATTRIBPROC)load("glPopAttrib"); + glad_glPushAttrib = (PFNGLPUSHATTRIBPROC)load("glPushAttrib"); + glad_glMap1d = (PFNGLMAP1DPROC)load("glMap1d"); + glad_glMap1f = (PFNGLMAP1FPROC)load("glMap1f"); + glad_glMap2d = (PFNGLMAP2DPROC)load("glMap2d"); + glad_glMap2f = (PFNGLMAP2FPROC)load("glMap2f"); + glad_glMapGrid1d = (PFNGLMAPGRID1DPROC)load("glMapGrid1d"); + glad_glMapGrid1f = (PFNGLMAPGRID1FPROC)load("glMapGrid1f"); + glad_glMapGrid2d = (PFNGLMAPGRID2DPROC)load("glMapGrid2d"); + glad_glMapGrid2f = (PFNGLMAPGRID2FPROC)load("glMapGrid2f"); + glad_glEvalCoord1d = (PFNGLEVALCOORD1DPROC)load("glEvalCoord1d"); + glad_glEvalCoord1dv = (PFNGLEVALCOORD1DVPROC)load("glEvalCoord1dv"); + glad_glEvalCoord1f = (PFNGLEVALCOORD1FPROC)load("glEvalCoord1f"); + glad_glEvalCoord1fv = (PFNGLEVALCOORD1FVPROC)load("glEvalCoord1fv"); + glad_glEvalCoord2d = (PFNGLEVALCOORD2DPROC)load("glEvalCoord2d"); + glad_glEvalCoord2dv = (PFNGLEVALCOORD2DVPROC)load("glEvalCoord2dv"); + glad_glEvalCoord2f = (PFNGLEVALCOORD2FPROC)load("glEvalCoord2f"); + glad_glEvalCoord2fv = (PFNGLEVALCOORD2FVPROC)load("glEvalCoord2fv"); + glad_glEvalMesh1 = (PFNGLEVALMESH1PROC)load("glEvalMesh1"); + glad_glEvalPoint1 = (PFNGLEVALPOINT1PROC)load("glEvalPoint1"); + glad_glEvalMesh2 = (PFNGLEVALMESH2PROC)load("glEvalMesh2"); + glad_glEvalPoint2 = (PFNGLEVALPOINT2PROC)load("glEvalPoint2"); + glad_glAlphaFunc = (PFNGLALPHAFUNCPROC)load("glAlphaFunc"); + glad_glPixelZoom = (PFNGLPIXELZOOMPROC)load("glPixelZoom"); + glad_glPixelTransferf = (PFNGLPIXELTRANSFERFPROC)load("glPixelTransferf"); + glad_glPixelTransferi = (PFNGLPIXELTRANSFERIPROC)load("glPixelTransferi"); + glad_glPixelMapfv = (PFNGLPIXELMAPFVPROC)load("glPixelMapfv"); + glad_glPixelMapuiv = (PFNGLPIXELMAPUIVPROC)load("glPixelMapuiv"); + glad_glPixelMapusv = (PFNGLPIXELMAPUSVPROC)load("glPixelMapusv"); + glad_glCopyPixels = (PFNGLCOPYPIXELSPROC)load("glCopyPixels"); + glad_glDrawPixels = (PFNGLDRAWPIXELSPROC)load("glDrawPixels"); + glad_glGetClipPlane = (PFNGLGETCLIPPLANEPROC)load("glGetClipPlane"); + glad_glGetLightfv = (PFNGLGETLIGHTFVPROC)load("glGetLightfv"); + glad_glGetLightiv = (PFNGLGETLIGHTIVPROC)load("glGetLightiv"); + glad_glGetMapdv = (PFNGLGETMAPDVPROC)load("glGetMapdv"); + glad_glGetMapfv = (PFNGLGETMAPFVPROC)load("glGetMapfv"); + glad_glGetMapiv = (PFNGLGETMAPIVPROC)load("glGetMapiv"); + glad_glGetMaterialfv = (PFNGLGETMATERIALFVPROC)load("glGetMaterialfv"); + glad_glGetMaterialiv = (PFNGLGETMATERIALIVPROC)load("glGetMaterialiv"); + glad_glGetPixelMapfv = (PFNGLGETPIXELMAPFVPROC)load("glGetPixelMapfv"); + glad_glGetPixelMapuiv = (PFNGLGETPIXELMAPUIVPROC)load("glGetPixelMapuiv"); + glad_glGetPixelMapusv = (PFNGLGETPIXELMAPUSVPROC)load("glGetPixelMapusv"); + glad_glGetPolygonStipple = (PFNGLGETPOLYGONSTIPPLEPROC)load("glGetPolygonStipple"); + glad_glGetTexEnvfv = (PFNGLGETTEXENVFVPROC)load("glGetTexEnvfv"); + glad_glGetTexEnviv = (PFNGLGETTEXENVIVPROC)load("glGetTexEnviv"); + glad_glGetTexGendv = (PFNGLGETTEXGENDVPROC)load("glGetTexGendv"); + glad_glGetTexGenfv = (PFNGLGETTEXGENFVPROC)load("glGetTexGenfv"); + glad_glGetTexGeniv = (PFNGLGETTEXGENIVPROC)load("glGetTexGeniv"); + glad_glIsList = (PFNGLISLISTPROC)load("glIsList"); + glad_glFrustum = (PFNGLFRUSTUMPROC)load("glFrustum"); + glad_glLoadIdentity = (PFNGLLOADIDENTITYPROC)load("glLoadIdentity"); + glad_glLoadMatrixf = (PFNGLLOADMATRIXFPROC)load("glLoadMatrixf"); + glad_glLoadMatrixd = (PFNGLLOADMATRIXDPROC)load("glLoadMatrixd"); + glad_glMatrixMode = (PFNGLMATRIXMODEPROC)load("glMatrixMode"); + glad_glMultMatrixf = (PFNGLMULTMATRIXFPROC)load("glMultMatrixf"); + glad_glMultMatrixd = (PFNGLMULTMATRIXDPROC)load("glMultMatrixd"); + glad_glOrtho = (PFNGLORTHOPROC)load("glOrtho"); + glad_glPopMatrix = (PFNGLPOPMATRIXPROC)load("glPopMatrix"); + glad_glPushMatrix = (PFNGLPUSHMATRIXPROC)load("glPushMatrix"); + glad_glRotated = (PFNGLROTATEDPROC)load("glRotated"); + glad_glRotatef = (PFNGLROTATEFPROC)load("glRotatef"); + glad_glScaled = (PFNGLSCALEDPROC)load("glScaled"); + glad_glScalef = (PFNGLSCALEFPROC)load("glScalef"); + glad_glTranslated = (PFNGLTRANSLATEDPROC)load("glTranslated"); + glad_glTranslatef = (PFNGLTRANSLATEFPROC)load("glTranslatef"); +} +static void load_GL_VERSION_1_1(GLADloadproc load) { + if(!GLAD_GL_VERSION_1_1) return; + glad_glDrawArrays = (PFNGLDRAWARRAYSPROC)load("glDrawArrays"); + glad_glDrawElements = (PFNGLDRAWELEMENTSPROC)load("glDrawElements"); + glad_glGetPointerv = (PFNGLGETPOINTERVPROC)load("glGetPointerv"); + glad_glPolygonOffset = (PFNGLPOLYGONOFFSETPROC)load("glPolygonOffset"); + glad_glCopyTexImage1D = (PFNGLCOPYTEXIMAGE1DPROC)load("glCopyTexImage1D"); + glad_glCopyTexImage2D = (PFNGLCOPYTEXIMAGE2DPROC)load("glCopyTexImage2D"); + glad_glCopyTexSubImage1D = (PFNGLCOPYTEXSUBIMAGE1DPROC)load("glCopyTexSubImage1D"); + glad_glCopyTexSubImage2D = (PFNGLCOPYTEXSUBIMAGE2DPROC)load("glCopyTexSubImage2D"); + glad_glTexSubImage1D = (PFNGLTEXSUBIMAGE1DPROC)load("glTexSubImage1D"); + glad_glTexSubImage2D = (PFNGLTEXSUBIMAGE2DPROC)load("glTexSubImage2D"); + glad_glBindTexture = (PFNGLBINDTEXTUREPROC)load("glBindTexture"); + glad_glDeleteTextures = (PFNGLDELETETEXTURESPROC)load("glDeleteTextures"); + glad_glGenTextures = (PFNGLGENTEXTURESPROC)load("glGenTextures"); + glad_glIsTexture = (PFNGLISTEXTUREPROC)load("glIsTexture"); + glad_glArrayElement = (PFNGLARRAYELEMENTPROC)load("glArrayElement"); + glad_glColorPointer = (PFNGLCOLORPOINTERPROC)load("glColorPointer"); + glad_glDisableClientState = (PFNGLDISABLECLIENTSTATEPROC)load("glDisableClientState"); + glad_glEdgeFlagPointer = (PFNGLEDGEFLAGPOINTERPROC)load("glEdgeFlagPointer"); + glad_glEnableClientState = (PFNGLENABLECLIENTSTATEPROC)load("glEnableClientState"); + glad_glIndexPointer = (PFNGLINDEXPOINTERPROC)load("glIndexPointer"); + glad_glInterleavedArrays = (PFNGLINTERLEAVEDARRAYSPROC)load("glInterleavedArrays"); + glad_glNormalPointer = (PFNGLNORMALPOINTERPROC)load("glNormalPointer"); + glad_glTexCoordPointer = (PFNGLTEXCOORDPOINTERPROC)load("glTexCoordPointer"); + glad_glVertexPointer = (PFNGLVERTEXPOINTERPROC)load("glVertexPointer"); + glad_glAreTexturesResident = (PFNGLARETEXTURESRESIDENTPROC)load("glAreTexturesResident"); + glad_glPrioritizeTextures = (PFNGLPRIORITIZETEXTURESPROC)load("glPrioritizeTextures"); + glad_glIndexub = (PFNGLINDEXUBPROC)load("glIndexub"); + glad_glIndexubv = (PFNGLINDEXUBVPROC)load("glIndexubv"); + glad_glPopClientAttrib = (PFNGLPOPCLIENTATTRIBPROC)load("glPopClientAttrib"); + glad_glPushClientAttrib = (PFNGLPUSHCLIENTATTRIBPROC)load("glPushClientAttrib"); +} +static void load_GL_VERSION_1_2(GLADloadproc load) { + if(!GLAD_GL_VERSION_1_2) return; + glad_glDrawRangeElements = (PFNGLDRAWRANGEELEMENTSPROC)load("glDrawRangeElements"); + glad_glTexImage3D = (PFNGLTEXIMAGE3DPROC)load("glTexImage3D"); + glad_glTexSubImage3D = (PFNGLTEXSUBIMAGE3DPROC)load("glTexSubImage3D"); + glad_glCopyTexSubImage3D = (PFNGLCOPYTEXSUBIMAGE3DPROC)load("glCopyTexSubImage3D"); +} +static void load_GL_VERSION_1_3(GLADloadproc load) { + if(!GLAD_GL_VERSION_1_3) return; + glad_glActiveTexture = (PFNGLACTIVETEXTUREPROC)load("glActiveTexture"); + glad_glSampleCoverage = (PFNGLSAMPLECOVERAGEPROC)load("glSampleCoverage"); + glad_glCompressedTexImage3D = (PFNGLCOMPRESSEDTEXIMAGE3DPROC)load("glCompressedTexImage3D"); + glad_glCompressedTexImage2D = (PFNGLCOMPRESSEDTEXIMAGE2DPROC)load("glCompressedTexImage2D"); + glad_glCompressedTexImage1D = (PFNGLCOMPRESSEDTEXIMAGE1DPROC)load("glCompressedTexImage1D"); + glad_glCompressedTexSubImage3D = (PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC)load("glCompressedTexSubImage3D"); + glad_glCompressedTexSubImage2D = (PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC)load("glCompressedTexSubImage2D"); + glad_glCompressedTexSubImage1D = (PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC)load("glCompressedTexSubImage1D"); + glad_glGetCompressedTexImage = (PFNGLGETCOMPRESSEDTEXIMAGEPROC)load("glGetCompressedTexImage"); + glad_glClientActiveTexture = (PFNGLCLIENTACTIVETEXTUREPROC)load("glClientActiveTexture"); + glad_glMultiTexCoord1d = (PFNGLMULTITEXCOORD1DPROC)load("glMultiTexCoord1d"); + glad_glMultiTexCoord1dv = (PFNGLMULTITEXCOORD1DVPROC)load("glMultiTexCoord1dv"); + glad_glMultiTexCoord1f = (PFNGLMULTITEXCOORD1FPROC)load("glMultiTexCoord1f"); + glad_glMultiTexCoord1fv = (PFNGLMULTITEXCOORD1FVPROC)load("glMultiTexCoord1fv"); + glad_glMultiTexCoord1i = (PFNGLMULTITEXCOORD1IPROC)load("glMultiTexCoord1i"); + glad_glMultiTexCoord1iv = (PFNGLMULTITEXCOORD1IVPROC)load("glMultiTexCoord1iv"); + glad_glMultiTexCoord1s = (PFNGLMULTITEXCOORD1SPROC)load("glMultiTexCoord1s"); + glad_glMultiTexCoord1sv = (PFNGLMULTITEXCOORD1SVPROC)load("glMultiTexCoord1sv"); + glad_glMultiTexCoord2d = (PFNGLMULTITEXCOORD2DPROC)load("glMultiTexCoord2d"); + glad_glMultiTexCoord2dv = (PFNGLMULTITEXCOORD2DVPROC)load("glMultiTexCoord2dv"); + glad_glMultiTexCoord2f = (PFNGLMULTITEXCOORD2FPROC)load("glMultiTexCoord2f"); + glad_glMultiTexCoord2fv = (PFNGLMULTITEXCOORD2FVPROC)load("glMultiTexCoord2fv"); + glad_glMultiTexCoord2i = (PFNGLMULTITEXCOORD2IPROC)load("glMultiTexCoord2i"); + glad_glMultiTexCoord2iv = (PFNGLMULTITEXCOORD2IVPROC)load("glMultiTexCoord2iv"); + glad_glMultiTexCoord2s = (PFNGLMULTITEXCOORD2SPROC)load("glMultiTexCoord2s"); + glad_glMultiTexCoord2sv = (PFNGLMULTITEXCOORD2SVPROC)load("glMultiTexCoord2sv"); + glad_glMultiTexCoord3d = (PFNGLMULTITEXCOORD3DPROC)load("glMultiTexCoord3d"); + glad_glMultiTexCoord3dv = (PFNGLMULTITEXCOORD3DVPROC)load("glMultiTexCoord3dv"); + glad_glMultiTexCoord3f = (PFNGLMULTITEXCOORD3FPROC)load("glMultiTexCoord3f"); + glad_glMultiTexCoord3fv = (PFNGLMULTITEXCOORD3FVPROC)load("glMultiTexCoord3fv"); + glad_glMultiTexCoord3i = (PFNGLMULTITEXCOORD3IPROC)load("glMultiTexCoord3i"); + glad_glMultiTexCoord3iv = (PFNGLMULTITEXCOORD3IVPROC)load("glMultiTexCoord3iv"); + glad_glMultiTexCoord3s = (PFNGLMULTITEXCOORD3SPROC)load("glMultiTexCoord3s"); + glad_glMultiTexCoord3sv = (PFNGLMULTITEXCOORD3SVPROC)load("glMultiTexCoord3sv"); + glad_glMultiTexCoord4d = (PFNGLMULTITEXCOORD4DPROC)load("glMultiTexCoord4d"); + glad_glMultiTexCoord4dv = (PFNGLMULTITEXCOORD4DVPROC)load("glMultiTexCoord4dv"); + glad_glMultiTexCoord4f = (PFNGLMULTITEXCOORD4FPROC)load("glMultiTexCoord4f"); + glad_glMultiTexCoord4fv = (PFNGLMULTITEXCOORD4FVPROC)load("glMultiTexCoord4fv"); + glad_glMultiTexCoord4i = (PFNGLMULTITEXCOORD4IPROC)load("glMultiTexCoord4i"); + glad_glMultiTexCoord4iv = (PFNGLMULTITEXCOORD4IVPROC)load("glMultiTexCoord4iv"); + glad_glMultiTexCoord4s = (PFNGLMULTITEXCOORD4SPROC)load("glMultiTexCoord4s"); + glad_glMultiTexCoord4sv = (PFNGLMULTITEXCOORD4SVPROC)load("glMultiTexCoord4sv"); + glad_glLoadTransposeMatrixf = (PFNGLLOADTRANSPOSEMATRIXFPROC)load("glLoadTransposeMatrixf"); + glad_glLoadTransposeMatrixd = (PFNGLLOADTRANSPOSEMATRIXDPROC)load("glLoadTransposeMatrixd"); + glad_glMultTransposeMatrixf = (PFNGLMULTTRANSPOSEMATRIXFPROC)load("glMultTransposeMatrixf"); + glad_glMultTransposeMatrixd = (PFNGLMULTTRANSPOSEMATRIXDPROC)load("glMultTransposeMatrixd"); +} +static void load_GL_VERSION_1_4(GLADloadproc load) { + if(!GLAD_GL_VERSION_1_4) return; + glad_glBlendFuncSeparate = (PFNGLBLENDFUNCSEPARATEPROC)load("glBlendFuncSeparate"); + glad_glMultiDrawArrays = (PFNGLMULTIDRAWARRAYSPROC)load("glMultiDrawArrays"); + glad_glMultiDrawElements = (PFNGLMULTIDRAWELEMENTSPROC)load("glMultiDrawElements"); + glad_glPointParameterf = (PFNGLPOINTPARAMETERFPROC)load("glPointParameterf"); + glad_glPointParameterfv = (PFNGLPOINTPARAMETERFVPROC)load("glPointParameterfv"); + glad_glPointParameteri = (PFNGLPOINTPARAMETERIPROC)load("glPointParameteri"); + glad_glPointParameteriv = (PFNGLPOINTPARAMETERIVPROC)load("glPointParameteriv"); + glad_glFogCoordf = (PFNGLFOGCOORDFPROC)load("glFogCoordf"); + glad_glFogCoordfv = (PFNGLFOGCOORDFVPROC)load("glFogCoordfv"); + glad_glFogCoordd = (PFNGLFOGCOORDDPROC)load("glFogCoordd"); + glad_glFogCoorddv = (PFNGLFOGCOORDDVPROC)load("glFogCoorddv"); + glad_glFogCoordPointer = (PFNGLFOGCOORDPOINTERPROC)load("glFogCoordPointer"); + glad_glSecondaryColor3b = (PFNGLSECONDARYCOLOR3BPROC)load("glSecondaryColor3b"); + glad_glSecondaryColor3bv = (PFNGLSECONDARYCOLOR3BVPROC)load("glSecondaryColor3bv"); + glad_glSecondaryColor3d = (PFNGLSECONDARYCOLOR3DPROC)load("glSecondaryColor3d"); + glad_glSecondaryColor3dv = (PFNGLSECONDARYCOLOR3DVPROC)load("glSecondaryColor3dv"); + glad_glSecondaryColor3f = (PFNGLSECONDARYCOLOR3FPROC)load("glSecondaryColor3f"); + glad_glSecondaryColor3fv = (PFNGLSECONDARYCOLOR3FVPROC)load("glSecondaryColor3fv"); + glad_glSecondaryColor3i = (PFNGLSECONDARYCOLOR3IPROC)load("glSecondaryColor3i"); + glad_glSecondaryColor3iv = (PFNGLSECONDARYCOLOR3IVPROC)load("glSecondaryColor3iv"); + glad_glSecondaryColor3s = (PFNGLSECONDARYCOLOR3SPROC)load("glSecondaryColor3s"); + glad_glSecondaryColor3sv = (PFNGLSECONDARYCOLOR3SVPROC)load("glSecondaryColor3sv"); + glad_glSecondaryColor3ub = (PFNGLSECONDARYCOLOR3UBPROC)load("glSecondaryColor3ub"); + glad_glSecondaryColor3ubv = (PFNGLSECONDARYCOLOR3UBVPROC)load("glSecondaryColor3ubv"); + glad_glSecondaryColor3ui = (PFNGLSECONDARYCOLOR3UIPROC)load("glSecondaryColor3ui"); + glad_glSecondaryColor3uiv = (PFNGLSECONDARYCOLOR3UIVPROC)load("glSecondaryColor3uiv"); + glad_glSecondaryColor3us = (PFNGLSECONDARYCOLOR3USPROC)load("glSecondaryColor3us"); + glad_glSecondaryColor3usv = (PFNGLSECONDARYCOLOR3USVPROC)load("glSecondaryColor3usv"); + glad_glSecondaryColorPointer = (PFNGLSECONDARYCOLORPOINTERPROC)load("glSecondaryColorPointer"); + glad_glWindowPos2d = (PFNGLWINDOWPOS2DPROC)load("glWindowPos2d"); + glad_glWindowPos2dv = (PFNGLWINDOWPOS2DVPROC)load("glWindowPos2dv"); + glad_glWindowPos2f = (PFNGLWINDOWPOS2FPROC)load("glWindowPos2f"); + glad_glWindowPos2fv = (PFNGLWINDOWPOS2FVPROC)load("glWindowPos2fv"); + glad_glWindowPos2i = (PFNGLWINDOWPOS2IPROC)load("glWindowPos2i"); + glad_glWindowPos2iv = (PFNGLWINDOWPOS2IVPROC)load("glWindowPos2iv"); + glad_glWindowPos2s = (PFNGLWINDOWPOS2SPROC)load("glWindowPos2s"); + glad_glWindowPos2sv = (PFNGLWINDOWPOS2SVPROC)load("glWindowPos2sv"); + glad_glWindowPos3d = (PFNGLWINDOWPOS3DPROC)load("glWindowPos3d"); + glad_glWindowPos3dv = (PFNGLWINDOWPOS3DVPROC)load("glWindowPos3dv"); + glad_glWindowPos3f = (PFNGLWINDOWPOS3FPROC)load("glWindowPos3f"); + glad_glWindowPos3fv = (PFNGLWINDOWPOS3FVPROC)load("glWindowPos3fv"); + glad_glWindowPos3i = (PFNGLWINDOWPOS3IPROC)load("glWindowPos3i"); + glad_glWindowPos3iv = (PFNGLWINDOWPOS3IVPROC)load("glWindowPos3iv"); + glad_glWindowPos3s = (PFNGLWINDOWPOS3SPROC)load("glWindowPos3s"); + glad_glWindowPos3sv = (PFNGLWINDOWPOS3SVPROC)load("glWindowPos3sv"); + glad_glBlendColor = (PFNGLBLENDCOLORPROC)load("glBlendColor"); + glad_glBlendEquation = (PFNGLBLENDEQUATIONPROC)load("glBlendEquation"); +} +static void load_GL_VERSION_1_5(GLADloadproc load) { + if(!GLAD_GL_VERSION_1_5) return; + glad_glGenQueries = (PFNGLGENQUERIESPROC)load("glGenQueries"); + glad_glDeleteQueries = (PFNGLDELETEQUERIESPROC)load("glDeleteQueries"); + glad_glIsQuery = (PFNGLISQUERYPROC)load("glIsQuery"); + glad_glBeginQuery = (PFNGLBEGINQUERYPROC)load("glBeginQuery"); + glad_glEndQuery = (PFNGLENDQUERYPROC)load("glEndQuery"); + glad_glGetQueryiv = (PFNGLGETQUERYIVPROC)load("glGetQueryiv"); + glad_glGetQueryObjectiv = (PFNGLGETQUERYOBJECTIVPROC)load("glGetQueryObjectiv"); + glad_glGetQueryObjectuiv = (PFNGLGETQUERYOBJECTUIVPROC)load("glGetQueryObjectuiv"); + glad_glBindBuffer = (PFNGLBINDBUFFERPROC)load("glBindBuffer"); + glad_glDeleteBuffers = (PFNGLDELETEBUFFERSPROC)load("glDeleteBuffers"); + glad_glGenBuffers = (PFNGLGENBUFFERSPROC)load("glGenBuffers"); + glad_glIsBuffer = (PFNGLISBUFFERPROC)load("glIsBuffer"); + glad_glBufferData = (PFNGLBUFFERDATAPROC)load("glBufferData"); + glad_glBufferSubData = (PFNGLBUFFERSUBDATAPROC)load("glBufferSubData"); + glad_glGetBufferSubData = (PFNGLGETBUFFERSUBDATAPROC)load("glGetBufferSubData"); + glad_glMapBuffer = (PFNGLMAPBUFFERPROC)load("glMapBuffer"); + glad_glUnmapBuffer = (PFNGLUNMAPBUFFERPROC)load("glUnmapBuffer"); + glad_glGetBufferParameteriv = (PFNGLGETBUFFERPARAMETERIVPROC)load("glGetBufferParameteriv"); + glad_glGetBufferPointerv = (PFNGLGETBUFFERPOINTERVPROC)load("glGetBufferPointerv"); +} +static void load_GL_VERSION_2_0(GLADloadproc load) { + if(!GLAD_GL_VERSION_2_0) return; + glad_glBlendEquationSeparate = (PFNGLBLENDEQUATIONSEPARATEPROC)load("glBlendEquationSeparate"); + glad_glDrawBuffers = (PFNGLDRAWBUFFERSPROC)load("glDrawBuffers"); + glad_glStencilOpSeparate = (PFNGLSTENCILOPSEPARATEPROC)load("glStencilOpSeparate"); + glad_glStencilFuncSeparate = (PFNGLSTENCILFUNCSEPARATEPROC)load("glStencilFuncSeparate"); + glad_glStencilMaskSeparate = (PFNGLSTENCILMASKSEPARATEPROC)load("glStencilMaskSeparate"); + glad_glAttachShader = (PFNGLATTACHSHADERPROC)load("glAttachShader"); + glad_glBindAttribLocation = (PFNGLBINDATTRIBLOCATIONPROC)load("glBindAttribLocation"); + glad_glCompileShader = (PFNGLCOMPILESHADERPROC)load("glCompileShader"); + glad_glCreateProgram = (PFNGLCREATEPROGRAMPROC)load("glCreateProgram"); + glad_glCreateShader = (PFNGLCREATESHADERPROC)load("glCreateShader"); + glad_glDeleteProgram = (PFNGLDELETEPROGRAMPROC)load("glDeleteProgram"); + glad_glDeleteShader = (PFNGLDELETESHADERPROC)load("glDeleteShader"); + glad_glDetachShader = (PFNGLDETACHSHADERPROC)load("glDetachShader"); + glad_glDisableVertexAttribArray = (PFNGLDISABLEVERTEXATTRIBARRAYPROC)load("glDisableVertexAttribArray"); + glad_glEnableVertexAttribArray = (PFNGLENABLEVERTEXATTRIBARRAYPROC)load("glEnableVertexAttribArray"); + glad_glGetActiveAttrib = (PFNGLGETACTIVEATTRIBPROC)load("glGetActiveAttrib"); + glad_glGetActiveUniform = (PFNGLGETACTIVEUNIFORMPROC)load("glGetActiveUniform"); + glad_glGetAttachedShaders = (PFNGLGETATTACHEDSHADERSPROC)load("glGetAttachedShaders"); + glad_glGetAttribLocation = (PFNGLGETATTRIBLOCATIONPROC)load("glGetAttribLocation"); + glad_glGetProgramiv = (PFNGLGETPROGRAMIVPROC)load("glGetProgramiv"); + glad_glGetProgramInfoLog = (PFNGLGETPROGRAMINFOLOGPROC)load("glGetProgramInfoLog"); + glad_glGetShaderiv = (PFNGLGETSHADERIVPROC)load("glGetShaderiv"); + glad_glGetShaderInfoLog = (PFNGLGETSHADERINFOLOGPROC)load("glGetShaderInfoLog"); + glad_glGetShaderSource = (PFNGLGETSHADERSOURCEPROC)load("glGetShaderSource"); + glad_glGetUniformLocation = (PFNGLGETUNIFORMLOCATIONPROC)load("glGetUniformLocation"); + glad_glGetUniformfv = (PFNGLGETUNIFORMFVPROC)load("glGetUniformfv"); + glad_glGetUniformiv = (PFNGLGETUNIFORMIVPROC)load("glGetUniformiv"); + glad_glGetVertexAttribdv = (PFNGLGETVERTEXATTRIBDVPROC)load("glGetVertexAttribdv"); + glad_glGetVertexAttribfv = (PFNGLGETVERTEXATTRIBFVPROC)load("glGetVertexAttribfv"); + glad_glGetVertexAttribiv = (PFNGLGETVERTEXATTRIBIVPROC)load("glGetVertexAttribiv"); + glad_glGetVertexAttribPointerv = (PFNGLGETVERTEXATTRIBPOINTERVPROC)load("glGetVertexAttribPointerv"); + glad_glIsProgram = (PFNGLISPROGRAMPROC)load("glIsProgram"); + glad_glIsShader = (PFNGLISSHADERPROC)load("glIsShader"); + glad_glLinkProgram = (PFNGLLINKPROGRAMPROC)load("glLinkProgram"); + glad_glShaderSource = (PFNGLSHADERSOURCEPROC)load("glShaderSource"); + glad_glUseProgram = (PFNGLUSEPROGRAMPROC)load("glUseProgram"); + glad_glUniform1f = (PFNGLUNIFORM1FPROC)load("glUniform1f"); + glad_glUniform2f = (PFNGLUNIFORM2FPROC)load("glUniform2f"); + glad_glUniform3f = (PFNGLUNIFORM3FPROC)load("glUniform3f"); + glad_glUniform4f = (PFNGLUNIFORM4FPROC)load("glUniform4f"); + glad_glUniform1i = (PFNGLUNIFORM1IPROC)load("glUniform1i"); + glad_glUniform2i = (PFNGLUNIFORM2IPROC)load("glUniform2i"); + glad_glUniform3i = (PFNGLUNIFORM3IPROC)load("glUniform3i"); + glad_glUniform4i = (PFNGLUNIFORM4IPROC)load("glUniform4i"); + glad_glUniform1fv = (PFNGLUNIFORM1FVPROC)load("glUniform1fv"); + glad_glUniform2fv = (PFNGLUNIFORM2FVPROC)load("glUniform2fv"); + glad_glUniform3fv = (PFNGLUNIFORM3FVPROC)load("glUniform3fv"); + glad_glUniform4fv = (PFNGLUNIFORM4FVPROC)load("glUniform4fv"); + glad_glUniform1iv = (PFNGLUNIFORM1IVPROC)load("glUniform1iv"); + glad_glUniform2iv = (PFNGLUNIFORM2IVPROC)load("glUniform2iv"); + glad_glUniform3iv = (PFNGLUNIFORM3IVPROC)load("glUniform3iv"); + glad_glUniform4iv = (PFNGLUNIFORM4IVPROC)load("glUniform4iv"); + glad_glUniformMatrix2fv = (PFNGLUNIFORMMATRIX2FVPROC)load("glUniformMatrix2fv"); + glad_glUniformMatrix3fv = (PFNGLUNIFORMMATRIX3FVPROC)load("glUniformMatrix3fv"); + glad_glUniformMatrix4fv = (PFNGLUNIFORMMATRIX4FVPROC)load("glUniformMatrix4fv"); + glad_glValidateProgram = (PFNGLVALIDATEPROGRAMPROC)load("glValidateProgram"); + glad_glVertexAttrib1d = (PFNGLVERTEXATTRIB1DPROC)load("glVertexAttrib1d"); + glad_glVertexAttrib1dv = (PFNGLVERTEXATTRIB1DVPROC)load("glVertexAttrib1dv"); + glad_glVertexAttrib1f = (PFNGLVERTEXATTRIB1FPROC)load("glVertexAttrib1f"); + glad_glVertexAttrib1fv = (PFNGLVERTEXATTRIB1FVPROC)load("glVertexAttrib1fv"); + glad_glVertexAttrib1s = (PFNGLVERTEXATTRIB1SPROC)load("glVertexAttrib1s"); + glad_glVertexAttrib1sv = (PFNGLVERTEXATTRIB1SVPROC)load("glVertexAttrib1sv"); + glad_glVertexAttrib2d = (PFNGLVERTEXATTRIB2DPROC)load("glVertexAttrib2d"); + glad_glVertexAttrib2dv = (PFNGLVERTEXATTRIB2DVPROC)load("glVertexAttrib2dv"); + glad_glVertexAttrib2f = (PFNGLVERTEXATTRIB2FPROC)load("glVertexAttrib2f"); + glad_glVertexAttrib2fv = (PFNGLVERTEXATTRIB2FVPROC)load("glVertexAttrib2fv"); + glad_glVertexAttrib2s = (PFNGLVERTEXATTRIB2SPROC)load("glVertexAttrib2s"); + glad_glVertexAttrib2sv = (PFNGLVERTEXATTRIB2SVPROC)load("glVertexAttrib2sv"); + glad_glVertexAttrib3d = (PFNGLVERTEXATTRIB3DPROC)load("glVertexAttrib3d"); + glad_glVertexAttrib3dv = (PFNGLVERTEXATTRIB3DVPROC)load("glVertexAttrib3dv"); + glad_glVertexAttrib3f = (PFNGLVERTEXATTRIB3FPROC)load("glVertexAttrib3f"); + glad_glVertexAttrib3fv = (PFNGLVERTEXATTRIB3FVPROC)load("glVertexAttrib3fv"); + glad_glVertexAttrib3s = (PFNGLVERTEXATTRIB3SPROC)load("glVertexAttrib3s"); + glad_glVertexAttrib3sv = (PFNGLVERTEXATTRIB3SVPROC)load("glVertexAttrib3sv"); + glad_glVertexAttrib4Nbv = (PFNGLVERTEXATTRIB4NBVPROC)load("glVertexAttrib4Nbv"); + glad_glVertexAttrib4Niv = (PFNGLVERTEXATTRIB4NIVPROC)load("glVertexAttrib4Niv"); + glad_glVertexAttrib4Nsv = (PFNGLVERTEXATTRIB4NSVPROC)load("glVertexAttrib4Nsv"); + glad_glVertexAttrib4Nub = (PFNGLVERTEXATTRIB4NUBPROC)load("glVertexAttrib4Nub"); + glad_glVertexAttrib4Nubv = (PFNGLVERTEXATTRIB4NUBVPROC)load("glVertexAttrib4Nubv"); + glad_glVertexAttrib4Nuiv = (PFNGLVERTEXATTRIB4NUIVPROC)load("glVertexAttrib4Nuiv"); + glad_glVertexAttrib4Nusv = (PFNGLVERTEXATTRIB4NUSVPROC)load("glVertexAttrib4Nusv"); + glad_glVertexAttrib4bv = (PFNGLVERTEXATTRIB4BVPROC)load("glVertexAttrib4bv"); + glad_glVertexAttrib4d = (PFNGLVERTEXATTRIB4DPROC)load("glVertexAttrib4d"); + glad_glVertexAttrib4dv = (PFNGLVERTEXATTRIB4DVPROC)load("glVertexAttrib4dv"); + glad_glVertexAttrib4f = (PFNGLVERTEXATTRIB4FPROC)load("glVertexAttrib4f"); + glad_glVertexAttrib4fv = (PFNGLVERTEXATTRIB4FVPROC)load("glVertexAttrib4fv"); + glad_glVertexAttrib4iv = (PFNGLVERTEXATTRIB4IVPROC)load("glVertexAttrib4iv"); + glad_glVertexAttrib4s = (PFNGLVERTEXATTRIB4SPROC)load("glVertexAttrib4s"); + glad_glVertexAttrib4sv = (PFNGLVERTEXATTRIB4SVPROC)load("glVertexAttrib4sv"); + glad_glVertexAttrib4ubv = (PFNGLVERTEXATTRIB4UBVPROC)load("glVertexAttrib4ubv"); + glad_glVertexAttrib4uiv = (PFNGLVERTEXATTRIB4UIVPROC)load("glVertexAttrib4uiv"); + glad_glVertexAttrib4usv = (PFNGLVERTEXATTRIB4USVPROC)load("glVertexAttrib4usv"); + glad_glVertexAttribPointer = (PFNGLVERTEXATTRIBPOINTERPROC)load("glVertexAttribPointer"); +} +static void load_GL_VERSION_2_1(GLADloadproc load) { + if(!GLAD_GL_VERSION_2_1) return; + glad_glUniformMatrix2x3fv = (PFNGLUNIFORMMATRIX2X3FVPROC)load("glUniformMatrix2x3fv"); + glad_glUniformMatrix3x2fv = (PFNGLUNIFORMMATRIX3X2FVPROC)load("glUniformMatrix3x2fv"); + glad_glUniformMatrix2x4fv = (PFNGLUNIFORMMATRIX2X4FVPROC)load("glUniformMatrix2x4fv"); + glad_glUniformMatrix4x2fv = (PFNGLUNIFORMMATRIX4X2FVPROC)load("glUniformMatrix4x2fv"); + glad_glUniformMatrix3x4fv = (PFNGLUNIFORMMATRIX3X4FVPROC)load("glUniformMatrix3x4fv"); + glad_glUniformMatrix4x3fv = (PFNGLUNIFORMMATRIX4X3FVPROC)load("glUniformMatrix4x3fv"); +} +static void load_GL_VERSION_3_0(GLADloadproc load) { + if(!GLAD_GL_VERSION_3_0) return; + glad_glColorMaski = (PFNGLCOLORMASKIPROC)load("glColorMaski"); + glad_glGetBooleani_v = (PFNGLGETBOOLEANI_VPROC)load("glGetBooleani_v"); + glad_glGetIntegeri_v = (PFNGLGETINTEGERI_VPROC)load("glGetIntegeri_v"); + glad_glEnablei = (PFNGLENABLEIPROC)load("glEnablei"); + glad_glDisablei = (PFNGLDISABLEIPROC)load("glDisablei"); + glad_glIsEnabledi = (PFNGLISENABLEDIPROC)load("glIsEnabledi"); + glad_glBeginTransformFeedback = (PFNGLBEGINTRANSFORMFEEDBACKPROC)load("glBeginTransformFeedback"); + glad_glEndTransformFeedback = (PFNGLENDTRANSFORMFEEDBACKPROC)load("glEndTransformFeedback"); + glad_glBindBufferRange = (PFNGLBINDBUFFERRANGEPROC)load("glBindBufferRange"); + glad_glBindBufferBase = (PFNGLBINDBUFFERBASEPROC)load("glBindBufferBase"); + glad_glTransformFeedbackVaryings = (PFNGLTRANSFORMFEEDBACKVARYINGSPROC)load("glTransformFeedbackVaryings"); + glad_glGetTransformFeedbackVarying = (PFNGLGETTRANSFORMFEEDBACKVARYINGPROC)load("glGetTransformFeedbackVarying"); + glad_glClampColor = (PFNGLCLAMPCOLORPROC)load("glClampColor"); + glad_glBeginConditionalRender = (PFNGLBEGINCONDITIONALRENDERPROC)load("glBeginConditionalRender"); + glad_glEndConditionalRender = (PFNGLENDCONDITIONALRENDERPROC)load("glEndConditionalRender"); + glad_glVertexAttribIPointer = (PFNGLVERTEXATTRIBIPOINTERPROC)load("glVertexAttribIPointer"); + glad_glGetVertexAttribIiv = (PFNGLGETVERTEXATTRIBIIVPROC)load("glGetVertexAttribIiv"); + glad_glGetVertexAttribIuiv = (PFNGLGETVERTEXATTRIBIUIVPROC)load("glGetVertexAttribIuiv"); + glad_glVertexAttribI1i = (PFNGLVERTEXATTRIBI1IPROC)load("glVertexAttribI1i"); + glad_glVertexAttribI2i = (PFNGLVERTEXATTRIBI2IPROC)load("glVertexAttribI2i"); + glad_glVertexAttribI3i = (PFNGLVERTEXATTRIBI3IPROC)load("glVertexAttribI3i"); + glad_glVertexAttribI4i = (PFNGLVERTEXATTRIBI4IPROC)load("glVertexAttribI4i"); + glad_glVertexAttribI1ui = (PFNGLVERTEXATTRIBI1UIPROC)load("glVertexAttribI1ui"); + glad_glVertexAttribI2ui = (PFNGLVERTEXATTRIBI2UIPROC)load("glVertexAttribI2ui"); + glad_glVertexAttribI3ui = (PFNGLVERTEXATTRIBI3UIPROC)load("glVertexAttribI3ui"); + glad_glVertexAttribI4ui = (PFNGLVERTEXATTRIBI4UIPROC)load("glVertexAttribI4ui"); + glad_glVertexAttribI1iv = (PFNGLVERTEXATTRIBI1IVPROC)load("glVertexAttribI1iv"); + glad_glVertexAttribI2iv = (PFNGLVERTEXATTRIBI2IVPROC)load("glVertexAttribI2iv"); + glad_glVertexAttribI3iv = (PFNGLVERTEXATTRIBI3IVPROC)load("glVertexAttribI3iv"); + glad_glVertexAttribI4iv = (PFNGLVERTEXATTRIBI4IVPROC)load("glVertexAttribI4iv"); + glad_glVertexAttribI1uiv = (PFNGLVERTEXATTRIBI1UIVPROC)load("glVertexAttribI1uiv"); + glad_glVertexAttribI2uiv = (PFNGLVERTEXATTRIBI2UIVPROC)load("glVertexAttribI2uiv"); + glad_glVertexAttribI3uiv = (PFNGLVERTEXATTRIBI3UIVPROC)load("glVertexAttribI3uiv"); + glad_glVertexAttribI4uiv = (PFNGLVERTEXATTRIBI4UIVPROC)load("glVertexAttribI4uiv"); + glad_glVertexAttribI4bv = (PFNGLVERTEXATTRIBI4BVPROC)load("glVertexAttribI4bv"); + glad_glVertexAttribI4sv = (PFNGLVERTEXATTRIBI4SVPROC)load("glVertexAttribI4sv"); + glad_glVertexAttribI4ubv = (PFNGLVERTEXATTRIBI4UBVPROC)load("glVertexAttribI4ubv"); + glad_glVertexAttribI4usv = (PFNGLVERTEXATTRIBI4USVPROC)load("glVertexAttribI4usv"); + glad_glGetUniformuiv = (PFNGLGETUNIFORMUIVPROC)load("glGetUniformuiv"); + glad_glBindFragDataLocation = (PFNGLBINDFRAGDATALOCATIONPROC)load("glBindFragDataLocation"); + glad_glGetFragDataLocation = (PFNGLGETFRAGDATALOCATIONPROC)load("glGetFragDataLocation"); + glad_glUniform1ui = (PFNGLUNIFORM1UIPROC)load("glUniform1ui"); + glad_glUniform2ui = (PFNGLUNIFORM2UIPROC)load("glUniform2ui"); + glad_glUniform3ui = (PFNGLUNIFORM3UIPROC)load("glUniform3ui"); + glad_glUniform4ui = (PFNGLUNIFORM4UIPROC)load("glUniform4ui"); + glad_glUniform1uiv = (PFNGLUNIFORM1UIVPROC)load("glUniform1uiv"); + glad_glUniform2uiv = (PFNGLUNIFORM2UIVPROC)load("glUniform2uiv"); + glad_glUniform3uiv = (PFNGLUNIFORM3UIVPROC)load("glUniform3uiv"); + glad_glUniform4uiv = (PFNGLUNIFORM4UIVPROC)load("glUniform4uiv"); + glad_glTexParameterIiv = (PFNGLTEXPARAMETERIIVPROC)load("glTexParameterIiv"); + glad_glTexParameterIuiv = (PFNGLTEXPARAMETERIUIVPROC)load("glTexParameterIuiv"); + glad_glGetTexParameterIiv = (PFNGLGETTEXPARAMETERIIVPROC)load("glGetTexParameterIiv"); + glad_glGetTexParameterIuiv = (PFNGLGETTEXPARAMETERIUIVPROC)load("glGetTexParameterIuiv"); + glad_glClearBufferiv = (PFNGLCLEARBUFFERIVPROC)load("glClearBufferiv"); + glad_glClearBufferuiv = (PFNGLCLEARBUFFERUIVPROC)load("glClearBufferuiv"); + glad_glClearBufferfv = (PFNGLCLEARBUFFERFVPROC)load("glClearBufferfv"); + glad_glClearBufferfi = (PFNGLCLEARBUFFERFIPROC)load("glClearBufferfi"); + glad_glGetStringi = (PFNGLGETSTRINGIPROC)load("glGetStringi"); + glad_glIsRenderbuffer = (PFNGLISRENDERBUFFERPROC)load("glIsRenderbuffer"); + glad_glBindRenderbuffer = (PFNGLBINDRENDERBUFFERPROC)load("glBindRenderbuffer"); + glad_glDeleteRenderbuffers = (PFNGLDELETERENDERBUFFERSPROC)load("glDeleteRenderbuffers"); + glad_glGenRenderbuffers = (PFNGLGENRENDERBUFFERSPROC)load("glGenRenderbuffers"); + glad_glRenderbufferStorage = (PFNGLRENDERBUFFERSTORAGEPROC)load("glRenderbufferStorage"); + glad_glGetRenderbufferParameteriv = (PFNGLGETRENDERBUFFERPARAMETERIVPROC)load("glGetRenderbufferParameteriv"); + glad_glIsFramebuffer = (PFNGLISFRAMEBUFFERPROC)load("glIsFramebuffer"); + glad_glBindFramebuffer = (PFNGLBINDFRAMEBUFFERPROC)load("glBindFramebuffer"); + glad_glDeleteFramebuffers = (PFNGLDELETEFRAMEBUFFERSPROC)load("glDeleteFramebuffers"); + glad_glGenFramebuffers = (PFNGLGENFRAMEBUFFERSPROC)load("glGenFramebuffers"); + glad_glCheckFramebufferStatus = (PFNGLCHECKFRAMEBUFFERSTATUSPROC)load("glCheckFramebufferStatus"); + glad_glFramebufferTexture1D = (PFNGLFRAMEBUFFERTEXTURE1DPROC)load("glFramebufferTexture1D"); + glad_glFramebufferTexture2D = (PFNGLFRAMEBUFFERTEXTURE2DPROC)load("glFramebufferTexture2D"); + glad_glFramebufferTexture3D = (PFNGLFRAMEBUFFERTEXTURE3DPROC)load("glFramebufferTexture3D"); + glad_glFramebufferRenderbuffer = (PFNGLFRAMEBUFFERRENDERBUFFERPROC)load("glFramebufferRenderbuffer"); + glad_glGetFramebufferAttachmentParameteriv = (PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVPROC)load("glGetFramebufferAttachmentParameteriv"); + glad_glGenerateMipmap = (PFNGLGENERATEMIPMAPPROC)load("glGenerateMipmap"); + glad_glBlitFramebuffer = (PFNGLBLITFRAMEBUFFERPROC)load("glBlitFramebuffer"); + glad_glRenderbufferStorageMultisample = (PFNGLRENDERBUFFERSTORAGEMULTISAMPLEPROC)load("glRenderbufferStorageMultisample"); + glad_glFramebufferTextureLayer = (PFNGLFRAMEBUFFERTEXTURELAYERPROC)load("glFramebufferTextureLayer"); + glad_glMapBufferRange = (PFNGLMAPBUFFERRANGEPROC)load("glMapBufferRange"); + glad_glFlushMappedBufferRange = (PFNGLFLUSHMAPPEDBUFFERRANGEPROC)load("glFlushMappedBufferRange"); + glad_glBindVertexArray = (PFNGLBINDVERTEXARRAYPROC)load("glBindVertexArray"); + glad_glDeleteVertexArrays = (PFNGLDELETEVERTEXARRAYSPROC)load("glDeleteVertexArrays"); + glad_glGenVertexArrays = (PFNGLGENVERTEXARRAYSPROC)load("glGenVertexArrays"); + glad_glIsVertexArray = (PFNGLISVERTEXARRAYPROC)load("glIsVertexArray"); +} +static void load_GL_VERSION_3_1(GLADloadproc load) { + if(!GLAD_GL_VERSION_3_1) return; + glad_glDrawArraysInstanced = (PFNGLDRAWARRAYSINSTANCEDPROC)load("glDrawArraysInstanced"); + glad_glDrawElementsInstanced = (PFNGLDRAWELEMENTSINSTANCEDPROC)load("glDrawElementsInstanced"); + glad_glTexBuffer = (PFNGLTEXBUFFERPROC)load("glTexBuffer"); + glad_glPrimitiveRestartIndex = (PFNGLPRIMITIVERESTARTINDEXPROC)load("glPrimitiveRestartIndex"); + glad_glCopyBufferSubData = (PFNGLCOPYBUFFERSUBDATAPROC)load("glCopyBufferSubData"); + glad_glGetUniformIndices = (PFNGLGETUNIFORMINDICESPROC)load("glGetUniformIndices"); + glad_glGetActiveUniformsiv = (PFNGLGETACTIVEUNIFORMSIVPROC)load("glGetActiveUniformsiv"); + glad_glGetActiveUniformName = (PFNGLGETACTIVEUNIFORMNAMEPROC)load("glGetActiveUniformName"); + glad_glGetUniformBlockIndex = (PFNGLGETUNIFORMBLOCKINDEXPROC)load("glGetUniformBlockIndex"); + glad_glGetActiveUniformBlockiv = (PFNGLGETACTIVEUNIFORMBLOCKIVPROC)load("glGetActiveUniformBlockiv"); + glad_glGetActiveUniformBlockName = (PFNGLGETACTIVEUNIFORMBLOCKNAMEPROC)load("glGetActiveUniformBlockName"); + glad_glUniformBlockBinding = (PFNGLUNIFORMBLOCKBINDINGPROC)load("glUniformBlockBinding"); + glad_glBindBufferRange = (PFNGLBINDBUFFERRANGEPROC)load("glBindBufferRange"); + glad_glBindBufferBase = (PFNGLBINDBUFFERBASEPROC)load("glBindBufferBase"); + glad_glGetIntegeri_v = (PFNGLGETINTEGERI_VPROC)load("glGetIntegeri_v"); +} +static void load_GL_VERSION_3_2(GLADloadproc load) { + if(!GLAD_GL_VERSION_3_2) return; + glad_glDrawElementsBaseVertex = (PFNGLDRAWELEMENTSBASEVERTEXPROC)load("glDrawElementsBaseVertex"); + glad_glDrawRangeElementsBaseVertex = (PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC)load("glDrawRangeElementsBaseVertex"); + glad_glDrawElementsInstancedBaseVertex = (PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC)load("glDrawElementsInstancedBaseVertex"); + glad_glMultiDrawElementsBaseVertex = (PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC)load("glMultiDrawElementsBaseVertex"); + glad_glProvokingVertex = (PFNGLPROVOKINGVERTEXPROC)load("glProvokingVertex"); + glad_glFenceSync = (PFNGLFENCESYNCPROC)load("glFenceSync"); + glad_glIsSync = (PFNGLISSYNCPROC)load("glIsSync"); + glad_glDeleteSync = (PFNGLDELETESYNCPROC)load("glDeleteSync"); + glad_glClientWaitSync = (PFNGLCLIENTWAITSYNCPROC)load("glClientWaitSync"); + glad_glWaitSync = (PFNGLWAITSYNCPROC)load("glWaitSync"); + glad_glGetInteger64v = (PFNGLGETINTEGER64VPROC)load("glGetInteger64v"); + glad_glGetSynciv = (PFNGLGETSYNCIVPROC)load("glGetSynciv"); + glad_glGetInteger64i_v = (PFNGLGETINTEGER64I_VPROC)load("glGetInteger64i_v"); + glad_glGetBufferParameteri64v = (PFNGLGETBUFFERPARAMETERI64VPROC)load("glGetBufferParameteri64v"); + glad_glFramebufferTexture = (PFNGLFRAMEBUFFERTEXTUREPROC)load("glFramebufferTexture"); + glad_glTexImage2DMultisample = (PFNGLTEXIMAGE2DMULTISAMPLEPROC)load("glTexImage2DMultisample"); + glad_glTexImage3DMultisample = (PFNGLTEXIMAGE3DMULTISAMPLEPROC)load("glTexImage3DMultisample"); + glad_glGetMultisamplefv = (PFNGLGETMULTISAMPLEFVPROC)load("glGetMultisamplefv"); + glad_glSampleMaski = (PFNGLSAMPLEMASKIPROC)load("glSampleMaski"); +} +static void load_GL_ARB_multisample(GLADloadproc load) { + if(!GLAD_GL_ARB_multisample) return; + glad_glSampleCoverageARB = (PFNGLSAMPLECOVERAGEARBPROC)load("glSampleCoverageARB"); +} +static void load_GL_ARB_robustness(GLADloadproc load) { + if(!GLAD_GL_ARB_robustness) return; + glad_glGetGraphicsResetStatusARB = (PFNGLGETGRAPHICSRESETSTATUSARBPROC)load("glGetGraphicsResetStatusARB"); + glad_glGetnTexImageARB = (PFNGLGETNTEXIMAGEARBPROC)load("glGetnTexImageARB"); + glad_glReadnPixelsARB = (PFNGLREADNPIXELSARBPROC)load("glReadnPixelsARB"); + glad_glGetnCompressedTexImageARB = (PFNGLGETNCOMPRESSEDTEXIMAGEARBPROC)load("glGetnCompressedTexImageARB"); + glad_glGetnUniformfvARB = (PFNGLGETNUNIFORMFVARBPROC)load("glGetnUniformfvARB"); + glad_glGetnUniformivARB = (PFNGLGETNUNIFORMIVARBPROC)load("glGetnUniformivARB"); + glad_glGetnUniformuivARB = (PFNGLGETNUNIFORMUIVARBPROC)load("glGetnUniformuivARB"); + glad_glGetnUniformdvARB = (PFNGLGETNUNIFORMDVARBPROC)load("glGetnUniformdvARB"); + glad_glGetnMapdvARB = (PFNGLGETNMAPDVARBPROC)load("glGetnMapdvARB"); + glad_glGetnMapfvARB = (PFNGLGETNMAPFVARBPROC)load("glGetnMapfvARB"); + glad_glGetnMapivARB = (PFNGLGETNMAPIVARBPROC)load("glGetnMapivARB"); + glad_glGetnPixelMapfvARB = (PFNGLGETNPIXELMAPFVARBPROC)load("glGetnPixelMapfvARB"); + glad_glGetnPixelMapuivARB = (PFNGLGETNPIXELMAPUIVARBPROC)load("glGetnPixelMapuivARB"); + glad_glGetnPixelMapusvARB = (PFNGLGETNPIXELMAPUSVARBPROC)load("glGetnPixelMapusvARB"); + glad_glGetnPolygonStippleARB = (PFNGLGETNPOLYGONSTIPPLEARBPROC)load("glGetnPolygonStippleARB"); + glad_glGetnColorTableARB = (PFNGLGETNCOLORTABLEARBPROC)load("glGetnColorTableARB"); + glad_glGetnConvolutionFilterARB = (PFNGLGETNCONVOLUTIONFILTERARBPROC)load("glGetnConvolutionFilterARB"); + glad_glGetnSeparableFilterARB = (PFNGLGETNSEPARABLEFILTERARBPROC)load("glGetnSeparableFilterARB"); + glad_glGetnHistogramARB = (PFNGLGETNHISTOGRAMARBPROC)load("glGetnHistogramARB"); + glad_glGetnMinmaxARB = (PFNGLGETNMINMAXARBPROC)load("glGetnMinmaxARB"); +} +static void load_GL_KHR_debug(GLADloadproc load) { + if(!GLAD_GL_KHR_debug) return; + glad_glDebugMessageControl = (PFNGLDEBUGMESSAGECONTROLPROC)load("glDebugMessageControl"); + glad_glDebugMessageInsert = (PFNGLDEBUGMESSAGEINSERTPROC)load("glDebugMessageInsert"); + glad_glDebugMessageCallback = (PFNGLDEBUGMESSAGECALLBACKPROC)load("glDebugMessageCallback"); + glad_glGetDebugMessageLog = (PFNGLGETDEBUGMESSAGELOGPROC)load("glGetDebugMessageLog"); + glad_glPushDebugGroup = (PFNGLPUSHDEBUGGROUPPROC)load("glPushDebugGroup"); + glad_glPopDebugGroup = (PFNGLPOPDEBUGGROUPPROC)load("glPopDebugGroup"); + glad_glObjectLabel = (PFNGLOBJECTLABELPROC)load("glObjectLabel"); + glad_glGetObjectLabel = (PFNGLGETOBJECTLABELPROC)load("glGetObjectLabel"); + glad_glObjectPtrLabel = (PFNGLOBJECTPTRLABELPROC)load("glObjectPtrLabel"); + glad_glGetObjectPtrLabel = (PFNGLGETOBJECTPTRLABELPROC)load("glGetObjectPtrLabel"); + glad_glGetPointerv = (PFNGLGETPOINTERVPROC)load("glGetPointerv"); + glad_glDebugMessageControlKHR = (PFNGLDEBUGMESSAGECONTROLKHRPROC)load("glDebugMessageControlKHR"); + glad_glDebugMessageInsertKHR = (PFNGLDEBUGMESSAGEINSERTKHRPROC)load("glDebugMessageInsertKHR"); + glad_glDebugMessageCallbackKHR = (PFNGLDEBUGMESSAGECALLBACKKHRPROC)load("glDebugMessageCallbackKHR"); + glad_glGetDebugMessageLogKHR = (PFNGLGETDEBUGMESSAGELOGKHRPROC)load("glGetDebugMessageLogKHR"); + glad_glPushDebugGroupKHR = (PFNGLPUSHDEBUGGROUPKHRPROC)load("glPushDebugGroupKHR"); + glad_glPopDebugGroupKHR = (PFNGLPOPDEBUGGROUPKHRPROC)load("glPopDebugGroupKHR"); + glad_glObjectLabelKHR = (PFNGLOBJECTLABELKHRPROC)load("glObjectLabelKHR"); + glad_glGetObjectLabelKHR = (PFNGLGETOBJECTLABELKHRPROC)load("glGetObjectLabelKHR"); + glad_glObjectPtrLabelKHR = (PFNGLOBJECTPTRLABELKHRPROC)load("glObjectPtrLabelKHR"); + glad_glGetObjectPtrLabelKHR = (PFNGLGETOBJECTPTRLABELKHRPROC)load("glGetObjectPtrLabelKHR"); + glad_glGetPointervKHR = (PFNGLGETPOINTERVKHRPROC)load("glGetPointervKHR"); +} +static int find_extensionsGL(void) { + if (!get_exts()) return 0; + GLAD_GL_ARB_multisample = has_ext("GL_ARB_multisample"); + GLAD_GL_ARB_robustness = has_ext("GL_ARB_robustness"); + GLAD_GL_KHR_debug = has_ext("GL_KHR_debug"); + free_exts(); + return 1; +} + +static void find_coreGL(void) { + + /* Thank you @elmindreda + * https://github.com/elmindreda/greg/blob/master/templates/greg.c.in#L176 + * https://github.com/glfw/glfw/blob/master/src/context.c#L36 + */ + int i, major, minor; + + const char* version; + const char* prefixes[] = { + "OpenGL ES-CM ", + "OpenGL ES-CL ", + "OpenGL ES ", + NULL + }; + + version = (const char*) glGetString(GL_VERSION); + if (!version) return; + + for (i = 0; prefixes[i]; i++) { + const size_t length = strlen(prefixes[i]); + if (strncmp(version, prefixes[i], length) == 0) { + version += length; + break; + } + } + +/* PR #18 */ +#ifdef _MSC_VER + sscanf_s(version, "%d.%d", &major, &minor); +#else + sscanf(version, "%d.%d", &major, &minor); +#endif + + GLVersion.major = major; GLVersion.minor = minor; + max_loaded_major = major; max_loaded_minor = minor; + GLAD_GL_VERSION_1_0 = (major == 1 && minor >= 0) || major > 1; + GLAD_GL_VERSION_1_1 = (major == 1 && minor >= 1) || major > 1; + GLAD_GL_VERSION_1_2 = (major == 1 && minor >= 2) || major > 1; + GLAD_GL_VERSION_1_3 = (major == 1 && minor >= 3) || major > 1; + GLAD_GL_VERSION_1_4 = (major == 1 && minor >= 4) || major > 1; + GLAD_GL_VERSION_1_5 = (major == 1 && minor >= 5) || major > 1; + GLAD_GL_VERSION_2_0 = (major == 2 && minor >= 0) || major > 2; + GLAD_GL_VERSION_2_1 = (major == 2 && minor >= 1) || major > 2; + GLAD_GL_VERSION_3_0 = (major == 3 && minor >= 0) || major > 3; + GLAD_GL_VERSION_3_1 = (major == 3 && minor >= 1) || major > 3; + GLAD_GL_VERSION_3_2 = (major == 3 && minor >= 2) || major > 3; + if (GLVersion.major > 3 || (GLVersion.major >= 3 && GLVersion.minor >= 2)) { + max_loaded_major = 3; + max_loaded_minor = 2; + } +} + +int gladLoadGLLoader(GLADloadproc load) { + GLVersion.major = 0; GLVersion.minor = 0; + glGetString = (PFNGLGETSTRINGPROC)load("glGetString"); + if(glGetString == NULL) return 0; + if(glGetString(GL_VERSION) == NULL) return 0; + find_coreGL(); + load_GL_VERSION_1_0(load); + load_GL_VERSION_1_1(load); + load_GL_VERSION_1_2(load); + load_GL_VERSION_1_3(load); + load_GL_VERSION_1_4(load); + load_GL_VERSION_1_5(load); + load_GL_VERSION_2_0(load); + load_GL_VERSION_2_1(load); + load_GL_VERSION_3_0(load); + load_GL_VERSION_3_1(load); + load_GL_VERSION_3_2(load); + + if (!find_extensionsGL()) return 0; + load_GL_ARB_multisample(load); + load_GL_ARB_robustness(load); + load_GL_KHR_debug(load); + return GLVersion.major != 0 || GLVersion.minor != 0; +} + diff --git a/src/external/glfw/deps/glad/glad.h b/src/external/glfw/deps/glad/glad.h new file mode 100644 index 000000000..7d81e98ed --- /dev/null +++ b/src/external/glfw/deps/glad/glad.h @@ -0,0 +1,3680 @@ +/* + + OpenGL loader generated by glad 0.1.12a0 on Fri Sep 23 13:36:15 2016. + + Language/Generator: C/C++ + Specification: gl + APIs: gl=3.2 + Profile: compatibility + Extensions: + GL_ARB_multisample, + GL_ARB_robustness, + GL_KHR_debug + Loader: False + Local files: False + Omit khrplatform: False + + Commandline: + --profile="compatibility" --api="gl=3.2" --generator="c" --spec="gl" --no-loader --extensions="GL_ARB_multisample,GL_ARB_robustness,GL_KHR_debug" + Online: + http://glad.dav1d.de/#profile=compatibility&language=c&specification=gl&api=gl%3D3.2&extensions=GL_ARB_multisample&extensions=GL_ARB_robustness&extensions=GL_KHR_debug +*/ + + +#ifndef __glad_h_ +#define __glad_h_ + +#ifdef __gl_h_ +#error OpenGL header already included, remove this include, glad already provides it +#endif +#define __gl_h_ + +#if defined(_WIN32) && !defined(APIENTRY) && !defined(__CYGWIN__) && !defined(__SCITECH_SNAP__) +#ifndef WIN32_LEAN_AND_MEAN +#define WIN32_LEAN_AND_MEAN 1 +#endif +#include +#endif + +#ifndef APIENTRY +#define APIENTRY +#endif +#ifndef APIENTRYP +#define APIENTRYP APIENTRY * +#endif + +#ifdef __cplusplus +extern "C" { +#endif + +struct gladGLversionStruct { + int major; + int minor; +}; + +typedef void* (* GLADloadproc)(const char *name); + +#ifndef GLAPI +# if defined(GLAD_GLAPI_EXPORT) +# if defined(WIN32) || defined(__CYGWIN__) +# if defined(GLAD_GLAPI_EXPORT_BUILD) +# if defined(__GNUC__) +# define GLAPI __attribute__ ((dllexport)) extern +# else +# define GLAPI __declspec(dllexport) extern +# endif +# else +# if defined(__GNUC__) +# define GLAPI __attribute__ ((dllimport)) extern +# else +# define GLAPI __declspec(dllimport) extern +# endif +# endif +# elif defined(__GNUC__) && defined(GLAD_GLAPI_EXPORT_BUILD) +# define GLAPI __attribute__ ((visibility ("default"))) extern +# else +# define GLAPI extern +# endif +# else +# define GLAPI extern +# endif +#endif + +GLAPI struct gladGLversionStruct GLVersion; +GLAPI int gladLoadGLLoader(GLADloadproc); + +#include +#include +#ifndef GLEXT_64_TYPES_DEFINED +/* This code block is duplicated in glxext.h, so must be protected */ +#define GLEXT_64_TYPES_DEFINED +/* Define int32_t, int64_t, and uint64_t types for UST/MSC */ +/* (as used in the GL_EXT_timer_query extension). */ +#if defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L +#include +#elif defined(__sun__) || defined(__digital__) +#include +#if defined(__STDC__) +#if defined(__arch64__) || defined(_LP64) +typedef long int int64_t; +typedef unsigned long int uint64_t; +#else +typedef long long int int64_t; +typedef unsigned long long int uint64_t; +#endif /* __arch64__ */ +#endif /* __STDC__ */ +#elif defined( __VMS ) || defined(__sgi) +#include +#elif defined(__SCO__) || defined(__USLC__) +#include +#elif defined(__UNIXOS2__) || defined(__SOL64__) +typedef long int int32_t; +typedef long long int int64_t; +typedef unsigned long long int uint64_t; +#elif defined(_WIN32) && defined(__GNUC__) +#include +#elif defined(_WIN32) +typedef __int32 int32_t; +typedef __int64 int64_t; +typedef unsigned __int64 uint64_t; +#else +/* Fallback if nothing above works */ +#include +#endif +#endif +typedef unsigned int GLenum; +typedef unsigned char GLboolean; +typedef unsigned int GLbitfield; +typedef void GLvoid; +typedef signed char GLbyte; +typedef short GLshort; +typedef int GLint; +typedef int GLclampx; +typedef unsigned char GLubyte; +typedef unsigned short GLushort; +typedef unsigned int GLuint; +typedef int GLsizei; +typedef float GLfloat; +typedef float GLclampf; +typedef double GLdouble; +typedef double GLclampd; +typedef void *GLeglImageOES; +typedef char GLchar; +typedef char GLcharARB; +#ifdef __APPLE__ +typedef void *GLhandleARB; +#else +typedef unsigned int GLhandleARB; +#endif +typedef unsigned short GLhalfARB; +typedef unsigned short GLhalf; +typedef GLint GLfixed; +typedef ptrdiff_t GLintptr; +typedef ptrdiff_t GLsizeiptr; +typedef int64_t GLint64; +typedef uint64_t GLuint64; +typedef ptrdiff_t GLintptrARB; +typedef ptrdiff_t GLsizeiptrARB; +typedef int64_t GLint64EXT; +typedef uint64_t GLuint64EXT; +typedef struct __GLsync *GLsync; +struct _cl_context; +struct _cl_event; +typedef void (APIENTRY *GLDEBUGPROC)(GLenum source,GLenum type,GLuint id,GLenum severity,GLsizei length,const GLchar *message,const void *userParam); +typedef void (APIENTRY *GLDEBUGPROCARB)(GLenum source,GLenum type,GLuint id,GLenum severity,GLsizei length,const GLchar *message,const void *userParam); +typedef void (APIENTRY *GLDEBUGPROCKHR)(GLenum source,GLenum type,GLuint id,GLenum severity,GLsizei length,const GLchar *message,const void *userParam); +typedef void (APIENTRY *GLDEBUGPROCAMD)(GLuint id,GLenum category,GLenum severity,GLsizei length,const GLchar *message,void *userParam); +typedef unsigned short GLhalfNV; +typedef GLintptr GLvdpauSurfaceNV; +#define GL_DEPTH_BUFFER_BIT 0x00000100 +#define GL_STENCIL_BUFFER_BIT 0x00000400 +#define GL_COLOR_BUFFER_BIT 0x00004000 +#define GL_FALSE 0 +#define GL_TRUE 1 +#define GL_POINTS 0x0000 +#define GL_LINES 0x0001 +#define GL_LINE_LOOP 0x0002 +#define GL_LINE_STRIP 0x0003 +#define GL_TRIANGLES 0x0004 +#define GL_TRIANGLE_STRIP 0x0005 +#define GL_TRIANGLE_FAN 0x0006 +#define GL_QUADS 0x0007 +#define GL_NEVER 0x0200 +#define GL_LESS 0x0201 +#define GL_EQUAL 0x0202 +#define GL_LEQUAL 0x0203 +#define GL_GREATER 0x0204 +#define GL_NOTEQUAL 0x0205 +#define GL_GEQUAL 0x0206 +#define GL_ALWAYS 0x0207 +#define GL_ZERO 0 +#define GL_ONE 1 +#define GL_SRC_COLOR 0x0300 +#define GL_ONE_MINUS_SRC_COLOR 0x0301 +#define GL_SRC_ALPHA 0x0302 +#define GL_ONE_MINUS_SRC_ALPHA 0x0303 +#define GL_DST_ALPHA 0x0304 +#define GL_ONE_MINUS_DST_ALPHA 0x0305 +#define GL_DST_COLOR 0x0306 +#define GL_ONE_MINUS_DST_COLOR 0x0307 +#define GL_SRC_ALPHA_SATURATE 0x0308 +#define GL_NONE 0 +#define GL_FRONT_LEFT 0x0400 +#define GL_FRONT_RIGHT 0x0401 +#define GL_BACK_LEFT 0x0402 +#define GL_BACK_RIGHT 0x0403 +#define GL_FRONT 0x0404 +#define GL_BACK 0x0405 +#define GL_LEFT 0x0406 +#define GL_RIGHT 0x0407 +#define GL_FRONT_AND_BACK 0x0408 +#define GL_NO_ERROR 0 +#define GL_INVALID_ENUM 0x0500 +#define GL_INVALID_VALUE 0x0501 +#define GL_INVALID_OPERATION 0x0502 +#define GL_OUT_OF_MEMORY 0x0505 +#define GL_CW 0x0900 +#define GL_CCW 0x0901 +#define GL_POINT_SIZE 0x0B11 +#define GL_POINT_SIZE_RANGE 0x0B12 +#define GL_POINT_SIZE_GRANULARITY 0x0B13 +#define GL_LINE_SMOOTH 0x0B20 +#define GL_LINE_WIDTH 0x0B21 +#define GL_LINE_WIDTH_RANGE 0x0B22 +#define GL_LINE_WIDTH_GRANULARITY 0x0B23 +#define GL_POLYGON_MODE 0x0B40 +#define GL_POLYGON_SMOOTH 0x0B41 +#define GL_CULL_FACE 0x0B44 +#define GL_CULL_FACE_MODE 0x0B45 +#define GL_FRONT_FACE 0x0B46 +#define GL_DEPTH_RANGE 0x0B70 +#define GL_DEPTH_TEST 0x0B71 +#define GL_DEPTH_WRITEMASK 0x0B72 +#define GL_DEPTH_CLEAR_VALUE 0x0B73 +#define GL_DEPTH_FUNC 0x0B74 +#define GL_STENCIL_TEST 0x0B90 +#define GL_STENCIL_CLEAR_VALUE 0x0B91 +#define GL_STENCIL_FUNC 0x0B92 +#define GL_STENCIL_VALUE_MASK 0x0B93 +#define GL_STENCIL_FAIL 0x0B94 +#define GL_STENCIL_PASS_DEPTH_FAIL 0x0B95 +#define GL_STENCIL_PASS_DEPTH_PASS 0x0B96 +#define GL_STENCIL_REF 0x0B97 +#define GL_STENCIL_WRITEMASK 0x0B98 +#define GL_VIEWPORT 0x0BA2 +#define GL_DITHER 0x0BD0 +#define GL_BLEND_DST 0x0BE0 +#define GL_BLEND_SRC 0x0BE1 +#define GL_BLEND 0x0BE2 +#define GL_LOGIC_OP_MODE 0x0BF0 +#define GL_COLOR_LOGIC_OP 0x0BF2 +#define GL_DRAW_BUFFER 0x0C01 +#define GL_READ_BUFFER 0x0C02 +#define GL_SCISSOR_BOX 0x0C10 +#define GL_SCISSOR_TEST 0x0C11 +#define GL_COLOR_CLEAR_VALUE 0x0C22 +#define GL_COLOR_WRITEMASK 0x0C23 +#define GL_DOUBLEBUFFER 0x0C32 +#define GL_STEREO 0x0C33 +#define GL_LINE_SMOOTH_HINT 0x0C52 +#define GL_POLYGON_SMOOTH_HINT 0x0C53 +#define GL_UNPACK_SWAP_BYTES 0x0CF0 +#define GL_UNPACK_LSB_FIRST 0x0CF1 +#define GL_UNPACK_ROW_LENGTH 0x0CF2 +#define GL_UNPACK_SKIP_ROWS 0x0CF3 +#define GL_UNPACK_SKIP_PIXELS 0x0CF4 +#define GL_UNPACK_ALIGNMENT 0x0CF5 +#define GL_PACK_SWAP_BYTES 0x0D00 +#define GL_PACK_LSB_FIRST 0x0D01 +#define GL_PACK_ROW_LENGTH 0x0D02 +#define GL_PACK_SKIP_ROWS 0x0D03 +#define GL_PACK_SKIP_PIXELS 0x0D04 +#define GL_PACK_ALIGNMENT 0x0D05 +#define GL_MAX_TEXTURE_SIZE 0x0D33 +#define GL_MAX_VIEWPORT_DIMS 0x0D3A +#define GL_SUBPIXEL_BITS 0x0D50 +#define GL_TEXTURE_1D 0x0DE0 +#define GL_TEXTURE_2D 0x0DE1 +#define GL_POLYGON_OFFSET_UNITS 0x2A00 +#define GL_POLYGON_OFFSET_POINT 0x2A01 +#define GL_POLYGON_OFFSET_LINE 0x2A02 +#define GL_POLYGON_OFFSET_FILL 0x8037 +#define GL_POLYGON_OFFSET_FACTOR 0x8038 +#define GL_TEXTURE_BINDING_1D 0x8068 +#define GL_TEXTURE_BINDING_2D 0x8069 +#define GL_TEXTURE_WIDTH 0x1000 +#define GL_TEXTURE_HEIGHT 0x1001 +#define GL_TEXTURE_INTERNAL_FORMAT 0x1003 +#define GL_TEXTURE_BORDER_COLOR 0x1004 +#define GL_TEXTURE_RED_SIZE 0x805C +#define GL_TEXTURE_GREEN_SIZE 0x805D +#define GL_TEXTURE_BLUE_SIZE 0x805E +#define GL_TEXTURE_ALPHA_SIZE 0x805F +#define GL_DONT_CARE 0x1100 +#define GL_FASTEST 0x1101 +#define GL_NICEST 0x1102 +#define GL_BYTE 0x1400 +#define GL_UNSIGNED_BYTE 0x1401 +#define GL_SHORT 0x1402 +#define GL_UNSIGNED_SHORT 0x1403 +#define GL_INT 0x1404 +#define GL_UNSIGNED_INT 0x1405 +#define GL_FLOAT 0x1406 +#define GL_DOUBLE 0x140A +#define GL_STACK_OVERFLOW 0x0503 +#define GL_STACK_UNDERFLOW 0x0504 +#define GL_CLEAR 0x1500 +#define GL_AND 0x1501 +#define GL_AND_REVERSE 0x1502 +#define GL_COPY 0x1503 +#define GL_AND_INVERTED 0x1504 +#define GL_NOOP 0x1505 +#define GL_XOR 0x1506 +#define GL_OR 0x1507 +#define GL_NOR 0x1508 +#define GL_EQUIV 0x1509 +#define GL_INVERT 0x150A +#define GL_OR_REVERSE 0x150B +#define GL_COPY_INVERTED 0x150C +#define GL_OR_INVERTED 0x150D +#define GL_NAND 0x150E +#define GL_SET 0x150F +#define GL_TEXTURE 0x1702 +#define GL_COLOR 0x1800 +#define GL_DEPTH 0x1801 +#define GL_STENCIL 0x1802 +#define GL_STENCIL_INDEX 0x1901 +#define GL_DEPTH_COMPONENT 0x1902 +#define GL_RED 0x1903 +#define GL_GREEN 0x1904 +#define GL_BLUE 0x1905 +#define GL_ALPHA 0x1906 +#define GL_RGB 0x1907 +#define GL_RGBA 0x1908 +#define GL_POINT 0x1B00 +#define GL_LINE 0x1B01 +#define GL_FILL 0x1B02 +#define GL_KEEP 0x1E00 +#define GL_REPLACE 0x1E01 +#define GL_INCR 0x1E02 +#define GL_DECR 0x1E03 +#define GL_VENDOR 0x1F00 +#define GL_RENDERER 0x1F01 +#define GL_VERSION 0x1F02 +#define GL_EXTENSIONS 0x1F03 +#define GL_NEAREST 0x2600 +#define GL_LINEAR 0x2601 +#define GL_NEAREST_MIPMAP_NEAREST 0x2700 +#define GL_LINEAR_MIPMAP_NEAREST 0x2701 +#define GL_NEAREST_MIPMAP_LINEAR 0x2702 +#define GL_LINEAR_MIPMAP_LINEAR 0x2703 +#define GL_TEXTURE_MAG_FILTER 0x2800 +#define GL_TEXTURE_MIN_FILTER 0x2801 +#define GL_TEXTURE_WRAP_S 0x2802 +#define GL_TEXTURE_WRAP_T 0x2803 +#define GL_PROXY_TEXTURE_1D 0x8063 +#define GL_PROXY_TEXTURE_2D 0x8064 +#define GL_REPEAT 0x2901 +#define GL_R3_G3_B2 0x2A10 +#define GL_RGB4 0x804F +#define GL_RGB5 0x8050 +#define GL_RGB8 0x8051 +#define GL_RGB10 0x8052 +#define GL_RGB12 0x8053 +#define GL_RGB16 0x8054 +#define GL_RGBA2 0x8055 +#define GL_RGBA4 0x8056 +#define GL_RGB5_A1 0x8057 +#define GL_RGBA8 0x8058 +#define GL_RGB10_A2 0x8059 +#define GL_RGBA12 0x805A +#define GL_RGBA16 0x805B +#define GL_CURRENT_BIT 0x00000001 +#define GL_POINT_BIT 0x00000002 +#define GL_LINE_BIT 0x00000004 +#define GL_POLYGON_BIT 0x00000008 +#define GL_POLYGON_STIPPLE_BIT 0x00000010 +#define GL_PIXEL_MODE_BIT 0x00000020 +#define GL_LIGHTING_BIT 0x00000040 +#define GL_FOG_BIT 0x00000080 +#define GL_ACCUM_BUFFER_BIT 0x00000200 +#define GL_VIEWPORT_BIT 0x00000800 +#define GL_TRANSFORM_BIT 0x00001000 +#define GL_ENABLE_BIT 0x00002000 +#define GL_HINT_BIT 0x00008000 +#define GL_EVAL_BIT 0x00010000 +#define GL_LIST_BIT 0x00020000 +#define GL_TEXTURE_BIT 0x00040000 +#define GL_SCISSOR_BIT 0x00080000 +#define GL_ALL_ATTRIB_BITS 0xFFFFFFFF +#define GL_CLIENT_PIXEL_STORE_BIT 0x00000001 +#define GL_CLIENT_VERTEX_ARRAY_BIT 0x00000002 +#define GL_CLIENT_ALL_ATTRIB_BITS 0xFFFFFFFF +#define GL_QUAD_STRIP 0x0008 +#define GL_POLYGON 0x0009 +#define GL_ACCUM 0x0100 +#define GL_LOAD 0x0101 +#define GL_RETURN 0x0102 +#define GL_MULT 0x0103 +#define GL_ADD 0x0104 +#define GL_AUX0 0x0409 +#define GL_AUX1 0x040A +#define GL_AUX2 0x040B +#define GL_AUX3 0x040C +#define GL_2D 0x0600 +#define GL_3D 0x0601 +#define GL_3D_COLOR 0x0602 +#define GL_3D_COLOR_TEXTURE 0x0603 +#define GL_4D_COLOR_TEXTURE 0x0604 +#define GL_PASS_THROUGH_TOKEN 0x0700 +#define GL_POINT_TOKEN 0x0701 +#define GL_LINE_TOKEN 0x0702 +#define GL_POLYGON_TOKEN 0x0703 +#define GL_BITMAP_TOKEN 0x0704 +#define GL_DRAW_PIXEL_TOKEN 0x0705 +#define GL_COPY_PIXEL_TOKEN 0x0706 +#define GL_LINE_RESET_TOKEN 0x0707 +#define GL_EXP 0x0800 +#define GL_EXP2 0x0801 +#define GL_COEFF 0x0A00 +#define GL_ORDER 0x0A01 +#define GL_DOMAIN 0x0A02 +#define GL_PIXEL_MAP_I_TO_I 0x0C70 +#define GL_PIXEL_MAP_S_TO_S 0x0C71 +#define GL_PIXEL_MAP_I_TO_R 0x0C72 +#define GL_PIXEL_MAP_I_TO_G 0x0C73 +#define GL_PIXEL_MAP_I_TO_B 0x0C74 +#define GL_PIXEL_MAP_I_TO_A 0x0C75 +#define GL_PIXEL_MAP_R_TO_R 0x0C76 +#define GL_PIXEL_MAP_G_TO_G 0x0C77 +#define GL_PIXEL_MAP_B_TO_B 0x0C78 +#define GL_PIXEL_MAP_A_TO_A 0x0C79 +#define GL_VERTEX_ARRAY_POINTER 0x808E +#define GL_NORMAL_ARRAY_POINTER 0x808F +#define GL_COLOR_ARRAY_POINTER 0x8090 +#define GL_INDEX_ARRAY_POINTER 0x8091 +#define GL_TEXTURE_COORD_ARRAY_POINTER 0x8092 +#define GL_EDGE_FLAG_ARRAY_POINTER 0x8093 +#define GL_FEEDBACK_BUFFER_POINTER 0x0DF0 +#define GL_SELECTION_BUFFER_POINTER 0x0DF3 +#define GL_CURRENT_COLOR 0x0B00 +#define GL_CURRENT_INDEX 0x0B01 +#define GL_CURRENT_NORMAL 0x0B02 +#define GL_CURRENT_TEXTURE_COORDS 0x0B03 +#define GL_CURRENT_RASTER_COLOR 0x0B04 +#define GL_CURRENT_RASTER_INDEX 0x0B05 +#define GL_CURRENT_RASTER_TEXTURE_COORDS 0x0B06 +#define GL_CURRENT_RASTER_POSITION 0x0B07 +#define GL_CURRENT_RASTER_POSITION_VALID 0x0B08 +#define GL_CURRENT_RASTER_DISTANCE 0x0B09 +#define GL_POINT_SMOOTH 0x0B10 +#define GL_LINE_STIPPLE 0x0B24 +#define GL_LINE_STIPPLE_PATTERN 0x0B25 +#define GL_LINE_STIPPLE_REPEAT 0x0B26 +#define GL_LIST_MODE 0x0B30 +#define GL_MAX_LIST_NESTING 0x0B31 +#define GL_LIST_BASE 0x0B32 +#define GL_LIST_INDEX 0x0B33 +#define GL_POLYGON_STIPPLE 0x0B42 +#define GL_EDGE_FLAG 0x0B43 +#define GL_LIGHTING 0x0B50 +#define GL_LIGHT_MODEL_LOCAL_VIEWER 0x0B51 +#define GL_LIGHT_MODEL_TWO_SIDE 0x0B52 +#define GL_LIGHT_MODEL_AMBIENT 0x0B53 +#define GL_SHADE_MODEL 0x0B54 +#define GL_COLOR_MATERIAL_FACE 0x0B55 +#define GL_COLOR_MATERIAL_PARAMETER 0x0B56 +#define GL_COLOR_MATERIAL 0x0B57 +#define GL_FOG 0x0B60 +#define GL_FOG_INDEX 0x0B61 +#define GL_FOG_DENSITY 0x0B62 +#define GL_FOG_START 0x0B63 +#define GL_FOG_END 0x0B64 +#define GL_FOG_MODE 0x0B65 +#define GL_FOG_COLOR 0x0B66 +#define GL_ACCUM_CLEAR_VALUE 0x0B80 +#define GL_MATRIX_MODE 0x0BA0 +#define GL_NORMALIZE 0x0BA1 +#define GL_MODELVIEW_STACK_DEPTH 0x0BA3 +#define GL_PROJECTION_STACK_DEPTH 0x0BA4 +#define GL_TEXTURE_STACK_DEPTH 0x0BA5 +#define GL_MODELVIEW_MATRIX 0x0BA6 +#define GL_PROJECTION_MATRIX 0x0BA7 +#define GL_TEXTURE_MATRIX 0x0BA8 +#define GL_ATTRIB_STACK_DEPTH 0x0BB0 +#define GL_CLIENT_ATTRIB_STACK_DEPTH 0x0BB1 +#define GL_ALPHA_TEST 0x0BC0 +#define GL_ALPHA_TEST_FUNC 0x0BC1 +#define GL_ALPHA_TEST_REF 0x0BC2 +#define GL_INDEX_LOGIC_OP 0x0BF1 +#define GL_LOGIC_OP 0x0BF1 +#define GL_AUX_BUFFERS 0x0C00 +#define GL_INDEX_CLEAR_VALUE 0x0C20 +#define GL_INDEX_WRITEMASK 0x0C21 +#define GL_INDEX_MODE 0x0C30 +#define GL_RGBA_MODE 0x0C31 +#define GL_RENDER_MODE 0x0C40 +#define GL_PERSPECTIVE_CORRECTION_HINT 0x0C50 +#define GL_POINT_SMOOTH_HINT 0x0C51 +#define GL_FOG_HINT 0x0C54 +#define GL_TEXTURE_GEN_S 0x0C60 +#define GL_TEXTURE_GEN_T 0x0C61 +#define GL_TEXTURE_GEN_R 0x0C62 +#define GL_TEXTURE_GEN_Q 0x0C63 +#define GL_PIXEL_MAP_I_TO_I_SIZE 0x0CB0 +#define GL_PIXEL_MAP_S_TO_S_SIZE 0x0CB1 +#define GL_PIXEL_MAP_I_TO_R_SIZE 0x0CB2 +#define GL_PIXEL_MAP_I_TO_G_SIZE 0x0CB3 +#define GL_PIXEL_MAP_I_TO_B_SIZE 0x0CB4 +#define GL_PIXEL_MAP_I_TO_A_SIZE 0x0CB5 +#define GL_PIXEL_MAP_R_TO_R_SIZE 0x0CB6 +#define GL_PIXEL_MAP_G_TO_G_SIZE 0x0CB7 +#define GL_PIXEL_MAP_B_TO_B_SIZE 0x0CB8 +#define GL_PIXEL_MAP_A_TO_A_SIZE 0x0CB9 +#define GL_MAP_COLOR 0x0D10 +#define GL_MAP_STENCIL 0x0D11 +#define GL_INDEX_SHIFT 0x0D12 +#define GL_INDEX_OFFSET 0x0D13 +#define GL_RED_SCALE 0x0D14 +#define GL_RED_BIAS 0x0D15 +#define GL_ZOOM_X 0x0D16 +#define GL_ZOOM_Y 0x0D17 +#define GL_GREEN_SCALE 0x0D18 +#define GL_GREEN_BIAS 0x0D19 +#define GL_BLUE_SCALE 0x0D1A +#define GL_BLUE_BIAS 0x0D1B +#define GL_ALPHA_SCALE 0x0D1C +#define GL_ALPHA_BIAS 0x0D1D +#define GL_DEPTH_SCALE 0x0D1E +#define GL_DEPTH_BIAS 0x0D1F +#define GL_MAX_EVAL_ORDER 0x0D30 +#define GL_MAX_LIGHTS 0x0D31 +#define GL_MAX_CLIP_PLANES 0x0D32 +#define GL_MAX_PIXEL_MAP_TABLE 0x0D34 +#define GL_MAX_ATTRIB_STACK_DEPTH 0x0D35 +#define GL_MAX_MODELVIEW_STACK_DEPTH 0x0D36 +#define GL_MAX_NAME_STACK_DEPTH 0x0D37 +#define GL_MAX_PROJECTION_STACK_DEPTH 0x0D38 +#define GL_MAX_TEXTURE_STACK_DEPTH 0x0D39 +#define GL_MAX_CLIENT_ATTRIB_STACK_DEPTH 0x0D3B +#define GL_INDEX_BITS 0x0D51 +#define GL_RED_BITS 0x0D52 +#define GL_GREEN_BITS 0x0D53 +#define GL_BLUE_BITS 0x0D54 +#define GL_ALPHA_BITS 0x0D55 +#define GL_DEPTH_BITS 0x0D56 +#define GL_STENCIL_BITS 0x0D57 +#define GL_ACCUM_RED_BITS 0x0D58 +#define GL_ACCUM_GREEN_BITS 0x0D59 +#define GL_ACCUM_BLUE_BITS 0x0D5A +#define GL_ACCUM_ALPHA_BITS 0x0D5B +#define GL_NAME_STACK_DEPTH 0x0D70 +#define GL_AUTO_NORMAL 0x0D80 +#define GL_MAP1_COLOR_4 0x0D90 +#define GL_MAP1_INDEX 0x0D91 +#define GL_MAP1_NORMAL 0x0D92 +#define GL_MAP1_TEXTURE_COORD_1 0x0D93 +#define GL_MAP1_TEXTURE_COORD_2 0x0D94 +#define GL_MAP1_TEXTURE_COORD_3 0x0D95 +#define GL_MAP1_TEXTURE_COORD_4 0x0D96 +#define GL_MAP1_VERTEX_3 0x0D97 +#define GL_MAP1_VERTEX_4 0x0D98 +#define GL_MAP2_COLOR_4 0x0DB0 +#define GL_MAP2_INDEX 0x0DB1 +#define GL_MAP2_NORMAL 0x0DB2 +#define GL_MAP2_TEXTURE_COORD_1 0x0DB3 +#define GL_MAP2_TEXTURE_COORD_2 0x0DB4 +#define GL_MAP2_TEXTURE_COORD_3 0x0DB5 +#define GL_MAP2_TEXTURE_COORD_4 0x0DB6 +#define GL_MAP2_VERTEX_3 0x0DB7 +#define GL_MAP2_VERTEX_4 0x0DB8 +#define GL_MAP1_GRID_DOMAIN 0x0DD0 +#define GL_MAP1_GRID_SEGMENTS 0x0DD1 +#define GL_MAP2_GRID_DOMAIN 0x0DD2 +#define GL_MAP2_GRID_SEGMENTS 0x0DD3 +#define GL_FEEDBACK_BUFFER_SIZE 0x0DF1 +#define GL_FEEDBACK_BUFFER_TYPE 0x0DF2 +#define GL_SELECTION_BUFFER_SIZE 0x0DF4 +#define GL_VERTEX_ARRAY 0x8074 +#define GL_NORMAL_ARRAY 0x8075 +#define GL_COLOR_ARRAY 0x8076 +#define GL_INDEX_ARRAY 0x8077 +#define GL_TEXTURE_COORD_ARRAY 0x8078 +#define GL_EDGE_FLAG_ARRAY 0x8079 +#define GL_VERTEX_ARRAY_SIZE 0x807A +#define GL_VERTEX_ARRAY_TYPE 0x807B +#define GL_VERTEX_ARRAY_STRIDE 0x807C +#define GL_NORMAL_ARRAY_TYPE 0x807E +#define GL_NORMAL_ARRAY_STRIDE 0x807F +#define GL_COLOR_ARRAY_SIZE 0x8081 +#define GL_COLOR_ARRAY_TYPE 0x8082 +#define GL_COLOR_ARRAY_STRIDE 0x8083 +#define GL_INDEX_ARRAY_TYPE 0x8085 +#define GL_INDEX_ARRAY_STRIDE 0x8086 +#define GL_TEXTURE_COORD_ARRAY_SIZE 0x8088 +#define GL_TEXTURE_COORD_ARRAY_TYPE 0x8089 +#define GL_TEXTURE_COORD_ARRAY_STRIDE 0x808A +#define GL_EDGE_FLAG_ARRAY_STRIDE 0x808C +#define GL_TEXTURE_COMPONENTS 0x1003 +#define GL_TEXTURE_BORDER 0x1005 +#define GL_TEXTURE_LUMINANCE_SIZE 0x8060 +#define GL_TEXTURE_INTENSITY_SIZE 0x8061 +#define GL_TEXTURE_PRIORITY 0x8066 +#define GL_TEXTURE_RESIDENT 0x8067 +#define GL_AMBIENT 0x1200 +#define GL_DIFFUSE 0x1201 +#define GL_SPECULAR 0x1202 +#define GL_POSITION 0x1203 +#define GL_SPOT_DIRECTION 0x1204 +#define GL_SPOT_EXPONENT 0x1205 +#define GL_SPOT_CUTOFF 0x1206 +#define GL_CONSTANT_ATTENUATION 0x1207 +#define GL_LINEAR_ATTENUATION 0x1208 +#define GL_QUADRATIC_ATTENUATION 0x1209 +#define GL_COMPILE 0x1300 +#define GL_COMPILE_AND_EXECUTE 0x1301 +#define GL_2_BYTES 0x1407 +#define GL_3_BYTES 0x1408 +#define GL_4_BYTES 0x1409 +#define GL_EMISSION 0x1600 +#define GL_SHININESS 0x1601 +#define GL_AMBIENT_AND_DIFFUSE 0x1602 +#define GL_COLOR_INDEXES 0x1603 +#define GL_MODELVIEW 0x1700 +#define GL_PROJECTION 0x1701 +#define GL_COLOR_INDEX 0x1900 +#define GL_LUMINANCE 0x1909 +#define GL_LUMINANCE_ALPHA 0x190A +#define GL_BITMAP 0x1A00 +#define GL_RENDER 0x1C00 +#define GL_FEEDBACK 0x1C01 +#define GL_SELECT 0x1C02 +#define GL_FLAT 0x1D00 +#define GL_SMOOTH 0x1D01 +#define GL_S 0x2000 +#define GL_T 0x2001 +#define GL_R 0x2002 +#define GL_Q 0x2003 +#define GL_MODULATE 0x2100 +#define GL_DECAL 0x2101 +#define GL_TEXTURE_ENV_MODE 0x2200 +#define GL_TEXTURE_ENV_COLOR 0x2201 +#define GL_TEXTURE_ENV 0x2300 +#define GL_EYE_LINEAR 0x2400 +#define GL_OBJECT_LINEAR 0x2401 +#define GL_SPHERE_MAP 0x2402 +#define GL_TEXTURE_GEN_MODE 0x2500 +#define GL_OBJECT_PLANE 0x2501 +#define GL_EYE_PLANE 0x2502 +#define GL_CLAMP 0x2900 +#define GL_ALPHA4 0x803B +#define GL_ALPHA8 0x803C +#define GL_ALPHA12 0x803D +#define GL_ALPHA16 0x803E +#define GL_LUMINANCE4 0x803F +#define GL_LUMINANCE8 0x8040 +#define GL_LUMINANCE12 0x8041 +#define GL_LUMINANCE16 0x8042 +#define GL_LUMINANCE4_ALPHA4 0x8043 +#define GL_LUMINANCE6_ALPHA2 0x8044 +#define GL_LUMINANCE8_ALPHA8 0x8045 +#define GL_LUMINANCE12_ALPHA4 0x8046 +#define GL_LUMINANCE12_ALPHA12 0x8047 +#define GL_LUMINANCE16_ALPHA16 0x8048 +#define GL_INTENSITY 0x8049 +#define GL_INTENSITY4 0x804A +#define GL_INTENSITY8 0x804B +#define GL_INTENSITY12 0x804C +#define GL_INTENSITY16 0x804D +#define GL_V2F 0x2A20 +#define GL_V3F 0x2A21 +#define GL_C4UB_V2F 0x2A22 +#define GL_C4UB_V3F 0x2A23 +#define GL_C3F_V3F 0x2A24 +#define GL_N3F_V3F 0x2A25 +#define GL_C4F_N3F_V3F 0x2A26 +#define GL_T2F_V3F 0x2A27 +#define GL_T4F_V4F 0x2A28 +#define GL_T2F_C4UB_V3F 0x2A29 +#define GL_T2F_C3F_V3F 0x2A2A +#define GL_T2F_N3F_V3F 0x2A2B +#define GL_T2F_C4F_N3F_V3F 0x2A2C +#define GL_T4F_C4F_N3F_V4F 0x2A2D +#define GL_CLIP_PLANE0 0x3000 +#define GL_CLIP_PLANE1 0x3001 +#define GL_CLIP_PLANE2 0x3002 +#define GL_CLIP_PLANE3 0x3003 +#define GL_CLIP_PLANE4 0x3004 +#define GL_CLIP_PLANE5 0x3005 +#define GL_LIGHT0 0x4000 +#define GL_LIGHT1 0x4001 +#define GL_LIGHT2 0x4002 +#define GL_LIGHT3 0x4003 +#define GL_LIGHT4 0x4004 +#define GL_LIGHT5 0x4005 +#define GL_LIGHT6 0x4006 +#define GL_LIGHT7 0x4007 +#define GL_UNSIGNED_BYTE_3_3_2 0x8032 +#define GL_UNSIGNED_SHORT_4_4_4_4 0x8033 +#define GL_UNSIGNED_SHORT_5_5_5_1 0x8034 +#define GL_UNSIGNED_INT_8_8_8_8 0x8035 +#define GL_UNSIGNED_INT_10_10_10_2 0x8036 +#define GL_TEXTURE_BINDING_3D 0x806A +#define GL_PACK_SKIP_IMAGES 0x806B +#define GL_PACK_IMAGE_HEIGHT 0x806C +#define GL_UNPACK_SKIP_IMAGES 0x806D +#define GL_UNPACK_IMAGE_HEIGHT 0x806E +#define GL_TEXTURE_3D 0x806F +#define GL_PROXY_TEXTURE_3D 0x8070 +#define GL_TEXTURE_DEPTH 0x8071 +#define GL_TEXTURE_WRAP_R 0x8072 +#define GL_MAX_3D_TEXTURE_SIZE 0x8073 +#define GL_UNSIGNED_BYTE_2_3_3_REV 0x8362 +#define GL_UNSIGNED_SHORT_5_6_5 0x8363 +#define GL_UNSIGNED_SHORT_5_6_5_REV 0x8364 +#define GL_UNSIGNED_SHORT_4_4_4_4_REV 0x8365 +#define GL_UNSIGNED_SHORT_1_5_5_5_REV 0x8366 +#define GL_UNSIGNED_INT_8_8_8_8_REV 0x8367 +#define GL_UNSIGNED_INT_2_10_10_10_REV 0x8368 +#define GL_BGR 0x80E0 +#define GL_BGRA 0x80E1 +#define GL_MAX_ELEMENTS_VERTICES 0x80E8 +#define GL_MAX_ELEMENTS_INDICES 0x80E9 +#define GL_CLAMP_TO_EDGE 0x812F +#define GL_TEXTURE_MIN_LOD 0x813A +#define GL_TEXTURE_MAX_LOD 0x813B +#define GL_TEXTURE_BASE_LEVEL 0x813C +#define GL_TEXTURE_MAX_LEVEL 0x813D +#define GL_SMOOTH_POINT_SIZE_RANGE 0x0B12 +#define GL_SMOOTH_POINT_SIZE_GRANULARITY 0x0B13 +#define GL_SMOOTH_LINE_WIDTH_RANGE 0x0B22 +#define GL_SMOOTH_LINE_WIDTH_GRANULARITY 0x0B23 +#define GL_ALIASED_LINE_WIDTH_RANGE 0x846E +#define GL_RESCALE_NORMAL 0x803A +#define GL_LIGHT_MODEL_COLOR_CONTROL 0x81F8 +#define GL_SINGLE_COLOR 0x81F9 +#define GL_SEPARATE_SPECULAR_COLOR 0x81FA +#define GL_ALIASED_POINT_SIZE_RANGE 0x846D +#define GL_TEXTURE0 0x84C0 +#define GL_TEXTURE1 0x84C1 +#define GL_TEXTURE2 0x84C2 +#define GL_TEXTURE3 0x84C3 +#define GL_TEXTURE4 0x84C4 +#define GL_TEXTURE5 0x84C5 +#define GL_TEXTURE6 0x84C6 +#define GL_TEXTURE7 0x84C7 +#define GL_TEXTURE8 0x84C8 +#define GL_TEXTURE9 0x84C9 +#define GL_TEXTURE10 0x84CA +#define GL_TEXTURE11 0x84CB +#define GL_TEXTURE12 0x84CC +#define GL_TEXTURE13 0x84CD +#define GL_TEXTURE14 0x84CE +#define GL_TEXTURE15 0x84CF +#define GL_TEXTURE16 0x84D0 +#define GL_TEXTURE17 0x84D1 +#define GL_TEXTURE18 0x84D2 +#define GL_TEXTURE19 0x84D3 +#define GL_TEXTURE20 0x84D4 +#define GL_TEXTURE21 0x84D5 +#define GL_TEXTURE22 0x84D6 +#define GL_TEXTURE23 0x84D7 +#define GL_TEXTURE24 0x84D8 +#define GL_TEXTURE25 0x84D9 +#define GL_TEXTURE26 0x84DA +#define GL_TEXTURE27 0x84DB +#define GL_TEXTURE28 0x84DC +#define GL_TEXTURE29 0x84DD +#define GL_TEXTURE30 0x84DE +#define GL_TEXTURE31 0x84DF +#define GL_ACTIVE_TEXTURE 0x84E0 +#define GL_MULTISAMPLE 0x809D +#define GL_SAMPLE_ALPHA_TO_COVERAGE 0x809E +#define GL_SAMPLE_ALPHA_TO_ONE 0x809F +#define GL_SAMPLE_COVERAGE 0x80A0 +#define GL_SAMPLE_BUFFERS 0x80A8 +#define GL_SAMPLES 0x80A9 +#define GL_SAMPLE_COVERAGE_VALUE 0x80AA +#define GL_SAMPLE_COVERAGE_INVERT 0x80AB +#define GL_TEXTURE_CUBE_MAP 0x8513 +#define GL_TEXTURE_BINDING_CUBE_MAP 0x8514 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_X 0x8515 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X 0x8516 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y 0x8517 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y 0x8518 +#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z 0x8519 +#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z 0x851A +#define GL_PROXY_TEXTURE_CUBE_MAP 0x851B +#define GL_MAX_CUBE_MAP_TEXTURE_SIZE 0x851C +#define GL_COMPRESSED_RGB 0x84ED +#define GL_COMPRESSED_RGBA 0x84EE +#define GL_TEXTURE_COMPRESSION_HINT 0x84EF +#define GL_TEXTURE_COMPRESSED_IMAGE_SIZE 0x86A0 +#define GL_TEXTURE_COMPRESSED 0x86A1 +#define GL_NUM_COMPRESSED_TEXTURE_FORMATS 0x86A2 +#define GL_COMPRESSED_TEXTURE_FORMATS 0x86A3 +#define GL_CLAMP_TO_BORDER 0x812D +#define GL_CLIENT_ACTIVE_TEXTURE 0x84E1 +#define GL_MAX_TEXTURE_UNITS 0x84E2 +#define GL_TRANSPOSE_MODELVIEW_MATRIX 0x84E3 +#define GL_TRANSPOSE_PROJECTION_MATRIX 0x84E4 +#define GL_TRANSPOSE_TEXTURE_MATRIX 0x84E5 +#define GL_TRANSPOSE_COLOR_MATRIX 0x84E6 +#define GL_MULTISAMPLE_BIT 0x20000000 +#define GL_NORMAL_MAP 0x8511 +#define GL_REFLECTION_MAP 0x8512 +#define GL_COMPRESSED_ALPHA 0x84E9 +#define GL_COMPRESSED_LUMINANCE 0x84EA +#define GL_COMPRESSED_LUMINANCE_ALPHA 0x84EB +#define GL_COMPRESSED_INTENSITY 0x84EC +#define GL_COMBINE 0x8570 +#define GL_COMBINE_RGB 0x8571 +#define GL_COMBINE_ALPHA 0x8572 +#define GL_SOURCE0_RGB 0x8580 +#define GL_SOURCE1_RGB 0x8581 +#define GL_SOURCE2_RGB 0x8582 +#define GL_SOURCE0_ALPHA 0x8588 +#define GL_SOURCE1_ALPHA 0x8589 +#define GL_SOURCE2_ALPHA 0x858A +#define GL_OPERAND0_RGB 0x8590 +#define GL_OPERAND1_RGB 0x8591 +#define GL_OPERAND2_RGB 0x8592 +#define GL_OPERAND0_ALPHA 0x8598 +#define GL_OPERAND1_ALPHA 0x8599 +#define GL_OPERAND2_ALPHA 0x859A +#define GL_RGB_SCALE 0x8573 +#define GL_ADD_SIGNED 0x8574 +#define GL_INTERPOLATE 0x8575 +#define GL_SUBTRACT 0x84E7 +#define GL_CONSTANT 0x8576 +#define GL_PRIMARY_COLOR 0x8577 +#define GL_PREVIOUS 0x8578 +#define GL_DOT3_RGB 0x86AE +#define GL_DOT3_RGBA 0x86AF +#define GL_BLEND_DST_RGB 0x80C8 +#define GL_BLEND_SRC_RGB 0x80C9 +#define GL_BLEND_DST_ALPHA 0x80CA +#define GL_BLEND_SRC_ALPHA 0x80CB +#define GL_POINT_FADE_THRESHOLD_SIZE 0x8128 +#define GL_DEPTH_COMPONENT16 0x81A5 +#define GL_DEPTH_COMPONENT24 0x81A6 +#define GL_DEPTH_COMPONENT32 0x81A7 +#define GL_MIRRORED_REPEAT 0x8370 +#define GL_MAX_TEXTURE_LOD_BIAS 0x84FD +#define GL_TEXTURE_LOD_BIAS 0x8501 +#define GL_INCR_WRAP 0x8507 +#define GL_DECR_WRAP 0x8508 +#define GL_TEXTURE_DEPTH_SIZE 0x884A +#define GL_TEXTURE_COMPARE_MODE 0x884C +#define GL_TEXTURE_COMPARE_FUNC 0x884D +#define GL_POINT_SIZE_MIN 0x8126 +#define GL_POINT_SIZE_MAX 0x8127 +#define GL_POINT_DISTANCE_ATTENUATION 0x8129 +#define GL_GENERATE_MIPMAP 0x8191 +#define GL_GENERATE_MIPMAP_HINT 0x8192 +#define GL_FOG_COORDINATE_SOURCE 0x8450 +#define GL_FOG_COORDINATE 0x8451 +#define GL_FRAGMENT_DEPTH 0x8452 +#define GL_CURRENT_FOG_COORDINATE 0x8453 +#define GL_FOG_COORDINATE_ARRAY_TYPE 0x8454 +#define GL_FOG_COORDINATE_ARRAY_STRIDE 0x8455 +#define GL_FOG_COORDINATE_ARRAY_POINTER 0x8456 +#define GL_FOG_COORDINATE_ARRAY 0x8457 +#define GL_COLOR_SUM 0x8458 +#define GL_CURRENT_SECONDARY_COLOR 0x8459 +#define GL_SECONDARY_COLOR_ARRAY_SIZE 0x845A +#define GL_SECONDARY_COLOR_ARRAY_TYPE 0x845B +#define GL_SECONDARY_COLOR_ARRAY_STRIDE 0x845C +#define GL_SECONDARY_COLOR_ARRAY_POINTER 0x845D +#define GL_SECONDARY_COLOR_ARRAY 0x845E +#define GL_TEXTURE_FILTER_CONTROL 0x8500 +#define GL_DEPTH_TEXTURE_MODE 0x884B +#define GL_COMPARE_R_TO_TEXTURE 0x884E +#define GL_FUNC_ADD 0x8006 +#define GL_FUNC_SUBTRACT 0x800A +#define GL_FUNC_REVERSE_SUBTRACT 0x800B +#define GL_MIN 0x8007 +#define GL_MAX 0x8008 +#define GL_CONSTANT_COLOR 0x8001 +#define GL_ONE_MINUS_CONSTANT_COLOR 0x8002 +#define GL_CONSTANT_ALPHA 0x8003 +#define GL_ONE_MINUS_CONSTANT_ALPHA 0x8004 +#define GL_BUFFER_SIZE 0x8764 +#define GL_BUFFER_USAGE 0x8765 +#define GL_QUERY_COUNTER_BITS 0x8864 +#define GL_CURRENT_QUERY 0x8865 +#define GL_QUERY_RESULT 0x8866 +#define GL_QUERY_RESULT_AVAILABLE 0x8867 +#define GL_ARRAY_BUFFER 0x8892 +#define GL_ELEMENT_ARRAY_BUFFER 0x8893 +#define GL_ARRAY_BUFFER_BINDING 0x8894 +#define GL_ELEMENT_ARRAY_BUFFER_BINDING 0x8895 +#define GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING 0x889F +#define GL_READ_ONLY 0x88B8 +#define GL_WRITE_ONLY 0x88B9 +#define GL_READ_WRITE 0x88BA +#define GL_BUFFER_ACCESS 0x88BB +#define GL_BUFFER_MAPPED 0x88BC +#define GL_BUFFER_MAP_POINTER 0x88BD +#define GL_STREAM_DRAW 0x88E0 +#define GL_STREAM_READ 0x88E1 +#define GL_STREAM_COPY 0x88E2 +#define GL_STATIC_DRAW 0x88E4 +#define GL_STATIC_READ 0x88E5 +#define GL_STATIC_COPY 0x88E6 +#define GL_DYNAMIC_DRAW 0x88E8 +#define GL_DYNAMIC_READ 0x88E9 +#define GL_DYNAMIC_COPY 0x88EA +#define GL_SAMPLES_PASSED 0x8914 +#define GL_SRC1_ALPHA 0x8589 +#define GL_VERTEX_ARRAY_BUFFER_BINDING 0x8896 +#define GL_NORMAL_ARRAY_BUFFER_BINDING 0x8897 +#define GL_COLOR_ARRAY_BUFFER_BINDING 0x8898 +#define GL_INDEX_ARRAY_BUFFER_BINDING 0x8899 +#define GL_TEXTURE_COORD_ARRAY_BUFFER_BINDING 0x889A +#define GL_EDGE_FLAG_ARRAY_BUFFER_BINDING 0x889B +#define GL_SECONDARY_COLOR_ARRAY_BUFFER_BINDING 0x889C +#define GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING 0x889D +#define GL_WEIGHT_ARRAY_BUFFER_BINDING 0x889E +#define GL_FOG_COORD_SRC 0x8450 +#define GL_FOG_COORD 0x8451 +#define GL_CURRENT_FOG_COORD 0x8453 +#define GL_FOG_COORD_ARRAY_TYPE 0x8454 +#define GL_FOG_COORD_ARRAY_STRIDE 0x8455 +#define GL_FOG_COORD_ARRAY_POINTER 0x8456 +#define GL_FOG_COORD_ARRAY 0x8457 +#define GL_FOG_COORD_ARRAY_BUFFER_BINDING 0x889D +#define GL_SRC0_RGB 0x8580 +#define GL_SRC1_RGB 0x8581 +#define GL_SRC2_RGB 0x8582 +#define GL_SRC0_ALPHA 0x8588 +#define GL_SRC2_ALPHA 0x858A +#define GL_BLEND_EQUATION_RGB 0x8009 +#define GL_VERTEX_ATTRIB_ARRAY_ENABLED 0x8622 +#define GL_VERTEX_ATTRIB_ARRAY_SIZE 0x8623 +#define GL_VERTEX_ATTRIB_ARRAY_STRIDE 0x8624 +#define GL_VERTEX_ATTRIB_ARRAY_TYPE 0x8625 +#define GL_CURRENT_VERTEX_ATTRIB 0x8626 +#define GL_VERTEX_PROGRAM_POINT_SIZE 0x8642 +#define GL_VERTEX_ATTRIB_ARRAY_POINTER 0x8645 +#define GL_STENCIL_BACK_FUNC 0x8800 +#define GL_STENCIL_BACK_FAIL 0x8801 +#define GL_STENCIL_BACK_PASS_DEPTH_FAIL 0x8802 +#define GL_STENCIL_BACK_PASS_DEPTH_PASS 0x8803 +#define GL_MAX_DRAW_BUFFERS 0x8824 +#define GL_DRAW_BUFFER0 0x8825 +#define GL_DRAW_BUFFER1 0x8826 +#define GL_DRAW_BUFFER2 0x8827 +#define GL_DRAW_BUFFER3 0x8828 +#define GL_DRAW_BUFFER4 0x8829 +#define GL_DRAW_BUFFER5 0x882A +#define GL_DRAW_BUFFER6 0x882B +#define GL_DRAW_BUFFER7 0x882C +#define GL_DRAW_BUFFER8 0x882D +#define GL_DRAW_BUFFER9 0x882E +#define GL_DRAW_BUFFER10 0x882F +#define GL_DRAW_BUFFER11 0x8830 +#define GL_DRAW_BUFFER12 0x8831 +#define GL_DRAW_BUFFER13 0x8832 +#define GL_DRAW_BUFFER14 0x8833 +#define GL_DRAW_BUFFER15 0x8834 +#define GL_BLEND_EQUATION_ALPHA 0x883D +#define GL_MAX_VERTEX_ATTRIBS 0x8869 +#define GL_VERTEX_ATTRIB_ARRAY_NORMALIZED 0x886A +#define GL_MAX_TEXTURE_IMAGE_UNITS 0x8872 +#define GL_FRAGMENT_SHADER 0x8B30 +#define GL_VERTEX_SHADER 0x8B31 +#define GL_MAX_FRAGMENT_UNIFORM_COMPONENTS 0x8B49 +#define GL_MAX_VERTEX_UNIFORM_COMPONENTS 0x8B4A +#define GL_MAX_VARYING_FLOATS 0x8B4B +#define GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS 0x8B4C +#define GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS 0x8B4D +#define GL_SHADER_TYPE 0x8B4F +#define GL_FLOAT_VEC2 0x8B50 +#define GL_FLOAT_VEC3 0x8B51 +#define GL_FLOAT_VEC4 0x8B52 +#define GL_INT_VEC2 0x8B53 +#define GL_INT_VEC3 0x8B54 +#define GL_INT_VEC4 0x8B55 +#define GL_BOOL 0x8B56 +#define GL_BOOL_VEC2 0x8B57 +#define GL_BOOL_VEC3 0x8B58 +#define GL_BOOL_VEC4 0x8B59 +#define GL_FLOAT_MAT2 0x8B5A +#define GL_FLOAT_MAT3 0x8B5B +#define GL_FLOAT_MAT4 0x8B5C +#define GL_SAMPLER_1D 0x8B5D +#define GL_SAMPLER_2D 0x8B5E +#define GL_SAMPLER_3D 0x8B5F +#define GL_SAMPLER_CUBE 0x8B60 +#define GL_SAMPLER_1D_SHADOW 0x8B61 +#define GL_SAMPLER_2D_SHADOW 0x8B62 +#define GL_DELETE_STATUS 0x8B80 +#define GL_COMPILE_STATUS 0x8B81 +#define GL_LINK_STATUS 0x8B82 +#define GL_VALIDATE_STATUS 0x8B83 +#define GL_INFO_LOG_LENGTH 0x8B84 +#define GL_ATTACHED_SHADERS 0x8B85 +#define GL_ACTIVE_UNIFORMS 0x8B86 +#define GL_ACTIVE_UNIFORM_MAX_LENGTH 0x8B87 +#define GL_SHADER_SOURCE_LENGTH 0x8B88 +#define GL_ACTIVE_ATTRIBUTES 0x8B89 +#define GL_ACTIVE_ATTRIBUTE_MAX_LENGTH 0x8B8A +#define GL_FRAGMENT_SHADER_DERIVATIVE_HINT 0x8B8B +#define GL_SHADING_LANGUAGE_VERSION 0x8B8C +#define GL_CURRENT_PROGRAM 0x8B8D +#define GL_POINT_SPRITE_COORD_ORIGIN 0x8CA0 +#define GL_LOWER_LEFT 0x8CA1 +#define GL_UPPER_LEFT 0x8CA2 +#define GL_STENCIL_BACK_REF 0x8CA3 +#define GL_STENCIL_BACK_VALUE_MASK 0x8CA4 +#define GL_STENCIL_BACK_WRITEMASK 0x8CA5 +#define GL_VERTEX_PROGRAM_TWO_SIDE 0x8643 +#define GL_POINT_SPRITE 0x8861 +#define GL_COORD_REPLACE 0x8862 +#define GL_MAX_TEXTURE_COORDS 0x8871 +#define GL_PIXEL_PACK_BUFFER 0x88EB +#define GL_PIXEL_UNPACK_BUFFER 0x88EC +#define GL_PIXEL_PACK_BUFFER_BINDING 0x88ED +#define GL_PIXEL_UNPACK_BUFFER_BINDING 0x88EF +#define GL_FLOAT_MAT2x3 0x8B65 +#define GL_FLOAT_MAT2x4 0x8B66 +#define GL_FLOAT_MAT3x2 0x8B67 +#define GL_FLOAT_MAT3x4 0x8B68 +#define GL_FLOAT_MAT4x2 0x8B69 +#define GL_FLOAT_MAT4x3 0x8B6A +#define GL_SRGB 0x8C40 +#define GL_SRGB8 0x8C41 +#define GL_SRGB_ALPHA 0x8C42 +#define GL_SRGB8_ALPHA8 0x8C43 +#define GL_COMPRESSED_SRGB 0x8C48 +#define GL_COMPRESSED_SRGB_ALPHA 0x8C49 +#define GL_CURRENT_RASTER_SECONDARY_COLOR 0x845F +#define GL_SLUMINANCE_ALPHA 0x8C44 +#define GL_SLUMINANCE8_ALPHA8 0x8C45 +#define GL_SLUMINANCE 0x8C46 +#define GL_SLUMINANCE8 0x8C47 +#define GL_COMPRESSED_SLUMINANCE 0x8C4A +#define GL_COMPRESSED_SLUMINANCE_ALPHA 0x8C4B +#define GL_COMPARE_REF_TO_TEXTURE 0x884E +#define GL_CLIP_DISTANCE0 0x3000 +#define GL_CLIP_DISTANCE1 0x3001 +#define GL_CLIP_DISTANCE2 0x3002 +#define GL_CLIP_DISTANCE3 0x3003 +#define GL_CLIP_DISTANCE4 0x3004 +#define GL_CLIP_DISTANCE5 0x3005 +#define GL_CLIP_DISTANCE6 0x3006 +#define GL_CLIP_DISTANCE7 0x3007 +#define GL_MAX_CLIP_DISTANCES 0x0D32 +#define GL_MAJOR_VERSION 0x821B +#define GL_MINOR_VERSION 0x821C +#define GL_NUM_EXTENSIONS 0x821D +#define GL_CONTEXT_FLAGS 0x821E +#define GL_COMPRESSED_RED 0x8225 +#define GL_COMPRESSED_RG 0x8226 +#define GL_CONTEXT_FLAG_FORWARD_COMPATIBLE_BIT 0x00000001 +#define GL_RGBA32F 0x8814 +#define GL_RGB32F 0x8815 +#define GL_RGBA16F 0x881A +#define GL_RGB16F 0x881B +#define GL_VERTEX_ATTRIB_ARRAY_INTEGER 0x88FD +#define GL_MAX_ARRAY_TEXTURE_LAYERS 0x88FF +#define GL_MIN_PROGRAM_TEXEL_OFFSET 0x8904 +#define GL_MAX_PROGRAM_TEXEL_OFFSET 0x8905 +#define GL_CLAMP_READ_COLOR 0x891C +#define GL_FIXED_ONLY 0x891D +#define GL_MAX_VARYING_COMPONENTS 0x8B4B +#define GL_TEXTURE_1D_ARRAY 0x8C18 +#define GL_PROXY_TEXTURE_1D_ARRAY 0x8C19 +#define GL_TEXTURE_2D_ARRAY 0x8C1A +#define GL_PROXY_TEXTURE_2D_ARRAY 0x8C1B +#define GL_TEXTURE_BINDING_1D_ARRAY 0x8C1C +#define GL_TEXTURE_BINDING_2D_ARRAY 0x8C1D +#define GL_R11F_G11F_B10F 0x8C3A +#define GL_UNSIGNED_INT_10F_11F_11F_REV 0x8C3B +#define GL_RGB9_E5 0x8C3D +#define GL_UNSIGNED_INT_5_9_9_9_REV 0x8C3E +#define GL_TEXTURE_SHARED_SIZE 0x8C3F +#define GL_TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH 0x8C76 +#define GL_TRANSFORM_FEEDBACK_BUFFER_MODE 0x8C7F +#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS 0x8C80 +#define GL_TRANSFORM_FEEDBACK_VARYINGS 0x8C83 +#define GL_TRANSFORM_FEEDBACK_BUFFER_START 0x8C84 +#define GL_TRANSFORM_FEEDBACK_BUFFER_SIZE 0x8C85 +#define GL_PRIMITIVES_GENERATED 0x8C87 +#define GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN 0x8C88 +#define GL_RASTERIZER_DISCARD 0x8C89 +#define GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS 0x8C8A +#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS 0x8C8B +#define GL_INTERLEAVED_ATTRIBS 0x8C8C +#define GL_SEPARATE_ATTRIBS 0x8C8D +#define GL_TRANSFORM_FEEDBACK_BUFFER 0x8C8E +#define GL_TRANSFORM_FEEDBACK_BUFFER_BINDING 0x8C8F +#define GL_RGBA32UI 0x8D70 +#define GL_RGB32UI 0x8D71 +#define GL_RGBA16UI 0x8D76 +#define GL_RGB16UI 0x8D77 +#define GL_RGBA8UI 0x8D7C +#define GL_RGB8UI 0x8D7D +#define GL_RGBA32I 0x8D82 +#define GL_RGB32I 0x8D83 +#define GL_RGBA16I 0x8D88 +#define GL_RGB16I 0x8D89 +#define GL_RGBA8I 0x8D8E +#define GL_RGB8I 0x8D8F +#define GL_RED_INTEGER 0x8D94 +#define GL_GREEN_INTEGER 0x8D95 +#define GL_BLUE_INTEGER 0x8D96 +#define GL_RGB_INTEGER 0x8D98 +#define GL_RGBA_INTEGER 0x8D99 +#define GL_BGR_INTEGER 0x8D9A +#define GL_BGRA_INTEGER 0x8D9B +#define GL_SAMPLER_1D_ARRAY 0x8DC0 +#define GL_SAMPLER_2D_ARRAY 0x8DC1 +#define GL_SAMPLER_1D_ARRAY_SHADOW 0x8DC3 +#define GL_SAMPLER_2D_ARRAY_SHADOW 0x8DC4 +#define GL_SAMPLER_CUBE_SHADOW 0x8DC5 +#define GL_UNSIGNED_INT_VEC2 0x8DC6 +#define GL_UNSIGNED_INT_VEC3 0x8DC7 +#define GL_UNSIGNED_INT_VEC4 0x8DC8 +#define GL_INT_SAMPLER_1D 0x8DC9 +#define GL_INT_SAMPLER_2D 0x8DCA +#define GL_INT_SAMPLER_3D 0x8DCB +#define GL_INT_SAMPLER_CUBE 0x8DCC +#define GL_INT_SAMPLER_1D_ARRAY 0x8DCE +#define GL_INT_SAMPLER_2D_ARRAY 0x8DCF +#define GL_UNSIGNED_INT_SAMPLER_1D 0x8DD1 +#define GL_UNSIGNED_INT_SAMPLER_2D 0x8DD2 +#define GL_UNSIGNED_INT_SAMPLER_3D 0x8DD3 +#define GL_UNSIGNED_INT_SAMPLER_CUBE 0x8DD4 +#define GL_UNSIGNED_INT_SAMPLER_1D_ARRAY 0x8DD6 +#define GL_UNSIGNED_INT_SAMPLER_2D_ARRAY 0x8DD7 +#define GL_QUERY_WAIT 0x8E13 +#define GL_QUERY_NO_WAIT 0x8E14 +#define GL_QUERY_BY_REGION_WAIT 0x8E15 +#define GL_QUERY_BY_REGION_NO_WAIT 0x8E16 +#define GL_BUFFER_ACCESS_FLAGS 0x911F +#define GL_BUFFER_MAP_LENGTH 0x9120 +#define GL_BUFFER_MAP_OFFSET 0x9121 +#define GL_DEPTH_COMPONENT32F 0x8CAC +#define GL_DEPTH32F_STENCIL8 0x8CAD +#define GL_FLOAT_32_UNSIGNED_INT_24_8_REV 0x8DAD +#define GL_INVALID_FRAMEBUFFER_OPERATION 0x0506 +#define GL_FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING 0x8210 +#define GL_FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE 0x8211 +#define GL_FRAMEBUFFER_ATTACHMENT_RED_SIZE 0x8212 +#define GL_FRAMEBUFFER_ATTACHMENT_GREEN_SIZE 0x8213 +#define GL_FRAMEBUFFER_ATTACHMENT_BLUE_SIZE 0x8214 +#define GL_FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE 0x8215 +#define GL_FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE 0x8216 +#define GL_FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE 0x8217 +#define GL_FRAMEBUFFER_DEFAULT 0x8218 +#define GL_FRAMEBUFFER_UNDEFINED 0x8219 +#define GL_DEPTH_STENCIL_ATTACHMENT 0x821A +#define GL_MAX_RENDERBUFFER_SIZE 0x84E8 +#define GL_DEPTH_STENCIL 0x84F9 +#define GL_UNSIGNED_INT_24_8 0x84FA +#define GL_DEPTH24_STENCIL8 0x88F0 +#define GL_TEXTURE_STENCIL_SIZE 0x88F1 +#define GL_TEXTURE_RED_TYPE 0x8C10 +#define GL_TEXTURE_GREEN_TYPE 0x8C11 +#define GL_TEXTURE_BLUE_TYPE 0x8C12 +#define GL_TEXTURE_ALPHA_TYPE 0x8C13 +#define GL_TEXTURE_DEPTH_TYPE 0x8C16 +#define GL_UNSIGNED_NORMALIZED 0x8C17 +#define GL_FRAMEBUFFER_BINDING 0x8CA6 +#define GL_DRAW_FRAMEBUFFER_BINDING 0x8CA6 +#define GL_RENDERBUFFER_BINDING 0x8CA7 +#define GL_READ_FRAMEBUFFER 0x8CA8 +#define GL_DRAW_FRAMEBUFFER 0x8CA9 +#define GL_READ_FRAMEBUFFER_BINDING 0x8CAA +#define GL_RENDERBUFFER_SAMPLES 0x8CAB +#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE 0x8CD0 +#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_NAME 0x8CD1 +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL 0x8CD2 +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE 0x8CD3 +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER 0x8CD4 +#define GL_FRAMEBUFFER_COMPLETE 0x8CD5 +#define GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT 0x8CD6 +#define GL_FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT 0x8CD7 +#define GL_FRAMEBUFFER_INCOMPLETE_DRAW_BUFFER 0x8CDB +#define GL_FRAMEBUFFER_INCOMPLETE_READ_BUFFER 0x8CDC +#define GL_FRAMEBUFFER_UNSUPPORTED 0x8CDD +#define GL_MAX_COLOR_ATTACHMENTS 0x8CDF +#define GL_COLOR_ATTACHMENT0 0x8CE0 +#define GL_COLOR_ATTACHMENT1 0x8CE1 +#define GL_COLOR_ATTACHMENT2 0x8CE2 +#define GL_COLOR_ATTACHMENT3 0x8CE3 +#define GL_COLOR_ATTACHMENT4 0x8CE4 +#define GL_COLOR_ATTACHMENT5 0x8CE5 +#define GL_COLOR_ATTACHMENT6 0x8CE6 +#define GL_COLOR_ATTACHMENT7 0x8CE7 +#define GL_COLOR_ATTACHMENT8 0x8CE8 +#define GL_COLOR_ATTACHMENT9 0x8CE9 +#define GL_COLOR_ATTACHMENT10 0x8CEA +#define GL_COLOR_ATTACHMENT11 0x8CEB +#define GL_COLOR_ATTACHMENT12 0x8CEC +#define GL_COLOR_ATTACHMENT13 0x8CED +#define GL_COLOR_ATTACHMENT14 0x8CEE +#define GL_COLOR_ATTACHMENT15 0x8CEF +#define GL_COLOR_ATTACHMENT16 0x8CF0 +#define GL_COLOR_ATTACHMENT17 0x8CF1 +#define GL_COLOR_ATTACHMENT18 0x8CF2 +#define GL_COLOR_ATTACHMENT19 0x8CF3 +#define GL_COLOR_ATTACHMENT20 0x8CF4 +#define GL_COLOR_ATTACHMENT21 0x8CF5 +#define GL_COLOR_ATTACHMENT22 0x8CF6 +#define GL_COLOR_ATTACHMENT23 0x8CF7 +#define GL_COLOR_ATTACHMENT24 0x8CF8 +#define GL_COLOR_ATTACHMENT25 0x8CF9 +#define GL_COLOR_ATTACHMENT26 0x8CFA +#define GL_COLOR_ATTACHMENT27 0x8CFB +#define GL_COLOR_ATTACHMENT28 0x8CFC +#define GL_COLOR_ATTACHMENT29 0x8CFD +#define GL_COLOR_ATTACHMENT30 0x8CFE +#define GL_COLOR_ATTACHMENT31 0x8CFF +#define GL_DEPTH_ATTACHMENT 0x8D00 +#define GL_STENCIL_ATTACHMENT 0x8D20 +#define GL_FRAMEBUFFER 0x8D40 +#define GL_RENDERBUFFER 0x8D41 +#define GL_RENDERBUFFER_WIDTH 0x8D42 +#define GL_RENDERBUFFER_HEIGHT 0x8D43 +#define GL_RENDERBUFFER_INTERNAL_FORMAT 0x8D44 +#define GL_STENCIL_INDEX1 0x8D46 +#define GL_STENCIL_INDEX4 0x8D47 +#define GL_STENCIL_INDEX8 0x8D48 +#define GL_STENCIL_INDEX16 0x8D49 +#define GL_RENDERBUFFER_RED_SIZE 0x8D50 +#define GL_RENDERBUFFER_GREEN_SIZE 0x8D51 +#define GL_RENDERBUFFER_BLUE_SIZE 0x8D52 +#define GL_RENDERBUFFER_ALPHA_SIZE 0x8D53 +#define GL_RENDERBUFFER_DEPTH_SIZE 0x8D54 +#define GL_RENDERBUFFER_STENCIL_SIZE 0x8D55 +#define GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE 0x8D56 +#define GL_MAX_SAMPLES 0x8D57 +#define GL_INDEX 0x8222 +#define GL_TEXTURE_LUMINANCE_TYPE 0x8C14 +#define GL_TEXTURE_INTENSITY_TYPE 0x8C15 +#define GL_FRAMEBUFFER_SRGB 0x8DB9 +#define GL_HALF_FLOAT 0x140B +#define GL_MAP_READ_BIT 0x0001 +#define GL_MAP_WRITE_BIT 0x0002 +#define GL_MAP_INVALIDATE_RANGE_BIT 0x0004 +#define GL_MAP_INVALIDATE_BUFFER_BIT 0x0008 +#define GL_MAP_FLUSH_EXPLICIT_BIT 0x0010 +#define GL_MAP_UNSYNCHRONIZED_BIT 0x0020 +#define GL_COMPRESSED_RED_RGTC1 0x8DBB +#define GL_COMPRESSED_SIGNED_RED_RGTC1 0x8DBC +#define GL_COMPRESSED_RG_RGTC2 0x8DBD +#define GL_COMPRESSED_SIGNED_RG_RGTC2 0x8DBE +#define GL_RG 0x8227 +#define GL_RG_INTEGER 0x8228 +#define GL_R8 0x8229 +#define GL_R16 0x822A +#define GL_RG8 0x822B +#define GL_RG16 0x822C +#define GL_R16F 0x822D +#define GL_R32F 0x822E +#define GL_RG16F 0x822F +#define GL_RG32F 0x8230 +#define GL_R8I 0x8231 +#define GL_R8UI 0x8232 +#define GL_R16I 0x8233 +#define GL_R16UI 0x8234 +#define GL_R32I 0x8235 +#define GL_R32UI 0x8236 +#define GL_RG8I 0x8237 +#define GL_RG8UI 0x8238 +#define GL_RG16I 0x8239 +#define GL_RG16UI 0x823A +#define GL_RG32I 0x823B +#define GL_RG32UI 0x823C +#define GL_VERTEX_ARRAY_BINDING 0x85B5 +#define GL_CLAMP_VERTEX_COLOR 0x891A +#define GL_CLAMP_FRAGMENT_COLOR 0x891B +#define GL_ALPHA_INTEGER 0x8D97 +#define GL_SAMPLER_2D_RECT 0x8B63 +#define GL_SAMPLER_2D_RECT_SHADOW 0x8B64 +#define GL_SAMPLER_BUFFER 0x8DC2 +#define GL_INT_SAMPLER_2D_RECT 0x8DCD +#define GL_INT_SAMPLER_BUFFER 0x8DD0 +#define GL_UNSIGNED_INT_SAMPLER_2D_RECT 0x8DD5 +#define GL_UNSIGNED_INT_SAMPLER_BUFFER 0x8DD8 +#define GL_TEXTURE_BUFFER 0x8C2A +#define GL_MAX_TEXTURE_BUFFER_SIZE 0x8C2B +#define GL_TEXTURE_BINDING_BUFFER 0x8C2C +#define GL_TEXTURE_BUFFER_DATA_STORE_BINDING 0x8C2D +#define GL_TEXTURE_RECTANGLE 0x84F5 +#define GL_TEXTURE_BINDING_RECTANGLE 0x84F6 +#define GL_PROXY_TEXTURE_RECTANGLE 0x84F7 +#define GL_MAX_RECTANGLE_TEXTURE_SIZE 0x84F8 +#define GL_R8_SNORM 0x8F94 +#define GL_RG8_SNORM 0x8F95 +#define GL_RGB8_SNORM 0x8F96 +#define GL_RGBA8_SNORM 0x8F97 +#define GL_R16_SNORM 0x8F98 +#define GL_RG16_SNORM 0x8F99 +#define GL_RGB16_SNORM 0x8F9A +#define GL_RGBA16_SNORM 0x8F9B +#define GL_SIGNED_NORMALIZED 0x8F9C +#define GL_PRIMITIVE_RESTART 0x8F9D +#define GL_PRIMITIVE_RESTART_INDEX 0x8F9E +#define GL_COPY_READ_BUFFER 0x8F36 +#define GL_COPY_WRITE_BUFFER 0x8F37 +#define GL_UNIFORM_BUFFER 0x8A11 +#define GL_UNIFORM_BUFFER_BINDING 0x8A28 +#define GL_UNIFORM_BUFFER_START 0x8A29 +#define GL_UNIFORM_BUFFER_SIZE 0x8A2A +#define GL_MAX_VERTEX_UNIFORM_BLOCKS 0x8A2B +#define GL_MAX_GEOMETRY_UNIFORM_BLOCKS 0x8A2C +#define GL_MAX_FRAGMENT_UNIFORM_BLOCKS 0x8A2D +#define GL_MAX_COMBINED_UNIFORM_BLOCKS 0x8A2E +#define GL_MAX_UNIFORM_BUFFER_BINDINGS 0x8A2F +#define GL_MAX_UNIFORM_BLOCK_SIZE 0x8A30 +#define GL_MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS 0x8A31 +#define GL_MAX_COMBINED_GEOMETRY_UNIFORM_COMPONENTS 0x8A32 +#define GL_MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS 0x8A33 +#define GL_UNIFORM_BUFFER_OFFSET_ALIGNMENT 0x8A34 +#define GL_ACTIVE_UNIFORM_BLOCK_MAX_NAME_LENGTH 0x8A35 +#define GL_ACTIVE_UNIFORM_BLOCKS 0x8A36 +#define GL_UNIFORM_TYPE 0x8A37 +#define GL_UNIFORM_SIZE 0x8A38 +#define GL_UNIFORM_NAME_LENGTH 0x8A39 +#define GL_UNIFORM_BLOCK_INDEX 0x8A3A +#define GL_UNIFORM_OFFSET 0x8A3B +#define GL_UNIFORM_ARRAY_STRIDE 0x8A3C +#define GL_UNIFORM_MATRIX_STRIDE 0x8A3D +#define GL_UNIFORM_IS_ROW_MAJOR 0x8A3E +#define GL_UNIFORM_BLOCK_BINDING 0x8A3F +#define GL_UNIFORM_BLOCK_DATA_SIZE 0x8A40 +#define GL_UNIFORM_BLOCK_NAME_LENGTH 0x8A41 +#define GL_UNIFORM_BLOCK_ACTIVE_UNIFORMS 0x8A42 +#define GL_UNIFORM_BLOCK_ACTIVE_UNIFORM_INDICES 0x8A43 +#define GL_UNIFORM_BLOCK_REFERENCED_BY_VERTEX_SHADER 0x8A44 +#define GL_UNIFORM_BLOCK_REFERENCED_BY_GEOMETRY_SHADER 0x8A45 +#define GL_UNIFORM_BLOCK_REFERENCED_BY_FRAGMENT_SHADER 0x8A46 +#define GL_INVALID_INDEX 0xFFFFFFFF +#define GL_CONTEXT_CORE_PROFILE_BIT 0x00000001 +#define GL_CONTEXT_COMPATIBILITY_PROFILE_BIT 0x00000002 +#define GL_LINES_ADJACENCY 0x000A +#define GL_LINE_STRIP_ADJACENCY 0x000B +#define GL_TRIANGLES_ADJACENCY 0x000C +#define GL_TRIANGLE_STRIP_ADJACENCY 0x000D +#define GL_PROGRAM_POINT_SIZE 0x8642 +#define GL_MAX_GEOMETRY_TEXTURE_IMAGE_UNITS 0x8C29 +#define GL_FRAMEBUFFER_ATTACHMENT_LAYERED 0x8DA7 +#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_TARGETS 0x8DA8 +#define GL_GEOMETRY_SHADER 0x8DD9 +#define GL_GEOMETRY_VERTICES_OUT 0x8916 +#define GL_GEOMETRY_INPUT_TYPE 0x8917 +#define GL_GEOMETRY_OUTPUT_TYPE 0x8918 +#define GL_MAX_GEOMETRY_UNIFORM_COMPONENTS 0x8DDF +#define GL_MAX_GEOMETRY_OUTPUT_VERTICES 0x8DE0 +#define GL_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS 0x8DE1 +#define GL_MAX_VERTEX_OUTPUT_COMPONENTS 0x9122 +#define GL_MAX_GEOMETRY_INPUT_COMPONENTS 0x9123 +#define GL_MAX_GEOMETRY_OUTPUT_COMPONENTS 0x9124 +#define GL_MAX_FRAGMENT_INPUT_COMPONENTS 0x9125 +#define GL_CONTEXT_PROFILE_MASK 0x9126 +#define GL_DEPTH_CLAMP 0x864F +#define GL_QUADS_FOLLOW_PROVOKING_VERTEX_CONVENTION 0x8E4C +#define GL_FIRST_VERTEX_CONVENTION 0x8E4D +#define GL_LAST_VERTEX_CONVENTION 0x8E4E +#define GL_PROVOKING_VERTEX 0x8E4F +#define GL_TEXTURE_CUBE_MAP_SEAMLESS 0x884F +#define GL_MAX_SERVER_WAIT_TIMEOUT 0x9111 +#define GL_OBJECT_TYPE 0x9112 +#define GL_SYNC_CONDITION 0x9113 +#define GL_SYNC_STATUS 0x9114 +#define GL_SYNC_FLAGS 0x9115 +#define GL_SYNC_FENCE 0x9116 +#define GL_SYNC_GPU_COMMANDS_COMPLETE 0x9117 +#define GL_UNSIGNALED 0x9118 +#define GL_SIGNALED 0x9119 +#define GL_ALREADY_SIGNALED 0x911A +#define GL_TIMEOUT_EXPIRED 0x911B +#define GL_CONDITION_SATISFIED 0x911C +#define GL_WAIT_FAILED 0x911D +#define GL_TIMEOUT_IGNORED 0xFFFFFFFFFFFFFFFF +#define GL_SYNC_FLUSH_COMMANDS_BIT 0x00000001 +#define GL_SAMPLE_POSITION 0x8E50 +#define GL_SAMPLE_MASK 0x8E51 +#define GL_SAMPLE_MASK_VALUE 0x8E52 +#define GL_MAX_SAMPLE_MASK_WORDS 0x8E59 +#define GL_TEXTURE_2D_MULTISAMPLE 0x9100 +#define GL_PROXY_TEXTURE_2D_MULTISAMPLE 0x9101 +#define GL_TEXTURE_2D_MULTISAMPLE_ARRAY 0x9102 +#define GL_PROXY_TEXTURE_2D_MULTISAMPLE_ARRAY 0x9103 +#define GL_TEXTURE_BINDING_2D_MULTISAMPLE 0x9104 +#define GL_TEXTURE_BINDING_2D_MULTISAMPLE_ARRAY 0x9105 +#define GL_TEXTURE_SAMPLES 0x9106 +#define GL_TEXTURE_FIXED_SAMPLE_LOCATIONS 0x9107 +#define GL_SAMPLER_2D_MULTISAMPLE 0x9108 +#define GL_INT_SAMPLER_2D_MULTISAMPLE 0x9109 +#define GL_UNSIGNED_INT_SAMPLER_2D_MULTISAMPLE 0x910A +#define GL_SAMPLER_2D_MULTISAMPLE_ARRAY 0x910B +#define GL_INT_SAMPLER_2D_MULTISAMPLE_ARRAY 0x910C +#define GL_UNSIGNED_INT_SAMPLER_2D_MULTISAMPLE_ARRAY 0x910D +#define GL_MAX_COLOR_TEXTURE_SAMPLES 0x910E +#define GL_MAX_DEPTH_TEXTURE_SAMPLES 0x910F +#define GL_MAX_INTEGER_SAMPLES 0x9110 +#ifndef GL_VERSION_1_0 +#define GL_VERSION_1_0 1 +GLAPI int GLAD_GL_VERSION_1_0; +typedef void (APIENTRYP PFNGLCULLFACEPROC)(GLenum mode); +GLAPI PFNGLCULLFACEPROC glad_glCullFace; +#define glCullFace glad_glCullFace +typedef void (APIENTRYP PFNGLFRONTFACEPROC)(GLenum mode); +GLAPI PFNGLFRONTFACEPROC glad_glFrontFace; +#define glFrontFace glad_glFrontFace +typedef void (APIENTRYP PFNGLHINTPROC)(GLenum target, GLenum mode); +GLAPI PFNGLHINTPROC glad_glHint; +#define glHint glad_glHint +typedef void (APIENTRYP PFNGLLINEWIDTHPROC)(GLfloat width); +GLAPI PFNGLLINEWIDTHPROC glad_glLineWidth; +#define glLineWidth glad_glLineWidth +typedef void (APIENTRYP PFNGLPOINTSIZEPROC)(GLfloat size); +GLAPI PFNGLPOINTSIZEPROC glad_glPointSize; +#define glPointSize glad_glPointSize +typedef void (APIENTRYP PFNGLPOLYGONMODEPROC)(GLenum face, GLenum mode); +GLAPI PFNGLPOLYGONMODEPROC glad_glPolygonMode; +#define glPolygonMode glad_glPolygonMode +typedef void (APIENTRYP PFNGLSCISSORPROC)(GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI PFNGLSCISSORPROC glad_glScissor; +#define glScissor glad_glScissor +typedef void (APIENTRYP PFNGLTEXPARAMETERFPROC)(GLenum target, GLenum pname, GLfloat param); +GLAPI PFNGLTEXPARAMETERFPROC glad_glTexParameterf; +#define glTexParameterf glad_glTexParameterf +typedef void (APIENTRYP PFNGLTEXPARAMETERFVPROC)(GLenum target, GLenum pname, const GLfloat *params); +GLAPI PFNGLTEXPARAMETERFVPROC glad_glTexParameterfv; +#define glTexParameterfv glad_glTexParameterfv +typedef void (APIENTRYP PFNGLTEXPARAMETERIPROC)(GLenum target, GLenum pname, GLint param); +GLAPI PFNGLTEXPARAMETERIPROC glad_glTexParameteri; +#define glTexParameteri glad_glTexParameteri +typedef void (APIENTRYP PFNGLTEXPARAMETERIVPROC)(GLenum target, GLenum pname, const GLint *params); +GLAPI PFNGLTEXPARAMETERIVPROC glad_glTexParameteriv; +#define glTexParameteriv glad_glTexParameteriv +typedef void (APIENTRYP PFNGLTEXIMAGE1DPROC)(GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const void *pixels); +GLAPI PFNGLTEXIMAGE1DPROC glad_glTexImage1D; +#define glTexImage1D glad_glTexImage1D +typedef void (APIENTRYP PFNGLTEXIMAGE2DPROC)(GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const void *pixels); +GLAPI PFNGLTEXIMAGE2DPROC glad_glTexImage2D; +#define glTexImage2D glad_glTexImage2D +typedef void (APIENTRYP PFNGLDRAWBUFFERPROC)(GLenum buf); +GLAPI PFNGLDRAWBUFFERPROC glad_glDrawBuffer; +#define glDrawBuffer glad_glDrawBuffer +typedef void (APIENTRYP PFNGLCLEARPROC)(GLbitfield mask); +GLAPI PFNGLCLEARPROC glad_glClear; +#define glClear glad_glClear +typedef void (APIENTRYP PFNGLCLEARCOLORPROC)(GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); +GLAPI PFNGLCLEARCOLORPROC glad_glClearColor; +#define glClearColor glad_glClearColor +typedef void (APIENTRYP PFNGLCLEARSTENCILPROC)(GLint s); +GLAPI PFNGLCLEARSTENCILPROC glad_glClearStencil; +#define glClearStencil glad_glClearStencil +typedef void (APIENTRYP PFNGLCLEARDEPTHPROC)(GLdouble depth); +GLAPI PFNGLCLEARDEPTHPROC glad_glClearDepth; +#define glClearDepth glad_glClearDepth +typedef void (APIENTRYP PFNGLSTENCILMASKPROC)(GLuint mask); +GLAPI PFNGLSTENCILMASKPROC glad_glStencilMask; +#define glStencilMask glad_glStencilMask +typedef void (APIENTRYP PFNGLCOLORMASKPROC)(GLboolean red, GLboolean green, GLboolean blue, GLboolean alpha); +GLAPI PFNGLCOLORMASKPROC glad_glColorMask; +#define glColorMask glad_glColorMask +typedef void (APIENTRYP PFNGLDEPTHMASKPROC)(GLboolean flag); +GLAPI PFNGLDEPTHMASKPROC glad_glDepthMask; +#define glDepthMask glad_glDepthMask +typedef void (APIENTRYP PFNGLDISABLEPROC)(GLenum cap); +GLAPI PFNGLDISABLEPROC glad_glDisable; +#define glDisable glad_glDisable +typedef void (APIENTRYP PFNGLENABLEPROC)(GLenum cap); +GLAPI PFNGLENABLEPROC glad_glEnable; +#define glEnable glad_glEnable +typedef void (APIENTRYP PFNGLFINISHPROC)(); +GLAPI PFNGLFINISHPROC glad_glFinish; +#define glFinish glad_glFinish +typedef void (APIENTRYP PFNGLFLUSHPROC)(); +GLAPI PFNGLFLUSHPROC glad_glFlush; +#define glFlush glad_glFlush +typedef void (APIENTRYP PFNGLBLENDFUNCPROC)(GLenum sfactor, GLenum dfactor); +GLAPI PFNGLBLENDFUNCPROC glad_glBlendFunc; +#define glBlendFunc glad_glBlendFunc +typedef void (APIENTRYP PFNGLLOGICOPPROC)(GLenum opcode); +GLAPI PFNGLLOGICOPPROC glad_glLogicOp; +#define glLogicOp glad_glLogicOp +typedef void (APIENTRYP PFNGLSTENCILFUNCPROC)(GLenum func, GLint ref, GLuint mask); +GLAPI PFNGLSTENCILFUNCPROC glad_glStencilFunc; +#define glStencilFunc glad_glStencilFunc +typedef void (APIENTRYP PFNGLSTENCILOPPROC)(GLenum fail, GLenum zfail, GLenum zpass); +GLAPI PFNGLSTENCILOPPROC glad_glStencilOp; +#define glStencilOp glad_glStencilOp +typedef void (APIENTRYP PFNGLDEPTHFUNCPROC)(GLenum func); +GLAPI PFNGLDEPTHFUNCPROC glad_glDepthFunc; +#define glDepthFunc glad_glDepthFunc +typedef void (APIENTRYP PFNGLPIXELSTOREFPROC)(GLenum pname, GLfloat param); +GLAPI PFNGLPIXELSTOREFPROC glad_glPixelStoref; +#define glPixelStoref glad_glPixelStoref +typedef void (APIENTRYP PFNGLPIXELSTOREIPROC)(GLenum pname, GLint param); +GLAPI PFNGLPIXELSTOREIPROC glad_glPixelStorei; +#define glPixelStorei glad_glPixelStorei +typedef void (APIENTRYP PFNGLREADBUFFERPROC)(GLenum src); +GLAPI PFNGLREADBUFFERPROC glad_glReadBuffer; +#define glReadBuffer glad_glReadBuffer +typedef void (APIENTRYP PFNGLREADPIXELSPROC)(GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, void *pixels); +GLAPI PFNGLREADPIXELSPROC glad_glReadPixels; +#define glReadPixels glad_glReadPixels +typedef void (APIENTRYP PFNGLGETBOOLEANVPROC)(GLenum pname, GLboolean *data); +GLAPI PFNGLGETBOOLEANVPROC glad_glGetBooleanv; +#define glGetBooleanv glad_glGetBooleanv +typedef void (APIENTRYP PFNGLGETDOUBLEVPROC)(GLenum pname, GLdouble *data); +GLAPI PFNGLGETDOUBLEVPROC glad_glGetDoublev; +#define glGetDoublev glad_glGetDoublev +typedef GLenum (APIENTRYP PFNGLGETERRORPROC)(); +GLAPI PFNGLGETERRORPROC glad_glGetError; +#define glGetError glad_glGetError +typedef void (APIENTRYP PFNGLGETFLOATVPROC)(GLenum pname, GLfloat *data); +GLAPI PFNGLGETFLOATVPROC glad_glGetFloatv; +#define glGetFloatv glad_glGetFloatv +typedef void (APIENTRYP PFNGLGETINTEGERVPROC)(GLenum pname, GLint *data); +GLAPI PFNGLGETINTEGERVPROC glad_glGetIntegerv; +#define glGetIntegerv glad_glGetIntegerv +typedef const GLubyte * (APIENTRYP PFNGLGETSTRINGPROC)(GLenum name); +GLAPI PFNGLGETSTRINGPROC glad_glGetString; +#define glGetString glad_glGetString +typedef void (APIENTRYP PFNGLGETTEXIMAGEPROC)(GLenum target, GLint level, GLenum format, GLenum type, void *pixels); +GLAPI PFNGLGETTEXIMAGEPROC glad_glGetTexImage; +#define glGetTexImage glad_glGetTexImage +typedef void (APIENTRYP PFNGLGETTEXPARAMETERFVPROC)(GLenum target, GLenum pname, GLfloat *params); +GLAPI PFNGLGETTEXPARAMETERFVPROC glad_glGetTexParameterfv; +#define glGetTexParameterfv glad_glGetTexParameterfv +typedef void (APIENTRYP PFNGLGETTEXPARAMETERIVPROC)(GLenum target, GLenum pname, GLint *params); +GLAPI PFNGLGETTEXPARAMETERIVPROC glad_glGetTexParameteriv; +#define glGetTexParameteriv glad_glGetTexParameteriv +typedef void (APIENTRYP PFNGLGETTEXLEVELPARAMETERFVPROC)(GLenum target, GLint level, GLenum pname, GLfloat *params); +GLAPI PFNGLGETTEXLEVELPARAMETERFVPROC glad_glGetTexLevelParameterfv; +#define glGetTexLevelParameterfv glad_glGetTexLevelParameterfv +typedef void (APIENTRYP PFNGLGETTEXLEVELPARAMETERIVPROC)(GLenum target, GLint level, GLenum pname, GLint *params); +GLAPI PFNGLGETTEXLEVELPARAMETERIVPROC glad_glGetTexLevelParameteriv; +#define glGetTexLevelParameteriv glad_glGetTexLevelParameteriv +typedef GLboolean (APIENTRYP PFNGLISENABLEDPROC)(GLenum cap); +GLAPI PFNGLISENABLEDPROC glad_glIsEnabled; +#define glIsEnabled glad_glIsEnabled +typedef void (APIENTRYP PFNGLDEPTHRANGEPROC)(GLdouble near, GLdouble far); +GLAPI PFNGLDEPTHRANGEPROC glad_glDepthRange; +#define glDepthRange glad_glDepthRange +typedef void (APIENTRYP PFNGLVIEWPORTPROC)(GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI PFNGLVIEWPORTPROC glad_glViewport; +#define glViewport glad_glViewport +typedef void (APIENTRYP PFNGLNEWLISTPROC)(GLuint list, GLenum mode); +GLAPI PFNGLNEWLISTPROC glad_glNewList; +#define glNewList glad_glNewList +typedef void (APIENTRYP PFNGLENDLISTPROC)(); +GLAPI PFNGLENDLISTPROC glad_glEndList; +#define glEndList glad_glEndList +typedef void (APIENTRYP PFNGLCALLLISTPROC)(GLuint list); +GLAPI PFNGLCALLLISTPROC glad_glCallList; +#define glCallList glad_glCallList +typedef void (APIENTRYP PFNGLCALLLISTSPROC)(GLsizei n, GLenum type, const void *lists); +GLAPI PFNGLCALLLISTSPROC glad_glCallLists; +#define glCallLists glad_glCallLists +typedef void (APIENTRYP PFNGLDELETELISTSPROC)(GLuint list, GLsizei range); +GLAPI PFNGLDELETELISTSPROC glad_glDeleteLists; +#define glDeleteLists glad_glDeleteLists +typedef GLuint (APIENTRYP PFNGLGENLISTSPROC)(GLsizei range); +GLAPI PFNGLGENLISTSPROC glad_glGenLists; +#define glGenLists glad_glGenLists +typedef void (APIENTRYP PFNGLLISTBASEPROC)(GLuint base); +GLAPI PFNGLLISTBASEPROC glad_glListBase; +#define glListBase glad_glListBase +typedef void (APIENTRYP PFNGLBEGINPROC)(GLenum mode); +GLAPI PFNGLBEGINPROC glad_glBegin; +#define glBegin glad_glBegin +typedef void (APIENTRYP PFNGLBITMAPPROC)(GLsizei width, GLsizei height, GLfloat xorig, GLfloat yorig, GLfloat xmove, GLfloat ymove, const GLubyte *bitmap); +GLAPI PFNGLBITMAPPROC glad_glBitmap; +#define glBitmap glad_glBitmap +typedef void (APIENTRYP PFNGLCOLOR3BPROC)(GLbyte red, GLbyte green, GLbyte blue); +GLAPI PFNGLCOLOR3BPROC glad_glColor3b; +#define glColor3b glad_glColor3b +typedef void (APIENTRYP PFNGLCOLOR3BVPROC)(const GLbyte *v); +GLAPI PFNGLCOLOR3BVPROC glad_glColor3bv; +#define glColor3bv glad_glColor3bv +typedef void (APIENTRYP PFNGLCOLOR3DPROC)(GLdouble red, GLdouble green, GLdouble blue); +GLAPI PFNGLCOLOR3DPROC glad_glColor3d; +#define glColor3d glad_glColor3d +typedef void (APIENTRYP PFNGLCOLOR3DVPROC)(const GLdouble *v); +GLAPI PFNGLCOLOR3DVPROC glad_glColor3dv; +#define glColor3dv glad_glColor3dv +typedef void (APIENTRYP PFNGLCOLOR3FPROC)(GLfloat red, GLfloat green, GLfloat blue); +GLAPI PFNGLCOLOR3FPROC glad_glColor3f; +#define glColor3f glad_glColor3f +typedef void (APIENTRYP PFNGLCOLOR3FVPROC)(const GLfloat *v); +GLAPI PFNGLCOLOR3FVPROC glad_glColor3fv; +#define glColor3fv glad_glColor3fv +typedef void (APIENTRYP PFNGLCOLOR3IPROC)(GLint red, GLint green, GLint blue); +GLAPI PFNGLCOLOR3IPROC glad_glColor3i; +#define glColor3i glad_glColor3i +typedef void (APIENTRYP PFNGLCOLOR3IVPROC)(const GLint *v); +GLAPI PFNGLCOLOR3IVPROC glad_glColor3iv; +#define glColor3iv glad_glColor3iv +typedef void (APIENTRYP PFNGLCOLOR3SPROC)(GLshort red, GLshort green, GLshort blue); +GLAPI PFNGLCOLOR3SPROC glad_glColor3s; +#define glColor3s glad_glColor3s +typedef void (APIENTRYP PFNGLCOLOR3SVPROC)(const GLshort *v); +GLAPI PFNGLCOLOR3SVPROC glad_glColor3sv; +#define glColor3sv glad_glColor3sv +typedef void (APIENTRYP PFNGLCOLOR3UBPROC)(GLubyte red, GLubyte green, GLubyte blue); +GLAPI PFNGLCOLOR3UBPROC glad_glColor3ub; +#define glColor3ub glad_glColor3ub +typedef void (APIENTRYP PFNGLCOLOR3UBVPROC)(const GLubyte *v); +GLAPI PFNGLCOLOR3UBVPROC glad_glColor3ubv; +#define glColor3ubv glad_glColor3ubv +typedef void (APIENTRYP PFNGLCOLOR3UIPROC)(GLuint red, GLuint green, GLuint blue); +GLAPI PFNGLCOLOR3UIPROC glad_glColor3ui; +#define glColor3ui glad_glColor3ui +typedef void (APIENTRYP PFNGLCOLOR3UIVPROC)(const GLuint *v); +GLAPI PFNGLCOLOR3UIVPROC glad_glColor3uiv; +#define glColor3uiv glad_glColor3uiv +typedef void (APIENTRYP PFNGLCOLOR3USPROC)(GLushort red, GLushort green, GLushort blue); +GLAPI PFNGLCOLOR3USPROC glad_glColor3us; +#define glColor3us glad_glColor3us +typedef void (APIENTRYP PFNGLCOLOR3USVPROC)(const GLushort *v); +GLAPI PFNGLCOLOR3USVPROC glad_glColor3usv; +#define glColor3usv glad_glColor3usv +typedef void (APIENTRYP PFNGLCOLOR4BPROC)(GLbyte red, GLbyte green, GLbyte blue, GLbyte alpha); +GLAPI PFNGLCOLOR4BPROC glad_glColor4b; +#define glColor4b glad_glColor4b +typedef void (APIENTRYP PFNGLCOLOR4BVPROC)(const GLbyte *v); +GLAPI PFNGLCOLOR4BVPROC glad_glColor4bv; +#define glColor4bv glad_glColor4bv +typedef void (APIENTRYP PFNGLCOLOR4DPROC)(GLdouble red, GLdouble green, GLdouble blue, GLdouble alpha); +GLAPI PFNGLCOLOR4DPROC glad_glColor4d; +#define glColor4d glad_glColor4d +typedef void (APIENTRYP PFNGLCOLOR4DVPROC)(const GLdouble *v); +GLAPI PFNGLCOLOR4DVPROC glad_glColor4dv; +#define glColor4dv glad_glColor4dv +typedef void (APIENTRYP PFNGLCOLOR4FPROC)(GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); +GLAPI PFNGLCOLOR4FPROC glad_glColor4f; +#define glColor4f glad_glColor4f +typedef void (APIENTRYP PFNGLCOLOR4FVPROC)(const GLfloat *v); +GLAPI PFNGLCOLOR4FVPROC glad_glColor4fv; +#define glColor4fv glad_glColor4fv +typedef void (APIENTRYP PFNGLCOLOR4IPROC)(GLint red, GLint green, GLint blue, GLint alpha); +GLAPI PFNGLCOLOR4IPROC glad_glColor4i; +#define glColor4i glad_glColor4i +typedef void (APIENTRYP PFNGLCOLOR4IVPROC)(const GLint *v); +GLAPI PFNGLCOLOR4IVPROC glad_glColor4iv; +#define glColor4iv glad_glColor4iv +typedef void (APIENTRYP PFNGLCOLOR4SPROC)(GLshort red, GLshort green, GLshort blue, GLshort alpha); +GLAPI PFNGLCOLOR4SPROC glad_glColor4s; +#define glColor4s glad_glColor4s +typedef void (APIENTRYP PFNGLCOLOR4SVPROC)(const GLshort *v); +GLAPI PFNGLCOLOR4SVPROC glad_glColor4sv; +#define glColor4sv glad_glColor4sv +typedef void (APIENTRYP PFNGLCOLOR4UBPROC)(GLubyte red, GLubyte green, GLubyte blue, GLubyte alpha); +GLAPI PFNGLCOLOR4UBPROC glad_glColor4ub; +#define glColor4ub glad_glColor4ub +typedef void (APIENTRYP PFNGLCOLOR4UBVPROC)(const GLubyte *v); +GLAPI PFNGLCOLOR4UBVPROC glad_glColor4ubv; +#define glColor4ubv glad_glColor4ubv +typedef void (APIENTRYP PFNGLCOLOR4UIPROC)(GLuint red, GLuint green, GLuint blue, GLuint alpha); +GLAPI PFNGLCOLOR4UIPROC glad_glColor4ui; +#define glColor4ui glad_glColor4ui +typedef void (APIENTRYP PFNGLCOLOR4UIVPROC)(const GLuint *v); +GLAPI PFNGLCOLOR4UIVPROC glad_glColor4uiv; +#define glColor4uiv glad_glColor4uiv +typedef void (APIENTRYP PFNGLCOLOR4USPROC)(GLushort red, GLushort green, GLushort blue, GLushort alpha); +GLAPI PFNGLCOLOR4USPROC glad_glColor4us; +#define glColor4us glad_glColor4us +typedef void (APIENTRYP PFNGLCOLOR4USVPROC)(const GLushort *v); +GLAPI PFNGLCOLOR4USVPROC glad_glColor4usv; +#define glColor4usv glad_glColor4usv +typedef void (APIENTRYP PFNGLEDGEFLAGPROC)(GLboolean flag); +GLAPI PFNGLEDGEFLAGPROC glad_glEdgeFlag; +#define glEdgeFlag glad_glEdgeFlag +typedef void (APIENTRYP PFNGLEDGEFLAGVPROC)(const GLboolean *flag); +GLAPI PFNGLEDGEFLAGVPROC glad_glEdgeFlagv; +#define glEdgeFlagv glad_glEdgeFlagv +typedef void (APIENTRYP PFNGLENDPROC)(); +GLAPI PFNGLENDPROC glad_glEnd; +#define glEnd glad_glEnd +typedef void (APIENTRYP PFNGLINDEXDPROC)(GLdouble c); +GLAPI PFNGLINDEXDPROC glad_glIndexd; +#define glIndexd glad_glIndexd +typedef void (APIENTRYP PFNGLINDEXDVPROC)(const GLdouble *c); +GLAPI PFNGLINDEXDVPROC glad_glIndexdv; +#define glIndexdv glad_glIndexdv +typedef void (APIENTRYP PFNGLINDEXFPROC)(GLfloat c); +GLAPI PFNGLINDEXFPROC glad_glIndexf; +#define glIndexf glad_glIndexf +typedef void (APIENTRYP PFNGLINDEXFVPROC)(const GLfloat *c); +GLAPI PFNGLINDEXFVPROC glad_glIndexfv; +#define glIndexfv glad_glIndexfv +typedef void (APIENTRYP PFNGLINDEXIPROC)(GLint c); +GLAPI PFNGLINDEXIPROC glad_glIndexi; +#define glIndexi glad_glIndexi +typedef void (APIENTRYP PFNGLINDEXIVPROC)(const GLint *c); +GLAPI PFNGLINDEXIVPROC glad_glIndexiv; +#define glIndexiv glad_glIndexiv +typedef void (APIENTRYP PFNGLINDEXSPROC)(GLshort c); +GLAPI PFNGLINDEXSPROC glad_glIndexs; +#define glIndexs glad_glIndexs +typedef void (APIENTRYP PFNGLINDEXSVPROC)(const GLshort *c); +GLAPI PFNGLINDEXSVPROC glad_glIndexsv; +#define glIndexsv glad_glIndexsv +typedef void (APIENTRYP PFNGLNORMAL3BPROC)(GLbyte nx, GLbyte ny, GLbyte nz); +GLAPI PFNGLNORMAL3BPROC glad_glNormal3b; +#define glNormal3b glad_glNormal3b +typedef void (APIENTRYP PFNGLNORMAL3BVPROC)(const GLbyte *v); +GLAPI PFNGLNORMAL3BVPROC glad_glNormal3bv; +#define glNormal3bv glad_glNormal3bv +typedef void (APIENTRYP PFNGLNORMAL3DPROC)(GLdouble nx, GLdouble ny, GLdouble nz); +GLAPI PFNGLNORMAL3DPROC glad_glNormal3d; +#define glNormal3d glad_glNormal3d +typedef void (APIENTRYP PFNGLNORMAL3DVPROC)(const GLdouble *v); +GLAPI PFNGLNORMAL3DVPROC glad_glNormal3dv; +#define glNormal3dv glad_glNormal3dv +typedef void (APIENTRYP PFNGLNORMAL3FPROC)(GLfloat nx, GLfloat ny, GLfloat nz); +GLAPI PFNGLNORMAL3FPROC glad_glNormal3f; +#define glNormal3f glad_glNormal3f +typedef void (APIENTRYP PFNGLNORMAL3FVPROC)(const GLfloat *v); +GLAPI PFNGLNORMAL3FVPROC glad_glNormal3fv; +#define glNormal3fv glad_glNormal3fv +typedef void (APIENTRYP PFNGLNORMAL3IPROC)(GLint nx, GLint ny, GLint nz); +GLAPI PFNGLNORMAL3IPROC glad_glNormal3i; +#define glNormal3i glad_glNormal3i +typedef void (APIENTRYP PFNGLNORMAL3IVPROC)(const GLint *v); +GLAPI PFNGLNORMAL3IVPROC glad_glNormal3iv; +#define glNormal3iv glad_glNormal3iv +typedef void (APIENTRYP PFNGLNORMAL3SPROC)(GLshort nx, GLshort ny, GLshort nz); +GLAPI PFNGLNORMAL3SPROC glad_glNormal3s; +#define glNormal3s glad_glNormal3s +typedef void (APIENTRYP PFNGLNORMAL3SVPROC)(const GLshort *v); +GLAPI PFNGLNORMAL3SVPROC glad_glNormal3sv; +#define glNormal3sv glad_glNormal3sv +typedef void (APIENTRYP PFNGLRASTERPOS2DPROC)(GLdouble x, GLdouble y); +GLAPI PFNGLRASTERPOS2DPROC glad_glRasterPos2d; +#define glRasterPos2d glad_glRasterPos2d +typedef void (APIENTRYP PFNGLRASTERPOS2DVPROC)(const GLdouble *v); +GLAPI PFNGLRASTERPOS2DVPROC glad_glRasterPos2dv; +#define glRasterPos2dv glad_glRasterPos2dv +typedef void (APIENTRYP PFNGLRASTERPOS2FPROC)(GLfloat x, GLfloat y); +GLAPI PFNGLRASTERPOS2FPROC glad_glRasterPos2f; +#define glRasterPos2f glad_glRasterPos2f +typedef void (APIENTRYP PFNGLRASTERPOS2FVPROC)(const GLfloat *v); +GLAPI PFNGLRASTERPOS2FVPROC glad_glRasterPos2fv; +#define glRasterPos2fv glad_glRasterPos2fv +typedef void (APIENTRYP PFNGLRASTERPOS2IPROC)(GLint x, GLint y); +GLAPI PFNGLRASTERPOS2IPROC glad_glRasterPos2i; +#define glRasterPos2i glad_glRasterPos2i +typedef void (APIENTRYP PFNGLRASTERPOS2IVPROC)(const GLint *v); +GLAPI PFNGLRASTERPOS2IVPROC glad_glRasterPos2iv; +#define glRasterPos2iv glad_glRasterPos2iv +typedef void (APIENTRYP PFNGLRASTERPOS2SPROC)(GLshort x, GLshort y); +GLAPI PFNGLRASTERPOS2SPROC glad_glRasterPos2s; +#define glRasterPos2s glad_glRasterPos2s +typedef void (APIENTRYP PFNGLRASTERPOS2SVPROC)(const GLshort *v); +GLAPI PFNGLRASTERPOS2SVPROC glad_glRasterPos2sv; +#define glRasterPos2sv glad_glRasterPos2sv +typedef void (APIENTRYP PFNGLRASTERPOS3DPROC)(GLdouble x, GLdouble y, GLdouble z); +GLAPI PFNGLRASTERPOS3DPROC glad_glRasterPos3d; +#define glRasterPos3d glad_glRasterPos3d +typedef void (APIENTRYP PFNGLRASTERPOS3DVPROC)(const GLdouble *v); +GLAPI PFNGLRASTERPOS3DVPROC glad_glRasterPos3dv; +#define glRasterPos3dv glad_glRasterPos3dv +typedef void (APIENTRYP PFNGLRASTERPOS3FPROC)(GLfloat x, GLfloat y, GLfloat z); +GLAPI PFNGLRASTERPOS3FPROC glad_glRasterPos3f; +#define glRasterPos3f glad_glRasterPos3f +typedef void (APIENTRYP PFNGLRASTERPOS3FVPROC)(const GLfloat *v); +GLAPI PFNGLRASTERPOS3FVPROC glad_glRasterPos3fv; +#define glRasterPos3fv glad_glRasterPos3fv +typedef void (APIENTRYP PFNGLRASTERPOS3IPROC)(GLint x, GLint y, GLint z); +GLAPI PFNGLRASTERPOS3IPROC glad_glRasterPos3i; +#define glRasterPos3i glad_glRasterPos3i +typedef void (APIENTRYP PFNGLRASTERPOS3IVPROC)(const GLint *v); +GLAPI PFNGLRASTERPOS3IVPROC glad_glRasterPos3iv; +#define glRasterPos3iv glad_glRasterPos3iv +typedef void (APIENTRYP PFNGLRASTERPOS3SPROC)(GLshort x, GLshort y, GLshort z); +GLAPI PFNGLRASTERPOS3SPROC glad_glRasterPos3s; +#define glRasterPos3s glad_glRasterPos3s +typedef void (APIENTRYP PFNGLRASTERPOS3SVPROC)(const GLshort *v); +GLAPI PFNGLRASTERPOS3SVPROC glad_glRasterPos3sv; +#define glRasterPos3sv glad_glRasterPos3sv +typedef void (APIENTRYP PFNGLRASTERPOS4DPROC)(GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI PFNGLRASTERPOS4DPROC glad_glRasterPos4d; +#define glRasterPos4d glad_glRasterPos4d +typedef void (APIENTRYP PFNGLRASTERPOS4DVPROC)(const GLdouble *v); +GLAPI PFNGLRASTERPOS4DVPROC glad_glRasterPos4dv; +#define glRasterPos4dv glad_glRasterPos4dv +typedef void (APIENTRYP PFNGLRASTERPOS4FPROC)(GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI PFNGLRASTERPOS4FPROC glad_glRasterPos4f; +#define glRasterPos4f glad_glRasterPos4f +typedef void (APIENTRYP PFNGLRASTERPOS4FVPROC)(const GLfloat *v); +GLAPI PFNGLRASTERPOS4FVPROC glad_glRasterPos4fv; +#define glRasterPos4fv glad_glRasterPos4fv +typedef void (APIENTRYP PFNGLRASTERPOS4IPROC)(GLint x, GLint y, GLint z, GLint w); +GLAPI PFNGLRASTERPOS4IPROC glad_glRasterPos4i; +#define glRasterPos4i glad_glRasterPos4i +typedef void (APIENTRYP PFNGLRASTERPOS4IVPROC)(const GLint *v); +GLAPI PFNGLRASTERPOS4IVPROC glad_glRasterPos4iv; +#define glRasterPos4iv glad_glRasterPos4iv +typedef void (APIENTRYP PFNGLRASTERPOS4SPROC)(GLshort x, GLshort y, GLshort z, GLshort w); +GLAPI PFNGLRASTERPOS4SPROC glad_glRasterPos4s; +#define glRasterPos4s glad_glRasterPos4s +typedef void (APIENTRYP PFNGLRASTERPOS4SVPROC)(const GLshort *v); +GLAPI PFNGLRASTERPOS4SVPROC glad_glRasterPos4sv; +#define glRasterPos4sv glad_glRasterPos4sv +typedef void (APIENTRYP PFNGLRECTDPROC)(GLdouble x1, GLdouble y1, GLdouble x2, GLdouble y2); +GLAPI PFNGLRECTDPROC glad_glRectd; +#define glRectd glad_glRectd +typedef void (APIENTRYP PFNGLRECTDVPROC)(const GLdouble *v1, const GLdouble *v2); +GLAPI PFNGLRECTDVPROC glad_glRectdv; +#define glRectdv glad_glRectdv +typedef void (APIENTRYP PFNGLRECTFPROC)(GLfloat x1, GLfloat y1, GLfloat x2, GLfloat y2); +GLAPI PFNGLRECTFPROC glad_glRectf; +#define glRectf glad_glRectf +typedef void (APIENTRYP PFNGLRECTFVPROC)(const GLfloat *v1, const GLfloat *v2); +GLAPI PFNGLRECTFVPROC glad_glRectfv; +#define glRectfv glad_glRectfv +typedef void (APIENTRYP PFNGLRECTIPROC)(GLint x1, GLint y1, GLint x2, GLint y2); +GLAPI PFNGLRECTIPROC glad_glRecti; +#define glRecti glad_glRecti +typedef void (APIENTRYP PFNGLRECTIVPROC)(const GLint *v1, const GLint *v2); +GLAPI PFNGLRECTIVPROC glad_glRectiv; +#define glRectiv glad_glRectiv +typedef void (APIENTRYP PFNGLRECTSPROC)(GLshort x1, GLshort y1, GLshort x2, GLshort y2); +GLAPI PFNGLRECTSPROC glad_glRects; +#define glRects glad_glRects +typedef void (APIENTRYP PFNGLRECTSVPROC)(const GLshort *v1, const GLshort *v2); +GLAPI PFNGLRECTSVPROC glad_glRectsv; +#define glRectsv glad_glRectsv +typedef void (APIENTRYP PFNGLTEXCOORD1DPROC)(GLdouble s); +GLAPI PFNGLTEXCOORD1DPROC glad_glTexCoord1d; +#define glTexCoord1d glad_glTexCoord1d +typedef void (APIENTRYP PFNGLTEXCOORD1DVPROC)(const GLdouble *v); +GLAPI PFNGLTEXCOORD1DVPROC glad_glTexCoord1dv; +#define glTexCoord1dv glad_glTexCoord1dv +typedef void (APIENTRYP PFNGLTEXCOORD1FPROC)(GLfloat s); +GLAPI PFNGLTEXCOORD1FPROC glad_glTexCoord1f; +#define glTexCoord1f glad_glTexCoord1f +typedef void (APIENTRYP PFNGLTEXCOORD1FVPROC)(const GLfloat *v); +GLAPI PFNGLTEXCOORD1FVPROC glad_glTexCoord1fv; +#define glTexCoord1fv glad_glTexCoord1fv +typedef void (APIENTRYP PFNGLTEXCOORD1IPROC)(GLint s); +GLAPI PFNGLTEXCOORD1IPROC glad_glTexCoord1i; +#define glTexCoord1i glad_glTexCoord1i +typedef void (APIENTRYP PFNGLTEXCOORD1IVPROC)(const GLint *v); +GLAPI PFNGLTEXCOORD1IVPROC glad_glTexCoord1iv; +#define glTexCoord1iv glad_glTexCoord1iv +typedef void (APIENTRYP PFNGLTEXCOORD1SPROC)(GLshort s); +GLAPI PFNGLTEXCOORD1SPROC glad_glTexCoord1s; +#define glTexCoord1s glad_glTexCoord1s +typedef void (APIENTRYP PFNGLTEXCOORD1SVPROC)(const GLshort *v); +GLAPI PFNGLTEXCOORD1SVPROC glad_glTexCoord1sv; +#define glTexCoord1sv glad_glTexCoord1sv +typedef void (APIENTRYP PFNGLTEXCOORD2DPROC)(GLdouble s, GLdouble t); +GLAPI PFNGLTEXCOORD2DPROC glad_glTexCoord2d; +#define glTexCoord2d glad_glTexCoord2d +typedef void (APIENTRYP PFNGLTEXCOORD2DVPROC)(const GLdouble *v); +GLAPI PFNGLTEXCOORD2DVPROC glad_glTexCoord2dv; +#define glTexCoord2dv glad_glTexCoord2dv +typedef void (APIENTRYP PFNGLTEXCOORD2FPROC)(GLfloat s, GLfloat t); +GLAPI PFNGLTEXCOORD2FPROC glad_glTexCoord2f; +#define glTexCoord2f glad_glTexCoord2f +typedef void (APIENTRYP PFNGLTEXCOORD2FVPROC)(const GLfloat *v); +GLAPI PFNGLTEXCOORD2FVPROC glad_glTexCoord2fv; +#define glTexCoord2fv glad_glTexCoord2fv +typedef void (APIENTRYP PFNGLTEXCOORD2IPROC)(GLint s, GLint t); +GLAPI PFNGLTEXCOORD2IPROC glad_glTexCoord2i; +#define glTexCoord2i glad_glTexCoord2i +typedef void (APIENTRYP PFNGLTEXCOORD2IVPROC)(const GLint *v); +GLAPI PFNGLTEXCOORD2IVPROC glad_glTexCoord2iv; +#define glTexCoord2iv glad_glTexCoord2iv +typedef void (APIENTRYP PFNGLTEXCOORD2SPROC)(GLshort s, GLshort t); +GLAPI PFNGLTEXCOORD2SPROC glad_glTexCoord2s; +#define glTexCoord2s glad_glTexCoord2s +typedef void (APIENTRYP PFNGLTEXCOORD2SVPROC)(const GLshort *v); +GLAPI PFNGLTEXCOORD2SVPROC glad_glTexCoord2sv; +#define glTexCoord2sv glad_glTexCoord2sv +typedef void (APIENTRYP PFNGLTEXCOORD3DPROC)(GLdouble s, GLdouble t, GLdouble r); +GLAPI PFNGLTEXCOORD3DPROC glad_glTexCoord3d; +#define glTexCoord3d glad_glTexCoord3d +typedef void (APIENTRYP PFNGLTEXCOORD3DVPROC)(const GLdouble *v); +GLAPI PFNGLTEXCOORD3DVPROC glad_glTexCoord3dv; +#define glTexCoord3dv glad_glTexCoord3dv +typedef void (APIENTRYP PFNGLTEXCOORD3FPROC)(GLfloat s, GLfloat t, GLfloat r); +GLAPI PFNGLTEXCOORD3FPROC glad_glTexCoord3f; +#define glTexCoord3f glad_glTexCoord3f +typedef void (APIENTRYP PFNGLTEXCOORD3FVPROC)(const GLfloat *v); +GLAPI PFNGLTEXCOORD3FVPROC glad_glTexCoord3fv; +#define glTexCoord3fv glad_glTexCoord3fv +typedef void (APIENTRYP PFNGLTEXCOORD3IPROC)(GLint s, GLint t, GLint r); +GLAPI PFNGLTEXCOORD3IPROC glad_glTexCoord3i; +#define glTexCoord3i glad_glTexCoord3i +typedef void (APIENTRYP PFNGLTEXCOORD3IVPROC)(const GLint *v); +GLAPI PFNGLTEXCOORD3IVPROC glad_glTexCoord3iv; +#define glTexCoord3iv glad_glTexCoord3iv +typedef void (APIENTRYP PFNGLTEXCOORD3SPROC)(GLshort s, GLshort t, GLshort r); +GLAPI PFNGLTEXCOORD3SPROC glad_glTexCoord3s; +#define glTexCoord3s glad_glTexCoord3s +typedef void (APIENTRYP PFNGLTEXCOORD3SVPROC)(const GLshort *v); +GLAPI PFNGLTEXCOORD3SVPROC glad_glTexCoord3sv; +#define glTexCoord3sv glad_glTexCoord3sv +typedef void (APIENTRYP PFNGLTEXCOORD4DPROC)(GLdouble s, GLdouble t, GLdouble r, GLdouble q); +GLAPI PFNGLTEXCOORD4DPROC glad_glTexCoord4d; +#define glTexCoord4d glad_glTexCoord4d +typedef void (APIENTRYP PFNGLTEXCOORD4DVPROC)(const GLdouble *v); +GLAPI PFNGLTEXCOORD4DVPROC glad_glTexCoord4dv; +#define glTexCoord4dv glad_glTexCoord4dv +typedef void (APIENTRYP PFNGLTEXCOORD4FPROC)(GLfloat s, GLfloat t, GLfloat r, GLfloat q); +GLAPI PFNGLTEXCOORD4FPROC glad_glTexCoord4f; +#define glTexCoord4f glad_glTexCoord4f +typedef void (APIENTRYP PFNGLTEXCOORD4FVPROC)(const GLfloat *v); +GLAPI PFNGLTEXCOORD4FVPROC glad_glTexCoord4fv; +#define glTexCoord4fv glad_glTexCoord4fv +typedef void (APIENTRYP PFNGLTEXCOORD4IPROC)(GLint s, GLint t, GLint r, GLint q); +GLAPI PFNGLTEXCOORD4IPROC glad_glTexCoord4i; +#define glTexCoord4i glad_glTexCoord4i +typedef void (APIENTRYP PFNGLTEXCOORD4IVPROC)(const GLint *v); +GLAPI PFNGLTEXCOORD4IVPROC glad_glTexCoord4iv; +#define glTexCoord4iv glad_glTexCoord4iv +typedef void (APIENTRYP PFNGLTEXCOORD4SPROC)(GLshort s, GLshort t, GLshort r, GLshort q); +GLAPI PFNGLTEXCOORD4SPROC glad_glTexCoord4s; +#define glTexCoord4s glad_glTexCoord4s +typedef void (APIENTRYP PFNGLTEXCOORD4SVPROC)(const GLshort *v); +GLAPI PFNGLTEXCOORD4SVPROC glad_glTexCoord4sv; +#define glTexCoord4sv glad_glTexCoord4sv +typedef void (APIENTRYP PFNGLVERTEX2DPROC)(GLdouble x, GLdouble y); +GLAPI PFNGLVERTEX2DPROC glad_glVertex2d; +#define glVertex2d glad_glVertex2d +typedef void (APIENTRYP PFNGLVERTEX2DVPROC)(const GLdouble *v); +GLAPI PFNGLVERTEX2DVPROC glad_glVertex2dv; +#define glVertex2dv glad_glVertex2dv +typedef void (APIENTRYP PFNGLVERTEX2FPROC)(GLfloat x, GLfloat y); +GLAPI PFNGLVERTEX2FPROC glad_glVertex2f; +#define glVertex2f glad_glVertex2f +typedef void (APIENTRYP PFNGLVERTEX2FVPROC)(const GLfloat *v); +GLAPI PFNGLVERTEX2FVPROC glad_glVertex2fv; +#define glVertex2fv glad_glVertex2fv +typedef void (APIENTRYP PFNGLVERTEX2IPROC)(GLint x, GLint y); +GLAPI PFNGLVERTEX2IPROC glad_glVertex2i; +#define glVertex2i glad_glVertex2i +typedef void (APIENTRYP PFNGLVERTEX2IVPROC)(const GLint *v); +GLAPI PFNGLVERTEX2IVPROC glad_glVertex2iv; +#define glVertex2iv glad_glVertex2iv +typedef void (APIENTRYP PFNGLVERTEX2SPROC)(GLshort x, GLshort y); +GLAPI PFNGLVERTEX2SPROC glad_glVertex2s; +#define glVertex2s glad_glVertex2s +typedef void (APIENTRYP PFNGLVERTEX2SVPROC)(const GLshort *v); +GLAPI PFNGLVERTEX2SVPROC glad_glVertex2sv; +#define glVertex2sv glad_glVertex2sv +typedef void (APIENTRYP PFNGLVERTEX3DPROC)(GLdouble x, GLdouble y, GLdouble z); +GLAPI PFNGLVERTEX3DPROC glad_glVertex3d; +#define glVertex3d glad_glVertex3d +typedef void (APIENTRYP PFNGLVERTEX3DVPROC)(const GLdouble *v); +GLAPI PFNGLVERTEX3DVPROC glad_glVertex3dv; +#define glVertex3dv glad_glVertex3dv +typedef void (APIENTRYP PFNGLVERTEX3FPROC)(GLfloat x, GLfloat y, GLfloat z); +GLAPI PFNGLVERTEX3FPROC glad_glVertex3f; +#define glVertex3f glad_glVertex3f +typedef void (APIENTRYP PFNGLVERTEX3FVPROC)(const GLfloat *v); +GLAPI PFNGLVERTEX3FVPROC glad_glVertex3fv; +#define glVertex3fv glad_glVertex3fv +typedef void (APIENTRYP PFNGLVERTEX3IPROC)(GLint x, GLint y, GLint z); +GLAPI PFNGLVERTEX3IPROC glad_glVertex3i; +#define glVertex3i glad_glVertex3i +typedef void (APIENTRYP PFNGLVERTEX3IVPROC)(const GLint *v); +GLAPI PFNGLVERTEX3IVPROC glad_glVertex3iv; +#define glVertex3iv glad_glVertex3iv +typedef void (APIENTRYP PFNGLVERTEX3SPROC)(GLshort x, GLshort y, GLshort z); +GLAPI PFNGLVERTEX3SPROC glad_glVertex3s; +#define glVertex3s glad_glVertex3s +typedef void (APIENTRYP PFNGLVERTEX3SVPROC)(const GLshort *v); +GLAPI PFNGLVERTEX3SVPROC glad_glVertex3sv; +#define glVertex3sv glad_glVertex3sv +typedef void (APIENTRYP PFNGLVERTEX4DPROC)(GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI PFNGLVERTEX4DPROC glad_glVertex4d; +#define glVertex4d glad_glVertex4d +typedef void (APIENTRYP PFNGLVERTEX4DVPROC)(const GLdouble *v); +GLAPI PFNGLVERTEX4DVPROC glad_glVertex4dv; +#define glVertex4dv glad_glVertex4dv +typedef void (APIENTRYP PFNGLVERTEX4FPROC)(GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI PFNGLVERTEX4FPROC glad_glVertex4f; +#define glVertex4f glad_glVertex4f +typedef void (APIENTRYP PFNGLVERTEX4FVPROC)(const GLfloat *v); +GLAPI PFNGLVERTEX4FVPROC glad_glVertex4fv; +#define glVertex4fv glad_glVertex4fv +typedef void (APIENTRYP PFNGLVERTEX4IPROC)(GLint x, GLint y, GLint z, GLint w); +GLAPI PFNGLVERTEX4IPROC glad_glVertex4i; +#define glVertex4i glad_glVertex4i +typedef void (APIENTRYP PFNGLVERTEX4IVPROC)(const GLint *v); +GLAPI PFNGLVERTEX4IVPROC glad_glVertex4iv; +#define glVertex4iv glad_glVertex4iv +typedef void (APIENTRYP PFNGLVERTEX4SPROC)(GLshort x, GLshort y, GLshort z, GLshort w); +GLAPI PFNGLVERTEX4SPROC glad_glVertex4s; +#define glVertex4s glad_glVertex4s +typedef void (APIENTRYP PFNGLVERTEX4SVPROC)(const GLshort *v); +GLAPI PFNGLVERTEX4SVPROC glad_glVertex4sv; +#define glVertex4sv glad_glVertex4sv +typedef void (APIENTRYP PFNGLCLIPPLANEPROC)(GLenum plane, const GLdouble *equation); +GLAPI PFNGLCLIPPLANEPROC glad_glClipPlane; +#define glClipPlane glad_glClipPlane +typedef void (APIENTRYP PFNGLCOLORMATERIALPROC)(GLenum face, GLenum mode); +GLAPI PFNGLCOLORMATERIALPROC glad_glColorMaterial; +#define glColorMaterial glad_glColorMaterial +typedef void (APIENTRYP PFNGLFOGFPROC)(GLenum pname, GLfloat param); +GLAPI PFNGLFOGFPROC glad_glFogf; +#define glFogf glad_glFogf +typedef void (APIENTRYP PFNGLFOGFVPROC)(GLenum pname, const GLfloat *params); +GLAPI PFNGLFOGFVPROC glad_glFogfv; +#define glFogfv glad_glFogfv +typedef void (APIENTRYP PFNGLFOGIPROC)(GLenum pname, GLint param); +GLAPI PFNGLFOGIPROC glad_glFogi; +#define glFogi glad_glFogi +typedef void (APIENTRYP PFNGLFOGIVPROC)(GLenum pname, const GLint *params); +GLAPI PFNGLFOGIVPROC glad_glFogiv; +#define glFogiv glad_glFogiv +typedef void (APIENTRYP PFNGLLIGHTFPROC)(GLenum light, GLenum pname, GLfloat param); +GLAPI PFNGLLIGHTFPROC glad_glLightf; +#define glLightf glad_glLightf +typedef void (APIENTRYP PFNGLLIGHTFVPROC)(GLenum light, GLenum pname, const GLfloat *params); +GLAPI PFNGLLIGHTFVPROC glad_glLightfv; +#define glLightfv glad_glLightfv +typedef void (APIENTRYP PFNGLLIGHTIPROC)(GLenum light, GLenum pname, GLint param); +GLAPI PFNGLLIGHTIPROC glad_glLighti; +#define glLighti glad_glLighti +typedef void (APIENTRYP PFNGLLIGHTIVPROC)(GLenum light, GLenum pname, const GLint *params); +GLAPI PFNGLLIGHTIVPROC glad_glLightiv; +#define glLightiv glad_glLightiv +typedef void (APIENTRYP PFNGLLIGHTMODELFPROC)(GLenum pname, GLfloat param); +GLAPI PFNGLLIGHTMODELFPROC glad_glLightModelf; +#define glLightModelf glad_glLightModelf +typedef void (APIENTRYP PFNGLLIGHTMODELFVPROC)(GLenum pname, const GLfloat *params); +GLAPI PFNGLLIGHTMODELFVPROC glad_glLightModelfv; +#define glLightModelfv glad_glLightModelfv +typedef void (APIENTRYP PFNGLLIGHTMODELIPROC)(GLenum pname, GLint param); +GLAPI PFNGLLIGHTMODELIPROC glad_glLightModeli; +#define glLightModeli glad_glLightModeli +typedef void (APIENTRYP PFNGLLIGHTMODELIVPROC)(GLenum pname, const GLint *params); +GLAPI PFNGLLIGHTMODELIVPROC glad_glLightModeliv; +#define glLightModeliv glad_glLightModeliv +typedef void (APIENTRYP PFNGLLINESTIPPLEPROC)(GLint factor, GLushort pattern); +GLAPI PFNGLLINESTIPPLEPROC glad_glLineStipple; +#define glLineStipple glad_glLineStipple +typedef void (APIENTRYP PFNGLMATERIALFPROC)(GLenum face, GLenum pname, GLfloat param); +GLAPI PFNGLMATERIALFPROC glad_glMaterialf; +#define glMaterialf glad_glMaterialf +typedef void (APIENTRYP PFNGLMATERIALFVPROC)(GLenum face, GLenum pname, const GLfloat *params); +GLAPI PFNGLMATERIALFVPROC glad_glMaterialfv; +#define glMaterialfv glad_glMaterialfv +typedef void (APIENTRYP PFNGLMATERIALIPROC)(GLenum face, GLenum pname, GLint param); +GLAPI PFNGLMATERIALIPROC glad_glMateriali; +#define glMateriali glad_glMateriali +typedef void (APIENTRYP PFNGLMATERIALIVPROC)(GLenum face, GLenum pname, const GLint *params); +GLAPI PFNGLMATERIALIVPROC glad_glMaterialiv; +#define glMaterialiv glad_glMaterialiv +typedef void (APIENTRYP PFNGLPOLYGONSTIPPLEPROC)(const GLubyte *mask); +GLAPI PFNGLPOLYGONSTIPPLEPROC glad_glPolygonStipple; +#define glPolygonStipple glad_glPolygonStipple +typedef void (APIENTRYP PFNGLSHADEMODELPROC)(GLenum mode); +GLAPI PFNGLSHADEMODELPROC glad_glShadeModel; +#define glShadeModel glad_glShadeModel +typedef void (APIENTRYP PFNGLTEXENVFPROC)(GLenum target, GLenum pname, GLfloat param); +GLAPI PFNGLTEXENVFPROC glad_glTexEnvf; +#define glTexEnvf glad_glTexEnvf +typedef void (APIENTRYP PFNGLTEXENVFVPROC)(GLenum target, GLenum pname, const GLfloat *params); +GLAPI PFNGLTEXENVFVPROC glad_glTexEnvfv; +#define glTexEnvfv glad_glTexEnvfv +typedef void (APIENTRYP PFNGLTEXENVIPROC)(GLenum target, GLenum pname, GLint param); +GLAPI PFNGLTEXENVIPROC glad_glTexEnvi; +#define glTexEnvi glad_glTexEnvi +typedef void (APIENTRYP PFNGLTEXENVIVPROC)(GLenum target, GLenum pname, const GLint *params); +GLAPI PFNGLTEXENVIVPROC glad_glTexEnviv; +#define glTexEnviv glad_glTexEnviv +typedef void (APIENTRYP PFNGLTEXGENDPROC)(GLenum coord, GLenum pname, GLdouble param); +GLAPI PFNGLTEXGENDPROC glad_glTexGend; +#define glTexGend glad_glTexGend +typedef void (APIENTRYP PFNGLTEXGENDVPROC)(GLenum coord, GLenum pname, const GLdouble *params); +GLAPI PFNGLTEXGENDVPROC glad_glTexGendv; +#define glTexGendv glad_glTexGendv +typedef void (APIENTRYP PFNGLTEXGENFPROC)(GLenum coord, GLenum pname, GLfloat param); +GLAPI PFNGLTEXGENFPROC glad_glTexGenf; +#define glTexGenf glad_glTexGenf +typedef void (APIENTRYP PFNGLTEXGENFVPROC)(GLenum coord, GLenum pname, const GLfloat *params); +GLAPI PFNGLTEXGENFVPROC glad_glTexGenfv; +#define glTexGenfv glad_glTexGenfv +typedef void (APIENTRYP PFNGLTEXGENIPROC)(GLenum coord, GLenum pname, GLint param); +GLAPI PFNGLTEXGENIPROC glad_glTexGeni; +#define glTexGeni glad_glTexGeni +typedef void (APIENTRYP PFNGLTEXGENIVPROC)(GLenum coord, GLenum pname, const GLint *params); +GLAPI PFNGLTEXGENIVPROC glad_glTexGeniv; +#define glTexGeniv glad_glTexGeniv +typedef void (APIENTRYP PFNGLFEEDBACKBUFFERPROC)(GLsizei size, GLenum type, GLfloat *buffer); +GLAPI PFNGLFEEDBACKBUFFERPROC glad_glFeedbackBuffer; +#define glFeedbackBuffer glad_glFeedbackBuffer +typedef void (APIENTRYP PFNGLSELECTBUFFERPROC)(GLsizei size, GLuint *buffer); +GLAPI PFNGLSELECTBUFFERPROC glad_glSelectBuffer; +#define glSelectBuffer glad_glSelectBuffer +typedef GLint (APIENTRYP PFNGLRENDERMODEPROC)(GLenum mode); +GLAPI PFNGLRENDERMODEPROC glad_glRenderMode; +#define glRenderMode glad_glRenderMode +typedef void (APIENTRYP PFNGLINITNAMESPROC)(); +GLAPI PFNGLINITNAMESPROC glad_glInitNames; +#define glInitNames glad_glInitNames +typedef void (APIENTRYP PFNGLLOADNAMEPROC)(GLuint name); +GLAPI PFNGLLOADNAMEPROC glad_glLoadName; +#define glLoadName glad_glLoadName +typedef void (APIENTRYP PFNGLPASSTHROUGHPROC)(GLfloat token); +GLAPI PFNGLPASSTHROUGHPROC glad_glPassThrough; +#define glPassThrough glad_glPassThrough +typedef void (APIENTRYP PFNGLPOPNAMEPROC)(); +GLAPI PFNGLPOPNAMEPROC glad_glPopName; +#define glPopName glad_glPopName +typedef void (APIENTRYP PFNGLPUSHNAMEPROC)(GLuint name); +GLAPI PFNGLPUSHNAMEPROC glad_glPushName; +#define glPushName glad_glPushName +typedef void (APIENTRYP PFNGLCLEARACCUMPROC)(GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); +GLAPI PFNGLCLEARACCUMPROC glad_glClearAccum; +#define glClearAccum glad_glClearAccum +typedef void (APIENTRYP PFNGLCLEARINDEXPROC)(GLfloat c); +GLAPI PFNGLCLEARINDEXPROC glad_glClearIndex; +#define glClearIndex glad_glClearIndex +typedef void (APIENTRYP PFNGLINDEXMASKPROC)(GLuint mask); +GLAPI PFNGLINDEXMASKPROC glad_glIndexMask; +#define glIndexMask glad_glIndexMask +typedef void (APIENTRYP PFNGLACCUMPROC)(GLenum op, GLfloat value); +GLAPI PFNGLACCUMPROC glad_glAccum; +#define glAccum glad_glAccum +typedef void (APIENTRYP PFNGLPOPATTRIBPROC)(); +GLAPI PFNGLPOPATTRIBPROC glad_glPopAttrib; +#define glPopAttrib glad_glPopAttrib +typedef void (APIENTRYP PFNGLPUSHATTRIBPROC)(GLbitfield mask); +GLAPI PFNGLPUSHATTRIBPROC glad_glPushAttrib; +#define glPushAttrib glad_glPushAttrib +typedef void (APIENTRYP PFNGLMAP1DPROC)(GLenum target, GLdouble u1, GLdouble u2, GLint stride, GLint order, const GLdouble *points); +GLAPI PFNGLMAP1DPROC glad_glMap1d; +#define glMap1d glad_glMap1d +typedef void (APIENTRYP PFNGLMAP1FPROC)(GLenum target, GLfloat u1, GLfloat u2, GLint stride, GLint order, const GLfloat *points); +GLAPI PFNGLMAP1FPROC glad_glMap1f; +#define glMap1f glad_glMap1f +typedef void (APIENTRYP PFNGLMAP2DPROC)(GLenum target, GLdouble u1, GLdouble u2, GLint ustride, GLint uorder, GLdouble v1, GLdouble v2, GLint vstride, GLint vorder, const GLdouble *points); +GLAPI PFNGLMAP2DPROC glad_glMap2d; +#define glMap2d glad_glMap2d +typedef void (APIENTRYP PFNGLMAP2FPROC)(GLenum target, GLfloat u1, GLfloat u2, GLint ustride, GLint uorder, GLfloat v1, GLfloat v2, GLint vstride, GLint vorder, const GLfloat *points); +GLAPI PFNGLMAP2FPROC glad_glMap2f; +#define glMap2f glad_glMap2f +typedef void (APIENTRYP PFNGLMAPGRID1DPROC)(GLint un, GLdouble u1, GLdouble u2); +GLAPI PFNGLMAPGRID1DPROC glad_glMapGrid1d; +#define glMapGrid1d glad_glMapGrid1d +typedef void (APIENTRYP PFNGLMAPGRID1FPROC)(GLint un, GLfloat u1, GLfloat u2); +GLAPI PFNGLMAPGRID1FPROC glad_glMapGrid1f; +#define glMapGrid1f glad_glMapGrid1f +typedef void (APIENTRYP PFNGLMAPGRID2DPROC)(GLint un, GLdouble u1, GLdouble u2, GLint vn, GLdouble v1, GLdouble v2); +GLAPI PFNGLMAPGRID2DPROC glad_glMapGrid2d; +#define glMapGrid2d glad_glMapGrid2d +typedef void (APIENTRYP PFNGLMAPGRID2FPROC)(GLint un, GLfloat u1, GLfloat u2, GLint vn, GLfloat v1, GLfloat v2); +GLAPI PFNGLMAPGRID2FPROC glad_glMapGrid2f; +#define glMapGrid2f glad_glMapGrid2f +typedef void (APIENTRYP PFNGLEVALCOORD1DPROC)(GLdouble u); +GLAPI PFNGLEVALCOORD1DPROC glad_glEvalCoord1d; +#define glEvalCoord1d glad_glEvalCoord1d +typedef void (APIENTRYP PFNGLEVALCOORD1DVPROC)(const GLdouble *u); +GLAPI PFNGLEVALCOORD1DVPROC glad_glEvalCoord1dv; +#define glEvalCoord1dv glad_glEvalCoord1dv +typedef void (APIENTRYP PFNGLEVALCOORD1FPROC)(GLfloat u); +GLAPI PFNGLEVALCOORD1FPROC glad_glEvalCoord1f; +#define glEvalCoord1f glad_glEvalCoord1f +typedef void (APIENTRYP PFNGLEVALCOORD1FVPROC)(const GLfloat *u); +GLAPI PFNGLEVALCOORD1FVPROC glad_glEvalCoord1fv; +#define glEvalCoord1fv glad_glEvalCoord1fv +typedef void (APIENTRYP PFNGLEVALCOORD2DPROC)(GLdouble u, GLdouble v); +GLAPI PFNGLEVALCOORD2DPROC glad_glEvalCoord2d; +#define glEvalCoord2d glad_glEvalCoord2d +typedef void (APIENTRYP PFNGLEVALCOORD2DVPROC)(const GLdouble *u); +GLAPI PFNGLEVALCOORD2DVPROC glad_glEvalCoord2dv; +#define glEvalCoord2dv glad_glEvalCoord2dv +typedef void (APIENTRYP PFNGLEVALCOORD2FPROC)(GLfloat u, GLfloat v); +GLAPI PFNGLEVALCOORD2FPROC glad_glEvalCoord2f; +#define glEvalCoord2f glad_glEvalCoord2f +typedef void (APIENTRYP PFNGLEVALCOORD2FVPROC)(const GLfloat *u); +GLAPI PFNGLEVALCOORD2FVPROC glad_glEvalCoord2fv; +#define glEvalCoord2fv glad_glEvalCoord2fv +typedef void (APIENTRYP PFNGLEVALMESH1PROC)(GLenum mode, GLint i1, GLint i2); +GLAPI PFNGLEVALMESH1PROC glad_glEvalMesh1; +#define glEvalMesh1 glad_glEvalMesh1 +typedef void (APIENTRYP PFNGLEVALPOINT1PROC)(GLint i); +GLAPI PFNGLEVALPOINT1PROC glad_glEvalPoint1; +#define glEvalPoint1 glad_glEvalPoint1 +typedef void (APIENTRYP PFNGLEVALMESH2PROC)(GLenum mode, GLint i1, GLint i2, GLint j1, GLint j2); +GLAPI PFNGLEVALMESH2PROC glad_glEvalMesh2; +#define glEvalMesh2 glad_glEvalMesh2 +typedef void (APIENTRYP PFNGLEVALPOINT2PROC)(GLint i, GLint j); +GLAPI PFNGLEVALPOINT2PROC glad_glEvalPoint2; +#define glEvalPoint2 glad_glEvalPoint2 +typedef void (APIENTRYP PFNGLALPHAFUNCPROC)(GLenum func, GLfloat ref); +GLAPI PFNGLALPHAFUNCPROC glad_glAlphaFunc; +#define glAlphaFunc glad_glAlphaFunc +typedef void (APIENTRYP PFNGLPIXELZOOMPROC)(GLfloat xfactor, GLfloat yfactor); +GLAPI PFNGLPIXELZOOMPROC glad_glPixelZoom; +#define glPixelZoom glad_glPixelZoom +typedef void (APIENTRYP PFNGLPIXELTRANSFERFPROC)(GLenum pname, GLfloat param); +GLAPI PFNGLPIXELTRANSFERFPROC glad_glPixelTransferf; +#define glPixelTransferf glad_glPixelTransferf +typedef void (APIENTRYP PFNGLPIXELTRANSFERIPROC)(GLenum pname, GLint param); +GLAPI PFNGLPIXELTRANSFERIPROC glad_glPixelTransferi; +#define glPixelTransferi glad_glPixelTransferi +typedef void (APIENTRYP PFNGLPIXELMAPFVPROC)(GLenum map, GLsizei mapsize, const GLfloat *values); +GLAPI PFNGLPIXELMAPFVPROC glad_glPixelMapfv; +#define glPixelMapfv glad_glPixelMapfv +typedef void (APIENTRYP PFNGLPIXELMAPUIVPROC)(GLenum map, GLsizei mapsize, const GLuint *values); +GLAPI PFNGLPIXELMAPUIVPROC glad_glPixelMapuiv; +#define glPixelMapuiv glad_glPixelMapuiv +typedef void (APIENTRYP PFNGLPIXELMAPUSVPROC)(GLenum map, GLsizei mapsize, const GLushort *values); +GLAPI PFNGLPIXELMAPUSVPROC glad_glPixelMapusv; +#define glPixelMapusv glad_glPixelMapusv +typedef void (APIENTRYP PFNGLCOPYPIXELSPROC)(GLint x, GLint y, GLsizei width, GLsizei height, GLenum type); +GLAPI PFNGLCOPYPIXELSPROC glad_glCopyPixels; +#define glCopyPixels glad_glCopyPixels +typedef void (APIENTRYP PFNGLDRAWPIXELSPROC)(GLsizei width, GLsizei height, GLenum format, GLenum type, const void *pixels); +GLAPI PFNGLDRAWPIXELSPROC glad_glDrawPixels; +#define glDrawPixels glad_glDrawPixels +typedef void (APIENTRYP PFNGLGETCLIPPLANEPROC)(GLenum plane, GLdouble *equation); +GLAPI PFNGLGETCLIPPLANEPROC glad_glGetClipPlane; +#define glGetClipPlane glad_glGetClipPlane +typedef void (APIENTRYP PFNGLGETLIGHTFVPROC)(GLenum light, GLenum pname, GLfloat *params); +GLAPI PFNGLGETLIGHTFVPROC glad_glGetLightfv; +#define glGetLightfv glad_glGetLightfv +typedef void (APIENTRYP PFNGLGETLIGHTIVPROC)(GLenum light, GLenum pname, GLint *params); +GLAPI PFNGLGETLIGHTIVPROC glad_glGetLightiv; +#define glGetLightiv glad_glGetLightiv +typedef void (APIENTRYP PFNGLGETMAPDVPROC)(GLenum target, GLenum query, GLdouble *v); +GLAPI PFNGLGETMAPDVPROC glad_glGetMapdv; +#define glGetMapdv glad_glGetMapdv +typedef void (APIENTRYP PFNGLGETMAPFVPROC)(GLenum target, GLenum query, GLfloat *v); +GLAPI PFNGLGETMAPFVPROC glad_glGetMapfv; +#define glGetMapfv glad_glGetMapfv +typedef void (APIENTRYP PFNGLGETMAPIVPROC)(GLenum target, GLenum query, GLint *v); +GLAPI PFNGLGETMAPIVPROC glad_glGetMapiv; +#define glGetMapiv glad_glGetMapiv +typedef void (APIENTRYP PFNGLGETMATERIALFVPROC)(GLenum face, GLenum pname, GLfloat *params); +GLAPI PFNGLGETMATERIALFVPROC glad_glGetMaterialfv; +#define glGetMaterialfv glad_glGetMaterialfv +typedef void (APIENTRYP PFNGLGETMATERIALIVPROC)(GLenum face, GLenum pname, GLint *params); +GLAPI PFNGLGETMATERIALIVPROC glad_glGetMaterialiv; +#define glGetMaterialiv glad_glGetMaterialiv +typedef void (APIENTRYP PFNGLGETPIXELMAPFVPROC)(GLenum map, GLfloat *values); +GLAPI PFNGLGETPIXELMAPFVPROC glad_glGetPixelMapfv; +#define glGetPixelMapfv glad_glGetPixelMapfv +typedef void (APIENTRYP PFNGLGETPIXELMAPUIVPROC)(GLenum map, GLuint *values); +GLAPI PFNGLGETPIXELMAPUIVPROC glad_glGetPixelMapuiv; +#define glGetPixelMapuiv glad_glGetPixelMapuiv +typedef void (APIENTRYP PFNGLGETPIXELMAPUSVPROC)(GLenum map, GLushort *values); +GLAPI PFNGLGETPIXELMAPUSVPROC glad_glGetPixelMapusv; +#define glGetPixelMapusv glad_glGetPixelMapusv +typedef void (APIENTRYP PFNGLGETPOLYGONSTIPPLEPROC)(GLubyte *mask); +GLAPI PFNGLGETPOLYGONSTIPPLEPROC glad_glGetPolygonStipple; +#define glGetPolygonStipple glad_glGetPolygonStipple +typedef void (APIENTRYP PFNGLGETTEXENVFVPROC)(GLenum target, GLenum pname, GLfloat *params); +GLAPI PFNGLGETTEXENVFVPROC glad_glGetTexEnvfv; +#define glGetTexEnvfv glad_glGetTexEnvfv +typedef void (APIENTRYP PFNGLGETTEXENVIVPROC)(GLenum target, GLenum pname, GLint *params); +GLAPI PFNGLGETTEXENVIVPROC glad_glGetTexEnviv; +#define glGetTexEnviv glad_glGetTexEnviv +typedef void (APIENTRYP PFNGLGETTEXGENDVPROC)(GLenum coord, GLenum pname, GLdouble *params); +GLAPI PFNGLGETTEXGENDVPROC glad_glGetTexGendv; +#define glGetTexGendv glad_glGetTexGendv +typedef void (APIENTRYP PFNGLGETTEXGENFVPROC)(GLenum coord, GLenum pname, GLfloat *params); +GLAPI PFNGLGETTEXGENFVPROC glad_glGetTexGenfv; +#define glGetTexGenfv glad_glGetTexGenfv +typedef void (APIENTRYP PFNGLGETTEXGENIVPROC)(GLenum coord, GLenum pname, GLint *params); +GLAPI PFNGLGETTEXGENIVPROC glad_glGetTexGeniv; +#define glGetTexGeniv glad_glGetTexGeniv +typedef GLboolean (APIENTRYP PFNGLISLISTPROC)(GLuint list); +GLAPI PFNGLISLISTPROC glad_glIsList; +#define glIsList glad_glIsList +typedef void (APIENTRYP PFNGLFRUSTUMPROC)(GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); +GLAPI PFNGLFRUSTUMPROC glad_glFrustum; +#define glFrustum glad_glFrustum +typedef void (APIENTRYP PFNGLLOADIDENTITYPROC)(); +GLAPI PFNGLLOADIDENTITYPROC glad_glLoadIdentity; +#define glLoadIdentity glad_glLoadIdentity +typedef void (APIENTRYP PFNGLLOADMATRIXFPROC)(const GLfloat *m); +GLAPI PFNGLLOADMATRIXFPROC glad_glLoadMatrixf; +#define glLoadMatrixf glad_glLoadMatrixf +typedef void (APIENTRYP PFNGLLOADMATRIXDPROC)(const GLdouble *m); +GLAPI PFNGLLOADMATRIXDPROC glad_glLoadMatrixd; +#define glLoadMatrixd glad_glLoadMatrixd +typedef void (APIENTRYP PFNGLMATRIXMODEPROC)(GLenum mode); +GLAPI PFNGLMATRIXMODEPROC glad_glMatrixMode; +#define glMatrixMode glad_glMatrixMode +typedef void (APIENTRYP PFNGLMULTMATRIXFPROC)(const GLfloat *m); +GLAPI PFNGLMULTMATRIXFPROC glad_glMultMatrixf; +#define glMultMatrixf glad_glMultMatrixf +typedef void (APIENTRYP PFNGLMULTMATRIXDPROC)(const GLdouble *m); +GLAPI PFNGLMULTMATRIXDPROC glad_glMultMatrixd; +#define glMultMatrixd glad_glMultMatrixd +typedef void (APIENTRYP PFNGLORTHOPROC)(GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); +GLAPI PFNGLORTHOPROC glad_glOrtho; +#define glOrtho glad_glOrtho +typedef void (APIENTRYP PFNGLPOPMATRIXPROC)(); +GLAPI PFNGLPOPMATRIXPROC glad_glPopMatrix; +#define glPopMatrix glad_glPopMatrix +typedef void (APIENTRYP PFNGLPUSHMATRIXPROC)(); +GLAPI PFNGLPUSHMATRIXPROC glad_glPushMatrix; +#define glPushMatrix glad_glPushMatrix +typedef void (APIENTRYP PFNGLROTATEDPROC)(GLdouble angle, GLdouble x, GLdouble y, GLdouble z); +GLAPI PFNGLROTATEDPROC glad_glRotated; +#define glRotated glad_glRotated +typedef void (APIENTRYP PFNGLROTATEFPROC)(GLfloat angle, GLfloat x, GLfloat y, GLfloat z); +GLAPI PFNGLROTATEFPROC glad_glRotatef; +#define glRotatef glad_glRotatef +typedef void (APIENTRYP PFNGLSCALEDPROC)(GLdouble x, GLdouble y, GLdouble z); +GLAPI PFNGLSCALEDPROC glad_glScaled; +#define glScaled glad_glScaled +typedef void (APIENTRYP PFNGLSCALEFPROC)(GLfloat x, GLfloat y, GLfloat z); +GLAPI PFNGLSCALEFPROC glad_glScalef; +#define glScalef glad_glScalef +typedef void (APIENTRYP PFNGLTRANSLATEDPROC)(GLdouble x, GLdouble y, GLdouble z); +GLAPI PFNGLTRANSLATEDPROC glad_glTranslated; +#define glTranslated glad_glTranslated +typedef void (APIENTRYP PFNGLTRANSLATEFPROC)(GLfloat x, GLfloat y, GLfloat z); +GLAPI PFNGLTRANSLATEFPROC glad_glTranslatef; +#define glTranslatef glad_glTranslatef +#endif +#ifndef GL_VERSION_1_1 +#define GL_VERSION_1_1 1 +GLAPI int GLAD_GL_VERSION_1_1; +typedef void (APIENTRYP PFNGLDRAWARRAYSPROC)(GLenum mode, GLint first, GLsizei count); +GLAPI PFNGLDRAWARRAYSPROC glad_glDrawArrays; +#define glDrawArrays glad_glDrawArrays +typedef void (APIENTRYP PFNGLDRAWELEMENTSPROC)(GLenum mode, GLsizei count, GLenum type, const void *indices); +GLAPI PFNGLDRAWELEMENTSPROC glad_glDrawElements; +#define glDrawElements glad_glDrawElements +typedef void (APIENTRYP PFNGLGETPOINTERVPROC)(GLenum pname, void **params); +GLAPI PFNGLGETPOINTERVPROC glad_glGetPointerv; +#define glGetPointerv glad_glGetPointerv +typedef void (APIENTRYP PFNGLPOLYGONOFFSETPROC)(GLfloat factor, GLfloat units); +GLAPI PFNGLPOLYGONOFFSETPROC glad_glPolygonOffset; +#define glPolygonOffset glad_glPolygonOffset +typedef void (APIENTRYP PFNGLCOPYTEXIMAGE1DPROC)(GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); +GLAPI PFNGLCOPYTEXIMAGE1DPROC glad_glCopyTexImage1D; +#define glCopyTexImage1D glad_glCopyTexImage1D +typedef void (APIENTRYP PFNGLCOPYTEXIMAGE2DPROC)(GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); +GLAPI PFNGLCOPYTEXIMAGE2DPROC glad_glCopyTexImage2D; +#define glCopyTexImage2D glad_glCopyTexImage2D +typedef void (APIENTRYP PFNGLCOPYTEXSUBIMAGE1DPROC)(GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); +GLAPI PFNGLCOPYTEXSUBIMAGE1DPROC glad_glCopyTexSubImage1D; +#define glCopyTexSubImage1D glad_glCopyTexSubImage1D +typedef void (APIENTRYP PFNGLCOPYTEXSUBIMAGE2DPROC)(GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI PFNGLCOPYTEXSUBIMAGE2DPROC glad_glCopyTexSubImage2D; +#define glCopyTexSubImage2D glad_glCopyTexSubImage2D +typedef void (APIENTRYP PFNGLTEXSUBIMAGE1DPROC)(GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void *pixels); +GLAPI PFNGLTEXSUBIMAGE1DPROC glad_glTexSubImage1D; +#define glTexSubImage1D glad_glTexSubImage1D +typedef void (APIENTRYP PFNGLTEXSUBIMAGE2DPROC)(GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void *pixels); +GLAPI PFNGLTEXSUBIMAGE2DPROC glad_glTexSubImage2D; +#define glTexSubImage2D glad_glTexSubImage2D +typedef void (APIENTRYP PFNGLBINDTEXTUREPROC)(GLenum target, GLuint texture); +GLAPI PFNGLBINDTEXTUREPROC glad_glBindTexture; +#define glBindTexture glad_glBindTexture +typedef void (APIENTRYP PFNGLDELETETEXTURESPROC)(GLsizei n, const GLuint *textures); +GLAPI PFNGLDELETETEXTURESPROC glad_glDeleteTextures; +#define glDeleteTextures glad_glDeleteTextures +typedef void (APIENTRYP PFNGLGENTEXTURESPROC)(GLsizei n, GLuint *textures); +GLAPI PFNGLGENTEXTURESPROC glad_glGenTextures; +#define glGenTextures glad_glGenTextures +typedef GLboolean (APIENTRYP PFNGLISTEXTUREPROC)(GLuint texture); +GLAPI PFNGLISTEXTUREPROC glad_glIsTexture; +#define glIsTexture glad_glIsTexture +typedef void (APIENTRYP PFNGLARRAYELEMENTPROC)(GLint i); +GLAPI PFNGLARRAYELEMENTPROC glad_glArrayElement; +#define glArrayElement glad_glArrayElement +typedef void (APIENTRYP PFNGLCOLORPOINTERPROC)(GLint size, GLenum type, GLsizei stride, const void *pointer); +GLAPI PFNGLCOLORPOINTERPROC glad_glColorPointer; +#define glColorPointer glad_glColorPointer +typedef void (APIENTRYP PFNGLDISABLECLIENTSTATEPROC)(GLenum array); +GLAPI PFNGLDISABLECLIENTSTATEPROC glad_glDisableClientState; +#define glDisableClientState glad_glDisableClientState +typedef void (APIENTRYP PFNGLEDGEFLAGPOINTERPROC)(GLsizei stride, const void *pointer); +GLAPI PFNGLEDGEFLAGPOINTERPROC glad_glEdgeFlagPointer; +#define glEdgeFlagPointer glad_glEdgeFlagPointer +typedef void (APIENTRYP PFNGLENABLECLIENTSTATEPROC)(GLenum array); +GLAPI PFNGLENABLECLIENTSTATEPROC glad_glEnableClientState; +#define glEnableClientState glad_glEnableClientState +typedef void (APIENTRYP PFNGLINDEXPOINTERPROC)(GLenum type, GLsizei stride, const void *pointer); +GLAPI PFNGLINDEXPOINTERPROC glad_glIndexPointer; +#define glIndexPointer glad_glIndexPointer +typedef void (APIENTRYP PFNGLINTERLEAVEDARRAYSPROC)(GLenum format, GLsizei stride, const void *pointer); +GLAPI PFNGLINTERLEAVEDARRAYSPROC glad_glInterleavedArrays; +#define glInterleavedArrays glad_glInterleavedArrays +typedef void (APIENTRYP PFNGLNORMALPOINTERPROC)(GLenum type, GLsizei stride, const void *pointer); +GLAPI PFNGLNORMALPOINTERPROC glad_glNormalPointer; +#define glNormalPointer glad_glNormalPointer +typedef void (APIENTRYP PFNGLTEXCOORDPOINTERPROC)(GLint size, GLenum type, GLsizei stride, const void *pointer); +GLAPI PFNGLTEXCOORDPOINTERPROC glad_glTexCoordPointer; +#define glTexCoordPointer glad_glTexCoordPointer +typedef void (APIENTRYP PFNGLVERTEXPOINTERPROC)(GLint size, GLenum type, GLsizei stride, const void *pointer); +GLAPI PFNGLVERTEXPOINTERPROC glad_glVertexPointer; +#define glVertexPointer glad_glVertexPointer +typedef GLboolean (APIENTRYP PFNGLARETEXTURESRESIDENTPROC)(GLsizei n, const GLuint *textures, GLboolean *residences); +GLAPI PFNGLARETEXTURESRESIDENTPROC glad_glAreTexturesResident; +#define glAreTexturesResident glad_glAreTexturesResident +typedef void (APIENTRYP PFNGLPRIORITIZETEXTURESPROC)(GLsizei n, const GLuint *textures, const GLfloat *priorities); +GLAPI PFNGLPRIORITIZETEXTURESPROC glad_glPrioritizeTextures; +#define glPrioritizeTextures glad_glPrioritizeTextures +typedef void (APIENTRYP PFNGLINDEXUBPROC)(GLubyte c); +GLAPI PFNGLINDEXUBPROC glad_glIndexub; +#define glIndexub glad_glIndexub +typedef void (APIENTRYP PFNGLINDEXUBVPROC)(const GLubyte *c); +GLAPI PFNGLINDEXUBVPROC glad_glIndexubv; +#define glIndexubv glad_glIndexubv +typedef void (APIENTRYP PFNGLPOPCLIENTATTRIBPROC)(); +GLAPI PFNGLPOPCLIENTATTRIBPROC glad_glPopClientAttrib; +#define glPopClientAttrib glad_glPopClientAttrib +typedef void (APIENTRYP PFNGLPUSHCLIENTATTRIBPROC)(GLbitfield mask); +GLAPI PFNGLPUSHCLIENTATTRIBPROC glad_glPushClientAttrib; +#define glPushClientAttrib glad_glPushClientAttrib +#endif +#ifndef GL_VERSION_1_2 +#define GL_VERSION_1_2 1 +GLAPI int GLAD_GL_VERSION_1_2; +typedef void (APIENTRYP PFNGLDRAWRANGEELEMENTSPROC)(GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const void *indices); +GLAPI PFNGLDRAWRANGEELEMENTSPROC glad_glDrawRangeElements; +#define glDrawRangeElements glad_glDrawRangeElements +typedef void (APIENTRYP PFNGLTEXIMAGE3DPROC)(GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void *pixels); +GLAPI PFNGLTEXIMAGE3DPROC glad_glTexImage3D; +#define glTexImage3D glad_glTexImage3D +typedef void (APIENTRYP PFNGLTEXSUBIMAGE3DPROC)(GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const void *pixels); +GLAPI PFNGLTEXSUBIMAGE3DPROC glad_glTexSubImage3D; +#define glTexSubImage3D glad_glTexSubImage3D +typedef void (APIENTRYP PFNGLCOPYTEXSUBIMAGE3DPROC)(GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI PFNGLCOPYTEXSUBIMAGE3DPROC glad_glCopyTexSubImage3D; +#define glCopyTexSubImage3D glad_glCopyTexSubImage3D +#endif +#ifndef GL_VERSION_1_3 +#define GL_VERSION_1_3 1 +GLAPI int GLAD_GL_VERSION_1_3; +typedef void (APIENTRYP PFNGLACTIVETEXTUREPROC)(GLenum texture); +GLAPI PFNGLACTIVETEXTUREPROC glad_glActiveTexture; +#define glActiveTexture glad_glActiveTexture +typedef void (APIENTRYP PFNGLSAMPLECOVERAGEPROC)(GLfloat value, GLboolean invert); +GLAPI PFNGLSAMPLECOVERAGEPROC glad_glSampleCoverage; +#define glSampleCoverage glad_glSampleCoverage +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE3DPROC)(GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void *data); +GLAPI PFNGLCOMPRESSEDTEXIMAGE3DPROC glad_glCompressedTexImage3D; +#define glCompressedTexImage3D glad_glCompressedTexImage3D +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE2DPROC)(GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void *data); +GLAPI PFNGLCOMPRESSEDTEXIMAGE2DPROC glad_glCompressedTexImage2D; +#define glCompressedTexImage2D glad_glCompressedTexImage2D +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE1DPROC)(GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void *data); +GLAPI PFNGLCOMPRESSEDTEXIMAGE1DPROC glad_glCompressedTexImage1D; +#define glCompressedTexImage1D glad_glCompressedTexImage1D +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC)(GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const void *data); +GLAPI PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC glad_glCompressedTexSubImage3D; +#define glCompressedTexSubImage3D glad_glCompressedTexSubImage3D +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC)(GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void *data); +GLAPI PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC glad_glCompressedTexSubImage2D; +#define glCompressedTexSubImage2D glad_glCompressedTexSubImage2D +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC)(GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void *data); +GLAPI PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC glad_glCompressedTexSubImage1D; +#define glCompressedTexSubImage1D glad_glCompressedTexSubImage1D +typedef void (APIENTRYP PFNGLGETCOMPRESSEDTEXIMAGEPROC)(GLenum target, GLint level, void *img); +GLAPI PFNGLGETCOMPRESSEDTEXIMAGEPROC glad_glGetCompressedTexImage; +#define glGetCompressedTexImage glad_glGetCompressedTexImage +typedef void (APIENTRYP PFNGLCLIENTACTIVETEXTUREPROC)(GLenum texture); +GLAPI PFNGLCLIENTACTIVETEXTUREPROC glad_glClientActiveTexture; +#define glClientActiveTexture glad_glClientActiveTexture +typedef void (APIENTRYP PFNGLMULTITEXCOORD1DPROC)(GLenum target, GLdouble s); +GLAPI PFNGLMULTITEXCOORD1DPROC glad_glMultiTexCoord1d; +#define glMultiTexCoord1d glad_glMultiTexCoord1d +typedef void (APIENTRYP PFNGLMULTITEXCOORD1DVPROC)(GLenum target, const GLdouble *v); +GLAPI PFNGLMULTITEXCOORD1DVPROC glad_glMultiTexCoord1dv; +#define glMultiTexCoord1dv glad_glMultiTexCoord1dv +typedef void (APIENTRYP PFNGLMULTITEXCOORD1FPROC)(GLenum target, GLfloat s); +GLAPI PFNGLMULTITEXCOORD1FPROC glad_glMultiTexCoord1f; +#define glMultiTexCoord1f glad_glMultiTexCoord1f +typedef void (APIENTRYP PFNGLMULTITEXCOORD1FVPROC)(GLenum target, const GLfloat *v); +GLAPI PFNGLMULTITEXCOORD1FVPROC glad_glMultiTexCoord1fv; +#define glMultiTexCoord1fv glad_glMultiTexCoord1fv +typedef void (APIENTRYP PFNGLMULTITEXCOORD1IPROC)(GLenum target, GLint s); +GLAPI PFNGLMULTITEXCOORD1IPROC glad_glMultiTexCoord1i; +#define glMultiTexCoord1i glad_glMultiTexCoord1i +typedef void (APIENTRYP PFNGLMULTITEXCOORD1IVPROC)(GLenum target, const GLint *v); +GLAPI PFNGLMULTITEXCOORD1IVPROC glad_glMultiTexCoord1iv; +#define glMultiTexCoord1iv glad_glMultiTexCoord1iv +typedef void (APIENTRYP PFNGLMULTITEXCOORD1SPROC)(GLenum target, GLshort s); +GLAPI PFNGLMULTITEXCOORD1SPROC glad_glMultiTexCoord1s; +#define glMultiTexCoord1s glad_glMultiTexCoord1s +typedef void (APIENTRYP PFNGLMULTITEXCOORD1SVPROC)(GLenum target, const GLshort *v); +GLAPI PFNGLMULTITEXCOORD1SVPROC glad_glMultiTexCoord1sv; +#define glMultiTexCoord1sv glad_glMultiTexCoord1sv +typedef void (APIENTRYP PFNGLMULTITEXCOORD2DPROC)(GLenum target, GLdouble s, GLdouble t); +GLAPI PFNGLMULTITEXCOORD2DPROC glad_glMultiTexCoord2d; +#define glMultiTexCoord2d glad_glMultiTexCoord2d +typedef void (APIENTRYP PFNGLMULTITEXCOORD2DVPROC)(GLenum target, const GLdouble *v); +GLAPI PFNGLMULTITEXCOORD2DVPROC glad_glMultiTexCoord2dv; +#define glMultiTexCoord2dv glad_glMultiTexCoord2dv +typedef void (APIENTRYP PFNGLMULTITEXCOORD2FPROC)(GLenum target, GLfloat s, GLfloat t); +GLAPI PFNGLMULTITEXCOORD2FPROC glad_glMultiTexCoord2f; +#define glMultiTexCoord2f glad_glMultiTexCoord2f +typedef void (APIENTRYP PFNGLMULTITEXCOORD2FVPROC)(GLenum target, const GLfloat *v); +GLAPI PFNGLMULTITEXCOORD2FVPROC glad_glMultiTexCoord2fv; +#define glMultiTexCoord2fv glad_glMultiTexCoord2fv +typedef void (APIENTRYP PFNGLMULTITEXCOORD2IPROC)(GLenum target, GLint s, GLint t); +GLAPI PFNGLMULTITEXCOORD2IPROC glad_glMultiTexCoord2i; +#define glMultiTexCoord2i glad_glMultiTexCoord2i +typedef void (APIENTRYP PFNGLMULTITEXCOORD2IVPROC)(GLenum target, const GLint *v); +GLAPI PFNGLMULTITEXCOORD2IVPROC glad_glMultiTexCoord2iv; +#define glMultiTexCoord2iv glad_glMultiTexCoord2iv +typedef void (APIENTRYP PFNGLMULTITEXCOORD2SPROC)(GLenum target, GLshort s, GLshort t); +GLAPI PFNGLMULTITEXCOORD2SPROC glad_glMultiTexCoord2s; +#define glMultiTexCoord2s glad_glMultiTexCoord2s +typedef void (APIENTRYP PFNGLMULTITEXCOORD2SVPROC)(GLenum target, const GLshort *v); +GLAPI PFNGLMULTITEXCOORD2SVPROC glad_glMultiTexCoord2sv; +#define glMultiTexCoord2sv glad_glMultiTexCoord2sv +typedef void (APIENTRYP PFNGLMULTITEXCOORD3DPROC)(GLenum target, GLdouble s, GLdouble t, GLdouble r); +GLAPI PFNGLMULTITEXCOORD3DPROC glad_glMultiTexCoord3d; +#define glMultiTexCoord3d glad_glMultiTexCoord3d +typedef void (APIENTRYP PFNGLMULTITEXCOORD3DVPROC)(GLenum target, const GLdouble *v); +GLAPI PFNGLMULTITEXCOORD3DVPROC glad_glMultiTexCoord3dv; +#define glMultiTexCoord3dv glad_glMultiTexCoord3dv +typedef void (APIENTRYP PFNGLMULTITEXCOORD3FPROC)(GLenum target, GLfloat s, GLfloat t, GLfloat r); +GLAPI PFNGLMULTITEXCOORD3FPROC glad_glMultiTexCoord3f; +#define glMultiTexCoord3f glad_glMultiTexCoord3f +typedef void (APIENTRYP PFNGLMULTITEXCOORD3FVPROC)(GLenum target, const GLfloat *v); +GLAPI PFNGLMULTITEXCOORD3FVPROC glad_glMultiTexCoord3fv; +#define glMultiTexCoord3fv glad_glMultiTexCoord3fv +typedef void (APIENTRYP PFNGLMULTITEXCOORD3IPROC)(GLenum target, GLint s, GLint t, GLint r); +GLAPI PFNGLMULTITEXCOORD3IPROC glad_glMultiTexCoord3i; +#define glMultiTexCoord3i glad_glMultiTexCoord3i +typedef void (APIENTRYP PFNGLMULTITEXCOORD3IVPROC)(GLenum target, const GLint *v); +GLAPI PFNGLMULTITEXCOORD3IVPROC glad_glMultiTexCoord3iv; +#define glMultiTexCoord3iv glad_glMultiTexCoord3iv +typedef void (APIENTRYP PFNGLMULTITEXCOORD3SPROC)(GLenum target, GLshort s, GLshort t, GLshort r); +GLAPI PFNGLMULTITEXCOORD3SPROC glad_glMultiTexCoord3s; +#define glMultiTexCoord3s glad_glMultiTexCoord3s +typedef void (APIENTRYP PFNGLMULTITEXCOORD3SVPROC)(GLenum target, const GLshort *v); +GLAPI PFNGLMULTITEXCOORD3SVPROC glad_glMultiTexCoord3sv; +#define glMultiTexCoord3sv glad_glMultiTexCoord3sv +typedef void (APIENTRYP PFNGLMULTITEXCOORD4DPROC)(GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); +GLAPI PFNGLMULTITEXCOORD4DPROC glad_glMultiTexCoord4d; +#define glMultiTexCoord4d glad_glMultiTexCoord4d +typedef void (APIENTRYP PFNGLMULTITEXCOORD4DVPROC)(GLenum target, const GLdouble *v); +GLAPI PFNGLMULTITEXCOORD4DVPROC glad_glMultiTexCoord4dv; +#define glMultiTexCoord4dv glad_glMultiTexCoord4dv +typedef void (APIENTRYP PFNGLMULTITEXCOORD4FPROC)(GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); +GLAPI PFNGLMULTITEXCOORD4FPROC glad_glMultiTexCoord4f; +#define glMultiTexCoord4f glad_glMultiTexCoord4f +typedef void (APIENTRYP PFNGLMULTITEXCOORD4FVPROC)(GLenum target, const GLfloat *v); +GLAPI PFNGLMULTITEXCOORD4FVPROC glad_glMultiTexCoord4fv; +#define glMultiTexCoord4fv glad_glMultiTexCoord4fv +typedef void (APIENTRYP PFNGLMULTITEXCOORD4IPROC)(GLenum target, GLint s, GLint t, GLint r, GLint q); +GLAPI PFNGLMULTITEXCOORD4IPROC glad_glMultiTexCoord4i; +#define glMultiTexCoord4i glad_glMultiTexCoord4i +typedef void (APIENTRYP PFNGLMULTITEXCOORD4IVPROC)(GLenum target, const GLint *v); +GLAPI PFNGLMULTITEXCOORD4IVPROC glad_glMultiTexCoord4iv; +#define glMultiTexCoord4iv glad_glMultiTexCoord4iv +typedef void (APIENTRYP PFNGLMULTITEXCOORD4SPROC)(GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); +GLAPI PFNGLMULTITEXCOORD4SPROC glad_glMultiTexCoord4s; +#define glMultiTexCoord4s glad_glMultiTexCoord4s +typedef void (APIENTRYP PFNGLMULTITEXCOORD4SVPROC)(GLenum target, const GLshort *v); +GLAPI PFNGLMULTITEXCOORD4SVPROC glad_glMultiTexCoord4sv; +#define glMultiTexCoord4sv glad_glMultiTexCoord4sv +typedef void (APIENTRYP PFNGLLOADTRANSPOSEMATRIXFPROC)(const GLfloat *m); +GLAPI PFNGLLOADTRANSPOSEMATRIXFPROC glad_glLoadTransposeMatrixf; +#define glLoadTransposeMatrixf glad_glLoadTransposeMatrixf +typedef void (APIENTRYP PFNGLLOADTRANSPOSEMATRIXDPROC)(const GLdouble *m); +GLAPI PFNGLLOADTRANSPOSEMATRIXDPROC glad_glLoadTransposeMatrixd; +#define glLoadTransposeMatrixd glad_glLoadTransposeMatrixd +typedef void (APIENTRYP PFNGLMULTTRANSPOSEMATRIXFPROC)(const GLfloat *m); +GLAPI PFNGLMULTTRANSPOSEMATRIXFPROC glad_glMultTransposeMatrixf; +#define glMultTransposeMatrixf glad_glMultTransposeMatrixf +typedef void (APIENTRYP PFNGLMULTTRANSPOSEMATRIXDPROC)(const GLdouble *m); +GLAPI PFNGLMULTTRANSPOSEMATRIXDPROC glad_glMultTransposeMatrixd; +#define glMultTransposeMatrixd glad_glMultTransposeMatrixd +#endif +#ifndef GL_VERSION_1_4 +#define GL_VERSION_1_4 1 +GLAPI int GLAD_GL_VERSION_1_4; +typedef void (APIENTRYP PFNGLBLENDFUNCSEPARATEPROC)(GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); +GLAPI PFNGLBLENDFUNCSEPARATEPROC glad_glBlendFuncSeparate; +#define glBlendFuncSeparate glad_glBlendFuncSeparate +typedef void (APIENTRYP PFNGLMULTIDRAWARRAYSPROC)(GLenum mode, const GLint *first, const GLsizei *count, GLsizei drawcount); +GLAPI PFNGLMULTIDRAWARRAYSPROC glad_glMultiDrawArrays; +#define glMultiDrawArrays glad_glMultiDrawArrays +typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSPROC)(GLenum mode, const GLsizei *count, GLenum type, const void *const*indices, GLsizei drawcount); +GLAPI PFNGLMULTIDRAWELEMENTSPROC glad_glMultiDrawElements; +#define glMultiDrawElements glad_glMultiDrawElements +typedef void (APIENTRYP PFNGLPOINTPARAMETERFPROC)(GLenum pname, GLfloat param); +GLAPI PFNGLPOINTPARAMETERFPROC glad_glPointParameterf; +#define glPointParameterf glad_glPointParameterf +typedef void (APIENTRYP PFNGLPOINTPARAMETERFVPROC)(GLenum pname, const GLfloat *params); +GLAPI PFNGLPOINTPARAMETERFVPROC glad_glPointParameterfv; +#define glPointParameterfv glad_glPointParameterfv +typedef void (APIENTRYP PFNGLPOINTPARAMETERIPROC)(GLenum pname, GLint param); +GLAPI PFNGLPOINTPARAMETERIPROC glad_glPointParameteri; +#define glPointParameteri glad_glPointParameteri +typedef void (APIENTRYP PFNGLPOINTPARAMETERIVPROC)(GLenum pname, const GLint *params); +GLAPI PFNGLPOINTPARAMETERIVPROC glad_glPointParameteriv; +#define glPointParameteriv glad_glPointParameteriv +typedef void (APIENTRYP PFNGLFOGCOORDFPROC)(GLfloat coord); +GLAPI PFNGLFOGCOORDFPROC glad_glFogCoordf; +#define glFogCoordf glad_glFogCoordf +typedef void (APIENTRYP PFNGLFOGCOORDFVPROC)(const GLfloat *coord); +GLAPI PFNGLFOGCOORDFVPROC glad_glFogCoordfv; +#define glFogCoordfv glad_glFogCoordfv +typedef void (APIENTRYP PFNGLFOGCOORDDPROC)(GLdouble coord); +GLAPI PFNGLFOGCOORDDPROC glad_glFogCoordd; +#define glFogCoordd glad_glFogCoordd +typedef void (APIENTRYP PFNGLFOGCOORDDVPROC)(const GLdouble *coord); +GLAPI PFNGLFOGCOORDDVPROC glad_glFogCoorddv; +#define glFogCoorddv glad_glFogCoorddv +typedef void (APIENTRYP PFNGLFOGCOORDPOINTERPROC)(GLenum type, GLsizei stride, const void *pointer); +GLAPI PFNGLFOGCOORDPOINTERPROC glad_glFogCoordPointer; +#define glFogCoordPointer glad_glFogCoordPointer +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3BPROC)(GLbyte red, GLbyte green, GLbyte blue); +GLAPI PFNGLSECONDARYCOLOR3BPROC glad_glSecondaryColor3b; +#define glSecondaryColor3b glad_glSecondaryColor3b +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3BVPROC)(const GLbyte *v); +GLAPI PFNGLSECONDARYCOLOR3BVPROC glad_glSecondaryColor3bv; +#define glSecondaryColor3bv glad_glSecondaryColor3bv +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3DPROC)(GLdouble red, GLdouble green, GLdouble blue); +GLAPI PFNGLSECONDARYCOLOR3DPROC glad_glSecondaryColor3d; +#define glSecondaryColor3d glad_glSecondaryColor3d +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3DVPROC)(const GLdouble *v); +GLAPI PFNGLSECONDARYCOLOR3DVPROC glad_glSecondaryColor3dv; +#define glSecondaryColor3dv glad_glSecondaryColor3dv +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3FPROC)(GLfloat red, GLfloat green, GLfloat blue); +GLAPI PFNGLSECONDARYCOLOR3FPROC glad_glSecondaryColor3f; +#define glSecondaryColor3f glad_glSecondaryColor3f +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3FVPROC)(const GLfloat *v); +GLAPI PFNGLSECONDARYCOLOR3FVPROC glad_glSecondaryColor3fv; +#define glSecondaryColor3fv glad_glSecondaryColor3fv +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3IPROC)(GLint red, GLint green, GLint blue); +GLAPI PFNGLSECONDARYCOLOR3IPROC glad_glSecondaryColor3i; +#define glSecondaryColor3i glad_glSecondaryColor3i +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3IVPROC)(const GLint *v); +GLAPI PFNGLSECONDARYCOLOR3IVPROC glad_glSecondaryColor3iv; +#define glSecondaryColor3iv glad_glSecondaryColor3iv +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3SPROC)(GLshort red, GLshort green, GLshort blue); +GLAPI PFNGLSECONDARYCOLOR3SPROC glad_glSecondaryColor3s; +#define glSecondaryColor3s glad_glSecondaryColor3s +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3SVPROC)(const GLshort *v); +GLAPI PFNGLSECONDARYCOLOR3SVPROC glad_glSecondaryColor3sv; +#define glSecondaryColor3sv glad_glSecondaryColor3sv +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UBPROC)(GLubyte red, GLubyte green, GLubyte blue); +GLAPI PFNGLSECONDARYCOLOR3UBPROC glad_glSecondaryColor3ub; +#define glSecondaryColor3ub glad_glSecondaryColor3ub +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UBVPROC)(const GLubyte *v); +GLAPI PFNGLSECONDARYCOLOR3UBVPROC glad_glSecondaryColor3ubv; +#define glSecondaryColor3ubv glad_glSecondaryColor3ubv +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UIPROC)(GLuint red, GLuint green, GLuint blue); +GLAPI PFNGLSECONDARYCOLOR3UIPROC glad_glSecondaryColor3ui; +#define glSecondaryColor3ui glad_glSecondaryColor3ui +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UIVPROC)(const GLuint *v); +GLAPI PFNGLSECONDARYCOLOR3UIVPROC glad_glSecondaryColor3uiv; +#define glSecondaryColor3uiv glad_glSecondaryColor3uiv +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3USPROC)(GLushort red, GLushort green, GLushort blue); +GLAPI PFNGLSECONDARYCOLOR3USPROC glad_glSecondaryColor3us; +#define glSecondaryColor3us glad_glSecondaryColor3us +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3USVPROC)(const GLushort *v); +GLAPI PFNGLSECONDARYCOLOR3USVPROC glad_glSecondaryColor3usv; +#define glSecondaryColor3usv glad_glSecondaryColor3usv +typedef void (APIENTRYP PFNGLSECONDARYCOLORPOINTERPROC)(GLint size, GLenum type, GLsizei stride, const void *pointer); +GLAPI PFNGLSECONDARYCOLORPOINTERPROC glad_glSecondaryColorPointer; +#define glSecondaryColorPointer glad_glSecondaryColorPointer +typedef void (APIENTRYP PFNGLWINDOWPOS2DPROC)(GLdouble x, GLdouble y); +GLAPI PFNGLWINDOWPOS2DPROC glad_glWindowPos2d; +#define glWindowPos2d glad_glWindowPos2d +typedef void (APIENTRYP PFNGLWINDOWPOS2DVPROC)(const GLdouble *v); +GLAPI PFNGLWINDOWPOS2DVPROC glad_glWindowPos2dv; +#define glWindowPos2dv glad_glWindowPos2dv +typedef void (APIENTRYP PFNGLWINDOWPOS2FPROC)(GLfloat x, GLfloat y); +GLAPI PFNGLWINDOWPOS2FPROC glad_glWindowPos2f; +#define glWindowPos2f glad_glWindowPos2f +typedef void (APIENTRYP PFNGLWINDOWPOS2FVPROC)(const GLfloat *v); +GLAPI PFNGLWINDOWPOS2FVPROC glad_glWindowPos2fv; +#define glWindowPos2fv glad_glWindowPos2fv +typedef void (APIENTRYP PFNGLWINDOWPOS2IPROC)(GLint x, GLint y); +GLAPI PFNGLWINDOWPOS2IPROC glad_glWindowPos2i; +#define glWindowPos2i glad_glWindowPos2i +typedef void (APIENTRYP PFNGLWINDOWPOS2IVPROC)(const GLint *v); +GLAPI PFNGLWINDOWPOS2IVPROC glad_glWindowPos2iv; +#define glWindowPos2iv glad_glWindowPos2iv +typedef void (APIENTRYP PFNGLWINDOWPOS2SPROC)(GLshort x, GLshort y); +GLAPI PFNGLWINDOWPOS2SPROC glad_glWindowPos2s; +#define glWindowPos2s glad_glWindowPos2s +typedef void (APIENTRYP PFNGLWINDOWPOS2SVPROC)(const GLshort *v); +GLAPI PFNGLWINDOWPOS2SVPROC glad_glWindowPos2sv; +#define glWindowPos2sv glad_glWindowPos2sv +typedef void (APIENTRYP PFNGLWINDOWPOS3DPROC)(GLdouble x, GLdouble y, GLdouble z); +GLAPI PFNGLWINDOWPOS3DPROC glad_glWindowPos3d; +#define glWindowPos3d glad_glWindowPos3d +typedef void (APIENTRYP PFNGLWINDOWPOS3DVPROC)(const GLdouble *v); +GLAPI PFNGLWINDOWPOS3DVPROC glad_glWindowPos3dv; +#define glWindowPos3dv glad_glWindowPos3dv +typedef void (APIENTRYP PFNGLWINDOWPOS3FPROC)(GLfloat x, GLfloat y, GLfloat z); +GLAPI PFNGLWINDOWPOS3FPROC glad_glWindowPos3f; +#define glWindowPos3f glad_glWindowPos3f +typedef void (APIENTRYP PFNGLWINDOWPOS3FVPROC)(const GLfloat *v); +GLAPI PFNGLWINDOWPOS3FVPROC glad_glWindowPos3fv; +#define glWindowPos3fv glad_glWindowPos3fv +typedef void (APIENTRYP PFNGLWINDOWPOS3IPROC)(GLint x, GLint y, GLint z); +GLAPI PFNGLWINDOWPOS3IPROC glad_glWindowPos3i; +#define glWindowPos3i glad_glWindowPos3i +typedef void (APIENTRYP PFNGLWINDOWPOS3IVPROC)(const GLint *v); +GLAPI PFNGLWINDOWPOS3IVPROC glad_glWindowPos3iv; +#define glWindowPos3iv glad_glWindowPos3iv +typedef void (APIENTRYP PFNGLWINDOWPOS3SPROC)(GLshort x, GLshort y, GLshort z); +GLAPI PFNGLWINDOWPOS3SPROC glad_glWindowPos3s; +#define glWindowPos3s glad_glWindowPos3s +typedef void (APIENTRYP PFNGLWINDOWPOS3SVPROC)(const GLshort *v); +GLAPI PFNGLWINDOWPOS3SVPROC glad_glWindowPos3sv; +#define glWindowPos3sv glad_glWindowPos3sv +typedef void (APIENTRYP PFNGLBLENDCOLORPROC)(GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); +GLAPI PFNGLBLENDCOLORPROC glad_glBlendColor; +#define glBlendColor glad_glBlendColor +typedef void (APIENTRYP PFNGLBLENDEQUATIONPROC)(GLenum mode); +GLAPI PFNGLBLENDEQUATIONPROC glad_glBlendEquation; +#define glBlendEquation glad_glBlendEquation +#endif +#ifndef GL_VERSION_1_5 +#define GL_VERSION_1_5 1 +GLAPI int GLAD_GL_VERSION_1_5; +typedef void (APIENTRYP PFNGLGENQUERIESPROC)(GLsizei n, GLuint *ids); +GLAPI PFNGLGENQUERIESPROC glad_glGenQueries; +#define glGenQueries glad_glGenQueries +typedef void (APIENTRYP PFNGLDELETEQUERIESPROC)(GLsizei n, const GLuint *ids); +GLAPI PFNGLDELETEQUERIESPROC glad_glDeleteQueries; +#define glDeleteQueries glad_glDeleteQueries +typedef GLboolean (APIENTRYP PFNGLISQUERYPROC)(GLuint id); +GLAPI PFNGLISQUERYPROC glad_glIsQuery; +#define glIsQuery glad_glIsQuery +typedef void (APIENTRYP PFNGLBEGINQUERYPROC)(GLenum target, GLuint id); +GLAPI PFNGLBEGINQUERYPROC glad_glBeginQuery; +#define glBeginQuery glad_glBeginQuery +typedef void (APIENTRYP PFNGLENDQUERYPROC)(GLenum target); +GLAPI PFNGLENDQUERYPROC glad_glEndQuery; +#define glEndQuery glad_glEndQuery +typedef void (APIENTRYP PFNGLGETQUERYIVPROC)(GLenum target, GLenum pname, GLint *params); +GLAPI PFNGLGETQUERYIVPROC glad_glGetQueryiv; +#define glGetQueryiv glad_glGetQueryiv +typedef void (APIENTRYP PFNGLGETQUERYOBJECTIVPROC)(GLuint id, GLenum pname, GLint *params); +GLAPI PFNGLGETQUERYOBJECTIVPROC glad_glGetQueryObjectiv; +#define glGetQueryObjectiv glad_glGetQueryObjectiv +typedef void (APIENTRYP PFNGLGETQUERYOBJECTUIVPROC)(GLuint id, GLenum pname, GLuint *params); +GLAPI PFNGLGETQUERYOBJECTUIVPROC glad_glGetQueryObjectuiv; +#define glGetQueryObjectuiv glad_glGetQueryObjectuiv +typedef void (APIENTRYP PFNGLBINDBUFFERPROC)(GLenum target, GLuint buffer); +GLAPI PFNGLBINDBUFFERPROC glad_glBindBuffer; +#define glBindBuffer glad_glBindBuffer +typedef void (APIENTRYP PFNGLDELETEBUFFERSPROC)(GLsizei n, const GLuint *buffers); +GLAPI PFNGLDELETEBUFFERSPROC glad_glDeleteBuffers; +#define glDeleteBuffers glad_glDeleteBuffers +typedef void (APIENTRYP PFNGLGENBUFFERSPROC)(GLsizei n, GLuint *buffers); +GLAPI PFNGLGENBUFFERSPROC glad_glGenBuffers; +#define glGenBuffers glad_glGenBuffers +typedef GLboolean (APIENTRYP PFNGLISBUFFERPROC)(GLuint buffer); +GLAPI PFNGLISBUFFERPROC glad_glIsBuffer; +#define glIsBuffer glad_glIsBuffer +typedef void (APIENTRYP PFNGLBUFFERDATAPROC)(GLenum target, GLsizeiptr size, const void *data, GLenum usage); +GLAPI PFNGLBUFFERDATAPROC glad_glBufferData; +#define glBufferData glad_glBufferData +typedef void (APIENTRYP PFNGLBUFFERSUBDATAPROC)(GLenum target, GLintptr offset, GLsizeiptr size, const void *data); +GLAPI PFNGLBUFFERSUBDATAPROC glad_glBufferSubData; +#define glBufferSubData glad_glBufferSubData +typedef void (APIENTRYP PFNGLGETBUFFERSUBDATAPROC)(GLenum target, GLintptr offset, GLsizeiptr size, void *data); +GLAPI PFNGLGETBUFFERSUBDATAPROC glad_glGetBufferSubData; +#define glGetBufferSubData glad_glGetBufferSubData +typedef void * (APIENTRYP PFNGLMAPBUFFERPROC)(GLenum target, GLenum access); +GLAPI PFNGLMAPBUFFERPROC glad_glMapBuffer; +#define glMapBuffer glad_glMapBuffer +typedef GLboolean (APIENTRYP PFNGLUNMAPBUFFERPROC)(GLenum target); +GLAPI PFNGLUNMAPBUFFERPROC glad_glUnmapBuffer; +#define glUnmapBuffer glad_glUnmapBuffer +typedef void (APIENTRYP PFNGLGETBUFFERPARAMETERIVPROC)(GLenum target, GLenum pname, GLint *params); +GLAPI PFNGLGETBUFFERPARAMETERIVPROC glad_glGetBufferParameteriv; +#define glGetBufferParameteriv glad_glGetBufferParameteriv +typedef void (APIENTRYP PFNGLGETBUFFERPOINTERVPROC)(GLenum target, GLenum pname, void **params); +GLAPI PFNGLGETBUFFERPOINTERVPROC glad_glGetBufferPointerv; +#define glGetBufferPointerv glad_glGetBufferPointerv +#endif +#ifndef GL_VERSION_2_0 +#define GL_VERSION_2_0 1 +GLAPI int GLAD_GL_VERSION_2_0; +typedef void (APIENTRYP PFNGLBLENDEQUATIONSEPARATEPROC)(GLenum modeRGB, GLenum modeAlpha); +GLAPI PFNGLBLENDEQUATIONSEPARATEPROC glad_glBlendEquationSeparate; +#define glBlendEquationSeparate glad_glBlendEquationSeparate +typedef void (APIENTRYP PFNGLDRAWBUFFERSPROC)(GLsizei n, const GLenum *bufs); +GLAPI PFNGLDRAWBUFFERSPROC glad_glDrawBuffers; +#define glDrawBuffers glad_glDrawBuffers +typedef void (APIENTRYP PFNGLSTENCILOPSEPARATEPROC)(GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass); +GLAPI PFNGLSTENCILOPSEPARATEPROC glad_glStencilOpSeparate; +#define glStencilOpSeparate glad_glStencilOpSeparate +typedef void (APIENTRYP PFNGLSTENCILFUNCSEPARATEPROC)(GLenum face, GLenum func, GLint ref, GLuint mask); +GLAPI PFNGLSTENCILFUNCSEPARATEPROC glad_glStencilFuncSeparate; +#define glStencilFuncSeparate glad_glStencilFuncSeparate +typedef void (APIENTRYP PFNGLSTENCILMASKSEPARATEPROC)(GLenum face, GLuint mask); +GLAPI PFNGLSTENCILMASKSEPARATEPROC glad_glStencilMaskSeparate; +#define glStencilMaskSeparate glad_glStencilMaskSeparate +typedef void (APIENTRYP PFNGLATTACHSHADERPROC)(GLuint program, GLuint shader); +GLAPI PFNGLATTACHSHADERPROC glad_glAttachShader; +#define glAttachShader glad_glAttachShader +typedef void (APIENTRYP PFNGLBINDATTRIBLOCATIONPROC)(GLuint program, GLuint index, const GLchar *name); +GLAPI PFNGLBINDATTRIBLOCATIONPROC glad_glBindAttribLocation; +#define glBindAttribLocation glad_glBindAttribLocation +typedef void (APIENTRYP PFNGLCOMPILESHADERPROC)(GLuint shader); +GLAPI PFNGLCOMPILESHADERPROC glad_glCompileShader; +#define glCompileShader glad_glCompileShader +typedef GLuint (APIENTRYP PFNGLCREATEPROGRAMPROC)(); +GLAPI PFNGLCREATEPROGRAMPROC glad_glCreateProgram; +#define glCreateProgram glad_glCreateProgram +typedef GLuint (APIENTRYP PFNGLCREATESHADERPROC)(GLenum type); +GLAPI PFNGLCREATESHADERPROC glad_glCreateShader; +#define glCreateShader glad_glCreateShader +typedef void (APIENTRYP PFNGLDELETEPROGRAMPROC)(GLuint program); +GLAPI PFNGLDELETEPROGRAMPROC glad_glDeleteProgram; +#define glDeleteProgram glad_glDeleteProgram +typedef void (APIENTRYP PFNGLDELETESHADERPROC)(GLuint shader); +GLAPI PFNGLDELETESHADERPROC glad_glDeleteShader; +#define glDeleteShader glad_glDeleteShader +typedef void (APIENTRYP PFNGLDETACHSHADERPROC)(GLuint program, GLuint shader); +GLAPI PFNGLDETACHSHADERPROC glad_glDetachShader; +#define glDetachShader glad_glDetachShader +typedef void (APIENTRYP PFNGLDISABLEVERTEXATTRIBARRAYPROC)(GLuint index); +GLAPI PFNGLDISABLEVERTEXATTRIBARRAYPROC glad_glDisableVertexAttribArray; +#define glDisableVertexAttribArray glad_glDisableVertexAttribArray +typedef void (APIENTRYP PFNGLENABLEVERTEXATTRIBARRAYPROC)(GLuint index); +GLAPI PFNGLENABLEVERTEXATTRIBARRAYPROC glad_glEnableVertexAttribArray; +#define glEnableVertexAttribArray glad_glEnableVertexAttribArray +typedef void (APIENTRYP PFNGLGETACTIVEATTRIBPROC)(GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLint *size, GLenum *type, GLchar *name); +GLAPI PFNGLGETACTIVEATTRIBPROC glad_glGetActiveAttrib; +#define glGetActiveAttrib glad_glGetActiveAttrib +typedef void (APIENTRYP PFNGLGETACTIVEUNIFORMPROC)(GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLint *size, GLenum *type, GLchar *name); +GLAPI PFNGLGETACTIVEUNIFORMPROC glad_glGetActiveUniform; +#define glGetActiveUniform glad_glGetActiveUniform +typedef void (APIENTRYP PFNGLGETATTACHEDSHADERSPROC)(GLuint program, GLsizei maxCount, GLsizei *count, GLuint *shaders); +GLAPI PFNGLGETATTACHEDSHADERSPROC glad_glGetAttachedShaders; +#define glGetAttachedShaders glad_glGetAttachedShaders +typedef GLint (APIENTRYP PFNGLGETATTRIBLOCATIONPROC)(GLuint program, const GLchar *name); +GLAPI PFNGLGETATTRIBLOCATIONPROC glad_glGetAttribLocation; +#define glGetAttribLocation glad_glGetAttribLocation +typedef void (APIENTRYP PFNGLGETPROGRAMIVPROC)(GLuint program, GLenum pname, GLint *params); +GLAPI PFNGLGETPROGRAMIVPROC glad_glGetProgramiv; +#define glGetProgramiv glad_glGetProgramiv +typedef void (APIENTRYP PFNGLGETPROGRAMINFOLOGPROC)(GLuint program, GLsizei bufSize, GLsizei *length, GLchar *infoLog); +GLAPI PFNGLGETPROGRAMINFOLOGPROC glad_glGetProgramInfoLog; +#define glGetProgramInfoLog glad_glGetProgramInfoLog +typedef void (APIENTRYP PFNGLGETSHADERIVPROC)(GLuint shader, GLenum pname, GLint *params); +GLAPI PFNGLGETSHADERIVPROC glad_glGetShaderiv; +#define glGetShaderiv glad_glGetShaderiv +typedef void (APIENTRYP PFNGLGETSHADERINFOLOGPROC)(GLuint shader, GLsizei bufSize, GLsizei *length, GLchar *infoLog); +GLAPI PFNGLGETSHADERINFOLOGPROC glad_glGetShaderInfoLog; +#define glGetShaderInfoLog glad_glGetShaderInfoLog +typedef void (APIENTRYP PFNGLGETSHADERSOURCEPROC)(GLuint shader, GLsizei bufSize, GLsizei *length, GLchar *source); +GLAPI PFNGLGETSHADERSOURCEPROC glad_glGetShaderSource; +#define glGetShaderSource glad_glGetShaderSource +typedef GLint (APIENTRYP PFNGLGETUNIFORMLOCATIONPROC)(GLuint program, const GLchar *name); +GLAPI PFNGLGETUNIFORMLOCATIONPROC glad_glGetUniformLocation; +#define glGetUniformLocation glad_glGetUniformLocation +typedef void (APIENTRYP PFNGLGETUNIFORMFVPROC)(GLuint program, GLint location, GLfloat *params); +GLAPI PFNGLGETUNIFORMFVPROC glad_glGetUniformfv; +#define glGetUniformfv glad_glGetUniformfv +typedef void (APIENTRYP PFNGLGETUNIFORMIVPROC)(GLuint program, GLint location, GLint *params); +GLAPI PFNGLGETUNIFORMIVPROC glad_glGetUniformiv; +#define glGetUniformiv glad_glGetUniformiv +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBDVPROC)(GLuint index, GLenum pname, GLdouble *params); +GLAPI PFNGLGETVERTEXATTRIBDVPROC glad_glGetVertexAttribdv; +#define glGetVertexAttribdv glad_glGetVertexAttribdv +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBFVPROC)(GLuint index, GLenum pname, GLfloat *params); +GLAPI PFNGLGETVERTEXATTRIBFVPROC glad_glGetVertexAttribfv; +#define glGetVertexAttribfv glad_glGetVertexAttribfv +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBIVPROC)(GLuint index, GLenum pname, GLint *params); +GLAPI PFNGLGETVERTEXATTRIBIVPROC glad_glGetVertexAttribiv; +#define glGetVertexAttribiv glad_glGetVertexAttribiv +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBPOINTERVPROC)(GLuint index, GLenum pname, void **pointer); +GLAPI PFNGLGETVERTEXATTRIBPOINTERVPROC glad_glGetVertexAttribPointerv; +#define glGetVertexAttribPointerv glad_glGetVertexAttribPointerv +typedef GLboolean (APIENTRYP PFNGLISPROGRAMPROC)(GLuint program); +GLAPI PFNGLISPROGRAMPROC glad_glIsProgram; +#define glIsProgram glad_glIsProgram +typedef GLboolean (APIENTRYP PFNGLISSHADERPROC)(GLuint shader); +GLAPI PFNGLISSHADERPROC glad_glIsShader; +#define glIsShader glad_glIsShader +typedef void (APIENTRYP PFNGLLINKPROGRAMPROC)(GLuint program); +GLAPI PFNGLLINKPROGRAMPROC glad_glLinkProgram; +#define glLinkProgram glad_glLinkProgram +typedef void (APIENTRYP PFNGLSHADERSOURCEPROC)(GLuint shader, GLsizei count, const GLchar *const*string, const GLint *length); +GLAPI PFNGLSHADERSOURCEPROC glad_glShaderSource; +#define glShaderSource glad_glShaderSource +typedef void (APIENTRYP PFNGLUSEPROGRAMPROC)(GLuint program); +GLAPI PFNGLUSEPROGRAMPROC glad_glUseProgram; +#define glUseProgram glad_glUseProgram +typedef void (APIENTRYP PFNGLUNIFORM1FPROC)(GLint location, GLfloat v0); +GLAPI PFNGLUNIFORM1FPROC glad_glUniform1f; +#define glUniform1f glad_glUniform1f +typedef void (APIENTRYP PFNGLUNIFORM2FPROC)(GLint location, GLfloat v0, GLfloat v1); +GLAPI PFNGLUNIFORM2FPROC glad_glUniform2f; +#define glUniform2f glad_glUniform2f +typedef void (APIENTRYP PFNGLUNIFORM3FPROC)(GLint location, GLfloat v0, GLfloat v1, GLfloat v2); +GLAPI PFNGLUNIFORM3FPROC glad_glUniform3f; +#define glUniform3f glad_glUniform3f +typedef void (APIENTRYP PFNGLUNIFORM4FPROC)(GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); +GLAPI PFNGLUNIFORM4FPROC glad_glUniform4f; +#define glUniform4f glad_glUniform4f +typedef void (APIENTRYP PFNGLUNIFORM1IPROC)(GLint location, GLint v0); +GLAPI PFNGLUNIFORM1IPROC glad_glUniform1i; +#define glUniform1i glad_glUniform1i +typedef void (APIENTRYP PFNGLUNIFORM2IPROC)(GLint location, GLint v0, GLint v1); +GLAPI PFNGLUNIFORM2IPROC glad_glUniform2i; +#define glUniform2i glad_glUniform2i +typedef void (APIENTRYP PFNGLUNIFORM3IPROC)(GLint location, GLint v0, GLint v1, GLint v2); +GLAPI PFNGLUNIFORM3IPROC glad_glUniform3i; +#define glUniform3i glad_glUniform3i +typedef void (APIENTRYP PFNGLUNIFORM4IPROC)(GLint location, GLint v0, GLint v1, GLint v2, GLint v3); +GLAPI PFNGLUNIFORM4IPROC glad_glUniform4i; +#define glUniform4i glad_glUniform4i +typedef void (APIENTRYP PFNGLUNIFORM1FVPROC)(GLint location, GLsizei count, const GLfloat *value); +GLAPI PFNGLUNIFORM1FVPROC glad_glUniform1fv; +#define glUniform1fv glad_glUniform1fv +typedef void (APIENTRYP PFNGLUNIFORM2FVPROC)(GLint location, GLsizei count, const GLfloat *value); +GLAPI PFNGLUNIFORM2FVPROC glad_glUniform2fv; +#define glUniform2fv glad_glUniform2fv +typedef void (APIENTRYP PFNGLUNIFORM3FVPROC)(GLint location, GLsizei count, const GLfloat *value); +GLAPI PFNGLUNIFORM3FVPROC glad_glUniform3fv; +#define glUniform3fv glad_glUniform3fv +typedef void (APIENTRYP PFNGLUNIFORM4FVPROC)(GLint location, GLsizei count, const GLfloat *value); +GLAPI PFNGLUNIFORM4FVPROC glad_glUniform4fv; +#define glUniform4fv glad_glUniform4fv +typedef void (APIENTRYP PFNGLUNIFORM1IVPROC)(GLint location, GLsizei count, const GLint *value); +GLAPI PFNGLUNIFORM1IVPROC glad_glUniform1iv; +#define glUniform1iv glad_glUniform1iv +typedef void (APIENTRYP PFNGLUNIFORM2IVPROC)(GLint location, GLsizei count, const GLint *value); +GLAPI PFNGLUNIFORM2IVPROC glad_glUniform2iv; +#define glUniform2iv glad_glUniform2iv +typedef void (APIENTRYP PFNGLUNIFORM3IVPROC)(GLint location, GLsizei count, const GLint *value); +GLAPI PFNGLUNIFORM3IVPROC glad_glUniform3iv; +#define glUniform3iv glad_glUniform3iv +typedef void (APIENTRYP PFNGLUNIFORM4IVPROC)(GLint location, GLsizei count, const GLint *value); +GLAPI PFNGLUNIFORM4IVPROC glad_glUniform4iv; +#define glUniform4iv glad_glUniform4iv +typedef void (APIENTRYP PFNGLUNIFORMMATRIX2FVPROC)(GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI PFNGLUNIFORMMATRIX2FVPROC glad_glUniformMatrix2fv; +#define glUniformMatrix2fv glad_glUniformMatrix2fv +typedef void (APIENTRYP PFNGLUNIFORMMATRIX3FVPROC)(GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI PFNGLUNIFORMMATRIX3FVPROC glad_glUniformMatrix3fv; +#define glUniformMatrix3fv glad_glUniformMatrix3fv +typedef void (APIENTRYP PFNGLUNIFORMMATRIX4FVPROC)(GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI PFNGLUNIFORMMATRIX4FVPROC glad_glUniformMatrix4fv; +#define glUniformMatrix4fv glad_glUniformMatrix4fv +typedef void (APIENTRYP PFNGLVALIDATEPROGRAMPROC)(GLuint program); +GLAPI PFNGLVALIDATEPROGRAMPROC glad_glValidateProgram; +#define glValidateProgram glad_glValidateProgram +typedef void (APIENTRYP PFNGLVERTEXATTRIB1DPROC)(GLuint index, GLdouble x); +GLAPI PFNGLVERTEXATTRIB1DPROC glad_glVertexAttrib1d; +#define glVertexAttrib1d glad_glVertexAttrib1d +typedef void (APIENTRYP PFNGLVERTEXATTRIB1DVPROC)(GLuint index, const GLdouble *v); +GLAPI PFNGLVERTEXATTRIB1DVPROC glad_glVertexAttrib1dv; +#define glVertexAttrib1dv glad_glVertexAttrib1dv +typedef void (APIENTRYP PFNGLVERTEXATTRIB1FPROC)(GLuint index, GLfloat x); +GLAPI PFNGLVERTEXATTRIB1FPROC glad_glVertexAttrib1f; +#define glVertexAttrib1f glad_glVertexAttrib1f +typedef void (APIENTRYP PFNGLVERTEXATTRIB1FVPROC)(GLuint index, const GLfloat *v); +GLAPI PFNGLVERTEXATTRIB1FVPROC glad_glVertexAttrib1fv; +#define glVertexAttrib1fv glad_glVertexAttrib1fv +typedef void (APIENTRYP PFNGLVERTEXATTRIB1SPROC)(GLuint index, GLshort x); +GLAPI PFNGLVERTEXATTRIB1SPROC glad_glVertexAttrib1s; +#define glVertexAttrib1s glad_glVertexAttrib1s +typedef void (APIENTRYP PFNGLVERTEXATTRIB1SVPROC)(GLuint index, const GLshort *v); +GLAPI PFNGLVERTEXATTRIB1SVPROC glad_glVertexAttrib1sv; +#define glVertexAttrib1sv glad_glVertexAttrib1sv +typedef void (APIENTRYP PFNGLVERTEXATTRIB2DPROC)(GLuint index, GLdouble x, GLdouble y); +GLAPI PFNGLVERTEXATTRIB2DPROC glad_glVertexAttrib2d; +#define glVertexAttrib2d glad_glVertexAttrib2d +typedef void (APIENTRYP PFNGLVERTEXATTRIB2DVPROC)(GLuint index, const GLdouble *v); +GLAPI PFNGLVERTEXATTRIB2DVPROC glad_glVertexAttrib2dv; +#define glVertexAttrib2dv glad_glVertexAttrib2dv +typedef void (APIENTRYP PFNGLVERTEXATTRIB2FPROC)(GLuint index, GLfloat x, GLfloat y); +GLAPI PFNGLVERTEXATTRIB2FPROC glad_glVertexAttrib2f; +#define glVertexAttrib2f glad_glVertexAttrib2f +typedef void (APIENTRYP PFNGLVERTEXATTRIB2FVPROC)(GLuint index, const GLfloat *v); +GLAPI PFNGLVERTEXATTRIB2FVPROC glad_glVertexAttrib2fv; +#define glVertexAttrib2fv glad_glVertexAttrib2fv +typedef void (APIENTRYP PFNGLVERTEXATTRIB2SPROC)(GLuint index, GLshort x, GLshort y); +GLAPI PFNGLVERTEXATTRIB2SPROC glad_glVertexAttrib2s; +#define glVertexAttrib2s glad_glVertexAttrib2s +typedef void (APIENTRYP PFNGLVERTEXATTRIB2SVPROC)(GLuint index, const GLshort *v); +GLAPI PFNGLVERTEXATTRIB2SVPROC glad_glVertexAttrib2sv; +#define glVertexAttrib2sv glad_glVertexAttrib2sv +typedef void (APIENTRYP PFNGLVERTEXATTRIB3DPROC)(GLuint index, GLdouble x, GLdouble y, GLdouble z); +GLAPI PFNGLVERTEXATTRIB3DPROC glad_glVertexAttrib3d; +#define glVertexAttrib3d glad_glVertexAttrib3d +typedef void (APIENTRYP PFNGLVERTEXATTRIB3DVPROC)(GLuint index, const GLdouble *v); +GLAPI PFNGLVERTEXATTRIB3DVPROC glad_glVertexAttrib3dv; +#define glVertexAttrib3dv glad_glVertexAttrib3dv +typedef void (APIENTRYP PFNGLVERTEXATTRIB3FPROC)(GLuint index, GLfloat x, GLfloat y, GLfloat z); +GLAPI PFNGLVERTEXATTRIB3FPROC glad_glVertexAttrib3f; +#define glVertexAttrib3f glad_glVertexAttrib3f +typedef void (APIENTRYP PFNGLVERTEXATTRIB3FVPROC)(GLuint index, const GLfloat *v); +GLAPI PFNGLVERTEXATTRIB3FVPROC glad_glVertexAttrib3fv; +#define glVertexAttrib3fv glad_glVertexAttrib3fv +typedef void (APIENTRYP PFNGLVERTEXATTRIB3SPROC)(GLuint index, GLshort x, GLshort y, GLshort z); +GLAPI PFNGLVERTEXATTRIB3SPROC glad_glVertexAttrib3s; +#define glVertexAttrib3s glad_glVertexAttrib3s +typedef void (APIENTRYP PFNGLVERTEXATTRIB3SVPROC)(GLuint index, const GLshort *v); +GLAPI PFNGLVERTEXATTRIB3SVPROC glad_glVertexAttrib3sv; +#define glVertexAttrib3sv glad_glVertexAttrib3sv +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NBVPROC)(GLuint index, const GLbyte *v); +GLAPI PFNGLVERTEXATTRIB4NBVPROC glad_glVertexAttrib4Nbv; +#define glVertexAttrib4Nbv glad_glVertexAttrib4Nbv +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NIVPROC)(GLuint index, const GLint *v); +GLAPI PFNGLVERTEXATTRIB4NIVPROC glad_glVertexAttrib4Niv; +#define glVertexAttrib4Niv glad_glVertexAttrib4Niv +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NSVPROC)(GLuint index, const GLshort *v); +GLAPI PFNGLVERTEXATTRIB4NSVPROC glad_glVertexAttrib4Nsv; +#define glVertexAttrib4Nsv glad_glVertexAttrib4Nsv +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUBPROC)(GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); +GLAPI PFNGLVERTEXATTRIB4NUBPROC glad_glVertexAttrib4Nub; +#define glVertexAttrib4Nub glad_glVertexAttrib4Nub +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUBVPROC)(GLuint index, const GLubyte *v); +GLAPI PFNGLVERTEXATTRIB4NUBVPROC glad_glVertexAttrib4Nubv; +#define glVertexAttrib4Nubv glad_glVertexAttrib4Nubv +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUIVPROC)(GLuint index, const GLuint *v); +GLAPI PFNGLVERTEXATTRIB4NUIVPROC glad_glVertexAttrib4Nuiv; +#define glVertexAttrib4Nuiv glad_glVertexAttrib4Nuiv +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUSVPROC)(GLuint index, const GLushort *v); +GLAPI PFNGLVERTEXATTRIB4NUSVPROC glad_glVertexAttrib4Nusv; +#define glVertexAttrib4Nusv glad_glVertexAttrib4Nusv +typedef void (APIENTRYP PFNGLVERTEXATTRIB4BVPROC)(GLuint index, const GLbyte *v); +GLAPI PFNGLVERTEXATTRIB4BVPROC glad_glVertexAttrib4bv; +#define glVertexAttrib4bv glad_glVertexAttrib4bv +typedef void (APIENTRYP PFNGLVERTEXATTRIB4DPROC)(GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI PFNGLVERTEXATTRIB4DPROC glad_glVertexAttrib4d; +#define glVertexAttrib4d glad_glVertexAttrib4d +typedef void (APIENTRYP PFNGLVERTEXATTRIB4DVPROC)(GLuint index, const GLdouble *v); +GLAPI PFNGLVERTEXATTRIB4DVPROC glad_glVertexAttrib4dv; +#define glVertexAttrib4dv glad_glVertexAttrib4dv +typedef void (APIENTRYP PFNGLVERTEXATTRIB4FPROC)(GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI PFNGLVERTEXATTRIB4FPROC glad_glVertexAttrib4f; +#define glVertexAttrib4f glad_glVertexAttrib4f +typedef void (APIENTRYP PFNGLVERTEXATTRIB4FVPROC)(GLuint index, const GLfloat *v); +GLAPI PFNGLVERTEXATTRIB4FVPROC glad_glVertexAttrib4fv; +#define glVertexAttrib4fv glad_glVertexAttrib4fv +typedef void (APIENTRYP PFNGLVERTEXATTRIB4IVPROC)(GLuint index, const GLint *v); +GLAPI PFNGLVERTEXATTRIB4IVPROC glad_glVertexAttrib4iv; +#define glVertexAttrib4iv glad_glVertexAttrib4iv +typedef void (APIENTRYP PFNGLVERTEXATTRIB4SPROC)(GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); +GLAPI PFNGLVERTEXATTRIB4SPROC glad_glVertexAttrib4s; +#define glVertexAttrib4s glad_glVertexAttrib4s +typedef void (APIENTRYP PFNGLVERTEXATTRIB4SVPROC)(GLuint index, const GLshort *v); +GLAPI PFNGLVERTEXATTRIB4SVPROC glad_glVertexAttrib4sv; +#define glVertexAttrib4sv glad_glVertexAttrib4sv +typedef void (APIENTRYP PFNGLVERTEXATTRIB4UBVPROC)(GLuint index, const GLubyte *v); +GLAPI PFNGLVERTEXATTRIB4UBVPROC glad_glVertexAttrib4ubv; +#define glVertexAttrib4ubv glad_glVertexAttrib4ubv +typedef void (APIENTRYP PFNGLVERTEXATTRIB4UIVPROC)(GLuint index, const GLuint *v); +GLAPI PFNGLVERTEXATTRIB4UIVPROC glad_glVertexAttrib4uiv; +#define glVertexAttrib4uiv glad_glVertexAttrib4uiv +typedef void (APIENTRYP PFNGLVERTEXATTRIB4USVPROC)(GLuint index, const GLushort *v); +GLAPI PFNGLVERTEXATTRIB4USVPROC glad_glVertexAttrib4usv; +#define glVertexAttrib4usv glad_glVertexAttrib4usv +typedef void (APIENTRYP PFNGLVERTEXATTRIBPOINTERPROC)(GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const void *pointer); +GLAPI PFNGLVERTEXATTRIBPOINTERPROC glad_glVertexAttribPointer; +#define glVertexAttribPointer glad_glVertexAttribPointer +#endif +#ifndef GL_VERSION_2_1 +#define GL_VERSION_2_1 1 +GLAPI int GLAD_GL_VERSION_2_1; +typedef void (APIENTRYP PFNGLUNIFORMMATRIX2X3FVPROC)(GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI PFNGLUNIFORMMATRIX2X3FVPROC glad_glUniformMatrix2x3fv; +#define glUniformMatrix2x3fv glad_glUniformMatrix2x3fv +typedef void (APIENTRYP PFNGLUNIFORMMATRIX3X2FVPROC)(GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI PFNGLUNIFORMMATRIX3X2FVPROC glad_glUniformMatrix3x2fv; +#define glUniformMatrix3x2fv glad_glUniformMatrix3x2fv +typedef void (APIENTRYP PFNGLUNIFORMMATRIX2X4FVPROC)(GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI PFNGLUNIFORMMATRIX2X4FVPROC glad_glUniformMatrix2x4fv; +#define glUniformMatrix2x4fv glad_glUniformMatrix2x4fv +typedef void (APIENTRYP PFNGLUNIFORMMATRIX4X2FVPROC)(GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI PFNGLUNIFORMMATRIX4X2FVPROC glad_glUniformMatrix4x2fv; +#define glUniformMatrix4x2fv glad_glUniformMatrix4x2fv +typedef void (APIENTRYP PFNGLUNIFORMMATRIX3X4FVPROC)(GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI PFNGLUNIFORMMATRIX3X4FVPROC glad_glUniformMatrix3x4fv; +#define glUniformMatrix3x4fv glad_glUniformMatrix3x4fv +typedef void (APIENTRYP PFNGLUNIFORMMATRIX4X3FVPROC)(GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI PFNGLUNIFORMMATRIX4X3FVPROC glad_glUniformMatrix4x3fv; +#define glUniformMatrix4x3fv glad_glUniformMatrix4x3fv +#endif +#ifndef GL_VERSION_3_0 +#define GL_VERSION_3_0 1 +GLAPI int GLAD_GL_VERSION_3_0; +typedef void (APIENTRYP PFNGLCOLORMASKIPROC)(GLuint index, GLboolean r, GLboolean g, GLboolean b, GLboolean a); +GLAPI PFNGLCOLORMASKIPROC glad_glColorMaski; +#define glColorMaski glad_glColorMaski +typedef void (APIENTRYP PFNGLGETBOOLEANI_VPROC)(GLenum target, GLuint index, GLboolean *data); +GLAPI PFNGLGETBOOLEANI_VPROC glad_glGetBooleani_v; +#define glGetBooleani_v glad_glGetBooleani_v +typedef void (APIENTRYP PFNGLGETINTEGERI_VPROC)(GLenum target, GLuint index, GLint *data); +GLAPI PFNGLGETINTEGERI_VPROC glad_glGetIntegeri_v; +#define glGetIntegeri_v glad_glGetIntegeri_v +typedef void (APIENTRYP PFNGLENABLEIPROC)(GLenum target, GLuint index); +GLAPI PFNGLENABLEIPROC glad_glEnablei; +#define glEnablei glad_glEnablei +typedef void (APIENTRYP PFNGLDISABLEIPROC)(GLenum target, GLuint index); +GLAPI PFNGLDISABLEIPROC glad_glDisablei; +#define glDisablei glad_glDisablei +typedef GLboolean (APIENTRYP PFNGLISENABLEDIPROC)(GLenum target, GLuint index); +GLAPI PFNGLISENABLEDIPROC glad_glIsEnabledi; +#define glIsEnabledi glad_glIsEnabledi +typedef void (APIENTRYP PFNGLBEGINTRANSFORMFEEDBACKPROC)(GLenum primitiveMode); +GLAPI PFNGLBEGINTRANSFORMFEEDBACKPROC glad_glBeginTransformFeedback; +#define glBeginTransformFeedback glad_glBeginTransformFeedback +typedef void (APIENTRYP PFNGLENDTRANSFORMFEEDBACKPROC)(); +GLAPI PFNGLENDTRANSFORMFEEDBACKPROC glad_glEndTransformFeedback; +#define glEndTransformFeedback glad_glEndTransformFeedback +typedef void (APIENTRYP PFNGLBINDBUFFERRANGEPROC)(GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); +GLAPI PFNGLBINDBUFFERRANGEPROC glad_glBindBufferRange; +#define glBindBufferRange glad_glBindBufferRange +typedef void (APIENTRYP PFNGLBINDBUFFERBASEPROC)(GLenum target, GLuint index, GLuint buffer); +GLAPI PFNGLBINDBUFFERBASEPROC glad_glBindBufferBase; +#define glBindBufferBase glad_glBindBufferBase +typedef void (APIENTRYP PFNGLTRANSFORMFEEDBACKVARYINGSPROC)(GLuint program, GLsizei count, const GLchar *const*varyings, GLenum bufferMode); +GLAPI PFNGLTRANSFORMFEEDBACKVARYINGSPROC glad_glTransformFeedbackVaryings; +#define glTransformFeedbackVaryings glad_glTransformFeedbackVaryings +typedef void (APIENTRYP PFNGLGETTRANSFORMFEEDBACKVARYINGPROC)(GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLsizei *size, GLenum *type, GLchar *name); +GLAPI PFNGLGETTRANSFORMFEEDBACKVARYINGPROC glad_glGetTransformFeedbackVarying; +#define glGetTransformFeedbackVarying glad_glGetTransformFeedbackVarying +typedef void (APIENTRYP PFNGLCLAMPCOLORPROC)(GLenum target, GLenum clamp); +GLAPI PFNGLCLAMPCOLORPROC glad_glClampColor; +#define glClampColor glad_glClampColor +typedef void (APIENTRYP PFNGLBEGINCONDITIONALRENDERPROC)(GLuint id, GLenum mode); +GLAPI PFNGLBEGINCONDITIONALRENDERPROC glad_glBeginConditionalRender; +#define glBeginConditionalRender glad_glBeginConditionalRender +typedef void (APIENTRYP PFNGLENDCONDITIONALRENDERPROC)(); +GLAPI PFNGLENDCONDITIONALRENDERPROC glad_glEndConditionalRender; +#define glEndConditionalRender glad_glEndConditionalRender +typedef void (APIENTRYP PFNGLVERTEXATTRIBIPOINTERPROC)(GLuint index, GLint size, GLenum type, GLsizei stride, const void *pointer); +GLAPI PFNGLVERTEXATTRIBIPOINTERPROC glad_glVertexAttribIPointer; +#define glVertexAttribIPointer glad_glVertexAttribIPointer +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBIIVPROC)(GLuint index, GLenum pname, GLint *params); +GLAPI PFNGLGETVERTEXATTRIBIIVPROC glad_glGetVertexAttribIiv; +#define glGetVertexAttribIiv glad_glGetVertexAttribIiv +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBIUIVPROC)(GLuint index, GLenum pname, GLuint *params); +GLAPI PFNGLGETVERTEXATTRIBIUIVPROC glad_glGetVertexAttribIuiv; +#define glGetVertexAttribIuiv glad_glGetVertexAttribIuiv +typedef void (APIENTRYP PFNGLVERTEXATTRIBI1IPROC)(GLuint index, GLint x); +GLAPI PFNGLVERTEXATTRIBI1IPROC glad_glVertexAttribI1i; +#define glVertexAttribI1i glad_glVertexAttribI1i +typedef void (APIENTRYP PFNGLVERTEXATTRIBI2IPROC)(GLuint index, GLint x, GLint y); +GLAPI PFNGLVERTEXATTRIBI2IPROC glad_glVertexAttribI2i; +#define glVertexAttribI2i glad_glVertexAttribI2i +typedef void (APIENTRYP PFNGLVERTEXATTRIBI3IPROC)(GLuint index, GLint x, GLint y, GLint z); +GLAPI PFNGLVERTEXATTRIBI3IPROC glad_glVertexAttribI3i; +#define glVertexAttribI3i glad_glVertexAttribI3i +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4IPROC)(GLuint index, GLint x, GLint y, GLint z, GLint w); +GLAPI PFNGLVERTEXATTRIBI4IPROC glad_glVertexAttribI4i; +#define glVertexAttribI4i glad_glVertexAttribI4i +typedef void (APIENTRYP PFNGLVERTEXATTRIBI1UIPROC)(GLuint index, GLuint x); +GLAPI PFNGLVERTEXATTRIBI1UIPROC glad_glVertexAttribI1ui; +#define glVertexAttribI1ui glad_glVertexAttribI1ui +typedef void (APIENTRYP PFNGLVERTEXATTRIBI2UIPROC)(GLuint index, GLuint x, GLuint y); +GLAPI PFNGLVERTEXATTRIBI2UIPROC glad_glVertexAttribI2ui; +#define glVertexAttribI2ui glad_glVertexAttribI2ui +typedef void (APIENTRYP PFNGLVERTEXATTRIBI3UIPROC)(GLuint index, GLuint x, GLuint y, GLuint z); +GLAPI PFNGLVERTEXATTRIBI3UIPROC glad_glVertexAttribI3ui; +#define glVertexAttribI3ui glad_glVertexAttribI3ui +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4UIPROC)(GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); +GLAPI PFNGLVERTEXATTRIBI4UIPROC glad_glVertexAttribI4ui; +#define glVertexAttribI4ui glad_glVertexAttribI4ui +typedef void (APIENTRYP PFNGLVERTEXATTRIBI1IVPROC)(GLuint index, const GLint *v); +GLAPI PFNGLVERTEXATTRIBI1IVPROC glad_glVertexAttribI1iv; +#define glVertexAttribI1iv glad_glVertexAttribI1iv +typedef void (APIENTRYP PFNGLVERTEXATTRIBI2IVPROC)(GLuint index, const GLint *v); +GLAPI PFNGLVERTEXATTRIBI2IVPROC glad_glVertexAttribI2iv; +#define glVertexAttribI2iv glad_glVertexAttribI2iv +typedef void (APIENTRYP PFNGLVERTEXATTRIBI3IVPROC)(GLuint index, const GLint *v); +GLAPI PFNGLVERTEXATTRIBI3IVPROC glad_glVertexAttribI3iv; +#define glVertexAttribI3iv glad_glVertexAttribI3iv +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4IVPROC)(GLuint index, const GLint *v); +GLAPI PFNGLVERTEXATTRIBI4IVPROC glad_glVertexAttribI4iv; +#define glVertexAttribI4iv glad_glVertexAttribI4iv +typedef void (APIENTRYP PFNGLVERTEXATTRIBI1UIVPROC)(GLuint index, const GLuint *v); +GLAPI PFNGLVERTEXATTRIBI1UIVPROC glad_glVertexAttribI1uiv; +#define glVertexAttribI1uiv glad_glVertexAttribI1uiv +typedef void (APIENTRYP PFNGLVERTEXATTRIBI2UIVPROC)(GLuint index, const GLuint *v); +GLAPI PFNGLVERTEXATTRIBI2UIVPROC glad_glVertexAttribI2uiv; +#define glVertexAttribI2uiv glad_glVertexAttribI2uiv +typedef void (APIENTRYP PFNGLVERTEXATTRIBI3UIVPROC)(GLuint index, const GLuint *v); +GLAPI PFNGLVERTEXATTRIBI3UIVPROC glad_glVertexAttribI3uiv; +#define glVertexAttribI3uiv glad_glVertexAttribI3uiv +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4UIVPROC)(GLuint index, const GLuint *v); +GLAPI PFNGLVERTEXATTRIBI4UIVPROC glad_glVertexAttribI4uiv; +#define glVertexAttribI4uiv glad_glVertexAttribI4uiv +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4BVPROC)(GLuint index, const GLbyte *v); +GLAPI PFNGLVERTEXATTRIBI4BVPROC glad_glVertexAttribI4bv; +#define glVertexAttribI4bv glad_glVertexAttribI4bv +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4SVPROC)(GLuint index, const GLshort *v); +GLAPI PFNGLVERTEXATTRIBI4SVPROC glad_glVertexAttribI4sv; +#define glVertexAttribI4sv glad_glVertexAttribI4sv +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4UBVPROC)(GLuint index, const GLubyte *v); +GLAPI PFNGLVERTEXATTRIBI4UBVPROC glad_glVertexAttribI4ubv; +#define glVertexAttribI4ubv glad_glVertexAttribI4ubv +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4USVPROC)(GLuint index, const GLushort *v); +GLAPI PFNGLVERTEXATTRIBI4USVPROC glad_glVertexAttribI4usv; +#define glVertexAttribI4usv glad_glVertexAttribI4usv +typedef void (APIENTRYP PFNGLGETUNIFORMUIVPROC)(GLuint program, GLint location, GLuint *params); +GLAPI PFNGLGETUNIFORMUIVPROC glad_glGetUniformuiv; +#define glGetUniformuiv glad_glGetUniformuiv +typedef void (APIENTRYP PFNGLBINDFRAGDATALOCATIONPROC)(GLuint program, GLuint color, const GLchar *name); +GLAPI PFNGLBINDFRAGDATALOCATIONPROC glad_glBindFragDataLocation; +#define glBindFragDataLocation glad_glBindFragDataLocation +typedef GLint (APIENTRYP PFNGLGETFRAGDATALOCATIONPROC)(GLuint program, const GLchar *name); +GLAPI PFNGLGETFRAGDATALOCATIONPROC glad_glGetFragDataLocation; +#define glGetFragDataLocation glad_glGetFragDataLocation +typedef void (APIENTRYP PFNGLUNIFORM1UIPROC)(GLint location, GLuint v0); +GLAPI PFNGLUNIFORM1UIPROC glad_glUniform1ui; +#define glUniform1ui glad_glUniform1ui +typedef void (APIENTRYP PFNGLUNIFORM2UIPROC)(GLint location, GLuint v0, GLuint v1); +GLAPI PFNGLUNIFORM2UIPROC glad_glUniform2ui; +#define glUniform2ui glad_glUniform2ui +typedef void (APIENTRYP PFNGLUNIFORM3UIPROC)(GLint location, GLuint v0, GLuint v1, GLuint v2); +GLAPI PFNGLUNIFORM3UIPROC glad_glUniform3ui; +#define glUniform3ui glad_glUniform3ui +typedef void (APIENTRYP PFNGLUNIFORM4UIPROC)(GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3); +GLAPI PFNGLUNIFORM4UIPROC glad_glUniform4ui; +#define glUniform4ui glad_glUniform4ui +typedef void (APIENTRYP PFNGLUNIFORM1UIVPROC)(GLint location, GLsizei count, const GLuint *value); +GLAPI PFNGLUNIFORM1UIVPROC glad_glUniform1uiv; +#define glUniform1uiv glad_glUniform1uiv +typedef void (APIENTRYP PFNGLUNIFORM2UIVPROC)(GLint location, GLsizei count, const GLuint *value); +GLAPI PFNGLUNIFORM2UIVPROC glad_glUniform2uiv; +#define glUniform2uiv glad_glUniform2uiv +typedef void (APIENTRYP PFNGLUNIFORM3UIVPROC)(GLint location, GLsizei count, const GLuint *value); +GLAPI PFNGLUNIFORM3UIVPROC glad_glUniform3uiv; +#define glUniform3uiv glad_glUniform3uiv +typedef void (APIENTRYP PFNGLUNIFORM4UIVPROC)(GLint location, GLsizei count, const GLuint *value); +GLAPI PFNGLUNIFORM4UIVPROC glad_glUniform4uiv; +#define glUniform4uiv glad_glUniform4uiv +typedef void (APIENTRYP PFNGLTEXPARAMETERIIVPROC)(GLenum target, GLenum pname, const GLint *params); +GLAPI PFNGLTEXPARAMETERIIVPROC glad_glTexParameterIiv; +#define glTexParameterIiv glad_glTexParameterIiv +typedef void (APIENTRYP PFNGLTEXPARAMETERIUIVPROC)(GLenum target, GLenum pname, const GLuint *params); +GLAPI PFNGLTEXPARAMETERIUIVPROC glad_glTexParameterIuiv; +#define glTexParameterIuiv glad_glTexParameterIuiv +typedef void (APIENTRYP PFNGLGETTEXPARAMETERIIVPROC)(GLenum target, GLenum pname, GLint *params); +GLAPI PFNGLGETTEXPARAMETERIIVPROC glad_glGetTexParameterIiv; +#define glGetTexParameterIiv glad_glGetTexParameterIiv +typedef void (APIENTRYP PFNGLGETTEXPARAMETERIUIVPROC)(GLenum target, GLenum pname, GLuint *params); +GLAPI PFNGLGETTEXPARAMETERIUIVPROC glad_glGetTexParameterIuiv; +#define glGetTexParameterIuiv glad_glGetTexParameterIuiv +typedef void (APIENTRYP PFNGLCLEARBUFFERIVPROC)(GLenum buffer, GLint drawbuffer, const GLint *value); +GLAPI PFNGLCLEARBUFFERIVPROC glad_glClearBufferiv; +#define glClearBufferiv glad_glClearBufferiv +typedef void (APIENTRYP PFNGLCLEARBUFFERUIVPROC)(GLenum buffer, GLint drawbuffer, const GLuint *value); +GLAPI PFNGLCLEARBUFFERUIVPROC glad_glClearBufferuiv; +#define glClearBufferuiv glad_glClearBufferuiv +typedef void (APIENTRYP PFNGLCLEARBUFFERFVPROC)(GLenum buffer, GLint drawbuffer, const GLfloat *value); +GLAPI PFNGLCLEARBUFFERFVPROC glad_glClearBufferfv; +#define glClearBufferfv glad_glClearBufferfv +typedef void (APIENTRYP PFNGLCLEARBUFFERFIPROC)(GLenum buffer, GLint drawbuffer, GLfloat depth, GLint stencil); +GLAPI PFNGLCLEARBUFFERFIPROC glad_glClearBufferfi; +#define glClearBufferfi glad_glClearBufferfi +typedef const GLubyte * (APIENTRYP PFNGLGETSTRINGIPROC)(GLenum name, GLuint index); +GLAPI PFNGLGETSTRINGIPROC glad_glGetStringi; +#define glGetStringi glad_glGetStringi +typedef GLboolean (APIENTRYP PFNGLISRENDERBUFFERPROC)(GLuint renderbuffer); +GLAPI PFNGLISRENDERBUFFERPROC glad_glIsRenderbuffer; +#define glIsRenderbuffer glad_glIsRenderbuffer +typedef void (APIENTRYP PFNGLBINDRENDERBUFFERPROC)(GLenum target, GLuint renderbuffer); +GLAPI PFNGLBINDRENDERBUFFERPROC glad_glBindRenderbuffer; +#define glBindRenderbuffer glad_glBindRenderbuffer +typedef void (APIENTRYP PFNGLDELETERENDERBUFFERSPROC)(GLsizei n, const GLuint *renderbuffers); +GLAPI PFNGLDELETERENDERBUFFERSPROC glad_glDeleteRenderbuffers; +#define glDeleteRenderbuffers glad_glDeleteRenderbuffers +typedef void (APIENTRYP PFNGLGENRENDERBUFFERSPROC)(GLsizei n, GLuint *renderbuffers); +GLAPI PFNGLGENRENDERBUFFERSPROC glad_glGenRenderbuffers; +#define glGenRenderbuffers glad_glGenRenderbuffers +typedef void (APIENTRYP PFNGLRENDERBUFFERSTORAGEPROC)(GLenum target, GLenum internalformat, GLsizei width, GLsizei height); +GLAPI PFNGLRENDERBUFFERSTORAGEPROC glad_glRenderbufferStorage; +#define glRenderbufferStorage glad_glRenderbufferStorage +typedef void (APIENTRYP PFNGLGETRENDERBUFFERPARAMETERIVPROC)(GLenum target, GLenum pname, GLint *params); +GLAPI PFNGLGETRENDERBUFFERPARAMETERIVPROC glad_glGetRenderbufferParameteriv; +#define glGetRenderbufferParameteriv glad_glGetRenderbufferParameteriv +typedef GLboolean (APIENTRYP PFNGLISFRAMEBUFFERPROC)(GLuint framebuffer); +GLAPI PFNGLISFRAMEBUFFERPROC glad_glIsFramebuffer; +#define glIsFramebuffer glad_glIsFramebuffer +typedef void (APIENTRYP PFNGLBINDFRAMEBUFFERPROC)(GLenum target, GLuint framebuffer); +GLAPI PFNGLBINDFRAMEBUFFERPROC glad_glBindFramebuffer; +#define glBindFramebuffer glad_glBindFramebuffer +typedef void (APIENTRYP PFNGLDELETEFRAMEBUFFERSPROC)(GLsizei n, const GLuint *framebuffers); +GLAPI PFNGLDELETEFRAMEBUFFERSPROC glad_glDeleteFramebuffers; +#define glDeleteFramebuffers glad_glDeleteFramebuffers +typedef void (APIENTRYP PFNGLGENFRAMEBUFFERSPROC)(GLsizei n, GLuint *framebuffers); +GLAPI PFNGLGENFRAMEBUFFERSPROC glad_glGenFramebuffers; +#define glGenFramebuffers glad_glGenFramebuffers +typedef GLenum (APIENTRYP PFNGLCHECKFRAMEBUFFERSTATUSPROC)(GLenum target); +GLAPI PFNGLCHECKFRAMEBUFFERSTATUSPROC glad_glCheckFramebufferStatus; +#define glCheckFramebufferStatus glad_glCheckFramebufferStatus +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURE1DPROC)(GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +GLAPI PFNGLFRAMEBUFFERTEXTURE1DPROC glad_glFramebufferTexture1D; +#define glFramebufferTexture1D glad_glFramebufferTexture1D +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURE2DPROC)(GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +GLAPI PFNGLFRAMEBUFFERTEXTURE2DPROC glad_glFramebufferTexture2D; +#define glFramebufferTexture2D glad_glFramebufferTexture2D +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURE3DPROC)(GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); +GLAPI PFNGLFRAMEBUFFERTEXTURE3DPROC glad_glFramebufferTexture3D; +#define glFramebufferTexture3D glad_glFramebufferTexture3D +typedef void (APIENTRYP PFNGLFRAMEBUFFERRENDERBUFFERPROC)(GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); +GLAPI PFNGLFRAMEBUFFERRENDERBUFFERPROC glad_glFramebufferRenderbuffer; +#define glFramebufferRenderbuffer glad_glFramebufferRenderbuffer +typedef void (APIENTRYP PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVPROC)(GLenum target, GLenum attachment, GLenum pname, GLint *params); +GLAPI PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVPROC glad_glGetFramebufferAttachmentParameteriv; +#define glGetFramebufferAttachmentParameteriv glad_glGetFramebufferAttachmentParameteriv +typedef void (APIENTRYP PFNGLGENERATEMIPMAPPROC)(GLenum target); +GLAPI PFNGLGENERATEMIPMAPPROC glad_glGenerateMipmap; +#define glGenerateMipmap glad_glGenerateMipmap +typedef void (APIENTRYP PFNGLBLITFRAMEBUFFERPROC)(GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); +GLAPI PFNGLBLITFRAMEBUFFERPROC glad_glBlitFramebuffer; +#define glBlitFramebuffer glad_glBlitFramebuffer +typedef void (APIENTRYP PFNGLRENDERBUFFERSTORAGEMULTISAMPLEPROC)(GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +GLAPI PFNGLRENDERBUFFERSTORAGEMULTISAMPLEPROC glad_glRenderbufferStorageMultisample; +#define glRenderbufferStorageMultisample glad_glRenderbufferStorageMultisample +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURELAYERPROC)(GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer); +GLAPI PFNGLFRAMEBUFFERTEXTURELAYERPROC glad_glFramebufferTextureLayer; +#define glFramebufferTextureLayer glad_glFramebufferTextureLayer +typedef void * (APIENTRYP PFNGLMAPBUFFERRANGEPROC)(GLenum target, GLintptr offset, GLsizeiptr length, GLbitfield access); +GLAPI PFNGLMAPBUFFERRANGEPROC glad_glMapBufferRange; +#define glMapBufferRange glad_glMapBufferRange +typedef void (APIENTRYP PFNGLFLUSHMAPPEDBUFFERRANGEPROC)(GLenum target, GLintptr offset, GLsizeiptr length); +GLAPI PFNGLFLUSHMAPPEDBUFFERRANGEPROC glad_glFlushMappedBufferRange; +#define glFlushMappedBufferRange glad_glFlushMappedBufferRange +typedef void (APIENTRYP PFNGLBINDVERTEXARRAYPROC)(GLuint array); +GLAPI PFNGLBINDVERTEXARRAYPROC glad_glBindVertexArray; +#define glBindVertexArray glad_glBindVertexArray +typedef void (APIENTRYP PFNGLDELETEVERTEXARRAYSPROC)(GLsizei n, const GLuint *arrays); +GLAPI PFNGLDELETEVERTEXARRAYSPROC glad_glDeleteVertexArrays; +#define glDeleteVertexArrays glad_glDeleteVertexArrays +typedef void (APIENTRYP PFNGLGENVERTEXARRAYSPROC)(GLsizei n, GLuint *arrays); +GLAPI PFNGLGENVERTEXARRAYSPROC glad_glGenVertexArrays; +#define glGenVertexArrays glad_glGenVertexArrays +typedef GLboolean (APIENTRYP PFNGLISVERTEXARRAYPROC)(GLuint array); +GLAPI PFNGLISVERTEXARRAYPROC glad_glIsVertexArray; +#define glIsVertexArray glad_glIsVertexArray +#endif +#ifndef GL_VERSION_3_1 +#define GL_VERSION_3_1 1 +GLAPI int GLAD_GL_VERSION_3_1; +typedef void (APIENTRYP PFNGLDRAWARRAYSINSTANCEDPROC)(GLenum mode, GLint first, GLsizei count, GLsizei instancecount); +GLAPI PFNGLDRAWARRAYSINSTANCEDPROC glad_glDrawArraysInstanced; +#define glDrawArraysInstanced glad_glDrawArraysInstanced +typedef void (APIENTRYP PFNGLDRAWELEMENTSINSTANCEDPROC)(GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei instancecount); +GLAPI PFNGLDRAWELEMENTSINSTANCEDPROC glad_glDrawElementsInstanced; +#define glDrawElementsInstanced glad_glDrawElementsInstanced +typedef void (APIENTRYP PFNGLTEXBUFFERPROC)(GLenum target, GLenum internalformat, GLuint buffer); +GLAPI PFNGLTEXBUFFERPROC glad_glTexBuffer; +#define glTexBuffer glad_glTexBuffer +typedef void (APIENTRYP PFNGLPRIMITIVERESTARTINDEXPROC)(GLuint index); +GLAPI PFNGLPRIMITIVERESTARTINDEXPROC glad_glPrimitiveRestartIndex; +#define glPrimitiveRestartIndex glad_glPrimitiveRestartIndex +typedef void (APIENTRYP PFNGLCOPYBUFFERSUBDATAPROC)(GLenum readTarget, GLenum writeTarget, GLintptr readOffset, GLintptr writeOffset, GLsizeiptr size); +GLAPI PFNGLCOPYBUFFERSUBDATAPROC glad_glCopyBufferSubData; +#define glCopyBufferSubData glad_glCopyBufferSubData +typedef void (APIENTRYP PFNGLGETUNIFORMINDICESPROC)(GLuint program, GLsizei uniformCount, const GLchar *const*uniformNames, GLuint *uniformIndices); +GLAPI PFNGLGETUNIFORMINDICESPROC glad_glGetUniformIndices; +#define glGetUniformIndices glad_glGetUniformIndices +typedef void (APIENTRYP PFNGLGETACTIVEUNIFORMSIVPROC)(GLuint program, GLsizei uniformCount, const GLuint *uniformIndices, GLenum pname, GLint *params); +GLAPI PFNGLGETACTIVEUNIFORMSIVPROC glad_glGetActiveUniformsiv; +#define glGetActiveUniformsiv glad_glGetActiveUniformsiv +typedef void (APIENTRYP PFNGLGETACTIVEUNIFORMNAMEPROC)(GLuint program, GLuint uniformIndex, GLsizei bufSize, GLsizei *length, GLchar *uniformName); +GLAPI PFNGLGETACTIVEUNIFORMNAMEPROC glad_glGetActiveUniformName; +#define glGetActiveUniformName glad_glGetActiveUniformName +typedef GLuint (APIENTRYP PFNGLGETUNIFORMBLOCKINDEXPROC)(GLuint program, const GLchar *uniformBlockName); +GLAPI PFNGLGETUNIFORMBLOCKINDEXPROC glad_glGetUniformBlockIndex; +#define glGetUniformBlockIndex glad_glGetUniformBlockIndex +typedef void (APIENTRYP PFNGLGETACTIVEUNIFORMBLOCKIVPROC)(GLuint program, GLuint uniformBlockIndex, GLenum pname, GLint *params); +GLAPI PFNGLGETACTIVEUNIFORMBLOCKIVPROC glad_glGetActiveUniformBlockiv; +#define glGetActiveUniformBlockiv glad_glGetActiveUniformBlockiv +typedef void (APIENTRYP PFNGLGETACTIVEUNIFORMBLOCKNAMEPROC)(GLuint program, GLuint uniformBlockIndex, GLsizei bufSize, GLsizei *length, GLchar *uniformBlockName); +GLAPI PFNGLGETACTIVEUNIFORMBLOCKNAMEPROC glad_glGetActiveUniformBlockName; +#define glGetActiveUniformBlockName glad_glGetActiveUniformBlockName +typedef void (APIENTRYP PFNGLUNIFORMBLOCKBINDINGPROC)(GLuint program, GLuint uniformBlockIndex, GLuint uniformBlockBinding); +GLAPI PFNGLUNIFORMBLOCKBINDINGPROC glad_glUniformBlockBinding; +#define glUniformBlockBinding glad_glUniformBlockBinding +#endif +#ifndef GL_VERSION_3_2 +#define GL_VERSION_3_2 1 +GLAPI int GLAD_GL_VERSION_3_2; +typedef void (APIENTRYP PFNGLDRAWELEMENTSBASEVERTEXPROC)(GLenum mode, GLsizei count, GLenum type, const void *indices, GLint basevertex); +GLAPI PFNGLDRAWELEMENTSBASEVERTEXPROC glad_glDrawElementsBaseVertex; +#define glDrawElementsBaseVertex glad_glDrawElementsBaseVertex +typedef void (APIENTRYP PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC)(GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const void *indices, GLint basevertex); +GLAPI PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC glad_glDrawRangeElementsBaseVertex; +#define glDrawRangeElementsBaseVertex glad_glDrawRangeElementsBaseVertex +typedef void (APIENTRYP PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC)(GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei instancecount, GLint basevertex); +GLAPI PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC glad_glDrawElementsInstancedBaseVertex; +#define glDrawElementsInstancedBaseVertex glad_glDrawElementsInstancedBaseVertex +typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC)(GLenum mode, const GLsizei *count, GLenum type, const void *const*indices, GLsizei drawcount, const GLint *basevertex); +GLAPI PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC glad_glMultiDrawElementsBaseVertex; +#define glMultiDrawElementsBaseVertex glad_glMultiDrawElementsBaseVertex +typedef void (APIENTRYP PFNGLPROVOKINGVERTEXPROC)(GLenum mode); +GLAPI PFNGLPROVOKINGVERTEXPROC glad_glProvokingVertex; +#define glProvokingVertex glad_glProvokingVertex +typedef GLsync (APIENTRYP PFNGLFENCESYNCPROC)(GLenum condition, GLbitfield flags); +GLAPI PFNGLFENCESYNCPROC glad_glFenceSync; +#define glFenceSync glad_glFenceSync +typedef GLboolean (APIENTRYP PFNGLISSYNCPROC)(GLsync sync); +GLAPI PFNGLISSYNCPROC glad_glIsSync; +#define glIsSync glad_glIsSync +typedef void (APIENTRYP PFNGLDELETESYNCPROC)(GLsync sync); +GLAPI PFNGLDELETESYNCPROC glad_glDeleteSync; +#define glDeleteSync glad_glDeleteSync +typedef GLenum (APIENTRYP PFNGLCLIENTWAITSYNCPROC)(GLsync sync, GLbitfield flags, GLuint64 timeout); +GLAPI PFNGLCLIENTWAITSYNCPROC glad_glClientWaitSync; +#define glClientWaitSync glad_glClientWaitSync +typedef void (APIENTRYP PFNGLWAITSYNCPROC)(GLsync sync, GLbitfield flags, GLuint64 timeout); +GLAPI PFNGLWAITSYNCPROC glad_glWaitSync; +#define glWaitSync glad_glWaitSync +typedef void (APIENTRYP PFNGLGETINTEGER64VPROC)(GLenum pname, GLint64 *data); +GLAPI PFNGLGETINTEGER64VPROC glad_glGetInteger64v; +#define glGetInteger64v glad_glGetInteger64v +typedef void (APIENTRYP PFNGLGETSYNCIVPROC)(GLsync sync, GLenum pname, GLsizei bufSize, GLsizei *length, GLint *values); +GLAPI PFNGLGETSYNCIVPROC glad_glGetSynciv; +#define glGetSynciv glad_glGetSynciv +typedef void (APIENTRYP PFNGLGETINTEGER64I_VPROC)(GLenum target, GLuint index, GLint64 *data); +GLAPI PFNGLGETINTEGER64I_VPROC glad_glGetInteger64i_v; +#define glGetInteger64i_v glad_glGetInteger64i_v +typedef void (APIENTRYP PFNGLGETBUFFERPARAMETERI64VPROC)(GLenum target, GLenum pname, GLint64 *params); +GLAPI PFNGLGETBUFFERPARAMETERI64VPROC glad_glGetBufferParameteri64v; +#define glGetBufferParameteri64v glad_glGetBufferParameteri64v +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTUREPROC)(GLenum target, GLenum attachment, GLuint texture, GLint level); +GLAPI PFNGLFRAMEBUFFERTEXTUREPROC glad_glFramebufferTexture; +#define glFramebufferTexture glad_glFramebufferTexture +typedef void (APIENTRYP PFNGLTEXIMAGE2DMULTISAMPLEPROC)(GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLboolean fixedsamplelocations); +GLAPI PFNGLTEXIMAGE2DMULTISAMPLEPROC glad_glTexImage2DMultisample; +#define glTexImage2DMultisample glad_glTexImage2DMultisample +typedef void (APIENTRYP PFNGLTEXIMAGE3DMULTISAMPLEPROC)(GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedsamplelocations); +GLAPI PFNGLTEXIMAGE3DMULTISAMPLEPROC glad_glTexImage3DMultisample; +#define glTexImage3DMultisample glad_glTexImage3DMultisample +typedef void (APIENTRYP PFNGLGETMULTISAMPLEFVPROC)(GLenum pname, GLuint index, GLfloat *val); +GLAPI PFNGLGETMULTISAMPLEFVPROC glad_glGetMultisamplefv; +#define glGetMultisamplefv glad_glGetMultisamplefv +typedef void (APIENTRYP PFNGLSAMPLEMASKIPROC)(GLuint maskNumber, GLbitfield mask); +GLAPI PFNGLSAMPLEMASKIPROC glad_glSampleMaski; +#define glSampleMaski glad_glSampleMaski +#endif +#define GL_MULTISAMPLE_ARB 0x809D +#define GL_SAMPLE_ALPHA_TO_COVERAGE_ARB 0x809E +#define GL_SAMPLE_ALPHA_TO_ONE_ARB 0x809F +#define GL_SAMPLE_COVERAGE_ARB 0x80A0 +#define GL_SAMPLE_BUFFERS_ARB 0x80A8 +#define GL_SAMPLES_ARB 0x80A9 +#define GL_SAMPLE_COVERAGE_VALUE_ARB 0x80AA +#define GL_SAMPLE_COVERAGE_INVERT_ARB 0x80AB +#define GL_MULTISAMPLE_BIT_ARB 0x20000000 +#define GL_CONTEXT_FLAG_ROBUST_ACCESS_BIT_ARB 0x00000004 +#define GL_LOSE_CONTEXT_ON_RESET_ARB 0x8252 +#define GL_GUILTY_CONTEXT_RESET_ARB 0x8253 +#define GL_INNOCENT_CONTEXT_RESET_ARB 0x8254 +#define GL_UNKNOWN_CONTEXT_RESET_ARB 0x8255 +#define GL_RESET_NOTIFICATION_STRATEGY_ARB 0x8256 +#define GL_NO_RESET_NOTIFICATION_ARB 0x8261 +#define GL_DEBUG_OUTPUT_SYNCHRONOUS 0x8242 +#define GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH 0x8243 +#define GL_DEBUG_CALLBACK_FUNCTION 0x8244 +#define GL_DEBUG_CALLBACK_USER_PARAM 0x8245 +#define GL_DEBUG_SOURCE_API 0x8246 +#define GL_DEBUG_SOURCE_WINDOW_SYSTEM 0x8247 +#define GL_DEBUG_SOURCE_SHADER_COMPILER 0x8248 +#define GL_DEBUG_SOURCE_THIRD_PARTY 0x8249 +#define GL_DEBUG_SOURCE_APPLICATION 0x824A +#define GL_DEBUG_SOURCE_OTHER 0x824B +#define GL_DEBUG_TYPE_ERROR 0x824C +#define GL_DEBUG_TYPE_DEPRECATED_BEHAVIOR 0x824D +#define GL_DEBUG_TYPE_UNDEFINED_BEHAVIOR 0x824E +#define GL_DEBUG_TYPE_PORTABILITY 0x824F +#define GL_DEBUG_TYPE_PERFORMANCE 0x8250 +#define GL_DEBUG_TYPE_OTHER 0x8251 +#define GL_DEBUG_TYPE_MARKER 0x8268 +#define GL_DEBUG_TYPE_PUSH_GROUP 0x8269 +#define GL_DEBUG_TYPE_POP_GROUP 0x826A +#define GL_DEBUG_SEVERITY_NOTIFICATION 0x826B +#define GL_MAX_DEBUG_GROUP_STACK_DEPTH 0x826C +#define GL_DEBUG_GROUP_STACK_DEPTH 0x826D +#define GL_BUFFER 0x82E0 +#define GL_SHADER 0x82E1 +#define GL_PROGRAM 0x82E2 +#define GL_QUERY 0x82E3 +#define GL_PROGRAM_PIPELINE 0x82E4 +#define GL_SAMPLER 0x82E6 +#define GL_MAX_LABEL_LENGTH 0x82E8 +#define GL_MAX_DEBUG_MESSAGE_LENGTH 0x9143 +#define GL_MAX_DEBUG_LOGGED_MESSAGES 0x9144 +#define GL_DEBUG_LOGGED_MESSAGES 0x9145 +#define GL_DEBUG_SEVERITY_HIGH 0x9146 +#define GL_DEBUG_SEVERITY_MEDIUM 0x9147 +#define GL_DEBUG_SEVERITY_LOW 0x9148 +#define GL_DEBUG_OUTPUT 0x92E0 +#define GL_CONTEXT_FLAG_DEBUG_BIT 0x00000002 +#define GL_DEBUG_OUTPUT_SYNCHRONOUS_KHR 0x8242 +#define GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH_KHR 0x8243 +#define GL_DEBUG_CALLBACK_FUNCTION_KHR 0x8244 +#define GL_DEBUG_CALLBACK_USER_PARAM_KHR 0x8245 +#define GL_DEBUG_SOURCE_API_KHR 0x8246 +#define GL_DEBUG_SOURCE_WINDOW_SYSTEM_KHR 0x8247 +#define GL_DEBUG_SOURCE_SHADER_COMPILER_KHR 0x8248 +#define GL_DEBUG_SOURCE_THIRD_PARTY_KHR 0x8249 +#define GL_DEBUG_SOURCE_APPLICATION_KHR 0x824A +#define GL_DEBUG_SOURCE_OTHER_KHR 0x824B +#define GL_DEBUG_TYPE_ERROR_KHR 0x824C +#define GL_DEBUG_TYPE_DEPRECATED_BEHAVIOR_KHR 0x824D +#define GL_DEBUG_TYPE_UNDEFINED_BEHAVIOR_KHR 0x824E +#define GL_DEBUG_TYPE_PORTABILITY_KHR 0x824F +#define GL_DEBUG_TYPE_PERFORMANCE_KHR 0x8250 +#define GL_DEBUG_TYPE_OTHER_KHR 0x8251 +#define GL_DEBUG_TYPE_MARKER_KHR 0x8268 +#define GL_DEBUG_TYPE_PUSH_GROUP_KHR 0x8269 +#define GL_DEBUG_TYPE_POP_GROUP_KHR 0x826A +#define GL_DEBUG_SEVERITY_NOTIFICATION_KHR 0x826B +#define GL_MAX_DEBUG_GROUP_STACK_DEPTH_KHR 0x826C +#define GL_DEBUG_GROUP_STACK_DEPTH_KHR 0x826D +#define GL_BUFFER_KHR 0x82E0 +#define GL_SHADER_KHR 0x82E1 +#define GL_PROGRAM_KHR 0x82E2 +#define GL_VERTEX_ARRAY_KHR 0x8074 +#define GL_QUERY_KHR 0x82E3 +#define GL_PROGRAM_PIPELINE_KHR 0x82E4 +#define GL_SAMPLER_KHR 0x82E6 +#define GL_MAX_LABEL_LENGTH_KHR 0x82E8 +#define GL_MAX_DEBUG_MESSAGE_LENGTH_KHR 0x9143 +#define GL_MAX_DEBUG_LOGGED_MESSAGES_KHR 0x9144 +#define GL_DEBUG_LOGGED_MESSAGES_KHR 0x9145 +#define GL_DEBUG_SEVERITY_HIGH_KHR 0x9146 +#define GL_DEBUG_SEVERITY_MEDIUM_KHR 0x9147 +#define GL_DEBUG_SEVERITY_LOW_KHR 0x9148 +#define GL_DEBUG_OUTPUT_KHR 0x92E0 +#define GL_CONTEXT_FLAG_DEBUG_BIT_KHR 0x00000002 +#define GL_STACK_OVERFLOW_KHR 0x0503 +#define GL_STACK_UNDERFLOW_KHR 0x0504 +#define GL_DISPLAY_LIST 0x82E7 +#ifndef GL_ARB_multisample +#define GL_ARB_multisample 1 +GLAPI int GLAD_GL_ARB_multisample; +typedef void (APIENTRYP PFNGLSAMPLECOVERAGEARBPROC)(GLfloat value, GLboolean invert); +GLAPI PFNGLSAMPLECOVERAGEARBPROC glad_glSampleCoverageARB; +#define glSampleCoverageARB glad_glSampleCoverageARB +#endif +#ifndef GL_ARB_robustness +#define GL_ARB_robustness 1 +GLAPI int GLAD_GL_ARB_robustness; +typedef GLenum (APIENTRYP PFNGLGETGRAPHICSRESETSTATUSARBPROC)(); +GLAPI PFNGLGETGRAPHICSRESETSTATUSARBPROC glad_glGetGraphicsResetStatusARB; +#define glGetGraphicsResetStatusARB glad_glGetGraphicsResetStatusARB +typedef void (APIENTRYP PFNGLGETNTEXIMAGEARBPROC)(GLenum target, GLint level, GLenum format, GLenum type, GLsizei bufSize, void *img); +GLAPI PFNGLGETNTEXIMAGEARBPROC glad_glGetnTexImageARB; +#define glGetnTexImageARB glad_glGetnTexImageARB +typedef void (APIENTRYP PFNGLREADNPIXELSARBPROC)(GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLsizei bufSize, void *data); +GLAPI PFNGLREADNPIXELSARBPROC glad_glReadnPixelsARB; +#define glReadnPixelsARB glad_glReadnPixelsARB +typedef void (APIENTRYP PFNGLGETNCOMPRESSEDTEXIMAGEARBPROC)(GLenum target, GLint lod, GLsizei bufSize, void *img); +GLAPI PFNGLGETNCOMPRESSEDTEXIMAGEARBPROC glad_glGetnCompressedTexImageARB; +#define glGetnCompressedTexImageARB glad_glGetnCompressedTexImageARB +typedef void (APIENTRYP PFNGLGETNUNIFORMFVARBPROC)(GLuint program, GLint location, GLsizei bufSize, GLfloat *params); +GLAPI PFNGLGETNUNIFORMFVARBPROC glad_glGetnUniformfvARB; +#define glGetnUniformfvARB glad_glGetnUniformfvARB +typedef void (APIENTRYP PFNGLGETNUNIFORMIVARBPROC)(GLuint program, GLint location, GLsizei bufSize, GLint *params); +GLAPI PFNGLGETNUNIFORMIVARBPROC glad_glGetnUniformivARB; +#define glGetnUniformivARB glad_glGetnUniformivARB +typedef void (APIENTRYP PFNGLGETNUNIFORMUIVARBPROC)(GLuint program, GLint location, GLsizei bufSize, GLuint *params); +GLAPI PFNGLGETNUNIFORMUIVARBPROC glad_glGetnUniformuivARB; +#define glGetnUniformuivARB glad_glGetnUniformuivARB +typedef void (APIENTRYP PFNGLGETNUNIFORMDVARBPROC)(GLuint program, GLint location, GLsizei bufSize, GLdouble *params); +GLAPI PFNGLGETNUNIFORMDVARBPROC glad_glGetnUniformdvARB; +#define glGetnUniformdvARB glad_glGetnUniformdvARB +typedef void (APIENTRYP PFNGLGETNMAPDVARBPROC)(GLenum target, GLenum query, GLsizei bufSize, GLdouble *v); +GLAPI PFNGLGETNMAPDVARBPROC glad_glGetnMapdvARB; +#define glGetnMapdvARB glad_glGetnMapdvARB +typedef void (APIENTRYP PFNGLGETNMAPFVARBPROC)(GLenum target, GLenum query, GLsizei bufSize, GLfloat *v); +GLAPI PFNGLGETNMAPFVARBPROC glad_glGetnMapfvARB; +#define glGetnMapfvARB glad_glGetnMapfvARB +typedef void (APIENTRYP PFNGLGETNMAPIVARBPROC)(GLenum target, GLenum query, GLsizei bufSize, GLint *v); +GLAPI PFNGLGETNMAPIVARBPROC glad_glGetnMapivARB; +#define glGetnMapivARB glad_glGetnMapivARB +typedef void (APIENTRYP PFNGLGETNPIXELMAPFVARBPROC)(GLenum map, GLsizei bufSize, GLfloat *values); +GLAPI PFNGLGETNPIXELMAPFVARBPROC glad_glGetnPixelMapfvARB; +#define glGetnPixelMapfvARB glad_glGetnPixelMapfvARB +typedef void (APIENTRYP PFNGLGETNPIXELMAPUIVARBPROC)(GLenum map, GLsizei bufSize, GLuint *values); +GLAPI PFNGLGETNPIXELMAPUIVARBPROC glad_glGetnPixelMapuivARB; +#define glGetnPixelMapuivARB glad_glGetnPixelMapuivARB +typedef void (APIENTRYP PFNGLGETNPIXELMAPUSVARBPROC)(GLenum map, GLsizei bufSize, GLushort *values); +GLAPI PFNGLGETNPIXELMAPUSVARBPROC glad_glGetnPixelMapusvARB; +#define glGetnPixelMapusvARB glad_glGetnPixelMapusvARB +typedef void (APIENTRYP PFNGLGETNPOLYGONSTIPPLEARBPROC)(GLsizei bufSize, GLubyte *pattern); +GLAPI PFNGLGETNPOLYGONSTIPPLEARBPROC glad_glGetnPolygonStippleARB; +#define glGetnPolygonStippleARB glad_glGetnPolygonStippleARB +typedef void (APIENTRYP PFNGLGETNCOLORTABLEARBPROC)(GLenum target, GLenum format, GLenum type, GLsizei bufSize, void *table); +GLAPI PFNGLGETNCOLORTABLEARBPROC glad_glGetnColorTableARB; +#define glGetnColorTableARB glad_glGetnColorTableARB +typedef void (APIENTRYP PFNGLGETNCONVOLUTIONFILTERARBPROC)(GLenum target, GLenum format, GLenum type, GLsizei bufSize, void *image); +GLAPI PFNGLGETNCONVOLUTIONFILTERARBPROC glad_glGetnConvolutionFilterARB; +#define glGetnConvolutionFilterARB glad_glGetnConvolutionFilterARB +typedef void (APIENTRYP PFNGLGETNSEPARABLEFILTERARBPROC)(GLenum target, GLenum format, GLenum type, GLsizei rowBufSize, void *row, GLsizei columnBufSize, void *column, void *span); +GLAPI PFNGLGETNSEPARABLEFILTERARBPROC glad_glGetnSeparableFilterARB; +#define glGetnSeparableFilterARB glad_glGetnSeparableFilterARB +typedef void (APIENTRYP PFNGLGETNHISTOGRAMARBPROC)(GLenum target, GLboolean reset, GLenum format, GLenum type, GLsizei bufSize, void *values); +GLAPI PFNGLGETNHISTOGRAMARBPROC glad_glGetnHistogramARB; +#define glGetnHistogramARB glad_glGetnHistogramARB +typedef void (APIENTRYP PFNGLGETNMINMAXARBPROC)(GLenum target, GLboolean reset, GLenum format, GLenum type, GLsizei bufSize, void *values); +GLAPI PFNGLGETNMINMAXARBPROC glad_glGetnMinmaxARB; +#define glGetnMinmaxARB glad_glGetnMinmaxARB +#endif +#ifndef GL_KHR_debug +#define GL_KHR_debug 1 +GLAPI int GLAD_GL_KHR_debug; +typedef void (APIENTRYP PFNGLDEBUGMESSAGECONTROLPROC)(GLenum source, GLenum type, GLenum severity, GLsizei count, const GLuint *ids, GLboolean enabled); +GLAPI PFNGLDEBUGMESSAGECONTROLPROC glad_glDebugMessageControl; +#define glDebugMessageControl glad_glDebugMessageControl +typedef void (APIENTRYP PFNGLDEBUGMESSAGEINSERTPROC)(GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar *buf); +GLAPI PFNGLDEBUGMESSAGEINSERTPROC glad_glDebugMessageInsert; +#define glDebugMessageInsert glad_glDebugMessageInsert +typedef void (APIENTRYP PFNGLDEBUGMESSAGECALLBACKPROC)(GLDEBUGPROC callback, const void *userParam); +GLAPI PFNGLDEBUGMESSAGECALLBACKPROC glad_glDebugMessageCallback; +#define glDebugMessageCallback glad_glDebugMessageCallback +typedef GLuint (APIENTRYP PFNGLGETDEBUGMESSAGELOGPROC)(GLuint count, GLsizei bufSize, GLenum *sources, GLenum *types, GLuint *ids, GLenum *severities, GLsizei *lengths, GLchar *messageLog); +GLAPI PFNGLGETDEBUGMESSAGELOGPROC glad_glGetDebugMessageLog; +#define glGetDebugMessageLog glad_glGetDebugMessageLog +typedef void (APIENTRYP PFNGLPUSHDEBUGGROUPPROC)(GLenum source, GLuint id, GLsizei length, const GLchar *message); +GLAPI PFNGLPUSHDEBUGGROUPPROC glad_glPushDebugGroup; +#define glPushDebugGroup glad_glPushDebugGroup +typedef void (APIENTRYP PFNGLPOPDEBUGGROUPPROC)(); +GLAPI PFNGLPOPDEBUGGROUPPROC glad_glPopDebugGroup; +#define glPopDebugGroup glad_glPopDebugGroup +typedef void (APIENTRYP PFNGLOBJECTLABELPROC)(GLenum identifier, GLuint name, GLsizei length, const GLchar *label); +GLAPI PFNGLOBJECTLABELPROC glad_glObjectLabel; +#define glObjectLabel glad_glObjectLabel +typedef void (APIENTRYP PFNGLGETOBJECTLABELPROC)(GLenum identifier, GLuint name, GLsizei bufSize, GLsizei *length, GLchar *label); +GLAPI PFNGLGETOBJECTLABELPROC glad_glGetObjectLabel; +#define glGetObjectLabel glad_glGetObjectLabel +typedef void (APIENTRYP PFNGLOBJECTPTRLABELPROC)(const void *ptr, GLsizei length, const GLchar *label); +GLAPI PFNGLOBJECTPTRLABELPROC glad_glObjectPtrLabel; +#define glObjectPtrLabel glad_glObjectPtrLabel +typedef void (APIENTRYP PFNGLGETOBJECTPTRLABELPROC)(const void *ptr, GLsizei bufSize, GLsizei *length, GLchar *label); +GLAPI PFNGLGETOBJECTPTRLABELPROC glad_glGetObjectPtrLabel; +#define glGetObjectPtrLabel glad_glGetObjectPtrLabel +typedef void (APIENTRYP PFNGLDEBUGMESSAGECONTROLKHRPROC)(GLenum source, GLenum type, GLenum severity, GLsizei count, const GLuint *ids, GLboolean enabled); +GLAPI PFNGLDEBUGMESSAGECONTROLKHRPROC glad_glDebugMessageControlKHR; +#define glDebugMessageControlKHR glad_glDebugMessageControlKHR +typedef void (APIENTRYP PFNGLDEBUGMESSAGEINSERTKHRPROC)(GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar *buf); +GLAPI PFNGLDEBUGMESSAGEINSERTKHRPROC glad_glDebugMessageInsertKHR; +#define glDebugMessageInsertKHR glad_glDebugMessageInsertKHR +typedef void (APIENTRYP PFNGLDEBUGMESSAGECALLBACKKHRPROC)(GLDEBUGPROCKHR callback, const void *userParam); +GLAPI PFNGLDEBUGMESSAGECALLBACKKHRPROC glad_glDebugMessageCallbackKHR; +#define glDebugMessageCallbackKHR glad_glDebugMessageCallbackKHR +typedef GLuint (APIENTRYP PFNGLGETDEBUGMESSAGELOGKHRPROC)(GLuint count, GLsizei bufSize, GLenum *sources, GLenum *types, GLuint *ids, GLenum *severities, GLsizei *lengths, GLchar *messageLog); +GLAPI PFNGLGETDEBUGMESSAGELOGKHRPROC glad_glGetDebugMessageLogKHR; +#define glGetDebugMessageLogKHR glad_glGetDebugMessageLogKHR +typedef void (APIENTRYP PFNGLPUSHDEBUGGROUPKHRPROC)(GLenum source, GLuint id, GLsizei length, const GLchar *message); +GLAPI PFNGLPUSHDEBUGGROUPKHRPROC glad_glPushDebugGroupKHR; +#define glPushDebugGroupKHR glad_glPushDebugGroupKHR +typedef void (APIENTRYP PFNGLPOPDEBUGGROUPKHRPROC)(); +GLAPI PFNGLPOPDEBUGGROUPKHRPROC glad_glPopDebugGroupKHR; +#define glPopDebugGroupKHR glad_glPopDebugGroupKHR +typedef void (APIENTRYP PFNGLOBJECTLABELKHRPROC)(GLenum identifier, GLuint name, GLsizei length, const GLchar *label); +GLAPI PFNGLOBJECTLABELKHRPROC glad_glObjectLabelKHR; +#define glObjectLabelKHR glad_glObjectLabelKHR +typedef void (APIENTRYP PFNGLGETOBJECTLABELKHRPROC)(GLenum identifier, GLuint name, GLsizei bufSize, GLsizei *length, GLchar *label); +GLAPI PFNGLGETOBJECTLABELKHRPROC glad_glGetObjectLabelKHR; +#define glGetObjectLabelKHR glad_glGetObjectLabelKHR +typedef void (APIENTRYP PFNGLOBJECTPTRLABELKHRPROC)(const void *ptr, GLsizei length, const GLchar *label); +GLAPI PFNGLOBJECTPTRLABELKHRPROC glad_glObjectPtrLabelKHR; +#define glObjectPtrLabelKHR glad_glObjectPtrLabelKHR +typedef void (APIENTRYP PFNGLGETOBJECTPTRLABELKHRPROC)(const void *ptr, GLsizei bufSize, GLsizei *length, GLchar *label); +GLAPI PFNGLGETOBJECTPTRLABELKHRPROC glad_glGetObjectPtrLabelKHR; +#define glGetObjectPtrLabelKHR glad_glGetObjectPtrLabelKHR +typedef void (APIENTRYP PFNGLGETPOINTERVKHRPROC)(GLenum pname, void **params); +GLAPI PFNGLGETPOINTERVKHRPROC glad_glGetPointervKHR; +#define glGetPointervKHR glad_glGetPointervKHR +#endif + +#ifdef __cplusplus +} +#endif + +#endif diff --git a/src/external/glfw/deps/linmath.h b/src/external/glfw/deps/linmath.h new file mode 100644 index 000000000..9c2e2a0ab --- /dev/null +++ b/src/external/glfw/deps/linmath.h @@ -0,0 +1,574 @@ +#ifndef LINMATH_H +#define LINMATH_H + +#include + +#ifdef _MSC_VER +#define inline __inline +#endif + +#define LINMATH_H_DEFINE_VEC(n) \ +typedef float vec##n[n]; \ +static inline void vec##n##_add(vec##n r, vec##n const a, vec##n const b) \ +{ \ + int i; \ + for(i=0; i 1e-4) { + mat4x4 T, C, S = {{0}}; + + vec3_norm(u, u); + mat4x4_from_vec3_mul_outer(T, u, u); + + S[1][2] = u[0]; + S[2][1] = -u[0]; + S[2][0] = u[1]; + S[0][2] = -u[1]; + S[0][1] = u[2]; + S[1][0] = -u[2]; + + mat4x4_scale(S, S, s); + + mat4x4_identity(C); + mat4x4_sub(C, C, T); + + mat4x4_scale(C, C, c); + + mat4x4_add(T, T, C); + mat4x4_add(T, T, S); + + T[3][3] = 1.; + mat4x4_mul(R, M, T); + } else { + mat4x4_dup(R, M); + } +} +static inline void mat4x4_rotate_X(mat4x4 Q, mat4x4 M, float angle) +{ + float s = sinf(angle); + float c = cosf(angle); + mat4x4 R = { + {1.f, 0.f, 0.f, 0.f}, + {0.f, c, s, 0.f}, + {0.f, -s, c, 0.f}, + {0.f, 0.f, 0.f, 1.f} + }; + mat4x4_mul(Q, M, R); +} +static inline void mat4x4_rotate_Y(mat4x4 Q, mat4x4 M, float angle) +{ + float s = sinf(angle); + float c = cosf(angle); + mat4x4 R = { + { c, 0.f, s, 0.f}, + { 0.f, 1.f, 0.f, 0.f}, + { -s, 0.f, c, 0.f}, + { 0.f, 0.f, 0.f, 1.f} + }; + mat4x4_mul(Q, M, R); +} +static inline void mat4x4_rotate_Z(mat4x4 Q, mat4x4 M, float angle) +{ + float s = sinf(angle); + float c = cosf(angle); + mat4x4 R = { + { c, s, 0.f, 0.f}, + { -s, c, 0.f, 0.f}, + { 0.f, 0.f, 1.f, 0.f}, + { 0.f, 0.f, 0.f, 1.f} + }; + mat4x4_mul(Q, M, R); +} +static inline void mat4x4_invert(mat4x4 T, mat4x4 M) +{ + float idet; + float s[6]; + float c[6]; + s[0] = M[0][0]*M[1][1] - M[1][0]*M[0][1]; + s[1] = M[0][0]*M[1][2] - M[1][0]*M[0][2]; + s[2] = M[0][0]*M[1][3] - M[1][0]*M[0][3]; + s[3] = M[0][1]*M[1][2] - M[1][1]*M[0][2]; + s[4] = M[0][1]*M[1][3] - M[1][1]*M[0][3]; + s[5] = M[0][2]*M[1][3] - M[1][2]*M[0][3]; + + c[0] = M[2][0]*M[3][1] - M[3][0]*M[2][1]; + c[1] = M[2][0]*M[3][2] - M[3][0]*M[2][2]; + c[2] = M[2][0]*M[3][3] - M[3][0]*M[2][3]; + c[3] = M[2][1]*M[3][2] - M[3][1]*M[2][2]; + c[4] = M[2][1]*M[3][3] - M[3][1]*M[2][3]; + c[5] = M[2][2]*M[3][3] - M[3][2]*M[2][3]; + + /* Assumes it is invertible */ + idet = 1.0f/( s[0]*c[5]-s[1]*c[4]+s[2]*c[3]+s[3]*c[2]-s[4]*c[1]+s[5]*c[0] ); + + T[0][0] = ( M[1][1] * c[5] - M[1][2] * c[4] + M[1][3] * c[3]) * idet; + T[0][1] = (-M[0][1] * c[5] + M[0][2] * c[4] - M[0][3] * c[3]) * idet; + T[0][2] = ( M[3][1] * s[5] - M[3][2] * s[4] + M[3][3] * s[3]) * idet; + T[0][3] = (-M[2][1] * s[5] + M[2][2] * s[4] - M[2][3] * s[3]) * idet; + + T[1][0] = (-M[1][0] * c[5] + M[1][2] * c[2] - M[1][3] * c[1]) * idet; + T[1][1] = ( M[0][0] * c[5] - M[0][2] * c[2] + M[0][3] * c[1]) * idet; + T[1][2] = (-M[3][0] * s[5] + M[3][2] * s[2] - M[3][3] * s[1]) * idet; + T[1][3] = ( M[2][0] * s[5] - M[2][2] * s[2] + M[2][3] * s[1]) * idet; + + T[2][0] = ( M[1][0] * c[4] - M[1][1] * c[2] + M[1][3] * c[0]) * idet; + T[2][1] = (-M[0][0] * c[4] + M[0][1] * c[2] - M[0][3] * c[0]) * idet; + T[2][2] = ( M[3][0] * s[4] - M[3][1] * s[2] + M[3][3] * s[0]) * idet; + T[2][3] = (-M[2][0] * s[4] + M[2][1] * s[2] - M[2][3] * s[0]) * idet; + + T[3][0] = (-M[1][0] * c[3] + M[1][1] * c[1] - M[1][2] * c[0]) * idet; + T[3][1] = ( M[0][0] * c[3] - M[0][1] * c[1] + M[0][2] * c[0]) * idet; + T[3][2] = (-M[3][0] * s[3] + M[3][1] * s[1] - M[3][2] * s[0]) * idet; + T[3][3] = ( M[2][0] * s[3] - M[2][1] * s[1] + M[2][2] * s[0]) * idet; +} +static inline void mat4x4_orthonormalize(mat4x4 R, mat4x4 M) +{ + float s = 1.; + vec3 h; + + mat4x4_dup(R, M); + vec3_norm(R[2], R[2]); + + s = vec3_mul_inner(R[1], R[2]); + vec3_scale(h, R[2], s); + vec3_sub(R[1], R[1], h); + vec3_norm(R[2], R[2]); + + s = vec3_mul_inner(R[1], R[2]); + vec3_scale(h, R[2], s); + vec3_sub(R[1], R[1], h); + vec3_norm(R[1], R[1]); + + s = vec3_mul_inner(R[0], R[1]); + vec3_scale(h, R[1], s); + vec3_sub(R[0], R[0], h); + vec3_norm(R[0], R[0]); +} + +static inline void mat4x4_frustum(mat4x4 M, float l, float r, float b, float t, float n, float f) +{ + M[0][0] = 2.f*n/(r-l); + M[0][1] = M[0][2] = M[0][3] = 0.f; + + M[1][1] = 2.f*n/(t-b); + M[1][0] = M[1][2] = M[1][3] = 0.f; + + M[2][0] = (r+l)/(r-l); + M[2][1] = (t+b)/(t-b); + M[2][2] = -(f+n)/(f-n); + M[2][3] = -1.f; + + M[3][2] = -2.f*(f*n)/(f-n); + M[3][0] = M[3][1] = M[3][3] = 0.f; +} +static inline void mat4x4_ortho(mat4x4 M, float l, float r, float b, float t, float n, float f) +{ + M[0][0] = 2.f/(r-l); + M[0][1] = M[0][2] = M[0][3] = 0.f; + + M[1][1] = 2.f/(t-b); + M[1][0] = M[1][2] = M[1][3] = 0.f; + + M[2][2] = -2.f/(f-n); + M[2][0] = M[2][1] = M[2][3] = 0.f; + + M[3][0] = -(r+l)/(r-l); + M[3][1] = -(t+b)/(t-b); + M[3][2] = -(f+n)/(f-n); + M[3][3] = 1.f; +} +static inline void mat4x4_perspective(mat4x4 m, float y_fov, float aspect, float n, float f) +{ + /* NOTE: Degrees are an unhandy unit to work with. + * linmath.h uses radians for everything! */ + float const a = 1.f / (float) tan(y_fov / 2.f); + + m[0][0] = a / aspect; + m[0][1] = 0.f; + m[0][2] = 0.f; + m[0][3] = 0.f; + + m[1][0] = 0.f; + m[1][1] = a; + m[1][2] = 0.f; + m[1][3] = 0.f; + + m[2][0] = 0.f; + m[2][1] = 0.f; + m[2][2] = -((f + n) / (f - n)); + m[2][3] = -1.f; + + m[3][0] = 0.f; + m[3][1] = 0.f; + m[3][2] = -((2.f * f * n) / (f - n)); + m[3][3] = 0.f; +} +static inline void mat4x4_look_at(mat4x4 m, vec3 eye, vec3 center, vec3 up) +{ + /* Adapted from Android's OpenGL Matrix.java. */ + /* See the OpenGL GLUT documentation for gluLookAt for a description */ + /* of the algorithm. We implement it in a straightforward way: */ + + /* TODO: The negation of of can be spared by swapping the order of + * operands in the following cross products in the right way. */ + vec3 f; + vec3 s; + vec3 t; + + vec3_sub(f, center, eye); + vec3_norm(f, f); + + vec3_mul_cross(s, f, up); + vec3_norm(s, s); + + vec3_mul_cross(t, s, f); + + m[0][0] = s[0]; + m[0][1] = t[0]; + m[0][2] = -f[0]; + m[0][3] = 0.f; + + m[1][0] = s[1]; + m[1][1] = t[1]; + m[1][2] = -f[1]; + m[1][3] = 0.f; + + m[2][0] = s[2]; + m[2][1] = t[2]; + m[2][2] = -f[2]; + m[2][3] = 0.f; + + m[3][0] = 0.f; + m[3][1] = 0.f; + m[3][2] = 0.f; + m[3][3] = 1.f; + + mat4x4_translate_in_place(m, -eye[0], -eye[1], -eye[2]); +} + +typedef float quat[4]; +static inline void quat_identity(quat q) +{ + q[0] = q[1] = q[2] = 0.f; + q[3] = 1.f; +} +static inline void quat_add(quat r, quat a, quat b) +{ + int i; + for(i=0; i<4; ++i) + r[i] = a[i] + b[i]; +} +static inline void quat_sub(quat r, quat a, quat b) +{ + int i; + for(i=0; i<4; ++i) + r[i] = a[i] - b[i]; +} +static inline void quat_mul(quat r, quat p, quat q) +{ + vec3 w; + vec3_mul_cross(r, p, q); + vec3_scale(w, p, q[3]); + vec3_add(r, r, w); + vec3_scale(w, q, p[3]); + vec3_add(r, r, w); + r[3] = p[3]*q[3] - vec3_mul_inner(p, q); +} +static inline void quat_scale(quat r, quat v, float s) +{ + int i; + for(i=0; i<4; ++i) + r[i] = v[i] * s; +} +static inline float quat_inner_product(quat a, quat b) +{ + float p = 0.f; + int i; + for(i=0; i<4; ++i) + p += b[i]*a[i]; + return p; +} +static inline void quat_conj(quat r, quat q) +{ + int i; + for(i=0; i<3; ++i) + r[i] = -q[i]; + r[3] = q[3]; +} +static inline void quat_rotate(quat r, float angle, vec3 axis) { + int i; + vec3 v; + vec3_scale(v, axis, sinf(angle / 2)); + for(i=0; i<3; ++i) + r[i] = v[i]; + r[3] = cosf(angle / 2); +} +#define quat_norm vec4_norm +static inline void quat_mul_vec3(vec3 r, quat q, vec3 v) +{ +/* + * Method by Fabian 'ryg' Giessen (of Farbrausch) +t = 2 * cross(q.xyz, v) +v' = v + q.w * t + cross(q.xyz, t) + */ + vec3 t = {q[0], q[1], q[2]}; + vec3 u = {q[0], q[1], q[2]}; + + vec3_mul_cross(t, t, v); + vec3_scale(t, t, 2); + + vec3_mul_cross(u, u, t); + vec3_scale(t, t, q[3]); + + vec3_add(r, v, t); + vec3_add(r, r, u); +} +static inline void mat4x4_from_quat(mat4x4 M, quat q) +{ + float a = q[3]; + float b = q[0]; + float c = q[1]; + float d = q[2]; + float a2 = a*a; + float b2 = b*b; + float c2 = c*c; + float d2 = d*d; + + M[0][0] = a2 + b2 - c2 - d2; + M[0][1] = 2.f*(b*c + a*d); + M[0][2] = 2.f*(b*d - a*c); + M[0][3] = 0.f; + + M[1][0] = 2*(b*c - a*d); + M[1][1] = a2 - b2 + c2 - d2; + M[1][2] = 2.f*(c*d + a*b); + M[1][3] = 0.f; + + M[2][0] = 2.f*(b*d + a*c); + M[2][1] = 2.f*(c*d - a*b); + M[2][2] = a2 - b2 - c2 + d2; + M[2][3] = 0.f; + + M[3][0] = M[3][1] = M[3][2] = 0.f; + M[3][3] = 1.f; +} + +static inline void mat4x4o_mul_quat(mat4x4 R, mat4x4 M, quat q) +{ +/* XXX: The way this is written only works for othogonal matrices. */ +/* TODO: Take care of non-orthogonal case. */ + quat_mul_vec3(R[0], q, M[0]); + quat_mul_vec3(R[1], q, M[1]); + quat_mul_vec3(R[2], q, M[2]); + + R[3][0] = R[3][1] = R[3][2] = 0.f; + R[3][3] = 1.f; +} +static inline void quat_from_mat4x4(quat q, mat4x4 M) +{ + float r=0.f; + int i; + + int perm[] = { 0, 1, 2, 0, 1 }; + int *p = perm; + + for(i = 0; i<3; i++) { + float m = M[i][i]; + if( m < r ) + continue; + m = r; + p = &perm[i]; + } + + r = (float) sqrt(1.f + M[p[0]][p[0]] - M[p[1]][p[1]] - M[p[2]][p[2]] ); + + if(r < 1e-6) { + q[0] = 1.f; + q[1] = q[2] = q[3] = 0.f; + return; + } + + q[0] = r/2.f; + q[1] = (M[p[0]][p[1]] - M[p[1]][p[0]])/(2.f*r); + q[2] = (M[p[2]][p[0]] - M[p[0]][p[2]])/(2.f*r); + q[3] = (M[p[2]][p[1]] - M[p[1]][p[2]])/(2.f*r); +} + +#endif diff --git a/src/external/glfw/deps/nuklear.h b/src/external/glfw/deps/nuklear.h new file mode 100644 index 000000000..9b304a22a --- /dev/null +++ b/src/external/glfw/deps/nuklear.h @@ -0,0 +1,23717 @@ +/* + Nuklear - 2.00.4 - public domain + no warranty implied; use at your own risk. + authored from 2015-2017 by Micha Mettke + +ABOUT: + This is a minimal state graphical user interface single header toolkit + written in ANSI C and licensed under public domain. + It was designed as a simple embeddable user interface for application and does + not have any dependencies, a default renderbackend or OS window and input handling + but instead provides a very modular library approach by using simple input state + for input and draw commands describing primitive shapes as output. + So instead of providing a layered library that tries to abstract over a number + of platform and render backends it only focuses on the actual UI. + +VALUES: + - Graphical user interface toolkit + - Single header library + - Written in C89 (a.k.a. ANSI C or ISO C90) + - Small codebase (~18kLOC) + - Focus on portability, efficiency and simplicity + - No dependencies (not even the standard library if not wanted) + - Fully skinnable and customizable + - Low memory footprint with total memory control if needed or wanted + - UTF-8 support + - No global or hidden state + - Customizable library modules (you can compile and use only what you need) + - Optional font baker and vertex buffer output + +USAGE: + This library is self contained in one single header file and can be used either + in header only mode or in implementation mode. The header only mode is used + by default when included and allows including this header in other headers + and does not contain the actual implementation. + + The implementation mode requires to define the preprocessor macro + NK_IMPLEMENTATION in *one* .c/.cpp file before #includeing this file, e.g.: + + #define NK_IMPLEMENTATION + #include "nuklear.h" + + Also optionally define the symbols listed in the section "OPTIONAL DEFINES" + below in header and implementation mode if you want to use additional functionality + or need more control over the library. + IMPORTANT: Every time you include "nuklear.h" you have to define the same flags. + This is very important not doing it either leads to compiler errors + or even worse stack corruptions. + +FEATURES: + - Absolutely no platform dependent code + - Memory management control ranging from/to + - Ease of use by allocating everything from standard library + - Control every byte of memory inside the library + - Font handling control ranging from/to + - Use your own font implementation for everything + - Use this libraries internal font baking and handling API + - Drawing output control ranging from/to + - Simple shapes for more high level APIs which already have drawing capabilities + - Hardware accessible anti-aliased vertex buffer output + - Customizable colors and properties ranging from/to + - Simple changes to color by filling a simple color table + - Complete control with ability to use skinning to decorate widgets + - Bendable UI library with widget ranging from/to + - Basic widgets like buttons, checkboxes, slider, ... + - Advanced widget like abstract comboboxes, contextual menus,... + - Compile time configuration to only compile what you need + - Subset which can be used if you do not want to link or use the standard library + - Can be easily modified to only update on user input instead of frame updates + +OPTIONAL DEFINES: + NK_PRIVATE + If defined declares all functions as static, so they can only be accessed + inside the file that contains the implementation + + NK_INCLUDE_FIXED_TYPES + If defined it will include header for fixed sized types + otherwise nuklear tries to select the correct type. If that fails it will + throw a compiler error and you have to select the correct types yourself. + If used needs to be defined for implementation and header + + NK_INCLUDE_DEFAULT_ALLOCATOR + if defined it will include header and provide additional functions + to use this library without caring for memory allocation control and therefore + ease memory management. + Adds the standard library with malloc and free so don't define if you + don't want to link to the standard library + If used needs to be defined for implementation and header + + NK_INCLUDE_STANDARD_IO + if defined it will include header and provide + additional functions depending on file loading. + Adds the standard library with fopen, fclose,... so don't define this + if you don't want to link to the standard library + If used needs to be defined for implementation and header + + NK_INCLUDE_STANDARD_VARARGS + if defined it will include header and provide + additional functions depending on variable arguments + Adds the standard library with va_list and so don't define this if + you don't want to link to the standard library + If used needs to be defined for implementation and header + + NK_INCLUDE_VERTEX_BUFFER_OUTPUT + Defining this adds a vertex draw command list backend to this + library, which allows you to convert queue commands into vertex draw commands. + This is mainly if you need a hardware accessible format for OpenGL, DirectX, + Vulkan, Metal,... + If used needs to be defined for implementation and header + + NK_INCLUDE_FONT_BAKING + Defining this adds `stb_truetype` and `stb_rect_pack` implementation + to this library and provides font baking and rendering. + If you already have font handling or do not want to use this font handler + you don't have to define it. + If used needs to be defined for implementation and header + + NK_INCLUDE_DEFAULT_FONT + Defining this adds the default font: ProggyClean.ttf into this library + which can be loaded into a font atlas and allows using this library without + having a truetype font + Enabling this adds ~12kb to global stack memory + If used needs to be defined for implementation and header + + NK_INCLUDE_COMMAND_USERDATA + Defining this adds a userdata pointer into each command. Can be useful for + example if you want to provide custom shaders depending on the used widget. + Can be combined with the style structures. + If used needs to be defined for implementation and header + + NK_BUTTON_TRIGGER_ON_RELEASE + Different platforms require button clicks occurring either on buttons being + pressed (up to down) or released (down to up). + By default this library will react on buttons being pressed, but if you + define this it will only trigger if a button is released. + If used it is only required to be defined for the implementation part + + NK_ZERO_COMMAND_MEMORY + Defining this will zero out memory for each drawing command added to a + drawing queue (inside nk_command_buffer_push). Zeroing command memory + is very useful for fast checking (using memcmp) if command buffers are + equal and avoid drawing frames when nothing on screen has changed since + previous frame. + + NK_ASSERT + If you don't define this, nuklear will use with assert(). + Adds the standard library so define to nothing of not wanted + If used needs to be defined for implementation and header + + NK_BUFFER_DEFAULT_INITIAL_SIZE + Initial buffer size allocated by all buffers while using the default allocator + functions included by defining NK_INCLUDE_DEFAULT_ALLOCATOR. If you don't + want to allocate the default 4k memory then redefine it. + If used needs to be defined for implementation and header + + NK_MAX_NUMBER_BUFFER + Maximum buffer size for the conversion buffer between float and string + Under normal circumstances this should be more than sufficient. + If used needs to be defined for implementation and header + + NK_INPUT_MAX + Defines the max number of bytes which can be added as text input in one frame. + Under normal circumstances this should be more than sufficient. + If used it is only required to be defined for the implementation part + + NK_MEMSET + You can define this to 'memset' or your own memset implementation + replacement. If not nuklear will use its own version. + If used it is only required to be defined for the implementation part + + NK_MEMCPY + You can define this to 'memcpy' or your own memcpy implementation + replacement. If not nuklear will use its own version. + If used it is only required to be defined for the implementation part + + NK_SQRT + You can define this to 'sqrt' or your own sqrt implementation + replacement. If not nuklear will use its own slow and not highly + accurate version. + If used it is only required to be defined for the implementation part + + NK_SIN + You can define this to 'sinf' or your own sine implementation + replacement. If not nuklear will use its own approximation implementation. + If used it is only required to be defined for the implementation part + + NK_COS + You can define this to 'cosf' or your own cosine implementation + replacement. If not nuklear will use its own approximation implementation. + If used it is only required to be defined for the implementation part + + NK_STRTOD + You can define this to `strtod` or your own string to double conversion + implementation replacement. If not defined nuklear will use its own + imprecise and possibly unsafe version (does not handle nan or infinity!). + If used it is only required to be defined for the implementation part + + NK_DTOA + You can define this to `dtoa` or your own double to string conversion + implementation replacement. If not defined nuklear will use its own + imprecise and possibly unsafe version (does not handle nan or infinity!). + If used it is only required to be defined for the implementation part + + NK_VSNPRINTF + If you define `NK_INCLUDE_STANDARD_VARARGS` as well as `NK_INCLUDE_STANDARD_IO` + and want to be safe define this to `vsnprintf` on compilers supporting + later versions of C or C++. By default nuklear will check for your stdlib version + in C as well as compiler version in C++. if `vsnprintf` is available + it will define it to `vsnprintf` directly. If not defined and if you have + older versions of C or C++ it will be defined to `vsprintf` which is unsafe. + If used it is only required to be defined for the implementation part + + NK_BYTE + NK_INT16 + NK_UINT16 + NK_INT32 + NK_UINT32 + NK_SIZE_TYPE + NK_POINTER_TYPE + If you compile without NK_USE_FIXED_TYPE then a number of standard types + will be selected and compile time validated. If they are incorrect you can + define the correct types by overloading these type defines. + +CREDITS: + Developed by Micha Mettke and every direct or indirect contributor. + + Embeds stb_texedit, stb_truetype and stb_rectpack by Sean Barret (public domain) + Embeds ProggyClean.ttf font by Tristan Grimmer (MIT license). + + Big thank you to Omar Cornut (ocornut@github) for his imgui library and + giving me the inspiration for this library, Casey Muratori for handmade hero + and his original immediate mode graphical user interface idea and Sean + Barret for his amazing single header libraries which restored my faith + in libraries and brought me to create some of my own. + +LICENSE: + This software is dual-licensed to the public domain and under the following + license: you are granted a perpetual, irrevocable license to copy, modify, + publish and distribute this file as you see fit. +*/ +#ifndef NK_NUKLEAR_H_ +#define NK_NUKLEAR_H_ + +#ifdef __cplusplus +extern "C" { +#endif +/* + * ============================================================== + * + * CONSTANTS + * + * =============================================================== + */ +#define NK_UNDEFINED (-1.0f) +#define NK_UTF_INVALID 0xFFFD /* internal invalid utf8 rune */ +#define NK_UTF_SIZE 4 /* describes the number of bytes a glyph consists of*/ +#ifndef NK_INPUT_MAX +#define NK_INPUT_MAX 16 +#endif +#ifndef NK_MAX_NUMBER_BUFFER +#define NK_MAX_NUMBER_BUFFER 64 +#endif +#ifndef NK_SCROLLBAR_HIDING_TIMEOUT +#define NK_SCROLLBAR_HIDING_TIMEOUT 4.0f +#endif +/* + * ============================================================== + * + * HELPER + * + * =============================================================== + */ +#ifndef NK_API + #ifdef NK_PRIVATE + #if (defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 199409L)) + #define NK_API static inline + #elif defined(__cplusplus) + #define NK_API static inline + #else + #define NK_API static + #endif + #else + #define NK_API extern + #endif +#endif + +#define NK_INTERN static +#define NK_STORAGE static +#define NK_GLOBAL static + +#define NK_FLAG(x) (1 << (x)) +#define NK_STRINGIFY(x) #x +#define NK_MACRO_STRINGIFY(x) NK_STRINGIFY(x) +#define NK_STRING_JOIN_IMMEDIATE(arg1, arg2) arg1 ## arg2 +#define NK_STRING_JOIN_DELAY(arg1, arg2) NK_STRING_JOIN_IMMEDIATE(arg1, arg2) +#define NK_STRING_JOIN(arg1, arg2) NK_STRING_JOIN_DELAY(arg1, arg2) + +#ifdef _MSC_VER +#define NK_UNIQUE_NAME(name) NK_STRING_JOIN(name,__COUNTER__) +#else +#define NK_UNIQUE_NAME(name) NK_STRING_JOIN(name,__LINE__) +#endif + +#ifndef NK_STATIC_ASSERT +#define NK_STATIC_ASSERT(exp) typedef char NK_UNIQUE_NAME(_dummy_array)[(exp)?1:-1] +#endif + +#ifndef NK_FILE_LINE +#ifdef _MSC_VER +#define NK_FILE_LINE __FILE__ ":" NK_MACRO_STRINGIFY(__COUNTER__) +#else +#define NK_FILE_LINE __FILE__ ":" NK_MACRO_STRINGIFY(__LINE__) +#endif +#endif + +#define NK_MIN(a,b) ((a) < (b) ? (a) : (b)) +#define NK_MAX(a,b) ((a) < (b) ? (b) : (a)) +#define NK_CLAMP(i,v,x) (NK_MAX(NK_MIN(v,x), i)) +/* + * =============================================================== + * + * BASIC + * + * =============================================================== + */ +#ifdef NK_INCLUDE_FIXED_TYPES + #include + #define NK_INT8 int8_t + #define NK_UINT8 uint8_t + #define NK_INT16 int16_t + #define NK_UINT16 uint16_t + #define NK_INT32 int32_t + #define NK_UINT32 uint32_t + #define NK_SIZE_TYPE uintptr_t + #define NK_POINTER_TYPE uintptr_t +#else + #ifndef NK_INT8 + #define NK_INT8 char + #endif + #ifndef NK_UINT8 + #define NK_UINT8 unsigned char + #endif + #ifndef NK_INT16 + #define NK_INT16 signed short + #endif + #ifndef NK_UINT16 + #define NK_UINT16 unsigned short + #endif + #ifndef NK_INT32 + #if defined(_MSC_VER) + #define NK_INT32 __int32 + #else + #define NK_INT32 signed int + #endif + #endif + #ifndef NK_UINT32 + #if defined(_MSC_VER) + #define NK_UINT32 unsigned __int32 + #else + #define NK_UINT32 unsigned int + #endif + #endif + #ifndef NK_SIZE_TYPE + #if defined(_WIN64) && defined(_MSC_VER) + #define NK_SIZE_TYPE unsigned __int64 + #elif (defined(_WIN32) || defined(WIN32)) && defined(_MSC_VER) + #define NK_SIZE_TYPE unsigned __int32 + #elif defined(__GNUC__) || defined(__clang__) + #if defined(__x86_64__) || defined(__ppc64__) + #define NK_SIZE_TYPE unsigned long + #else + #define NK_SIZE_TYPE unsigned int + #endif + #else + #define NK_SIZE_TYPE unsigned long + #endif + #endif + #ifndef NK_POINTER_TYPE + #if defined(_WIN64) && defined(_MSC_VER) + #define NK_POINTER_TYPE unsigned __int64 + #elif (defined(_WIN32) || defined(WIN32)) && defined(_MSC_VER) + #define NK_POINTER_TYPE unsigned __int32 + #elif defined(__GNUC__) || defined(__clang__) + #if defined(__x86_64__) || defined(__ppc64__) + #define NK_POINTER_TYPE unsigned long + #else + #define NK_POINTER_TYPE unsigned int + #endif + #else + #define NK_POINTER_TYPE unsigned long + #endif + #endif +#endif + +typedef NK_INT8 nk_char; +typedef NK_UINT8 nk_uchar; +typedef NK_UINT8 nk_byte; +typedef NK_INT16 nk_short; +typedef NK_UINT16 nk_ushort; +typedef NK_INT32 nk_int; +typedef NK_UINT32 nk_uint; +typedef NK_SIZE_TYPE nk_size; +typedef NK_POINTER_TYPE nk_ptr; + +typedef nk_uint nk_hash; +typedef nk_uint nk_flags; +typedef nk_uint nk_rune; + +/* Make sure correct type size: + * This will fire with a negative subscript error if the type sizes + * are set incorrectly by the compiler, and compile out if not */ +NK_STATIC_ASSERT(sizeof(nk_short) == 2); +NK_STATIC_ASSERT(sizeof(nk_ushort) == 2); +NK_STATIC_ASSERT(sizeof(nk_uint) == 4); +NK_STATIC_ASSERT(sizeof(nk_int) == 4); +NK_STATIC_ASSERT(sizeof(nk_byte) == 1); +NK_STATIC_ASSERT(sizeof(nk_flags) >= 4); +NK_STATIC_ASSERT(sizeof(nk_rune) >= 4); +NK_STATIC_ASSERT(sizeof(nk_size) >= sizeof(void*)); +NK_STATIC_ASSERT(sizeof(nk_ptr) >= sizeof(void*)); + +/* ============================================================================ + * + * API + * + * =========================================================================== */ +struct nk_buffer; +struct nk_allocator; +struct nk_command_buffer; +struct nk_draw_command; +struct nk_convert_config; +struct nk_style_item; +struct nk_text_edit; +struct nk_draw_list; +struct nk_user_font; +struct nk_panel; +struct nk_context; +struct nk_draw_vertex_layout_element; +struct nk_style_button; +struct nk_style_toggle; +struct nk_style_selectable; +struct nk_style_slide; +struct nk_style_progress; +struct nk_style_scrollbar; +struct nk_style_edit; +struct nk_style_property; +struct nk_style_chart; +struct nk_style_combo; +struct nk_style_tab; +struct nk_style_window_header; +struct nk_style_window; + +enum {nk_false, nk_true}; +struct nk_color {nk_byte r,g,b,a;}; +struct nk_colorf {float r,g,b,a;}; +struct nk_vec2 {float x,y;}; +struct nk_vec2i {short x, y;}; +struct nk_rect {float x,y,w,h;}; +struct nk_recti {short x,y,w,h;}; +typedef char nk_glyph[NK_UTF_SIZE]; +typedef union {void *ptr; int id;} nk_handle; +struct nk_image {nk_handle handle;unsigned short w,h;unsigned short region[4];}; +struct nk_cursor {struct nk_image img; struct nk_vec2 size, offset;}; +struct nk_scroll {nk_uint x, y;}; + +enum nk_heading {NK_UP, NK_RIGHT, NK_DOWN, NK_LEFT}; +enum nk_button_behavior {NK_BUTTON_DEFAULT, NK_BUTTON_REPEATER}; +enum nk_modify {NK_FIXED = nk_false, NK_MODIFIABLE = nk_true}; +enum nk_orientation {NK_VERTICAL, NK_HORIZONTAL}; +enum nk_collapse_states {NK_MINIMIZED = nk_false, NK_MAXIMIZED = nk_true}; +enum nk_show_states {NK_HIDDEN = nk_false, NK_SHOWN = nk_true}; +enum nk_chart_type {NK_CHART_LINES, NK_CHART_COLUMN, NK_CHART_MAX}; +enum nk_chart_event {NK_CHART_HOVERING = 0x01, NK_CHART_CLICKED = 0x02}; +enum nk_color_format {NK_RGB, NK_RGBA}; +enum nk_popup_type {NK_POPUP_STATIC, NK_POPUP_DYNAMIC}; +enum nk_layout_format {NK_DYNAMIC, NK_STATIC}; +enum nk_tree_type {NK_TREE_NODE, NK_TREE_TAB}; + +typedef void*(*nk_plugin_alloc)(nk_handle, void *old, nk_size); +typedef void (*nk_plugin_free)(nk_handle, void *old); +typedef int(*nk_plugin_filter)(const struct nk_text_edit*, nk_rune unicode); +typedef void(*nk_plugin_paste)(nk_handle, struct nk_text_edit*); +typedef void(*nk_plugin_copy)(nk_handle, const char*, int len); + +struct nk_allocator { + nk_handle userdata; + nk_plugin_alloc alloc; + nk_plugin_free free; +}; +enum nk_symbol_type { + NK_SYMBOL_NONE, + NK_SYMBOL_X, + NK_SYMBOL_UNDERSCORE, + NK_SYMBOL_CIRCLE_SOLID, + NK_SYMBOL_CIRCLE_OUTLINE, + NK_SYMBOL_RECT_SOLID, + NK_SYMBOL_RECT_OUTLINE, + NK_SYMBOL_TRIANGLE_UP, + NK_SYMBOL_TRIANGLE_DOWN, + NK_SYMBOL_TRIANGLE_LEFT, + NK_SYMBOL_TRIANGLE_RIGHT, + NK_SYMBOL_PLUS, + NK_SYMBOL_MINUS, + NK_SYMBOL_MAX +}; +/* ============================================================================= + * + * CONTEXT + * + * =============================================================================*/ +/* Contexts are the main entry point and the majestro of nuklear and contain all required state. + * They are used for window, memory, input, style, stack, commands and time management and need + * to be passed into all nuklear GUI specific functions. + * + * Usage + * ------------------- + * To use a context it first has to be initialized which can be achieved by calling + * one of either `nk_init_default`, `nk_init_fixed`, `nk_init`, `nk_init_custom`. + * Each takes in a font handle and a specific way of handling memory. Memory control + * hereby ranges from standard library to just specifying a fixed sized block of memory + * which nuklear has to manage itself from. + * + * struct nk_context ctx; + * nk_init_xxx(&ctx, ...); + * while (1) { + * [...] + * nk_clear(&ctx); + * } + * nk_free(&ctx); + * + * Reference + * ------------------- + * nk_init_default - Initializes context with standard library memory allocation (malloc,free) + * nk_init_fixed - Initializes context from single fixed size memory block + * nk_init - Initializes context with memory allocator callbacks for alloc and free + * nk_init_custom - Initializes context from two buffers. One for draw commands the other for window/panel/table allocations + * nk_clear - Called at the end of the frame to reset and prepare the context for the next frame + * nk_free - Shutdown and free all memory allocated inside the context + * nk_set_user_data - Utility function to pass user data to draw command + */ +#ifdef NK_INCLUDE_DEFAULT_ALLOCATOR +/* nk_init_default - Initializes a `nk_context` struct with a default standard library allocator. + * Should be used if you don't want to be bothered with memory management in nuklear. + * Parameters: + * @ctx must point to an either stack or heap allocated `nk_context` struct + * @font must point to a previously initialized font handle for more info look at font documentation + * Return values: + * true(1) on success + * false(0) on failure */ +NK_API int nk_init_default(struct nk_context*, const struct nk_user_font*); +#endif +/* nk_init_fixed - Initializes a `nk_context` struct from a single fixed size memory block + * Should be used if you want complete control over nuklear's memory management. + * Especially recommended for system with little memory or systems with virtual memory. + * For the later case you can just allocate for example 16MB of virtual memory + * and only the required amount of memory will actually be committed. + * IMPORTANT: make sure the passed memory block is aligned correctly for `nk_draw_commands` + * Parameters: + * @ctx must point to an either stack or heap allocated `nk_context` struct + * @memory must point to a previously allocated memory block + * @size must contain the total size of @memory + * @font must point to a previously initialized font handle for more info look at font documentation + * Return values: + * true(1) on success + * false(0) on failure */ +NK_API int nk_init_fixed(struct nk_context*, void *memory, nk_size size, const struct nk_user_font*); +/* nk_init - Initializes a `nk_context` struct with memory allocation callbacks for nuklear to allocate + * memory from. Used internally for `nk_init_default` and provides a kitchen sink allocation + * interface to nuklear. Can be useful for cases like monitoring memory consumption. + * Parameters: + * @ctx must point to an either stack or heap allocated `nk_context` struct + * @alloc must point to a previously allocated memory allocator + * @font must point to a previously initialized font handle for more info look at font documentation + * Return values: + * true(1) on success + * false(0) on failure */ +NK_API int nk_init(struct nk_context*, struct nk_allocator*, const struct nk_user_font*); +/* nk_init_custom - Initializes a `nk_context` struct from two different either fixed or growing + * buffers. The first buffer is for allocating draw commands while the second buffer is + * used for allocating windows, panels and state tables. + * Parameters: + * @ctx must point to an either stack or heap allocated `nk_context` struct + * @cmds must point to a previously initialized memory buffer either fixed or dynamic to store draw commands into + * @pool must point to a previously initialized memory buffer either fixed or dynamic to store windows, panels and tables + * @font must point to a previously initialized font handle for more info look at font documentation + * Return values: + * true(1) on success + * false(0) on failure */ +NK_API int nk_init_custom(struct nk_context*, struct nk_buffer *cmds, struct nk_buffer *pool, const struct nk_user_font*); +/* nk_clear - Resets the context state at the end of the frame. This includes mostly + * garbage collector tasks like removing windows or table not called and therefore + * used anymore. + * Parameters: + * @ctx must point to a previously initialized `nk_context` struct */ +NK_API void nk_clear(struct nk_context*); +/* nk_free - Frees all memory allocated by nuklear. Not needed if context was + * initialized with `nk_init_fixed`. + * Parameters: + * @ctx must point to a previously initialized `nk_context` struct */ +NK_API void nk_free(struct nk_context*); +#ifdef NK_INCLUDE_COMMAND_USERDATA +/* nk_set_user_data - Sets the currently passed userdata passed down into each draw command. + * Parameters: + * @ctx must point to a previously initialized `nk_context` struct + * @data handle with either pointer or index to be passed into every draw commands */ +NK_API void nk_set_user_data(struct nk_context*, nk_handle handle); +#endif +/* ============================================================================= + * + * INPUT + * + * =============================================================================*/ +/* The input API is responsible for holding the current input state composed of + * mouse, key and text input states. + * It is worth noting that no direct os or window handling is done in nuklear. + * Instead all input state has to be provided by platform specific code. This in one hand + * expects more work from the user and complicates usage but on the other hand + * provides simple abstraction over a big number of platforms, libraries and other + * already provided functionality. + * + * Usage + * ------------------- + * Input state needs to be provided to nuklear by first calling `nk_input_begin` + * which resets internal state like delta mouse position and button transistions. + * After `nk_input_begin` all current input state needs to be provided. This includes + * mouse motion, button and key pressed and released, text input and scrolling. + * Both event- or state-based input handling are supported by this API + * and should work without problems. Finally after all input state has been + * mirrored `nk_input_end` needs to be called to finish input process. + * + * struct nk_context ctx; + * nk_init_xxx(&ctx, ...); + * while (1) { + * Event evt; + * nk_input_begin(&ctx); + * while (GetEvent(&evt)) { + * if (evt.type == MOUSE_MOVE) + * nk_input_motion(&ctx, evt.motion.x, evt.motion.y); + * else if (evt.type == ...) { + * ... + * } + * } + * nk_input_end(&ctx); + * [...] + * nk_clear(&ctx); + * } + * nk_free(&ctx); + * + * Reference + * ------------------- + * nk_input_begin - Begins the input mirroring process. Needs to be called before all other `nk_input_xxx` calls + * nk_input_motion - Mirrors mouse cursor position + * nk_input_key - Mirrors key state with either pressed or released + * nk_input_button - Mirrors mouse button state with either pressed or released + * nk_input_scroll - Mirrors mouse scroll values + * nk_input_char - Adds a single ASCII text character into an internal text buffer + * nk_input_glyph - Adds a single multi-byte UTF-8 character into an internal text buffer + * nk_input_unicode - Adds a single unicode rune into an internal text buffer + * nk_input_end - Ends the input mirroring process by calculating state changes. Don't call any `nk_input_xxx` function referenced above after this call + */ +enum nk_keys { + NK_KEY_NONE, + NK_KEY_SHIFT, + NK_KEY_CTRL, + NK_KEY_DEL, + NK_KEY_ENTER, + NK_KEY_TAB, + NK_KEY_BACKSPACE, + NK_KEY_COPY, + NK_KEY_CUT, + NK_KEY_PASTE, + NK_KEY_UP, + NK_KEY_DOWN, + NK_KEY_LEFT, + NK_KEY_RIGHT, + /* Shortcuts: text field */ + NK_KEY_TEXT_INSERT_MODE, + NK_KEY_TEXT_REPLACE_MODE, + NK_KEY_TEXT_RESET_MODE, + NK_KEY_TEXT_LINE_START, + NK_KEY_TEXT_LINE_END, + NK_KEY_TEXT_START, + NK_KEY_TEXT_END, + NK_KEY_TEXT_UNDO, + NK_KEY_TEXT_REDO, + NK_KEY_TEXT_SELECT_ALL, + NK_KEY_TEXT_WORD_LEFT, + NK_KEY_TEXT_WORD_RIGHT, + /* Shortcuts: scrollbar */ + NK_KEY_SCROLL_START, + NK_KEY_SCROLL_END, + NK_KEY_SCROLL_DOWN, + NK_KEY_SCROLL_UP, + NK_KEY_MAX +}; +enum nk_buttons { + NK_BUTTON_LEFT, + NK_BUTTON_MIDDLE, + NK_BUTTON_RIGHT, + NK_BUTTON_DOUBLE, + NK_BUTTON_MAX +}; +/* nk_input_begin - Begins the input mirroring process by resetting text, scroll + * mouse previous mouse position and movement as well as key state transitions, + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct */ +NK_API void nk_input_begin(struct nk_context*); +/* nk_input_motion - Mirrors current mouse position to nuklear + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @x must contain an integer describing the current mouse cursor x-position + * @y must contain an integer describing the current mouse cursor y-position */ +NK_API void nk_input_motion(struct nk_context*, int x, int y); +/* nk_input_key - Mirrors state of a specific key to nuklear + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @key must be any value specified in enum `nk_keys` that needs to be mirrored + * @down must be 0 for key is up and 1 for key is down */ +NK_API void nk_input_key(struct nk_context*, enum nk_keys, int down); +/* nk_input_button - Mirrors the state of a specific mouse button to nuklear + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @nk_buttons must be any value specified in enum `nk_buttons` that needs to be mirrored + * @x must contain an integer describing mouse cursor x-position on click up/down + * @y must contain an integer describing mouse cursor y-position on click up/down + * @down must be 0 for key is up and 1 for key is down */ +NK_API void nk_input_button(struct nk_context*, enum nk_buttons, int x, int y, int down); +/* nk_input_scroll - Copies the last mouse scroll value to nuklear. Is generally + * a scroll value. So does not have to come from mouse and could also originate + * from touch for example. + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @val vector with both X- as well as Y-scroll value */ +NK_API void nk_input_scroll(struct nk_context*, struct nk_vec2 val); +/* nk_input_char - Copies a single ASCII character into an internal text buffer + * This is basically a helper function to quickly push ASCII characters into + * nuklear. Note that you can only push up to NK_INPUT_MAX bytes into + * struct `nk_input` between `nk_input_begin` and `nk_input_end`. + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @c must be a single ASCII character preferable one that can be printed */ +NK_API void nk_input_char(struct nk_context*, char); +/* nk_input_unicode - Converts a encoded unicode rune into UTF-8 and copies the result + * into an internal text buffer. + * Note that you can only push up to NK_INPUT_MAX bytes into + * struct `nk_input` between `nk_input_begin` and `nk_input_end`. + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @glyph UTF-32 unicode codepoint */ +NK_API void nk_input_glyph(struct nk_context*, const nk_glyph); +/* nk_input_unicode - Converts a unicode rune into UTF-8 and copies the result + * into an internal text buffer. + * Note that you can only push up to NK_INPUT_MAX bytes into + * struct `nk_input` between `nk_input_begin` and `nk_input_end`. + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @glyph UTF-32 unicode codepoint */ +NK_API void nk_input_unicode(struct nk_context*, nk_rune); +/* nk_input_end - End the input mirroring process by resetting mouse grabbing + * state to ensure the mouse cursor is not grabbed indefinitely. + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct */ +NK_API void nk_input_end(struct nk_context*); +/* ============================================================================= + * + * DRAWING + * + * =============================================================================*/ +/* This library was designed to be render backend agnostic so it does + * not draw anything to screen directly. Instead all drawn shapes, widgets + * are made of, are buffered into memory and make up a command queue. + * Each frame therefore fills the command buffer with draw commands + * that then need to be executed by the user and his own render backend. + * After that the command buffer needs to be cleared and a new frame can be + * started. It is probably important to note that the command buffer is the main + * drawing API and the optional vertex buffer API only takes this format and + * converts it into a hardware accessible format. + * + * Usage + * ------------------- + * To draw all draw commands accumulated over a frame you need your own render + * backend able to draw a number of 2D primitives. This includes at least + * filled and stroked rectangles, circles, text, lines, triangles and scissors. + * As soon as this criterion is met you can iterate over each draw command + * and execute each draw command in a interpreter like fashion: + * + * const struct nk_command *cmd = 0; + * nk_foreach(cmd, &ctx) { + * switch (cmd->type) { + * case NK_COMMAND_LINE: + * your_draw_line_function(...) + * break; + * case NK_COMMAND_RECT + * your_draw_rect_function(...) + * break; + * case ...: + * [...] + * } + * + * In program flow context draw commands need to be executed after input has been + * gathered and the complete UI with windows and their contained widgets have + * been executed and before calling `nk_clear` which frees all previously + * allocated draw commands. + * + * struct nk_context ctx; + * nk_init_xxx(&ctx, ...); + * while (1) { + * Event evt; + * nk_input_begin(&ctx); + * while (GetEvent(&evt)) { + * if (evt.type == MOUSE_MOVE) + * nk_input_motion(&ctx, evt.motion.x, evt.motion.y); + * else if (evt.type == [...]) { + * [...] + * } + * } + * nk_input_end(&ctx); + * + * [...] + * + * const struct nk_command *cmd = 0; + * nk_foreach(cmd, &ctx) { + * switch (cmd->type) { + * case NK_COMMAND_LINE: + * your_draw_line_function(...) + * break; + * case NK_COMMAND_RECT + * your_draw_rect_function(...) + * break; + * case ...: + * [...] + * } + * nk_clear(&ctx); + * } + * nk_free(&ctx); + * + * You probably noticed that you have to draw all of the UI each frame which is + * quite wasteful. While the actual UI updating loop is quite fast rendering + * without actually needing it is not. So there are multiple things you could do. + * + * First is only update on input. This of course is only an option if your + * application only depends on the UI and does not require any outside calculations. + * If you actually only update on input make sure to update the UI two times each + * frame and call `nk_clear` directly after the first pass and only draw in + * the second pass. In addition it is recommended to also add additional timers + * to make sure the UI is not drawn more than a fixed number of frames per second. + * + * struct nk_context ctx; + * nk_init_xxx(&ctx, ...); + * while (1) { + * [...wait for input ] + * + * [...do two UI passes ...] + * do_ui(...) + * nk_clear(&ctx); + * do_ui(...) + * + * const struct nk_command *cmd = 0; + * nk_foreach(cmd, &ctx) { + * switch (cmd->type) { + * case NK_COMMAND_LINE: + * your_draw_line_function(...) + * break; + * case NK_COMMAND_RECT + * your_draw_rect_function(...) + * break; + * case ...: + * [...] + * } + * nk_clear(&ctx); + * } + * nk_free(&ctx); + * + * The second probably more applicable trick is to only draw if anything changed. + * It is not really useful for applications with continuous draw loop but + * quite useful for desktop applications. To actually get nuklear to only + * draw on changes you first have to define `NK_ZERO_COMMAND_MEMORY` and + * allocate a memory buffer that will store each unique drawing output. + * After each frame you compare the draw command memory inside the library + * with your allocated buffer by memcmp. If memcmp detects differences + * you have to copy the command buffer into the allocated buffer + * and then draw like usual (this example uses fixed memory but you could + * use dynamically allocated memory). + * + * [... other defines ...] + * #define NK_ZERO_COMMAND_MEMORY + * #include "nuklear.h" + * + * struct nk_context ctx; + * void *last = calloc(1,64*1024); + * void *buf = calloc(1,64*1024); + * nk_init_fixed(&ctx, buf, 64*1024); + * while (1) { + * [...input...] + * [...ui...] + * + * void *cmds = nk_buffer_memory(&ctx.memory); + * if (memcmp(cmds, last, ctx.memory.allocated)) { + * memcpy(last,cmds,ctx.memory.allocated); + * const struct nk_command *cmd = 0; + * nk_foreach(cmd, &ctx) { + * switch (cmd->type) { + * case NK_COMMAND_LINE: + * your_draw_line_function(...) + * break; + * case NK_COMMAND_RECT + * your_draw_rect_function(...) + * break; + * case ...: + * [...] + * } + * } + * } + * nk_clear(&ctx); + * } + * nk_free(&ctx); + * + * Finally while using draw commands makes sense for higher abstracted platforms like + * X11 and Win32 or drawing libraries it is often desirable to use graphics + * hardware directly. Therefore it is possible to just define + * `NK_INCLUDE_VERTEX_BUFFER_OUTPUT` which includes optional vertex output. + * To access the vertex output you first have to convert all draw commands into + * vertexes by calling `nk_convert` which takes in your preferred vertex format. + * After successfully converting all draw commands just iterate over and execute all + * vertex draw commands: + * + * struct nk_convert_config cfg = {}; + * static const struct nk_draw_vertex_layout_element vertex_layout[] = { + * {NK_VERTEX_POSITION, NK_FORMAT_FLOAT, NK_OFFSETOF(struct your_vertex, pos)}, + * {NK_VERTEX_TEXCOORD, NK_FORMAT_FLOAT, NK_OFFSETOF(struct your_vertex, uv)}, + * {NK_VERTEX_COLOR, NK_FORMAT_R8G8B8A8, NK_OFFSETOF(struct your_vertex, col)}, + * {NK_VERTEX_LAYOUT_END} + * }; + * cfg.shape_AA = NK_ANTI_ALIASING_ON; + * cfg.line_AA = NK_ANTI_ALIASING_ON; + * cfg.vertex_layout = vertex_layout; + * cfg.vertex_size = sizeof(struct your_vertex); + * cfg.vertex_alignment = NK_ALIGNOF(struct your_vertex); + * cfg.circle_segment_count = 22; + * cfg.curve_segment_count = 22; + * cfg.arc_segment_count = 22; + * cfg.global_alpha = 1.0f; + * cfg.null = dev->null; + * + * struct nk_buffer cmds, verts, idx; + * nk_buffer_init_default(&cmds); + * nk_buffer_init_default(&verts); + * nk_buffer_init_default(&idx); + * nk_convert(&ctx, &cmds, &verts, &idx, &cfg); + * nk_draw_foreach(cmd, &ctx, &cmds) { + * if (!cmd->elem_count) continue; + * [...] + * } + * nk_buffer_free(&cms); + * nk_buffer_free(&verts); + * nk_buffer_free(&idx); + * + * Reference + * ------------------- + * nk__begin - Returns the first draw command in the context draw command list to be drawn + * nk__next - Increments the draw command iterator to the next command inside the context draw command list + * nk_foreach - Iterates over each draw command inside the context draw command list + * + * nk_convert - Converts from the abstract draw commands list into a hardware accessible vertex format + * nk__draw_begin - Returns the first vertex command in the context vertex draw list to be executed + * nk__draw_next - Increments the vertex command iterator to the next command inside the context vertex command list + * nk__draw_end - Returns the end of the vertex draw list + * nk_draw_foreach - Iterates over each vertex draw command inside the vertex draw list + */ +enum nk_anti_aliasing {NK_ANTI_ALIASING_OFF, NK_ANTI_ALIASING_ON}; +enum nk_convert_result { + NK_CONVERT_SUCCESS = 0, + NK_CONVERT_INVALID_PARAM = 1, + NK_CONVERT_COMMAND_BUFFER_FULL = NK_FLAG(1), + NK_CONVERT_VERTEX_BUFFER_FULL = NK_FLAG(2), + NK_CONVERT_ELEMENT_BUFFER_FULL = NK_FLAG(3) +}; +struct nk_draw_null_texture { + nk_handle texture; /* texture handle to a texture with a white pixel */ + struct nk_vec2 uv; /* coordinates to a white pixel in the texture */ +}; +struct nk_convert_config { + float global_alpha; /* global alpha value */ + enum nk_anti_aliasing line_AA; /* line anti-aliasing flag can be turned off if you are tight on memory */ + enum nk_anti_aliasing shape_AA; /* shape anti-aliasing flag can be turned off if you are tight on memory */ + unsigned circle_segment_count; /* number of segments used for circles: default to 22 */ + unsigned arc_segment_count; /* number of segments used for arcs: default to 22 */ + unsigned curve_segment_count; /* number of segments used for curves: default to 22 */ + struct nk_draw_null_texture null; /* handle to texture with a white pixel for shape drawing */ + const struct nk_draw_vertex_layout_element *vertex_layout; /* describes the vertex output format and packing */ + nk_size vertex_size; /* sizeof one vertex for vertex packing */ + nk_size vertex_alignment; /* vertex alignment: Can be obtained by NK_ALIGNOF */ +}; +/* nk__begin - Returns a draw command list iterator to iterate all draw + * commands accumulated over one frame. + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct at the end of a frame + * Return values: + * draw command pointer pointing to the first command inside the draw command list */ +NK_API const struct nk_command* nk__begin(struct nk_context*); +/* nk__next - Returns a draw command list iterator to iterate all draw + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct at the end of a frame + * @cmd must point to an previously a draw command either returned by `nk__begin` or `nk__next` + * Return values: + * draw command pointer pointing to the next command inside the draw command list */ +NK_API const struct nk_command* nk__next(struct nk_context*, const struct nk_command*); +/* nk_foreach - Iterates over each draw command inside the context draw command list + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct at the end of a frame + * @cmd pointer initialized to NULL */ +#define nk_foreach(c, ctx) for((c) = nk__begin(ctx); (c) != 0; (c) = nk__next(ctx,c)) +#ifdef NK_INCLUDE_VERTEX_BUFFER_OUTPUT +/* nk_convert - converts all internal draw command into vertex draw commands and fills + * three buffers with vertexes, vertex draw commands and vertex indices. The vertex format + * as well as some other configuration values have to be configured by filling out a + * `nk_convert_config` struct. + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct at the end of a frame + * @cmds must point to a previously initialized buffer to hold converted vertex draw commands + * @vertices must point to a previously initialized buffer to hold all produced vertices + * @elements must point to a previously initialized buffer to hold all produced vertex indices + * @config must point to a filled out `nk_config` struct to configure the conversion process + * Returns: + * returns NK_CONVERT_SUCCESS on success and a enum nk_convert_result error values if not */ +NK_API nk_flags nk_convert(struct nk_context*, struct nk_buffer *cmds, struct nk_buffer *vertices, struct nk_buffer *elements, const struct nk_convert_config*); +/* nk__draw_begin - Returns a draw vertex command buffer iterator to iterate each the vertex draw command buffer + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct at the end of a frame + * @buf must point to an previously by `nk_convert` filled out vertex draw command buffer + * Return values: + * vertex draw command pointer pointing to the first command inside the vertex draw command buffer */ +NK_API const struct nk_draw_command* nk__draw_begin(const struct nk_context*, const struct nk_buffer*); +/* nk__draw_end - Returns the vertex draw command at the end of the vertex draw command buffer + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct at the end of a frame + * @buf must point to an previously by `nk_convert` filled out vertex draw command buffer + * Return values: + * vertex draw command pointer pointing to the end of the last vertex draw command inside the vertex draw command buffer */ +NK_API const struct nk_draw_command* nk__draw_end(const struct nk_context*, const struct nk_buffer*); +/* nk__draw_next - Increments the vertex draw command buffer iterator + * Parameters: + * @cmd must point to an previously either by `nk__draw_begin` or `nk__draw_next` returned vertex draw command + * @buf must point to an previously by `nk_convert` filled out vertex draw command buffer + * @ctx must point to an previously initialized `nk_context` struct at the end of a frame + * Return values: + * vertex draw command pointer pointing to the end of the last vertex draw command inside the vertex draw command buffer */ +NK_API const struct nk_draw_command* nk__draw_next(const struct nk_draw_command*, const struct nk_buffer*, const struct nk_context*); +/* nk_draw_foreach - Iterates over each vertex draw command inside a vertex draw command buffer + * Parameters: + * @cmd nk_draw_command pointer set to NULL + * @buf must point to an previously by `nk_convert` filled out vertex draw command buffer + * @ctx must point to an previously initialized `nk_context` struct at the end of a frame */ +#define nk_draw_foreach(cmd,ctx, b) for((cmd)=nk__draw_begin(ctx, b); (cmd)!=0; (cmd)=nk__draw_next(cmd, b, ctx)) +#endif +/* ============================================================================= + * + * WINDOW + * + * ============================================================================= + * Windows are the main persistent state used inside nuklear and are life time + * controlled by simply "retouching" (i.e. calling) each window each frame. + * All widgets inside nuklear can only be added inside function pair `nk_begin_xxx` + * and `nk_end`. Calling any widgets outside these two functions will result in an + * assert in debug or no state change in release mode. + * + * Each window holds frame persistent state like position, size, flags, state tables, + * and some garbage collected internal persistent widget state. Each window + * is linked into a window stack list which determines the drawing and overlapping + * order. The topmost window thereby is the currently active window. + * + * To change window position inside the stack occurs either automatically by + * user input by being clicked on or programmatically by calling `nk_window_focus`. + * Windows by default are visible unless explicitly being defined with flag + * `NK_WINDOW_HIDDEN`, the user clicked the close button on windows with flag + * `NK_WINDOW_CLOSABLE` or if a window was explicitly hidden by calling + * `nk_window_show`. To explicitly close and destroy a window call `nk_window_close`. + * + * Usage + * ------------------- + * To create and keep a window you have to call one of the two `nk_begin_xxx` + * functions to start window declarations and `nk_end` at the end. Furthermore it + * is recommended to check the return value of `nk_begin_xxx` and only process + * widgets inside the window if the value is not 0. Either way you have to call + * `nk_end` at the end of window declarations. Furthermore, do not attempt to + * nest `nk_begin_xxx` calls which will hopefully result in an assert or if not + * in a segmentation fault. + * + * if (nk_begin_xxx(...) { + * [... widgets ...] + * } + * nk_end(ctx); + * + * In the grand concept window and widget declarations need to occur after input + * handling and before drawing to screen. Not doing so can result in higher + * latency or at worst invalid behavior. Furthermore make sure that `nk_clear` + * is called at the end of the frame. While nuklear's default platform backends + * already call `nk_clear` for you if you write your own backend not calling + * `nk_clear` can cause asserts or even worse undefined behavior. + * + * struct nk_context ctx; + * nk_init_xxx(&ctx, ...); + * while (1) { + * Event evt; + * nk_input_begin(&ctx); + * while (GetEvent(&evt)) { + * if (evt.type == MOUSE_MOVE) + * nk_input_motion(&ctx, evt.motion.x, evt.motion.y); + * else if (evt.type == [...]) { + * nk_input_xxx(...); + * } + * } + * nk_input_end(&ctx); + * + * if (nk_begin_xxx(...) { + * [...] + * } + * nk_end(ctx); + * + * const struct nk_command *cmd = 0; + * nk_foreach(cmd, &ctx) { + * case NK_COMMAND_LINE: + * your_draw_line_function(...) + * break; + * case NK_COMMAND_RECT + * your_draw_rect_function(...) + * break; + * case ...: + * [...] + * } + * nk_clear(&ctx); + * } + * nk_free(&ctx); + * + * Reference + * ------------------- + * nk_begin - starts a new window; needs to be called every frame for every window (unless hidden) or otherwise the window gets removed + * nk_begin_titled - extended window start with separated title and identifier to allow multiple windows with same name but not title + * nk_end - needs to be called at the end of the window building process to process scaling, scrollbars and general cleanup + * + * nk_window_find - finds and returns the window with give name + * nk_window_get_bounds - returns a rectangle with screen position and size of the currently processed window. + * nk_window_get_position - returns the position of the currently processed window + * nk_window_get_size - returns the size with width and height of the currently processed window + * nk_window_get_width - returns the width of the currently processed window + * nk_window_get_height - returns the height of the currently processed window + * nk_window_get_panel - returns the underlying panel which contains all processing state of the current window + * nk_window_get_content_region - returns the position and size of the currently visible and non-clipped space inside the currently processed window + * nk_window_get_content_region_min - returns the upper rectangle position of the currently visible and non-clipped space inside the currently processed window + * nk_window_get_content_region_max - returns the upper rectangle position of the currently visible and non-clipped space inside the currently processed window + * nk_window_get_content_region_size - returns the size of the currently visible and non-clipped space inside the currently processed window + * nk_window_get_canvas - returns the draw command buffer. Can be used to draw custom widgets + * + * nk_window_has_focus - returns if the currently processed window is currently active + * nk_window_is_collapsed - returns if the window with given name is currently minimized/collapsed + * nk_window_is_closed - returns if the currently processed window was closed + * nk_window_is_hidden - returns if the currently processed window was hidden + * nk_window_is_active - same as nk_window_has_focus for some reason + * nk_window_is_hovered - returns if the currently processed window is currently being hovered by mouse + * nk_window_is_any_hovered - return if any window currently hovered + * nk_item_is_any_active - returns if any window or widgets is currently hovered or active + * + * nk_window_set_bounds - updates position and size of the currently processed window + * nk_window_set_position - updates position of the currently process window + * nk_window_set_size - updates the size of the currently processed window + * nk_window_set_focus - set the currently processed window as active window + * + * nk_window_close - closes the window with given window name which deletes the window at the end of the frame + * nk_window_collapse - collapses the window with given window name + * nk_window_collapse_if - collapses the window with given window name if the given condition was met + * nk_window_show - hides a visible or reshows a hidden window + * nk_window_show_if - hides/shows a window depending on condition + */ +enum nk_panel_flags { + NK_WINDOW_BORDER = NK_FLAG(0), /* Draws a border around the window to visually separate window from the background */ + NK_WINDOW_MOVABLE = NK_FLAG(1), /* The movable flag indicates that a window can be moved by user input or by dragging the window header */ + NK_WINDOW_SCALABLE = NK_FLAG(2), /* The scalable flag indicates that a window can be scaled by user input by dragging a scaler icon at the button of the window */ + NK_WINDOW_CLOSABLE = NK_FLAG(3), /* adds a closable icon into the header */ + NK_WINDOW_MINIMIZABLE = NK_FLAG(4), /* adds a minimize icon into the header */ + NK_WINDOW_NO_SCROLLBAR = NK_FLAG(5), /* Removes the scrollbar from the window */ + NK_WINDOW_TITLE = NK_FLAG(6), /* Forces a header at the top at the window showing the title */ + NK_WINDOW_SCROLL_AUTO_HIDE = NK_FLAG(7), /* Automatically hides the window scrollbar if no user interaction: also requires delta time in `nk_context` to be set each frame */ + NK_WINDOW_BACKGROUND = NK_FLAG(8), /* Always keep window in the background */ + NK_WINDOW_SCALE_LEFT = NK_FLAG(9), /* Puts window scaler in the left-ottom corner instead right-bottom*/ + NK_WINDOW_NO_INPUT = NK_FLAG(10) /* Prevents window of scaling, moving or getting focus */ +}; +/* nk_begin - starts a new window; needs to be called every frame for every window (unless hidden) or otherwise the window gets removed + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @title window title and identifier. Needs to be persistent over frames to identify the window + * @bounds initial position and window size. However if you do not define `NK_WINDOW_SCALABLE` or `NK_WINDOW_MOVABLE` you can set window position and size every frame + * @flags window flags defined in `enum nk_panel_flags` with a number of different window behaviors + * Return values: + * returns 1 if the window can be filled up with widgets from this point until `nk_end or 0 otherwise for example if minimized `*/ +NK_API int nk_begin(struct nk_context *ctx, const char *title, struct nk_rect bounds, nk_flags flags); +/* nk_begin_titled - extended window start with separated title and identifier to allow multiple windows with same name but not title + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @name window identifier. Needs to be persistent over frames to identify the window + * @title window title displayed inside header if flag `NK_WINDOW_TITLE` or either `NK_WINDOW_CLOSABLE` or `NK_WINDOW_MINIMIZED` was set + * @bounds initial position and window size. However if you do not define `NK_WINDOW_SCALABLE` or `NK_WINDOW_MOVABLE` you can set window position and size every frame + * @flags window flags defined in `enum nk_panel_flags` with a number of different window behaviors + * Return values: + * returns 1 if the window can be filled up with widgets from this point until `nk_end or 0 otherwise `*/ +NK_API int nk_begin_titled(struct nk_context *ctx, const char *name, const char *title, struct nk_rect bounds, nk_flags flags); +/* nk_end - needs to be called at the end of the window building process to process scaling, scrollbars and general cleanup. + * All widget calls after this functions will result in asserts or no state changes + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct */ +NK_API void nk_end(struct nk_context *ctx); +/* nk_window_find - finds and returns the window with give name + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @name window identifier + * Return values: + * returns a `nk_window` struct pointing to the identified window or 0 if no window with given name was found */ +NK_API struct nk_window *nk_window_find(struct nk_context *ctx, const char *name); +/* nk_window_get_bounds - returns a rectangle with screen position and size of the currently processed window. + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * Return values: + * returns a `nk_rect` struct with window upper left position and size */ +NK_API struct nk_rect nk_window_get_bounds(const struct nk_context *ctx); +/* nk_window_get_position - returns the position of the currently processed window. + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * Return values: + * returns a `nk_vec2` struct with window upper left position */ +NK_API struct nk_vec2 nk_window_get_position(const struct nk_context *ctx); +/* nk_window_get_size - returns the size with width and height of the currently processed window. + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * Return values: + * returns a `nk_vec2` struct with window size */ +NK_API struct nk_vec2 nk_window_get_size(const struct nk_context*); +/* nk_window_get_width - returns the width of the currently processed window. + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * Return values: + * returns the window width */ +NK_API float nk_window_get_width(const struct nk_context*); +/* nk_window_get_height - returns the height of the currently processed window. + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * Return values: + * returns the window height */ +NK_API float nk_window_get_height(const struct nk_context*); +/* nk_window_get_panel - returns the underlying panel which contains all processing state of the current window. + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * Return values: + * returns a pointer to window internal `nk_panel` state. DO NOT keep this pointer around it is only valid until `nk_end` */ +NK_API struct nk_panel* nk_window_get_panel(struct nk_context*); +/* nk_window_get_content_region - returns the position and size of the currently visible and non-clipped space inside the currently processed window. + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * Return values: + * returns `nk_rect` struct with screen position and size (no scrollbar offset) of the visible space inside the current window */ +NK_API struct nk_rect nk_window_get_content_region(struct nk_context*); +/* nk_window_get_content_region_min - returns the upper left position of the currently visible and non-clipped space inside the currently processed window. + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * Return values: + * returns `nk_vec2` struct with upper left screen position (no scrollbar offset) of the visible space inside the current window */ +NK_API struct nk_vec2 nk_window_get_content_region_min(struct nk_context*); +/* nk_window_get_content_region_max - returns the lower right screen position of the currently visible and non-clipped space inside the currently processed window. + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * Return values: + * returns `nk_vec2` struct with lower right screen position (no scrollbar offset) of the visible space inside the current window */ +NK_API struct nk_vec2 nk_window_get_content_region_max(struct nk_context*); +/* nk_window_get_content_region_size - returns the size of the currently visible and non-clipped space inside the currently processed window + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * Return values: + * returns `nk_vec2` struct with size the visible space inside the current window */ +NK_API struct nk_vec2 nk_window_get_content_region_size(struct nk_context*); +/* nk_window_get_canvas - returns the draw command buffer. Can be used to draw custom widgets + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * Return values: + * returns a pointer to window internal `nk_command_buffer` struct used as drawing canvas. Can be used to do custom drawing */ +NK_API struct nk_command_buffer* nk_window_get_canvas(struct nk_context*); +/* nk_window_has_focus - returns if the currently processed window is currently active + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * Return values: + * returns 0 if current window is not active or 1 if it is */ +NK_API int nk_window_has_focus(const struct nk_context*); +/* nk_window_is_collapsed - returns if the window with given name is currently minimized/collapsed + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @name of window you want to check is collapsed + * Return values: + * returns 1 if current window is minimized and 0 if window not found or is not minimized */ +NK_API int nk_window_is_collapsed(struct nk_context *ctx, const char *name); +/* nk_window_is_closed - returns if the window with given name was closed by calling `nk_close` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @name of window you want to check is closed + * Return values: + * returns 1 if current window was closed or 0 window not found or not closed */ +NK_API int nk_window_is_closed(struct nk_context*, const char*); +/* nk_window_is_hidden - returns if the window with given name is hidden + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @name of window you want to check is hidden + * Return values: + * returns 1 if current window is hidden or 0 window not found or visible */ +NK_API int nk_window_is_hidden(struct nk_context*, const char*); +/* nk_window_is_active - same as nk_window_has_focus for some reason + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @name of window you want to check is hidden + * Return values: + * returns 1 if current window is active or 0 window not found or not active */ +NK_API int nk_window_is_active(struct nk_context*, const char*); +/* nk_window_is_hovered - return if the current window is being hovered + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * Return values: + * returns 1 if current window is hovered or 0 otherwise */ +NK_API int nk_window_is_hovered(struct nk_context*); +/* nk_window_is_any_hovered - returns if the any window is being hovered + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * Return values: + * returns 1 if any window is hovered or 0 otherwise */ +NK_API int nk_window_is_any_hovered(struct nk_context*); +/* nk_item_is_any_active - returns if the any window is being hovered or any widget is currently active. + * Can be used to decide if input should be processed by UI or your specific input handling. + * Example could be UI and 3D camera to move inside a 3D space. + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * Return values: + * returns 1 if any window is hovered or any item is active or 0 otherwise */ +NK_API int nk_item_is_any_active(struct nk_context*); +/* nk_window_set_bounds - updates position and size of the currently processed window + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @name of the window to modify both position and size + * @bounds points to a `nk_rect` struct with the new position and size of currently active window */ +NK_API void nk_window_set_bounds(struct nk_context*, const char *name, struct nk_rect bounds); +/* nk_window_set_position - updates position of the currently processed window + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @name of the window to modify position of + * @pos points to a `nk_vec2` struct with the new position of currently active window */ +NK_API void nk_window_set_position(struct nk_context*, const char *name, struct nk_vec2 pos); +/* nk_window_set_size - updates size of the currently processed window + * IMPORTANT: only call this function between calls `nk_begin_xxx` and `nk_end` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @name of the window to modify size of + * @size points to a `nk_vec2` struct with the new size of currently active window */ +NK_API void nk_window_set_size(struct nk_context*, const char *name, struct nk_vec2); +/* nk_window_set_focus - sets the window with given name as active + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @name of the window to be set active */ +NK_API void nk_window_set_focus(struct nk_context*, const char *name); +/* nk_window_close - closed a window and marks it for being freed at the end of the frame + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @name of the window to be closed */ +NK_API void nk_window_close(struct nk_context *ctx, const char *name); +/* nk_window_collapse - updates collapse state of a window with given name + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @name of the window to be either collapse or maximize */ +NK_API void nk_window_collapse(struct nk_context*, const char *name, enum nk_collapse_states state); +/* nk_window_collapse - updates collapse state of a window with given name if given condition is met + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @name of the window to be either collapse or maximize + * @state the window should be put into + * @condition that has to be true to actually commit the collapse state change */ +NK_API void nk_window_collapse_if(struct nk_context*, const char *name, enum nk_collapse_states, int cond); +/* nk_window_show - updates visibility state of a window with given name + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @name of the window to be either collapse or maximize + * @state with either visible or hidden to modify the window with */ +NK_API void nk_window_show(struct nk_context*, const char *name, enum nk_show_states); +/* nk_window_show_if - updates visibility state of a window with given name if a given condition is met + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @name of the window to be either collapse or maximize + * @state with either visible or hidden to modify the window with + * @condition that has to be true to actually commit the visible state change */ +NK_API void nk_window_show_if(struct nk_context*, const char *name, enum nk_show_states, int cond); +/* ============================================================================= + * + * LAYOUT + * + * ============================================================================= */ +/* Layouting in general describes placing widget inside a window with position and size. + * While in this particular implementation there are five different APIs for layouting + * each with different trade offs between control and ease of use. + * + * All layouting methods in this library are based around the concept of a row. + * A row has a height the window content grows by and a number of columns and each + * layouting method specifies how each widget is placed inside the row. + * After a row has been allocated by calling a layouting functions and then + * filled with widgets will advance an internal pointer over the allocated row. + * + * To actually define a layout you just call the appropriate layouting function + * and each subsequent widget call will place the widget as specified. Important + * here is that if you define more widgets then columns defined inside the layout + * functions it will allocate the next row without you having to make another layouting + * call. + * + * Biggest limitation with using all these APIs outside the `nk_layout_space_xxx` API + * is that you have to define the row height for each. However the row height + * often depends on the height of the font. + * + * To fix that internally nuklear uses a minimum row height that is set to the + * height plus padding of currently active font and overwrites the row height + * value if zero. + * + * If you manually want to change the minimum row height then + * use nk_layout_set_min_row_height, and use nk_layout_reset_min_row_height to + * reset it back to be derived from font height. + * + * Also if you change the font in nuklear it will automatically change the minimum + * row height for you and. This means if you change the font but still want + * a minimum row height smaller than the font you have to repush your value. + * + * For actually more advanced UI I would even recommend using the `nk_layout_space_xxx` + * layouting method in combination with a cassowary constraint solver (there are + * some versions on github with permissive license model) to take over all control over widget + * layouting yourself. However for quick and dirty layouting using all the other layouting + * functions should be fine. + * + * Usage + * ------------------- + * 1.) nk_layout_row_dynamic + * The easiest layouting function is `nk_layout_row_dynamic`. It provides each + * widgets with same horizontal space inside the row and dynamically grows + * if the owning window grows in width. So the number of columns dictates + * the size of each widget dynamically by formula: + * + * widget_width = (window_width - padding - spacing) * (1/colum_count) + * + * Just like all other layouting APIs if you define more widget than columns this + * library will allocate a new row and keep all layouting parameters previously + * defined. + * + * if (nk_begin_xxx(...) { + * // first row with height: 30 composed of two widgets + * nk_layout_row_dynamic(&ctx, 30, 2); + * nk_widget(...); + * nk_widget(...); + * + * // second row with same parameter as defined above + * nk_widget(...); + * nk_widget(...); + * + * // third row uses 0 for height which will use auto layouting + * nk_layout_row_dynamic(&ctx, 0, 2); + * nk_widget(...); + * nk_widget(...); + * } + * nk_end(...); + * + * 2.) nk_layout_row_static + * Another easy layouting function is `nk_layout_row_static`. It provides each + * widget with same horizontal pixel width inside the row and does not grow + * if the owning window scales smaller or bigger. + * + * if (nk_begin_xxx(...) { + * // first row with height: 30 composed of two widgets with width: 80 + * nk_layout_row_static(&ctx, 30, 80, 2); + * nk_widget(...); + * nk_widget(...); + * + * // second row with same parameter as defined above + * nk_widget(...); + * nk_widget(...); + * + * // third row uses 0 for height which will use auto layouting + * nk_layout_row_static(&ctx, 0, 80, 2); + * nk_widget(...); + * nk_widget(...); + * } + * nk_end(...); + * + * 3.) nk_layout_row_xxx + * A little bit more advanced layouting API are functions `nk_layout_row_begin`, + * `nk_layout_row_push` and `nk_layout_row_end`. They allow to directly + * specify each column pixel or window ratio in a row. It supports either + * directly setting per column pixel width or widget window ratio but not + * both. Furthermore it is a immediate mode API so each value is directly + * pushed before calling a widget. Therefore the layout is not automatically + * repeating like the last two layouting functions. + * + * if (nk_begin_xxx(...) { + * // first row with height: 25 composed of two widgets with width 60 and 40 + * nk_layout_row_begin(ctx, NK_STATIC, 25, 2); + * nk_layout_row_push(ctx, 60); + * nk_widget(...); + * nk_layout_row_push(ctx, 40); + * nk_widget(...); + * nk_layout_row_end(ctx); + * + * // second row with height: 25 composed of two widgets with window ratio 0.25 and 0.75 + * nk_layout_row_begin(ctx, NK_DYNAMIC, 25, 2); + * nk_layout_row_push(ctx, 0.25f); + * nk_widget(...); + * nk_layout_row_push(ctx, 0.75f); + * nk_widget(...); + * nk_layout_row_end(ctx); + * + * // third row with auto generated height: composed of two widgets with window ratio 0.25 and 0.75 + * nk_layout_row_begin(ctx, NK_DYNAMIC, 0, 2); + * nk_layout_row_push(ctx, 0.25f); + * nk_widget(...); + * nk_layout_row_push(ctx, 0.75f); + * nk_widget(...); + * nk_layout_row_end(ctx); + * } + * nk_end(...); + * + * 4.) nk_layout_row + * The array counterpart to API nk_layout_row_xxx is the single nk_layout_row + * functions. Instead of pushing either pixel or window ratio for every widget + * it allows to define it by array. The trade of for less control is that + * `nk_layout_row` is automatically repeating. Otherwise the behavior is the + * same. + * + * if (nk_begin_xxx(...) { + * // two rows with height: 30 composed of two widgets with width 60 and 40 + * const float size[] = {60,40}; + * nk_layout_row(ctx, NK_STATIC, 30, 2, ratio); + * nk_widget(...); + * nk_widget(...); + * nk_widget(...); + * nk_widget(...); + * + * // two rows with height: 30 composed of two widgets with window ratio 0.25 and 0.75 + * const float ratio[] = {0.25, 0.75}; + * nk_layout_row(ctx, NK_DYNAMIC, 30, 2, ratio); + * nk_widget(...); + * nk_widget(...); + * nk_widget(...); + * nk_widget(...); + * + * // two rows with auto generated height composed of two widgets with window ratio 0.25 and 0.75 + * const float ratio[] = {0.25, 0.75}; + * nk_layout_row(ctx, NK_DYNAMIC, 30, 2, ratio); + * nk_widget(...); + * nk_widget(...); + * nk_widget(...); + * nk_widget(...); + * } + * nk_end(...); + * + * 5.) nk_layout_row_template_xxx + * The most complex and second most flexible API is a simplified flexbox version without + * line wrapping and weights for dynamic widgets. It is an immediate mode API but + * unlike `nk_layout_row_xxx` it has auto repeat behavior and needs to be called + * before calling the templated widgets. + * The row template layout has three different per widget size specifier. The first + * one is the static widget size specifier with fixed widget pixel width. They do + * not grow if the row grows and will always stay the same. The second size + * specifier is nk_layout_row_template_push_variable which defines a + * minimum widget size but it also can grow if more space is available not taken + * by other widgets. Finally there are dynamic widgets which are completely flexible + * and unlike variable widgets can even shrink to zero if not enough space + * is provided. + * + * if (nk_begin_xxx(...) { + * // two rows with height: 30 composed of three widgets + * nk_layout_row_template_begin(ctx, 30); + * nk_layout_row_template_push_dynamic(ctx); + * nk_layout_row_template_push_variable(ctx, 80); + * nk_layout_row_template_push_static(ctx, 80); + * nk_layout_row_template_end(ctx); + * + * nk_widget(...); // dynamic widget can go to zero if not enough space + * nk_widget(...); // variable widget with min 80 pixel but can grow bigger if enough space + * nk_widget(...); // static widget with fixed 80 pixel width + * + * // second row same layout + * nk_widget(...); + * nk_widget(...); + * nk_widget(...); + * } + * nk_end(...); + * + * 6.) nk_layout_space_xxx + * Finally the most flexible API directly allows you to place widgets inside the + * window. The space layout API is an immediate mode API which does not support + * row auto repeat and directly sets position and size of a widget. Position + * and size hereby can be either specified as ratio of allocated space or + * allocated space local position and pixel size. Since this API is quite + * powerful there are a number of utility functions to get the available space + * and convert between local allocated space and screen space. + * + * if (nk_begin_xxx(...) { + * // static row with height: 500 (you can set column count to INT_MAX if you don't want to be bothered) + * nk_layout_space_begin(ctx, NK_STATIC, 500, INT_MAX); + * nk_layout_space_push(ctx, nk_rect(0,0,150,200)); + * nk_widget(...); + * nk_layout_space_push(ctx, nk_rect(200,200,100,200)); + * nk_widget(...); + * nk_layout_space_end(ctx); + * + * // dynamic row with height: 500 (you can set column count to INT_MAX if you don't want to be bothered) + * nk_layout_space_begin(ctx, NK_DYNAMIC, 500, INT_MAX); + * nk_layout_space_push(ctx, nk_rect(0.5,0.5,0.1,0.1)); + * nk_widget(...); + * nk_layout_space_push(ctx, nk_rect(0.7,0.6,0.1,0.1)); + * nk_widget(...); + * } + * nk_end(...); + * + * Reference + * ------------------- + * nk_layout_set_min_row_height - set the currently used minimum row height to a specified value + * nk_layout_reset_min_row_height - resets the currently used minimum row height to font height + * + * nk_layout_widget_bounds - calculates current width a static layout row can fit inside a window + * nk_layout_ratio_from_pixel - utility functions to calculate window ratio from pixel size + * + * nk_layout_row_dynamic - current layout is divided into n same sized growing columns + * nk_layout_row_static - current layout is divided into n same fixed sized columns + * nk_layout_row_begin - starts a new row with given height and number of columns + * nk_layout_row_push - pushes another column with given size or window ratio + * nk_layout_row_end - finished previously started row + * nk_layout_row - specifies row columns in array as either window ratio or size + * + * nk_layout_row_template_begin - begins the row template declaration + * nk_layout_row_template_push_dynamic - adds a dynamic column that dynamically grows and can go to zero if not enough space + * nk_layout_row_template_push_variable - adds a variable column that dynamically grows but does not shrink below specified pixel width + * nk_layout_row_template_push_static - adds a static column that does not grow and will always have the same size + * nk_layout_row_template_end - marks the end of the row template + * + * nk_layout_space_begin - begins a new layouting space that allows to specify each widgets position and size + * nk_layout_space_push - pushes position and size of the next widget in own coordinate space either as pixel or ratio + * nk_layout_space_end - marks the end of the layouting space + * + * nk_layout_space_bounds - callable after nk_layout_space_begin and returns total space allocated + * nk_layout_space_to_screen - converts vector from nk_layout_space coordinate space into screen space + * nk_layout_space_to_local - converts vector from screen space into nk_layout_space coordinates + * nk_layout_space_rect_to_screen - converts rectangle from nk_layout_space coordinate space into screen space + * nk_layout_space_rect_to_local - converts rectangle from screen space into nk_layout_space coordinates + */ +/* nk_layout_set_min_row_height - sets the currently used minimum row height. + * IMPORTANT: The passed height needs to include both your preferred row height + * as well as padding. No internal padding is added. + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_begin_xxx` + * @height new minimum row height to be used for auto generating the row height */ +NK_API void nk_layout_set_min_row_height(struct nk_context*, float height); +/* nk_layout_reset_min_row_height - Reset the currently used minimum row height + * back to font height + text padding + additional padding (style_window.min_row_height_padding) + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_begin_xxx` */ +NK_API void nk_layout_reset_min_row_height(struct nk_context*); +/* nk_layout_widget_bounds - returns the width of the next row allocate by one of the layouting functions + * Parameters: + * @ctx must point to an previously initialized `nk_context` */ +NK_API struct nk_rect nk_layout_widget_bounds(struct nk_context*); +/* nk_layout_ratio_from_pixel - utility functions to calculate window ratio from pixel size + * Parameters: + * @ctx must point to an previously initialized `nk_context` + * @pixel_width to convert to window ratio */ +NK_API float nk_layout_ratio_from_pixel(struct nk_context*, float pixel_width); +/* nk_layout_row_dynamic - Sets current row layout to share horizontal space + * between @cols number of widgets evenly. Once called all subsequent widget + * calls greater than @cols will allocate a new row with same layout. + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_begin_xxx` + * @row_height holds height of each widget in row or zero for auto layouting + * @cols number of widget inside row */ +NK_API void nk_layout_row_dynamic(struct nk_context *ctx, float height, int cols); +/* nk_layout_row_static - Sets current row layout to fill @cols number of widgets + * in row with same @item_width horizontal size. Once called all subsequent widget + * calls greater than @cols will allocate a new row with same layout. + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_begin_xxx` + * @height holds row height to allocate from panel for widget height + * @item_width holds width of each widget in row + * @cols number of widget inside row */ +NK_API void nk_layout_row_static(struct nk_context *ctx, float height, int item_width, int cols); +/* nk_layout_row_begin - Starts a new dynamic or fixed row with given height and columns. + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_begin_xxx` + * @fmt either `NK_DYNAMIC` for window ratio or `NK_STATIC` for fixed size columns + * @row_height holds height of each widget in row or zero for auto layouting + * @cols number of widget inside row */ +NK_API void nk_layout_row_begin(struct nk_context *ctx, enum nk_layout_format fmt, float row_height, int cols); +/* nk_layout_row_push - Specifies either window ratio or width of a single column + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_layout_row_begin` + * @value either a window ratio or fixed width depending on @fmt in previous `nk_layout_row_begin` call */ +NK_API void nk_layout_row_push(struct nk_context*, float value); +/* nk_layout_row_end - finished previously started row + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_layout_row_begin` */ +NK_API void nk_layout_row_end(struct nk_context*); +/* nk_layout_row - specifies row columns in array as either window ratio or size + * Parameters: + * @ctx must point to an previously initialized `nk_context` + * @fmt either `NK_DYNAMIC` for window ratio or `NK_STATIC` for fixed size columns + * @row_height holds height of each widget in row or zero for auto layouting + * @cols number of widget inside row */ +NK_API void nk_layout_row(struct nk_context*, enum nk_layout_format, float height, int cols, const float *ratio); +/* nk_layout_row_template_begin - Begins the row template declaration + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @row_height holds height of each widget in row or zero for auto layouting */ +NK_API void nk_layout_row_template_begin(struct nk_context*, float row_height); +/* nk_layout_row_template_push_dynamic - adds a dynamic column that dynamically grows and can go to zero if not enough space + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_layout_row_template_begin` */ +NK_API void nk_layout_row_template_push_dynamic(struct nk_context*); +/* nk_layout_row_template_push_variable - adds a variable column that dynamically grows but does not shrink below specified pixel width + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_layout_row_template_begin` + * @min_width holds the minimum pixel width the next column must be */ +NK_API void nk_layout_row_template_push_variable(struct nk_context*, float min_width); +/* nk_layout_row_template_push_static - adds a static column that does not grow and will always have the same size + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_layout_row_template_begin` + * @width holds the absolute pixel width value the next column must be */ +NK_API void nk_layout_row_template_push_static(struct nk_context*, float width); +/* nk_layout_row_template_end - marks the end of the row template + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_layout_row_template_begin` */ +NK_API void nk_layout_row_template_end(struct nk_context*); +/* nk_layout_space_begin - begins a new layouting space that allows to specify each widgets position and size. + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct + * @fmt either `NK_DYNAMIC` for window ratio or `NK_STATIC` for fixed size columns + * @row_height holds height of each widget in row or zero for auto layouting + * @widget_count number of widgets inside row */ +NK_API void nk_layout_space_begin(struct nk_context*, enum nk_layout_format, float height, int widget_count); +/* nk_layout_space_push - pushes position and size of the next widget in own coordinate space either as pixel or ratio + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_layout_space_begin` + * @bounds position and size in laoyut space local coordinates */ +NK_API void nk_layout_space_push(struct nk_context*, struct nk_rect); +/* nk_layout_space_end - marks the end of the layout space + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_layout_space_begin` */ +NK_API void nk_layout_space_end(struct nk_context*); +/* nk_layout_space_bounds - returns total space allocated for `nk_layout_space` + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_layout_space_begin` */ +NK_API struct nk_rect nk_layout_space_bounds(struct nk_context*); +/* nk_layout_space_to_screen - converts vector from nk_layout_space coordinate space into screen space + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_layout_space_begin` + * @vec position to convert from layout space into screen coordinate space */ +NK_API struct nk_vec2 nk_layout_space_to_screen(struct nk_context*, struct nk_vec2); +/* nk_layout_space_to_screen - converts vector from layout space into screen space + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_layout_space_begin` + * @vec position to convert from screen space into layout coordinate space */ +NK_API struct nk_vec2 nk_layout_space_to_local(struct nk_context*, struct nk_vec2); +/* nk_layout_space_rect_to_screen - converts rectangle from screen space into layout space + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_layout_space_begin` + * @bounds rectangle to convert from layout space into screen space */ +NK_API struct nk_rect nk_layout_space_rect_to_screen(struct nk_context*, struct nk_rect); +/* nk_layout_space_rect_to_local - converts rectangle from layout space into screen space + * Parameters: + * @ctx must point to an previously initialized `nk_context` struct after call `nk_layout_space_begin` + * @bounds rectangle to convert from screen space into layout space */ +NK_API struct nk_rect nk_layout_space_rect_to_local(struct nk_context*, struct nk_rect); +/* ============================================================================= + * + * GROUP + * + * ============================================================================= */ +NK_API int nk_group_begin(struct nk_context*, const char *title, nk_flags); +NK_API int nk_group_scrolled_offset_begin(struct nk_context*, nk_uint *x_offset, nk_uint *y_offset, const char*, nk_flags); +NK_API int nk_group_scrolled_begin(struct nk_context*, struct nk_scroll*, const char *title, nk_flags); +NK_API void nk_group_scrolled_end(struct nk_context*); +NK_API void nk_group_end(struct nk_context*); +/* ============================================================================= + * + * LIST VIEW + * + * ============================================================================= */ +struct nk_list_view { +/* public: */ + int begin, end, count; +/* private: */ + int total_height; + struct nk_context *ctx; + nk_uint *scroll_pointer; + nk_uint scroll_value; +}; +NK_API int nk_list_view_begin(struct nk_context*, struct nk_list_view *out, const char *id, nk_flags, int row_height, int row_count); +NK_API void nk_list_view_end(struct nk_list_view*); +/* ============================================================================= + * + * TREE + * + * ============================================================================= */ +#define nk_tree_push(ctx, type, title, state) nk_tree_push_hashed(ctx, type, title, state, NK_FILE_LINE,nk_strlen(NK_FILE_LINE),__LINE__) +#define nk_tree_push_id(ctx, type, title, state, id) nk_tree_push_hashed(ctx, type, title, state, NK_FILE_LINE,nk_strlen(NK_FILE_LINE),id) +NK_API int nk_tree_push_hashed(struct nk_context*, enum nk_tree_type, const char *title, enum nk_collapse_states initial_state, const char *hash, int len,int seed); +#define nk_tree_image_push(ctx, type, img, title, state) nk_tree_image_push_hashed(ctx, type, img, title, state, NK_FILE_LINE,nk_strlen(NK_FILE_LINE),__LINE__) +#define nk_tree_image_push_id(ctx, type, img, title, state, id) nk_tree_image_push_hashed(ctx, type, img, title, state, NK_FILE_LINE,nk_strlen(NK_FILE_LINE),id) +NK_API int nk_tree_image_push_hashed(struct nk_context*, enum nk_tree_type, struct nk_image, const char *title, enum nk_collapse_states initial_state, const char *hash, int len,int seed); +NK_API void nk_tree_pop(struct nk_context*); +NK_API int nk_tree_state_push(struct nk_context*, enum nk_tree_type, const char *title, enum nk_collapse_states *state); +NK_API int nk_tree_state_image_push(struct nk_context*, enum nk_tree_type, struct nk_image, const char *title, enum nk_collapse_states *state); +NK_API void nk_tree_state_pop(struct nk_context*); +/* ============================================================================= + * + * WIDGET + * + * ============================================================================= */ +enum nk_widget_layout_states { + NK_WIDGET_INVALID, /* The widget cannot be seen and is completely out of view */ + NK_WIDGET_VALID, /* The widget is completely inside the window and can be updated and drawn */ + NK_WIDGET_ROM /* The widget is partially visible and cannot be updated */ +}; +enum nk_widget_states { + NK_WIDGET_STATE_MODIFIED = NK_FLAG(1), + NK_WIDGET_STATE_INACTIVE = NK_FLAG(2), /* widget is neither active nor hovered */ + NK_WIDGET_STATE_ENTERED = NK_FLAG(3), /* widget has been hovered on the current frame */ + NK_WIDGET_STATE_HOVER = NK_FLAG(4), /* widget is being hovered */ + NK_WIDGET_STATE_ACTIVED = NK_FLAG(5),/* widget is currently activated */ + NK_WIDGET_STATE_LEFT = NK_FLAG(6), /* widget is from this frame on not hovered anymore */ + NK_WIDGET_STATE_HOVERED = NK_WIDGET_STATE_HOVER|NK_WIDGET_STATE_MODIFIED, /* widget is being hovered */ + NK_WIDGET_STATE_ACTIVE = NK_WIDGET_STATE_ACTIVED|NK_WIDGET_STATE_MODIFIED /* widget is currently activated */ +}; +NK_API enum nk_widget_layout_states nk_widget(struct nk_rect*, const struct nk_context*); +NK_API enum nk_widget_layout_states nk_widget_fitting(struct nk_rect*, struct nk_context*, struct nk_vec2); +NK_API struct nk_rect nk_widget_bounds(struct nk_context*); +NK_API struct nk_vec2 nk_widget_position(struct nk_context*); +NK_API struct nk_vec2 nk_widget_size(struct nk_context*); +NK_API float nk_widget_width(struct nk_context*); +NK_API float nk_widget_height(struct nk_context*); +NK_API int nk_widget_is_hovered(struct nk_context*); +NK_API int nk_widget_is_mouse_clicked(struct nk_context*, enum nk_buttons); +NK_API int nk_widget_has_mouse_click_down(struct nk_context*, enum nk_buttons, int down); +NK_API void nk_spacing(struct nk_context*, int cols); +/* ============================================================================= + * + * TEXT + * + * ============================================================================= */ +enum nk_text_align { + NK_TEXT_ALIGN_LEFT = 0x01, + NK_TEXT_ALIGN_CENTERED = 0x02, + NK_TEXT_ALIGN_RIGHT = 0x04, + NK_TEXT_ALIGN_TOP = 0x08, + NK_TEXT_ALIGN_MIDDLE = 0x10, + NK_TEXT_ALIGN_BOTTOM = 0x20 +}; +enum nk_text_alignment { + NK_TEXT_LEFT = NK_TEXT_ALIGN_MIDDLE|NK_TEXT_ALIGN_LEFT, + NK_TEXT_CENTERED = NK_TEXT_ALIGN_MIDDLE|NK_TEXT_ALIGN_CENTERED, + NK_TEXT_RIGHT = NK_TEXT_ALIGN_MIDDLE|NK_TEXT_ALIGN_RIGHT +}; +NK_API void nk_text(struct nk_context*, const char*, int, nk_flags); +NK_API void nk_text_colored(struct nk_context*, const char*, int, nk_flags, struct nk_color); +NK_API void nk_text_wrap(struct nk_context*, const char*, int); +NK_API void nk_text_wrap_colored(struct nk_context*, const char*, int, struct nk_color); +NK_API void nk_label(struct nk_context*, const char*, nk_flags align); +NK_API void nk_label_colored(struct nk_context*, const char*, nk_flags align, struct nk_color); +NK_API void nk_label_wrap(struct nk_context*, const char*); +NK_API void nk_label_colored_wrap(struct nk_context*, const char*, struct nk_color); +NK_API void nk_image(struct nk_context*, struct nk_image); +#ifdef NK_INCLUDE_STANDARD_VARARGS +NK_API void nk_labelf(struct nk_context*, nk_flags, const char*, ...); +NK_API void nk_labelf_colored(struct nk_context*, nk_flags align, struct nk_color, const char*,...); +NK_API void nk_labelf_wrap(struct nk_context*, const char*,...); +NK_API void nk_labelf_colored_wrap(struct nk_context*, struct nk_color, const char*,...); +NK_API void nk_value_bool(struct nk_context*, const char *prefix, int); +NK_API void nk_value_int(struct nk_context*, const char *prefix, int); +NK_API void nk_value_uint(struct nk_context*, const char *prefix, unsigned int); +NK_API void nk_value_float(struct nk_context*, const char *prefix, float); +NK_API void nk_value_color_byte(struct nk_context*, const char *prefix, struct nk_color); +NK_API void nk_value_color_float(struct nk_context*, const char *prefix, struct nk_color); +NK_API void nk_value_color_hex(struct nk_context*, const char *prefix, struct nk_color); +#endif +/* ============================================================================= + * + * BUTTON + * + * ============================================================================= */ +NK_API int nk_button_text(struct nk_context*, const char *title, int len); +NK_API int nk_button_label(struct nk_context*, const char *title); +NK_API int nk_button_color(struct nk_context*, struct nk_color); +NK_API int nk_button_symbol(struct nk_context*, enum nk_symbol_type); +NK_API int nk_button_image(struct nk_context*, struct nk_image img); +NK_API int nk_button_symbol_label(struct nk_context*, enum nk_symbol_type, const char*, nk_flags text_alignment); +NK_API int nk_button_symbol_text(struct nk_context*, enum nk_symbol_type, const char*, int, nk_flags alignment); +NK_API int nk_button_image_label(struct nk_context*, struct nk_image img, const char*, nk_flags text_alignment); +NK_API int nk_button_image_text(struct nk_context*, struct nk_image img, const char*, int, nk_flags alignment); +NK_API int nk_button_text_styled(struct nk_context*, const struct nk_style_button*, const char *title, int len); +NK_API int nk_button_label_styled(struct nk_context*, const struct nk_style_button*, const char *title); +NK_API int nk_button_symbol_styled(struct nk_context*, const struct nk_style_button*, enum nk_symbol_type); +NK_API int nk_button_image_styled(struct nk_context*, const struct nk_style_button*, struct nk_image img); +NK_API int nk_button_symbol_text_styled(struct nk_context*,const struct nk_style_button*, enum nk_symbol_type, const char*, int, nk_flags alignment); +NK_API int nk_button_symbol_label_styled(struct nk_context *ctx, const struct nk_style_button *style, enum nk_symbol_type symbol, const char *title, nk_flags align); +NK_API int nk_button_image_label_styled(struct nk_context*,const struct nk_style_button*, struct nk_image img, const char*, nk_flags text_alignment); +NK_API int nk_button_image_text_styled(struct nk_context*,const struct nk_style_button*, struct nk_image img, const char*, int, nk_flags alignment); +NK_API void nk_button_set_behavior(struct nk_context*, enum nk_button_behavior); +NK_API int nk_button_push_behavior(struct nk_context*, enum nk_button_behavior); +NK_API int nk_button_pop_behavior(struct nk_context*); +/* ============================================================================= + * + * CHECKBOX + * + * ============================================================================= */ +NK_API int nk_check_label(struct nk_context*, const char*, int active); +NK_API int nk_check_text(struct nk_context*, const char*, int,int active); +NK_API unsigned nk_check_flags_label(struct nk_context*, const char*, unsigned int flags, unsigned int value); +NK_API unsigned nk_check_flags_text(struct nk_context*, const char*, int, unsigned int flags, unsigned int value); +NK_API int nk_checkbox_label(struct nk_context*, const char*, int *active); +NK_API int nk_checkbox_text(struct nk_context*, const char*, int, int *active); +NK_API int nk_checkbox_flags_label(struct nk_context*, const char*, unsigned int *flags, unsigned int value); +NK_API int nk_checkbox_flags_text(struct nk_context*, const char*, int, unsigned int *flags, unsigned int value); +/* ============================================================================= + * + * RADIO BUTTON + * + * ============================================================================= */ +NK_API int nk_radio_label(struct nk_context*, const char*, int *active); +NK_API int nk_radio_text(struct nk_context*, const char*, int, int *active); +NK_API int nk_option_label(struct nk_context*, const char*, int active); +NK_API int nk_option_text(struct nk_context*, const char*, int, int active); +/* ============================================================================= + * + * SELECTABLE + * + * ============================================================================= */ +NK_API int nk_selectable_label(struct nk_context*, const char*, nk_flags align, int *value); +NK_API int nk_selectable_text(struct nk_context*, const char*, int, nk_flags align, int *value); +NK_API int nk_selectable_image_label(struct nk_context*,struct nk_image, const char*, nk_flags align, int *value); +NK_API int nk_selectable_image_text(struct nk_context*,struct nk_image, const char*, int, nk_flags align, int *value); +NK_API int nk_select_label(struct nk_context*, const char*, nk_flags align, int value); +NK_API int nk_select_text(struct nk_context*, const char*, int, nk_flags align, int value); +NK_API int nk_select_image_label(struct nk_context*, struct nk_image,const char*, nk_flags align, int value); +NK_API int nk_select_image_text(struct nk_context*, struct nk_image,const char*, int, nk_flags align, int value); +/* ============================================================================= + * + * SLIDER + * + * ============================================================================= */ +NK_API float nk_slide_float(struct nk_context*, float min, float val, float max, float step); +NK_API int nk_slide_int(struct nk_context*, int min, int val, int max, int step); +NK_API int nk_slider_float(struct nk_context*, float min, float *val, float max, float step); +NK_API int nk_slider_int(struct nk_context*, int min, int *val, int max, int step); +/* ============================================================================= + * + * PROGRESSBAR + * + * ============================================================================= */ +NK_API int nk_progress(struct nk_context*, nk_size *cur, nk_size max, int modifyable); +NK_API nk_size nk_prog(struct nk_context*, nk_size cur, nk_size max, int modifyable); + +/* ============================================================================= + * + * COLOR PICKER + * + * ============================================================================= */ +NK_API struct nk_color nk_color_picker(struct nk_context*, struct nk_color, enum nk_color_format); +NK_API int nk_color_pick(struct nk_context*, struct nk_color*, enum nk_color_format); +/* ============================================================================= + * + * PROPERTIES + * + * ============================================================================= */ +NK_API void nk_property_int(struct nk_context*, const char *name, int min, int *val, int max, int step, float inc_per_pixel); +NK_API void nk_property_float(struct nk_context*, const char *name, float min, float *val, float max, float step, float inc_per_pixel); +NK_API void nk_property_double(struct nk_context*, const char *name, double min, double *val, double max, double step, float inc_per_pixel); +NK_API int nk_propertyi(struct nk_context*, const char *name, int min, int val, int max, int step, float inc_per_pixel); +NK_API float nk_propertyf(struct nk_context*, const char *name, float min, float val, float max, float step, float inc_per_pixel); +NK_API double nk_propertyd(struct nk_context*, const char *name, double min, double val, double max, double step, float inc_per_pixel); +/* ============================================================================= + * + * TEXT EDIT + * + * ============================================================================= */ +enum nk_edit_flags { + NK_EDIT_DEFAULT = 0, + NK_EDIT_READ_ONLY = NK_FLAG(0), + NK_EDIT_AUTO_SELECT = NK_FLAG(1), + NK_EDIT_SIG_ENTER = NK_FLAG(2), + NK_EDIT_ALLOW_TAB = NK_FLAG(3), + NK_EDIT_NO_CURSOR = NK_FLAG(4), + NK_EDIT_SELECTABLE = NK_FLAG(5), + NK_EDIT_CLIPBOARD = NK_FLAG(6), + NK_EDIT_CTRL_ENTER_NEWLINE = NK_FLAG(7), + NK_EDIT_NO_HORIZONTAL_SCROLL = NK_FLAG(8), + NK_EDIT_ALWAYS_INSERT_MODE = NK_FLAG(9), + NK_EDIT_MULTILINE = NK_FLAG(10), + NK_EDIT_GOTO_END_ON_ACTIVATE = NK_FLAG(11) +}; +enum nk_edit_types { + NK_EDIT_SIMPLE = NK_EDIT_ALWAYS_INSERT_MODE, + NK_EDIT_FIELD = NK_EDIT_SIMPLE|NK_EDIT_SELECTABLE|NK_EDIT_CLIPBOARD, + NK_EDIT_BOX = NK_EDIT_ALWAYS_INSERT_MODE| NK_EDIT_SELECTABLE| NK_EDIT_MULTILINE|NK_EDIT_ALLOW_TAB|NK_EDIT_CLIPBOARD, + NK_EDIT_EDITOR = NK_EDIT_SELECTABLE|NK_EDIT_MULTILINE|NK_EDIT_ALLOW_TAB| NK_EDIT_CLIPBOARD +}; +enum nk_edit_events { + NK_EDIT_ACTIVE = NK_FLAG(0), /* edit widget is currently being modified */ + NK_EDIT_INACTIVE = NK_FLAG(1), /* edit widget is not active and is not being modified */ + NK_EDIT_ACTIVATED = NK_FLAG(2), /* edit widget went from state inactive to state active */ + NK_EDIT_DEACTIVATED = NK_FLAG(3), /* edit widget went from state active to state inactive */ + NK_EDIT_COMMITED = NK_FLAG(4) /* edit widget has received an enter and lost focus */ +}; +NK_API nk_flags nk_edit_string(struct nk_context*, nk_flags, char *buffer, int *len, int max, nk_plugin_filter); +NK_API nk_flags nk_edit_string_zero_terminated(struct nk_context*, nk_flags, char *buffer, int max, nk_plugin_filter); +NK_API nk_flags nk_edit_buffer(struct nk_context*, nk_flags, struct nk_text_edit*, nk_plugin_filter); +NK_API void nk_edit_focus(struct nk_context*, nk_flags flags); +NK_API void nk_edit_unfocus(struct nk_context*); +/* ============================================================================= + * + * CHART + * + * ============================================================================= */ +NK_API int nk_chart_begin(struct nk_context*, enum nk_chart_type, int num, float min, float max); +NK_API int nk_chart_begin_colored(struct nk_context*, enum nk_chart_type, struct nk_color, struct nk_color active, int num, float min, float max); +NK_API void nk_chart_add_slot(struct nk_context *ctx, const enum nk_chart_type, int count, float min_value, float max_value); +NK_API void nk_chart_add_slot_colored(struct nk_context *ctx, const enum nk_chart_type, struct nk_color, struct nk_color active, int count, float min_value, float max_value); +NK_API nk_flags nk_chart_push(struct nk_context*, float); +NK_API nk_flags nk_chart_push_slot(struct nk_context*, float, int); +NK_API void nk_chart_end(struct nk_context*); +NK_API void nk_plot(struct nk_context*, enum nk_chart_type, const float *values, int count, int offset); +NK_API void nk_plot_function(struct nk_context*, enum nk_chart_type, void *userdata, float(*value_getter)(void* user, int index), int count, int offset); +/* ============================================================================= + * + * POPUP + * + * ============================================================================= */ +NK_API int nk_popup_begin(struct nk_context*, enum nk_popup_type, const char*, nk_flags, struct nk_rect bounds); +NK_API void nk_popup_close(struct nk_context*); +NK_API void nk_popup_end(struct nk_context*); +/* ============================================================================= + * + * COMBOBOX + * + * ============================================================================= */ +NK_API int nk_combo(struct nk_context*, const char **items, int count, int selected, int item_height, struct nk_vec2 size); +NK_API int nk_combo_separator(struct nk_context*, const char *items_separated_by_separator, int separator, int selected, int count, int item_height, struct nk_vec2 size); +NK_API int nk_combo_string(struct nk_context*, const char *items_separated_by_zeros, int selected, int count, int item_height, struct nk_vec2 size); +NK_API int nk_combo_callback(struct nk_context*, void(*item_getter)(void*, int, const char**), void *userdata, int selected, int count, int item_height, struct nk_vec2 size); +NK_API void nk_combobox(struct nk_context*, const char **items, int count, int *selected, int item_height, struct nk_vec2 size); +NK_API void nk_combobox_string(struct nk_context*, const char *items_separated_by_zeros, int *selected, int count, int item_height, struct nk_vec2 size); +NK_API void nk_combobox_separator(struct nk_context*, const char *items_separated_by_separator, int separator,int *selected, int count, int item_height, struct nk_vec2 size); +NK_API void nk_combobox_callback(struct nk_context*, void(*item_getter)(void*, int, const char**), void*, int *selected, int count, int item_height, struct nk_vec2 size); +/* ============================================================================= + * + * ABSTRACT COMBOBOX + * + * ============================================================================= */ +NK_API int nk_combo_begin_text(struct nk_context*, const char *selected, int, struct nk_vec2 size); +NK_API int nk_combo_begin_label(struct nk_context*, const char *selected, struct nk_vec2 size); +NK_API int nk_combo_begin_color(struct nk_context*, struct nk_color color, struct nk_vec2 size); +NK_API int nk_combo_begin_symbol(struct nk_context*, enum nk_symbol_type, struct nk_vec2 size); +NK_API int nk_combo_begin_symbol_label(struct nk_context*, const char *selected, enum nk_symbol_type, struct nk_vec2 size); +NK_API int nk_combo_begin_symbol_text(struct nk_context*, const char *selected, int, enum nk_symbol_type, struct nk_vec2 size); +NK_API int nk_combo_begin_image(struct nk_context*, struct nk_image img, struct nk_vec2 size); +NK_API int nk_combo_begin_image_label(struct nk_context*, const char *selected, struct nk_image, struct nk_vec2 size); +NK_API int nk_combo_begin_image_text(struct nk_context*, const char *selected, int, struct nk_image, struct nk_vec2 size); +NK_API int nk_combo_item_label(struct nk_context*, const char*, nk_flags alignment); +NK_API int nk_combo_item_text(struct nk_context*, const char*,int, nk_flags alignment); +NK_API int nk_combo_item_image_label(struct nk_context*, struct nk_image, const char*, nk_flags alignment); +NK_API int nk_combo_item_image_text(struct nk_context*, struct nk_image, const char*, int,nk_flags alignment); +NK_API int nk_combo_item_symbol_label(struct nk_context*, enum nk_symbol_type, const char*, nk_flags alignment); +NK_API int nk_combo_item_symbol_text(struct nk_context*, enum nk_symbol_type, const char*, int, nk_flags alignment); +NK_API void nk_combo_close(struct nk_context*); +NK_API void nk_combo_end(struct nk_context*); +/* ============================================================================= + * + * CONTEXTUAL + * + * ============================================================================= */ +NK_API int nk_contextual_begin(struct nk_context*, nk_flags, struct nk_vec2, struct nk_rect trigger_bounds); +NK_API int nk_contextual_item_text(struct nk_context*, const char*, int,nk_flags align); +NK_API int nk_contextual_item_label(struct nk_context*, const char*, nk_flags align); +NK_API int nk_contextual_item_image_label(struct nk_context*, struct nk_image, const char*, nk_flags alignment); +NK_API int nk_contextual_item_image_text(struct nk_context*, struct nk_image, const char*, int len, nk_flags alignment); +NK_API int nk_contextual_item_symbol_label(struct nk_context*, enum nk_symbol_type, const char*, nk_flags alignment); +NK_API int nk_contextual_item_symbol_text(struct nk_context*, enum nk_symbol_type, const char*, int, nk_flags alignment); +NK_API void nk_contextual_close(struct nk_context*); +NK_API void nk_contextual_end(struct nk_context*); +/* ============================================================================= + * + * TOOLTIP + * + * ============================================================================= */ +NK_API void nk_tooltip(struct nk_context*, const char*); +#ifdef NK_INCLUDE_STANDARD_VARARGS +NK_API void nk_tooltipf(struct nk_context*, const char*, ...); +#endif +NK_API int nk_tooltip_begin(struct nk_context*, float width); +NK_API void nk_tooltip_end(struct nk_context*); +/* ============================================================================= + * + * MENU + * + * ============================================================================= */ +NK_API void nk_menubar_begin(struct nk_context*); +NK_API void nk_menubar_end(struct nk_context*); +NK_API int nk_menu_begin_text(struct nk_context*, const char* title, int title_len, nk_flags align, struct nk_vec2 size); +NK_API int nk_menu_begin_label(struct nk_context*, const char*, nk_flags align, struct nk_vec2 size); +NK_API int nk_menu_begin_image(struct nk_context*, const char*, struct nk_image, struct nk_vec2 size); +NK_API int nk_menu_begin_image_text(struct nk_context*, const char*, int,nk_flags align,struct nk_image, struct nk_vec2 size); +NK_API int nk_menu_begin_image_label(struct nk_context*, const char*, nk_flags align,struct nk_image, struct nk_vec2 size); +NK_API int nk_menu_begin_symbol(struct nk_context*, const char*, enum nk_symbol_type, struct nk_vec2 size); +NK_API int nk_menu_begin_symbol_text(struct nk_context*, const char*, int,nk_flags align,enum nk_symbol_type, struct nk_vec2 size); +NK_API int nk_menu_begin_symbol_label(struct nk_context*, const char*, nk_flags align,enum nk_symbol_type, struct nk_vec2 size); +NK_API int nk_menu_item_text(struct nk_context*, const char*, int,nk_flags align); +NK_API int nk_menu_item_label(struct nk_context*, const char*, nk_flags alignment); +NK_API int nk_menu_item_image_label(struct nk_context*, struct nk_image, const char*, nk_flags alignment); +NK_API int nk_menu_item_image_text(struct nk_context*, struct nk_image, const char*, int len, nk_flags alignment); +NK_API int nk_menu_item_symbol_text(struct nk_context*, enum nk_symbol_type, const char*, int, nk_flags alignment); +NK_API int nk_menu_item_symbol_label(struct nk_context*, enum nk_symbol_type, const char*, nk_flags alignment); +NK_API void nk_menu_close(struct nk_context*); +NK_API void nk_menu_end(struct nk_context*); +/* ============================================================================= + * + * STYLE + * + * ============================================================================= */ +enum nk_style_colors { + NK_COLOR_TEXT, + NK_COLOR_WINDOW, + NK_COLOR_HEADER, + NK_COLOR_BORDER, + NK_COLOR_BUTTON, + NK_COLOR_BUTTON_HOVER, + NK_COLOR_BUTTON_ACTIVE, + NK_COLOR_TOGGLE, + NK_COLOR_TOGGLE_HOVER, + NK_COLOR_TOGGLE_CURSOR, + NK_COLOR_SELECT, + NK_COLOR_SELECT_ACTIVE, + NK_COLOR_SLIDER, + NK_COLOR_SLIDER_CURSOR, + NK_COLOR_SLIDER_CURSOR_HOVER, + NK_COLOR_SLIDER_CURSOR_ACTIVE, + NK_COLOR_PROPERTY, + NK_COLOR_EDIT, + NK_COLOR_EDIT_CURSOR, + NK_COLOR_COMBO, + NK_COLOR_CHART, + NK_COLOR_CHART_COLOR, + NK_COLOR_CHART_COLOR_HIGHLIGHT, + NK_COLOR_SCROLLBAR, + NK_COLOR_SCROLLBAR_CURSOR, + NK_COLOR_SCROLLBAR_CURSOR_HOVER, + NK_COLOR_SCROLLBAR_CURSOR_ACTIVE, + NK_COLOR_TAB_HEADER, + NK_COLOR_COUNT +}; +enum nk_style_cursor { + NK_CURSOR_ARROW, + NK_CURSOR_TEXT, + NK_CURSOR_MOVE, + NK_CURSOR_RESIZE_VERTICAL, + NK_CURSOR_RESIZE_HORIZONTAL, + NK_CURSOR_RESIZE_TOP_LEFT_DOWN_RIGHT, + NK_CURSOR_RESIZE_TOP_RIGHT_DOWN_LEFT, + NK_CURSOR_COUNT +}; +NK_API void nk_style_default(struct nk_context*); +NK_API void nk_style_from_table(struct nk_context*, const struct nk_color*); +NK_API void nk_style_load_cursor(struct nk_context*, enum nk_style_cursor, const struct nk_cursor*); +NK_API void nk_style_load_all_cursors(struct nk_context*, struct nk_cursor*); +NK_API const char* nk_style_get_color_by_name(enum nk_style_colors); +NK_API void nk_style_set_font(struct nk_context*, const struct nk_user_font*); +NK_API int nk_style_set_cursor(struct nk_context*, enum nk_style_cursor); +NK_API void nk_style_show_cursor(struct nk_context*); +NK_API void nk_style_hide_cursor(struct nk_context*); + +NK_API int nk_style_push_font(struct nk_context*, const struct nk_user_font*); +NK_API int nk_style_push_float(struct nk_context*, float*, float); +NK_API int nk_style_push_vec2(struct nk_context*, struct nk_vec2*, struct nk_vec2); +NK_API int nk_style_push_style_item(struct nk_context*, struct nk_style_item*, struct nk_style_item); +NK_API int nk_style_push_flags(struct nk_context*, nk_flags*, nk_flags); +NK_API int nk_style_push_color(struct nk_context*, struct nk_color*, struct nk_color); + +NK_API int nk_style_pop_font(struct nk_context*); +NK_API int nk_style_pop_float(struct nk_context*); +NK_API int nk_style_pop_vec2(struct nk_context*); +NK_API int nk_style_pop_style_item(struct nk_context*); +NK_API int nk_style_pop_flags(struct nk_context*); +NK_API int nk_style_pop_color(struct nk_context*); +/* ============================================================================= + * + * COLOR + * + * ============================================================================= */ +NK_API struct nk_color nk_rgb(int r, int g, int b); +NK_API struct nk_color nk_rgb_iv(const int *rgb); +NK_API struct nk_color nk_rgb_bv(const nk_byte* rgb); +NK_API struct nk_color nk_rgb_f(float r, float g, float b); +NK_API struct nk_color nk_rgb_fv(const float *rgb); +NK_API struct nk_color nk_rgb_hex(const char *rgb); + +NK_API struct nk_color nk_rgba(int r, int g, int b, int a); +NK_API struct nk_color nk_rgba_u32(nk_uint); +NK_API struct nk_color nk_rgba_iv(const int *rgba); +NK_API struct nk_color nk_rgba_bv(const nk_byte *rgba); +NK_API struct nk_color nk_rgba_f(float r, float g, float b, float a); +NK_API struct nk_color nk_rgba_fv(const float *rgba); +NK_API struct nk_color nk_rgba_hex(const char *rgb); + +NK_API struct nk_color nk_hsv(int h, int s, int v); +NK_API struct nk_color nk_hsv_iv(const int *hsv); +NK_API struct nk_color nk_hsv_bv(const nk_byte *hsv); +NK_API struct nk_color nk_hsv_f(float h, float s, float v); +NK_API struct nk_color nk_hsv_fv(const float *hsv); + +NK_API struct nk_color nk_hsva(int h, int s, int v, int a); +NK_API struct nk_color nk_hsva_iv(const int *hsva); +NK_API struct nk_color nk_hsva_bv(const nk_byte *hsva); +NK_API struct nk_color nk_hsva_f(float h, float s, float v, float a); +NK_API struct nk_color nk_hsva_fv(const float *hsva); + +/* color (conversion nuklear --> user) */ +NK_API void nk_color_f(float *r, float *g, float *b, float *a, struct nk_color); +NK_API void nk_color_fv(float *rgba_out, struct nk_color); +NK_API void nk_color_d(double *r, double *g, double *b, double *a, struct nk_color); +NK_API void nk_color_dv(double *rgba_out, struct nk_color); + +NK_API nk_uint nk_color_u32(struct nk_color); +NK_API void nk_color_hex_rgba(char *output, struct nk_color); +NK_API void nk_color_hex_rgb(char *output, struct nk_color); + +NK_API void nk_color_hsv_i(int *out_h, int *out_s, int *out_v, struct nk_color); +NK_API void nk_color_hsv_b(nk_byte *out_h, nk_byte *out_s, nk_byte *out_v, struct nk_color); +NK_API void nk_color_hsv_iv(int *hsv_out, struct nk_color); +NK_API void nk_color_hsv_bv(nk_byte *hsv_out, struct nk_color); +NK_API void nk_color_hsv_f(float *out_h, float *out_s, float *out_v, struct nk_color); +NK_API void nk_color_hsv_fv(float *hsv_out, struct nk_color); + +NK_API void nk_color_hsva_i(int *h, int *s, int *v, int *a, struct nk_color); +NK_API void nk_color_hsva_b(nk_byte *h, nk_byte *s, nk_byte *v, nk_byte *a, struct nk_color); +NK_API void nk_color_hsva_iv(int *hsva_out, struct nk_color); +NK_API void nk_color_hsva_bv(nk_byte *hsva_out, struct nk_color); +NK_API void nk_color_hsva_f(float *out_h, float *out_s, float *out_v, float *out_a, struct nk_color); +NK_API void nk_color_hsva_fv(float *hsva_out, struct nk_color); +/* ============================================================================= + * + * IMAGE + * + * ============================================================================= */ +NK_API nk_handle nk_handle_ptr(void*); +NK_API nk_handle nk_handle_id(int); +NK_API struct nk_image nk_image_handle(nk_handle); +NK_API struct nk_image nk_image_ptr(void*); +NK_API struct nk_image nk_image_id(int); +NK_API int nk_image_is_subimage(const struct nk_image* img); +NK_API struct nk_image nk_subimage_ptr(void*, unsigned short w, unsigned short h, struct nk_rect sub_region); +NK_API struct nk_image nk_subimage_id(int, unsigned short w, unsigned short h, struct nk_rect sub_region); +NK_API struct nk_image nk_subimage_handle(nk_handle, unsigned short w, unsigned short h, struct nk_rect sub_region); +/* ============================================================================= + * + * MATH + * + * ============================================================================= */ +NK_API nk_hash nk_murmur_hash(const void *key, int len, nk_hash seed); +NK_API void nk_triangle_from_direction(struct nk_vec2 *result, struct nk_rect r, float pad_x, float pad_y, enum nk_heading); + +NK_API struct nk_vec2 nk_vec2(float x, float y); +NK_API struct nk_vec2 nk_vec2i(int x, int y); +NK_API struct nk_vec2 nk_vec2v(const float *xy); +NK_API struct nk_vec2 nk_vec2iv(const int *xy); + +NK_API struct nk_rect nk_get_null_rect(void); +NK_API struct nk_rect nk_rect(float x, float y, float w, float h); +NK_API struct nk_rect nk_recti(int x, int y, int w, int h); +NK_API struct nk_rect nk_recta(struct nk_vec2 pos, struct nk_vec2 size); +NK_API struct nk_rect nk_rectv(const float *xywh); +NK_API struct nk_rect nk_rectiv(const int *xywh); +NK_API struct nk_vec2 nk_rect_pos(struct nk_rect); +NK_API struct nk_vec2 nk_rect_size(struct nk_rect); +/* ============================================================================= + * + * STRING + * + * ============================================================================= */ +NK_API int nk_strlen(const char *str); +NK_API int nk_stricmp(const char *s1, const char *s2); +NK_API int nk_stricmpn(const char *s1, const char *s2, int n); +NK_API int nk_strtoi(const char *str, const char **endptr); +NK_API float nk_strtof(const char *str, const char **endptr); +NK_API double nk_strtod(const char *str, const char **endptr); +NK_API int nk_strfilter(const char *text, const char *regexp); +NK_API int nk_strmatch_fuzzy_string(char const *str, char const *pattern, int *out_score); +NK_API int nk_strmatch_fuzzy_text(const char *txt, int txt_len, const char *pattern, int *out_score); +/* ============================================================================= + * + * UTF-8 + * + * ============================================================================= */ +NK_API int nk_utf_decode(const char*, nk_rune*, int); +NK_API int nk_utf_encode(nk_rune, char*, int); +NK_API int nk_utf_len(const char*, int byte_len); +NK_API const char* nk_utf_at(const char *buffer, int length, int index, nk_rune *unicode, int *len); +/* =============================================================== + * + * FONT + * + * ===============================================================*/ +/* Font handling in this library was designed to be quite customizable and lets + you decide what you want to use and what you want to provide. There are three + different ways to use the font atlas. The first two will use your font + handling scheme and only requires essential data to run nuklear. The next + slightly more advanced features is font handling with vertex buffer output. + Finally the most complex API wise is using nuklear's font baking API. + + 1.) Using your own implementation without vertex buffer output + -------------------------------------------------------------- + So first up the easiest way to do font handling is by just providing a + `nk_user_font` struct which only requires the height in pixel of the used + font and a callback to calculate the width of a string. This way of handling + fonts is best fitted for using the normal draw shape command API where you + do all the text drawing yourself and the library does not require any kind + of deeper knowledge about which font handling mechanism you use. + IMPORTANT: the `nk_user_font` pointer provided to nuklear has to persist + over the complete life time! I know this sucks but it is currently the only + way to switch between fonts. + + float your_text_width_calculation(nk_handle handle, float height, const char *text, int len) + { + your_font_type *type = handle.ptr; + float text_width = ...; + return text_width; + } + + struct nk_user_font font; + font.userdata.ptr = &your_font_class_or_struct; + font.height = your_font_height; + font.width = your_text_width_calculation; + + struct nk_context ctx; + nk_init_default(&ctx, &font); + + 2.) Using your own implementation with vertex buffer output + -------------------------------------------------------------- + While the first approach works fine if you don't want to use the optional + vertex buffer output it is not enough if you do. To get font handling working + for these cases you have to provide two additional parameters inside the + `nk_user_font`. First a texture atlas handle used to draw text as subimages + of a bigger font atlas texture and a callback to query a character's glyph + information (offset, size, ...). So it is still possible to provide your own + font and use the vertex buffer output. + + float your_text_width_calculation(nk_handle handle, float height, const char *text, int len) + { + your_font_type *type = handle.ptr; + float text_width = ...; + return text_width; + } + void query_your_font_glyph(nk_handle handle, float font_height, struct nk_user_font_glyph *glyph, nk_rune codepoint, nk_rune next_codepoint) + { + your_font_type *type = handle.ptr; + glyph.width = ...; + glyph.height = ...; + glyph.xadvance = ...; + glyph.uv[0].x = ...; + glyph.uv[0].y = ...; + glyph.uv[1].x = ...; + glyph.uv[1].y = ...; + glyph.offset.x = ...; + glyph.offset.y = ...; + } + + struct nk_user_font font; + font.userdata.ptr = &your_font_class_or_struct; + font.height = your_font_height; + font.width = your_text_width_calculation; + font.query = query_your_font_glyph; + font.texture.id = your_font_texture; + + struct nk_context ctx; + nk_init_default(&ctx, &font); + + 3.) Nuklear font baker + ------------------------------------ + The final approach if you do not have a font handling functionality or don't + want to use it in this library is by using the optional font baker. + The font baker APIs can be used to create a font plus font atlas texture + and can be used with or without the vertex buffer output. + + It still uses the `nk_user_font` struct and the two different approaches + previously stated still work. The font baker is not located inside + `nk_context` like all other systems since it can be understood as more of + an extension to nuklear and does not really depend on any `nk_context` state. + + Font baker need to be initialized first by one of the nk_font_atlas_init_xxx + functions. If you don't care about memory just call the default version + `nk_font_atlas_init_default` which will allocate all memory from the standard library. + If you want to control memory allocation but you don't care if the allocated + memory is temporary and therefore can be freed directly after the baking process + is over or permanent you can call `nk_font_atlas_init`. + + After successfully initializing the font baker you can add Truetype(.ttf) fonts from + different sources like memory or from file by calling one of the `nk_font_atlas_add_xxx`. + functions. Adding font will permanently store each font, font config and ttf memory block(!) + inside the font atlas and allows to reuse the font atlas. If you don't want to reuse + the font baker by for example adding additional fonts you can call + `nk_font_atlas_cleanup` after the baking process is over (after calling nk_font_atlas_end). + + As soon as you added all fonts you wanted you can now start the baking process + for every selected glyph to image by calling `nk_font_atlas_bake`. + The baking process returns image memory, width and height which can be used to + either create your own image object or upload it to any graphics library. + No matter which case you finally have to call `nk_font_atlas_end` which + will free all temporary memory including the font atlas image so make sure + you created our texture beforehand. `nk_font_atlas_end` requires a handle + to your font texture or object and optionally fills a `struct nk_draw_null_texture` + which can be used for the optional vertex output. If you don't want it just + set the argument to `NULL`. + + At this point you are done and if you don't want to reuse the font atlas you + can call `nk_font_atlas_cleanup` to free all truetype blobs and configuration + memory. Finally if you don't use the font atlas and any of it's fonts anymore + you need to call `nk_font_atlas_clear` to free all memory still being used. + + struct nk_font_atlas atlas; + nk_font_atlas_init_default(&atlas); + nk_font_atlas_begin(&atlas); + nk_font *font = nk_font_atlas_add_from_file(&atlas, "Path/To/Your/TTF_Font.ttf", 13, 0); + nk_font *font2 = nk_font_atlas_add_from_file(&atlas, "Path/To/Your/TTF_Font2.ttf", 16, 0); + const void* img = nk_font_atlas_bake(&atlas, &img_width, &img_height, NK_FONT_ATLAS_RGBA32); + nk_font_atlas_end(&atlas, nk_handle_id(texture), 0); + + struct nk_context ctx; + nk_init_default(&ctx, &font->handle); + while (1) { + + } + nk_font_atlas_clear(&atlas); + + The font baker API is probably the most complex API inside this library and + I would suggest reading some of my examples `example/` to get a grip on how + to use the font atlas. There are a number of details I left out. For example + how to merge fonts, configure a font with `nk_font_config` to use other languages, + use another texture coordinate format and a lot more: + + struct nk_font_config cfg = nk_font_config(font_pixel_height); + cfg.merge_mode = nk_false or nk_true; + cfg.range = nk_font_korean_glyph_ranges(); + cfg.coord_type = NK_COORD_PIXEL; + nk_font *font = nk_font_atlas_add_from_file(&atlas, "Path/To/Your/TTF_Font.ttf", 13, &cfg); + +*/ +struct nk_user_font_glyph; +typedef float(*nk_text_width_f)(nk_handle, float h, const char*, int len); +typedef void(*nk_query_font_glyph_f)(nk_handle handle, float font_height, + struct nk_user_font_glyph *glyph, + nk_rune codepoint, nk_rune next_codepoint); + +#if defined(NK_INCLUDE_VERTEX_BUFFER_OUTPUT) || defined(NK_INCLUDE_SOFTWARE_FONT) +struct nk_user_font_glyph { + struct nk_vec2 uv[2]; + /* texture coordinates */ + struct nk_vec2 offset; + /* offset between top left and glyph */ + float width, height; + /* size of the glyph */ + float xadvance; + /* offset to the next glyph */ +}; +#endif + +struct nk_user_font { + nk_handle userdata; + /* user provided font handle */ + float height; + /* max height of the font */ + nk_text_width_f width; + /* font string width in pixel callback */ +#ifdef NK_INCLUDE_VERTEX_BUFFER_OUTPUT + nk_query_font_glyph_f query; + /* font glyph callback to query drawing info */ + nk_handle texture; + /* texture handle to the used font atlas or texture */ +#endif +}; + +#ifdef NK_INCLUDE_FONT_BAKING +enum nk_font_coord_type { + NK_COORD_UV, /* texture coordinates inside font glyphs are clamped between 0-1 */ + NK_COORD_PIXEL /* texture coordinates inside font glyphs are in absolute pixel */ +}; + +struct nk_font; +struct nk_baked_font { + float height; + /* height of the font */ + float ascent, descent; + /* font glyphs ascent and descent */ + nk_rune glyph_offset; + /* glyph array offset inside the font glyph baking output array */ + nk_rune glyph_count; + /* number of glyphs of this font inside the glyph baking array output */ + const nk_rune *ranges; + /* font codepoint ranges as pairs of (from/to) and 0 as last element */ +}; + +struct nk_font_config { + struct nk_font_config *next; + /* NOTE: only used internally */ + void *ttf_blob; + /* pointer to loaded TTF file memory block. + * NOTE: not needed for nk_font_atlas_add_from_memory and nk_font_atlas_add_from_file. */ + nk_size ttf_size; + /* size of the loaded TTF file memory block + * NOTE: not needed for nk_font_atlas_add_from_memory and nk_font_atlas_add_from_file. */ + + unsigned char ttf_data_owned_by_atlas; + /* used inside font atlas: default to: 0*/ + unsigned char merge_mode; + /* merges this font into the last font */ + unsigned char pixel_snap; + /* align every character to pixel boundary (if true set oversample (1,1)) */ + unsigned char oversample_v, oversample_h; + /* rasterize at hight quality for sub-pixel position */ + unsigned char padding[3]; + + float size; + /* baked pixel height of the font */ + enum nk_font_coord_type coord_type; + /* texture coordinate format with either pixel or UV coordinates */ + struct nk_vec2 spacing; + /* extra pixel spacing between glyphs */ + const nk_rune *range; + /* list of unicode ranges (2 values per range, zero terminated) */ + struct nk_baked_font *font; + /* font to setup in the baking process: NOTE: not needed for font atlas */ + nk_rune fallback_glyph; + /* fallback glyph to use if a given rune is not found */ + struct nk_font_config *n; + struct nk_font_config *p; +}; + +struct nk_font_glyph { + nk_rune codepoint; + float xadvance; + float x0, y0, x1, y1, w, h; + float u0, v0, u1, v1; +}; + +struct nk_font { + struct nk_font *next; + struct nk_user_font handle; + struct nk_baked_font info; + float scale; + struct nk_font_glyph *glyphs; + const struct nk_font_glyph *fallback; + nk_rune fallback_codepoint; + nk_handle texture; + struct nk_font_config *config; +}; + +enum nk_font_atlas_format { + NK_FONT_ATLAS_ALPHA8, + NK_FONT_ATLAS_RGBA32 +}; + +struct nk_font_atlas { + void *pixel; + int tex_width; + int tex_height; + + struct nk_allocator permanent; + struct nk_allocator temporary; + + struct nk_recti custom; + struct nk_cursor cursors[NK_CURSOR_COUNT]; + + int glyph_count; + struct nk_font_glyph *glyphs; + struct nk_font *default_font; + struct nk_font *fonts; + struct nk_font_config *config; + int font_num; +}; + +/* some language glyph codepoint ranges */ +NK_API const nk_rune *nk_font_default_glyph_ranges(void); +NK_API const nk_rune *nk_font_chinese_glyph_ranges(void); +NK_API const nk_rune *nk_font_cyrillic_glyph_ranges(void); +NK_API const nk_rune *nk_font_korean_glyph_ranges(void); + +#ifdef NK_INCLUDE_DEFAULT_ALLOCATOR +NK_API void nk_font_atlas_init_default(struct nk_font_atlas*); +#endif +NK_API void nk_font_atlas_init(struct nk_font_atlas*, struct nk_allocator*); +NK_API void nk_font_atlas_init_custom(struct nk_font_atlas*, struct nk_allocator *persistent, struct nk_allocator *transient); +NK_API void nk_font_atlas_begin(struct nk_font_atlas*); +NK_API struct nk_font_config nk_font_config(float pixel_height); +NK_API struct nk_font *nk_font_atlas_add(struct nk_font_atlas*, const struct nk_font_config*); +#ifdef NK_INCLUDE_DEFAULT_FONT +NK_API struct nk_font* nk_font_atlas_add_default(struct nk_font_atlas*, float height, const struct nk_font_config*); +#endif +NK_API struct nk_font* nk_font_atlas_add_from_memory(struct nk_font_atlas *atlas, void *memory, nk_size size, float height, const struct nk_font_config *config); +#ifdef NK_INCLUDE_STANDARD_IO +NK_API struct nk_font* nk_font_atlas_add_from_file(struct nk_font_atlas *atlas, const char *file_path, float height, const struct nk_font_config*); +#endif +NK_API struct nk_font *nk_font_atlas_add_compressed(struct nk_font_atlas*, void *memory, nk_size size, float height, const struct nk_font_config*); +NK_API struct nk_font* nk_font_atlas_add_compressed_base85(struct nk_font_atlas*, const char *data, float height, const struct nk_font_config *config); +NK_API const void* nk_font_atlas_bake(struct nk_font_atlas*, int *width, int *height, enum nk_font_atlas_format); +NK_API void nk_font_atlas_end(struct nk_font_atlas*, nk_handle tex, struct nk_draw_null_texture*); +NK_API const struct nk_font_glyph* nk_font_find_glyph(struct nk_font*, nk_rune unicode); +NK_API void nk_font_atlas_cleanup(struct nk_font_atlas *atlas); +NK_API void nk_font_atlas_clear(struct nk_font_atlas*); + +#endif + +/* ============================================================== + * + * MEMORY BUFFER + * + * ===============================================================*/ +/* A basic (double)-buffer with linear allocation and resetting as only + freeing policy. The buffer's main purpose is to control all memory management + inside the GUI toolkit and still leave memory control as much as possible in + the hand of the user while also making sure the library is easy to use if + not as much control is needed. + In general all memory inside this library can be provided from the user in + three different ways. + + The first way and the one providing most control is by just passing a fixed + size memory block. In this case all control lies in the hand of the user + since he can exactly control where the memory comes from and how much memory + the library should consume. Of course using the fixed size API removes the + ability to automatically resize a buffer if not enough memory is provided so + you have to take over the resizing. While being a fixed sized buffer sounds + quite limiting, it is very effective in this library since the actual memory + consumption is quite stable and has a fixed upper bound for a lot of cases. + + If you don't want to think about how much memory the library should allocate + at all time or have a very dynamic UI with unpredictable memory consumption + habits but still want control over memory allocation you can use the dynamic + allocator based API. The allocator consists of two callbacks for allocating + and freeing memory and optional userdata so you can plugin your own allocator. + + The final and easiest way can be used by defining + NK_INCLUDE_DEFAULT_ALLOCATOR which uses the standard library memory + allocation functions malloc and free and takes over complete control over + memory in this library. +*/ +struct nk_memory_status { + void *memory; + unsigned int type; + nk_size size; + nk_size allocated; + nk_size needed; + nk_size calls; +}; + +enum nk_allocation_type { + NK_BUFFER_FIXED, + NK_BUFFER_DYNAMIC +}; + +enum nk_buffer_allocation_type { + NK_BUFFER_FRONT, + NK_BUFFER_BACK, + NK_BUFFER_MAX +}; + +struct nk_buffer_marker { + int active; + nk_size offset; +}; + +struct nk_memory {void *ptr;nk_size size;}; +struct nk_buffer { + struct nk_buffer_marker marker[NK_BUFFER_MAX]; + /* buffer marker to free a buffer to a certain offset */ + struct nk_allocator pool; + /* allocator callback for dynamic buffers */ + enum nk_allocation_type type; + /* memory management type */ + struct nk_memory memory; + /* memory and size of the current memory block */ + float grow_factor; + /* growing factor for dynamic memory management */ + nk_size allocated; + /* total amount of memory allocated */ + nk_size needed; + /* totally consumed memory given that enough memory is present */ + nk_size calls; + /* number of allocation calls */ + nk_size size; + /* current size of the buffer */ +}; + +#ifdef NK_INCLUDE_DEFAULT_ALLOCATOR +NK_API void nk_buffer_init_default(struct nk_buffer*); +#endif +NK_API void nk_buffer_init(struct nk_buffer*, const struct nk_allocator*, nk_size size); +NK_API void nk_buffer_init_fixed(struct nk_buffer*, void *memory, nk_size size); +NK_API void nk_buffer_info(struct nk_memory_status*, struct nk_buffer*); +NK_API void nk_buffer_push(struct nk_buffer*, enum nk_buffer_allocation_type type, const void *memory, nk_size size, nk_size align); +NK_API void nk_buffer_mark(struct nk_buffer*, enum nk_buffer_allocation_type type); +NK_API void nk_buffer_reset(struct nk_buffer*, enum nk_buffer_allocation_type type); +NK_API void nk_buffer_clear(struct nk_buffer*); +NK_API void nk_buffer_free(struct nk_buffer*); +NK_API void *nk_buffer_memory(struct nk_buffer*); +NK_API const void *nk_buffer_memory_const(const struct nk_buffer*); +NK_API nk_size nk_buffer_total(struct nk_buffer*); + +/* ============================================================== + * + * STRING + * + * ===============================================================*/ +/* Basic string buffer which is only used in context with the text editor + * to manage and manipulate dynamic or fixed size string content. This is _NOT_ + * the default string handling method. The only instance you should have any contact + * with this API is if you interact with an `nk_text_edit` object inside one of the + * copy and paste functions and even there only for more advanced cases. */ +struct nk_str { + struct nk_buffer buffer; + int len; /* in codepoints/runes/glyphs */ +}; + +#ifdef NK_INCLUDE_DEFAULT_ALLOCATOR +NK_API void nk_str_init_default(struct nk_str*); +#endif +NK_API void nk_str_init(struct nk_str*, const struct nk_allocator*, nk_size size); +NK_API void nk_str_init_fixed(struct nk_str*, void *memory, nk_size size); +NK_API void nk_str_clear(struct nk_str*); +NK_API void nk_str_free(struct nk_str*); + +NK_API int nk_str_append_text_char(struct nk_str*, const char*, int); +NK_API int nk_str_append_str_char(struct nk_str*, const char*); +NK_API int nk_str_append_text_utf8(struct nk_str*, const char*, int); +NK_API int nk_str_append_str_utf8(struct nk_str*, const char*); +NK_API int nk_str_append_text_runes(struct nk_str*, const nk_rune*, int); +NK_API int nk_str_append_str_runes(struct nk_str*, const nk_rune*); + +NK_API int nk_str_insert_at_char(struct nk_str*, int pos, const char*, int); +NK_API int nk_str_insert_at_rune(struct nk_str*, int pos, const char*, int); + +NK_API int nk_str_insert_text_char(struct nk_str*, int pos, const char*, int); +NK_API int nk_str_insert_str_char(struct nk_str*, int pos, const char*); +NK_API int nk_str_insert_text_utf8(struct nk_str*, int pos, const char*, int); +NK_API int nk_str_insert_str_utf8(struct nk_str*, int pos, const char*); +NK_API int nk_str_insert_text_runes(struct nk_str*, int pos, const nk_rune*, int); +NK_API int nk_str_insert_str_runes(struct nk_str*, int pos, const nk_rune*); + +NK_API void nk_str_remove_chars(struct nk_str*, int len); +NK_API void nk_str_remove_runes(struct nk_str *str, int len); +NK_API void nk_str_delete_chars(struct nk_str*, int pos, int len); +NK_API void nk_str_delete_runes(struct nk_str*, int pos, int len); + +NK_API char *nk_str_at_char(struct nk_str*, int pos); +NK_API char *nk_str_at_rune(struct nk_str*, int pos, nk_rune *unicode, int *len); +NK_API nk_rune nk_str_rune_at(const struct nk_str*, int pos); +NK_API const char *nk_str_at_char_const(const struct nk_str*, int pos); +NK_API const char *nk_str_at_const(const struct nk_str*, int pos, nk_rune *unicode, int *len); + +NK_API char *nk_str_get(struct nk_str*); +NK_API const char *nk_str_get_const(const struct nk_str*); +NK_API int nk_str_len(struct nk_str*); +NK_API int nk_str_len_char(struct nk_str*); + +/*=============================================================== + * + * TEXT EDITOR + * + * ===============================================================*/ +/* Editing text in this library is handled by either `nk_edit_string` or + * `nk_edit_buffer`. But like almost everything in this library there are multiple + * ways of doing it and a balance between control and ease of use with memory + * as well as functionality controlled by flags. + * + * This library generally allows three different levels of memory control: + * First of is the most basic way of just providing a simple char array with + * string length. This method is probably the easiest way of handling simple + * user text input. Main upside is complete control over memory while the biggest + * downside in comparison with the other two approaches is missing undo/redo. + * + * For UIs that require undo/redo the second way was created. It is based on + * a fixed size nk_text_edit struct, which has an internal undo/redo stack. + * This is mainly useful if you want something more like a text editor but don't want + * to have a dynamically growing buffer. + * + * The final way is using a dynamically growing nk_text_edit struct, which + * has both a default version if you don't care where memory comes from and an + * allocator version if you do. While the text editor is quite powerful for its + * complexity I would not recommend editing gigabytes of data with it. + * It is rather designed for uses cases which make sense for a GUI library not for + * an full blown text editor. + */ +#ifndef NK_TEXTEDIT_UNDOSTATECOUNT +#define NK_TEXTEDIT_UNDOSTATECOUNT 99 +#endif + +#ifndef NK_TEXTEDIT_UNDOCHARCOUNT +#define NK_TEXTEDIT_UNDOCHARCOUNT 999 +#endif + +struct nk_text_edit; +struct nk_clipboard { + nk_handle userdata; + nk_plugin_paste paste; + nk_plugin_copy copy; +}; + +struct nk_text_undo_record { + int where; + short insert_length; + short delete_length; + short char_storage; +}; + +struct nk_text_undo_state { + struct nk_text_undo_record undo_rec[NK_TEXTEDIT_UNDOSTATECOUNT]; + nk_rune undo_char[NK_TEXTEDIT_UNDOCHARCOUNT]; + short undo_point; + short redo_point; + short undo_char_point; + short redo_char_point; +}; + +enum nk_text_edit_type { + NK_TEXT_EDIT_SINGLE_LINE, + NK_TEXT_EDIT_MULTI_LINE +}; + +enum nk_text_edit_mode { + NK_TEXT_EDIT_MODE_VIEW, + NK_TEXT_EDIT_MODE_INSERT, + NK_TEXT_EDIT_MODE_REPLACE +}; + +struct nk_text_edit { + struct nk_clipboard clip; + struct nk_str string; + nk_plugin_filter filter; + struct nk_vec2 scrollbar; + + int cursor; + int select_start; + int select_end; + unsigned char mode; + unsigned char cursor_at_end_of_line; + unsigned char initialized; + unsigned char has_preferred_x; + unsigned char single_line; + unsigned char active; + unsigned char padding1; + float preferred_x; + struct nk_text_undo_state undo; +}; + +/* filter function */ +NK_API int nk_filter_default(const struct nk_text_edit*, nk_rune unicode); +NK_API int nk_filter_ascii(const struct nk_text_edit*, nk_rune unicode); +NK_API int nk_filter_float(const struct nk_text_edit*, nk_rune unicode); +NK_API int nk_filter_decimal(const struct nk_text_edit*, nk_rune unicode); +NK_API int nk_filter_hex(const struct nk_text_edit*, nk_rune unicode); +NK_API int nk_filter_oct(const struct nk_text_edit*, nk_rune unicode); +NK_API int nk_filter_binary(const struct nk_text_edit*, nk_rune unicode); + +/* text editor */ +#ifdef NK_INCLUDE_DEFAULT_ALLOCATOR +NK_API void nk_textedit_init_default(struct nk_text_edit*); +#endif +NK_API void nk_textedit_init(struct nk_text_edit*, struct nk_allocator*, nk_size size); +NK_API void nk_textedit_init_fixed(struct nk_text_edit*, void *memory, nk_size size); +NK_API void nk_textedit_free(struct nk_text_edit*); +NK_API void nk_textedit_text(struct nk_text_edit*, const char*, int total_len); +NK_API void nk_textedit_delete(struct nk_text_edit*, int where, int len); +NK_API void nk_textedit_delete_selection(struct nk_text_edit*); +NK_API void nk_textedit_select_all(struct nk_text_edit*); +NK_API int nk_textedit_cut(struct nk_text_edit*); +NK_API int nk_textedit_paste(struct nk_text_edit*, char const*, int len); +NK_API void nk_textedit_undo(struct nk_text_edit*); +NK_API void nk_textedit_redo(struct nk_text_edit*); + +/* =============================================================== + * + * DRAWING + * + * ===============================================================*/ +/* This library was designed to be render backend agnostic so it does + not draw anything to screen. Instead all drawn shapes, widgets + are made of, are buffered into memory and make up a command queue. + Each frame therefore fills the command buffer with draw commands + that then need to be executed by the user and his own render backend. + After that the command buffer needs to be cleared and a new frame can be + started. It is probably important to note that the command buffer is the main + drawing API and the optional vertex buffer API only takes this format and + converts it into a hardware accessible format. + + To use the command queue to draw your own widgets you can access the + command buffer of each window by calling `nk_window_get_canvas` after + previously having called `nk_begin`: + + void draw_red_rectangle_widget(struct nk_context *ctx) + { + struct nk_command_buffer *canvas; + struct nk_input *input = &ctx->input; + canvas = nk_window_get_canvas(ctx); + + struct nk_rect space; + enum nk_widget_layout_states state; + state = nk_widget(&space, ctx); + if (!state) return; + + if (state != NK_WIDGET_ROM) + update_your_widget_by_user_input(...); + nk_fill_rect(canvas, space, 0, nk_rgb(255,0,0)); + } + + if (nk_begin(...)) { + nk_layout_row_dynamic(ctx, 25, 1); + draw_red_rectangle_widget(ctx); + } + nk_end(..) + + Important to know if you want to create your own widgets is the `nk_widget` + call. It allocates space on the panel reserved for this widget to be used, + but also returns the state of the widget space. If your widget is not seen and does + not have to be updated it is '0' and you can just return. If it only has + to be drawn the state will be `NK_WIDGET_ROM` otherwise you can do both + update and draw your widget. The reason for separating is to only draw and + update what is actually necessary which is crucial for performance. +*/ +enum nk_command_type { + NK_COMMAND_NOP, + NK_COMMAND_SCISSOR, + NK_COMMAND_LINE, + NK_COMMAND_CURVE, + NK_COMMAND_RECT, + NK_COMMAND_RECT_FILLED, + NK_COMMAND_RECT_MULTI_COLOR, + NK_COMMAND_CIRCLE, + NK_COMMAND_CIRCLE_FILLED, + NK_COMMAND_ARC, + NK_COMMAND_ARC_FILLED, + NK_COMMAND_TRIANGLE, + NK_COMMAND_TRIANGLE_FILLED, + NK_COMMAND_POLYGON, + NK_COMMAND_POLYGON_FILLED, + NK_COMMAND_POLYLINE, + NK_COMMAND_TEXT, + NK_COMMAND_IMAGE, + NK_COMMAND_CUSTOM +}; + +/* command base and header of every command inside the buffer */ +struct nk_command { + enum nk_command_type type; + nk_size next; +#ifdef NK_INCLUDE_COMMAND_USERDATA + nk_handle userdata; +#endif +}; + +struct nk_command_scissor { + struct nk_command header; + short x, y; + unsigned short w, h; +}; + +struct nk_command_line { + struct nk_command header; + unsigned short line_thickness; + struct nk_vec2i begin; + struct nk_vec2i end; + struct nk_color color; +}; + +struct nk_command_curve { + struct nk_command header; + unsigned short line_thickness; + struct nk_vec2i begin; + struct nk_vec2i end; + struct nk_vec2i ctrl[2]; + struct nk_color color; +}; + +struct nk_command_rect { + struct nk_command header; + unsigned short rounding; + unsigned short line_thickness; + short x, y; + unsigned short w, h; + struct nk_color color; +}; + +struct nk_command_rect_filled { + struct nk_command header; + unsigned short rounding; + short x, y; + unsigned short w, h; + struct nk_color color; +}; + +struct nk_command_rect_multi_color { + struct nk_command header; + short x, y; + unsigned short w, h; + struct nk_color left; + struct nk_color top; + struct nk_color bottom; + struct nk_color right; +}; + +struct nk_command_triangle { + struct nk_command header; + unsigned short line_thickness; + struct nk_vec2i a; + struct nk_vec2i b; + struct nk_vec2i c; + struct nk_color color; +}; + +struct nk_command_triangle_filled { + struct nk_command header; + struct nk_vec2i a; + struct nk_vec2i b; + struct nk_vec2i c; + struct nk_color color; +}; + +struct nk_command_circle { + struct nk_command header; + short x, y; + unsigned short line_thickness; + unsigned short w, h; + struct nk_color color; +}; + +struct nk_command_circle_filled { + struct nk_command header; + short x, y; + unsigned short w, h; + struct nk_color color; +}; + +struct nk_command_arc { + struct nk_command header; + short cx, cy; + unsigned short r; + unsigned short line_thickness; + float a[2]; + struct nk_color color; +}; + +struct nk_command_arc_filled { + struct nk_command header; + short cx, cy; + unsigned short r; + float a[2]; + struct nk_color color; +}; + +struct nk_command_polygon { + struct nk_command header; + struct nk_color color; + unsigned short line_thickness; + unsigned short point_count; + struct nk_vec2i points[1]; +}; + +struct nk_command_polygon_filled { + struct nk_command header; + struct nk_color color; + unsigned short point_count; + struct nk_vec2i points[1]; +}; + +struct nk_command_polyline { + struct nk_command header; + struct nk_color color; + unsigned short line_thickness; + unsigned short point_count; + struct nk_vec2i points[1]; +}; + +struct nk_command_image { + struct nk_command header; + short x, y; + unsigned short w, h; + struct nk_image img; + struct nk_color col; +}; + +typedef void (*nk_command_custom_callback)(void *canvas, short x,short y, + unsigned short w, unsigned short h, nk_handle callback_data); +struct nk_command_custom { + struct nk_command header; + short x, y; + unsigned short w, h; + nk_handle callback_data; + nk_command_custom_callback callback; +}; + +struct nk_command_text { + struct nk_command header; + const struct nk_user_font *font; + struct nk_color background; + struct nk_color foreground; + short x, y; + unsigned short w, h; + float height; + int length; + char string[1]; +}; + +enum nk_command_clipping { + NK_CLIPPING_OFF = nk_false, + NK_CLIPPING_ON = nk_true +}; + +struct nk_command_buffer { + struct nk_buffer *base; + struct nk_rect clip; + int use_clipping; + nk_handle userdata; + nk_size begin, end, last; +}; + +/* shape outlines */ +NK_API void nk_stroke_line(struct nk_command_buffer *b, float x0, float y0, float x1, float y1, float line_thickness, struct nk_color); +NK_API void nk_stroke_curve(struct nk_command_buffer*, float, float, float, float, float, float, float, float, float line_thickness, struct nk_color); +NK_API void nk_stroke_rect(struct nk_command_buffer*, struct nk_rect, float rounding, float line_thickness, struct nk_color); +NK_API void nk_stroke_circle(struct nk_command_buffer*, struct nk_rect, float line_thickness, struct nk_color); +NK_API void nk_stroke_arc(struct nk_command_buffer*, float cx, float cy, float radius, float a_min, float a_max, float line_thickness, struct nk_color); +NK_API void nk_stroke_triangle(struct nk_command_buffer*, float, float, float, float, float, float, float line_thichness, struct nk_color); +NK_API void nk_stroke_polyline(struct nk_command_buffer*, float *points, int point_count, float line_thickness, struct nk_color col); +NK_API void nk_stroke_polygon(struct nk_command_buffer*, float*, int point_count, float line_thickness, struct nk_color); + +/* filled shades */ +NK_API void nk_fill_rect(struct nk_command_buffer*, struct nk_rect, float rounding, struct nk_color); +NK_API void nk_fill_rect_multi_color(struct nk_command_buffer*, struct nk_rect, struct nk_color left, struct nk_color top, struct nk_color right, struct nk_color bottom); +NK_API void nk_fill_circle(struct nk_command_buffer*, struct nk_rect, struct nk_color); +NK_API void nk_fill_arc(struct nk_command_buffer*, float cx, float cy, float radius, float a_min, float a_max, struct nk_color); +NK_API void nk_fill_triangle(struct nk_command_buffer*, float x0, float y0, float x1, float y1, float x2, float y2, struct nk_color); +NK_API void nk_fill_polygon(struct nk_command_buffer*, float*, int point_count, struct nk_color); + +/* misc */ +NK_API void nk_draw_image(struct nk_command_buffer*, struct nk_rect, const struct nk_image*, struct nk_color); +NK_API void nk_draw_text(struct nk_command_buffer*, struct nk_rect, const char *text, int len, const struct nk_user_font*, struct nk_color, struct nk_color); +NK_API void nk_push_scissor(struct nk_command_buffer*, struct nk_rect); +NK_API void nk_push_custom(struct nk_command_buffer*, struct nk_rect, nk_command_custom_callback, nk_handle usr); + +/* =============================================================== + * + * INPUT + * + * ===============================================================*/ +struct nk_mouse_button { + int down; + unsigned int clicked; + struct nk_vec2 clicked_pos; +}; +struct nk_mouse { + struct nk_mouse_button buttons[NK_BUTTON_MAX]; + struct nk_vec2 pos; + struct nk_vec2 prev; + struct nk_vec2 delta; + struct nk_vec2 scroll_delta; + unsigned char grab; + unsigned char grabbed; + unsigned char ungrab; +}; + +struct nk_key { + int down; + unsigned int clicked; +}; +struct nk_keyboard { + struct nk_key keys[NK_KEY_MAX]; + char text[NK_INPUT_MAX]; + int text_len; +}; + +struct nk_input { + struct nk_keyboard keyboard; + struct nk_mouse mouse; +}; + +NK_API int nk_input_has_mouse_click(const struct nk_input*, enum nk_buttons); +NK_API int nk_input_has_mouse_click_in_rect(const struct nk_input*, enum nk_buttons, struct nk_rect); +NK_API int nk_input_has_mouse_click_down_in_rect(const struct nk_input*, enum nk_buttons, struct nk_rect, int down); +NK_API int nk_input_is_mouse_click_in_rect(const struct nk_input*, enum nk_buttons, struct nk_rect); +NK_API int nk_input_is_mouse_click_down_in_rect(const struct nk_input *i, enum nk_buttons id, struct nk_rect b, int down); +NK_API int nk_input_any_mouse_click_in_rect(const struct nk_input*, struct nk_rect); +NK_API int nk_input_is_mouse_prev_hovering_rect(const struct nk_input*, struct nk_rect); +NK_API int nk_input_is_mouse_hovering_rect(const struct nk_input*, struct nk_rect); +NK_API int nk_input_mouse_clicked(const struct nk_input*, enum nk_buttons, struct nk_rect); +NK_API int nk_input_is_mouse_down(const struct nk_input*, enum nk_buttons); +NK_API int nk_input_is_mouse_pressed(const struct nk_input*, enum nk_buttons); +NK_API int nk_input_is_mouse_released(const struct nk_input*, enum nk_buttons); +NK_API int nk_input_is_key_pressed(const struct nk_input*, enum nk_keys); +NK_API int nk_input_is_key_released(const struct nk_input*, enum nk_keys); +NK_API int nk_input_is_key_down(const struct nk_input*, enum nk_keys); + +/* =============================================================== + * + * DRAW LIST + * + * ===============================================================*/ +#ifdef NK_INCLUDE_VERTEX_BUFFER_OUTPUT +/* The optional vertex buffer draw list provides a 2D drawing context + with antialiasing functionality which takes basic filled or outlined shapes + or a path and outputs vertexes, elements and draw commands. + The actual draw list API is not required to be used directly while using this + library since converting the default library draw command output is done by + just calling `nk_convert` but I decided to still make this library accessible + since it can be useful. + + The draw list is based on a path buffering and polygon and polyline + rendering API which allows a lot of ways to draw 2D content to screen. + In fact it is probably more powerful than needed but allows even more crazy + things than this library provides by default. +*/ +typedef nk_ushort nk_draw_index; +enum nk_draw_list_stroke { + NK_STROKE_OPEN = nk_false, + /* build up path has no connection back to the beginning */ + NK_STROKE_CLOSED = nk_true + /* build up path has a connection back to the beginning */ +}; + +enum nk_draw_vertex_layout_attribute { + NK_VERTEX_POSITION, + NK_VERTEX_COLOR, + NK_VERTEX_TEXCOORD, + NK_VERTEX_ATTRIBUTE_COUNT +}; + +enum nk_draw_vertex_layout_format { + NK_FORMAT_SCHAR, + NK_FORMAT_SSHORT, + NK_FORMAT_SINT, + NK_FORMAT_UCHAR, + NK_FORMAT_USHORT, + NK_FORMAT_UINT, + NK_FORMAT_FLOAT, + NK_FORMAT_DOUBLE, + +NK_FORMAT_COLOR_BEGIN, + NK_FORMAT_R8G8B8 = NK_FORMAT_COLOR_BEGIN, + NK_FORMAT_R16G15B16, + NK_FORMAT_R32G32B32, + + NK_FORMAT_R8G8B8A8, + NK_FORMAT_B8G8R8A8, + NK_FORMAT_R16G15B16A16, + NK_FORMAT_R32G32B32A32, + NK_FORMAT_R32G32B32A32_FLOAT, + NK_FORMAT_R32G32B32A32_DOUBLE, + + NK_FORMAT_RGB32, + NK_FORMAT_RGBA32, +NK_FORMAT_COLOR_END = NK_FORMAT_RGBA32, + NK_FORMAT_COUNT +}; + +#define NK_VERTEX_LAYOUT_END NK_VERTEX_ATTRIBUTE_COUNT,NK_FORMAT_COUNT,0 +struct nk_draw_vertex_layout_element { + enum nk_draw_vertex_layout_attribute attribute; + enum nk_draw_vertex_layout_format format; + nk_size offset; +}; + +struct nk_draw_command { + unsigned int elem_count; + /* number of elements in the current draw batch */ + struct nk_rect clip_rect; + /* current screen clipping rectangle */ + nk_handle texture; + /* current texture to set */ +#ifdef NK_INCLUDE_COMMAND_USERDATA + nk_handle userdata; +#endif +}; + +struct nk_draw_list { + struct nk_rect clip_rect; + struct nk_vec2 circle_vtx[12]; + struct nk_convert_config config; + + struct nk_buffer *buffer; + struct nk_buffer *vertices; + struct nk_buffer *elements; + + unsigned int element_count; + unsigned int vertex_count; + unsigned int cmd_count; + nk_size cmd_offset; + + unsigned int path_count; + unsigned int path_offset; + + enum nk_anti_aliasing line_AA; + enum nk_anti_aliasing shape_AA; + +#ifdef NK_INCLUDE_COMMAND_USERDATA + nk_handle userdata; +#endif +}; + +/* draw list */ +NK_API void nk_draw_list_init(struct nk_draw_list*); +NK_API void nk_draw_list_setup(struct nk_draw_list*, const struct nk_convert_config*, struct nk_buffer *cmds, struct nk_buffer *vertices, struct nk_buffer *elements, enum nk_anti_aliasing line_aa,enum nk_anti_aliasing shape_aa); +NK_API void nk_draw_list_clear(struct nk_draw_list*); + +/* drawing */ +#define nk_draw_list_foreach(cmd, can, b) for((cmd)=nk__draw_list_begin(can, b); (cmd)!=0; (cmd)=nk__draw_list_next(cmd, b, can)) +NK_API const struct nk_draw_command* nk__draw_list_begin(const struct nk_draw_list*, const struct nk_buffer*); +NK_API const struct nk_draw_command* nk__draw_list_next(const struct nk_draw_command*, const struct nk_buffer*, const struct nk_draw_list*); +NK_API const struct nk_draw_command* nk__draw_list_end(const struct nk_draw_list*, const struct nk_buffer*); +NK_API void nk_draw_list_clear(struct nk_draw_list *list); + +/* path */ +NK_API void nk_draw_list_path_clear(struct nk_draw_list*); +NK_API void nk_draw_list_path_line_to(struct nk_draw_list*, struct nk_vec2 pos); +NK_API void nk_draw_list_path_arc_to_fast(struct nk_draw_list*, struct nk_vec2 center, float radius, int a_min, int a_max); +NK_API void nk_draw_list_path_arc_to(struct nk_draw_list*, struct nk_vec2 center, float radius, float a_min, float a_max, unsigned int segments); +NK_API void nk_draw_list_path_rect_to(struct nk_draw_list*, struct nk_vec2 a, struct nk_vec2 b, float rounding); +NK_API void nk_draw_list_path_curve_to(struct nk_draw_list*, struct nk_vec2 p2, struct nk_vec2 p3, struct nk_vec2 p4, unsigned int num_segments); +NK_API void nk_draw_list_path_fill(struct nk_draw_list*, struct nk_color); +NK_API void nk_draw_list_path_stroke(struct nk_draw_list*, struct nk_color, enum nk_draw_list_stroke closed, float thickness); + +/* stroke */ +NK_API void nk_draw_list_stroke_line(struct nk_draw_list*, struct nk_vec2 a, struct nk_vec2 b, struct nk_color, float thickness); +NK_API void nk_draw_list_stroke_rect(struct nk_draw_list*, struct nk_rect rect, struct nk_color, float rounding, float thickness); +NK_API void nk_draw_list_stroke_triangle(struct nk_draw_list*, struct nk_vec2 a, struct nk_vec2 b, struct nk_vec2 c, struct nk_color, float thickness); +NK_API void nk_draw_list_stroke_circle(struct nk_draw_list*, struct nk_vec2 center, float radius, struct nk_color, unsigned int segs, float thickness); +NK_API void nk_draw_list_stroke_curve(struct nk_draw_list*, struct nk_vec2 p0, struct nk_vec2 cp0, struct nk_vec2 cp1, struct nk_vec2 p1, struct nk_color, unsigned int segments, float thickness); +NK_API void nk_draw_list_stroke_poly_line(struct nk_draw_list*, const struct nk_vec2 *pnts, const unsigned int cnt, struct nk_color, enum nk_draw_list_stroke, float thickness, enum nk_anti_aliasing); + +/* fill */ +NK_API void nk_draw_list_fill_rect(struct nk_draw_list*, struct nk_rect rect, struct nk_color, float rounding); +NK_API void nk_draw_list_fill_rect_multi_color(struct nk_draw_list*, struct nk_rect rect, struct nk_color left, struct nk_color top, struct nk_color right, struct nk_color bottom); +NK_API void nk_draw_list_fill_triangle(struct nk_draw_list*, struct nk_vec2 a, struct nk_vec2 b, struct nk_vec2 c, struct nk_color); +NK_API void nk_draw_list_fill_circle(struct nk_draw_list*, struct nk_vec2 center, float radius, struct nk_color col, unsigned int segs); +NK_API void nk_draw_list_fill_poly_convex(struct nk_draw_list*, const struct nk_vec2 *points, const unsigned int count, struct nk_color, enum nk_anti_aliasing); + +/* misc */ +NK_API void nk_draw_list_add_image(struct nk_draw_list*, struct nk_image texture, struct nk_rect rect, struct nk_color); +NK_API void nk_draw_list_add_text(struct nk_draw_list*, const struct nk_user_font*, struct nk_rect, const char *text, int len, float font_height, struct nk_color); +#ifdef NK_INCLUDE_COMMAND_USERDATA +NK_API void nk_draw_list_push_userdata(struct nk_draw_list*, nk_handle userdata); +#endif + +#endif + +/* =============================================================== + * + * GUI + * + * ===============================================================*/ +enum nk_style_item_type { + NK_STYLE_ITEM_COLOR, + NK_STYLE_ITEM_IMAGE +}; + +union nk_style_item_data { + struct nk_image image; + struct nk_color color; +}; + +struct nk_style_item { + enum nk_style_item_type type; + union nk_style_item_data data; +}; + +struct nk_style_text { + struct nk_color color; + struct nk_vec2 padding; +}; + +struct nk_style_button { + /* background */ + struct nk_style_item normal; + struct nk_style_item hover; + struct nk_style_item active; + struct nk_color border_color; + + /* text */ + struct nk_color text_background; + struct nk_color text_normal; + struct nk_color text_hover; + struct nk_color text_active; + nk_flags text_alignment; + + /* properties */ + float border; + float rounding; + struct nk_vec2 padding; + struct nk_vec2 image_padding; + struct nk_vec2 touch_padding; + + /* optional user callbacks */ + nk_handle userdata; + void(*draw_begin)(struct nk_command_buffer*, nk_handle userdata); + void(*draw_end)(struct nk_command_buffer*, nk_handle userdata); +}; + +struct nk_style_toggle { + /* background */ + struct nk_style_item normal; + struct nk_style_item hover; + struct nk_style_item active; + struct nk_color border_color; + + /* cursor */ + struct nk_style_item cursor_normal; + struct nk_style_item cursor_hover; + + /* text */ + struct nk_color text_normal; + struct nk_color text_hover; + struct nk_color text_active; + struct nk_color text_background; + nk_flags text_alignment; + + /* properties */ + struct nk_vec2 padding; + struct nk_vec2 touch_padding; + float spacing; + float border; + + /* optional user callbacks */ + nk_handle userdata; + void(*draw_begin)(struct nk_command_buffer*, nk_handle); + void(*draw_end)(struct nk_command_buffer*, nk_handle); +}; + +struct nk_style_selectable { + /* background (inactive) */ + struct nk_style_item normal; + struct nk_style_item hover; + struct nk_style_item pressed; + + /* background (active) */ + struct nk_style_item normal_active; + struct nk_style_item hover_active; + struct nk_style_item pressed_active; + + /* text color (inactive) */ + struct nk_color text_normal; + struct nk_color text_hover; + struct nk_color text_pressed; + + /* text color (active) */ + struct nk_color text_normal_active; + struct nk_color text_hover_active; + struct nk_color text_pressed_active; + struct nk_color text_background; + nk_flags text_alignment; + + /* properties */ + float rounding; + struct nk_vec2 padding; + struct nk_vec2 touch_padding; + struct nk_vec2 image_padding; + + /* optional user callbacks */ + nk_handle userdata; + void(*draw_begin)(struct nk_command_buffer*, nk_handle); + void(*draw_end)(struct nk_command_buffer*, nk_handle); +}; + +struct nk_style_slider { + /* background */ + struct nk_style_item normal; + struct nk_style_item hover; + struct nk_style_item active; + struct nk_color border_color; + + /* background bar */ + struct nk_color bar_normal; + struct nk_color bar_hover; + struct nk_color bar_active; + struct nk_color bar_filled; + + /* cursor */ + struct nk_style_item cursor_normal; + struct nk_style_item cursor_hover; + struct nk_style_item cursor_active; + + /* properties */ + float border; + float rounding; + float bar_height; + struct nk_vec2 padding; + struct nk_vec2 spacing; + struct nk_vec2 cursor_size; + + /* optional buttons */ + int show_buttons; + struct nk_style_button inc_button; + struct nk_style_button dec_button; + enum nk_symbol_type inc_symbol; + enum nk_symbol_type dec_symbol; + + /* optional user callbacks */ + nk_handle userdata; + void(*draw_begin)(struct nk_command_buffer*, nk_handle); + void(*draw_end)(struct nk_command_buffer*, nk_handle); +}; + +struct nk_style_progress { + /* background */ + struct nk_style_item normal; + struct nk_style_item hover; + struct nk_style_item active; + struct nk_color border_color; + + /* cursor */ + struct nk_style_item cursor_normal; + struct nk_style_item cursor_hover; + struct nk_style_item cursor_active; + struct nk_color cursor_border_color; + + /* properties */ + float rounding; + float border; + float cursor_border; + float cursor_rounding; + struct nk_vec2 padding; + + /* optional user callbacks */ + nk_handle userdata; + void(*draw_begin)(struct nk_command_buffer*, nk_handle); + void(*draw_end)(struct nk_command_buffer*, nk_handle); +}; + +struct nk_style_scrollbar { + /* background */ + struct nk_style_item normal; + struct nk_style_item hover; + struct nk_style_item active; + struct nk_color border_color; + + /* cursor */ + struct nk_style_item cursor_normal; + struct nk_style_item cursor_hover; + struct nk_style_item cursor_active; + struct nk_color cursor_border_color; + + /* properties */ + float border; + float rounding; + float border_cursor; + float rounding_cursor; + struct nk_vec2 padding; + + /* optional buttons */ + int show_buttons; + struct nk_style_button inc_button; + struct nk_style_button dec_button; + enum nk_symbol_type inc_symbol; + enum nk_symbol_type dec_symbol; + + /* optional user callbacks */ + nk_handle userdata; + void(*draw_begin)(struct nk_command_buffer*, nk_handle); + void(*draw_end)(struct nk_command_buffer*, nk_handle); +}; + +struct nk_style_edit { + /* background */ + struct nk_style_item normal; + struct nk_style_item hover; + struct nk_style_item active; + struct nk_color border_color; + struct nk_style_scrollbar scrollbar; + + /* cursor */ + struct nk_color cursor_normal; + struct nk_color cursor_hover; + struct nk_color cursor_text_normal; + struct nk_color cursor_text_hover; + + /* text (unselected) */ + struct nk_color text_normal; + struct nk_color text_hover; + struct nk_color text_active; + + /* text (selected) */ + struct nk_color selected_normal; + struct nk_color selected_hover; + struct nk_color selected_text_normal; + struct nk_color selected_text_hover; + + /* properties */ + float border; + float rounding; + float cursor_size; + struct nk_vec2 scrollbar_size; + struct nk_vec2 padding; + float row_padding; +}; + +struct nk_style_property { + /* background */ + struct nk_style_item normal; + struct nk_style_item hover; + struct nk_style_item active; + struct nk_color border_color; + + /* text */ + struct nk_color label_normal; + struct nk_color label_hover; + struct nk_color label_active; + + /* symbols */ + enum nk_symbol_type sym_left; + enum nk_symbol_type sym_right; + + /* properties */ + float border; + float rounding; + struct nk_vec2 padding; + + struct nk_style_edit edit; + struct nk_style_button inc_button; + struct nk_style_button dec_button; + + /* optional user callbacks */ + nk_handle userdata; + void(*draw_begin)(struct nk_command_buffer*, nk_handle); + void(*draw_end)(struct nk_command_buffer*, nk_handle); +}; + +struct nk_style_chart { + /* colors */ + struct nk_style_item background; + struct nk_color border_color; + struct nk_color selected_color; + struct nk_color color; + + /* properties */ + float border; + float rounding; + struct nk_vec2 padding; +}; + +struct nk_style_combo { + /* background */ + struct nk_style_item normal; + struct nk_style_item hover; + struct nk_style_item active; + struct nk_color border_color; + + /* label */ + struct nk_color label_normal; + struct nk_color label_hover; + struct nk_color label_active; + + /* symbol */ + struct nk_color symbol_normal; + struct nk_color symbol_hover; + struct nk_color symbol_active; + + /* button */ + struct nk_style_button button; + enum nk_symbol_type sym_normal; + enum nk_symbol_type sym_hover; + enum nk_symbol_type sym_active; + + /* properties */ + float border; + float rounding; + struct nk_vec2 content_padding; + struct nk_vec2 button_padding; + struct nk_vec2 spacing; +}; + +struct nk_style_tab { + /* background */ + struct nk_style_item background; + struct nk_color border_color; + struct nk_color text; + + /* button */ + struct nk_style_button tab_maximize_button; + struct nk_style_button tab_minimize_button; + struct nk_style_button node_maximize_button; + struct nk_style_button node_minimize_button; + enum nk_symbol_type sym_minimize; + enum nk_symbol_type sym_maximize; + + /* properties */ + float border; + float rounding; + float indent; + struct nk_vec2 padding; + struct nk_vec2 spacing; +}; + +enum nk_style_header_align { + NK_HEADER_LEFT, + NK_HEADER_RIGHT +}; +struct nk_style_window_header { + /* background */ + struct nk_style_item normal; + struct nk_style_item hover; + struct nk_style_item active; + + /* button */ + struct nk_style_button close_button; + struct nk_style_button minimize_button; + enum nk_symbol_type close_symbol; + enum nk_symbol_type minimize_symbol; + enum nk_symbol_type maximize_symbol; + + /* title */ + struct nk_color label_normal; + struct nk_color label_hover; + struct nk_color label_active; + + /* properties */ + enum nk_style_header_align align; + struct nk_vec2 padding; + struct nk_vec2 label_padding; + struct nk_vec2 spacing; +}; + +struct nk_style_window { + struct nk_style_window_header header; + struct nk_style_item fixed_background; + struct nk_color background; + + struct nk_color border_color; + struct nk_color popup_border_color; + struct nk_color combo_border_color; + struct nk_color contextual_border_color; + struct nk_color menu_border_color; + struct nk_color group_border_color; + struct nk_color tooltip_border_color; + struct nk_style_item scaler; + + float border; + float combo_border; + float contextual_border; + float menu_border; + float group_border; + float tooltip_border; + float popup_border; + float min_row_height_padding; + + float rounding; + struct nk_vec2 spacing; + struct nk_vec2 scrollbar_size; + struct nk_vec2 min_size; + + struct nk_vec2 padding; + struct nk_vec2 group_padding; + struct nk_vec2 popup_padding; + struct nk_vec2 combo_padding; + struct nk_vec2 contextual_padding; + struct nk_vec2 menu_padding; + struct nk_vec2 tooltip_padding; +}; + +struct nk_style { + const struct nk_user_font *font; + const struct nk_cursor *cursors[NK_CURSOR_COUNT]; + const struct nk_cursor *cursor_active; + struct nk_cursor *cursor_last; + int cursor_visible; + + struct nk_style_text text; + struct nk_style_button button; + struct nk_style_button contextual_button; + struct nk_style_button menu_button; + struct nk_style_toggle option; + struct nk_style_toggle checkbox; + struct nk_style_selectable selectable; + struct nk_style_slider slider; + struct nk_style_progress progress; + struct nk_style_property property; + struct nk_style_edit edit; + struct nk_style_chart chart; + struct nk_style_scrollbar scrollh; + struct nk_style_scrollbar scrollv; + struct nk_style_tab tab; + struct nk_style_combo combo; + struct nk_style_window window; +}; + +NK_API struct nk_style_item nk_style_item_image(struct nk_image img); +NK_API struct nk_style_item nk_style_item_color(struct nk_color); +NK_API struct nk_style_item nk_style_item_hide(void); + +/*============================================================== + * PANEL + * =============================================================*/ +#ifndef NK_MAX_LAYOUT_ROW_TEMPLATE_COLUMNS +#define NK_MAX_LAYOUT_ROW_TEMPLATE_COLUMNS 16 +#endif +#ifndef NK_CHART_MAX_SLOT +#define NK_CHART_MAX_SLOT 4 +#endif + +enum nk_panel_type { + NK_PANEL_WINDOW = NK_FLAG(0), + NK_PANEL_GROUP = NK_FLAG(1), + NK_PANEL_POPUP = NK_FLAG(2), + NK_PANEL_CONTEXTUAL = NK_FLAG(4), + NK_PANEL_COMBO = NK_FLAG(5), + NK_PANEL_MENU = NK_FLAG(6), + NK_PANEL_TOOLTIP = NK_FLAG(7) +}; +enum nk_panel_set { + NK_PANEL_SET_NONBLOCK = NK_PANEL_CONTEXTUAL|NK_PANEL_COMBO|NK_PANEL_MENU|NK_PANEL_TOOLTIP, + NK_PANEL_SET_POPUP = NK_PANEL_SET_NONBLOCK|NK_PANEL_POPUP, + NK_PANEL_SET_SUB = NK_PANEL_SET_POPUP|NK_PANEL_GROUP +}; + +struct nk_chart_slot { + enum nk_chart_type type; + struct nk_color color; + struct nk_color highlight; + float min, max, range; + int count; + struct nk_vec2 last; + int index; +}; + +struct nk_chart { + int slot; + float x, y, w, h; + struct nk_chart_slot slots[NK_CHART_MAX_SLOT]; +}; + +enum nk_panel_row_layout_type { + NK_LAYOUT_DYNAMIC_FIXED = 0, + NK_LAYOUT_DYNAMIC_ROW, + NK_LAYOUT_DYNAMIC_FREE, + NK_LAYOUT_DYNAMIC, + NK_LAYOUT_STATIC_FIXED, + NK_LAYOUT_STATIC_ROW, + NK_LAYOUT_STATIC_FREE, + NK_LAYOUT_STATIC, + NK_LAYOUT_TEMPLATE, + NK_LAYOUT_COUNT +}; +struct nk_row_layout { + enum nk_panel_row_layout_type type; + int index; + float height; + float min_height; + int columns; + const float *ratio; + float item_width; + float item_height; + float item_offset; + float filled; + struct nk_rect item; + int tree_depth; + float templates[NK_MAX_LAYOUT_ROW_TEMPLATE_COLUMNS]; +}; + +struct nk_popup_buffer { + nk_size begin; + nk_size parent; + nk_size last; + nk_size end; + int active; +}; + +struct nk_menu_state { + float x, y, w, h; + struct nk_scroll offset; +}; + +struct nk_panel { + enum nk_panel_type type; + nk_flags flags; + struct nk_rect bounds; + nk_uint *offset_x; + nk_uint *offset_y; + float at_x, at_y, max_x; + float footer_height; + float header_height; + float border; + unsigned int has_scrolling; + struct nk_rect clip; + struct nk_menu_state menu; + struct nk_row_layout row; + struct nk_chart chart; + struct nk_command_buffer *buffer; + struct nk_panel *parent; +}; + +/*============================================================== + * WINDOW + * =============================================================*/ +#ifndef NK_WINDOW_MAX_NAME +#define NK_WINDOW_MAX_NAME 64 +#endif + +struct nk_table; +enum nk_window_flags { + NK_WINDOW_PRIVATE = NK_FLAG(11), + NK_WINDOW_DYNAMIC = NK_WINDOW_PRIVATE, + /* special window type growing up in height while being filled to a certain maximum height */ + NK_WINDOW_ROM = NK_FLAG(12), + /* sets window widgets into a read only mode and does not allow input changes */ + NK_WINDOW_NOT_INTERACTIVE = NK_WINDOW_ROM|NK_WINDOW_NO_INPUT, + /* prevents all interaction caused by input to either window or widgets inside */ + NK_WINDOW_HIDDEN = NK_FLAG(13), + /* Hides window and stops any window interaction and drawing */ + NK_WINDOW_CLOSED = NK_FLAG(14), + /* Directly closes and frees the window at the end of the frame */ + NK_WINDOW_MINIMIZED = NK_FLAG(15), + /* marks the window as minimized */ + NK_WINDOW_REMOVE_ROM = NK_FLAG(16) + /* Removes read only mode at the end of the window */ +}; + +struct nk_popup_state { + struct nk_window *win; + enum nk_panel_type type; + struct nk_popup_buffer buf; + nk_hash name; + int active; + unsigned combo_count; + unsigned con_count, con_old; + unsigned active_con; + struct nk_rect header; +}; + +struct nk_edit_state { + nk_hash name; + unsigned int seq; + unsigned int old; + int active, prev; + int cursor; + int sel_start; + int sel_end; + struct nk_scroll scrollbar; + unsigned char mode; + unsigned char single_line; +}; + +struct nk_property_state { + int active, prev; + char buffer[NK_MAX_NUMBER_BUFFER]; + int length; + int cursor; + int select_start; + int select_end; + nk_hash name; + unsigned int seq; + unsigned int old; + int state; +}; + +struct nk_window { + unsigned int seq; + nk_hash name; + char name_string[NK_WINDOW_MAX_NAME]; + nk_flags flags; + + struct nk_rect bounds; + struct nk_scroll scrollbar; + struct nk_command_buffer buffer; + struct nk_panel *layout; + float scrollbar_hiding_timer; + + /* persistent widget state */ + struct nk_property_state property; + struct nk_popup_state popup; + struct nk_edit_state edit; + unsigned int scrolled; + + struct nk_table *tables; + unsigned int table_count; + + /* window list hooks */ + struct nk_window *next; + struct nk_window *prev; + struct nk_window *parent; +}; + +/*============================================================== + * STACK + * =============================================================*/ +/* The style modifier stack can be used to temporarily change a + * property inside `nk_style`. For example if you want a special + * red button you can temporarily push the old button color onto a stack + * draw the button with a red color and then you just pop the old color + * back from the stack: + * + * nk_style_push_style_item(ctx, &ctx->style.button.normal, nk_style_item_color(nk_rgb(255,0,0))); + * nk_style_push_style_item(ctx, &ctx->style.button.hover, nk_style_item_color(nk_rgb(255,0,0))); + * nk_style_push_style_item(ctx, &ctx->style.button.active, nk_style_item_color(nk_rgb(255,0,0))); + * nk_style_push_vec2(ctx, &cx->style.button.padding, nk_vec2(2,2)); + * + * nk_button(...); + * + * nk_style_pop_style_item(ctx); + * nk_style_pop_style_item(ctx); + * nk_style_pop_style_item(ctx); + * nk_style_pop_vec2(ctx); + * + * Nuklear has a stack for style_items, float properties, vector properties, + * flags, colors, fonts and for button_behavior. Each has it's own fixed size stack + * which can be changed at compile time. + */ +#ifndef NK_BUTTON_BEHAVIOR_STACK_SIZE +#define NK_BUTTON_BEHAVIOR_STACK_SIZE 8 +#endif + +#ifndef NK_FONT_STACK_SIZE +#define NK_FONT_STACK_SIZE 8 +#endif + +#ifndef NK_STYLE_ITEM_STACK_SIZE +#define NK_STYLE_ITEM_STACK_SIZE 16 +#endif + +#ifndef NK_FLOAT_STACK_SIZE +#define NK_FLOAT_STACK_SIZE 32 +#endif + +#ifndef NK_VECTOR_STACK_SIZE +#define NK_VECTOR_STACK_SIZE 16 +#endif + +#ifndef NK_FLAGS_STACK_SIZE +#define NK_FLAGS_STACK_SIZE 32 +#endif + +#ifndef NK_COLOR_STACK_SIZE +#define NK_COLOR_STACK_SIZE 32 +#endif + +#define NK_CONFIGURATION_STACK_TYPE(prefix, name, type)\ + struct nk_config_stack_##name##_element {\ + prefix##_##type *address;\ + prefix##_##type old_value;\ + } +#define NK_CONFIG_STACK(type,size)\ + struct nk_config_stack_##type {\ + int head;\ + struct nk_config_stack_##type##_element elements[size];\ + } + +#define nk_float float +NK_CONFIGURATION_STACK_TYPE(struct nk, style_item, style_item); +NK_CONFIGURATION_STACK_TYPE(nk ,float, float); +NK_CONFIGURATION_STACK_TYPE(struct nk, vec2, vec2); +NK_CONFIGURATION_STACK_TYPE(nk ,flags, flags); +NK_CONFIGURATION_STACK_TYPE(struct nk, color, color); +NK_CONFIGURATION_STACK_TYPE(const struct nk, user_font, user_font*); +NK_CONFIGURATION_STACK_TYPE(enum nk, button_behavior, button_behavior); + +NK_CONFIG_STACK(style_item, NK_STYLE_ITEM_STACK_SIZE); +NK_CONFIG_STACK(float, NK_FLOAT_STACK_SIZE); +NK_CONFIG_STACK(vec2, NK_VECTOR_STACK_SIZE); +NK_CONFIG_STACK(flags, NK_FLAGS_STACK_SIZE); +NK_CONFIG_STACK(color, NK_COLOR_STACK_SIZE); +NK_CONFIG_STACK(user_font, NK_FONT_STACK_SIZE); +NK_CONFIG_STACK(button_behavior, NK_BUTTON_BEHAVIOR_STACK_SIZE); + +struct nk_configuration_stacks { + struct nk_config_stack_style_item style_items; + struct nk_config_stack_float floats; + struct nk_config_stack_vec2 vectors; + struct nk_config_stack_flags flags; + struct nk_config_stack_color colors; + struct nk_config_stack_user_font fonts; + struct nk_config_stack_button_behavior button_behaviors; +}; + +/*============================================================== + * CONTEXT + * =============================================================*/ +#define NK_VALUE_PAGE_CAPACITY \ + (((NK_MAX(sizeof(struct nk_window),sizeof(struct nk_panel)) / sizeof(nk_uint))) / 2) + +struct nk_table { + unsigned int seq; + unsigned int size; + nk_hash keys[NK_VALUE_PAGE_CAPACITY]; + nk_uint values[NK_VALUE_PAGE_CAPACITY]; + struct nk_table *next, *prev; +}; + +union nk_page_data { + struct nk_table tbl; + struct nk_panel pan; + struct nk_window win; +}; + +struct nk_page_element { + union nk_page_data data; + struct nk_page_element *next; + struct nk_page_element *prev; +}; + +struct nk_page { + unsigned int size; + struct nk_page *next; + struct nk_page_element win[1]; +}; + +struct nk_pool { + struct nk_allocator alloc; + enum nk_allocation_type type; + unsigned int page_count; + struct nk_page *pages; + struct nk_page_element *freelist; + unsigned capacity; + nk_size size; + nk_size cap; +}; + +struct nk_context { +/* public: can be accessed freely */ + struct nk_input input; + struct nk_style style; + struct nk_buffer memory; + struct nk_clipboard clip; + nk_flags last_widget_state; + enum nk_button_behavior button_behavior; + struct nk_configuration_stacks stacks; + float delta_time_seconds; + +/* private: + should only be accessed if you + know what you are doing */ +#ifdef NK_INCLUDE_VERTEX_BUFFER_OUTPUT + struct nk_draw_list draw_list; +#endif +#ifdef NK_INCLUDE_COMMAND_USERDATA + nk_handle userdata; +#endif + /* text editor objects are quite big because of an internal + * undo/redo stack. Therefore it does not make sense to have one for + * each window for temporary use cases, so I only provide *one* instance + * for all windows. This works because the content is cleared anyway */ + struct nk_text_edit text_edit; + /* draw buffer used for overlay drawing operation like cursor */ + struct nk_command_buffer overlay; + + /* windows */ + int build; + int use_pool; + struct nk_pool pool; + struct nk_window *begin; + struct nk_window *end; + struct nk_window *active; + struct nk_window *current; + struct nk_page_element *freelist; + unsigned int count; + unsigned int seq; +}; + +/* ============================================================== + * MATH + * =============================================================== */ +#define NK_PI 3.141592654f +#define NK_UTF_INVALID 0xFFFD +#define NK_MAX_FLOAT_PRECISION 2 + +#define NK_UNUSED(x) ((void)(x)) +#define NK_SATURATE(x) (NK_MAX(0, NK_MIN(1.0f, x))) +#define NK_LEN(a) (sizeof(a)/sizeof(a)[0]) +#define NK_ABS(a) (((a) < 0) ? -(a) : (a)) +#define NK_BETWEEN(x, a, b) ((a) <= (x) && (x) < (b)) +#define NK_INBOX(px, py, x, y, w, h)\ + (NK_BETWEEN(px,x,x+w) && NK_BETWEEN(py,y,y+h)) +#define NK_INTERSECT(x0, y0, w0, h0, x1, y1, w1, h1) \ + (!(((x1 > (x0 + w0)) || ((x1 + w1) < x0) || (y1 > (y0 + h0)) || (y1 + h1) < y0))) +#define NK_CONTAINS(x, y, w, h, bx, by, bw, bh)\ + (NK_INBOX(x,y, bx, by, bw, bh) && NK_INBOX(x+w,y+h, bx, by, bw, bh)) + +#define nk_vec2_sub(a, b) nk_vec2((a).x - (b).x, (a).y - (b).y) +#define nk_vec2_add(a, b) nk_vec2((a).x + (b).x, (a).y + (b).y) +#define nk_vec2_len_sqr(a) ((a).x*(a).x+(a).y*(a).y) +#define nk_vec2_muls(a, t) nk_vec2((a).x * (t), (a).y * (t)) + +#define nk_ptr_add(t, p, i) ((t*)((void*)((nk_byte*)(p) + (i)))) +#define nk_ptr_add_const(t, p, i) ((const t*)((const void*)((const nk_byte*)(p) + (i)))) +#define nk_zero_struct(s) nk_zero(&s, sizeof(s)) + +/* ============================================================== + * ALIGNMENT + * =============================================================== */ +/* Pointer to Integer type conversion for pointer alignment */ +#if defined(__PTRDIFF_TYPE__) /* This case should work for GCC*/ +# define NK_UINT_TO_PTR(x) ((void*)(__PTRDIFF_TYPE__)(x)) +# define NK_PTR_TO_UINT(x) ((nk_size)(__PTRDIFF_TYPE__)(x)) +#elif !defined(__GNUC__) /* works for compilers other than LLVM */ +# define NK_UINT_TO_PTR(x) ((void*)&((char*)0)[x]) +# define NK_PTR_TO_UINT(x) ((nk_size)(((char*)x)-(char*)0)) +#elif defined(NK_USE_FIXED_TYPES) /* used if we have */ +# define NK_UINT_TO_PTR(x) ((void*)(uintptr_t)(x)) +# define NK_PTR_TO_UINT(x) ((uintptr_t)(x)) +#else /* generates warning but works */ +# define NK_UINT_TO_PTR(x) ((void*)(x)) +# define NK_PTR_TO_UINT(x) ((nk_size)(x)) +#endif + +#define NK_ALIGN_PTR(x, mask)\ + (NK_UINT_TO_PTR((NK_PTR_TO_UINT((nk_byte*)(x) + (mask-1)) & ~(mask-1)))) +#define NK_ALIGN_PTR_BACK(x, mask)\ + (NK_UINT_TO_PTR((NK_PTR_TO_UINT((nk_byte*)(x)) & ~(mask-1)))) + +#define NK_OFFSETOF(st,m) ((nk_ptr)&(((st*)0)->m)) +#define NK_CONTAINER_OF(ptr,type,member)\ + (type*)((void*)((char*)(1 ? (ptr): &((type*)0)->member) - NK_OFFSETOF(type, member))) + +#ifdef __cplusplus +} +#endif + +#ifdef __cplusplus +template struct nk_alignof; +template struct nk_helper{enum {value = size_diff};}; +template struct nk_helper{enum {value = nk_alignof::value};}; +template struct nk_alignof{struct Big {T x; char c;}; enum { + diff = sizeof(Big) - sizeof(T), value = nk_helper::value};}; +#define NK_ALIGNOF(t) (nk_alignof::value) +#elif defined(_MSC_VER) +#define NK_ALIGNOF(t) (__alignof(t)) +#else +#define NK_ALIGNOF(t) ((char*)(&((struct {char c; t _h;}*)0)->_h) - (char*)0) +#endif + +#endif /* NK_NUKLEAR_H_ */ +/* + * ============================================================== + * + * IMPLEMENTATION + * + * =============================================================== + */ +#ifdef NK_IMPLEMENTATION + +#ifndef NK_POOL_DEFAULT_CAPACITY +#define NK_POOL_DEFAULT_CAPACITY 16 +#endif + +#ifndef NK_DEFAULT_COMMAND_BUFFER_SIZE +#define NK_DEFAULT_COMMAND_BUFFER_SIZE (4*1024) +#endif + +#ifndef NK_BUFFER_DEFAULT_INITIAL_SIZE +#define NK_BUFFER_DEFAULT_INITIAL_SIZE (4*1024) +#endif + +/* standard library headers */ +#ifdef NK_INCLUDE_DEFAULT_ALLOCATOR +#include /* malloc, free */ +#endif +#ifdef NK_INCLUDE_STANDARD_IO +#include /* fopen, fclose,... */ +#endif +#ifdef NK_INCLUDE_STANDARD_VARARGS +#include /* valist, va_start, va_end, ... */ +#endif +#ifndef NK_ASSERT +#include +#define NK_ASSERT(expr) assert(expr) +#endif + +#ifndef NK_MEMSET +#define NK_MEMSET nk_memset +#endif +#ifndef NK_MEMCPY +#define NK_MEMCPY nk_memcopy +#endif +#ifndef NK_SQRT +#define NK_SQRT nk_sqrt +#endif +#ifndef NK_SIN +#define NK_SIN nk_sin +#endif +#ifndef NK_COS +#define NK_COS nk_cos +#endif +#ifndef NK_STRTOD +#define NK_STRTOD nk_strtod +#endif +#ifndef NK_DTOA +#define NK_DTOA nk_dtoa +#endif + +#define NK_DEFAULT (-1) + +#ifndef NK_VSNPRINTF +/* If your compiler does support `vsnprintf` I would highly recommend + * defining this to vsnprintf instead since `vsprintf` is basically + * unbelievable unsafe and should *NEVER* be used. But I have to support + * it since C89 only provides this unsafe version. */ + #if (defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 199901L)) ||\ + (defined(__cplusplus) && (__cplusplus >= 201103L)) || \ + (defined(_POSIX_C_SOURCE) && (_POSIX_C_SOURCE >= 200112L)) ||\ + (defined(_XOPEN_SOURCE) && (_XOPEN_SOURCE >= 500)) ||\ + defined(_ISOC99_SOURCE) || defined(_BSD_SOURCE) + #define NK_VSNPRINTF(s,n,f,a) vsnprintf(s,n,f,a) + #else + #define NK_VSNPRINTF(s,n,f,a) vsprintf(s,f,a) + #endif +#endif + +#define NK_SCHAR_MIN (-127) +#define NK_SCHAR_MAX 127 +#define NK_UCHAR_MIN 0 +#define NK_UCHAR_MAX 256 +#define NK_SSHORT_MIN (-32767) +#define NK_SSHORT_MAX 32767 +#define NK_USHORT_MIN 0 +#define NK_USHORT_MAX 65535 +#define NK_SINT_MIN (-2147483647) +#define NK_SINT_MAX 2147483647 +#define NK_UINT_MIN 0 +#define NK_UINT_MAX 4294967295u + +/* Make sure correct type size: + * This will fire with a negative subscript error if the type sizes + * are set incorrectly by the compiler, and compile out if not */ +NK_STATIC_ASSERT(sizeof(nk_size) >= sizeof(void*)); +NK_STATIC_ASSERT(sizeof(nk_ptr) == sizeof(void*)); +NK_STATIC_ASSERT(sizeof(nk_flags) >= 4); +NK_STATIC_ASSERT(sizeof(nk_rune) >= 4); +NK_STATIC_ASSERT(sizeof(nk_ushort) == 2); +NK_STATIC_ASSERT(sizeof(nk_short) == 2); +NK_STATIC_ASSERT(sizeof(nk_uint) == 4); +NK_STATIC_ASSERT(sizeof(nk_int) == 4); +NK_STATIC_ASSERT(sizeof(nk_byte) == 1); + +NK_GLOBAL const struct nk_rect nk_null_rect = {-8192.0f, -8192.0f, 16384, 16384}; +#define NK_FLOAT_PRECISION 0.00000000000001 + +NK_GLOBAL const struct nk_color nk_red = {255,0,0,255}; +NK_GLOBAL const struct nk_color nk_green = {0,255,0,255}; +NK_GLOBAL const struct nk_color nk_blue = {0,0,255,255}; +NK_GLOBAL const struct nk_color nk_white = {255,255,255,255}; +NK_GLOBAL const struct nk_color nk_black = {0,0,0,255}; +NK_GLOBAL const struct nk_color nk_yellow = {255,255,0,255}; + +/* + * ============================================================== + * + * MATH + * + * =============================================================== + */ +/* Since nuklear is supposed to work on all systems providing floating point + math without any dependencies I also had to implement my own math functions + for sqrt, sin and cos. Since the actual highly accurate implementations for + the standard library functions are quite complex and I do not need high + precision for my use cases I use approximations. + + Sqrt + ---- + For square root nuklear uses the famous fast inverse square root: + https://en.wikipedia.org/wiki/Fast_inverse_square_root with + slightly tweaked magic constant. While on today's hardware it is + probably not faster it is still fast and accurate enough for + nuklear's use cases. IMPORTANT: this requires float format IEEE 754 + + Sine/Cosine + ----------- + All constants inside both function are generated Remez's minimax + approximations for value range 0...2*PI. The reason why I decided to + approximate exactly that range is that nuklear only needs sine and + cosine to generate circles which only requires that exact range. + In addition I used Remez instead of Taylor for additional precision: + www.lolengine.net/blog/2011/12/21/better-function-approximations. + + The tool I used to generate constants for both sine and cosine + (it can actually approximate a lot more functions) can be + found here: www.lolengine.net/wiki/oss/lolremez +*/ +NK_INTERN float +nk_inv_sqrt(float number) +{ + float x2; + const float threehalfs = 1.5f; + union {nk_uint i; float f;} conv = {0}; + conv.f = number; + x2 = number * 0.5f; + conv.i = 0x5f375A84 - (conv.i >> 1); + conv.f = conv.f * (threehalfs - (x2 * conv.f * conv.f)); + return conv.f; +} + +NK_INTERN float +nk_sqrt(float x) +{ + return x * nk_inv_sqrt(x); +} + +NK_INTERN float +nk_sin(float x) +{ + NK_STORAGE const float a0 = +1.91059300966915117e-31f; + NK_STORAGE const float a1 = +1.00086760103908896f; + NK_STORAGE const float a2 = -1.21276126894734565e-2f; + NK_STORAGE const float a3 = -1.38078780785773762e-1f; + NK_STORAGE const float a4 = -2.67353392911981221e-2f; + NK_STORAGE const float a5 = +2.08026600266304389e-2f; + NK_STORAGE const float a6 = -3.03996055049204407e-3f; + NK_STORAGE const float a7 = +1.38235642404333740e-4f; + return a0 + x*(a1 + x*(a2 + x*(a3 + x*(a4 + x*(a5 + x*(a6 + x*a7)))))); +} + +NK_INTERN float +nk_cos(float x) +{ + NK_STORAGE const float a0 = +1.00238601909309722f; + NK_STORAGE const float a1 = -3.81919947353040024e-2f; + NK_STORAGE const float a2 = -3.94382342128062756e-1f; + NK_STORAGE const float a3 = -1.18134036025221444e-1f; + NK_STORAGE const float a4 = +1.07123798512170878e-1f; + NK_STORAGE const float a5 = -1.86637164165180873e-2f; + NK_STORAGE const float a6 = +9.90140908664079833e-4f; + NK_STORAGE const float a7 = -5.23022132118824778e-14f; + return a0 + x*(a1 + x*(a2 + x*(a3 + x*(a4 + x*(a5 + x*(a6 + x*a7)))))); +} + +NK_INTERN nk_uint +nk_round_up_pow2(nk_uint v) +{ + v--; + v |= v >> 1; + v |= v >> 2; + v |= v >> 4; + v |= v >> 8; + v |= v >> 16; + v++; + return v; +} + +NK_API struct nk_rect +nk_get_null_rect(void) +{ + return nk_null_rect; +} + +NK_API struct nk_rect +nk_rect(float x, float y, float w, float h) +{ + struct nk_rect r; + r.x = x; r.y = y; + r.w = w; r.h = h; + return r; +} + +NK_API struct nk_rect +nk_recti(int x, int y, int w, int h) +{ + struct nk_rect r; + r.x = (float)x; + r.y = (float)y; + r.w = (float)w; + r.h = (float)h; + return r; +} + +NK_API struct nk_rect +nk_recta(struct nk_vec2 pos, struct nk_vec2 size) +{ + return nk_rect(pos.x, pos.y, size.x, size.y); +} + +NK_API struct nk_rect +nk_rectv(const float *r) +{ + return nk_rect(r[0], r[1], r[2], r[3]); +} + +NK_API struct nk_rect +nk_rectiv(const int *r) +{ + return nk_recti(r[0], r[1], r[2], r[3]); +} + +NK_API struct nk_vec2 +nk_rect_pos(struct nk_rect r) +{ + struct nk_vec2 ret; + ret.x = r.x; ret.y = r.y; + return ret; +} + +NK_API struct nk_vec2 +nk_rect_size(struct nk_rect r) +{ + struct nk_vec2 ret; + ret.x = r.w; ret.y = r.h; + return ret; +} + +NK_INTERN struct nk_rect +nk_shrink_rect(struct nk_rect r, float amount) +{ + struct nk_rect res; + r.w = NK_MAX(r.w, 2 * amount); + r.h = NK_MAX(r.h, 2 * amount); + res.x = r.x + amount; + res.y = r.y + amount; + res.w = r.w - 2 * amount; + res.h = r.h - 2 * amount; + return res; +} + +NK_INTERN struct nk_rect +nk_pad_rect(struct nk_rect r, struct nk_vec2 pad) +{ + r.w = NK_MAX(r.w, 2 * pad.x); + r.h = NK_MAX(r.h, 2 * pad.y); + r.x += pad.x; r.y += pad.y; + r.w -= 2 * pad.x; + r.h -= 2 * pad.y; + return r; +} + +NK_API struct nk_vec2 +nk_vec2(float x, float y) +{ + struct nk_vec2 ret; + ret.x = x; ret.y = y; + return ret; +} + +NK_API struct nk_vec2 +nk_vec2i(int x, int y) +{ + struct nk_vec2 ret; + ret.x = (float)x; + ret.y = (float)y; + return ret; +} + +NK_API struct nk_vec2 +nk_vec2v(const float *v) +{ + return nk_vec2(v[0], v[1]); +} + +NK_API struct nk_vec2 +nk_vec2iv(const int *v) +{ + return nk_vec2i(v[0], v[1]); +} + +/* + * ============================================================== + * + * UTIL + * + * =============================================================== + */ +NK_INTERN int nk_str_match_here(const char *regexp, const char *text); +NK_INTERN int nk_str_match_star(int c, const char *regexp, const char *text); +NK_INTERN int nk_is_lower(int c) {return (c >= 'a' && c <= 'z') || (c >= 0xE0 && c <= 0xFF);} +NK_INTERN int nk_is_upper(int c){return (c >= 'A' && c <= 'Z') || (c >= 0xC0 && c <= 0xDF);} +NK_INTERN int nk_to_upper(int c) {return (c >= 'a' && c <= 'z') ? (c - ('a' - 'A')) : c;} +NK_INTERN int nk_to_lower(int c) {return (c >= 'A' && c <= 'Z') ? (c - ('a' + 'A')) : c;} + +NK_INTERN void* +nk_memcopy(void *dst0, const void *src0, nk_size length) +{ + nk_ptr t; + char *dst = (char*)dst0; + const char *src = (const char*)src0; + if (length == 0 || dst == src) + goto done; + + #define nk_word int + #define nk_wsize sizeof(nk_word) + #define nk_wmask (nk_wsize-1) + #define NK_TLOOP(s) if (t) NK_TLOOP1(s) + #define NK_TLOOP1(s) do { s; } while (--t) + + if (dst < src) { + t = (nk_ptr)src; /* only need low bits */ + if ((t | (nk_ptr)dst) & nk_wmask) { + if ((t ^ (nk_ptr)dst) & nk_wmask || length < nk_wsize) + t = length; + else + t = nk_wsize - (t & nk_wmask); + length -= t; + NK_TLOOP1(*dst++ = *src++); + } + t = length / nk_wsize; + NK_TLOOP(*(nk_word*)(void*)dst = *(const nk_word*)(const void*)src; + src += nk_wsize; dst += nk_wsize); + t = length & nk_wmask; + NK_TLOOP(*dst++ = *src++); + } else { + src += length; + dst += length; + t = (nk_ptr)src; + if ((t | (nk_ptr)dst) & nk_wmask) { + if ((t ^ (nk_ptr)dst) & nk_wmask || length <= nk_wsize) + t = length; + else + t &= nk_wmask; + length -= t; + NK_TLOOP1(*--dst = *--src); + } + t = length / nk_wsize; + NK_TLOOP(src -= nk_wsize; dst -= nk_wsize; + *(nk_word*)(void*)dst = *(const nk_word*)(const void*)src); + t = length & nk_wmask; + NK_TLOOP(*--dst = *--src); + } + #undef nk_word + #undef nk_wsize + #undef nk_wmask + #undef NK_TLOOP + #undef NK_TLOOP1 +done: + return (dst0); +} + +NK_INTERN void +nk_memset(void *ptr, int c0, nk_size size) +{ + #define nk_word unsigned + #define nk_wsize sizeof(nk_word) + #define nk_wmask (nk_wsize - 1) + nk_byte *dst = (nk_byte*)ptr; + unsigned c = 0; + nk_size t = 0; + + if ((c = (nk_byte)c0) != 0) { + c = (c << 8) | c; /* at least 16-bits */ + if (sizeof(unsigned int) > 2) + c = (c << 16) | c; /* at least 32-bits*/ + } + + /* too small of a word count */ + dst = (nk_byte*)ptr; + if (size < 3 * nk_wsize) { + while (size--) *dst++ = (nk_byte)c0; + return; + } + + /* align destination */ + if ((t = NK_PTR_TO_UINT(dst) & nk_wmask) != 0) { + t = nk_wsize -t; + size -= t; + do { + *dst++ = (nk_byte)c0; + } while (--t != 0); + } + + /* fill word */ + t = size / nk_wsize; + do { + *(nk_word*)((void*)dst) = c; + dst += nk_wsize; + } while (--t != 0); + + /* fill trailing bytes */ + t = (size & nk_wmask); + if (t != 0) { + do { + *dst++ = (nk_byte)c0; + } while (--t != 0); + } + + #undef nk_word + #undef nk_wsize + #undef nk_wmask +} + +NK_INTERN void +nk_zero(void *ptr, nk_size size) +{ + NK_ASSERT(ptr); + NK_MEMSET(ptr, 0, size); +} + +NK_API int +nk_strlen(const char *str) +{ + int siz = 0; + NK_ASSERT(str); + while (str && *str++ != '\0') siz++; + return siz; +} + +NK_API int +nk_strtoi(const char *str, const char **endptr) +{ + int neg = 1; + const char *p = str; + int value = 0; + + NK_ASSERT(str); + if (!str) return 0; + + /* skip whitespace */ + while (*p == ' ') p++; + if (*p == '-') { + neg = -1; + p++; + } + while (*p && *p >= '0' && *p <= '9') { + value = value * 10 + (int) (*p - '0'); + p++; + } + if (endptr) + *endptr = p; + return neg*value; +} + +NK_API double +nk_strtod(const char *str, const char **endptr) +{ + double m; + double neg = 1.0; + const char *p = str; + double value = 0; + double number = 0; + + NK_ASSERT(str); + if (!str) return 0; + + /* skip whitespace */ + while (*p == ' ') p++; + if (*p == '-') { + neg = -1.0; + p++; + } + + while (*p && *p != '.' && *p != 'e') { + value = value * 10.0 + (double) (*p - '0'); + p++; + } + + if (*p == '.') { + p++; + for(m = 0.1; *p && *p != 'e'; p++ ) { + value = value + (double) (*p - '0') * m; + m *= 0.1; + } + } + if (*p == 'e') { + int i, pow, div; + p++; + if (*p == '-') { + div = nk_true; + p++; + } else if (*p == '+') { + div = nk_false; + p++; + } else div = nk_false; + + for (pow = 0; *p; p++) + pow = pow * 10 + (int) (*p - '0'); + + for (m = 1.0, i = 0; i < pow; i++) + m *= 10.0; + + if (div) + value /= m; + else value *= m; + } + number = value * neg; + if (endptr) + *endptr = p; + return number; +} + +NK_API float +nk_strtof(const char *str, const char **endptr) +{ + float float_value; + double double_value; + double_value = NK_STRTOD(str, endptr); + float_value = (float)double_value; + return float_value; +} + +NK_API int +nk_stricmp(const char *s1, const char *s2) +{ + nk_int c1,c2,d; + do { + c1 = *s1++; + c2 = *s2++; + d = c1 - c2; + while (d) { + if (c1 <= 'Z' && c1 >= 'A') { + d += ('a' - 'A'); + if (!d) break; + } + if (c2 <= 'Z' && c2 >= 'A') { + d -= ('a' - 'A'); + if (!d) break; + } + return ((d >= 0) << 1) - 1; + } + } while (c1); + return 0; +} + +NK_API int +nk_stricmpn(const char *s1, const char *s2, int n) +{ + int c1,c2,d; + NK_ASSERT(n >= 0); + do { + c1 = *s1++; + c2 = *s2++; + if (!n--) return 0; + + d = c1 - c2; + while (d) { + if (c1 <= 'Z' && c1 >= 'A') { + d += ('a' - 'A'); + if (!d) break; + } + if (c2 <= 'Z' && c2 >= 'A') { + d -= ('a' - 'A'); + if (!d) break; + } + return ((d >= 0) << 1) - 1; + } + } while (c1); + return 0; +} + +NK_INTERN int +nk_str_match_here(const char *regexp, const char *text) +{ + if (regexp[0] == '\0') + return 1; + if (regexp[1] == '*') + return nk_str_match_star(regexp[0], regexp+2, text); + if (regexp[0] == '$' && regexp[1] == '\0') + return *text == '\0'; + if (*text!='\0' && (regexp[0]=='.' || regexp[0]==*text)) + return nk_str_match_here(regexp+1, text+1); + return 0; +} + +NK_INTERN int +nk_str_match_star(int c, const char *regexp, const char *text) +{ + do {/* a '* matches zero or more instances */ + if (nk_str_match_here(regexp, text)) + return 1; + } while (*text != '\0' && (*text++ == c || c == '.')); + return 0; +} + +NK_API int +nk_strfilter(const char *text, const char *regexp) +{ + /* + c matches any literal character c + . matches any single character + ^ matches the beginning of the input string + $ matches the end of the input string + * matches zero or more occurrences of the previous character*/ + if (regexp[0] == '^') + return nk_str_match_here(regexp+1, text); + do { /* must look even if string is empty */ + if (nk_str_match_here(regexp, text)) + return 1; + } while (*text++ != '\0'); + return 0; +} + +NK_API int +nk_strmatch_fuzzy_text(const char *str, int str_len, + const char *pattern, int *out_score) +{ + /* Returns true if each character in pattern is found sequentially within str + * if found then out_score is also set. Score value has no intrinsic meaning. + * Range varies with pattern. Can only compare scores with same search pattern. */ + + /* ------- scores --------- */ + /* bonus for adjacent matches */ + #define NK_ADJACENCY_BONUS 5 + /* bonus if match occurs after a separator */ + #define NK_SEPARATOR_BONUS 10 + /* bonus if match is uppercase and prev is lower */ + #define NK_CAMEL_BONUS 10 + /* penalty applied for every letter in str before the first match */ + #define NK_LEADING_LETTER_PENALTY (-3) + /* maximum penalty for leading letters */ + #define NK_MAX_LEADING_LETTER_PENALTY (-9) + /* penalty for every letter that doesn't matter */ + #define NK_UNMATCHED_LETTER_PENALTY (-1) + + /* loop variables */ + int score = 0; + char const * pattern_iter = pattern; + int str_iter = 0; + int prev_matched = nk_false; + int prev_lower = nk_false; + /* true so if first letter match gets separator bonus*/ + int prev_separator = nk_true; + + /* use "best" matched letter if multiple string letters match the pattern */ + char const * best_letter = 0; + int best_letter_score = 0; + + /* loop over strings */ + NK_ASSERT(str); + NK_ASSERT(pattern); + if (!str || !str_len || !pattern) return 0; + while (str_iter < str_len) + { + const char pattern_letter = *pattern_iter; + const char str_letter = str[str_iter]; + + int next_match = *pattern_iter != '\0' && + nk_to_lower(pattern_letter) == nk_to_lower(str_letter); + int rematch = best_letter && nk_to_upper(*best_letter) == nk_to_upper(str_letter); + + int advanced = next_match && best_letter; + int pattern_repeat = best_letter && *pattern_iter != '\0'; + pattern_repeat = pattern_repeat && + nk_to_lower(*best_letter) == nk_to_lower(pattern_letter); + + if (advanced || pattern_repeat) { + score += best_letter_score; + best_letter = 0; + best_letter_score = 0; + } + + if (next_match || rematch) + { + int new_score = 0; + /* Apply penalty for each letter before the first pattern match */ + if (pattern_iter == pattern) { + int count = (int)(&str[str_iter] - str); + int penalty = NK_LEADING_LETTER_PENALTY * count; + if (penalty < NK_MAX_LEADING_LETTER_PENALTY) + penalty = NK_MAX_LEADING_LETTER_PENALTY; + + score += penalty; + } + + /* apply bonus for consecutive bonuses */ + if (prev_matched) + new_score += NK_ADJACENCY_BONUS; + + /* apply bonus for matches after a separator */ + if (prev_separator) + new_score += NK_SEPARATOR_BONUS; + + /* apply bonus across camel case boundaries */ + if (prev_lower && nk_is_upper(str_letter)) + new_score += NK_CAMEL_BONUS; + + /* update pattern iter IFF the next pattern letter was matched */ + if (next_match) + ++pattern_iter; + + /* update best letter in str which may be for a "next" letter or a rematch */ + if (new_score >= best_letter_score) { + /* apply penalty for now skipped letter */ + if (best_letter != 0) + score += NK_UNMATCHED_LETTER_PENALTY; + + best_letter = &str[str_iter]; + best_letter_score = new_score; + } + prev_matched = nk_true; + } else { + score += NK_UNMATCHED_LETTER_PENALTY; + prev_matched = nk_false; + } + + /* separators should be more easily defined */ + prev_lower = nk_is_lower(str_letter) != 0; + prev_separator = str_letter == '_' || str_letter == ' '; + + ++str_iter; + } + + /* apply score for last match */ + if (best_letter) + score += best_letter_score; + + /* did not match full pattern */ + if (*pattern_iter != '\0') + return nk_false; + + if (out_score) + *out_score = score; + return nk_true; +} + +NK_API int +nk_strmatch_fuzzy_string(char const *str, char const *pattern, int *out_score) +{return nk_strmatch_fuzzy_text(str, nk_strlen(str), pattern, out_score);} + +NK_INTERN int +nk_string_float_limit(char *string, int prec) +{ + int dot = 0; + char *c = string; + while (*c) { + if (*c == '.') { + dot = 1; + c++; + continue; + } + if (dot == (prec+1)) { + *c = 0; + break; + } + if (dot > 0) dot++; + c++; + } + return (int)(c - string); +} + +NK_INTERN double +nk_pow(double x, int n) +{ + /* check the sign of n */ + double r = 1; + int plus = n >= 0; + n = (plus) ? n : -n; + while (n > 0) { + if ((n & 1) == 1) + r *= x; + n /= 2; + x *= x; + } + return plus ? r : 1.0 / r; +} + +NK_INTERN int +nk_ifloord(double x) +{ + x = (double)((int)x - ((x < 0.0) ? 1 : 0)); + return (int)x; +} + +NK_INTERN int +nk_ifloorf(float x) +{ + x = (float)((int)x - ((x < 0.0f) ? 1 : 0)); + return (int)x; +} + +NK_INTERN int +nk_iceilf(float x) +{ + if (x >= 0) { + int i = (int)x; + return (x > i) ? i+1: i; + } else { + int t = (int)x; + float r = x - (float)t; + return (r > 0.0f) ? t+1: t; + } +} + +NK_INTERN int +nk_log10(double n) +{ + int neg; + int ret; + int exp = 0; + + neg = (n < 0) ? 1 : 0; + ret = (neg) ? (int)-n : (int)n; + while ((ret / 10) > 0) { + ret /= 10; + exp++; + } + if (neg) exp = -exp; + return exp; +} + +NK_INTERN void +nk_strrev_ascii(char *s) +{ + int len = nk_strlen(s); + int end = len / 2; + int i = 0; + char t; + for (; i < end; ++i) { + t = s[i]; + s[i] = s[len - 1 - i]; + s[len -1 - i] = t; + } +} + +NK_INTERN char* +nk_itoa(char *s, long n) +{ + long i = 0; + if (n == 0) { + s[i++] = '0'; + s[i] = 0; + return s; + } + if (n < 0) { + s[i++] = '-'; + n = -n; + } + while (n > 0) { + s[i++] = (char)('0' + (n % 10)); + n /= 10; + } + s[i] = 0; + if (s[0] == '-') + ++s; + + nk_strrev_ascii(s); + return s; +} + +NK_INTERN char* +nk_dtoa(char *s, double n) +{ + int useExp = 0; + int digit = 0, m = 0, m1 = 0; + char *c = s; + int neg = 0; + + NK_ASSERT(s); + if (!s) return 0; + + if (n == 0.0) { + s[0] = '0'; s[1] = '\0'; + return s; + } + + neg = (n < 0); + if (neg) n = -n; + + /* calculate magnitude */ + m = nk_log10(n); + useExp = (m >= 14 || (neg && m >= 9) || m <= -9); + if (neg) *(c++) = '-'; + + /* set up for scientific notation */ + if (useExp) { + if (m < 0) + m -= 1; + n = n / (double)nk_pow(10.0, m); + m1 = m; + m = 0; + } + if (m < 1.0) { + m = 0; + } + + /* convert the number */ + while (n > NK_FLOAT_PRECISION || m >= 0) { + double weight = nk_pow(10.0, m); + if (weight > 0) { + double t = (double)n / weight; + digit = nk_ifloord(t); + n -= ((double)digit * weight); + *(c++) = (char)('0' + (char)digit); + } + if (m == 0 && n > 0) + *(c++) = '.'; + m--; + } + + if (useExp) { + /* convert the exponent */ + int i, j; + *(c++) = 'e'; + if (m1 > 0) { + *(c++) = '+'; + } else { + *(c++) = '-'; + m1 = -m1; + } + m = 0; + while (m1 > 0) { + *(c++) = (char)('0' + (char)(m1 % 10)); + m1 /= 10; + m++; + } + c -= m; + for (i = 0, j = m-1; i= buf_size) break; + iter++; + + /* flag arguments */ + while (*iter) { + if (*iter == '-') flag |= NK_ARG_FLAG_LEFT; + else if (*iter == '+') flag |= NK_ARG_FLAG_PLUS; + else if (*iter == ' ') flag |= NK_ARG_FLAG_SPACE; + else if (*iter == '#') flag |= NK_ARG_FLAG_NUM; + else if (*iter == '0') flag |= NK_ARG_FLAG_ZERO; + else break; + iter++; + } + + /* width argument */ + width = NK_DEFAULT; + if (*iter >= '1' && *iter <= '9') { + const char *end; + width = nk_strtoi(iter, &end); + if (end == iter) + width = -1; + else iter = end; + } else if (*iter == '*') { + width = va_arg(args, int); + iter++; + } + + /* precision argument */ + precision = NK_DEFAULT; + if (*iter == '.') { + iter++; + if (*iter == '*') { + precision = va_arg(args, int); + iter++; + } else { + const char *end; + precision = nk_strtoi(iter, &end); + if (end == iter) + precision = -1; + else iter = end; + } + } + + /* length modifier */ + if (*iter == 'h') { + if (*(iter+1) == 'h') { + arg_type = NK_ARG_TYPE_CHAR; + iter++; + } else arg_type = NK_ARG_TYPE_SHORT; + iter++; + } else if (*iter == 'l') { + arg_type = NK_ARG_TYPE_LONG; + iter++; + } else arg_type = NK_ARG_TYPE_DEFAULT; + + /* specifier */ + if (*iter == '%') { + NK_ASSERT(arg_type == NK_ARG_TYPE_DEFAULT); + NK_ASSERT(precision == NK_DEFAULT); + NK_ASSERT(width == NK_DEFAULT); + if (len < buf_size) + buf[len++] = '%'; + } else if (*iter == 's') { + /* string */ + const char *str = va_arg(args, const char*); + NK_ASSERT(str != buf && "buffer and argument are not allowed to overlap!"); + NK_ASSERT(arg_type == NK_ARG_TYPE_DEFAULT); + NK_ASSERT(precision == NK_DEFAULT); + NK_ASSERT(width == NK_DEFAULT); + if (str == buf) return -1; + while (str && *str && len < buf_size) + buf[len++] = *str++; + } else if (*iter == 'n') { + /* current length callback */ + signed int *n = va_arg(args, int*); + NK_ASSERT(arg_type == NK_ARG_TYPE_DEFAULT); + NK_ASSERT(precision == NK_DEFAULT); + NK_ASSERT(width == NK_DEFAULT); + if (n) *n = len; + } else if (*iter == 'c' || *iter == 'i' || *iter == 'd') { + /* signed integer */ + long value = 0; + const char *num_iter; + int num_len, num_print, padding; + int cur_precision = NK_MAX(precision, 1); + int cur_width = NK_MAX(width, 0); + + /* retrieve correct value type */ + if (arg_type == NK_ARG_TYPE_CHAR) + value = (signed char)va_arg(args, int); + else if (arg_type == NK_ARG_TYPE_SHORT) + value = (signed short)va_arg(args, int); + else if (arg_type == NK_ARG_TYPE_LONG) + value = va_arg(args, signed long); + else if (*iter == 'c') + value = (unsigned char)va_arg(args, int); + else value = va_arg(args, signed int); + + /* convert number to string */ + nk_itoa(number_buffer, value); + num_len = nk_strlen(number_buffer); + padding = NK_MAX(cur_width - NK_MAX(cur_precision, num_len), 0); + if ((flag & NK_ARG_FLAG_PLUS) || (flag & NK_ARG_FLAG_SPACE)) + padding = NK_MAX(padding-1, 0); + + /* fill left padding up to a total of `width` characters */ + if (!(flag & NK_ARG_FLAG_LEFT)) { + while (padding-- > 0 && (len < buf_size)) { + if ((flag & NK_ARG_FLAG_ZERO) && (precision == NK_DEFAULT)) + buf[len++] = '0'; + else buf[len++] = ' '; + } + } + + /* copy string value representation into buffer */ + if ((flag & NK_ARG_FLAG_PLUS) && value >= 0 && len < buf_size) + buf[len++] = '+'; + else if ((flag & NK_ARG_FLAG_SPACE) && value >= 0 && len < buf_size) + buf[len++] = ' '; + + /* fill up to precision number of digits with '0' */ + num_print = NK_MAX(cur_precision, num_len); + while (precision && (num_print > num_len) && (len < buf_size)) { + buf[len++] = '0'; + num_print--; + } + + /* copy string value representation into buffer */ + num_iter = number_buffer; + while (precision && *num_iter && len < buf_size) + buf[len++] = *num_iter++; + + /* fill right padding up to width characters */ + if (flag & NK_ARG_FLAG_LEFT) { + while ((padding-- > 0) && (len < buf_size)) + buf[len++] = ' '; + } + } else if (*iter == 'o' || *iter == 'x' || *iter == 'X' || *iter == 'u') { + /* unsigned integer */ + unsigned long value = 0; + int num_len = 0, num_print, padding = 0; + int cur_precision = NK_MAX(precision, 1); + int cur_width = NK_MAX(width, 0); + unsigned int base = (*iter == 'o') ? 8: (*iter == 'u')? 10: 16; + + /* print oct/hex/dec value */ + const char *upper_output_format = "0123456789ABCDEF"; + const char *lower_output_format = "0123456789abcdef"; + const char *output_format = (*iter == 'x') ? + lower_output_format: upper_output_format; + + /* retrieve correct value type */ + if (arg_type == NK_ARG_TYPE_CHAR) + value = (unsigned char)va_arg(args, int); + else if (arg_type == NK_ARG_TYPE_SHORT) + value = (unsigned short)va_arg(args, int); + else if (arg_type == NK_ARG_TYPE_LONG) + value = va_arg(args, unsigned long); + else value = va_arg(args, unsigned int); + + do { + /* convert decimal number into hex/oct number */ + int digit = output_format[value % base]; + if (num_len < NK_MAX_NUMBER_BUFFER) + number_buffer[num_len++] = (char)digit; + value /= base; + } while (value > 0); + + num_print = NK_MAX(cur_precision, num_len); + padding = NK_MAX(cur_width - NK_MAX(cur_precision, num_len), 0); + if (flag & NK_ARG_FLAG_NUM) + padding = NK_MAX(padding-1, 0); + + /* fill left padding up to a total of `width` characters */ + if (!(flag & NK_ARG_FLAG_LEFT)) { + while ((padding-- > 0) && (len < buf_size)) { + if ((flag & NK_ARG_FLAG_ZERO) && (precision == NK_DEFAULT)) + buf[len++] = '0'; + else buf[len++] = ' '; + } + } + + /* fill up to precision number of digits */ + if (num_print && (flag & NK_ARG_FLAG_NUM)) { + if ((*iter == 'o') && (len < buf_size)) { + buf[len++] = '0'; + } else if ((*iter == 'x') && ((len+1) < buf_size)) { + buf[len++] = '0'; + buf[len++] = 'x'; + } else if ((*iter == 'X') && ((len+1) < buf_size)) { + buf[len++] = '0'; + buf[len++] = 'X'; + } + } + while (precision && (num_print > num_len) && (len < buf_size)) { + buf[len++] = '0'; + num_print--; + } + + /* reverse number direction */ + while (num_len > 0) { + if (precision && (len < buf_size)) + buf[len++] = number_buffer[num_len-1]; + num_len--; + } + + /* fill right padding up to width characters */ + if (flag & NK_ARG_FLAG_LEFT) { + while ((padding-- > 0) && (len < buf_size)) + buf[len++] = ' '; + } + } else if (*iter == 'f') { + /* floating point */ + const char *num_iter; + int cur_precision = (precision < 0) ? 6: precision; + int prefix, cur_width = NK_MAX(width, 0); + double value = va_arg(args, double); + int num_len = 0, frac_len = 0, dot = 0; + int padding = 0; + + NK_ASSERT(arg_type == NK_ARG_TYPE_DEFAULT); + NK_DTOA(number_buffer, value); + num_len = nk_strlen(number_buffer); + + /* calculate padding */ + num_iter = number_buffer; + while (*num_iter && *num_iter != '.') + num_iter++; + + prefix = (*num_iter == '.')?(int)(num_iter - number_buffer)+1:0; + padding = NK_MAX(cur_width - (prefix + NK_MIN(cur_precision, num_len - prefix)) , 0); + if ((flag & NK_ARG_FLAG_PLUS) || (flag & NK_ARG_FLAG_SPACE)) + padding = NK_MAX(padding-1, 0); + + /* fill left padding up to a total of `width` characters */ + if (!(flag & NK_ARG_FLAG_LEFT)) { + while (padding-- > 0 && (len < buf_size)) { + if (flag & NK_ARG_FLAG_ZERO) + buf[len++] = '0'; + else buf[len++] = ' '; + } + } + + /* copy string value representation into buffer */ + num_iter = number_buffer; + if ((flag & NK_ARG_FLAG_PLUS) && (value >= 0) && (len < buf_size)) + buf[len++] = '+'; + else if ((flag & NK_ARG_FLAG_SPACE) && (value >= 0) && (len < buf_size)) + buf[len++] = ' '; + while (*num_iter) { + if (dot) frac_len++; + if (len < buf_size) + buf[len++] = *num_iter; + if (*num_iter == '.') dot = 1; + if (frac_len >= cur_precision) break; + num_iter++; + } + + /* fill number up to precision */ + while (frac_len < cur_precision) { + if (!dot && len < buf_size) { + buf[len++] = '.'; + dot = 1; + } + if (len < buf_size) + buf[len++] = '0'; + frac_len++; + } + + /* fill right padding up to width characters */ + if (flag & NK_ARG_FLAG_LEFT) { + while ((padding-- > 0) && (len < buf_size)) + buf[len++] = ' '; + } + } else { + /* Specifier not supported: g,G,e,E,p,z */ + NK_ASSERT(0 && "specifier is not supported!"); + return result; + } + } + buf[(len >= buf_size)?(buf_size-1):len] = 0; + result = (len >= buf_size)?-1:len; + return result; +} +#endif + +NK_INTERN int +nk_strfmt(char *buf, int buf_size, const char *fmt, va_list args) +{ + int result = -1; + NK_ASSERT(buf); + NK_ASSERT(buf_size); + if (!buf || !buf_size || !fmt) return 0; +#ifdef NK_INCLUDE_STANDARD_IO + result = NK_VSNPRINTF(buf, (nk_size)buf_size, fmt, args); + result = (result >= buf_size) ? -1: result; + buf[buf_size-1] = 0; +#else + result = nk_vsnprintf(buf, buf_size, fmt, args); +#endif + return result; +} +#endif + +NK_API nk_hash +nk_murmur_hash(const void * key, int len, nk_hash seed) +{ + /* 32-Bit MurmurHash3: https://code.google.com/p/smhasher/wiki/MurmurHash3*/ + #define NK_ROTL(x,r) ((x) << (r) | ((x) >> (32 - r))) + union {const nk_uint *i; const nk_byte *b;} conv = {0}; + const nk_byte *data = (const nk_byte*)key; + const int nblocks = len/4; + nk_uint h1 = seed; + const nk_uint c1 = 0xcc9e2d51; + const nk_uint c2 = 0x1b873593; + const nk_byte *tail; + const nk_uint *blocks; + nk_uint k1; + int i; + + /* body */ + if (!key) return 0; + conv.b = (data + nblocks*4); + blocks = (const nk_uint*)conv.i; + for (i = -nblocks; i; ++i) { + k1 = blocks[i]; + k1 *= c1; + k1 = NK_ROTL(k1,15); + k1 *= c2; + + h1 ^= k1; + h1 = NK_ROTL(h1,13); + h1 = h1*5+0xe6546b64; + } + + /* tail */ + tail = (const nk_byte*)(data + nblocks*4); + k1 = 0; + switch (len & 3) { + case 3: k1 ^= (nk_uint)(tail[2] << 16); + case 2: k1 ^= (nk_uint)(tail[1] << 8u); + case 1: k1 ^= tail[0]; + k1 *= c1; + k1 = NK_ROTL(k1,15); + k1 *= c2; + h1 ^= k1; + default: break; + } + + /* finalization */ + h1 ^= (nk_uint)len; + /* fmix32 */ + h1 ^= h1 >> 16; + h1 *= 0x85ebca6b; + h1 ^= h1 >> 13; + h1 *= 0xc2b2ae35; + h1 ^= h1 >> 16; + + #undef NK_ROTL + return h1; +} + +#ifdef NK_INCLUDE_STANDARD_IO +NK_INTERN char* +nk_file_load(const char* path, nk_size* siz, struct nk_allocator *alloc) +{ + char *buf; + FILE *fd; + long ret; + + NK_ASSERT(path); + NK_ASSERT(siz); + NK_ASSERT(alloc); + if (!path || !siz || !alloc) + return 0; + + fd = fopen(path, "rb"); + if (!fd) return 0; + fseek(fd, 0, SEEK_END); + ret = ftell(fd); + if (ret < 0) { + fclose(fd); + return 0; + } + *siz = (nk_size)ret; + fseek(fd, 0, SEEK_SET); + buf = (char*)alloc->alloc(alloc->userdata,0, *siz); + NK_ASSERT(buf); + if (!buf) { + fclose(fd); + return 0; + } + *siz = (nk_size)fread(buf, 1,*siz, fd); + fclose(fd); + return buf; +} +#endif + +/* + * ============================================================== + * + * COLOR + * + * =============================================================== + */ +NK_INTERN int +nk_parse_hex(const char *p, int length) +{ + int i = 0; + int len = 0; + while (len < length) { + i <<= 4; + if (p[len] >= 'a' && p[len] <= 'f') + i += ((p[len] - 'a') + 10); + else if (p[len] >= 'A' && p[len] <= 'F') + i += ((p[len] - 'A') + 10); + else i += (p[len] - '0'); + len++; + } + return i; +} + +NK_API struct nk_color +nk_rgba(int r, int g, int b, int a) +{ + struct nk_color ret; + ret.r = (nk_byte)NK_CLAMP(0, r, 255); + ret.g = (nk_byte)NK_CLAMP(0, g, 255); + ret.b = (nk_byte)NK_CLAMP(0, b, 255); + ret.a = (nk_byte)NK_CLAMP(0, a, 255); + return ret; +} + +NK_API struct nk_color +nk_rgb_hex(const char *rgb) +{ + struct nk_color col; + const char *c = rgb; + if (*c == '#') c++; + col.r = (nk_byte)nk_parse_hex(c, 2); + col.g = (nk_byte)nk_parse_hex(c+2, 2); + col.b = (nk_byte)nk_parse_hex(c+4, 2); + col.a = 255; + return col; +} + +NK_API struct nk_color +nk_rgba_hex(const char *rgb) +{ + struct nk_color col; + const char *c = rgb; + if (*c == '#') c++; + col.r = (nk_byte)nk_parse_hex(c, 2); + col.g = (nk_byte)nk_parse_hex(c+2, 2); + col.b = (nk_byte)nk_parse_hex(c+4, 2); + col.a = (nk_byte)nk_parse_hex(c+6, 2); + return col; +} + +NK_API void +nk_color_hex_rgba(char *output, struct nk_color col) +{ + #define NK_TO_HEX(i) ((i) <= 9 ? '0' + (i): 'A' - 10 + (i)) + output[0] = (char)NK_TO_HEX((col.r & 0xF0) >> 4); + output[1] = (char)NK_TO_HEX((col.r & 0x0F)); + output[2] = (char)NK_TO_HEX((col.g & 0xF0) >> 4); + output[3] = (char)NK_TO_HEX((col.g & 0x0F)); + output[4] = (char)NK_TO_HEX((col.b & 0xF0) >> 4); + output[5] = (char)NK_TO_HEX((col.b & 0x0F)); + output[6] = (char)NK_TO_HEX((col.a & 0xF0) >> 4); + output[7] = (char)NK_TO_HEX((col.a & 0x0F)); + output[8] = '\0'; + #undef NK_TO_HEX +} + +NK_API void +nk_color_hex_rgb(char *output, struct nk_color col) +{ + #define NK_TO_HEX(i) ((i) <= 9 ? '0' + (i): 'A' - 10 + (i)) + output[0] = (char)NK_TO_HEX((col.r & 0xF0) >> 4); + output[1] = (char)NK_TO_HEX((col.r & 0x0F)); + output[2] = (char)NK_TO_HEX((col.g & 0xF0) >> 4); + output[3] = (char)NK_TO_HEX((col.g & 0x0F)); + output[4] = (char)NK_TO_HEX((col.b & 0xF0) >> 4); + output[5] = (char)NK_TO_HEX((col.b & 0x0F)); + output[6] = '\0'; + #undef NK_TO_HEX +} + +NK_API struct nk_color +nk_rgba_iv(const int *c) +{ + return nk_rgba(c[0], c[1], c[2], c[3]); +} + +NK_API struct nk_color +nk_rgba_bv(const nk_byte *c) +{ + return nk_rgba(c[0], c[1], c[2], c[3]); +} + +NK_API struct nk_color +nk_rgb(int r, int g, int b) +{ + struct nk_color ret; + ret.r = (nk_byte)NK_CLAMP(0, r, 255); + ret.g = (nk_byte)NK_CLAMP(0, g, 255); + ret.b = (nk_byte)NK_CLAMP(0, b, 255); + ret.a = (nk_byte)255; + return ret; +} + +NK_API struct nk_color +nk_rgb_iv(const int *c) +{ + return nk_rgb(c[0], c[1], c[2]); +} + +NK_API struct nk_color +nk_rgb_bv(const nk_byte* c) +{ + return nk_rgb(c[0], c[1], c[2]); +} + +NK_API struct nk_color +nk_rgba_u32(nk_uint in) +{ + struct nk_color ret; + ret.r = (in & 0xFF); + ret.g = ((in >> 8) & 0xFF); + ret.b = ((in >> 16) & 0xFF); + ret.a = (nk_byte)((in >> 24) & 0xFF); + return ret; +} + +NK_API struct nk_color +nk_rgba_f(float r, float g, float b, float a) +{ + struct nk_color ret; + ret.r = (nk_byte)(NK_SATURATE(r) * 255.0f); + ret.g = (nk_byte)(NK_SATURATE(g) * 255.0f); + ret.b = (nk_byte)(NK_SATURATE(b) * 255.0f); + ret.a = (nk_byte)(NK_SATURATE(a) * 255.0f); + return ret; +} + +NK_API struct nk_color +nk_rgba_fv(const float *c) +{ + return nk_rgba_f(c[0], c[1], c[2], c[3]); +} + +NK_API struct nk_color +nk_rgb_f(float r, float g, float b) +{ + struct nk_color ret; + ret.r = (nk_byte)(NK_SATURATE(r) * 255.0f); + ret.g = (nk_byte)(NK_SATURATE(g) * 255.0f); + ret.b = (nk_byte)(NK_SATURATE(b) * 255.0f); + ret.a = 255; + return ret; +} + +NK_API struct nk_color +nk_rgb_fv(const float *c) +{ + return nk_rgb_f(c[0], c[1], c[2]); +} + +NK_API struct nk_color +nk_hsv(int h, int s, int v) +{ + return nk_hsva(h, s, v, 255); +} + +NK_API struct nk_color +nk_hsv_iv(const int *c) +{ + return nk_hsv(c[0], c[1], c[2]); +} + +NK_API struct nk_color +nk_hsv_bv(const nk_byte *c) +{ + return nk_hsv(c[0], c[1], c[2]); +} + +NK_API struct nk_color +nk_hsv_f(float h, float s, float v) +{ + return nk_hsva_f(h, s, v, 1.0f); +} + +NK_API struct nk_color +nk_hsv_fv(const float *c) +{ + return nk_hsv_f(c[0], c[1], c[2]); +} + +NK_API struct nk_color +nk_hsva(int h, int s, int v, int a) +{ + float hf = ((float)NK_CLAMP(0, h, 255)) / 255.0f; + float sf = ((float)NK_CLAMP(0, s, 255)) / 255.0f; + float vf = ((float)NK_CLAMP(0, v, 255)) / 255.0f; + float af = ((float)NK_CLAMP(0, a, 255)) / 255.0f; + return nk_hsva_f(hf, sf, vf, af); +} + +NK_API struct nk_color +nk_hsva_iv(const int *c) +{ + return nk_hsva(c[0], c[1], c[2], c[3]); +} + +NK_API struct nk_color +nk_hsva_bv(const nk_byte *c) +{ + return nk_hsva(c[0], c[1], c[2], c[3]); +} + +NK_API struct nk_color +nk_hsva_f(float h, float s, float v, float a) +{ + struct nk_colorf out = {0,0,0,0}; + float p, q, t, f; + int i; + + if (s <= 0.0f) { + out.r = v; out.g = v; out.b = v; + return nk_rgb_f(out.r, out.g, out.b); + } + + h = h / (60.0f/360.0f); + i = (int)h; + f = h - (float)i; + p = v * (1.0f - s); + q = v * (1.0f - (s * f)); + t = v * (1.0f - s * (1.0f - f)); + + switch (i) { + case 0: default: out.r = v; out.g = t; out.b = p; break; + case 1: out.r = q; out.g = v; out.b = p; break; + case 2: out.r = p; out.g = v; out.b = t; break; + case 3: out.r = p; out.g = q; out.b = v; break; + case 4: out.r = t; out.g = p; out.b = v; break; + case 5: out.r = v; out.g = p; out.b = q; break; + } + return nk_rgba_f(out.r, out.g, out.b, a); +} + +NK_API struct nk_color +nk_hsva_fv(const float *c) +{ + return nk_hsva_f(c[0], c[1], c[2], c[3]); +} + +NK_API nk_uint +nk_color_u32(struct nk_color in) +{ + nk_uint out = (nk_uint)in.r; + out |= ((nk_uint)in.g << 8); + out |= ((nk_uint)in.b << 16); + out |= ((nk_uint)in.a << 24); + return out; +} + +NK_API void +nk_color_f(float *r, float *g, float *b, float *a, struct nk_color in) +{ + NK_STORAGE const float s = 1.0f/255.0f; + *r = (float)in.r * s; + *g = (float)in.g * s; + *b = (float)in.b * s; + *a = (float)in.a * s; +} + +NK_API void +nk_color_fv(float *c, struct nk_color in) +{ + nk_color_f(&c[0], &c[1], &c[2], &c[3], in); +} + +NK_API void +nk_color_d(double *r, double *g, double *b, double *a, struct nk_color in) +{ + NK_STORAGE const double s = 1.0/255.0; + *r = (double)in.r * s; + *g = (double)in.g * s; + *b = (double)in.b * s; + *a = (double)in.a * s; +} + +NK_API void +nk_color_dv(double *c, struct nk_color in) +{ + nk_color_d(&c[0], &c[1], &c[2], &c[3], in); +} + +NK_API void +nk_color_hsv_f(float *out_h, float *out_s, float *out_v, struct nk_color in) +{ + float a; + nk_color_hsva_f(out_h, out_s, out_v, &a, in); +} + +NK_API void +nk_color_hsv_fv(float *out, struct nk_color in) +{ + float a; + nk_color_hsva_f(&out[0], &out[1], &out[2], &a, in); +} + +NK_API void +nk_color_hsva_f(float *out_h, float *out_s, + float *out_v, float *out_a, struct nk_color in) +{ + float chroma; + float K = 0.0f; + float r,g,b,a; + + nk_color_f(&r,&g,&b,&a, in); + if (g < b) { + const float t = g; g = b; b = t; + K = -1.f; + } + if (r < g) { + const float t = r; r = g; g = t; + K = -2.f/6.0f - K; + } + chroma = r - ((g < b) ? g: b); + *out_h = NK_ABS(K + (g - b)/(6.0f * chroma + 1e-20f)); + *out_s = chroma / (r + 1e-20f); + *out_v = r; + *out_a = (float)in.a / 255.0f; +} + +NK_API void +nk_color_hsva_fv(float *out, struct nk_color in) +{ + nk_color_hsva_f(&out[0], &out[1], &out[2], &out[3], in); +} + +NK_API void +nk_color_hsva_i(int *out_h, int *out_s, int *out_v, + int *out_a, struct nk_color in) +{ + float h,s,v,a; + nk_color_hsva_f(&h, &s, &v, &a, in); + *out_h = (nk_byte)(h * 255.0f); + *out_s = (nk_byte)(s * 255.0f); + *out_v = (nk_byte)(v * 255.0f); + *out_a = (nk_byte)(a * 255.0f); +} + +NK_API void +nk_color_hsva_iv(int *out, struct nk_color in) +{ + nk_color_hsva_i(&out[0], &out[1], &out[2], &out[3], in); +} + +NK_API void +nk_color_hsva_bv(nk_byte *out, struct nk_color in) +{ + int tmp[4]; + nk_color_hsva_i(&tmp[0], &tmp[1], &tmp[2], &tmp[3], in); + out[0] = (nk_byte)tmp[0]; + out[1] = (nk_byte)tmp[1]; + out[2] = (nk_byte)tmp[2]; + out[3] = (nk_byte)tmp[3]; +} + +NK_API void +nk_color_hsva_b(nk_byte *h, nk_byte *s, nk_byte *v, nk_byte *a, struct nk_color in) +{ + int tmp[4]; + nk_color_hsva_i(&tmp[0], &tmp[1], &tmp[2], &tmp[3], in); + *h = (nk_byte)tmp[0]; + *s = (nk_byte)tmp[1]; + *v = (nk_byte)tmp[2]; + *a = (nk_byte)tmp[3]; +} + +NK_API void +nk_color_hsv_i(int *out_h, int *out_s, int *out_v, struct nk_color in) +{ + int a; + nk_color_hsva_i(out_h, out_s, out_v, &a, in); +} + +NK_API void +nk_color_hsv_b(nk_byte *out_h, nk_byte *out_s, nk_byte *out_v, struct nk_color in) +{ + int tmp[4]; + nk_color_hsva_i(&tmp[0], &tmp[1], &tmp[2], &tmp[3], in); + *out_h = (nk_byte)tmp[0]; + *out_s = (nk_byte)tmp[1]; + *out_v = (nk_byte)tmp[2]; +} + +NK_API void +nk_color_hsv_iv(int *out, struct nk_color in) +{ + nk_color_hsv_i(&out[0], &out[1], &out[2], in); +} + +NK_API void +nk_color_hsv_bv(nk_byte *out, struct nk_color in) +{ + int tmp[4]; + nk_color_hsv_i(&tmp[0], &tmp[1], &tmp[2], in); + out[0] = (nk_byte)tmp[0]; + out[1] = (nk_byte)tmp[1]; + out[2] = (nk_byte)tmp[2]; +} +/* + * ============================================================== + * + * IMAGE + * + * =============================================================== + */ +NK_API nk_handle +nk_handle_ptr(void *ptr) +{ + nk_handle handle = {0}; + handle.ptr = ptr; + return handle; +} + +NK_API nk_handle +nk_handle_id(int id) +{ + nk_handle handle; + nk_zero_struct(handle); + handle.id = id; + return handle; +} + +NK_API struct nk_image +nk_subimage_ptr(void *ptr, unsigned short w, unsigned short h, struct nk_rect r) +{ + struct nk_image s; + nk_zero(&s, sizeof(s)); + s.handle.ptr = ptr; + s.w = w; s.h = h; + s.region[0] = (unsigned short)r.x; + s.region[1] = (unsigned short)r.y; + s.region[2] = (unsigned short)r.w; + s.region[3] = (unsigned short)r.h; + return s; +} + +NK_API struct nk_image +nk_subimage_id(int id, unsigned short w, unsigned short h, struct nk_rect r) +{ + struct nk_image s; + nk_zero(&s, sizeof(s)); + s.handle.id = id; + s.w = w; s.h = h; + s.region[0] = (unsigned short)r.x; + s.region[1] = (unsigned short)r.y; + s.region[2] = (unsigned short)r.w; + s.region[3] = (unsigned short)r.h; + return s; +} + +NK_API struct nk_image +nk_subimage_handle(nk_handle handle, unsigned short w, unsigned short h, + struct nk_rect r) +{ + struct nk_image s; + nk_zero(&s, sizeof(s)); + s.handle = handle; + s.w = w; s.h = h; + s.region[0] = (unsigned short)r.x; + s.region[1] = (unsigned short)r.y; + s.region[2] = (unsigned short)r.w; + s.region[3] = (unsigned short)r.h; + return s; +} + +NK_API struct nk_image +nk_image_handle(nk_handle handle) +{ + struct nk_image s; + nk_zero(&s, sizeof(s)); + s.handle = handle; + s.w = 0; s.h = 0; + s.region[0] = 0; + s.region[1] = 0; + s.region[2] = 0; + s.region[3] = 0; + return s; +} + +NK_API struct nk_image +nk_image_ptr(void *ptr) +{ + struct nk_image s; + nk_zero(&s, sizeof(s)); + NK_ASSERT(ptr); + s.handle.ptr = ptr; + s.w = 0; s.h = 0; + s.region[0] = 0; + s.region[1] = 0; + s.region[2] = 0; + s.region[3] = 0; + return s; +} + +NK_API struct nk_image +nk_image_id(int id) +{ + struct nk_image s; + nk_zero(&s, sizeof(s)); + s.handle.id = id; + s.w = 0; s.h = 0; + s.region[0] = 0; + s.region[1] = 0; + s.region[2] = 0; + s.region[3] = 0; + return s; +} + +NK_API int +nk_image_is_subimage(const struct nk_image* img) +{ + NK_ASSERT(img); + return !(img->w == 0 && img->h == 0); +} + +NK_INTERN void +nk_unify(struct nk_rect *clip, const struct nk_rect *a, float x0, float y0, + float x1, float y1) +{ + NK_ASSERT(a); + NK_ASSERT(clip); + clip->x = NK_MAX(a->x, x0); + clip->y = NK_MAX(a->y, y0); + clip->w = NK_MIN(a->x + a->w, x1) - clip->x; + clip->h = NK_MIN(a->y + a->h, y1) - clip->y; + clip->w = NK_MAX(0, clip->w); + clip->h = NK_MAX(0, clip->h); +} + +NK_API void +nk_triangle_from_direction(struct nk_vec2 *result, struct nk_rect r, + float pad_x, float pad_y, enum nk_heading direction) +{ + float w_half, h_half; + NK_ASSERT(result); + + r.w = NK_MAX(2 * pad_x, r.w); + r.h = NK_MAX(2 * pad_y, r.h); + r.w = r.w - 2 * pad_x; + r.h = r.h - 2 * pad_y; + + r.x = r.x + pad_x; + r.y = r.y + pad_y; + + w_half = r.w / 2.0f; + h_half = r.h / 2.0f; + + if (direction == NK_UP) { + result[0] = nk_vec2(r.x + w_half, r.y); + result[1] = nk_vec2(r.x + r.w, r.y + r.h); + result[2] = nk_vec2(r.x, r.y + r.h); + } else if (direction == NK_RIGHT) { + result[0] = nk_vec2(r.x, r.y); + result[1] = nk_vec2(r.x + r.w, r.y + h_half); + result[2] = nk_vec2(r.x, r.y + r.h); + } else if (direction == NK_DOWN) { + result[0] = nk_vec2(r.x, r.y); + result[1] = nk_vec2(r.x + r.w, r.y); + result[2] = nk_vec2(r.x + w_half, r.y + r.h); + } else { + result[0] = nk_vec2(r.x, r.y + h_half); + result[1] = nk_vec2(r.x + r.w, r.y); + result[2] = nk_vec2(r.x + r.w, r.y + r.h); + } +} + +NK_INTERN int +nk_text_clamp(const struct nk_user_font *font, const char *text, + int text_len, float space, int *glyphs, float *text_width, + nk_rune *sep_list, int sep_count) +{ + int i = 0; + int glyph_len = 0; + float last_width = 0; + nk_rune unicode = 0; + float width = 0; + int len = 0; + int g = 0; + float s; + + int sep_len = 0; + int sep_g = 0; + float sep_width = 0; + sep_count = NK_MAX(sep_count,0); + + glyph_len = nk_utf_decode(text, &unicode, text_len); + while (glyph_len && (width < space) && (len < text_len)) { + len += glyph_len; + s = font->width(font->userdata, font->height, text, len); + for (i = 0; i < sep_count; ++i) { + if (unicode != sep_list[i]) continue; + sep_width = last_width = width; + sep_g = g+1; + sep_len = len; + break; + } + if (i == sep_count){ + last_width = sep_width = width; + sep_g = g+1; + } + width = s; + glyph_len = nk_utf_decode(&text[len], &unicode, text_len - len); + g++; + } + if (len >= text_len) { + *glyphs = g; + *text_width = last_width; + return len; + } else { + *glyphs = sep_g; + *text_width = sep_width; + return (!sep_len) ? len: sep_len; + } +} + +enum {NK_DO_NOT_STOP_ON_NEW_LINE, NK_STOP_ON_NEW_LINE}; +NK_INTERN struct nk_vec2 +nk_text_calculate_text_bounds(const struct nk_user_font *font, + const char *begin, int byte_len, float row_height, const char **remaining, + struct nk_vec2 *out_offset, int *glyphs, int op) +{ + float line_height = row_height; + struct nk_vec2 text_size = nk_vec2(0,0); + float line_width = 0.0f; + + float glyph_width; + int glyph_len = 0; + nk_rune unicode = 0; + int text_len = 0; + if (!begin || byte_len <= 0 || !font) + return nk_vec2(0,row_height); + + glyph_len = nk_utf_decode(begin, &unicode, byte_len); + if (!glyph_len) return text_size; + glyph_width = font->width(font->userdata, font->height, begin, glyph_len); + + *glyphs = 0; + while ((text_len < byte_len) && glyph_len) { + if (unicode == '\n') { + text_size.x = NK_MAX(text_size.x, line_width); + text_size.y += line_height; + line_width = 0; + *glyphs+=1; + if (op == NK_STOP_ON_NEW_LINE) + break; + + text_len++; + glyph_len = nk_utf_decode(begin + text_len, &unicode, byte_len-text_len); + continue; + } + + if (unicode == '\r') { + text_len++; + *glyphs+=1; + glyph_len = nk_utf_decode(begin + text_len, &unicode, byte_len-text_len); + continue; + } + + *glyphs = *glyphs + 1; + text_len += glyph_len; + line_width += (float)glyph_width; + glyph_len = nk_utf_decode(begin + text_len, &unicode, byte_len-text_len); + glyph_width = font->width(font->userdata, font->height, begin+text_len, glyph_len); + continue; + } + + if (text_size.x < line_width) + text_size.x = line_width; + if (out_offset) + *out_offset = nk_vec2(line_width, text_size.y + line_height); + if (line_width > 0 || text_size.y == 0.0f) + text_size.y += line_height; + if (remaining) + *remaining = begin+text_len; + return text_size; +} + +/* ============================================================== + * + * UTF-8 + * + * ===============================================================*/ +NK_GLOBAL const nk_byte nk_utfbyte[NK_UTF_SIZE+1] = {0x80, 0, 0xC0, 0xE0, 0xF0}; +NK_GLOBAL const nk_byte nk_utfmask[NK_UTF_SIZE+1] = {0xC0, 0x80, 0xE0, 0xF0, 0xF8}; +NK_GLOBAL const nk_uint nk_utfmin[NK_UTF_SIZE+1] = {0, 0, 0x80, 0x800, 0x10000}; +NK_GLOBAL const nk_uint nk_utfmax[NK_UTF_SIZE+1] = {0x10FFFF, 0x7F, 0x7FF, 0xFFFF, 0x10FFFF}; + +NK_INTERN int +nk_utf_validate(nk_rune *u, int i) +{ + NK_ASSERT(u); + if (!u) return 0; + if (!NK_BETWEEN(*u, nk_utfmin[i], nk_utfmax[i]) || + NK_BETWEEN(*u, 0xD800, 0xDFFF)) + *u = NK_UTF_INVALID; + for (i = 1; *u > nk_utfmax[i]; ++i); + return i; +} + +NK_INTERN nk_rune +nk_utf_decode_byte(char c, int *i) +{ + NK_ASSERT(i); + if (!i) return 0; + for(*i = 0; *i < (int)NK_LEN(nk_utfmask); ++(*i)) { + if (((nk_byte)c & nk_utfmask[*i]) == nk_utfbyte[*i]) + return (nk_byte)(c & ~nk_utfmask[*i]); + } + return 0; +} + +NK_API int +nk_utf_decode(const char *c, nk_rune *u, int clen) +{ + int i, j, len, type=0; + nk_rune udecoded; + + NK_ASSERT(c); + NK_ASSERT(u); + + if (!c || !u) return 0; + if (!clen) return 0; + *u = NK_UTF_INVALID; + + udecoded = nk_utf_decode_byte(c[0], &len); + if (!NK_BETWEEN(len, 1, NK_UTF_SIZE)) + return 1; + + for (i = 1, j = 1; i < clen && j < len; ++i, ++j) { + udecoded = (udecoded << 6) | nk_utf_decode_byte(c[i], &type); + if (type != 0) + return j; + } + if (j < len) + return 0; + *u = udecoded; + nk_utf_validate(u, len); + return len; +} + +NK_INTERN char +nk_utf_encode_byte(nk_rune u, int i) +{ + return (char)((nk_utfbyte[i]) | ((nk_byte)u & ~nk_utfmask[i])); +} + +NK_API int +nk_utf_encode(nk_rune u, char *c, int clen) +{ + int len, i; + len = nk_utf_validate(&u, 0); + if (clen < len || !len || len > NK_UTF_SIZE) + return 0; + + for (i = len - 1; i != 0; --i) { + c[i] = nk_utf_encode_byte(u, 0); + u >>= 6; + } + c[0] = nk_utf_encode_byte(u, len); + return len; +} + +NK_API int +nk_utf_len(const char *str, int len) +{ + const char *text; + int glyphs = 0; + int text_len; + int glyph_len; + int src_len = 0; + nk_rune unicode; + + NK_ASSERT(str); + if (!str || !len) return 0; + + text = str; + text_len = len; + glyph_len = nk_utf_decode(text, &unicode, text_len); + while (glyph_len && src_len < len) { + glyphs++; + src_len = src_len + glyph_len; + glyph_len = nk_utf_decode(text + src_len, &unicode, text_len - src_len); + } + return glyphs; +} + +NK_API const char* +nk_utf_at(const char *buffer, int length, int index, + nk_rune *unicode, int *len) +{ + int i = 0; + int src_len = 0; + int glyph_len = 0; + const char *text; + int text_len; + + NK_ASSERT(buffer); + NK_ASSERT(unicode); + NK_ASSERT(len); + + if (!buffer || !unicode || !len) return 0; + if (index < 0) { + *unicode = NK_UTF_INVALID; + *len = 0; + return 0; + } + + text = buffer; + text_len = length; + glyph_len = nk_utf_decode(text, unicode, text_len); + while (glyph_len) { + if (i == index) { + *len = glyph_len; + break; + } + + i++; + src_len = src_len + glyph_len; + glyph_len = nk_utf_decode(text + src_len, unicode, text_len - src_len); + } + if (i != index) return 0; + return buffer + src_len; +} + +/* ============================================================== + * + * BUFFER + * + * ===============================================================*/ +#ifdef NK_INCLUDE_DEFAULT_ALLOCATOR +NK_INTERN void* nk_malloc(nk_handle unused, void *old,nk_size size) +{NK_UNUSED(unused); NK_UNUSED(old); return malloc(size);} +NK_INTERN void nk_mfree(nk_handle unused, void *ptr) +{NK_UNUSED(unused); free(ptr);} + +NK_API void +nk_buffer_init_default(struct nk_buffer *buffer) +{ + struct nk_allocator alloc; + alloc.userdata.ptr = 0; + alloc.alloc = nk_malloc; + alloc.free = nk_mfree; + nk_buffer_init(buffer, &alloc, NK_BUFFER_DEFAULT_INITIAL_SIZE); +} +#endif + +NK_API void +nk_buffer_init(struct nk_buffer *b, const struct nk_allocator *a, + nk_size initial_size) +{ + NK_ASSERT(b); + NK_ASSERT(a); + NK_ASSERT(initial_size); + if (!b || !a || !initial_size) return; + + nk_zero(b, sizeof(*b)); + b->type = NK_BUFFER_DYNAMIC; + b->memory.ptr = a->alloc(a->userdata,0, initial_size); + b->memory.size = initial_size; + b->size = initial_size; + b->grow_factor = 2.0f; + b->pool = *a; +} + +NK_API void +nk_buffer_init_fixed(struct nk_buffer *b, void *m, nk_size size) +{ + NK_ASSERT(b); + NK_ASSERT(m); + NK_ASSERT(size); + if (!b || !m || !size) return; + + nk_zero(b, sizeof(*b)); + b->type = NK_BUFFER_FIXED; + b->memory.ptr = m; + b->memory.size = size; + b->size = size; +} + +NK_INTERN void* +nk_buffer_align(void *unaligned, nk_size align, nk_size *alignment, + enum nk_buffer_allocation_type type) +{ + void *memory = 0; + switch (type) { + default: + case NK_BUFFER_MAX: + case NK_BUFFER_FRONT: + if (align) { + memory = NK_ALIGN_PTR(unaligned, align); + *alignment = (nk_size)((nk_byte*)memory - (nk_byte*)unaligned); + } else { + memory = unaligned; + *alignment = 0; + } + break; + case NK_BUFFER_BACK: + if (align) { + memory = NK_ALIGN_PTR_BACK(unaligned, align); + *alignment = (nk_size)((nk_byte*)unaligned - (nk_byte*)memory); + } else { + memory = unaligned; + *alignment = 0; + } + break; + } + return memory; +} + +NK_INTERN void* +nk_buffer_realloc(struct nk_buffer *b, nk_size capacity, nk_size *size) +{ + void *temp; + nk_size buffer_size; + + NK_ASSERT(b); + NK_ASSERT(size); + if (!b || !size || !b->pool.alloc || !b->pool.free) + return 0; + + buffer_size = b->memory.size; + temp = b->pool.alloc(b->pool.userdata, b->memory.ptr, capacity); + NK_ASSERT(temp); + if (!temp) return 0; + + *size = capacity; + if (temp != b->memory.ptr) { + NK_MEMCPY(temp, b->memory.ptr, buffer_size); + b->pool.free(b->pool.userdata, b->memory.ptr); + } + + if (b->size == buffer_size) { + /* no back buffer so just set correct size */ + b->size = capacity; + return temp; + } else { + /* copy back buffer to the end of the new buffer */ + void *dst, *src; + nk_size back_size; + back_size = buffer_size - b->size; + dst = nk_ptr_add(void, temp, capacity - back_size); + src = nk_ptr_add(void, temp, b->size); + NK_MEMCPY(dst, src, back_size); + b->size = capacity - back_size; + } + return temp; +} + +NK_INTERN void* +nk_buffer_alloc(struct nk_buffer *b, enum nk_buffer_allocation_type type, + nk_size size, nk_size align) +{ + int full; + nk_size alignment; + void *unaligned; + void *memory; + + NK_ASSERT(b); + NK_ASSERT(size); + if (!b || !size) return 0; + b->needed += size; + + /* calculate total size with needed alignment + size */ + if (type == NK_BUFFER_FRONT) + unaligned = nk_ptr_add(void, b->memory.ptr, b->allocated); + else unaligned = nk_ptr_add(void, b->memory.ptr, b->size - size); + memory = nk_buffer_align(unaligned, align, &alignment, type); + + /* check if buffer has enough memory*/ + if (type == NK_BUFFER_FRONT) + full = ((b->allocated + size + alignment) > b->size); + else full = ((b->size - NK_MIN(b->size,(size + alignment))) <= b->allocated); + + if (full) { + nk_size capacity; + if (b->type != NK_BUFFER_DYNAMIC) + return 0; + NK_ASSERT(b->pool.alloc && b->pool.free); + if (b->type != NK_BUFFER_DYNAMIC || !b->pool.alloc || !b->pool.free) + return 0; + + /* buffer is full so allocate bigger buffer if dynamic */ + capacity = (nk_size)((float)b->memory.size * b->grow_factor); + capacity = NK_MAX(capacity, nk_round_up_pow2((nk_uint)(b->allocated + size))); + b->memory.ptr = nk_buffer_realloc(b, capacity, &b->memory.size); + if (!b->memory.ptr) return 0; + + /* align newly allocated pointer */ + if (type == NK_BUFFER_FRONT) + unaligned = nk_ptr_add(void, b->memory.ptr, b->allocated); + else unaligned = nk_ptr_add(void, b->memory.ptr, b->size - size); + memory = nk_buffer_align(unaligned, align, &alignment, type); + } + if (type == NK_BUFFER_FRONT) + b->allocated += size + alignment; + else b->size -= (size + alignment); + b->needed += alignment; + b->calls++; + return memory; +} + +NK_API void +nk_buffer_push(struct nk_buffer *b, enum nk_buffer_allocation_type type, + const void *memory, nk_size size, nk_size align) +{ + void *mem = nk_buffer_alloc(b, type, size, align); + if (!mem) return; + NK_MEMCPY(mem, memory, size); +} + +NK_API void +nk_buffer_mark(struct nk_buffer *buffer, enum nk_buffer_allocation_type type) +{ + NK_ASSERT(buffer); + if (!buffer) return; + buffer->marker[type].active = nk_true; + if (type == NK_BUFFER_BACK) + buffer->marker[type].offset = buffer->size; + else buffer->marker[type].offset = buffer->allocated; +} + +NK_API void +nk_buffer_reset(struct nk_buffer *buffer, enum nk_buffer_allocation_type type) +{ + NK_ASSERT(buffer); + if (!buffer) return; + if (type == NK_BUFFER_BACK) { + /* reset back buffer either back to marker or empty */ + buffer->needed -= (buffer->memory.size - buffer->marker[type].offset); + if (buffer->marker[type].active) + buffer->size = buffer->marker[type].offset; + else buffer->size = buffer->memory.size; + buffer->marker[type].active = nk_false; + } else { + /* reset front buffer either back to back marker or empty */ + buffer->needed -= (buffer->allocated - buffer->marker[type].offset); + if (buffer->marker[type].active) + buffer->allocated = buffer->marker[type].offset; + else buffer->allocated = 0; + buffer->marker[type].active = nk_false; + } +} + +NK_API void +nk_buffer_clear(struct nk_buffer *b) +{ + NK_ASSERT(b); + if (!b) return; + b->allocated = 0; + b->size = b->memory.size; + b->calls = 0; + b->needed = 0; +} + +NK_API void +nk_buffer_free(struct nk_buffer *b) +{ + NK_ASSERT(b); + if (!b || !b->memory.ptr) return; + if (b->type == NK_BUFFER_FIXED) return; + if (!b->pool.free) return; + NK_ASSERT(b->pool.free); + b->pool.free(b->pool.userdata, b->memory.ptr); +} + +NK_API void +nk_buffer_info(struct nk_memory_status *s, struct nk_buffer *b) +{ + NK_ASSERT(b); + NK_ASSERT(s); + if (!s || !b) return; + s->allocated = b->allocated; + s->size = b->memory.size; + s->needed = b->needed; + s->memory = b->memory.ptr; + s->calls = b->calls; +} + +NK_API void* +nk_buffer_memory(struct nk_buffer *buffer) +{ + NK_ASSERT(buffer); + if (!buffer) return 0; + return buffer->memory.ptr; +} + +NK_API const void* +nk_buffer_memory_const(const struct nk_buffer *buffer) +{ + NK_ASSERT(buffer); + if (!buffer) return 0; + return buffer->memory.ptr; +} + +NK_API nk_size +nk_buffer_total(struct nk_buffer *buffer) +{ + NK_ASSERT(buffer); + if (!buffer) return 0; + return buffer->memory.size; +} + +/* + * ============================================================== + * + * STRING + * + * =============================================================== + */ +#ifdef NK_INCLUDE_DEFAULT_ALLOCATOR +NK_API void +nk_str_init_default(struct nk_str *str) +{ + struct nk_allocator alloc; + alloc.userdata.ptr = 0; + alloc.alloc = nk_malloc; + alloc.free = nk_mfree; + nk_buffer_init(&str->buffer, &alloc, 32); + str->len = 0; +} +#endif + +NK_API void +nk_str_init(struct nk_str *str, const struct nk_allocator *alloc, nk_size size) +{ + nk_buffer_init(&str->buffer, alloc, size); + str->len = 0; +} + +NK_API void +nk_str_init_fixed(struct nk_str *str, void *memory, nk_size size) +{ + nk_buffer_init_fixed(&str->buffer, memory, size); + str->len = 0; +} + +NK_API int +nk_str_append_text_char(struct nk_str *s, const char *str, int len) +{ + char *mem; + NK_ASSERT(s); + NK_ASSERT(str); + if (!s || !str || !len) return 0; + mem = (char*)nk_buffer_alloc(&s->buffer, NK_BUFFER_FRONT, (nk_size)len * sizeof(char), 0); + if (!mem) return 0; + NK_MEMCPY(mem, str, (nk_size)len * sizeof(char)); + s->len += nk_utf_len(str, len); + return len; +} + +NK_API int +nk_str_append_str_char(struct nk_str *s, const char *str) +{ + return nk_str_append_text_char(s, str, nk_strlen(str)); +} + +NK_API int +nk_str_append_text_utf8(struct nk_str *str, const char *text, int len) +{ + int i = 0; + int byte_len = 0; + nk_rune unicode; + if (!str || !text || !len) return 0; + for (i = 0; i < len; ++i) + byte_len += nk_utf_decode(text+byte_len, &unicode, 4); + nk_str_append_text_char(str, text, byte_len); + return len; +} + +NK_API int +nk_str_append_str_utf8(struct nk_str *str, const char *text) +{ + int runes = 0; + int byte_len = 0; + int num_runes = 0; + int glyph_len = 0; + nk_rune unicode; + if (!str || !text) return 0; + + glyph_len = byte_len = nk_utf_decode(text+byte_len, &unicode, 4); + while (unicode != '\0' && glyph_len) { + glyph_len = nk_utf_decode(text+byte_len, &unicode, 4); + byte_len += glyph_len; + num_runes++; + } + nk_str_append_text_char(str, text, byte_len); + return runes; +} + +NK_API int +nk_str_append_text_runes(struct nk_str *str, const nk_rune *text, int len) +{ + int i = 0; + int byte_len = 0; + nk_glyph glyph; + + NK_ASSERT(str); + if (!str || !text || !len) return 0; + for (i = 0; i < len; ++i) { + byte_len = nk_utf_encode(text[i], glyph, NK_UTF_SIZE); + if (!byte_len) break; + nk_str_append_text_char(str, glyph, byte_len); + } + return len; +} + +NK_API int +nk_str_append_str_runes(struct nk_str *str, const nk_rune *runes) +{ + int i = 0; + nk_glyph glyph; + int byte_len; + NK_ASSERT(str); + if (!str || !runes) return 0; + while (runes[i] != '\0') { + byte_len = nk_utf_encode(runes[i], glyph, NK_UTF_SIZE); + nk_str_append_text_char(str, glyph, byte_len); + i++; + } + return i; +} + +NK_API int +nk_str_insert_at_char(struct nk_str *s, int pos, const char *str, int len) +{ + int i; + void *mem; + char *src; + char *dst; + + int copylen; + NK_ASSERT(s); + NK_ASSERT(str); + NK_ASSERT(len >= 0); + if (!s || !str || !len || (nk_size)pos > s->buffer.allocated) return 0; + if ((s->buffer.allocated + (nk_size)len >= s->buffer.memory.size) && + (s->buffer.type == NK_BUFFER_FIXED)) return 0; + + copylen = (int)s->buffer.allocated - pos; + if (!copylen) { + nk_str_append_text_char(s, str, len); + return 1; + } + mem = nk_buffer_alloc(&s->buffer, NK_BUFFER_FRONT, (nk_size)len * sizeof(char), 0); + if (!mem) return 0; + + /* memmove */ + NK_ASSERT(((int)pos + (int)len + ((int)copylen - 1)) >= 0); + NK_ASSERT(((int)pos + ((int)copylen - 1)) >= 0); + dst = nk_ptr_add(char, s->buffer.memory.ptr, pos + len + (copylen - 1)); + src = nk_ptr_add(char, s->buffer.memory.ptr, pos + (copylen-1)); + for (i = 0; i < copylen; ++i) *dst-- = *src--; + mem = nk_ptr_add(void, s->buffer.memory.ptr, pos); + NK_MEMCPY(mem, str, (nk_size)len * sizeof(char)); + s->len = nk_utf_len((char *)s->buffer.memory.ptr, (int)s->buffer.allocated); + return 1; +} + +NK_API int +nk_str_insert_at_rune(struct nk_str *str, int pos, const char *cstr, int len) +{ + int glyph_len; + nk_rune unicode; + const char *begin; + const char *buffer; + + NK_ASSERT(str); + NK_ASSERT(cstr); + NK_ASSERT(len); + if (!str || !cstr || !len) return 0; + begin = nk_str_at_rune(str, pos, &unicode, &glyph_len); + if (!str->len) + return nk_str_append_text_char(str, cstr, len); + buffer = nk_str_get_const(str); + if (!begin) return 0; + return nk_str_insert_at_char(str, (int)(begin - buffer), cstr, len); +} + +NK_API int +nk_str_insert_text_char(struct nk_str *str, int pos, const char *text, int len) +{ + return nk_str_insert_text_utf8(str, pos, text, len); +} + +NK_API int +nk_str_insert_str_char(struct nk_str *str, int pos, const char *text) +{ + return nk_str_insert_text_utf8(str, pos, text, nk_strlen(text)); +} + +NK_API int +nk_str_insert_text_utf8(struct nk_str *str, int pos, const char *text, int len) +{ + int i = 0; + int byte_len = 0; + nk_rune unicode; + + NK_ASSERT(str); + NK_ASSERT(text); + if (!str || !text || !len) return 0; + for (i = 0; i < len; ++i) + byte_len += nk_utf_decode(text+byte_len, &unicode, 4); + nk_str_insert_at_rune(str, pos, text, byte_len); + return len; +} + +NK_API int +nk_str_insert_str_utf8(struct nk_str *str, int pos, const char *text) +{ + int runes = 0; + int byte_len = 0; + int num_runes = 0; + int glyph_len = 0; + nk_rune unicode; + if (!str || !text) return 0; + + glyph_len = byte_len = nk_utf_decode(text+byte_len, &unicode, 4); + while (unicode != '\0' && glyph_len) { + glyph_len = nk_utf_decode(text+byte_len, &unicode, 4); + byte_len += glyph_len; + num_runes++; + } + nk_str_insert_at_rune(str, pos, text, byte_len); + return runes; +} + +NK_API int +nk_str_insert_text_runes(struct nk_str *str, int pos, const nk_rune *runes, int len) +{ + int i = 0; + int byte_len = 0; + nk_glyph glyph; + + NK_ASSERT(str); + if (!str || !runes || !len) return 0; + for (i = 0; i < len; ++i) { + byte_len = nk_utf_encode(runes[i], glyph, NK_UTF_SIZE); + if (!byte_len) break; + nk_str_insert_at_rune(str, pos+i, glyph, byte_len); + } + return len; +} + +NK_API int +nk_str_insert_str_runes(struct nk_str *str, int pos, const nk_rune *runes) +{ + int i = 0; + nk_glyph glyph; + int byte_len; + NK_ASSERT(str); + if (!str || !runes) return 0; + while (runes[i] != '\0') { + byte_len = nk_utf_encode(runes[i], glyph, NK_UTF_SIZE); + nk_str_insert_at_rune(str, pos+i, glyph, byte_len); + i++; + } + return i; +} + +NK_API void +nk_str_remove_chars(struct nk_str *s, int len) +{ + NK_ASSERT(s); + NK_ASSERT(len >= 0); + if (!s || len < 0 || (nk_size)len > s->buffer.allocated) return; + NK_ASSERT(((int)s->buffer.allocated - (int)len) >= 0); + s->buffer.allocated -= (nk_size)len; + s->len = nk_utf_len((char *)s->buffer.memory.ptr, (int)s->buffer.allocated); +} + +NK_API void +nk_str_remove_runes(struct nk_str *str, int len) +{ + int index; + const char *begin; + const char *end; + nk_rune unicode; + + NK_ASSERT(str); + NK_ASSERT(len >= 0); + if (!str || len < 0) return; + if (len >= str->len) { + str->len = 0; + return; + } + + index = str->len - len; + begin = nk_str_at_rune(str, index, &unicode, &len); + end = (const char*)str->buffer.memory.ptr + str->buffer.allocated; + nk_str_remove_chars(str, (int)(end-begin)+1); +} + +NK_API void +nk_str_delete_chars(struct nk_str *s, int pos, int len) +{ + NK_ASSERT(s); + if (!s || !len || (nk_size)pos > s->buffer.allocated || + (nk_size)(pos + len) > s->buffer.allocated) return; + + if ((nk_size)(pos + len) < s->buffer.allocated) { + /* memmove */ + char *dst = nk_ptr_add(char, s->buffer.memory.ptr, pos); + char *src = nk_ptr_add(char, s->buffer.memory.ptr, pos + len); + NK_MEMCPY(dst, src, s->buffer.allocated - (nk_size)(pos + len)); + NK_ASSERT(((int)s->buffer.allocated - (int)len) >= 0); + s->buffer.allocated -= (nk_size)len; + } else nk_str_remove_chars(s, len); + s->len = nk_utf_len((char *)s->buffer.memory.ptr, (int)s->buffer.allocated); +} + +NK_API void +nk_str_delete_runes(struct nk_str *s, int pos, int len) +{ + char *temp; + nk_rune unicode; + char *begin; + char *end; + int unused; + + NK_ASSERT(s); + NK_ASSERT(s->len >= pos + len); + if (s->len < pos + len) + len = NK_CLAMP(0, (s->len - pos), s->len); + if (!len) return; + + temp = (char *)s->buffer.memory.ptr; + begin = nk_str_at_rune(s, pos, &unicode, &unused); + if (!begin) return; + s->buffer.memory.ptr = begin; + end = nk_str_at_rune(s, len, &unicode, &unused); + s->buffer.memory.ptr = temp; + if (!end) return; + nk_str_delete_chars(s, (int)(begin - temp), (int)(end - begin)); +} + +NK_API char* +nk_str_at_char(struct nk_str *s, int pos) +{ + NK_ASSERT(s); + if (!s || pos > (int)s->buffer.allocated) return 0; + return nk_ptr_add(char, s->buffer.memory.ptr, pos); +} + +NK_API char* +nk_str_at_rune(struct nk_str *str, int pos, nk_rune *unicode, int *len) +{ + int i = 0; + int src_len = 0; + int glyph_len = 0; + char *text; + int text_len; + + NK_ASSERT(str); + NK_ASSERT(unicode); + NK_ASSERT(len); + + if (!str || !unicode || !len) return 0; + if (pos < 0) { + *unicode = 0; + *len = 0; + return 0; + } + + text = (char*)str->buffer.memory.ptr; + text_len = (int)str->buffer.allocated; + glyph_len = nk_utf_decode(text, unicode, text_len); + while (glyph_len) { + if (i == pos) { + *len = glyph_len; + break; + } + + i++; + src_len = src_len + glyph_len; + glyph_len = nk_utf_decode(text + src_len, unicode, text_len - src_len); + } + if (i != pos) return 0; + return text + src_len; +} + +NK_API const char* +nk_str_at_char_const(const struct nk_str *s, int pos) +{ + NK_ASSERT(s); + if (!s || pos > (int)s->buffer.allocated) return 0; + return nk_ptr_add(char, s->buffer.memory.ptr, pos); +} + +NK_API const char* +nk_str_at_const(const struct nk_str *str, int pos, nk_rune *unicode, int *len) +{ + int i = 0; + int src_len = 0; + int glyph_len = 0; + char *text; + int text_len; + + NK_ASSERT(str); + NK_ASSERT(unicode); + NK_ASSERT(len); + + if (!str || !unicode || !len) return 0; + if (pos < 0) { + *unicode = 0; + *len = 0; + return 0; + } + + text = (char*)str->buffer.memory.ptr; + text_len = (int)str->buffer.allocated; + glyph_len = nk_utf_decode(text, unicode, text_len); + while (glyph_len) { + if (i == pos) { + *len = glyph_len; + break; + } + + i++; + src_len = src_len + glyph_len; + glyph_len = nk_utf_decode(text + src_len, unicode, text_len - src_len); + } + if (i != pos) return 0; + return text + src_len; +} + +NK_API nk_rune +nk_str_rune_at(const struct nk_str *str, int pos) +{ + int len; + nk_rune unicode = 0; + nk_str_at_const(str, pos, &unicode, &len); + return unicode; +} + +NK_API char* +nk_str_get(struct nk_str *s) +{ + NK_ASSERT(s); + if (!s || !s->len || !s->buffer.allocated) return 0; + return (char*)s->buffer.memory.ptr; +} + +NK_API const char* +nk_str_get_const(const struct nk_str *s) +{ + NK_ASSERT(s); + if (!s || !s->len || !s->buffer.allocated) return 0; + return (const char*)s->buffer.memory.ptr; +} + +NK_API int +nk_str_len(struct nk_str *s) +{ + NK_ASSERT(s); + if (!s || !s->len || !s->buffer.allocated) return 0; + return s->len; +} + +NK_API int +nk_str_len_char(struct nk_str *s) +{ + NK_ASSERT(s); + if (!s || !s->len || !s->buffer.allocated) return 0; + return (int)s->buffer.allocated; +} + +NK_API void +nk_str_clear(struct nk_str *str) +{ + NK_ASSERT(str); + nk_buffer_clear(&str->buffer); + str->len = 0; +} + +NK_API void +nk_str_free(struct nk_str *str) +{ + NK_ASSERT(str); + nk_buffer_free(&str->buffer); + str->len = 0; +} + +/* + * ============================================================== + * + * Command buffer + * + * =============================================================== +*/ +NK_INTERN void +nk_command_buffer_init(struct nk_command_buffer *cmdbuf, + struct nk_buffer *buffer, enum nk_command_clipping clip) +{ + NK_ASSERT(cmdbuf); + NK_ASSERT(buffer); + if (!cmdbuf || !buffer) return; + cmdbuf->base = buffer; + cmdbuf->use_clipping = clip; + cmdbuf->begin = buffer->allocated; + cmdbuf->end = buffer->allocated; + cmdbuf->last = buffer->allocated; +} + +NK_INTERN void +nk_command_buffer_reset(struct nk_command_buffer *buffer) +{ + NK_ASSERT(buffer); + if (!buffer) return; + buffer->begin = 0; + buffer->end = 0; + buffer->last = 0; + buffer->clip = nk_null_rect; +#ifdef NK_INCLUDE_COMMAND_USERDATA + buffer->userdata.ptr = 0; +#endif +} + +NK_INTERN void* +nk_command_buffer_push(struct nk_command_buffer* b, + enum nk_command_type t, nk_size size) +{ + NK_STORAGE const nk_size align = NK_ALIGNOF(struct nk_command); + struct nk_command *cmd; + nk_size alignment; + void *unaligned; + void *memory; + + NK_ASSERT(b); + NK_ASSERT(b->base); + if (!b) return 0; + cmd = (struct nk_command*)nk_buffer_alloc(b->base,NK_BUFFER_FRONT,size,align); + if (!cmd) return 0; + + /* make sure the offset to the next command is aligned */ + b->last = (nk_size)((nk_byte*)cmd - (nk_byte*)b->base->memory.ptr); + unaligned = (nk_byte*)cmd + size; + memory = NK_ALIGN_PTR(unaligned, align); + alignment = (nk_size)((nk_byte*)memory - (nk_byte*)unaligned); +#ifdef NK_ZERO_COMMAND_MEMORY + NK_MEMSET(cmd, 0, size + alignment); +#endif + + cmd->type = t; + cmd->next = b->base->allocated + alignment; +#ifdef NK_INCLUDE_COMMAND_USERDATA + cmd->userdata = b->userdata; +#endif + b->end = cmd->next; + return cmd; +} + +NK_API void +nk_push_scissor(struct nk_command_buffer *b, struct nk_rect r) +{ + struct nk_command_scissor *cmd; + NK_ASSERT(b); + if (!b) return; + + b->clip.x = r.x; + b->clip.y = r.y; + b->clip.w = r.w; + b->clip.h = r.h; + cmd = (struct nk_command_scissor*) + nk_command_buffer_push(b, NK_COMMAND_SCISSOR, sizeof(*cmd)); + + if (!cmd) return; + cmd->x = (short)r.x; + cmd->y = (short)r.y; + cmd->w = (unsigned short)NK_MAX(0, r.w); + cmd->h = (unsigned short)NK_MAX(0, r.h); +} + +NK_API void +nk_stroke_line(struct nk_command_buffer *b, float x0, float y0, + float x1, float y1, float line_thickness, struct nk_color c) +{ + struct nk_command_line *cmd; + NK_ASSERT(b); + if (!b || line_thickness <= 0) return; + cmd = (struct nk_command_line*) + nk_command_buffer_push(b, NK_COMMAND_LINE, sizeof(*cmd)); + if (!cmd) return; + cmd->line_thickness = (unsigned short)line_thickness; + cmd->begin.x = (short)x0; + cmd->begin.y = (short)y0; + cmd->end.x = (short)x1; + cmd->end.y = (short)y1; + cmd->color = c; +} + +NK_API void +nk_stroke_curve(struct nk_command_buffer *b, float ax, float ay, + float ctrl0x, float ctrl0y, float ctrl1x, float ctrl1y, + float bx, float by, float line_thickness, struct nk_color col) +{ + struct nk_command_curve *cmd; + NK_ASSERT(b); + if (!b || col.a == 0 || line_thickness <= 0) return; + + cmd = (struct nk_command_curve*) + nk_command_buffer_push(b, NK_COMMAND_CURVE, sizeof(*cmd)); + if (!cmd) return; + cmd->line_thickness = (unsigned short)line_thickness; + cmd->begin.x = (short)ax; + cmd->begin.y = (short)ay; + cmd->ctrl[0].x = (short)ctrl0x; + cmd->ctrl[0].y = (short)ctrl0y; + cmd->ctrl[1].x = (short)ctrl1x; + cmd->ctrl[1].y = (short)ctrl1y; + cmd->end.x = (short)bx; + cmd->end.y = (short)by; + cmd->color = col; +} + +NK_API void +nk_stroke_rect(struct nk_command_buffer *b, struct nk_rect rect, + float rounding, float line_thickness, struct nk_color c) +{ + struct nk_command_rect *cmd; + NK_ASSERT(b); + if (!b || c.a == 0 || rect.w == 0 || rect.h == 0 || line_thickness <= 0) return; + if (b->use_clipping) { + const struct nk_rect *clip = &b->clip; + if (!NK_INTERSECT(rect.x, rect.y, rect.w, rect.h, + clip->x, clip->y, clip->w, clip->h)) return; + } + cmd = (struct nk_command_rect*) + nk_command_buffer_push(b, NK_COMMAND_RECT, sizeof(*cmd)); + if (!cmd) return; + cmd->rounding = (unsigned short)rounding; + cmd->line_thickness = (unsigned short)line_thickness; + cmd->x = (short)rect.x; + cmd->y = (short)rect.y; + cmd->w = (unsigned short)NK_MAX(0, rect.w); + cmd->h = (unsigned short)NK_MAX(0, rect.h); + cmd->color = c; +} + +NK_API void +nk_fill_rect(struct nk_command_buffer *b, struct nk_rect rect, + float rounding, struct nk_color c) +{ + struct nk_command_rect_filled *cmd; + NK_ASSERT(b); + if (!b || c.a == 0 || rect.w == 0 || rect.h == 0) return; + if (b->use_clipping) { + const struct nk_rect *clip = &b->clip; + if (!NK_INTERSECT(rect.x, rect.y, rect.w, rect.h, + clip->x, clip->y, clip->w, clip->h)) return; + } + + cmd = (struct nk_command_rect_filled*) + nk_command_buffer_push(b, NK_COMMAND_RECT_FILLED, sizeof(*cmd)); + if (!cmd) return; + cmd->rounding = (unsigned short)rounding; + cmd->x = (short)rect.x; + cmd->y = (short)rect.y; + cmd->w = (unsigned short)NK_MAX(0, rect.w); + cmd->h = (unsigned short)NK_MAX(0, rect.h); + cmd->color = c; +} + +NK_API void +nk_fill_rect_multi_color(struct nk_command_buffer *b, struct nk_rect rect, + struct nk_color left, struct nk_color top, struct nk_color right, + struct nk_color bottom) +{ + struct nk_command_rect_multi_color *cmd; + NK_ASSERT(b); + if (!b || rect.w == 0 || rect.h == 0) return; + if (b->use_clipping) { + const struct nk_rect *clip = &b->clip; + if (!NK_INTERSECT(rect.x, rect.y, rect.w, rect.h, + clip->x, clip->y, clip->w, clip->h)) return; + } + + cmd = (struct nk_command_rect_multi_color*) + nk_command_buffer_push(b, NK_COMMAND_RECT_MULTI_COLOR, sizeof(*cmd)); + if (!cmd) return; + cmd->x = (short)rect.x; + cmd->y = (short)rect.y; + cmd->w = (unsigned short)NK_MAX(0, rect.w); + cmd->h = (unsigned short)NK_MAX(0, rect.h); + cmd->left = left; + cmd->top = top; + cmd->right = right; + cmd->bottom = bottom; +} + +NK_API void +nk_stroke_circle(struct nk_command_buffer *b, struct nk_rect r, + float line_thickness, struct nk_color c) +{ + struct nk_command_circle *cmd; + if (!b || r.w == 0 || r.h == 0 || line_thickness <= 0) return; + if (b->use_clipping) { + const struct nk_rect *clip = &b->clip; + if (!NK_INTERSECT(r.x, r.y, r.w, r.h, clip->x, clip->y, clip->w, clip->h)) + return; + } + + cmd = (struct nk_command_circle*) + nk_command_buffer_push(b, NK_COMMAND_CIRCLE, sizeof(*cmd)); + if (!cmd) return; + cmd->line_thickness = (unsigned short)line_thickness; + cmd->x = (short)r.x; + cmd->y = (short)r.y; + cmd->w = (unsigned short)NK_MAX(r.w, 0); + cmd->h = (unsigned short)NK_MAX(r.h, 0); + cmd->color = c; +} + +NK_API void +nk_fill_circle(struct nk_command_buffer *b, struct nk_rect r, struct nk_color c) +{ + struct nk_command_circle_filled *cmd; + NK_ASSERT(b); + if (!b || c.a == 0 || r.w == 0 || r.h == 0) return; + if (b->use_clipping) { + const struct nk_rect *clip = &b->clip; + if (!NK_INTERSECT(r.x, r.y, r.w, r.h, clip->x, clip->y, clip->w, clip->h)) + return; + } + + cmd = (struct nk_command_circle_filled*) + nk_command_buffer_push(b, NK_COMMAND_CIRCLE_FILLED, sizeof(*cmd)); + if (!cmd) return; + cmd->x = (short)r.x; + cmd->y = (short)r.y; + cmd->w = (unsigned short)NK_MAX(r.w, 0); + cmd->h = (unsigned short)NK_MAX(r.h, 0); + cmd->color = c; +} + +NK_API void +nk_stroke_arc(struct nk_command_buffer *b, float cx, float cy, float radius, + float a_min, float a_max, float line_thickness, struct nk_color c) +{ + struct nk_command_arc *cmd; + if (!b || c.a == 0 || line_thickness <= 0) return; + cmd = (struct nk_command_arc*) + nk_command_buffer_push(b, NK_COMMAND_ARC, sizeof(*cmd)); + if (!cmd) return; + cmd->line_thickness = (unsigned short)line_thickness; + cmd->cx = (short)cx; + cmd->cy = (short)cy; + cmd->r = (unsigned short)radius; + cmd->a[0] = a_min; + cmd->a[1] = a_max; + cmd->color = c; +} + +NK_API void +nk_fill_arc(struct nk_command_buffer *b, float cx, float cy, float radius, + float a_min, float a_max, struct nk_color c) +{ + struct nk_command_arc_filled *cmd; + NK_ASSERT(b); + if (!b || c.a == 0) return; + cmd = (struct nk_command_arc_filled*) + nk_command_buffer_push(b, NK_COMMAND_ARC_FILLED, sizeof(*cmd)); + if (!cmd) return; + cmd->cx = (short)cx; + cmd->cy = (short)cy; + cmd->r = (unsigned short)radius; + cmd->a[0] = a_min; + cmd->a[1] = a_max; + cmd->color = c; +} + +NK_API void +nk_stroke_triangle(struct nk_command_buffer *b, float x0, float y0, float x1, + float y1, float x2, float y2, float line_thickness, struct nk_color c) +{ + struct nk_command_triangle *cmd; + NK_ASSERT(b); + if (!b || c.a == 0 || line_thickness <= 0) return; + if (b->use_clipping) { + const struct nk_rect *clip = &b->clip; + if (!NK_INBOX(x0, y0, clip->x, clip->y, clip->w, clip->h) && + !NK_INBOX(x1, y1, clip->x, clip->y, clip->w, clip->h) && + !NK_INBOX(x2, y2, clip->x, clip->y, clip->w, clip->h)) + return; + } + + cmd = (struct nk_command_triangle*) + nk_command_buffer_push(b, NK_COMMAND_TRIANGLE, sizeof(*cmd)); + if (!cmd) return; + cmd->line_thickness = (unsigned short)line_thickness; + cmd->a.x = (short)x0; + cmd->a.y = (short)y0; + cmd->b.x = (short)x1; + cmd->b.y = (short)y1; + cmd->c.x = (short)x2; + cmd->c.y = (short)y2; + cmd->color = c; +} + +NK_API void +nk_fill_triangle(struct nk_command_buffer *b, float x0, float y0, float x1, + float y1, float x2, float y2, struct nk_color c) +{ + struct nk_command_triangle_filled *cmd; + NK_ASSERT(b); + if (!b || c.a == 0) return; + if (!b) return; + if (b->use_clipping) { + const struct nk_rect *clip = &b->clip; + if (!NK_INBOX(x0, y0, clip->x, clip->y, clip->w, clip->h) && + !NK_INBOX(x1, y1, clip->x, clip->y, clip->w, clip->h) && + !NK_INBOX(x2, y2, clip->x, clip->y, clip->w, clip->h)) + return; + } + + cmd = (struct nk_command_triangle_filled*) + nk_command_buffer_push(b, NK_COMMAND_TRIANGLE_FILLED, sizeof(*cmd)); + if (!cmd) return; + cmd->a.x = (short)x0; + cmd->a.y = (short)y0; + cmd->b.x = (short)x1; + cmd->b.y = (short)y1; + cmd->c.x = (short)x2; + cmd->c.y = (short)y2; + cmd->color = c; +} + +NK_API void +nk_stroke_polygon(struct nk_command_buffer *b, float *points, int point_count, + float line_thickness, struct nk_color col) +{ + int i; + nk_size size = 0; + struct nk_command_polygon *cmd; + + NK_ASSERT(b); + if (!b || col.a == 0 || line_thickness <= 0) return; + size = sizeof(*cmd) + sizeof(short) * 2 * (nk_size)point_count; + cmd = (struct nk_command_polygon*) nk_command_buffer_push(b, NK_COMMAND_POLYGON, size); + if (!cmd) return; + cmd->color = col; + cmd->line_thickness = (unsigned short)line_thickness; + cmd->point_count = (unsigned short)point_count; + for (i = 0; i < point_count; ++i) { + cmd->points[i].x = (short)points[i*2]; + cmd->points[i].y = (short)points[i*2+1]; + } +} + +NK_API void +nk_fill_polygon(struct nk_command_buffer *b, float *points, int point_count, + struct nk_color col) +{ + int i; + nk_size size = 0; + struct nk_command_polygon_filled *cmd; + + NK_ASSERT(b); + if (!b || col.a == 0) return; + size = sizeof(*cmd) + sizeof(short) * 2 * (nk_size)point_count; + cmd = (struct nk_command_polygon_filled*) + nk_command_buffer_push(b, NK_COMMAND_POLYGON_FILLED, size); + if (!cmd) return; + cmd->color = col; + cmd->point_count = (unsigned short)point_count; + for (i = 0; i < point_count; ++i) { + cmd->points[i].x = (short)points[i*2+0]; + cmd->points[i].y = (short)points[i*2+1]; + } +} + +NK_API void +nk_stroke_polyline(struct nk_command_buffer *b, float *points, int point_count, + float line_thickness, struct nk_color col) +{ + int i; + nk_size size = 0; + struct nk_command_polyline *cmd; + + NK_ASSERT(b); + if (!b || col.a == 0 || line_thickness <= 0) return; + size = sizeof(*cmd) + sizeof(short) * 2 * (nk_size)point_count; + cmd = (struct nk_command_polyline*) nk_command_buffer_push(b, NK_COMMAND_POLYLINE, size); + if (!cmd) return; + cmd->color = col; + cmd->point_count = (unsigned short)point_count; + cmd->line_thickness = (unsigned short)line_thickness; + for (i = 0; i < point_count; ++i) { + cmd->points[i].x = (short)points[i*2]; + cmd->points[i].y = (short)points[i*2+1]; + } +} + +NK_API void +nk_draw_image(struct nk_command_buffer *b, struct nk_rect r, + const struct nk_image *img, struct nk_color col) +{ + struct nk_command_image *cmd; + NK_ASSERT(b); + if (!b) return; + if (b->use_clipping) { + const struct nk_rect *c = &b->clip; + if (c->w == 0 || c->h == 0 || !NK_INTERSECT(r.x, r.y, r.w, r.h, c->x, c->y, c->w, c->h)) + return; + } + + cmd = (struct nk_command_image*) + nk_command_buffer_push(b, NK_COMMAND_IMAGE, sizeof(*cmd)); + if (!cmd) return; + cmd->x = (short)r.x; + cmd->y = (short)r.y; + cmd->w = (unsigned short)NK_MAX(0, r.w); + cmd->h = (unsigned short)NK_MAX(0, r.h); + cmd->img = *img; + cmd->col = col; +} + +NK_API void +nk_push_custom(struct nk_command_buffer *b, struct nk_rect r, + nk_command_custom_callback cb, nk_handle usr) +{ + struct nk_command_custom *cmd; + NK_ASSERT(b); + if (!b) return; + if (b->use_clipping) { + const struct nk_rect *c = &b->clip; + if (c->w == 0 || c->h == 0 || !NK_INTERSECT(r.x, r.y, r.w, r.h, c->x, c->y, c->w, c->h)) + return; + } + + cmd = (struct nk_command_custom*) + nk_command_buffer_push(b, NK_COMMAND_CUSTOM, sizeof(*cmd)); + if (!cmd) return; + cmd->x = (short)r.x; + cmd->y = (short)r.y; + cmd->w = (unsigned short)NK_MAX(0, r.w); + cmd->h = (unsigned short)NK_MAX(0, r.h); + cmd->callback_data = usr; + cmd->callback = cb; +} + +NK_API void +nk_draw_text(struct nk_command_buffer *b, struct nk_rect r, + const char *string, int length, const struct nk_user_font *font, + struct nk_color bg, struct nk_color fg) +{ + float text_width = 0; + struct nk_command_text *cmd; + + NK_ASSERT(b); + NK_ASSERT(font); + if (!b || !string || !length || (bg.a == 0 && fg.a == 0)) return; + if (b->use_clipping) { + const struct nk_rect *c = &b->clip; + if (c->w == 0 || c->h == 0 || !NK_INTERSECT(r.x, r.y, r.w, r.h, c->x, c->y, c->w, c->h)) + return; + } + + /* make sure text fits inside bounds */ + text_width = font->width(font->userdata, font->height, string, length); + if (text_width > r.w){ + int glyphs = 0; + float txt_width = (float)text_width; + length = nk_text_clamp(font, string, length, r.w, &glyphs, &txt_width, 0,0); + } + + if (!length) return; + cmd = (struct nk_command_text*) + nk_command_buffer_push(b, NK_COMMAND_TEXT, sizeof(*cmd) + (nk_size)(length + 1)); + if (!cmd) return; + cmd->x = (short)r.x; + cmd->y = (short)r.y; + cmd->w = (unsigned short)r.w; + cmd->h = (unsigned short)r.h; + cmd->background = bg; + cmd->foreground = fg; + cmd->font = font; + cmd->length = length; + cmd->height = font->height; + NK_MEMCPY(cmd->string, string, (nk_size)length); + cmd->string[length] = '\0'; +} + +/* ============================================================== + * + * DRAW LIST + * + * ===============================================================*/ +#ifdef NK_INCLUDE_VERTEX_BUFFER_OUTPUT +NK_API void +nk_draw_list_init(struct nk_draw_list *list) +{ + nk_size i = 0; + NK_ASSERT(list); + if (!list) return; + nk_zero(list, sizeof(*list)); + for (i = 0; i < NK_LEN(list->circle_vtx); ++i) { + const float a = ((float)i / (float)NK_LEN(list->circle_vtx)) * 2 * NK_PI; + list->circle_vtx[i].x = (float)NK_COS(a); + list->circle_vtx[i].y = (float)NK_SIN(a); + } +} + +NK_API void +nk_draw_list_setup(struct nk_draw_list *canvas, const struct nk_convert_config *config, + struct nk_buffer *cmds, struct nk_buffer *vertices, struct nk_buffer *elements, + enum nk_anti_aliasing line_aa, enum nk_anti_aliasing shape_aa) +{ + NK_ASSERT(canvas); + NK_ASSERT(config); + NK_ASSERT(cmds); + NK_ASSERT(vertices); + NK_ASSERT(elements); + if (!canvas || !config || !cmds || !vertices || !elements) + return; + + canvas->buffer = cmds; + canvas->config = *config; + canvas->elements = elements; + canvas->vertices = vertices; + canvas->line_AA = line_aa; + canvas->shape_AA = shape_aa; + canvas->clip_rect = nk_null_rect; +} + +NK_API const struct nk_draw_command* +nk__draw_list_begin(const struct nk_draw_list *canvas, const struct nk_buffer *buffer) +{ + nk_byte *memory; + nk_size offset; + const struct nk_draw_command *cmd; + + NK_ASSERT(buffer); + if (!buffer || !buffer->size || !canvas->cmd_count) + return 0; + + memory = (nk_byte*)buffer->memory.ptr; + offset = buffer->memory.size - canvas->cmd_offset; + cmd = nk_ptr_add(const struct nk_draw_command, memory, offset); + return cmd; +} + +NK_API const struct nk_draw_command* +nk__draw_list_end(const struct nk_draw_list *canvas, const struct nk_buffer *buffer) +{ + nk_size size; + nk_size offset; + nk_byte *memory; + const struct nk_draw_command *end; + + NK_ASSERT(buffer); + NK_ASSERT(canvas); + if (!buffer || !canvas) + return 0; + + memory = (nk_byte*)buffer->memory.ptr; + size = buffer->memory.size; + offset = size - canvas->cmd_offset; + end = nk_ptr_add(const struct nk_draw_command, memory, offset); + end -= (canvas->cmd_count-1); + return end; +} + +NK_API const struct nk_draw_command* +nk__draw_list_next(const struct nk_draw_command *cmd, + const struct nk_buffer *buffer, const struct nk_draw_list *canvas) +{ + const struct nk_draw_command *end; + NK_ASSERT(buffer); + NK_ASSERT(canvas); + if (!cmd || !buffer || !canvas) + return 0; + + end = nk__draw_list_end(canvas, buffer); + if (cmd <= end) return 0; + return (cmd-1); +} + +NK_API void +nk_draw_list_clear(struct nk_draw_list *list) +{ + NK_ASSERT(list); + if (!list) return; + if (list->buffer) + nk_buffer_clear(list->buffer); + if (list->vertices) + nk_buffer_clear(list->vertices); + if (list->elements) + nk_buffer_clear(list->elements); + + list->element_count = 0; + list->vertex_count = 0; + list->cmd_offset = 0; + list->cmd_count = 0; + list->path_count = 0; + list->vertices = 0; + list->elements = 0; + list->clip_rect = nk_null_rect; +} + +NK_INTERN struct nk_vec2* +nk_draw_list_alloc_path(struct nk_draw_list *list, int count) +{ + struct nk_vec2 *points; + NK_STORAGE const nk_size point_align = NK_ALIGNOF(struct nk_vec2); + NK_STORAGE const nk_size point_size = sizeof(struct nk_vec2); + points = (struct nk_vec2*) + nk_buffer_alloc(list->buffer, NK_BUFFER_FRONT, + point_size * (nk_size)count, point_align); + + if (!points) return 0; + if (!list->path_offset) { + void *memory = nk_buffer_memory(list->buffer); + list->path_offset = (unsigned int)((nk_byte*)points - (nk_byte*)memory); + } + list->path_count += (unsigned int)count; + return points; +} + +NK_INTERN struct nk_vec2 +nk_draw_list_path_last(struct nk_draw_list *list) +{ + void *memory; + struct nk_vec2 *point; + NK_ASSERT(list->path_count); + memory = nk_buffer_memory(list->buffer); + point = nk_ptr_add(struct nk_vec2, memory, list->path_offset); + point += (list->path_count-1); + return *point; +} + +NK_INTERN struct nk_draw_command* +nk_draw_list_push_command(struct nk_draw_list *list, struct nk_rect clip, + nk_handle texture) +{ + NK_STORAGE const nk_size cmd_align = NK_ALIGNOF(struct nk_draw_command); + NK_STORAGE const nk_size cmd_size = sizeof(struct nk_draw_command); + struct nk_draw_command *cmd; + + NK_ASSERT(list); + cmd = (struct nk_draw_command*) + nk_buffer_alloc(list->buffer, NK_BUFFER_BACK, cmd_size, cmd_align); + + if (!cmd) return 0; + if (!list->cmd_count) { + nk_byte *memory = (nk_byte*)nk_buffer_memory(list->buffer); + nk_size total = nk_buffer_total(list->buffer); + memory = nk_ptr_add(nk_byte, memory, total); + list->cmd_offset = (nk_size)(memory - (nk_byte*)cmd); + } + + cmd->elem_count = 0; + cmd->clip_rect = clip; + cmd->texture = texture; +#ifdef NK_INCLUDE_COMMAND_USERDATA + cmd->userdata = list->userdata; +#endif + + list->cmd_count++; + list->clip_rect = clip; + return cmd; +} + +NK_INTERN struct nk_draw_command* +nk_draw_list_command_last(struct nk_draw_list *list) +{ + void *memory; + nk_size size; + struct nk_draw_command *cmd; + NK_ASSERT(list->cmd_count); + + memory = nk_buffer_memory(list->buffer); + size = nk_buffer_total(list->buffer); + cmd = nk_ptr_add(struct nk_draw_command, memory, size - list->cmd_offset); + return (cmd - (list->cmd_count-1)); +} + +NK_INTERN void +nk_draw_list_add_clip(struct nk_draw_list *list, struct nk_rect rect) +{ + NK_ASSERT(list); + if (!list) return; + if (!list->cmd_count) { + nk_draw_list_push_command(list, rect, list->config.null.texture); + } else { + struct nk_draw_command *prev = nk_draw_list_command_last(list); + if (prev->elem_count == 0) + prev->clip_rect = rect; + nk_draw_list_push_command(list, rect, prev->texture); + } +} + +NK_INTERN void +nk_draw_list_push_image(struct nk_draw_list *list, nk_handle texture) +{ + NK_ASSERT(list); + if (!list) return; + if (!list->cmd_count) { + nk_draw_list_push_command(list, nk_null_rect, texture); + } else { + struct nk_draw_command *prev = nk_draw_list_command_last(list); + if (prev->elem_count == 0) { + prev->texture = texture; + #ifdef NK_INCLUDE_COMMAND_USERDATA + prev->userdata = list->userdata; + #endif + } else if (prev->texture.id != texture.id + #ifdef NK_INCLUDE_COMMAND_USERDATA + || prev->userdata.id != list->userdata.id + #endif + ) nk_draw_list_push_command(list, prev->clip_rect, texture); + } +} + +#ifdef NK_INCLUDE_COMMAND_USERDATA +NK_API void +nk_draw_list_push_userdata(struct nk_draw_list *list, nk_handle userdata) +{ + list->userdata = userdata; +} +#endif + +NK_INTERN void* +nk_draw_list_alloc_vertices(struct nk_draw_list *list, nk_size count) +{ + void *vtx; + NK_ASSERT(list); + if (!list) return 0; + vtx = nk_buffer_alloc(list->vertices, NK_BUFFER_FRONT, + list->config.vertex_size*count, list->config.vertex_alignment); + if (!vtx) return 0; + list->vertex_count += (unsigned int)count; + return vtx; +} + +NK_INTERN nk_draw_index* +nk_draw_list_alloc_elements(struct nk_draw_list *list, nk_size count) +{ + nk_draw_index *ids; + struct nk_draw_command *cmd; + NK_STORAGE const nk_size elem_align = NK_ALIGNOF(nk_draw_index); + NK_STORAGE const nk_size elem_size = sizeof(nk_draw_index); + NK_ASSERT(list); + if (!list) return 0; + + ids = (nk_draw_index*) + nk_buffer_alloc(list->elements, NK_BUFFER_FRONT, elem_size*count, elem_align); + if (!ids) return 0; + cmd = nk_draw_list_command_last(list); + list->element_count += (unsigned int)count; + cmd->elem_count += (unsigned int)count; + return ids; +} + +NK_INTERN int +nk_draw_vertex_layout_element_is_end_of_layout( + const struct nk_draw_vertex_layout_element *element) +{ + return (element->attribute == NK_VERTEX_ATTRIBUTE_COUNT || + element->format == NK_FORMAT_COUNT); +} + +NK_INTERN void +nk_draw_vertex_color(void *attribute, const float *values, + enum nk_draw_vertex_layout_format format) +{ + /* if this triggers you tried to provide a value format for a color */ + NK_ASSERT(format >= NK_FORMAT_COLOR_BEGIN); + NK_ASSERT(format <= NK_FORMAT_COLOR_END); + if (format < NK_FORMAT_COLOR_BEGIN || format > NK_FORMAT_COLOR_END) return; + + switch (format) { + default: NK_ASSERT(0 && "Invalid vertex layout color format"); break; + case NK_FORMAT_R8G8B8A8: + case NK_FORMAT_R8G8B8: { + struct nk_color col = nk_rgba_fv(values); + NK_MEMCPY(attribute, &col.r, sizeof(col)); + } break; + case NK_FORMAT_B8G8R8A8: { + struct nk_color col = nk_rgba_fv(values); + struct nk_color bgra = nk_rgba(col.b, col.g, col.r, col.a); + NK_MEMCPY(attribute, &bgra, sizeof(bgra)); + } break; + case NK_FORMAT_R16G15B16: { + nk_ushort col[3]; + col[0] = (nk_ushort)NK_CLAMP(NK_USHORT_MIN, values[0] * NK_USHORT_MAX, NK_USHORT_MAX); + col[1] = (nk_ushort)NK_CLAMP(NK_USHORT_MIN, values[1] * NK_USHORT_MAX, NK_USHORT_MAX); + col[2] = (nk_ushort)NK_CLAMP(NK_USHORT_MIN, values[2] * NK_USHORT_MAX, NK_USHORT_MAX); + NK_MEMCPY(attribute, col, sizeof(col)); + } break; + case NK_FORMAT_R16G15B16A16: { + nk_ushort col[4]; + col[0] = (nk_ushort)NK_CLAMP(NK_USHORT_MIN, values[0] * NK_USHORT_MAX, NK_USHORT_MAX); + col[1] = (nk_ushort)NK_CLAMP(NK_USHORT_MIN, values[1] * NK_USHORT_MAX, NK_USHORT_MAX); + col[2] = (nk_ushort)NK_CLAMP(NK_USHORT_MIN, values[2] * NK_USHORT_MAX, NK_USHORT_MAX); + col[3] = (nk_ushort)NK_CLAMP(NK_USHORT_MIN, values[3] * NK_USHORT_MAX, NK_USHORT_MAX); + NK_MEMCPY(attribute, col, sizeof(col)); + } break; + case NK_FORMAT_R32G32B32: { + nk_uint col[3]; + col[0] = (nk_uint)NK_CLAMP(NK_UINT_MIN, values[0] * NK_UINT_MAX, NK_UINT_MAX); + col[1] = (nk_uint)NK_CLAMP(NK_UINT_MIN, values[1] * NK_UINT_MAX, NK_UINT_MAX); + col[2] = (nk_uint)NK_CLAMP(NK_UINT_MIN, values[2] * NK_UINT_MAX, NK_UINT_MAX); + NK_MEMCPY(attribute, col, sizeof(col)); + } break; + case NK_FORMAT_R32G32B32A32: { + nk_uint col[4]; + col[0] = (nk_uint)NK_CLAMP(NK_UINT_MIN, values[0] * NK_UINT_MAX, NK_UINT_MAX); + col[1] = (nk_uint)NK_CLAMP(NK_UINT_MIN, values[1] * NK_UINT_MAX, NK_UINT_MAX); + col[2] = (nk_uint)NK_CLAMP(NK_UINT_MIN, values[2] * NK_UINT_MAX, NK_UINT_MAX); + col[3] = (nk_uint)NK_CLAMP(NK_UINT_MIN, values[3] * NK_UINT_MAX, NK_UINT_MAX); + NK_MEMCPY(attribute, col, sizeof(col)); + } break; + case NK_FORMAT_R32G32B32A32_FLOAT: + NK_MEMCPY(attribute, values, sizeof(float)*4); + break; + case NK_FORMAT_R32G32B32A32_DOUBLE: { + double col[4]; + col[0] = (double)NK_SATURATE(values[0]); + col[1] = (double)NK_SATURATE(values[1]); + col[2] = (double)NK_SATURATE(values[2]); + col[3] = (double)NK_SATURATE(values[3]); + NK_MEMCPY(attribute, col, sizeof(col)); + } break; + case NK_FORMAT_RGB32: + case NK_FORMAT_RGBA32: { + struct nk_color col = nk_rgba_fv(values); + nk_uint color = nk_color_u32(col); + NK_MEMCPY(attribute, &color, sizeof(color)); + } break; + } +} + +NK_INTERN void +nk_draw_vertex_element(void *dst, const float *values, int value_count, + enum nk_draw_vertex_layout_format format) +{ + int value_index; + void *attribute = dst; + /* if this triggers you tried to provide a color format for a value */ + NK_ASSERT(format < NK_FORMAT_COLOR_BEGIN); + if (format >= NK_FORMAT_COLOR_BEGIN && format <= NK_FORMAT_COLOR_END) return; + for (value_index = 0; value_index < value_count; ++value_index) { + switch (format) { + default: NK_ASSERT(0 && "invalid vertex layout format"); break; + case NK_FORMAT_SCHAR: { + char value = (char)NK_CLAMP(NK_SCHAR_MIN, values[value_index], NK_SCHAR_MAX); + NK_MEMCPY(attribute, &value, sizeof(value)); + attribute = (void*)((char*)attribute + sizeof(char)); + } break; + case NK_FORMAT_SSHORT: { + nk_short value = (nk_short)NK_CLAMP(NK_SSHORT_MIN, values[value_index], NK_SSHORT_MAX); + NK_MEMCPY(attribute, &value, sizeof(value)); + attribute = (void*)((char*)attribute + sizeof(value)); + } break; + case NK_FORMAT_SINT: { + nk_int value = (nk_int)NK_CLAMP(NK_SINT_MIN, values[value_index], NK_SINT_MAX); + NK_MEMCPY(attribute, &value, sizeof(value)); + attribute = (void*)((char*)attribute + sizeof(nk_int)); + } break; + case NK_FORMAT_UCHAR: { + unsigned char value = (unsigned char)NK_CLAMP(NK_UCHAR_MIN, values[value_index], NK_UCHAR_MAX); + NK_MEMCPY(attribute, &value, sizeof(value)); + attribute = (void*)((char*)attribute + sizeof(unsigned char)); + } break; + case NK_FORMAT_USHORT: { + nk_ushort value = (nk_ushort)NK_CLAMP(NK_USHORT_MIN, values[value_index], NK_USHORT_MAX); + NK_MEMCPY(attribute, &value, sizeof(value)); + attribute = (void*)((char*)attribute + sizeof(value)); + } break; + case NK_FORMAT_UINT: { + nk_uint value = (nk_uint)NK_CLAMP(NK_UINT_MIN, values[value_index], NK_UINT_MAX); + NK_MEMCPY(attribute, &value, sizeof(value)); + attribute = (void*)((char*)attribute + sizeof(nk_uint)); + } break; + case NK_FORMAT_FLOAT: + NK_MEMCPY(attribute, &values[value_index], sizeof(values[value_index])); + attribute = (void*)((char*)attribute + sizeof(float)); + break; + case NK_FORMAT_DOUBLE: { + double value = (double)values[value_index]; + NK_MEMCPY(attribute, &value, sizeof(value)); + attribute = (void*)((char*)attribute + sizeof(double)); + } break; + } + } +} + +NK_INTERN void* +nk_draw_vertex(void *dst, const struct nk_convert_config *config, + struct nk_vec2 pos, struct nk_vec2 uv, struct nk_colorf color) +{ + void *result = (void*)((char*)dst + config->vertex_size); + const struct nk_draw_vertex_layout_element *elem_iter = config->vertex_layout; + while (!nk_draw_vertex_layout_element_is_end_of_layout(elem_iter)) { + void *address = (void*)((char*)dst + elem_iter->offset); + switch (elem_iter->attribute) { + case NK_VERTEX_ATTRIBUTE_COUNT: + default: NK_ASSERT(0 && "wrong element attribute"); + case NK_VERTEX_POSITION: nk_draw_vertex_element(address, &pos.x, 2, elem_iter->format); break; + case NK_VERTEX_TEXCOORD: nk_draw_vertex_element(address, &uv.x, 2, elem_iter->format); break; + case NK_VERTEX_COLOR: nk_draw_vertex_color(address, &color.r, elem_iter->format); break; + } + elem_iter++; + } + return result; +} + +NK_API void +nk_draw_list_stroke_poly_line(struct nk_draw_list *list, const struct nk_vec2 *points, + const unsigned int points_count, struct nk_color color, enum nk_draw_list_stroke closed, + float thickness, enum nk_anti_aliasing aliasing) +{ + nk_size count; + int thick_line; + struct nk_colorf col; + struct nk_colorf col_trans; + NK_ASSERT(list); + if (!list || points_count < 2) return; + + color.a = (nk_byte)((float)color.a * list->config.global_alpha); + count = points_count; + if (!closed) count = points_count-1; + thick_line = thickness > 1.0f; + +#ifdef NK_INCLUDE_COMMAND_USERDATA + nk_draw_list_push_userdata(list, list->userdata); +#endif + + color.a = (nk_byte)((float)color.a * list->config.global_alpha); + nk_color_fv(&col.r, color); + col_trans = col; + col_trans.a = 0; + + if (aliasing == NK_ANTI_ALIASING_ON) { + /* ANTI-ALIASED STROKE */ + const float AA_SIZE = 1.0f; + NK_STORAGE const nk_size pnt_align = NK_ALIGNOF(struct nk_vec2); + NK_STORAGE const nk_size pnt_size = sizeof(struct nk_vec2); + + /* allocate vertices and elements */ + nk_size i1 = 0; + nk_size vertex_offset; + nk_size index = list->vertex_count; + + const nk_size idx_count = (thick_line) ? (count * 18) : (count * 12); + const nk_size vtx_count = (thick_line) ? (points_count * 4): (points_count *3); + + void *vtx = nk_draw_list_alloc_vertices(list, vtx_count); + nk_draw_index *ids = nk_draw_list_alloc_elements(list, idx_count); + + nk_size size; + struct nk_vec2 *normals, *temp; + if (!vtx || !ids) return; + + /* temporary allocate normals + points */ + vertex_offset = (nk_size)((nk_byte*)vtx - (nk_byte*)list->vertices->memory.ptr); + nk_buffer_mark(list->vertices, NK_BUFFER_FRONT); + size = pnt_size * ((thick_line) ? 5 : 3) * points_count; + normals = (struct nk_vec2*) nk_buffer_alloc(list->vertices, NK_BUFFER_FRONT, size, pnt_align); + NK_ASSERT(normals); + if (!normals) return; + temp = normals + points_count; + + /* make sure vertex pointer is still correct */ + vtx = (void*)((nk_byte*)list->vertices->memory.ptr + vertex_offset); + + /* calculate normals */ + for (i1 = 0; i1 < count; ++i1) { + const nk_size i2 = ((i1 + 1) == points_count) ? 0 : (i1 + 1); + struct nk_vec2 diff = nk_vec2_sub(points[i2], points[i1]); + float len; + + /* vec2 inverted length */ + len = nk_vec2_len_sqr(diff); + if (len != 0.0f) + len = nk_inv_sqrt(len); + else len = 1.0f; + + diff = nk_vec2_muls(diff, len); + normals[i1].x = diff.y; + normals[i1].y = -diff.x; + } + + if (!closed) + normals[points_count-1] = normals[points_count-2]; + + if (!thick_line) { + nk_size idx1, i; + if (!closed) { + struct nk_vec2 d; + temp[0] = nk_vec2_add(points[0], nk_vec2_muls(normals[0], AA_SIZE)); + temp[1] = nk_vec2_sub(points[0], nk_vec2_muls(normals[0], AA_SIZE)); + d = nk_vec2_muls(normals[points_count-1], AA_SIZE); + temp[(points_count-1) * 2 + 0] = nk_vec2_add(points[points_count-1], d); + temp[(points_count-1) * 2 + 1] = nk_vec2_sub(points[points_count-1], d); + } + + /* fill elements */ + idx1 = index; + for (i1 = 0; i1 < count; i1++) { + struct nk_vec2 dm; + float dmr2; + nk_size i2 = ((i1 + 1) == points_count) ? 0 : (i1 + 1); + nk_size idx2 = ((i1+1) == points_count) ? index: (idx1 + 3); + + /* average normals */ + dm = nk_vec2_muls(nk_vec2_add(normals[i1], normals[i2]), 0.5f); + dmr2 = dm.x * dm.x + dm.y* dm.y; + if (dmr2 > 0.000001f) { + float scale = 1.0f/dmr2; + scale = NK_MIN(100.0f, scale); + dm = nk_vec2_muls(dm, scale); + } + + dm = nk_vec2_muls(dm, AA_SIZE); + temp[i2*2+0] = nk_vec2_add(points[i2], dm); + temp[i2*2+1] = nk_vec2_sub(points[i2], dm); + + ids[0] = (nk_draw_index)(idx2 + 0); ids[1] = (nk_draw_index)(idx1+0); + ids[2] = (nk_draw_index)(idx1 + 2); ids[3] = (nk_draw_index)(idx1+2); + ids[4] = (nk_draw_index)(idx2 + 2); ids[5] = (nk_draw_index)(idx2+0); + ids[6] = (nk_draw_index)(idx2 + 1); ids[7] = (nk_draw_index)(idx1+1); + ids[8] = (nk_draw_index)(idx1 + 0); ids[9] = (nk_draw_index)(idx1+0); + ids[10]= (nk_draw_index)(idx2 + 0); ids[11]= (nk_draw_index)(idx2+1); + ids += 12; + idx1 = idx2; + } + + /* fill vertices */ + for (i = 0; i < points_count; ++i) { + const struct nk_vec2 uv = list->config.null.uv; + vtx = nk_draw_vertex(vtx, &list->config, points[i], uv, col); + vtx = nk_draw_vertex(vtx, &list->config, temp[i*2+0], uv, col_trans); + vtx = nk_draw_vertex(vtx, &list->config, temp[i*2+1], uv, col_trans); + } + } else { + nk_size idx1, i; + const float half_inner_thickness = (thickness - AA_SIZE) * 0.5f; + if (!closed) { + struct nk_vec2 d1 = nk_vec2_muls(normals[0], half_inner_thickness + AA_SIZE); + struct nk_vec2 d2 = nk_vec2_muls(normals[0], half_inner_thickness); + + temp[0] = nk_vec2_add(points[0], d1); + temp[1] = nk_vec2_add(points[0], d2); + temp[2] = nk_vec2_sub(points[0], d2); + temp[3] = nk_vec2_sub(points[0], d1); + + d1 = nk_vec2_muls(normals[points_count-1], half_inner_thickness + AA_SIZE); + d2 = nk_vec2_muls(normals[points_count-1], half_inner_thickness); + + temp[(points_count-1)*4+0] = nk_vec2_add(points[points_count-1], d1); + temp[(points_count-1)*4+1] = nk_vec2_add(points[points_count-1], d2); + temp[(points_count-1)*4+2] = nk_vec2_sub(points[points_count-1], d2); + temp[(points_count-1)*4+3] = nk_vec2_sub(points[points_count-1], d1); + } + + /* add all elements */ + idx1 = index; + for (i1 = 0; i1 < count; ++i1) { + struct nk_vec2 dm_out, dm_in; + const nk_size i2 = ((i1+1) == points_count) ? 0: (i1 + 1); + nk_size idx2 = ((i1+1) == points_count) ? index: (idx1 + 4); + + /* average normals */ + struct nk_vec2 dm = nk_vec2_muls(nk_vec2_add(normals[i1], normals[i2]), 0.5f); + float dmr2 = dm.x * dm.x + dm.y* dm.y; + if (dmr2 > 0.000001f) { + float scale = 1.0f/dmr2; + scale = NK_MIN(100.0f, scale); + dm = nk_vec2_muls(dm, scale); + } + + dm_out = nk_vec2_muls(dm, ((half_inner_thickness) + AA_SIZE)); + dm_in = nk_vec2_muls(dm, half_inner_thickness); + temp[i2*4+0] = nk_vec2_add(points[i2], dm_out); + temp[i2*4+1] = nk_vec2_add(points[i2], dm_in); + temp[i2*4+2] = nk_vec2_sub(points[i2], dm_in); + temp[i2*4+3] = nk_vec2_sub(points[i2], dm_out); + + /* add indexes */ + ids[0] = (nk_draw_index)(idx2 + 1); ids[1] = (nk_draw_index)(idx1+1); + ids[2] = (nk_draw_index)(idx1 + 2); ids[3] = (nk_draw_index)(idx1+2); + ids[4] = (nk_draw_index)(idx2 + 2); ids[5] = (nk_draw_index)(idx2+1); + ids[6] = (nk_draw_index)(idx2 + 1); ids[7] = (nk_draw_index)(idx1+1); + ids[8] = (nk_draw_index)(idx1 + 0); ids[9] = (nk_draw_index)(idx1+0); + ids[10]= (nk_draw_index)(idx2 + 0); ids[11] = (nk_draw_index)(idx2+1); + ids[12]= (nk_draw_index)(idx2 + 2); ids[13] = (nk_draw_index)(idx1+2); + ids[14]= (nk_draw_index)(idx1 + 3); ids[15] = (nk_draw_index)(idx1+3); + ids[16]= (nk_draw_index)(idx2 + 3); ids[17] = (nk_draw_index)(idx2+2); + ids += 18; + idx1 = idx2; + } + + /* add vertices */ + for (i = 0; i < points_count; ++i) { + const struct nk_vec2 uv = list->config.null.uv; + vtx = nk_draw_vertex(vtx, &list->config, temp[i*4+0], uv, col_trans); + vtx = nk_draw_vertex(vtx, &list->config, temp[i*4+1], uv, col); + vtx = nk_draw_vertex(vtx, &list->config, temp[i*4+2], uv, col); + vtx = nk_draw_vertex(vtx, &list->config, temp[i*4+3], uv, col_trans); + } + } + /* free temporary normals + points */ + nk_buffer_reset(list->vertices, NK_BUFFER_FRONT); + } else { + /* NON ANTI-ALIASED STROKE */ + nk_size i1 = 0; + nk_size idx = list->vertex_count; + const nk_size idx_count = count * 6; + const nk_size vtx_count = count * 4; + void *vtx = nk_draw_list_alloc_vertices(list, vtx_count); + nk_draw_index *ids = nk_draw_list_alloc_elements(list, idx_count); + if (!vtx || !ids) return; + + for (i1 = 0; i1 < count; ++i1) { + float dx, dy; + const struct nk_vec2 uv = list->config.null.uv; + const nk_size i2 = ((i1+1) == points_count) ? 0 : i1 + 1; + const struct nk_vec2 p1 = points[i1]; + const struct nk_vec2 p2 = points[i2]; + struct nk_vec2 diff = nk_vec2_sub(p2, p1); + float len; + + /* vec2 inverted length */ + len = nk_vec2_len_sqr(diff); + if (len != 0.0f) + len = nk_inv_sqrt(len); + else len = 1.0f; + diff = nk_vec2_muls(diff, len); + + /* add vertices */ + dx = diff.x * (thickness * 0.5f); + dy = diff.y * (thickness * 0.5f); + + vtx = nk_draw_vertex(vtx, &list->config, nk_vec2(p1.x + dy, p1.y - dx), uv, col); + vtx = nk_draw_vertex(vtx, &list->config, nk_vec2(p2.x + dy, p2.y - dx), uv, col); + vtx = nk_draw_vertex(vtx, &list->config, nk_vec2(p2.x - dy, p2.y + dx), uv, col); + vtx = nk_draw_vertex(vtx, &list->config, nk_vec2(p1.x - dy, p1.y + dx), uv, col); + + ids[0] = (nk_draw_index)(idx+0); ids[1] = (nk_draw_index)(idx+1); + ids[2] = (nk_draw_index)(idx+2); ids[3] = (nk_draw_index)(idx+0); + ids[4] = (nk_draw_index)(idx+2); ids[5] = (nk_draw_index)(idx+3); + + ids += 6; + idx += 4; + } + } +} + +NK_API void +nk_draw_list_fill_poly_convex(struct nk_draw_list *list, + const struct nk_vec2 *points, const unsigned int points_count, + struct nk_color color, enum nk_anti_aliasing aliasing) +{ + struct nk_colorf col; + struct nk_colorf col_trans; + + NK_STORAGE const nk_size pnt_align = NK_ALIGNOF(struct nk_vec2); + NK_STORAGE const nk_size pnt_size = sizeof(struct nk_vec2); + NK_ASSERT(list); + if (!list || points_count < 3) return; + +#ifdef NK_INCLUDE_COMMAND_USERDATA + nk_draw_list_push_userdata(list, list->userdata); +#endif + + color.a = (nk_byte)((float)color.a * list->config.global_alpha); + nk_color_fv(&col.r, color); + col_trans = col; + col_trans.a = 0; + + if (aliasing == NK_ANTI_ALIASING_ON) { + nk_size i = 0; + nk_size i0 = 0; + nk_size i1 = 0; + + const float AA_SIZE = 1.0f; + nk_size vertex_offset = 0; + nk_size index = list->vertex_count; + + const nk_size idx_count = (points_count-2)*3 + points_count*6; + const nk_size vtx_count = (points_count*2); + + void *vtx = nk_draw_list_alloc_vertices(list, vtx_count); + nk_draw_index *ids = nk_draw_list_alloc_elements(list, idx_count); + + nk_size size = 0; + struct nk_vec2 *normals = 0; + unsigned int vtx_inner_idx = (unsigned int)(index + 0); + unsigned int vtx_outer_idx = (unsigned int)(index + 1); + if (!vtx || !ids) return; + + /* temporary allocate normals */ + vertex_offset = (nk_size)((nk_byte*)vtx - (nk_byte*)list->vertices->memory.ptr); + nk_buffer_mark(list->vertices, NK_BUFFER_FRONT); + size = pnt_size * points_count; + normals = (struct nk_vec2*) nk_buffer_alloc(list->vertices, NK_BUFFER_FRONT, size, pnt_align); + NK_ASSERT(normals); + if (!normals) return; + vtx = (void*)((nk_byte*)list->vertices->memory.ptr + vertex_offset); + + /* add elements */ + for (i = 2; i < points_count; i++) { + ids[0] = (nk_draw_index)(vtx_inner_idx); + ids[1] = (nk_draw_index)(vtx_inner_idx + ((i-1) << 1)); + ids[2] = (nk_draw_index)(vtx_inner_idx + (i << 1)); + ids += 3; + } + + /* compute normals */ + for (i0 = points_count-1, i1 = 0; i1 < points_count; i0 = i1++) { + struct nk_vec2 p0 = points[i0]; + struct nk_vec2 p1 = points[i1]; + struct nk_vec2 diff = nk_vec2_sub(p1, p0); + + /* vec2 inverted length */ + float len = nk_vec2_len_sqr(diff); + if (len != 0.0f) + len = nk_inv_sqrt(len); + else len = 1.0f; + diff = nk_vec2_muls(diff, len); + + normals[i0].x = diff.y; + normals[i0].y = -diff.x; + } + + /* add vertices + indexes */ + for (i0 = points_count-1, i1 = 0; i1 < points_count; i0 = i1++) { + const struct nk_vec2 uv = list->config.null.uv; + struct nk_vec2 n0 = normals[i0]; + struct nk_vec2 n1 = normals[i1]; + struct nk_vec2 dm = nk_vec2_muls(nk_vec2_add(n0, n1), 0.5f); + float dmr2 = dm.x*dm.x + dm.y*dm.y; + if (dmr2 > 0.000001f) { + float scale = 1.0f / dmr2; + scale = NK_MIN(scale, 100.0f); + dm = nk_vec2_muls(dm, scale); + } + dm = nk_vec2_muls(dm, AA_SIZE * 0.5f); + + /* add vertices */ + vtx = nk_draw_vertex(vtx, &list->config, nk_vec2_sub(points[i1], dm), uv, col); + vtx = nk_draw_vertex(vtx, &list->config, nk_vec2_add(points[i1], dm), uv, col_trans); + + /* add indexes */ + ids[0] = (nk_draw_index)(vtx_inner_idx+(i1<<1)); + ids[1] = (nk_draw_index)(vtx_inner_idx+(i0<<1)); + ids[2] = (nk_draw_index)(vtx_outer_idx+(i0<<1)); + ids[3] = (nk_draw_index)(vtx_outer_idx+(i0<<1)); + ids[4] = (nk_draw_index)(vtx_outer_idx+(i1<<1)); + ids[5] = (nk_draw_index)(vtx_inner_idx+(i1<<1)); + ids += 6; + } + /* free temporary normals + points */ + nk_buffer_reset(list->vertices, NK_BUFFER_FRONT); + } else { + nk_size i = 0; + nk_size index = list->vertex_count; + const nk_size idx_count = (points_count-2)*3; + const nk_size vtx_count = points_count; + void *vtx = nk_draw_list_alloc_vertices(list, vtx_count); + nk_draw_index *ids = nk_draw_list_alloc_elements(list, idx_count); + + if (!vtx || !ids) return; + for (i = 0; i < vtx_count; ++i) + vtx = nk_draw_vertex(vtx, &list->config, points[i], list->config.null.uv, col); + for (i = 2; i < points_count; ++i) { + ids[0] = (nk_draw_index)index; + ids[1] = (nk_draw_index)(index+ i - 1); + ids[2] = (nk_draw_index)(index+i); + ids += 3; + } + } +} + +NK_API void +nk_draw_list_path_clear(struct nk_draw_list *list) +{ + NK_ASSERT(list); + if (!list) return; + nk_buffer_reset(list->buffer, NK_BUFFER_FRONT); + list->path_count = 0; + list->path_offset = 0; +} + +NK_API void +nk_draw_list_path_line_to(struct nk_draw_list *list, struct nk_vec2 pos) +{ + struct nk_vec2 *points = 0; + struct nk_draw_command *cmd = 0; + NK_ASSERT(list); + if (!list) return; + if (!list->cmd_count) + nk_draw_list_add_clip(list, nk_null_rect); + + cmd = nk_draw_list_command_last(list); + if (cmd && cmd->texture.ptr != list->config.null.texture.ptr) + nk_draw_list_push_image(list, list->config.null.texture); + + points = nk_draw_list_alloc_path(list, 1); + if (!points) return; + points[0] = pos; +} + +NK_API void +nk_draw_list_path_arc_to_fast(struct nk_draw_list *list, struct nk_vec2 center, + float radius, int a_min, int a_max) +{ + int a = 0; + NK_ASSERT(list); + if (!list) return; + if (a_min <= a_max) { + for (a = a_min; a <= a_max; a++) { + const struct nk_vec2 c = list->circle_vtx[(nk_size)a % NK_LEN(list->circle_vtx)]; + const float x = center.x + c.x * radius; + const float y = center.y + c.y * radius; + nk_draw_list_path_line_to(list, nk_vec2(x, y)); + } + } +} + +NK_API void +nk_draw_list_path_arc_to(struct nk_draw_list *list, struct nk_vec2 center, + float radius, float a_min, float a_max, unsigned int segments) +{ + unsigned int i = 0; + NK_ASSERT(list); + if (!list) return; + if (radius == 0.0f) return; + + /* This algorithm for arc drawing relies on these two trigonometric identities[1]: + sin(a + b) = sin(a) * cos(b) + cos(a) * sin(b) + cos(a + b) = cos(a) * cos(b) - sin(a) * sin(b) + + Two coordinates (x, y) of a point on a circle centered on + the origin can be written in polar form as: + x = r * cos(a) + y = r * sin(a) + where r is the radius of the circle, + a is the angle between (x, y) and the origin. + + This allows us to rotate the coordinates around the + origin by an angle b using the following transformation: + x' = r * cos(a + b) = x * cos(b) - y * sin(b) + y' = r * sin(a + b) = y * cos(b) + x * sin(b) + + [1] https://en.wikipedia.org/wiki/List_of_trigonometric_identities#Angle_sum_and_difference_identities + */ + {const float d_angle = (a_max - a_min) / (float)segments; + const float sin_d = (float)NK_SIN(d_angle); + const float cos_d = (float)NK_COS(d_angle); + + float cx = (float)NK_COS(a_min) * radius; + float cy = (float)NK_SIN(a_min) * radius; + for(i = 0; i <= segments; ++i) { + float new_cx, new_cy; + const float x = center.x + cx; + const float y = center.y + cy; + nk_draw_list_path_line_to(list, nk_vec2(x, y)); + + new_cx = cx * cos_d - cy * sin_d; + new_cy = cy * cos_d + cx * sin_d; + cx = new_cx; + cy = new_cy; + }} +} + +NK_API void +nk_draw_list_path_rect_to(struct nk_draw_list *list, struct nk_vec2 a, + struct nk_vec2 b, float rounding) +{ + float r; + NK_ASSERT(list); + if (!list) return; + r = rounding; + r = NK_MIN(r, ((b.x-a.x) < 0) ? -(b.x-a.x): (b.x-a.x)); + r = NK_MIN(r, ((b.y-a.y) < 0) ? -(b.y-a.y): (b.y-a.y)); + + if (r == 0.0f) { + nk_draw_list_path_line_to(list, a); + nk_draw_list_path_line_to(list, nk_vec2(b.x,a.y)); + nk_draw_list_path_line_to(list, b); + nk_draw_list_path_line_to(list, nk_vec2(a.x,b.y)); + } else { + nk_draw_list_path_arc_to_fast(list, nk_vec2(a.x + r, a.y + r), r, 6, 9); + nk_draw_list_path_arc_to_fast(list, nk_vec2(b.x - r, a.y + r), r, 9, 12); + nk_draw_list_path_arc_to_fast(list, nk_vec2(b.x - r, b.y - r), r, 0, 3); + nk_draw_list_path_arc_to_fast(list, nk_vec2(a.x + r, b.y - r), r, 3, 6); + } +} + +NK_API void +nk_draw_list_path_curve_to(struct nk_draw_list *list, struct nk_vec2 p2, + struct nk_vec2 p3, struct nk_vec2 p4, unsigned int num_segments) +{ + float t_step; + unsigned int i_step; + struct nk_vec2 p1; + + NK_ASSERT(list); + NK_ASSERT(list->path_count); + if (!list || !list->path_count) return; + num_segments = NK_MAX(num_segments, 1); + + p1 = nk_draw_list_path_last(list); + t_step = 1.0f/(float)num_segments; + for (i_step = 1; i_step <= num_segments; ++i_step) { + float t = t_step * (float)i_step; + float u = 1.0f - t; + float w1 = u*u*u; + float w2 = 3*u*u*t; + float w3 = 3*u*t*t; + float w4 = t * t *t; + float x = w1 * p1.x + w2 * p2.x + w3 * p3.x + w4 * p4.x; + float y = w1 * p1.y + w2 * p2.y + w3 * p3.y + w4 * p4.y; + nk_draw_list_path_line_to(list, nk_vec2(x,y)); + } +} + +NK_API void +nk_draw_list_path_fill(struct nk_draw_list *list, struct nk_color color) +{ + struct nk_vec2 *points; + NK_ASSERT(list); + if (!list) return; + points = (struct nk_vec2*)nk_buffer_memory(list->buffer); + nk_draw_list_fill_poly_convex(list, points, list->path_count, color, list->config.shape_AA); + nk_draw_list_path_clear(list); +} + +NK_API void +nk_draw_list_path_stroke(struct nk_draw_list *list, struct nk_color color, + enum nk_draw_list_stroke closed, float thickness) +{ + struct nk_vec2 *points; + NK_ASSERT(list); + if (!list) return; + points = (struct nk_vec2*)nk_buffer_memory(list->buffer); + nk_draw_list_stroke_poly_line(list, points, list->path_count, color, + closed, thickness, list->config.line_AA); + nk_draw_list_path_clear(list); +} + +NK_API void +nk_draw_list_stroke_line(struct nk_draw_list *list, struct nk_vec2 a, + struct nk_vec2 b, struct nk_color col, float thickness) +{ + NK_ASSERT(list); + if (!list || !col.a) return; + if (list->line_AA == NK_ANTI_ALIASING_ON) { + nk_draw_list_path_line_to(list, a); + nk_draw_list_path_line_to(list, b); + } else { + nk_draw_list_path_line_to(list, nk_vec2_sub(a,nk_vec2(0.5f,0.5f))); + nk_draw_list_path_line_to(list, nk_vec2_sub(b,nk_vec2(0.5f,0.5f))); + } + nk_draw_list_path_stroke(list, col, NK_STROKE_OPEN, thickness); +} + +NK_API void +nk_draw_list_fill_rect(struct nk_draw_list *list, struct nk_rect rect, + struct nk_color col, float rounding) +{ + NK_ASSERT(list); + if (!list || !col.a) return; + + if (list->line_AA == NK_ANTI_ALIASING_ON) { + nk_draw_list_path_rect_to(list, nk_vec2(rect.x, rect.y), + nk_vec2(rect.x + rect.w, rect.y + rect.h), rounding); + } else { + nk_draw_list_path_rect_to(list, nk_vec2(rect.x-0.5f, rect.y-0.5f), + nk_vec2(rect.x + rect.w, rect.y + rect.h), rounding); + } nk_draw_list_path_fill(list, col); +} + +NK_API void +nk_draw_list_stroke_rect(struct nk_draw_list *list, struct nk_rect rect, + struct nk_color col, float rounding, float thickness) +{ + NK_ASSERT(list); + if (!list || !col.a) return; + if (list->line_AA == NK_ANTI_ALIASING_ON) { + nk_draw_list_path_rect_to(list, nk_vec2(rect.x, rect.y), + nk_vec2(rect.x + rect.w, rect.y + rect.h), rounding); + } else { + nk_draw_list_path_rect_to(list, nk_vec2(rect.x-0.5f, rect.y-0.5f), + nk_vec2(rect.x + rect.w, rect.y + rect.h), rounding); + } nk_draw_list_path_stroke(list, col, NK_STROKE_CLOSED, thickness); +} + +NK_API void +nk_draw_list_fill_rect_multi_color(struct nk_draw_list *list, struct nk_rect rect, + struct nk_color left, struct nk_color top, struct nk_color right, + struct nk_color bottom) +{ + void *vtx; + struct nk_colorf col_left, col_top; + struct nk_colorf col_right, col_bottom; + nk_draw_index *idx; + nk_draw_index index; + + nk_color_fv(&col_left.r, left); + nk_color_fv(&col_right.r, right); + nk_color_fv(&col_top.r, top); + nk_color_fv(&col_bottom.r, bottom); + + NK_ASSERT(list); + if (!list) return; + + nk_draw_list_push_image(list, list->config.null.texture); + index = (nk_draw_index)list->vertex_count; + vtx = nk_draw_list_alloc_vertices(list, 4); + idx = nk_draw_list_alloc_elements(list, 6); + if (!vtx || !idx) return; + + idx[0] = (nk_draw_index)(index+0); idx[1] = (nk_draw_index)(index+1); + idx[2] = (nk_draw_index)(index+2); idx[3] = (nk_draw_index)(index+0); + idx[4] = (nk_draw_index)(index+2); idx[5] = (nk_draw_index)(index+3); + + vtx = nk_draw_vertex(vtx, &list->config, nk_vec2(rect.x, rect.y), list->config.null.uv, col_left); + vtx = nk_draw_vertex(vtx, &list->config, nk_vec2(rect.x + rect.w, rect.y), list->config.null.uv, col_top); + vtx = nk_draw_vertex(vtx, &list->config, nk_vec2(rect.x + rect.w, rect.y + rect.h), list->config.null.uv, col_right); + vtx = nk_draw_vertex(vtx, &list->config, nk_vec2(rect.x, rect.y + rect.h), list->config.null.uv, col_bottom); +} + +NK_API void +nk_draw_list_fill_triangle(struct nk_draw_list *list, struct nk_vec2 a, + struct nk_vec2 b, struct nk_vec2 c, struct nk_color col) +{ + NK_ASSERT(list); + if (!list || !col.a) return; + nk_draw_list_path_line_to(list, a); + nk_draw_list_path_line_to(list, b); + nk_draw_list_path_line_to(list, c); + nk_draw_list_path_fill(list, col); +} + +NK_API void +nk_draw_list_stroke_triangle(struct nk_draw_list *list, struct nk_vec2 a, + struct nk_vec2 b, struct nk_vec2 c, struct nk_color col, float thickness) +{ + NK_ASSERT(list); + if (!list || !col.a) return; + nk_draw_list_path_line_to(list, a); + nk_draw_list_path_line_to(list, b); + nk_draw_list_path_line_to(list, c); + nk_draw_list_path_stroke(list, col, NK_STROKE_CLOSED, thickness); +} + +NK_API void +nk_draw_list_fill_circle(struct nk_draw_list *list, struct nk_vec2 center, + float radius, struct nk_color col, unsigned int segs) +{ + float a_max; + NK_ASSERT(list); + if (!list || !col.a) return; + a_max = NK_PI * 2.0f * ((float)segs - 1.0f) / (float)segs; + nk_draw_list_path_arc_to(list, center, radius, 0.0f, a_max, segs); + nk_draw_list_path_fill(list, col); +} + +NK_API void +nk_draw_list_stroke_circle(struct nk_draw_list *list, struct nk_vec2 center, + float radius, struct nk_color col, unsigned int segs, float thickness) +{ + float a_max; + NK_ASSERT(list); + if (!list || !col.a) return; + a_max = NK_PI * 2.0f * ((float)segs - 1.0f) / (float)segs; + nk_draw_list_path_arc_to(list, center, radius, 0.0f, a_max, segs); + nk_draw_list_path_stroke(list, col, NK_STROKE_CLOSED, thickness); +} + +NK_API void +nk_draw_list_stroke_curve(struct nk_draw_list *list, struct nk_vec2 p0, + struct nk_vec2 cp0, struct nk_vec2 cp1, struct nk_vec2 p1, + struct nk_color col, unsigned int segments, float thickness) +{ + NK_ASSERT(list); + if (!list || !col.a) return; + nk_draw_list_path_line_to(list, p0); + nk_draw_list_path_curve_to(list, cp0, cp1, p1, segments); + nk_draw_list_path_stroke(list, col, NK_STROKE_OPEN, thickness); +} + +NK_INTERN void +nk_draw_list_push_rect_uv(struct nk_draw_list *list, struct nk_vec2 a, + struct nk_vec2 c, struct nk_vec2 uva, struct nk_vec2 uvc, + struct nk_color color) +{ + void *vtx; + struct nk_vec2 uvb; + struct nk_vec2 uvd; + struct nk_vec2 b; + struct nk_vec2 d; + + struct nk_colorf col; + nk_draw_index *idx; + nk_draw_index index; + NK_ASSERT(list); + if (!list) return; + + nk_color_fv(&col.r, color); + uvb = nk_vec2(uvc.x, uva.y); + uvd = nk_vec2(uva.x, uvc.y); + b = nk_vec2(c.x, a.y); + d = nk_vec2(a.x, c.y); + + index = (nk_draw_index)list->vertex_count; + vtx = nk_draw_list_alloc_vertices(list, 4); + idx = nk_draw_list_alloc_elements(list, 6); + if (!vtx || !idx) return; + + idx[0] = (nk_draw_index)(index+0); idx[1] = (nk_draw_index)(index+1); + idx[2] = (nk_draw_index)(index+2); idx[3] = (nk_draw_index)(index+0); + idx[4] = (nk_draw_index)(index+2); idx[5] = (nk_draw_index)(index+3); + + vtx = nk_draw_vertex(vtx, &list->config, a, uva, col); + vtx = nk_draw_vertex(vtx, &list->config, b, uvb, col); + vtx = nk_draw_vertex(vtx, &list->config, c, uvc, col); + vtx = nk_draw_vertex(vtx, &list->config, d, uvd, col); +} + +NK_API void +nk_draw_list_add_image(struct nk_draw_list *list, struct nk_image texture, + struct nk_rect rect, struct nk_color color) +{ + NK_ASSERT(list); + if (!list) return; + /* push new command with given texture */ + nk_draw_list_push_image(list, texture.handle); + if (nk_image_is_subimage(&texture)) { + /* add region inside of the texture */ + struct nk_vec2 uv[2]; + uv[0].x = (float)texture.region[0]/(float)texture.w; + uv[0].y = (float)texture.region[1]/(float)texture.h; + uv[1].x = (float)(texture.region[0] + texture.region[2])/(float)texture.w; + uv[1].y = (float)(texture.region[1] + texture.region[3])/(float)texture.h; + nk_draw_list_push_rect_uv(list, nk_vec2(rect.x, rect.y), + nk_vec2(rect.x + rect.w, rect.y + rect.h), uv[0], uv[1], color); + } else nk_draw_list_push_rect_uv(list, nk_vec2(rect.x, rect.y), + nk_vec2(rect.x + rect.w, rect.y + rect.h), + nk_vec2(0.0f, 0.0f), nk_vec2(1.0f, 1.0f),color); +} + +NK_API void +nk_draw_list_add_text(struct nk_draw_list *list, const struct nk_user_font *font, + struct nk_rect rect, const char *text, int len, float font_height, + struct nk_color fg) +{ + float x = 0; + int text_len = 0; + nk_rune unicode = 0; + nk_rune next = 0; + int glyph_len = 0; + int next_glyph_len = 0; + struct nk_user_font_glyph g; + + NK_ASSERT(list); + if (!list || !len || !text) return; + if (!NK_INTERSECT(rect.x, rect.y, rect.w, rect.h, + list->clip_rect.x, list->clip_rect.y, list->clip_rect.w, list->clip_rect.h)) return; + + nk_draw_list_push_image(list, font->texture); + x = rect.x; + glyph_len = nk_utf_decode(text, &unicode, len); + if (!glyph_len) return; + + /* draw every glyph image */ + fg.a = (nk_byte)((float)fg.a * list->config.global_alpha); + while (text_len < len && glyph_len) { + float gx, gy, gh, gw; + float char_width = 0; + if (unicode == NK_UTF_INVALID) break; + + /* query currently drawn glyph information */ + next_glyph_len = nk_utf_decode(text + text_len + glyph_len, &next, (int)len - text_len); + font->query(font->userdata, font_height, &g, unicode, + (next == NK_UTF_INVALID) ? '\0' : next); + + /* calculate and draw glyph drawing rectangle and image */ + gx = x + g.offset.x; + gy = rect.y + g.offset.y; + gw = g.width; gh = g.height; + char_width = g.xadvance; + nk_draw_list_push_rect_uv(list, nk_vec2(gx,gy), nk_vec2(gx + gw, gy+ gh), + g.uv[0], g.uv[1], fg); + + /* offset next glyph */ + text_len += glyph_len; + x += char_width; + glyph_len = next_glyph_len; + unicode = next; + } +} + +NK_API nk_flags +nk_convert(struct nk_context *ctx, struct nk_buffer *cmds, + struct nk_buffer *vertices, struct nk_buffer *elements, + const struct nk_convert_config *config) +{ + nk_flags res = NK_CONVERT_SUCCESS; + const struct nk_command *cmd; + NK_ASSERT(ctx); + NK_ASSERT(cmds); + NK_ASSERT(vertices); + NK_ASSERT(elements); + NK_ASSERT(config); + NK_ASSERT(config->vertex_layout); + NK_ASSERT(config->vertex_size); + if (!ctx || !cmds || !vertices || !elements || !config || !config->vertex_layout) + return NK_CONVERT_INVALID_PARAM; + + nk_draw_list_setup(&ctx->draw_list, config, cmds, vertices, elements, + config->line_AA, config->shape_AA); + nk_foreach(cmd, ctx) + { +#ifdef NK_INCLUDE_COMMAND_USERDATA + ctx->draw_list.userdata = cmd->userdata; +#endif + switch (cmd->type) { + case NK_COMMAND_NOP: break; + case NK_COMMAND_SCISSOR: { + const struct nk_command_scissor *s = (const struct nk_command_scissor*)cmd; + nk_draw_list_add_clip(&ctx->draw_list, nk_rect(s->x, s->y, s->w, s->h)); + } break; + case NK_COMMAND_LINE: { + const struct nk_command_line *l = (const struct nk_command_line*)cmd; + nk_draw_list_stroke_line(&ctx->draw_list, nk_vec2(l->begin.x, l->begin.y), + nk_vec2(l->end.x, l->end.y), l->color, l->line_thickness); + } break; + case NK_COMMAND_CURVE: { + const struct nk_command_curve *q = (const struct nk_command_curve*)cmd; + nk_draw_list_stroke_curve(&ctx->draw_list, nk_vec2(q->begin.x, q->begin.y), + nk_vec2(q->ctrl[0].x, q->ctrl[0].y), nk_vec2(q->ctrl[1].x, + q->ctrl[1].y), nk_vec2(q->end.x, q->end.y), q->color, + config->curve_segment_count, q->line_thickness); + } break; + case NK_COMMAND_RECT: { + const struct nk_command_rect *r = (const struct nk_command_rect*)cmd; + nk_draw_list_stroke_rect(&ctx->draw_list, nk_rect(r->x, r->y, r->w, r->h), + r->color, (float)r->rounding, r->line_thickness); + } break; + case NK_COMMAND_RECT_FILLED: { + const struct nk_command_rect_filled *r = (const struct nk_command_rect_filled*)cmd; + nk_draw_list_fill_rect(&ctx->draw_list, nk_rect(r->x, r->y, r->w, r->h), + r->color, (float)r->rounding); + } break; + case NK_COMMAND_RECT_MULTI_COLOR: { + const struct nk_command_rect_multi_color *r = (const struct nk_command_rect_multi_color*)cmd; + nk_draw_list_fill_rect_multi_color(&ctx->draw_list, nk_rect(r->x, r->y, r->w, r->h), + r->left, r->top, r->right, r->bottom); + } break; + case NK_COMMAND_CIRCLE: { + const struct nk_command_circle *c = (const struct nk_command_circle*)cmd; + nk_draw_list_stroke_circle(&ctx->draw_list, nk_vec2((float)c->x + (float)c->w/2, + (float)c->y + (float)c->h/2), (float)c->w/2, c->color, + config->circle_segment_count, c->line_thickness); + } break; + case NK_COMMAND_CIRCLE_FILLED: { + const struct nk_command_circle_filled *c = (const struct nk_command_circle_filled *)cmd; + nk_draw_list_fill_circle(&ctx->draw_list, nk_vec2((float)c->x + (float)c->w/2, + (float)c->y + (float)c->h/2), (float)c->w/2, c->color, + config->circle_segment_count); + } break; + case NK_COMMAND_ARC: { + const struct nk_command_arc *c = (const struct nk_command_arc*)cmd; + nk_draw_list_path_line_to(&ctx->draw_list, nk_vec2(c->cx, c->cy)); + nk_draw_list_path_arc_to(&ctx->draw_list, nk_vec2(c->cx, c->cy), c->r, + c->a[0], c->a[1], config->arc_segment_count); + nk_draw_list_path_stroke(&ctx->draw_list, c->color, NK_STROKE_CLOSED, c->line_thickness); + } break; + case NK_COMMAND_ARC_FILLED: { + const struct nk_command_arc_filled *c = (const struct nk_command_arc_filled*)cmd; + nk_draw_list_path_line_to(&ctx->draw_list, nk_vec2(c->cx, c->cy)); + nk_draw_list_path_arc_to(&ctx->draw_list, nk_vec2(c->cx, c->cy), c->r, + c->a[0], c->a[1], config->arc_segment_count); + nk_draw_list_path_fill(&ctx->draw_list, c->color); + } break; + case NK_COMMAND_TRIANGLE: { + const struct nk_command_triangle *t = (const struct nk_command_triangle*)cmd; + nk_draw_list_stroke_triangle(&ctx->draw_list, nk_vec2(t->a.x, t->a.y), + nk_vec2(t->b.x, t->b.y), nk_vec2(t->c.x, t->c.y), t->color, + t->line_thickness); + } break; + case NK_COMMAND_TRIANGLE_FILLED: { + const struct nk_command_triangle_filled *t = (const struct nk_command_triangle_filled*)cmd; + nk_draw_list_fill_triangle(&ctx->draw_list, nk_vec2(t->a.x, t->a.y), + nk_vec2(t->b.x, t->b.y), nk_vec2(t->c.x, t->c.y), t->color); + } break; + case NK_COMMAND_POLYGON: { + int i; + const struct nk_command_polygon*p = (const struct nk_command_polygon*)cmd; + for (i = 0; i < p->point_count; ++i) { + struct nk_vec2 pnt = nk_vec2((float)p->points[i].x, (float)p->points[i].y); + nk_draw_list_path_line_to(&ctx->draw_list, pnt); + } + nk_draw_list_path_stroke(&ctx->draw_list, p->color, NK_STROKE_CLOSED, p->line_thickness); + } break; + case NK_COMMAND_POLYGON_FILLED: { + int i; + const struct nk_command_polygon_filled *p = (const struct nk_command_polygon_filled*)cmd; + for (i = 0; i < p->point_count; ++i) { + struct nk_vec2 pnt = nk_vec2((float)p->points[i].x, (float)p->points[i].y); + nk_draw_list_path_line_to(&ctx->draw_list, pnt); + } + nk_draw_list_path_fill(&ctx->draw_list, p->color); + } break; + case NK_COMMAND_POLYLINE: { + int i; + const struct nk_command_polyline *p = (const struct nk_command_polyline*)cmd; + for (i = 0; i < p->point_count; ++i) { + struct nk_vec2 pnt = nk_vec2((float)p->points[i].x, (float)p->points[i].y); + nk_draw_list_path_line_to(&ctx->draw_list, pnt); + } + nk_draw_list_path_stroke(&ctx->draw_list, p->color, NK_STROKE_OPEN, p->line_thickness); + } break; + case NK_COMMAND_TEXT: { + const struct nk_command_text *t = (const struct nk_command_text*)cmd; + nk_draw_list_add_text(&ctx->draw_list, t->font, nk_rect(t->x, t->y, t->w, t->h), + t->string, t->length, t->height, t->foreground); + } break; + case NK_COMMAND_IMAGE: { + const struct nk_command_image *i = (const struct nk_command_image*)cmd; + nk_draw_list_add_image(&ctx->draw_list, i->img, nk_rect(i->x, i->y, i->w, i->h), i->col); + } break; + case NK_COMMAND_CUSTOM: { + const struct nk_command_custom *c = (const struct nk_command_custom*)cmd; + c->callback(&ctx->draw_list, c->x, c->y, c->w, c->h, c->callback_data); + } break; + default: break; + } + } + res |= (cmds->needed > cmds->allocated + (cmds->memory.size - cmds->size)) ? NK_CONVERT_COMMAND_BUFFER_FULL: 0; + res |= (vertices->needed > vertices->allocated) ? NK_CONVERT_VERTEX_BUFFER_FULL: 0; + res |= (elements->needed > elements->allocated) ? NK_CONVERT_ELEMENT_BUFFER_FULL: 0; + return res; +} +NK_API const struct nk_draw_command* +nk__draw_begin(const struct nk_context *ctx, + const struct nk_buffer *buffer) +{return nk__draw_list_begin(&ctx->draw_list, buffer);} + +NK_API const struct nk_draw_command* +nk__draw_end(const struct nk_context *ctx, const struct nk_buffer *buffer) +{return nk__draw_list_end(&ctx->draw_list, buffer);} + +NK_API const struct nk_draw_command* +nk__draw_next(const struct nk_draw_command *cmd, + const struct nk_buffer *buffer, const struct nk_context *ctx) +{return nk__draw_list_next(cmd, buffer, &ctx->draw_list);} + +#endif + +/* + * ============================================================== + * + * FONT HANDLING + * + * =============================================================== + */ +#ifdef NK_INCLUDE_FONT_BAKING +/* ------------------------------------------------------------- + * + * RECT PACK + * + * --------------------------------------------------------------*/ +/* stb_rect_pack.h - v0.05 - public domain - rectangle packing */ +/* Sean Barrett 2014 */ +#define NK_RP__MAXVAL 0xffff +typedef unsigned short nk_rp_coord; + +struct nk_rp_rect { + /* reserved for your use: */ + int id; + /* input: */ + nk_rp_coord w, h; + /* output: */ + nk_rp_coord x, y; + int was_packed; + /* non-zero if valid packing */ +}; /* 16 bytes, nominally */ + +struct nk_rp_node { + nk_rp_coord x,y; + struct nk_rp_node *next; +}; + +struct nk_rp_context { + int width; + int height; + int align; + int init_mode; + int heuristic; + int num_nodes; + struct nk_rp_node *active_head; + struct nk_rp_node *free_head; + struct nk_rp_node extra[2]; + /* we allocate two extra nodes so optimal user-node-count is 'width' not 'width+2' */ +}; + +struct nk_rp__findresult { + int x,y; + struct nk_rp_node **prev_link; +}; + +enum NK_RP_HEURISTIC { + NK_RP_HEURISTIC_Skyline_default=0, + NK_RP_HEURISTIC_Skyline_BL_sortHeight = NK_RP_HEURISTIC_Skyline_default, + NK_RP_HEURISTIC_Skyline_BF_sortHeight +}; +enum NK_RP_INIT_STATE{NK_RP__INIT_skyline = 1}; + +NK_INTERN void +nk_rp_setup_allow_out_of_mem(struct nk_rp_context *context, int allow_out_of_mem) +{ + if (allow_out_of_mem) + /* if it's ok to run out of memory, then don't bother aligning them; */ + /* this gives better packing, but may fail due to OOM (even though */ + /* the rectangles easily fit). @TODO a smarter approach would be to only */ + /* quantize once we've hit OOM, then we could get rid of this parameter. */ + context->align = 1; + else { + /* if it's not ok to run out of memory, then quantize the widths */ + /* so that num_nodes is always enough nodes. */ + /* */ + /* I.e. num_nodes * align >= width */ + /* align >= width / num_nodes */ + /* align = ceil(width/num_nodes) */ + context->align = (context->width + context->num_nodes-1) / context->num_nodes; + } +} + +NK_INTERN void +nk_rp_init_target(struct nk_rp_context *context, int width, int height, + struct nk_rp_node *nodes, int num_nodes) +{ + int i; +#ifndef STBRP_LARGE_RECTS + NK_ASSERT(width <= 0xffff && height <= 0xffff); +#endif + + for (i=0; i < num_nodes-1; ++i) + nodes[i].next = &nodes[i+1]; + nodes[i].next = 0; + context->init_mode = NK_RP__INIT_skyline; + context->heuristic = NK_RP_HEURISTIC_Skyline_default; + context->free_head = &nodes[0]; + context->active_head = &context->extra[0]; + context->width = width; + context->height = height; + context->num_nodes = num_nodes; + nk_rp_setup_allow_out_of_mem(context, 0); + + /* node 0 is the full width, node 1 is the sentinel (lets us not store width explicitly) */ + context->extra[0].x = 0; + context->extra[0].y = 0; + context->extra[0].next = &context->extra[1]; + context->extra[1].x = (nk_rp_coord) width; + context->extra[1].y = 65535; + context->extra[1].next = 0; +} + +/* find minimum y position if it starts at x1 */ +NK_INTERN int +nk_rp__skyline_find_min_y(struct nk_rp_context *c, struct nk_rp_node *first, + int x0, int width, int *pwaste) +{ + struct nk_rp_node *node = first; + int x1 = x0 + width; + int min_y, visited_width, waste_area; + NK_ASSERT(first->x <= x0); + NK_UNUSED(c); + + NK_ASSERT(node->next->x > x0); + /* we ended up handling this in the caller for efficiency */ + NK_ASSERT(node->x <= x0); + + min_y = 0; + waste_area = 0; + visited_width = 0; + while (node->x < x1) + { + if (node->y > min_y) { + /* raise min_y higher. */ + /* we've accounted for all waste up to min_y, */ + /* but we'll now add more waste for everything we've visited */ + waste_area += visited_width * (node->y - min_y); + min_y = node->y; + /* the first time through, visited_width might be reduced */ + if (node->x < x0) + visited_width += node->next->x - x0; + else + visited_width += node->next->x - node->x; + } else { + /* add waste area */ + int under_width = node->next->x - node->x; + if (under_width + visited_width > width) + under_width = width - visited_width; + waste_area += under_width * (min_y - node->y); + visited_width += under_width; + } + node = node->next; + } + *pwaste = waste_area; + return min_y; +} + +NK_INTERN struct nk_rp__findresult +nk_rp__skyline_find_best_pos(struct nk_rp_context *c, int width, int height) +{ + int best_waste = (1<<30), best_x, best_y = (1 << 30); + struct nk_rp__findresult fr; + struct nk_rp_node **prev, *node, *tail, **best = 0; + + /* align to multiple of c->align */ + width = (width + c->align - 1); + width -= width % c->align; + NK_ASSERT(width % c->align == 0); + + node = c->active_head; + prev = &c->active_head; + while (node->x + width <= c->width) { + int y,waste; + y = nk_rp__skyline_find_min_y(c, node, node->x, width, &waste); + /* actually just want to test BL */ + if (c->heuristic == NK_RP_HEURISTIC_Skyline_BL_sortHeight) { + /* bottom left */ + if (y < best_y) { + best_y = y; + best = prev; + } + } else { + /* best-fit */ + if (y + height <= c->height) { + /* can only use it if it first vertically */ + if (y < best_y || (y == best_y && waste < best_waste)) { + best_y = y; + best_waste = waste; + best = prev; + } + } + } + prev = &node->next; + node = node->next; + } + best_x = (best == 0) ? 0 : (*best)->x; + + /* if doing best-fit (BF), we also have to try aligning right edge to each node position */ + /* */ + /* e.g, if fitting */ + /* */ + /* ____________________ */ + /* |____________________| */ + /* */ + /* into */ + /* */ + /* | | */ + /* | ____________| */ + /* |____________| */ + /* */ + /* then right-aligned reduces waste, but bottom-left BL is always chooses left-aligned */ + /* */ + /* This makes BF take about 2x the time */ + if (c->heuristic == NK_RP_HEURISTIC_Skyline_BF_sortHeight) + { + tail = c->active_head; + node = c->active_head; + prev = &c->active_head; + /* find first node that's admissible */ + while (tail->x < width) + tail = tail->next; + while (tail) + { + int xpos = tail->x - width; + int y,waste; + NK_ASSERT(xpos >= 0); + /* find the left position that matches this */ + while (node->next->x <= xpos) { + prev = &node->next; + node = node->next; + } + NK_ASSERT(node->next->x > xpos && node->x <= xpos); + y = nk_rp__skyline_find_min_y(c, node, xpos, width, &waste); + if (y + height < c->height) { + if (y <= best_y) { + if (y < best_y || waste < best_waste || (waste==best_waste && xpos < best_x)) { + best_x = xpos; + NK_ASSERT(y <= best_y); + best_y = y; + best_waste = waste; + best = prev; + } + } + } + tail = tail->next; + } + } + fr.prev_link = best; + fr.x = best_x; + fr.y = best_y; + return fr; +} + +NK_INTERN struct nk_rp__findresult +nk_rp__skyline_pack_rectangle(struct nk_rp_context *context, int width, int height) +{ + /* find best position according to heuristic */ + struct nk_rp__findresult res = nk_rp__skyline_find_best_pos(context, width, height); + struct nk_rp_node *node, *cur; + + /* bail if: */ + /* 1. it failed */ + /* 2. the best node doesn't fit (we don't always check this) */ + /* 3. we're out of memory */ + if (res.prev_link == 0 || res.y + height > context->height || context->free_head == 0) { + res.prev_link = 0; + return res; + } + + /* on success, create new node */ + node = context->free_head; + node->x = (nk_rp_coord) res.x; + node->y = (nk_rp_coord) (res.y + height); + + context->free_head = node->next; + + /* insert the new node into the right starting point, and */ + /* let 'cur' point to the remaining nodes needing to be */ + /* stitched back in */ + cur = *res.prev_link; + if (cur->x < res.x) { + /* preserve the existing one, so start testing with the next one */ + struct nk_rp_node *next = cur->next; + cur->next = node; + cur = next; + } else { + *res.prev_link = node; + } + + /* from here, traverse cur and free the nodes, until we get to one */ + /* that shouldn't be freed */ + while (cur->next && cur->next->x <= res.x + width) { + struct nk_rp_node *next = cur->next; + /* move the current node to the free list */ + cur->next = context->free_head; + context->free_head = cur; + cur = next; + } + /* stitch the list back in */ + node->next = cur; + + if (cur->x < res.x + width) + cur->x = (nk_rp_coord) (res.x + width); + return res; +} + +NK_INTERN int +nk_rect_height_compare(const void *a, const void *b) +{ + const struct nk_rp_rect *p = (const struct nk_rp_rect *) a; + const struct nk_rp_rect *q = (const struct nk_rp_rect *) b; + if (p->h > q->h) + return -1; + if (p->h < q->h) + return 1; + return (p->w > q->w) ? -1 : (p->w < q->w); +} + +NK_INTERN int +nk_rect_original_order(const void *a, const void *b) +{ + const struct nk_rp_rect *p = (const struct nk_rp_rect *) a; + const struct nk_rp_rect *q = (const struct nk_rp_rect *) b; + return (p->was_packed < q->was_packed) ? -1 : (p->was_packed > q->was_packed); +} + +NK_INTERN void +nk_rp_qsort(struct nk_rp_rect *array, unsigned int len, int(*cmp)(const void*,const void*)) +{ + /* iterative quick sort */ + #define NK_MAX_SORT_STACK 64 + unsigned right, left = 0, stack[NK_MAX_SORT_STACK], pos = 0; + unsigned seed = len/2 * 69069+1; + for (;;) { + for (; left+1 < len; len++) { + struct nk_rp_rect pivot, tmp; + if (pos == NK_MAX_SORT_STACK) len = stack[pos = 0]; + pivot = array[left+seed%(len-left)]; + seed = seed * 69069 + 1; + stack[pos++] = len; + for (right = left-1;;) { + while (cmp(&array[++right], &pivot) < 0); + while (cmp(&pivot, &array[--len]) < 0); + if (right >= len) break; + tmp = array[right]; + array[right] = array[len]; + array[len] = tmp; + } + } + if (pos == 0) break; + left = len; + len = stack[--pos]; + } + #undef NK_MAX_SORT_STACK +} + +NK_INTERN void +nk_rp_pack_rects(struct nk_rp_context *context, struct nk_rp_rect *rects, int num_rects) +{ + int i; + /* we use the 'was_packed' field internally to allow sorting/unsorting */ + for (i=0; i < num_rects; ++i) { + rects[i].was_packed = i; + } + + /* sort according to heuristic */ + nk_rp_qsort(rects, (unsigned)num_rects, nk_rect_height_compare); + + for (i=0; i < num_rects; ++i) { + struct nk_rp__findresult fr = nk_rp__skyline_pack_rectangle(context, rects[i].w, rects[i].h); + if (fr.prev_link) { + rects[i].x = (nk_rp_coord) fr.x; + rects[i].y = (nk_rp_coord) fr.y; + } else { + rects[i].x = rects[i].y = NK_RP__MAXVAL; + } + } + + /* unsort */ + nk_rp_qsort(rects, (unsigned)num_rects, nk_rect_original_order); + + /* set was_packed flags */ + for (i=0; i < num_rects; ++i) + rects[i].was_packed = !(rects[i].x == NK_RP__MAXVAL && rects[i].y == NK_RP__MAXVAL); +} + +/* + * ============================================================== + * + * TRUETYPE + * + * =============================================================== + */ +/* stb_truetype.h - v1.07 - public domain */ +#define NK_TT_MAX_OVERSAMPLE 8 +#define NK_TT__OVER_MASK (NK_TT_MAX_OVERSAMPLE-1) + +struct nk_tt_bakedchar { + unsigned short x0,y0,x1,y1; + /* coordinates of bbox in bitmap */ + float xoff,yoff,xadvance; +}; + +struct nk_tt_aligned_quad{ + float x0,y0,s0,t0; /* top-left */ + float x1,y1,s1,t1; /* bottom-right */ +}; + +struct nk_tt_packedchar { + unsigned short x0,y0,x1,y1; + /* coordinates of bbox in bitmap */ + float xoff,yoff,xadvance; + float xoff2,yoff2; +}; + +struct nk_tt_pack_range { + float font_size; + int first_unicode_codepoint_in_range; + /* if non-zero, then the chars are continuous, and this is the first codepoint */ + int *array_of_unicode_codepoints; + /* if non-zero, then this is an array of unicode codepoints */ + int num_chars; + struct nk_tt_packedchar *chardata_for_range; /* output */ + unsigned char h_oversample, v_oversample; + /* don't set these, they're used internally */ +}; + +struct nk_tt_pack_context { + void *pack_info; + int width; + int height; + int stride_in_bytes; + int padding; + unsigned int h_oversample, v_oversample; + unsigned char *pixels; + void *nodes; +}; + +struct nk_tt_fontinfo { + const unsigned char* data; /* pointer to .ttf file */ + int fontstart;/* offset of start of font */ + int numGlyphs;/* number of glyphs, needed for range checking */ + int loca,head,glyf,hhea,hmtx,kern; /* table locations as offset from start of .ttf */ + int index_map; /* a cmap mapping for our chosen character encoding */ + int indexToLocFormat; /* format needed to map from glyph index to glyph */ +}; + +enum { + NK_TT_vmove=1, + NK_TT_vline, + NK_TT_vcurve +}; + +struct nk_tt_vertex { + short x,y,cx,cy; + unsigned char type,padding; +}; + +struct nk_tt__bitmap{ + int w,h,stride; + unsigned char *pixels; +}; + +struct nk_tt__hheap_chunk { + struct nk_tt__hheap_chunk *next; +}; +struct nk_tt__hheap { + struct nk_allocator alloc; + struct nk_tt__hheap_chunk *head; + void *first_free; + int num_remaining_in_head_chunk; +}; + +struct nk_tt__edge { + float x0,y0, x1,y1; + int invert; +}; + +struct nk_tt__active_edge { + struct nk_tt__active_edge *next; + float fx,fdx,fdy; + float direction; + float sy; + float ey; +}; +struct nk_tt__point {float x,y;}; + +#define NK_TT_MACSTYLE_DONTCARE 0 +#define NK_TT_MACSTYLE_BOLD 1 +#define NK_TT_MACSTYLE_ITALIC 2 +#define NK_TT_MACSTYLE_UNDERSCORE 4 +#define NK_TT_MACSTYLE_NONE 8 +/* <= not same as 0, this makes us check the bitfield is 0 */ + +enum { /* platformID */ + NK_TT_PLATFORM_ID_UNICODE =0, + NK_TT_PLATFORM_ID_MAC =1, + NK_TT_PLATFORM_ID_ISO =2, + NK_TT_PLATFORM_ID_MICROSOFT =3 +}; + +enum { /* encodingID for NK_TT_PLATFORM_ID_UNICODE */ + NK_TT_UNICODE_EID_UNICODE_1_0 =0, + NK_TT_UNICODE_EID_UNICODE_1_1 =1, + NK_TT_UNICODE_EID_ISO_10646 =2, + NK_TT_UNICODE_EID_UNICODE_2_0_BMP=3, + NK_TT_UNICODE_EID_UNICODE_2_0_FULL=4 +}; + +enum { /* encodingID for NK_TT_PLATFORM_ID_MICROSOFT */ + NK_TT_MS_EID_SYMBOL =0, + NK_TT_MS_EID_UNICODE_BMP =1, + NK_TT_MS_EID_SHIFTJIS =2, + NK_TT_MS_EID_UNICODE_FULL =10 +}; + +enum { /* encodingID for NK_TT_PLATFORM_ID_MAC; same as Script Manager codes */ + NK_TT_MAC_EID_ROMAN =0, NK_TT_MAC_EID_ARABIC =4, + NK_TT_MAC_EID_JAPANESE =1, NK_TT_MAC_EID_HEBREW =5, + NK_TT_MAC_EID_CHINESE_TRAD =2, NK_TT_MAC_EID_GREEK =6, + NK_TT_MAC_EID_KOREAN =3, NK_TT_MAC_EID_RUSSIAN =7 +}; + +enum { /* languageID for NK_TT_PLATFORM_ID_MICROSOFT; same as LCID... */ + /* problematic because there are e.g. 16 english LCIDs and 16 arabic LCIDs */ + NK_TT_MS_LANG_ENGLISH =0x0409, NK_TT_MS_LANG_ITALIAN =0x0410, + NK_TT_MS_LANG_CHINESE =0x0804, NK_TT_MS_LANG_JAPANESE =0x0411, + NK_TT_MS_LANG_DUTCH =0x0413, NK_TT_MS_LANG_KOREAN =0x0412, + NK_TT_MS_LANG_FRENCH =0x040c, NK_TT_MS_LANG_RUSSIAN =0x0419, + NK_TT_MS_LANG_GERMAN =0x0407, NK_TT_MS_LANG_SPANISH =0x0409, + NK_TT_MS_LANG_HEBREW =0x040d, NK_TT_MS_LANG_SWEDISH =0x041D +}; + +enum { /* languageID for NK_TT_PLATFORM_ID_MAC */ + NK_TT_MAC_LANG_ENGLISH =0 , NK_TT_MAC_LANG_JAPANESE =11, + NK_TT_MAC_LANG_ARABIC =12, NK_TT_MAC_LANG_KOREAN =23, + NK_TT_MAC_LANG_DUTCH =4 , NK_TT_MAC_LANG_RUSSIAN =32, + NK_TT_MAC_LANG_FRENCH =1 , NK_TT_MAC_LANG_SPANISH =6 , + NK_TT_MAC_LANG_GERMAN =2 , NK_TT_MAC_LANG_SWEDISH =5 , + NK_TT_MAC_LANG_HEBREW =10, NK_TT_MAC_LANG_CHINESE_SIMPLIFIED =33, + NK_TT_MAC_LANG_ITALIAN =3 , NK_TT_MAC_LANG_CHINESE_TRAD =19 +}; + +#define nk_ttBYTE(p) (* (const nk_byte *) (p)) +#define nk_ttCHAR(p) (* (const char *) (p)) + +#if defined(NK_BIGENDIAN) && !defined(NK_ALLOW_UNALIGNED_TRUETYPE) + #define nk_ttUSHORT(p) (* (nk_ushort *) (p)) + #define nk_ttSHORT(p) (* (nk_short *) (p)) + #define nk_ttULONG(p) (* (nk_uint *) (p)) + #define nk_ttLONG(p) (* (nk_int *) (p)) +#else + static nk_ushort nk_ttUSHORT(const nk_byte *p) { return (nk_ushort)(p[0]*256 + p[1]); } + static nk_short nk_ttSHORT(const nk_byte *p) { return (nk_short)(p[0]*256 + p[1]); } + static nk_uint nk_ttULONG(const nk_byte *p) { return (nk_uint)((p[0]<<24) + (p[1]<<16) + (p[2]<<8) + p[3]); } +#endif + +#define nk_tt_tag4(p,c0,c1,c2,c3)\ + ((p)[0] == (c0) && (p)[1] == (c1) && (p)[2] == (c2) && (p)[3] == (c3)) +#define nk_tt_tag(p,str) nk_tt_tag4(p,str[0],str[1],str[2],str[3]) + +NK_INTERN int nk_tt_GetGlyphShape(const struct nk_tt_fontinfo *info, struct nk_allocator *alloc, + int glyph_index, struct nk_tt_vertex **pvertices); + +NK_INTERN nk_uint +nk_tt__find_table(const nk_byte *data, nk_uint fontstart, const char *tag) +{ + /* @OPTIMIZE: binary search */ + nk_int num_tables = nk_ttUSHORT(data+fontstart+4); + nk_uint tabledir = fontstart + 12; + nk_int i; + for (i = 0; i < num_tables; ++i) { + nk_uint loc = tabledir + (nk_uint)(16*i); + if (nk_tt_tag(data+loc+0, tag)) + return nk_ttULONG(data+loc+8); + } + return 0; +} + +NK_INTERN int +nk_tt_InitFont(struct nk_tt_fontinfo *info, const unsigned char *data2, int fontstart) +{ + nk_uint cmap, t; + nk_int i,numTables; + const nk_byte *data = (const nk_byte *) data2; + + info->data = data; + info->fontstart = fontstart; + + cmap = nk_tt__find_table(data, (nk_uint)fontstart, "cmap"); /* required */ + info->loca = (int)nk_tt__find_table(data, (nk_uint)fontstart, "loca"); /* required */ + info->head = (int)nk_tt__find_table(data, (nk_uint)fontstart, "head"); /* required */ + info->glyf = (int)nk_tt__find_table(data, (nk_uint)fontstart, "glyf"); /* required */ + info->hhea = (int)nk_tt__find_table(data, (nk_uint)fontstart, "hhea"); /* required */ + info->hmtx = (int)nk_tt__find_table(data, (nk_uint)fontstart, "hmtx"); /* required */ + info->kern = (int)nk_tt__find_table(data, (nk_uint)fontstart, "kern"); /* not required */ + if (!cmap || !info->loca || !info->head || !info->glyf || !info->hhea || !info->hmtx) + return 0; + + t = nk_tt__find_table(data, (nk_uint)fontstart, "maxp"); + if (t) info->numGlyphs = nk_ttUSHORT(data+t+4); + else info->numGlyphs = 0xffff; + + /* find a cmap encoding table we understand *now* to avoid searching */ + /* later. (todo: could make this installable) */ + /* the same regardless of glyph. */ + numTables = nk_ttUSHORT(data + cmap + 2); + info->index_map = 0; + for (i=0; i < numTables; ++i) + { + nk_uint encoding_record = cmap + 4 + 8 * (nk_uint)i; + /* find an encoding we understand: */ + switch(nk_ttUSHORT(data+encoding_record)) { + case NK_TT_PLATFORM_ID_MICROSOFT: + switch (nk_ttUSHORT(data+encoding_record+2)) { + case NK_TT_MS_EID_UNICODE_BMP: + case NK_TT_MS_EID_UNICODE_FULL: + /* MS/Unicode */ + info->index_map = (int)(cmap + nk_ttULONG(data+encoding_record+4)); + break; + default: break; + } break; + case NK_TT_PLATFORM_ID_UNICODE: + /* Mac/iOS has these */ + /* all the encodingIDs are unicode, so we don't bother to check it */ + info->index_map = (int)(cmap + nk_ttULONG(data+encoding_record+4)); + break; + default: break; + } + } + if (info->index_map == 0) + return 0; + info->indexToLocFormat = nk_ttUSHORT(data+info->head + 50); + return 1; +} + +NK_INTERN int +nk_tt_FindGlyphIndex(const struct nk_tt_fontinfo *info, int unicode_codepoint) +{ + const nk_byte *data = info->data; + nk_uint index_map = (nk_uint)info->index_map; + + nk_ushort format = nk_ttUSHORT(data + index_map + 0); + if (format == 0) { /* apple byte encoding */ + nk_int bytes = nk_ttUSHORT(data + index_map + 2); + if (unicode_codepoint < bytes-6) + return nk_ttBYTE(data + index_map + 6 + unicode_codepoint); + return 0; + } else if (format == 6) { + nk_uint first = nk_ttUSHORT(data + index_map + 6); + nk_uint count = nk_ttUSHORT(data + index_map + 8); + if ((nk_uint) unicode_codepoint >= first && (nk_uint) unicode_codepoint < first+count) + return nk_ttUSHORT(data + index_map + 10 + (unicode_codepoint - (int)first)*2); + return 0; + } else if (format == 2) { + NK_ASSERT(0); /* @TODO: high-byte mapping for japanese/chinese/korean */ + return 0; + } else if (format == 4) { /* standard mapping for windows fonts: binary search collection of ranges */ + nk_ushort segcount = nk_ttUSHORT(data+index_map+6) >> 1; + nk_ushort searchRange = nk_ttUSHORT(data+index_map+8) >> 1; + nk_ushort entrySelector = nk_ttUSHORT(data+index_map+10); + nk_ushort rangeShift = nk_ttUSHORT(data+index_map+12) >> 1; + + /* do a binary search of the segments */ + nk_uint endCount = index_map + 14; + nk_uint search = endCount; + + if (unicode_codepoint > 0xffff) + return 0; + + /* they lie from endCount .. endCount + segCount */ + /* but searchRange is the nearest power of two, so... */ + if (unicode_codepoint >= nk_ttUSHORT(data + search + rangeShift*2)) + search += (nk_uint)(rangeShift*2); + + /* now decrement to bias correctly to find smallest */ + search -= 2; + while (entrySelector) { + nk_ushort end; + searchRange >>= 1; + end = nk_ttUSHORT(data + search + searchRange*2); + if (unicode_codepoint > end) + search += (nk_uint)(searchRange*2); + --entrySelector; + } + search += 2; + + { + nk_ushort offset, start; + nk_ushort item = (nk_ushort) ((search - endCount) >> 1); + + NK_ASSERT(unicode_codepoint <= nk_ttUSHORT(data + endCount + 2*item)); + start = nk_ttUSHORT(data + index_map + 14 + segcount*2 + 2 + 2*item); + if (unicode_codepoint < start) + return 0; + + offset = nk_ttUSHORT(data + index_map + 14 + segcount*6 + 2 + 2*item); + if (offset == 0) + return (nk_ushort) (unicode_codepoint + nk_ttSHORT(data + index_map + 14 + segcount*4 + 2 + 2*item)); + + return nk_ttUSHORT(data + offset + (unicode_codepoint-start)*2 + index_map + 14 + segcount*6 + 2 + 2*item); + } + } else if (format == 12 || format == 13) { + nk_uint ngroups = nk_ttULONG(data+index_map+12); + nk_int low,high; + low = 0; high = (nk_int)ngroups; + /* Binary search the right group. */ + while (low < high) { + nk_int mid = low + ((high-low) >> 1); /* rounds down, so low <= mid < high */ + nk_uint start_char = nk_ttULONG(data+index_map+16+mid*12); + nk_uint end_char = nk_ttULONG(data+index_map+16+mid*12+4); + if ((nk_uint) unicode_codepoint < start_char) + high = mid; + else if ((nk_uint) unicode_codepoint > end_char) + low = mid+1; + else { + nk_uint start_glyph = nk_ttULONG(data+index_map+16+mid*12+8); + if (format == 12) + return (int)start_glyph + (int)unicode_codepoint - (int)start_char; + else /* format == 13 */ + return (int)start_glyph; + } + } + return 0; /* not found */ + } + /* @TODO */ + NK_ASSERT(0); + return 0; +} + +NK_INTERN void +nk_tt_setvertex(struct nk_tt_vertex *v, nk_byte type, nk_int x, nk_int y, nk_int cx, nk_int cy) +{ + v->type = type; + v->x = (nk_short) x; + v->y = (nk_short) y; + v->cx = (nk_short) cx; + v->cy = (nk_short) cy; +} + +NK_INTERN int +nk_tt__GetGlyfOffset(const struct nk_tt_fontinfo *info, int glyph_index) +{ + int g1,g2; + if (glyph_index >= info->numGlyphs) return -1; /* glyph index out of range */ + if (info->indexToLocFormat >= 2) return -1; /* unknown index->glyph map format */ + + if (info->indexToLocFormat == 0) { + g1 = info->glyf + nk_ttUSHORT(info->data + info->loca + glyph_index * 2) * 2; + g2 = info->glyf + nk_ttUSHORT(info->data + info->loca + glyph_index * 2 + 2) * 2; + } else { + g1 = info->glyf + (int)nk_ttULONG (info->data + info->loca + glyph_index * 4); + g2 = info->glyf + (int)nk_ttULONG (info->data + info->loca + glyph_index * 4 + 4); + } + return g1==g2 ? -1 : g1; /* if length is 0, return -1 */ +} + +NK_INTERN int +nk_tt_GetGlyphBox(const struct nk_tt_fontinfo *info, int glyph_index, + int *x0, int *y0, int *x1, int *y1) +{ + int g = nk_tt__GetGlyfOffset(info, glyph_index); + if (g < 0) return 0; + + if (x0) *x0 = nk_ttSHORT(info->data + g + 2); + if (y0) *y0 = nk_ttSHORT(info->data + g + 4); + if (x1) *x1 = nk_ttSHORT(info->data + g + 6); + if (y1) *y1 = nk_ttSHORT(info->data + g + 8); + return 1; +} + +NK_INTERN int +stbtt__close_shape(struct nk_tt_vertex *vertices, int num_vertices, int was_off, + int start_off, nk_int sx, nk_int sy, nk_int scx, nk_int scy, nk_int cx, nk_int cy) +{ + if (start_off) { + if (was_off) + nk_tt_setvertex(&vertices[num_vertices++], NK_TT_vcurve, (cx+scx)>>1, (cy+scy)>>1, cx,cy); + nk_tt_setvertex(&vertices[num_vertices++], NK_TT_vcurve, sx,sy,scx,scy); + } else { + if (was_off) + nk_tt_setvertex(&vertices[num_vertices++], NK_TT_vcurve,sx,sy,cx,cy); + else + nk_tt_setvertex(&vertices[num_vertices++], NK_TT_vline,sx,sy,0,0); + } + return num_vertices; +} + +NK_INTERN int +nk_tt_GetGlyphShape(const struct nk_tt_fontinfo *info, struct nk_allocator *alloc, + int glyph_index, struct nk_tt_vertex **pvertices) +{ + nk_short numberOfContours; + const nk_byte *endPtsOfContours; + const nk_byte *data = info->data; + struct nk_tt_vertex *vertices=0; + int num_vertices=0; + int g = nk_tt__GetGlyfOffset(info, glyph_index); + *pvertices = 0; + + if (g < 0) return 0; + numberOfContours = nk_ttSHORT(data + g); + if (numberOfContours > 0) { + nk_byte flags=0,flagcount; + nk_int ins, i,j=0,m,n, next_move, was_off=0, off, start_off=0; + nk_int x,y,cx,cy,sx,sy, scx,scy; + const nk_byte *points; + endPtsOfContours = (data + g + 10); + ins = nk_ttUSHORT(data + g + 10 + numberOfContours * 2); + points = data + g + 10 + numberOfContours * 2 + 2 + ins; + + n = 1+nk_ttUSHORT(endPtsOfContours + numberOfContours*2-2); + m = n + 2*numberOfContours; /* a loose bound on how many vertices we might need */ + vertices = (struct nk_tt_vertex *)alloc->alloc(alloc->userdata, 0, (nk_size)m * sizeof(vertices[0])); + if (vertices == 0) + return 0; + + next_move = 0; + flagcount=0; + + /* in first pass, we load uninterpreted data into the allocated array */ + /* above, shifted to the end of the array so we won't overwrite it when */ + /* we create our final data starting from the front */ + off = m - n; /* starting offset for uninterpreted data, regardless of how m ends up being calculated */ + + /* first load flags */ + for (i=0; i < n; ++i) { + if (flagcount == 0) { + flags = *points++; + if (flags & 8) + flagcount = *points++; + } else --flagcount; + vertices[off+i].type = flags; + } + + /* now load x coordinates */ + x=0; + for (i=0; i < n; ++i) { + flags = vertices[off+i].type; + if (flags & 2) { + nk_short dx = *points++; + x += (flags & 16) ? dx : -dx; /* ??? */ + } else { + if (!(flags & 16)) { + x = x + (nk_short) (points[0]*256 + points[1]); + points += 2; + } + } + vertices[off+i].x = (nk_short) x; + } + + /* now load y coordinates */ + y=0; + for (i=0; i < n; ++i) { + flags = vertices[off+i].type; + if (flags & 4) { + nk_short dy = *points++; + y += (flags & 32) ? dy : -dy; /* ??? */ + } else { + if (!(flags & 32)) { + y = y + (nk_short) (points[0]*256 + points[1]); + points += 2; + } + } + vertices[off+i].y = (nk_short) y; + } + + /* now convert them to our format */ + num_vertices=0; + sx = sy = cx = cy = scx = scy = 0; + for (i=0; i < n; ++i) + { + flags = vertices[off+i].type; + x = (nk_short) vertices[off+i].x; + y = (nk_short) vertices[off+i].y; + + if (next_move == i) { + if (i != 0) + num_vertices = stbtt__close_shape(vertices, num_vertices, was_off, start_off, sx,sy,scx,scy,cx,cy); + + /* now start the new one */ + start_off = !(flags & 1); + if (start_off) { + /* if we start off with an off-curve point, then when we need to find a point on the curve */ + /* where we can start, and we need to save some state for when we wraparound. */ + scx = x; + scy = y; + if (!(vertices[off+i+1].type & 1)) { + /* next point is also a curve point, so interpolate an on-point curve */ + sx = (x + (nk_int) vertices[off+i+1].x) >> 1; + sy = (y + (nk_int) vertices[off+i+1].y) >> 1; + } else { + /* otherwise just use the next point as our start point */ + sx = (nk_int) vertices[off+i+1].x; + sy = (nk_int) vertices[off+i+1].y; + ++i; /* we're using point i+1 as the starting point, so skip it */ + } + } else { + sx = x; + sy = y; + } + nk_tt_setvertex(&vertices[num_vertices++], NK_TT_vmove,sx,sy,0,0); + was_off = 0; + next_move = 1 + nk_ttUSHORT(endPtsOfContours+j*2); + ++j; + } else { + if (!(flags & 1)) + { /* if it's a curve */ + if (was_off) /* two off-curve control points in a row means interpolate an on-curve midpoint */ + nk_tt_setvertex(&vertices[num_vertices++], NK_TT_vcurve, (cx+x)>>1, (cy+y)>>1, cx, cy); + cx = x; + cy = y; + was_off = 1; + } else { + if (was_off) + nk_tt_setvertex(&vertices[num_vertices++], NK_TT_vcurve, x,y, cx, cy); + else nk_tt_setvertex(&vertices[num_vertices++], NK_TT_vline, x,y,0,0); + was_off = 0; + } + } + } + num_vertices = stbtt__close_shape(vertices, num_vertices, was_off, start_off, sx,sy,scx,scy,cx,cy); + } else if (numberOfContours == -1) { + /* Compound shapes. */ + int more = 1; + const nk_byte *comp = data + g + 10; + num_vertices = 0; + vertices = 0; + + while (more) + { + nk_ushort flags, gidx; + int comp_num_verts = 0, i; + struct nk_tt_vertex *comp_verts = 0, *tmp = 0; + float mtx[6] = {1,0,0,1,0,0}, m, n; + + flags = (nk_ushort)nk_ttSHORT(comp); comp+=2; + gidx = (nk_ushort)nk_ttSHORT(comp); comp+=2; + + if (flags & 2) { /* XY values */ + if (flags & 1) { /* shorts */ + mtx[4] = nk_ttSHORT(comp); comp+=2; + mtx[5] = nk_ttSHORT(comp); comp+=2; + } else { + mtx[4] = nk_ttCHAR(comp); comp+=1; + mtx[5] = nk_ttCHAR(comp); comp+=1; + } + } else { + /* @TODO handle matching point */ + NK_ASSERT(0); + } + if (flags & (1<<3)) { /* WE_HAVE_A_SCALE */ + mtx[0] = mtx[3] = nk_ttSHORT(comp)/16384.0f; comp+=2; + mtx[1] = mtx[2] = 0; + } else if (flags & (1<<6)) { /* WE_HAVE_AN_X_AND_YSCALE */ + mtx[0] = nk_ttSHORT(comp)/16384.0f; comp+=2; + mtx[1] = mtx[2] = 0; + mtx[3] = nk_ttSHORT(comp)/16384.0f; comp+=2; + } else if (flags & (1<<7)) { /* WE_HAVE_A_TWO_BY_TWO */ + mtx[0] = nk_ttSHORT(comp)/16384.0f; comp+=2; + mtx[1] = nk_ttSHORT(comp)/16384.0f; comp+=2; + mtx[2] = nk_ttSHORT(comp)/16384.0f; comp+=2; + mtx[3] = nk_ttSHORT(comp)/16384.0f; comp+=2; + } + + /* Find transformation scales. */ + m = (float) NK_SQRT(mtx[0]*mtx[0] + mtx[1]*mtx[1]); + n = (float) NK_SQRT(mtx[2]*mtx[2] + mtx[3]*mtx[3]); + + /* Get indexed glyph. */ + comp_num_verts = nk_tt_GetGlyphShape(info, alloc, gidx, &comp_verts); + if (comp_num_verts > 0) + { + /* Transform vertices. */ + for (i = 0; i < comp_num_verts; ++i) { + struct nk_tt_vertex* v = &comp_verts[i]; + short x,y; + x=v->x; y=v->y; + v->x = (short)(m * (mtx[0]*x + mtx[2]*y + mtx[4])); + v->y = (short)(n * (mtx[1]*x + mtx[3]*y + mtx[5])); + x=v->cx; y=v->cy; + v->cx = (short)(m * (mtx[0]*x + mtx[2]*y + mtx[4])); + v->cy = (short)(n * (mtx[1]*x + mtx[3]*y + mtx[5])); + } + /* Append vertices. */ + tmp = (struct nk_tt_vertex*)alloc->alloc(alloc->userdata, 0, + (nk_size)(num_vertices+comp_num_verts)*sizeof(struct nk_tt_vertex)); + if (!tmp) { + if (vertices) alloc->free(alloc->userdata, vertices); + if (comp_verts) alloc->free(alloc->userdata, comp_verts); + return 0; + } + if (num_vertices > 0) NK_MEMCPY(tmp, vertices, (nk_size)num_vertices*sizeof(struct nk_tt_vertex)); + NK_MEMCPY(tmp+num_vertices, comp_verts, (nk_size)comp_num_verts*sizeof(struct nk_tt_vertex)); + if (vertices) alloc->free(alloc->userdata,vertices); + vertices = tmp; + alloc->free(alloc->userdata,comp_verts); + num_vertices += comp_num_verts; + } + /* More components ? */ + more = flags & (1<<5); + } + } else if (numberOfContours < 0) { + /* @TODO other compound variations? */ + NK_ASSERT(0); + } else { + /* numberOfCounters == 0, do nothing */ + } + *pvertices = vertices; + return num_vertices; +} + +NK_INTERN void +nk_tt_GetGlyphHMetrics(const struct nk_tt_fontinfo *info, int glyph_index, + int *advanceWidth, int *leftSideBearing) +{ + nk_ushort numOfLongHorMetrics = nk_ttUSHORT(info->data+info->hhea + 34); + if (glyph_index < numOfLongHorMetrics) { + if (advanceWidth) + *advanceWidth = nk_ttSHORT(info->data + info->hmtx + 4*glyph_index); + if (leftSideBearing) + *leftSideBearing = nk_ttSHORT(info->data + info->hmtx + 4*glyph_index + 2); + } else { + if (advanceWidth) + *advanceWidth = nk_ttSHORT(info->data + info->hmtx + 4*(numOfLongHorMetrics-1)); + if (leftSideBearing) + *leftSideBearing = nk_ttSHORT(info->data + info->hmtx + 4*numOfLongHorMetrics + 2*(glyph_index - numOfLongHorMetrics)); + } +} + +NK_INTERN void +nk_tt_GetFontVMetrics(const struct nk_tt_fontinfo *info, + int *ascent, int *descent, int *lineGap) +{ + if (ascent ) *ascent = nk_ttSHORT(info->data+info->hhea + 4); + if (descent) *descent = nk_ttSHORT(info->data+info->hhea + 6); + if (lineGap) *lineGap = nk_ttSHORT(info->data+info->hhea + 8); +} + +NK_INTERN float +nk_tt_ScaleForPixelHeight(const struct nk_tt_fontinfo *info, float height) +{ + int fheight = nk_ttSHORT(info->data + info->hhea + 4) - nk_ttSHORT(info->data + info->hhea + 6); + return (float) height / (float)fheight; +} + +NK_INTERN float +nk_tt_ScaleForMappingEmToPixels(const struct nk_tt_fontinfo *info, float pixels) +{ + int unitsPerEm = nk_ttUSHORT(info->data + info->head + 18); + return pixels / (float)unitsPerEm; +} + +/*------------------------------------------------------------- + * antialiasing software rasterizer + * --------------------------------------------------------------*/ +NK_INTERN void +nk_tt_GetGlyphBitmapBoxSubpixel(const struct nk_tt_fontinfo *font, + int glyph, float scale_x, float scale_y,float shift_x, float shift_y, + int *ix0, int *iy0, int *ix1, int *iy1) +{ + int x0,y0,x1,y1; + if (!nk_tt_GetGlyphBox(font, glyph, &x0,&y0,&x1,&y1)) { + /* e.g. space character */ + if (ix0) *ix0 = 0; + if (iy0) *iy0 = 0; + if (ix1) *ix1 = 0; + if (iy1) *iy1 = 0; + } else { + /* move to integral bboxes (treating pixels as little squares, what pixels get touched)? */ + if (ix0) *ix0 = nk_ifloorf((float)x0 * scale_x + shift_x); + if (iy0) *iy0 = nk_ifloorf((float)-y1 * scale_y + shift_y); + if (ix1) *ix1 = nk_iceilf ((float)x1 * scale_x + shift_x); + if (iy1) *iy1 = nk_iceilf ((float)-y0 * scale_y + shift_y); + } +} + +NK_INTERN void +nk_tt_GetGlyphBitmapBox(const struct nk_tt_fontinfo *font, int glyph, + float scale_x, float scale_y, int *ix0, int *iy0, int *ix1, int *iy1) +{ + nk_tt_GetGlyphBitmapBoxSubpixel(font, glyph, scale_x, scale_y,0.0f,0.0f, ix0, iy0, ix1, iy1); +} + +/*------------------------------------------------------------- + * Rasterizer + * --------------------------------------------------------------*/ +NK_INTERN void* +nk_tt__hheap_alloc(struct nk_tt__hheap *hh, nk_size size) +{ + if (hh->first_free) { + void *p = hh->first_free; + hh->first_free = * (void **) p; + return p; + } else { + if (hh->num_remaining_in_head_chunk == 0) { + int count = (size < 32 ? 2000 : size < 128 ? 800 : 100); + struct nk_tt__hheap_chunk *c = (struct nk_tt__hheap_chunk *) + hh->alloc.alloc(hh->alloc.userdata, 0, + sizeof(struct nk_tt__hheap_chunk) + size * (nk_size)count); + if (c == 0) return 0; + c->next = hh->head; + hh->head = c; + hh->num_remaining_in_head_chunk = count; + } + --hh->num_remaining_in_head_chunk; + return (char *) (hh->head) + size * (nk_size)hh->num_remaining_in_head_chunk; + } +} + +NK_INTERN void +nk_tt__hheap_free(struct nk_tt__hheap *hh, void *p) +{ + *(void **) p = hh->first_free; + hh->first_free = p; +} + +NK_INTERN void +nk_tt__hheap_cleanup(struct nk_tt__hheap *hh) +{ + struct nk_tt__hheap_chunk *c = hh->head; + while (c) { + struct nk_tt__hheap_chunk *n = c->next; + hh->alloc.free(hh->alloc.userdata, c); + c = n; + } +} + +NK_INTERN struct nk_tt__active_edge* +nk_tt__new_active(struct nk_tt__hheap *hh, struct nk_tt__edge *e, + int off_x, float start_point) +{ + struct nk_tt__active_edge *z = (struct nk_tt__active_edge *) + nk_tt__hheap_alloc(hh, sizeof(*z)); + float dxdy = (e->x1 - e->x0) / (e->y1 - e->y0); + /*STBTT_assert(e->y0 <= start_point); */ + if (!z) return z; + z->fdx = dxdy; + z->fdy = (dxdy != 0) ? (1/dxdy): 0; + z->fx = e->x0 + dxdy * (start_point - e->y0); + z->fx -= (float)off_x; + z->direction = e->invert ? 1.0f : -1.0f; + z->sy = e->y0; + z->ey = e->y1; + z->next = 0; + return z; +} + +NK_INTERN void +nk_tt__handle_clipped_edge(float *scanline, int x, struct nk_tt__active_edge *e, + float x0, float y0, float x1, float y1) +{ + if (y0 == y1) return; + NK_ASSERT(y0 < y1); + NK_ASSERT(e->sy <= e->ey); + if (y0 > e->ey) return; + if (y1 < e->sy) return; + if (y0 < e->sy) { + x0 += (x1-x0) * (e->sy - y0) / (y1-y0); + y0 = e->sy; + } + if (y1 > e->ey) { + x1 += (x1-x0) * (e->ey - y1) / (y1-y0); + y1 = e->ey; + } + + if (x0 == x) NK_ASSERT(x1 <= x+1); + else if (x0 == x+1) NK_ASSERT(x1 >= x); + else if (x0 <= x) NK_ASSERT(x1 <= x); + else if (x0 >= x+1) NK_ASSERT(x1 >= x+1); + else NK_ASSERT(x1 >= x && x1 <= x+1); + + if (x0 <= x && x1 <= x) + scanline[x] += e->direction * (y1-y0); + else if (x0 >= x+1 && x1 >= x+1); + else { + NK_ASSERT(x0 >= x && x0 <= x+1 && x1 >= x && x1 <= x+1); + /* coverage = 1 - average x position */ + scanline[x] += (float)e->direction * (float)(y1-y0) * (1.0f-((x0-(float)x)+(x1-(float)x))/2.0f); + } +} + +NK_INTERN void +nk_tt__fill_active_edges_new(float *scanline, float *scanline_fill, int len, + struct nk_tt__active_edge *e, float y_top) +{ + float y_bottom = y_top+1; + while (e) + { + /* brute force every pixel */ + /* compute intersection points with top & bottom */ + NK_ASSERT(e->ey >= y_top); + if (e->fdx == 0) { + float x0 = e->fx; + if (x0 < len) { + if (x0 >= 0) { + nk_tt__handle_clipped_edge(scanline,(int) x0,e, x0,y_top, x0,y_bottom); + nk_tt__handle_clipped_edge(scanline_fill-1,(int) x0+1,e, x0,y_top, x0,y_bottom); + } else { + nk_tt__handle_clipped_edge(scanline_fill-1,0,e, x0,y_top, x0,y_bottom); + } + } + } else { + float x0 = e->fx; + float dx = e->fdx; + float xb = x0 + dx; + float x_top, x_bottom; + float y0,y1; + float dy = e->fdy; + NK_ASSERT(e->sy <= y_bottom && e->ey >= y_top); + + /* compute endpoints of line segment clipped to this scanline (if the */ + /* line segment starts on this scanline. x0 is the intersection of the */ + /* line with y_top, but that may be off the line segment. */ + if (e->sy > y_top) { + x_top = x0 + dx * (e->sy - y_top); + y0 = e->sy; + } else { + x_top = x0; + y0 = y_top; + } + + if (e->ey < y_bottom) { + x_bottom = x0 + dx * (e->ey - y_top); + y1 = e->ey; + } else { + x_bottom = xb; + y1 = y_bottom; + } + + if (x_top >= 0 && x_bottom >= 0 && x_top < len && x_bottom < len) + { + /* from here on, we don't have to range check x values */ + if ((int) x_top == (int) x_bottom) { + float height; + /* simple case, only spans one pixel */ + int x = (int) x_top; + height = y1 - y0; + NK_ASSERT(x >= 0 && x < len); + scanline[x] += e->direction * (1.0f-(((float)x_top - (float)x) + ((float)x_bottom-(float)x))/2.0f) * (float)height; + scanline_fill[x] += e->direction * (float)height; /* everything right of this pixel is filled */ + } else { + int x,x1,x2; + float y_crossing, step, sign, area; + /* covers 2+ pixels */ + if (x_top > x_bottom) + { + /* flip scanline vertically; signed area is the same */ + float t; + y0 = y_bottom - (y0 - y_top); + y1 = y_bottom - (y1 - y_top); + t = y0; y0 = y1; y1 = t; + t = x_bottom; x_bottom = x_top; x_top = t; + dx = -dx; + dy = -dy; + t = x0; x0 = xb; xb = t; + } + + x1 = (int) x_top; + x2 = (int) x_bottom; + /* compute intersection with y axis at x1+1 */ + y_crossing = ((float)x1+1 - (float)x0) * (float)dy + (float)y_top; + + sign = e->direction; + /* area of the rectangle covered from y0..y_crossing */ + area = sign * (y_crossing-y0); + /* area of the triangle (x_top,y0), (x+1,y0), (x+1,y_crossing) */ + scanline[x1] += area * (1.0f-((float)((float)x_top - (float)x1)+(float)(x1+1-x1))/2.0f); + + step = sign * dy; + for (x = x1+1; x < x2; ++x) { + scanline[x] += area + step/2; + area += step; + } + y_crossing += (float)dy * (float)(x2 - (x1+1)); + + scanline[x2] += area + sign * (1.0f-((float)(x2-x2)+((float)x_bottom-(float)x2))/2.0f) * (y1-y_crossing); + scanline_fill[x2] += sign * (y1-y0); + } + } + else + { + /* if edge goes outside of box we're drawing, we require */ + /* clipping logic. since this does not match the intended use */ + /* of this library, we use a different, very slow brute */ + /* force implementation */ + int x; + for (x=0; x < len; ++x) + { + /* cases: */ + /* */ + /* there can be up to two intersections with the pixel. any intersection */ + /* with left or right edges can be handled by splitting into two (or three) */ + /* regions. intersections with top & bottom do not necessitate case-wise logic. */ + /* */ + /* the old way of doing this found the intersections with the left & right edges, */ + /* then used some simple logic to produce up to three segments in sorted order */ + /* from top-to-bottom. however, this had a problem: if an x edge was epsilon */ + /* across the x border, then the corresponding y position might not be distinct */ + /* from the other y segment, and it might ignored as an empty segment. to avoid */ + /* that, we need to explicitly produce segments based on x positions. */ + + /* rename variables to clear pairs */ + float ya = y_top; + float x1 = (float) (x); + float x2 = (float) (x+1); + float x3 = xb; + float y3 = y_bottom; + float yb,y2; + + yb = ((float)x - x0) / dx + y_top; + y2 = ((float)x+1 - x0) / dx + y_top; + + if (x0 < x1 && x3 > x2) { /* three segments descending down-right */ + nk_tt__handle_clipped_edge(scanline,x,e, x0,ya, x1,yb); + nk_tt__handle_clipped_edge(scanline,x,e, x1,yb, x2,y2); + nk_tt__handle_clipped_edge(scanline,x,e, x2,y2, x3,y3); + } else if (x3 < x1 && x0 > x2) { /* three segments descending down-left */ + nk_tt__handle_clipped_edge(scanline,x,e, x0,ya, x2,y2); + nk_tt__handle_clipped_edge(scanline,x,e, x2,y2, x1,yb); + nk_tt__handle_clipped_edge(scanline,x,e, x1,yb, x3,y3); + } else if (x0 < x1 && x3 > x1) { /* two segments across x, down-right */ + nk_tt__handle_clipped_edge(scanline,x,e, x0,ya, x1,yb); + nk_tt__handle_clipped_edge(scanline,x,e, x1,yb, x3,y3); + } else if (x3 < x1 && x0 > x1) { /* two segments across x, down-left */ + nk_tt__handle_clipped_edge(scanline,x,e, x0,ya, x1,yb); + nk_tt__handle_clipped_edge(scanline,x,e, x1,yb, x3,y3); + } else if (x0 < x2 && x3 > x2) { /* two segments across x+1, down-right */ + nk_tt__handle_clipped_edge(scanline,x,e, x0,ya, x2,y2); + nk_tt__handle_clipped_edge(scanline,x,e, x2,y2, x3,y3); + } else if (x3 < x2 && x0 > x2) { /* two segments across x+1, down-left */ + nk_tt__handle_clipped_edge(scanline,x,e, x0,ya, x2,y2); + nk_tt__handle_clipped_edge(scanline,x,e, x2,y2, x3,y3); + } else { /* one segment */ + nk_tt__handle_clipped_edge(scanline,x,e, x0,ya, x3,y3); + } + } + } + } + e = e->next; + } +} + +/* directly AA rasterize edges w/o supersampling */ +NK_INTERN void +nk_tt__rasterize_sorted_edges(struct nk_tt__bitmap *result, struct nk_tt__edge *e, + int n, int vsubsample, int off_x, int off_y, struct nk_allocator *alloc) +{ + struct nk_tt__hheap hh; + struct nk_tt__active_edge *active = 0; + int y,j=0, i; + float scanline_data[129], *scanline, *scanline2; + + NK_UNUSED(vsubsample); + nk_zero_struct(hh); + hh.alloc = *alloc; + + if (result->w > 64) + scanline = (float *) alloc->alloc(alloc->userdata,0, (nk_size)(result->w*2+1) * sizeof(float)); + else scanline = scanline_data; + + scanline2 = scanline + result->w; + y = off_y; + e[n].y0 = (float) (off_y + result->h) + 1; + + while (j < result->h) + { + /* find center of pixel for this scanline */ + float scan_y_top = (float)y + 0.0f; + float scan_y_bottom = (float)y + 1.0f; + struct nk_tt__active_edge **step = &active; + + NK_MEMSET(scanline , 0, (nk_size)result->w*sizeof(scanline[0])); + NK_MEMSET(scanline2, 0, (nk_size)(result->w+1)*sizeof(scanline[0])); + + /* update all active edges; */ + /* remove all active edges that terminate before the top of this scanline */ + while (*step) { + struct nk_tt__active_edge * z = *step; + if (z->ey <= scan_y_top) { + *step = z->next; /* delete from list */ + NK_ASSERT(z->direction); + z->direction = 0; + nk_tt__hheap_free(&hh, z); + } else { + step = &((*step)->next); /* advance through list */ + } + } + + /* insert all edges that start before the bottom of this scanline */ + while (e->y0 <= scan_y_bottom) { + if (e->y0 != e->y1) { + struct nk_tt__active_edge *z = nk_tt__new_active(&hh, e, off_x, scan_y_top); + if (z != 0) { + NK_ASSERT(z->ey >= scan_y_top); + /* insert at front */ + z->next = active; + active = z; + } + } + ++e; + } + + /* now process all active edges */ + if (active) + nk_tt__fill_active_edges_new(scanline, scanline2+1, result->w, active, scan_y_top); + + { + float sum = 0; + for (i=0; i < result->w; ++i) { + float k; + int m; + sum += scanline2[i]; + k = scanline[i] + sum; + k = (float) NK_ABS(k) * 255.0f + 0.5f; + m = (int) k; + if (m > 255) m = 255; + result->pixels[j*result->stride + i] = (unsigned char) m; + } + } + /* advance all the edges */ + step = &active; + while (*step) { + struct nk_tt__active_edge *z = *step; + z->fx += z->fdx; /* advance to position for current scanline */ + step = &((*step)->next); /* advance through list */ + } + ++y; + ++j; + } + nk_tt__hheap_cleanup(&hh); + if (scanline != scanline_data) + alloc->free(alloc->userdata, scanline); +} + +#define NK_TT__COMPARE(a,b) ((a)->y0 < (b)->y0) +NK_INTERN void +nk_tt__sort_edges_ins_sort(struct nk_tt__edge *p, int n) +{ + int i,j; + for (i=1; i < n; ++i) { + struct nk_tt__edge t = p[i], *a = &t; + j = i; + while (j > 0) { + struct nk_tt__edge *b = &p[j-1]; + int c = NK_TT__COMPARE(a,b); + if (!c) break; + p[j] = p[j-1]; + --j; + } + if (i != j) + p[j] = t; + } +} + +NK_INTERN void +nk_tt__sort_edges_quicksort(struct nk_tt__edge *p, int n) +{ + /* threshold for transitioning to insertion sort */ + while (n > 12) { + struct nk_tt__edge t; + int c01,c12,c,m,i,j; + + /* compute median of three */ + m = n >> 1; + c01 = NK_TT__COMPARE(&p[0],&p[m]); + c12 = NK_TT__COMPARE(&p[m],&p[n-1]); + + /* if 0 >= mid >= end, or 0 < mid < end, then use mid */ + if (c01 != c12) { + /* otherwise, we'll need to swap something else to middle */ + int z; + c = NK_TT__COMPARE(&p[0],&p[n-1]); + /* 0>mid && midn => n; 0 0 */ + /* 0n: 0>n => 0; 0 n */ + z = (c == c12) ? 0 : n-1; + t = p[z]; + p[z] = p[m]; + p[m] = t; + } + + /* now p[m] is the median-of-three */ + /* swap it to the beginning so it won't move around */ + t = p[0]; + p[0] = p[m]; + p[m] = t; + + /* partition loop */ + i=1; + j=n-1; + for(;;) { + /* handling of equality is crucial here */ + /* for sentinels & efficiency with duplicates */ + for (;;++i) { + if (!NK_TT__COMPARE(&p[i], &p[0])) break; + } + for (;;--j) { + if (!NK_TT__COMPARE(&p[0], &p[j])) break; + } + + /* make sure we haven't crossed */ + if (i >= j) break; + t = p[i]; + p[i] = p[j]; + p[j] = t; + + ++i; + --j; + + } + + /* recurse on smaller side, iterate on larger */ + if (j < (n-i)) { + nk_tt__sort_edges_quicksort(p,j); + p = p+i; + n = n-i; + } else { + nk_tt__sort_edges_quicksort(p+i, n-i); + n = j; + } + } +} + +NK_INTERN void +nk_tt__sort_edges(struct nk_tt__edge *p, int n) +{ + nk_tt__sort_edges_quicksort(p, n); + nk_tt__sort_edges_ins_sort(p, n); +} + +NK_INTERN void +nk_tt__rasterize(struct nk_tt__bitmap *result, struct nk_tt__point *pts, + int *wcount, int windings, float scale_x, float scale_y, + float shift_x, float shift_y, int off_x, int off_y, int invert, + struct nk_allocator *alloc) +{ + float y_scale_inv = invert ? -scale_y : scale_y; + struct nk_tt__edge *e; + int n,i,j,k,m; + int vsubsample = 1; + /* vsubsample should divide 255 evenly; otherwise we won't reach full opacity */ + + /* now we have to blow out the windings into explicit edge lists */ + n = 0; + for (i=0; i < windings; ++i) + n += wcount[i]; + + e = (struct nk_tt__edge*) + alloc->alloc(alloc->userdata, 0,(sizeof(*e) * (nk_size)(n+1))); + if (e == 0) return; + n = 0; + + m=0; + for (i=0; i < windings; ++i) + { + struct nk_tt__point *p = pts + m; + m += wcount[i]; + j = wcount[i]-1; + for (k=0; k < wcount[i]; j=k++) { + int a=k,b=j; + /* skip the edge if horizontal */ + if (p[j].y == p[k].y) + continue; + + /* add edge from j to k to the list */ + e[n].invert = 0; + if (invert ? p[j].y > p[k].y : p[j].y < p[k].y) { + e[n].invert = 1; + a=j,b=k; + } + e[n].x0 = p[a].x * scale_x + shift_x; + e[n].y0 = (p[a].y * y_scale_inv + shift_y) * (float)vsubsample; + e[n].x1 = p[b].x * scale_x + shift_x; + e[n].y1 = (p[b].y * y_scale_inv + shift_y) * (float)vsubsample; + ++n; + } + } + + /* now sort the edges by their highest point (should snap to integer, and then by x) */ + /*STBTT_sort(e, n, sizeof(e[0]), stbtt__edge_compare); */ + nk_tt__sort_edges(e, n); + /* now, traverse the scanlines and find the intersections on each scanline, use xor winding rule */ + nk_tt__rasterize_sorted_edges(result, e, n, vsubsample, off_x, off_y, alloc); + alloc->free(alloc->userdata, e); +} + +NK_INTERN void +nk_tt__add_point(struct nk_tt__point *points, int n, float x, float y) +{ + if (!points) return; /* during first pass, it's unallocated */ + points[n].x = x; + points[n].y = y; +} + +NK_INTERN int +nk_tt__tesselate_curve(struct nk_tt__point *points, int *num_points, + float x0, float y0, float x1, float y1, float x2, float y2, + float objspace_flatness_squared, int n) +{ + /* tesselate until threshold p is happy... + * @TODO warped to compensate for non-linear stretching */ + /* midpoint */ + float mx = (x0 + 2*x1 + x2)/4; + float my = (y0 + 2*y1 + y2)/4; + /* versus directly drawn line */ + float dx = (x0+x2)/2 - mx; + float dy = (y0+y2)/2 - my; + if (n > 16) /* 65536 segments on one curve better be enough! */ + return 1; + + /* half-pixel error allowed... need to be smaller if AA */ + if (dx*dx+dy*dy > objspace_flatness_squared) { + nk_tt__tesselate_curve(points, num_points, x0,y0, + (x0+x1)/2.0f,(y0+y1)/2.0f, mx,my, objspace_flatness_squared,n+1); + nk_tt__tesselate_curve(points, num_points, mx,my, + (x1+x2)/2.0f,(y1+y2)/2.0f, x2,y2, objspace_flatness_squared,n+1); + } else { + nk_tt__add_point(points, *num_points,x2,y2); + *num_points = *num_points+1; + } + return 1; +} + +/* returns number of contours */ +NK_INTERN struct nk_tt__point* +nk_tt_FlattenCurves(struct nk_tt_vertex *vertices, int num_verts, + float objspace_flatness, int **contour_lengths, int *num_contours, + struct nk_allocator *alloc) +{ + struct nk_tt__point *points=0; + int num_points=0; + float objspace_flatness_squared = objspace_flatness * objspace_flatness; + int i; + int n=0; + int start=0; + int pass; + + /* count how many "moves" there are to get the contour count */ + for (i=0; i < num_verts; ++i) + if (vertices[i].type == NK_TT_vmove) ++n; + + *num_contours = n; + if (n == 0) return 0; + + *contour_lengths = (int *) + alloc->alloc(alloc->userdata,0, (sizeof(**contour_lengths) * (nk_size)n)); + if (*contour_lengths == 0) { + *num_contours = 0; + return 0; + } + + /* make two passes through the points so we don't need to realloc */ + for (pass=0; pass < 2; ++pass) + { + float x=0,y=0; + if (pass == 1) { + points = (struct nk_tt__point *) + alloc->alloc(alloc->userdata,0, (nk_size)num_points * sizeof(points[0])); + if (points == 0) goto error; + } + num_points = 0; + n= -1; + + for (i=0; i < num_verts; ++i) + { + switch (vertices[i].type) { + case NK_TT_vmove: + /* start the next contour */ + if (n >= 0) + (*contour_lengths)[n] = num_points - start; + ++n; + start = num_points; + + x = vertices[i].x, y = vertices[i].y; + nk_tt__add_point(points, num_points++, x,y); + break; + case NK_TT_vline: + x = vertices[i].x, y = vertices[i].y; + nk_tt__add_point(points, num_points++, x, y); + break; + case NK_TT_vcurve: + nk_tt__tesselate_curve(points, &num_points, x,y, + vertices[i].cx, vertices[i].cy, + vertices[i].x, vertices[i].y, + objspace_flatness_squared, 0); + x = vertices[i].x, y = vertices[i].y; + break; + default: break; + } + } + (*contour_lengths)[n] = num_points - start; + } + return points; + +error: + alloc->free(alloc->userdata, points); + alloc->free(alloc->userdata, *contour_lengths); + *contour_lengths = 0; + *num_contours = 0; + return 0; +} + +NK_INTERN void +nk_tt_Rasterize(struct nk_tt__bitmap *result, float flatness_in_pixels, + struct nk_tt_vertex *vertices, int num_verts, + float scale_x, float scale_y, float shift_x, float shift_y, + int x_off, int y_off, int invert, struct nk_allocator *alloc) +{ + float scale = scale_x > scale_y ? scale_y : scale_x; + int winding_count, *winding_lengths; + struct nk_tt__point *windings = nk_tt_FlattenCurves(vertices, num_verts, + flatness_in_pixels / scale, &winding_lengths, &winding_count, alloc); + + NK_ASSERT(alloc); + if (windings) { + nk_tt__rasterize(result, windings, winding_lengths, winding_count, + scale_x, scale_y, shift_x, shift_y, x_off, y_off, invert, alloc); + alloc->free(alloc->userdata, winding_lengths); + alloc->free(alloc->userdata, windings); + } +} + +NK_INTERN void +nk_tt_MakeGlyphBitmapSubpixel(const struct nk_tt_fontinfo *info, unsigned char *output, + int out_w, int out_h, int out_stride, float scale_x, float scale_y, + float shift_x, float shift_y, int glyph, struct nk_allocator *alloc) +{ + int ix0,iy0; + struct nk_tt_vertex *vertices; + int num_verts = nk_tt_GetGlyphShape(info, alloc, glyph, &vertices); + struct nk_tt__bitmap gbm; + + nk_tt_GetGlyphBitmapBoxSubpixel(info, glyph, scale_x, scale_y, shift_x, + shift_y, &ix0,&iy0,0,0); + gbm.pixels = output; + gbm.w = out_w; + gbm.h = out_h; + gbm.stride = out_stride; + + if (gbm.w && gbm.h) + nk_tt_Rasterize(&gbm, 0.35f, vertices, num_verts, scale_x, scale_y, + shift_x, shift_y, ix0,iy0, 1, alloc); + alloc->free(alloc->userdata, vertices); +} + +/*------------------------------------------------------------- + * Bitmap baking + * --------------------------------------------------------------*/ +NK_INTERN int +nk_tt_PackBegin(struct nk_tt_pack_context *spc, unsigned char *pixels, + int pw, int ph, int stride_in_bytes, int padding, struct nk_allocator *alloc) +{ + int num_nodes = pw - padding; + struct nk_rp_context *context = (struct nk_rp_context *) + alloc->alloc(alloc->userdata,0, sizeof(*context)); + struct nk_rp_node *nodes = (struct nk_rp_node*) + alloc->alloc(alloc->userdata,0, (sizeof(*nodes ) * (nk_size)num_nodes)); + + if (context == 0 || nodes == 0) { + if (context != 0) alloc->free(alloc->userdata, context); + if (nodes != 0) alloc->free(alloc->userdata, nodes); + return 0; + } + + spc->width = pw; + spc->height = ph; + spc->pixels = pixels; + spc->pack_info = context; + spc->nodes = nodes; + spc->padding = padding; + spc->stride_in_bytes = (stride_in_bytes != 0) ? stride_in_bytes : pw; + spc->h_oversample = 1; + spc->v_oversample = 1; + + nk_rp_init_target(context, pw-padding, ph-padding, nodes, num_nodes); + if (pixels) + NK_MEMSET(pixels, 0, (nk_size)(pw*ph)); /* background of 0 around pixels */ + return 1; +} + +NK_INTERN void +nk_tt_PackEnd(struct nk_tt_pack_context *spc, struct nk_allocator *alloc) +{ + alloc->free(alloc->userdata, spc->nodes); + alloc->free(alloc->userdata, spc->pack_info); +} + +NK_INTERN void +nk_tt_PackSetOversampling(struct nk_tt_pack_context *spc, + unsigned int h_oversample, unsigned int v_oversample) +{ + NK_ASSERT(h_oversample <= NK_TT_MAX_OVERSAMPLE); + NK_ASSERT(v_oversample <= NK_TT_MAX_OVERSAMPLE); + if (h_oversample <= NK_TT_MAX_OVERSAMPLE) + spc->h_oversample = h_oversample; + if (v_oversample <= NK_TT_MAX_OVERSAMPLE) + spc->v_oversample = v_oversample; +} + +NK_INTERN void +nk_tt__h_prefilter(unsigned char *pixels, int w, int h, int stride_in_bytes, + int kernel_width) +{ + unsigned char buffer[NK_TT_MAX_OVERSAMPLE]; + int safe_w = w - kernel_width; + int j; + + for (j=0; j < h; ++j) + { + int i; + unsigned int total; + NK_MEMSET(buffer, 0, (nk_size)kernel_width); + + total = 0; + + /* make kernel_width a constant in common cases so compiler can optimize out the divide */ + switch (kernel_width) { + case 2: + for (i=0; i <= safe_w; ++i) { + total += (unsigned int)(pixels[i] - buffer[i & NK_TT__OVER_MASK]); + buffer[(i+kernel_width) & NK_TT__OVER_MASK] = pixels[i]; + pixels[i] = (unsigned char) (total / 2); + } + break; + case 3: + for (i=0; i <= safe_w; ++i) { + total += (unsigned int)(pixels[i] - buffer[i & NK_TT__OVER_MASK]); + buffer[(i+kernel_width) & NK_TT__OVER_MASK] = pixels[i]; + pixels[i] = (unsigned char) (total / 3); + } + break; + case 4: + for (i=0; i <= safe_w; ++i) { + total += (unsigned int)pixels[i] - buffer[i & NK_TT__OVER_MASK]; + buffer[(i+kernel_width) & NK_TT__OVER_MASK] = pixels[i]; + pixels[i] = (unsigned char) (total / 4); + } + break; + case 5: + for (i=0; i <= safe_w; ++i) { + total += (unsigned int)(pixels[i] - buffer[i & NK_TT__OVER_MASK]); + buffer[(i+kernel_width) & NK_TT__OVER_MASK] = pixels[i]; + pixels[i] = (unsigned char) (total / 5); + } + break; + default: + for (i=0; i <= safe_w; ++i) { + total += (unsigned int)(pixels[i] - buffer[i & NK_TT__OVER_MASK]); + buffer[(i+kernel_width) & NK_TT__OVER_MASK] = pixels[i]; + pixels[i] = (unsigned char) (total / (unsigned int)kernel_width); + } + break; + } + + for (; i < w; ++i) { + NK_ASSERT(pixels[i] == 0); + total -= (unsigned int)(buffer[i & NK_TT__OVER_MASK]); + pixels[i] = (unsigned char) (total / (unsigned int)kernel_width); + } + pixels += stride_in_bytes; + } +} + +NK_INTERN void +nk_tt__v_prefilter(unsigned char *pixels, int w, int h, int stride_in_bytes, + int kernel_width) +{ + unsigned char buffer[NK_TT_MAX_OVERSAMPLE]; + int safe_h = h - kernel_width; + int j; + + for (j=0; j < w; ++j) + { + int i; + unsigned int total; + NK_MEMSET(buffer, 0, (nk_size)kernel_width); + + total = 0; + + /* make kernel_width a constant in common cases so compiler can optimize out the divide */ + switch (kernel_width) { + case 2: + for (i=0; i <= safe_h; ++i) { + total += (unsigned int)(pixels[i*stride_in_bytes] - buffer[i & NK_TT__OVER_MASK]); + buffer[(i+kernel_width) & NK_TT__OVER_MASK] = pixels[i*stride_in_bytes]; + pixels[i*stride_in_bytes] = (unsigned char) (total / 2); + } + break; + case 3: + for (i=0; i <= safe_h; ++i) { + total += (unsigned int)(pixels[i*stride_in_bytes] - buffer[i & NK_TT__OVER_MASK]); + buffer[(i+kernel_width) & NK_TT__OVER_MASK] = pixels[i*stride_in_bytes]; + pixels[i*stride_in_bytes] = (unsigned char) (total / 3); + } + break; + case 4: + for (i=0; i <= safe_h; ++i) { + total += (unsigned int)(pixels[i*stride_in_bytes] - buffer[i & NK_TT__OVER_MASK]); + buffer[(i+kernel_width) & NK_TT__OVER_MASK] = pixels[i*stride_in_bytes]; + pixels[i*stride_in_bytes] = (unsigned char) (total / 4); + } + break; + case 5: + for (i=0; i <= safe_h; ++i) { + total += (unsigned int)(pixels[i*stride_in_bytes] - buffer[i & NK_TT__OVER_MASK]); + buffer[(i+kernel_width) & NK_TT__OVER_MASK] = pixels[i*stride_in_bytes]; + pixels[i*stride_in_bytes] = (unsigned char) (total / 5); + } + break; + default: + for (i=0; i <= safe_h; ++i) { + total += (unsigned int)(pixels[i*stride_in_bytes] - buffer[i & NK_TT__OVER_MASK]); + buffer[(i+kernel_width) & NK_TT__OVER_MASK] = pixels[i*stride_in_bytes]; + pixels[i*stride_in_bytes] = (unsigned char) (total / (unsigned int)kernel_width); + } + break; + } + + for (; i < h; ++i) { + NK_ASSERT(pixels[i*stride_in_bytes] == 0); + total -= (unsigned int)(buffer[i & NK_TT__OVER_MASK]); + pixels[i*stride_in_bytes] = (unsigned char) (total / (unsigned int)kernel_width); + } + pixels += 1; + } +} + +NK_INTERN float +nk_tt__oversample_shift(int oversample) +{ + if (!oversample) + return 0.0f; + + /* The prefilter is a box filter of width "oversample", */ + /* which shifts phase by (oversample - 1)/2 pixels in */ + /* oversampled space. We want to shift in the opposite */ + /* direction to counter this. */ + return (float)-(oversample - 1) / (2.0f * (float)oversample); +} + +/* rects array must be big enough to accommodate all characters in the given ranges */ +NK_INTERN int +nk_tt_PackFontRangesGatherRects(struct nk_tt_pack_context *spc, + struct nk_tt_fontinfo *info, struct nk_tt_pack_range *ranges, + int num_ranges, struct nk_rp_rect *rects) +{ + int i,j,k; + k = 0; + + for (i=0; i < num_ranges; ++i) { + float fh = ranges[i].font_size; + float scale = (fh > 0) ? nk_tt_ScaleForPixelHeight(info, fh): + nk_tt_ScaleForMappingEmToPixels(info, -fh); + ranges[i].h_oversample = (unsigned char) spc->h_oversample; + ranges[i].v_oversample = (unsigned char) spc->v_oversample; + for (j=0; j < ranges[i].num_chars; ++j) { + int x0,y0,x1,y1; + int codepoint = ranges[i].first_unicode_codepoint_in_range ? + ranges[i].first_unicode_codepoint_in_range + j : + ranges[i].array_of_unicode_codepoints[j]; + + int glyph = nk_tt_FindGlyphIndex(info, codepoint); + nk_tt_GetGlyphBitmapBoxSubpixel(info,glyph, scale * (float)spc->h_oversample, + scale * (float)spc->v_oversample, 0,0, &x0,&y0,&x1,&y1); + rects[k].w = (nk_rp_coord) (x1-x0 + spc->padding + (int)spc->h_oversample-1); + rects[k].h = (nk_rp_coord) (y1-y0 + spc->padding + (int)spc->v_oversample-1); + ++k; + } + } + return k; +} + +NK_INTERN int +nk_tt_PackFontRangesRenderIntoRects(struct nk_tt_pack_context *spc, + struct nk_tt_fontinfo *info, struct nk_tt_pack_range *ranges, + int num_ranges, struct nk_rp_rect *rects, struct nk_allocator *alloc) +{ + int i,j,k, return_value = 1; + /* save current values */ + int old_h_over = (int)spc->h_oversample; + int old_v_over = (int)spc->v_oversample; + /* rects array must be big enough to accommodate all characters in the given ranges */ + + k = 0; + for (i=0; i < num_ranges; ++i) + { + float fh = ranges[i].font_size; + float recip_h,recip_v,sub_x,sub_y; + float scale = fh > 0 ? nk_tt_ScaleForPixelHeight(info, fh): + nk_tt_ScaleForMappingEmToPixels(info, -fh); + + spc->h_oversample = ranges[i].h_oversample; + spc->v_oversample = ranges[i].v_oversample; + + recip_h = 1.0f / (float)spc->h_oversample; + recip_v = 1.0f / (float)spc->v_oversample; + + sub_x = nk_tt__oversample_shift((int)spc->h_oversample); + sub_y = nk_tt__oversample_shift((int)spc->v_oversample); + + for (j=0; j < ranges[i].num_chars; ++j) + { + struct nk_rp_rect *r = &rects[k]; + if (r->was_packed) + { + struct nk_tt_packedchar *bc = &ranges[i].chardata_for_range[j]; + int advance, lsb, x0,y0,x1,y1; + int codepoint = ranges[i].first_unicode_codepoint_in_range ? + ranges[i].first_unicode_codepoint_in_range + j : + ranges[i].array_of_unicode_codepoints[j]; + int glyph = nk_tt_FindGlyphIndex(info, codepoint); + nk_rp_coord pad = (nk_rp_coord) spc->padding; + + /* pad on left and top */ + r->x = (nk_rp_coord)((int)r->x + (int)pad); + r->y = (nk_rp_coord)((int)r->y + (int)pad); + r->w = (nk_rp_coord)((int)r->w - (int)pad); + r->h = (nk_rp_coord)((int)r->h - (int)pad); + + nk_tt_GetGlyphHMetrics(info, glyph, &advance, &lsb); + nk_tt_GetGlyphBitmapBox(info, glyph, scale * (float)spc->h_oversample, + (scale * (float)spc->v_oversample), &x0,&y0,&x1,&y1); + nk_tt_MakeGlyphBitmapSubpixel(info, spc->pixels + r->x + r->y*spc->stride_in_bytes, + (int)(r->w - spc->h_oversample+1), (int)(r->h - spc->v_oversample+1), + spc->stride_in_bytes, scale * (float)spc->h_oversample, + scale * (float)spc->v_oversample, 0,0, glyph, alloc); + + if (spc->h_oversample > 1) + nk_tt__h_prefilter(spc->pixels + r->x + r->y*spc->stride_in_bytes, + r->w, r->h, spc->stride_in_bytes, (int)spc->h_oversample); + + if (spc->v_oversample > 1) + nk_tt__v_prefilter(spc->pixels + r->x + r->y*spc->stride_in_bytes, + r->w, r->h, spc->stride_in_bytes, (int)spc->v_oversample); + + bc->x0 = (nk_ushort) r->x; + bc->y0 = (nk_ushort) r->y; + bc->x1 = (nk_ushort) (r->x + r->w); + bc->y1 = (nk_ushort) (r->y + r->h); + bc->xadvance = scale * (float)advance; + bc->xoff = (float) x0 * recip_h + sub_x; + bc->yoff = (float) y0 * recip_v + sub_y; + bc->xoff2 = ((float)x0 + r->w) * recip_h + sub_x; + bc->yoff2 = ((float)y0 + r->h) * recip_v + sub_y; + } else { + return_value = 0; /* if any fail, report failure */ + } + ++k; + } + } + /* restore original values */ + spc->h_oversample = (unsigned int)old_h_over; + spc->v_oversample = (unsigned int)old_v_over; + return return_value; +} + +NK_INTERN void +nk_tt_GetPackedQuad(struct nk_tt_packedchar *chardata, int pw, int ph, + int char_index, float *xpos, float *ypos, struct nk_tt_aligned_quad *q, + int align_to_integer) +{ + float ipw = 1.0f / (float)pw, iph = 1.0f / (float)ph; + struct nk_tt_packedchar *b = (struct nk_tt_packedchar*)(chardata + char_index); + if (align_to_integer) { + int tx = nk_ifloorf((*xpos + b->xoff) + 0.5f); + int ty = nk_ifloorf((*ypos + b->yoff) + 0.5f); + + float x = (float)tx; + float y = (float)ty; + + q->x0 = x; + q->y0 = y; + q->x1 = x + b->xoff2 - b->xoff; + q->y1 = y + b->yoff2 - b->yoff; + } else { + q->x0 = *xpos + b->xoff; + q->y0 = *ypos + b->yoff; + q->x1 = *xpos + b->xoff2; + q->y1 = *ypos + b->yoff2; + } + q->s0 = b->x0 * ipw; + q->t0 = b->y0 * iph; + q->s1 = b->x1 * ipw; + q->t1 = b->y1 * iph; + *xpos += b->xadvance; +} + +/* ------------------------------------------------------------- + * + * FONT BAKING + * + * --------------------------------------------------------------*/ +struct nk_font_bake_data { + struct nk_tt_fontinfo info; + struct nk_rp_rect *rects; + struct nk_tt_pack_range *ranges; + nk_rune range_count; +}; + +struct nk_font_baker { + struct nk_allocator alloc; + struct nk_tt_pack_context spc; + struct nk_font_bake_data *build; + struct nk_tt_packedchar *packed_chars; + struct nk_rp_rect *rects; + struct nk_tt_pack_range *ranges; +}; + +NK_GLOBAL const nk_size nk_rect_align = NK_ALIGNOF(struct nk_rp_rect); +NK_GLOBAL const nk_size nk_range_align = NK_ALIGNOF(struct nk_tt_pack_range); +NK_GLOBAL const nk_size nk_char_align = NK_ALIGNOF(struct nk_tt_packedchar); +NK_GLOBAL const nk_size nk_build_align = NK_ALIGNOF(struct nk_font_bake_data); +NK_GLOBAL const nk_size nk_baker_align = NK_ALIGNOF(struct nk_font_baker); + +NK_INTERN int +nk_range_count(const nk_rune *range) +{ + const nk_rune *iter = range; + NK_ASSERT(range); + if (!range) return 0; + while (*(iter++) != 0); + return (iter == range) ? 0 : (int)((iter - range)/2); +} + +NK_INTERN int +nk_range_glyph_count(const nk_rune *range, int count) +{ + int i = 0; + int total_glyphs = 0; + for (i = 0; i < count; ++i) { + int diff; + nk_rune f = range[(i*2)+0]; + nk_rune t = range[(i*2)+1]; + NK_ASSERT(t >= f); + diff = (int)((t - f) + 1); + total_glyphs += diff; + } + return total_glyphs; +} + +NK_API const nk_rune* +nk_font_default_glyph_ranges(void) +{ + NK_STORAGE const nk_rune ranges[] = {0x0020, 0x00FF, 0}; + return ranges; +} + +NK_API const nk_rune* +nk_font_chinese_glyph_ranges(void) +{ + NK_STORAGE const nk_rune ranges[] = { + 0x0020, 0x00FF, + 0x3000, 0x30FF, + 0x31F0, 0x31FF, + 0xFF00, 0xFFEF, + 0x4e00, 0x9FAF, + 0 + }; + return ranges; +} + +NK_API const nk_rune* +nk_font_cyrillic_glyph_ranges(void) +{ + NK_STORAGE const nk_rune ranges[] = { + 0x0020, 0x00FF, + 0x0400, 0x052F, + 0x2DE0, 0x2DFF, + 0xA640, 0xA69F, + 0 + }; + return ranges; +} + +NK_API const nk_rune* +nk_font_korean_glyph_ranges(void) +{ + NK_STORAGE const nk_rune ranges[] = { + 0x0020, 0x00FF, + 0x3131, 0x3163, + 0xAC00, 0xD79D, + 0 + }; + return ranges; +} + +NK_INTERN void +nk_font_baker_memory(nk_size *temp, int *glyph_count, + struct nk_font_config *config_list, int count) +{ + int range_count = 0; + int total_range_count = 0; + struct nk_font_config *iter, *i; + + NK_ASSERT(config_list); + NK_ASSERT(glyph_count); + if (!config_list) { + *temp = 0; + *glyph_count = 0; + return; + } + *glyph_count = 0; + for (iter = config_list; iter; iter = iter->next) { + i = iter; + do {if (!i->range) iter->range = nk_font_default_glyph_ranges(); + range_count = nk_range_count(i->range); + total_range_count += range_count; + *glyph_count += nk_range_glyph_count(i->range, range_count); + } while ((i = i->n) != iter); + } + *temp = (nk_size)*glyph_count * sizeof(struct nk_rp_rect); + *temp += (nk_size)total_range_count * sizeof(struct nk_tt_pack_range); + *temp += (nk_size)*glyph_count * sizeof(struct nk_tt_packedchar); + *temp += (nk_size)count * sizeof(struct nk_font_bake_data); + *temp += sizeof(struct nk_font_baker); + *temp += nk_rect_align + nk_range_align + nk_char_align; + *temp += nk_build_align + nk_baker_align; +} + +NK_INTERN struct nk_font_baker* +nk_font_baker(void *memory, int glyph_count, int count, struct nk_allocator *alloc) +{ + struct nk_font_baker *baker; + if (!memory) return 0; + /* setup baker inside a memory block */ + baker = (struct nk_font_baker*)NK_ALIGN_PTR(memory, nk_baker_align); + baker->build = (struct nk_font_bake_data*)NK_ALIGN_PTR((baker + 1), nk_build_align); + baker->packed_chars = (struct nk_tt_packedchar*)NK_ALIGN_PTR((baker->build + count), nk_char_align); + baker->rects = (struct nk_rp_rect*)NK_ALIGN_PTR((baker->packed_chars + glyph_count), nk_rect_align); + baker->ranges = (struct nk_tt_pack_range*)NK_ALIGN_PTR((baker->rects + glyph_count), nk_range_align); + baker->alloc = *alloc; + return baker; +} + +NK_INTERN int +nk_font_bake_pack(struct nk_font_baker *baker, + nk_size *image_memory, int *width, int *height, struct nk_recti *custom, + const struct nk_font_config *config_list, int count, + struct nk_allocator *alloc) +{ + NK_STORAGE const nk_size max_height = 1024 * 32; + const struct nk_font_config *config_iter, *it; + int total_glyph_count = 0; + int total_range_count = 0; + int range_count = 0; + int i = 0; + + NK_ASSERT(image_memory); + NK_ASSERT(width); + NK_ASSERT(height); + NK_ASSERT(config_list); + NK_ASSERT(count); + NK_ASSERT(alloc); + + if (!image_memory || !width || !height || !config_list || !count) return nk_false; + for (config_iter = config_list; config_iter; config_iter = config_iter->next) { + it = config_iter; + do {range_count = nk_range_count(it->range); + total_range_count += range_count; + total_glyph_count += nk_range_glyph_count(it->range, range_count); + } while ((it = it->n) != config_iter); + } + /* setup font baker from temporary memory */ + for (config_iter = config_list; config_iter; config_iter = config_iter->next) { + it = config_iter; + do {if (!nk_tt_InitFont(&baker->build[i++].info, (const unsigned char*)it->ttf_blob, 0)) + return nk_false; + } while ((it = it->n) != config_iter); + } + *height = 0; + *width = (total_glyph_count > 1000) ? 1024 : 512; + nk_tt_PackBegin(&baker->spc, 0, (int)*width, (int)max_height, 0, 1, alloc); + { + int input_i = 0; + int range_n = 0; + int rect_n = 0; + int char_n = 0; + + if (custom) { + /* pack custom user data first so it will be in the upper left corner*/ + struct nk_rp_rect custom_space; + nk_zero(&custom_space, sizeof(custom_space)); + custom_space.w = (nk_rp_coord)((custom->w * 2) + 1); + custom_space.h = (nk_rp_coord)(custom->h + 1); + + nk_tt_PackSetOversampling(&baker->spc, 1, 1); + nk_rp_pack_rects((struct nk_rp_context*)baker->spc.pack_info, &custom_space, 1); + *height = NK_MAX(*height, (int)(custom_space.y + custom_space.h)); + + custom->x = (short)custom_space.x; + custom->y = (short)custom_space.y; + custom->w = (short)custom_space.w; + custom->h = (short)custom_space.h; + } + + /* first font pass: pack all glyphs */ + for (input_i = 0, config_iter = config_list; input_i < count && config_iter; + config_iter = config_iter->next) { + it = config_iter; + do {int n = 0; + int glyph_count; + const nk_rune *in_range; + const struct nk_font_config *cfg = it; + struct nk_font_bake_data *tmp = &baker->build[input_i++]; + + /* count glyphs + ranges in current font */ + glyph_count = 0; range_count = 0; + for (in_range = cfg->range; in_range[0] && in_range[1]; in_range += 2) { + glyph_count += (int)(in_range[1] - in_range[0]) + 1; + range_count++; + } + + /* setup ranges */ + tmp->ranges = baker->ranges + range_n; + tmp->range_count = (nk_rune)range_count; + range_n += range_count; + for (i = 0; i < range_count; ++i) { + in_range = &cfg->range[i * 2]; + tmp->ranges[i].font_size = cfg->size; + tmp->ranges[i].first_unicode_codepoint_in_range = (int)in_range[0]; + tmp->ranges[i].num_chars = (int)(in_range[1]- in_range[0]) + 1; + tmp->ranges[i].chardata_for_range = baker->packed_chars + char_n; + char_n += tmp->ranges[i].num_chars; + } + + /* pack */ + tmp->rects = baker->rects + rect_n; + rect_n += glyph_count; + nk_tt_PackSetOversampling(&baker->spc, cfg->oversample_h, cfg->oversample_v); + n = nk_tt_PackFontRangesGatherRects(&baker->spc, &tmp->info, + tmp->ranges, (int)tmp->range_count, tmp->rects); + nk_rp_pack_rects((struct nk_rp_context*)baker->spc.pack_info, tmp->rects, (int)n); + + /* texture height */ + for (i = 0; i < n; ++i) { + if (tmp->rects[i].was_packed) + *height = NK_MAX(*height, tmp->rects[i].y + tmp->rects[i].h); + } + } while ((it = it->n) != config_iter); + } + NK_ASSERT(rect_n == total_glyph_count); + NK_ASSERT(char_n == total_glyph_count); + NK_ASSERT(range_n == total_range_count); + } + *height = (int)nk_round_up_pow2((nk_uint)*height); + *image_memory = (nk_size)(*width) * (nk_size)(*height); + return nk_true; +} + +NK_INTERN void +nk_font_bake(struct nk_font_baker *baker, void *image_memory, int width, int height, + struct nk_font_glyph *glyphs, int glyphs_count, + const struct nk_font_config *config_list, int font_count) +{ + int input_i = 0; + nk_rune glyph_n = 0; + const struct nk_font_config *config_iter; + const struct nk_font_config *it; + + NK_ASSERT(image_memory); + NK_ASSERT(width); + NK_ASSERT(height); + NK_ASSERT(config_list); + NK_ASSERT(baker); + NK_ASSERT(font_count); + NK_ASSERT(glyphs_count); + if (!image_memory || !width || !height || !config_list || + !font_count || !glyphs || !glyphs_count) + return; + + /* second font pass: render glyphs */ + nk_zero(image_memory, (nk_size)((nk_size)width * (nk_size)height)); + baker->spc.pixels = (unsigned char*)image_memory; + baker->spc.height = (int)height; + for (input_i = 0, config_iter = config_list; input_i < font_count && config_iter; + config_iter = config_iter->next) { + it = config_iter; + do {const struct nk_font_config *cfg = it; + struct nk_font_bake_data *tmp = &baker->build[input_i++]; + nk_tt_PackSetOversampling(&baker->spc, cfg->oversample_h, cfg->oversample_v); + nk_tt_PackFontRangesRenderIntoRects(&baker->spc, &tmp->info, tmp->ranges, + (int)tmp->range_count, tmp->rects, &baker->alloc); + } while ((it = it->n) != config_iter); + } nk_tt_PackEnd(&baker->spc, &baker->alloc); + + /* third pass: setup font and glyphs */ + for (input_i = 0, config_iter = config_list; input_i < font_count && config_iter; + config_iter = config_iter->next) { + it = config_iter; + do {nk_size i = 0; + int char_idx = 0; + nk_rune glyph_count = 0; + const struct nk_font_config *cfg = it; + struct nk_font_bake_data *tmp = &baker->build[input_i++]; + struct nk_baked_font *dst_font = cfg->font; + + float font_scale = nk_tt_ScaleForPixelHeight(&tmp->info, cfg->size); + int unscaled_ascent, unscaled_descent, unscaled_line_gap; + nk_tt_GetFontVMetrics(&tmp->info, &unscaled_ascent, &unscaled_descent, + &unscaled_line_gap); + + /* fill baked font */ + if (!cfg->merge_mode) { + dst_font->ranges = cfg->range; + dst_font->height = cfg->size; + dst_font->ascent = ((float)unscaled_ascent * font_scale); + dst_font->descent = ((float)unscaled_descent * font_scale); + dst_font->glyph_offset = glyph_n; + } + + /* fill own baked font glyph array */ + for (i = 0; i < tmp->range_count; ++i) { + struct nk_tt_pack_range *range = &tmp->ranges[i]; + for (char_idx = 0; char_idx < range->num_chars; char_idx++) + { + nk_rune codepoint = 0; + float dummy_x = 0, dummy_y = 0; + struct nk_tt_aligned_quad q; + struct nk_font_glyph *glyph; + + /* query glyph bounds from stb_truetype */ + const struct nk_tt_packedchar *pc = &range->chardata_for_range[char_idx]; + if (!pc->x0 && !pc->x1 && !pc->y0 && !pc->y1) continue; + codepoint = (nk_rune)(range->first_unicode_codepoint_in_range + char_idx); + nk_tt_GetPackedQuad(range->chardata_for_range, (int)width, + (int)height, char_idx, &dummy_x, &dummy_y, &q, 0); + + /* fill own glyph type with data */ + glyph = &glyphs[dst_font->glyph_offset + dst_font->glyph_count + (unsigned int)glyph_count]; + glyph->codepoint = codepoint; + glyph->x0 = q.x0; glyph->y0 = q.y0; + glyph->x1 = q.x1; glyph->y1 = q.y1; + glyph->y0 += (dst_font->ascent + 0.5f); + glyph->y1 += (dst_font->ascent + 0.5f); + glyph->w = glyph->x1 - glyph->x0 + 0.5f; + glyph->h = glyph->y1 - glyph->y0; + + if (cfg->coord_type == NK_COORD_PIXEL) { + glyph->u0 = q.s0 * (float)width; + glyph->v0 = q.t0 * (float)height; + glyph->u1 = q.s1 * (float)width; + glyph->v1 = q.t1 * (float)height; + } else { + glyph->u0 = q.s0; + glyph->v0 = q.t0; + glyph->u1 = q.s1; + glyph->v1 = q.t1; + } + glyph->xadvance = (pc->xadvance + cfg->spacing.x); + if (cfg->pixel_snap) + glyph->xadvance = (float)(int)(glyph->xadvance + 0.5f); + glyph_count++; + } + } + dst_font->glyph_count += glyph_count; + glyph_n += glyph_count; + } while ((it = it->n) != config_iter); + } +} + +NK_INTERN void +nk_font_bake_custom_data(void *img_memory, int img_width, int img_height, + struct nk_recti img_dst, const char *texture_data_mask, int tex_width, + int tex_height, char white, char black) +{ + nk_byte *pixels; + int y = 0; + int x = 0; + int n = 0; + + NK_ASSERT(img_memory); + NK_ASSERT(img_width); + NK_ASSERT(img_height); + NK_ASSERT(texture_data_mask); + NK_UNUSED(tex_height); + if (!img_memory || !img_width || !img_height || !texture_data_mask) + return; + + pixels = (nk_byte*)img_memory; + for (y = 0, n = 0; y < tex_height; ++y) { + for (x = 0; x < tex_width; ++x, ++n) { + const int off0 = ((img_dst.x + x) + (img_dst.y + y) * img_width); + const int off1 = off0 + 1 + tex_width; + pixels[off0] = (texture_data_mask[n] == white) ? 0xFF : 0x00; + pixels[off1] = (texture_data_mask[n] == black) ? 0xFF : 0x00; + } + } +} + +NK_INTERN void +nk_font_bake_convert(void *out_memory, int img_width, int img_height, + const void *in_memory) +{ + int n = 0; + nk_rune *dst; + const nk_byte *src; + + NK_ASSERT(out_memory); + NK_ASSERT(in_memory); + NK_ASSERT(img_width); + NK_ASSERT(img_height); + if (!out_memory || !in_memory || !img_height || !img_width) return; + + dst = (nk_rune*)out_memory; + src = (const nk_byte*)in_memory; + for (n = (int)(img_width * img_height); n > 0; n--) + *dst++ = ((nk_rune)(*src++) << 24) | 0x00FFFFFF; +} + +/* ------------------------------------------------------------- + * + * FONT + * + * --------------------------------------------------------------*/ +NK_INTERN float +nk_font_text_width(nk_handle handle, float height, const char *text, int len) +{ + nk_rune unicode; + int text_len = 0; + float text_width = 0; + int glyph_len = 0; + float scale = 0; + + struct nk_font *font = (struct nk_font*)handle.ptr; + NK_ASSERT(font); + NK_ASSERT(font->glyphs); + if (!font || !text || !len) + return 0; + + scale = height/font->info.height; + glyph_len = text_len = nk_utf_decode(text, &unicode, (int)len); + if (!glyph_len) return 0; + while (text_len <= (int)len && glyph_len) { + const struct nk_font_glyph *g; + if (unicode == NK_UTF_INVALID) break; + + /* query currently drawn glyph information */ + g = nk_font_find_glyph(font, unicode); + text_width += g->xadvance * scale; + + /* offset next glyph */ + glyph_len = nk_utf_decode(text + text_len, &unicode, (int)len - text_len); + text_len += glyph_len; + } + return text_width; +} + +#ifdef NK_INCLUDE_VERTEX_BUFFER_OUTPUT +NK_INTERN void +nk_font_query_font_glyph(nk_handle handle, float height, + struct nk_user_font_glyph *glyph, nk_rune codepoint, nk_rune next_codepoint) +{ + float scale; + const struct nk_font_glyph *g; + struct nk_font *font; + + NK_ASSERT(glyph); + NK_UNUSED(next_codepoint); + + font = (struct nk_font*)handle.ptr; + NK_ASSERT(font); + NK_ASSERT(font->glyphs); + if (!font || !glyph) + return; + + scale = height/font->info.height; + g = nk_font_find_glyph(font, codepoint); + glyph->width = (g->x1 - g->x0) * scale; + glyph->height = (g->y1 - g->y0) * scale; + glyph->offset = nk_vec2(g->x0 * scale, g->y0 * scale); + glyph->xadvance = (g->xadvance * scale); + glyph->uv[0] = nk_vec2(g->u0, g->v0); + glyph->uv[1] = nk_vec2(g->u1, g->v1); +} +#endif + +NK_API const struct nk_font_glyph* +nk_font_find_glyph(struct nk_font *font, nk_rune unicode) +{ + int i = 0; + int count; + int total_glyphs = 0; + const struct nk_font_glyph *glyph = 0; + const struct nk_font_config *iter = 0; + + NK_ASSERT(font); + NK_ASSERT(font->glyphs); + NK_ASSERT(font->info.ranges); + if (!font || !font->glyphs) return 0; + + glyph = font->fallback; + iter = font->config; + do {count = nk_range_count(iter->range); + for (i = 0; i < count; ++i) { + nk_rune f = iter->range[(i*2)+0]; + nk_rune t = iter->range[(i*2)+1]; + int diff = (int)((t - f) + 1); + if (unicode >= f && unicode <= t) + return &font->glyphs[((nk_rune)total_glyphs + (unicode - f))]; + total_glyphs += diff; + } + } while ((iter = iter->n) != font->config); + return glyph; +} + +NK_INTERN void +nk_font_init(struct nk_font *font, float pixel_height, + nk_rune fallback_codepoint, struct nk_font_glyph *glyphs, + const struct nk_baked_font *baked_font, nk_handle atlas) +{ + struct nk_baked_font baked; + NK_ASSERT(font); + NK_ASSERT(glyphs); + NK_ASSERT(baked_font); + if (!font || !glyphs || !baked_font) + return; + + baked = *baked_font; + font->fallback = 0; + font->info = baked; + font->scale = (float)pixel_height / (float)font->info.height; + font->glyphs = &glyphs[baked_font->glyph_offset]; + font->texture = atlas; + font->fallback_codepoint = fallback_codepoint; + font->fallback = nk_font_find_glyph(font, fallback_codepoint); + + font->handle.height = font->info.height * font->scale; + font->handle.width = nk_font_text_width; + font->handle.userdata.ptr = font; +#ifdef NK_INCLUDE_VERTEX_BUFFER_OUTPUT + font->handle.query = nk_font_query_font_glyph; + font->handle.texture = font->texture; +#endif +} + +/* --------------------------------------------------------------------------- + * + * DEFAULT FONT + * + * ProggyClean.ttf + * Copyright (c) 2004, 2005 Tristan Grimmer + * MIT license (see License.txt in http://www.upperbounds.net/download/ProggyClean.ttf.zip) + * Download and more information at http://upperbounds.net + *-----------------------------------------------------------------------------*/ +#ifdef NK_INCLUDE_DEFAULT_FONT + + #ifdef __clang__ +#pragma clang diagnostic push + +#pragma clang diagnostic ignored "-Woverlength-strings" +#elif defined(__GNUC__) || defined(__GNUG__) +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Woverlength-strings" +#endif + +NK_GLOBAL const char nk_proggy_clean_ttf_compressed_data_base85[11980+1] = + "7])#######hV0qs'/###[),##/l:$#Q6>##5[n42>c-TH`->>#/e>11NNV=Bv(*:.F?uu#(gRU.o0XGH`$vhLG1hxt9?W`#,5LsCp#-i>.r$<$6pD>Lb';9Crc6tgXmKVeU2cD4Eo3R/" + "2*>]b(MC;$jPfY.;h^`IWM9Qo#t'X#(v#Y9w0#1D$CIf;W'#pWUPXOuxXuU(H9M(1=Ke$$'5F%)]0^#0X@U.a$FBjVQTSDgEKnIS7EM9>ZY9w0#L;>>#Mx&4Mvt//L[MkA#W@lK.N'[0#7RL_&#w+F%HtG9M#XL`N&.,GM4Pg;--VsM.M0rJfLH2eTM`*oJMHRC`N" + "kfimM2J,W-jXS:)r0wK#@Fge$U>`w'N7G#$#fB#$E^$#:9:hk+eOe--6x)F7*E%?76%^GMHePW-Z5l'&GiF#$956:rS?dA#fiK:)Yr+`�j@'DbG&#^$PG.Ll+DNa&VZ>1i%h1S9u5o@YaaW$e+bROPOpxTO7Stwi1::iB1q)C_=dV26J;2,]7op$]uQr@_V7$q^%lQwtuHY]=DX,n3L#0PHDO4f9>dC@O>HBuKPpP*E,N+b3L#lpR/MrTEH.IAQk.a>D[.e;mc." + "x]Ip.PH^'/aqUO/$1WxLoW0[iLAw=4h(9.`G" + "CRUxHPeR`5Mjol(dUWxZa(>STrPkrJiWx`5U7F#.g*jrohGg`cg:lSTvEY/EV_7H4Q9[Z%cnv;JQYZ5q.l7Zeas:HOIZOB?Ggv:[7MI2k).'2($5FNP&EQ(,)" + "U]W]+fh18.vsai00);D3@4ku5P?DP8aJt+;qUM]=+b'8@;mViBKx0DE[-auGl8:PJ&Dj+M6OC]O^((##]`0i)drT;-7X`=-H3[igUnPG-NZlo.#k@h#=Ork$m>a>$-?Tm$UV(?#P6YY#" + "'/###xe7q.73rI3*pP/$1>s9)W,JrM7SN]'/4C#v$U`0#V.[0>xQsH$fEmPMgY2u7Kh(G%siIfLSoS+MK2eTM$=5,M8p`A.;_R%#u[K#$x4AG8.kK/HSB==-'Ie/QTtG?-.*^N-4B/ZM" + "_3YlQC7(p7q)&](`6_c)$/*JL(L-^(]$wIM`dPtOdGA,U3:w2M-0+WomX2u7lqM2iEumMTcsF?-aT=Z-97UEnXglEn1K-bnEO`gu" + "Ft(c%=;Am_Qs@jLooI&NX;]0#j4#F14;gl8-GQpgwhrq8'=l_f-b49'UOqkLu7-##oDY2L(te+Mch&gLYtJ,MEtJfLh'x'M=$CS-ZZ%P]8bZ>#S?YY#%Q&q'3^Fw&?D)UDNrocM3A76/" + "/oL?#h7gl85[qW/NDOk%16ij;+:1a'iNIdb-ou8.P*w,v5#EI$TWS>Pot-R*H'-SEpA:g)f+O$%%`kA#G=8RMmG1&O`>to8bC]T&$,n.LoO>29sp3dt-52U%VM#q7'DHpg+#Z9%H[Ket`e;)f#Km8&+DC$I46>#Kr]]u-[=99tts1.qb#q72g1WJO81q+eN'03'eM>&1XxY-caEnO" + "j%2n8)),?ILR5^.Ibn<-X-Mq7[a82Lq:F&#ce+S9wsCK*x`569E8ew'He]h:sI[2LM$[guka3ZRd6:t%IG:;$%YiJ:Nq=?eAw;/:nnDq0(CYcMpG)qLN4$##&J-XTt,%OVU4)S1+R-#dg0/Nn?Ku1^0f$B*P:Rowwm-`0PKjYDDM'3]d39VZHEl4,.j']Pk-M.h^&:0FACm$maq-&sgw0t7/6(^xtk%" + "LuH88Fj-ekm>GA#_>568x6(OFRl-IZp`&b,_P'$MhLbxfc$mj`,O;&%W2m`Zh:/)Uetw:aJ%]K9h:TcF]u_-Sj9,VK3M.*'&0D[Ca]J9gp8,kAW]" + "%(?A%R$f<->Zts'^kn=-^@c4%-pY6qI%J%1IGxfLU9CP8cbPlXv);C=b),<2mOvP8up,UVf3839acAWAW-W?#ao/^#%KYo8fRULNd2.>%m]UK:n%r$'sw]J;5pAoO_#2mO3n,'=H5(et" + "Hg*`+RLgv>=4U8guD$I%D:W>-r5V*%j*W:Kvej.Lp$'?;++O'>()jLR-^u68PHm8ZFWe+ej8h:9r6L*0//c&iH&R8pRbA#Kjm%upV1g:" + "a_#Ur7FuA#(tRh#.Y5K+@?3<-8m0$PEn;J:rh6?I6uG<-`wMU'ircp0LaE_OtlMb&1#6T.#FDKu#1Lw%u%+GM+X'e?YLfjM[VO0MbuFp7;>Q&#WIo)0@F%q7c#4XAXN-U&VBpqB>0ie&jhZ[?iLR@@_AvA-iQC(=ksRZRVp7`.=+NpBC%rh&3]R:8XDmE5^V8O(x<-+k?'(^](H.aREZSi,#1:[IXaZFOm<-ui#qUq2$##Ri;u75OK#(RtaW-K-F`S+cF]uN`-KMQ%rP/Xri.LRcB##=YL3BgM/3M" + "D?@f&1'BW-)Ju#bmmWCMkk&#TR`C,5d>g)F;t,4:@_l8G/5h4vUd%&%950:VXD'QdWoY-F$BtUwmfe$YqL'8(PWX(" + "P?^@Po3$##`MSs?DWBZ/S>+4%>fX,VWv/w'KD`LP5IbH;rTV>n3cEK8U#bX]l-/V+^lj3;vlMb&[5YQ8#pekX9JP3XUC72L,,?+Ni&co7ApnO*5NK,((W-i:$,kp'UDAO(G0Sq7MVjJs" + "bIu)'Z,*[>br5fX^:FPAWr-m2KgLQ_nN6'8uTGT5g)uLv:873UpTLgH+#FgpH'_o1780Ph8KmxQJ8#H72L4@768@Tm&Q" + "h4CB/5OvmA&,Q&QbUoi$a_%3M01H)4x7I^&KQVgtFnV+;[Pc>[m4k//,]1?#`VY[Jr*3&&slRfLiVZJ:]?=K3Sw=[$=uRB?3xk48@aege0jT6'N#(q%.O=?2S]u*(m<-" + "V8J'(1)G][68hW$5'q[GC&5j`TE?m'esFGNRM)j,ffZ?-qx8;->g4t*:CIP/[Qap7/9'#(1sao7w-.qNUdkJ)tCF&#B^;xGvn2r9FEPFFFcL@.iFNkTve$m%#QvQS8U@)2Z+3K:AKM5i" + "sZ88+dKQ)W6>J%CL`.d*(B`-n8D9oK-XV1q['-5k'cAZ69e;D_?$ZPP&s^+7])$*$#@QYi9,5P r+$%CE=68>K8r0=dSC%%(@p7" + ".m7jilQ02'0-VWAgTlGW'b)Tq7VT9q^*^$$.:&N@@" + "$&)WHtPm*5_rO0&e%K&#-30j(E4#'Zb.o/(Tpm$>K'f@[PvFl,hfINTNU6u'0pao7%XUp9]5.>%h`8_=VYbxuel.NTSsJfLacFu3B'lQSu/m6-Oqem8T+oE--$0a/k]uj9EwsG>%veR*" + "hv^BFpQj:K'#SJ,sB-'#](j.Lg92rTw-*n%@/;39rrJF,l#qV%OrtBeC6/,;qB3ebNW[?,Hqj2L.1NP&GjUR=1D8QaS3Up&@*9wP?+lo7b?@%'k4`p0Z$22%K3+iCZj?XJN4Nm&+YF]u" + "@-W$U%VEQ/,,>>#)D#%8cY#YZ?=,`Wdxu/ae&#" + "w6)R89tI#6@s'(6Bf7a&?S=^ZI_kS&ai`&=tE72L_D,;^R)7[$so8lKN%5/$(vdfq7+ebA#" + "u1p]ovUKW&Y%q]'>$1@-[xfn$7ZTp7mM,G,Ko7a&Gu%G[RMxJs[0MM%wci.LFDK)(%:_i2B5CsR8&9Z&#=mPEnm0f`<&c)QL5uJ#%u%lJj+D-r;BoFDoS97h5g)E#o:&S4weDF,9^Hoe`h*L+_a*NrLW-1pG_&2UdB8" + "6e%B/:=>)N4xeW.*wft-;$'58-ESqr#U`'6AQ]m&6/`Z>#S?YY#Vc;r7U2&326d=w&H####?TZ`*4?&.MK?LP8Vxg>$[QXc%QJv92.(Db*B)gb*BM9dM*hJMAo*c&#" + "b0v=Pjer]$gG&JXDf->'StvU7505l9$AFvgYRI^&<^b68?j#q9QX4SM'RO#&sL1IM.rJfLUAj221]d##DW=m83u5;'bYx,*Sl0hL(W;;$doB&O/TQ:(Z^xBdLjLV#*8U_72Lh+2Q8Cj0i:6hp&$C/:p(HK>T8Y[gHQ4`4)'$Ab(Nof%V'8hL&#SfD07&6D@M.*J:;$-rv29'M]8qMv-tLp,'886iaC=Hb*YJoKJ,(j%K=H`K.v9HggqBIiZu'QvBT.#=)0ukruV&.)3=(^1`o*Pj4<-#MJ+gLq9-##@HuZPN0]u:h7.T..G:;$/Usj(T7`Q8tT72LnYl<-qx8;-HV7Q-&Xdx%1a,hC=0u+HlsV>nuIQL-5" + "_>@kXQtMacfD.m-VAb8;IReM3$wf0''hra*so568'Ip&vRs849'MRYSp%:t:h5qSgwpEr$B>Q,;s(C#$)`svQuF$##-D,##,g68@2[T;.XSdN9Qe)rpt._K-#5wF)sP'##p#C0c%-Gb%" + "hd+<-j'Ai*x&&HMkT]C'OSl##5RG[JXaHN;d'uA#x._U;.`PU@(Z3dt4r152@:v,'R.Sj'w#0<-;kPI)FfJ&#AYJ&#//)>-k=m=*XnK$>=)72L]0I%>.G690a:$##<,);?;72#?x9+d;" + "^V'9;jY@;)br#q^YQpx:X#Te$Z^'=-=bGhLf:D6&bNwZ9-ZD#n^9HhLMr5G;']d&6'wYmTFmLq9wI>P(9mI[>kC-ekLC/R&CH+s'B;K-M6$EB%is00:" + "+A4[7xks.LrNk0&E)wILYF@2L'0Nb$+pv<(2.768/FrY&h$^3i&@+G%JT'<-,v`3;_)I9M^AE]CN?Cl2AZg+%4iTpT3$U4O]GKx'm9)b@p7YsvK3w^YR-" + "CdQ*:Ir<($u&)#(&?L9Rg3H)4fiEp^iI9O8KnTj,]H?D*r7'M;PwZ9K0E^k&-cpI;.p/6_vwoFMV<->#%Xi.LxVnrU(4&8/P+:hLSKj$#U%]49t'I:rgMi'FL@a:0Y-uA[39',(vbma*" + "hU%<-SRF`Tt:542R_VV$p@[p8DV[A,?1839FWdFTi1O*H&#(AL8[_P%.M>v^-))qOT*F5Cq0`Ye%+$B6i:7@0IXSsDiWP,##P`%/L-" + "S(qw%sf/@%#B6;/U7K]uZbi^Oc^2n%t<)'mEVE''n`WnJra$^TKvX5B>;_aSEK',(hwa0:i4G?.Bci.(X[?b*($,=-n<.Q%`(X=?+@Am*Js0&=3bh8K]mL69=Lb,OcZV/);TTm8VI;?%OtJ<(b4mq7M6:u?KRdFl*:xP?Yb.5)%w_I?7uk5JC+FS(m#i'k.'a0i)9<7b'fs'59hq$*5Uhv##pi^8+hIEBF`nvo`;'l0.^S1<-wUK2/Coh58KKhLj" + "M=SO*rfO`+qC`W-On.=AJ56>>i2@2LH6A:&5q`?9I3@@'04&p2/LVa*T-4<-i3;M9UvZd+N7>b*eIwg:CC)c<>nO&#$(>.Z-I&J(Q0Hd5Q%7Co-b`-cP)hI;*_F]u`Rb[.j8_Q/<&>uu+VsH$sM9TA%?)(vmJ80),P7E>)tjD%2L=-t#fK[%`v=Q8WlA2);Sa" + ">gXm8YB`1d@K#n]76-a$U,mF%Ul:#/'xoFM9QX-$.QN'>" + "[%$Z$uF6pA6Ki2O5:8w*vP1<-1`[G,)-m#>0`P&#eb#.3i)rtB61(o'$?X3B2Qft^ae_5tKL9MUe9b*sLEQ95C&`=G?@Mj=wh*'3E>=-<)Gt*Iw)'QG:`@I" + "wOf7&]1i'S01B+Ev/Nac#9S;=;YQpg_6U`*kVY39xK,[/6Aj7:'1Bm-_1EYfa1+o&o4hp7KN_Q(OlIo@S%;jVdn0'1h19w,WQhLI)3S#f$2(eb,jr*b;3Vw]*7NH%$c4Vs,eD9>XW8?N]o+(*pgC%/72LV-uW%iewS8W6m2rtCpo'RS1R84=@paTKt)>=%&1[)*vp'u+x,VrwN;&]kuO9JDbg=pO$J*.jVe;u'm0dr9l,<*wMK*Oe=g8lV_KEBFkO'oU]^=[-792#ok,)" + "i]lR8qQ2oA8wcRCZ^7w/Njh;?.stX?Q1>S1q4Bn$)K1<-rGdO'$Wr.Lc.CG)$/*JL4tNR/,SVO3,aUw'DJN:)Ss;wGn9A32ijw%FL+Z0Fn.U9;reSq)bmI32U==5ALuG&#Vf1398/pVo" + "1*c-(aY168o<`JsSbk-,1N;$>0:OUas(3:8Z972LSfF8eb=c-;>SPw7.6hn3m`9^Xkn(r.qS[0;T%&Qc=+STRxX'q1BNk3&*eu2;&8q$&x>Q#Q7^Tf+6<(d%ZVmj2bDi%.3L2n+4W'$P" + "iDDG)g,r%+?,$@?uou5tSe2aN_AQU*'IAO" + "URQ##V^Fv-XFbGM7Fl(N<3DhLGF%q.1rC$#:T__&Pi68%0xi_&[qFJ(77j_&JWoF.V735&T,[R*:xFR*K5>>#`bW-?4Ne_&6Ne_&6Ne_&n`kr-#GJcM6X;uM6X;uM(.a..^2TkL%oR(#" + ";u.T%fAr%4tJ8&><1=GHZ_+m9/#H1F^R#SC#*N=BA9(D?v[UiFY>>^8p,KKF.W]L29uLkLlu/+4T" + "w$)F./^n3+rlo+DB;5sIYGNk+i1t-69Jg--0pao7Sm#K)pdHW&;LuDNH@H>#/X-TI(;P>#,Gc>#0Su>#4`1?#8lC?#xL$#B.`$#F:r$#JF.%#NR@%#R_R%#Vke%#Zww%#_-4^Rh%Sflr-k'MS.o?.5/sWel/wpEM0%3'/1)K^f1-d>G21&v(35>V`39V7A4=onx4" + "A1OY5EI0;6Ibgr6M$HS7Q<)58C5w,;WoA*#[%T*#`1g*#d=#+#hI5+#lUG+#pbY+#tnl+#x$),#&1;,#*=M,#.I`,#2Ur,#6b.-#;w[H#iQtA#m^0B#qjBB#uvTB##-hB#'9$C#+E6C#" + "/QHC#3^ZC#7jmC#;v)D#?,)4kMYD4lVu`4m`:&5niUA5@(A5BA1]PBB:xlBCC=2CDLXMCEUtiCf&0g2'tN?PGT4CPGT4CPGT4CPGT4CPGT4CPGT4CPGT4CP" + "GT4CPGT4CPGT4CPGT4CPGT4CPGT4CP-qekC`.9kEg^+F$kwViFJTB&5KTB&5KTB&5KTB&5KTB&5KTB&5KTB&5KTB&5KTB&5KTB&5KTB&5KTB&5KTB&5KTB&5KTB&5o,^<-28ZI'O?;xp" + "O?;xpO?;xpO?;xpO?;xpO?;xpO?;xpO?;xpO?;xpO?;xpO?;xpO?;xpO?;xpO?;xp;7q-#lLYI:xvD=#"; +#endif /* NK_INCLUDE_DEFAULT_FONT */ + +#define NK_CURSOR_DATA_W 90 +#define NK_CURSOR_DATA_H 27 +NK_GLOBAL const char nk_custom_cursor_data[NK_CURSOR_DATA_W * NK_CURSOR_DATA_H + 1] = +{ + "..- -XXXXXXX- X - X -XXXXXXX - XXXXXXX" + "..- -X.....X- X.X - X.X -X.....X - X.....X" + "--- -XXX.XXX- X...X - X...X -X....X - X....X" + "X - X.X - X.....X - X.....X -X...X - X...X" + "XX - X.X -X.......X- X.......X -X..X.X - X.X..X" + "X.X - X.X -XXXX.XXXX- XXXX.XXXX -X.X X.X - X.X X.X" + "X..X - X.X - X.X - X.X -XX X.X - X.X XX" + "X...X - X.X - X.X - XX X.X XX - X.X - X.X " + "X....X - X.X - X.X - X.X X.X X.X - X.X - X.X " + "X.....X - X.X - X.X - X..X X.X X..X - X.X - X.X " + "X......X - X.X - X.X - X...XXXXXX.XXXXXX...X - X.X XX-XX X.X " + "X.......X - X.X - X.X -X.....................X- X.X X.X-X.X X.X " + "X........X - X.X - X.X - X...XXXXXX.XXXXXX...X - X.X..X-X..X.X " + "X.........X -XXX.XXX- X.X - X..X X.X X..X - X...X-X...X " + "X..........X-X.....X- X.X - X.X X.X X.X - X....X-X....X " + "X......XXXXX-XXXXXXX- X.X - XX X.X XX - X.....X-X.....X " + "X...X..X --------- X.X - X.X - XXXXXXX-XXXXXXX " + "X..X X..X - -XXXX.XXXX- XXXX.XXXX ------------------------------------" + "X.X X..X - -X.......X- X.......X - XX XX - " + "XX X..X - - X.....X - X.....X - X.X X.X - " + " X..X - X...X - X...X - X..X X..X - " + " XX - X.X - X.X - X...XXXXXXXXXXXXX...X - " + "------------ - X - X -X.....................X- " + " ----------------------------------- X...XXXXXXXXXXXXX...X - " + " - X..X X..X - " + " - X.X X.X - " + " - XX XX - " +}; + +#ifdef __clang__ +#pragma clang diagnostic pop +#elif defined(__GNUC__) || defined(__GNUG__) +#pragma GCC diagnostic pop +#endif + +NK_INTERN unsigned int +nk_decompress_length(unsigned char *input) +{ + return (unsigned int)((input[8] << 24) + (input[9] << 16) + (input[10] << 8) + input[11]); +} + +NK_GLOBAL unsigned char *nk__barrier; +NK_GLOBAL unsigned char *nk__barrier2; +NK_GLOBAL unsigned char *nk__barrier3; +NK_GLOBAL unsigned char *nk__barrier4; +NK_GLOBAL unsigned char *nk__dout; + +NK_INTERN void +nk__match(unsigned char *data, unsigned int length) +{ + /* INVERSE of memmove... write each byte before copying the next...*/ + NK_ASSERT (nk__dout + length <= nk__barrier); + if (nk__dout + length > nk__barrier) { nk__dout += length; return; } + if (data < nk__barrier4) { nk__dout = nk__barrier+1; return; } + while (length--) *nk__dout++ = *data++; +} + +NK_INTERN void +nk__lit(unsigned char *data, unsigned int length) +{ + NK_ASSERT (nk__dout + length <= nk__barrier); + if (nk__dout + length > nk__barrier) { nk__dout += length; return; } + if (data < nk__barrier2) { nk__dout = nk__barrier+1; return; } + NK_MEMCPY(nk__dout, data, length); + nk__dout += length; +} + +#define nk__in2(x) ((i[x] << 8) + i[(x)+1]) +#define nk__in3(x) ((i[x] << 16) + nk__in2((x)+1)) +#define nk__in4(x) ((i[x] << 24) + nk__in3((x)+1)) + +NK_INTERN unsigned char* +nk_decompress_token(unsigned char *i) +{ + if (*i >= 0x20) { /* use fewer if's for cases that expand small */ + if (*i >= 0x80) nk__match(nk__dout-i[1]-1, (unsigned int)i[0] - 0x80 + 1), i += 2; + else if (*i >= 0x40) nk__match(nk__dout-(nk__in2(0) - 0x4000 + 1), (unsigned int)i[2]+1), i += 3; + else /* *i >= 0x20 */ nk__lit(i+1, (unsigned int)i[0] - 0x20 + 1), i += 1 + (i[0] - 0x20 + 1); + } else { /* more ifs for cases that expand large, since overhead is amortized */ + if (*i >= 0x18) nk__match(nk__dout-(unsigned int)(nk__in3(0) - 0x180000 + 1), (unsigned int)i[3]+1), i += 4; + else if (*i >= 0x10) nk__match(nk__dout-(unsigned int)(nk__in3(0) - 0x100000 + 1), (unsigned int)nk__in2(3)+1), i += 5; + else if (*i >= 0x08) nk__lit(i+2, (unsigned int)nk__in2(0) - 0x0800 + 1), i += 2 + (nk__in2(0) - 0x0800 + 1); + else if (*i == 0x07) nk__lit(i+3, (unsigned int)nk__in2(1) + 1), i += 3 + (nk__in2(1) + 1); + else if (*i == 0x06) nk__match(nk__dout-(unsigned int)(nk__in3(1)+1), i[4]+1u), i += 5; + else if (*i == 0x04) nk__match(nk__dout-(unsigned int)(nk__in3(1)+1), (unsigned int)nk__in2(4)+1u), i += 6; + } + return i; +} + +NK_INTERN unsigned int +nk_adler32(unsigned int adler32, unsigned char *buffer, unsigned int buflen) +{ + const unsigned long ADLER_MOD = 65521; + unsigned long s1 = adler32 & 0xffff, s2 = adler32 >> 16; + unsigned long blocklen, i; + + blocklen = buflen % 5552; + while (buflen) { + for (i=0; i + 7 < blocklen; i += 8) { + s1 += buffer[0]; s2 += s1; + s1 += buffer[1]; s2 += s1; + s1 += buffer[2]; s2 += s1; + s1 += buffer[3]; s2 += s1; + s1 += buffer[4]; s2 += s1; + s1 += buffer[5]; s2 += s1; + s1 += buffer[6]; s2 += s1; + s1 += buffer[7]; s2 += s1; + buffer += 8; + } + for (; i < blocklen; ++i) { + s1 += *buffer++; s2 += s1; + } + + s1 %= ADLER_MOD; s2 %= ADLER_MOD; + buflen -= (unsigned int)blocklen; + blocklen = 5552; + } + return (unsigned int)(s2 << 16) + (unsigned int)s1; +} + +NK_INTERN unsigned int +nk_decompress(unsigned char *output, unsigned char *i, unsigned int length) +{ + unsigned int olen; + if (nk__in4(0) != 0x57bC0000) return 0; + if (nk__in4(4) != 0) return 0; /* error! stream is > 4GB */ + olen = nk_decompress_length(i); + nk__barrier2 = i; + nk__barrier3 = i+length; + nk__barrier = output + olen; + nk__barrier4 = output; + i += 16; + + nk__dout = output; + for (;;) { + unsigned char *old_i = i; + i = nk_decompress_token(i); + if (i == old_i) { + if (*i == 0x05 && i[1] == 0xfa) { + NK_ASSERT(nk__dout == output + olen); + if (nk__dout != output + olen) return 0; + if (nk_adler32(1, output, olen) != (unsigned int) nk__in4(2)) + return 0; + return olen; + } else { + NK_ASSERT(0); /* NOTREACHED */ + return 0; + } + } + NK_ASSERT(nk__dout <= output + olen); + if (nk__dout > output + olen) + return 0; + } +} + +NK_INTERN unsigned int +nk_decode_85_byte(char c) +{ return (unsigned int)((c >= '\\') ? c-36 : c-35); } + +NK_INTERN void +nk_decode_85(unsigned char* dst, const unsigned char* src) +{ + while (*src) + { + unsigned int tmp = + nk_decode_85_byte((char)src[0]) + + 85 * (nk_decode_85_byte((char)src[1]) + + 85 * (nk_decode_85_byte((char)src[2]) + + 85 * (nk_decode_85_byte((char)src[3]) + + 85 * nk_decode_85_byte((char)src[4])))); + + /* we can't assume little-endianess. */ + dst[0] = (unsigned char)((tmp >> 0) & 0xFF); + dst[1] = (unsigned char)((tmp >> 8) & 0xFF); + dst[2] = (unsigned char)((tmp >> 16) & 0xFF); + dst[3] = (unsigned char)((tmp >> 24) & 0xFF); + + src += 5; + dst += 4; + } +} + +/* ------------------------------------------------------------- + * + * FONT ATLAS + * + * --------------------------------------------------------------*/ +NK_API struct nk_font_config +nk_font_config(float pixel_height) +{ + struct nk_font_config cfg; + nk_zero_struct(cfg); + cfg.ttf_blob = 0; + cfg.ttf_size = 0; + cfg.ttf_data_owned_by_atlas = 0; + cfg.size = pixel_height; + cfg.oversample_h = 3; + cfg.oversample_v = 1; + cfg.pixel_snap = 0; + cfg.coord_type = NK_COORD_UV; + cfg.spacing = nk_vec2(0,0); + cfg.range = nk_font_default_glyph_ranges(); + cfg.merge_mode = 0; + cfg.fallback_glyph = '?'; + cfg.font = 0; + cfg.n = 0; + return cfg; +} + +#ifdef NK_INCLUDE_DEFAULT_ALLOCATOR +NK_API void +nk_font_atlas_init_default(struct nk_font_atlas *atlas) +{ + NK_ASSERT(atlas); + if (!atlas) return; + nk_zero_struct(*atlas); + atlas->temporary.userdata.ptr = 0; + atlas->temporary.alloc = nk_malloc; + atlas->temporary.free = nk_mfree; + atlas->permanent.userdata.ptr = 0; + atlas->permanent.alloc = nk_malloc; + atlas->permanent.free = nk_mfree; +} +#endif + +NK_API void +nk_font_atlas_init(struct nk_font_atlas *atlas, struct nk_allocator *alloc) +{ + NK_ASSERT(atlas); + NK_ASSERT(alloc); + if (!atlas || !alloc) return; + nk_zero_struct(*atlas); + atlas->permanent = *alloc; + atlas->temporary = *alloc; +} + +NK_API void +nk_font_atlas_init_custom(struct nk_font_atlas *atlas, + struct nk_allocator *permanent, struct nk_allocator *temporary) +{ + NK_ASSERT(atlas); + NK_ASSERT(permanent); + NK_ASSERT(temporary); + if (!atlas || !permanent || !temporary) return; + nk_zero_struct(*atlas); + atlas->permanent = *permanent; + atlas->temporary = *temporary; +} + +NK_API void +nk_font_atlas_begin(struct nk_font_atlas *atlas) +{ + NK_ASSERT(atlas); + NK_ASSERT(atlas->temporary.alloc && atlas->temporary.free); + NK_ASSERT(atlas->permanent.alloc && atlas->permanent.free); + if (!atlas || !atlas->permanent.alloc || !atlas->permanent.free || + !atlas->temporary.alloc || !atlas->temporary.free) return; + if (atlas->glyphs) { + atlas->permanent.free(atlas->permanent.userdata, atlas->glyphs); + atlas->glyphs = 0; + } + if (atlas->pixel) { + atlas->permanent.free(atlas->permanent.userdata, atlas->pixel); + atlas->pixel = 0; + } +} + +NK_API struct nk_font* +nk_font_atlas_add(struct nk_font_atlas *atlas, const struct nk_font_config *config) +{ + struct nk_font *font = 0; + struct nk_font_config *cfg; + + NK_ASSERT(atlas); + NK_ASSERT(atlas->permanent.alloc); + NK_ASSERT(atlas->permanent.free); + NK_ASSERT(atlas->temporary.alloc); + NK_ASSERT(atlas->temporary.free); + + NK_ASSERT(config); + NK_ASSERT(config->ttf_blob); + NK_ASSERT(config->ttf_size); + NK_ASSERT(config->size > 0.0f); + + if (!atlas || !config || !config->ttf_blob || !config->ttf_size || config->size <= 0.0f|| + !atlas->permanent.alloc || !atlas->permanent.free || + !atlas->temporary.alloc || !atlas->temporary.free) + return 0; + + /* allocate font config */ + cfg = (struct nk_font_config*) + atlas->permanent.alloc(atlas->permanent.userdata,0, sizeof(struct nk_font_config)); + NK_MEMCPY(cfg, config, sizeof(*config)); + cfg->n = cfg; + cfg->p = cfg; + + if (!config->merge_mode) { + /* insert font config into list */ + if (!atlas->config) { + atlas->config = cfg; + cfg->next = 0; + } else { + struct nk_font_config *i = atlas->config; + while (i->next) i = i->next; + i->next = cfg; + cfg->next = 0; + } + /* allocate new font */ + font = (struct nk_font*) + atlas->permanent.alloc(atlas->permanent.userdata,0, sizeof(struct nk_font)); + NK_ASSERT(font); + nk_zero(font, sizeof(*font)); + if (!font) return 0; + font->config = cfg; + + /* insert font into list */ + if (!atlas->fonts) { + atlas->fonts = font; + font->next = 0; + } else { + struct nk_font *i = atlas->fonts; + while (i->next) i = i->next; + i->next = font; + font->next = 0; + } + cfg->font = &font->info; + } else { + /* extend previously added font */ + struct nk_font *f = 0; + struct nk_font_config *c = 0; + NK_ASSERT(atlas->font_num); + f = atlas->fonts; + c = f->config; + cfg->font = &f->info; + + cfg->n = c; + cfg->p = c->p; + c->p->n = cfg; + c->p = cfg; + } + /* create own copy of .TTF font blob */ + if (!config->ttf_data_owned_by_atlas) { + cfg->ttf_blob = atlas->permanent.alloc(atlas->permanent.userdata,0, cfg->ttf_size); + NK_ASSERT(cfg->ttf_blob); + if (!cfg->ttf_blob) { + atlas->font_num++; + return 0; + } + NK_MEMCPY(cfg->ttf_blob, config->ttf_blob, cfg->ttf_size); + cfg->ttf_data_owned_by_atlas = 1; + } + atlas->font_num++; + return font; +} + +NK_API struct nk_font* +nk_font_atlas_add_from_memory(struct nk_font_atlas *atlas, void *memory, + nk_size size, float height, const struct nk_font_config *config) +{ + struct nk_font_config cfg; + NK_ASSERT(memory); + NK_ASSERT(size); + + NK_ASSERT(atlas); + NK_ASSERT(atlas->temporary.alloc); + NK_ASSERT(atlas->temporary.free); + NK_ASSERT(atlas->permanent.alloc); + NK_ASSERT(atlas->permanent.free); + if (!atlas || !atlas->temporary.alloc || !atlas->temporary.free || !memory || !size || + !atlas->permanent.alloc || !atlas->permanent.free) + return 0; + + cfg = (config) ? *config: nk_font_config(height); + cfg.ttf_blob = memory; + cfg.ttf_size = size; + cfg.size = height; + cfg.ttf_data_owned_by_atlas = 0; + return nk_font_atlas_add(atlas, &cfg); +} + +#ifdef NK_INCLUDE_STANDARD_IO +NK_API struct nk_font* +nk_font_atlas_add_from_file(struct nk_font_atlas *atlas, const char *file_path, + float height, const struct nk_font_config *config) +{ + nk_size size; + char *memory; + struct nk_font_config cfg; + + NK_ASSERT(atlas); + NK_ASSERT(atlas->temporary.alloc); + NK_ASSERT(atlas->temporary.free); + NK_ASSERT(atlas->permanent.alloc); + NK_ASSERT(atlas->permanent.free); + + if (!atlas || !file_path) return 0; + memory = nk_file_load(file_path, &size, &atlas->permanent); + if (!memory) return 0; + + cfg = (config) ? *config: nk_font_config(height); + cfg.ttf_blob = memory; + cfg.ttf_size = size; + cfg.size = height; + cfg.ttf_data_owned_by_atlas = 1; + return nk_font_atlas_add(atlas, &cfg); +} +#endif + +NK_API struct nk_font* +nk_font_atlas_add_compressed(struct nk_font_atlas *atlas, + void *compressed_data, nk_size compressed_size, float height, + const struct nk_font_config *config) +{ + unsigned int decompressed_size; + void *decompressed_data; + struct nk_font_config cfg; + + NK_ASSERT(atlas); + NK_ASSERT(atlas->temporary.alloc); + NK_ASSERT(atlas->temporary.free); + NK_ASSERT(atlas->permanent.alloc); + NK_ASSERT(atlas->permanent.free); + + NK_ASSERT(compressed_data); + NK_ASSERT(compressed_size); + if (!atlas || !compressed_data || !atlas->temporary.alloc || !atlas->temporary.free || + !atlas->permanent.alloc || !atlas->permanent.free) + return 0; + + decompressed_size = nk_decompress_length((unsigned char*)compressed_data); + decompressed_data = atlas->permanent.alloc(atlas->permanent.userdata,0,decompressed_size); + NK_ASSERT(decompressed_data); + if (!decompressed_data) return 0; + nk_decompress((unsigned char*)decompressed_data, (unsigned char*)compressed_data, + (unsigned int)compressed_size); + + cfg = (config) ? *config: nk_font_config(height); + cfg.ttf_blob = decompressed_data; + cfg.ttf_size = decompressed_size; + cfg.size = height; + cfg.ttf_data_owned_by_atlas = 1; + return nk_font_atlas_add(atlas, &cfg); +} + +NK_API struct nk_font* +nk_font_atlas_add_compressed_base85(struct nk_font_atlas *atlas, + const char *data_base85, float height, const struct nk_font_config *config) +{ + int compressed_size; + void *compressed_data; + struct nk_font *font; + + NK_ASSERT(atlas); + NK_ASSERT(atlas->temporary.alloc); + NK_ASSERT(atlas->temporary.free); + NK_ASSERT(atlas->permanent.alloc); + NK_ASSERT(atlas->permanent.free); + + NK_ASSERT(data_base85); + if (!atlas || !data_base85 || !atlas->temporary.alloc || !atlas->temporary.free || + !atlas->permanent.alloc || !atlas->permanent.free) + return 0; + + compressed_size = (((int)nk_strlen(data_base85) + 4) / 5) * 4; + compressed_data = atlas->temporary.alloc(atlas->temporary.userdata,0, (nk_size)compressed_size); + NK_ASSERT(compressed_data); + if (!compressed_data) return 0; + nk_decode_85((unsigned char*)compressed_data, (const unsigned char*)data_base85); + font = nk_font_atlas_add_compressed(atlas, compressed_data, + (nk_size)compressed_size, height, config); + atlas->temporary.free(atlas->temporary.userdata, compressed_data); + return font; +} + +#ifdef NK_INCLUDE_DEFAULT_FONT +NK_API struct nk_font* +nk_font_atlas_add_default(struct nk_font_atlas *atlas, + float pixel_height, const struct nk_font_config *config) +{ + NK_ASSERT(atlas); + NK_ASSERT(atlas->temporary.alloc); + NK_ASSERT(atlas->temporary.free); + NK_ASSERT(atlas->permanent.alloc); + NK_ASSERT(atlas->permanent.free); + return nk_font_atlas_add_compressed_base85(atlas, + nk_proggy_clean_ttf_compressed_data_base85, pixel_height, config); +} +#endif + +NK_API const void* +nk_font_atlas_bake(struct nk_font_atlas *atlas, int *width, int *height, + enum nk_font_atlas_format fmt) +{ + int i = 0; + void *tmp = 0; + nk_size tmp_size, img_size; + struct nk_font *font_iter; + struct nk_font_baker *baker; + + NK_ASSERT(atlas); + NK_ASSERT(atlas->temporary.alloc); + NK_ASSERT(atlas->temporary.free); + NK_ASSERT(atlas->permanent.alloc); + NK_ASSERT(atlas->permanent.free); + + NK_ASSERT(width); + NK_ASSERT(height); + if (!atlas || !width || !height || + !atlas->temporary.alloc || !atlas->temporary.free || + !atlas->permanent.alloc || !atlas->permanent.free) + return 0; + +#ifdef NK_INCLUDE_DEFAULT_FONT + /* no font added so just use default font */ + if (!atlas->font_num) + atlas->default_font = nk_font_atlas_add_default(atlas, 13.0f, 0); +#endif + NK_ASSERT(atlas->font_num); + if (!atlas->font_num) return 0; + + /* allocate temporary baker memory required for the baking process */ + nk_font_baker_memory(&tmp_size, &atlas->glyph_count, atlas->config, atlas->font_num); + tmp = atlas->temporary.alloc(atlas->temporary.userdata,0, tmp_size); + NK_ASSERT(tmp); + if (!tmp) goto failed; + + /* allocate glyph memory for all fonts */ + baker = nk_font_baker(tmp, atlas->glyph_count, atlas->font_num, &atlas->temporary); + atlas->glyphs = (struct nk_font_glyph*)atlas->permanent.alloc( + atlas->permanent.userdata,0, sizeof(struct nk_font_glyph)*(nk_size)atlas->glyph_count); + NK_ASSERT(atlas->glyphs); + if (!atlas->glyphs) + goto failed; + + /* pack all glyphs into a tight fit space */ + atlas->custom.w = (NK_CURSOR_DATA_W*2)+1; + atlas->custom.h = NK_CURSOR_DATA_H + 1; + if (!nk_font_bake_pack(baker, &img_size, width, height, &atlas->custom, + atlas->config, atlas->font_num, &atlas->temporary)) + goto failed; + + /* allocate memory for the baked image font atlas */ + atlas->pixel = atlas->temporary.alloc(atlas->temporary.userdata,0, img_size); + NK_ASSERT(atlas->pixel); + if (!atlas->pixel) + goto failed; + + /* bake glyphs and custom white pixel into image */ + nk_font_bake(baker, atlas->pixel, *width, *height, + atlas->glyphs, atlas->glyph_count, atlas->config, atlas->font_num); + nk_font_bake_custom_data(atlas->pixel, *width, *height, atlas->custom, + nk_custom_cursor_data, NK_CURSOR_DATA_W, NK_CURSOR_DATA_H, '.', 'X'); + + if (fmt == NK_FONT_ATLAS_RGBA32) { + /* convert alpha8 image into rgba32 image */ + void *img_rgba = atlas->temporary.alloc(atlas->temporary.userdata,0, + (nk_size)(*width * *height * 4)); + NK_ASSERT(img_rgba); + if (!img_rgba) goto failed; + nk_font_bake_convert(img_rgba, *width, *height, atlas->pixel); + atlas->temporary.free(atlas->temporary.userdata, atlas->pixel); + atlas->pixel = img_rgba; + } + atlas->tex_width = *width; + atlas->tex_height = *height; + + /* initialize each font */ + for (font_iter = atlas->fonts; font_iter; font_iter = font_iter->next) { + struct nk_font *font = font_iter; + struct nk_font_config *config = font->config; + nk_font_init(font, config->size, config->fallback_glyph, atlas->glyphs, + config->font, nk_handle_ptr(0)); + } + + /* initialize each cursor */ + {NK_STORAGE const struct nk_vec2 nk_cursor_data[NK_CURSOR_COUNT][3] = { + /* Pos ----- Size ------- Offset --*/ + {{ 0, 3}, {12,19}, { 0, 0}}, + {{13, 0}, { 7,16}, { 4, 8}}, + {{31, 0}, {23,23}, {11,11}}, + {{21, 0}, { 9, 23}, { 5,11}}, + {{55,18}, {23, 9}, {11, 5}}, + {{73, 0}, {17,17}, { 9, 9}}, + {{55, 0}, {17,17}, { 9, 9}} + }; + for (i = 0; i < NK_CURSOR_COUNT; ++i) { + struct nk_cursor *cursor = &atlas->cursors[i]; + cursor->img.w = (unsigned short)*width; + cursor->img.h = (unsigned short)*height; + cursor->img.region[0] = (unsigned short)(atlas->custom.x + nk_cursor_data[i][0].x); + cursor->img.region[1] = (unsigned short)(atlas->custom.y + nk_cursor_data[i][0].y); + cursor->img.region[2] = (unsigned short)nk_cursor_data[i][1].x; + cursor->img.region[3] = (unsigned short)nk_cursor_data[i][1].y; + cursor->size = nk_cursor_data[i][1]; + cursor->offset = nk_cursor_data[i][2]; + }} + /* free temporary memory */ + atlas->temporary.free(atlas->temporary.userdata, tmp); + return atlas->pixel; + +failed: + /* error so cleanup all memory */ + if (tmp) atlas->temporary.free(atlas->temporary.userdata, tmp); + if (atlas->glyphs) { + atlas->permanent.free(atlas->permanent.userdata, atlas->glyphs); + atlas->glyphs = 0; + } + if (atlas->pixel) { + atlas->temporary.free(atlas->temporary.userdata, atlas->pixel); + atlas->pixel = 0; + } + return 0; +} + +NK_API void +nk_font_atlas_end(struct nk_font_atlas *atlas, nk_handle texture, + struct nk_draw_null_texture *null) +{ + int i = 0; + struct nk_font *font_iter; + NK_ASSERT(atlas); + if (!atlas) { + if (!null) return; + null->texture = texture; + null->uv = nk_vec2(0.5f,0.5f); + } + if (null) { + null->texture = texture; + null->uv.x = (atlas->custom.x + 0.5f)/(float)atlas->tex_width; + null->uv.y = (atlas->custom.y + 0.5f)/(float)atlas->tex_height; + } + for (font_iter = atlas->fonts; font_iter; font_iter = font_iter->next) { + font_iter->texture = texture; +#ifdef NK_INCLUDE_VERTEX_BUFFER_OUTPUT + font_iter->handle.texture = texture; +#endif + } + for (i = 0; i < NK_CURSOR_COUNT; ++i) + atlas->cursors[i].img.handle = texture; + + atlas->temporary.free(atlas->temporary.userdata, atlas->pixel); + atlas->pixel = 0; + atlas->tex_width = 0; + atlas->tex_height = 0; + atlas->custom.x = 0; + atlas->custom.y = 0; + atlas->custom.w = 0; + atlas->custom.h = 0; +} + +NK_API void +nk_font_atlas_cleanup(struct nk_font_atlas *atlas) +{ + NK_ASSERT(atlas); + NK_ASSERT(atlas->temporary.alloc); + NK_ASSERT(atlas->temporary.free); + NK_ASSERT(atlas->permanent.alloc); + NK_ASSERT(atlas->permanent.free); + if (!atlas || !atlas->permanent.alloc || !atlas->permanent.free) return; + if (atlas->config) { + struct nk_font_config *iter; + for (iter = atlas->config; iter; iter = iter->next) { + struct nk_font_config *i; + for (i = iter->n; i != iter; i = i->n) { + atlas->permanent.free(atlas->permanent.userdata, i->ttf_blob); + i->ttf_blob = 0; + } + atlas->permanent.free(atlas->permanent.userdata, iter->ttf_blob); + iter->ttf_blob = 0; + } + } +} + +NK_API void +nk_font_atlas_clear(struct nk_font_atlas *atlas) +{ + NK_ASSERT(atlas); + NK_ASSERT(atlas->temporary.alloc); + NK_ASSERT(atlas->temporary.free); + NK_ASSERT(atlas->permanent.alloc); + NK_ASSERT(atlas->permanent.free); + if (!atlas || !atlas->permanent.alloc || !atlas->permanent.free) return; + + if (atlas->config) { + struct nk_font_config *iter, *next; + for (iter = atlas->config; iter; iter = next) { + struct nk_font_config *i, *n; + for (i = iter->n; i != iter; i = n) { + n = i->n; + if (i->ttf_blob) + atlas->permanent.free(atlas->permanent.userdata, i->ttf_blob); + atlas->permanent.free(atlas->permanent.userdata, i); + } + next = iter->next; + if (i->ttf_blob) + atlas->permanent.free(atlas->permanent.userdata, iter->ttf_blob); + atlas->permanent.free(atlas->permanent.userdata, iter); + } + atlas->config = 0; + } + if (atlas->fonts) { + struct nk_font *iter, *next; + for (iter = atlas->fonts; iter; iter = next) { + next = iter->next; + atlas->permanent.free(atlas->permanent.userdata, iter); + } + atlas->fonts = 0; + } + if (atlas->glyphs) + atlas->permanent.free(atlas->permanent.userdata, atlas->glyphs); + nk_zero_struct(*atlas); +} +#endif +/* ============================================================== + * + * INPUT + * + * ===============================================================*/ +NK_API void +nk_input_begin(struct nk_context *ctx) +{ + int i; + struct nk_input *in; + NK_ASSERT(ctx); + if (!ctx) return; + in = &ctx->input; + for (i = 0; i < NK_BUTTON_MAX; ++i) + in->mouse.buttons[i].clicked = 0; + + in->keyboard.text_len = 0; + in->mouse.scroll_delta = nk_vec2(0,0); + in->mouse.prev.x = in->mouse.pos.x; + in->mouse.prev.y = in->mouse.pos.y; + in->mouse.delta.x = 0; + in->mouse.delta.y = 0; + for (i = 0; i < NK_KEY_MAX; i++) + in->keyboard.keys[i].clicked = 0; +} + +NK_API void +nk_input_end(struct nk_context *ctx) +{ + struct nk_input *in; + NK_ASSERT(ctx); + if (!ctx) return; + in = &ctx->input; + if (in->mouse.grab) + in->mouse.grab = 0; + if (in->mouse.ungrab) { + in->mouse.grabbed = 0; + in->mouse.ungrab = 0; + in->mouse.grab = 0; + } +} + +NK_API void +nk_input_motion(struct nk_context *ctx, int x, int y) +{ + struct nk_input *in; + NK_ASSERT(ctx); + if (!ctx) return; + in = &ctx->input; + in->mouse.pos.x = (float)x; + in->mouse.pos.y = (float)y; + in->mouse.delta.x = in->mouse.pos.x - in->mouse.prev.x; + in->mouse.delta.y = in->mouse.pos.y - in->mouse.prev.y; +} + +NK_API void +nk_input_key(struct nk_context *ctx, enum nk_keys key, int down) +{ + struct nk_input *in; + NK_ASSERT(ctx); + if (!ctx) return; + in = &ctx->input; + if (in->keyboard.keys[key].down != down) + in->keyboard.keys[key].clicked++; + in->keyboard.keys[key].down = down; +} + +NK_API void +nk_input_button(struct nk_context *ctx, enum nk_buttons id, int x, int y, int down) +{ + struct nk_mouse_button *btn; + struct nk_input *in; + NK_ASSERT(ctx); + if (!ctx) return; + in = &ctx->input; + if (in->mouse.buttons[id].down == down) return; + + btn = &in->mouse.buttons[id]; + btn->clicked_pos.x = (float)x; + btn->clicked_pos.y = (float)y; + btn->down = down; + btn->clicked++; +} + +NK_API void +nk_input_scroll(struct nk_context *ctx, struct nk_vec2 val) +{ + NK_ASSERT(ctx); + if (!ctx) return; + ctx->input.mouse.scroll_delta.x += val.x; + ctx->input.mouse.scroll_delta.y += val.y; +} + +NK_API void +nk_input_glyph(struct nk_context *ctx, const nk_glyph glyph) +{ + int len = 0; + nk_rune unicode; + struct nk_input *in; + + NK_ASSERT(ctx); + if (!ctx) return; + in = &ctx->input; + + len = nk_utf_decode(glyph, &unicode, NK_UTF_SIZE); + if (len && ((in->keyboard.text_len + len) < NK_INPUT_MAX)) { + nk_utf_encode(unicode, &in->keyboard.text[in->keyboard.text_len], + NK_INPUT_MAX - in->keyboard.text_len); + in->keyboard.text_len += len; + } +} + +NK_API void +nk_input_char(struct nk_context *ctx, char c) +{ + nk_glyph glyph; + NK_ASSERT(ctx); + if (!ctx) return; + glyph[0] = c; + nk_input_glyph(ctx, glyph); +} + +NK_API void +nk_input_unicode(struct nk_context *ctx, nk_rune unicode) +{ + nk_glyph rune; + NK_ASSERT(ctx); + if (!ctx) return; + nk_utf_encode(unicode, rune, NK_UTF_SIZE); + nk_input_glyph(ctx, rune); +} + +NK_API int +nk_input_has_mouse_click(const struct nk_input *i, enum nk_buttons id) +{ + const struct nk_mouse_button *btn; + if (!i) return nk_false; + btn = &i->mouse.buttons[id]; + return (btn->clicked && btn->down == nk_false) ? nk_true : nk_false; +} + +NK_API int +nk_input_has_mouse_click_in_rect(const struct nk_input *i, enum nk_buttons id, + struct nk_rect b) +{ + const struct nk_mouse_button *btn; + if (!i) return nk_false; + btn = &i->mouse.buttons[id]; + if (!NK_INBOX(btn->clicked_pos.x,btn->clicked_pos.y,b.x,b.y,b.w,b.h)) + return nk_false; + return nk_true; +} + +NK_API int +nk_input_has_mouse_click_down_in_rect(const struct nk_input *i, enum nk_buttons id, + struct nk_rect b, int down) +{ + const struct nk_mouse_button *btn; + if (!i) return nk_false; + btn = &i->mouse.buttons[id]; + return nk_input_has_mouse_click_in_rect(i, id, b) && (btn->down == down); +} + +NK_API int +nk_input_is_mouse_click_in_rect(const struct nk_input *i, enum nk_buttons id, + struct nk_rect b) +{ + const struct nk_mouse_button *btn; + if (!i) return nk_false; + btn = &i->mouse.buttons[id]; + return (nk_input_has_mouse_click_down_in_rect(i, id, b, nk_false) && + btn->clicked) ? nk_true : nk_false; +} + +NK_API int +nk_input_is_mouse_click_down_in_rect(const struct nk_input *i, enum nk_buttons id, + struct nk_rect b, int down) +{ + const struct nk_mouse_button *btn; + if (!i) return nk_false; + btn = &i->mouse.buttons[id]; + return (nk_input_has_mouse_click_down_in_rect(i, id, b, down) && + btn->clicked) ? nk_true : nk_false; +} + +NK_API int +nk_input_any_mouse_click_in_rect(const struct nk_input *in, struct nk_rect b) +{ + int i, down = 0; + for (i = 0; i < NK_BUTTON_MAX; ++i) + down = down || nk_input_is_mouse_click_in_rect(in, (enum nk_buttons)i, b); + return down; +} + +NK_API int +nk_input_is_mouse_hovering_rect(const struct nk_input *i, struct nk_rect rect) +{ + if (!i) return nk_false; + return NK_INBOX(i->mouse.pos.x, i->mouse.pos.y, rect.x, rect.y, rect.w, rect.h); +} + +NK_API int +nk_input_is_mouse_prev_hovering_rect(const struct nk_input *i, struct nk_rect rect) +{ + if (!i) return nk_false; + return NK_INBOX(i->mouse.prev.x, i->mouse.prev.y, rect.x, rect.y, rect.w, rect.h); +} + +NK_API int +nk_input_mouse_clicked(const struct nk_input *i, enum nk_buttons id, struct nk_rect rect) +{ + if (!i) return nk_false; + if (!nk_input_is_mouse_hovering_rect(i, rect)) return nk_false; + return nk_input_is_mouse_click_in_rect(i, id, rect); +} + +NK_API int +nk_input_is_mouse_down(const struct nk_input *i, enum nk_buttons id) +{ + if (!i) return nk_false; + return i->mouse.buttons[id].down; +} + +NK_API int +nk_input_is_mouse_pressed(const struct nk_input *i, enum nk_buttons id) +{ + const struct nk_mouse_button *b; + if (!i) return nk_false; + b = &i->mouse.buttons[id]; + if (b->down && b->clicked) + return nk_true; + return nk_false; +} + +NK_API int +nk_input_is_mouse_released(const struct nk_input *i, enum nk_buttons id) +{ + if (!i) return nk_false; + return (!i->mouse.buttons[id].down && i->mouse.buttons[id].clicked); +} + +NK_API int +nk_input_is_key_pressed(const struct nk_input *i, enum nk_keys key) +{ + const struct nk_key *k; + if (!i) return nk_false; + k = &i->keyboard.keys[key]; + if ((k->down && k->clicked) || (!k->down && k->clicked >= 2)) + return nk_true; + return nk_false; +} + +NK_API int +nk_input_is_key_released(const struct nk_input *i, enum nk_keys key) +{ + const struct nk_key *k; + if (!i) return nk_false; + k = &i->keyboard.keys[key]; + if ((!k->down && k->clicked) || (k->down && k->clicked >= 2)) + return nk_true; + return nk_false; +} + +NK_API int +nk_input_is_key_down(const struct nk_input *i, enum nk_keys key) +{ + const struct nk_key *k; + if (!i) return nk_false; + k = &i->keyboard.keys[key]; + if (k->down) return nk_true; + return nk_false; +} + +/* + * ============================================================== + * + * TEXT EDITOR + * + * =============================================================== + */ +/* stb_textedit.h - v1.8 - public domain - Sean Barrett */ +struct nk_text_find { + float x,y; /* position of n'th character */ + float height; /* height of line */ + int first_char, length; /* first char of row, and length */ + int prev_first; /*_ first char of previous row */ +}; + +struct nk_text_edit_row { + float x0,x1; + /* starting x location, end x location (allows for align=right, etc) */ + float baseline_y_delta; + /* position of baseline relative to previous row's baseline*/ + float ymin,ymax; + /* height of row above and below baseline */ + int num_chars; +}; + +/* forward declarations */ +NK_INTERN void nk_textedit_makeundo_delete(struct nk_text_edit*, int, int); +NK_INTERN void nk_textedit_makeundo_insert(struct nk_text_edit*, int, int); +NK_INTERN void nk_textedit_makeundo_replace(struct nk_text_edit*, int, int, int); +#define NK_TEXT_HAS_SELECTION(s) ((s)->select_start != (s)->select_end) + +NK_INTERN float +nk_textedit_get_width(const struct nk_text_edit *edit, int line_start, int char_id, + const struct nk_user_font *font) +{ + int len = 0; + nk_rune unicode = 0; + const char *str = nk_str_at_const(&edit->string, line_start + char_id, &unicode, &len); + return font->width(font->userdata, font->height, str, len); +} + +NK_INTERN void +nk_textedit_layout_row(struct nk_text_edit_row *r, struct nk_text_edit *edit, + int line_start_id, float row_height, const struct nk_user_font *font) +{ + int l; + int glyphs = 0; + nk_rune unicode; + const char *remaining; + int len = nk_str_len_char(&edit->string); + const char *end = nk_str_get_const(&edit->string) + len; + const char *text = nk_str_at_const(&edit->string, line_start_id, &unicode, &l); + const struct nk_vec2 size = nk_text_calculate_text_bounds(font, + text, (int)(end - text), row_height, &remaining, 0, &glyphs, NK_STOP_ON_NEW_LINE); + + r->x0 = 0.0f; + r->x1 = size.x; + r->baseline_y_delta = size.y; + r->ymin = 0.0f; + r->ymax = size.y; + r->num_chars = glyphs; +} + +NK_INTERN int +nk_textedit_locate_coord(struct nk_text_edit *edit, float x, float y, + const struct nk_user_font *font, float row_height) +{ + struct nk_text_edit_row r; + int n = edit->string.len; + float base_y = 0, prev_x; + int i=0, k; + + r.x0 = r.x1 = 0; + r.ymin = r.ymax = 0; + r.num_chars = 0; + + /* search rows to find one that straddles 'y' */ + while (i < n) { + nk_textedit_layout_row(&r, edit, i, row_height, font); + if (r.num_chars <= 0) + return n; + + if (i==0 && y < base_y + r.ymin) + return 0; + + if (y < base_y + r.ymax) + break; + + i += r.num_chars; + base_y += r.baseline_y_delta; + } + + /* below all text, return 'after' last character */ + if (i >= n) + return n; + + /* check if it's before the beginning of the line */ + if (x < r.x0) + return i; + + /* check if it's before the end of the line */ + if (x < r.x1) { + /* search characters in row for one that straddles 'x' */ + k = i; + prev_x = r.x0; + for (i=0; i < r.num_chars; ++i) { + float w = nk_textedit_get_width(edit, k, i, font); + if (x < prev_x+w) { + if (x < prev_x+w/2) + return k+i; + else return k+i+1; + } + prev_x += w; + } + /* shouldn't happen, but if it does, fall through to end-of-line case */ + } + + /* if the last character is a newline, return that. + * otherwise return 'after' the last character */ + if (nk_str_rune_at(&edit->string, i+r.num_chars-1) == '\n') + return i+r.num_chars-1; + else return i+r.num_chars; +} + +NK_INTERN void +nk_textedit_click(struct nk_text_edit *state, float x, float y, + const struct nk_user_font *font, float row_height) +{ + /* API click: on mouse down, move the cursor to the clicked location, + * and reset the selection */ + state->cursor = nk_textedit_locate_coord(state, x, y, font, row_height); + state->select_start = state->cursor; + state->select_end = state->cursor; + state->has_preferred_x = 0; +} + +NK_INTERN void +nk_textedit_drag(struct nk_text_edit *state, float x, float y, + const struct nk_user_font *font, float row_height) +{ + /* API drag: on mouse drag, move the cursor and selection endpoint + * to the clicked location */ + int p = nk_textedit_locate_coord(state, x, y, font, row_height); + if (state->select_start == state->select_end) + state->select_start = state->cursor; + state->cursor = state->select_end = p; +} + +NK_INTERN void +nk_textedit_find_charpos(struct nk_text_find *find, struct nk_text_edit *state, + int n, int single_line, const struct nk_user_font *font, float row_height) +{ + /* find the x/y location of a character, and remember info about the previous + * row in case we get a move-up event (for page up, we'll have to rescan) */ + struct nk_text_edit_row r; + int prev_start = 0; + int z = state->string.len; + int i=0, first; + + nk_zero_struct(r); + if (n == z) { + /* if it's at the end, then find the last line -- simpler than trying to + explicitly handle this case in the regular code */ + nk_textedit_layout_row(&r, state, 0, row_height, font); + if (single_line) { + find->first_char = 0; + find->length = z; + } else { + while (i < z) { + prev_start = i; + i += r.num_chars; + nk_textedit_layout_row(&r, state, i, row_height, font); + } + + find->first_char = i; + find->length = r.num_chars; + } + find->x = r.x1; + find->y = r.ymin; + find->height = r.ymax - r.ymin; + find->prev_first = prev_start; + return; + } + + /* search rows to find the one that straddles character n */ + find->y = 0; + + for(;;) { + nk_textedit_layout_row(&r, state, i, row_height, font); + if (n < i + r.num_chars) break; + prev_start = i; + i += r.num_chars; + find->y += r.baseline_y_delta; + } + + find->first_char = first = i; + find->length = r.num_chars; + find->height = r.ymax - r.ymin; + find->prev_first = prev_start; + + /* now scan to find xpos */ + find->x = r.x0; + for (i=0; first+i < n; ++i) + find->x += nk_textedit_get_width(state, first, i, font); +} + +NK_INTERN void +nk_textedit_clamp(struct nk_text_edit *state) +{ + /* make the selection/cursor state valid if client altered the string */ + int n = state->string.len; + if (NK_TEXT_HAS_SELECTION(state)) { + if (state->select_start > n) state->select_start = n; + if (state->select_end > n) state->select_end = n; + /* if clamping forced them to be equal, move the cursor to match */ + if (state->select_start == state->select_end) + state->cursor = state->select_start; + } + if (state->cursor > n) state->cursor = n; +} + +NK_API void +nk_textedit_delete(struct nk_text_edit *state, int where, int len) +{ + /* delete characters while updating undo */ + nk_textedit_makeundo_delete(state, where, len); + nk_str_delete_runes(&state->string, where, len); + state->has_preferred_x = 0; +} + +NK_API void +nk_textedit_delete_selection(struct nk_text_edit *state) +{ + /* delete the section */ + nk_textedit_clamp(state); + if (NK_TEXT_HAS_SELECTION(state)) { + if (state->select_start < state->select_end) { + nk_textedit_delete(state, state->select_start, + state->select_end - state->select_start); + state->select_end = state->cursor = state->select_start; + } else { + nk_textedit_delete(state, state->select_end, + state->select_start - state->select_end); + state->select_start = state->cursor = state->select_end; + } + state->has_preferred_x = 0; + } +} + +NK_INTERN void +nk_textedit_sortselection(struct nk_text_edit *state) +{ + /* canonicalize the selection so start <= end */ + if (state->select_end < state->select_start) { + int temp = state->select_end; + state->select_end = state->select_start; + state->select_start = temp; + } +} + +NK_INTERN void +nk_textedit_move_to_first(struct nk_text_edit *state) +{ + /* move cursor to first character of selection */ + if (NK_TEXT_HAS_SELECTION(state)) { + nk_textedit_sortselection(state); + state->cursor = state->select_start; + state->select_end = state->select_start; + state->has_preferred_x = 0; + } +} + +NK_INTERN void +nk_textedit_move_to_last(struct nk_text_edit *state) +{ + /* move cursor to last character of selection */ + if (NK_TEXT_HAS_SELECTION(state)) { + nk_textedit_sortselection(state); + nk_textedit_clamp(state); + state->cursor = state->select_end; + state->select_start = state->select_end; + state->has_preferred_x = 0; + } +} + +NK_INTERN int +nk_is_word_boundary( struct nk_text_edit *state, int idx) +{ + int len; + nk_rune c; + if (idx <= 0) return 1; + if (!nk_str_at_rune(&state->string, idx, &c, &len)) return 1; + return (c == ' ' || c == '\t' ||c == 0x3000 || c == ',' || c == ';' || + c == '(' || c == ')' || c == '{' || c == '}' || c == '[' || c == ']' || + c == '|'); +} + +NK_INTERN int +nk_textedit_move_to_word_previous(struct nk_text_edit *state) +{ + int c = state->cursor - 1; + while( c >= 0 && !nk_is_word_boundary(state, c)) + --c; + + if( c < 0 ) + c = 0; + + return c; +} + +NK_INTERN int +nk_textedit_move_to_word_next(struct nk_text_edit *state) +{ + const int len = state->string.len; + int c = state->cursor+1; + while( c < len && !nk_is_word_boundary(state, c)) + ++c; + + if( c > len ) + c = len; + + return c; +} + +NK_INTERN void +nk_textedit_prep_selection_at_cursor(struct nk_text_edit *state) +{ + /* update selection and cursor to match each other */ + if (!NK_TEXT_HAS_SELECTION(state)) + state->select_start = state->select_end = state->cursor; + else state->cursor = state->select_end; +} + +NK_API int +nk_textedit_cut(struct nk_text_edit *state) +{ + /* API cut: delete selection */ + if (state->mode == NK_TEXT_EDIT_MODE_VIEW) + return 0; + if (NK_TEXT_HAS_SELECTION(state)) { + nk_textedit_delete_selection(state); /* implicitly clamps */ + state->has_preferred_x = 0; + return 1; + } + return 0; +} + +NK_API int +nk_textedit_paste(struct nk_text_edit *state, char const *ctext, int len) +{ + /* API paste: replace existing selection with passed-in text */ + int glyphs; + const char *text = (const char *) ctext; + if (state->mode == NK_TEXT_EDIT_MODE_VIEW) return 0; + + /* if there's a selection, the paste should delete it */ + nk_textedit_clamp(state); + nk_textedit_delete_selection(state); + + /* try to insert the characters */ + glyphs = nk_utf_len(ctext, len); + if (nk_str_insert_text_char(&state->string, state->cursor, text, len)) { + nk_textedit_makeundo_insert(state, state->cursor, glyphs); + state->cursor += len; + state->has_preferred_x = 0; + return 1; + } + /* remove the undo since we didn't actually insert the characters */ + if (state->undo.undo_point) + --state->undo.undo_point; + return 0; +} + +NK_API void +nk_textedit_text(struct nk_text_edit *state, const char *text, int total_len) +{ + nk_rune unicode; + int glyph_len; + int text_len = 0; + + NK_ASSERT(state); + NK_ASSERT(text); + if (!text || !total_len || state->mode == NK_TEXT_EDIT_MODE_VIEW) return; + + glyph_len = nk_utf_decode(text, &unicode, total_len); + while ((text_len < total_len) && glyph_len) + { + /* don't insert a backward delete, just process the event */ + if (unicode == 127) goto next; + /* can't add newline in single-line mode */ + if (unicode == '\n' && state->single_line) goto next; + /* filter incoming text */ + if (state->filter && !state->filter(state, unicode)) goto next; + + if (!NK_TEXT_HAS_SELECTION(state) && + state->cursor < state->string.len) + { + if (state->mode == NK_TEXT_EDIT_MODE_REPLACE) { + nk_textedit_makeundo_replace(state, state->cursor, 1, 1); + nk_str_delete_runes(&state->string, state->cursor, 1); + } + if (nk_str_insert_text_utf8(&state->string, state->cursor, + text+text_len, 1)) + { + ++state->cursor; + state->has_preferred_x = 0; + } + } else { + nk_textedit_delete_selection(state); /* implicitly clamps */ + if (nk_str_insert_text_utf8(&state->string, state->cursor, + text+text_len, 1)) + { + nk_textedit_makeundo_insert(state, state->cursor, 1); + ++state->cursor; + state->has_preferred_x = 0; + } + } + next: + text_len += glyph_len; + glyph_len = nk_utf_decode(text + text_len, &unicode, total_len-text_len); + } +} + +NK_INTERN void +nk_textedit_key(struct nk_text_edit *state, enum nk_keys key, int shift_mod, + const struct nk_user_font *font, float row_height) +{ +retry: + switch (key) + { + case NK_KEY_NONE: + case NK_KEY_CTRL: + case NK_KEY_ENTER: + case NK_KEY_SHIFT: + case NK_KEY_TAB: + case NK_KEY_COPY: + case NK_KEY_CUT: + case NK_KEY_PASTE: + case NK_KEY_MAX: + default: break; + case NK_KEY_TEXT_UNDO: + nk_textedit_undo(state); + state->has_preferred_x = 0; + break; + + case NK_KEY_TEXT_REDO: + nk_textedit_redo(state); + state->has_preferred_x = 0; + break; + + case NK_KEY_TEXT_SELECT_ALL: + nk_textedit_select_all(state); + state->has_preferred_x = 0; + break; + + case NK_KEY_TEXT_INSERT_MODE: + if (state->mode == NK_TEXT_EDIT_MODE_VIEW) + state->mode = NK_TEXT_EDIT_MODE_INSERT; + break; + case NK_KEY_TEXT_REPLACE_MODE: + if (state->mode == NK_TEXT_EDIT_MODE_VIEW) + state->mode = NK_TEXT_EDIT_MODE_REPLACE; + break; + case NK_KEY_TEXT_RESET_MODE: + if (state->mode == NK_TEXT_EDIT_MODE_INSERT || + state->mode == NK_TEXT_EDIT_MODE_REPLACE) + state->mode = NK_TEXT_EDIT_MODE_VIEW; + break; + + case NK_KEY_LEFT: + if (shift_mod) { + nk_textedit_clamp(state); + nk_textedit_prep_selection_at_cursor(state); + /* move selection left */ + if (state->select_end > 0) + --state->select_end; + state->cursor = state->select_end; + state->has_preferred_x = 0; + } else { + /* if currently there's a selection, + * move cursor to start of selection */ + if (NK_TEXT_HAS_SELECTION(state)) + nk_textedit_move_to_first(state); + else if (state->cursor > 0) + --state->cursor; + state->has_preferred_x = 0; + } break; + + case NK_KEY_RIGHT: + if (shift_mod) { + nk_textedit_prep_selection_at_cursor(state); + /* move selection right */ + ++state->select_end; + nk_textedit_clamp(state); + state->cursor = state->select_end; + state->has_preferred_x = 0; + } else { + /* if currently there's a selection, + * move cursor to end of selection */ + if (NK_TEXT_HAS_SELECTION(state)) + nk_textedit_move_to_last(state); + else ++state->cursor; + nk_textedit_clamp(state); + state->has_preferred_x = 0; + } break; + + case NK_KEY_TEXT_WORD_LEFT: + if (shift_mod) { + if( !NK_TEXT_HAS_SELECTION( state ) ) + nk_textedit_prep_selection_at_cursor(state); + state->cursor = nk_textedit_move_to_word_previous(state); + state->select_end = state->cursor; + nk_textedit_clamp(state ); + } else { + if (NK_TEXT_HAS_SELECTION(state)) + nk_textedit_move_to_first(state); + else { + state->cursor = nk_textedit_move_to_word_previous(state); + nk_textedit_clamp(state ); + } + } break; + + case NK_KEY_TEXT_WORD_RIGHT: + if (shift_mod) { + if( !NK_TEXT_HAS_SELECTION( state ) ) + nk_textedit_prep_selection_at_cursor(state); + state->cursor = nk_textedit_move_to_word_next(state); + state->select_end = state->cursor; + nk_textedit_clamp(state); + } else { + if (NK_TEXT_HAS_SELECTION(state)) + nk_textedit_move_to_last(state); + else { + state->cursor = nk_textedit_move_to_word_next(state); + nk_textedit_clamp(state ); + } + } break; + + case NK_KEY_DOWN: { + struct nk_text_find find; + struct nk_text_edit_row row; + int i, sel = shift_mod; + + if (state->single_line) { + /* on windows, up&down in single-line behave like left&right */ + key = NK_KEY_RIGHT; + goto retry; + } + + if (sel) + nk_textedit_prep_selection_at_cursor(state); + else if (NK_TEXT_HAS_SELECTION(state)) + nk_textedit_move_to_last(state); + + /* compute current position of cursor point */ + nk_textedit_clamp(state); + nk_textedit_find_charpos(&find, state, state->cursor, state->single_line, + font, row_height); + + /* now find character position down a row */ + if (find.length) + { + float x; + float goal_x = state->has_preferred_x ? state->preferred_x : find.x; + int start = find.first_char + find.length; + + state->cursor = start; + nk_textedit_layout_row(&row, state, state->cursor, row_height, font); + x = row.x0; + + for (i=0; i < row.num_chars && x < row.x1; ++i) { + float dx = nk_textedit_get_width(state, start, i, font); + x += dx; + if (x > goal_x) + break; + ++state->cursor; + } + nk_textedit_clamp(state); + + state->has_preferred_x = 1; + state->preferred_x = goal_x; + if (sel) + state->select_end = state->cursor; + } + } break; + + case NK_KEY_UP: { + struct nk_text_find find; + struct nk_text_edit_row row; + int i, sel = shift_mod; + + if (state->single_line) { + /* on windows, up&down become left&right */ + key = NK_KEY_LEFT; + goto retry; + } + + if (sel) + nk_textedit_prep_selection_at_cursor(state); + else if (NK_TEXT_HAS_SELECTION(state)) + nk_textedit_move_to_first(state); + + /* compute current position of cursor point */ + nk_textedit_clamp(state); + nk_textedit_find_charpos(&find, state, state->cursor, state->single_line, + font, row_height); + + /* can only go up if there's a previous row */ + if (find.prev_first != find.first_char) { + /* now find character position up a row */ + float x; + float goal_x = state->has_preferred_x ? state->preferred_x : find.x; + + state->cursor = find.prev_first; + nk_textedit_layout_row(&row, state, state->cursor, row_height, font); + x = row.x0; + + for (i=0; i < row.num_chars && x < row.x1; ++i) { + float dx = nk_textedit_get_width(state, find.prev_first, i, font); + x += dx; + if (x > goal_x) + break; + ++state->cursor; + } + nk_textedit_clamp(state); + + state->has_preferred_x = 1; + state->preferred_x = goal_x; + if (sel) state->select_end = state->cursor; + } + } break; + + case NK_KEY_DEL: + if (state->mode == NK_TEXT_EDIT_MODE_VIEW) + break; + if (NK_TEXT_HAS_SELECTION(state)) + nk_textedit_delete_selection(state); + else { + int n = state->string.len; + if (state->cursor < n) + nk_textedit_delete(state, state->cursor, 1); + } + state->has_preferred_x = 0; + break; + + case NK_KEY_BACKSPACE: + if (state->mode == NK_TEXT_EDIT_MODE_VIEW) + break; + if (NK_TEXT_HAS_SELECTION(state)) + nk_textedit_delete_selection(state); + else { + nk_textedit_clamp(state); + if (state->cursor > 0) { + nk_textedit_delete(state, state->cursor-1, 1); + --state->cursor; + } + } + state->has_preferred_x = 0; + break; + + case NK_KEY_TEXT_START: + if (shift_mod) { + nk_textedit_prep_selection_at_cursor(state); + state->cursor = state->select_end = 0; + state->has_preferred_x = 0; + } else { + state->cursor = state->select_start = state->select_end = 0; + state->has_preferred_x = 0; + } + break; + + case NK_KEY_TEXT_END: + if (shift_mod) { + nk_textedit_prep_selection_at_cursor(state); + state->cursor = state->select_end = state->string.len; + state->has_preferred_x = 0; + } else { + state->cursor = state->string.len; + state->select_start = state->select_end = 0; + state->has_preferred_x = 0; + } + break; + + case NK_KEY_TEXT_LINE_START: { + if (shift_mod) { + struct nk_text_find find; + nk_textedit_clamp(state); + nk_textedit_prep_selection_at_cursor(state); + if (state->string.len && state->cursor == state->string.len) + --state->cursor; + nk_textedit_find_charpos(&find, state,state->cursor, state->single_line, + font, row_height); + state->cursor = state->select_end = find.first_char; + state->has_preferred_x = 0; + } else { + struct nk_text_find find; + if (state->string.len && state->cursor == state->string.len) + --state->cursor; + nk_textedit_clamp(state); + nk_textedit_move_to_first(state); + nk_textedit_find_charpos(&find, state, state->cursor, state->single_line, + font, row_height); + state->cursor = find.first_char; + state->has_preferred_x = 0; + } + } break; + + case NK_KEY_TEXT_LINE_END: { + if (shift_mod) { + struct nk_text_find find; + nk_textedit_clamp(state); + nk_textedit_prep_selection_at_cursor(state); + nk_textedit_find_charpos(&find, state, state->cursor, state->single_line, + font, row_height); + state->has_preferred_x = 0; + state->cursor = find.first_char + find.length; + if (find.length > 0 && nk_str_rune_at(&state->string, state->cursor-1) == '\n') + --state->cursor; + state->select_end = state->cursor; + } else { + struct nk_text_find find; + nk_textedit_clamp(state); + nk_textedit_move_to_first(state); + nk_textedit_find_charpos(&find, state, state->cursor, state->single_line, + font, row_height); + + state->has_preferred_x = 0; + state->cursor = find.first_char + find.length; + if (find.length > 0 && nk_str_rune_at(&state->string, state->cursor-1) == '\n') + --state->cursor; + }} break; + } +} + +NK_INTERN void +nk_textedit_flush_redo(struct nk_text_undo_state *state) +{ + state->redo_point = NK_TEXTEDIT_UNDOSTATECOUNT; + state->redo_char_point = NK_TEXTEDIT_UNDOCHARCOUNT; +} + +NK_INTERN void +nk_textedit_discard_undo(struct nk_text_undo_state *state) +{ + /* discard the oldest entry in the undo list */ + if (state->undo_point > 0) { + /* if the 0th undo state has characters, clean those up */ + if (state->undo_rec[0].char_storage >= 0) { + int n = state->undo_rec[0].insert_length, i; + /* delete n characters from all other records */ + state->undo_char_point = (short)(state->undo_char_point - n); + NK_MEMCPY(state->undo_char, state->undo_char + n, + (nk_size)state->undo_char_point*sizeof(nk_rune)); + for (i=0; i < state->undo_point; ++i) { + if (state->undo_rec[i].char_storage >= 0) + state->undo_rec[i].char_storage = (short) + (state->undo_rec[i].char_storage - n); + } + } + --state->undo_point; + NK_MEMCPY(state->undo_rec, state->undo_rec+1, + (nk_size)((nk_size)state->undo_point * sizeof(state->undo_rec[0]))); + } +} + +NK_INTERN void +nk_textedit_discard_redo(struct nk_text_undo_state *state) +{ +/* discard the oldest entry in the redo list--it's bad if this + ever happens, but because undo & redo have to store the actual + characters in different cases, the redo character buffer can + fill up even though the undo buffer didn't */ + nk_size num; + int k = NK_TEXTEDIT_UNDOSTATECOUNT-1; + if (state->redo_point <= k) { + /* if the k'th undo state has characters, clean those up */ + if (state->undo_rec[k].char_storage >= 0) { + int n = state->undo_rec[k].insert_length, i; + /* delete n characters from all other records */ + state->redo_char_point = (short)(state->redo_char_point + n); + num = (nk_size)(NK_TEXTEDIT_UNDOCHARCOUNT - state->redo_char_point); + NK_MEMCPY(state->undo_char + state->redo_char_point, + state->undo_char + state->redo_char_point-n, num * sizeof(char)); + for (i = state->redo_point; i < k; ++i) { + if (state->undo_rec[i].char_storage >= 0) { + state->undo_rec[i].char_storage = (short) + (state->undo_rec[i].char_storage + n); + } + } + } + ++state->redo_point; + num = (nk_size)(NK_TEXTEDIT_UNDOSTATECOUNT - state->redo_point); + if (num) NK_MEMCPY(state->undo_rec + state->redo_point-1, + state->undo_rec + state->redo_point, num * sizeof(state->undo_rec[0])); + } +} + +NK_INTERN struct nk_text_undo_record* +nk_textedit_create_undo_record(struct nk_text_undo_state *state, int numchars) +{ + /* any time we create a new undo record, we discard redo*/ + nk_textedit_flush_redo(state); + + /* if we have no free records, we have to make room, + * by sliding the existing records down */ + if (state->undo_point == NK_TEXTEDIT_UNDOSTATECOUNT) + nk_textedit_discard_undo(state); + + /* if the characters to store won't possibly fit in the buffer, + * we can't undo */ + if (numchars > NK_TEXTEDIT_UNDOCHARCOUNT) { + state->undo_point = 0; + state->undo_char_point = 0; + return 0; + } + + /* if we don't have enough free characters in the buffer, + * we have to make room */ + while (state->undo_char_point + numchars > NK_TEXTEDIT_UNDOCHARCOUNT) + nk_textedit_discard_undo(state); + return &state->undo_rec[state->undo_point++]; +} + +NK_INTERN nk_rune* +nk_textedit_createundo(struct nk_text_undo_state *state, int pos, + int insert_len, int delete_len) +{ + struct nk_text_undo_record *r = nk_textedit_create_undo_record(state, insert_len); + if (r == 0) + return 0; + + r->where = pos; + r->insert_length = (short) insert_len; + r->delete_length = (short) delete_len; + + if (insert_len == 0) { + r->char_storage = -1; + return 0; + } else { + r->char_storage = state->undo_char_point; + state->undo_char_point = (short)(state->undo_char_point + insert_len); + return &state->undo_char[r->char_storage]; + } +} + +NK_API void +nk_textedit_undo(struct nk_text_edit *state) +{ + struct nk_text_undo_state *s = &state->undo; + struct nk_text_undo_record u, *r; + if (s->undo_point == 0) + return; + + /* we need to do two things: apply the undo record, and create a redo record */ + u = s->undo_rec[s->undo_point-1]; + r = &s->undo_rec[s->redo_point-1]; + r->char_storage = -1; + + r->insert_length = u.delete_length; + r->delete_length = u.insert_length; + r->where = u.where; + + if (u.delete_length) + { + /* if the undo record says to delete characters, then the redo record will + need to re-insert the characters that get deleted, so we need to store + them. + there are three cases: + - there's enough room to store the characters + - characters stored for *redoing* don't leave room for redo + - characters stored for *undoing* don't leave room for redo + if the last is true, we have to bail */ + if (s->undo_char_point + u.delete_length >= NK_TEXTEDIT_UNDOCHARCOUNT) { + /* the undo records take up too much character space; there's no space + * to store the redo characters */ + r->insert_length = 0; + } else { + int i; + /* there's definitely room to store the characters eventually */ + while (s->undo_char_point + u.delete_length > s->redo_char_point) { + /* there's currently not enough room, so discard a redo record */ + nk_textedit_discard_redo(s); + /* should never happen: */ + if (s->redo_point == NK_TEXTEDIT_UNDOSTATECOUNT) + return; + } + + r = &s->undo_rec[s->redo_point-1]; + r->char_storage = (short)(s->redo_char_point - u.delete_length); + s->redo_char_point = (short)(s->redo_char_point - u.delete_length); + + /* now save the characters */ + for (i=0; i < u.delete_length; ++i) + s->undo_char[r->char_storage + i] = + nk_str_rune_at(&state->string, u.where + i); + } + /* now we can carry out the deletion */ + nk_str_delete_runes(&state->string, u.where, u.delete_length); + } + + /* check type of recorded action: */ + if (u.insert_length) { + /* easy case: was a deletion, so we need to insert n characters */ + nk_str_insert_text_runes(&state->string, u.where, + &s->undo_char[u.char_storage], u.insert_length); + s->undo_char_point = (short)(s->undo_char_point - u.insert_length); + } + state->cursor = (short)(u.where + u.insert_length); + + s->undo_point--; + s->redo_point--; +} + +NK_API void +nk_textedit_redo(struct nk_text_edit *state) +{ + struct nk_text_undo_state *s = &state->undo; + struct nk_text_undo_record *u, r; + if (s->redo_point == NK_TEXTEDIT_UNDOSTATECOUNT) + return; + + /* we need to do two things: apply the redo record, and create an undo record */ + u = &s->undo_rec[s->undo_point]; + r = s->undo_rec[s->redo_point]; + + /* we KNOW there must be room for the undo record, because the redo record + was derived from an undo record */ + u->delete_length = r.insert_length; + u->insert_length = r.delete_length; + u->where = r.where; + u->char_storage = -1; + + if (r.delete_length) { + /* the redo record requires us to delete characters, so the undo record + needs to store the characters */ + if (s->undo_char_point + u->insert_length > s->redo_char_point) { + u->insert_length = 0; + u->delete_length = 0; + } else { + int i; + u->char_storage = s->undo_char_point; + s->undo_char_point = (short)(s->undo_char_point + u->insert_length); + + /* now save the characters */ + for (i=0; i < u->insert_length; ++i) { + s->undo_char[u->char_storage + i] = + nk_str_rune_at(&state->string, u->where + i); + } + } + nk_str_delete_runes(&state->string, r.where, r.delete_length); + } + + if (r.insert_length) { + /* easy case: need to insert n characters */ + nk_str_insert_text_runes(&state->string, r.where, + &s->undo_char[r.char_storage], r.insert_length); + } + state->cursor = r.where + r.insert_length; + + s->undo_point++; + s->redo_point++; +} + +NK_INTERN void +nk_textedit_makeundo_insert(struct nk_text_edit *state, int where, int length) +{ + nk_textedit_createundo(&state->undo, where, 0, length); +} + +NK_INTERN void +nk_textedit_makeundo_delete(struct nk_text_edit *state, int where, int length) +{ + int i; + nk_rune *p = nk_textedit_createundo(&state->undo, where, length, 0); + if (p) { + for (i=0; i < length; ++i) + p[i] = nk_str_rune_at(&state->string, where+i); + } +} + +NK_INTERN void +nk_textedit_makeundo_replace(struct nk_text_edit *state, int where, + int old_length, int new_length) +{ + int i; + nk_rune *p = nk_textedit_createundo(&state->undo, where, old_length, new_length); + if (p) { + for (i=0; i < old_length; ++i) + p[i] = nk_str_rune_at(&state->string, where+i); + } +} + +NK_INTERN void +nk_textedit_clear_state(struct nk_text_edit *state, enum nk_text_edit_type type, + nk_plugin_filter filter) +{ + /* reset the state to default */ + state->undo.undo_point = 0; + state->undo.undo_char_point = 0; + state->undo.redo_point = NK_TEXTEDIT_UNDOSTATECOUNT; + state->undo.redo_char_point = NK_TEXTEDIT_UNDOCHARCOUNT; + state->select_end = state->select_start = 0; + state->cursor = 0; + state->has_preferred_x = 0; + state->preferred_x = 0; + state->cursor_at_end_of_line = 0; + state->initialized = 1; + state->single_line = (unsigned char)(type == NK_TEXT_EDIT_SINGLE_LINE); + state->mode = NK_TEXT_EDIT_MODE_VIEW; + state->filter = filter; + state->scrollbar = nk_vec2(0,0); +} + +NK_API void +nk_textedit_init_fixed(struct nk_text_edit *state, void *memory, nk_size size) +{ + NK_ASSERT(state); + NK_ASSERT(memory); + if (!state || !memory || !size) return; + NK_MEMSET(state, 0, sizeof(struct nk_text_edit)); + nk_textedit_clear_state(state, NK_TEXT_EDIT_SINGLE_LINE, 0); + nk_str_init_fixed(&state->string, memory, size); +} + +NK_API void +nk_textedit_init(struct nk_text_edit *state, struct nk_allocator *alloc, nk_size size) +{ + NK_ASSERT(state); + NK_ASSERT(alloc); + if (!state || !alloc) return; + NK_MEMSET(state, 0, sizeof(struct nk_text_edit)); + nk_textedit_clear_state(state, NK_TEXT_EDIT_SINGLE_LINE, 0); + nk_str_init(&state->string, alloc, size); +} + +#ifdef NK_INCLUDE_DEFAULT_ALLOCATOR +NK_API void +nk_textedit_init_default(struct nk_text_edit *state) +{ + NK_ASSERT(state); + if (!state) return; + NK_MEMSET(state, 0, sizeof(struct nk_text_edit)); + nk_textedit_clear_state(state, NK_TEXT_EDIT_SINGLE_LINE, 0); + nk_str_init_default(&state->string); +} +#endif + +NK_API void +nk_textedit_select_all(struct nk_text_edit *state) +{ + NK_ASSERT(state); + state->select_start = 0; + state->select_end = state->string.len; +} + +NK_API void +nk_textedit_free(struct nk_text_edit *state) +{ + NK_ASSERT(state); + if (!state) return; + nk_str_free(&state->string); +} + +/* =============================================================== + * + * TEXT WIDGET + * + * ===============================================================*/ +#define nk_widget_state_reset(s)\ + if ((*(s)) & NK_WIDGET_STATE_MODIFIED)\ + (*(s)) = NK_WIDGET_STATE_INACTIVE|NK_WIDGET_STATE_MODIFIED;\ + else (*(s)) = NK_WIDGET_STATE_INACTIVE; + +struct nk_text { + struct nk_vec2 padding; + struct nk_color background; + struct nk_color text; +}; + +NK_INTERN void +nk_widget_text(struct nk_command_buffer *o, struct nk_rect b, + const char *string, int len, const struct nk_text *t, + nk_flags a, const struct nk_user_font *f) +{ + struct nk_rect label; + float text_width; + + NK_ASSERT(o); + NK_ASSERT(t); + if (!o || !t) return; + + b.h = NK_MAX(b.h, 2 * t->padding.y); + label.x = 0; label.w = 0; + label.y = b.y + t->padding.y; + label.h = NK_MIN(f->height, b.h - 2 * t->padding.y); + + text_width = f->width(f->userdata, f->height, (const char*)string, len); + text_width += (2.0f * t->padding.x); + + /* align in x-axis */ + if (a & NK_TEXT_ALIGN_LEFT) { + label.x = b.x + t->padding.x; + label.w = NK_MAX(0, b.w - 2 * t->padding.x); + } else if (a & NK_TEXT_ALIGN_CENTERED) { + label.w = NK_MAX(1, 2 * t->padding.x + (float)text_width); + label.x = (b.x + t->padding.x + ((b.w - 2 * t->padding.x) - label.w) / 2); + label.x = NK_MAX(b.x + t->padding.x, label.x); + label.w = NK_MIN(b.x + b.w, label.x + label.w); + if (label.w >= label.x) label.w -= label.x; + } else if (a & NK_TEXT_ALIGN_RIGHT) { + label.x = NK_MAX(b.x + t->padding.x, (b.x + b.w) - (2 * t->padding.x + (float)text_width)); + label.w = (float)text_width + 2 * t->padding.x; + } else return; + + /* align in y-axis */ + if (a & NK_TEXT_ALIGN_MIDDLE) { + label.y = b.y + b.h/2.0f - (float)f->height/2.0f; + label.h = NK_MAX(b.h/2.0f, b.h - (b.h/2.0f + f->height/2.0f)); + } else if (a & NK_TEXT_ALIGN_BOTTOM) { + label.y = b.y + b.h - f->height; + label.h = f->height; + } + nk_draw_text(o, label, (const char*)string, + len, f, t->background, t->text); +} + +NK_INTERN void +nk_widget_text_wrap(struct nk_command_buffer *o, struct nk_rect b, + const char *string, int len, const struct nk_text *t, + const struct nk_user_font *f) +{ + float width; + int glyphs = 0; + int fitting = 0; + int done = 0; + struct nk_rect line; + struct nk_text text; + NK_INTERN nk_rune seperator[] = {' '}; + + NK_ASSERT(o); + NK_ASSERT(t); + if (!o || !t) return; + + text.padding = nk_vec2(0,0); + text.background = t->background; + text.text = t->text; + + b.w = NK_MAX(b.w, 2 * t->padding.x); + b.h = NK_MAX(b.h, 2 * t->padding.y); + b.h = b.h - 2 * t->padding.y; + + line.x = b.x + t->padding.x; + line.y = b.y + t->padding.y; + line.w = b.w - 2 * t->padding.x; + line.h = 2 * t->padding.y + f->height; + + fitting = nk_text_clamp(f, string, len, line.w, &glyphs, &width, seperator,NK_LEN(seperator)); + while (done < len) { + if (!fitting || line.y + line.h >= (b.y + b.h)) break; + nk_widget_text(o, line, &string[done], fitting, &text, NK_TEXT_LEFT, f); + done += fitting; + line.y += f->height + 2 * t->padding.y; + fitting = nk_text_clamp(f, &string[done], len - done, line.w, &glyphs, &width, seperator,NK_LEN(seperator)); + } +} + +/* =============================================================== + * + * BUTTON + * + * ===============================================================*/ +NK_INTERN void +nk_draw_symbol(struct nk_command_buffer *out, enum nk_symbol_type type, + struct nk_rect content, struct nk_color background, struct nk_color foreground, + float border_width, const struct nk_user_font *font) +{ + switch (type) { + case NK_SYMBOL_X: + case NK_SYMBOL_UNDERSCORE: + case NK_SYMBOL_PLUS: + case NK_SYMBOL_MINUS: { + /* single character text symbol */ + const char *X = (type == NK_SYMBOL_X) ? "x": + (type == NK_SYMBOL_UNDERSCORE) ? "_": + (type == NK_SYMBOL_PLUS) ? "+": "-"; + struct nk_text text; + text.padding = nk_vec2(0,0); + text.background = background; + text.text = foreground; + nk_widget_text(out, content, X, 1, &text, NK_TEXT_CENTERED, font); + } break; + case NK_SYMBOL_CIRCLE_SOLID: + case NK_SYMBOL_CIRCLE_OUTLINE: + case NK_SYMBOL_RECT_SOLID: + case NK_SYMBOL_RECT_OUTLINE: { + /* simple empty/filled shapes */ + if (type == NK_SYMBOL_RECT_SOLID || type == NK_SYMBOL_RECT_OUTLINE) { + nk_fill_rect(out, content, 0, foreground); + if (type == NK_SYMBOL_RECT_OUTLINE) + nk_fill_rect(out, nk_shrink_rect(content, border_width), 0, background); + } else { + nk_fill_circle(out, content, foreground); + if (type == NK_SYMBOL_CIRCLE_OUTLINE) + nk_fill_circle(out, nk_shrink_rect(content, 1), background); + } + } break; + case NK_SYMBOL_TRIANGLE_UP: + case NK_SYMBOL_TRIANGLE_DOWN: + case NK_SYMBOL_TRIANGLE_LEFT: + case NK_SYMBOL_TRIANGLE_RIGHT: { + enum nk_heading heading; + struct nk_vec2 points[3]; + heading = (type == NK_SYMBOL_TRIANGLE_RIGHT) ? NK_RIGHT : + (type == NK_SYMBOL_TRIANGLE_LEFT) ? NK_LEFT: + (type == NK_SYMBOL_TRIANGLE_UP) ? NK_UP: NK_DOWN; + nk_triangle_from_direction(points, content, 0, 0, heading); + nk_fill_triangle(out, points[0].x, points[0].y, points[1].x, points[1].y, + points[2].x, points[2].y, foreground); + } break; + default: + case NK_SYMBOL_NONE: + case NK_SYMBOL_MAX: break; + } +} + +NK_INTERN int +nk_button_behavior(nk_flags *state, struct nk_rect r, + const struct nk_input *i, enum nk_button_behavior behavior) +{ + int ret = 0; + nk_widget_state_reset(state); + if (!i) return 0; + if (nk_input_is_mouse_hovering_rect(i, r)) { + *state = NK_WIDGET_STATE_HOVERED; + if (nk_input_is_mouse_down(i, NK_BUTTON_LEFT)) + *state = NK_WIDGET_STATE_ACTIVE; + if (nk_input_has_mouse_click_in_rect(i, NK_BUTTON_LEFT, r)) { + ret = (behavior != NK_BUTTON_DEFAULT) ? + nk_input_is_mouse_down(i, NK_BUTTON_LEFT): +#ifdef NK_BUTTON_TRIGGER_ON_RELEASE + nk_input_is_mouse_released(i, NK_BUTTON_LEFT); +#else + nk_input_is_mouse_pressed(i, NK_BUTTON_LEFT); +#endif + } + } + if (*state & NK_WIDGET_STATE_HOVER && !nk_input_is_mouse_prev_hovering_rect(i, r)) + *state |= NK_WIDGET_STATE_ENTERED; + else if (nk_input_is_mouse_prev_hovering_rect(i, r)) + *state |= NK_WIDGET_STATE_LEFT; + return ret; +} + +NK_INTERN const struct nk_style_item* +nk_draw_button(struct nk_command_buffer *out, + const struct nk_rect *bounds, nk_flags state, + const struct nk_style_button *style) +{ + const struct nk_style_item *background; + if (state & NK_WIDGET_STATE_HOVER) + background = &style->hover; + else if (state & NK_WIDGET_STATE_ACTIVED) + background = &style->active; + else background = &style->normal; + + if (background->type == NK_STYLE_ITEM_IMAGE) { + nk_draw_image(out, *bounds, &background->data.image, nk_white); + } else { + nk_fill_rect(out, *bounds, style->rounding, background->data.color); + nk_stroke_rect(out, *bounds, style->rounding, style->border, style->border_color); + } + return background; +} + +NK_INTERN int +nk_do_button(nk_flags *state, struct nk_command_buffer *out, struct nk_rect r, + const struct nk_style_button *style, const struct nk_input *in, + enum nk_button_behavior behavior, struct nk_rect *content) +{ + struct nk_rect bounds; + NK_ASSERT(style); + NK_ASSERT(state); + NK_ASSERT(out); + if (!out || !style) + return nk_false; + + /* calculate button content space */ + content->x = r.x + style->padding.x + style->border + style->rounding; + content->y = r.y + style->padding.y + style->border + style->rounding; + content->w = r.w - (2 * style->padding.x + style->border + style->rounding*2); + content->h = r.h - (2 * style->padding.y + style->border + style->rounding*2); + + /* execute button behavior */ + bounds.x = r.x - style->touch_padding.x; + bounds.y = r.y - style->touch_padding.y; + bounds.w = r.w + 2 * style->touch_padding.x; + bounds.h = r.h + 2 * style->touch_padding.y; + return nk_button_behavior(state, bounds, in, behavior); +} + +NK_INTERN void +nk_draw_button_text(struct nk_command_buffer *out, + const struct nk_rect *bounds, const struct nk_rect *content, nk_flags state, + const struct nk_style_button *style, const char *txt, int len, + nk_flags text_alignment, const struct nk_user_font *font) +{ + struct nk_text text; + const struct nk_style_item *background; + background = nk_draw_button(out, bounds, state, style); + + /* select correct colors/images */ + if (background->type == NK_STYLE_ITEM_COLOR) + text.background = background->data.color; + else text.background = style->text_background; + if (state & NK_WIDGET_STATE_HOVER) + text.text = style->text_hover; + else if (state & NK_WIDGET_STATE_ACTIVED) + text.text = style->text_active; + else text.text = style->text_normal; + + text.padding = nk_vec2(0,0); + nk_widget_text(out, *content, txt, len, &text, text_alignment, font); +} + +NK_INTERN int +nk_do_button_text(nk_flags *state, + struct nk_command_buffer *out, struct nk_rect bounds, + const char *string, int len, nk_flags align, enum nk_button_behavior behavior, + const struct nk_style_button *style, const struct nk_input *in, + const struct nk_user_font *font) +{ + struct nk_rect content; + int ret = nk_false; + + NK_ASSERT(state); + NK_ASSERT(style); + NK_ASSERT(out); + NK_ASSERT(string); + NK_ASSERT(font); + if (!out || !style || !font || !string) + return nk_false; + + ret = nk_do_button(state, out, bounds, style, in, behavior, &content); + if (style->draw_begin) style->draw_begin(out, style->userdata); + nk_draw_button_text(out, &bounds, &content, *state, style, string, len, align, font); + if (style->draw_end) style->draw_end(out, style->userdata); + return ret; +} + +NK_INTERN void +nk_draw_button_symbol(struct nk_command_buffer *out, + const struct nk_rect *bounds, const struct nk_rect *content, + nk_flags state, const struct nk_style_button *style, + enum nk_symbol_type type, const struct nk_user_font *font) +{ + struct nk_color sym, bg; + const struct nk_style_item *background; + + /* select correct colors/images */ + background = nk_draw_button(out, bounds, state, style); + if (background->type == NK_STYLE_ITEM_COLOR) + bg = background->data.color; + else bg = style->text_background; + + if (state & NK_WIDGET_STATE_HOVER) + sym = style->text_hover; + else if (state & NK_WIDGET_STATE_ACTIVED) + sym = style->text_active; + else sym = style->text_normal; + nk_draw_symbol(out, type, *content, bg, sym, 1, font); +} + +NK_INTERN int +nk_do_button_symbol(nk_flags *state, + struct nk_command_buffer *out, struct nk_rect bounds, + enum nk_symbol_type symbol, enum nk_button_behavior behavior, + const struct nk_style_button *style, const struct nk_input *in, + const struct nk_user_font *font) +{ + int ret; + struct nk_rect content; + + NK_ASSERT(state); + NK_ASSERT(style); + NK_ASSERT(font); + NK_ASSERT(out); + if (!out || !style || !font || !state) + return nk_false; + + ret = nk_do_button(state, out, bounds, style, in, behavior, &content); + if (style->draw_begin) style->draw_begin(out, style->userdata); + nk_draw_button_symbol(out, &bounds, &content, *state, style, symbol, font); + if (style->draw_end) style->draw_end(out, style->userdata); + return ret; +} + +NK_INTERN void +nk_draw_button_image(struct nk_command_buffer *out, + const struct nk_rect *bounds, const struct nk_rect *content, + nk_flags state, const struct nk_style_button *style, const struct nk_image *img) +{ + nk_draw_button(out, bounds, state, style); + nk_draw_image(out, *content, img, nk_white); +} + +NK_INTERN int +nk_do_button_image(nk_flags *state, + struct nk_command_buffer *out, struct nk_rect bounds, + struct nk_image img, enum nk_button_behavior b, + const struct nk_style_button *style, const struct nk_input *in) +{ + int ret; + struct nk_rect content; + + NK_ASSERT(state); + NK_ASSERT(style); + NK_ASSERT(out); + if (!out || !style || !state) + return nk_false; + + ret = nk_do_button(state, out, bounds, style, in, b, &content); + content.x += style->image_padding.x; + content.y += style->image_padding.y; + content.w -= 2 * style->image_padding.x; + content.h -= 2 * style->image_padding.y; + + if (style->draw_begin) style->draw_begin(out, style->userdata); + nk_draw_button_image(out, &bounds, &content, *state, style, &img); + if (style->draw_end) style->draw_end(out, style->userdata); + return ret; +} + +NK_INTERN void +nk_draw_button_text_symbol(struct nk_command_buffer *out, + const struct nk_rect *bounds, const struct nk_rect *label, + const struct nk_rect *symbol, nk_flags state, const struct nk_style_button *style, + const char *str, int len, enum nk_symbol_type type, + const struct nk_user_font *font) +{ + struct nk_color sym; + struct nk_text text; + const struct nk_style_item *background; + + /* select correct background colors/images */ + background = nk_draw_button(out, bounds, state, style); + if (background->type == NK_STYLE_ITEM_COLOR) + text.background = background->data.color; + else text.background = style->text_background; + + /* select correct text colors */ + if (state & NK_WIDGET_STATE_HOVER) { + sym = style->text_hover; + text.text = style->text_hover; + } else if (state & NK_WIDGET_STATE_ACTIVED) { + sym = style->text_active; + text.text = style->text_active; + } else { + sym = style->text_normal; + text.text = style->text_normal; + } + + text.padding = nk_vec2(0,0); + nk_draw_symbol(out, type, *symbol, style->text_background, sym, 0, font); + nk_widget_text(out, *label, str, len, &text, NK_TEXT_CENTERED, font); +} + +NK_INTERN int +nk_do_button_text_symbol(nk_flags *state, + struct nk_command_buffer *out, struct nk_rect bounds, + enum nk_symbol_type symbol, const char *str, int len, nk_flags align, + enum nk_button_behavior behavior, const struct nk_style_button *style, + const struct nk_user_font *font, const struct nk_input *in) +{ + int ret; + struct nk_rect tri = {0,0,0,0}; + struct nk_rect content; + + NK_ASSERT(style); + NK_ASSERT(out); + NK_ASSERT(font); + if (!out || !style || !font) + return nk_false; + + ret = nk_do_button(state, out, bounds, style, in, behavior, &content); + tri.y = content.y + (content.h/2) - font->height/2; + tri.w = font->height; tri.h = font->height; + if (align & NK_TEXT_ALIGN_LEFT) { + tri.x = (content.x + content.w) - (2 * style->padding.x + tri.w); + tri.x = NK_MAX(tri.x, 0); + } else tri.x = content.x + 2 * style->padding.x; + + /* draw button */ + if (style->draw_begin) style->draw_begin(out, style->userdata); + nk_draw_button_text_symbol(out, &bounds, &content, &tri, + *state, style, str, len, symbol, font); + if (style->draw_end) style->draw_end(out, style->userdata); + return ret; +} + +NK_INTERN void +nk_draw_button_text_image(struct nk_command_buffer *out, + const struct nk_rect *bounds, const struct nk_rect *label, + const struct nk_rect *image, nk_flags state, const struct nk_style_button *style, + const char *str, int len, const struct nk_user_font *font, + const struct nk_image *img) +{ + struct nk_text text; + const struct nk_style_item *background; + background = nk_draw_button(out, bounds, state, style); + + /* select correct colors */ + if (background->type == NK_STYLE_ITEM_COLOR) + text.background = background->data.color; + else text.background = style->text_background; + if (state & NK_WIDGET_STATE_HOVER) + text.text = style->text_hover; + else if (state & NK_WIDGET_STATE_ACTIVED) + text.text = style->text_active; + else text.text = style->text_normal; + + text.padding = nk_vec2(0,0); + nk_widget_text(out, *label, str, len, &text, NK_TEXT_CENTERED, font); + nk_draw_image(out, *image, img, nk_white); +} + +NK_INTERN int +nk_do_button_text_image(nk_flags *state, + struct nk_command_buffer *out, struct nk_rect bounds, + struct nk_image img, const char* str, int len, nk_flags align, + enum nk_button_behavior behavior, const struct nk_style_button *style, + const struct nk_user_font *font, const struct nk_input *in) +{ + int ret; + struct nk_rect icon; + struct nk_rect content; + + NK_ASSERT(style); + NK_ASSERT(state); + NK_ASSERT(font); + NK_ASSERT(out); + if (!out || !font || !style || !str) + return nk_false; + + ret = nk_do_button(state, out, bounds, style, in, behavior, &content); + icon.y = bounds.y + style->padding.y; + icon.w = icon.h = bounds.h - 2 * style->padding.y; + if (align & NK_TEXT_ALIGN_LEFT) { + icon.x = (bounds.x + bounds.w) - (2 * style->padding.x + icon.w); + icon.x = NK_MAX(icon.x, 0); + } else icon.x = bounds.x + 2 * style->padding.x; + + icon.x += style->image_padding.x; + icon.y += style->image_padding.y; + icon.w -= 2 * style->image_padding.x; + icon.h -= 2 * style->image_padding.y; + + if (style->draw_begin) style->draw_begin(out, style->userdata); + nk_draw_button_text_image(out, &bounds, &content, &icon, *state, style, str, len, font, &img); + if (style->draw_end) style->draw_end(out, style->userdata); + return ret; +} + +/* =============================================================== + * + * TOGGLE + * + * ===============================================================*/ +enum nk_toggle_type { + NK_TOGGLE_CHECK, + NK_TOGGLE_OPTION +}; + +NK_INTERN int +nk_toggle_behavior(const struct nk_input *in, struct nk_rect select, + nk_flags *state, int active) +{ + nk_widget_state_reset(state); + if (nk_button_behavior(state, select, in, NK_BUTTON_DEFAULT)) { + *state = NK_WIDGET_STATE_ACTIVE; + active = !active; + } + if (*state & NK_WIDGET_STATE_HOVER && !nk_input_is_mouse_prev_hovering_rect(in, select)) + *state |= NK_WIDGET_STATE_ENTERED; + else if (nk_input_is_mouse_prev_hovering_rect(in, select)) + *state |= NK_WIDGET_STATE_LEFT; + return active; +} + +NK_INTERN void +nk_draw_checkbox(struct nk_command_buffer *out, + nk_flags state, const struct nk_style_toggle *style, int active, + const struct nk_rect *label, const struct nk_rect *selector, + const struct nk_rect *cursors, const char *string, int len, + const struct nk_user_font *font) +{ + const struct nk_style_item *background; + const struct nk_style_item *cursor; + struct nk_text text; + + /* select correct colors/images */ + if (state & NK_WIDGET_STATE_HOVER) { + background = &style->hover; + cursor = &style->cursor_hover; + text.text = style->text_hover; + } else if (state & NK_WIDGET_STATE_ACTIVED) { + background = &style->hover; + cursor = &style->cursor_hover; + text.text = style->text_active; + } else { + background = &style->normal; + cursor = &style->cursor_normal; + text.text = style->text_normal; + } + + /* draw background and cursor */ + if (background->type == NK_STYLE_ITEM_COLOR) { + nk_fill_rect(out, *selector, 0, style->border_color); + nk_fill_rect(out, nk_shrink_rect(*selector, style->border), 0, background->data.color); + } else nk_draw_image(out, *selector, &background->data.image, nk_white); + if (active) { + if (cursor->type == NK_STYLE_ITEM_IMAGE) + nk_draw_image(out, *cursors, &cursor->data.image, nk_white); + else nk_fill_rect(out, *cursors, 0, cursor->data.color); + } + + text.padding.x = 0; + text.padding.y = 0; + text.background = style->text_background; + nk_widget_text(out, *label, string, len, &text, NK_TEXT_LEFT, font); +} + +NK_INTERN void +nk_draw_option(struct nk_command_buffer *out, + nk_flags state, const struct nk_style_toggle *style, int active, + const struct nk_rect *label, const struct nk_rect *selector, + const struct nk_rect *cursors, const char *string, int len, + const struct nk_user_font *font) +{ + const struct nk_style_item *background; + const struct nk_style_item *cursor; + struct nk_text text; + + /* select correct colors/images */ + if (state & NK_WIDGET_STATE_HOVER) { + background = &style->hover; + cursor = &style->cursor_hover; + text.text = style->text_hover; + } else if (state & NK_WIDGET_STATE_ACTIVED) { + background = &style->hover; + cursor = &style->cursor_hover; + text.text = style->text_active; + } else { + background = &style->normal; + cursor = &style->cursor_normal; + text.text = style->text_normal; + } + + /* draw background and cursor */ + if (background->type == NK_STYLE_ITEM_COLOR) { + nk_fill_circle(out, *selector, style->border_color); + nk_fill_circle(out, nk_shrink_rect(*selector, style->border), background->data.color); + } else nk_draw_image(out, *selector, &background->data.image, nk_white); + if (active) { + if (cursor->type == NK_STYLE_ITEM_IMAGE) + nk_draw_image(out, *cursors, &cursor->data.image, nk_white); + else nk_fill_circle(out, *cursors, cursor->data.color); + } + + text.padding.x = 0; + text.padding.y = 0; + text.background = style->text_background; + nk_widget_text(out, *label, string, len, &text, NK_TEXT_LEFT, font); +} + +NK_INTERN int +nk_do_toggle(nk_flags *state, + struct nk_command_buffer *out, struct nk_rect r, + int *active, const char *str, int len, enum nk_toggle_type type, + const struct nk_style_toggle *style, const struct nk_input *in, + const struct nk_user_font *font) +{ + int was_active; + struct nk_rect bounds; + struct nk_rect select; + struct nk_rect cursor; + struct nk_rect label; + + NK_ASSERT(style); + NK_ASSERT(out); + NK_ASSERT(font); + if (!out || !style || !font || !active) + return 0; + + r.w = NK_MAX(r.w, font->height + 2 * style->padding.x); + r.h = NK_MAX(r.h, font->height + 2 * style->padding.y); + + /* add additional touch padding for touch screen devices */ + bounds.x = r.x - style->touch_padding.x; + bounds.y = r.y - style->touch_padding.y; + bounds.w = r.w + 2 * style->touch_padding.x; + bounds.h = r.h + 2 * style->touch_padding.y; + + /* calculate the selector space */ + select.w = font->height; + select.h = select.w; + select.y = r.y + r.h/2.0f - select.h/2.0f; + select.x = r.x; + + /* calculate the bounds of the cursor inside the selector */ + cursor.x = select.x + style->padding.x + style->border; + cursor.y = select.y + style->padding.y + style->border; + cursor.w = select.w - (2 * style->padding.x + 2 * style->border); + cursor.h = select.h - (2 * style->padding.y + 2 * style->border); + + /* label behind the selector */ + label.x = select.x + select.w + style->spacing; + label.y = select.y; + label.w = NK_MAX(r.x + r.w, label.x) - label.x; + label.h = select.w; + + /* update selector */ + was_active = *active; + *active = nk_toggle_behavior(in, bounds, state, *active); + + /* draw selector */ + if (style->draw_begin) + style->draw_begin(out, style->userdata); + if (type == NK_TOGGLE_CHECK) { + nk_draw_checkbox(out, *state, style, *active, &label, &select, &cursor, str, len, font); + } else { + nk_draw_option(out, *state, style, *active, &label, &select, &cursor, str, len, font); + } + if (style->draw_end) + style->draw_end(out, style->userdata); + return (was_active != *active); +} + +/* =============================================================== + * + * SELECTABLE + * + * ===============================================================*/ +NK_INTERN void +nk_draw_selectable(struct nk_command_buffer *out, + nk_flags state, const struct nk_style_selectable *style, int active, + const struct nk_rect *bounds, const struct nk_rect *icon, const struct nk_image *img, + const char *string, int len, nk_flags align, const struct nk_user_font *font) +{ + const struct nk_style_item *background; + struct nk_text text; + text.padding = style->padding; + + /* select correct colors/images */ + if (!active) { + if (state & NK_WIDGET_STATE_ACTIVED) { + background = &style->pressed; + text.text = style->text_pressed; + } else if (state & NK_WIDGET_STATE_HOVER) { + background = &style->hover; + text.text = style->text_hover; + } else { + background = &style->normal; + text.text = style->text_normal; + } + } else { + if (state & NK_WIDGET_STATE_ACTIVED) { + background = &style->pressed_active; + text.text = style->text_pressed_active; + } else if (state & NK_WIDGET_STATE_HOVER) { + background = &style->hover_active; + text.text = style->text_hover_active; + } else { + background = &style->normal_active; + text.text = style->text_normal_active; + } + } + + + /* draw selectable background and text */ + if (background->type == NK_STYLE_ITEM_IMAGE) { + nk_draw_image(out, *bounds, &background->data.image, nk_white); + text.background = nk_rgba(0,0,0,0); + } else { + nk_fill_rect(out, *bounds, style->rounding, background->data.color); + text.background = background->data.color; + } + if (img && icon) nk_draw_image(out, *icon, img, nk_white); + nk_widget_text(out, *bounds, string, len, &text, align, font); +} + +NK_INTERN int +nk_do_selectable(nk_flags *state, struct nk_command_buffer *out, + struct nk_rect bounds, const char *str, int len, nk_flags align, int *value, + const struct nk_style_selectable *style, const struct nk_input *in, + const struct nk_user_font *font) +{ + int old_value; + struct nk_rect touch; + + NK_ASSERT(state); + NK_ASSERT(out); + NK_ASSERT(str); + NK_ASSERT(len); + NK_ASSERT(value); + NK_ASSERT(style); + NK_ASSERT(font); + + if (!state || !out || !str || !len || !value || !style || !font) return 0; + old_value = *value; + + /* remove padding */ + touch.x = bounds.x - style->touch_padding.x; + touch.y = bounds.y - style->touch_padding.y; + touch.w = bounds.w + style->touch_padding.x * 2; + touch.h = bounds.h + style->touch_padding.y * 2; + + /* update button */ + if (nk_button_behavior(state, touch, in, NK_BUTTON_DEFAULT)) + *value = !(*value); + + /* draw selectable */ + if (style->draw_begin) style->draw_begin(out, style->userdata); + nk_draw_selectable(out, *state, style, *value, &bounds, 0,0, str, len, align, font); + if (style->draw_end) style->draw_end(out, style->userdata); + return old_value != *value; +} + +NK_INTERN int +nk_do_selectable_image(nk_flags *state, struct nk_command_buffer *out, + struct nk_rect bounds, const char *str, int len, nk_flags align, int *value, + const struct nk_image *img, const struct nk_style_selectable *style, + const struct nk_input *in, const struct nk_user_font *font) +{ + int old_value; + struct nk_rect touch; + struct nk_rect icon; + + NK_ASSERT(state); + NK_ASSERT(out); + NK_ASSERT(str); + NK_ASSERT(len); + NK_ASSERT(value); + NK_ASSERT(style); + NK_ASSERT(font); + + if (!state || !out || !str || !len || !value || !style || !font) return 0; + old_value = *value; + + /* toggle behavior */ + touch.x = bounds.x - style->touch_padding.x; + touch.y = bounds.y - style->touch_padding.y; + touch.w = bounds.w + style->touch_padding.x * 2; + touch.h = bounds.h + style->touch_padding.y * 2; + if (nk_button_behavior(state, touch, in, NK_BUTTON_DEFAULT)) + *value = !(*value); + + icon.y = bounds.y + style->padding.y; + icon.w = icon.h = bounds.h - 2 * style->padding.y; + if (align & NK_TEXT_ALIGN_LEFT) { + icon.x = (bounds.x + bounds.w) - (2 * style->padding.x + icon.w); + icon.x = NK_MAX(icon.x, 0); + } else icon.x = bounds.x + 2 * style->padding.x; + + icon.x += style->image_padding.x; + icon.y += style->image_padding.y; + icon.w -= 2 * style->image_padding.x; + icon.h -= 2 * style->image_padding.y; + + /* draw selectable */ + if (style->draw_begin) style->draw_begin(out, style->userdata); + nk_draw_selectable(out, *state, style, *value, &bounds, &icon, img, str, len, align, font); + if (style->draw_end) style->draw_end(out, style->userdata); + return old_value != *value; +} + + +/* =============================================================== + * + * SLIDER + * + * ===============================================================*/ +NK_INTERN float +nk_slider_behavior(nk_flags *state, struct nk_rect *logical_cursor, + struct nk_rect *visual_cursor, struct nk_input *in, + struct nk_rect bounds, float slider_min, float slider_max, float slider_value, + float slider_step, float slider_steps) +{ + int left_mouse_down; + int left_mouse_click_in_cursor; + + /* check if visual cursor is being dragged */ + nk_widget_state_reset(state); + left_mouse_down = in && in->mouse.buttons[NK_BUTTON_LEFT].down; + left_mouse_click_in_cursor = in && nk_input_has_mouse_click_down_in_rect(in, + NK_BUTTON_LEFT, *visual_cursor, nk_true); + + if (left_mouse_down && left_mouse_click_in_cursor) + { + float ratio = 0; + const float d = in->mouse.pos.x - (visual_cursor->x+visual_cursor->w*0.5f); + const float pxstep = bounds.w / slider_steps; + + /* only update value if the next slider step is reached */ + *state = NK_WIDGET_STATE_ACTIVE; + if (NK_ABS(d) >= pxstep) { + const float steps = (float)((int)(NK_ABS(d) / pxstep)); + slider_value += (d > 0) ? (slider_step*steps) : -(slider_step*steps); + slider_value = NK_CLAMP(slider_min, slider_value, slider_max); + ratio = (slider_value - slider_min)/slider_step; + logical_cursor->x = bounds.x + (logical_cursor->w * ratio); + in->mouse.buttons[NK_BUTTON_LEFT].clicked_pos.x = logical_cursor->x; + } + } + + /* slider widget state */ + if (nk_input_is_mouse_hovering_rect(in, bounds)) + *state = NK_WIDGET_STATE_HOVERED; + if (*state & NK_WIDGET_STATE_HOVER && + !nk_input_is_mouse_prev_hovering_rect(in, bounds)) + *state |= NK_WIDGET_STATE_ENTERED; + else if (nk_input_is_mouse_prev_hovering_rect(in, bounds)) + *state |= NK_WIDGET_STATE_LEFT; + return slider_value; +} + +NK_INTERN void +nk_draw_slider(struct nk_command_buffer *out, nk_flags state, + const struct nk_style_slider *style, const struct nk_rect *bounds, + const struct nk_rect *visual_cursor, float min, float value, float max) +{ + struct nk_rect fill; + struct nk_rect bar; + const struct nk_style_item *background; + + /* select correct slider images/colors */ + struct nk_color bar_color; + const struct nk_style_item *cursor; + + NK_UNUSED(min); + NK_UNUSED(max); + NK_UNUSED(value); + + if (state & NK_WIDGET_STATE_ACTIVED) { + background = &style->active; + bar_color = style->bar_active; + cursor = &style->cursor_active; + } else if (state & NK_WIDGET_STATE_HOVER) { + background = &style->hover; + bar_color = style->bar_hover; + cursor = &style->cursor_hover; + } else { + background = &style->normal; + bar_color = style->bar_normal; + cursor = &style->cursor_normal; + } + + /* calculate slider background bar */ + bar.x = bounds->x; + bar.y = (visual_cursor->y + visual_cursor->h/2) - bounds->h/12; + bar.w = bounds->w; + bar.h = bounds->h/6; + + /* filled background bar style */ + fill.w = (visual_cursor->x + (visual_cursor->w/2.0f)) - bar.x; + fill.x = bar.x; + fill.y = bar.y; + fill.h = bar.h; + + /* draw background */ + if (background->type == NK_STYLE_ITEM_IMAGE) { + nk_draw_image(out, *bounds, &background->data.image, nk_white); + } else { + nk_fill_rect(out, *bounds, style->rounding, background->data.color); + nk_stroke_rect(out, *bounds, style->rounding, style->border, style->border_color); + } + + /* draw slider bar */ + nk_fill_rect(out, bar, style->rounding, bar_color); + nk_fill_rect(out, fill, style->rounding, style->bar_filled); + + /* draw cursor */ + if (cursor->type == NK_STYLE_ITEM_IMAGE) + nk_draw_image(out, *visual_cursor, &cursor->data.image, nk_white); + else nk_fill_circle(out, *visual_cursor, cursor->data.color); +} + +NK_INTERN float +nk_do_slider(nk_flags *state, + struct nk_command_buffer *out, struct nk_rect bounds, + float min, float val, float max, float step, + const struct nk_style_slider *style, struct nk_input *in, + const struct nk_user_font *font) +{ + float slider_range; + float slider_min; + float slider_max; + float slider_value; + float slider_steps; + float cursor_offset; + + struct nk_rect visual_cursor; + struct nk_rect logical_cursor; + + NK_ASSERT(style); + NK_ASSERT(out); + if (!out || !style) + return 0; + + /* remove padding from slider bounds */ + bounds.x = bounds.x + style->padding.x; + bounds.y = bounds.y + style->padding.y; + bounds.h = NK_MAX(bounds.h, 2*style->padding.y); + bounds.w = NK_MAX(bounds.w, 2*style->padding.x + style->cursor_size.x); + bounds.w -= 2 * style->padding.x; + bounds.h -= 2 * style->padding.y; + + /* optional buttons */ + if (style->show_buttons) { + nk_flags ws; + struct nk_rect button; + button.y = bounds.y; + button.w = bounds.h; + button.h = bounds.h; + + /* decrement button */ + button.x = bounds.x; + if (nk_do_button_symbol(&ws, out, button, style->dec_symbol, NK_BUTTON_DEFAULT, + &style->dec_button, in, font)) + val -= step; + + /* increment button */ + button.x = (bounds.x + bounds.w) - button.w; + if (nk_do_button_symbol(&ws, out, button, style->inc_symbol, NK_BUTTON_DEFAULT, + &style->inc_button, in, font)) + val += step; + + bounds.x = bounds.x + button.w + style->spacing.x; + bounds.w = bounds.w - (2*button.w + 2*style->spacing.x); + } + + /* remove one cursor size to support visual cursor */ + bounds.x += style->cursor_size.x*0.5f; + bounds.w -= style->cursor_size.x; + + /* make sure the provided values are correct */ + slider_max = NK_MAX(min, max); + slider_min = NK_MIN(min, max); + slider_value = NK_CLAMP(slider_min, val, slider_max); + slider_range = slider_max - slider_min; + slider_steps = slider_range / step; + cursor_offset = (slider_value - slider_min) / step; + + /* calculate cursor + Basically you have two cursors. One for visual representation and interaction + and one for updating the actual cursor value. */ + logical_cursor.h = bounds.h; + logical_cursor.w = bounds.w / slider_steps; + logical_cursor.x = bounds.x + (logical_cursor.w * cursor_offset); + logical_cursor.y = bounds.y; + + visual_cursor.h = style->cursor_size.y; + visual_cursor.w = style->cursor_size.x; + visual_cursor.y = (bounds.y + bounds.h*0.5f) - visual_cursor.h*0.5f; + visual_cursor.x = logical_cursor.x - visual_cursor.w*0.5f; + + slider_value = nk_slider_behavior(state, &logical_cursor, &visual_cursor, + in, bounds, slider_min, slider_max, slider_value, step, slider_steps); + visual_cursor.x = logical_cursor.x - visual_cursor.w*0.5f; + + /* draw slider */ + if (style->draw_begin) style->draw_begin(out, style->userdata); + nk_draw_slider(out, *state, style, &bounds, &visual_cursor, slider_min, slider_value, slider_max); + if (style->draw_end) style->draw_end(out, style->userdata); + return slider_value; +} + +/* =============================================================== + * + * PROGRESSBAR + * + * ===============================================================*/ +NK_INTERN nk_size +nk_progress_behavior(nk_flags *state, const struct nk_input *in, + struct nk_rect r, nk_size max, nk_size value, int modifiable) +{ + nk_widget_state_reset(state); + if (in && modifiable && nk_input_is_mouse_hovering_rect(in, r)) { + int left_mouse_down = in->mouse.buttons[NK_BUTTON_LEFT].down; + int left_mouse_click_in_cursor = nk_input_has_mouse_click_down_in_rect(in, + NK_BUTTON_LEFT, r, nk_true); + + if (left_mouse_down && left_mouse_click_in_cursor) { + float ratio = NK_MAX(0, (float)(in->mouse.pos.x - r.x)) / (float)r.w; + value = (nk_size)NK_MAX(0,((float)max * ratio)); + *state = NK_WIDGET_STATE_ACTIVE; + } else *state = NK_WIDGET_STATE_HOVERED; + } + + /* set progressbar widget state */ + if (*state & NK_WIDGET_STATE_HOVER && !nk_input_is_mouse_prev_hovering_rect(in, r)) + *state |= NK_WIDGET_STATE_ENTERED; + else if (nk_input_is_mouse_prev_hovering_rect(in, r)) + *state |= NK_WIDGET_STATE_LEFT; + + if (!max) return value; + value = NK_MIN(value, max); + return value; +} + +NK_INTERN void +nk_draw_progress(struct nk_command_buffer *out, nk_flags state, + const struct nk_style_progress *style, const struct nk_rect *bounds, + const struct nk_rect *scursor, nk_size value, nk_size max) +{ + const struct nk_style_item *background; + const struct nk_style_item *cursor; + + NK_UNUSED(max); + NK_UNUSED(value); + + /* select correct colors/images to draw */ + if (state & NK_WIDGET_STATE_ACTIVED) { + background = &style->active; + cursor = &style->cursor_active; + } else if (state & NK_WIDGET_STATE_HOVER){ + background = &style->hover; + cursor = &style->cursor_hover; + } else { + background = &style->normal; + cursor = &style->cursor_normal; + } + + /* draw background */ + if (background->type == NK_STYLE_ITEM_COLOR) { + nk_fill_rect(out, *bounds, style->rounding, background->data.color); + nk_stroke_rect(out, *bounds, style->rounding, style->border, style->border_color); + } else nk_draw_image(out, *bounds, &background->data.image, nk_white); + + /* draw cursor */ + if (cursor->type == NK_STYLE_ITEM_COLOR) { + nk_fill_rect(out, *scursor, style->rounding, cursor->data.color); + nk_stroke_rect(out, *scursor, style->rounding, style->border, style->border_color); + } else nk_draw_image(out, *scursor, &cursor->data.image, nk_white); +} + +NK_INTERN nk_size +nk_do_progress(nk_flags *state, + struct nk_command_buffer *out, struct nk_rect bounds, + nk_size value, nk_size max, int modifiable, + const struct nk_style_progress *style, const struct nk_input *in) +{ + float prog_scale; + nk_size prog_value; + struct nk_rect cursor; + + NK_ASSERT(style); + NK_ASSERT(out); + if (!out || !style) return 0; + + /* calculate progressbar cursor */ + cursor.w = NK_MAX(bounds.w, 2 * style->padding.x + 2 * style->border); + cursor.h = NK_MAX(bounds.h, 2 * style->padding.y + 2 * style->border); + cursor = nk_pad_rect(bounds, nk_vec2(style->padding.x + style->border, style->padding.y + style->border)); + prog_scale = (float)value / (float)max; + cursor.w = (bounds.w - 2) * prog_scale; + + /* update progressbar */ + prog_value = NK_MIN(value, max); + prog_value = nk_progress_behavior(state, in, bounds, max, prog_value, modifiable); + + /* draw progressbar */ + if (style->draw_begin) style->draw_begin(out, style->userdata); + nk_draw_progress(out, *state, style, &bounds, &cursor, value, max); + if (style->draw_end) style->draw_end(out, style->userdata); + return prog_value; +} + +/* =============================================================== + * + * SCROLLBAR + * + * ===============================================================*/ +NK_INTERN float +nk_scrollbar_behavior(nk_flags *state, struct nk_input *in, + int has_scrolling, const struct nk_rect *scroll, + const struct nk_rect *cursor, const struct nk_rect *empty0, + const struct nk_rect *empty1, float scroll_offset, + float target, float scroll_step, enum nk_orientation o) +{ + nk_flags ws = 0; + int left_mouse_down; + int left_mouse_click_in_cursor; + float scroll_delta; + + nk_widget_state_reset(state); + if (!in) return scroll_offset; + + left_mouse_down = in->mouse.buttons[NK_BUTTON_LEFT].down; + left_mouse_click_in_cursor = nk_input_has_mouse_click_down_in_rect(in, + NK_BUTTON_LEFT, *cursor, nk_true); + if (nk_input_is_mouse_hovering_rect(in, *scroll)) + *state = NK_WIDGET_STATE_HOVERED; + + scroll_delta = (o == NK_VERTICAL) ? in->mouse.scroll_delta.y: in->mouse.scroll_delta.x; + if (left_mouse_down && left_mouse_click_in_cursor) { + /* update cursor by mouse dragging */ + float pixel, delta; + *state = NK_WIDGET_STATE_ACTIVE; + if (o == NK_VERTICAL) { + float cursor_y; + pixel = in->mouse.delta.y; + delta = (pixel / scroll->h) * target; + scroll_offset = NK_CLAMP(0, scroll_offset + delta, target - scroll->h); + cursor_y = scroll->y + ((scroll_offset/target) * scroll->h); + in->mouse.buttons[NK_BUTTON_LEFT].clicked_pos.y = cursor_y + cursor->h/2.0f; + } else { + float cursor_x; + pixel = in->mouse.delta.x; + delta = (pixel / scroll->w) * target; + scroll_offset = NK_CLAMP(0, scroll_offset + delta, target - scroll->w); + cursor_x = scroll->x + ((scroll_offset/target) * scroll->w); + in->mouse.buttons[NK_BUTTON_LEFT].clicked_pos.x = cursor_x + cursor->w/2.0f; + } + } else if ((nk_input_is_key_pressed(in, NK_KEY_SCROLL_UP) && o == NK_VERTICAL && has_scrolling)|| + nk_button_behavior(&ws, *empty0, in, NK_BUTTON_DEFAULT)) { + /* scroll page up by click on empty space or shortcut */ + if (o == NK_VERTICAL) + scroll_offset = NK_MAX(0, scroll_offset - scroll->h); + else scroll_offset = NK_MAX(0, scroll_offset - scroll->w); + } else if ((nk_input_is_key_pressed(in, NK_KEY_SCROLL_DOWN) && o == NK_VERTICAL && has_scrolling) || + nk_button_behavior(&ws, *empty1, in, NK_BUTTON_DEFAULT)) { + /* scroll page down by click on empty space or shortcut */ + if (o == NK_VERTICAL) + scroll_offset = NK_MIN(scroll_offset + scroll->h, target - scroll->h); + else scroll_offset = NK_MIN(scroll_offset + scroll->w, target - scroll->w); + } else if (has_scrolling) { + if ((scroll_delta < 0 || (scroll_delta > 0))) { + /* update cursor by mouse scrolling */ + scroll_offset = scroll_offset + scroll_step * (-scroll_delta); + if (o == NK_VERTICAL) + scroll_offset = NK_CLAMP(0, scroll_offset, target - scroll->h); + else scroll_offset = NK_CLAMP(0, scroll_offset, target - scroll->w); + } else if (nk_input_is_key_pressed(in, NK_KEY_SCROLL_START)) { + /* update cursor to the beginning */ + if (o == NK_VERTICAL) scroll_offset = 0; + } else if (nk_input_is_key_pressed(in, NK_KEY_SCROLL_END)) { + /* update cursor to the end */ + if (o == NK_VERTICAL) scroll_offset = target - scroll->h; + } + } + if (*state & NK_WIDGET_STATE_HOVER && !nk_input_is_mouse_prev_hovering_rect(in, *scroll)) + *state |= NK_WIDGET_STATE_ENTERED; + else if (nk_input_is_mouse_prev_hovering_rect(in, *scroll)) + *state |= NK_WIDGET_STATE_LEFT; + return scroll_offset; +} + +NK_INTERN void +nk_draw_scrollbar(struct nk_command_buffer *out, nk_flags state, + const struct nk_style_scrollbar *style, const struct nk_rect *bounds, + const struct nk_rect *scroll) +{ + const struct nk_style_item *background; + const struct nk_style_item *cursor; + + /* select correct colors/images to draw */ + if (state & NK_WIDGET_STATE_ACTIVED) { + background = &style->active; + cursor = &style->cursor_active; + } else if (state & NK_WIDGET_STATE_HOVER) { + background = &style->hover; + cursor = &style->cursor_hover; + } else { + background = &style->normal; + cursor = &style->cursor_normal; + } + + /* draw background */ + if (background->type == NK_STYLE_ITEM_COLOR) { + nk_fill_rect(out, *bounds, style->rounding, background->data.color); + nk_stroke_rect(out, *bounds, style->rounding, style->border, style->border_color); + } else { + nk_draw_image(out, *bounds, &background->data.image, nk_white); + } + + /* draw cursor */ + if (background->type == NK_STYLE_ITEM_COLOR) { + nk_fill_rect(out, *scroll, style->rounding_cursor, cursor->data.color); + nk_stroke_rect(out, *scroll, style->rounding_cursor, style->border_cursor, style->cursor_border_color); + } else nk_draw_image(out, *scroll, &cursor->data.image, nk_white); +} + +NK_INTERN float +nk_do_scrollbarv(nk_flags *state, + struct nk_command_buffer *out, struct nk_rect scroll, int has_scrolling, + float offset, float target, float step, float button_pixel_inc, + const struct nk_style_scrollbar *style, struct nk_input *in, + const struct nk_user_font *font) +{ + struct nk_rect empty_north; + struct nk_rect empty_south; + struct nk_rect cursor; + + float scroll_step; + float scroll_offset; + float scroll_off; + float scroll_ratio; + + NK_ASSERT(out); + NK_ASSERT(style); + NK_ASSERT(state); + if (!out || !style) return 0; + + scroll.w = NK_MAX(scroll.w, 1); + scroll.h = NK_MAX(scroll.h, 0); + if (target <= scroll.h) return 0; + + /* optional scrollbar buttons */ + if (style->show_buttons) { + nk_flags ws; + float scroll_h; + struct nk_rect button; + + button.x = scroll.x; + button.w = scroll.w; + button.h = scroll.w; + + scroll_h = NK_MAX(scroll.h - 2 * button.h,0); + scroll_step = NK_MIN(step, button_pixel_inc); + + /* decrement button */ + button.y = scroll.y; + if (nk_do_button_symbol(&ws, out, button, style->dec_symbol, + NK_BUTTON_REPEATER, &style->dec_button, in, font)) + offset = offset - scroll_step; + + /* increment button */ + button.y = scroll.y + scroll.h - button.h; + if (nk_do_button_symbol(&ws, out, button, style->inc_symbol, + NK_BUTTON_REPEATER, &style->inc_button, in, font)) + offset = offset + scroll_step; + + scroll.y = scroll.y + button.h; + scroll.h = scroll_h; + } + + /* calculate scrollbar constants */ + scroll_step = NK_MIN(step, scroll.h); + scroll_offset = NK_CLAMP(0, offset, target - scroll.h); + scroll_ratio = scroll.h / target; + scroll_off = scroll_offset / target; + + /* calculate scrollbar cursor bounds */ + cursor.h = NK_MAX((scroll_ratio * scroll.h) - (2*style->border + 2*style->padding.y), 0); + cursor.y = scroll.y + (scroll_off * scroll.h) + style->border + style->padding.y; + cursor.w = scroll.w - (2 * style->border + 2 * style->padding.x); + cursor.x = scroll.x + style->border + style->padding.x; + + /* calculate empty space around cursor */ + empty_north.x = scroll.x; + empty_north.y = scroll.y; + empty_north.w = scroll.w; + empty_north.h = NK_MAX(cursor.y - scroll.y, 0); + + empty_south.x = scroll.x; + empty_south.y = cursor.y + cursor.h; + empty_south.w = scroll.w; + empty_south.h = NK_MAX((scroll.y + scroll.h) - (cursor.y + cursor.h), 0); + + /* update scrollbar */ + scroll_offset = nk_scrollbar_behavior(state, in, has_scrolling, &scroll, &cursor, + &empty_north, &empty_south, scroll_offset, target, scroll_step, NK_VERTICAL); + scroll_off = scroll_offset / target; + cursor.y = scroll.y + (scroll_off * scroll.h) + style->border_cursor + style->padding.y; + + /* draw scrollbar */ + if (style->draw_begin) style->draw_begin(out, style->userdata); + nk_draw_scrollbar(out, *state, style, &scroll, &cursor); + if (style->draw_end) style->draw_end(out, style->userdata); + return scroll_offset; +} + +NK_INTERN float +nk_do_scrollbarh(nk_flags *state, + struct nk_command_buffer *out, struct nk_rect scroll, int has_scrolling, + float offset, float target, float step, float button_pixel_inc, + const struct nk_style_scrollbar *style, struct nk_input *in, + const struct nk_user_font *font) +{ + struct nk_rect cursor; + struct nk_rect empty_west; + struct nk_rect empty_east; + + float scroll_step; + float scroll_offset; + float scroll_off; + float scroll_ratio; + + NK_ASSERT(out); + NK_ASSERT(style); + if (!out || !style) return 0; + + /* scrollbar background */ + scroll.h = NK_MAX(scroll.h, 1); + scroll.w = NK_MAX(scroll.w, 2 * scroll.h); + if (target <= scroll.w) return 0; + + /* optional scrollbar buttons */ + if (style->show_buttons) { + nk_flags ws; + float scroll_w; + struct nk_rect button; + button.y = scroll.y; + button.w = scroll.h; + button.h = scroll.h; + + scroll_w = scroll.w - 2 * button.w; + scroll_step = NK_MIN(step, button_pixel_inc); + + /* decrement button */ + button.x = scroll.x; + if (nk_do_button_symbol(&ws, out, button, style->dec_symbol, + NK_BUTTON_REPEATER, &style->dec_button, in, font)) + offset = offset - scroll_step; + + /* increment button */ + button.x = scroll.x + scroll.w - button.w; + if (nk_do_button_symbol(&ws, out, button, style->inc_symbol, + NK_BUTTON_REPEATER, &style->inc_button, in, font)) + offset = offset + scroll_step; + + scroll.x = scroll.x + button.w; + scroll.w = scroll_w; + } + + /* calculate scrollbar constants */ + scroll_step = NK_MIN(step, scroll.w); + scroll_offset = NK_CLAMP(0, offset, target - scroll.w); + scroll_ratio = scroll.w / target; + scroll_off = scroll_offset / target; + + /* calculate cursor bounds */ + cursor.w = (scroll_ratio * scroll.w) - (2*style->border + 2*style->padding.x); + cursor.x = scroll.x + (scroll_off * scroll.w) + style->border + style->padding.x; + cursor.h = scroll.h - (2 * style->border + 2 * style->padding.y); + cursor.y = scroll.y + style->border + style->padding.y; + + /* calculate empty space around cursor */ + empty_west.x = scroll.x; + empty_west.y = scroll.y; + empty_west.w = cursor.x - scroll.x; + empty_west.h = scroll.h; + + empty_east.x = cursor.x + cursor.w; + empty_east.y = scroll.y; + empty_east.w = (scroll.x + scroll.w) - (cursor.x + cursor.w); + empty_east.h = scroll.h; + + /* update scrollbar */ + scroll_offset = nk_scrollbar_behavior(state, in, has_scrolling, &scroll, &cursor, + &empty_west, &empty_east, scroll_offset, target, scroll_step, NK_HORIZONTAL); + scroll_off = scroll_offset / target; + cursor.x = scroll.x + (scroll_off * scroll.w); + + /* draw scrollbar */ + if (style->draw_begin) style->draw_begin(out, style->userdata); + nk_draw_scrollbar(out, *state, style, &scroll, &cursor); + if (style->draw_end) style->draw_end(out, style->userdata); + return scroll_offset; +} + +/* =============================================================== + * + * FILTER + * + * ===============================================================*/ +NK_API int nk_filter_default(const struct nk_text_edit *box, nk_rune unicode) +{(void)unicode;NK_UNUSED(box);return nk_true;} + +NK_API int +nk_filter_ascii(const struct nk_text_edit *box, nk_rune unicode) +{ + NK_UNUSED(box); + if (unicode > 128) return nk_false; + else return nk_true; +} + +NK_API int +nk_filter_float(const struct nk_text_edit *box, nk_rune unicode) +{ + NK_UNUSED(box); + if ((unicode < '0' || unicode > '9') && unicode != '.' && unicode != '-') + return nk_false; + else return nk_true; +} + +NK_API int +nk_filter_decimal(const struct nk_text_edit *box, nk_rune unicode) +{ + NK_UNUSED(box); + if ((unicode < '0' || unicode > '9') && unicode != '-') + return nk_false; + else return nk_true; +} + +NK_API int +nk_filter_hex(const struct nk_text_edit *box, nk_rune unicode) +{ + NK_UNUSED(box); + if ((unicode < '0' || unicode > '9') && + (unicode < 'a' || unicode > 'f') && + (unicode < 'A' || unicode > 'F')) + return nk_false; + else return nk_true; +} + +NK_API int +nk_filter_oct(const struct nk_text_edit *box, nk_rune unicode) +{ + NK_UNUSED(box); + if (unicode < '0' || unicode > '7') + return nk_false; + else return nk_true; +} + +NK_API int +nk_filter_binary(const struct nk_text_edit *box, nk_rune unicode) +{ + NK_UNUSED(box); + if (unicode != '0' && unicode != '1') + return nk_false; + else return nk_true; +} + +/* =============================================================== + * + * EDIT + * + * ===============================================================*/ +NK_INTERN void +nk_edit_draw_text(struct nk_command_buffer *out, + const struct nk_style_edit *style, float pos_x, float pos_y, + float x_offset, const char *text, int byte_len, float row_height, + const struct nk_user_font *font, struct nk_color background, + struct nk_color foreground, int is_selected) +{ + NK_ASSERT(out); + NK_ASSERT(font); + NK_ASSERT(style); + if (!text || !byte_len || !out || !style) return; + + {int glyph_len = 0; + nk_rune unicode = 0; + int text_len = 0; + float line_width = 0; + float glyph_width; + const char *line = text; + float line_offset = 0; + int line_count = 0; + + struct nk_text txt; + txt.padding = nk_vec2(0,0); + txt.background = background; + txt.text = foreground; + + glyph_len = nk_utf_decode(text+text_len, &unicode, byte_len-text_len); + if (!glyph_len) return; + while ((text_len < byte_len) && glyph_len) + { + if (unicode == '\n') { + /* new line separator so draw previous line */ + struct nk_rect label; + label.y = pos_y + line_offset; + label.h = row_height; + label.w = line_width; + label.x = pos_x; + if (!line_count) + label.x += x_offset; + + if (is_selected) /* selection needs to draw different background color */ + nk_fill_rect(out, label, 0, background); + nk_widget_text(out, label, line, (int)((text + text_len) - line), + &txt, NK_TEXT_CENTERED, font); + + text_len++; + line_count++; + line_width = 0; + line = text + text_len; + line_offset += row_height; + glyph_len = nk_utf_decode(text + text_len, &unicode, (int)(byte_len-text_len)); + continue; + } + if (unicode == '\r') { + text_len++; + glyph_len = nk_utf_decode(text + text_len, &unicode, byte_len-text_len); + continue; + } + glyph_width = font->width(font->userdata, font->height, text+text_len, glyph_len); + line_width += (float)glyph_width; + text_len += glyph_len; + glyph_len = nk_utf_decode(text + text_len, &unicode, byte_len-text_len); + continue; + } + if (line_width > 0) { + /* draw last line */ + struct nk_rect label; + label.y = pos_y + line_offset; + label.h = row_height; + label.w = line_width; + label.x = pos_x; + if (!line_count) + label.x += x_offset; + + if (is_selected) + nk_fill_rect(out, label, 0, background); + nk_widget_text(out, label, line, (int)((text + text_len) - line), + &txt, NK_TEXT_LEFT, font); + }} +} + +NK_INTERN nk_flags +nk_do_edit(nk_flags *state, struct nk_command_buffer *out, + struct nk_rect bounds, nk_flags flags, nk_plugin_filter filter, + struct nk_text_edit *edit, const struct nk_style_edit *style, + struct nk_input *in, const struct nk_user_font *font) +{ + struct nk_rect area; + nk_flags ret = 0; + float row_height; + char prev_state = 0; + char is_hovered = 0; + char select_all = 0; + char cursor_follow = 0; + struct nk_rect old_clip; + struct nk_rect clip; + + NK_ASSERT(state); + NK_ASSERT(out); + NK_ASSERT(style); + if (!state || !out || !style) + return ret; + + /* visible text area calculation */ + area.x = bounds.x + style->padding.x + style->border; + area.y = bounds.y + style->padding.y + style->border; + area.w = bounds.w - (2.0f * style->padding.x + 2 * style->border); + area.h = bounds.h - (2.0f * style->padding.y + 2 * style->border); + if (flags & NK_EDIT_MULTILINE) + area.w = NK_MAX(0, area.w - style->scrollbar_size.x); + row_height = (flags & NK_EDIT_MULTILINE)? font->height + style->row_padding: area.h; + + /* calculate clipping rectangle */ + old_clip = out->clip; + nk_unify(&clip, &old_clip, area.x, area.y, area.x + area.w, area.y + area.h); + + /* update edit state */ + prev_state = (char)edit->active; + is_hovered = (char)nk_input_is_mouse_hovering_rect(in, bounds); + if (in && in->mouse.buttons[NK_BUTTON_LEFT].clicked && in->mouse.buttons[NK_BUTTON_LEFT].down) { + edit->active = NK_INBOX(in->mouse.pos.x, in->mouse.pos.y, + bounds.x, bounds.y, bounds.w, bounds.h); + } + + /* (de)activate text editor */ + if (!prev_state && edit->active) { + const enum nk_text_edit_type type = (flags & NK_EDIT_MULTILINE) ? + NK_TEXT_EDIT_MULTI_LINE: NK_TEXT_EDIT_SINGLE_LINE; + nk_textedit_clear_state(edit, type, filter); + if (flags & NK_EDIT_ALWAYS_INSERT_MODE) + edit->mode = NK_TEXT_EDIT_MODE_INSERT; + if (flags & NK_EDIT_AUTO_SELECT) + select_all = nk_true; + if (flags & NK_EDIT_GOTO_END_ON_ACTIVATE) { + edit->cursor = edit->string.len; + in = 0; + } + } else if (!edit->active) edit->mode = NK_TEXT_EDIT_MODE_VIEW; + if (flags & NK_EDIT_READ_ONLY) + edit->mode = NK_TEXT_EDIT_MODE_VIEW; + + ret = (edit->active) ? NK_EDIT_ACTIVE: NK_EDIT_INACTIVE; + if (prev_state != edit->active) + ret |= (edit->active) ? NK_EDIT_ACTIVATED: NK_EDIT_DEACTIVATED; + + /* handle user input */ + if (edit->active && in) + { + int shift_mod = in->keyboard.keys[NK_KEY_SHIFT].down; + const float mouse_x = (in->mouse.pos.x - area.x) + edit->scrollbar.x; + const float mouse_y = (in->mouse.pos.y - area.y) + edit->scrollbar.y; + + /* mouse click handler */ + is_hovered = (char)nk_input_is_mouse_hovering_rect(in, area); + if (select_all) { + nk_textedit_select_all(edit); + } else if (is_hovered && in->mouse.buttons[NK_BUTTON_LEFT].down && + in->mouse.buttons[NK_BUTTON_LEFT].clicked) { + nk_textedit_click(edit, mouse_x, mouse_y, font, row_height); + } else if (is_hovered && in->mouse.buttons[NK_BUTTON_LEFT].down && + (in->mouse.delta.x != 0.0f || in->mouse.delta.y != 0.0f)) { + nk_textedit_drag(edit, mouse_x, mouse_y, font, row_height); + cursor_follow = nk_true; + } else if (is_hovered && in->mouse.buttons[NK_BUTTON_RIGHT].clicked && + in->mouse.buttons[NK_BUTTON_RIGHT].down) { + nk_textedit_key(edit, NK_KEY_TEXT_WORD_LEFT, nk_false, font, row_height); + nk_textedit_key(edit, NK_KEY_TEXT_WORD_RIGHT, nk_true, font, row_height); + cursor_follow = nk_true; + } + + {int i; /* keyboard input */ + int old_mode = edit->mode; + for (i = 0; i < NK_KEY_MAX; ++i) { + if (i == NK_KEY_ENTER || i == NK_KEY_TAB) continue; /* special case */ + if (nk_input_is_key_pressed(in, (enum nk_keys)i)) { + nk_textedit_key(edit, (enum nk_keys)i, shift_mod, font, row_height); + cursor_follow = nk_true; + } + } + if (old_mode != edit->mode) { + in->keyboard.text_len = 0; + }} + + /* text input */ + edit->filter = filter; + if (in->keyboard.text_len) { + nk_textedit_text(edit, in->keyboard.text, in->keyboard.text_len); + cursor_follow = nk_true; + in->keyboard.text_len = 0; + } + + /* enter key handler */ + if (nk_input_is_key_pressed(in, NK_KEY_ENTER)) { + cursor_follow = nk_true; + if (flags & NK_EDIT_CTRL_ENTER_NEWLINE && shift_mod) + nk_textedit_text(edit, "\n", 1); + else if (flags & NK_EDIT_SIG_ENTER) + ret |= NK_EDIT_COMMITED; + else nk_textedit_text(edit, "\n", 1); + } + + /* cut & copy handler */ + {int copy= nk_input_is_key_pressed(in, NK_KEY_COPY); + int cut = nk_input_is_key_pressed(in, NK_KEY_CUT); + if ((copy || cut) && (flags & NK_EDIT_CLIPBOARD)) + { + int glyph_len; + nk_rune unicode; + const char *text; + int b = edit->select_start; + int e = edit->select_end; + + int begin = NK_MIN(b, e); + int end = NK_MAX(b, e); + text = nk_str_at_const(&edit->string, begin, &unicode, &glyph_len); + if (edit->clip.copy) + edit->clip.copy(edit->clip.userdata, text, end - begin); + if (cut && !(flags & NK_EDIT_READ_ONLY)){ + nk_textedit_cut(edit); + cursor_follow = nk_true; + } + }} + + /* paste handler */ + {int paste = nk_input_is_key_pressed(in, NK_KEY_PASTE); + if (paste && (flags & NK_EDIT_CLIPBOARD) && edit->clip.paste) { + edit->clip.paste(edit->clip.userdata, edit); + cursor_follow = nk_true; + }} + + /* tab handler */ + {int tab = nk_input_is_key_pressed(in, NK_KEY_TAB); + if (tab && (flags & NK_EDIT_ALLOW_TAB)) { + nk_textedit_text(edit, " ", 4); + cursor_follow = nk_true; + }} + } + + /* set widget state */ + if (edit->active) + *state = NK_WIDGET_STATE_ACTIVE; + else nk_widget_state_reset(state); + + if (is_hovered) + *state |= NK_WIDGET_STATE_HOVERED; + + /* DRAW EDIT */ + {const char *text = nk_str_get_const(&edit->string); + int len = nk_str_len_char(&edit->string); + + {/* select background colors/images */ + const struct nk_style_item *background; + if (*state & NK_WIDGET_STATE_ACTIVED) + background = &style->active; + else if (*state & NK_WIDGET_STATE_HOVER) + background = &style->hover; + else background = &style->normal; + + /* draw background frame */ + if (background->type == NK_STYLE_ITEM_COLOR) { + nk_stroke_rect(out, bounds, style->rounding, style->border, style->border_color); + nk_fill_rect(out, bounds, style->rounding, background->data.color); + } else nk_draw_image(out, bounds, &background->data.image, nk_white);} + + area.w = NK_MAX(0, area.w - style->cursor_size); + if (edit->active) + { + int total_lines = 1; + struct nk_vec2 text_size = nk_vec2(0,0); + + /* text pointer positions */ + const char *cursor_ptr = 0; + const char *select_begin_ptr = 0; + const char *select_end_ptr = 0; + + /* 2D pixel positions */ + struct nk_vec2 cursor_pos = nk_vec2(0,0); + struct nk_vec2 selection_offset_start = nk_vec2(0,0); + struct nk_vec2 selection_offset_end = nk_vec2(0,0); + + int selection_begin = NK_MIN(edit->select_start, edit->select_end); + int selection_end = NK_MAX(edit->select_start, edit->select_end); + + /* calculate total line count + total space + cursor/selection position */ + float line_width = 0.0f; + if (text && len) + { + /* utf8 encoding */ + float glyph_width; + int glyph_len = 0; + nk_rune unicode = 0; + int text_len = 0; + int glyphs = 0; + int row_begin = 0; + + glyph_len = nk_utf_decode(text, &unicode, len); + glyph_width = font->width(font->userdata, font->height, text, glyph_len); + line_width = 0; + + /* iterate all lines */ + while ((text_len < len) && glyph_len) + { + /* set cursor 2D position and line */ + if (!cursor_ptr && glyphs == edit->cursor) + { + int glyph_offset; + struct nk_vec2 out_offset; + struct nk_vec2 row_size; + const char *remaining; + + /* calculate 2d position */ + cursor_pos.y = (float)(total_lines-1) * row_height; + row_size = nk_text_calculate_text_bounds(font, text+row_begin, + text_len-row_begin, row_height, &remaining, + &out_offset, &glyph_offset, NK_STOP_ON_NEW_LINE); + cursor_pos.x = row_size.x; + cursor_ptr = text + text_len; + } + + /* set start selection 2D position and line */ + if (!select_begin_ptr && edit->select_start != edit->select_end && + glyphs == selection_begin) + { + int glyph_offset; + struct nk_vec2 out_offset; + struct nk_vec2 row_size; + const char *remaining; + + /* calculate 2d position */ + selection_offset_start.y = (float)(NK_MAX(total_lines-1,0)) * row_height; + row_size = nk_text_calculate_text_bounds(font, text+row_begin, + text_len-row_begin, row_height, &remaining, + &out_offset, &glyph_offset, NK_STOP_ON_NEW_LINE); + selection_offset_start.x = row_size.x; + select_begin_ptr = text + text_len; + } + + /* set end selection 2D position and line */ + if (!select_end_ptr && edit->select_start != edit->select_end && + glyphs == selection_end) + { + int glyph_offset; + struct nk_vec2 out_offset; + struct nk_vec2 row_size; + const char *remaining; + + /* calculate 2d position */ + selection_offset_end.y = (float)(total_lines-1) * row_height; + row_size = nk_text_calculate_text_bounds(font, text+row_begin, + text_len-row_begin, row_height, &remaining, + &out_offset, &glyph_offset, NK_STOP_ON_NEW_LINE); + selection_offset_end.x = row_size.x; + select_end_ptr = text + text_len; + } + if (unicode == '\n') { + text_size.x = NK_MAX(text_size.x, line_width); + total_lines++; + line_width = 0; + text_len++; + glyphs++; + row_begin = text_len; + glyph_len = nk_utf_decode(text + text_len, &unicode, len-text_len); + glyph_width = font->width(font->userdata, font->height, text+text_len, glyph_len); + continue; + } + + glyphs++; + text_len += glyph_len; + line_width += (float)glyph_width; + + glyph_len = nk_utf_decode(text + text_len, &unicode, len-text_len); + glyph_width = font->width(font->userdata, font->height, + text+text_len, glyph_len); + continue; + } + text_size.y = (float)total_lines * row_height; + + /* handle case when cursor is at end of text buffer */ + if (!cursor_ptr && edit->cursor == edit->string.len) { + cursor_pos.x = line_width; + cursor_pos.y = text_size.y - row_height; + } + } + { + /* scrollbar */ + if (cursor_follow) + { + /* update scrollbar to follow cursor */ + if (!(flags & NK_EDIT_NO_HORIZONTAL_SCROLL)) { + /* horizontal scroll */ + const float scroll_increment = area.w * 0.25f; + if (cursor_pos.x < edit->scrollbar.x) + edit->scrollbar.x = (float)(int)NK_MAX(0.0f, cursor_pos.x - scroll_increment); + if (cursor_pos.x >= edit->scrollbar.x + area.w) + edit->scrollbar.x = (float)(int)NK_MAX(0.0f, cursor_pos.x); + } else edit->scrollbar.x = 0; + + if (flags & NK_EDIT_MULTILINE) { + /* vertical scroll */ + if (cursor_pos.y < edit->scrollbar.y) + edit->scrollbar.y = NK_MAX(0.0f, cursor_pos.y - row_height); + if (cursor_pos.y >= edit->scrollbar.y + area.h) + edit->scrollbar.y = edit->scrollbar.y + row_height; + } else edit->scrollbar.y = 0; + } + + /* scrollbar widget */ + if (flags & NK_EDIT_MULTILINE) + { + nk_flags ws; + struct nk_rect scroll; + float scroll_target; + float scroll_offset; + float scroll_step; + float scroll_inc; + + scroll = area; + scroll.x = (bounds.x + bounds.w - style->border) - style->scrollbar_size.x; + scroll.w = style->scrollbar_size.x; + + scroll_offset = edit->scrollbar.y; + scroll_step = scroll.h * 0.10f; + scroll_inc = scroll.h * 0.01f; + scroll_target = text_size.y; + edit->scrollbar.y = nk_do_scrollbarv(&ws, out, scroll, 0, + scroll_offset, scroll_target, scroll_step, scroll_inc, + &style->scrollbar, in, font); + } + } + + /* draw text */ + {struct nk_color background_color; + struct nk_color text_color; + struct nk_color sel_background_color; + struct nk_color sel_text_color; + struct nk_color cursor_color; + struct nk_color cursor_text_color; + const struct nk_style_item *background; + nk_push_scissor(out, clip); + + /* select correct colors to draw */ + if (*state & NK_WIDGET_STATE_ACTIVED) { + background = &style->active; + text_color = style->text_active; + sel_text_color = style->selected_text_hover; + sel_background_color = style->selected_hover; + cursor_color = style->cursor_hover; + cursor_text_color = style->cursor_text_hover; + } else if (*state & NK_WIDGET_STATE_HOVER) { + background = &style->hover; + text_color = style->text_hover; + sel_text_color = style->selected_text_hover; + sel_background_color = style->selected_hover; + cursor_text_color = style->cursor_text_hover; + cursor_color = style->cursor_hover; + } else { + background = &style->normal; + text_color = style->text_normal; + sel_text_color = style->selected_text_normal; + sel_background_color = style->selected_normal; + cursor_color = style->cursor_normal; + cursor_text_color = style->cursor_text_normal; + } + if (background->type == NK_STYLE_ITEM_IMAGE) + background_color = nk_rgba(0,0,0,0); + else background_color = background->data.color; + + + if (edit->select_start == edit->select_end) { + /* no selection so just draw the complete text */ + const char *begin = nk_str_get_const(&edit->string); + int l = nk_str_len_char(&edit->string); + nk_edit_draw_text(out, style, area.x - edit->scrollbar.x, + area.y - edit->scrollbar.y, 0, begin, l, row_height, font, + background_color, text_color, nk_false); + } else { + /* edit has selection so draw 1-3 text chunks */ + if (edit->select_start != edit->select_end && selection_begin > 0){ + /* draw unselected text before selection */ + const char *begin = nk_str_get_const(&edit->string); + NK_ASSERT(select_begin_ptr); + nk_edit_draw_text(out, style, area.x - edit->scrollbar.x, + area.y - edit->scrollbar.y, 0, begin, (int)(select_begin_ptr - begin), + row_height, font, background_color, text_color, nk_false); + } + if (edit->select_start != edit->select_end) { + /* draw selected text */ + NK_ASSERT(select_begin_ptr); + if (!select_end_ptr) { + const char *begin = nk_str_get_const(&edit->string); + select_end_ptr = begin + nk_str_len_char(&edit->string); + } + nk_edit_draw_text(out, style, + area.x - edit->scrollbar.x, + area.y + selection_offset_start.y - edit->scrollbar.y, + selection_offset_start.x, + select_begin_ptr, (int)(select_end_ptr - select_begin_ptr), + row_height, font, sel_background_color, sel_text_color, nk_true); + } + if ((edit->select_start != edit->select_end && + selection_end < edit->string.len)) + { + /* draw unselected text after selected text */ + const char *begin = select_end_ptr; + const char *end = nk_str_get_const(&edit->string) + + nk_str_len_char(&edit->string); + NK_ASSERT(select_end_ptr); + nk_edit_draw_text(out, style, + area.x - edit->scrollbar.x, + area.y + selection_offset_end.y - edit->scrollbar.y, + selection_offset_end.x, + begin, (int)(end - begin), row_height, font, + background_color, text_color, nk_true); + } + } + + /* cursor */ + if (edit->select_start == edit->select_end) + { + if (edit->cursor >= nk_str_len(&edit->string) || + (cursor_ptr && *cursor_ptr == '\n')) { + /* draw cursor at end of line */ + struct nk_rect cursor; + cursor.w = style->cursor_size; + cursor.h = font->height; + cursor.x = area.x + cursor_pos.x - edit->scrollbar.x; + cursor.y = area.y + cursor_pos.y + row_height/2.0f - cursor.h/2.0f; + cursor.y -= edit->scrollbar.y; + nk_fill_rect(out, cursor, 0, cursor_color); + } else { + /* draw cursor inside text */ + int glyph_len; + struct nk_rect label; + struct nk_text txt; + + nk_rune unicode; + NK_ASSERT(cursor_ptr); + glyph_len = nk_utf_decode(cursor_ptr, &unicode, 4); + + label.x = area.x + cursor_pos.x - edit->scrollbar.x; + label.y = area.y + cursor_pos.y - edit->scrollbar.y; + label.w = font->width(font->userdata, font->height, cursor_ptr, glyph_len); + label.h = row_height; + + txt.padding = nk_vec2(0,0); + txt.background = cursor_color;; + txt.text = cursor_text_color; + nk_fill_rect(out, label, 0, cursor_color); + nk_widget_text(out, label, cursor_ptr, glyph_len, &txt, NK_TEXT_LEFT, font); + } + }} + } else { + /* not active so just draw text */ + int l = nk_str_len_char(&edit->string); + const char *begin = nk_str_get_const(&edit->string); + + const struct nk_style_item *background; + struct nk_color background_color; + struct nk_color text_color; + nk_push_scissor(out, clip); + if (*state & NK_WIDGET_STATE_ACTIVED) { + background = &style->active; + text_color = style->text_active; + } else if (*state & NK_WIDGET_STATE_HOVER) { + background = &style->hover; + text_color = style->text_hover; + } else { + background = &style->normal; + text_color = style->text_normal; + } + if (background->type == NK_STYLE_ITEM_IMAGE) + background_color = nk_rgba(0,0,0,0); + else background_color = background->data.color; + nk_edit_draw_text(out, style, area.x - edit->scrollbar.x, + area.y - edit->scrollbar.y, 0, begin, l, row_height, font, + background_color, text_color, nk_false); + } + nk_push_scissor(out, old_clip);} + return ret; +} + +/* =============================================================== + * + * PROPERTY + * + * ===============================================================*/ +enum nk_property_status { + NK_PROPERTY_DEFAULT, + NK_PROPERTY_EDIT, + NK_PROPERTY_DRAG +}; +enum nk_property_filter { + NK_FILTER_INT, + NK_FILTER_FLOAT +}; +enum nk_property_kind { + NK_PROPERTY_INT, + NK_PROPERTY_FLOAT, + NK_PROPERTY_DOUBLE +}; +union nk_property { + int i; + float f; + double d; +}; +struct nk_property_variant { + enum nk_property_kind kind; + union nk_property value; + union nk_property min_value; + union nk_property max_value; + union nk_property step; +}; + +NK_INTERN void +nk_drag_behavior(nk_flags *state, const struct nk_input *in, + struct nk_rect drag, struct nk_property_variant *variant, + float inc_per_pixel) +{ + int left_mouse_down = in && in->mouse.buttons[NK_BUTTON_LEFT].down; + int left_mouse_click_in_cursor = in && + nk_input_has_mouse_click_down_in_rect(in, NK_BUTTON_LEFT, drag, nk_true); + + nk_widget_state_reset(state); + if (nk_input_is_mouse_hovering_rect(in, drag)) + *state = NK_WIDGET_STATE_HOVERED; + + if (left_mouse_down && left_mouse_click_in_cursor) { + float delta, pixels; + pixels = in->mouse.delta.x; + delta = pixels * inc_per_pixel; + switch (variant->kind) { + default: break; + case NK_PROPERTY_INT: + variant->value.i = variant->value.i + (int)delta; + variant->value.i = NK_CLAMP(variant->min_value.i, variant->value.i, variant->max_value.i); + break; + case NK_PROPERTY_FLOAT: + variant->value.f = variant->value.f + (float)delta; + variant->value.f = NK_CLAMP(variant->min_value.f, variant->value.f, variant->max_value.f); + break; + case NK_PROPERTY_DOUBLE: + variant->value.d = variant->value.d + (double)delta; + variant->value.d = NK_CLAMP(variant->min_value.d, variant->value.d, variant->max_value.d); + break; + } + *state = NK_WIDGET_STATE_ACTIVE; + } + if (*state & NK_WIDGET_STATE_HOVER && !nk_input_is_mouse_prev_hovering_rect(in, drag)) + *state |= NK_WIDGET_STATE_ENTERED; + else if (nk_input_is_mouse_prev_hovering_rect(in, drag)) + *state |= NK_WIDGET_STATE_LEFT; +} + +NK_INTERN void +nk_property_behavior(nk_flags *ws, const struct nk_input *in, + struct nk_rect property, struct nk_rect label, struct nk_rect edit, + struct nk_rect empty, int *state, struct nk_property_variant *variant, + float inc_per_pixel) +{ + if (in && *state == NK_PROPERTY_DEFAULT) { + if (nk_button_behavior(ws, edit, in, NK_BUTTON_DEFAULT)) + *state = NK_PROPERTY_EDIT; + else if (nk_input_is_mouse_click_down_in_rect(in, NK_BUTTON_LEFT, label, nk_true)) + *state = NK_PROPERTY_DRAG; + else if (nk_input_is_mouse_click_down_in_rect(in, NK_BUTTON_LEFT, empty, nk_true)) + *state = NK_PROPERTY_DRAG; + } + if (*state == NK_PROPERTY_DRAG) { + nk_drag_behavior(ws, in, property, variant, inc_per_pixel); + if (!(*ws & NK_WIDGET_STATE_ACTIVED)) *state = NK_PROPERTY_DEFAULT; + } +} + +NK_INTERN void +nk_draw_property(struct nk_command_buffer *out, const struct nk_style_property *style, + const struct nk_rect *bounds, const struct nk_rect *label, nk_flags state, + const char *name, int len, const struct nk_user_font *font) +{ + struct nk_text text; + const struct nk_style_item *background; + + /* select correct background and text color */ + if (state & NK_WIDGET_STATE_ACTIVED) { + background = &style->active; + text.text = style->label_active; + } else if (state & NK_WIDGET_STATE_HOVER) { + background = &style->hover; + text.text = style->label_hover; + } else { + background = &style->normal; + text.text = style->label_normal; + } + + /* draw background */ + if (background->type == NK_STYLE_ITEM_IMAGE) { + nk_draw_image(out, *bounds, &background->data.image, nk_white); + text.background = nk_rgba(0,0,0,0); + } else { + text.background = background->data.color; + nk_fill_rect(out, *bounds, style->rounding, background->data.color); + nk_stroke_rect(out, *bounds, style->rounding, style->border, background->data.color); + } + + /* draw label */ + text.padding = nk_vec2(0,0); + nk_widget_text(out, *label, name, len, &text, NK_TEXT_CENTERED, font); +} + +NK_INTERN void +nk_do_property(nk_flags *ws, + struct nk_command_buffer *out, struct nk_rect property, + const char *name, struct nk_property_variant *variant, + float inc_per_pixel, char *buffer, int *len, + int *state, int *cursor, int *select_begin, int *select_end, + const struct nk_style_property *style, + enum nk_property_filter filter, struct nk_input *in, + const struct nk_user_font *font, struct nk_text_edit *text_edit, + enum nk_button_behavior behavior) +{ + const nk_plugin_filter filters[] = { + nk_filter_decimal, + nk_filter_float + }; + int active, old; + int num_len, name_len; + char string[NK_MAX_NUMBER_BUFFER]; + float size; + + char *dst = 0; + int *length; + + struct nk_rect left; + struct nk_rect right; + struct nk_rect label; + struct nk_rect edit; + struct nk_rect empty; + + /* left decrement button */ + left.h = font->height/2; + left.w = left.h; + left.x = property.x + style->border + style->padding.x; + left.y = property.y + style->border + property.h/2.0f - left.h/2; + + /* text label */ + name_len = nk_strlen(name); + size = font->width(font->userdata, font->height, name, name_len); + label.x = left.x + left.w + style->padding.x; + label.w = (float)size + 2 * style->padding.x; + label.y = property.y + style->border + style->padding.y; + label.h = property.h - (2 * style->border + 2 * style->padding.y); + + /* right increment button */ + right.y = left.y; + right.w = left.w; + right.h = left.h; + right.x = property.x + property.w - (right.w + style->padding.x); + + /* edit */ + if (*state == NK_PROPERTY_EDIT) { + size = font->width(font->userdata, font->height, buffer, *len); + size += style->edit.cursor_size; + length = len; + dst = buffer; + } else { + switch (variant->kind) { + default: break; + case NK_PROPERTY_INT: + nk_itoa(string, variant->value.i); + num_len = nk_strlen(string); + break; + case NK_PROPERTY_FLOAT: + NK_DTOA(string, (double)variant->value.f); + num_len = nk_string_float_limit(string, NK_MAX_FLOAT_PRECISION); + break; + case NK_PROPERTY_DOUBLE: + NK_DTOA(string, variant->value.d); + num_len = nk_string_float_limit(string, NK_MAX_FLOAT_PRECISION); + break; + } + size = font->width(font->userdata, font->height, string, num_len); + dst = string; + length = &num_len; + } + + edit.w = (float)size + 2 * style->padding.x; + edit.w = NK_MIN(edit.w, right.x - (label.x + label.w)); + edit.x = right.x - (edit.w + style->padding.x); + edit.y = property.y + style->border; + edit.h = property.h - (2 * style->border); + + /* empty left space activator */ + empty.w = edit.x - (label.x + label.w); + empty.x = label.x + label.w; + empty.y = property.y; + empty.h = property.h; + + /* update property */ + old = (*state == NK_PROPERTY_EDIT); + nk_property_behavior(ws, in, property, label, edit, empty, state, variant, inc_per_pixel); + + /* draw property */ + if (style->draw_begin) style->draw_begin(out, style->userdata); + nk_draw_property(out, style, &property, &label, *ws, name, name_len, font); + if (style->draw_end) style->draw_end(out, style->userdata); + + /* execute right button */ + if (nk_do_button_symbol(ws, out, left, style->sym_left, behavior, &style->dec_button, in, font)) { + switch (variant->kind) { + default: break; + case NK_PROPERTY_INT: + variant->value.i = NK_CLAMP(variant->min_value.i, variant->value.i - variant->step.i, variant->max_value.i); break; + case NK_PROPERTY_FLOAT: + variant->value.f = NK_CLAMP(variant->min_value.f, variant->value.f - variant->step.f, variant->max_value.f); break; + case NK_PROPERTY_DOUBLE: + variant->value.d = NK_CLAMP(variant->min_value.d, variant->value.d - variant->step.d, variant->max_value.d); break; + } + } + /* execute left button */ + if (nk_do_button_symbol(ws, out, right, style->sym_right, behavior, &style->inc_button, in, font)) { + switch (variant->kind) { + default: break; + case NK_PROPERTY_INT: + variant->value.i = NK_CLAMP(variant->min_value.i, variant->value.i + variant->step.i, variant->max_value.i); break; + case NK_PROPERTY_FLOAT: + variant->value.f = NK_CLAMP(variant->min_value.f, variant->value.f + variant->step.f, variant->max_value.f); break; + case NK_PROPERTY_DOUBLE: + variant->value.d = NK_CLAMP(variant->min_value.d, variant->value.d + variant->step.d, variant->max_value.d); break; + } + } + if (old != NK_PROPERTY_EDIT && (*state == NK_PROPERTY_EDIT)) { + /* property has been activated so setup buffer */ + NK_MEMCPY(buffer, dst, (nk_size)*length); + *cursor = nk_utf_len(buffer, *length); + *len = *length; + length = len; + dst = buffer; + active = 0; + } else active = (*state == NK_PROPERTY_EDIT); + + /* execute and run text edit field */ + nk_textedit_clear_state(text_edit, NK_TEXT_EDIT_SINGLE_LINE, filters[filter]); + text_edit->active = (unsigned char)active; + text_edit->string.len = *length; + text_edit->cursor = NK_CLAMP(0, *cursor, *length); + text_edit->select_start = NK_CLAMP(0,*select_begin, *length); + text_edit->select_end = NK_CLAMP(0,*select_end, *length); + text_edit->string.buffer.allocated = (nk_size)*length; + text_edit->string.buffer.memory.size = NK_MAX_NUMBER_BUFFER; + text_edit->string.buffer.memory.ptr = dst; + text_edit->string.buffer.size = NK_MAX_NUMBER_BUFFER; + text_edit->mode = NK_TEXT_EDIT_MODE_INSERT; + nk_do_edit(ws, out, edit, NK_EDIT_FIELD|NK_EDIT_AUTO_SELECT, + filters[filter], text_edit, &style->edit, (*state == NK_PROPERTY_EDIT) ? in: 0, font); + + *length = text_edit->string.len; + *cursor = text_edit->cursor; + *select_begin = text_edit->select_start; + *select_end = text_edit->select_end; + if (text_edit->active && nk_input_is_key_pressed(in, NK_KEY_ENTER)) + text_edit->active = nk_false; + + if (active && !text_edit->active) { + /* property is now not active so convert edit text to value*/ + *state = NK_PROPERTY_DEFAULT; + buffer[*len] = '\0'; + switch (variant->kind) { + default: break; + case NK_PROPERTY_INT: + variant->value.i = nk_strtoi(buffer, 0); + variant->value.i = NK_CLAMP(variant->min_value.i, variant->value.i, variant->max_value.i); + break; + case NK_PROPERTY_FLOAT: + nk_string_float_limit(buffer, NK_MAX_FLOAT_PRECISION); + variant->value.f = nk_strtof(buffer, 0); + variant->value.f = NK_CLAMP(variant->min_value.f, variant->value.f, variant->max_value.f); + break; + case NK_PROPERTY_DOUBLE: + nk_string_float_limit(buffer, NK_MAX_FLOAT_PRECISION); + variant->value.d = nk_strtod(buffer, 0); + variant->value.d = NK_CLAMP(variant->min_value.d, variant->value.d, variant->max_value.d); + break; + } + } +} +/* =============================================================== + * + * COLOR PICKER + * + * ===============================================================*/ +NK_INTERN int +nk_color_picker_behavior(nk_flags *state, + const struct nk_rect *bounds, const struct nk_rect *matrix, + const struct nk_rect *hue_bar, const struct nk_rect *alpha_bar, + struct nk_color *color, const struct nk_input *in) +{ + float hsva[4]; + int value_changed = 0; + int hsv_changed = 0; + + NK_ASSERT(state); + NK_ASSERT(matrix); + NK_ASSERT(hue_bar); + NK_ASSERT(color); + + /* color matrix */ + nk_color_hsva_fv(hsva, *color); + if (nk_button_behavior(state, *matrix, in, NK_BUTTON_REPEATER)) { + hsva[1] = NK_SATURATE((in->mouse.pos.x - matrix->x) / (matrix->w-1)); + hsva[2] = 1.0f - NK_SATURATE((in->mouse.pos.y - matrix->y) / (matrix->h-1)); + value_changed = hsv_changed = 1; + } + + /* hue bar */ + if (nk_button_behavior(state, *hue_bar, in, NK_BUTTON_REPEATER)) { + hsva[0] = NK_SATURATE((in->mouse.pos.y - hue_bar->y) / (hue_bar->h-1)); + value_changed = hsv_changed = 1; + } + + /* alpha bar */ + if (alpha_bar) { + if (nk_button_behavior(state, *alpha_bar, in, NK_BUTTON_REPEATER)) { + hsva[3] = 1.0f - NK_SATURATE((in->mouse.pos.y - alpha_bar->y) / (alpha_bar->h-1)); + value_changed = 1; + } + } + nk_widget_state_reset(state); + if (hsv_changed) { + *color = nk_hsva_fv(hsva); + *state = NK_WIDGET_STATE_ACTIVE; + } + if (value_changed) { + color->a = (nk_byte)(hsva[3] * 255.0f); + *state = NK_WIDGET_STATE_ACTIVE; + } + + /* set color picker widget state */ + if (nk_input_is_mouse_hovering_rect(in, *bounds)) + *state = NK_WIDGET_STATE_HOVERED; + if (*state & NK_WIDGET_STATE_HOVER && !nk_input_is_mouse_prev_hovering_rect(in, *bounds)) + *state |= NK_WIDGET_STATE_ENTERED; + else if (nk_input_is_mouse_prev_hovering_rect(in, *bounds)) + *state |= NK_WIDGET_STATE_LEFT; + return value_changed; +} + +NK_INTERN void +nk_draw_color_picker(struct nk_command_buffer *o, const struct nk_rect *matrix, + const struct nk_rect *hue_bar, const struct nk_rect *alpha_bar, + struct nk_color color) +{ + NK_STORAGE const struct nk_color black = {0,0,0,255}; + NK_STORAGE const struct nk_color white = {255, 255, 255, 255}; + NK_STORAGE const struct nk_color black_trans = {0,0,0,0}; + + const float crosshair_size = 7.0f; + struct nk_color temp; + float hsva[4]; + float line_y; + int i; + + NK_ASSERT(o); + NK_ASSERT(matrix); + NK_ASSERT(hue_bar); + + /* draw hue bar */ + nk_color_hsv_fv(hsva, color); + for (i = 0; i < 6; ++i) { + NK_GLOBAL const struct nk_color hue_colors[] = { + {255, 0, 0, 255}, + {255,255,0,255}, + {0,255,0,255}, + {0, 255,255,255}, + {0,0,255,255}, + {255, 0, 255, 255}, + {255, 0, 0, 255} + }; + nk_fill_rect_multi_color(o, + nk_rect(hue_bar->x, hue_bar->y + (float)i * (hue_bar->h/6.0f) + 0.5f, + hue_bar->w, (hue_bar->h/6.0f) + 0.5f), hue_colors[i], hue_colors[i], + hue_colors[i+1], hue_colors[i+1]); + } + line_y = (float)(int)(hue_bar->y + hsva[0] * matrix->h + 0.5f); + nk_stroke_line(o, hue_bar->x-1, line_y, hue_bar->x + hue_bar->w + 2, + line_y, 1, nk_rgb(255,255,255)); + + /* draw alpha bar */ + if (alpha_bar) { + float alpha = NK_SATURATE((float)color.a/255.0f); + line_y = (float)(int)(alpha_bar->y + (1.0f - alpha) * matrix->h + 0.5f); + + nk_fill_rect_multi_color(o, *alpha_bar, white, white, black, black); + nk_stroke_line(o, alpha_bar->x-1, line_y, alpha_bar->x + alpha_bar->w + 2, + line_y, 1, nk_rgb(255,255,255)); + } + + /* draw color matrix */ + temp = nk_hsv_f(hsva[0], 1.0f, 1.0f); + nk_fill_rect_multi_color(o, *matrix, white, temp, temp, white); + nk_fill_rect_multi_color(o, *matrix, black_trans, black_trans, black, black); + + /* draw cross-hair */ + {struct nk_vec2 p; float S = hsva[1]; float V = hsva[2]; + p.x = (float)(int)(matrix->x + S * matrix->w); + p.y = (float)(int)(matrix->y + (1.0f - V) * matrix->h); + nk_stroke_line(o, p.x - crosshair_size, p.y, p.x-2, p.y, 1.0f, white); + nk_stroke_line(o, p.x + crosshair_size + 1, p.y, p.x+3, p.y, 1.0f, white); + nk_stroke_line(o, p.x, p.y + crosshair_size + 1, p.x, p.y+3, 1.0f, white); + nk_stroke_line(o, p.x, p.y - crosshair_size, p.x, p.y-2, 1.0f, white);} +} + +NK_INTERN int +nk_do_color_picker(nk_flags *state, + struct nk_command_buffer *out, struct nk_color *color, + enum nk_color_format fmt, struct nk_rect bounds, + struct nk_vec2 padding, const struct nk_input *in, + const struct nk_user_font *font) +{ + int ret = 0; + struct nk_rect matrix; + struct nk_rect hue_bar; + struct nk_rect alpha_bar; + float bar_w; + + NK_ASSERT(out); + NK_ASSERT(color); + NK_ASSERT(state); + NK_ASSERT(font); + if (!out || !color || !state || !font) + return ret; + + bar_w = font->height; + bounds.x += padding.x; + bounds.y += padding.x; + bounds.w -= 2 * padding.x; + bounds.h -= 2 * padding.y; + + matrix.x = bounds.x; + matrix.y = bounds.y; + matrix.h = bounds.h; + matrix.w = bounds.w - (3 * padding.x + 2 * bar_w); + + hue_bar.w = bar_w; + hue_bar.y = bounds.y; + hue_bar.h = matrix.h; + hue_bar.x = matrix.x + matrix.w + padding.x; + + alpha_bar.x = hue_bar.x + hue_bar.w + padding.x; + alpha_bar.y = bounds.y; + alpha_bar.w = bar_w; + alpha_bar.h = matrix.h; + + ret = nk_color_picker_behavior(state, &bounds, &matrix, &hue_bar, + (fmt == NK_RGBA) ? &alpha_bar:0, color, in); + nk_draw_color_picker(out, &matrix, &hue_bar, (fmt == NK_RGBA) ? &alpha_bar:0, *color); + return ret; +} + +/* ============================================================== + * + * STYLE + * + * ===============================================================*/ +NK_API void nk_style_default(struct nk_context *ctx){nk_style_from_table(ctx, 0);} +#define NK_COLOR_MAP(NK_COLOR)\ + NK_COLOR(NK_COLOR_TEXT, 175,175,175,255) \ + NK_COLOR(NK_COLOR_WINDOW, 45, 45, 45, 255) \ + NK_COLOR(NK_COLOR_HEADER, 40, 40, 40, 255) \ + NK_COLOR(NK_COLOR_BORDER, 65, 65, 65, 255) \ + NK_COLOR(NK_COLOR_BUTTON, 50, 50, 50, 255) \ + NK_COLOR(NK_COLOR_BUTTON_HOVER, 40, 40, 40, 255) \ + NK_COLOR(NK_COLOR_BUTTON_ACTIVE, 35, 35, 35, 255) \ + NK_COLOR(NK_COLOR_TOGGLE, 100,100,100,255) \ + NK_COLOR(NK_COLOR_TOGGLE_HOVER, 120,120,120,255) \ + NK_COLOR(NK_COLOR_TOGGLE_CURSOR, 45, 45, 45, 255) \ + NK_COLOR(NK_COLOR_SELECT, 45, 45, 45, 255) \ + NK_COLOR(NK_COLOR_SELECT_ACTIVE, 35, 35, 35,255) \ + NK_COLOR(NK_COLOR_SLIDER, 38, 38, 38, 255) \ + NK_COLOR(NK_COLOR_SLIDER_CURSOR, 100,100,100,255) \ + NK_COLOR(NK_COLOR_SLIDER_CURSOR_HOVER, 120,120,120,255) \ + NK_COLOR(NK_COLOR_SLIDER_CURSOR_ACTIVE, 150,150,150,255) \ + NK_COLOR(NK_COLOR_PROPERTY, 38, 38, 38, 255) \ + NK_COLOR(NK_COLOR_EDIT, 38, 38, 38, 255) \ + NK_COLOR(NK_COLOR_EDIT_CURSOR, 175,175,175,255) \ + NK_COLOR(NK_COLOR_COMBO, 45, 45, 45, 255) \ + NK_COLOR(NK_COLOR_CHART, 120,120,120,255) \ + NK_COLOR(NK_COLOR_CHART_COLOR, 45, 45, 45, 255) \ + NK_COLOR(NK_COLOR_CHART_COLOR_HIGHLIGHT,255, 0, 0, 255) \ + NK_COLOR(NK_COLOR_SCROLLBAR, 40, 40, 40, 255) \ + NK_COLOR(NK_COLOR_SCROLLBAR_CURSOR, 100,100,100,255) \ + NK_COLOR(NK_COLOR_SCROLLBAR_CURSOR_HOVER,120,120,120,255) \ + NK_COLOR(NK_COLOR_SCROLLBAR_CURSOR_ACTIVE,150,150,150,255) \ + NK_COLOR(NK_COLOR_TAB_HEADER, 40, 40, 40,255) + +NK_GLOBAL const struct nk_color +nk_default_color_style[NK_COLOR_COUNT] = { +#define NK_COLOR(a,b,c,d,e) {b,c,d,e}, + NK_COLOR_MAP(NK_COLOR) +#undef NK_COLOR +}; + +NK_GLOBAL const char *nk_color_names[NK_COLOR_COUNT] = { +#define NK_COLOR(a,b,c,d,e) #a, + NK_COLOR_MAP(NK_COLOR) +#undef NK_COLOR +}; + +NK_API const char *nk_style_get_color_by_name(enum nk_style_colors c) +{return nk_color_names[c];} + +NK_API struct nk_style_item nk_style_item_image(struct nk_image img) +{struct nk_style_item i; i.type = NK_STYLE_ITEM_IMAGE; i.data.image = img; return i;} + +NK_API struct nk_style_item nk_style_item_color(struct nk_color col) +{struct nk_style_item i; i.type = NK_STYLE_ITEM_COLOR; i.data.color = col; return i;} + +NK_API struct nk_style_item nk_style_item_hide(void) +{struct nk_style_item i; i.type = NK_STYLE_ITEM_COLOR; i.data.color = nk_rgba(0,0,0,0); return i;} + +NK_API void +nk_style_from_table(struct nk_context *ctx, const struct nk_color *table) +{ + struct nk_style *style; + struct nk_style_text *text; + struct nk_style_button *button; + struct nk_style_toggle *toggle; + struct nk_style_selectable *select; + struct nk_style_slider *slider; + struct nk_style_progress *prog; + struct nk_style_scrollbar *scroll; + struct nk_style_edit *edit; + struct nk_style_property *property; + struct nk_style_combo *combo; + struct nk_style_chart *chart; + struct nk_style_tab *tab; + struct nk_style_window *win; + + NK_ASSERT(ctx); + if (!ctx) return; + style = &ctx->style; + table = (!table) ? nk_default_color_style: table; + + /* default text */ + text = &style->text; + text->color = table[NK_COLOR_TEXT]; + text->padding = nk_vec2(0,0); + + /* default button */ + button = &style->button; + nk_zero_struct(*button); + button->normal = nk_style_item_color(table[NK_COLOR_BUTTON]); + button->hover = nk_style_item_color(table[NK_COLOR_BUTTON_HOVER]); + button->active = nk_style_item_color(table[NK_COLOR_BUTTON_ACTIVE]); + button->border_color = table[NK_COLOR_BORDER]; + button->text_background = table[NK_COLOR_BUTTON]; + button->text_normal = table[NK_COLOR_TEXT]; + button->text_hover = table[NK_COLOR_TEXT]; + button->text_active = table[NK_COLOR_TEXT]; + button->padding = nk_vec2(2.0f,2.0f); + button->image_padding = nk_vec2(0.0f,0.0f); + button->touch_padding = nk_vec2(0.0f, 0.0f); + button->userdata = nk_handle_ptr(0); + button->text_alignment = NK_TEXT_CENTERED; + button->border = 1.0f; + button->rounding = 4.0f; + button->draw_begin = 0; + button->draw_end = 0; + + /* contextual button */ + button = &style->contextual_button; + nk_zero_struct(*button); + button->normal = nk_style_item_color(table[NK_COLOR_WINDOW]); + button->hover = nk_style_item_color(table[NK_COLOR_BUTTON_HOVER]); + button->active = nk_style_item_color(table[NK_COLOR_BUTTON_ACTIVE]); + button->border_color = table[NK_COLOR_WINDOW]; + button->text_background = table[NK_COLOR_WINDOW]; + button->text_normal = table[NK_COLOR_TEXT]; + button->text_hover = table[NK_COLOR_TEXT]; + button->text_active = table[NK_COLOR_TEXT]; + button->padding = nk_vec2(2.0f,2.0f); + button->touch_padding = nk_vec2(0.0f,0.0f); + button->userdata = nk_handle_ptr(0); + button->text_alignment = NK_TEXT_CENTERED; + button->border = 0.0f; + button->rounding = 0.0f; + button->draw_begin = 0; + button->draw_end = 0; + + /* menu button */ + button = &style->menu_button; + nk_zero_struct(*button); + button->normal = nk_style_item_color(table[NK_COLOR_WINDOW]); + button->hover = nk_style_item_color(table[NK_COLOR_WINDOW]); + button->active = nk_style_item_color(table[NK_COLOR_WINDOW]); + button->border_color = table[NK_COLOR_WINDOW]; + button->text_background = table[NK_COLOR_WINDOW]; + button->text_normal = table[NK_COLOR_TEXT]; + button->text_hover = table[NK_COLOR_TEXT]; + button->text_active = table[NK_COLOR_TEXT]; + button->padding = nk_vec2(2.0f,2.0f); + button->touch_padding = nk_vec2(0.0f,0.0f); + button->userdata = nk_handle_ptr(0); + button->text_alignment = NK_TEXT_CENTERED; + button->border = 0.0f; + button->rounding = 1.0f; + button->draw_begin = 0; + button->draw_end = 0; + + /* checkbox toggle */ + toggle = &style->checkbox; + nk_zero_struct(*toggle); + toggle->normal = nk_style_item_color(table[NK_COLOR_TOGGLE]); + toggle->hover = nk_style_item_color(table[NK_COLOR_TOGGLE_HOVER]); + toggle->active = nk_style_item_color(table[NK_COLOR_TOGGLE_HOVER]); + toggle->cursor_normal = nk_style_item_color(table[NK_COLOR_TOGGLE_CURSOR]); + toggle->cursor_hover = nk_style_item_color(table[NK_COLOR_TOGGLE_CURSOR]); + toggle->userdata = nk_handle_ptr(0); + toggle->text_background = table[NK_COLOR_WINDOW]; + toggle->text_normal = table[NK_COLOR_TEXT]; + toggle->text_hover = table[NK_COLOR_TEXT]; + toggle->text_active = table[NK_COLOR_TEXT]; + toggle->padding = nk_vec2(2.0f, 2.0f); + toggle->touch_padding = nk_vec2(0,0); + toggle->border_color = nk_rgba(0,0,0,0); + toggle->border = 0.0f; + toggle->spacing = 4; + + /* option toggle */ + toggle = &style->option; + nk_zero_struct(*toggle); + toggle->normal = nk_style_item_color(table[NK_COLOR_TOGGLE]); + toggle->hover = nk_style_item_color(table[NK_COLOR_TOGGLE_HOVER]); + toggle->active = nk_style_item_color(table[NK_COLOR_TOGGLE_HOVER]); + toggle->cursor_normal = nk_style_item_color(table[NK_COLOR_TOGGLE_CURSOR]); + toggle->cursor_hover = nk_style_item_color(table[NK_COLOR_TOGGLE_CURSOR]); + toggle->userdata = nk_handle_ptr(0); + toggle->text_background = table[NK_COLOR_WINDOW]; + toggle->text_normal = table[NK_COLOR_TEXT]; + toggle->text_hover = table[NK_COLOR_TEXT]; + toggle->text_active = table[NK_COLOR_TEXT]; + toggle->padding = nk_vec2(3.0f, 3.0f); + toggle->touch_padding = nk_vec2(0,0); + toggle->border_color = nk_rgba(0,0,0,0); + toggle->border = 0.0f; + toggle->spacing = 4; + + /* selectable */ + select = &style->selectable; + nk_zero_struct(*select); + select->normal = nk_style_item_color(table[NK_COLOR_SELECT]); + select->hover = nk_style_item_color(table[NK_COLOR_SELECT]); + select->pressed = nk_style_item_color(table[NK_COLOR_SELECT]); + select->normal_active = nk_style_item_color(table[NK_COLOR_SELECT_ACTIVE]); + select->hover_active = nk_style_item_color(table[NK_COLOR_SELECT_ACTIVE]); + select->pressed_active = nk_style_item_color(table[NK_COLOR_SELECT_ACTIVE]); + select->text_normal = table[NK_COLOR_TEXT]; + select->text_hover = table[NK_COLOR_TEXT]; + select->text_pressed = table[NK_COLOR_TEXT]; + select->text_normal_active = table[NK_COLOR_TEXT]; + select->text_hover_active = table[NK_COLOR_TEXT]; + select->text_pressed_active = table[NK_COLOR_TEXT]; + select->padding = nk_vec2(2.0f,2.0f); + select->touch_padding = nk_vec2(0,0); + select->userdata = nk_handle_ptr(0); + select->rounding = 0.0f; + select->draw_begin = 0; + select->draw_end = 0; + + /* slider */ + slider = &style->slider; + nk_zero_struct(*slider); + slider->normal = nk_style_item_hide(); + slider->hover = nk_style_item_hide(); + slider->active = nk_style_item_hide(); + slider->bar_normal = table[NK_COLOR_SLIDER]; + slider->bar_hover = table[NK_COLOR_SLIDER]; + slider->bar_active = table[NK_COLOR_SLIDER]; + slider->bar_filled = table[NK_COLOR_SLIDER_CURSOR]; + slider->cursor_normal = nk_style_item_color(table[NK_COLOR_SLIDER_CURSOR]); + slider->cursor_hover = nk_style_item_color(table[NK_COLOR_SLIDER_CURSOR_HOVER]); + slider->cursor_active = nk_style_item_color(table[NK_COLOR_SLIDER_CURSOR_ACTIVE]); + slider->inc_symbol = NK_SYMBOL_TRIANGLE_RIGHT; + slider->dec_symbol = NK_SYMBOL_TRIANGLE_LEFT; + slider->cursor_size = nk_vec2(16,16); + slider->padding = nk_vec2(2,2); + slider->spacing = nk_vec2(2,2); + slider->userdata = nk_handle_ptr(0); + slider->show_buttons = nk_false; + slider->bar_height = 8; + slider->rounding = 0; + slider->draw_begin = 0; + slider->draw_end = 0; + + /* slider buttons */ + button = &style->slider.inc_button; + button->normal = nk_style_item_color(nk_rgb(40,40,40)); + button->hover = nk_style_item_color(nk_rgb(42,42,42)); + button->active = nk_style_item_color(nk_rgb(44,44,44)); + button->border_color = nk_rgb(65,65,65); + button->text_background = nk_rgb(40,40,40); + button->text_normal = nk_rgb(175,175,175); + button->text_hover = nk_rgb(175,175,175); + button->text_active = nk_rgb(175,175,175); + button->padding = nk_vec2(8.0f,8.0f); + button->touch_padding = nk_vec2(0.0f,0.0f); + button->userdata = nk_handle_ptr(0); + button->text_alignment = NK_TEXT_CENTERED; + button->border = 1.0f; + button->rounding = 0.0f; + button->draw_begin = 0; + button->draw_end = 0; + style->slider.dec_button = style->slider.inc_button; + + /* progressbar */ + prog = &style->progress; + nk_zero_struct(*prog); + prog->normal = nk_style_item_color(table[NK_COLOR_SLIDER]); + prog->hover = nk_style_item_color(table[NK_COLOR_SLIDER]); + prog->active = nk_style_item_color(table[NK_COLOR_SLIDER]); + prog->cursor_normal = nk_style_item_color(table[NK_COLOR_SLIDER_CURSOR]); + prog->cursor_hover = nk_style_item_color(table[NK_COLOR_SLIDER_CURSOR_HOVER]); + prog->cursor_active = nk_style_item_color(table[NK_COLOR_SLIDER_CURSOR_ACTIVE]); + prog->border_color = nk_rgba(0,0,0,0); + prog->cursor_border_color = nk_rgba(0,0,0,0); + prog->userdata = nk_handle_ptr(0); + prog->padding = nk_vec2(4,4); + prog->rounding = 0; + prog->border = 0; + prog->cursor_rounding = 0; + prog->cursor_border = 0; + prog->draw_begin = 0; + prog->draw_end = 0; + + /* scrollbars */ + scroll = &style->scrollh; + nk_zero_struct(*scroll); + scroll->normal = nk_style_item_color(table[NK_COLOR_SCROLLBAR]); + scroll->hover = nk_style_item_color(table[NK_COLOR_SCROLLBAR]); + scroll->active = nk_style_item_color(table[NK_COLOR_SCROLLBAR]); + scroll->cursor_normal = nk_style_item_color(table[NK_COLOR_SCROLLBAR_CURSOR]); + scroll->cursor_hover = nk_style_item_color(table[NK_COLOR_SCROLLBAR_CURSOR_HOVER]); + scroll->cursor_active = nk_style_item_color(table[NK_COLOR_SCROLLBAR_CURSOR_ACTIVE]); + scroll->dec_symbol = NK_SYMBOL_CIRCLE_SOLID; + scroll->inc_symbol = NK_SYMBOL_CIRCLE_SOLID; + scroll->userdata = nk_handle_ptr(0); + scroll->border_color = table[NK_COLOR_SCROLLBAR]; + scroll->cursor_border_color = table[NK_COLOR_SCROLLBAR]; + scroll->padding = nk_vec2(0,0); + scroll->show_buttons = nk_false; + scroll->border = 0; + scroll->rounding = 0; + scroll->border_cursor = 0; + scroll->rounding_cursor = 0; + scroll->draw_begin = 0; + scroll->draw_end = 0; + style->scrollv = style->scrollh; + + /* scrollbars buttons */ + button = &style->scrollh.inc_button; + button->normal = nk_style_item_color(nk_rgb(40,40,40)); + button->hover = nk_style_item_color(nk_rgb(42,42,42)); + button->active = nk_style_item_color(nk_rgb(44,44,44)); + button->border_color = nk_rgb(65,65,65); + button->text_background = nk_rgb(40,40,40); + button->text_normal = nk_rgb(175,175,175); + button->text_hover = nk_rgb(175,175,175); + button->text_active = nk_rgb(175,175,175); + button->padding = nk_vec2(4.0f,4.0f); + button->touch_padding = nk_vec2(0.0f,0.0f); + button->userdata = nk_handle_ptr(0); + button->text_alignment = NK_TEXT_CENTERED; + button->border = 1.0f; + button->rounding = 0.0f; + button->draw_begin = 0; + button->draw_end = 0; + style->scrollh.dec_button = style->scrollh.inc_button; + style->scrollv.inc_button = style->scrollh.inc_button; + style->scrollv.dec_button = style->scrollh.inc_button; + + /* edit */ + edit = &style->edit; + nk_zero_struct(*edit); + edit->normal = nk_style_item_color(table[NK_COLOR_EDIT]); + edit->hover = nk_style_item_color(table[NK_COLOR_EDIT]); + edit->active = nk_style_item_color(table[NK_COLOR_EDIT]); + edit->cursor_normal = table[NK_COLOR_TEXT]; + edit->cursor_hover = table[NK_COLOR_TEXT]; + edit->cursor_text_normal= table[NK_COLOR_EDIT]; + edit->cursor_text_hover = table[NK_COLOR_EDIT]; + edit->border_color = table[NK_COLOR_BORDER]; + edit->text_normal = table[NK_COLOR_TEXT]; + edit->text_hover = table[NK_COLOR_TEXT]; + edit->text_active = table[NK_COLOR_TEXT]; + edit->selected_normal = table[NK_COLOR_TEXT]; + edit->selected_hover = table[NK_COLOR_TEXT]; + edit->selected_text_normal = table[NK_COLOR_EDIT]; + edit->selected_text_hover = table[NK_COLOR_EDIT]; + edit->scrollbar_size = nk_vec2(10,10); + edit->scrollbar = style->scrollv; + edit->padding = nk_vec2(4,4); + edit->row_padding = 2; + edit->cursor_size = 4; + edit->border = 1; + edit->rounding = 0; + + /* property */ + property = &style->property; + nk_zero_struct(*property); + property->normal = nk_style_item_color(table[NK_COLOR_PROPERTY]); + property->hover = nk_style_item_color(table[NK_COLOR_PROPERTY]); + property->active = nk_style_item_color(table[NK_COLOR_PROPERTY]); + property->border_color = table[NK_COLOR_BORDER]; + property->label_normal = table[NK_COLOR_TEXT]; + property->label_hover = table[NK_COLOR_TEXT]; + property->label_active = table[NK_COLOR_TEXT]; + property->sym_left = NK_SYMBOL_TRIANGLE_LEFT; + property->sym_right = NK_SYMBOL_TRIANGLE_RIGHT; + property->userdata = nk_handle_ptr(0); + property->padding = nk_vec2(4,4); + property->border = 1; + property->rounding = 10; + property->draw_begin = 0; + property->draw_end = 0; + + /* property buttons */ + button = &style->property.dec_button; + nk_zero_struct(*button); + button->normal = nk_style_item_color(table[NK_COLOR_PROPERTY]); + button->hover = nk_style_item_color(table[NK_COLOR_PROPERTY]); + button->active = nk_style_item_color(table[NK_COLOR_PROPERTY]); + button->border_color = nk_rgba(0,0,0,0); + button->text_background = table[NK_COLOR_PROPERTY]; + button->text_normal = table[NK_COLOR_TEXT]; + button->text_hover = table[NK_COLOR_TEXT]; + button->text_active = table[NK_COLOR_TEXT]; + button->padding = nk_vec2(0.0f,0.0f); + button->touch_padding = nk_vec2(0.0f,0.0f); + button->userdata = nk_handle_ptr(0); + button->text_alignment = NK_TEXT_CENTERED; + button->border = 0.0f; + button->rounding = 0.0f; + button->draw_begin = 0; + button->draw_end = 0; + style->property.inc_button = style->property.dec_button; + + /* property edit */ + edit = &style->property.edit; + nk_zero_struct(*edit); + edit->normal = nk_style_item_color(table[NK_COLOR_PROPERTY]); + edit->hover = nk_style_item_color(table[NK_COLOR_PROPERTY]); + edit->active = nk_style_item_color(table[NK_COLOR_PROPERTY]); + edit->border_color = nk_rgba(0,0,0,0); + edit->cursor_normal = table[NK_COLOR_TEXT]; + edit->cursor_hover = table[NK_COLOR_TEXT]; + edit->cursor_text_normal= table[NK_COLOR_EDIT]; + edit->cursor_text_hover = table[NK_COLOR_EDIT]; + edit->text_normal = table[NK_COLOR_TEXT]; + edit->text_hover = table[NK_COLOR_TEXT]; + edit->text_active = table[NK_COLOR_TEXT]; + edit->selected_normal = table[NK_COLOR_TEXT]; + edit->selected_hover = table[NK_COLOR_TEXT]; + edit->selected_text_normal = table[NK_COLOR_EDIT]; + edit->selected_text_hover = table[NK_COLOR_EDIT]; + edit->padding = nk_vec2(0,0); + edit->cursor_size = 8; + edit->border = 0; + edit->rounding = 0; + + /* chart */ + chart = &style->chart; + nk_zero_struct(*chart); + chart->background = nk_style_item_color(table[NK_COLOR_CHART]); + chart->border_color = table[NK_COLOR_BORDER]; + chart->selected_color = table[NK_COLOR_CHART_COLOR_HIGHLIGHT]; + chart->color = table[NK_COLOR_CHART_COLOR]; + chart->padding = nk_vec2(4,4); + chart->border = 0; + chart->rounding = 0; + + /* combo */ + combo = &style->combo; + combo->normal = nk_style_item_color(table[NK_COLOR_COMBO]); + combo->hover = nk_style_item_color(table[NK_COLOR_COMBO]); + combo->active = nk_style_item_color(table[NK_COLOR_COMBO]); + combo->border_color = table[NK_COLOR_BORDER]; + combo->label_normal = table[NK_COLOR_TEXT]; + combo->label_hover = table[NK_COLOR_TEXT]; + combo->label_active = table[NK_COLOR_TEXT]; + combo->sym_normal = NK_SYMBOL_TRIANGLE_DOWN; + combo->sym_hover = NK_SYMBOL_TRIANGLE_DOWN; + combo->sym_active = NK_SYMBOL_TRIANGLE_DOWN; + combo->content_padding = nk_vec2(4,4); + combo->button_padding = nk_vec2(0,4); + combo->spacing = nk_vec2(4,0); + combo->border = 1; + combo->rounding = 0; + + /* combo button */ + button = &style->combo.button; + nk_zero_struct(*button); + button->normal = nk_style_item_color(table[NK_COLOR_COMBO]); + button->hover = nk_style_item_color(table[NK_COLOR_COMBO]); + button->active = nk_style_item_color(table[NK_COLOR_COMBO]); + button->border_color = nk_rgba(0,0,0,0); + button->text_background = table[NK_COLOR_COMBO]; + button->text_normal = table[NK_COLOR_TEXT]; + button->text_hover = table[NK_COLOR_TEXT]; + button->text_active = table[NK_COLOR_TEXT]; + button->padding = nk_vec2(2.0f,2.0f); + button->touch_padding = nk_vec2(0.0f,0.0f); + button->userdata = nk_handle_ptr(0); + button->text_alignment = NK_TEXT_CENTERED; + button->border = 0.0f; + button->rounding = 0.0f; + button->draw_begin = 0; + button->draw_end = 0; + + /* tab */ + tab = &style->tab; + tab->background = nk_style_item_color(table[NK_COLOR_TAB_HEADER]); + tab->border_color = table[NK_COLOR_BORDER]; + tab->text = table[NK_COLOR_TEXT]; + tab->sym_minimize = NK_SYMBOL_TRIANGLE_RIGHT; + tab->sym_maximize = NK_SYMBOL_TRIANGLE_DOWN; + tab->padding = nk_vec2(4,4); + tab->spacing = nk_vec2(4,4); + tab->indent = 10.0f; + tab->border = 1; + tab->rounding = 0; + + /* tab button */ + button = &style->tab.tab_minimize_button; + nk_zero_struct(*button); + button->normal = nk_style_item_color(table[NK_COLOR_TAB_HEADER]); + button->hover = nk_style_item_color(table[NK_COLOR_TAB_HEADER]); + button->active = nk_style_item_color(table[NK_COLOR_TAB_HEADER]); + button->border_color = nk_rgba(0,0,0,0); + button->text_background = table[NK_COLOR_TAB_HEADER]; + button->text_normal = table[NK_COLOR_TEXT]; + button->text_hover = table[NK_COLOR_TEXT]; + button->text_active = table[NK_COLOR_TEXT]; + button->padding = nk_vec2(2.0f,2.0f); + button->touch_padding = nk_vec2(0.0f,0.0f); + button->userdata = nk_handle_ptr(0); + button->text_alignment = NK_TEXT_CENTERED; + button->border = 0.0f; + button->rounding = 0.0f; + button->draw_begin = 0; + button->draw_end = 0; + style->tab.tab_maximize_button =*button; + + /* node button */ + button = &style->tab.node_minimize_button; + nk_zero_struct(*button); + button->normal = nk_style_item_color(table[NK_COLOR_WINDOW]); + button->hover = nk_style_item_color(table[NK_COLOR_WINDOW]); + button->active = nk_style_item_color(table[NK_COLOR_WINDOW]); + button->border_color = nk_rgba(0,0,0,0); + button->text_background = table[NK_COLOR_TAB_HEADER]; + button->text_normal = table[NK_COLOR_TEXT]; + button->text_hover = table[NK_COLOR_TEXT]; + button->text_active = table[NK_COLOR_TEXT]; + button->padding = nk_vec2(2.0f,2.0f); + button->touch_padding = nk_vec2(0.0f,0.0f); + button->userdata = nk_handle_ptr(0); + button->text_alignment = NK_TEXT_CENTERED; + button->border = 0.0f; + button->rounding = 0.0f; + button->draw_begin = 0; + button->draw_end = 0; + style->tab.node_maximize_button =*button; + + /* window header */ + win = &style->window; + win->header.align = NK_HEADER_RIGHT; + win->header.close_symbol = NK_SYMBOL_X; + win->header.minimize_symbol = NK_SYMBOL_MINUS; + win->header.maximize_symbol = NK_SYMBOL_PLUS; + win->header.normal = nk_style_item_color(table[NK_COLOR_HEADER]); + win->header.hover = nk_style_item_color(table[NK_COLOR_HEADER]); + win->header.active = nk_style_item_color(table[NK_COLOR_HEADER]); + win->header.label_normal = table[NK_COLOR_TEXT]; + win->header.label_hover = table[NK_COLOR_TEXT]; + win->header.label_active = table[NK_COLOR_TEXT]; + win->header.label_padding = nk_vec2(4,4); + win->header.padding = nk_vec2(4,4); + win->header.spacing = nk_vec2(0,0); + + /* window header close button */ + button = &style->window.header.close_button; + nk_zero_struct(*button); + button->normal = nk_style_item_color(table[NK_COLOR_HEADER]); + button->hover = nk_style_item_color(table[NK_COLOR_HEADER]); + button->active = nk_style_item_color(table[NK_COLOR_HEADER]); + button->border_color = nk_rgba(0,0,0,0); + button->text_background = table[NK_COLOR_HEADER]; + button->text_normal = table[NK_COLOR_TEXT]; + button->text_hover = table[NK_COLOR_TEXT]; + button->text_active = table[NK_COLOR_TEXT]; + button->padding = nk_vec2(0.0f,0.0f); + button->touch_padding = nk_vec2(0.0f,0.0f); + button->userdata = nk_handle_ptr(0); + button->text_alignment = NK_TEXT_CENTERED; + button->border = 0.0f; + button->rounding = 0.0f; + button->draw_begin = 0; + button->draw_end = 0; + + /* window header minimize button */ + button = &style->window.header.minimize_button; + nk_zero_struct(*button); + button->normal = nk_style_item_color(table[NK_COLOR_HEADER]); + button->hover = nk_style_item_color(table[NK_COLOR_HEADER]); + button->active = nk_style_item_color(table[NK_COLOR_HEADER]); + button->border_color = nk_rgba(0,0,0,0); + button->text_background = table[NK_COLOR_HEADER]; + button->text_normal = table[NK_COLOR_TEXT]; + button->text_hover = table[NK_COLOR_TEXT]; + button->text_active = table[NK_COLOR_TEXT]; + button->padding = nk_vec2(0.0f,0.0f); + button->touch_padding = nk_vec2(0.0f,0.0f); + button->userdata = nk_handle_ptr(0); + button->text_alignment = NK_TEXT_CENTERED; + button->border = 0.0f; + button->rounding = 0.0f; + button->draw_begin = 0; + button->draw_end = 0; + + /* window */ + win->background = table[NK_COLOR_WINDOW]; + win->fixed_background = nk_style_item_color(table[NK_COLOR_WINDOW]); + win->border_color = table[NK_COLOR_BORDER]; + win->popup_border_color = table[NK_COLOR_BORDER]; + win->combo_border_color = table[NK_COLOR_BORDER]; + win->contextual_border_color = table[NK_COLOR_BORDER]; + win->menu_border_color = table[NK_COLOR_BORDER]; + win->group_border_color = table[NK_COLOR_BORDER]; + win->tooltip_border_color = table[NK_COLOR_BORDER]; + win->scaler = nk_style_item_color(table[NK_COLOR_TEXT]); + + win->rounding = 0.0f; + win->spacing = nk_vec2(4,4); + win->scrollbar_size = nk_vec2(10,10); + win->min_size = nk_vec2(64,64); + + win->combo_border = 1.0f; + win->contextual_border = 1.0f; + win->menu_border = 1.0f; + win->group_border = 1.0f; + win->tooltip_border = 1.0f; + win->popup_border = 1.0f; + win->border = 2.0f; + win->min_row_height_padding = 8; + + win->padding = nk_vec2(4,4); + win->group_padding = nk_vec2(4,4); + win->popup_padding = nk_vec2(4,4); + win->combo_padding = nk_vec2(4,4); + win->contextual_padding = nk_vec2(4,4); + win->menu_padding = nk_vec2(4,4); + win->tooltip_padding = nk_vec2(4,4); +} + +NK_API void +nk_style_set_font(struct nk_context *ctx, const struct nk_user_font *font) +{ + struct nk_style *style; + NK_ASSERT(ctx); + + if (!ctx) return; + style = &ctx->style; + style->font = font; + ctx->stacks.fonts.head = 0; + if (ctx->current) + nk_layout_reset_min_row_height(ctx); +} + +NK_API int +nk_style_push_font(struct nk_context *ctx, const struct nk_user_font *font) +{ + struct nk_config_stack_user_font *font_stack; + struct nk_config_stack_user_font_element *element; + + NK_ASSERT(ctx); + if (!ctx) return 0; + + font_stack = &ctx->stacks.fonts; + NK_ASSERT(font_stack->head < (int)NK_LEN(font_stack->elements)); + if (font_stack->head >= (int)NK_LEN(font_stack->elements)) + return 0; + + element = &font_stack->elements[font_stack->head++]; + element->address = &ctx->style.font; + element->old_value = ctx->style.font; + ctx->style.font = font; + return 1; +} + +NK_API int +nk_style_pop_font(struct nk_context *ctx) +{ + struct nk_config_stack_user_font *font_stack; + struct nk_config_stack_user_font_element *element; + + NK_ASSERT(ctx); + if (!ctx) return 0; + + font_stack = &ctx->stacks.fonts; + NK_ASSERT(font_stack->head > 0); + if (font_stack->head < 1) + return 0; + + element = &font_stack->elements[--font_stack->head]; + *element->address = element->old_value; + return 1; +} + +#define NK_STYLE_PUSH_IMPLEMENATION(prefix, type, stack) \ +nk_style_push_##type(struct nk_context *ctx, prefix##_##type *address, prefix##_##type value)\ +{\ + struct nk_config_stack_##type * type_stack;\ + struct nk_config_stack_##type##_element *element;\ + NK_ASSERT(ctx);\ + if (!ctx) return 0;\ + type_stack = &ctx->stacks.stack;\ + NK_ASSERT(type_stack->head < (int)NK_LEN(type_stack->elements));\ + if (type_stack->head >= (int)NK_LEN(type_stack->elements))\ + return 0;\ + element = &type_stack->elements[type_stack->head++];\ + element->address = address;\ + element->old_value = *address;\ + *address = value;\ + return 1;\ +} + +#define NK_STYLE_POP_IMPLEMENATION(type, stack) \ +nk_style_pop_##type(struct nk_context *ctx)\ +{\ + struct nk_config_stack_##type *type_stack;\ + struct nk_config_stack_##type##_element *element;\ + NK_ASSERT(ctx);\ + if (!ctx) return 0;\ + type_stack = &ctx->stacks.stack;\ + NK_ASSERT(type_stack->head > 0);\ + if (type_stack->head < 1)\ + return 0;\ + element = &type_stack->elements[--type_stack->head];\ + *element->address = element->old_value;\ + return 1;\ +} + +NK_API int NK_STYLE_PUSH_IMPLEMENATION(struct nk, style_item, style_items) +NK_API int NK_STYLE_PUSH_IMPLEMENATION(nk,float, floats) +NK_API int NK_STYLE_PUSH_IMPLEMENATION(struct nk, vec2, vectors) +NK_API int NK_STYLE_PUSH_IMPLEMENATION(nk,flags, flags) +NK_API int NK_STYLE_PUSH_IMPLEMENATION(struct nk,color, colors) + +NK_API int NK_STYLE_POP_IMPLEMENATION(style_item, style_items) +NK_API int NK_STYLE_POP_IMPLEMENATION(float,floats) +NK_API int NK_STYLE_POP_IMPLEMENATION(vec2, vectors) +NK_API int NK_STYLE_POP_IMPLEMENATION(flags,flags) +NK_API int NK_STYLE_POP_IMPLEMENATION(color,colors) + +NK_API int +nk_style_set_cursor(struct nk_context *ctx, enum nk_style_cursor c) +{ + struct nk_style *style; + NK_ASSERT(ctx); + if (!ctx) return 0; + style = &ctx->style; + if (style->cursors[c]) { + style->cursor_active = style->cursors[c]; + return 1; + } + return 0; +} + +NK_API void +nk_style_show_cursor(struct nk_context *ctx) +{ + ctx->style.cursor_visible = nk_true; +} + +NK_API void +nk_style_hide_cursor(struct nk_context *ctx) +{ + ctx->style.cursor_visible = nk_false; +} + +NK_API void +nk_style_load_cursor(struct nk_context *ctx, enum nk_style_cursor cursor, + const struct nk_cursor *c) +{ + struct nk_style *style; + NK_ASSERT(ctx); + if (!ctx) return; + style = &ctx->style; + style->cursors[cursor] = c; +} + +NK_API void +nk_style_load_all_cursors(struct nk_context *ctx, struct nk_cursor *cursors) +{ + int i = 0; + struct nk_style *style; + NK_ASSERT(ctx); + if (!ctx) return; + style = &ctx->style; + for (i = 0; i < NK_CURSOR_COUNT; ++i) + style->cursors[i] = &cursors[i]; + style->cursor_visible = nk_true; +} + +/* =============================================================== + * + * POOL + * + * ===============================================================*/ +NK_INTERN void +nk_pool_init(struct nk_pool *pool, struct nk_allocator *alloc, + unsigned int capacity) +{ + nk_zero(pool, sizeof(*pool)); + pool->alloc = *alloc; + pool->capacity = capacity; + pool->type = NK_BUFFER_DYNAMIC; + pool->pages = 0; +} + +NK_INTERN void +nk_pool_free(struct nk_pool *pool) +{ + struct nk_page *iter = pool->pages; + if (!pool) return; + if (pool->type == NK_BUFFER_FIXED) return; + while (iter) { + struct nk_page *next = iter->next; + pool->alloc.free(pool->alloc.userdata, iter); + iter = next; + } +} + +NK_INTERN void +nk_pool_init_fixed(struct nk_pool *pool, void *memory, nk_size size) +{ + nk_zero(pool, sizeof(*pool)); + NK_ASSERT(size >= sizeof(struct nk_page)); + if (size < sizeof(struct nk_page)) return; + pool->capacity = (unsigned)(size - sizeof(struct nk_page)) / sizeof(struct nk_page_element); + pool->pages = (struct nk_page*)memory; + pool->type = NK_BUFFER_FIXED; + pool->size = size; +} + +NK_INTERN struct nk_page_element* +nk_pool_alloc(struct nk_pool *pool) +{ + if (!pool->pages || pool->pages->size >= pool->capacity) { + /* allocate new page */ + struct nk_page *page; + if (pool->type == NK_BUFFER_FIXED) { + if (!pool->pages) { + NK_ASSERT(pool->pages); + return 0; + } + NK_ASSERT(pool->pages->size < pool->capacity); + return 0; + } else { + nk_size size = sizeof(struct nk_page); + size += NK_POOL_DEFAULT_CAPACITY * sizeof(union nk_page_data); + page = (struct nk_page*)pool->alloc.alloc(pool->alloc.userdata,0, size); + page->next = pool->pages; + pool->pages = page; + page->size = 0; + } + } + return &pool->pages->win[pool->pages->size++]; +} + +/* =============================================================== + * + * CONTEXT + * + * ===============================================================*/ +NK_INTERN void* nk_create_window(struct nk_context *ctx); +NK_INTERN void nk_remove_window(struct nk_context*, struct nk_window*); +NK_INTERN void nk_free_window(struct nk_context *ctx, struct nk_window *win); +NK_INTERN void nk_free_table(struct nk_context *ctx, struct nk_table *tbl); +NK_INTERN void nk_remove_table(struct nk_window *win, struct nk_table *tbl); +NK_INTERN void* nk_create_panel(struct nk_context *ctx); +NK_INTERN void nk_free_panel(struct nk_context*, struct nk_panel *pan); + +NK_INTERN void +nk_setup(struct nk_context *ctx, const struct nk_user_font *font) +{ + NK_ASSERT(ctx); + if (!ctx) return; + nk_zero_struct(*ctx); + nk_style_default(ctx); + ctx->seq = 1; + if (font) ctx->style.font = font; +#ifdef NK_INCLUDE_VERTEX_BUFFER_OUTPUT + nk_draw_list_init(&ctx->draw_list); +#endif +} + +#ifdef NK_INCLUDE_DEFAULT_ALLOCATOR +NK_API int +nk_init_default(struct nk_context *ctx, const struct nk_user_font *font) +{ + struct nk_allocator alloc; + alloc.userdata.ptr = 0; + alloc.alloc = nk_malloc; + alloc.free = nk_mfree; + return nk_init(ctx, &alloc, font); +} +#endif + +NK_API int +nk_init_fixed(struct nk_context *ctx, void *memory, nk_size size, + const struct nk_user_font *font) +{ + NK_ASSERT(memory); + if (!memory) return 0; + nk_setup(ctx, font); + nk_buffer_init_fixed(&ctx->memory, memory, size); + ctx->use_pool = nk_false; + return 1; +} + +NK_API int +nk_init_custom(struct nk_context *ctx, struct nk_buffer *cmds, + struct nk_buffer *pool, const struct nk_user_font *font) +{ + NK_ASSERT(cmds); + NK_ASSERT(pool); + if (!cmds || !pool) return 0; + + nk_setup(ctx, font); + ctx->memory = *cmds; + if (pool->type == NK_BUFFER_FIXED) { + /* take memory from buffer and alloc fixed pool */ + nk_pool_init_fixed(&ctx->pool, pool->memory.ptr, pool->memory.size); + } else { + /* create dynamic pool from buffer allocator */ + struct nk_allocator *alloc = &pool->pool; + nk_pool_init(&ctx->pool, alloc, NK_POOL_DEFAULT_CAPACITY); + } + ctx->use_pool = nk_true; + return 1; +} + +NK_API int +nk_init(struct nk_context *ctx, struct nk_allocator *alloc, + const struct nk_user_font *font) +{ + NK_ASSERT(alloc); + if (!alloc) return 0; + nk_setup(ctx, font); + nk_buffer_init(&ctx->memory, alloc, NK_DEFAULT_COMMAND_BUFFER_SIZE); + nk_pool_init(&ctx->pool, alloc, NK_POOL_DEFAULT_CAPACITY); + ctx->use_pool = nk_true; + return 1; +} + +#ifdef NK_INCLUDE_COMMAND_USERDATA +NK_API void +nk_set_user_data(struct nk_context *ctx, nk_handle handle) +{ + if (!ctx) return; + ctx->userdata = handle; + if (ctx->current) + ctx->current->buffer.userdata = handle; +} +#endif + +NK_API void +nk_free(struct nk_context *ctx) +{ + NK_ASSERT(ctx); + if (!ctx) return; + nk_buffer_free(&ctx->memory); + if (ctx->use_pool) + nk_pool_free(&ctx->pool); + + nk_zero(&ctx->input, sizeof(ctx->input)); + nk_zero(&ctx->style, sizeof(ctx->style)); + nk_zero(&ctx->memory, sizeof(ctx->memory)); + + ctx->seq = 0; + ctx->build = 0; + ctx->begin = 0; + ctx->end = 0; + ctx->active = 0; + ctx->current = 0; + ctx->freelist = 0; + ctx->count = 0; +} + +NK_API void +nk_clear(struct nk_context *ctx) +{ + struct nk_window *iter; + struct nk_window *next; + NK_ASSERT(ctx); + + if (!ctx) return; + if (ctx->use_pool) + nk_buffer_clear(&ctx->memory); + else nk_buffer_reset(&ctx->memory, NK_BUFFER_FRONT); + + ctx->build = 0; + ctx->memory.calls = 0; + ctx->last_widget_state = 0; + ctx->style.cursor_active = ctx->style.cursors[NK_CURSOR_ARROW]; + NK_MEMSET(&ctx->overlay, 0, sizeof(ctx->overlay)); +#ifdef NK_INCLUDE_VERTEX_BUFFER_OUTPUT + nk_draw_list_clear(&ctx->draw_list); +#endif + + /* garbage collector */ + iter = ctx->begin; + while (iter) { + /* make sure valid minimized windows do not get removed */ + if ((iter->flags & NK_WINDOW_MINIMIZED) && + !(iter->flags & NK_WINDOW_CLOSED) && + iter->seq == ctx->seq) { + iter = iter->next; + continue; + } + /* remove hotness from hidden or closed windows*/ + if (((iter->flags & NK_WINDOW_HIDDEN) || + (iter->flags & NK_WINDOW_CLOSED)) && + iter == ctx->active) { + ctx->active = iter->prev; + ctx->end = iter->prev; + if (ctx->active) + ctx->active->flags &= ~(unsigned)NK_WINDOW_ROM; + } + /* free unused popup windows */ + if (iter->popup.win && iter->popup.win->seq != ctx->seq) { + nk_free_window(ctx, iter->popup.win); + iter->popup.win = 0; + } + /* remove unused window state tables */ + {struct nk_table *n, *it = iter->tables; + while (it) { + n = it->next; + if (it->seq != ctx->seq) { + nk_remove_table(iter, it); + nk_zero(it, sizeof(union nk_page_data)); + nk_free_table(ctx, it); + if (it == iter->tables) + iter->tables = n; + } it = n; + }} + /* window itself is not used anymore so free */ + if (iter->seq != ctx->seq || iter->flags & NK_WINDOW_CLOSED) { + next = iter->next; + nk_remove_window(ctx, iter); + nk_free_window(ctx, iter); + iter = next; + } else iter = iter->next; + } + ctx->seq++; +} + +/* ---------------------------------------------------------------- + * + * BUFFERING + * + * ---------------------------------------------------------------*/ +NK_INTERN void +nk_start_buffer(struct nk_context *ctx, struct nk_command_buffer *buffer) +{ + NK_ASSERT(ctx); + NK_ASSERT(buffer); + if (!ctx || !buffer) return; + buffer->begin = ctx->memory.allocated; + buffer->end = buffer->begin; + buffer->last = buffer->begin; + buffer->clip = nk_null_rect; +} + +NK_INTERN void +nk_start(struct nk_context *ctx, struct nk_window *win) +{ + NK_ASSERT(ctx); + NK_ASSERT(win); + nk_start_buffer(ctx, &win->buffer); +} + +NK_INTERN void +nk_start_popup(struct nk_context *ctx, struct nk_window *win) +{ + struct nk_popup_buffer *buf; + NK_ASSERT(ctx); + NK_ASSERT(win); + if (!ctx || !win) return; + + /* save buffer fill state for popup */ + buf = &win->popup.buf; + buf->begin = win->buffer.end; + buf->end = win->buffer.end; + buf->parent = win->buffer.last; + buf->last = buf->begin; + buf->active = nk_true; +} + +NK_INTERN void +nk_finish_popup(struct nk_context *ctx, struct nk_window *win) +{ + struct nk_popup_buffer *buf; + NK_ASSERT(ctx); + NK_ASSERT(win); + if (!ctx || !win) return; + + buf = &win->popup.buf; + buf->last = win->buffer.last; + buf->end = win->buffer.end; +} + +NK_INTERN void +nk_finish_buffer(struct nk_context *ctx, struct nk_command_buffer *buffer) +{ + NK_ASSERT(ctx); + NK_ASSERT(buffer); + if (!ctx || !buffer) return; + buffer->end = ctx->memory.allocated; +} + +NK_INTERN void +nk_finish(struct nk_context *ctx, struct nk_window *win) +{ + struct nk_popup_buffer *buf; + struct nk_command *parent_last; + void *memory; + + NK_ASSERT(ctx); + NK_ASSERT(win); + if (!ctx || !win) return; + nk_finish_buffer(ctx, &win->buffer); + if (!win->popup.buf.active) return; + + buf = &win->popup.buf; + memory = ctx->memory.memory.ptr; + parent_last = nk_ptr_add(struct nk_command, memory, buf->parent); + parent_last->next = buf->end; +} + +NK_INTERN void +nk_build(struct nk_context *ctx) +{ + struct nk_window *it = 0; + struct nk_command *cmd = 0; + nk_byte *buffer = 0; + + /* draw cursor overlay */ + if (!ctx->style.cursor_active) + ctx->style.cursor_active = ctx->style.cursors[NK_CURSOR_ARROW]; + if (ctx->style.cursor_active && !ctx->input.mouse.grabbed && ctx->style.cursor_visible) { + struct nk_rect mouse_bounds; + const struct nk_cursor *cursor = ctx->style.cursor_active; + nk_command_buffer_init(&ctx->overlay, &ctx->memory, NK_CLIPPING_OFF); + nk_start_buffer(ctx, &ctx->overlay); + + mouse_bounds.x = ctx->input.mouse.pos.x - cursor->offset.x; + mouse_bounds.y = ctx->input.mouse.pos.y - cursor->offset.y; + mouse_bounds.w = cursor->size.x; + mouse_bounds.h = cursor->size.y; + + nk_draw_image(&ctx->overlay, mouse_bounds, &cursor->img, nk_white); + nk_finish_buffer(ctx, &ctx->overlay); + } + /* build one big draw command list out of all window buffers */ + it = ctx->begin; + buffer = (nk_byte*)ctx->memory.memory.ptr; + while (it != 0) { + struct nk_window *next = it->next; + if (it->buffer.last == it->buffer.begin || (it->flags & NK_WINDOW_HIDDEN)|| + it->seq != ctx->seq) + goto cont; + + cmd = nk_ptr_add(struct nk_command, buffer, it->buffer.last); + while (next && ((next->buffer.last == next->buffer.begin) || + (next->flags & NK_WINDOW_HIDDEN))) + next = next->next; /* skip empty command buffers */ + + if (next) cmd->next = next->buffer.begin; + cont: it = next; + } + /* append all popup draw commands into lists */ + it = ctx->begin; + while (it != 0) { + struct nk_window *next = it->next; + struct nk_popup_buffer *buf; + if (!it->popup.buf.active) + goto skip; + + buf = &it->popup.buf; + cmd->next = buf->begin; + cmd = nk_ptr_add(struct nk_command, buffer, buf->last); + buf->active = nk_false; + skip: it = next; + } + if (cmd) { + /* append overlay commands */ + if (ctx->overlay.end != ctx->overlay.begin) + cmd->next = ctx->overlay.begin; + else cmd->next = ctx->memory.allocated; + } +} + +NK_API const struct nk_command* +nk__begin(struct nk_context *ctx) +{ + struct nk_window *iter; + nk_byte *buffer; + NK_ASSERT(ctx); + if (!ctx) return 0; + if (!ctx->count) return 0; + + buffer = (nk_byte*)ctx->memory.memory.ptr; + if (!ctx->build) { + nk_build(ctx); + ctx->build = nk_true; + } + iter = ctx->begin; + while (iter && ((iter->buffer.begin == iter->buffer.end) || + (iter->flags & NK_WINDOW_HIDDEN) || iter->seq != ctx->seq)) + iter = iter->next; + if (!iter) return 0; + return nk_ptr_add_const(struct nk_command, buffer, iter->buffer.begin); +} + +NK_API const struct nk_command* +nk__next(struct nk_context *ctx, const struct nk_command *cmd) +{ + nk_byte *buffer; + const struct nk_command *next; + NK_ASSERT(ctx); + if (!ctx || !cmd || !ctx->count) return 0; + if (cmd->next >= ctx->memory.allocated) return 0; + buffer = (nk_byte*)ctx->memory.memory.ptr; + next = nk_ptr_add_const(struct nk_command, buffer, cmd->next); + return next; +} + +/* ---------------------------------------------------------------- + * + * PANEL + * + * ---------------------------------------------------------------*/ +static int +nk_panel_has_header(nk_flags flags, const char *title) +{ + int active = 0; + active = (flags & (NK_WINDOW_CLOSABLE|NK_WINDOW_MINIMIZABLE)); + active = active || (flags & NK_WINDOW_TITLE); + active = active && !(flags & NK_WINDOW_HIDDEN) && title; + return active; +} + +NK_INTERN struct nk_vec2 +nk_panel_get_padding(const struct nk_style *style, enum nk_panel_type type) +{ + switch (type) { + default: + case NK_PANEL_WINDOW: return style->window.padding; + case NK_PANEL_GROUP: return style->window.group_padding; + case NK_PANEL_POPUP: return style->window.popup_padding; + case NK_PANEL_CONTEXTUAL: return style->window.contextual_padding; + case NK_PANEL_COMBO: return style->window.combo_padding; + case NK_PANEL_MENU: return style->window.menu_padding; + case NK_PANEL_TOOLTIP: return style->window.menu_padding; + } +} + +NK_INTERN float +nk_panel_get_border(const struct nk_style *style, nk_flags flags, + enum nk_panel_type type) +{ + if (flags & NK_WINDOW_BORDER) { + switch (type) { + default: + case NK_PANEL_WINDOW: return style->window.border; + case NK_PANEL_GROUP: return style->window.group_border; + case NK_PANEL_POPUP: return style->window.popup_border; + case NK_PANEL_CONTEXTUAL: return style->window.contextual_border; + case NK_PANEL_COMBO: return style->window.combo_border; + case NK_PANEL_MENU: return style->window.menu_border; + case NK_PANEL_TOOLTIP: return style->window.menu_border; + }} else return 0; +} + +NK_INTERN struct nk_color +nk_panel_get_border_color(const struct nk_style *style, enum nk_panel_type type) +{ + switch (type) { + default: + case NK_PANEL_WINDOW: return style->window.border_color; + case NK_PANEL_GROUP: return style->window.group_border_color; + case NK_PANEL_POPUP: return style->window.popup_border_color; + case NK_PANEL_CONTEXTUAL: return style->window.contextual_border_color; + case NK_PANEL_COMBO: return style->window.combo_border_color; + case NK_PANEL_MENU: return style->window.menu_border_color; + case NK_PANEL_TOOLTIP: return style->window.menu_border_color; + } +} + +NK_INTERN int +nk_panel_is_sub(enum nk_panel_type type) +{ + return (type & NK_PANEL_SET_SUB)?1:0; +} + +NK_INTERN int +nk_panel_is_nonblock(enum nk_panel_type type) +{ + return (type & NK_PANEL_SET_NONBLOCK)?1:0; +} + +NK_INTERN int +nk_panel_begin(struct nk_context *ctx, const char *title, enum nk_panel_type panel_type) +{ + struct nk_input *in; + struct nk_window *win; + struct nk_panel *layout; + struct nk_command_buffer *out; + const struct nk_style *style; + const struct nk_user_font *font; + + struct nk_vec2 scrollbar_size; + struct nk_vec2 panel_padding; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) return 0; + nk_zero(ctx->current->layout, sizeof(*ctx->current->layout)); + if ((ctx->current->flags & NK_WINDOW_HIDDEN) || (ctx->current->flags & NK_WINDOW_CLOSED)) { + nk_zero(ctx->current->layout, sizeof(struct nk_panel)); + ctx->current->layout->type = panel_type; + return 0; + } + /* pull state into local stack */ + style = &ctx->style; + font = style->font; + win = ctx->current; + layout = win->layout; + out = &win->buffer; + in = (win->flags & NK_WINDOW_NO_INPUT) ? 0: &ctx->input; +#ifdef NK_INCLUDE_COMMAND_USERDATA + win->buffer.userdata = ctx->userdata; +#endif + /* pull style configuration into local stack */ + scrollbar_size = style->window.scrollbar_size; + panel_padding = nk_panel_get_padding(style, panel_type); + + /* window movement */ + if ((win->flags & NK_WINDOW_MOVABLE) && !(win->flags & NK_WINDOW_ROM)) { + int left_mouse_down; + int left_mouse_click_in_cursor; + + /* calculate draggable window space */ + struct nk_rect header; + header.x = win->bounds.x; + header.y = win->bounds.y; + header.w = win->bounds.w; + if (nk_panel_has_header(win->flags, title)) { + header.h = font->height + 2.0f * style->window.header.padding.y; + header.h += 2.0f * style->window.header.label_padding.y; + } else header.h = panel_padding.y; + + /* window movement by dragging */ + left_mouse_down = in->mouse.buttons[NK_BUTTON_LEFT].down; + left_mouse_click_in_cursor = nk_input_has_mouse_click_down_in_rect(in, + NK_BUTTON_LEFT, header, nk_true); + if (left_mouse_down && left_mouse_click_in_cursor) { + win->bounds.x = win->bounds.x + in->mouse.delta.x; + win->bounds.y = win->bounds.y + in->mouse.delta.y; + in->mouse.buttons[NK_BUTTON_LEFT].clicked_pos.x += in->mouse.delta.x; + in->mouse.buttons[NK_BUTTON_LEFT].clicked_pos.y += in->mouse.delta.y; + ctx->style.cursor_active = ctx->style.cursors[NK_CURSOR_MOVE]; + } + } + + /* setup panel */ + layout->type = panel_type; + layout->flags = win->flags; + layout->bounds = win->bounds; + layout->bounds.x += panel_padding.x; + layout->bounds.w -= 2*panel_padding.x; + if (win->flags & NK_WINDOW_BORDER) { + layout->border = nk_panel_get_border(style, win->flags, panel_type); + layout->bounds = nk_shrink_rect(layout->bounds, layout->border); + } else layout->border = 0; + layout->at_y = layout->bounds.y; + layout->at_x = layout->bounds.x; + layout->max_x = 0; + layout->header_height = 0; + layout->footer_height = 0; + nk_layout_reset_min_row_height(ctx); + layout->row.index = 0; + layout->row.columns = 0; + layout->row.ratio = 0; + layout->row.item_width = 0; + layout->row.tree_depth = 0; + layout->row.height = panel_padding.y; + layout->has_scrolling = nk_true; + if (!(win->flags & NK_WINDOW_NO_SCROLLBAR)) + layout->bounds.w -= scrollbar_size.x; + if (!nk_panel_is_nonblock(panel_type)) { + layout->footer_height = 0; + if (!(win->flags & NK_WINDOW_NO_SCROLLBAR) || win->flags & NK_WINDOW_SCALABLE) + layout->footer_height = scrollbar_size.y; + layout->bounds.h -= layout->footer_height; + } + + /* panel header */ + if (nk_panel_has_header(win->flags, title)) + { + struct nk_text text; + struct nk_rect header; + const struct nk_style_item *background = 0; + + /* calculate header bounds */ + header.x = win->bounds.x; + header.y = win->bounds.y; + header.w = win->bounds.w; + header.h = font->height + 2.0f * style->window.header.padding.y; + header.h += (2.0f * style->window.header.label_padding.y); + + /* shrink panel by header */ + layout->header_height = header.h; + layout->bounds.y += header.h; + layout->bounds.h -= header.h; + layout->at_y += header.h; + + /* select correct header background and text color */ + if (ctx->active == win) { + background = &style->window.header.active; + text.text = style->window.header.label_active; + } else if (nk_input_is_mouse_hovering_rect(&ctx->input, header)) { + background = &style->window.header.hover; + text.text = style->window.header.label_hover; + } else { + background = &style->window.header.normal; + text.text = style->window.header.label_normal; + } + + /* draw header background */ + header.h += 1.0f; + if (background->type == NK_STYLE_ITEM_IMAGE) { + text.background = nk_rgba(0,0,0,0); + nk_draw_image(&win->buffer, header, &background->data.image, nk_white); + } else { + text.background = background->data.color; + nk_fill_rect(out, header, 0, background->data.color); + } + + /* window close button */ + {struct nk_rect button; + button.y = header.y + style->window.header.padding.y; + button.h = header.h - 2 * style->window.header.padding.y; + button.w = button.h; + if (win->flags & NK_WINDOW_CLOSABLE) { + nk_flags ws = 0; + if (style->window.header.align == NK_HEADER_RIGHT) { + button.x = (header.w + header.x) - (button.w + style->window.header.padding.x); + header.w -= button.w + style->window.header.spacing.x + style->window.header.padding.x; + } else { + button.x = header.x + style->window.header.padding.x; + header.x += button.w + style->window.header.spacing.x + style->window.header.padding.x; + } + + if (nk_do_button_symbol(&ws, &win->buffer, button, + style->window.header.close_symbol, NK_BUTTON_DEFAULT, + &style->window.header.close_button, in, style->font) && !(win->flags & NK_WINDOW_ROM)) + { + layout->flags |= NK_WINDOW_HIDDEN; + layout->flags &= (nk_flags)~NK_WINDOW_MINIMIZED; + } + } + + /* window minimize button */ + if (win->flags & NK_WINDOW_MINIMIZABLE) { + nk_flags ws = 0; + if (style->window.header.align == NK_HEADER_RIGHT) { + button.x = (header.w + header.x) - button.w; + if (!(win->flags & NK_WINDOW_CLOSABLE)) { + button.x -= style->window.header.padding.x; + header.w -= style->window.header.padding.x; + } + header.w -= button.w + style->window.header.spacing.x; + } else { + button.x = header.x; + header.x += button.w + style->window.header.spacing.x + style->window.header.padding.x; + } + if (nk_do_button_symbol(&ws, &win->buffer, button, (layout->flags & NK_WINDOW_MINIMIZED)? + style->window.header.maximize_symbol: style->window.header.minimize_symbol, + NK_BUTTON_DEFAULT, &style->window.header.minimize_button, in, style->font) && !(win->flags & NK_WINDOW_ROM)) + layout->flags = (layout->flags & NK_WINDOW_MINIMIZED) ? + layout->flags & (nk_flags)~NK_WINDOW_MINIMIZED: + layout->flags | NK_WINDOW_MINIMIZED; + }} + + {/* window header title */ + int text_len = nk_strlen(title); + struct nk_rect label = {0,0,0,0}; + float t = font->width(font->userdata, font->height, title, text_len); + text.padding = nk_vec2(0,0); + + label.x = header.x + style->window.header.padding.x; + label.x += style->window.header.label_padding.x; + label.y = header.y + style->window.header.label_padding.y; + label.h = font->height + 2 * style->window.header.label_padding.y; + label.w = t + 2 * style->window.header.spacing.x; + label.w = NK_CLAMP(0, label.w, header.x + header.w - label.x); + nk_widget_text(out, label,(const char*)title, text_len, &text, NK_TEXT_LEFT, font);} + } + + /* draw window background */ + if (!(layout->flags & NK_WINDOW_MINIMIZED) && !(layout->flags & NK_WINDOW_DYNAMIC)) { + struct nk_rect body; + body.x = win->bounds.x; + body.w = win->bounds.w; + body.y = (win->bounds.y + layout->header_height); + body.h = (win->bounds.h - layout->header_height); + if (style->window.fixed_background.type == NK_STYLE_ITEM_IMAGE) + nk_draw_image(out, body, &style->window.fixed_background.data.image, nk_white); + else nk_fill_rect(out, body, 0, style->window.fixed_background.data.color); + } + + /* set clipping rectangle */ + {struct nk_rect clip; + layout->clip = layout->bounds; + nk_unify(&clip, &win->buffer.clip, layout->clip.x, layout->clip.y, + layout->clip.x + layout->clip.w, layout->clip.y + layout->clip.h); + nk_push_scissor(out, clip); + layout->clip = clip;} + return !(layout->flags & NK_WINDOW_HIDDEN) && !(layout->flags & NK_WINDOW_MINIMIZED); +} + +NK_INTERN void +nk_panel_end(struct nk_context *ctx) +{ + struct nk_input *in; + struct nk_window *window; + struct nk_panel *layout; + const struct nk_style *style; + struct nk_command_buffer *out; + + struct nk_vec2 scrollbar_size; + struct nk_vec2 panel_padding; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + window = ctx->current; + layout = window->layout; + style = &ctx->style; + out = &window->buffer; + in = (layout->flags & NK_WINDOW_ROM || layout->flags & NK_WINDOW_NO_INPUT) ? 0 :&ctx->input; + if (!nk_panel_is_sub(layout->type)) + nk_push_scissor(out, nk_null_rect); + + /* cache configuration data */ + scrollbar_size = style->window.scrollbar_size; + panel_padding = nk_panel_get_padding(style, layout->type); + + /* update the current cursor Y-position to point over the last added widget */ + layout->at_y += layout->row.height; + + /* dynamic panels */ + if (layout->flags & NK_WINDOW_DYNAMIC && !(layout->flags & NK_WINDOW_MINIMIZED)) + { + /* update panel height to fit dynamic growth */ + struct nk_rect empty_space; + if (layout->at_y < (layout->bounds.y + layout->bounds.h)) + layout->bounds.h = layout->at_y - layout->bounds.y; + + /* fill top empty space */ + empty_space.x = window->bounds.x; + empty_space.y = layout->bounds.y; + empty_space.h = panel_padding.y; + empty_space.w = window->bounds.w; + nk_fill_rect(out, empty_space, 0, style->window.background); + + /* fill left empty space */ + empty_space.x = window->bounds.x; + empty_space.y = layout->bounds.y; + empty_space.w = panel_padding.x + layout->border; + empty_space.h = layout->bounds.h; + nk_fill_rect(out, empty_space, 0, style->window.background); + + /* fill right empty space */ + empty_space.x = layout->bounds.x + layout->bounds.w - layout->border; + empty_space.y = layout->bounds.y; + empty_space.w = panel_padding.x + layout->border; + empty_space.h = layout->bounds.h; + if (*layout->offset_y == 0 && !(layout->flags & NK_WINDOW_NO_SCROLLBAR)) + empty_space.w += scrollbar_size.x; + nk_fill_rect(out, empty_space, 0, style->window.background); + + /* fill bottom empty space */ + if (*layout->offset_x != 0 && !(layout->flags & NK_WINDOW_NO_SCROLLBAR)) { + empty_space.x = window->bounds.x; + empty_space.y = layout->bounds.y + layout->bounds.h; + empty_space.w = window->bounds.w; + empty_space.h = scrollbar_size.y; + nk_fill_rect(out, empty_space, 0, style->window.background); + } + } + + /* scrollbars */ + if (!(layout->flags & NK_WINDOW_NO_SCROLLBAR) && + !(layout->flags & NK_WINDOW_MINIMIZED) && + window->scrollbar_hiding_timer < NK_SCROLLBAR_HIDING_TIMEOUT) + { + struct nk_rect scroll; + int scroll_has_scrolling; + float scroll_target; + float scroll_offset; + float scroll_step; + float scroll_inc; + + /* mouse wheel scrolling */ + if (nk_panel_is_sub(layout->type)) + { + /* sub-window mouse wheel scrolling */ + struct nk_window *root_window = window; + struct nk_panel *root_panel = window->layout; + while (root_panel->parent) + root_panel = root_panel->parent; + while (root_window->parent) + root_window = root_window->parent; + + /* only allow scrolling if parent window is active */ + scroll_has_scrolling = 0; + if ((root_window == ctx->active) && layout->has_scrolling) { + /* and panel is being hovered and inside clip rect*/ + if (nk_input_is_mouse_hovering_rect(in, layout->bounds) && + NK_INTERSECT(layout->bounds.x, layout->bounds.y, layout->bounds.w, layout->bounds.h, + root_panel->clip.x, root_panel->clip.y, root_panel->clip.w, root_panel->clip.h)) + { + /* deactivate all parent scrolling */ + root_panel = window->layout; + while (root_panel->parent) { + root_panel->has_scrolling = nk_false; + root_panel = root_panel->parent; + } + root_panel->has_scrolling = nk_false; + scroll_has_scrolling = nk_true; + } + } + } else if (!nk_panel_is_sub(layout->type)) { + /* window mouse wheel scrolling */ + scroll_has_scrolling = (window == ctx->active) && layout->has_scrolling; + if (in && (in->mouse.scroll_delta.y > 0 || in->mouse.scroll_delta.x > 0) && scroll_has_scrolling) + window->scrolled = nk_true; + else window->scrolled = nk_false; + } else scroll_has_scrolling = nk_false; + + { + /* vertical scrollbar */ + nk_flags state = 0; + scroll.x = layout->bounds.x + layout->bounds.w + panel_padding.x; + scroll.y = layout->bounds.y; + scroll.w = scrollbar_size.x; + scroll.h = layout->bounds.h; + + scroll_offset = (float)*layout->offset_y; + scroll_step = scroll.h * 0.10f; + scroll_inc = scroll.h * 0.01f; + scroll_target = (float)(int)(layout->at_y - scroll.y); + scroll_offset = nk_do_scrollbarv(&state, out, scroll, scroll_has_scrolling, + scroll_offset, scroll_target, scroll_step, scroll_inc, + &ctx->style.scrollv, in, style->font); + *layout->offset_y = (nk_uint)scroll_offset; + if (in && scroll_has_scrolling) + in->mouse.scroll_delta.y = 0; + } + { + /* horizontal scrollbar */ + nk_flags state = 0; + scroll.x = layout->bounds.x; + scroll.y = layout->bounds.y + layout->bounds.h; + scroll.w = layout->bounds.w; + scroll.h = scrollbar_size.y; + + scroll_offset = (float)*layout->offset_x; + scroll_target = (float)(int)(layout->max_x - scroll.x); + scroll_step = layout->max_x * 0.05f; + scroll_inc = layout->max_x * 0.005f; + scroll_offset = nk_do_scrollbarh(&state, out, scroll, scroll_has_scrolling, + scroll_offset, scroll_target, scroll_step, scroll_inc, + &ctx->style.scrollh, in, style->font); + *layout->offset_x = (nk_uint)scroll_offset; + } + } + + /* hide scroll if no user input */ + if (window->flags & NK_WINDOW_SCROLL_AUTO_HIDE) { + int has_input = ctx->input.mouse.delta.x != 0 || ctx->input.mouse.delta.y != 0 || ctx->input.mouse.scroll_delta.y != 0; + int is_window_hovered = nk_window_is_hovered(ctx); + int any_item_active = (ctx->last_widget_state & NK_WIDGET_STATE_MODIFIED); + if ((!has_input && is_window_hovered) || (!is_window_hovered && !any_item_active)) + window->scrollbar_hiding_timer += ctx->delta_time_seconds; + else window->scrollbar_hiding_timer = 0; + } else window->scrollbar_hiding_timer = 0; + + /* window border */ + if (layout->flags & NK_WINDOW_BORDER) + { + struct nk_color border_color = nk_panel_get_border_color(style, layout->type); + const float padding_y = (layout->flags & NK_WINDOW_MINIMIZED) ? + style->window.border + window->bounds.y + layout->header_height: + (layout->flags & NK_WINDOW_DYNAMIC)? + layout->bounds.y + layout->bounds.h + layout->footer_height: + window->bounds.y + window->bounds.h; + + /* draw border top */ + nk_stroke_line(out,window->bounds.x,window->bounds.y, + window->bounds.x + window->bounds.w, window->bounds.y, + layout->border, border_color); + + /* draw bottom border */ + nk_stroke_line(out, window->bounds.x, padding_y, + window->bounds.x + window->bounds.w, padding_y, layout->border, border_color); + + /* draw left border */ + nk_stroke_line(out, window->bounds.x + layout->border*0.5f, + window->bounds.y, window->bounds.x + layout->border*0.5f, + padding_y, layout->border, border_color); + + /* draw right border */ + nk_stroke_line(out, window->bounds.x + window->bounds.w - layout->border*0.5f, + window->bounds.y, window->bounds.x + window->bounds.w - layout->border*0.5f, + padding_y, layout->border, border_color); + } + + /* scaler */ + if ((layout->flags & NK_WINDOW_SCALABLE) && in && !(layout->flags & NK_WINDOW_MINIMIZED)) + { + /* calculate scaler bounds */ + struct nk_rect scaler; + scaler.w = scrollbar_size.x; + scaler.h = scrollbar_size.y; + scaler.y = layout->bounds.y + layout->bounds.h; + if (layout->flags & NK_WINDOW_SCALE_LEFT) + scaler.x = layout->bounds.x - panel_padding.x * 0.5f; + else scaler.x = layout->bounds.x + layout->bounds.w + panel_padding.x; + if (layout->flags & NK_WINDOW_NO_SCROLLBAR) + scaler.x -= scaler.w; + + /* draw scaler */ + {const struct nk_style_item *item = &style->window.scaler; + if (item->type == NK_STYLE_ITEM_IMAGE) + nk_draw_image(out, scaler, &item->data.image, nk_white); + else { + if (layout->flags & NK_WINDOW_SCALE_LEFT) { + nk_fill_triangle(out, scaler.x, scaler.y, scaler.x, + scaler.y + scaler.h, scaler.x + scaler.w, + scaler.y + scaler.h, item->data.color); + } else { + nk_fill_triangle(out, scaler.x + scaler.w, scaler.y, scaler.x + scaler.w, + scaler.y + scaler.h, scaler.x, scaler.y + scaler.h, item->data.color); + } + }} + + /* do window scaling */ + if (!(window->flags & NK_WINDOW_ROM)) { + struct nk_vec2 window_size = style->window.min_size; + int left_mouse_down = in->mouse.buttons[NK_BUTTON_LEFT].down; + int left_mouse_click_in_scaler = nk_input_has_mouse_click_down_in_rect(in, + NK_BUTTON_LEFT, scaler, nk_true); + + if (left_mouse_down && left_mouse_click_in_scaler) { + float delta_x = in->mouse.delta.x; + if (layout->flags & NK_WINDOW_SCALE_LEFT) { + delta_x = -delta_x; + window->bounds.x += in->mouse.delta.x; + } + /* dragging in x-direction */ + if (window->bounds.w + delta_x >= window_size.x) { + if ((delta_x < 0) || (delta_x > 0 && in->mouse.pos.x >= scaler.x)) { + window->bounds.w = window->bounds.w + delta_x; + scaler.x += in->mouse.delta.x; + } + } + /* dragging in y-direction (only possible if static window) */ + if (!(layout->flags & NK_WINDOW_DYNAMIC)) { + if (window_size.y < window->bounds.h + in->mouse.delta.y) { + if ((in->mouse.delta.y < 0) || (in->mouse.delta.y > 0 && in->mouse.pos.y >= scaler.y)) { + window->bounds.h = window->bounds.h + in->mouse.delta.y; + scaler.y += in->mouse.delta.y; + } + } + } + ctx->style.cursor_active = ctx->style.cursors[NK_CURSOR_RESIZE_TOP_RIGHT_DOWN_LEFT]; + in->mouse.buttons[NK_BUTTON_LEFT].clicked_pos.x = scaler.x + scaler.w/2.0f; + in->mouse.buttons[NK_BUTTON_LEFT].clicked_pos.y = scaler.y + scaler.h/2.0f; + } + } + } + if (!nk_panel_is_sub(layout->type)) { + /* window is hidden so clear command buffer */ + if (layout->flags & NK_WINDOW_HIDDEN) + nk_command_buffer_reset(&window->buffer); + /* window is visible and not tab */ + else nk_finish(ctx, window); + } + + /* NK_WINDOW_REMOVE_ROM flag was set so remove NK_WINDOW_ROM */ + if (layout->flags & NK_WINDOW_REMOVE_ROM) { + layout->flags &= ~(nk_flags)NK_WINDOW_ROM; + layout->flags &= ~(nk_flags)NK_WINDOW_REMOVE_ROM; + } + window->flags = layout->flags; + + /* property garbage collector */ + if (window->property.active && window->property.old != window->property.seq && + window->property.active == window->property.prev) { + nk_zero(&window->property, sizeof(window->property)); + } else { + window->property.old = window->property.seq; + window->property.prev = window->property.active; + window->property.seq = 0; + } + /* edit garbage collector */ + if (window->edit.active && window->edit.old != window->edit.seq && + window->edit.active == window->edit.prev) { + nk_zero(&window->edit, sizeof(window->edit)); + } else { + window->edit.old = window->edit.seq; + window->edit.prev = window->edit.active; + window->edit.seq = 0; + } + /* contextual garbage collector */ + if (window->popup.active_con && window->popup.con_old != window->popup.con_count) { + window->popup.con_count = 0; + window->popup.con_old = 0; + window->popup.active_con = 0; + } else { + window->popup.con_old = window->popup.con_count; + window->popup.con_count = 0; + } + window->popup.combo_count = 0; + /* helper to make sure you have a 'nk_tree_push' for every 'nk_tree_pop' */ + NK_ASSERT(!layout->row.tree_depth); +} + +/* ---------------------------------------------------------------- + * + * PAGE ELEMENT + * + * ---------------------------------------------------------------*/ +NK_INTERN struct nk_page_element* +nk_create_page_element(struct nk_context *ctx) +{ + struct nk_page_element *elem; + if (ctx->freelist) { + /* unlink page element from free list */ + elem = ctx->freelist; + ctx->freelist = elem->next; + } else if (ctx->use_pool) { + /* allocate page element from memory pool */ + elem = nk_pool_alloc(&ctx->pool); + NK_ASSERT(elem); + if (!elem) return 0; + } else { + /* allocate new page element from back of fixed size memory buffer */ + NK_STORAGE const nk_size size = sizeof(struct nk_page_element); + NK_STORAGE const nk_size align = NK_ALIGNOF(struct nk_page_element); + elem = (struct nk_page_element*)nk_buffer_alloc(&ctx->memory, NK_BUFFER_BACK, size, align); + NK_ASSERT(elem); + if (!elem) return 0; + } + nk_zero_struct(*elem); + elem->next = 0; + elem->prev = 0; + return elem; +} + +NK_INTERN void +nk_link_page_element_into_freelist(struct nk_context *ctx, + struct nk_page_element *elem) +{ + /* link table into freelist */ + if (!ctx->freelist) { + ctx->freelist = elem; + } else { + elem->next = ctx->freelist; + ctx->freelist = elem; + } +} + +NK_INTERN void +nk_free_page_element(struct nk_context *ctx, struct nk_page_element *elem) +{ + /* we have a pool so just add to free list */ + if (ctx->use_pool) { + nk_link_page_element_into_freelist(ctx, elem); + return; + } + /* if possible remove last element from back of fixed memory buffer */ + {void *elem_end = (void*)(elem + 1); + void *buffer_end = (nk_byte*)ctx->memory.memory.ptr + ctx->memory.size; + if (elem_end == buffer_end) + ctx->memory.size -= sizeof(struct nk_page_element); + else nk_link_page_element_into_freelist(ctx, elem);} +} + +/* ---------------------------------------------------------------- + * + * PANEL + * + * ---------------------------------------------------------------*/ +NK_INTERN void* +nk_create_panel(struct nk_context *ctx) +{ + struct nk_page_element *elem; + elem = nk_create_page_element(ctx); + if (!elem) return 0; + nk_zero_struct(*elem); + return &elem->data.pan; +} + +NK_INTERN void +nk_free_panel(struct nk_context *ctx, struct nk_panel *pan) +{ + union nk_page_data *pd = NK_CONTAINER_OF(pan, union nk_page_data, pan); + struct nk_page_element *pe = NK_CONTAINER_OF(pd, struct nk_page_element, data); + nk_free_page_element(ctx, pe); +} + +/* ---------------------------------------------------------------- + * + * TABLES + * + * ---------------------------------------------------------------*/ +NK_INTERN struct nk_table* +nk_create_table(struct nk_context *ctx) +{ + struct nk_page_element *elem; + elem = nk_create_page_element(ctx); + if (!elem) return 0; + nk_zero_struct(*elem); + return &elem->data.tbl; +} + +NK_INTERN void +nk_free_table(struct nk_context *ctx, struct nk_table *tbl) +{ + union nk_page_data *pd = NK_CONTAINER_OF(tbl, union nk_page_data, tbl); + struct nk_page_element *pe = NK_CONTAINER_OF(pd, struct nk_page_element, data); + nk_free_page_element(ctx, pe); +} + +NK_INTERN void +nk_push_table(struct nk_window *win, struct nk_table *tbl) +{ + if (!win->tables) { + win->tables = tbl; + tbl->next = 0; + tbl->prev = 0; + tbl->size = 0; + win->table_count = 1; + return; + } + win->tables->prev = tbl; + tbl->next = win->tables; + tbl->prev = 0; + tbl->size = 0; + win->tables = tbl; + win->table_count++; +} + +NK_INTERN void +nk_remove_table(struct nk_window *win, struct nk_table *tbl) +{ + if (win->tables == tbl) + win->tables = tbl->next; + if (tbl->next) + tbl->next->prev = tbl->prev; + if (tbl->prev) + tbl->prev->next = tbl->next; + tbl->next = 0; + tbl->prev = 0; +} + +NK_INTERN nk_uint* +nk_add_value(struct nk_context *ctx, struct nk_window *win, + nk_hash name, nk_uint value) +{ + NK_ASSERT(ctx); + NK_ASSERT(win); + if (!win || !ctx) return 0; + if (!win->tables || win->tables->size >= NK_VALUE_PAGE_CAPACITY) { + struct nk_table *tbl = nk_create_table(ctx); + NK_ASSERT(tbl); + if (!tbl) return 0; + nk_push_table(win, tbl); + } + win->tables->seq = win->seq; + win->tables->keys[win->tables->size] = name; + win->tables->values[win->tables->size] = value; + return &win->tables->values[win->tables->size++]; +} + +NK_INTERN nk_uint* +nk_find_value(struct nk_window *win, nk_hash name) +{ + struct nk_table *iter = win->tables; + while (iter) { + unsigned int i = 0; + unsigned int size = iter->size; + for (i = 0; i < size; ++i) { + if (iter->keys[i] == name) { + iter->seq = win->seq; + return &iter->values[i]; + } + } size = NK_VALUE_PAGE_CAPACITY; + iter = iter->next; + } + return 0; +} + +/* ---------------------------------------------------------------- + * + * WINDOW + * + * ---------------------------------------------------------------*/ +NK_INTERN void* +nk_create_window(struct nk_context *ctx) +{ + struct nk_page_element *elem; + elem = nk_create_page_element(ctx); + if (!elem) return 0; + elem->data.win.seq = ctx->seq; + return &elem->data.win; +} + +NK_INTERN void +nk_free_window(struct nk_context *ctx, struct nk_window *win) +{ + /* unlink windows from list */ + struct nk_table *it = win->tables; + if (win->popup.win) { + nk_free_window(ctx, win->popup.win); + win->popup.win = 0; + } + win->next = 0; + win->prev = 0; + + while (it) { + /*free window state tables */ + struct nk_table *n = it->next; + nk_remove_table(win, it); + nk_free_table(ctx, it); + if (it == win->tables) + win->tables = n; + it = n; + } + + /* link windows into freelist */ + {union nk_page_data *pd = NK_CONTAINER_OF(win, union nk_page_data, win); + struct nk_page_element *pe = NK_CONTAINER_OF(pd, struct nk_page_element, data); + nk_free_page_element(ctx, pe);} +} + +NK_INTERN struct nk_window* +nk_find_window(struct nk_context *ctx, nk_hash hash, const char *name) +{ + struct nk_window *iter; + iter = ctx->begin; + while (iter) { + NK_ASSERT(iter != iter->next); + if (iter->name == hash) { + int max_len = nk_strlen(iter->name_string); + if (!nk_stricmpn(iter->name_string, name, max_len)) + return iter; + } + iter = iter->next; + } + return 0; +} + +enum nk_window_insert_location { + NK_INSERT_BACK, /* inserts window into the back of list (front of screen) */ + NK_INSERT_FRONT /* inserts window into the front of list (back of screen) */ +}; +NK_INTERN void +nk_insert_window(struct nk_context *ctx, struct nk_window *win, + enum nk_window_insert_location loc) +{ + const struct nk_window *iter; + NK_ASSERT(ctx); + NK_ASSERT(win); + if (!win || !ctx) return; + + iter = ctx->begin; + while (iter) { + NK_ASSERT(iter != iter->next); + NK_ASSERT(iter != win); + if (iter == win) return; + iter = iter->next; + } + + if (!ctx->begin) { + win->next = 0; + win->prev = 0; + ctx->begin = win; + ctx->end = win; + ctx->count = 1; + return; + } + if (loc == NK_INSERT_BACK) { + struct nk_window *end; + end = ctx->end; + end->flags |= NK_WINDOW_ROM; + end->next = win; + win->prev = ctx->end; + win->next = 0; + ctx->end = win; + ctx->active = ctx->end; + ctx->end->flags &= ~(nk_flags)NK_WINDOW_ROM; + } else { + /*ctx->end->flags |= NK_WINDOW_ROM;*/ + ctx->begin->prev = win; + win->next = ctx->begin; + win->prev = 0; + ctx->begin = win; + ctx->begin->flags &= ~(nk_flags)NK_WINDOW_ROM; + } + ctx->count++; +} + +NK_INTERN void +nk_remove_window(struct nk_context *ctx, struct nk_window *win) +{ + if (win == ctx->begin || win == ctx->end) { + if (win == ctx->begin) { + ctx->begin = win->next; + if (win->next) + win->next->prev = 0; + } + if (win == ctx->end) { + ctx->end = win->prev; + if (win->prev) + win->prev->next = 0; + } + } else { + if (win->next) + win->next->prev = win->prev; + if (win->prev) + win->prev->next = win->next; + } + if (win == ctx->active || !ctx->active) { + ctx->active = ctx->end; + if (ctx->end) + ctx->end->flags &= ~(nk_flags)NK_WINDOW_ROM; + } + win->next = 0; + win->prev = 0; + ctx->count--; +} + +NK_API int +nk_begin(struct nk_context *ctx, const char *title, + struct nk_rect bounds, nk_flags flags) +{ + return nk_begin_titled(ctx, title, title, bounds, flags); +} + +NK_API int +nk_begin_titled(struct nk_context *ctx, const char *name, const char *title, + struct nk_rect bounds, nk_flags flags) +{ + struct nk_window *win; + struct nk_style *style; + nk_hash title_hash; + int title_len; + int ret = 0; + + NK_ASSERT(ctx); + NK_ASSERT(name); + NK_ASSERT(title); + NK_ASSERT(ctx->style.font && ctx->style.font->width && "if this triggers you forgot to add a font"); + NK_ASSERT(!ctx->current && "if this triggers you missed a `nk_end` call"); + if (!ctx || ctx->current || !title || !name) + return 0; + + /* find or create window */ + style = &ctx->style; + title_len = (int)nk_strlen(name); + title_hash = nk_murmur_hash(name, (int)title_len, NK_WINDOW_TITLE); + win = nk_find_window(ctx, title_hash, name); + if (!win) { + /* create new window */ + nk_size name_length = (nk_size)nk_strlen(name); + win = (struct nk_window*)nk_create_window(ctx); + NK_ASSERT(win); + if (!win) return 0; + + if (flags & NK_WINDOW_BACKGROUND) + nk_insert_window(ctx, win, NK_INSERT_FRONT); + else nk_insert_window(ctx, win, NK_INSERT_BACK); + nk_command_buffer_init(&win->buffer, &ctx->memory, NK_CLIPPING_ON); + + win->flags = flags; + win->bounds = bounds; + win->name = title_hash; + name_length = NK_MIN(name_length, NK_WINDOW_MAX_NAME-1); + NK_MEMCPY(win->name_string, name, name_length); + win->name_string[name_length] = 0; + win->popup.win = 0; + if (!ctx->active) + ctx->active = win; + } else { + /* update window */ + win->flags &= ~(nk_flags)(NK_WINDOW_PRIVATE-1); + win->flags |= flags; + if (!(win->flags & (NK_WINDOW_MOVABLE | NK_WINDOW_SCALABLE))) + win->bounds = bounds; + /* If this assert triggers you either: + * + * I.) Have more than one window with the same name or + * II.) You forgot to actually draw the window. + * More specific you did not call `nk_clear` (nk_clear will be + * automatically called for you if you are using one of the + * provided demo backends). */ + NK_ASSERT(win->seq != ctx->seq); + win->seq = ctx->seq; + if (!ctx->active && !(win->flags & NK_WINDOW_HIDDEN)) { + ctx->active = win; + ctx->end = win; + } + } + if (win->flags & NK_WINDOW_HIDDEN) { + ctx->current = win; + win->layout = 0; + return 0; + } else nk_start(ctx, win); + + /* window overlapping */ + if (!(win->flags & NK_WINDOW_HIDDEN) && !(win->flags & NK_WINDOW_NO_INPUT)) + { + int inpanel, ishovered; + struct nk_window *iter = win; + float h = ctx->style.font->height + 2.0f * style->window.header.padding.y + + (2.0f * style->window.header.label_padding.y); + struct nk_rect win_bounds = (!(win->flags & NK_WINDOW_MINIMIZED))? + win->bounds: nk_rect(win->bounds.x, win->bounds.y, win->bounds.w, h); + + /* activate window if hovered and no other window is overlapping this window */ + inpanel = nk_input_has_mouse_click_down_in_rect(&ctx->input, NK_BUTTON_LEFT, win_bounds, nk_true); + inpanel = inpanel && ctx->input.mouse.buttons[NK_BUTTON_LEFT].clicked; + ishovered = nk_input_is_mouse_hovering_rect(&ctx->input, win_bounds); + if ((win != ctx->active) && ishovered && !ctx->input.mouse.buttons[NK_BUTTON_LEFT].down) { + iter = win->next; + while (iter) { + struct nk_rect iter_bounds = (!(iter->flags & NK_WINDOW_MINIMIZED))? + iter->bounds: nk_rect(iter->bounds.x, iter->bounds.y, iter->bounds.w, h); + if (NK_INTERSECT(win_bounds.x, win_bounds.y, win_bounds.w, win_bounds.h, + iter_bounds.x, iter_bounds.y, iter_bounds.w, iter_bounds.h) && + (!(iter->flags & NK_WINDOW_HIDDEN))) + break; + + if (iter->popup.win && iter->popup.active && !(iter->flags & NK_WINDOW_HIDDEN) && + NK_INTERSECT(win->bounds.x, win_bounds.y, win_bounds.w, win_bounds.h, + iter->popup.win->bounds.x, iter->popup.win->bounds.y, + iter->popup.win->bounds.w, iter->popup.win->bounds.h)) + break; + iter = iter->next; + } + } + + /* activate window if clicked */ + if (iter && inpanel && (win != ctx->end)) { + iter = win->next; + while (iter) { + /* try to find a panel with higher priority in the same position */ + struct nk_rect iter_bounds = (!(iter->flags & NK_WINDOW_MINIMIZED))? + iter->bounds: nk_rect(iter->bounds.x, iter->bounds.y, iter->bounds.w, h); + if (NK_INBOX(ctx->input.mouse.pos.x, ctx->input.mouse.pos.y, + iter_bounds.x, iter_bounds.y, iter_bounds.w, iter_bounds.h) && + !(iter->flags & NK_WINDOW_HIDDEN)) + break; + if (iter->popup.win && iter->popup.active && !(iter->flags & NK_WINDOW_HIDDEN) && + NK_INTERSECT(win_bounds.x, win_bounds.y, win_bounds.w, win_bounds.h, + iter->popup.win->bounds.x, iter->popup.win->bounds.y, + iter->popup.win->bounds.w, iter->popup.win->bounds.h)) + break; + iter = iter->next; + } + } + if (iter && !(win->flags & NK_WINDOW_ROM) && (win->flags & NK_WINDOW_BACKGROUND)) { + win->flags |= (nk_flags)NK_WINDOW_ROM; + iter->flags &= ~(nk_flags)NK_WINDOW_ROM; + ctx->active = iter; + if (!(iter->flags & NK_WINDOW_BACKGROUND)) { + /* current window is active in that position so transfer to top + * at the highest priority in stack */ + nk_remove_window(ctx, iter); + nk_insert_window(ctx, iter, NK_INSERT_BACK); + } + } else { + if (!iter && ctx->end != win) { + if (!(win->flags & NK_WINDOW_BACKGROUND)) { + /* current window is active in that position so transfer to top + * at the highest priority in stack */ + nk_remove_window(ctx, win); + nk_insert_window(ctx, win, NK_INSERT_BACK); + } + win->flags &= ~(nk_flags)NK_WINDOW_ROM; + ctx->active = win; + } + if (ctx->end != win && !(win->flags & NK_WINDOW_BACKGROUND)) + win->flags |= NK_WINDOW_ROM; + } + } + win->layout = (struct nk_panel*)nk_create_panel(ctx); + ctx->current = win; + ret = nk_panel_begin(ctx, title, NK_PANEL_WINDOW); + win->layout->offset_x = &win->scrollbar.x; + win->layout->offset_y = &win->scrollbar.y; + return ret; +} + +NK_API void +nk_end(struct nk_context *ctx) +{ + struct nk_panel *layout; + NK_ASSERT(ctx); + NK_ASSERT(ctx->current && "if this triggers you forgot to call `nk_begin`"); + if (!ctx || !ctx->current) + return; + + layout = ctx->current->layout; + if (!layout || (layout->type == NK_PANEL_WINDOW && (ctx->current->flags & NK_WINDOW_HIDDEN))) { + ctx->current = 0; + return; + } + nk_panel_end(ctx); + nk_free_panel(ctx, ctx->current->layout); + ctx->current = 0; +} + +NK_API struct nk_rect +nk_window_get_bounds(const struct nk_context *ctx) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) return nk_rect(0,0,0,0); + return ctx->current->bounds; +} + +NK_API struct nk_vec2 +nk_window_get_position(const struct nk_context *ctx) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) return nk_vec2(0,0); + return nk_vec2(ctx->current->bounds.x, ctx->current->bounds.y); +} + +NK_API struct nk_vec2 +nk_window_get_size(const struct nk_context *ctx) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) return nk_vec2(0,0); + return nk_vec2(ctx->current->bounds.w, ctx->current->bounds.h); +} + +NK_API float +nk_window_get_width(const struct nk_context *ctx) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) return 0; + return ctx->current->bounds.w; +} + +NK_API float +nk_window_get_height(const struct nk_context *ctx) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) return 0; + return ctx->current->bounds.h; +} + +NK_API struct nk_rect +nk_window_get_content_region(struct nk_context *ctx) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) return nk_rect(0,0,0,0); + return ctx->current->layout->clip; +} + +NK_API struct nk_vec2 +nk_window_get_content_region_min(struct nk_context *ctx) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current) return nk_vec2(0,0); + return nk_vec2(ctx->current->layout->clip.x, ctx->current->layout->clip.y); +} + +NK_API struct nk_vec2 +nk_window_get_content_region_max(struct nk_context *ctx) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current) return nk_vec2(0,0); + return nk_vec2(ctx->current->layout->clip.x + ctx->current->layout->clip.w, + ctx->current->layout->clip.y + ctx->current->layout->clip.h); +} + +NK_API struct nk_vec2 +nk_window_get_content_region_size(struct nk_context *ctx) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current) return nk_vec2(0,0); + return nk_vec2(ctx->current->layout->clip.w, ctx->current->layout->clip.h); +} + +NK_API struct nk_command_buffer* +nk_window_get_canvas(struct nk_context *ctx) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current) return 0; + return &ctx->current->buffer; +} + +NK_API struct nk_panel* +nk_window_get_panel(struct nk_context *ctx) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) return 0; + return ctx->current->layout; +} + +NK_API int +nk_window_has_focus(const struct nk_context *ctx) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current) return 0; + return ctx->current == ctx->active; +} + +NK_API int +nk_window_is_hovered(struct nk_context *ctx) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) return 0; + if(ctx->current->flags & NK_WINDOW_HIDDEN) + return 0; + return nk_input_is_mouse_hovering_rect(&ctx->input, ctx->current->bounds); +} + +NK_API int +nk_window_is_any_hovered(struct nk_context *ctx) +{ + struct nk_window *iter; + NK_ASSERT(ctx); + if (!ctx) return 0; + iter = ctx->begin; + while (iter) { + /* check if window is being hovered */ + if(!(iter->flags & NK_WINDOW_HIDDEN)) { + /* check if window popup is being hovered */ + if (iter->popup.active && iter->popup.win && nk_input_is_mouse_hovering_rect(&ctx->input, iter->popup.win->bounds)) + return 1; + + if (iter->flags & NK_WINDOW_MINIMIZED) { + struct nk_rect header = iter->bounds; + header.h = ctx->style.font->height + 2 * ctx->style.window.header.padding.y; + if (nk_input_is_mouse_hovering_rect(&ctx->input, header)) + return 1; + } else if (nk_input_is_mouse_hovering_rect(&ctx->input, iter->bounds)) { + return 1; + } + } + iter = iter->next; + } + return 0; +} + +NK_API int +nk_item_is_any_active(struct nk_context *ctx) +{ + int any_hovered = nk_window_is_any_hovered(ctx); + int any_active = (ctx->last_widget_state & NK_WIDGET_STATE_MODIFIED); + return any_hovered || any_active; +} + +NK_API int +nk_window_is_collapsed(struct nk_context *ctx, const char *name) +{ + int title_len; + nk_hash title_hash; + struct nk_window *win; + NK_ASSERT(ctx); + if (!ctx) return 0; + + title_len = (int)nk_strlen(name); + title_hash = nk_murmur_hash(name, (int)title_len, NK_WINDOW_TITLE); + win = nk_find_window(ctx, title_hash, name); + if (!win) return 0; + return win->flags & NK_WINDOW_MINIMIZED; +} + +NK_API int +nk_window_is_closed(struct nk_context *ctx, const char *name) +{ + int title_len; + nk_hash title_hash; + struct nk_window *win; + NK_ASSERT(ctx); + if (!ctx) return 1; + + title_len = (int)nk_strlen(name); + title_hash = nk_murmur_hash(name, (int)title_len, NK_WINDOW_TITLE); + win = nk_find_window(ctx, title_hash, name); + if (!win) return 1; + return (win->flags & NK_WINDOW_CLOSED); +} + +NK_API int +nk_window_is_hidden(struct nk_context *ctx, const char *name) +{ + int title_len; + nk_hash title_hash; + struct nk_window *win; + NK_ASSERT(ctx); + if (!ctx) return 1; + + title_len = (int)nk_strlen(name); + title_hash = nk_murmur_hash(name, (int)title_len, NK_WINDOW_TITLE); + win = nk_find_window(ctx, title_hash, name); + if (!win) return 1; + return (win->flags & NK_WINDOW_HIDDEN); +} + +NK_API int +nk_window_is_active(struct nk_context *ctx, const char *name) +{ + int title_len; + nk_hash title_hash; + struct nk_window *win; + NK_ASSERT(ctx); + if (!ctx) return 0; + + title_len = (int)nk_strlen(name); + title_hash = nk_murmur_hash(name, (int)title_len, NK_WINDOW_TITLE); + win = nk_find_window(ctx, title_hash, name); + if (!win) return 0; + return win == ctx->active; +} + +NK_API struct nk_window* +nk_window_find(struct nk_context *ctx, const char *name) +{ + int title_len; + nk_hash title_hash; + title_len = (int)nk_strlen(name); + title_hash = nk_murmur_hash(name, (int)title_len, NK_WINDOW_TITLE); + return nk_find_window(ctx, title_hash, name); +} + +NK_API void +nk_window_close(struct nk_context *ctx, const char *name) +{ + struct nk_window *win; + NK_ASSERT(ctx); + if (!ctx) return; + win = nk_window_find(ctx, name); + if (!win) return; + NK_ASSERT(ctx->current != win && "You cannot close a currently active window"); + if (ctx->current == win) return; + win->flags |= NK_WINDOW_HIDDEN; + win->flags |= NK_WINDOW_CLOSED; +} + +NK_API void +nk_window_set_bounds(struct nk_context *ctx, + const char *name, struct nk_rect bounds) +{ + struct nk_window *win; + NK_ASSERT(ctx); + if (!ctx) return; + win = nk_window_find(ctx, name); + if (!win) return; + NK_ASSERT(ctx->current != win && "You cannot update a currently in procecss window"); + win->bounds = bounds; +} + +NK_API void +nk_window_set_position(struct nk_context *ctx, + const char *name, struct nk_vec2 pos) +{ + struct nk_window *win = nk_window_find(ctx, name); + if (!win) return; + win->bounds.x = pos.x; + win->bounds.y = pos.y; +} + +NK_API void +nk_window_set_size(struct nk_context *ctx, + const char *name, struct nk_vec2 size) +{ + struct nk_window *win = nk_window_find(ctx, name); + if (!win) return; + win->bounds.w = size.x; + win->bounds.h = size.y; +} + +NK_API void +nk_window_collapse(struct nk_context *ctx, const char *name, + enum nk_collapse_states c) +{ + int title_len; + nk_hash title_hash; + struct nk_window *win; + NK_ASSERT(ctx); + if (!ctx) return; + + title_len = (int)nk_strlen(name); + title_hash = nk_murmur_hash(name, (int)title_len, NK_WINDOW_TITLE); + win = nk_find_window(ctx, title_hash, name); + if (!win) return; + if (c == NK_MINIMIZED) + win->flags |= NK_WINDOW_MINIMIZED; + else win->flags &= ~(nk_flags)NK_WINDOW_MINIMIZED; +} + +NK_API void +nk_window_collapse_if(struct nk_context *ctx, const char *name, + enum nk_collapse_states c, int cond) +{ + NK_ASSERT(ctx); + if (!ctx || !cond) return; + nk_window_collapse(ctx, name, c); +} + +NK_API void +nk_window_show(struct nk_context *ctx, const char *name, enum nk_show_states s) +{ + int title_len; + nk_hash title_hash; + struct nk_window *win; + NK_ASSERT(ctx); + if (!ctx) return; + + title_len = (int)nk_strlen(name); + title_hash = nk_murmur_hash(name, (int)title_len, NK_WINDOW_TITLE); + win = nk_find_window(ctx, title_hash, name); + if (!win) return; + if (s == NK_HIDDEN) { + win->flags |= NK_WINDOW_HIDDEN; + } else win->flags &= ~(nk_flags)NK_WINDOW_HIDDEN; +} + +NK_API void +nk_window_show_if(struct nk_context *ctx, const char *name, + enum nk_show_states s, int cond) +{ + NK_ASSERT(ctx); + if (!ctx || !cond) return; + nk_window_show(ctx, name, s); +} + +NK_API void +nk_window_set_focus(struct nk_context *ctx, const char *name) +{ + int title_len; + nk_hash title_hash; + struct nk_window *win; + NK_ASSERT(ctx); + if (!ctx) return; + + title_len = (int)nk_strlen(name); + title_hash = nk_murmur_hash(name, (int)title_len, NK_WINDOW_TITLE); + win = nk_find_window(ctx, title_hash, name); + if (win && ctx->end != win) { + nk_remove_window(ctx, win); + nk_insert_window(ctx, win, NK_INSERT_BACK); + } + ctx->active = win; +} + +/*---------------------------------------------------------------- + * + * MENUBAR + * + * --------------------------------------------------------------*/ +NK_API void +nk_menubar_begin(struct nk_context *ctx) +{ + struct nk_panel *layout; + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + layout = ctx->current->layout; + NK_ASSERT(layout->at_y == layout->bounds.y); + /* if this assert triggers you allocated space between nk_begin and nk_menubar_begin. + If you want a menubar the first nuklear function after `nk_begin` has to be a + `nk_menubar_begin` call. Inside the menubar you then have to allocate space for + widgets (also supports multiple rows). + Example: + if (nk_begin(...)) { + nk_menubar_begin(...); + nk_layout_xxxx(...); + nk_button(...); + nk_layout_xxxx(...); + nk_button(...); + nk_menubar_end(...); + } + nk_end(...); + */ + if (layout->flags & NK_WINDOW_HIDDEN || layout->flags & NK_WINDOW_MINIMIZED) + return; + + layout->menu.x = layout->at_x; + layout->menu.y = layout->at_y + layout->row.height; + layout->menu.w = layout->bounds.w; + layout->menu.offset.x = *layout->offset_x; + layout->menu.offset.y = *layout->offset_y; + *layout->offset_y = 0; +} + +NK_API void +nk_menubar_end(struct nk_context *ctx) +{ + struct nk_window *win; + struct nk_panel *layout; + struct nk_command_buffer *out; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + out = &win->buffer; + layout = win->layout; + if (layout->flags & NK_WINDOW_HIDDEN || layout->flags & NK_WINDOW_MINIMIZED) + return; + + layout->menu.h = layout->at_y - layout->menu.y; + layout->bounds.y += layout->menu.h + ctx->style.window.spacing.y + layout->row.height; + layout->bounds.h -= layout->menu.h + ctx->style.window.spacing.y + layout->row.height; + + *layout->offset_x = layout->menu.offset.x; + *layout->offset_y = layout->menu.offset.y; + layout->at_y = layout->bounds.y - layout->row.height; + + layout->clip.y = layout->bounds.y; + layout->clip.h = layout->bounds.h; + nk_push_scissor(out, layout->clip); +} +/* ------------------------------------------------------------- + * + * LAYOUT + * + * --------------------------------------------------------------*/ +NK_API void +nk_layout_set_min_row_height(struct nk_context *ctx, float height) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + layout->row.min_height = height; +} + +NK_API void +nk_layout_reset_min_row_height(struct nk_context *ctx) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + layout->row.min_height = ctx->style.font->height; + layout->row.min_height += ctx->style.text.padding.y*2; + layout->row.min_height += ctx->style.window.min_row_height_padding*2; +} + +NK_INTERN float +nk_layout_row_calculate_usable_space(const struct nk_style *style, enum nk_panel_type type, + float total_space, int columns) +{ + float panel_padding; + float panel_spacing; + float panel_space; + + struct nk_vec2 spacing; + struct nk_vec2 padding; + + spacing = style->window.spacing; + padding = nk_panel_get_padding(style, type); + + /* calculate the usable panel space */ + panel_padding = 2 * padding.x; + panel_spacing = (float)NK_MAX(columns - 1, 0) * spacing.x; + panel_space = total_space - panel_padding - panel_spacing; + return panel_space; +} + +NK_INTERN void +nk_panel_layout(const struct nk_context *ctx, struct nk_window *win, + float height, int cols) +{ + struct nk_panel *layout; + const struct nk_style *style; + struct nk_command_buffer *out; + + struct nk_vec2 item_spacing; + struct nk_color color; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + /* prefetch some configuration data */ + layout = win->layout; + style = &ctx->style; + out = &win->buffer; + color = style->window.background; + item_spacing = style->window.spacing; + + /* if one of these triggers you forgot to add an `if` condition around either + a window, group, popup, combobox or contextual menu `begin` and `end` block. + Example: + if (nk_begin(...) {...} nk_end(...); or + if (nk_group_begin(...) { nk_group_end(...);} */ + NK_ASSERT(!(layout->flags & NK_WINDOW_MINIMIZED)); + NK_ASSERT(!(layout->flags & NK_WINDOW_HIDDEN)); + NK_ASSERT(!(layout->flags & NK_WINDOW_CLOSED)); + + /* update the current row and set the current row layout */ + layout->row.index = 0; + layout->at_y += layout->row.height; + layout->row.columns = cols; + if (height == 0.0f) + layout->row.height = NK_MAX(height, layout->row.min_height) + item_spacing.y; + else layout->row.height = height + item_spacing.y; + + layout->row.item_offset = 0; + if (layout->flags & NK_WINDOW_DYNAMIC) { + /* draw background for dynamic panels */ + struct nk_rect background; + background.x = win->bounds.x; + background.w = win->bounds.w; + background.y = layout->at_y - 1.0f; + background.h = layout->row.height + 1.0f; + nk_fill_rect(out, background, 0, color); + } +} + +NK_INTERN void +nk_row_layout(struct nk_context *ctx, enum nk_layout_format fmt, + float height, int cols, int width) +{ + /* update the current row and set the current row layout */ + struct nk_window *win; + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + nk_panel_layout(ctx, win, height, cols); + if (fmt == NK_DYNAMIC) + win->layout->row.type = NK_LAYOUT_DYNAMIC_FIXED; + else win->layout->row.type = NK_LAYOUT_STATIC_FIXED; + + win->layout->row.ratio = 0; + win->layout->row.filled = 0; + win->layout->row.item_offset = 0; + win->layout->row.item_width = (float)width; +} + +NK_API float +nk_layout_ratio_from_pixel(struct nk_context *ctx, float pixel_width) +{ + struct nk_window *win; + NK_ASSERT(ctx); + NK_ASSERT(pixel_width); + if (!ctx || !ctx->current || !ctx->current->layout) return 0; + win = ctx->current; + return NK_CLAMP(0.0f, pixel_width/win->bounds.x, 1.0f); +} + +NK_API void +nk_layout_row_dynamic(struct nk_context *ctx, float height, int cols) +{ + nk_row_layout(ctx, NK_DYNAMIC, height, cols, 0); +} + +NK_API void +nk_layout_row_static(struct nk_context *ctx, float height, int item_width, int cols) +{ + nk_row_layout(ctx, NK_STATIC, height, cols, item_width); +} + +NK_API void +nk_layout_row_begin(struct nk_context *ctx, enum nk_layout_format fmt, + float row_height, int cols) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + nk_panel_layout(ctx, win, row_height, cols); + if (fmt == NK_DYNAMIC) + layout->row.type = NK_LAYOUT_DYNAMIC_ROW; + else layout->row.type = NK_LAYOUT_STATIC_ROW; + + layout->row.ratio = 0; + layout->row.filled = 0; + layout->row.item_width = 0; + layout->row.item_offset = 0; + layout->row.columns = cols; +} + +NK_API void +nk_layout_row_push(struct nk_context *ctx, float ratio_or_width) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + NK_ASSERT(layout->row.type == NK_LAYOUT_STATIC_ROW || layout->row.type == NK_LAYOUT_DYNAMIC_ROW); + if (layout->row.type != NK_LAYOUT_STATIC_ROW && layout->row.type != NK_LAYOUT_DYNAMIC_ROW) + return; + + if (layout->row.type == NK_LAYOUT_DYNAMIC_ROW) { + float ratio = ratio_or_width; + if ((ratio + layout->row.filled) > 1.0f) return; + if (ratio > 0.0f) + layout->row.item_width = NK_SATURATE(ratio); + else layout->row.item_width = 1.0f - layout->row.filled; + } else layout->row.item_width = ratio_or_width; +} + +NK_API void +nk_layout_row_end(struct nk_context *ctx) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + NK_ASSERT(layout->row.type == NK_LAYOUT_STATIC_ROW || layout->row.type == NK_LAYOUT_DYNAMIC_ROW); + if (layout->row.type != NK_LAYOUT_STATIC_ROW && layout->row.type != NK_LAYOUT_DYNAMIC_ROW) + return; + layout->row.item_width = 0; + layout->row.item_offset = 0; +} + +NK_API void +nk_layout_row(struct nk_context *ctx, enum nk_layout_format fmt, + float height, int cols, const float *ratio) +{ + int i; + int n_undef = 0; + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + nk_panel_layout(ctx, win, height, cols); + if (fmt == NK_DYNAMIC) { + /* calculate width of undefined widget ratios */ + float r = 0; + layout->row.ratio = ratio; + for (i = 0; i < cols; ++i) { + if (ratio[i] < 0.0f) + n_undef++; + else r += ratio[i]; + } + r = NK_SATURATE(1.0f - r); + layout->row.type = NK_LAYOUT_DYNAMIC; + layout->row.item_width = (r > 0 && n_undef > 0) ? (r / (float)n_undef):0; + } else { + layout->row.ratio = ratio; + layout->row.type = NK_LAYOUT_STATIC; + layout->row.item_width = 0; + layout->row.item_offset = 0; + } + layout->row.item_offset = 0; + layout->row.filled = 0; +} + +NK_API void +nk_layout_row_template_begin(struct nk_context *ctx, float height) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + nk_panel_layout(ctx, win, height, 1); + layout->row.type = NK_LAYOUT_TEMPLATE; + layout->row.columns = 0; + layout->row.ratio = 0; + layout->row.item_width = 0; + layout->row.item_height = 0; + layout->row.item_offset = 0; + layout->row.filled = 0; + layout->row.item.x = 0; + layout->row.item.y = 0; + layout->row.item.w = 0; + layout->row.item.h = 0; +} + +NK_API void +nk_layout_row_template_push_dynamic(struct nk_context *ctx) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + NK_ASSERT(layout->row.type == NK_LAYOUT_TEMPLATE); + NK_ASSERT(layout->row.columns < NK_MAX_LAYOUT_ROW_TEMPLATE_COLUMNS); + if (layout->row.type != NK_LAYOUT_TEMPLATE) return; + if (layout->row.columns >= NK_MAX_LAYOUT_ROW_TEMPLATE_COLUMNS) return; + layout->row.templates[layout->row.columns++] = -1.0f; +} + +NK_API void +nk_layout_row_template_push_variable(struct nk_context *ctx, float min_width) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + NK_ASSERT(layout->row.type == NK_LAYOUT_TEMPLATE); + NK_ASSERT(layout->row.columns < NK_MAX_LAYOUT_ROW_TEMPLATE_COLUMNS); + if (layout->row.type != NK_LAYOUT_TEMPLATE) return; + if (layout->row.columns >= NK_MAX_LAYOUT_ROW_TEMPLATE_COLUMNS) return; + layout->row.templates[layout->row.columns++] = -min_width; +} + +NK_API void +nk_layout_row_template_push_static(struct nk_context *ctx, float width) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + NK_ASSERT(layout->row.type == NK_LAYOUT_TEMPLATE); + NK_ASSERT(layout->row.columns < NK_MAX_LAYOUT_ROW_TEMPLATE_COLUMNS); + if (layout->row.type != NK_LAYOUT_TEMPLATE) return; + if (layout->row.columns >= NK_MAX_LAYOUT_ROW_TEMPLATE_COLUMNS) return; + layout->row.templates[layout->row.columns++] = width; +} + +NK_API void +nk_layout_row_template_end(struct nk_context *ctx) +{ + struct nk_window *win; + struct nk_panel *layout; + + int i = 0; + int variable_count = 0; + int min_variable_count = 0; + float min_fixed_width = 0.0f; + float total_fixed_width = 0.0f; + float max_variable_width = 0.0f; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + NK_ASSERT(layout->row.type == NK_LAYOUT_TEMPLATE); + if (layout->row.type != NK_LAYOUT_TEMPLATE) return; + for (i = 0; i < layout->row.columns; ++i) { + float width = layout->row.templates[i]; + if (width >= 0.0f) { + total_fixed_width += width; + min_fixed_width += width; + } else if (width < -1.0f) { + width = -width; + total_fixed_width += width; + max_variable_width = NK_MAX(max_variable_width, width); + variable_count++; + } else { + min_variable_count++; + variable_count++; + } + } + if (variable_count) { + float space = nk_layout_row_calculate_usable_space(&ctx->style, layout->type, + layout->bounds.w, layout->row.columns); + float var_width = (NK_MAX(space-min_fixed_width,0.0f)) / (float)variable_count; + int enough_space = var_width >= max_variable_width; + if (!enough_space) + var_width = (NK_MAX(space-total_fixed_width,0)) / (float)min_variable_count; + for (i = 0; i < layout->row.columns; ++i) { + float *width = &layout->row.templates[i]; + *width = (*width >= 0.0f)? *width: (*width < -1.0f && !enough_space)? -(*width): var_width; + } + } +} + +NK_API void +nk_layout_space_begin(struct nk_context *ctx, enum nk_layout_format fmt, + float height, int widget_count) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + nk_panel_layout(ctx, win, height, widget_count); + if (fmt == NK_STATIC) + layout->row.type = NK_LAYOUT_STATIC_FREE; + else layout->row.type = NK_LAYOUT_DYNAMIC_FREE; + + layout->row.ratio = 0; + layout->row.filled = 0; + layout->row.item_width = 0; + layout->row.item_offset = 0; +} + +NK_API void +nk_layout_space_end(struct nk_context *ctx) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + layout->row.item_width = 0; + layout->row.item_height = 0; + layout->row.item_offset = 0; + nk_zero(&layout->row.item, sizeof(layout->row.item)); +} + +NK_API void +nk_layout_space_push(struct nk_context *ctx, struct nk_rect rect) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + layout->row.item = rect; +} + +NK_API struct nk_rect +nk_layout_space_bounds(struct nk_context *ctx) +{ + struct nk_rect ret; + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + win = ctx->current; + layout = win->layout; + + ret.x = layout->clip.x; + ret.y = layout->clip.y; + ret.w = layout->clip.w; + ret.h = layout->row.height; + return ret; +} + +NK_API struct nk_rect +nk_layout_widget_bounds(struct nk_context *ctx) +{ + struct nk_rect ret; + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + win = ctx->current; + layout = win->layout; + + ret.x = layout->at_x; + ret.y = layout->at_y; + ret.w = layout->bounds.w - NK_MAX(layout->at_x - layout->bounds.x,0); + ret.h = layout->row.height; + return ret; +} + +NK_API struct nk_vec2 +nk_layout_space_to_screen(struct nk_context *ctx, struct nk_vec2 ret) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + win = ctx->current; + layout = win->layout; + + ret.x += layout->at_x - (float)*layout->offset_x; + ret.y += layout->at_y - (float)*layout->offset_y; + return ret; +} + +NK_API struct nk_vec2 +nk_layout_space_to_local(struct nk_context *ctx, struct nk_vec2 ret) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + win = ctx->current; + layout = win->layout; + + ret.x += -layout->at_x + (float)*layout->offset_x; + ret.y += -layout->at_y + (float)*layout->offset_y; + return ret; +} + +NK_API struct nk_rect +nk_layout_space_rect_to_screen(struct nk_context *ctx, struct nk_rect ret) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + win = ctx->current; + layout = win->layout; + + ret.x += layout->at_x - (float)*layout->offset_x; + ret.y += layout->at_y - (float)*layout->offset_y; + return ret; +} + +NK_API struct nk_rect +nk_layout_space_rect_to_local(struct nk_context *ctx, struct nk_rect ret) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + win = ctx->current; + layout = win->layout; + + ret.x += -layout->at_x + (float)*layout->offset_x; + ret.y += -layout->at_y + (float)*layout->offset_y; + return ret; +} + +NK_INTERN void +nk_panel_alloc_row(const struct nk_context *ctx, struct nk_window *win) +{ + struct nk_panel *layout = win->layout; + struct nk_vec2 spacing = ctx->style.window.spacing; + const float row_height = layout->row.height - spacing.y; + nk_panel_layout(ctx, win, row_height, layout->row.columns); +} + +NK_INTERN void +nk_layout_widget_space(struct nk_rect *bounds, const struct nk_context *ctx, + struct nk_window *win, int modify) +{ + struct nk_panel *layout; + const struct nk_style *style; + + struct nk_vec2 spacing; + struct nk_vec2 padding; + + float item_offset = 0; + float item_width = 0; + float item_spacing = 0; + float panel_space = 0; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + style = &ctx->style; + NK_ASSERT(bounds); + + spacing = style->window.spacing; + padding = nk_panel_get_padding(style, layout->type); + panel_space = nk_layout_row_calculate_usable_space(&ctx->style, layout->type, + layout->bounds.w, layout->row.columns); + + /* calculate the width of one item inside the current layout space */ + switch (layout->row.type) { + case NK_LAYOUT_DYNAMIC_FIXED: { + /* scaling fixed size widgets item width */ + item_width = NK_MAX(1.0f,panel_space-1.0f) / (float)layout->row.columns; + item_offset = (float)layout->row.index * item_width; + item_spacing = (float)layout->row.index * spacing.x; + } break; + case NK_LAYOUT_DYNAMIC_ROW: { + /* scaling single ratio widget width */ + item_width = layout->row.item_width * panel_space; + item_offset = layout->row.item_offset; + item_spacing = 0; + + if (modify) { + layout->row.item_offset += item_width + spacing.x; + layout->row.filled += layout->row.item_width; + layout->row.index = 0; + } + } break; + case NK_LAYOUT_DYNAMIC_FREE: { + /* panel width depended free widget placing */ + bounds->x = layout->at_x + (layout->bounds.w * layout->row.item.x); + bounds->x -= (float)*layout->offset_x; + bounds->y = layout->at_y + (layout->row.height * layout->row.item.y); + bounds->y -= (float)*layout->offset_y; + bounds->w = layout->bounds.w * layout->row.item.w; + bounds->h = layout->row.height * layout->row.item.h; + return; + } break; + case NK_LAYOUT_DYNAMIC: { + /* scaling arrays of panel width ratios for every widget */ + float ratio; + NK_ASSERT(layout->row.ratio); + ratio = (layout->row.ratio[layout->row.index] < 0) ? + layout->row.item_width : layout->row.ratio[layout->row.index]; + + item_spacing = (float)layout->row.index * spacing.x; + item_width = (ratio * panel_space); + item_offset = layout->row.item_offset; + + if (modify) { + layout->row.item_offset += item_width; + layout->row.filled += ratio; + } + } break; + case NK_LAYOUT_STATIC_FIXED: { + /* non-scaling fixed widgets item width */ + item_width = layout->row.item_width; + item_offset = (float)layout->row.index * item_width; + item_spacing = (float)layout->row.index * spacing.x; + } break; + case NK_LAYOUT_STATIC_ROW: { + /* scaling single ratio widget width */ + item_width = layout->row.item_width; + item_offset = layout->row.item_offset; + item_spacing = (float)layout->row.index * spacing.x; + if (modify) layout->row.item_offset += item_width; + } break; + case NK_LAYOUT_STATIC_FREE: { + /* free widget placing */ + bounds->x = layout->at_x + layout->row.item.x; + bounds->w = layout->row.item.w; + if (((bounds->x + bounds->w) > layout->max_x) && modify) + layout->max_x = (bounds->x + bounds->w); + bounds->x -= (float)*layout->offset_x; + bounds->y = layout->at_y + layout->row.item.y; + bounds->y -= (float)*layout->offset_y; + bounds->h = layout->row.item.h; + return; + } break; + case NK_LAYOUT_STATIC: { + /* non-scaling array of panel pixel width for every widget */ + item_spacing = (float)layout->row.index * spacing.x; + item_width = layout->row.ratio[layout->row.index]; + item_offset = layout->row.item_offset; + if (modify) layout->row.item_offset += item_width; + } break; + case NK_LAYOUT_TEMPLATE: { + /* stretchy row layout with combined dynamic/static widget width*/ + NK_ASSERT(layout->row.index < layout->row.columns); + NK_ASSERT(layout->row.index < NK_MAX_LAYOUT_ROW_TEMPLATE_COLUMNS); + item_width = layout->row.templates[layout->row.index]; + item_offset = layout->row.item_offset; + item_spacing = (float)layout->row.index * spacing.x; + if (modify) layout->row.item_offset += item_width; + } break; + default: NK_ASSERT(0); break; + }; + + /* set the bounds of the newly allocated widget */ + bounds->w = item_width; + bounds->h = layout->row.height - spacing.y; + bounds->y = layout->at_y - (float)*layout->offset_y; + bounds->x = layout->at_x + item_offset + item_spacing + padding.x; + if (((bounds->x + bounds->w) > layout->max_x) && modify) + layout->max_x = bounds->x + bounds->w; + bounds->x -= (float)*layout->offset_x; +} + +NK_INTERN void +nk_panel_alloc_space(struct nk_rect *bounds, const struct nk_context *ctx) +{ + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + /* check if the end of the row has been hit and begin new row if so */ + win = ctx->current; + layout = win->layout; + if (layout->row.index >= layout->row.columns) + nk_panel_alloc_row(ctx, win); + + /* calculate widget position and size */ + nk_layout_widget_space(bounds, ctx, win, nk_true); + layout->row.index++; +} + +NK_INTERN void +nk_layout_peek(struct nk_rect *bounds, struct nk_context *ctx) +{ + float y; + int index; + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + y = layout->at_y; + index = layout->row.index; + if (layout->row.index >= layout->row.columns) { + layout->at_y += layout->row.height; + layout->row.index = 0; + } + nk_layout_widget_space(bounds, ctx, win, nk_false); + if (!layout->row.index) { + bounds->x -= layout->row.item_offset; + } + layout->at_y = y; + layout->row.index = index; +} + +NK_INTERN int +nk_tree_state_base(struct nk_context *ctx, enum nk_tree_type type, + struct nk_image *img, const char *title, enum nk_collapse_states *state) +{ + struct nk_window *win; + struct nk_panel *layout; + const struct nk_style *style; + struct nk_command_buffer *out; + const struct nk_input *in; + const struct nk_style_button *button; + enum nk_symbol_type symbol; + float row_height; + + struct nk_vec2 item_spacing; + struct nk_rect header = {0,0,0,0}; + struct nk_rect sym = {0,0,0,0}; + struct nk_text text; + + nk_flags ws = 0; + enum nk_widget_layout_states widget_state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + /* cache some data */ + win = ctx->current; + layout = win->layout; + out = &win->buffer; + style = &ctx->style; + item_spacing = style->window.spacing; + + /* calculate header bounds and draw background */ + row_height = style->font->height + 2 * style->tab.padding.y; + nk_layout_set_min_row_height(ctx, row_height); + nk_layout_row_dynamic(ctx, row_height, 1); + nk_layout_reset_min_row_height(ctx); + + widget_state = nk_widget(&header, ctx); + if (type == NK_TREE_TAB) { + const struct nk_style_item *background = &style->tab.background; + if (background->type == NK_STYLE_ITEM_IMAGE) { + nk_draw_image(out, header, &background->data.image, nk_white); + text.background = nk_rgba(0,0,0,0); + } else { + text.background = background->data.color; + nk_fill_rect(out, header, 0, style->tab.border_color); + nk_fill_rect(out, nk_shrink_rect(header, style->tab.border), + style->tab.rounding, background->data.color); + } + } else text.background = style->window.background; + + /* update node state */ + in = (!(layout->flags & NK_WINDOW_ROM)) ? &ctx->input: 0; + in = (in && widget_state == NK_WIDGET_VALID) ? &ctx->input : 0; + if (nk_button_behavior(&ws, header, in, NK_BUTTON_DEFAULT)) + *state = (*state == NK_MAXIMIZED) ? NK_MINIMIZED : NK_MAXIMIZED; + + /* select correct button style */ + if (*state == NK_MAXIMIZED) { + symbol = style->tab.sym_maximize; + if (type == NK_TREE_TAB) + button = &style->tab.tab_maximize_button; + else button = &style->tab.node_maximize_button; + } else { + symbol = style->tab.sym_minimize; + if (type == NK_TREE_TAB) + button = &style->tab.tab_minimize_button; + else button = &style->tab.node_minimize_button; + } + + {/* draw triangle button */ + sym.w = sym.h = style->font->height; + sym.y = header.y + style->tab.padding.y; + sym.x = header.x + style->tab.padding.x; + nk_do_button_symbol(&ws, &win->buffer, sym, symbol, NK_BUTTON_DEFAULT, + button, 0, style->font); + + if (img) { + /* draw optional image icon */ + sym.x = sym.x + sym.w + 4 * item_spacing.x; + nk_draw_image(&win->buffer, sym, img, nk_white); + sym.w = style->font->height + style->tab.spacing.x;} + } + + {/* draw label */ + struct nk_rect label; + header.w = NK_MAX(header.w, sym.w + item_spacing.x); + label.x = sym.x + sym.w + item_spacing.x; + label.y = sym.y; + label.w = header.w - (sym.w + item_spacing.y + style->tab.indent); + label.h = style->font->height; + text.text = style->tab.text; + text.padding = nk_vec2(0,0); + nk_widget_text(out, label, title, nk_strlen(title), &text, + NK_TEXT_LEFT, style->font);} + + /* increase x-axis cursor widget position pointer */ + if (*state == NK_MAXIMIZED) { + layout->at_x = header.x + (float)*layout->offset_x + style->tab.indent; + layout->bounds.w = NK_MAX(layout->bounds.w, style->tab.indent); + layout->bounds.w -= (style->tab.indent + style->window.padding.x); + layout->row.tree_depth++; + return nk_true; + } else return nk_false; +} + +NK_INTERN int +nk_tree_base(struct nk_context *ctx, enum nk_tree_type type, + struct nk_image *img, const char *title, enum nk_collapse_states initial_state, + const char *hash, int len, int line) +{ + struct nk_window *win = ctx->current; + int title_len = 0; + nk_hash tree_hash = 0; + nk_uint *state = 0; + + /* retrieve tree state from internal widget state tables */ + if (!hash) { + title_len = (int)nk_strlen(title); + tree_hash = nk_murmur_hash(title, (int)title_len, (nk_hash)line); + } else tree_hash = nk_murmur_hash(hash, len, (nk_hash)line); + state = nk_find_value(win, tree_hash); + if (!state) { + state = nk_add_value(ctx, win, tree_hash, 0); + *state = initial_state; + } + return nk_tree_state_base(ctx, type, img, title, (enum nk_collapse_states*)state); +} + +NK_API int +nk_tree_state_push(struct nk_context *ctx, enum nk_tree_type type, + const char *title, enum nk_collapse_states *state) +{return nk_tree_state_base(ctx, type, 0, title, state);} + +NK_API int +nk_tree_state_image_push(struct nk_context *ctx, enum nk_tree_type type, + struct nk_image img, const char *title, enum nk_collapse_states *state) +{return nk_tree_state_base(ctx, type, &img, title, state);} + +NK_API void +nk_tree_state_pop(struct nk_context *ctx) +{ + struct nk_window *win = 0; + struct nk_panel *layout = 0; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + layout->at_x -= ctx->style.tab.indent + ctx->style.window.padding.x; + layout->bounds.w += ctx->style.tab.indent + ctx->style.window.padding.x; + NK_ASSERT(layout->row.tree_depth); + layout->row.tree_depth--; +} + +NK_API int +nk_tree_push_hashed(struct nk_context *ctx, enum nk_tree_type type, + const char *title, enum nk_collapse_states initial_state, + const char *hash, int len, int line) +{return nk_tree_base(ctx, type, 0, title, initial_state, hash, len, line);} + +NK_API int +nk_tree_image_push_hashed(struct nk_context *ctx, enum nk_tree_type type, + struct nk_image img, const char *title, enum nk_collapse_states initial_state, + const char *hash, int len,int seed) +{return nk_tree_base(ctx, type, &img, title, initial_state, hash, len, seed);} + +NK_API void +nk_tree_pop(struct nk_context *ctx) +{nk_tree_state_pop(ctx);} + +/*---------------------------------------------------------------- + * + * WIDGETS + * + * --------------------------------------------------------------*/ +NK_API struct nk_rect +nk_widget_bounds(struct nk_context *ctx) +{ + struct nk_rect bounds; + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) + return nk_rect(0,0,0,0); + nk_layout_peek(&bounds, ctx); + return bounds; +} + +NK_API struct nk_vec2 +nk_widget_position(struct nk_context *ctx) +{ + struct nk_rect bounds; + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) + return nk_vec2(0,0); + + nk_layout_peek(&bounds, ctx); + return nk_vec2(bounds.x, bounds.y); +} + +NK_API struct nk_vec2 +nk_widget_size(struct nk_context *ctx) +{ + struct nk_rect bounds; + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) + return nk_vec2(0,0); + + nk_layout_peek(&bounds, ctx); + return nk_vec2(bounds.w, bounds.h); +} + +NK_API float +nk_widget_width(struct nk_context *ctx) +{ + struct nk_rect bounds; + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) + return 0; + + nk_layout_peek(&bounds, ctx); + return bounds.w; +} + +NK_API float +nk_widget_height(struct nk_context *ctx) +{ + struct nk_rect bounds; + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) + return 0; + + nk_layout_peek(&bounds, ctx); + return bounds.h; +} + +NK_API int +nk_widget_is_hovered(struct nk_context *ctx) +{ + struct nk_rect c, v; + struct nk_rect bounds; + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current || ctx->active != ctx->current) + return 0; + + c = ctx->current->layout->clip; + c.x = (float)((int)c.x); + c.y = (float)((int)c.y); + c.w = (float)((int)c.w); + c.h = (float)((int)c.h); + + nk_layout_peek(&bounds, ctx); + nk_unify(&v, &c, bounds.x, bounds.y, bounds.x + bounds.w, bounds.y + bounds.h); + if (!NK_INTERSECT(c.x, c.y, c.w, c.h, bounds.x, bounds.y, bounds.w, bounds.h)) + return 0; + return nk_input_is_mouse_hovering_rect(&ctx->input, bounds); +} + +NK_API int +nk_widget_is_mouse_clicked(struct nk_context *ctx, enum nk_buttons btn) +{ + struct nk_rect c, v; + struct nk_rect bounds; + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current || ctx->active != ctx->current) + return 0; + + c = ctx->current->layout->clip; + c.x = (float)((int)c.x); + c.y = (float)((int)c.y); + c.w = (float)((int)c.w); + c.h = (float)((int)c.h); + + nk_layout_peek(&bounds, ctx); + nk_unify(&v, &c, bounds.x, bounds.y, bounds.x + bounds.w, bounds.y + bounds.h); + if (!NK_INTERSECT(c.x, c.y, c.w, c.h, bounds.x, bounds.y, bounds.w, bounds.h)) + return 0; + return nk_input_mouse_clicked(&ctx->input, btn, bounds); +} + +NK_API int +nk_widget_has_mouse_click_down(struct nk_context *ctx, enum nk_buttons btn, int down) +{ + struct nk_rect c, v; + struct nk_rect bounds; + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current || ctx->active != ctx->current) + return 0; + + c = ctx->current->layout->clip; + c.x = (float)((int)c.x); + c.y = (float)((int)c.y); + c.w = (float)((int)c.w); + c.h = (float)((int)c.h); + + nk_layout_peek(&bounds, ctx); + nk_unify(&v, &c, bounds.x, bounds.y, bounds.x + bounds.w, bounds.y + bounds.h); + if (!NK_INTERSECT(c.x, c.y, c.w, c.h, bounds.x, bounds.y, bounds.w, bounds.h)) + return 0; + return nk_input_has_mouse_click_down_in_rect(&ctx->input, btn, bounds, down); +} + +NK_API enum nk_widget_layout_states +nk_widget(struct nk_rect *bounds, const struct nk_context *ctx) +{ + struct nk_rect c, v; + struct nk_window *win; + struct nk_panel *layout; + const struct nk_input *in; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return NK_WIDGET_INVALID; + + /* allocate space and check if the widget needs to be updated and drawn */ + nk_panel_alloc_space(bounds, ctx); + win = ctx->current; + layout = win->layout; + in = &ctx->input; + c = layout->clip; + + /* if one of these triggers you forgot to add an `if` condition around either + a window, group, popup, combobox or contextual menu `begin` and `end` block. + Example: + if (nk_begin(...) {...} nk_end(...); or + if (nk_group_begin(...) { nk_group_end(...);} */ + NK_ASSERT(!(layout->flags & NK_WINDOW_MINIMIZED)); + NK_ASSERT(!(layout->flags & NK_WINDOW_HIDDEN)); + NK_ASSERT(!(layout->flags & NK_WINDOW_CLOSED)); + + /* need to convert to int here to remove floating point errors */ + bounds->x = (float)((int)bounds->x); + bounds->y = (float)((int)bounds->y); + bounds->w = (float)((int)bounds->w); + bounds->h = (float)((int)bounds->h); + + c.x = (float)((int)c.x); + c.y = (float)((int)c.y); + c.w = (float)((int)c.w); + c.h = (float)((int)c.h); + + nk_unify(&v, &c, bounds->x, bounds->y, bounds->x + bounds->w, bounds->y + bounds->h); + if (!NK_INTERSECT(c.x, c.y, c.w, c.h, bounds->x, bounds->y, bounds->w, bounds->h)) + return NK_WIDGET_INVALID; + if (!NK_INBOX(in->mouse.pos.x, in->mouse.pos.y, v.x, v.y, v.w, v.h)) + return NK_WIDGET_ROM; + return NK_WIDGET_VALID; +} + +NK_API enum nk_widget_layout_states +nk_widget_fitting(struct nk_rect *bounds, struct nk_context *ctx, + struct nk_vec2 item_padding) +{ + /* update the bounds to stand without padding */ + struct nk_window *win; + struct nk_style *style; + struct nk_panel *layout; + enum nk_widget_layout_states state; + struct nk_vec2 panel_padding; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return NK_WIDGET_INVALID; + + win = ctx->current; + style = &ctx->style; + layout = win->layout; + state = nk_widget(bounds, ctx); + + panel_padding = nk_panel_get_padding(style, layout->type); + if (layout->row.index == 1) { + bounds->w += panel_padding.x; + bounds->x -= panel_padding.x; + } else bounds->x -= item_padding.x; + + if (layout->row.index == layout->row.columns) + bounds->w += panel_padding.x; + else bounds->w += item_padding.x; + return state; +} + +/*---------------------------------------------------------------- + * + * MISC + * + * --------------------------------------------------------------*/ +NK_API void +nk_spacing(struct nk_context *ctx, int cols) +{ + struct nk_window *win; + struct nk_panel *layout; + struct nk_rect none; + int i, index, rows; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + /* spacing over row boundaries */ + win = ctx->current; + layout = win->layout; + index = (layout->row.index + cols) % layout->row.columns; + rows = (layout->row.index + cols) / layout->row.columns; + if (rows) { + for (i = 0; i < rows; ++i) + nk_panel_alloc_row(ctx, win); + cols = index; + } + /* non table layout need to allocate space */ + if (layout->row.type != NK_LAYOUT_DYNAMIC_FIXED && + layout->row.type != NK_LAYOUT_STATIC_FIXED) { + for (i = 0; i < cols; ++i) + nk_panel_alloc_space(&none, ctx); + } + layout->row.index = index; +} + +/*---------------------------------------------------------------- + * + * TEXT + * + * --------------------------------------------------------------*/ +NK_API void +nk_text_colored(struct nk_context *ctx, const char *str, int len, + nk_flags alignment, struct nk_color color) +{ + struct nk_window *win; + const struct nk_style *style; + + struct nk_vec2 item_padding; + struct nk_rect bounds; + struct nk_text text; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) return; + + win = ctx->current; + style = &ctx->style; + nk_panel_alloc_space(&bounds, ctx); + item_padding = style->text.padding; + + text.padding.x = item_padding.x; + text.padding.y = item_padding.y; + text.background = style->window.background; + text.text = color; + nk_widget_text(&win->buffer, bounds, str, len, &text, alignment, style->font); +} + +NK_API void +nk_text_wrap_colored(struct nk_context *ctx, const char *str, + int len, struct nk_color color) +{ + struct nk_window *win; + const struct nk_style *style; + + struct nk_vec2 item_padding; + struct nk_rect bounds; + struct nk_text text; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) return; + + win = ctx->current; + style = &ctx->style; + nk_panel_alloc_space(&bounds, ctx); + item_padding = style->text.padding; + + text.padding.x = item_padding.x; + text.padding.y = item_padding.y; + text.background = style->window.background; + text.text = color; + nk_widget_text_wrap(&win->buffer, bounds, str, len, &text, style->font); +} + +#ifdef NK_INCLUDE_STANDARD_VARARGS +NK_API void +nk_labelf_colored(struct nk_context *ctx, nk_flags flags, + struct nk_color color, const char *fmt, ...) +{ + char buf[256]; + va_list args; + va_start(args, fmt); + nk_strfmt(buf, NK_LEN(buf), fmt, args); + nk_label_colored(ctx, buf, flags, color); + va_end(args); +} + +NK_API void +nk_labelf_colored_wrap(struct nk_context *ctx, struct nk_color color, + const char *fmt, ...) +{ + char buf[256]; + va_list args; + va_start(args, fmt); + nk_strfmt(buf, NK_LEN(buf), fmt, args); + nk_label_colored_wrap(ctx, buf, color); + va_end(args); +} + +NK_API void +nk_labelf(struct nk_context *ctx, nk_flags flags, const char *fmt, ...) +{ + char buf[256]; + va_list args; + va_start(args, fmt); + nk_strfmt(buf, NK_LEN(buf), fmt, args); + nk_label(ctx, buf, flags); + va_end(args); +} + +NK_API void +nk_labelf_wrap(struct nk_context *ctx, const char *fmt,...) +{ + char buf[256]; + va_list args; + va_start(args, fmt); + nk_strfmt(buf, NK_LEN(buf), fmt, args); + nk_label_wrap(ctx, buf); + va_end(args); +} + +NK_API void +nk_value_bool(struct nk_context *ctx, const char *prefix, int value) +{nk_labelf(ctx, NK_TEXT_LEFT, "%s: %s", prefix, ((value) ? "true": "false"));} + +NK_API void +nk_value_int(struct nk_context *ctx, const char *prefix, int value) +{nk_labelf(ctx, NK_TEXT_LEFT, "%s: %d", prefix, value);} + +NK_API void +nk_value_uint(struct nk_context *ctx, const char *prefix, unsigned int value) +{nk_labelf(ctx, NK_TEXT_LEFT, "%s: %u", prefix, value);} + +NK_API void +nk_value_float(struct nk_context *ctx, const char *prefix, float value) +{ + double double_value = (double)value; + nk_labelf(ctx, NK_TEXT_LEFT, "%s: %.3f", prefix, double_value); +} + +NK_API void +nk_value_color_byte(struct nk_context *ctx, const char *p, struct nk_color c) +{nk_labelf(ctx, NK_TEXT_LEFT, "%s: (%d, %d, %d, %d)", p, c.r, c.g, c.b, c.a);} + +NK_API void +nk_value_color_float(struct nk_context *ctx, const char *p, struct nk_color color) +{ + double c[4]; nk_color_dv(c, color); + nk_labelf(ctx, NK_TEXT_LEFT, "%s: (%.2f, %.2f, %.2f, %.2f)", + p, c[0], c[1], c[2], c[3]); +} + +NK_API void +nk_value_color_hex(struct nk_context *ctx, const char *prefix, struct nk_color color) +{ + char hex[16]; + nk_color_hex_rgba(hex, color); + nk_labelf(ctx, NK_TEXT_LEFT, "%s: %s", prefix, hex); +} +#endif + +NK_API void +nk_text(struct nk_context *ctx, const char *str, int len, nk_flags alignment) +{ + NK_ASSERT(ctx); + if (!ctx) return; + nk_text_colored(ctx, str, len, alignment, ctx->style.text.color); +} + +NK_API void +nk_text_wrap(struct nk_context *ctx, const char *str, int len) +{ + NK_ASSERT(ctx); + if (!ctx) return; + nk_text_wrap_colored(ctx, str, len, ctx->style.text.color); +} + +NK_API void +nk_label(struct nk_context *ctx, const char *str, nk_flags alignment) +{nk_text(ctx, str, nk_strlen(str), alignment);} + +NK_API void +nk_label_colored(struct nk_context *ctx, const char *str, nk_flags align, + struct nk_color color) +{nk_text_colored(ctx, str, nk_strlen(str), align, color);} + +NK_API void +nk_label_wrap(struct nk_context *ctx, const char *str) +{nk_text_wrap(ctx, str, nk_strlen(str));} + +NK_API void +nk_label_colored_wrap(struct nk_context *ctx, const char *str, struct nk_color color) +{nk_text_wrap_colored(ctx, str, nk_strlen(str), color);} + +NK_API void +nk_image(struct nk_context *ctx, struct nk_image img) +{ + struct nk_window *win; + struct nk_rect bounds; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) return; + + win = ctx->current; + if (!nk_widget(&bounds, ctx)) return; + nk_draw_image(&win->buffer, bounds, &img, nk_white); +} + +/*---------------------------------------------------------------- + * + * BUTTON + * + * --------------------------------------------------------------*/ +NK_API void +nk_button_set_behavior(struct nk_context *ctx, enum nk_button_behavior behavior) +{ + NK_ASSERT(ctx); + if (!ctx) return; + ctx->button_behavior = behavior; +} + +NK_API int +nk_button_push_behavior(struct nk_context *ctx, enum nk_button_behavior behavior) +{ + struct nk_config_stack_button_behavior *button_stack; + struct nk_config_stack_button_behavior_element *element; + + NK_ASSERT(ctx); + if (!ctx) return 0; + + button_stack = &ctx->stacks.button_behaviors; + NK_ASSERT(button_stack->head < (int)NK_LEN(button_stack->elements)); + if (button_stack->head >= (int)NK_LEN(button_stack->elements)) + return 0; + + element = &button_stack->elements[button_stack->head++]; + element->address = &ctx->button_behavior; + element->old_value = ctx->button_behavior; + ctx->button_behavior = behavior; + return 1; +} + +NK_API int +nk_button_pop_behavior(struct nk_context *ctx) +{ + struct nk_config_stack_button_behavior *button_stack; + struct nk_config_stack_button_behavior_element *element; + + NK_ASSERT(ctx); + if (!ctx) return 0; + + button_stack = &ctx->stacks.button_behaviors; + NK_ASSERT(button_stack->head > 0); + if (button_stack->head < 1) + return 0; + + element = &button_stack->elements[--button_stack->head]; + *element->address = element->old_value; + return 1; +} + +NK_API int +nk_button_text_styled(struct nk_context *ctx, + const struct nk_style_button *style, const char *title, int len) +{ + struct nk_window *win; + struct nk_panel *layout; + const struct nk_input *in; + + struct nk_rect bounds; + enum nk_widget_layout_states state; + + NK_ASSERT(ctx); + NK_ASSERT(style); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!style || !ctx || !ctx->current || !ctx->current->layout) return 0; + + win = ctx->current; + layout = win->layout; + state = nk_widget(&bounds, ctx); + + if (!state) return 0; + in = (state == NK_WIDGET_ROM || layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + return nk_do_button_text(&ctx->last_widget_state, &win->buffer, bounds, + title, len, style->text_alignment, ctx->button_behavior, + style, in, ctx->style.font); +} + +NK_API int +nk_button_text(struct nk_context *ctx, const char *title, int len) +{ + NK_ASSERT(ctx); + if (!ctx) return 0; + return nk_button_text_styled(ctx, &ctx->style.button, title, len); +} + +NK_API int nk_button_label_styled(struct nk_context *ctx, + const struct nk_style_button *style, const char *title) +{return nk_button_text_styled(ctx, style, title, nk_strlen(title));} + +NK_API int nk_button_label(struct nk_context *ctx, const char *title) +{return nk_button_text(ctx, title, nk_strlen(title));} + +NK_API int +nk_button_color(struct nk_context *ctx, struct nk_color color) +{ + struct nk_window *win; + struct nk_panel *layout; + const struct nk_input *in; + struct nk_style_button button; + + int ret = 0; + struct nk_rect bounds; + struct nk_rect content; + enum nk_widget_layout_states state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + layout = win->layout; + + state = nk_widget(&bounds, ctx); + if (!state) return 0; + in = (state == NK_WIDGET_ROM || layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + + button = ctx->style.button; + button.normal = nk_style_item_color(color); + button.hover = nk_style_item_color(color); + button.active = nk_style_item_color(color); + ret = nk_do_button(&ctx->last_widget_state, &win->buffer, bounds, + &button, in, ctx->button_behavior, &content); + nk_draw_button(&win->buffer, &bounds, ctx->last_widget_state, &button); + return ret; +} + +NK_API int +nk_button_symbol_styled(struct nk_context *ctx, + const struct nk_style_button *style, enum nk_symbol_type symbol) +{ + struct nk_window *win; + struct nk_panel *layout; + const struct nk_input *in; + + struct nk_rect bounds; + enum nk_widget_layout_states state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + layout = win->layout; + state = nk_widget(&bounds, ctx); + if (!state) return 0; + in = (state == NK_WIDGET_ROM || layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + return nk_do_button_symbol(&ctx->last_widget_state, &win->buffer, bounds, + symbol, ctx->button_behavior, style, in, ctx->style.font); +} + +NK_API int +nk_button_symbol(struct nk_context *ctx, enum nk_symbol_type symbol) +{ + NK_ASSERT(ctx); + if (!ctx) return 0; + return nk_button_symbol_styled(ctx, &ctx->style.button, symbol); +} + +NK_API int +nk_button_image_styled(struct nk_context *ctx, const struct nk_style_button *style, + struct nk_image img) +{ + struct nk_window *win; + struct nk_panel *layout; + const struct nk_input *in; + + struct nk_rect bounds; + enum nk_widget_layout_states state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + layout = win->layout; + + state = nk_widget(&bounds, ctx); + if (!state) return 0; + in = (state == NK_WIDGET_ROM || layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + return nk_do_button_image(&ctx->last_widget_state, &win->buffer, bounds, + img, ctx->button_behavior, style, in); +} + +NK_API int +nk_button_image(struct nk_context *ctx, struct nk_image img) +{ + NK_ASSERT(ctx); + if (!ctx) return 0; + return nk_button_image_styled(ctx, &ctx->style.button, img); +} + +NK_API int +nk_button_symbol_text_styled(struct nk_context *ctx, + const struct nk_style_button *style, enum nk_symbol_type symbol, + const char *text, int len, nk_flags align) +{ + struct nk_window *win; + struct nk_panel *layout; + const struct nk_input *in; + + struct nk_rect bounds; + enum nk_widget_layout_states state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + layout = win->layout; + + state = nk_widget(&bounds, ctx); + if (!state) return 0; + in = (state == NK_WIDGET_ROM || layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + return nk_do_button_text_symbol(&ctx->last_widget_state, &win->buffer, bounds, + symbol, text, len, align, ctx->button_behavior, + style, ctx->style.font, in); +} + +NK_API int +nk_button_symbol_text(struct nk_context *ctx, enum nk_symbol_type symbol, + const char* text, int len, nk_flags align) +{ + NK_ASSERT(ctx); + if (!ctx) return 0; + return nk_button_symbol_text_styled(ctx, &ctx->style.button, symbol, text, len, align); +} + +NK_API int nk_button_symbol_label(struct nk_context *ctx, enum nk_symbol_type symbol, + const char *label, nk_flags align) +{return nk_button_symbol_text(ctx, symbol, label, nk_strlen(label), align);} + +NK_API int nk_button_symbol_label_styled(struct nk_context *ctx, + const struct nk_style_button *style, enum nk_symbol_type symbol, + const char *title, nk_flags align) +{return nk_button_symbol_text_styled(ctx, style, symbol, title, nk_strlen(title), align);} + +NK_API int +nk_button_image_text_styled(struct nk_context *ctx, + const struct nk_style_button *style, struct nk_image img, const char *text, + int len, nk_flags align) +{ + struct nk_window *win; + struct nk_panel *layout; + const struct nk_input *in; + + struct nk_rect bounds; + enum nk_widget_layout_states state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + layout = win->layout; + + state = nk_widget(&bounds, ctx); + if (!state) return 0; + in = (state == NK_WIDGET_ROM || layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + return nk_do_button_text_image(&ctx->last_widget_state, &win->buffer, + bounds, img, text, len, align, ctx->button_behavior, + style, ctx->style.font, in); +} + +NK_API int +nk_button_image_text(struct nk_context *ctx, struct nk_image img, + const char *text, int len, nk_flags align) +{return nk_button_image_text_styled(ctx, &ctx->style.button,img, text, len, align);} + + +NK_API int nk_button_image_label(struct nk_context *ctx, struct nk_image img, + const char *label, nk_flags align) +{return nk_button_image_text(ctx, img, label, nk_strlen(label), align);} + +NK_API int nk_button_image_label_styled(struct nk_context *ctx, + const struct nk_style_button *style, struct nk_image img, + const char *label, nk_flags text_alignment) +{return nk_button_image_text_styled(ctx, style, img, label, nk_strlen(label), text_alignment);} + +/*---------------------------------------------------------------- + * + * SELECTABLE + * + * --------------------------------------------------------------*/ +NK_API int +nk_selectable_text(struct nk_context *ctx, const char *str, int len, + nk_flags align, int *value) +{ + struct nk_window *win; + struct nk_panel *layout; + const struct nk_input *in; + const struct nk_style *style; + + enum nk_widget_layout_states state; + struct nk_rect bounds; + + NK_ASSERT(ctx); + NK_ASSERT(value); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout || !value) + return 0; + + win = ctx->current; + layout = win->layout; + style = &ctx->style; + + state = nk_widget(&bounds, ctx); + if (!state) return 0; + in = (state == NK_WIDGET_ROM || layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + return nk_do_selectable(&ctx->last_widget_state, &win->buffer, bounds, + str, len, align, value, &style->selectable, in, style->font); +} + +NK_API int +nk_selectable_image_text(struct nk_context *ctx, struct nk_image img, + const char *str, int len, nk_flags align, int *value) +{ + struct nk_window *win; + struct nk_panel *layout; + const struct nk_input *in; + const struct nk_style *style; + + enum nk_widget_layout_states state; + struct nk_rect bounds; + + NK_ASSERT(ctx); + NK_ASSERT(value); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout || !value) + return 0; + + win = ctx->current; + layout = win->layout; + style = &ctx->style; + + state = nk_widget(&bounds, ctx); + if (!state) return 0; + in = (state == NK_WIDGET_ROM || layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + return nk_do_selectable_image(&ctx->last_widget_state, &win->buffer, bounds, + str, len, align, value, &img, &style->selectable, in, style->font); +} + +NK_API int nk_select_text(struct nk_context *ctx, const char *str, int len, + nk_flags align, int value) +{nk_selectable_text(ctx, str, len, align, &value);return value;} + +NK_API int nk_selectable_label(struct nk_context *ctx, const char *str, nk_flags align, int *value) +{return nk_selectable_text(ctx, str, nk_strlen(str), align, value);} + +NK_API int nk_selectable_image_label(struct nk_context *ctx,struct nk_image img, + const char *str, nk_flags align, int *value) +{return nk_selectable_image_text(ctx, img, str, nk_strlen(str), align, value);} + +NK_API int nk_select_label(struct nk_context *ctx, const char *str, nk_flags align, int value) +{nk_selectable_text(ctx, str, nk_strlen(str), align, &value);return value;} + +NK_API int nk_select_image_label(struct nk_context *ctx, struct nk_image img, + const char *str, nk_flags align, int value) +{nk_selectable_image_text(ctx, img, str, nk_strlen(str), align, &value);return value;} + +NK_API int nk_select_image_text(struct nk_context *ctx, struct nk_image img, + const char *str, int len, nk_flags align, int value) +{nk_selectable_image_text(ctx, img, str, len, align, &value);return value;} + +/*---------------------------------------------------------------- + * + * CHECKBOX + * + * --------------------------------------------------------------*/ +NK_API int +nk_check_text(struct nk_context *ctx, const char *text, int len, int active) +{ + struct nk_window *win; + struct nk_panel *layout; + const struct nk_input *in; + const struct nk_style *style; + + struct nk_rect bounds; + enum nk_widget_layout_states state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return active; + + win = ctx->current; + style = &ctx->style; + layout = win->layout; + + state = nk_widget(&bounds, ctx); + if (!state) return active; + in = (state == NK_WIDGET_ROM || layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + nk_do_toggle(&ctx->last_widget_state, &win->buffer, bounds, &active, + text, len, NK_TOGGLE_CHECK, &style->checkbox, in, style->font); + return active; +} + +NK_API unsigned int +nk_check_flags_text(struct nk_context *ctx, const char *text, int len, + unsigned int flags, unsigned int value) +{ + int old_active; + NK_ASSERT(ctx); + NK_ASSERT(text); + if (!ctx || !text) return flags; + old_active = (int)((flags & value) & value); + if (nk_check_text(ctx, text, len, old_active)) + flags |= value; + else flags &= ~value; + return flags; +} + +NK_API int +nk_checkbox_text(struct nk_context *ctx, const char *text, int len, int *active) +{ + int old_val; + NK_ASSERT(ctx); + NK_ASSERT(text); + NK_ASSERT(active); + if (!ctx || !text || !active) return 0; + old_val = *active; + *active = nk_check_text(ctx, text, len, *active); + return old_val != *active; +} + +NK_API int +nk_checkbox_flags_text(struct nk_context *ctx, const char *text, int len, + unsigned int *flags, unsigned int value) +{ + int active; + NK_ASSERT(ctx); + NK_ASSERT(text); + NK_ASSERT(flags); + if (!ctx || !text || !flags) return 0; + + active = (int)((*flags & value) & value); + if (nk_checkbox_text(ctx, text, len, &active)) { + if (active) *flags |= value; + else *flags &= ~value; + return 1; + } + return 0; +} + +NK_API int nk_check_label(struct nk_context *ctx, const char *label, int active) +{return nk_check_text(ctx, label, nk_strlen(label), active);} + +NK_API unsigned int nk_check_flags_label(struct nk_context *ctx, const char *label, + unsigned int flags, unsigned int value) +{return nk_check_flags_text(ctx, label, nk_strlen(label), flags, value);} + +NK_API int nk_checkbox_label(struct nk_context *ctx, const char *label, int *active) +{return nk_checkbox_text(ctx, label, nk_strlen(label), active);} + +NK_API int nk_checkbox_flags_label(struct nk_context *ctx, const char *label, + unsigned int *flags, unsigned int value) +{return nk_checkbox_flags_text(ctx, label, nk_strlen(label), flags, value);} + +/*---------------------------------------------------------------- + * + * OPTION + * + * --------------------------------------------------------------*/ +NK_API int +nk_option_text(struct nk_context *ctx, const char *text, int len, int is_active) +{ + struct nk_window *win; + struct nk_panel *layout; + const struct nk_input *in; + const struct nk_style *style; + + struct nk_rect bounds; + enum nk_widget_layout_states state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return is_active; + + win = ctx->current; + style = &ctx->style; + layout = win->layout; + + state = nk_widget(&bounds, ctx); + if (!state) return state; + in = (state == NK_WIDGET_ROM || layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + nk_do_toggle(&ctx->last_widget_state, &win->buffer, bounds, &is_active, + text, len, NK_TOGGLE_OPTION, &style->option, in, style->font); + return is_active; +} + +NK_API int +nk_radio_text(struct nk_context *ctx, const char *text, int len, int *active) +{ + int old_value; + NK_ASSERT(ctx); + NK_ASSERT(text); + NK_ASSERT(active); + if (!ctx || !text || !active) return 0; + old_value = *active; + *active = nk_option_text(ctx, text, len, old_value); + return old_value != *active; +} + +NK_API int +nk_option_label(struct nk_context *ctx, const char *label, int active) +{return nk_option_text(ctx, label, nk_strlen(label), active);} + +NK_API int +nk_radio_label(struct nk_context *ctx, const char *label, int *active) +{return nk_radio_text(ctx, label, nk_strlen(label), active);} + +/*---------------------------------------------------------------- + * + * SLIDER + * + * --------------------------------------------------------------*/ +NK_API int +nk_slider_float(struct nk_context *ctx, float min_value, float *value, float max_value, + float value_step) +{ + struct nk_window *win; + struct nk_panel *layout; + struct nk_input *in; + const struct nk_style *style; + + int ret = 0; + float old_value; + struct nk_rect bounds; + enum nk_widget_layout_states state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + NK_ASSERT(value); + if (!ctx || !ctx->current || !ctx->current->layout || !value) + return ret; + + win = ctx->current; + style = &ctx->style; + layout = win->layout; + + state = nk_widget(&bounds, ctx); + if (!state) return ret; + in = (state == NK_WIDGET_ROM || layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + + old_value = *value; + *value = nk_do_slider(&ctx->last_widget_state, &win->buffer, bounds, min_value, + old_value, max_value, value_step, &style->slider, in, style->font); + return (old_value > *value || old_value < *value); +} + +NK_API float +nk_slide_float(struct nk_context *ctx, float min, float val, float max, float step) +{ + nk_slider_float(ctx, min, &val, max, step); return val; +} + +NK_API int +nk_slide_int(struct nk_context *ctx, int min, int val, int max, int step) +{ + float value = (float)val; + nk_slider_float(ctx, (float)min, &value, (float)max, (float)step); + return (int)value; +} + +NK_API int +nk_slider_int(struct nk_context *ctx, int min, int *val, int max, int step) +{ + int ret; + float value = (float)*val; + ret = nk_slider_float(ctx, (float)min, &value, (float)max, (float)step); + *val = (int)value; + return ret; +} + +/*---------------------------------------------------------------- + * + * PROGRESSBAR + * + * --------------------------------------------------------------*/ +NK_API int +nk_progress(struct nk_context *ctx, nk_size *cur, nk_size max, int is_modifyable) +{ + struct nk_window *win; + struct nk_panel *layout; + const struct nk_style *style; + const struct nk_input *in; + + struct nk_rect bounds; + enum nk_widget_layout_states state; + nk_size old_value; + + NK_ASSERT(ctx); + NK_ASSERT(cur); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout || !cur) + return 0; + + win = ctx->current; + style = &ctx->style; + layout = win->layout; + state = nk_widget(&bounds, ctx); + if (!state) return 0; + + in = (state == NK_WIDGET_ROM || layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + old_value = *cur; + *cur = nk_do_progress(&ctx->last_widget_state, &win->buffer, bounds, + *cur, max, is_modifyable, &style->progress, in); + return (*cur != old_value); +} + +NK_API nk_size nk_prog(struct nk_context *ctx, nk_size cur, nk_size max, int modifyable) +{nk_progress(ctx, &cur, max, modifyable);return cur;} + +/*---------------------------------------------------------------- + * + * EDIT + * + * --------------------------------------------------------------*/ +NK_API void +nk_edit_focus(struct nk_context *ctx, nk_flags flags) +{ + nk_hash hash; + struct nk_window *win; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) return; + + win = ctx->current; + hash = win->edit.seq; + win->edit.active = nk_true; + win->edit.name = hash; + if (flags & NK_EDIT_ALWAYS_INSERT_MODE) + win->edit.mode = NK_TEXT_EDIT_MODE_INSERT; +} + +NK_API void +nk_edit_unfocus(struct nk_context *ctx) +{ + struct nk_window *win; + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) return; + + win = ctx->current; + win->edit.active = nk_false; + win->edit.name = 0; +} + +NK_API nk_flags +nk_edit_string(struct nk_context *ctx, nk_flags flags, + char *memory, int *len, int max, nk_plugin_filter filter) +{ + nk_hash hash; + nk_flags state; + struct nk_text_edit *edit; + struct nk_window *win; + + NK_ASSERT(ctx); + NK_ASSERT(memory); + NK_ASSERT(len); + if (!ctx || !memory || !len) + return 0; + + filter = (!filter) ? nk_filter_default: filter; + win = ctx->current; + hash = win->edit.seq; + edit = &ctx->text_edit; + nk_textedit_clear_state(&ctx->text_edit, (flags & NK_EDIT_MULTILINE)? + NK_TEXT_EDIT_MULTI_LINE: NK_TEXT_EDIT_SINGLE_LINE, filter); + + if (win->edit.active && hash == win->edit.name) { + if (flags & NK_EDIT_NO_CURSOR) + edit->cursor = nk_utf_len(memory, *len); + else edit->cursor = win->edit.cursor; + if (!(flags & NK_EDIT_SELECTABLE)) { + edit->select_start = win->edit.cursor; + edit->select_end = win->edit.cursor; + } else { + edit->select_start = win->edit.sel_start; + edit->select_end = win->edit.sel_end; + } + edit->mode = win->edit.mode; + edit->scrollbar.x = (float)win->edit.scrollbar.x; + edit->scrollbar.y = (float)win->edit.scrollbar.y; + edit->active = nk_true; + } else edit->active = nk_false; + + max = NK_MAX(1, max); + *len = NK_MIN(*len, max-1); + nk_str_init_fixed(&edit->string, memory, (nk_size)max); + edit->string.buffer.allocated = (nk_size)*len; + edit->string.len = nk_utf_len(memory, *len); + state = nk_edit_buffer(ctx, flags, edit, filter); + *len = (int)edit->string.buffer.allocated; + + if (edit->active) { + win->edit.cursor = edit->cursor; + win->edit.sel_start = edit->select_start; + win->edit.sel_end = edit->select_end; + win->edit.mode = edit->mode; + win->edit.scrollbar.x = (nk_uint)edit->scrollbar.x; + win->edit.scrollbar.y = (nk_uint)edit->scrollbar.y; + } + return state; +} + +NK_API nk_flags +nk_edit_buffer(struct nk_context *ctx, nk_flags flags, + struct nk_text_edit *edit, nk_plugin_filter filter) +{ + struct nk_window *win; + struct nk_style *style; + struct nk_input *in; + + enum nk_widget_layout_states state; + struct nk_rect bounds; + + nk_flags ret_flags = 0; + unsigned char prev_state; + nk_hash hash; + + /* make sure correct values */ + NK_ASSERT(ctx); + NK_ASSERT(edit); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + style = &ctx->style; + state = nk_widget(&bounds, ctx); + if (!state) return state; + in = (win->layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + + /* check if edit is currently hot item */ + hash = win->edit.seq++; + if (win->edit.active && hash == win->edit.name) { + if (flags & NK_EDIT_NO_CURSOR) + edit->cursor = edit->string.len; + if (!(flags & NK_EDIT_SELECTABLE)) { + edit->select_start = edit->cursor; + edit->select_end = edit->cursor; + } + if (flags & NK_EDIT_CLIPBOARD) + edit->clip = ctx->clip; + edit->active = (unsigned char)win->edit.active; + } else edit->active = nk_false; + edit->mode = win->edit.mode; + + filter = (!filter) ? nk_filter_default: filter; + prev_state = (unsigned char)edit->active; + in = (flags & NK_EDIT_READ_ONLY) ? 0: in; + ret_flags = nk_do_edit(&ctx->last_widget_state, &win->buffer, bounds, flags, + filter, edit, &style->edit, in, style->font); + + if (ctx->last_widget_state & NK_WIDGET_STATE_HOVER) + ctx->style.cursor_active = ctx->style.cursors[NK_CURSOR_TEXT]; + if (edit->active && prev_state != edit->active) { + /* current edit is now hot */ + win->edit.active = nk_true; + win->edit.name = hash; + } else if (prev_state && !edit->active) { + /* current edit is now cold */ + win->edit.active = nk_false; + } + return ret_flags; +} + +NK_API nk_flags +nk_edit_string_zero_terminated(struct nk_context *ctx, nk_flags flags, + char *buffer, int max, nk_plugin_filter filter) +{ + nk_flags result; + int len = nk_strlen(buffer); + result = nk_edit_string(ctx, flags, buffer, &len, max, filter); + buffer[NK_MIN(NK_MAX(max-1,0), len)] = '\0'; + return result; +} + +/*---------------------------------------------------------------- + * + * PROPERTY + * + * --------------------------------------------------------------*/ +NK_INTERN struct nk_property_variant +nk_property_variant_int(int value, int min_value, int max_value, int step) +{ + struct nk_property_variant result; + result.kind = NK_PROPERTY_INT; + result.value.i = value; + result.min_value.i = min_value; + result.max_value.i = max_value; + result.step.i = step; + return result; +} + +NK_INTERN struct nk_property_variant +nk_property_variant_float(float value, float min_value, float max_value, float step) +{ + struct nk_property_variant result; + result.kind = NK_PROPERTY_FLOAT; + result.value.f = value; + result.min_value.f = min_value; + result.max_value.f = max_value; + result.step.f = step; + return result; +} + +NK_INTERN struct nk_property_variant +nk_property_variant_double(double value, double min_value, double max_value, + double step) +{ + struct nk_property_variant result; + result.kind = NK_PROPERTY_DOUBLE; + result.value.d = value; + result.min_value.d = min_value; + result.max_value.d = max_value; + result.step.d = step; + return result; +} + +NK_INTERN void +nk_property(struct nk_context *ctx, const char *name, struct nk_property_variant *variant, + float inc_per_pixel, const enum nk_property_filter filter) +{ + struct nk_window *win; + struct nk_panel *layout; + struct nk_input *in; + const struct nk_style *style; + + struct nk_rect bounds; + enum nk_widget_layout_states s; + + int *state = 0; + nk_hash hash = 0; + char *buffer = 0; + int *len = 0; + int *cursor = 0; + int *select_begin = 0; + int *select_end = 0; + int old_state; + + char dummy_buffer[NK_MAX_NUMBER_BUFFER]; + int dummy_state = NK_PROPERTY_DEFAULT; + int dummy_length = 0; + int dummy_cursor = 0; + int dummy_select_begin = 0; + int dummy_select_end = 0; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + win = ctx->current; + layout = win->layout; + style = &ctx->style; + s = nk_widget(&bounds, ctx); + if (!s) return; + + /* calculate hash from name */ + if (name[0] == '#') { + hash = nk_murmur_hash(name, (int)nk_strlen(name), win->property.seq++); + name++; /* special number hash */ + } else hash = nk_murmur_hash(name, (int)nk_strlen(name), 42); + + /* check if property is currently hot item */ + if (win->property.active && hash == win->property.name) { + buffer = win->property.buffer; + len = &win->property.length; + cursor = &win->property.cursor; + state = &win->property.state; + select_begin = &win->property.select_start; + select_end = &win->property.select_end; + } else { + buffer = dummy_buffer; + len = &dummy_length; + cursor = &dummy_cursor; + state = &dummy_state; + select_begin = &dummy_select_begin; + select_end = &dummy_select_end; + } + + /* execute property widget */ + old_state = *state; + ctx->text_edit.clip = ctx->clip; + in = ((s == NK_WIDGET_ROM && !win->property.active) || + layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + nk_do_property(&ctx->last_widget_state, &win->buffer, bounds, name, + variant, inc_per_pixel, buffer, len, state, cursor, select_begin, + select_end, &style->property, filter, in, style->font, &ctx->text_edit, + ctx->button_behavior); + + if (in && *state != NK_PROPERTY_DEFAULT && !win->property.active) { + /* current property is now hot */ + win->property.active = 1; + NK_MEMCPY(win->property.buffer, buffer, (nk_size)*len); + win->property.length = *len; + win->property.cursor = *cursor; + win->property.state = *state; + win->property.name = hash; + win->property.select_start = *select_begin; + win->property.select_end = *select_end; + if (*state == NK_PROPERTY_DRAG) { + ctx->input.mouse.grab = nk_true; + ctx->input.mouse.grabbed = nk_true; + } + } + /* check if previously active property is now inactive */ + if (*state == NK_PROPERTY_DEFAULT && old_state != NK_PROPERTY_DEFAULT) { + if (old_state == NK_PROPERTY_DRAG) { + ctx->input.mouse.grab = nk_false; + ctx->input.mouse.grabbed = nk_false; + ctx->input.mouse.ungrab = nk_true; + } + win->property.select_start = 0; + win->property.select_end = 0; + win->property.active = 0; + } +} + +NK_API void +nk_property_int(struct nk_context *ctx, const char *name, + int min, int *val, int max, int step, float inc_per_pixel) +{ + struct nk_property_variant variant; + NK_ASSERT(ctx); + NK_ASSERT(name); + NK_ASSERT(val); + + if (!ctx || !ctx->current || !name || !val) return; + variant = nk_property_variant_int(*val, min, max, step); + nk_property(ctx, name, &variant, inc_per_pixel, NK_FILTER_INT); + *val = variant.value.i; +} + +NK_API void +nk_property_float(struct nk_context *ctx, const char *name, + float min, float *val, float max, float step, float inc_per_pixel) +{ + struct nk_property_variant variant; + NK_ASSERT(ctx); + NK_ASSERT(name); + NK_ASSERT(val); + + if (!ctx || !ctx->current || !name || !val) return; + variant = nk_property_variant_float(*val, min, max, step); + nk_property(ctx, name, &variant, inc_per_pixel, NK_FILTER_FLOAT); + *val = variant.value.f; +} + +NK_API void +nk_property_double(struct nk_context *ctx, const char *name, + double min, double *val, double max, double step, float inc_per_pixel) +{ + struct nk_property_variant variant; + NK_ASSERT(ctx); + NK_ASSERT(name); + NK_ASSERT(val); + + if (!ctx || !ctx->current || !name || !val) return; + variant = nk_property_variant_double(*val, min, max, step); + nk_property(ctx, name, &variant, inc_per_pixel, NK_FILTER_FLOAT); + *val = variant.value.d; +} + +NK_API int +nk_propertyi(struct nk_context *ctx, const char *name, int min, int val, + int max, int step, float inc_per_pixel) +{ + struct nk_property_variant variant; + NK_ASSERT(ctx); + NK_ASSERT(name); + + if (!ctx || !ctx->current || !name) return val; + variant = nk_property_variant_int(val, min, max, step); + nk_property(ctx, name, &variant, inc_per_pixel, NK_FILTER_INT); + val = variant.value.i; + return val; +} + +NK_API float +nk_propertyf(struct nk_context *ctx, const char *name, float min, + float val, float max, float step, float inc_per_pixel) +{ + struct nk_property_variant variant; + NK_ASSERT(ctx); + NK_ASSERT(name); + + if (!ctx || !ctx->current || !name) return val; + variant = nk_property_variant_float(val, min, max, step); + nk_property(ctx, name, &variant, inc_per_pixel, NK_FILTER_FLOAT); + val = variant.value.f; + return val; +} + +NK_API double +nk_propertyd(struct nk_context *ctx, const char *name, double min, + double val, double max, double step, float inc_per_pixel) +{ + struct nk_property_variant variant; + NK_ASSERT(ctx); + NK_ASSERT(name); + + if (!ctx || !ctx->current || !name) return val; + variant = nk_property_variant_double(val, min, max, step); + nk_property(ctx, name, &variant, inc_per_pixel, NK_FILTER_FLOAT); + val = variant.value.d; + return val; +} + +/*---------------------------------------------------------------- + * + * COLOR PICKER + * + * --------------------------------------------------------------*/ +NK_API int +nk_color_pick(struct nk_context * ctx, struct nk_color *color, + enum nk_color_format fmt) +{ + struct nk_window *win; + struct nk_panel *layout; + const struct nk_style *config; + const struct nk_input *in; + + enum nk_widget_layout_states state; + struct nk_rect bounds; + + NK_ASSERT(ctx); + NK_ASSERT(color); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout || !color) + return 0; + + win = ctx->current; + config = &ctx->style; + layout = win->layout; + state = nk_widget(&bounds, ctx); + if (!state) return 0; + in = (state == NK_WIDGET_ROM || layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + return nk_do_color_picker(&ctx->last_widget_state, &win->buffer, color, fmt, bounds, + nk_vec2(0,0), in, config->font); +} + +NK_API struct nk_color +nk_color_picker(struct nk_context *ctx, struct nk_color color, + enum nk_color_format fmt) +{ + nk_color_pick(ctx, &color, fmt); + return color; +} + +/* ------------------------------------------------------------- + * + * CHART + * + * --------------------------------------------------------------*/ +NK_API int +nk_chart_begin_colored(struct nk_context *ctx, enum nk_chart_type type, + struct nk_color color, struct nk_color highlight, + int count, float min_value, float max_value) +{ + struct nk_window *win; + struct nk_chart *chart; + const struct nk_style *config; + const struct nk_style_chart *style; + + const struct nk_style_item *background; + struct nk_rect bounds = {0, 0, 0, 0}; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + + if (!ctx || !ctx->current || !ctx->current->layout) return 0; + if (!nk_widget(&bounds, ctx)) { + chart = &ctx->current->layout->chart; + nk_zero(chart, sizeof(*chart)); + return 0; + } + + win = ctx->current; + config = &ctx->style; + chart = &win->layout->chart; + style = &config->chart; + + /* setup basic generic chart */ + nk_zero(chart, sizeof(*chart)); + chart->x = bounds.x + style->padding.x; + chart->y = bounds.y + style->padding.y; + chart->w = bounds.w - 2 * style->padding.x; + chart->h = bounds.h - 2 * style->padding.y; + chart->w = NK_MAX(chart->w, 2 * style->padding.x); + chart->h = NK_MAX(chart->h, 2 * style->padding.y); + + /* add first slot into chart */ + {struct nk_chart_slot *slot = &chart->slots[chart->slot++]; + slot->type = type; + slot->count = count; + slot->color = color; + slot->highlight = highlight; + slot->min = NK_MIN(min_value, max_value); + slot->max = NK_MAX(min_value, max_value); + slot->range = slot->max - slot->min;} + + /* draw chart background */ + background = &style->background; + if (background->type == NK_STYLE_ITEM_IMAGE) { + nk_draw_image(&win->buffer, bounds, &background->data.image, nk_white); + } else { + nk_fill_rect(&win->buffer, bounds, style->rounding, style->border_color); + nk_fill_rect(&win->buffer, nk_shrink_rect(bounds, style->border), + style->rounding, style->background.data.color); + } + return 1; +} + +NK_API int +nk_chart_begin(struct nk_context *ctx, const enum nk_chart_type type, + int count, float min_value, float max_value) +{return nk_chart_begin_colored(ctx, type, ctx->style.chart.color, ctx->style.chart.selected_color, count, min_value, max_value);} + +NK_API void +nk_chart_add_slot_colored(struct nk_context *ctx, const enum nk_chart_type type, + struct nk_color color, struct nk_color highlight, + int count, float min_value, float max_value) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + NK_ASSERT(ctx->current->layout->chart.slot < NK_CHART_MAX_SLOT); + if (!ctx || !ctx->current || !ctx->current->layout) return; + if (ctx->current->layout->chart.slot >= NK_CHART_MAX_SLOT) return; + + /* add another slot into the graph */ + {struct nk_chart *chart = &ctx->current->layout->chart; + struct nk_chart_slot *slot = &chart->slots[chart->slot++]; + slot->type = type; + slot->count = count; + slot->color = color; + slot->highlight = highlight; + slot->min = NK_MIN(min_value, max_value); + slot->max = NK_MAX(min_value, max_value); + slot->range = slot->max - slot->min;} +} + +NK_API void +nk_chart_add_slot(struct nk_context *ctx, const enum nk_chart_type type, + int count, float min_value, float max_value) +{nk_chart_add_slot_colored(ctx, type, ctx->style.chart.color, ctx->style.chart.selected_color, count, min_value, max_value);} + +NK_INTERN nk_flags +nk_chart_push_line(struct nk_context *ctx, struct nk_window *win, + struct nk_chart *g, float value, int slot) +{ + struct nk_panel *layout = win->layout; + const struct nk_input *i = &ctx->input; + struct nk_command_buffer *out = &win->buffer; + + nk_flags ret = 0; + struct nk_vec2 cur; + struct nk_rect bounds; + struct nk_color color; + float step; + float range; + float ratio; + + NK_ASSERT(slot >= 0 && slot < NK_CHART_MAX_SLOT); + step = g->w / (float)g->slots[slot].count; + range = g->slots[slot].max - g->slots[slot].min; + ratio = (value - g->slots[slot].min) / range; + + if (g->slots[slot].index == 0) { + /* first data point does not have a connection */ + g->slots[slot].last.x = g->x; + g->slots[slot].last.y = (g->y + g->h) - ratio * (float)g->h; + + bounds.x = g->slots[slot].last.x - 2; + bounds.y = g->slots[slot].last.y - 2; + bounds.w = bounds.h = 4; + + color = g->slots[slot].color; + if (!(layout->flags & NK_WINDOW_ROM) && + NK_INBOX(i->mouse.pos.x,i->mouse.pos.y, g->slots[slot].last.x-3, g->slots[slot].last.y-3, 6, 6)){ + ret = nk_input_is_mouse_hovering_rect(i, bounds) ? NK_CHART_HOVERING : 0; + ret |= (i->mouse.buttons[NK_BUTTON_LEFT].down && + i->mouse.buttons[NK_BUTTON_LEFT].clicked) ? NK_CHART_CLICKED: 0; + color = g->slots[slot].highlight; + } + nk_fill_rect(out, bounds, 0, color); + g->slots[slot].index += 1; + return ret; + } + + /* draw a line between the last data point and the new one */ + color = g->slots[slot].color; + cur.x = g->x + (float)(step * (float)g->slots[slot].index); + cur.y = (g->y + g->h) - (ratio * (float)g->h); + nk_stroke_line(out, g->slots[slot].last.x, g->slots[slot].last.y, cur.x, cur.y, 1.0f, color); + + bounds.x = cur.x - 3; + bounds.y = cur.y - 3; + bounds.w = bounds.h = 6; + + /* user selection of current data point */ + if (!(layout->flags & NK_WINDOW_ROM)) { + if (nk_input_is_mouse_hovering_rect(i, bounds)) { + ret = NK_CHART_HOVERING; + ret |= (!i->mouse.buttons[NK_BUTTON_LEFT].down && + i->mouse.buttons[NK_BUTTON_LEFT].clicked) ? NK_CHART_CLICKED: 0; + color = g->slots[slot].highlight; + } + } + nk_fill_rect(out, nk_rect(cur.x - 2, cur.y - 2, 4, 4), 0, color); + + /* save current data point position */ + g->slots[slot].last.x = cur.x; + g->slots[slot].last.y = cur.y; + g->slots[slot].index += 1; + return ret; +} + +NK_INTERN nk_flags +nk_chart_push_column(const struct nk_context *ctx, struct nk_window *win, + struct nk_chart *chart, float value, int slot) +{ + struct nk_command_buffer *out = &win->buffer; + const struct nk_input *in = &ctx->input; + struct nk_panel *layout = win->layout; + + float ratio; + nk_flags ret = 0; + struct nk_color color; + struct nk_rect item = {0,0,0,0}; + + NK_ASSERT(slot >= 0 && slot < NK_CHART_MAX_SLOT); + if (chart->slots[slot].index >= chart->slots[slot].count) + return nk_false; + if (chart->slots[slot].count) { + float padding = (float)(chart->slots[slot].count-1); + item.w = (chart->w - padding) / (float)(chart->slots[slot].count); + } + + /* calculate bounds of current bar chart entry */ + color = chart->slots[slot].color;; + item.h = chart->h * NK_ABS((value/chart->slots[slot].range)); + if (value >= 0) { + ratio = (value + NK_ABS(chart->slots[slot].min)) / NK_ABS(chart->slots[slot].range); + item.y = (chart->y + chart->h) - chart->h * ratio; + } else { + ratio = (value - chart->slots[slot].max) / chart->slots[slot].range; + item.y = chart->y + (chart->h * NK_ABS(ratio)) - item.h; + } + item.x = chart->x + ((float)chart->slots[slot].index * item.w); + item.x = item.x + ((float)chart->slots[slot].index); + + /* user chart bar selection */ + if (!(layout->flags & NK_WINDOW_ROM) && + NK_INBOX(in->mouse.pos.x,in->mouse.pos.y,item.x,item.y,item.w,item.h)) { + ret = NK_CHART_HOVERING; + ret |= (!in->mouse.buttons[NK_BUTTON_LEFT].down && + in->mouse.buttons[NK_BUTTON_LEFT].clicked) ? NK_CHART_CLICKED: 0; + color = chart->slots[slot].highlight; + } + nk_fill_rect(out, item, 0, color); + chart->slots[slot].index += 1; + return ret; +} + +NK_API nk_flags +nk_chart_push_slot(struct nk_context *ctx, float value, int slot) +{ + nk_flags flags; + struct nk_window *win; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(slot >= 0 && slot < NK_CHART_MAX_SLOT); + NK_ASSERT(slot < ctx->current->layout->chart.slot); + if (!ctx || !ctx->current || slot >= NK_CHART_MAX_SLOT) return nk_false; + if (slot >= ctx->current->layout->chart.slot) return nk_false; + + win = ctx->current; + if (win->layout->chart.slot < slot) return nk_false; + switch (win->layout->chart.slots[slot].type) { + case NK_CHART_LINES: + flags = nk_chart_push_line(ctx, win, &win->layout->chart, value, slot); break; + case NK_CHART_COLUMN: + flags = nk_chart_push_column(ctx, win, &win->layout->chart, value, slot); break; + default: + case NK_CHART_MAX: + flags = 0; + } + return flags; +} + +NK_API nk_flags +nk_chart_push(struct nk_context *ctx, float value) +{return nk_chart_push_slot(ctx, value, 0);} + +NK_API void +nk_chart_end(struct nk_context *ctx) +{ + struct nk_window *win; + struct nk_chart *chart; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) + return; + + win = ctx->current; + chart = &win->layout->chart; + NK_MEMSET(chart, 0, sizeof(*chart)); + return; +} + +NK_API void +nk_plot(struct nk_context *ctx, enum nk_chart_type type, const float *values, + int count, int offset) +{ + int i = 0; + float min_value; + float max_value; + + NK_ASSERT(ctx); + NK_ASSERT(values); + if (!ctx || !values || !count) return; + + min_value = values[offset]; + max_value = values[offset]; + for (i = 0; i < count; ++i) { + min_value = NK_MIN(values[i + offset], min_value); + max_value = NK_MAX(values[i + offset], max_value); + } + + if (nk_chart_begin(ctx, type, count, min_value, max_value)) { + for (i = 0; i < count; ++i) + nk_chart_push(ctx, values[i + offset]); + nk_chart_end(ctx); + } +} + +NK_API void +nk_plot_function(struct nk_context *ctx, enum nk_chart_type type, void *userdata, + float(*value_getter)(void* user, int index), int count, int offset) +{ + int i = 0; + float min_value; + float max_value; + + NK_ASSERT(ctx); + NK_ASSERT(value_getter); + if (!ctx || !value_getter || !count) return; + + max_value = min_value = value_getter(userdata, offset); + for (i = 0; i < count; ++i) { + float value = value_getter(userdata, i + offset); + min_value = NK_MIN(value, min_value); + max_value = NK_MAX(value, max_value); + } + + if (nk_chart_begin(ctx, type, count, min_value, max_value)) { + for (i = 0; i < count; ++i) + nk_chart_push(ctx, value_getter(userdata, i + offset)); + nk_chart_end(ctx); + } +} + +/* ------------------------------------------------------------- + * + * GROUP + * + * --------------------------------------------------------------*/ +NK_API int +nk_group_scrolled_offset_begin(struct nk_context *ctx, + nk_uint *x_offset, nk_uint *y_offset, const char *title, nk_flags flags) +{ + struct nk_rect bounds; + struct nk_window panel; + struct nk_window *win; + + win = ctx->current; + nk_panel_alloc_space(&bounds, ctx); + {const struct nk_rect *c = &win->layout->clip; + if (!NK_INTERSECT(c->x, c->y, c->w, c->h, bounds.x, bounds.y, bounds.w, bounds.h) && + !(flags & NK_WINDOW_MOVABLE)) { + return 0; + }} + if (win->flags & NK_WINDOW_ROM) + flags |= NK_WINDOW_ROM; + + /* initialize a fake window to create the panel from */ + nk_zero(&panel, sizeof(panel)); + panel.bounds = bounds; + panel.flags = flags; + panel.scrollbar.x = *x_offset; + panel.scrollbar.y = *y_offset; + panel.buffer = win->buffer; + panel.layout = (struct nk_panel*)nk_create_panel(ctx); + ctx->current = &panel; + nk_panel_begin(ctx, (flags & NK_WINDOW_TITLE) ? title: 0, NK_PANEL_GROUP); + + win->buffer = panel.buffer; + win->buffer.clip = panel.layout->clip; + panel.layout->offset_x = x_offset; + panel.layout->offset_y = y_offset; + panel.layout->parent = win->layout; + win->layout = panel.layout; + + ctx->current = win; + if ((panel.layout->flags & NK_WINDOW_CLOSED) || + (panel.layout->flags & NK_WINDOW_MINIMIZED)) + { + nk_flags f = panel.layout->flags; + nk_group_scrolled_end(ctx); + if (f & NK_WINDOW_CLOSED) + return NK_WINDOW_CLOSED; + if (f & NK_WINDOW_MINIMIZED) + return NK_WINDOW_MINIMIZED; + } + return 1; +} + +NK_API void +nk_group_scrolled_end(struct nk_context *ctx) +{ + struct nk_window *win; + struct nk_panel *parent; + struct nk_panel *g; + + struct nk_rect clip; + struct nk_window pan; + struct nk_vec2 panel_padding; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) + return; + + /* make sure nk_group_begin was called correctly */ + NK_ASSERT(ctx->current); + win = ctx->current; + NK_ASSERT(win->layout); + g = win->layout; + NK_ASSERT(g->parent); + parent = g->parent; + + /* dummy window */ + nk_zero_struct(pan); + panel_padding = nk_panel_get_padding(&ctx->style, NK_PANEL_GROUP); + pan.bounds.y = g->bounds.y - (g->header_height + g->menu.h); + pan.bounds.x = g->bounds.x - panel_padding.x; + pan.bounds.w = g->bounds.w + 2 * panel_padding.x; + pan.bounds.h = g->bounds.h + g->header_height + g->menu.h; + if (g->flags & NK_WINDOW_BORDER) { + pan.bounds.x -= g->border; + pan.bounds.y -= g->border; + pan.bounds.w += 2*g->border; + pan.bounds.h += 2*g->border; + } + if (!(g->flags & NK_WINDOW_NO_SCROLLBAR)) { + pan.bounds.w += ctx->style.window.scrollbar_size.x; + pan.bounds.h += ctx->style.window.scrollbar_size.y; + } + pan.scrollbar.x = *g->offset_x; + pan.scrollbar.y = *g->offset_y; + pan.flags = g->flags; + pan.buffer = win->buffer; + pan.layout = g; + pan.parent = win; + ctx->current = &pan; + + /* make sure group has correct clipping rectangle */ + nk_unify(&clip, &parent->clip, pan.bounds.x, pan.bounds.y, + pan.bounds.x + pan.bounds.w, pan.bounds.y + pan.bounds.h + panel_padding.x); + nk_push_scissor(&pan.buffer, clip); + nk_end(ctx); + + win->buffer = pan.buffer; + nk_push_scissor(&win->buffer, parent->clip); + ctx->current = win; + win->layout = parent; + g->bounds = pan.bounds; + return; +} + +NK_API int +nk_group_scrolled_begin(struct nk_context *ctx, + struct nk_scroll *scroll, const char *title, nk_flags flags) +{return nk_group_scrolled_offset_begin(ctx, &scroll->x, &scroll->y, title, flags);} + +NK_API int +nk_group_begin(struct nk_context *ctx, const char *title, nk_flags flags) +{ + int title_len; + nk_hash title_hash; + struct nk_window *win; + nk_uint *x_offset; + nk_uint *y_offset; + + NK_ASSERT(ctx); + NK_ASSERT(title); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout || !title) + return 0; + + /* find persistent group scrollbar value */ + win = ctx->current; + title_len = (int)nk_strlen(title); + title_hash = nk_murmur_hash(title, (int)title_len, NK_PANEL_GROUP); + x_offset = nk_find_value(win, title_hash); + if (!x_offset) { + x_offset = nk_add_value(ctx, win, title_hash, 0); + y_offset = nk_add_value(ctx, win, title_hash+1, 0); + + NK_ASSERT(x_offset); + NK_ASSERT(y_offset); + if (!x_offset || !y_offset) return 0; + *x_offset = *y_offset = 0; + } else y_offset = nk_find_value(win, title_hash+1); + return nk_group_scrolled_offset_begin(ctx, x_offset, y_offset, title, flags); +} + +NK_API void +nk_group_end(struct nk_context *ctx) +{nk_group_scrolled_end(ctx);} + +NK_API int +nk_list_view_begin(struct nk_context *ctx, struct nk_list_view *view, + const char *title, nk_flags flags, int row_height, int row_count) +{ + int title_len; + nk_hash title_hash; + nk_uint *x_offset; + nk_uint *y_offset; + + int result; + struct nk_window *win; + struct nk_panel *layout; + const struct nk_style *style; + struct nk_vec2 item_spacing; + + NK_ASSERT(ctx); + NK_ASSERT(view); + NK_ASSERT(title); + if (!ctx || !view || !title) return 0; + + win = ctx->current; + style = &ctx->style; + item_spacing = style->window.spacing; + row_height += NK_MAX(0, (int)item_spacing.y); + + /* find persistent list view scrollbar offset */ + title_len = (int)nk_strlen(title); + title_hash = nk_murmur_hash(title, (int)title_len, NK_PANEL_GROUP); + x_offset = nk_find_value(win, title_hash); + if (!x_offset) { + x_offset = nk_add_value(ctx, win, title_hash, 0); + y_offset = nk_add_value(ctx, win, title_hash+1, 0); + + NK_ASSERT(x_offset); + NK_ASSERT(y_offset); + if (!x_offset || !y_offset) return 0; + *x_offset = *y_offset = 0; + } else y_offset = nk_find_value(win, title_hash+1); + view->scroll_value = *y_offset; + view->scroll_pointer = y_offset; + + *y_offset = 0; + result = nk_group_scrolled_offset_begin(ctx, x_offset, y_offset, title, flags); + win = ctx->current; + layout = win->layout; + + view->total_height = row_height * NK_MAX(row_count,1); + view->begin = (int)NK_MAX(((float)view->scroll_value / (float)row_height), 0.0f); + view->count = (int)NK_MAX(nk_iceilf((layout->clip.h)/(float)row_height), 0); + view->end = view->begin + view->count; + view->ctx = ctx; + return result; +} + +NK_API void +nk_list_view_end(struct nk_list_view *view) +{ + struct nk_context *ctx; + struct nk_window *win; + struct nk_panel *layout; + + NK_ASSERT(view); + NK_ASSERT(view->ctx); + NK_ASSERT(view->scroll_pointer); + if (!view || !view->ctx) return; + + ctx = view->ctx; + win = ctx->current; + layout = win->layout; + layout->at_y = layout->bounds.y + (float)view->total_height; + *view->scroll_pointer = *view->scroll_pointer + view->scroll_value; + nk_group_end(view->ctx); +} + +/* -------------------------------------------------------------- + * + * POPUP + * + * --------------------------------------------------------------*/ +NK_API int +nk_popup_begin(struct nk_context *ctx, enum nk_popup_type type, + const char *title, nk_flags flags, struct nk_rect rect) +{ + struct nk_window *popup; + struct nk_window *win; + struct nk_panel *panel; + + int title_len; + nk_hash title_hash; + nk_size allocated; + + NK_ASSERT(ctx); + NK_ASSERT(title); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + panel = win->layout; + NK_ASSERT(!(panel->type & NK_PANEL_SET_POPUP) && "popups are not allowed to have popups"); + (void)panel; + title_len = (int)nk_strlen(title); + title_hash = nk_murmur_hash(title, (int)title_len, NK_PANEL_POPUP); + + popup = win->popup.win; + if (!popup) { + popup = (struct nk_window*)nk_create_window(ctx); + popup->parent = win; + win->popup.win = popup; + win->popup.active = 0; + win->popup.type = NK_PANEL_POPUP; + } + + /* make sure we have correct popup */ + if (win->popup.name != title_hash) { + if (!win->popup.active) { + nk_zero(popup, sizeof(*popup)); + win->popup.name = title_hash; + win->popup.active = 1; + win->popup.type = NK_PANEL_POPUP; + } else return 0; + } + + /* popup position is local to window */ + ctx->current = popup; + rect.x += win->layout->clip.x; + rect.y += win->layout->clip.y; + + /* setup popup data */ + popup->parent = win; + popup->bounds = rect; + popup->seq = ctx->seq; + popup->layout = (struct nk_panel*)nk_create_panel(ctx); + popup->flags = flags; + popup->flags |= NK_WINDOW_BORDER; + if (type == NK_POPUP_DYNAMIC) + popup->flags |= NK_WINDOW_DYNAMIC; + + popup->buffer = win->buffer; + nk_start_popup(ctx, win); + allocated = ctx->memory.allocated; + nk_push_scissor(&popup->buffer, nk_null_rect); + + if (nk_panel_begin(ctx, title, NK_PANEL_POPUP)) { + /* popup is running therefore invalidate parent panels */ + struct nk_panel *root; + root = win->layout; + while (root) { + root->flags |= NK_WINDOW_ROM; + root->flags &= ~(nk_flags)NK_WINDOW_REMOVE_ROM; + root = root->parent; + } + win->popup.active = 1; + popup->layout->offset_x = &popup->scrollbar.x; + popup->layout->offset_y = &popup->scrollbar.y; + popup->layout->parent = win->layout; + return 1; + } else { + /* popup was closed/is invalid so cleanup */ + struct nk_panel *root; + root = win->layout; + while (root) { + root->flags |= NK_WINDOW_REMOVE_ROM; + root = root->parent; + } + win->popup.buf.active = 0; + win->popup.active = 0; + ctx->memory.allocated = allocated; + ctx->current = win; + nk_free_panel(ctx, popup->layout); + popup->layout = 0; + return 0; + } +} + +NK_INTERN int +nk_nonblock_begin(struct nk_context *ctx, + nk_flags flags, struct nk_rect body, struct nk_rect header, + enum nk_panel_type panel_type) +{ + struct nk_window *popup; + struct nk_window *win; + struct nk_panel *panel; + int is_active = nk_true; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + /* popups cannot have popups */ + win = ctx->current; + panel = win->layout; + NK_ASSERT(!(panel->type & NK_PANEL_SET_POPUP)); + (void)panel; + popup = win->popup.win; + if (!popup) { + /* create window for nonblocking popup */ + popup = (struct nk_window*)nk_create_window(ctx); + popup->parent = win; + win->popup.win = popup; + win->popup.type = panel_type; + nk_command_buffer_init(&popup->buffer, &ctx->memory, NK_CLIPPING_ON); + } else { + /* close the popup if user pressed outside or in the header */ + int pressed, in_body, in_header; + pressed = nk_input_is_mouse_pressed(&ctx->input, NK_BUTTON_LEFT); + in_body = nk_input_is_mouse_hovering_rect(&ctx->input, body); + in_header = nk_input_is_mouse_hovering_rect(&ctx->input, header); + if (pressed && (!in_body || in_header)) + is_active = nk_false; + } + win->popup.header = header; + + if (!is_active) { + /* remove read only mode from all parent panels */ + struct nk_panel *root = win->layout; + while (root) { + root->flags |= NK_WINDOW_REMOVE_ROM; + root = root->parent; + } + return is_active; + } + + popup->bounds = body; + popup->parent = win; + popup->layout = (struct nk_panel*)nk_create_panel(ctx); + popup->flags = flags; + popup->flags |= NK_WINDOW_BORDER; + popup->flags |= NK_WINDOW_DYNAMIC; + popup->seq = ctx->seq; + win->popup.active = 1; + NK_ASSERT(popup->layout); + + nk_start_popup(ctx, win); + popup->buffer = win->buffer; + nk_push_scissor(&popup->buffer, nk_null_rect); + ctx->current = popup; + + nk_panel_begin(ctx, 0, panel_type); + win->buffer = popup->buffer; + popup->layout->parent = win->layout; + popup->layout->offset_x = &popup->scrollbar.x; + popup->layout->offset_y = &popup->scrollbar.y; + + /* set read only mode to all parent panels */ + {struct nk_panel *root; + root = win->layout; + while (root) { + root->flags |= NK_WINDOW_ROM; + root = root->parent; + }} + return is_active; +} + +NK_API void +nk_popup_close(struct nk_context *ctx) +{ + struct nk_window *popup; + NK_ASSERT(ctx); + if (!ctx || !ctx->current) return; + + popup = ctx->current; + NK_ASSERT(popup->parent); + NK_ASSERT(popup->layout->type & NK_PANEL_SET_POPUP); + popup->flags |= NK_WINDOW_HIDDEN; +} + +NK_API void +nk_popup_end(struct nk_context *ctx) +{ + struct nk_window *win; + struct nk_window *popup; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return; + + popup = ctx->current; + if (!popup->parent) return; + win = popup->parent; + if (popup->flags & NK_WINDOW_HIDDEN) { + struct nk_panel *root; + root = win->layout; + while (root) { + root->flags |= NK_WINDOW_REMOVE_ROM; + root = root->parent; + } + win->popup.active = 0; + } + nk_push_scissor(&popup->buffer, nk_null_rect); + nk_end(ctx); + + win->buffer = popup->buffer; + nk_finish_popup(ctx, win); + ctx->current = win; + nk_push_scissor(&win->buffer, win->layout->clip); +} +/* ------------------------------------------------------------- + * + * TOOLTIP + * + * -------------------------------------------------------------- */ +NK_API int +nk_tooltip_begin(struct nk_context *ctx, float width) +{ + struct nk_window *win; + const struct nk_input *in; + struct nk_rect bounds; + int ret; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + /* make sure that no nonblocking popup is currently active */ + win = ctx->current; + in = &ctx->input; + if (win->popup.win && (win->popup.type & NK_PANEL_SET_NONBLOCK)) + return 0; + + bounds.w = (float) nk_iceilf(width); + bounds.h = (float) nk_iceilf(nk_null_rect.h); + bounds.x = nk_ifloorf(in->mouse.pos.x + 1) - win->layout->clip.x; + bounds.y = nk_ifloorf(in->mouse.pos.y + 1) - win->layout->clip.y; + + ret = nk_popup_begin(ctx, NK_POPUP_DYNAMIC, + "__##Tooltip##__", NK_WINDOW_NO_SCROLLBAR|NK_WINDOW_BORDER, bounds); + if (ret) win->layout->flags &= ~(nk_flags)NK_WINDOW_ROM; + win->popup.type = NK_PANEL_TOOLTIP; + ctx->current->layout->type = NK_PANEL_TOOLTIP; + return ret; +} + +NK_API void +nk_tooltip_end(struct nk_context *ctx) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) return; + ctx->current->seq--; + nk_popup_close(ctx); + nk_popup_end(ctx); +} + +NK_API void +nk_tooltip(struct nk_context *ctx, const char *text) +{ + const struct nk_style *style; + struct nk_vec2 padding; + + int text_len; + float text_width; + float text_height; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + NK_ASSERT(text); + if (!ctx || !ctx->current || !ctx->current->layout || !text) + return; + + /* fetch configuration data */ + style = &ctx->style; + padding = style->window.padding; + + /* calculate size of the text and tooltip */ + text_len = nk_strlen(text); + text_width = style->font->width(style->font->userdata, + style->font->height, text, text_len); + text_width += (4 * padding.x); + text_height = (style->font->height + 2 * padding.y); + + /* execute tooltip and fill with text */ + if (nk_tooltip_begin(ctx, (float)text_width)) { + nk_layout_row_dynamic(ctx, (float)text_height, 1); + nk_text(ctx, text, text_len, NK_TEXT_LEFT); + nk_tooltip_end(ctx); + } +} +#ifdef NK_INCLUDE_STANDARD_VARARGS +NK_API void +nk_tooltipf(struct nk_context *ctx, const char *fmt, ...) +{ + char buf[256]; + va_list args; + va_start(args, fmt); + nk_strfmt(buf, NK_LEN(buf), fmt, args); + va_end(args); + nk_tooltip(ctx, buf); +} +#endif + +/* ------------------------------------------------------------- + * + * CONTEXTUAL + * + * -------------------------------------------------------------- */ +NK_API int +nk_contextual_begin(struct nk_context *ctx, nk_flags flags, struct nk_vec2 size, + struct nk_rect trigger_bounds) +{ + struct nk_window *win; + struct nk_window *popup; + struct nk_rect body; + + NK_STORAGE const struct nk_rect null_rect = {0,0,0,0}; + int is_clicked = 0; + int is_active = 0; + int is_open = 0; + int ret = 0; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + ++win->popup.con_count; + + /* check if currently active contextual is active */ + popup = win->popup.win; + is_open = (popup && win->popup.type == NK_PANEL_CONTEXTUAL); + is_clicked = nk_input_mouse_clicked(&ctx->input, NK_BUTTON_RIGHT, trigger_bounds); + if (win->popup.active_con && win->popup.con_count != win->popup.active_con) + return 0; + if ((is_clicked && is_open && !is_active) || (!is_open && !is_active && !is_clicked)) + return 0; + + /* calculate contextual position on click */ + win->popup.active_con = win->popup.con_count; + if (is_clicked) { + body.x = ctx->input.mouse.pos.x; + body.y = ctx->input.mouse.pos.y; + } else { + body.x = popup->bounds.x; + body.y = popup->bounds.y; + } + body.w = size.x; + body.h = size.y; + + /* start nonblocking contextual popup */ + ret = nk_nonblock_begin(ctx, flags|NK_WINDOW_NO_SCROLLBAR, body, + null_rect, NK_PANEL_CONTEXTUAL); + if (ret) win->popup.type = NK_PANEL_CONTEXTUAL; + else { + win->popup.active_con = 0; + if (win->popup.win) + win->popup.win->flags = 0; + } + return ret; +} + +NK_API int +nk_contextual_item_text(struct nk_context *ctx, const char *text, int len, + nk_flags alignment) +{ + struct nk_window *win; + const struct nk_input *in; + const struct nk_style *style; + + struct nk_rect bounds; + enum nk_widget_layout_states state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + style = &ctx->style; + state = nk_widget_fitting(&bounds, ctx, style->contextual_button.padding); + if (!state) return nk_false; + + in = (state == NK_WIDGET_ROM || win->layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + if (nk_do_button_text(&ctx->last_widget_state, &win->buffer, bounds, + text, len, alignment, NK_BUTTON_DEFAULT, &style->contextual_button, in, style->font)) { + nk_contextual_close(ctx); + return nk_true; + } + return nk_false; +} + +NK_API int nk_contextual_item_label(struct nk_context *ctx, const char *label, nk_flags align) +{return nk_contextual_item_text(ctx, label, nk_strlen(label), align);} + +NK_API int +nk_contextual_item_image_text(struct nk_context *ctx, struct nk_image img, + const char *text, int len, nk_flags align) +{ + struct nk_window *win; + const struct nk_input *in; + const struct nk_style *style; + + struct nk_rect bounds; + enum nk_widget_layout_states state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + style = &ctx->style; + state = nk_widget_fitting(&bounds, ctx, style->contextual_button.padding); + if (!state) return nk_false; + + in = (state == NK_WIDGET_ROM || win->layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + if (nk_do_button_text_image(&ctx->last_widget_state, &win->buffer, bounds, + img, text, len, align, NK_BUTTON_DEFAULT, &style->contextual_button, style->font, in)){ + nk_contextual_close(ctx); + return nk_true; + } + return nk_false; +} + +NK_API int nk_contextual_item_image_label(struct nk_context *ctx, struct nk_image img, + const char *label, nk_flags align) +{return nk_contextual_item_image_text(ctx, img, label, nk_strlen(label), align);} + +NK_API int +nk_contextual_item_symbol_text(struct nk_context *ctx, enum nk_symbol_type symbol, + const char *text, int len, nk_flags align) +{ + struct nk_window *win; + const struct nk_input *in; + const struct nk_style *style; + + struct nk_rect bounds; + enum nk_widget_layout_states state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + style = &ctx->style; + state = nk_widget_fitting(&bounds, ctx, style->contextual_button.padding); + if (!state) return nk_false; + + in = (state == NK_WIDGET_ROM || win->layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + if (nk_do_button_text_symbol(&ctx->last_widget_state, &win->buffer, bounds, + symbol, text, len, align, NK_BUTTON_DEFAULT, &style->contextual_button, style->font, in)) { + nk_contextual_close(ctx); + return nk_true; + } + return nk_false; +} + +NK_API int nk_contextual_item_symbol_label(struct nk_context *ctx, enum nk_symbol_type symbol, + const char *text, nk_flags align) +{return nk_contextual_item_symbol_text(ctx, symbol, text, nk_strlen(text), align);} + +NK_API void +nk_contextual_close(struct nk_context *ctx) +{ + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) return; + nk_popup_close(ctx); +} + +NK_API void +nk_contextual_end(struct nk_context *ctx) +{ + struct nk_window *popup; + struct nk_panel *panel; + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + if (!ctx || !ctx->current) return; + + popup = ctx->current; + panel = popup->layout; + NK_ASSERT(popup->parent); + NK_ASSERT(panel->type & NK_PANEL_SET_POPUP); + if (panel->flags & NK_WINDOW_DYNAMIC) { + /* Close behavior + This is a bit of a hack solution since we do not know before we end our popup + how big it will be. We therefore do not directly know when a + click outside the non-blocking popup must close it at that direct frame. + Instead it will be closed in the next frame.*/ + struct nk_rect body = {0,0,0,0}; + if (panel->at_y < (panel->bounds.y + panel->bounds.h)) { + struct nk_vec2 padding = nk_panel_get_padding(&ctx->style, panel->type); + body = panel->bounds; + body.y = (panel->at_y + panel->footer_height + panel->border + padding.y + panel->row.height); + body.h = (panel->bounds.y + panel->bounds.h) - body.y; + } + {int pressed = nk_input_is_mouse_pressed(&ctx->input, NK_BUTTON_LEFT); + int in_body = nk_input_is_mouse_hovering_rect(&ctx->input, body); + if (pressed && in_body) + popup->flags |= NK_WINDOW_HIDDEN; + } + } + if (popup->flags & NK_WINDOW_HIDDEN) + popup->seq = 0; + nk_popup_end(ctx); + return; +} +/* ------------------------------------------------------------- + * + * COMBO + * + * --------------------------------------------------------------*/ +NK_INTERN int +nk_combo_begin(struct nk_context *ctx, struct nk_window *win, + struct nk_vec2 size, int is_clicked, struct nk_rect header) +{ + struct nk_window *popup; + int is_open = 0; + int is_active = 0; + struct nk_rect body; + nk_hash hash; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + popup = win->popup.win; + body.x = header.x; + body.w = size.x; + body.y = header.y + header.h-ctx->style.window.combo_border; + body.h = size.y; + + hash = win->popup.combo_count++; + is_open = (popup) ? nk_true:nk_false; + is_active = (popup && (win->popup.name == hash) && win->popup.type == NK_PANEL_COMBO); + if ((is_clicked && is_open && !is_active) || (is_open && !is_active) || + (!is_open && !is_active && !is_clicked)) return 0; + if (!nk_nonblock_begin(ctx, 0, body, + (is_clicked && is_open)?nk_rect(0,0,0,0):header, NK_PANEL_COMBO)) return 0; + + win->popup.type = NK_PANEL_COMBO; + win->popup.name = hash; + return 1; +} + +NK_API int +nk_combo_begin_text(struct nk_context *ctx, const char *selected, int len, + struct nk_vec2 size) +{ + const struct nk_input *in; + struct nk_window *win; + struct nk_style *style; + + enum nk_widget_layout_states s; + int is_clicked = nk_false; + struct nk_rect header; + const struct nk_style_item *background; + struct nk_text text; + + NK_ASSERT(ctx); + NK_ASSERT(selected); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout || !selected) + return 0; + + win = ctx->current; + style = &ctx->style; + s = nk_widget(&header, ctx); + if (s == NK_WIDGET_INVALID) + return 0; + + in = (win->layout->flags & NK_WINDOW_ROM || s == NK_WIDGET_ROM)? 0: &ctx->input; + if (nk_button_behavior(&ctx->last_widget_state, header, in, NK_BUTTON_DEFAULT)) + is_clicked = nk_true; + + /* draw combo box header background and border */ + if (ctx->last_widget_state & NK_WIDGET_STATE_ACTIVED) { + background = &style->combo.active; + text.text = style->combo.label_active; + } else if (ctx->last_widget_state & NK_WIDGET_STATE_HOVER) { + background = &style->combo.hover; + text.text = style->combo.label_hover; + } else { + background = &style->combo.normal; + text.text = style->combo.label_normal; + } + if (background->type == NK_STYLE_ITEM_IMAGE) { + text.background = nk_rgba(0,0,0,0); + nk_draw_image(&win->buffer, header, &background->data.image, nk_white); + } else { + text.background = background->data.color; + nk_fill_rect(&win->buffer, header, style->combo.rounding, background->data.color); + nk_stroke_rect(&win->buffer, header, style->combo.rounding, style->combo.border, style->combo.border_color); + } + { + /* print currently selected text item */ + struct nk_rect label; + struct nk_rect button; + struct nk_rect content; + + enum nk_symbol_type sym; + if (ctx->last_widget_state & NK_WIDGET_STATE_HOVER) + sym = style->combo.sym_hover; + else if (is_clicked) + sym = style->combo.sym_active; + else sym = style->combo.sym_normal; + + /* calculate button */ + button.w = header.h - 2 * style->combo.button_padding.y; + button.x = (header.x + header.w - header.h) - style->combo.button_padding.x; + button.y = header.y + style->combo.button_padding.y; + button.h = button.w; + + content.x = button.x + style->combo.button.padding.x; + content.y = button.y + style->combo.button.padding.y; + content.w = button.w - 2 * style->combo.button.padding.x; + content.h = button.h - 2 * style->combo.button.padding.y; + + /* draw selected label */ + text.padding = nk_vec2(0,0); + label.x = header.x + style->combo.content_padding.x; + label.y = header.y + style->combo.content_padding.y; + label.w = button.x - (style->combo.content_padding.x + style->combo.spacing.x) - label.x;; + label.h = header.h - 2 * style->combo.content_padding.y; + nk_widget_text(&win->buffer, label, selected, len, &text, + NK_TEXT_LEFT, ctx->style.font); + + /* draw open/close button */ + nk_draw_button_symbol(&win->buffer, &button, &content, ctx->last_widget_state, + &ctx->style.combo.button, sym, style->font); + } + return nk_combo_begin(ctx, win, size, is_clicked, header); +} + +NK_API int nk_combo_begin_label(struct nk_context *ctx, const char *selected, struct nk_vec2 size) +{return nk_combo_begin_text(ctx, selected, nk_strlen(selected), size);} + +NK_API int +nk_combo_begin_color(struct nk_context *ctx, struct nk_color color, struct nk_vec2 size) +{ + struct nk_window *win; + struct nk_style *style; + const struct nk_input *in; + + struct nk_rect header; + int is_clicked = nk_false; + enum nk_widget_layout_states s; + const struct nk_style_item *background; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + style = &ctx->style; + s = nk_widget(&header, ctx); + if (s == NK_WIDGET_INVALID) + return 0; + + in = (win->layout->flags & NK_WINDOW_ROM || s == NK_WIDGET_ROM)? 0: &ctx->input; + if (nk_button_behavior(&ctx->last_widget_state, header, in, NK_BUTTON_DEFAULT)) + is_clicked = nk_true; + + /* draw combo box header background and border */ + if (ctx->last_widget_state & NK_WIDGET_STATE_ACTIVED) + background = &style->combo.active; + else if (ctx->last_widget_state & NK_WIDGET_STATE_HOVER) + background = &style->combo.hover; + else background = &style->combo.normal; + + if (background->type == NK_STYLE_ITEM_IMAGE) { + nk_draw_image(&win->buffer, header, &background->data.image,nk_white); + } else { + nk_fill_rect(&win->buffer, header, style->combo.rounding, background->data.color); + nk_stroke_rect(&win->buffer, header, style->combo.rounding, style->combo.border, style->combo.border_color); + } + { + struct nk_rect content; + struct nk_rect button; + struct nk_rect bounds; + + enum nk_symbol_type sym; + if (ctx->last_widget_state & NK_WIDGET_STATE_HOVER) + sym = style->combo.sym_hover; + else if (is_clicked) + sym = style->combo.sym_active; + else sym = style->combo.sym_normal; + + /* calculate button */ + button.w = header.h - 2 * style->combo.button_padding.y; + button.x = (header.x + header.w - header.h) - style->combo.button_padding.x; + button.y = header.y + style->combo.button_padding.y; + button.h = button.w; + + content.x = button.x + style->combo.button.padding.x; + content.y = button.y + style->combo.button.padding.y; + content.w = button.w - 2 * style->combo.button.padding.x; + content.h = button.h - 2 * style->combo.button.padding.y; + + /* draw color */ + bounds.h = header.h - 4 * style->combo.content_padding.y; + bounds.y = header.y + 2 * style->combo.content_padding.y; + bounds.x = header.x + 2 * style->combo.content_padding.x; + bounds.w = (button.x - (style->combo.content_padding.x + style->combo.spacing.x)) - bounds.x; + nk_fill_rect(&win->buffer, bounds, 0, color); + + /* draw open/close button */ + nk_draw_button_symbol(&win->buffer, &button, &content, ctx->last_widget_state, + &ctx->style.combo.button, sym, style->font); + } + return nk_combo_begin(ctx, win, size, is_clicked, header); +} + +NK_API int +nk_combo_begin_symbol(struct nk_context *ctx, enum nk_symbol_type symbol, struct nk_vec2 size) +{ + struct nk_window *win; + struct nk_style *style; + const struct nk_input *in; + + struct nk_rect header; + int is_clicked = nk_false; + enum nk_widget_layout_states s; + const struct nk_style_item *background; + struct nk_color sym_background; + struct nk_color symbol_color; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + style = &ctx->style; + s = nk_widget(&header, ctx); + if (s == NK_WIDGET_INVALID) + return 0; + + in = (win->layout->flags & NK_WINDOW_ROM || s == NK_WIDGET_ROM)? 0: &ctx->input; + if (nk_button_behavior(&ctx->last_widget_state, header, in, NK_BUTTON_DEFAULT)) + is_clicked = nk_true; + + /* draw combo box header background and border */ + if (ctx->last_widget_state & NK_WIDGET_STATE_ACTIVED) { + background = &style->combo.active; + symbol_color = style->combo.symbol_active; + } else if (ctx->last_widget_state & NK_WIDGET_STATE_HOVER) { + background = &style->combo.hover; + symbol_color = style->combo.symbol_hover; + } else { + background = &style->combo.normal; + symbol_color = style->combo.symbol_hover; + } + + if (background->type == NK_STYLE_ITEM_IMAGE) { + sym_background = nk_rgba(0,0,0,0); + nk_draw_image(&win->buffer, header, &background->data.image, nk_white); + } else { + sym_background = background->data.color; + nk_fill_rect(&win->buffer, header, style->combo.rounding, background->data.color); + nk_stroke_rect(&win->buffer, header, style->combo.rounding, style->combo.border, style->combo.border_color); + } + { + struct nk_rect bounds = {0,0,0,0}; + struct nk_rect content; + struct nk_rect button; + + enum nk_symbol_type sym; + if (ctx->last_widget_state & NK_WIDGET_STATE_HOVER) + sym = style->combo.sym_hover; + else if (is_clicked) + sym = style->combo.sym_active; + else sym = style->combo.sym_normal; + + /* calculate button */ + button.w = header.h - 2 * style->combo.button_padding.y; + button.x = (header.x + header.w - header.h) - style->combo.button_padding.y; + button.y = header.y + style->combo.button_padding.y; + button.h = button.w; + + content.x = button.x + style->combo.button.padding.x; + content.y = button.y + style->combo.button.padding.y; + content.w = button.w - 2 * style->combo.button.padding.x; + content.h = button.h - 2 * style->combo.button.padding.y; + + /* draw symbol */ + bounds.h = header.h - 2 * style->combo.content_padding.y; + bounds.y = header.y + style->combo.content_padding.y; + bounds.x = header.x + style->combo.content_padding.x; + bounds.w = (button.x - style->combo.content_padding.y) - bounds.x; + nk_draw_symbol(&win->buffer, symbol, bounds, sym_background, symbol_color, + 1.0f, style->font); + + /* draw open/close button */ + nk_draw_button_symbol(&win->buffer, &bounds, &content, ctx->last_widget_state, + &ctx->style.combo.button, sym, style->font); + } + return nk_combo_begin(ctx, win, size, is_clicked, header); +} + +NK_API int +nk_combo_begin_symbol_text(struct nk_context *ctx, const char *selected, int len, + enum nk_symbol_type symbol, struct nk_vec2 size) +{ + struct nk_window *win; + struct nk_style *style; + struct nk_input *in; + + struct nk_rect header; + int is_clicked = nk_false; + enum nk_widget_layout_states s; + const struct nk_style_item *background; + struct nk_color symbol_color; + struct nk_text text; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + style = &ctx->style; + s = nk_widget(&header, ctx); + if (!s) return 0; + + in = (win->layout->flags & NK_WINDOW_ROM || s == NK_WIDGET_ROM)? 0: &ctx->input; + if (nk_button_behavior(&ctx->last_widget_state, header, in, NK_BUTTON_DEFAULT)) + is_clicked = nk_true; + + /* draw combo box header background and border */ + if (ctx->last_widget_state & NK_WIDGET_STATE_ACTIVED) { + background = &style->combo.active; + symbol_color = style->combo.symbol_active; + text.text = style->combo.label_active; + } else if (ctx->last_widget_state & NK_WIDGET_STATE_HOVER) { + background = &style->combo.hover; + symbol_color = style->combo.symbol_hover; + text.text = style->combo.label_hover; + } else { + background = &style->combo.normal; + symbol_color = style->combo.symbol_normal; + text.text = style->combo.label_normal; + } + if (background->type == NK_STYLE_ITEM_IMAGE) { + text.background = nk_rgba(0,0,0,0); + nk_draw_image(&win->buffer, header, &background->data.image, nk_white); + } else { + text.background = background->data.color; + nk_fill_rect(&win->buffer, header, style->combo.rounding, background->data.color); + nk_stroke_rect(&win->buffer, header, style->combo.rounding, style->combo.border, style->combo.border_color); + } + { + struct nk_rect content; + struct nk_rect button; + struct nk_rect label; + struct nk_rect image; + + enum nk_symbol_type sym; + if (ctx->last_widget_state & NK_WIDGET_STATE_HOVER) + sym = style->combo.sym_hover; + else if (is_clicked) + sym = style->combo.sym_active; + else sym = style->combo.sym_normal; + + /* calculate button */ + button.w = header.h - 2 * style->combo.button_padding.y; + button.x = (header.x + header.w - header.h) - style->combo.button_padding.x; + button.y = header.y + style->combo.button_padding.y; + button.h = button.w; + + content.x = button.x + style->combo.button.padding.x; + content.y = button.y + style->combo.button.padding.y; + content.w = button.w - 2 * style->combo.button.padding.x; + content.h = button.h - 2 * style->combo.button.padding.y; + nk_draw_button_symbol(&win->buffer, &button, &content, ctx->last_widget_state, + &ctx->style.combo.button, sym, style->font); + + /* draw symbol */ + image.x = header.x + style->combo.content_padding.x; + image.y = header.y + style->combo.content_padding.y; + image.h = header.h - 2 * style->combo.content_padding.y; + image.w = image.h; + nk_draw_symbol(&win->buffer, symbol, image, text.background, symbol_color, + 1.0f, style->font); + + /* draw label */ + text.padding = nk_vec2(0,0); + label.x = image.x + image.w + style->combo.spacing.x + style->combo.content_padding.x; + label.y = header.y + style->combo.content_padding.y; + label.w = (button.x - style->combo.content_padding.x) - label.x; + label.h = header.h - 2 * style->combo.content_padding.y; + nk_widget_text(&win->buffer, label, selected, len, &text, NK_TEXT_LEFT, style->font); + } + return nk_combo_begin(ctx, win, size, is_clicked, header); +} + +NK_API int +nk_combo_begin_image(struct nk_context *ctx, struct nk_image img, struct nk_vec2 size) +{ + struct nk_window *win; + struct nk_style *style; + const struct nk_input *in; + + struct nk_rect header; + int is_clicked = nk_false; + enum nk_widget_layout_states s; + const struct nk_style_item *background; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + style = &ctx->style; + s = nk_widget(&header, ctx); + if (s == NK_WIDGET_INVALID) + return 0; + + in = (win->layout->flags & NK_WINDOW_ROM || s == NK_WIDGET_ROM)? 0: &ctx->input; + if (nk_button_behavior(&ctx->last_widget_state, header, in, NK_BUTTON_DEFAULT)) + is_clicked = nk_true; + + /* draw combo box header background and border */ + if (ctx->last_widget_state & NK_WIDGET_STATE_ACTIVED) + background = &style->combo.active; + else if (ctx->last_widget_state & NK_WIDGET_STATE_HOVER) + background = &style->combo.hover; + else background = &style->combo.normal; + + if (background->type == NK_STYLE_ITEM_IMAGE) { + nk_draw_image(&win->buffer, header, &background->data.image, nk_white); + } else { + nk_fill_rect(&win->buffer, header, style->combo.rounding, background->data.color); + nk_stroke_rect(&win->buffer, header, style->combo.rounding, style->combo.border, style->combo.border_color); + } + { + struct nk_rect bounds = {0,0,0,0}; + struct nk_rect content; + struct nk_rect button; + + enum nk_symbol_type sym; + if (ctx->last_widget_state & NK_WIDGET_STATE_HOVER) + sym = style->combo.sym_hover; + else if (is_clicked) + sym = style->combo.sym_active; + else sym = style->combo.sym_normal; + + /* calculate button */ + button.w = header.h - 2 * style->combo.button_padding.y; + button.x = (header.x + header.w - header.h) - style->combo.button_padding.y; + button.y = header.y + style->combo.button_padding.y; + button.h = button.w; + + content.x = button.x + style->combo.button.padding.x; + content.y = button.y + style->combo.button.padding.y; + content.w = button.w - 2 * style->combo.button.padding.x; + content.h = button.h - 2 * style->combo.button.padding.y; + + /* draw image */ + bounds.h = header.h - 2 * style->combo.content_padding.y; + bounds.y = header.y + style->combo.content_padding.y; + bounds.x = header.x + style->combo.content_padding.x; + bounds.w = (button.x - style->combo.content_padding.y) - bounds.x; + nk_draw_image(&win->buffer, bounds, &img, nk_white); + + /* draw open/close button */ + nk_draw_button_symbol(&win->buffer, &bounds, &content, ctx->last_widget_state, + &ctx->style.combo.button, sym, style->font); + } + return nk_combo_begin(ctx, win, size, is_clicked, header); +} + +NK_API int +nk_combo_begin_image_text(struct nk_context *ctx, const char *selected, int len, + struct nk_image img, struct nk_vec2 size) +{ + struct nk_window *win; + struct nk_style *style; + struct nk_input *in; + + struct nk_rect header; + int is_clicked = nk_false; + enum nk_widget_layout_states s; + const struct nk_style_item *background; + struct nk_text text; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + style = &ctx->style; + s = nk_widget(&header, ctx); + if (!s) return 0; + + in = (win->layout->flags & NK_WINDOW_ROM || s == NK_WIDGET_ROM)? 0: &ctx->input; + if (nk_button_behavior(&ctx->last_widget_state, header, in, NK_BUTTON_DEFAULT)) + is_clicked = nk_true; + + /* draw combo box header background and border */ + if (ctx->last_widget_state & NK_WIDGET_STATE_ACTIVED) { + background = &style->combo.active; + text.text = style->combo.label_active; + } else if (ctx->last_widget_state & NK_WIDGET_STATE_HOVER) { + background = &style->combo.hover; + text.text = style->combo.label_hover; + } else { + background = &style->combo.normal; + text.text = style->combo.label_normal; + } + if (background->type == NK_STYLE_ITEM_IMAGE) { + text.background = nk_rgba(0,0,0,0); + nk_draw_image(&win->buffer, header, &background->data.image, nk_white); + } else { + text.background = background->data.color; + nk_fill_rect(&win->buffer, header, style->combo.rounding, background->data.color); + nk_stroke_rect(&win->buffer, header, style->combo.rounding, style->combo.border, style->combo.border_color); + } + { + struct nk_rect content; + struct nk_rect button; + struct nk_rect label; + struct nk_rect image; + + enum nk_symbol_type sym; + if (ctx->last_widget_state & NK_WIDGET_STATE_HOVER) + sym = style->combo.sym_hover; + else if (is_clicked) + sym = style->combo.sym_active; + else sym = style->combo.sym_normal; + + /* calculate button */ + button.w = header.h - 2 * style->combo.button_padding.y; + button.x = (header.x + header.w - header.h) - style->combo.button_padding.x; + button.y = header.y + style->combo.button_padding.y; + button.h = button.w; + + content.x = button.x + style->combo.button.padding.x; + content.y = button.y + style->combo.button.padding.y; + content.w = button.w - 2 * style->combo.button.padding.x; + content.h = button.h - 2 * style->combo.button.padding.y; + nk_draw_button_symbol(&win->buffer, &button, &content, ctx->last_widget_state, + &ctx->style.combo.button, sym, style->font); + + /* draw image */ + image.x = header.x + style->combo.content_padding.x; + image.y = header.y + style->combo.content_padding.y; + image.h = header.h - 2 * style->combo.content_padding.y; + image.w = image.h; + nk_draw_image(&win->buffer, image, &img, nk_white); + + /* draw label */ + text.padding = nk_vec2(0,0); + label.x = image.x + image.w + style->combo.spacing.x + style->combo.content_padding.x; + label.y = header.y + style->combo.content_padding.y; + label.w = (button.x - style->combo.content_padding.x) - label.x; + label.h = header.h - 2 * style->combo.content_padding.y; + nk_widget_text(&win->buffer, label, selected, len, &text, NK_TEXT_LEFT, style->font); + } + return nk_combo_begin(ctx, win, size, is_clicked, header); +} + +NK_API int nk_combo_begin_symbol_label(struct nk_context *ctx, + const char *selected, enum nk_symbol_type type, struct nk_vec2 size) +{return nk_combo_begin_symbol_text(ctx, selected, nk_strlen(selected), type, size);} + +NK_API int nk_combo_begin_image_label(struct nk_context *ctx, + const char *selected, struct nk_image img, struct nk_vec2 size) +{return nk_combo_begin_image_text(ctx, selected, nk_strlen(selected), img, size);} + +NK_API int nk_combo_item_text(struct nk_context *ctx, const char *text, int len,nk_flags align) +{return nk_contextual_item_text(ctx, text, len, align);} + +NK_API int nk_combo_item_label(struct nk_context *ctx, const char *label, nk_flags align) +{return nk_contextual_item_label(ctx, label, align);} + +NK_API int nk_combo_item_image_text(struct nk_context *ctx, struct nk_image img, const char *text, + int len, nk_flags alignment) +{return nk_contextual_item_image_text(ctx, img, text, len, alignment);} + +NK_API int nk_combo_item_image_label(struct nk_context *ctx, struct nk_image img, + const char *text, nk_flags alignment) +{return nk_contextual_item_image_label(ctx, img, text, alignment);} + +NK_API int nk_combo_item_symbol_text(struct nk_context *ctx, enum nk_symbol_type sym, + const char *text, int len, nk_flags alignment) +{return nk_contextual_item_symbol_text(ctx, sym, text, len, alignment);} + +NK_API int nk_combo_item_symbol_label(struct nk_context *ctx, enum nk_symbol_type sym, + const char *label, nk_flags alignment) +{return nk_contextual_item_symbol_label(ctx, sym, label, alignment);} + +NK_API void nk_combo_end(struct nk_context *ctx) +{nk_contextual_end(ctx);} + +NK_API void nk_combo_close(struct nk_context *ctx) +{nk_contextual_close(ctx);} + +NK_API int +nk_combo(struct nk_context *ctx, const char **items, int count, + int selected, int item_height, struct nk_vec2 size) +{ + int i = 0; + int max_height; + struct nk_vec2 item_spacing; + struct nk_vec2 window_padding; + + NK_ASSERT(ctx); + NK_ASSERT(items); + NK_ASSERT(ctx->current); + if (!ctx || !items ||!count) + return selected; + + item_spacing = ctx->style.window.spacing; + window_padding = nk_panel_get_padding(&ctx->style, ctx->current->layout->type); + max_height = count * item_height + count * (int)item_spacing.y; + max_height += (int)item_spacing.y * 2 + (int)window_padding.y * 2; + size.y = NK_MIN(size.y, (float)max_height); + if (nk_combo_begin_label(ctx, items[selected], size)) { + nk_layout_row_dynamic(ctx, (float)item_height, 1); + for (i = 0; i < count; ++i) { + if (nk_combo_item_label(ctx, items[i], NK_TEXT_LEFT)) + selected = i; + } + nk_combo_end(ctx); + } + return selected; +} + +NK_API int +nk_combo_separator(struct nk_context *ctx, const char *items_separated_by_separator, + int separator, int selected, int count, int item_height, struct nk_vec2 size) +{ + int i; + int max_height; + struct nk_vec2 item_spacing; + struct nk_vec2 window_padding; + const char *current_item; + const char *iter; + int length = 0; + + NK_ASSERT(ctx); + NK_ASSERT(items_separated_by_separator); + if (!ctx || !items_separated_by_separator) + return selected; + + /* calculate popup window */ + item_spacing = ctx->style.window.spacing; + window_padding = nk_panel_get_padding(&ctx->style, ctx->current->layout->type); + max_height = count * item_height + count * (int)item_spacing.y; + max_height += (int)item_spacing.y * 2 + (int)window_padding.y * 2; + size.y = NK_MIN(size.y, (float)max_height); + + /* find selected item */ + current_item = items_separated_by_separator; + for (i = 0; i < count; ++i) { + iter = current_item; + while (*iter && *iter != separator) iter++; + length = (int)(iter - current_item); + if (i == selected) break; + current_item = iter + 1; + } + + if (nk_combo_begin_text(ctx, current_item, length, size)) { + current_item = items_separated_by_separator; + nk_layout_row_dynamic(ctx, (float)item_height, 1); + for (i = 0; i < count; ++i) { + iter = current_item; + while (*iter && *iter != separator) iter++; + length = (int)(iter - current_item); + if (nk_combo_item_text(ctx, current_item, length, NK_TEXT_LEFT)) + selected = i; + current_item = current_item + length + 1; + } + nk_combo_end(ctx); + } + return selected; +} + +NK_API int +nk_combo_string(struct nk_context *ctx, const char *items_separated_by_zeros, + int selected, int count, int item_height, struct nk_vec2 size) +{return nk_combo_separator(ctx, items_separated_by_zeros, '\0', selected, count, item_height, size);} + +NK_API int +nk_combo_callback(struct nk_context *ctx, void(*item_getter)(void*, int, const char**), + void *userdata, int selected, int count, int item_height, struct nk_vec2 size) +{ + int i; + int max_height; + struct nk_vec2 item_spacing; + struct nk_vec2 window_padding; + const char *item; + + NK_ASSERT(ctx); + NK_ASSERT(item_getter); + if (!ctx || !item_getter) + return selected; + + /* calculate popup window */ + item_spacing = ctx->style.window.spacing; + window_padding = nk_panel_get_padding(&ctx->style, ctx->current->layout->type); + max_height = count * item_height + count * (int)item_spacing.y; + max_height += (int)item_spacing.y * 2 + (int)window_padding.y * 2; + size.y = NK_MIN(size.y, (float)max_height); + + item_getter(userdata, selected, &item); + if (nk_combo_begin_label(ctx, item, size)) { + nk_layout_row_dynamic(ctx, (float)item_height, 1); + for (i = 0; i < count; ++i) { + item_getter(userdata, i, &item); + if (nk_combo_item_label(ctx, item, NK_TEXT_LEFT)) + selected = i; + } + nk_combo_end(ctx); + } + return selected; +} + +NK_API void nk_combobox(struct nk_context *ctx, const char **items, int count, + int *selected, int item_height, struct nk_vec2 size) +{*selected = nk_combo(ctx, items, count, *selected, item_height, size);} + +NK_API void nk_combobox_string(struct nk_context *ctx, const char *items_separated_by_zeros, + int *selected, int count, int item_height, struct nk_vec2 size) +{*selected = nk_combo_string(ctx, items_separated_by_zeros, *selected, count, item_height, size);} + +NK_API void nk_combobox_separator(struct nk_context *ctx, const char *items_separated_by_separator, + int separator,int *selected, int count, int item_height, struct nk_vec2 size) +{*selected = nk_combo_separator(ctx, items_separated_by_separator, separator, + *selected, count, item_height, size);} + +NK_API void nk_combobox_callback(struct nk_context *ctx, + void(*item_getter)(void* data, int id, const char **out_text), + void *userdata, int *selected, int count, int item_height, struct nk_vec2 size) +{*selected = nk_combo_callback(ctx, item_getter, userdata, *selected, count, item_height, size);} + +/* + * ------------------------------------------------------------- + * + * MENU + * + * -------------------------------------------------------------- + */ +NK_INTERN int +nk_menu_begin(struct nk_context *ctx, struct nk_window *win, + const char *id, int is_clicked, struct nk_rect header, struct nk_vec2 size) +{ + int is_open = 0; + int is_active = 0; + struct nk_rect body; + struct nk_window *popup; + nk_hash hash = nk_murmur_hash(id, (int)nk_strlen(id), NK_PANEL_MENU); + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + body.x = header.x; + body.w = size.x; + body.y = header.y + header.h; + body.h = size.y; + + popup = win->popup.win; + is_open = popup ? nk_true : nk_false; + is_active = (popup && (win->popup.name == hash) && win->popup.type == NK_PANEL_MENU); + if ((is_clicked && is_open && !is_active) || (is_open && !is_active) || + (!is_open && !is_active && !is_clicked)) return 0; + if (!nk_nonblock_begin(ctx, NK_WINDOW_NO_SCROLLBAR, body, header, NK_PANEL_MENU)) + return 0; + + win->popup.type = NK_PANEL_MENU; + win->popup.name = hash; + return 1; +} + +NK_API int +nk_menu_begin_text(struct nk_context *ctx, const char *title, int len, + nk_flags align, struct nk_vec2 size) +{ + struct nk_window *win; + const struct nk_input *in; + struct nk_rect header; + int is_clicked = nk_false; + nk_flags state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + state = nk_widget(&header, ctx); + if (!state) return 0; + in = (state == NK_WIDGET_ROM || win->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + if (nk_do_button_text(&ctx->last_widget_state, &win->buffer, header, + title, len, align, NK_BUTTON_DEFAULT, &ctx->style.menu_button, in, ctx->style.font)) + is_clicked = nk_true; + return nk_menu_begin(ctx, win, title, is_clicked, header, size); +} + +NK_API int nk_menu_begin_label(struct nk_context *ctx, + const char *text, nk_flags align, struct nk_vec2 size) +{return nk_menu_begin_text(ctx, text, nk_strlen(text), align, size);} + +NK_API int +nk_menu_begin_image(struct nk_context *ctx, const char *id, struct nk_image img, + struct nk_vec2 size) +{ + struct nk_window *win; + struct nk_rect header; + const struct nk_input *in; + int is_clicked = nk_false; + nk_flags state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + state = nk_widget(&header, ctx); + if (!state) return 0; + in = (state == NK_WIDGET_ROM || win->layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + if (nk_do_button_image(&ctx->last_widget_state, &win->buffer, header, + img, NK_BUTTON_DEFAULT, &ctx->style.menu_button, in)) + is_clicked = nk_true; + return nk_menu_begin(ctx, win, id, is_clicked, header, size); +} + +NK_API int +nk_menu_begin_symbol(struct nk_context *ctx, const char *id, + enum nk_symbol_type sym, struct nk_vec2 size) +{ + struct nk_window *win; + const struct nk_input *in; + struct nk_rect header; + int is_clicked = nk_false; + nk_flags state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + state = nk_widget(&header, ctx); + if (!state) return 0; + in = (state == NK_WIDGET_ROM || win->layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + if (nk_do_button_symbol(&ctx->last_widget_state, &win->buffer, header, + sym, NK_BUTTON_DEFAULT, &ctx->style.menu_button, in, ctx->style.font)) + is_clicked = nk_true; + return nk_menu_begin(ctx, win, id, is_clicked, header, size); +} + +NK_API int +nk_menu_begin_image_text(struct nk_context *ctx, const char *title, int len, + nk_flags align, struct nk_image img, struct nk_vec2 size) +{ + struct nk_window *win; + struct nk_rect header; + const struct nk_input *in; + int is_clicked = nk_false; + nk_flags state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + state = nk_widget(&header, ctx); + if (!state) return 0; + in = (state == NK_WIDGET_ROM || win->layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + if (nk_do_button_text_image(&ctx->last_widget_state, &win->buffer, + header, img, title, len, align, NK_BUTTON_DEFAULT, &ctx->style.menu_button, + ctx->style.font, in)) + is_clicked = nk_true; + return nk_menu_begin(ctx, win, title, is_clicked, header, size); +} + +NK_API int nk_menu_begin_image_label(struct nk_context *ctx, + const char *title, nk_flags align, struct nk_image img, struct nk_vec2 size) +{return nk_menu_begin_image_text(ctx, title, nk_strlen(title), align, img, size);} + +NK_API int +nk_menu_begin_symbol_text(struct nk_context *ctx, const char *title, int len, + nk_flags align, enum nk_symbol_type sym, struct nk_vec2 size) +{ + struct nk_window *win; + struct nk_rect header; + const struct nk_input *in; + int is_clicked = nk_false; + nk_flags state; + + NK_ASSERT(ctx); + NK_ASSERT(ctx->current); + NK_ASSERT(ctx->current->layout); + if (!ctx || !ctx->current || !ctx->current->layout) + return 0; + + win = ctx->current; + state = nk_widget(&header, ctx); + if (!state) return 0; + + in = (state == NK_WIDGET_ROM || win->layout->flags & NK_WINDOW_ROM) ? 0 : &ctx->input; + if (nk_do_button_text_symbol(&ctx->last_widget_state, &win->buffer, + header, sym, title, len, align, NK_BUTTON_DEFAULT, &ctx->style.menu_button, + ctx->style.font, in)) is_clicked = nk_true; + return nk_menu_begin(ctx, win, title, is_clicked, header, size); +} + +NK_API int nk_menu_begin_symbol_label(struct nk_context *ctx, + const char *title, nk_flags align, enum nk_symbol_type sym, struct nk_vec2 size ) +{return nk_menu_begin_symbol_text(ctx, title, nk_strlen(title), align,sym,size);} + +NK_API int nk_menu_item_text(struct nk_context *ctx, const char *title, int len, nk_flags align) +{return nk_contextual_item_text(ctx, title, len, align);} + +NK_API int nk_menu_item_label(struct nk_context *ctx, const char *label, nk_flags align) +{return nk_contextual_item_label(ctx, label, align);} + +NK_API int nk_menu_item_image_label(struct nk_context *ctx, struct nk_image img, + const char *label, nk_flags align) +{return nk_contextual_item_image_label(ctx, img, label, align);} + +NK_API int nk_menu_item_image_text(struct nk_context *ctx, struct nk_image img, + const char *text, int len, nk_flags align) +{return nk_contextual_item_image_text(ctx, img, text, len, align);} + +NK_API int nk_menu_item_symbol_text(struct nk_context *ctx, enum nk_symbol_type sym, + const char *text, int len, nk_flags align) +{return nk_contextual_item_symbol_text(ctx, sym, text, len, align);} + +NK_API int nk_menu_item_symbol_label(struct nk_context *ctx, enum nk_symbol_type sym, + const char *label, nk_flags align) +{return nk_contextual_item_symbol_label(ctx, sym, label, align);} + +NK_API void nk_menu_close(struct nk_context *ctx) +{nk_contextual_close(ctx);} + +NK_API void +nk_menu_end(struct nk_context *ctx) +{nk_contextual_end(ctx);} + +#endif /* NK_IMPLEMENTATION */ diff --git a/src/external/glfw/deps/nuklear_glfw_gl2.h b/src/external/glfw/deps/nuklear_glfw_gl2.h new file mode 100644 index 000000000..61acc29c6 --- /dev/null +++ b/src/external/glfw/deps/nuklear_glfw_gl2.h @@ -0,0 +1,381 @@ +/* + * Nuklear - v1.32.0 - public domain + * no warrenty implied; use at your own risk. + * authored from 2015-2017 by Micha Mettke + */ +/* + * ============================================================== + * + * API + * + * =============================================================== + */ +#ifndef NK_GLFW_GL2_H_ +#define NK_GLFW_GL2_H_ + +#include + +enum nk_glfw_init_state{ + NK_GLFW3_DEFAULT = 0, + NK_GLFW3_INSTALL_CALLBACKS +}; +NK_API struct nk_context* nk_glfw3_init(GLFWwindow *win, enum nk_glfw_init_state); +NK_API void nk_glfw3_font_stash_begin(struct nk_font_atlas **atlas); +NK_API void nk_glfw3_font_stash_end(void); + +NK_API void nk_glfw3_new_frame(void); +NK_API void nk_glfw3_render(enum nk_anti_aliasing); +NK_API void nk_glfw3_shutdown(void); + +NK_API void nk_glfw3_char_callback(GLFWwindow *win, unsigned int codepoint); +NK_API void nk_gflw3_scroll_callback(GLFWwindow *win, double xoff, double yoff); + +#endif + +/* + * ============================================================== + * + * IMPLEMENTATION + * + * =============================================================== + */ +#ifdef NK_GLFW_GL2_IMPLEMENTATION + +#ifndef NK_GLFW_TEXT_MAX +#define NK_GLFW_TEXT_MAX 256 +#endif +#ifndef NK_GLFW_DOUBLE_CLICK_LO +#define NK_GLFW_DOUBLE_CLICK_LO 0.02 +#endif +#ifndef NK_GLFW_DOUBLE_CLICK_HI +#define NK_GLFW_DOUBLE_CLICK_HI 0.2 +#endif + +struct nk_glfw_device { + struct nk_buffer cmds; + struct nk_draw_null_texture null; + GLuint font_tex; +}; + +struct nk_glfw_vertex { + float position[2]; + float uv[2]; + nk_byte col[4]; +}; + +static struct nk_glfw { + GLFWwindow *win; + int width, height; + int display_width, display_height; + struct nk_glfw_device ogl; + struct nk_context ctx; + struct nk_font_atlas atlas; + struct nk_vec2 fb_scale; + unsigned int text[NK_GLFW_TEXT_MAX]; + int text_len; + struct nk_vec2 scroll; + double last_button_click; + int is_double_click_down; + struct nk_vec2 double_click_pos; +} glfw; + +NK_INTERN void +nk_glfw3_device_upload_atlas(const void *image, int width, int height) +{ + struct nk_glfw_device *dev = &glfw.ogl; + glGenTextures(1, &dev->font_tex); + glBindTexture(GL_TEXTURE_2D, dev->font_tex); + glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); + glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR); + glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, (GLsizei)width, (GLsizei)height, 0, + GL_RGBA, GL_UNSIGNED_BYTE, image); +} + +NK_API void +nk_glfw3_render(enum nk_anti_aliasing AA) +{ + /* setup global state */ + struct nk_glfw_device *dev = &glfw.ogl; + glPushAttrib(GL_ENABLE_BIT|GL_COLOR_BUFFER_BIT|GL_TRANSFORM_BIT); + glDisable(GL_CULL_FACE); + glDisable(GL_DEPTH_TEST); + glEnable(GL_SCISSOR_TEST); + glEnable(GL_BLEND); + glEnable(GL_TEXTURE_2D); + glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); + + /* setup viewport/project */ + glViewport(0,0,(GLsizei)glfw.display_width,(GLsizei)glfw.display_height); + glMatrixMode(GL_PROJECTION); + glPushMatrix(); + glLoadIdentity(); + glOrtho(0.0f, glfw.width, glfw.height, 0.0f, -1.0f, 1.0f); + glMatrixMode(GL_MODELVIEW); + glPushMatrix(); + glLoadIdentity(); + + glEnableClientState(GL_VERTEX_ARRAY); + glEnableClientState(GL_TEXTURE_COORD_ARRAY); + glEnableClientState(GL_COLOR_ARRAY); + { + GLsizei vs = sizeof(struct nk_glfw_vertex); + size_t vp = offsetof(struct nk_glfw_vertex, position); + size_t vt = offsetof(struct nk_glfw_vertex, uv); + size_t vc = offsetof(struct nk_glfw_vertex, col); + + /* convert from command queue into draw list and draw to screen */ + const struct nk_draw_command *cmd; + const nk_draw_index *offset = NULL; + struct nk_buffer vbuf, ebuf; + + /* fill convert configuration */ + struct nk_convert_config config; + static const struct nk_draw_vertex_layout_element vertex_layout[] = { + {NK_VERTEX_POSITION, NK_FORMAT_FLOAT, NK_OFFSETOF(struct nk_glfw_vertex, position)}, + {NK_VERTEX_TEXCOORD, NK_FORMAT_FLOAT, NK_OFFSETOF(struct nk_glfw_vertex, uv)}, + {NK_VERTEX_COLOR, NK_FORMAT_R8G8B8A8, NK_OFFSETOF(struct nk_glfw_vertex, col)}, + {NK_VERTEX_LAYOUT_END} + }; + NK_MEMSET(&config, 0, sizeof(config)); + config.vertex_layout = vertex_layout; + config.vertex_size = sizeof(struct nk_glfw_vertex); + config.vertex_alignment = NK_ALIGNOF(struct nk_glfw_vertex); + config.null = dev->null; + config.circle_segment_count = 22; + config.curve_segment_count = 22; + config.arc_segment_count = 22; + config.global_alpha = 1.0f; + config.shape_AA = AA; + config.line_AA = AA; + + /* convert shapes into vertexes */ + nk_buffer_init_default(&vbuf); + nk_buffer_init_default(&ebuf); + nk_convert(&glfw.ctx, &dev->cmds, &vbuf, &ebuf, &config); + + /* setup vertex buffer pointer */ + {const void *vertices = nk_buffer_memory_const(&vbuf); + glVertexPointer(2, GL_FLOAT, vs, (const void*)((const nk_byte*)vertices + vp)); + glTexCoordPointer(2, GL_FLOAT, vs, (const void*)((const nk_byte*)vertices + vt)); + glColorPointer(4, GL_UNSIGNED_BYTE, vs, (const void*)((const nk_byte*)vertices + vc));} + + /* iterate over and execute each draw command */ + offset = (const nk_draw_index*)nk_buffer_memory_const(&ebuf); + nk_draw_foreach(cmd, &glfw.ctx, &dev->cmds) + { + if (!cmd->elem_count) continue; + glBindTexture(GL_TEXTURE_2D, (GLuint)cmd->texture.id); + glScissor( + (GLint)(cmd->clip_rect.x * glfw.fb_scale.x), + (GLint)((glfw.height - (GLint)(cmd->clip_rect.y + cmd->clip_rect.h)) * glfw.fb_scale.y), + (GLint)(cmd->clip_rect.w * glfw.fb_scale.x), + (GLint)(cmd->clip_rect.h * glfw.fb_scale.y)); + glDrawElements(GL_TRIANGLES, (GLsizei)cmd->elem_count, GL_UNSIGNED_SHORT, offset); + offset += cmd->elem_count; + } + nk_clear(&glfw.ctx); + nk_buffer_free(&vbuf); + nk_buffer_free(&ebuf); + } + + /* default OpenGL state */ + glDisableClientState(GL_VERTEX_ARRAY); + glDisableClientState(GL_TEXTURE_COORD_ARRAY); + glDisableClientState(GL_COLOR_ARRAY); + + glDisable(GL_CULL_FACE); + glDisable(GL_DEPTH_TEST); + glDisable(GL_SCISSOR_TEST); + glDisable(GL_BLEND); + glDisable(GL_TEXTURE_2D); + + glBindTexture(GL_TEXTURE_2D, 0); + glMatrixMode(GL_MODELVIEW); + glPopMatrix(); + glMatrixMode(GL_PROJECTION); + glPopMatrix(); + glPopAttrib(); +} + +NK_API void +nk_glfw3_char_callback(GLFWwindow *win, unsigned int codepoint) +{ + (void)win; + if (glfw.text_len < NK_GLFW_TEXT_MAX) + glfw.text[glfw.text_len++] = codepoint; +} + +NK_API void +nk_gflw3_scroll_callback(GLFWwindow *win, double xoff, double yoff) +{ + (void)win; (void)xoff; + glfw.scroll.x += (float)xoff; + glfw.scroll.y += (float)yoff; +} + +NK_API void +nk_glfw3_mouse_button_callback(GLFWwindow* window, int button, int action, int mods) +{ + double x, y; + if (button != GLFW_MOUSE_BUTTON_LEFT) return; + glfwGetCursorPos(window, &x, &y); + if (action == GLFW_PRESS) { + double dt = glfwGetTime() - glfw.last_button_click; + if (dt > NK_GLFW_DOUBLE_CLICK_LO && dt < NK_GLFW_DOUBLE_CLICK_HI) { + glfw.is_double_click_down = nk_true; + glfw.double_click_pos = nk_vec2((float)x, (float)y); + } + glfw.last_button_click = glfwGetTime(); + } else glfw.is_double_click_down = nk_false; +} + +NK_INTERN void +nk_glfw3_clipbard_paste(nk_handle usr, struct nk_text_edit *edit) +{ + const char *text = glfwGetClipboardString(glfw.win); + if (text) nk_textedit_paste(edit, text, nk_strlen(text)); + (void)usr; +} + +NK_INTERN void +nk_glfw3_clipbard_copy(nk_handle usr, const char *text, int len) +{ + char *str = 0; + (void)usr; + if (!len) return; + str = (char*)malloc((size_t)len+1); + if (!str) return; + NK_MEMCPY(str, text, (size_t)len); + str[len] = '\0'; + glfwSetClipboardString(glfw.win, str); + free(str); +} + +NK_API struct nk_context* +nk_glfw3_init(GLFWwindow *win, enum nk_glfw_init_state init_state) +{ + glfw.win = win; + if (init_state == NK_GLFW3_INSTALL_CALLBACKS) { + glfwSetScrollCallback(win, nk_gflw3_scroll_callback); + glfwSetCharCallback(win, nk_glfw3_char_callback); + glfwSetMouseButtonCallback(win, nk_glfw3_mouse_button_callback); + } + nk_init_default(&glfw.ctx, 0); + glfw.ctx.clip.copy = nk_glfw3_clipbard_copy; + glfw.ctx.clip.paste = nk_glfw3_clipbard_paste; + glfw.ctx.clip.userdata = nk_handle_ptr(0); + nk_buffer_init_default(&glfw.ogl.cmds); + + glfw.is_double_click_down = nk_false; + glfw.double_click_pos = nk_vec2(0, 0); + + return &glfw.ctx; +} + +NK_API void +nk_glfw3_font_stash_begin(struct nk_font_atlas **atlas) +{ + nk_font_atlas_init_default(&glfw.atlas); + nk_font_atlas_begin(&glfw.atlas); + *atlas = &glfw.atlas; +} + +NK_API void +nk_glfw3_font_stash_end(void) +{ + const void *image; int w, h; + image = nk_font_atlas_bake(&glfw.atlas, &w, &h, NK_FONT_ATLAS_RGBA32); + nk_glfw3_device_upload_atlas(image, w, h); + nk_font_atlas_end(&glfw.atlas, nk_handle_id((int)glfw.ogl.font_tex), &glfw.ogl.null); + if (glfw.atlas.default_font) + nk_style_set_font(&glfw.ctx, &glfw.atlas.default_font->handle); +} + +NK_API void +nk_glfw3_new_frame(void) +{ + int i; + double x, y; + struct nk_context *ctx = &glfw.ctx; + struct GLFWwindow *win = glfw.win; + + glfwGetWindowSize(win, &glfw.width, &glfw.height); + glfwGetFramebufferSize(win, &glfw.display_width, &glfw.display_height); + glfw.fb_scale.x = (float)glfw.display_width/(float)glfw.width; + glfw.fb_scale.y = (float)glfw.display_height/(float)glfw.height; + + nk_input_begin(ctx); + for (i = 0; i < glfw.text_len; ++i) + nk_input_unicode(ctx, glfw.text[i]); + + /* optional grabbing behavior */ + if (ctx->input.mouse.grab) + glfwSetInputMode(glfw.win, GLFW_CURSOR, GLFW_CURSOR_HIDDEN); + else if (ctx->input.mouse.ungrab) + glfwSetInputMode(glfw.win, GLFW_CURSOR, GLFW_CURSOR_NORMAL); + + nk_input_key(ctx, NK_KEY_DEL, glfwGetKey(win, GLFW_KEY_DELETE) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_ENTER, glfwGetKey(win, GLFW_KEY_ENTER) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_TAB, glfwGetKey(win, GLFW_KEY_TAB) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_BACKSPACE, glfwGetKey(win, GLFW_KEY_BACKSPACE) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_UP, glfwGetKey(win, GLFW_KEY_UP) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_DOWN, glfwGetKey(win, GLFW_KEY_DOWN) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_TEXT_START, glfwGetKey(win, GLFW_KEY_HOME) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_TEXT_END, glfwGetKey(win, GLFW_KEY_END) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_SCROLL_START, glfwGetKey(win, GLFW_KEY_HOME) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_SCROLL_END, glfwGetKey(win, GLFW_KEY_END) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_SCROLL_DOWN, glfwGetKey(win, GLFW_KEY_PAGE_DOWN) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_SCROLL_UP, glfwGetKey(win, GLFW_KEY_PAGE_UP) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_SHIFT, glfwGetKey(win, GLFW_KEY_LEFT_SHIFT) == GLFW_PRESS|| + glfwGetKey(win, GLFW_KEY_RIGHT_SHIFT) == GLFW_PRESS); + + if (glfwGetKey(win, GLFW_KEY_LEFT_CONTROL) == GLFW_PRESS || + glfwGetKey(win, GLFW_KEY_RIGHT_CONTROL) == GLFW_PRESS) { + nk_input_key(ctx, NK_KEY_COPY, glfwGetKey(win, GLFW_KEY_C) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_PASTE, glfwGetKey(win, GLFW_KEY_V) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_CUT, glfwGetKey(win, GLFW_KEY_X) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_TEXT_UNDO, glfwGetKey(win, GLFW_KEY_Z) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_TEXT_REDO, glfwGetKey(win, GLFW_KEY_R) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_TEXT_WORD_LEFT, glfwGetKey(win, GLFW_KEY_LEFT) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_TEXT_WORD_RIGHT, glfwGetKey(win, GLFW_KEY_RIGHT) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_TEXT_LINE_START, glfwGetKey(win, GLFW_KEY_B) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_TEXT_LINE_END, glfwGetKey(win, GLFW_KEY_E) == GLFW_PRESS); + } else { + nk_input_key(ctx, NK_KEY_LEFT, glfwGetKey(win, GLFW_KEY_LEFT) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_RIGHT, glfwGetKey(win, GLFW_KEY_RIGHT) == GLFW_PRESS); + nk_input_key(ctx, NK_KEY_COPY, 0); + nk_input_key(ctx, NK_KEY_PASTE, 0); + nk_input_key(ctx, NK_KEY_CUT, 0); + nk_input_key(ctx, NK_KEY_SHIFT, 0); + } + + glfwGetCursorPos(win, &x, &y); + nk_input_motion(ctx, (int)x, (int)y); + if (ctx->input.mouse.grabbed) { + glfwSetCursorPos(glfw.win, (double)ctx->input.mouse.prev.x, (double)ctx->input.mouse.prev.y); + ctx->input.mouse.pos.x = ctx->input.mouse.prev.x; + ctx->input.mouse.pos.y = ctx->input.mouse.prev.y; + } + + nk_input_button(ctx, NK_BUTTON_LEFT, (int)x, (int)y, glfwGetMouseButton(win, GLFW_MOUSE_BUTTON_LEFT) == GLFW_PRESS); + nk_input_button(ctx, NK_BUTTON_MIDDLE, (int)x, (int)y, glfwGetMouseButton(win, GLFW_MOUSE_BUTTON_MIDDLE) == GLFW_PRESS); + nk_input_button(ctx, NK_BUTTON_RIGHT, (int)x, (int)y, glfwGetMouseButton(win, GLFW_MOUSE_BUTTON_RIGHT) == GLFW_PRESS); + nk_input_button(ctx, NK_BUTTON_DOUBLE, (int)glfw.double_click_pos.x, (int)glfw.double_click_pos.y, glfw.is_double_click_down); + nk_input_scroll(ctx, glfw.scroll); + nk_input_end(&glfw.ctx); + glfw.text_len = 0; + glfw.scroll = nk_vec2(0,0); +} + +NK_API +void nk_glfw3_shutdown(void) +{ + struct nk_glfw_device *dev = &glfw.ogl; + nk_font_atlas_clear(&glfw.atlas); + nk_free(&glfw.ctx); + glDeleteTextures(1, &dev->font_tex); + nk_buffer_free(&dev->cmds); + NK_MEMSET(&glfw, 0, sizeof(glfw)); +} + +#endif diff --git a/src/external/glfw/deps/stb_image_write.h b/src/external/glfw/deps/stb_image_write.h new file mode 100644 index 000000000..4319c0de1 --- /dev/null +++ b/src/external/glfw/deps/stb_image_write.h @@ -0,0 +1,1048 @@ +/* stb_image_write - v1.02 - public domain - http://nothings.org/stb/stb_image_write.h + writes out PNG/BMP/TGA images to C stdio - Sean Barrett 2010-2015 + no warranty implied; use at your own risk + + Before #including, + + #define STB_IMAGE_WRITE_IMPLEMENTATION + + in the file that you want to have the implementation. + + Will probably not work correctly with strict-aliasing optimizations. + +ABOUT: + + This header file is a library for writing images to C stdio. It could be + adapted to write to memory or a general streaming interface; let me know. + + The PNG output is not optimal; it is 20-50% larger than the file + written by a decent optimizing implementation. This library is designed + for source code compactness and simplicity, not optimal image file size + or run-time performance. + +BUILDING: + + You can #define STBIW_ASSERT(x) before the #include to avoid using assert.h. + You can #define STBIW_MALLOC(), STBIW_REALLOC(), and STBIW_FREE() to replace + malloc,realloc,free. + You can define STBIW_MEMMOVE() to replace memmove() + +USAGE: + + There are four functions, one for each image file format: + + int stbi_write_png(char const *filename, int w, int h, int comp, const void *data, int stride_in_bytes); + int stbi_write_bmp(char const *filename, int w, int h, int comp, const void *data); + int stbi_write_tga(char const *filename, int w, int h, int comp, const void *data); + int stbi_write_hdr(char const *filename, int w, int h, int comp, const float *data); + + There are also four equivalent functions that use an arbitrary write function. You are + expected to open/close your file-equivalent before and after calling these: + + int stbi_write_png_to_func(stbi_write_func *func, void *context, int w, int h, int comp, const void *data, int stride_in_bytes); + int stbi_write_bmp_to_func(stbi_write_func *func, void *context, int w, int h, int comp, const void *data); + int stbi_write_tga_to_func(stbi_write_func *func, void *context, int w, int h, int comp, const void *data); + int stbi_write_hdr_to_func(stbi_write_func *func, void *context, int w, int h, int comp, const float *data); + + where the callback is: + void stbi_write_func(void *context, void *data, int size); + + You can define STBI_WRITE_NO_STDIO to disable the file variant of these + functions, so the library will not use stdio.h at all. However, this will + also disable HDR writing, because it requires stdio for formatted output. + + Each function returns 0 on failure and non-0 on success. + + The functions create an image file defined by the parameters. The image + is a rectangle of pixels stored from left-to-right, top-to-bottom. + Each pixel contains 'comp' channels of data stored interleaved with 8-bits + per channel, in the following order: 1=Y, 2=YA, 3=RGB, 4=RGBA. (Y is + monochrome color.) The rectangle is 'w' pixels wide and 'h' pixels tall. + The *data pointer points to the first byte of the top-left-most pixel. + For PNG, "stride_in_bytes" is the distance in bytes from the first byte of + a row of pixels to the first byte of the next row of pixels. + + PNG creates output files with the same number of components as the input. + The BMP format expands Y to RGB in the file format and does not + output alpha. + + PNG supports writing rectangles of data even when the bytes storing rows of + data are not consecutive in memory (e.g. sub-rectangles of a larger image), + by supplying the stride between the beginning of adjacent rows. The other + formats do not. (Thus you cannot write a native-format BMP through the BMP + writer, both because it is in BGR order and because it may have padding + at the end of the line.) + + HDR expects linear float data. Since the format is always 32-bit rgb(e) + data, alpha (if provided) is discarded, and for monochrome data it is + replicated across all three channels. + + TGA supports RLE or non-RLE compressed data. To use non-RLE-compressed + data, set the global variable 'stbi_write_tga_with_rle' to 0. + +CREDITS: + + PNG/BMP/TGA + Sean Barrett + HDR + Baldur Karlsson + TGA monochrome: + Jean-Sebastien Guay + misc enhancements: + Tim Kelsey + TGA RLE + Alan Hickman + initial file IO callback implementation + Emmanuel Julien + bugfixes: + github:Chribba + Guillaume Chereau + github:jry2 + github:romigrou + Sergio Gonzalez + Jonas Karlsson + Filip Wasil + Thatcher Ulrich + +LICENSE + +This software is dual-licensed to the public domain and under the following +license: you are granted a perpetual, irrevocable license to copy, modify, +publish, and distribute this file as you see fit. + +*/ + +#ifndef INCLUDE_STB_IMAGE_WRITE_H +#define INCLUDE_STB_IMAGE_WRITE_H + +#ifdef __cplusplus +extern "C" { +#endif + +#ifdef STB_IMAGE_WRITE_STATIC +#define STBIWDEF static +#else +#define STBIWDEF extern +extern int stbi_write_tga_with_rle; +#endif + +#ifndef STBI_WRITE_NO_STDIO +STBIWDEF int stbi_write_png(char const *filename, int w, int h, int comp, const void *data, int stride_in_bytes); +STBIWDEF int stbi_write_bmp(char const *filename, int w, int h, int comp, const void *data); +STBIWDEF int stbi_write_tga(char const *filename, int w, int h, int comp, const void *data); +STBIWDEF int stbi_write_hdr(char const *filename, int w, int h, int comp, const float *data); +#endif + +typedef void stbi_write_func(void *context, void *data, int size); + +STBIWDEF int stbi_write_png_to_func(stbi_write_func *func, void *context, int w, int h, int comp, const void *data, int stride_in_bytes); +STBIWDEF int stbi_write_bmp_to_func(stbi_write_func *func, void *context, int w, int h, int comp, const void *data); +STBIWDEF int stbi_write_tga_to_func(stbi_write_func *func, void *context, int w, int h, int comp, const void *data); +STBIWDEF int stbi_write_hdr_to_func(stbi_write_func *func, void *context, int w, int h, int comp, const float *data); + +#ifdef __cplusplus +} +#endif + +#endif//INCLUDE_STB_IMAGE_WRITE_H + +#ifdef STB_IMAGE_WRITE_IMPLEMENTATION + +#ifdef _WIN32 + #ifndef _CRT_SECURE_NO_WARNINGS + #define _CRT_SECURE_NO_WARNINGS + #endif + #ifndef _CRT_NONSTDC_NO_DEPRECATE + #define _CRT_NONSTDC_NO_DEPRECATE + #endif +#endif + +#ifndef STBI_WRITE_NO_STDIO +#include +#endif // STBI_WRITE_NO_STDIO + +#include +#include +#include +#include + +#if defined(STBIW_MALLOC) && defined(STBIW_FREE) && (defined(STBIW_REALLOC) || defined(STBIW_REALLOC_SIZED)) +// ok +#elif !defined(STBIW_MALLOC) && !defined(STBIW_FREE) && !defined(STBIW_REALLOC) && !defined(STBIW_REALLOC_SIZED) +// ok +#else +#error "Must define all or none of STBIW_MALLOC, STBIW_FREE, and STBIW_REALLOC (or STBIW_REALLOC_SIZED)." +#endif + +#ifndef STBIW_MALLOC +#define STBIW_MALLOC(sz) malloc(sz) +#define STBIW_REALLOC(p,newsz) realloc(p,newsz) +#define STBIW_FREE(p) free(p) +#endif + +#ifndef STBIW_REALLOC_SIZED +#define STBIW_REALLOC_SIZED(p,oldsz,newsz) STBIW_REALLOC(p,newsz) +#endif + + +#ifndef STBIW_MEMMOVE +#define STBIW_MEMMOVE(a,b,sz) memmove(a,b,sz) +#endif + + +#ifndef STBIW_ASSERT +#include +#define STBIW_ASSERT(x) assert(x) +#endif + +#define STBIW_UCHAR(x) (unsigned char) ((x) & 0xff) + +typedef struct +{ + stbi_write_func *func; + void *context; +} stbi__write_context; + +// initialize a callback-based context +static void stbi__start_write_callbacks(stbi__write_context *s, stbi_write_func *c, void *context) +{ + s->func = c; + s->context = context; +} + +#ifndef STBI_WRITE_NO_STDIO + +static void stbi__stdio_write(void *context, void *data, int size) +{ + fwrite(data,1,size,(FILE*) context); +} + +static int stbi__start_write_file(stbi__write_context *s, const char *filename) +{ + FILE *f = fopen(filename, "wb"); + stbi__start_write_callbacks(s, stbi__stdio_write, (void *) f); + return f != NULL; +} + +static void stbi__end_write_file(stbi__write_context *s) +{ + fclose((FILE *)s->context); +} + +#endif // !STBI_WRITE_NO_STDIO + +typedef unsigned int stbiw_uint32; +typedef int stb_image_write_test[sizeof(stbiw_uint32)==4 ? 1 : -1]; + +#ifdef STB_IMAGE_WRITE_STATIC +static int stbi_write_tga_with_rle = 1; +#else +int stbi_write_tga_with_rle = 1; +#endif + +static void stbiw__writefv(stbi__write_context *s, const char *fmt, va_list v) +{ + while (*fmt) { + switch (*fmt++) { + case ' ': break; + case '1': { unsigned char x = STBIW_UCHAR(va_arg(v, int)); + s->func(s->context,&x,1); + break; } + case '2': { int x = va_arg(v,int); + unsigned char b[2]; + b[0] = STBIW_UCHAR(x); + b[1] = STBIW_UCHAR(x>>8); + s->func(s->context,b,2); + break; } + case '4': { stbiw_uint32 x = va_arg(v,int); + unsigned char b[4]; + b[0]=STBIW_UCHAR(x); + b[1]=STBIW_UCHAR(x>>8); + b[2]=STBIW_UCHAR(x>>16); + b[3]=STBIW_UCHAR(x>>24); + s->func(s->context,b,4); + break; } + default: + STBIW_ASSERT(0); + return; + } + } +} + +static void stbiw__writef(stbi__write_context *s, const char *fmt, ...) +{ + va_list v; + va_start(v, fmt); + stbiw__writefv(s, fmt, v); + va_end(v); +} + +static void stbiw__write3(stbi__write_context *s, unsigned char a, unsigned char b, unsigned char c) +{ + unsigned char arr[3]; + arr[0] = a, arr[1] = b, arr[2] = c; + s->func(s->context, arr, 3); +} + +static void stbiw__write_pixel(stbi__write_context *s, int rgb_dir, int comp, int write_alpha, int expand_mono, unsigned char *d) +{ + unsigned char bg[3] = { 255, 0, 255}, px[3]; + int k; + + if (write_alpha < 0) + s->func(s->context, &d[comp - 1], 1); + + switch (comp) { + case 1: + s->func(s->context,d,1); + break; + case 2: + if (expand_mono) + stbiw__write3(s, d[0], d[0], d[0]); // monochrome bmp + else + s->func(s->context, d, 1); // monochrome TGA + break; + case 4: + if (!write_alpha) { + // composite against pink background + for (k = 0; k < 3; ++k) + px[k] = bg[k] + ((d[k] - bg[k]) * d[3]) / 255; + stbiw__write3(s, px[1 - rgb_dir], px[1], px[1 + rgb_dir]); + break; + } + /* FALLTHROUGH */ + case 3: + stbiw__write3(s, d[1 - rgb_dir], d[1], d[1 + rgb_dir]); + break; + } + if (write_alpha > 0) + s->func(s->context, &d[comp - 1], 1); +} + +static void stbiw__write_pixels(stbi__write_context *s, int rgb_dir, int vdir, int x, int y, int comp, void *data, int write_alpha, int scanline_pad, int expand_mono) +{ + stbiw_uint32 zero = 0; + int i,j, j_end; + + if (y <= 0) + return; + + if (vdir < 0) + j_end = -1, j = y-1; + else + j_end = y, j = 0; + + for (; j != j_end; j += vdir) { + for (i=0; i < x; ++i) { + unsigned char *d = (unsigned char *) data + (j*x+i)*comp; + stbiw__write_pixel(s, rgb_dir, comp, write_alpha, expand_mono, d); + } + s->func(s->context, &zero, scanline_pad); + } +} + +static int stbiw__outfile(stbi__write_context *s, int rgb_dir, int vdir, int x, int y, int comp, int expand_mono, void *data, int alpha, int pad, const char *fmt, ...) +{ + if (y < 0 || x < 0) { + return 0; + } else { + va_list v; + va_start(v, fmt); + stbiw__writefv(s, fmt, v); + va_end(v); + stbiw__write_pixels(s,rgb_dir,vdir,x,y,comp,data,alpha,pad, expand_mono); + return 1; + } +} + +static int stbi_write_bmp_core(stbi__write_context *s, int x, int y, int comp, const void *data) +{ + int pad = (-x*3) & 3; + return stbiw__outfile(s,-1,-1,x,y,comp,1,(void *) data,0,pad, + "11 4 22 4" "4 44 22 444444", + 'B', 'M', 14+40+(x*3+pad)*y, 0,0, 14+40, // file header + 40, x,y, 1,24, 0,0,0,0,0,0); // bitmap header +} + +STBIWDEF int stbi_write_bmp_to_func(stbi_write_func *func, void *context, int x, int y, int comp, const void *data) +{ + stbi__write_context s; + stbi__start_write_callbacks(&s, func, context); + return stbi_write_bmp_core(&s, x, y, comp, data); +} + +#ifndef STBI_WRITE_NO_STDIO +STBIWDEF int stbi_write_bmp(char const *filename, int x, int y, int comp, const void *data) +{ + stbi__write_context s; + if (stbi__start_write_file(&s,filename)) { + int r = stbi_write_bmp_core(&s, x, y, comp, data); + stbi__end_write_file(&s); + return r; + } else + return 0; +} +#endif //!STBI_WRITE_NO_STDIO + +static int stbi_write_tga_core(stbi__write_context *s, int x, int y, int comp, void *data) +{ + int has_alpha = (comp == 2 || comp == 4); + int colorbytes = has_alpha ? comp-1 : comp; + int format = colorbytes < 2 ? 3 : 2; // 3 color channels (RGB/RGBA) = 2, 1 color channel (Y/YA) = 3 + + if (y < 0 || x < 0) + return 0; + + if (!stbi_write_tga_with_rle) { + return stbiw__outfile(s, -1, -1, x, y, comp, 0, (void *) data, has_alpha, 0, + "111 221 2222 11", 0, 0, format, 0, 0, 0, 0, 0, x, y, (colorbytes + has_alpha) * 8, has_alpha * 8); + } else { + int i,j,k; + + stbiw__writef(s, "111 221 2222 11", 0,0,format+8, 0,0,0, 0,0,x,y, (colorbytes + has_alpha) * 8, has_alpha * 8); + + for (j = y - 1; j >= 0; --j) { + unsigned char *row = (unsigned char *) data + j * x * comp; + int len; + + for (i = 0; i < x; i += len) { + unsigned char *begin = row + i * comp; + int diff = 1; + len = 1; + + if (i < x - 1) { + ++len; + diff = memcmp(begin, row + (i + 1) * comp, comp); + if (diff) { + const unsigned char *prev = begin; + for (k = i + 2; k < x && len < 128; ++k) { + if (memcmp(prev, row + k * comp, comp)) { + prev += comp; + ++len; + } else { + --len; + break; + } + } + } else { + for (k = i + 2; k < x && len < 128; ++k) { + if (!memcmp(begin, row + k * comp, comp)) { + ++len; + } else { + break; + } + } + } + } + + if (diff) { + unsigned char header = STBIW_UCHAR(len - 1); + s->func(s->context, &header, 1); + for (k = 0; k < len; ++k) { + stbiw__write_pixel(s, -1, comp, has_alpha, 0, begin + k * comp); + } + } else { + unsigned char header = STBIW_UCHAR(len - 129); + s->func(s->context, &header, 1); + stbiw__write_pixel(s, -1, comp, has_alpha, 0, begin); + } + } + } + } + return 1; +} + +int stbi_write_tga_to_func(stbi_write_func *func, void *context, int x, int y, int comp, const void *data) +{ + stbi__write_context s; + stbi__start_write_callbacks(&s, func, context); + return stbi_write_tga_core(&s, x, y, comp, (void *) data); +} + +#ifndef STBI_WRITE_NO_STDIO +int stbi_write_tga(char const *filename, int x, int y, int comp, const void *data) +{ + stbi__write_context s; + if (stbi__start_write_file(&s,filename)) { + int r = stbi_write_tga_core(&s, x, y, comp, (void *) data); + stbi__end_write_file(&s); + return r; + } else + return 0; +} +#endif + +// ************************************************************************************************* +// Radiance RGBE HDR writer +// by Baldur Karlsson +#ifndef STBI_WRITE_NO_STDIO + +#define stbiw__max(a, b) ((a) > (b) ? (a) : (b)) + +void stbiw__linear_to_rgbe(unsigned char *rgbe, float *linear) +{ + int exponent; + float maxcomp = stbiw__max(linear[0], stbiw__max(linear[1], linear[2])); + + if (maxcomp < 1e-32f) { + rgbe[0] = rgbe[1] = rgbe[2] = rgbe[3] = 0; + } else { + float normalize = (float) frexp(maxcomp, &exponent) * 256.0f/maxcomp; + + rgbe[0] = (unsigned char)(linear[0] * normalize); + rgbe[1] = (unsigned char)(linear[1] * normalize); + rgbe[2] = (unsigned char)(linear[2] * normalize); + rgbe[3] = (unsigned char)(exponent + 128); + } +} + +void stbiw__write_run_data(stbi__write_context *s, int length, unsigned char databyte) +{ + unsigned char lengthbyte = STBIW_UCHAR(length+128); + STBIW_ASSERT(length+128 <= 255); + s->func(s->context, &lengthbyte, 1); + s->func(s->context, &databyte, 1); +} + +void stbiw__write_dump_data(stbi__write_context *s, int length, unsigned char *data) +{ + unsigned char lengthbyte = STBIW_UCHAR(length); + STBIW_ASSERT(length <= 128); // inconsistent with spec but consistent with official code + s->func(s->context, &lengthbyte, 1); + s->func(s->context, data, length); +} + +void stbiw__write_hdr_scanline(stbi__write_context *s, int width, int ncomp, unsigned char *scratch, float *scanline) +{ + unsigned char scanlineheader[4] = { 2, 2, 0, 0 }; + unsigned char rgbe[4]; + float linear[3]; + int x; + + scanlineheader[2] = (width&0xff00)>>8; + scanlineheader[3] = (width&0x00ff); + + /* skip RLE for images too small or large */ + if (width < 8 || width >= 32768) { + for (x=0; x < width; x++) { + switch (ncomp) { + case 4: /* fallthrough */ + case 3: linear[2] = scanline[x*ncomp + 2]; + linear[1] = scanline[x*ncomp + 1]; + linear[0] = scanline[x*ncomp + 0]; + break; + default: + linear[0] = linear[1] = linear[2] = scanline[x*ncomp + 0]; + break; + } + stbiw__linear_to_rgbe(rgbe, linear); + s->func(s->context, rgbe, 4); + } + } else { + int c,r; + /* encode into scratch buffer */ + for (x=0; x < width; x++) { + switch(ncomp) { + case 4: /* fallthrough */ + case 3: linear[2] = scanline[x*ncomp + 2]; + linear[1] = scanline[x*ncomp + 1]; + linear[0] = scanline[x*ncomp + 0]; + break; + default: + linear[0] = linear[1] = linear[2] = scanline[x*ncomp + 0]; + break; + } + stbiw__linear_to_rgbe(rgbe, linear); + scratch[x + width*0] = rgbe[0]; + scratch[x + width*1] = rgbe[1]; + scratch[x + width*2] = rgbe[2]; + scratch[x + width*3] = rgbe[3]; + } + + s->func(s->context, scanlineheader, 4); + + /* RLE each component separately */ + for (c=0; c < 4; c++) { + unsigned char *comp = &scratch[width*c]; + + x = 0; + while (x < width) { + // find first run + r = x; + while (r+2 < width) { + if (comp[r] == comp[r+1] && comp[r] == comp[r+2]) + break; + ++r; + } + if (r+2 >= width) + r = width; + // dump up to first run + while (x < r) { + int len = r-x; + if (len > 128) len = 128; + stbiw__write_dump_data(s, len, &comp[x]); + x += len; + } + // if there's a run, output it + if (r+2 < width) { // same test as what we break out of in search loop, so only true if we break'd + // find next byte after run + while (r < width && comp[r] == comp[x]) + ++r; + // output run up to r + while (x < r) { + int len = r-x; + if (len > 127) len = 127; + stbiw__write_run_data(s, len, comp[x]); + x += len; + } + } + } + } + } +} + +static int stbi_write_hdr_core(stbi__write_context *s, int x, int y, int comp, float *data) +{ + if (y <= 0 || x <= 0 || data == NULL) + return 0; + else { + // Each component is stored separately. Allocate scratch space for full output scanline. + unsigned char *scratch = (unsigned char *) STBIW_MALLOC(x*4); + int i, len; + char buffer[128]; + char header[] = "#?RADIANCE\n# Written by stb_image_write.h\nFORMAT=32-bit_rle_rgbe\n"; + s->func(s->context, header, sizeof(header)-1); + + len = sprintf(buffer, "EXPOSURE= 1.0000000000000\n\n-Y %d +X %d\n", y, x); + s->func(s->context, buffer, len); + + for(i=0; i < y; i++) + stbiw__write_hdr_scanline(s, x, comp, scratch, data + comp*i*x); + STBIW_FREE(scratch); + return 1; + } +} + +int stbi_write_hdr_to_func(stbi_write_func *func, void *context, int x, int y, int comp, const float *data) +{ + stbi__write_context s; + stbi__start_write_callbacks(&s, func, context); + return stbi_write_hdr_core(&s, x, y, comp, (float *) data); +} + +int stbi_write_hdr(char const *filename, int x, int y, int comp, const float *data) +{ + stbi__write_context s; + if (stbi__start_write_file(&s,filename)) { + int r = stbi_write_hdr_core(&s, x, y, comp, (float *) data); + stbi__end_write_file(&s); + return r; + } else + return 0; +} +#endif // STBI_WRITE_NO_STDIO + + +////////////////////////////////////////////////////////////////////////////// +// +// PNG writer +// + +// stretchy buffer; stbiw__sbpush() == vector<>::push_back() -- stbiw__sbcount() == vector<>::size() +#define stbiw__sbraw(a) ((int *) (a) - 2) +#define stbiw__sbm(a) stbiw__sbraw(a)[0] +#define stbiw__sbn(a) stbiw__sbraw(a)[1] + +#define stbiw__sbneedgrow(a,n) ((a)==0 || stbiw__sbn(a)+n >= stbiw__sbm(a)) +#define stbiw__sbmaybegrow(a,n) (stbiw__sbneedgrow(a,(n)) ? stbiw__sbgrow(a,n) : 0) +#define stbiw__sbgrow(a,n) stbiw__sbgrowf((void **) &(a), (n), sizeof(*(a))) + +#define stbiw__sbpush(a, v) (stbiw__sbmaybegrow(a,1), (a)[stbiw__sbn(a)++] = (v)) +#define stbiw__sbcount(a) ((a) ? stbiw__sbn(a) : 0) +#define stbiw__sbfree(a) ((a) ? STBIW_FREE(stbiw__sbraw(a)),0 : 0) + +static void *stbiw__sbgrowf(void **arr, int increment, int itemsize) +{ + int m = *arr ? 2*stbiw__sbm(*arr)+increment : increment+1; + void *p = STBIW_REALLOC_SIZED(*arr ? stbiw__sbraw(*arr) : 0, *arr ? (stbiw__sbm(*arr)*itemsize + sizeof(int)*2) : 0, itemsize * m + sizeof(int)*2); + STBIW_ASSERT(p); + if (p) { + if (!*arr) ((int *) p)[1] = 0; + *arr = (void *) ((int *) p + 2); + stbiw__sbm(*arr) = m; + } + return *arr; +} + +static unsigned char *stbiw__zlib_flushf(unsigned char *data, unsigned int *bitbuffer, int *bitcount) +{ + while (*bitcount >= 8) { + stbiw__sbpush(data, STBIW_UCHAR(*bitbuffer)); + *bitbuffer >>= 8; + *bitcount -= 8; + } + return data; +} + +static int stbiw__zlib_bitrev(int code, int codebits) +{ + int res=0; + while (codebits--) { + res = (res << 1) | (code & 1); + code >>= 1; + } + return res; +} + +static unsigned int stbiw__zlib_countm(unsigned char *a, unsigned char *b, int limit) +{ + int i; + for (i=0; i < limit && i < 258; ++i) + if (a[i] != b[i]) break; + return i; +} + +static unsigned int stbiw__zhash(unsigned char *data) +{ + stbiw_uint32 hash = data[0] + (data[1] << 8) + (data[2] << 16); + hash ^= hash << 3; + hash += hash >> 5; + hash ^= hash << 4; + hash += hash >> 17; + hash ^= hash << 25; + hash += hash >> 6; + return hash; +} + +#define stbiw__zlib_flush() (out = stbiw__zlib_flushf(out, &bitbuf, &bitcount)) +#define stbiw__zlib_add(code,codebits) \ + (bitbuf |= (code) << bitcount, bitcount += (codebits), stbiw__zlib_flush()) +#define stbiw__zlib_huffa(b,c) stbiw__zlib_add(stbiw__zlib_bitrev(b,c),c) +// default huffman tables +#define stbiw__zlib_huff1(n) stbiw__zlib_huffa(0x30 + (n), 8) +#define stbiw__zlib_huff2(n) stbiw__zlib_huffa(0x190 + (n)-144, 9) +#define stbiw__zlib_huff3(n) stbiw__zlib_huffa(0 + (n)-256,7) +#define stbiw__zlib_huff4(n) stbiw__zlib_huffa(0xc0 + (n)-280,8) +#define stbiw__zlib_huff(n) ((n) <= 143 ? stbiw__zlib_huff1(n) : (n) <= 255 ? stbiw__zlib_huff2(n) : (n) <= 279 ? stbiw__zlib_huff3(n) : stbiw__zlib_huff4(n)) +#define stbiw__zlib_huffb(n) ((n) <= 143 ? stbiw__zlib_huff1(n) : stbiw__zlib_huff2(n)) + +#define stbiw__ZHASH 16384 + +unsigned char * stbi_zlib_compress(unsigned char *data, int data_len, int *out_len, int quality) +{ + static unsigned short lengthc[] = { 3,4,5,6,7,8,9,10,11,13,15,17,19,23,27,31,35,43,51,59,67,83,99,115,131,163,195,227,258, 259 }; + static unsigned char lengtheb[]= { 0,0,0,0,0,0,0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0 }; + static unsigned short distc[] = { 1,2,3,4,5,7,9,13,17,25,33,49,65,97,129,193,257,385,513,769,1025,1537,2049,3073,4097,6145,8193,12289,16385,24577, 32768 }; + static unsigned char disteb[] = { 0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13 }; + unsigned int bitbuf=0; + int i,j, bitcount=0; + unsigned char *out = NULL; + unsigned char ***hash_table = (unsigned char***) STBIW_MALLOC(stbiw__ZHASH * sizeof(char**)); + if (quality < 5) quality = 5; + + stbiw__sbpush(out, 0x78); // DEFLATE 32K window + stbiw__sbpush(out, 0x5e); // FLEVEL = 1 + stbiw__zlib_add(1,1); // BFINAL = 1 + stbiw__zlib_add(1,2); // BTYPE = 1 -- fixed huffman + + for (i=0; i < stbiw__ZHASH; ++i) + hash_table[i] = NULL; + + i=0; + while (i < data_len-3) { + // hash next 3 bytes of data to be compressed + int h = stbiw__zhash(data+i)&(stbiw__ZHASH-1), best=3; + unsigned char *bestloc = 0; + unsigned char **hlist = hash_table[h]; + int n = stbiw__sbcount(hlist); + for (j=0; j < n; ++j) { + if (hlist[j]-data > i-32768) { // if entry lies within window + int d = stbiw__zlib_countm(hlist[j], data+i, data_len-i); + if (d >= best) best=d,bestloc=hlist[j]; + } + } + // when hash table entry is too long, delete half the entries + if (hash_table[h] && stbiw__sbn(hash_table[h]) == 2*quality) { + STBIW_MEMMOVE(hash_table[h], hash_table[h]+quality, sizeof(hash_table[h][0])*quality); + stbiw__sbn(hash_table[h]) = quality; + } + stbiw__sbpush(hash_table[h],data+i); + + if (bestloc) { + // "lazy matching" - check match at *next* byte, and if it's better, do cur byte as literal + h = stbiw__zhash(data+i+1)&(stbiw__ZHASH-1); + hlist = hash_table[h]; + n = stbiw__sbcount(hlist); + for (j=0; j < n; ++j) { + if (hlist[j]-data > i-32767) { + int e = stbiw__zlib_countm(hlist[j], data+i+1, data_len-i-1); + if (e > best) { // if next match is better, bail on current match + bestloc = NULL; + break; + } + } + } + } + + if (bestloc) { + int d = (int) (data+i - bestloc); // distance back + STBIW_ASSERT(d <= 32767 && best <= 258); + for (j=0; best > lengthc[j+1]-1; ++j); + stbiw__zlib_huff(j+257); + if (lengtheb[j]) stbiw__zlib_add(best - lengthc[j], lengtheb[j]); + for (j=0; d > distc[j+1]-1; ++j); + stbiw__zlib_add(stbiw__zlib_bitrev(j,5),5); + if (disteb[j]) stbiw__zlib_add(d - distc[j], disteb[j]); + i += best; + } else { + stbiw__zlib_huffb(data[i]); + ++i; + } + } + // write out final bytes + for (;i < data_len; ++i) + stbiw__zlib_huffb(data[i]); + stbiw__zlib_huff(256); // end of block + // pad with 0 bits to byte boundary + while (bitcount) + stbiw__zlib_add(0,1); + + for (i=0; i < stbiw__ZHASH; ++i) + (void) stbiw__sbfree(hash_table[i]); + STBIW_FREE(hash_table); + + { + // compute adler32 on input + unsigned int s1=1, s2=0; + int blocklen = (int) (data_len % 5552); + j=0; + while (j < data_len) { + for (i=0; i < blocklen; ++i) s1 += data[j+i], s2 += s1; + s1 %= 65521, s2 %= 65521; + j += blocklen; + blocklen = 5552; + } + stbiw__sbpush(out, STBIW_UCHAR(s2 >> 8)); + stbiw__sbpush(out, STBIW_UCHAR(s2)); + stbiw__sbpush(out, STBIW_UCHAR(s1 >> 8)); + stbiw__sbpush(out, STBIW_UCHAR(s1)); + } + *out_len = stbiw__sbn(out); + // make returned pointer freeable + STBIW_MEMMOVE(stbiw__sbraw(out), out, *out_len); + return (unsigned char *) stbiw__sbraw(out); +} + +static unsigned int stbiw__crc32(unsigned char *buffer, int len) +{ + static unsigned int crc_table[256] = + { + 0x00000000, 0x77073096, 0xEE0E612C, 0x990951BA, 0x076DC419, 0x706AF48F, 0xE963A535, 0x9E6495A3, + 0x0eDB8832, 0x79DCB8A4, 0xE0D5E91E, 0x97D2D988, 0x09B64C2B, 0x7EB17CBD, 0xE7B82D07, 0x90BF1D91, + 0x1DB71064, 0x6AB020F2, 0xF3B97148, 0x84BE41DE, 0x1ADAD47D, 0x6DDDE4EB, 0xF4D4B551, 0x83D385C7, + 0x136C9856, 0x646BA8C0, 0xFD62F97A, 0x8A65C9EC, 0x14015C4F, 0x63066CD9, 0xFA0F3D63, 0x8D080DF5, + 0x3B6E20C8, 0x4C69105E, 0xD56041E4, 0xA2677172, 0x3C03E4D1, 0x4B04D447, 0xD20D85FD, 0xA50AB56B, + 0x35B5A8FA, 0x42B2986C, 0xDBBBC9D6, 0xACBCF940, 0x32D86CE3, 0x45DF5C75, 0xDCD60DCF, 0xABD13D59, + 0x26D930AC, 0x51DE003A, 0xC8D75180, 0xBFD06116, 0x21B4F4B5, 0x56B3C423, 0xCFBA9599, 0xB8BDA50F, + 0x2802B89E, 0x5F058808, 0xC60CD9B2, 0xB10BE924, 0x2F6F7C87, 0x58684C11, 0xC1611DAB, 0xB6662D3D, + 0x76DC4190, 0x01DB7106, 0x98D220BC, 0xEFD5102A, 0x71B18589, 0x06B6B51F, 0x9FBFE4A5, 0xE8B8D433, + 0x7807C9A2, 0x0F00F934, 0x9609A88E, 0xE10E9818, 0x7F6A0DBB, 0x086D3D2D, 0x91646C97, 0xE6635C01, + 0x6B6B51F4, 0x1C6C6162, 0x856530D8, 0xF262004E, 0x6C0695ED, 0x1B01A57B, 0x8208F4C1, 0xF50FC457, + 0x65B0D9C6, 0x12B7E950, 0x8BBEB8EA, 0xFCB9887C, 0x62DD1DDF, 0x15DA2D49, 0x8CD37CF3, 0xFBD44C65, + 0x4DB26158, 0x3AB551CE, 0xA3BC0074, 0xD4BB30E2, 0x4ADFA541, 0x3DD895D7, 0xA4D1C46D, 0xD3D6F4FB, + 0x4369E96A, 0x346ED9FC, 0xAD678846, 0xDA60B8D0, 0x44042D73, 0x33031DE5, 0xAA0A4C5F, 0xDD0D7CC9, + 0x5005713C, 0x270241AA, 0xBE0B1010, 0xC90C2086, 0x5768B525, 0x206F85B3, 0xB966D409, 0xCE61E49F, + 0x5EDEF90E, 0x29D9C998, 0xB0D09822, 0xC7D7A8B4, 0x59B33D17, 0x2EB40D81, 0xB7BD5C3B, 0xC0BA6CAD, + 0xEDB88320, 0x9ABFB3B6, 0x03B6E20C, 0x74B1D29A, 0xEAD54739, 0x9DD277AF, 0x04DB2615, 0x73DC1683, + 0xE3630B12, 0x94643B84, 0x0D6D6A3E, 0x7A6A5AA8, 0xE40ECF0B, 0x9309FF9D, 0x0A00AE27, 0x7D079EB1, + 0xF00F9344, 0x8708A3D2, 0x1E01F268, 0x6906C2FE, 0xF762575D, 0x806567CB, 0x196C3671, 0x6E6B06E7, + 0xFED41B76, 0x89D32BE0, 0x10DA7A5A, 0x67DD4ACC, 0xF9B9DF6F, 0x8EBEEFF9, 0x17B7BE43, 0x60B08ED5, + 0xD6D6A3E8, 0xA1D1937E, 0x38D8C2C4, 0x4FDFF252, 0xD1BB67F1, 0xA6BC5767, 0x3FB506DD, 0x48B2364B, + 0xD80D2BDA, 0xAF0A1B4C, 0x36034AF6, 0x41047A60, 0xDF60EFC3, 0xA867DF55, 0x316E8EEF, 0x4669BE79, + 0xCB61B38C, 0xBC66831A, 0x256FD2A0, 0x5268E236, 0xCC0C7795, 0xBB0B4703, 0x220216B9, 0x5505262F, + 0xC5BA3BBE, 0xB2BD0B28, 0x2BB45A92, 0x5CB36A04, 0xC2D7FFA7, 0xB5D0CF31, 0x2CD99E8B, 0x5BDEAE1D, + 0x9B64C2B0, 0xEC63F226, 0x756AA39C, 0x026D930A, 0x9C0906A9, 0xEB0E363F, 0x72076785, 0x05005713, + 0x95BF4A82, 0xE2B87A14, 0x7BB12BAE, 0x0CB61B38, 0x92D28E9B, 0xE5D5BE0D, 0x7CDCEFB7, 0x0BDBDF21, + 0x86D3D2D4, 0xF1D4E242, 0x68DDB3F8, 0x1FDA836E, 0x81BE16CD, 0xF6B9265B, 0x6FB077E1, 0x18B74777, + 0x88085AE6, 0xFF0F6A70, 0x66063BCA, 0x11010B5C, 0x8F659EFF, 0xF862AE69, 0x616BFFD3, 0x166CCF45, + 0xA00AE278, 0xD70DD2EE, 0x4E048354, 0x3903B3C2, 0xA7672661, 0xD06016F7, 0x4969474D, 0x3E6E77DB, + 0xAED16A4A, 0xD9D65ADC, 0x40DF0B66, 0x37D83BF0, 0xA9BCAE53, 0xDEBB9EC5, 0x47B2CF7F, 0x30B5FFE9, + 0xBDBDF21C, 0xCABAC28A, 0x53B39330, 0x24B4A3A6, 0xBAD03605, 0xCDD70693, 0x54DE5729, 0x23D967BF, + 0xB3667A2E, 0xC4614AB8, 0x5D681B02, 0x2A6F2B94, 0xB40BBE37, 0xC30C8EA1, 0x5A05DF1B, 0x2D02EF8D + }; + + unsigned int crc = ~0u; + int i; + for (i=0; i < len; ++i) + crc = (crc >> 8) ^ crc_table[buffer[i] ^ (crc & 0xff)]; + return ~crc; +} + +#define stbiw__wpng4(o,a,b,c,d) ((o)[0]=STBIW_UCHAR(a),(o)[1]=STBIW_UCHAR(b),(o)[2]=STBIW_UCHAR(c),(o)[3]=STBIW_UCHAR(d),(o)+=4) +#define stbiw__wp32(data,v) stbiw__wpng4(data, (v)>>24,(v)>>16,(v)>>8,(v)); +#define stbiw__wptag(data,s) stbiw__wpng4(data, s[0],s[1],s[2],s[3]) + +static void stbiw__wpcrc(unsigned char **data, int len) +{ + unsigned int crc = stbiw__crc32(*data - len - 4, len+4); + stbiw__wp32(*data, crc); +} + +static unsigned char stbiw__paeth(int a, int b, int c) +{ + int p = a + b - c, pa = abs(p-a), pb = abs(p-b), pc = abs(p-c); + if (pa <= pb && pa <= pc) return STBIW_UCHAR(a); + if (pb <= pc) return STBIW_UCHAR(b); + return STBIW_UCHAR(c); +} + +unsigned char *stbi_write_png_to_mem(unsigned char *pixels, int stride_bytes, int x, int y, int n, int *out_len) +{ + int ctype[5] = { -1, 0, 4, 2, 6 }; + unsigned char sig[8] = { 137,80,78,71,13,10,26,10 }; + unsigned char *out,*o, *filt, *zlib; + signed char *line_buffer; + int i,j,k,p,zlen; + + if (stride_bytes == 0) + stride_bytes = x * n; + + filt = (unsigned char *) STBIW_MALLOC((x*n+1) * y); if (!filt) return 0; + line_buffer = (signed char *) STBIW_MALLOC(x * n); if (!line_buffer) { STBIW_FREE(filt); return 0; } + for (j=0; j < y; ++j) { + static int mapping[] = { 0,1,2,3,4 }; + static int firstmap[] = { 0,1,0,5,6 }; + int *mymap = j ? mapping : firstmap; + int best = 0, bestval = 0x7fffffff; + for (p=0; p < 2; ++p) { + for (k= p?best:0; k < 5; ++k) { + int type = mymap[k],est=0; + unsigned char *z = pixels + stride_bytes*j; + for (i=0; i < n; ++i) + switch (type) { + case 0: line_buffer[i] = z[i]; break; + case 1: line_buffer[i] = z[i]; break; + case 2: line_buffer[i] = z[i] - z[i-stride_bytes]; break; + case 3: line_buffer[i] = z[i] - (z[i-stride_bytes]>>1); break; + case 4: line_buffer[i] = (signed char) (z[i] - stbiw__paeth(0,z[i-stride_bytes],0)); break; + case 5: line_buffer[i] = z[i]; break; + case 6: line_buffer[i] = z[i]; break; + } + for (i=n; i < x*n; ++i) { + switch (type) { + case 0: line_buffer[i] = z[i]; break; + case 1: line_buffer[i] = z[i] - z[i-n]; break; + case 2: line_buffer[i] = z[i] - z[i-stride_bytes]; break; + case 3: line_buffer[i] = z[i] - ((z[i-n] + z[i-stride_bytes])>>1); break; + case 4: line_buffer[i] = z[i] - stbiw__paeth(z[i-n], z[i-stride_bytes], z[i-stride_bytes-n]); break; + case 5: line_buffer[i] = z[i] - (z[i-n]>>1); break; + case 6: line_buffer[i] = z[i] - stbiw__paeth(z[i-n], 0,0); break; + } + } + if (p) break; + for (i=0; i < x*n; ++i) + est += abs((signed char) line_buffer[i]); + if (est < bestval) { bestval = est; best = k; } + } + } + // when we get here, best contains the filter type, and line_buffer contains the data + filt[j*(x*n+1)] = (unsigned char) best; + STBIW_MEMMOVE(filt+j*(x*n+1)+1, line_buffer, x*n); + } + STBIW_FREE(line_buffer); + zlib = stbi_zlib_compress(filt, y*( x*n+1), &zlen, 8); // increase 8 to get smaller but use more memory + STBIW_FREE(filt); + if (!zlib) return 0; + + // each tag requires 12 bytes of overhead + out = (unsigned char *) STBIW_MALLOC(8 + 12+13 + 12+zlen + 12); + if (!out) return 0; + *out_len = 8 + 12+13 + 12+zlen + 12; + + o=out; + STBIW_MEMMOVE(o,sig,8); o+= 8; + stbiw__wp32(o, 13); // header length + stbiw__wptag(o, "IHDR"); + stbiw__wp32(o, x); + stbiw__wp32(o, y); + *o++ = 8; + *o++ = STBIW_UCHAR(ctype[n]); + *o++ = 0; + *o++ = 0; + *o++ = 0; + stbiw__wpcrc(&o,13); + + stbiw__wp32(o, zlen); + stbiw__wptag(o, "IDAT"); + STBIW_MEMMOVE(o, zlib, zlen); + o += zlen; + STBIW_FREE(zlib); + stbiw__wpcrc(&o, zlen); + + stbiw__wp32(o,0); + stbiw__wptag(o, "IEND"); + stbiw__wpcrc(&o,0); + + STBIW_ASSERT(o == out + *out_len); + + return out; +} + +#ifndef STBI_WRITE_NO_STDIO +STBIWDEF int stbi_write_png(char const *filename, int x, int y, int comp, const void *data, int stride_bytes) +{ + FILE *f; + int len; + unsigned char *png = stbi_write_png_to_mem((unsigned char *) data, stride_bytes, x, y, comp, &len); + if (png == NULL) return 0; + f = fopen(filename, "wb"); + if (!f) { STBIW_FREE(png); return 0; } + fwrite(png, 1, len, f); + fclose(f); + STBIW_FREE(png); + return 1; +} +#endif + +STBIWDEF int stbi_write_png_to_func(stbi_write_func *func, void *context, int x, int y, int comp, const void *data, int stride_bytes) +{ + int len; + unsigned char *png = stbi_write_png_to_mem((unsigned char *) data, stride_bytes, x, y, comp, &len); + if (png == NULL) return 0; + func(context, png, len); + STBIW_FREE(png); + return 1; +} + +#endif // STB_IMAGE_WRITE_IMPLEMENTATION + +/* Revision history + 1.02 (2016-04-02) + avoid allocating large structures on the stack + 1.01 (2016-01-16) + STBIW_REALLOC_SIZED: support allocators with no realloc support + avoid race-condition in crc initialization + minor compile issues + 1.00 (2015-09-14) + installable file IO function + 0.99 (2015-09-13) + warning fixes; TGA rle support + 0.98 (2015-04-08) + added STBIW_MALLOC, STBIW_ASSERT etc + 0.97 (2015-01-18) + fixed HDR asserts, rewrote HDR rle logic + 0.96 (2015-01-17) + add HDR output + fix monochrome BMP + 0.95 (2014-08-17) + add monochrome TGA output + 0.94 (2014-05-31) + rename private functions to avoid conflicts with stb_image.h + 0.93 (2014-05-27) + warning fixes + 0.92 (2010-08-01) + casts to unsigned char to fix warnings + 0.91 (2010-07-17) + first public release + 0.90 first internal release +*/ diff --git a/src/external/glfw/deps/tinycthread.c b/src/external/glfw/deps/tinycthread.c new file mode 100644 index 000000000..f9cea2ed8 --- /dev/null +++ b/src/external/glfw/deps/tinycthread.c @@ -0,0 +1,594 @@ +/* -*- mode: c; tab-width: 2; indent-tabs-mode: nil; -*- +Copyright (c) 2012 Marcus Geelnard + +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. +*/ + +/* 2013-01-06 Camilla Löwy + * + * Added casts from time_t to DWORD to avoid warnings on VC++. + * Fixed time retrieval on POSIX systems. + */ + +#include "tinycthread.h" +#include + +/* Platform specific includes */ +#if defined(_TTHREAD_POSIX_) + #include + #include + #include + #include + #include +#elif defined(_TTHREAD_WIN32_) + #include + #include +#endif + +/* Standard, good-to-have defines */ +#ifndef NULL + #define NULL (void*)0 +#endif +#ifndef TRUE + #define TRUE 1 +#endif +#ifndef FALSE + #define FALSE 0 +#endif + +int mtx_init(mtx_t *mtx, int type) +{ +#if defined(_TTHREAD_WIN32_) + mtx->mAlreadyLocked = FALSE; + mtx->mRecursive = type & mtx_recursive; + InitializeCriticalSection(&mtx->mHandle); + return thrd_success; +#else + int ret; + pthread_mutexattr_t attr; + pthread_mutexattr_init(&attr); + if (type & mtx_recursive) + { + pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_RECURSIVE); + } + ret = pthread_mutex_init(mtx, &attr); + pthread_mutexattr_destroy(&attr); + return ret == 0 ? thrd_success : thrd_error; +#endif +} + +void mtx_destroy(mtx_t *mtx) +{ +#if defined(_TTHREAD_WIN32_) + DeleteCriticalSection(&mtx->mHandle); +#else + pthread_mutex_destroy(mtx); +#endif +} + +int mtx_lock(mtx_t *mtx) +{ +#if defined(_TTHREAD_WIN32_) + EnterCriticalSection(&mtx->mHandle); + if (!mtx->mRecursive) + { + while(mtx->mAlreadyLocked) Sleep(1000); /* Simulate deadlock... */ + mtx->mAlreadyLocked = TRUE; + } + return thrd_success; +#else + return pthread_mutex_lock(mtx) == 0 ? thrd_success : thrd_error; +#endif +} + +int mtx_timedlock(mtx_t *mtx, const struct timespec *ts) +{ + /* FIXME! */ + (void)mtx; + (void)ts; + return thrd_error; +} + +int mtx_trylock(mtx_t *mtx) +{ +#if defined(_TTHREAD_WIN32_) + int ret = TryEnterCriticalSection(&mtx->mHandle) ? thrd_success : thrd_busy; + if ((!mtx->mRecursive) && (ret == thrd_success) && mtx->mAlreadyLocked) + { + LeaveCriticalSection(&mtx->mHandle); + ret = thrd_busy; + } + return ret; +#else + return (pthread_mutex_trylock(mtx) == 0) ? thrd_success : thrd_busy; +#endif +} + +int mtx_unlock(mtx_t *mtx) +{ +#if defined(_TTHREAD_WIN32_) + mtx->mAlreadyLocked = FALSE; + LeaveCriticalSection(&mtx->mHandle); + return thrd_success; +#else + return pthread_mutex_unlock(mtx) == 0 ? thrd_success : thrd_error;; +#endif +} + +#if defined(_TTHREAD_WIN32_) +#define _CONDITION_EVENT_ONE 0 +#define _CONDITION_EVENT_ALL 1 +#endif + +int cnd_init(cnd_t *cond) +{ +#if defined(_TTHREAD_WIN32_) + cond->mWaitersCount = 0; + + /* Init critical section */ + InitializeCriticalSection(&cond->mWaitersCountLock); + + /* Init events */ + cond->mEvents[_CONDITION_EVENT_ONE] = CreateEvent(NULL, FALSE, FALSE, NULL); + if (cond->mEvents[_CONDITION_EVENT_ONE] == NULL) + { + cond->mEvents[_CONDITION_EVENT_ALL] = NULL; + return thrd_error; + } + cond->mEvents[_CONDITION_EVENT_ALL] = CreateEvent(NULL, TRUE, FALSE, NULL); + if (cond->mEvents[_CONDITION_EVENT_ALL] == NULL) + { + CloseHandle(cond->mEvents[_CONDITION_EVENT_ONE]); + cond->mEvents[_CONDITION_EVENT_ONE] = NULL; + return thrd_error; + } + + return thrd_success; +#else + return pthread_cond_init(cond, NULL) == 0 ? thrd_success : thrd_error; +#endif +} + +void cnd_destroy(cnd_t *cond) +{ +#if defined(_TTHREAD_WIN32_) + if (cond->mEvents[_CONDITION_EVENT_ONE] != NULL) + { + CloseHandle(cond->mEvents[_CONDITION_EVENT_ONE]); + } + if (cond->mEvents[_CONDITION_EVENT_ALL] != NULL) + { + CloseHandle(cond->mEvents[_CONDITION_EVENT_ALL]); + } + DeleteCriticalSection(&cond->mWaitersCountLock); +#else + pthread_cond_destroy(cond); +#endif +} + +int cnd_signal(cnd_t *cond) +{ +#if defined(_TTHREAD_WIN32_) + int haveWaiters; + + /* Are there any waiters? */ + EnterCriticalSection(&cond->mWaitersCountLock); + haveWaiters = (cond->mWaitersCount > 0); + LeaveCriticalSection(&cond->mWaitersCountLock); + + /* If we have any waiting threads, send them a signal */ + if(haveWaiters) + { + if (SetEvent(cond->mEvents[_CONDITION_EVENT_ONE]) == 0) + { + return thrd_error; + } + } + + return thrd_success; +#else + return pthread_cond_signal(cond) == 0 ? thrd_success : thrd_error; +#endif +} + +int cnd_broadcast(cnd_t *cond) +{ +#if defined(_TTHREAD_WIN32_) + int haveWaiters; + + /* Are there any waiters? */ + EnterCriticalSection(&cond->mWaitersCountLock); + haveWaiters = (cond->mWaitersCount > 0); + LeaveCriticalSection(&cond->mWaitersCountLock); + + /* If we have any waiting threads, send them a signal */ + if(haveWaiters) + { + if (SetEvent(cond->mEvents[_CONDITION_EVENT_ALL]) == 0) + { + return thrd_error; + } + } + + return thrd_success; +#else + return pthread_cond_signal(cond) == 0 ? thrd_success : thrd_error; +#endif +} + +#if defined(_TTHREAD_WIN32_) +static int _cnd_timedwait_win32(cnd_t *cond, mtx_t *mtx, DWORD timeout) +{ + int result, lastWaiter; + + /* Increment number of waiters */ + EnterCriticalSection(&cond->mWaitersCountLock); + ++ cond->mWaitersCount; + LeaveCriticalSection(&cond->mWaitersCountLock); + + /* Release the mutex while waiting for the condition (will decrease + the number of waiters when done)... */ + mtx_unlock(mtx); + + /* Wait for either event to become signaled due to cnd_signal() or + cnd_broadcast() being called */ + result = WaitForMultipleObjects(2, cond->mEvents, FALSE, timeout); + if (result == WAIT_TIMEOUT) + { + return thrd_timeout; + } + else if (result == (int)WAIT_FAILED) + { + return thrd_error; + } + + /* Check if we are the last waiter */ + EnterCriticalSection(&cond->mWaitersCountLock); + -- cond->mWaitersCount; + lastWaiter = (result == (WAIT_OBJECT_0 + _CONDITION_EVENT_ALL)) && + (cond->mWaitersCount == 0); + LeaveCriticalSection(&cond->mWaitersCountLock); + + /* If we are the last waiter to be notified to stop waiting, reset the event */ + if (lastWaiter) + { + if (ResetEvent(cond->mEvents[_CONDITION_EVENT_ALL]) == 0) + { + return thrd_error; + } + } + + /* Re-acquire the mutex */ + mtx_lock(mtx); + + return thrd_success; +} +#endif + +int cnd_wait(cnd_t *cond, mtx_t *mtx) +{ +#if defined(_TTHREAD_WIN32_) + return _cnd_timedwait_win32(cond, mtx, INFINITE); +#else + return pthread_cond_wait(cond, mtx) == 0 ? thrd_success : thrd_error; +#endif +} + +int cnd_timedwait(cnd_t *cond, mtx_t *mtx, const struct timespec *ts) +{ +#if defined(_TTHREAD_WIN32_) + struct timespec now; + if (clock_gettime(CLOCK_REALTIME, &now) == 0) + { + DWORD delta = (DWORD) ((ts->tv_sec - now.tv_sec) * 1000 + + (ts->tv_nsec - now.tv_nsec + 500000) / 1000000); + return _cnd_timedwait_win32(cond, mtx, delta); + } + else + return thrd_error; +#else + int ret; + ret = pthread_cond_timedwait(cond, mtx, ts); + if (ret == ETIMEDOUT) + { + return thrd_timeout; + } + return ret == 0 ? thrd_success : thrd_error; +#endif +} + + +/** Information to pass to the new thread (what to run). */ +typedef struct { + thrd_start_t mFunction; /**< Pointer to the function to be executed. */ + void * mArg; /**< Function argument for the thread function. */ +} _thread_start_info; + +/* Thread wrapper function. */ +#if defined(_TTHREAD_WIN32_) +static unsigned WINAPI _thrd_wrapper_function(void * aArg) +#elif defined(_TTHREAD_POSIX_) +static void * _thrd_wrapper_function(void * aArg) +#endif +{ + thrd_start_t fun; + void *arg; + int res; +#if defined(_TTHREAD_POSIX_) + void *pres; +#endif + + /* Get thread startup information */ + _thread_start_info *ti = (_thread_start_info *) aArg; + fun = ti->mFunction; + arg = ti->mArg; + + /* The thread is responsible for freeing the startup information */ + free((void *)ti); + + /* Call the actual client thread function */ + res = fun(arg); + +#if defined(_TTHREAD_WIN32_) + return res; +#else + pres = malloc(sizeof(int)); + if (pres != NULL) + { + *(int*)pres = res; + } + return pres; +#endif +} + +int thrd_create(thrd_t *thr, thrd_start_t func, void *arg) +{ + /* Fill out the thread startup information (passed to the thread wrapper, + which will eventually free it) */ + _thread_start_info* ti = (_thread_start_info*)malloc(sizeof(_thread_start_info)); + if (ti == NULL) + { + return thrd_nomem; + } + ti->mFunction = func; + ti->mArg = arg; + + /* Create the thread */ +#if defined(_TTHREAD_WIN32_) + *thr = (HANDLE)_beginthreadex(NULL, 0, _thrd_wrapper_function, (void *)ti, 0, NULL); +#elif defined(_TTHREAD_POSIX_) + if(pthread_create(thr, NULL, _thrd_wrapper_function, (void *)ti) != 0) + { + *thr = 0; + } +#endif + + /* Did we fail to create the thread? */ + if(!*thr) + { + free(ti); + return thrd_error; + } + + return thrd_success; +} + +thrd_t thrd_current(void) +{ +#if defined(_TTHREAD_WIN32_) + return GetCurrentThread(); +#else + return pthread_self(); +#endif +} + +int thrd_detach(thrd_t thr) +{ + /* FIXME! */ + (void)thr; + return thrd_error; +} + +int thrd_equal(thrd_t thr0, thrd_t thr1) +{ +#if defined(_TTHREAD_WIN32_) + return thr0 == thr1; +#else + return pthread_equal(thr0, thr1); +#endif +} + +void thrd_exit(int res) +{ +#if defined(_TTHREAD_WIN32_) + ExitThread(res); +#else + void *pres = malloc(sizeof(int)); + if (pres != NULL) + { + *(int*)pres = res; + } + pthread_exit(pres); +#endif +} + +int thrd_join(thrd_t thr, int *res) +{ +#if defined(_TTHREAD_WIN32_) + if (WaitForSingleObject(thr, INFINITE) == WAIT_FAILED) + { + return thrd_error; + } + if (res != NULL) + { + DWORD dwRes; + GetExitCodeThread(thr, &dwRes); + *res = dwRes; + } +#elif defined(_TTHREAD_POSIX_) + void *pres; + int ires = 0; + if (pthread_join(thr, &pres) != 0) + { + return thrd_error; + } + if (pres != NULL) + { + ires = *(int*)pres; + free(pres); + } + if (res != NULL) + { + *res = ires; + } +#endif + return thrd_success; +} + +int thrd_sleep(const struct timespec *time_point, struct timespec *remaining) +{ + struct timespec now; +#if defined(_TTHREAD_WIN32_) + DWORD delta; +#else + long delta; +#endif + + /* Get the current time */ + if (clock_gettime(CLOCK_REALTIME, &now) != 0) + return -2; // FIXME: Some specific error code? + +#if defined(_TTHREAD_WIN32_) + /* Delta in milliseconds */ + delta = (DWORD) ((time_point->tv_sec - now.tv_sec) * 1000 + + (time_point->tv_nsec - now.tv_nsec + 500000) / 1000000); + if (delta > 0) + { + Sleep(delta); + } +#else + /* Delta in microseconds */ + delta = (time_point->tv_sec - now.tv_sec) * 1000000L + + (time_point->tv_nsec - now.tv_nsec + 500L) / 1000L; + + /* On some systems, the usleep argument must be < 1000000 */ + while (delta > 999999L) + { + usleep(999999); + delta -= 999999L; + } + if (delta > 0L) + { + usleep((useconds_t)delta); + } +#endif + + /* We don't support waking up prematurely (yet) */ + if (remaining) + { + remaining->tv_sec = 0; + remaining->tv_nsec = 0; + } + return 0; +} + +void thrd_yield(void) +{ +#if defined(_TTHREAD_WIN32_) + Sleep(0); +#else + sched_yield(); +#endif +} + +int tss_create(tss_t *key, tss_dtor_t dtor) +{ +#if defined(_TTHREAD_WIN32_) + /* FIXME: The destructor function is not supported yet... */ + if (dtor != NULL) + { + return thrd_error; + } + *key = TlsAlloc(); + if (*key == TLS_OUT_OF_INDEXES) + { + return thrd_error; + } +#else + if (pthread_key_create(key, dtor) != 0) + { + return thrd_error; + } +#endif + return thrd_success; +} + +void tss_delete(tss_t key) +{ +#if defined(_TTHREAD_WIN32_) + TlsFree(key); +#else + pthread_key_delete(key); +#endif +} + +void *tss_get(tss_t key) +{ +#if defined(_TTHREAD_WIN32_) + return TlsGetValue(key); +#else + return pthread_getspecific(key); +#endif +} + +int tss_set(tss_t key, void *val) +{ +#if defined(_TTHREAD_WIN32_) + if (TlsSetValue(key, val) == 0) + { + return thrd_error; + } +#else + if (pthread_setspecific(key, val) != 0) + { + return thrd_error; + } +#endif + return thrd_success; +} + +#if defined(_TTHREAD_EMULATE_CLOCK_GETTIME_) +int _tthread_clock_gettime(clockid_t clk_id, struct timespec *ts) +{ +#if defined(_TTHREAD_WIN32_) + struct _timeb tb; + _ftime(&tb); + ts->tv_sec = (time_t)tb.time; + ts->tv_nsec = 1000000L * (long)tb.millitm; +#else + struct timeval tv; + gettimeofday(&tv, NULL); + ts->tv_sec = (time_t)tv.tv_sec; + ts->tv_nsec = 1000L * (long)tv.tv_usec; +#endif + return 0; +} +#endif // _TTHREAD_EMULATE_CLOCK_GETTIME_ + diff --git a/src/external/glfw/deps/tinycthread.h b/src/external/glfw/deps/tinycthread.h new file mode 100644 index 000000000..42958c393 --- /dev/null +++ b/src/external/glfw/deps/tinycthread.h @@ -0,0 +1,443 @@ +/* -*- mode: c; tab-width: 2; indent-tabs-mode: nil; -*- +Copyright (c) 2012 Marcus Geelnard + +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 _TINYCTHREAD_H_ +#define _TINYCTHREAD_H_ + +/** +* @file +* @mainpage TinyCThread API Reference +* +* @section intro_sec Introduction +* TinyCThread is a minimal, portable implementation of basic threading +* classes for C. +* +* They closely mimic the functionality and naming of the C11 standard, and +* should be easily replaceable with the corresponding standard variants. +* +* @section port_sec Portability +* The Win32 variant uses the native Win32 API for implementing the thread +* classes, while for other systems, the POSIX threads API (pthread) is used. +* +* @section misc_sec Miscellaneous +* The following special keywords are available: #_Thread_local. +* +* For more detailed information, browse the different sections of this +* documentation. A good place to start is: +* tinycthread.h. +*/ + +/* Which platform are we on? */ +#if !defined(_TTHREAD_PLATFORM_DEFINED_) + #if defined(_WIN32) || defined(__WIN32__) || defined(__WINDOWS__) + #define _TTHREAD_WIN32_ + #else + #define _TTHREAD_POSIX_ + #endif + #define _TTHREAD_PLATFORM_DEFINED_ +#endif + +/* Activate some POSIX functionality (e.g. clock_gettime and recursive mutexes) */ +#if defined(_TTHREAD_POSIX_) + #undef _FEATURES_H + #if !defined(_GNU_SOURCE) + #define _GNU_SOURCE + #endif + #if !defined(_POSIX_C_SOURCE) || ((_POSIX_C_SOURCE - 0) < 199309L) + #undef _POSIX_C_SOURCE + #define _POSIX_C_SOURCE 199309L + #endif + #if !defined(_XOPEN_SOURCE) || ((_XOPEN_SOURCE - 0) < 500) + #undef _XOPEN_SOURCE + #define _XOPEN_SOURCE 500 + #endif +#endif + +/* Generic includes */ +#include + +/* Platform specific includes */ +#if defined(_TTHREAD_POSIX_) + #include + #include +#elif defined(_TTHREAD_WIN32_) + #ifndef WIN32_LEAN_AND_MEAN + #define WIN32_LEAN_AND_MEAN + #define __UNDEF_LEAN_AND_MEAN + #endif + #include + #ifdef __UNDEF_LEAN_AND_MEAN + #undef WIN32_LEAN_AND_MEAN + #undef __UNDEF_LEAN_AND_MEAN + #endif +#endif + +/* Workaround for missing TIME_UTC: If time.h doesn't provide TIME_UTC, + it's quite likely that libc does not support it either. Hence, fall back to + the only other supported time specifier: CLOCK_REALTIME (and if that fails, + we're probably emulating clock_gettime anyway, so anything goes). */ +#ifndef TIME_UTC + #ifdef CLOCK_REALTIME + #define TIME_UTC CLOCK_REALTIME + #else + #define TIME_UTC 0 + #endif +#endif + +/* Workaround for missing clock_gettime (most Windows compilers, afaik) */ +#if defined(_TTHREAD_WIN32_) || defined(__APPLE_CC__) +#define _TTHREAD_EMULATE_CLOCK_GETTIME_ +/* Emulate struct timespec */ +#if defined(_TTHREAD_WIN32_) +struct _ttherad_timespec { + time_t tv_sec; + long tv_nsec; +}; +#define timespec _ttherad_timespec +#endif + +/* Emulate clockid_t */ +typedef int _tthread_clockid_t; +#define clockid_t _tthread_clockid_t + +/* Emulate clock_gettime */ +int _tthread_clock_gettime(clockid_t clk_id, struct timespec *ts); +#define clock_gettime _tthread_clock_gettime +#ifndef CLOCK_REALTIME + #define CLOCK_REALTIME 0 +#endif +#endif + + +/** TinyCThread version (major number). */ +#define TINYCTHREAD_VERSION_MAJOR 1 +/** TinyCThread version (minor number). */ +#define TINYCTHREAD_VERSION_MINOR 1 +/** TinyCThread version (full version). */ +#define TINYCTHREAD_VERSION (TINYCTHREAD_VERSION_MAJOR * 100 + TINYCTHREAD_VERSION_MINOR) + +/** +* @def _Thread_local +* Thread local storage keyword. +* A variable that is declared with the @c _Thread_local keyword makes the +* value of the variable local to each thread (known as thread-local storage, +* or TLS). Example usage: +* @code +* // This variable is local to each thread. +* _Thread_local int variable; +* @endcode +* @note The @c _Thread_local keyword is a macro that maps to the corresponding +* compiler directive (e.g. @c __declspec(thread)). +* @note This directive is currently not supported on Mac OS X (it will give +* a compiler error), since compile-time TLS is not supported in the Mac OS X +* executable format. Also, some older versions of MinGW (before GCC 4.x) do +* not support this directive. +* @hideinitializer +*/ + +/* FIXME: Check for a PROPER value of __STDC_VERSION__ to know if we have C11 */ +#if !(defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 201102L)) && !defined(_Thread_local) + #if defined(__GNUC__) || defined(__INTEL_COMPILER) || defined(__SUNPRO_CC) || defined(__IBMCPP__) + #define _Thread_local __thread + #else + #define _Thread_local __declspec(thread) + #endif +#endif + +/* Macros */ +#define TSS_DTOR_ITERATIONS 0 + +/* Function return values */ +#define thrd_error 0 /**< The requested operation failed */ +#define thrd_success 1 /**< The requested operation succeeded */ +#define thrd_timeout 2 /**< The time specified in the call was reached without acquiring the requested resource */ +#define thrd_busy 3 /**< The requested operation failed because a tesource requested by a test and return function is already in use */ +#define thrd_nomem 4 /**< The requested operation failed because it was unable to allocate memory */ + +/* Mutex types */ +#define mtx_plain 1 +#define mtx_timed 2 +#define mtx_try 4 +#define mtx_recursive 8 + +/* Mutex */ +#if defined(_TTHREAD_WIN32_) +typedef struct { + CRITICAL_SECTION mHandle; /* Critical section handle */ + int mAlreadyLocked; /* TRUE if the mutex is already locked */ + int mRecursive; /* TRUE if the mutex is recursive */ +} mtx_t; +#else +typedef pthread_mutex_t mtx_t; +#endif + +/** Create a mutex object. +* @param mtx A mutex object. +* @param type Bit-mask that must have one of the following six values: +* @li @c mtx_plain for a simple non-recursive mutex +* @li @c mtx_timed for a non-recursive mutex that supports timeout +* @li @c mtx_try for a non-recursive mutex that supports test and return +* @li @c mtx_plain | @c mtx_recursive (same as @c mtx_plain, but recursive) +* @li @c mtx_timed | @c mtx_recursive (same as @c mtx_timed, but recursive) +* @li @c mtx_try | @c mtx_recursive (same as @c mtx_try, but recursive) +* @return @ref thrd_success on success, or @ref thrd_error if the request could +* not be honored. +*/ +int mtx_init(mtx_t *mtx, int type); + +/** Release any resources used by the given mutex. +* @param mtx A mutex object. +*/ +void mtx_destroy(mtx_t *mtx); + +/** Lock the given mutex. +* Blocks until the given mutex can be locked. If the mutex is non-recursive, and +* the calling thread already has a lock on the mutex, this call will block +* forever. +* @param mtx A mutex object. +* @return @ref thrd_success on success, or @ref thrd_error if the request could +* not be honored. +*/ +int mtx_lock(mtx_t *mtx); + +/** NOT YET IMPLEMENTED. +*/ +int mtx_timedlock(mtx_t *mtx, const struct timespec *ts); + +/** Try to lock the given mutex. +* The specified mutex shall support either test and return or timeout. If the +* mutex is already locked, the function returns without blocking. +* @param mtx A mutex object. +* @return @ref thrd_success on success, or @ref thrd_busy if the resource +* requested is already in use, or @ref thrd_error if the request could not be +* honored. +*/ +int mtx_trylock(mtx_t *mtx); + +/** Unlock the given mutex. +* @param mtx A mutex object. +* @return @ref thrd_success on success, or @ref thrd_error if the request could +* not be honored. +*/ +int mtx_unlock(mtx_t *mtx); + +/* Condition variable */ +#if defined(_TTHREAD_WIN32_) +typedef struct { + HANDLE mEvents[2]; /* Signal and broadcast event HANDLEs. */ + unsigned int mWaitersCount; /* Count of the number of waiters. */ + CRITICAL_SECTION mWaitersCountLock; /* Serialize access to mWaitersCount. */ +} cnd_t; +#else +typedef pthread_cond_t cnd_t; +#endif + +/** Create a condition variable object. +* @param cond A condition variable object. +* @return @ref thrd_success on success, or @ref thrd_error if the request could +* not be honored. +*/ +int cnd_init(cnd_t *cond); + +/** Release any resources used by the given condition variable. +* @param cond A condition variable object. +*/ +void cnd_destroy(cnd_t *cond); + +/** Signal a condition variable. +* Unblocks one of the threads that are blocked on the given condition variable +* at the time of the call. If no threads are blocked on the condition variable +* at the time of the call, the function does nothing and return success. +* @param cond A condition variable object. +* @return @ref thrd_success on success, or @ref thrd_error if the request could +* not be honored. +*/ +int cnd_signal(cnd_t *cond); + +/** Broadcast a condition variable. +* Unblocks all of the threads that are blocked on the given condition variable +* at the time of the call. If no threads are blocked on the condition variable +* at the time of the call, the function does nothing and return success. +* @param cond A condition variable object. +* @return @ref thrd_success on success, or @ref thrd_error if the request could +* not be honored. +*/ +int cnd_broadcast(cnd_t *cond); + +/** Wait for a condition variable to become signaled. +* The function atomically unlocks the given mutex and endeavors to block until +* the given condition variable is signaled by a call to cnd_signal or to +* cnd_broadcast. When the calling thread becomes unblocked it locks the mutex +* before it returns. +* @param cond A condition variable object. +* @param mtx A mutex object. +* @return @ref thrd_success on success, or @ref thrd_error if the request could +* not be honored. +*/ +int cnd_wait(cnd_t *cond, mtx_t *mtx); + +/** Wait for a condition variable to become signaled. +* The function atomically unlocks the given mutex and endeavors to block until +* the given condition variable is signaled by a call to cnd_signal or to +* cnd_broadcast, or until after the specified time. When the calling thread +* becomes unblocked it locks the mutex before it returns. +* @param cond A condition variable object. +* @param mtx A mutex object. +* @param xt A point in time at which the request will time out (absolute time). +* @return @ref thrd_success upon success, or @ref thrd_timeout if the time +* specified in the call was reached without acquiring the requested resource, or +* @ref thrd_error if the request could not be honored. +*/ +int cnd_timedwait(cnd_t *cond, mtx_t *mtx, const struct timespec *ts); + +/* Thread */ +#if defined(_TTHREAD_WIN32_) +typedef HANDLE thrd_t; +#else +typedef pthread_t thrd_t; +#endif + +/** Thread start function. +* Any thread that is started with the @ref thrd_create() function must be +* started through a function of this type. +* @param arg The thread argument (the @c arg argument of the corresponding +* @ref thrd_create() call). +* @return The thread return value, which can be obtained by another thread +* by using the @ref thrd_join() function. +*/ +typedef int (*thrd_start_t)(void *arg); + +/** Create a new thread. +* @param thr Identifier of the newly created thread. +* @param func A function pointer to the function that will be executed in +* the new thread. +* @param arg An argument to the thread function. +* @return @ref thrd_success on success, or @ref thrd_nomem if no memory could +* be allocated for the thread requested, or @ref thrd_error if the request +* could not be honored. +* @note A thread’s identifier may be reused for a different thread once the +* original thread has exited and either been detached or joined to another +* thread. +*/ +int thrd_create(thrd_t *thr, thrd_start_t func, void *arg); + +/** Identify the calling thread. +* @return The identifier of the calling thread. +*/ +thrd_t thrd_current(void); + +/** NOT YET IMPLEMENTED. +*/ +int thrd_detach(thrd_t thr); + +/** Compare two thread identifiers. +* The function determines if two thread identifiers refer to the same thread. +* @return Zero if the two thread identifiers refer to different threads. +* Otherwise a nonzero value is returned. +*/ +int thrd_equal(thrd_t thr0, thrd_t thr1); + +/** Terminate execution of the calling thread. +* @param res Result code of the calling thread. +*/ +void thrd_exit(int res); + +/** Wait for a thread to terminate. +* The function joins the given thread with the current thread by blocking +* until the other thread has terminated. +* @param thr The thread to join with. +* @param res If this pointer is not NULL, the function will store the result +* code of the given thread in the integer pointed to by @c res. +* @return @ref thrd_success on success, or @ref thrd_error if the request could +* not be honored. +*/ +int thrd_join(thrd_t thr, int *res); + +/** Put the calling thread to sleep. +* Suspend execution of the calling thread. +* @param time_point A point in time at which the thread will resume (absolute time). +* @param remaining If non-NULL, this parameter will hold the remaining time until +* time_point upon return. This will typically be zero, but if +* the thread was woken up by a signal that is not ignored before +* time_point was reached @c remaining will hold a positive +* time. +* @return 0 (zero) on successful sleep, or -1 if an interrupt occurred. +*/ +int thrd_sleep(const struct timespec *time_point, struct timespec *remaining); + +/** Yield execution to another thread. +* Permit other threads to run, even if the current thread would ordinarily +* continue to run. +*/ +void thrd_yield(void); + +/* Thread local storage */ +#if defined(_TTHREAD_WIN32_) +typedef DWORD tss_t; +#else +typedef pthread_key_t tss_t; +#endif + +/** Destructor function for a thread-specific storage. +* @param val The value of the destructed thread-specific storage. +*/ +typedef void (*tss_dtor_t)(void *val); + +/** Create a thread-specific storage. +* @param key The unique key identifier that will be set if the function is +* successful. +* @param dtor Destructor function. This can be NULL. +* @return @ref thrd_success on success, or @ref thrd_error if the request could +* not be honored. +* @note The destructor function is not supported under Windows. If @c dtor is +* not NULL when calling this function under Windows, the function will fail +* and return @ref thrd_error. +*/ +int tss_create(tss_t *key, tss_dtor_t dtor); + +/** Delete a thread-specific storage. +* The function releases any resources used by the given thread-specific +* storage. +* @param key The key that shall be deleted. +*/ +void tss_delete(tss_t key); + +/** Get the value for a thread-specific storage. +* @param key The thread-specific storage identifier. +* @return The value for the current thread held in the given thread-specific +* storage. +*/ +void *tss_get(tss_t key); + +/** Set the value for a thread-specific storage. +* @param key The thread-specific storage identifier. +* @param val The value of the thread-specific storage to set for the current +* thread. +* @return @ref thrd_success on success, or @ref thrd_error if the request could +* not be honored. +*/ +int tss_set(tss_t key, void *val); + + +#endif /* _TINYTHREAD_H_ */ + diff --git a/src/external/glfw/deps/vulkan/vk_platform.h b/src/external/glfw/deps/vulkan/vk_platform.h index 0fa62ee23..8e21a17df 100644 --- a/src/external/glfw/deps/vulkan/vk_platform.h +++ b/src/external/glfw/deps/vulkan/vk_platform.h @@ -1,120 +1,92 @@ -// -// File: vk_platform.h -// -/* -** Copyright (c) 2014-2015 The Khronos Group Inc. -** -** Licensed under the Apache License, Version 2.0 (the "License"); -** you may not use this file except in compliance with the License. -** You may obtain a copy of the License at -** -** http://www.apache.org/licenses/LICENSE-2.0 -** -** Unless required by applicable law or agreed to in writing, software -** distributed under the License is distributed on an "AS IS" BASIS, -** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -** See the License for the specific language governing permissions and -** limitations under the License. -*/ - - -#ifndef VK_PLATFORM_H_ -#define VK_PLATFORM_H_ - -#ifdef __cplusplus -extern "C" -{ -#endif // __cplusplus - -/* -*************************************************************************************************** -* Platform-specific directives and type declarations -*************************************************************************************************** -*/ - -/* Platform-specific calling convention macros. - * - * Platforms should define these so that Vulkan clients call Vulkan commands - * with the same calling conventions that the Vulkan implementation expects. - * - * VKAPI_ATTR - Placed before the return type in function declarations. - * Useful for C++11 and GCC/Clang-style function attribute syntax. - * VKAPI_CALL - Placed after the return type in function declarations. - * Useful for MSVC-style calling convention syntax. - * VKAPI_PTR - Placed between the '(' and '*' in function pointer types. - * - * Function declaration: VKAPI_ATTR void VKAPI_CALL vkCommand(void); - * Function pointer type: typedef void (VKAPI_PTR *PFN_vkCommand)(void); - */ -#if defined(_WIN32) - // On Windows, Vulkan commands use the stdcall convention - #define VKAPI_ATTR - #define VKAPI_CALL __stdcall - #define VKAPI_PTR VKAPI_CALL -#elif defined(__ANDROID__) && defined(__ARM_ARCH) && __ARM_ARCH < 7 - #error "Vulkan isn't supported for the 'armeabi' NDK ABI" -#elif defined(__ANDROID__) && defined(__ARM_ARCH) && __ARM_ARCH >= 7 && defined(__ARM_32BIT_STATE) - // On Android 32-bit ARM targets, Vulkan functions use the "hardfloat" - // calling convention, i.e. float parameters are passed in registers. This - // is true even if the rest of the application passes floats on the stack, - // as it does by default when compiling for the armeabi-v7a NDK ABI. - #define VKAPI_ATTR __attribute__((pcs("aapcs-vfp"))) - #define VKAPI_CALL - #define VKAPI_PTR VKAPI_ATTR -#else - // On other platforms, use the default calling convention - #define VKAPI_ATTR - #define VKAPI_CALL - #define VKAPI_PTR -#endif - -#include - -#if !defined(VK_NO_STDINT_H) - #if defined(_MSC_VER) && (_MSC_VER < 1600) - typedef signed __int8 int8_t; - typedef unsigned __int8 uint8_t; - typedef signed __int16 int16_t; - typedef unsigned __int16 uint16_t; - typedef signed __int32 int32_t; - typedef unsigned __int32 uint32_t; - typedef signed __int64 int64_t; - typedef unsigned __int64 uint64_t; - #else - #include - #endif -#endif // !defined(VK_NO_STDINT_H) - -#ifdef __cplusplus -} // extern "C" -#endif // __cplusplus - -// Platform-specific headers required by platform window system extensions. -// These are enabled prior to #including "vulkan.h". The same enable then -// controls inclusion of the extension interfaces in vulkan.h. - -#ifdef VK_USE_PLATFORM_ANDROID_KHR -#include -#endif - -#ifdef VK_USE_PLATFORM_MIR_KHR -#include -#endif - -#ifdef VK_USE_PLATFORM_WAYLAND_KHR -#include -#endif - -#ifdef VK_USE_PLATFORM_WIN32_KHR -#include -#endif - -#ifdef VK_USE_PLATFORM_XLIB_KHR -#include -#endif - -#ifdef VK_USE_PLATFORM_XCB_KHR -#include -#endif - -#endif +// +// File: vk_platform.h +// +/* +** Copyright (c) 2014-2017 The Khronos Group Inc. +** +** Licensed under the Apache License, Version 2.0 (the "License"); +** you may not use this file except in compliance with the License. +** You may obtain a copy of the License at +** +** http://www.apache.org/licenses/LICENSE-2.0 +** +** Unless required by applicable law or agreed to in writing, software +** distributed under the License is distributed on an "AS IS" BASIS, +** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +** See the License for the specific language governing permissions and +** limitations under the License. +*/ + + +#ifndef VK_PLATFORM_H_ +#define VK_PLATFORM_H_ + +#ifdef __cplusplus +extern "C" +{ +#endif // __cplusplus + +/* +*************************************************************************************************** +* Platform-specific directives and type declarations +*************************************************************************************************** +*/ + +/* Platform-specific calling convention macros. + * + * Platforms should define these so that Vulkan clients call Vulkan commands + * with the same calling conventions that the Vulkan implementation expects. + * + * VKAPI_ATTR - Placed before the return type in function declarations. + * Useful for C++11 and GCC/Clang-style function attribute syntax. + * VKAPI_CALL - Placed after the return type in function declarations. + * Useful for MSVC-style calling convention syntax. + * VKAPI_PTR - Placed between the '(' and '*' in function pointer types. + * + * Function declaration: VKAPI_ATTR void VKAPI_CALL vkCommand(void); + * Function pointer type: typedef void (VKAPI_PTR *PFN_vkCommand)(void); + */ +#if defined(_WIN32) + // On Windows, Vulkan commands use the stdcall convention + #define VKAPI_ATTR + #define VKAPI_CALL __stdcall + #define VKAPI_PTR VKAPI_CALL +#elif defined(__ANDROID__) && defined(__ARM_ARCH) && __ARM_ARCH < 7 + #error "Vulkan isn't supported for the 'armeabi' NDK ABI" +#elif defined(__ANDROID__) && defined(__ARM_ARCH) && __ARM_ARCH >= 7 && defined(__ARM_32BIT_STATE) + // On Android 32-bit ARM targets, Vulkan functions use the "hardfloat" + // calling convention, i.e. float parameters are passed in registers. This + // is true even if the rest of the application passes floats on the stack, + // as it does by default when compiling for the armeabi-v7a NDK ABI. + #define VKAPI_ATTR __attribute__((pcs("aapcs-vfp"))) + #define VKAPI_CALL + #define VKAPI_PTR VKAPI_ATTR +#else + // On other platforms, use the default calling convention + #define VKAPI_ATTR + #define VKAPI_CALL + #define VKAPI_PTR +#endif + +#include + +#if !defined(VK_NO_STDINT_H) + #if defined(_MSC_VER) && (_MSC_VER < 1600) + typedef signed __int8 int8_t; + typedef unsigned __int8 uint8_t; + typedef signed __int16 int16_t; + typedef unsigned __int16 uint16_t; + typedef signed __int32 int32_t; + typedef unsigned __int32 uint32_t; + typedef signed __int64 int64_t; + typedef unsigned __int64 uint64_t; + #else + #include + #endif +#endif // !defined(VK_NO_STDINT_H) + +#ifdef __cplusplus +} // extern "C" +#endif // __cplusplus + +#endif diff --git a/src/external/glfw/deps/vulkan/vulkan.h b/src/external/glfw/deps/vulkan/vulkan.h index 81dedf777..bf35a3a7a 100644 --- a/src/external/glfw/deps/vulkan/vulkan.h +++ b/src/external/glfw/deps/vulkan/vulkan.h @@ -1,4763 +1,79 @@ -#ifndef VULKAN_H_ -#define VULKAN_H_ 1 - -#ifdef __cplusplus -extern "C" { -#endif - -/* -** Copyright (c) 2015-2017 The Khronos Group Inc. -** -** Licensed under the Apache License, Version 2.0 (the "License"); -** you may not use this file except in compliance with the License. -** You may obtain a copy of the License at -** -** http://www.apache.org/licenses/LICENSE-2.0 -** -** Unless required by applicable law or agreed to in writing, software -** distributed under the License is distributed on an "AS IS" BASIS, -** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -** See the License for the specific language governing permissions and -** limitations under the License. -*/ - -/* -** This header is generated from the Khronos Vulkan XML API Registry. -** -*/ - - -#define VK_VERSION_1_0 1 -#include "vk_platform.h" - -#define VK_MAKE_VERSION(major, minor, patch) \ - (((major) << 22) | ((minor) << 12) | (patch)) - -// DEPRECATED: This define has been removed. Specific version defines (e.g. VK_API_VERSION_1_0), or the VK_MAKE_VERSION macro, should be used instead. -//#define VK_API_VERSION VK_MAKE_VERSION(1, 0, 0) - -// Vulkan 1.0 version number -#define VK_API_VERSION_1_0 VK_MAKE_VERSION(1, 0, 0) - -#define VK_VERSION_MAJOR(version) ((uint32_t)(version) >> 22) -#define VK_VERSION_MINOR(version) (((uint32_t)(version) >> 12) & 0x3ff) -#define VK_VERSION_PATCH(version) ((uint32_t)(version) & 0xfff) -// Version of this file -#define VK_HEADER_VERSION 39 - - -#define VK_NULL_HANDLE 0 - - - -#define VK_DEFINE_HANDLE(object) typedef struct object##_T* object; - - -#if !defined(VK_DEFINE_NON_DISPATCHABLE_HANDLE) -#if defined(__LP64__) || defined(_WIN64) || (defined(__x86_64__) && !defined(__ILP32__) ) || defined(_M_X64) || defined(__ia64) || defined (_M_IA64) || defined(__aarch64__) || defined(__powerpc64__) - #define VK_DEFINE_NON_DISPATCHABLE_HANDLE(object) typedef struct object##_T *object; -#else - #define VK_DEFINE_NON_DISPATCHABLE_HANDLE(object) typedef uint64_t object; -#endif -#endif - - - -typedef uint32_t VkFlags; -typedef uint32_t VkBool32; -typedef uint64_t VkDeviceSize; -typedef uint32_t VkSampleMask; - -VK_DEFINE_HANDLE(VkInstance) -VK_DEFINE_HANDLE(VkPhysicalDevice) -VK_DEFINE_HANDLE(VkDevice) -VK_DEFINE_HANDLE(VkQueue) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSemaphore) -VK_DEFINE_HANDLE(VkCommandBuffer) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkFence) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDeviceMemory) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkBuffer) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkImage) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkEvent) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkQueryPool) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkBufferView) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkImageView) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkShaderModule) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkPipelineCache) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkPipelineLayout) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkRenderPass) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkPipeline) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDescriptorSetLayout) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSampler) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDescriptorPool) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDescriptorSet) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkFramebuffer) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkCommandPool) - -#define VK_LOD_CLAMP_NONE 1000.0f -#define VK_REMAINING_MIP_LEVELS (~0U) -#define VK_REMAINING_ARRAY_LAYERS (~0U) -#define VK_WHOLE_SIZE (~0ULL) -#define VK_ATTACHMENT_UNUSED (~0U) -#define VK_TRUE 1 -#define VK_FALSE 0 -#define VK_QUEUE_FAMILY_IGNORED (~0U) -#define VK_SUBPASS_EXTERNAL (~0U) -#define VK_MAX_PHYSICAL_DEVICE_NAME_SIZE 256 -#define VK_UUID_SIZE 16 -#define VK_MAX_MEMORY_TYPES 32 -#define VK_MAX_MEMORY_HEAPS 16 -#define VK_MAX_EXTENSION_NAME_SIZE 256 -#define VK_MAX_DESCRIPTION_SIZE 256 - - -typedef enum VkPipelineCacheHeaderVersion { - VK_PIPELINE_CACHE_HEADER_VERSION_ONE = 1, - VK_PIPELINE_CACHE_HEADER_VERSION_BEGIN_RANGE = VK_PIPELINE_CACHE_HEADER_VERSION_ONE, - VK_PIPELINE_CACHE_HEADER_VERSION_END_RANGE = VK_PIPELINE_CACHE_HEADER_VERSION_ONE, - VK_PIPELINE_CACHE_HEADER_VERSION_RANGE_SIZE = (VK_PIPELINE_CACHE_HEADER_VERSION_ONE - VK_PIPELINE_CACHE_HEADER_VERSION_ONE + 1), - VK_PIPELINE_CACHE_HEADER_VERSION_MAX_ENUM = 0x7FFFFFFF -} VkPipelineCacheHeaderVersion; - -typedef enum VkResult { - VK_SUCCESS = 0, - VK_NOT_READY = 1, - VK_TIMEOUT = 2, - VK_EVENT_SET = 3, - VK_EVENT_RESET = 4, - VK_INCOMPLETE = 5, - VK_ERROR_OUT_OF_HOST_MEMORY = -1, - VK_ERROR_OUT_OF_DEVICE_MEMORY = -2, - VK_ERROR_INITIALIZATION_FAILED = -3, - VK_ERROR_DEVICE_LOST = -4, - VK_ERROR_MEMORY_MAP_FAILED = -5, - VK_ERROR_LAYER_NOT_PRESENT = -6, - VK_ERROR_EXTENSION_NOT_PRESENT = -7, - VK_ERROR_FEATURE_NOT_PRESENT = -8, - VK_ERROR_INCOMPATIBLE_DRIVER = -9, - VK_ERROR_TOO_MANY_OBJECTS = -10, - VK_ERROR_FORMAT_NOT_SUPPORTED = -11, - VK_ERROR_FRAGMENTED_POOL = -12, - VK_ERROR_SURFACE_LOST_KHR = -1000000000, - VK_ERROR_NATIVE_WINDOW_IN_USE_KHR = -1000000001, - VK_SUBOPTIMAL_KHR = 1000001003, - VK_ERROR_OUT_OF_DATE_KHR = -1000001004, - VK_ERROR_INCOMPATIBLE_DISPLAY_KHR = -1000003001, - VK_ERROR_VALIDATION_FAILED_EXT = -1000011001, - VK_ERROR_INVALID_SHADER_NV = -1000012000, - VK_ERROR_OUT_OF_POOL_MEMORY_KHR = -1000069000, - VK_RESULT_BEGIN_RANGE = VK_ERROR_FRAGMENTED_POOL, - VK_RESULT_END_RANGE = VK_INCOMPLETE, - VK_RESULT_RANGE_SIZE = (VK_INCOMPLETE - VK_ERROR_FRAGMENTED_POOL + 1), - VK_RESULT_MAX_ENUM = 0x7FFFFFFF -} VkResult; - -typedef enum VkStructureType { - VK_STRUCTURE_TYPE_APPLICATION_INFO = 0, - VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO = 1, - VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO = 2, - VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO = 3, - VK_STRUCTURE_TYPE_SUBMIT_INFO = 4, - VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_INFO = 5, - VK_STRUCTURE_TYPE_MAPPED_MEMORY_RANGE = 6, - VK_STRUCTURE_TYPE_BIND_SPARSE_INFO = 7, - VK_STRUCTURE_TYPE_FENCE_CREATE_INFO = 8, - VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO = 9, - VK_STRUCTURE_TYPE_EVENT_CREATE_INFO = 10, - VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO = 11, - VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO = 12, - VK_STRUCTURE_TYPE_BUFFER_VIEW_CREATE_INFO = 13, - VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO = 14, - VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO = 15, - VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO = 16, - VK_STRUCTURE_TYPE_PIPELINE_CACHE_CREATE_INFO = 17, - VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO = 18, - VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO = 19, - VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO = 20, - VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_STATE_CREATE_INFO = 21, - VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO = 22, - VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO = 23, - VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO = 24, - VK_STRUCTURE_TYPE_PIPELINE_DEPTH_STENCIL_STATE_CREATE_INFO = 25, - VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO = 26, - VK_STRUCTURE_TYPE_PIPELINE_DYNAMIC_STATE_CREATE_INFO = 27, - VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO = 28, - VK_STRUCTURE_TYPE_COMPUTE_PIPELINE_CREATE_INFO = 29, - VK_STRUCTURE_TYPE_PIPELINE_LAYOUT_CREATE_INFO = 30, - VK_STRUCTURE_TYPE_SAMPLER_CREATE_INFO = 31, - VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO = 32, - VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO = 33, - VK_STRUCTURE_TYPE_DESCRIPTOR_SET_ALLOCATE_INFO = 34, - VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET = 35, - VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET = 36, - VK_STRUCTURE_TYPE_FRAMEBUFFER_CREATE_INFO = 37, - VK_STRUCTURE_TYPE_RENDER_PASS_CREATE_INFO = 38, - VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO = 39, - VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO = 40, - VK_STRUCTURE_TYPE_COMMAND_BUFFER_INHERITANCE_INFO = 41, - VK_STRUCTURE_TYPE_COMMAND_BUFFER_BEGIN_INFO = 42, - VK_STRUCTURE_TYPE_RENDER_PASS_BEGIN_INFO = 43, - VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER = 44, - VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER = 45, - VK_STRUCTURE_TYPE_MEMORY_BARRIER = 46, - VK_STRUCTURE_TYPE_LOADER_INSTANCE_CREATE_INFO = 47, - VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO = 48, - VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR = 1000001000, - VK_STRUCTURE_TYPE_PRESENT_INFO_KHR = 1000001001, - VK_STRUCTURE_TYPE_DISPLAY_MODE_CREATE_INFO_KHR = 1000002000, - VK_STRUCTURE_TYPE_DISPLAY_SURFACE_CREATE_INFO_KHR = 1000002001, - VK_STRUCTURE_TYPE_DISPLAY_PRESENT_INFO_KHR = 1000003000, - VK_STRUCTURE_TYPE_XLIB_SURFACE_CREATE_INFO_KHR = 1000004000, - VK_STRUCTURE_TYPE_XCB_SURFACE_CREATE_INFO_KHR = 1000005000, - VK_STRUCTURE_TYPE_WAYLAND_SURFACE_CREATE_INFO_KHR = 1000006000, - VK_STRUCTURE_TYPE_MIR_SURFACE_CREATE_INFO_KHR = 1000007000, - VK_STRUCTURE_TYPE_ANDROID_SURFACE_CREATE_INFO_KHR = 1000008000, - VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR = 1000009000, - VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT = 1000011000, - VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_RASTERIZATION_ORDER_AMD = 1000018000, - VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_NAME_INFO_EXT = 1000022000, - VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_TAG_INFO_EXT = 1000022001, - VK_STRUCTURE_TYPE_DEBUG_MARKER_MARKER_INFO_EXT = 1000022002, - VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_IMAGE_CREATE_INFO_NV = 1000026000, - VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_BUFFER_CREATE_INFO_NV = 1000026001, - VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_MEMORY_ALLOCATE_INFO_NV = 1000026002, - VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO_NV = 1000056000, - VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO_NV = 1000056001, - VK_STRUCTURE_TYPE_IMPORT_MEMORY_WIN32_HANDLE_INFO_NV = 1000057000, - VK_STRUCTURE_TYPE_EXPORT_MEMORY_WIN32_HANDLE_INFO_NV = 1000057001, - VK_STRUCTURE_TYPE_WIN32_KEYED_MUTEX_ACQUIRE_RELEASE_INFO_NV = 1000058000, - VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2_KHR = 1000059000, - VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2_KHR = 1000059001, - VK_STRUCTURE_TYPE_FORMAT_PROPERTIES_2_KHR = 1000059002, - VK_STRUCTURE_TYPE_IMAGE_FORMAT_PROPERTIES_2_KHR = 1000059003, - VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2_KHR = 1000059004, - VK_STRUCTURE_TYPE_QUEUE_FAMILY_PROPERTIES_2_KHR = 1000059005, - VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2_KHR = 1000059006, - VK_STRUCTURE_TYPE_SPARSE_IMAGE_FORMAT_PROPERTIES_2_KHR = 1000059007, - VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SPARSE_IMAGE_FORMAT_INFO_2_KHR = 1000059008, - VK_STRUCTURE_TYPE_VALIDATION_FLAGS_EXT = 1000061000, - VK_STRUCTURE_TYPE_VI_SURFACE_CREATE_INFO_NN = 1000062000, - VK_STRUCTURE_TYPE_OBJECT_TABLE_CREATE_INFO_NVX = 1000086000, - VK_STRUCTURE_TYPE_INDIRECT_COMMANDS_LAYOUT_CREATE_INFO_NVX = 1000086001, - VK_STRUCTURE_TYPE_CMD_PROCESS_COMMANDS_INFO_NVX = 1000086002, - VK_STRUCTURE_TYPE_CMD_RESERVE_SPACE_FOR_COMMANDS_INFO_NVX = 1000086003, - VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_LIMITS_NVX = 1000086004, - VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_FEATURES_NVX = 1000086005, - VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES2_EXT = 1000090000, - VK_STRUCTURE_TYPE_DISPLAY_POWER_INFO_EXT = 1000091000, - VK_STRUCTURE_TYPE_DEVICE_EVENT_INFO_EXT = 1000091001, - VK_STRUCTURE_TYPE_DISPLAY_EVENT_INFO_EXT = 1000091002, - VK_STRUCTURE_TYPE_SWAPCHAIN_COUNTER_CREATE_INFO_EXT = 1000091003, - VK_STRUCTURE_TYPE_BEGIN_RANGE = VK_STRUCTURE_TYPE_APPLICATION_INFO, - VK_STRUCTURE_TYPE_END_RANGE = VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO, - VK_STRUCTURE_TYPE_RANGE_SIZE = (VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO - VK_STRUCTURE_TYPE_APPLICATION_INFO + 1), - VK_STRUCTURE_TYPE_MAX_ENUM = 0x7FFFFFFF -} VkStructureType; - -typedef enum VkSystemAllocationScope { - VK_SYSTEM_ALLOCATION_SCOPE_COMMAND = 0, - VK_SYSTEM_ALLOCATION_SCOPE_OBJECT = 1, - VK_SYSTEM_ALLOCATION_SCOPE_CACHE = 2, - VK_SYSTEM_ALLOCATION_SCOPE_DEVICE = 3, - VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE = 4, - VK_SYSTEM_ALLOCATION_SCOPE_BEGIN_RANGE = VK_SYSTEM_ALLOCATION_SCOPE_COMMAND, - VK_SYSTEM_ALLOCATION_SCOPE_END_RANGE = VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE, - VK_SYSTEM_ALLOCATION_SCOPE_RANGE_SIZE = (VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE - VK_SYSTEM_ALLOCATION_SCOPE_COMMAND + 1), - VK_SYSTEM_ALLOCATION_SCOPE_MAX_ENUM = 0x7FFFFFFF -} VkSystemAllocationScope; - -typedef enum VkInternalAllocationType { - VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE = 0, - VK_INTERNAL_ALLOCATION_TYPE_BEGIN_RANGE = VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE, - VK_INTERNAL_ALLOCATION_TYPE_END_RANGE = VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE, - VK_INTERNAL_ALLOCATION_TYPE_RANGE_SIZE = (VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE - VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE + 1), - VK_INTERNAL_ALLOCATION_TYPE_MAX_ENUM = 0x7FFFFFFF -} VkInternalAllocationType; - -typedef enum VkFormat { - VK_FORMAT_UNDEFINED = 0, - VK_FORMAT_R4G4_UNORM_PACK8 = 1, - VK_FORMAT_R4G4B4A4_UNORM_PACK16 = 2, - VK_FORMAT_B4G4R4A4_UNORM_PACK16 = 3, - VK_FORMAT_R5G6B5_UNORM_PACK16 = 4, - VK_FORMAT_B5G6R5_UNORM_PACK16 = 5, - VK_FORMAT_R5G5B5A1_UNORM_PACK16 = 6, - VK_FORMAT_B5G5R5A1_UNORM_PACK16 = 7, - VK_FORMAT_A1R5G5B5_UNORM_PACK16 = 8, - VK_FORMAT_R8_UNORM = 9, - VK_FORMAT_R8_SNORM = 10, - VK_FORMAT_R8_USCALED = 11, - VK_FORMAT_R8_SSCALED = 12, - VK_FORMAT_R8_UINT = 13, - VK_FORMAT_R8_SINT = 14, - VK_FORMAT_R8_SRGB = 15, - VK_FORMAT_R8G8_UNORM = 16, - VK_FORMAT_R8G8_SNORM = 17, - VK_FORMAT_R8G8_USCALED = 18, - VK_FORMAT_R8G8_SSCALED = 19, - VK_FORMAT_R8G8_UINT = 20, - VK_FORMAT_R8G8_SINT = 21, - VK_FORMAT_R8G8_SRGB = 22, - VK_FORMAT_R8G8B8_UNORM = 23, - VK_FORMAT_R8G8B8_SNORM = 24, - VK_FORMAT_R8G8B8_USCALED = 25, - VK_FORMAT_R8G8B8_SSCALED = 26, - VK_FORMAT_R8G8B8_UINT = 27, - VK_FORMAT_R8G8B8_SINT = 28, - VK_FORMAT_R8G8B8_SRGB = 29, - VK_FORMAT_B8G8R8_UNORM = 30, - VK_FORMAT_B8G8R8_SNORM = 31, - VK_FORMAT_B8G8R8_USCALED = 32, - VK_FORMAT_B8G8R8_SSCALED = 33, - VK_FORMAT_B8G8R8_UINT = 34, - VK_FORMAT_B8G8R8_SINT = 35, - VK_FORMAT_B8G8R8_SRGB = 36, - VK_FORMAT_R8G8B8A8_UNORM = 37, - VK_FORMAT_R8G8B8A8_SNORM = 38, - VK_FORMAT_R8G8B8A8_USCALED = 39, - VK_FORMAT_R8G8B8A8_SSCALED = 40, - VK_FORMAT_R8G8B8A8_UINT = 41, - VK_FORMAT_R8G8B8A8_SINT = 42, - VK_FORMAT_R8G8B8A8_SRGB = 43, - VK_FORMAT_B8G8R8A8_UNORM = 44, - VK_FORMAT_B8G8R8A8_SNORM = 45, - VK_FORMAT_B8G8R8A8_USCALED = 46, - VK_FORMAT_B8G8R8A8_SSCALED = 47, - VK_FORMAT_B8G8R8A8_UINT = 48, - VK_FORMAT_B8G8R8A8_SINT = 49, - VK_FORMAT_B8G8R8A8_SRGB = 50, - VK_FORMAT_A8B8G8R8_UNORM_PACK32 = 51, - VK_FORMAT_A8B8G8R8_SNORM_PACK32 = 52, - VK_FORMAT_A8B8G8R8_USCALED_PACK32 = 53, - VK_FORMAT_A8B8G8R8_SSCALED_PACK32 = 54, - VK_FORMAT_A8B8G8R8_UINT_PACK32 = 55, - VK_FORMAT_A8B8G8R8_SINT_PACK32 = 56, - VK_FORMAT_A8B8G8R8_SRGB_PACK32 = 57, - VK_FORMAT_A2R10G10B10_UNORM_PACK32 = 58, - VK_FORMAT_A2R10G10B10_SNORM_PACK32 = 59, - VK_FORMAT_A2R10G10B10_USCALED_PACK32 = 60, - VK_FORMAT_A2R10G10B10_SSCALED_PACK32 = 61, - VK_FORMAT_A2R10G10B10_UINT_PACK32 = 62, - VK_FORMAT_A2R10G10B10_SINT_PACK32 = 63, - VK_FORMAT_A2B10G10R10_UNORM_PACK32 = 64, - VK_FORMAT_A2B10G10R10_SNORM_PACK32 = 65, - VK_FORMAT_A2B10G10R10_USCALED_PACK32 = 66, - VK_FORMAT_A2B10G10R10_SSCALED_PACK32 = 67, - VK_FORMAT_A2B10G10R10_UINT_PACK32 = 68, - VK_FORMAT_A2B10G10R10_SINT_PACK32 = 69, - VK_FORMAT_R16_UNORM = 70, - VK_FORMAT_R16_SNORM = 71, - VK_FORMAT_R16_USCALED = 72, - VK_FORMAT_R16_SSCALED = 73, - VK_FORMAT_R16_UINT = 74, - VK_FORMAT_R16_SINT = 75, - VK_FORMAT_R16_SFLOAT = 76, - VK_FORMAT_R16G16_UNORM = 77, - VK_FORMAT_R16G16_SNORM = 78, - VK_FORMAT_R16G16_USCALED = 79, - VK_FORMAT_R16G16_SSCALED = 80, - VK_FORMAT_R16G16_UINT = 81, - VK_FORMAT_R16G16_SINT = 82, - VK_FORMAT_R16G16_SFLOAT = 83, - VK_FORMAT_R16G16B16_UNORM = 84, - VK_FORMAT_R16G16B16_SNORM = 85, - VK_FORMAT_R16G16B16_USCALED = 86, - VK_FORMAT_R16G16B16_SSCALED = 87, - VK_FORMAT_R16G16B16_UINT = 88, - VK_FORMAT_R16G16B16_SINT = 89, - VK_FORMAT_R16G16B16_SFLOAT = 90, - VK_FORMAT_R16G16B16A16_UNORM = 91, - VK_FORMAT_R16G16B16A16_SNORM = 92, - VK_FORMAT_R16G16B16A16_USCALED = 93, - VK_FORMAT_R16G16B16A16_SSCALED = 94, - VK_FORMAT_R16G16B16A16_UINT = 95, - VK_FORMAT_R16G16B16A16_SINT = 96, - VK_FORMAT_R16G16B16A16_SFLOAT = 97, - VK_FORMAT_R32_UINT = 98, - VK_FORMAT_R32_SINT = 99, - VK_FORMAT_R32_SFLOAT = 100, - VK_FORMAT_R32G32_UINT = 101, - VK_FORMAT_R32G32_SINT = 102, - VK_FORMAT_R32G32_SFLOAT = 103, - VK_FORMAT_R32G32B32_UINT = 104, - VK_FORMAT_R32G32B32_SINT = 105, - VK_FORMAT_R32G32B32_SFLOAT = 106, - VK_FORMAT_R32G32B32A32_UINT = 107, - VK_FORMAT_R32G32B32A32_SINT = 108, - VK_FORMAT_R32G32B32A32_SFLOAT = 109, - VK_FORMAT_R64_UINT = 110, - VK_FORMAT_R64_SINT = 111, - VK_FORMAT_R64_SFLOAT = 112, - VK_FORMAT_R64G64_UINT = 113, - VK_FORMAT_R64G64_SINT = 114, - VK_FORMAT_R64G64_SFLOAT = 115, - VK_FORMAT_R64G64B64_UINT = 116, - VK_FORMAT_R64G64B64_SINT = 117, - VK_FORMAT_R64G64B64_SFLOAT = 118, - VK_FORMAT_R64G64B64A64_UINT = 119, - VK_FORMAT_R64G64B64A64_SINT = 120, - VK_FORMAT_R64G64B64A64_SFLOAT = 121, - VK_FORMAT_B10G11R11_UFLOAT_PACK32 = 122, - VK_FORMAT_E5B9G9R9_UFLOAT_PACK32 = 123, - VK_FORMAT_D16_UNORM = 124, - VK_FORMAT_X8_D24_UNORM_PACK32 = 125, - VK_FORMAT_D32_SFLOAT = 126, - VK_FORMAT_S8_UINT = 127, - VK_FORMAT_D16_UNORM_S8_UINT = 128, - VK_FORMAT_D24_UNORM_S8_UINT = 129, - VK_FORMAT_D32_SFLOAT_S8_UINT = 130, - VK_FORMAT_BC1_RGB_UNORM_BLOCK = 131, - VK_FORMAT_BC1_RGB_SRGB_BLOCK = 132, - VK_FORMAT_BC1_RGBA_UNORM_BLOCK = 133, - VK_FORMAT_BC1_RGBA_SRGB_BLOCK = 134, - VK_FORMAT_BC2_UNORM_BLOCK = 135, - VK_FORMAT_BC2_SRGB_BLOCK = 136, - VK_FORMAT_BC3_UNORM_BLOCK = 137, - VK_FORMAT_BC3_SRGB_BLOCK = 138, - VK_FORMAT_BC4_UNORM_BLOCK = 139, - VK_FORMAT_BC4_SNORM_BLOCK = 140, - VK_FORMAT_BC5_UNORM_BLOCK = 141, - VK_FORMAT_BC5_SNORM_BLOCK = 142, - VK_FORMAT_BC6H_UFLOAT_BLOCK = 143, - VK_FORMAT_BC6H_SFLOAT_BLOCK = 144, - VK_FORMAT_BC7_UNORM_BLOCK = 145, - VK_FORMAT_BC7_SRGB_BLOCK = 146, - VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK = 147, - VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK = 148, - VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK = 149, - VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK = 150, - VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK = 151, - VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK = 152, - VK_FORMAT_EAC_R11_UNORM_BLOCK = 153, - VK_FORMAT_EAC_R11_SNORM_BLOCK = 154, - VK_FORMAT_EAC_R11G11_UNORM_BLOCK = 155, - VK_FORMAT_EAC_R11G11_SNORM_BLOCK = 156, - VK_FORMAT_ASTC_4x4_UNORM_BLOCK = 157, - VK_FORMAT_ASTC_4x4_SRGB_BLOCK = 158, - VK_FORMAT_ASTC_5x4_UNORM_BLOCK = 159, - VK_FORMAT_ASTC_5x4_SRGB_BLOCK = 160, - VK_FORMAT_ASTC_5x5_UNORM_BLOCK = 161, - VK_FORMAT_ASTC_5x5_SRGB_BLOCK = 162, - VK_FORMAT_ASTC_6x5_UNORM_BLOCK = 163, - VK_FORMAT_ASTC_6x5_SRGB_BLOCK = 164, - VK_FORMAT_ASTC_6x6_UNORM_BLOCK = 165, - VK_FORMAT_ASTC_6x6_SRGB_BLOCK = 166, - VK_FORMAT_ASTC_8x5_UNORM_BLOCK = 167, - VK_FORMAT_ASTC_8x5_SRGB_BLOCK = 168, - VK_FORMAT_ASTC_8x6_UNORM_BLOCK = 169, - VK_FORMAT_ASTC_8x6_SRGB_BLOCK = 170, - VK_FORMAT_ASTC_8x8_UNORM_BLOCK = 171, - VK_FORMAT_ASTC_8x8_SRGB_BLOCK = 172, - VK_FORMAT_ASTC_10x5_UNORM_BLOCK = 173, - VK_FORMAT_ASTC_10x5_SRGB_BLOCK = 174, - VK_FORMAT_ASTC_10x6_UNORM_BLOCK = 175, - VK_FORMAT_ASTC_10x6_SRGB_BLOCK = 176, - VK_FORMAT_ASTC_10x8_UNORM_BLOCK = 177, - VK_FORMAT_ASTC_10x8_SRGB_BLOCK = 178, - VK_FORMAT_ASTC_10x10_UNORM_BLOCK = 179, - VK_FORMAT_ASTC_10x10_SRGB_BLOCK = 180, - VK_FORMAT_ASTC_12x10_UNORM_BLOCK = 181, - VK_FORMAT_ASTC_12x10_SRGB_BLOCK = 182, - VK_FORMAT_ASTC_12x12_UNORM_BLOCK = 183, - VK_FORMAT_ASTC_12x12_SRGB_BLOCK = 184, - VK_FORMAT_PVRTC1_2BPP_UNORM_BLOCK_IMG = 1000054000, - VK_FORMAT_PVRTC1_4BPP_UNORM_BLOCK_IMG = 1000054001, - VK_FORMAT_PVRTC2_2BPP_UNORM_BLOCK_IMG = 1000054002, - VK_FORMAT_PVRTC2_4BPP_UNORM_BLOCK_IMG = 1000054003, - VK_FORMAT_PVRTC1_2BPP_SRGB_BLOCK_IMG = 1000054004, - VK_FORMAT_PVRTC1_4BPP_SRGB_BLOCK_IMG = 1000054005, - VK_FORMAT_PVRTC2_2BPP_SRGB_BLOCK_IMG = 1000054006, - VK_FORMAT_PVRTC2_4BPP_SRGB_BLOCK_IMG = 1000054007, - VK_FORMAT_BEGIN_RANGE = VK_FORMAT_UNDEFINED, - VK_FORMAT_END_RANGE = VK_FORMAT_ASTC_12x12_SRGB_BLOCK, - VK_FORMAT_RANGE_SIZE = (VK_FORMAT_ASTC_12x12_SRGB_BLOCK - VK_FORMAT_UNDEFINED + 1), - VK_FORMAT_MAX_ENUM = 0x7FFFFFFF -} VkFormat; - -typedef enum VkImageType { - VK_IMAGE_TYPE_1D = 0, - VK_IMAGE_TYPE_2D = 1, - VK_IMAGE_TYPE_3D = 2, - VK_IMAGE_TYPE_BEGIN_RANGE = VK_IMAGE_TYPE_1D, - VK_IMAGE_TYPE_END_RANGE = VK_IMAGE_TYPE_3D, - VK_IMAGE_TYPE_RANGE_SIZE = (VK_IMAGE_TYPE_3D - VK_IMAGE_TYPE_1D + 1), - VK_IMAGE_TYPE_MAX_ENUM = 0x7FFFFFFF -} VkImageType; - -typedef enum VkImageTiling { - VK_IMAGE_TILING_OPTIMAL = 0, - VK_IMAGE_TILING_LINEAR = 1, - VK_IMAGE_TILING_BEGIN_RANGE = VK_IMAGE_TILING_OPTIMAL, - VK_IMAGE_TILING_END_RANGE = VK_IMAGE_TILING_LINEAR, - VK_IMAGE_TILING_RANGE_SIZE = (VK_IMAGE_TILING_LINEAR - VK_IMAGE_TILING_OPTIMAL + 1), - VK_IMAGE_TILING_MAX_ENUM = 0x7FFFFFFF -} VkImageTiling; - -typedef enum VkPhysicalDeviceType { - VK_PHYSICAL_DEVICE_TYPE_OTHER = 0, - VK_PHYSICAL_DEVICE_TYPE_INTEGRATED_GPU = 1, - VK_PHYSICAL_DEVICE_TYPE_DISCRETE_GPU = 2, - VK_PHYSICAL_DEVICE_TYPE_VIRTUAL_GPU = 3, - VK_PHYSICAL_DEVICE_TYPE_CPU = 4, - VK_PHYSICAL_DEVICE_TYPE_BEGIN_RANGE = VK_PHYSICAL_DEVICE_TYPE_OTHER, - VK_PHYSICAL_DEVICE_TYPE_END_RANGE = VK_PHYSICAL_DEVICE_TYPE_CPU, - VK_PHYSICAL_DEVICE_TYPE_RANGE_SIZE = (VK_PHYSICAL_DEVICE_TYPE_CPU - VK_PHYSICAL_DEVICE_TYPE_OTHER + 1), - VK_PHYSICAL_DEVICE_TYPE_MAX_ENUM = 0x7FFFFFFF -} VkPhysicalDeviceType; - -typedef enum VkQueryType { - VK_QUERY_TYPE_OCCLUSION = 0, - VK_QUERY_TYPE_PIPELINE_STATISTICS = 1, - VK_QUERY_TYPE_TIMESTAMP = 2, - VK_QUERY_TYPE_BEGIN_RANGE = VK_QUERY_TYPE_OCCLUSION, - VK_QUERY_TYPE_END_RANGE = VK_QUERY_TYPE_TIMESTAMP, - VK_QUERY_TYPE_RANGE_SIZE = (VK_QUERY_TYPE_TIMESTAMP - VK_QUERY_TYPE_OCCLUSION + 1), - VK_QUERY_TYPE_MAX_ENUM = 0x7FFFFFFF -} VkQueryType; - -typedef enum VkSharingMode { - VK_SHARING_MODE_EXCLUSIVE = 0, - VK_SHARING_MODE_CONCURRENT = 1, - VK_SHARING_MODE_BEGIN_RANGE = VK_SHARING_MODE_EXCLUSIVE, - VK_SHARING_MODE_END_RANGE = VK_SHARING_MODE_CONCURRENT, - VK_SHARING_MODE_RANGE_SIZE = (VK_SHARING_MODE_CONCURRENT - VK_SHARING_MODE_EXCLUSIVE + 1), - VK_SHARING_MODE_MAX_ENUM = 0x7FFFFFFF -} VkSharingMode; - -typedef enum VkImageLayout { - VK_IMAGE_LAYOUT_UNDEFINED = 0, - VK_IMAGE_LAYOUT_GENERAL = 1, - VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL = 2, - VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL = 3, - VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL = 4, - VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL = 5, - VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL = 6, - VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL = 7, - VK_IMAGE_LAYOUT_PREINITIALIZED = 8, - VK_IMAGE_LAYOUT_PRESENT_SRC_KHR = 1000001002, - VK_IMAGE_LAYOUT_BEGIN_RANGE = VK_IMAGE_LAYOUT_UNDEFINED, - VK_IMAGE_LAYOUT_END_RANGE = VK_IMAGE_LAYOUT_PREINITIALIZED, - VK_IMAGE_LAYOUT_RANGE_SIZE = (VK_IMAGE_LAYOUT_PREINITIALIZED - VK_IMAGE_LAYOUT_UNDEFINED + 1), - VK_IMAGE_LAYOUT_MAX_ENUM = 0x7FFFFFFF -} VkImageLayout; - -typedef enum VkImageViewType { - VK_IMAGE_VIEW_TYPE_1D = 0, - VK_IMAGE_VIEW_TYPE_2D = 1, - VK_IMAGE_VIEW_TYPE_3D = 2, - VK_IMAGE_VIEW_TYPE_CUBE = 3, - VK_IMAGE_VIEW_TYPE_1D_ARRAY = 4, - VK_IMAGE_VIEW_TYPE_2D_ARRAY = 5, - VK_IMAGE_VIEW_TYPE_CUBE_ARRAY = 6, - VK_IMAGE_VIEW_TYPE_BEGIN_RANGE = VK_IMAGE_VIEW_TYPE_1D, - VK_IMAGE_VIEW_TYPE_END_RANGE = VK_IMAGE_VIEW_TYPE_CUBE_ARRAY, - VK_IMAGE_VIEW_TYPE_RANGE_SIZE = (VK_IMAGE_VIEW_TYPE_CUBE_ARRAY - VK_IMAGE_VIEW_TYPE_1D + 1), - VK_IMAGE_VIEW_TYPE_MAX_ENUM = 0x7FFFFFFF -} VkImageViewType; - -typedef enum VkComponentSwizzle { - VK_COMPONENT_SWIZZLE_IDENTITY = 0, - VK_COMPONENT_SWIZZLE_ZERO = 1, - VK_COMPONENT_SWIZZLE_ONE = 2, - VK_COMPONENT_SWIZZLE_R = 3, - VK_COMPONENT_SWIZZLE_G = 4, - VK_COMPONENT_SWIZZLE_B = 5, - VK_COMPONENT_SWIZZLE_A = 6, - VK_COMPONENT_SWIZZLE_BEGIN_RANGE = VK_COMPONENT_SWIZZLE_IDENTITY, - VK_COMPONENT_SWIZZLE_END_RANGE = VK_COMPONENT_SWIZZLE_A, - VK_COMPONENT_SWIZZLE_RANGE_SIZE = (VK_COMPONENT_SWIZZLE_A - VK_COMPONENT_SWIZZLE_IDENTITY + 1), - VK_COMPONENT_SWIZZLE_MAX_ENUM = 0x7FFFFFFF -} VkComponentSwizzle; - -typedef enum VkVertexInputRate { - VK_VERTEX_INPUT_RATE_VERTEX = 0, - VK_VERTEX_INPUT_RATE_INSTANCE = 1, - VK_VERTEX_INPUT_RATE_BEGIN_RANGE = VK_VERTEX_INPUT_RATE_VERTEX, - VK_VERTEX_INPUT_RATE_END_RANGE = VK_VERTEX_INPUT_RATE_INSTANCE, - VK_VERTEX_INPUT_RATE_RANGE_SIZE = (VK_VERTEX_INPUT_RATE_INSTANCE - VK_VERTEX_INPUT_RATE_VERTEX + 1), - VK_VERTEX_INPUT_RATE_MAX_ENUM = 0x7FFFFFFF -} VkVertexInputRate; - -typedef enum VkPrimitiveTopology { - VK_PRIMITIVE_TOPOLOGY_POINT_LIST = 0, - VK_PRIMITIVE_TOPOLOGY_LINE_LIST = 1, - VK_PRIMITIVE_TOPOLOGY_LINE_STRIP = 2, - VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST = 3, - VK_PRIMITIVE_TOPOLOGY_TRIANGLE_STRIP = 4, - VK_PRIMITIVE_TOPOLOGY_TRIANGLE_FAN = 5, - VK_PRIMITIVE_TOPOLOGY_LINE_LIST_WITH_ADJACENCY = 6, - VK_PRIMITIVE_TOPOLOGY_LINE_STRIP_WITH_ADJACENCY = 7, - VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST_WITH_ADJACENCY = 8, - VK_PRIMITIVE_TOPOLOGY_TRIANGLE_STRIP_WITH_ADJACENCY = 9, - VK_PRIMITIVE_TOPOLOGY_PATCH_LIST = 10, - VK_PRIMITIVE_TOPOLOGY_BEGIN_RANGE = VK_PRIMITIVE_TOPOLOGY_POINT_LIST, - VK_PRIMITIVE_TOPOLOGY_END_RANGE = VK_PRIMITIVE_TOPOLOGY_PATCH_LIST, - VK_PRIMITIVE_TOPOLOGY_RANGE_SIZE = (VK_PRIMITIVE_TOPOLOGY_PATCH_LIST - VK_PRIMITIVE_TOPOLOGY_POINT_LIST + 1), - VK_PRIMITIVE_TOPOLOGY_MAX_ENUM = 0x7FFFFFFF -} VkPrimitiveTopology; - -typedef enum VkPolygonMode { - VK_POLYGON_MODE_FILL = 0, - VK_POLYGON_MODE_LINE = 1, - VK_POLYGON_MODE_POINT = 2, - VK_POLYGON_MODE_BEGIN_RANGE = VK_POLYGON_MODE_FILL, - VK_POLYGON_MODE_END_RANGE = VK_POLYGON_MODE_POINT, - VK_POLYGON_MODE_RANGE_SIZE = (VK_POLYGON_MODE_POINT - VK_POLYGON_MODE_FILL + 1), - VK_POLYGON_MODE_MAX_ENUM = 0x7FFFFFFF -} VkPolygonMode; - -typedef enum VkFrontFace { - VK_FRONT_FACE_COUNTER_CLOCKWISE = 0, - VK_FRONT_FACE_CLOCKWISE = 1, - VK_FRONT_FACE_BEGIN_RANGE = VK_FRONT_FACE_COUNTER_CLOCKWISE, - VK_FRONT_FACE_END_RANGE = VK_FRONT_FACE_CLOCKWISE, - VK_FRONT_FACE_RANGE_SIZE = (VK_FRONT_FACE_CLOCKWISE - VK_FRONT_FACE_COUNTER_CLOCKWISE + 1), - VK_FRONT_FACE_MAX_ENUM = 0x7FFFFFFF -} VkFrontFace; - -typedef enum VkCompareOp { - VK_COMPARE_OP_NEVER = 0, - VK_COMPARE_OP_LESS = 1, - VK_COMPARE_OP_EQUAL = 2, - VK_COMPARE_OP_LESS_OR_EQUAL = 3, - VK_COMPARE_OP_GREATER = 4, - VK_COMPARE_OP_NOT_EQUAL = 5, - VK_COMPARE_OP_GREATER_OR_EQUAL = 6, - VK_COMPARE_OP_ALWAYS = 7, - VK_COMPARE_OP_BEGIN_RANGE = VK_COMPARE_OP_NEVER, - VK_COMPARE_OP_END_RANGE = VK_COMPARE_OP_ALWAYS, - VK_COMPARE_OP_RANGE_SIZE = (VK_COMPARE_OP_ALWAYS - VK_COMPARE_OP_NEVER + 1), - VK_COMPARE_OP_MAX_ENUM = 0x7FFFFFFF -} VkCompareOp; - -typedef enum VkStencilOp { - VK_STENCIL_OP_KEEP = 0, - VK_STENCIL_OP_ZERO = 1, - VK_STENCIL_OP_REPLACE = 2, - VK_STENCIL_OP_INCREMENT_AND_CLAMP = 3, - VK_STENCIL_OP_DECREMENT_AND_CLAMP = 4, - VK_STENCIL_OP_INVERT = 5, - VK_STENCIL_OP_INCREMENT_AND_WRAP = 6, - VK_STENCIL_OP_DECREMENT_AND_WRAP = 7, - VK_STENCIL_OP_BEGIN_RANGE = VK_STENCIL_OP_KEEP, - VK_STENCIL_OP_END_RANGE = VK_STENCIL_OP_DECREMENT_AND_WRAP, - VK_STENCIL_OP_RANGE_SIZE = (VK_STENCIL_OP_DECREMENT_AND_WRAP - VK_STENCIL_OP_KEEP + 1), - VK_STENCIL_OP_MAX_ENUM = 0x7FFFFFFF -} VkStencilOp; - -typedef enum VkLogicOp { - VK_LOGIC_OP_CLEAR = 0, - VK_LOGIC_OP_AND = 1, - VK_LOGIC_OP_AND_REVERSE = 2, - VK_LOGIC_OP_COPY = 3, - VK_LOGIC_OP_AND_INVERTED = 4, - VK_LOGIC_OP_NO_OP = 5, - VK_LOGIC_OP_XOR = 6, - VK_LOGIC_OP_OR = 7, - VK_LOGIC_OP_NOR = 8, - VK_LOGIC_OP_EQUIVALENT = 9, - VK_LOGIC_OP_INVERT = 10, - VK_LOGIC_OP_OR_REVERSE = 11, - VK_LOGIC_OP_COPY_INVERTED = 12, - VK_LOGIC_OP_OR_INVERTED = 13, - VK_LOGIC_OP_NAND = 14, - VK_LOGIC_OP_SET = 15, - VK_LOGIC_OP_BEGIN_RANGE = VK_LOGIC_OP_CLEAR, - VK_LOGIC_OP_END_RANGE = VK_LOGIC_OP_SET, - VK_LOGIC_OP_RANGE_SIZE = (VK_LOGIC_OP_SET - VK_LOGIC_OP_CLEAR + 1), - VK_LOGIC_OP_MAX_ENUM = 0x7FFFFFFF -} VkLogicOp; - -typedef enum VkBlendFactor { - VK_BLEND_FACTOR_ZERO = 0, - VK_BLEND_FACTOR_ONE = 1, - VK_BLEND_FACTOR_SRC_COLOR = 2, - VK_BLEND_FACTOR_ONE_MINUS_SRC_COLOR = 3, - VK_BLEND_FACTOR_DST_COLOR = 4, - VK_BLEND_FACTOR_ONE_MINUS_DST_COLOR = 5, - VK_BLEND_FACTOR_SRC_ALPHA = 6, - VK_BLEND_FACTOR_ONE_MINUS_SRC_ALPHA = 7, - VK_BLEND_FACTOR_DST_ALPHA = 8, - VK_BLEND_FACTOR_ONE_MINUS_DST_ALPHA = 9, - VK_BLEND_FACTOR_CONSTANT_COLOR = 10, - VK_BLEND_FACTOR_ONE_MINUS_CONSTANT_COLOR = 11, - VK_BLEND_FACTOR_CONSTANT_ALPHA = 12, - VK_BLEND_FACTOR_ONE_MINUS_CONSTANT_ALPHA = 13, - VK_BLEND_FACTOR_SRC_ALPHA_SATURATE = 14, - VK_BLEND_FACTOR_SRC1_COLOR = 15, - VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR = 16, - VK_BLEND_FACTOR_SRC1_ALPHA = 17, - VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA = 18, - VK_BLEND_FACTOR_BEGIN_RANGE = VK_BLEND_FACTOR_ZERO, - VK_BLEND_FACTOR_END_RANGE = VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA, - VK_BLEND_FACTOR_RANGE_SIZE = (VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA - VK_BLEND_FACTOR_ZERO + 1), - VK_BLEND_FACTOR_MAX_ENUM = 0x7FFFFFFF -} VkBlendFactor; - -typedef enum VkBlendOp { - VK_BLEND_OP_ADD = 0, - VK_BLEND_OP_SUBTRACT = 1, - VK_BLEND_OP_REVERSE_SUBTRACT = 2, - VK_BLEND_OP_MIN = 3, - VK_BLEND_OP_MAX = 4, - VK_BLEND_OP_BEGIN_RANGE = VK_BLEND_OP_ADD, - VK_BLEND_OP_END_RANGE = VK_BLEND_OP_MAX, - VK_BLEND_OP_RANGE_SIZE = (VK_BLEND_OP_MAX - VK_BLEND_OP_ADD + 1), - VK_BLEND_OP_MAX_ENUM = 0x7FFFFFFF -} VkBlendOp; - -typedef enum VkDynamicState { - VK_DYNAMIC_STATE_VIEWPORT = 0, - VK_DYNAMIC_STATE_SCISSOR = 1, - VK_DYNAMIC_STATE_LINE_WIDTH = 2, - VK_DYNAMIC_STATE_DEPTH_BIAS = 3, - VK_DYNAMIC_STATE_BLEND_CONSTANTS = 4, - VK_DYNAMIC_STATE_DEPTH_BOUNDS = 5, - VK_DYNAMIC_STATE_STENCIL_COMPARE_MASK = 6, - VK_DYNAMIC_STATE_STENCIL_WRITE_MASK = 7, - VK_DYNAMIC_STATE_STENCIL_REFERENCE = 8, - VK_DYNAMIC_STATE_BEGIN_RANGE = VK_DYNAMIC_STATE_VIEWPORT, - VK_DYNAMIC_STATE_END_RANGE = VK_DYNAMIC_STATE_STENCIL_REFERENCE, - VK_DYNAMIC_STATE_RANGE_SIZE = (VK_DYNAMIC_STATE_STENCIL_REFERENCE - VK_DYNAMIC_STATE_VIEWPORT + 1), - VK_DYNAMIC_STATE_MAX_ENUM = 0x7FFFFFFF -} VkDynamicState; - -typedef enum VkFilter { - VK_FILTER_NEAREST = 0, - VK_FILTER_LINEAR = 1, - VK_FILTER_CUBIC_IMG = 1000015000, - VK_FILTER_BEGIN_RANGE = VK_FILTER_NEAREST, - VK_FILTER_END_RANGE = VK_FILTER_LINEAR, - VK_FILTER_RANGE_SIZE = (VK_FILTER_LINEAR - VK_FILTER_NEAREST + 1), - VK_FILTER_MAX_ENUM = 0x7FFFFFFF -} VkFilter; - -typedef enum VkSamplerMipmapMode { - VK_SAMPLER_MIPMAP_MODE_NEAREST = 0, - VK_SAMPLER_MIPMAP_MODE_LINEAR = 1, - VK_SAMPLER_MIPMAP_MODE_BEGIN_RANGE = VK_SAMPLER_MIPMAP_MODE_NEAREST, - VK_SAMPLER_MIPMAP_MODE_END_RANGE = VK_SAMPLER_MIPMAP_MODE_LINEAR, - VK_SAMPLER_MIPMAP_MODE_RANGE_SIZE = (VK_SAMPLER_MIPMAP_MODE_LINEAR - VK_SAMPLER_MIPMAP_MODE_NEAREST + 1), - VK_SAMPLER_MIPMAP_MODE_MAX_ENUM = 0x7FFFFFFF -} VkSamplerMipmapMode; - -typedef enum VkSamplerAddressMode { - VK_SAMPLER_ADDRESS_MODE_REPEAT = 0, - VK_SAMPLER_ADDRESS_MODE_MIRRORED_REPEAT = 1, - VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE = 2, - VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER = 3, - VK_SAMPLER_ADDRESS_MODE_MIRROR_CLAMP_TO_EDGE = 4, - VK_SAMPLER_ADDRESS_MODE_BEGIN_RANGE = VK_SAMPLER_ADDRESS_MODE_REPEAT, - VK_SAMPLER_ADDRESS_MODE_END_RANGE = VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER, - VK_SAMPLER_ADDRESS_MODE_RANGE_SIZE = (VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER - VK_SAMPLER_ADDRESS_MODE_REPEAT + 1), - VK_SAMPLER_ADDRESS_MODE_MAX_ENUM = 0x7FFFFFFF -} VkSamplerAddressMode; - -typedef enum VkBorderColor { - VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK = 0, - VK_BORDER_COLOR_INT_TRANSPARENT_BLACK = 1, - VK_BORDER_COLOR_FLOAT_OPAQUE_BLACK = 2, - VK_BORDER_COLOR_INT_OPAQUE_BLACK = 3, - VK_BORDER_COLOR_FLOAT_OPAQUE_WHITE = 4, - VK_BORDER_COLOR_INT_OPAQUE_WHITE = 5, - VK_BORDER_COLOR_BEGIN_RANGE = VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK, - VK_BORDER_COLOR_END_RANGE = VK_BORDER_COLOR_INT_OPAQUE_WHITE, - VK_BORDER_COLOR_RANGE_SIZE = (VK_BORDER_COLOR_INT_OPAQUE_WHITE - VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK + 1), - VK_BORDER_COLOR_MAX_ENUM = 0x7FFFFFFF -} VkBorderColor; - -typedef enum VkDescriptorType { - VK_DESCRIPTOR_TYPE_SAMPLER = 0, - VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER = 1, - VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE = 2, - VK_DESCRIPTOR_TYPE_STORAGE_IMAGE = 3, - VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER = 4, - VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER = 5, - VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER = 6, - VK_DESCRIPTOR_TYPE_STORAGE_BUFFER = 7, - VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC = 8, - VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC = 9, - VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT = 10, - VK_DESCRIPTOR_TYPE_BEGIN_RANGE = VK_DESCRIPTOR_TYPE_SAMPLER, - VK_DESCRIPTOR_TYPE_END_RANGE = VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT, - VK_DESCRIPTOR_TYPE_RANGE_SIZE = (VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT - VK_DESCRIPTOR_TYPE_SAMPLER + 1), - VK_DESCRIPTOR_TYPE_MAX_ENUM = 0x7FFFFFFF -} VkDescriptorType; - -typedef enum VkAttachmentLoadOp { - VK_ATTACHMENT_LOAD_OP_LOAD = 0, - VK_ATTACHMENT_LOAD_OP_CLEAR = 1, - VK_ATTACHMENT_LOAD_OP_DONT_CARE = 2, - VK_ATTACHMENT_LOAD_OP_BEGIN_RANGE = VK_ATTACHMENT_LOAD_OP_LOAD, - VK_ATTACHMENT_LOAD_OP_END_RANGE = VK_ATTACHMENT_LOAD_OP_DONT_CARE, - VK_ATTACHMENT_LOAD_OP_RANGE_SIZE = (VK_ATTACHMENT_LOAD_OP_DONT_CARE - VK_ATTACHMENT_LOAD_OP_LOAD + 1), - VK_ATTACHMENT_LOAD_OP_MAX_ENUM = 0x7FFFFFFF -} VkAttachmentLoadOp; - -typedef enum VkAttachmentStoreOp { - VK_ATTACHMENT_STORE_OP_STORE = 0, - VK_ATTACHMENT_STORE_OP_DONT_CARE = 1, - VK_ATTACHMENT_STORE_OP_BEGIN_RANGE = VK_ATTACHMENT_STORE_OP_STORE, - VK_ATTACHMENT_STORE_OP_END_RANGE = VK_ATTACHMENT_STORE_OP_DONT_CARE, - VK_ATTACHMENT_STORE_OP_RANGE_SIZE = (VK_ATTACHMENT_STORE_OP_DONT_CARE - VK_ATTACHMENT_STORE_OP_STORE + 1), - VK_ATTACHMENT_STORE_OP_MAX_ENUM = 0x7FFFFFFF -} VkAttachmentStoreOp; - -typedef enum VkPipelineBindPoint { - VK_PIPELINE_BIND_POINT_GRAPHICS = 0, - VK_PIPELINE_BIND_POINT_COMPUTE = 1, - VK_PIPELINE_BIND_POINT_BEGIN_RANGE = VK_PIPELINE_BIND_POINT_GRAPHICS, - VK_PIPELINE_BIND_POINT_END_RANGE = VK_PIPELINE_BIND_POINT_COMPUTE, - VK_PIPELINE_BIND_POINT_RANGE_SIZE = (VK_PIPELINE_BIND_POINT_COMPUTE - VK_PIPELINE_BIND_POINT_GRAPHICS + 1), - VK_PIPELINE_BIND_POINT_MAX_ENUM = 0x7FFFFFFF -} VkPipelineBindPoint; - -typedef enum VkCommandBufferLevel { - VK_COMMAND_BUFFER_LEVEL_PRIMARY = 0, - VK_COMMAND_BUFFER_LEVEL_SECONDARY = 1, - VK_COMMAND_BUFFER_LEVEL_BEGIN_RANGE = VK_COMMAND_BUFFER_LEVEL_PRIMARY, - VK_COMMAND_BUFFER_LEVEL_END_RANGE = VK_COMMAND_BUFFER_LEVEL_SECONDARY, - VK_COMMAND_BUFFER_LEVEL_RANGE_SIZE = (VK_COMMAND_BUFFER_LEVEL_SECONDARY - VK_COMMAND_BUFFER_LEVEL_PRIMARY + 1), - VK_COMMAND_BUFFER_LEVEL_MAX_ENUM = 0x7FFFFFFF -} VkCommandBufferLevel; - -typedef enum VkIndexType { - VK_INDEX_TYPE_UINT16 = 0, - VK_INDEX_TYPE_UINT32 = 1, - VK_INDEX_TYPE_BEGIN_RANGE = VK_INDEX_TYPE_UINT16, - VK_INDEX_TYPE_END_RANGE = VK_INDEX_TYPE_UINT32, - VK_INDEX_TYPE_RANGE_SIZE = (VK_INDEX_TYPE_UINT32 - VK_INDEX_TYPE_UINT16 + 1), - VK_INDEX_TYPE_MAX_ENUM = 0x7FFFFFFF -} VkIndexType; - -typedef enum VkSubpassContents { - VK_SUBPASS_CONTENTS_INLINE = 0, - VK_SUBPASS_CONTENTS_SECONDARY_COMMAND_BUFFERS = 1, - VK_SUBPASS_CONTENTS_BEGIN_RANGE = VK_SUBPASS_CONTENTS_INLINE, - VK_SUBPASS_CONTENTS_END_RANGE = VK_SUBPASS_CONTENTS_SECONDARY_COMMAND_BUFFERS, - VK_SUBPASS_CONTENTS_RANGE_SIZE = (VK_SUBPASS_CONTENTS_SECONDARY_COMMAND_BUFFERS - VK_SUBPASS_CONTENTS_INLINE + 1), - VK_SUBPASS_CONTENTS_MAX_ENUM = 0x7FFFFFFF -} VkSubpassContents; - -typedef VkFlags VkInstanceCreateFlags; - -typedef enum VkFormatFeatureFlagBits { - VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT = 0x00000001, - VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT = 0x00000002, - VK_FORMAT_FEATURE_STORAGE_IMAGE_ATOMIC_BIT = 0x00000004, - VK_FORMAT_FEATURE_UNIFORM_TEXEL_BUFFER_BIT = 0x00000008, - VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_BIT = 0x00000010, - VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_ATOMIC_BIT = 0x00000020, - VK_FORMAT_FEATURE_VERTEX_BUFFER_BIT = 0x00000040, - VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT = 0x00000080, - VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BLEND_BIT = 0x00000100, - VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT = 0x00000200, - VK_FORMAT_FEATURE_BLIT_SRC_BIT = 0x00000400, - VK_FORMAT_FEATURE_BLIT_DST_BIT = 0x00000800, - VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT = 0x00001000, - VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG = 0x00002000, - VK_FORMAT_FEATURE_TRANSFER_SRC_BIT_KHR = 0x00004000, - VK_FORMAT_FEATURE_TRANSFER_DST_BIT_KHR = 0x00008000, - VK_FORMAT_FEATURE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkFormatFeatureFlagBits; -typedef VkFlags VkFormatFeatureFlags; - -typedef enum VkImageUsageFlagBits { - VK_IMAGE_USAGE_TRANSFER_SRC_BIT = 0x00000001, - VK_IMAGE_USAGE_TRANSFER_DST_BIT = 0x00000002, - VK_IMAGE_USAGE_SAMPLED_BIT = 0x00000004, - VK_IMAGE_USAGE_STORAGE_BIT = 0x00000008, - VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT = 0x00000010, - VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT = 0x00000020, - VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT = 0x00000040, - VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT = 0x00000080, - VK_IMAGE_USAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkImageUsageFlagBits; -typedef VkFlags VkImageUsageFlags; - -typedef enum VkImageCreateFlagBits { - VK_IMAGE_CREATE_SPARSE_BINDING_BIT = 0x00000001, - VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT = 0x00000002, - VK_IMAGE_CREATE_SPARSE_ALIASED_BIT = 0x00000004, - VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT = 0x00000008, - VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT = 0x00000010, - VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT_KHR = 0x00000020, - VK_IMAGE_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkImageCreateFlagBits; -typedef VkFlags VkImageCreateFlags; - -typedef enum VkSampleCountFlagBits { - VK_SAMPLE_COUNT_1_BIT = 0x00000001, - VK_SAMPLE_COUNT_2_BIT = 0x00000002, - VK_SAMPLE_COUNT_4_BIT = 0x00000004, - VK_SAMPLE_COUNT_8_BIT = 0x00000008, - VK_SAMPLE_COUNT_16_BIT = 0x00000010, - VK_SAMPLE_COUNT_32_BIT = 0x00000020, - VK_SAMPLE_COUNT_64_BIT = 0x00000040, - VK_SAMPLE_COUNT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkSampleCountFlagBits; -typedef VkFlags VkSampleCountFlags; - -typedef enum VkQueueFlagBits { - VK_QUEUE_GRAPHICS_BIT = 0x00000001, - VK_QUEUE_COMPUTE_BIT = 0x00000002, - VK_QUEUE_TRANSFER_BIT = 0x00000004, - VK_QUEUE_SPARSE_BINDING_BIT = 0x00000008, - VK_QUEUE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkQueueFlagBits; -typedef VkFlags VkQueueFlags; - -typedef enum VkMemoryPropertyFlagBits { - VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT = 0x00000001, - VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT = 0x00000002, - VK_MEMORY_PROPERTY_HOST_COHERENT_BIT = 0x00000004, - VK_MEMORY_PROPERTY_HOST_CACHED_BIT = 0x00000008, - VK_MEMORY_PROPERTY_LAZILY_ALLOCATED_BIT = 0x00000010, - VK_MEMORY_PROPERTY_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkMemoryPropertyFlagBits; -typedef VkFlags VkMemoryPropertyFlags; - -typedef enum VkMemoryHeapFlagBits { - VK_MEMORY_HEAP_DEVICE_LOCAL_BIT = 0x00000001, - VK_MEMORY_HEAP_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkMemoryHeapFlagBits; -typedef VkFlags VkMemoryHeapFlags; -typedef VkFlags VkDeviceCreateFlags; -typedef VkFlags VkDeviceQueueCreateFlags; - -typedef enum VkPipelineStageFlagBits { - VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT = 0x00000001, - VK_PIPELINE_STAGE_DRAW_INDIRECT_BIT = 0x00000002, - VK_PIPELINE_STAGE_VERTEX_INPUT_BIT = 0x00000004, - VK_PIPELINE_STAGE_VERTEX_SHADER_BIT = 0x00000008, - VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT = 0x00000010, - VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT = 0x00000020, - VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT = 0x00000040, - VK_PIPELINE_STAGE_FRAGMENT_SHADER_BIT = 0x00000080, - VK_PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT = 0x00000100, - VK_PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT = 0x00000200, - VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT = 0x00000400, - VK_PIPELINE_STAGE_COMPUTE_SHADER_BIT = 0x00000800, - VK_PIPELINE_STAGE_TRANSFER_BIT = 0x00001000, - VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT = 0x00002000, - VK_PIPELINE_STAGE_HOST_BIT = 0x00004000, - VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT = 0x00008000, - VK_PIPELINE_STAGE_ALL_COMMANDS_BIT = 0x00010000, - VK_PIPELINE_STAGE_COMMAND_PROCESS_BIT_NVX = 0x00020000, - VK_PIPELINE_STAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkPipelineStageFlagBits; -typedef VkFlags VkPipelineStageFlags; -typedef VkFlags VkMemoryMapFlags; - -typedef enum VkImageAspectFlagBits { - VK_IMAGE_ASPECT_COLOR_BIT = 0x00000001, - VK_IMAGE_ASPECT_DEPTH_BIT = 0x00000002, - VK_IMAGE_ASPECT_STENCIL_BIT = 0x00000004, - VK_IMAGE_ASPECT_METADATA_BIT = 0x00000008, - VK_IMAGE_ASPECT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkImageAspectFlagBits; -typedef VkFlags VkImageAspectFlags; - -typedef enum VkSparseImageFormatFlagBits { - VK_SPARSE_IMAGE_FORMAT_SINGLE_MIPTAIL_BIT = 0x00000001, - VK_SPARSE_IMAGE_FORMAT_ALIGNED_MIP_SIZE_BIT = 0x00000002, - VK_SPARSE_IMAGE_FORMAT_NONSTANDARD_BLOCK_SIZE_BIT = 0x00000004, - VK_SPARSE_IMAGE_FORMAT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkSparseImageFormatFlagBits; -typedef VkFlags VkSparseImageFormatFlags; - -typedef enum VkSparseMemoryBindFlagBits { - VK_SPARSE_MEMORY_BIND_METADATA_BIT = 0x00000001, - VK_SPARSE_MEMORY_BIND_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkSparseMemoryBindFlagBits; -typedef VkFlags VkSparseMemoryBindFlags; - -typedef enum VkFenceCreateFlagBits { - VK_FENCE_CREATE_SIGNALED_BIT = 0x00000001, - VK_FENCE_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkFenceCreateFlagBits; -typedef VkFlags VkFenceCreateFlags; -typedef VkFlags VkSemaphoreCreateFlags; -typedef VkFlags VkEventCreateFlags; -typedef VkFlags VkQueryPoolCreateFlags; - -typedef enum VkQueryPipelineStatisticFlagBits { - VK_QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_VERTICES_BIT = 0x00000001, - VK_QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_PRIMITIVES_BIT = 0x00000002, - VK_QUERY_PIPELINE_STATISTIC_VERTEX_SHADER_INVOCATIONS_BIT = 0x00000004, - VK_QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_INVOCATIONS_BIT = 0x00000008, - VK_QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_PRIMITIVES_BIT = 0x00000010, - VK_QUERY_PIPELINE_STATISTIC_CLIPPING_INVOCATIONS_BIT = 0x00000020, - VK_QUERY_PIPELINE_STATISTIC_CLIPPING_PRIMITIVES_BIT = 0x00000040, - VK_QUERY_PIPELINE_STATISTIC_FRAGMENT_SHADER_INVOCATIONS_BIT = 0x00000080, - VK_QUERY_PIPELINE_STATISTIC_TESSELLATION_CONTROL_SHADER_PATCHES_BIT = 0x00000100, - VK_QUERY_PIPELINE_STATISTIC_TESSELLATION_EVALUATION_SHADER_INVOCATIONS_BIT = 0x00000200, - VK_QUERY_PIPELINE_STATISTIC_COMPUTE_SHADER_INVOCATIONS_BIT = 0x00000400, - VK_QUERY_PIPELINE_STATISTIC_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkQueryPipelineStatisticFlagBits; -typedef VkFlags VkQueryPipelineStatisticFlags; - -typedef enum VkQueryResultFlagBits { - VK_QUERY_RESULT_64_BIT = 0x00000001, - VK_QUERY_RESULT_WAIT_BIT = 0x00000002, - VK_QUERY_RESULT_WITH_AVAILABILITY_BIT = 0x00000004, - VK_QUERY_RESULT_PARTIAL_BIT = 0x00000008, - VK_QUERY_RESULT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkQueryResultFlagBits; -typedef VkFlags VkQueryResultFlags; - -typedef enum VkBufferCreateFlagBits { - VK_BUFFER_CREATE_SPARSE_BINDING_BIT = 0x00000001, - VK_BUFFER_CREATE_SPARSE_RESIDENCY_BIT = 0x00000002, - VK_BUFFER_CREATE_SPARSE_ALIASED_BIT = 0x00000004, - VK_BUFFER_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkBufferCreateFlagBits; -typedef VkFlags VkBufferCreateFlags; - -typedef enum VkBufferUsageFlagBits { - VK_BUFFER_USAGE_TRANSFER_SRC_BIT = 0x00000001, - VK_BUFFER_USAGE_TRANSFER_DST_BIT = 0x00000002, - VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT = 0x00000004, - VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT = 0x00000008, - VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT = 0x00000010, - VK_BUFFER_USAGE_STORAGE_BUFFER_BIT = 0x00000020, - VK_BUFFER_USAGE_INDEX_BUFFER_BIT = 0x00000040, - VK_BUFFER_USAGE_VERTEX_BUFFER_BIT = 0x00000080, - VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT = 0x00000100, - VK_BUFFER_USAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkBufferUsageFlagBits; -typedef VkFlags VkBufferUsageFlags; -typedef VkFlags VkBufferViewCreateFlags; -typedef VkFlags VkImageViewCreateFlags; -typedef VkFlags VkShaderModuleCreateFlags; -typedef VkFlags VkPipelineCacheCreateFlags; - -typedef enum VkPipelineCreateFlagBits { - VK_PIPELINE_CREATE_DISABLE_OPTIMIZATION_BIT = 0x00000001, - VK_PIPELINE_CREATE_ALLOW_DERIVATIVES_BIT = 0x00000002, - VK_PIPELINE_CREATE_DERIVATIVE_BIT = 0x00000004, - VK_PIPELINE_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkPipelineCreateFlagBits; -typedef VkFlags VkPipelineCreateFlags; -typedef VkFlags VkPipelineShaderStageCreateFlags; - -typedef enum VkShaderStageFlagBits { - VK_SHADER_STAGE_VERTEX_BIT = 0x00000001, - VK_SHADER_STAGE_TESSELLATION_CONTROL_BIT = 0x00000002, - VK_SHADER_STAGE_TESSELLATION_EVALUATION_BIT = 0x00000004, - VK_SHADER_STAGE_GEOMETRY_BIT = 0x00000008, - VK_SHADER_STAGE_FRAGMENT_BIT = 0x00000010, - VK_SHADER_STAGE_COMPUTE_BIT = 0x00000020, - VK_SHADER_STAGE_ALL_GRAPHICS = 0x0000001F, - VK_SHADER_STAGE_ALL = 0x7FFFFFFF, - VK_SHADER_STAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkShaderStageFlagBits; -typedef VkFlags VkPipelineVertexInputStateCreateFlags; -typedef VkFlags VkPipelineInputAssemblyStateCreateFlags; -typedef VkFlags VkPipelineTessellationStateCreateFlags; -typedef VkFlags VkPipelineViewportStateCreateFlags; -typedef VkFlags VkPipelineRasterizationStateCreateFlags; - -typedef enum VkCullModeFlagBits { - VK_CULL_MODE_NONE = 0, - VK_CULL_MODE_FRONT_BIT = 0x00000001, - VK_CULL_MODE_BACK_BIT = 0x00000002, - VK_CULL_MODE_FRONT_AND_BACK = 0x00000003, - VK_CULL_MODE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkCullModeFlagBits; -typedef VkFlags VkCullModeFlags; -typedef VkFlags VkPipelineMultisampleStateCreateFlags; -typedef VkFlags VkPipelineDepthStencilStateCreateFlags; -typedef VkFlags VkPipelineColorBlendStateCreateFlags; - -typedef enum VkColorComponentFlagBits { - VK_COLOR_COMPONENT_R_BIT = 0x00000001, - VK_COLOR_COMPONENT_G_BIT = 0x00000002, - VK_COLOR_COMPONENT_B_BIT = 0x00000004, - VK_COLOR_COMPONENT_A_BIT = 0x00000008, - VK_COLOR_COMPONENT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkColorComponentFlagBits; -typedef VkFlags VkColorComponentFlags; -typedef VkFlags VkPipelineDynamicStateCreateFlags; -typedef VkFlags VkPipelineLayoutCreateFlags; -typedef VkFlags VkShaderStageFlags; -typedef VkFlags VkSamplerCreateFlags; -typedef VkFlags VkDescriptorSetLayoutCreateFlags; - -typedef enum VkDescriptorPoolCreateFlagBits { - VK_DESCRIPTOR_POOL_CREATE_FREE_DESCRIPTOR_SET_BIT = 0x00000001, - VK_DESCRIPTOR_POOL_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkDescriptorPoolCreateFlagBits; -typedef VkFlags VkDescriptorPoolCreateFlags; -typedef VkFlags VkDescriptorPoolResetFlags; -typedef VkFlags VkFramebufferCreateFlags; -typedef VkFlags VkRenderPassCreateFlags; - -typedef enum VkAttachmentDescriptionFlagBits { - VK_ATTACHMENT_DESCRIPTION_MAY_ALIAS_BIT = 0x00000001, - VK_ATTACHMENT_DESCRIPTION_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkAttachmentDescriptionFlagBits; -typedef VkFlags VkAttachmentDescriptionFlags; -typedef VkFlags VkSubpassDescriptionFlags; - -typedef enum VkAccessFlagBits { - VK_ACCESS_INDIRECT_COMMAND_READ_BIT = 0x00000001, - VK_ACCESS_INDEX_READ_BIT = 0x00000002, - VK_ACCESS_VERTEX_ATTRIBUTE_READ_BIT = 0x00000004, - VK_ACCESS_UNIFORM_READ_BIT = 0x00000008, - VK_ACCESS_INPUT_ATTACHMENT_READ_BIT = 0x00000010, - VK_ACCESS_SHADER_READ_BIT = 0x00000020, - VK_ACCESS_SHADER_WRITE_BIT = 0x00000040, - VK_ACCESS_COLOR_ATTACHMENT_READ_BIT = 0x00000080, - VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT = 0x00000100, - VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_READ_BIT = 0x00000200, - VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT = 0x00000400, - VK_ACCESS_TRANSFER_READ_BIT = 0x00000800, - VK_ACCESS_TRANSFER_WRITE_BIT = 0x00001000, - VK_ACCESS_HOST_READ_BIT = 0x00002000, - VK_ACCESS_HOST_WRITE_BIT = 0x00004000, - VK_ACCESS_MEMORY_READ_BIT = 0x00008000, - VK_ACCESS_MEMORY_WRITE_BIT = 0x00010000, - VK_ACCESS_COMMAND_PROCESS_READ_BIT_NVX = 0x00020000, - VK_ACCESS_COMMAND_PROCESS_WRITE_BIT_NVX = 0x00040000, - VK_ACCESS_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkAccessFlagBits; -typedef VkFlags VkAccessFlags; - -typedef enum VkDependencyFlagBits { - VK_DEPENDENCY_BY_REGION_BIT = 0x00000001, - VK_DEPENDENCY_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkDependencyFlagBits; -typedef VkFlags VkDependencyFlags; - -typedef enum VkCommandPoolCreateFlagBits { - VK_COMMAND_POOL_CREATE_TRANSIENT_BIT = 0x00000001, - VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT = 0x00000002, - VK_COMMAND_POOL_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkCommandPoolCreateFlagBits; -typedef VkFlags VkCommandPoolCreateFlags; - -typedef enum VkCommandPoolResetFlagBits { - VK_COMMAND_POOL_RESET_RELEASE_RESOURCES_BIT = 0x00000001, - VK_COMMAND_POOL_RESET_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkCommandPoolResetFlagBits; -typedef VkFlags VkCommandPoolResetFlags; - -typedef enum VkCommandBufferUsageFlagBits { - VK_COMMAND_BUFFER_USAGE_ONE_TIME_SUBMIT_BIT = 0x00000001, - VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT = 0x00000002, - VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT = 0x00000004, - VK_COMMAND_BUFFER_USAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkCommandBufferUsageFlagBits; -typedef VkFlags VkCommandBufferUsageFlags; - -typedef enum VkQueryControlFlagBits { - VK_QUERY_CONTROL_PRECISE_BIT = 0x00000001, - VK_QUERY_CONTROL_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkQueryControlFlagBits; -typedef VkFlags VkQueryControlFlags; - -typedef enum VkCommandBufferResetFlagBits { - VK_COMMAND_BUFFER_RESET_RELEASE_RESOURCES_BIT = 0x00000001, - VK_COMMAND_BUFFER_RESET_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkCommandBufferResetFlagBits; -typedef VkFlags VkCommandBufferResetFlags; - -typedef enum VkStencilFaceFlagBits { - VK_STENCIL_FACE_FRONT_BIT = 0x00000001, - VK_STENCIL_FACE_BACK_BIT = 0x00000002, - VK_STENCIL_FRONT_AND_BACK = 0x00000003, - VK_STENCIL_FACE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF -} VkStencilFaceFlagBits; -typedef VkFlags VkStencilFaceFlags; - -typedef void* (VKAPI_PTR *PFN_vkAllocationFunction)( - void* pUserData, - size_t size, - size_t alignment, - VkSystemAllocationScope allocationScope); - -typedef void* (VKAPI_PTR *PFN_vkReallocationFunction)( - void* pUserData, - void* pOriginal, - size_t size, - size_t alignment, - VkSystemAllocationScope allocationScope); - -typedef void (VKAPI_PTR *PFN_vkFreeFunction)( - void* pUserData, - void* pMemory); - -typedef void (VKAPI_PTR *PFN_vkInternalAllocationNotification)( - void* pUserData, - size_t size, - VkInternalAllocationType allocationType, - VkSystemAllocationScope allocationScope); - -typedef void (VKAPI_PTR *PFN_vkInternalFreeNotification)( - void* pUserData, - size_t size, - VkInternalAllocationType allocationType, - VkSystemAllocationScope allocationScope); - -typedef void (VKAPI_PTR *PFN_vkVoidFunction)(void); - -typedef struct VkApplicationInfo { - VkStructureType sType; - const void* pNext; - const char* pApplicationName; - uint32_t applicationVersion; - const char* pEngineName; - uint32_t engineVersion; - uint32_t apiVersion; -} VkApplicationInfo; - -typedef struct VkInstanceCreateInfo { - VkStructureType sType; - const void* pNext; - VkInstanceCreateFlags flags; - const VkApplicationInfo* pApplicationInfo; - uint32_t enabledLayerCount; - const char* const* ppEnabledLayerNames; - uint32_t enabledExtensionCount; - const char* const* ppEnabledExtensionNames; -} VkInstanceCreateInfo; - -typedef struct VkAllocationCallbacks { - void* pUserData; - PFN_vkAllocationFunction pfnAllocation; - PFN_vkReallocationFunction pfnReallocation; - PFN_vkFreeFunction pfnFree; - PFN_vkInternalAllocationNotification pfnInternalAllocation; - PFN_vkInternalFreeNotification pfnInternalFree; -} VkAllocationCallbacks; - -typedef struct VkPhysicalDeviceFeatures { - VkBool32 robustBufferAccess; - VkBool32 fullDrawIndexUint32; - VkBool32 imageCubeArray; - VkBool32 independentBlend; - VkBool32 geometryShader; - VkBool32 tessellationShader; - VkBool32 sampleRateShading; - VkBool32 dualSrcBlend; - VkBool32 logicOp; - VkBool32 multiDrawIndirect; - VkBool32 drawIndirectFirstInstance; - VkBool32 depthClamp; - VkBool32 depthBiasClamp; - VkBool32 fillModeNonSolid; - VkBool32 depthBounds; - VkBool32 wideLines; - VkBool32 largePoints; - VkBool32 alphaToOne; - VkBool32 multiViewport; - VkBool32 samplerAnisotropy; - VkBool32 textureCompressionETC2; - VkBool32 textureCompressionASTC_LDR; - VkBool32 textureCompressionBC; - VkBool32 occlusionQueryPrecise; - VkBool32 pipelineStatisticsQuery; - VkBool32 vertexPipelineStoresAndAtomics; - VkBool32 fragmentStoresAndAtomics; - VkBool32 shaderTessellationAndGeometryPointSize; - VkBool32 shaderImageGatherExtended; - VkBool32 shaderStorageImageExtendedFormats; - VkBool32 shaderStorageImageMultisample; - VkBool32 shaderStorageImageReadWithoutFormat; - VkBool32 shaderStorageImageWriteWithoutFormat; - VkBool32 shaderUniformBufferArrayDynamicIndexing; - VkBool32 shaderSampledImageArrayDynamicIndexing; - VkBool32 shaderStorageBufferArrayDynamicIndexing; - VkBool32 shaderStorageImageArrayDynamicIndexing; - VkBool32 shaderClipDistance; - VkBool32 shaderCullDistance; - VkBool32 shaderFloat64; - VkBool32 shaderInt64; - VkBool32 shaderInt16; - VkBool32 shaderResourceResidency; - VkBool32 shaderResourceMinLod; - VkBool32 sparseBinding; - VkBool32 sparseResidencyBuffer; - VkBool32 sparseResidencyImage2D; - VkBool32 sparseResidencyImage3D; - VkBool32 sparseResidency2Samples; - VkBool32 sparseResidency4Samples; - VkBool32 sparseResidency8Samples; - VkBool32 sparseResidency16Samples; - VkBool32 sparseResidencyAliased; - VkBool32 variableMultisampleRate; - VkBool32 inheritedQueries; -} VkPhysicalDeviceFeatures; - -typedef struct VkFormatProperties { - VkFormatFeatureFlags linearTilingFeatures; - VkFormatFeatureFlags optimalTilingFeatures; - VkFormatFeatureFlags bufferFeatures; -} VkFormatProperties; - -typedef struct VkExtent3D { - uint32_t width; - uint32_t height; - uint32_t depth; -} VkExtent3D; - -typedef struct VkImageFormatProperties { - VkExtent3D maxExtent; - uint32_t maxMipLevels; - uint32_t maxArrayLayers; - VkSampleCountFlags sampleCounts; - VkDeviceSize maxResourceSize; -} VkImageFormatProperties; - -typedef struct VkPhysicalDeviceLimits { - uint32_t maxImageDimension1D; - uint32_t maxImageDimension2D; - uint32_t maxImageDimension3D; - uint32_t maxImageDimensionCube; - uint32_t maxImageArrayLayers; - uint32_t maxTexelBufferElements; - uint32_t maxUniformBufferRange; - uint32_t maxStorageBufferRange; - uint32_t maxPushConstantsSize; - uint32_t maxMemoryAllocationCount; - uint32_t maxSamplerAllocationCount; - VkDeviceSize bufferImageGranularity; - VkDeviceSize sparseAddressSpaceSize; - uint32_t maxBoundDescriptorSets; - uint32_t maxPerStageDescriptorSamplers; - uint32_t maxPerStageDescriptorUniformBuffers; - uint32_t maxPerStageDescriptorStorageBuffers; - uint32_t maxPerStageDescriptorSampledImages; - uint32_t maxPerStageDescriptorStorageImages; - uint32_t maxPerStageDescriptorInputAttachments; - uint32_t maxPerStageResources; - uint32_t maxDescriptorSetSamplers; - uint32_t maxDescriptorSetUniformBuffers; - uint32_t maxDescriptorSetUniformBuffersDynamic; - uint32_t maxDescriptorSetStorageBuffers; - uint32_t maxDescriptorSetStorageBuffersDynamic; - uint32_t maxDescriptorSetSampledImages; - uint32_t maxDescriptorSetStorageImages; - uint32_t maxDescriptorSetInputAttachments; - uint32_t maxVertexInputAttributes; - uint32_t maxVertexInputBindings; - uint32_t maxVertexInputAttributeOffset; - uint32_t maxVertexInputBindingStride; - uint32_t maxVertexOutputComponents; - uint32_t maxTessellationGenerationLevel; - uint32_t maxTessellationPatchSize; - uint32_t maxTessellationControlPerVertexInputComponents; - uint32_t maxTessellationControlPerVertexOutputComponents; - uint32_t maxTessellationControlPerPatchOutputComponents; - uint32_t maxTessellationControlTotalOutputComponents; - uint32_t maxTessellationEvaluationInputComponents; - uint32_t maxTessellationEvaluationOutputComponents; - uint32_t maxGeometryShaderInvocations; - uint32_t maxGeometryInputComponents; - uint32_t maxGeometryOutputComponents; - uint32_t maxGeometryOutputVertices; - uint32_t maxGeometryTotalOutputComponents; - uint32_t maxFragmentInputComponents; - uint32_t maxFragmentOutputAttachments; - uint32_t maxFragmentDualSrcAttachments; - uint32_t maxFragmentCombinedOutputResources; - uint32_t maxComputeSharedMemorySize; - uint32_t maxComputeWorkGroupCount[3]; - uint32_t maxComputeWorkGroupInvocations; - uint32_t maxComputeWorkGroupSize[3]; - uint32_t subPixelPrecisionBits; - uint32_t subTexelPrecisionBits; - uint32_t mipmapPrecisionBits; - uint32_t maxDrawIndexedIndexValue; - uint32_t maxDrawIndirectCount; - float maxSamplerLodBias; - float maxSamplerAnisotropy; - uint32_t maxViewports; - uint32_t maxViewportDimensions[2]; - float viewportBoundsRange[2]; - uint32_t viewportSubPixelBits; - size_t minMemoryMapAlignment; - VkDeviceSize minTexelBufferOffsetAlignment; - VkDeviceSize minUniformBufferOffsetAlignment; - VkDeviceSize minStorageBufferOffsetAlignment; - int32_t minTexelOffset; - uint32_t maxTexelOffset; - int32_t minTexelGatherOffset; - uint32_t maxTexelGatherOffset; - float minInterpolationOffset; - float maxInterpolationOffset; - uint32_t subPixelInterpolationOffsetBits; - uint32_t maxFramebufferWidth; - uint32_t maxFramebufferHeight; - uint32_t maxFramebufferLayers; - VkSampleCountFlags framebufferColorSampleCounts; - VkSampleCountFlags framebufferDepthSampleCounts; - VkSampleCountFlags framebufferStencilSampleCounts; - VkSampleCountFlags framebufferNoAttachmentsSampleCounts; - uint32_t maxColorAttachments; - VkSampleCountFlags sampledImageColorSampleCounts; - VkSampleCountFlags sampledImageIntegerSampleCounts; - VkSampleCountFlags sampledImageDepthSampleCounts; - VkSampleCountFlags sampledImageStencilSampleCounts; - VkSampleCountFlags storageImageSampleCounts; - uint32_t maxSampleMaskWords; - VkBool32 timestampComputeAndGraphics; - float timestampPeriod; - uint32_t maxClipDistances; - uint32_t maxCullDistances; - uint32_t maxCombinedClipAndCullDistances; - uint32_t discreteQueuePriorities; - float pointSizeRange[2]; - float lineWidthRange[2]; - float pointSizeGranularity; - float lineWidthGranularity; - VkBool32 strictLines; - VkBool32 standardSampleLocations; - VkDeviceSize optimalBufferCopyOffsetAlignment; - VkDeviceSize optimalBufferCopyRowPitchAlignment; - VkDeviceSize nonCoherentAtomSize; -} VkPhysicalDeviceLimits; - -typedef struct VkPhysicalDeviceSparseProperties { - VkBool32 residencyStandard2DBlockShape; - VkBool32 residencyStandard2DMultisampleBlockShape; - VkBool32 residencyStandard3DBlockShape; - VkBool32 residencyAlignedMipSize; - VkBool32 residencyNonResidentStrict; -} VkPhysicalDeviceSparseProperties; - -typedef struct VkPhysicalDeviceProperties { - uint32_t apiVersion; - uint32_t driverVersion; - uint32_t vendorID; - uint32_t deviceID; - VkPhysicalDeviceType deviceType; - char deviceName[VK_MAX_PHYSICAL_DEVICE_NAME_SIZE]; - uint8_t pipelineCacheUUID[VK_UUID_SIZE]; - VkPhysicalDeviceLimits limits; - VkPhysicalDeviceSparseProperties sparseProperties; -} VkPhysicalDeviceProperties; - -typedef struct VkQueueFamilyProperties { - VkQueueFlags queueFlags; - uint32_t queueCount; - uint32_t timestampValidBits; - VkExtent3D minImageTransferGranularity; -} VkQueueFamilyProperties; - -typedef struct VkMemoryType { - VkMemoryPropertyFlags propertyFlags; - uint32_t heapIndex; -} VkMemoryType; - -typedef struct VkMemoryHeap { - VkDeviceSize size; - VkMemoryHeapFlags flags; -} VkMemoryHeap; - -typedef struct VkPhysicalDeviceMemoryProperties { - uint32_t memoryTypeCount; - VkMemoryType memoryTypes[VK_MAX_MEMORY_TYPES]; - uint32_t memoryHeapCount; - VkMemoryHeap memoryHeaps[VK_MAX_MEMORY_HEAPS]; -} VkPhysicalDeviceMemoryProperties; - -typedef struct VkDeviceQueueCreateInfo { - VkStructureType sType; - const void* pNext; - VkDeviceQueueCreateFlags flags; - uint32_t queueFamilyIndex; - uint32_t queueCount; - const float* pQueuePriorities; -} VkDeviceQueueCreateInfo; - -typedef struct VkDeviceCreateInfo { - VkStructureType sType; - const void* pNext; - VkDeviceCreateFlags flags; - uint32_t queueCreateInfoCount; - const VkDeviceQueueCreateInfo* pQueueCreateInfos; - uint32_t enabledLayerCount; - const char* const* ppEnabledLayerNames; - uint32_t enabledExtensionCount; - const char* const* ppEnabledExtensionNames; - const VkPhysicalDeviceFeatures* pEnabledFeatures; -} VkDeviceCreateInfo; - -typedef struct VkExtensionProperties { - char extensionName[VK_MAX_EXTENSION_NAME_SIZE]; - uint32_t specVersion; -} VkExtensionProperties; - -typedef struct VkLayerProperties { - char layerName[VK_MAX_EXTENSION_NAME_SIZE]; - uint32_t specVersion; - uint32_t implementationVersion; - char description[VK_MAX_DESCRIPTION_SIZE]; -} VkLayerProperties; - -typedef struct VkSubmitInfo { - VkStructureType sType; - const void* pNext; - uint32_t waitSemaphoreCount; - const VkSemaphore* pWaitSemaphores; - const VkPipelineStageFlags* pWaitDstStageMask; - uint32_t commandBufferCount; - const VkCommandBuffer* pCommandBuffers; - uint32_t signalSemaphoreCount; - const VkSemaphore* pSignalSemaphores; -} VkSubmitInfo; - -typedef struct VkMemoryAllocateInfo { - VkStructureType sType; - const void* pNext; - VkDeviceSize allocationSize; - uint32_t memoryTypeIndex; -} VkMemoryAllocateInfo; - -typedef struct VkMappedMemoryRange { - VkStructureType sType; - const void* pNext; - VkDeviceMemory memory; - VkDeviceSize offset; - VkDeviceSize size; -} VkMappedMemoryRange; - -typedef struct VkMemoryRequirements { - VkDeviceSize size; - VkDeviceSize alignment; - uint32_t memoryTypeBits; -} VkMemoryRequirements; - -typedef struct VkSparseImageFormatProperties { - VkImageAspectFlags aspectMask; - VkExtent3D imageGranularity; - VkSparseImageFormatFlags flags; -} VkSparseImageFormatProperties; - -typedef struct VkSparseImageMemoryRequirements { - VkSparseImageFormatProperties formatProperties; - uint32_t imageMipTailFirstLod; - VkDeviceSize imageMipTailSize; - VkDeviceSize imageMipTailOffset; - VkDeviceSize imageMipTailStride; -} VkSparseImageMemoryRequirements; - -typedef struct VkSparseMemoryBind { - VkDeviceSize resourceOffset; - VkDeviceSize size; - VkDeviceMemory memory; - VkDeviceSize memoryOffset; - VkSparseMemoryBindFlags flags; -} VkSparseMemoryBind; - -typedef struct VkSparseBufferMemoryBindInfo { - VkBuffer buffer; - uint32_t bindCount; - const VkSparseMemoryBind* pBinds; -} VkSparseBufferMemoryBindInfo; - -typedef struct VkSparseImageOpaqueMemoryBindInfo { - VkImage image; - uint32_t bindCount; - const VkSparseMemoryBind* pBinds; -} VkSparseImageOpaqueMemoryBindInfo; - -typedef struct VkImageSubresource { - VkImageAspectFlags aspectMask; - uint32_t mipLevel; - uint32_t arrayLayer; -} VkImageSubresource; - -typedef struct VkOffset3D { - int32_t x; - int32_t y; - int32_t z; -} VkOffset3D; - -typedef struct VkSparseImageMemoryBind { - VkImageSubresource subresource; - VkOffset3D offset; - VkExtent3D extent; - VkDeviceMemory memory; - VkDeviceSize memoryOffset; - VkSparseMemoryBindFlags flags; -} VkSparseImageMemoryBind; - -typedef struct VkSparseImageMemoryBindInfo { - VkImage image; - uint32_t bindCount; - const VkSparseImageMemoryBind* pBinds; -} VkSparseImageMemoryBindInfo; - -typedef struct VkBindSparseInfo { - VkStructureType sType; - const void* pNext; - uint32_t waitSemaphoreCount; - const VkSemaphore* pWaitSemaphores; - uint32_t bufferBindCount; - const VkSparseBufferMemoryBindInfo* pBufferBinds; - uint32_t imageOpaqueBindCount; - const VkSparseImageOpaqueMemoryBindInfo* pImageOpaqueBinds; - uint32_t imageBindCount; - const VkSparseImageMemoryBindInfo* pImageBinds; - uint32_t signalSemaphoreCount; - const VkSemaphore* pSignalSemaphores; -} VkBindSparseInfo; - -typedef struct VkFenceCreateInfo { - VkStructureType sType; - const void* pNext; - VkFenceCreateFlags flags; -} VkFenceCreateInfo; - -typedef struct VkSemaphoreCreateInfo { - VkStructureType sType; - const void* pNext; - VkSemaphoreCreateFlags flags; -} VkSemaphoreCreateInfo; - -typedef struct VkEventCreateInfo { - VkStructureType sType; - const void* pNext; - VkEventCreateFlags flags; -} VkEventCreateInfo; - -typedef struct VkQueryPoolCreateInfo { - VkStructureType sType; - const void* pNext; - VkQueryPoolCreateFlags flags; - VkQueryType queryType; - uint32_t queryCount; - VkQueryPipelineStatisticFlags pipelineStatistics; -} VkQueryPoolCreateInfo; - -typedef struct VkBufferCreateInfo { - VkStructureType sType; - const void* pNext; - VkBufferCreateFlags flags; - VkDeviceSize size; - VkBufferUsageFlags usage; - VkSharingMode sharingMode; - uint32_t queueFamilyIndexCount; - const uint32_t* pQueueFamilyIndices; -} VkBufferCreateInfo; - -typedef struct VkBufferViewCreateInfo { - VkStructureType sType; - const void* pNext; - VkBufferViewCreateFlags flags; - VkBuffer buffer; - VkFormat format; - VkDeviceSize offset; - VkDeviceSize range; -} VkBufferViewCreateInfo; - -typedef struct VkImageCreateInfo { - VkStructureType sType; - const void* pNext; - VkImageCreateFlags flags; - VkImageType imageType; - VkFormat format; - VkExtent3D extent; - uint32_t mipLevels; - uint32_t arrayLayers; - VkSampleCountFlagBits samples; - VkImageTiling tiling; - VkImageUsageFlags usage; - VkSharingMode sharingMode; - uint32_t queueFamilyIndexCount; - const uint32_t* pQueueFamilyIndices; - VkImageLayout initialLayout; -} VkImageCreateInfo; - -typedef struct VkSubresourceLayout { - VkDeviceSize offset; - VkDeviceSize size; - VkDeviceSize rowPitch; - VkDeviceSize arrayPitch; - VkDeviceSize depthPitch; -} VkSubresourceLayout; - -typedef struct VkComponentMapping { - VkComponentSwizzle r; - VkComponentSwizzle g; - VkComponentSwizzle b; - VkComponentSwizzle a; -} VkComponentMapping; - -typedef struct VkImageSubresourceRange { - VkImageAspectFlags aspectMask; - uint32_t baseMipLevel; - uint32_t levelCount; - uint32_t baseArrayLayer; - uint32_t layerCount; -} VkImageSubresourceRange; - -typedef struct VkImageViewCreateInfo { - VkStructureType sType; - const void* pNext; - VkImageViewCreateFlags flags; - VkImage image; - VkImageViewType viewType; - VkFormat format; - VkComponentMapping components; - VkImageSubresourceRange subresourceRange; -} VkImageViewCreateInfo; - -typedef struct VkShaderModuleCreateInfo { - VkStructureType sType; - const void* pNext; - VkShaderModuleCreateFlags flags; - size_t codeSize; - const uint32_t* pCode; -} VkShaderModuleCreateInfo; - -typedef struct VkPipelineCacheCreateInfo { - VkStructureType sType; - const void* pNext; - VkPipelineCacheCreateFlags flags; - size_t initialDataSize; - const void* pInitialData; -} VkPipelineCacheCreateInfo; - -typedef struct VkSpecializationMapEntry { - uint32_t constantID; - uint32_t offset; - size_t size; -} VkSpecializationMapEntry; - -typedef struct VkSpecializationInfo { - uint32_t mapEntryCount; - const VkSpecializationMapEntry* pMapEntries; - size_t dataSize; - const void* pData; -} VkSpecializationInfo; - -typedef struct VkPipelineShaderStageCreateInfo { - VkStructureType sType; - const void* pNext; - VkPipelineShaderStageCreateFlags flags; - VkShaderStageFlagBits stage; - VkShaderModule module; - const char* pName; - const VkSpecializationInfo* pSpecializationInfo; -} VkPipelineShaderStageCreateInfo; - -typedef struct VkVertexInputBindingDescription { - uint32_t binding; - uint32_t stride; - VkVertexInputRate inputRate; -} VkVertexInputBindingDescription; - -typedef struct VkVertexInputAttributeDescription { - uint32_t location; - uint32_t binding; - VkFormat format; - uint32_t offset; -} VkVertexInputAttributeDescription; - -typedef struct VkPipelineVertexInputStateCreateInfo { - VkStructureType sType; - const void* pNext; - VkPipelineVertexInputStateCreateFlags flags; - uint32_t vertexBindingDescriptionCount; - const VkVertexInputBindingDescription* pVertexBindingDescriptions; - uint32_t vertexAttributeDescriptionCount; - const VkVertexInputAttributeDescription* pVertexAttributeDescriptions; -} VkPipelineVertexInputStateCreateInfo; - -typedef struct VkPipelineInputAssemblyStateCreateInfo { - VkStructureType sType; - const void* pNext; - VkPipelineInputAssemblyStateCreateFlags flags; - VkPrimitiveTopology topology; - VkBool32 primitiveRestartEnable; -} VkPipelineInputAssemblyStateCreateInfo; - -typedef struct VkPipelineTessellationStateCreateInfo { - VkStructureType sType; - const void* pNext; - VkPipelineTessellationStateCreateFlags flags; - uint32_t patchControlPoints; -} VkPipelineTessellationStateCreateInfo; - -typedef struct VkViewport { - float x; - float y; - float width; - float height; - float minDepth; - float maxDepth; -} VkViewport; - -typedef struct VkOffset2D { - int32_t x; - int32_t y; -} VkOffset2D; - -typedef struct VkExtent2D { - uint32_t width; - uint32_t height; -} VkExtent2D; - -typedef struct VkRect2D { - VkOffset2D offset; - VkExtent2D extent; -} VkRect2D; - -typedef struct VkPipelineViewportStateCreateInfo { - VkStructureType sType; - const void* pNext; - VkPipelineViewportStateCreateFlags flags; - uint32_t viewportCount; - const VkViewport* pViewports; - uint32_t scissorCount; - const VkRect2D* pScissors; -} VkPipelineViewportStateCreateInfo; - -typedef struct VkPipelineRasterizationStateCreateInfo { - VkStructureType sType; - const void* pNext; - VkPipelineRasterizationStateCreateFlags flags; - VkBool32 depthClampEnable; - VkBool32 rasterizerDiscardEnable; - VkPolygonMode polygonMode; - VkCullModeFlags cullMode; - VkFrontFace frontFace; - VkBool32 depthBiasEnable; - float depthBiasConstantFactor; - float depthBiasClamp; - float depthBiasSlopeFactor; - float lineWidth; -} VkPipelineRasterizationStateCreateInfo; - -typedef struct VkPipelineMultisampleStateCreateInfo { - VkStructureType sType; - const void* pNext; - VkPipelineMultisampleStateCreateFlags flags; - VkSampleCountFlagBits rasterizationSamples; - VkBool32 sampleShadingEnable; - float minSampleShading; - const VkSampleMask* pSampleMask; - VkBool32 alphaToCoverageEnable; - VkBool32 alphaToOneEnable; -} VkPipelineMultisampleStateCreateInfo; - -typedef struct VkStencilOpState { - VkStencilOp failOp; - VkStencilOp passOp; - VkStencilOp depthFailOp; - VkCompareOp compareOp; - uint32_t compareMask; - uint32_t writeMask; - uint32_t reference; -} VkStencilOpState; - -typedef struct VkPipelineDepthStencilStateCreateInfo { - VkStructureType sType; - const void* pNext; - VkPipelineDepthStencilStateCreateFlags flags; - VkBool32 depthTestEnable; - VkBool32 depthWriteEnable; - VkCompareOp depthCompareOp; - VkBool32 depthBoundsTestEnable; - VkBool32 stencilTestEnable; - VkStencilOpState front; - VkStencilOpState back; - float minDepthBounds; - float maxDepthBounds; -} VkPipelineDepthStencilStateCreateInfo; - -typedef struct VkPipelineColorBlendAttachmentState { - VkBool32 blendEnable; - VkBlendFactor srcColorBlendFactor; - VkBlendFactor dstColorBlendFactor; - VkBlendOp colorBlendOp; - VkBlendFactor srcAlphaBlendFactor; - VkBlendFactor dstAlphaBlendFactor; - VkBlendOp alphaBlendOp; - VkColorComponentFlags colorWriteMask; -} VkPipelineColorBlendAttachmentState; - -typedef struct VkPipelineColorBlendStateCreateInfo { - VkStructureType sType; - const void* pNext; - VkPipelineColorBlendStateCreateFlags flags; - VkBool32 logicOpEnable; - VkLogicOp logicOp; - uint32_t attachmentCount; - const VkPipelineColorBlendAttachmentState* pAttachments; - float blendConstants[4]; -} VkPipelineColorBlendStateCreateInfo; - -typedef struct VkPipelineDynamicStateCreateInfo { - VkStructureType sType; - const void* pNext; - VkPipelineDynamicStateCreateFlags flags; - uint32_t dynamicStateCount; - const VkDynamicState* pDynamicStates; -} VkPipelineDynamicStateCreateInfo; - -typedef struct VkGraphicsPipelineCreateInfo { - VkStructureType sType; - const void* pNext; - VkPipelineCreateFlags flags; - uint32_t stageCount; - const VkPipelineShaderStageCreateInfo* pStages; - const VkPipelineVertexInputStateCreateInfo* pVertexInputState; - const VkPipelineInputAssemblyStateCreateInfo* pInputAssemblyState; - const VkPipelineTessellationStateCreateInfo* pTessellationState; - const VkPipelineViewportStateCreateInfo* pViewportState; - const VkPipelineRasterizationStateCreateInfo* pRasterizationState; - const VkPipelineMultisampleStateCreateInfo* pMultisampleState; - const VkPipelineDepthStencilStateCreateInfo* pDepthStencilState; - const VkPipelineColorBlendStateCreateInfo* pColorBlendState; - const VkPipelineDynamicStateCreateInfo* pDynamicState; - VkPipelineLayout layout; - VkRenderPass renderPass; - uint32_t subpass; - VkPipeline basePipelineHandle; - int32_t basePipelineIndex; -} VkGraphicsPipelineCreateInfo; - -typedef struct VkComputePipelineCreateInfo { - VkStructureType sType; - const void* pNext; - VkPipelineCreateFlags flags; - VkPipelineShaderStageCreateInfo stage; - VkPipelineLayout layout; - VkPipeline basePipelineHandle; - int32_t basePipelineIndex; -} VkComputePipelineCreateInfo; - -typedef struct VkPushConstantRange { - VkShaderStageFlags stageFlags; - uint32_t offset; - uint32_t size; -} VkPushConstantRange; - -typedef struct VkPipelineLayoutCreateInfo { - VkStructureType sType; - const void* pNext; - VkPipelineLayoutCreateFlags flags; - uint32_t setLayoutCount; - const VkDescriptorSetLayout* pSetLayouts; - uint32_t pushConstantRangeCount; - const VkPushConstantRange* pPushConstantRanges; -} VkPipelineLayoutCreateInfo; - -typedef struct VkSamplerCreateInfo { - VkStructureType sType; - const void* pNext; - VkSamplerCreateFlags flags; - VkFilter magFilter; - VkFilter minFilter; - VkSamplerMipmapMode mipmapMode; - VkSamplerAddressMode addressModeU; - VkSamplerAddressMode addressModeV; - VkSamplerAddressMode addressModeW; - float mipLodBias; - VkBool32 anisotropyEnable; - float maxAnisotropy; - VkBool32 compareEnable; - VkCompareOp compareOp; - float minLod; - float maxLod; - VkBorderColor borderColor; - VkBool32 unnormalizedCoordinates; -} VkSamplerCreateInfo; - -typedef struct VkDescriptorSetLayoutBinding { - uint32_t binding; - VkDescriptorType descriptorType; - uint32_t descriptorCount; - VkShaderStageFlags stageFlags; - const VkSampler* pImmutableSamplers; -} VkDescriptorSetLayoutBinding; - -typedef struct VkDescriptorSetLayoutCreateInfo { - VkStructureType sType; - const void* pNext; - VkDescriptorSetLayoutCreateFlags flags; - uint32_t bindingCount; - const VkDescriptorSetLayoutBinding* pBindings; -} VkDescriptorSetLayoutCreateInfo; - -typedef struct VkDescriptorPoolSize { - VkDescriptorType type; - uint32_t descriptorCount; -} VkDescriptorPoolSize; - -typedef struct VkDescriptorPoolCreateInfo { - VkStructureType sType; - const void* pNext; - VkDescriptorPoolCreateFlags flags; - uint32_t maxSets; - uint32_t poolSizeCount; - const VkDescriptorPoolSize* pPoolSizes; -} VkDescriptorPoolCreateInfo; - -typedef struct VkDescriptorSetAllocateInfo { - VkStructureType sType; - const void* pNext; - VkDescriptorPool descriptorPool; - uint32_t descriptorSetCount; - const VkDescriptorSetLayout* pSetLayouts; -} VkDescriptorSetAllocateInfo; - -typedef struct VkDescriptorImageInfo { - VkSampler sampler; - VkImageView imageView; - VkImageLayout imageLayout; -} VkDescriptorImageInfo; - -typedef struct VkDescriptorBufferInfo { - VkBuffer buffer; - VkDeviceSize offset; - VkDeviceSize range; -} VkDescriptorBufferInfo; - -typedef struct VkWriteDescriptorSet { - VkStructureType sType; - const void* pNext; - VkDescriptorSet dstSet; - uint32_t dstBinding; - uint32_t dstArrayElement; - uint32_t descriptorCount; - VkDescriptorType descriptorType; - const VkDescriptorImageInfo* pImageInfo; - const VkDescriptorBufferInfo* pBufferInfo; - const VkBufferView* pTexelBufferView; -} VkWriteDescriptorSet; - -typedef struct VkCopyDescriptorSet { - VkStructureType sType; - const void* pNext; - VkDescriptorSet srcSet; - uint32_t srcBinding; - uint32_t srcArrayElement; - VkDescriptorSet dstSet; - uint32_t dstBinding; - uint32_t dstArrayElement; - uint32_t descriptorCount; -} VkCopyDescriptorSet; - -typedef struct VkFramebufferCreateInfo { - VkStructureType sType; - const void* pNext; - VkFramebufferCreateFlags flags; - VkRenderPass renderPass; - uint32_t attachmentCount; - const VkImageView* pAttachments; - uint32_t width; - uint32_t height; - uint32_t layers; -} VkFramebufferCreateInfo; - -typedef struct VkAttachmentDescription { - VkAttachmentDescriptionFlags flags; - VkFormat format; - VkSampleCountFlagBits samples; - VkAttachmentLoadOp loadOp; - VkAttachmentStoreOp storeOp; - VkAttachmentLoadOp stencilLoadOp; - VkAttachmentStoreOp stencilStoreOp; - VkImageLayout initialLayout; - VkImageLayout finalLayout; -} VkAttachmentDescription; - -typedef struct VkAttachmentReference { - uint32_t attachment; - VkImageLayout layout; -} VkAttachmentReference; - -typedef struct VkSubpassDescription { - VkSubpassDescriptionFlags flags; - VkPipelineBindPoint pipelineBindPoint; - uint32_t inputAttachmentCount; - const VkAttachmentReference* pInputAttachments; - uint32_t colorAttachmentCount; - const VkAttachmentReference* pColorAttachments; - const VkAttachmentReference* pResolveAttachments; - const VkAttachmentReference* pDepthStencilAttachment; - uint32_t preserveAttachmentCount; - const uint32_t* pPreserveAttachments; -} VkSubpassDescription; - -typedef struct VkSubpassDependency { - uint32_t srcSubpass; - uint32_t dstSubpass; - VkPipelineStageFlags srcStageMask; - VkPipelineStageFlags dstStageMask; - VkAccessFlags srcAccessMask; - VkAccessFlags dstAccessMask; - VkDependencyFlags dependencyFlags; -} VkSubpassDependency; - -typedef struct VkRenderPassCreateInfo { - VkStructureType sType; - const void* pNext; - VkRenderPassCreateFlags flags; - uint32_t attachmentCount; - const VkAttachmentDescription* pAttachments; - uint32_t subpassCount; - const VkSubpassDescription* pSubpasses; - uint32_t dependencyCount; - const VkSubpassDependency* pDependencies; -} VkRenderPassCreateInfo; - -typedef struct VkCommandPoolCreateInfo { - VkStructureType sType; - const void* pNext; - VkCommandPoolCreateFlags flags; - uint32_t queueFamilyIndex; -} VkCommandPoolCreateInfo; - -typedef struct VkCommandBufferAllocateInfo { - VkStructureType sType; - const void* pNext; - VkCommandPool commandPool; - VkCommandBufferLevel level; - uint32_t commandBufferCount; -} VkCommandBufferAllocateInfo; - -typedef struct VkCommandBufferInheritanceInfo { - VkStructureType sType; - const void* pNext; - VkRenderPass renderPass; - uint32_t subpass; - VkFramebuffer framebuffer; - VkBool32 occlusionQueryEnable; - VkQueryControlFlags queryFlags; - VkQueryPipelineStatisticFlags pipelineStatistics; -} VkCommandBufferInheritanceInfo; - -typedef struct VkCommandBufferBeginInfo { - VkStructureType sType; - const void* pNext; - VkCommandBufferUsageFlags flags; - const VkCommandBufferInheritanceInfo* pInheritanceInfo; -} VkCommandBufferBeginInfo; - -typedef struct VkBufferCopy { - VkDeviceSize srcOffset; - VkDeviceSize dstOffset; - VkDeviceSize size; -} VkBufferCopy; - -typedef struct VkImageSubresourceLayers { - VkImageAspectFlags aspectMask; - uint32_t mipLevel; - uint32_t baseArrayLayer; - uint32_t layerCount; -} VkImageSubresourceLayers; - -typedef struct VkImageCopy { - VkImageSubresourceLayers srcSubresource; - VkOffset3D srcOffset; - VkImageSubresourceLayers dstSubresource; - VkOffset3D dstOffset; - VkExtent3D extent; -} VkImageCopy; - -typedef struct VkImageBlit { - VkImageSubresourceLayers srcSubresource; - VkOffset3D srcOffsets[2]; - VkImageSubresourceLayers dstSubresource; - VkOffset3D dstOffsets[2]; -} VkImageBlit; - -typedef struct VkBufferImageCopy { - VkDeviceSize bufferOffset; - uint32_t bufferRowLength; - uint32_t bufferImageHeight; - VkImageSubresourceLayers imageSubresource; - VkOffset3D imageOffset; - VkExtent3D imageExtent; -} VkBufferImageCopy; - -typedef union VkClearColorValue { - float float32[4]; - int32_t int32[4]; - uint32_t uint32[4]; -} VkClearColorValue; - -typedef struct VkClearDepthStencilValue { - float depth; - uint32_t stencil; -} VkClearDepthStencilValue; - -typedef union VkClearValue { - VkClearColorValue color; - VkClearDepthStencilValue depthStencil; -} VkClearValue; - -typedef struct VkClearAttachment { - VkImageAspectFlags aspectMask; - uint32_t colorAttachment; - VkClearValue clearValue; -} VkClearAttachment; - -typedef struct VkClearRect { - VkRect2D rect; - uint32_t baseArrayLayer; - uint32_t layerCount; -} VkClearRect; - -typedef struct VkImageResolve { - VkImageSubresourceLayers srcSubresource; - VkOffset3D srcOffset; - VkImageSubresourceLayers dstSubresource; - VkOffset3D dstOffset; - VkExtent3D extent; -} VkImageResolve; - -typedef struct VkMemoryBarrier { - VkStructureType sType; - const void* pNext; - VkAccessFlags srcAccessMask; - VkAccessFlags dstAccessMask; -} VkMemoryBarrier; - -typedef struct VkBufferMemoryBarrier { - VkStructureType sType; - const void* pNext; - VkAccessFlags srcAccessMask; - VkAccessFlags dstAccessMask; - uint32_t srcQueueFamilyIndex; - uint32_t dstQueueFamilyIndex; - VkBuffer buffer; - VkDeviceSize offset; - VkDeviceSize size; -} VkBufferMemoryBarrier; - -typedef struct VkImageMemoryBarrier { - VkStructureType sType; - const void* pNext; - VkAccessFlags srcAccessMask; - VkAccessFlags dstAccessMask; - VkImageLayout oldLayout; - VkImageLayout newLayout; - uint32_t srcQueueFamilyIndex; - uint32_t dstQueueFamilyIndex; - VkImage image; - VkImageSubresourceRange subresourceRange; -} VkImageMemoryBarrier; - -typedef struct VkRenderPassBeginInfo { - VkStructureType sType; - const void* pNext; - VkRenderPass renderPass; - VkFramebuffer framebuffer; - VkRect2D renderArea; - uint32_t clearValueCount; - const VkClearValue* pClearValues; -} VkRenderPassBeginInfo; - -typedef struct VkDispatchIndirectCommand { - uint32_t x; - uint32_t y; - uint32_t z; -} VkDispatchIndirectCommand; - -typedef struct VkDrawIndexedIndirectCommand { - uint32_t indexCount; - uint32_t instanceCount; - uint32_t firstIndex; - int32_t vertexOffset; - uint32_t firstInstance; -} VkDrawIndexedIndirectCommand; - -typedef struct VkDrawIndirectCommand { - uint32_t vertexCount; - uint32_t instanceCount; - uint32_t firstVertex; - uint32_t firstInstance; -} VkDrawIndirectCommand; - - -typedef VkResult (VKAPI_PTR *PFN_vkCreateInstance)(const VkInstanceCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkInstance* pInstance); -typedef void (VKAPI_PTR *PFN_vkDestroyInstance)(VkInstance instance, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkEnumeratePhysicalDevices)(VkInstance instance, uint32_t* pPhysicalDeviceCount, VkPhysicalDevice* pPhysicalDevices); -typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFeatures)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceFeatures* pFeatures); -typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFormatProperties)(VkPhysicalDevice physicalDevice, VkFormat format, VkFormatProperties* pFormatProperties); -typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceImageFormatProperties)(VkPhysicalDevice physicalDevice, VkFormat format, VkImageType type, VkImageTiling tiling, VkImageUsageFlags usage, VkImageCreateFlags flags, VkImageFormatProperties* pImageFormatProperties); -typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceProperties)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceProperties* pProperties); -typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceQueueFamilyProperties)(VkPhysicalDevice physicalDevice, uint32_t* pQueueFamilyPropertyCount, VkQueueFamilyProperties* pQueueFamilyProperties); -typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceMemoryProperties)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceMemoryProperties* pMemoryProperties); -typedef PFN_vkVoidFunction (VKAPI_PTR *PFN_vkGetInstanceProcAddr)(VkInstance instance, const char* pName); -typedef PFN_vkVoidFunction (VKAPI_PTR *PFN_vkGetDeviceProcAddr)(VkDevice device, const char* pName); -typedef VkResult (VKAPI_PTR *PFN_vkCreateDevice)(VkPhysicalDevice physicalDevice, const VkDeviceCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDevice* pDevice); -typedef void (VKAPI_PTR *PFN_vkDestroyDevice)(VkDevice device, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkEnumerateInstanceExtensionProperties)(const char* pLayerName, uint32_t* pPropertyCount, VkExtensionProperties* pProperties); -typedef VkResult (VKAPI_PTR *PFN_vkEnumerateDeviceExtensionProperties)(VkPhysicalDevice physicalDevice, const char* pLayerName, uint32_t* pPropertyCount, VkExtensionProperties* pProperties); -typedef VkResult (VKAPI_PTR *PFN_vkEnumerateInstanceLayerProperties)(uint32_t* pPropertyCount, VkLayerProperties* pProperties); -typedef VkResult (VKAPI_PTR *PFN_vkEnumerateDeviceLayerProperties)(VkPhysicalDevice physicalDevice, uint32_t* pPropertyCount, VkLayerProperties* pProperties); -typedef void (VKAPI_PTR *PFN_vkGetDeviceQueue)(VkDevice device, uint32_t queueFamilyIndex, uint32_t queueIndex, VkQueue* pQueue); -typedef VkResult (VKAPI_PTR *PFN_vkQueueSubmit)(VkQueue queue, uint32_t submitCount, const VkSubmitInfo* pSubmits, VkFence fence); -typedef VkResult (VKAPI_PTR *PFN_vkQueueWaitIdle)(VkQueue queue); -typedef VkResult (VKAPI_PTR *PFN_vkDeviceWaitIdle)(VkDevice device); -typedef VkResult (VKAPI_PTR *PFN_vkAllocateMemory)(VkDevice device, const VkMemoryAllocateInfo* pAllocateInfo, const VkAllocationCallbacks* pAllocator, VkDeviceMemory* pMemory); -typedef void (VKAPI_PTR *PFN_vkFreeMemory)(VkDevice device, VkDeviceMemory memory, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkMapMemory)(VkDevice device, VkDeviceMemory memory, VkDeviceSize offset, VkDeviceSize size, VkMemoryMapFlags flags, void** ppData); -typedef void (VKAPI_PTR *PFN_vkUnmapMemory)(VkDevice device, VkDeviceMemory memory); -typedef VkResult (VKAPI_PTR *PFN_vkFlushMappedMemoryRanges)(VkDevice device, uint32_t memoryRangeCount, const VkMappedMemoryRange* pMemoryRanges); -typedef VkResult (VKAPI_PTR *PFN_vkInvalidateMappedMemoryRanges)(VkDevice device, uint32_t memoryRangeCount, const VkMappedMemoryRange* pMemoryRanges); -typedef void (VKAPI_PTR *PFN_vkGetDeviceMemoryCommitment)(VkDevice device, VkDeviceMemory memory, VkDeviceSize* pCommittedMemoryInBytes); -typedef VkResult (VKAPI_PTR *PFN_vkBindBufferMemory)(VkDevice device, VkBuffer buffer, VkDeviceMemory memory, VkDeviceSize memoryOffset); -typedef VkResult (VKAPI_PTR *PFN_vkBindImageMemory)(VkDevice device, VkImage image, VkDeviceMemory memory, VkDeviceSize memoryOffset); -typedef void (VKAPI_PTR *PFN_vkGetBufferMemoryRequirements)(VkDevice device, VkBuffer buffer, VkMemoryRequirements* pMemoryRequirements); -typedef void (VKAPI_PTR *PFN_vkGetImageMemoryRequirements)(VkDevice device, VkImage image, VkMemoryRequirements* pMemoryRequirements); -typedef void (VKAPI_PTR *PFN_vkGetImageSparseMemoryRequirements)(VkDevice device, VkImage image, uint32_t* pSparseMemoryRequirementCount, VkSparseImageMemoryRequirements* pSparseMemoryRequirements); -typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceSparseImageFormatProperties)(VkPhysicalDevice physicalDevice, VkFormat format, VkImageType type, VkSampleCountFlagBits samples, VkImageUsageFlags usage, VkImageTiling tiling, uint32_t* pPropertyCount, VkSparseImageFormatProperties* pProperties); -typedef VkResult (VKAPI_PTR *PFN_vkQueueBindSparse)(VkQueue queue, uint32_t bindInfoCount, const VkBindSparseInfo* pBindInfo, VkFence fence); -typedef VkResult (VKAPI_PTR *PFN_vkCreateFence)(VkDevice device, const VkFenceCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkFence* pFence); -typedef void (VKAPI_PTR *PFN_vkDestroyFence)(VkDevice device, VkFence fence, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkResetFences)(VkDevice device, uint32_t fenceCount, const VkFence* pFences); -typedef VkResult (VKAPI_PTR *PFN_vkGetFenceStatus)(VkDevice device, VkFence fence); -typedef VkResult (VKAPI_PTR *PFN_vkWaitForFences)(VkDevice device, uint32_t fenceCount, const VkFence* pFences, VkBool32 waitAll, uint64_t timeout); -typedef VkResult (VKAPI_PTR *PFN_vkCreateSemaphore)(VkDevice device, const VkSemaphoreCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSemaphore* pSemaphore); -typedef void (VKAPI_PTR *PFN_vkDestroySemaphore)(VkDevice device, VkSemaphore semaphore, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkCreateEvent)(VkDevice device, const VkEventCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkEvent* pEvent); -typedef void (VKAPI_PTR *PFN_vkDestroyEvent)(VkDevice device, VkEvent event, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkGetEventStatus)(VkDevice device, VkEvent event); -typedef VkResult (VKAPI_PTR *PFN_vkSetEvent)(VkDevice device, VkEvent event); -typedef VkResult (VKAPI_PTR *PFN_vkResetEvent)(VkDevice device, VkEvent event); -typedef VkResult (VKAPI_PTR *PFN_vkCreateQueryPool)(VkDevice device, const VkQueryPoolCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkQueryPool* pQueryPool); -typedef void (VKAPI_PTR *PFN_vkDestroyQueryPool)(VkDevice device, VkQueryPool queryPool, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkGetQueryPoolResults)(VkDevice device, VkQueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, size_t dataSize, void* pData, VkDeviceSize stride, VkQueryResultFlags flags); -typedef VkResult (VKAPI_PTR *PFN_vkCreateBuffer)(VkDevice device, const VkBufferCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkBuffer* pBuffer); -typedef void (VKAPI_PTR *PFN_vkDestroyBuffer)(VkDevice device, VkBuffer buffer, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkCreateBufferView)(VkDevice device, const VkBufferViewCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkBufferView* pView); -typedef void (VKAPI_PTR *PFN_vkDestroyBufferView)(VkDevice device, VkBufferView bufferView, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkCreateImage)(VkDevice device, const VkImageCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkImage* pImage); -typedef void (VKAPI_PTR *PFN_vkDestroyImage)(VkDevice device, VkImage image, const VkAllocationCallbacks* pAllocator); -typedef void (VKAPI_PTR *PFN_vkGetImageSubresourceLayout)(VkDevice device, VkImage image, const VkImageSubresource* pSubresource, VkSubresourceLayout* pLayout); -typedef VkResult (VKAPI_PTR *PFN_vkCreateImageView)(VkDevice device, const VkImageViewCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkImageView* pView); -typedef void (VKAPI_PTR *PFN_vkDestroyImageView)(VkDevice device, VkImageView imageView, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkCreateShaderModule)(VkDevice device, const VkShaderModuleCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkShaderModule* pShaderModule); -typedef void (VKAPI_PTR *PFN_vkDestroyShaderModule)(VkDevice device, VkShaderModule shaderModule, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkCreatePipelineCache)(VkDevice device, const VkPipelineCacheCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkPipelineCache* pPipelineCache); -typedef void (VKAPI_PTR *PFN_vkDestroyPipelineCache)(VkDevice device, VkPipelineCache pipelineCache, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkGetPipelineCacheData)(VkDevice device, VkPipelineCache pipelineCache, size_t* pDataSize, void* pData); -typedef VkResult (VKAPI_PTR *PFN_vkMergePipelineCaches)(VkDevice device, VkPipelineCache dstCache, uint32_t srcCacheCount, const VkPipelineCache* pSrcCaches); -typedef VkResult (VKAPI_PTR *PFN_vkCreateGraphicsPipelines)(VkDevice device, VkPipelineCache pipelineCache, uint32_t createInfoCount, const VkGraphicsPipelineCreateInfo* pCreateInfos, const VkAllocationCallbacks* pAllocator, VkPipeline* pPipelines); -typedef VkResult (VKAPI_PTR *PFN_vkCreateComputePipelines)(VkDevice device, VkPipelineCache pipelineCache, uint32_t createInfoCount, const VkComputePipelineCreateInfo* pCreateInfos, const VkAllocationCallbacks* pAllocator, VkPipeline* pPipelines); -typedef void (VKAPI_PTR *PFN_vkDestroyPipeline)(VkDevice device, VkPipeline pipeline, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkCreatePipelineLayout)(VkDevice device, const VkPipelineLayoutCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkPipelineLayout* pPipelineLayout); -typedef void (VKAPI_PTR *PFN_vkDestroyPipelineLayout)(VkDevice device, VkPipelineLayout pipelineLayout, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkCreateSampler)(VkDevice device, const VkSamplerCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSampler* pSampler); -typedef void (VKAPI_PTR *PFN_vkDestroySampler)(VkDevice device, VkSampler sampler, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkCreateDescriptorSetLayout)(VkDevice device, const VkDescriptorSetLayoutCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDescriptorSetLayout* pSetLayout); -typedef void (VKAPI_PTR *PFN_vkDestroyDescriptorSetLayout)(VkDevice device, VkDescriptorSetLayout descriptorSetLayout, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkCreateDescriptorPool)(VkDevice device, const VkDescriptorPoolCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDescriptorPool* pDescriptorPool); -typedef void (VKAPI_PTR *PFN_vkDestroyDescriptorPool)(VkDevice device, VkDescriptorPool descriptorPool, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkResetDescriptorPool)(VkDevice device, VkDescriptorPool descriptorPool, VkDescriptorPoolResetFlags flags); -typedef VkResult (VKAPI_PTR *PFN_vkAllocateDescriptorSets)(VkDevice device, const VkDescriptorSetAllocateInfo* pAllocateInfo, VkDescriptorSet* pDescriptorSets); -typedef VkResult (VKAPI_PTR *PFN_vkFreeDescriptorSets)(VkDevice device, VkDescriptorPool descriptorPool, uint32_t descriptorSetCount, const VkDescriptorSet* pDescriptorSets); -typedef void (VKAPI_PTR *PFN_vkUpdateDescriptorSets)(VkDevice device, uint32_t descriptorWriteCount, const VkWriteDescriptorSet* pDescriptorWrites, uint32_t descriptorCopyCount, const VkCopyDescriptorSet* pDescriptorCopies); -typedef VkResult (VKAPI_PTR *PFN_vkCreateFramebuffer)(VkDevice device, const VkFramebufferCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkFramebuffer* pFramebuffer); -typedef void (VKAPI_PTR *PFN_vkDestroyFramebuffer)(VkDevice device, VkFramebuffer framebuffer, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkCreateRenderPass)(VkDevice device, const VkRenderPassCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkRenderPass* pRenderPass); -typedef void (VKAPI_PTR *PFN_vkDestroyRenderPass)(VkDevice device, VkRenderPass renderPass, const VkAllocationCallbacks* pAllocator); -typedef void (VKAPI_PTR *PFN_vkGetRenderAreaGranularity)(VkDevice device, VkRenderPass renderPass, VkExtent2D* pGranularity); -typedef VkResult (VKAPI_PTR *PFN_vkCreateCommandPool)(VkDevice device, const VkCommandPoolCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkCommandPool* pCommandPool); -typedef void (VKAPI_PTR *PFN_vkDestroyCommandPool)(VkDevice device, VkCommandPool commandPool, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkResetCommandPool)(VkDevice device, VkCommandPool commandPool, VkCommandPoolResetFlags flags); -typedef VkResult (VKAPI_PTR *PFN_vkAllocateCommandBuffers)(VkDevice device, const VkCommandBufferAllocateInfo* pAllocateInfo, VkCommandBuffer* pCommandBuffers); -typedef void (VKAPI_PTR *PFN_vkFreeCommandBuffers)(VkDevice device, VkCommandPool commandPool, uint32_t commandBufferCount, const VkCommandBuffer* pCommandBuffers); -typedef VkResult (VKAPI_PTR *PFN_vkBeginCommandBuffer)(VkCommandBuffer commandBuffer, const VkCommandBufferBeginInfo* pBeginInfo); -typedef VkResult (VKAPI_PTR *PFN_vkEndCommandBuffer)(VkCommandBuffer commandBuffer); -typedef VkResult (VKAPI_PTR *PFN_vkResetCommandBuffer)(VkCommandBuffer commandBuffer, VkCommandBufferResetFlags flags); -typedef void (VKAPI_PTR *PFN_vkCmdBindPipeline)(VkCommandBuffer commandBuffer, VkPipelineBindPoint pipelineBindPoint, VkPipeline pipeline); -typedef void (VKAPI_PTR *PFN_vkCmdSetViewport)(VkCommandBuffer commandBuffer, uint32_t firstViewport, uint32_t viewportCount, const VkViewport* pViewports); -typedef void (VKAPI_PTR *PFN_vkCmdSetScissor)(VkCommandBuffer commandBuffer, uint32_t firstScissor, uint32_t scissorCount, const VkRect2D* pScissors); -typedef void (VKAPI_PTR *PFN_vkCmdSetLineWidth)(VkCommandBuffer commandBuffer, float lineWidth); -typedef void (VKAPI_PTR *PFN_vkCmdSetDepthBias)(VkCommandBuffer commandBuffer, float depthBiasConstantFactor, float depthBiasClamp, float depthBiasSlopeFactor); -typedef void (VKAPI_PTR *PFN_vkCmdSetBlendConstants)(VkCommandBuffer commandBuffer, const float blendConstants[4]); -typedef void (VKAPI_PTR *PFN_vkCmdSetDepthBounds)(VkCommandBuffer commandBuffer, float minDepthBounds, float maxDepthBounds); -typedef void (VKAPI_PTR *PFN_vkCmdSetStencilCompareMask)(VkCommandBuffer commandBuffer, VkStencilFaceFlags faceMask, uint32_t compareMask); -typedef void (VKAPI_PTR *PFN_vkCmdSetStencilWriteMask)(VkCommandBuffer commandBuffer, VkStencilFaceFlags faceMask, uint32_t writeMask); -typedef void (VKAPI_PTR *PFN_vkCmdSetStencilReference)(VkCommandBuffer commandBuffer, VkStencilFaceFlags faceMask, uint32_t reference); -typedef void (VKAPI_PTR *PFN_vkCmdBindDescriptorSets)(VkCommandBuffer commandBuffer, VkPipelineBindPoint pipelineBindPoint, VkPipelineLayout layout, uint32_t firstSet, uint32_t descriptorSetCount, const VkDescriptorSet* pDescriptorSets, uint32_t dynamicOffsetCount, const uint32_t* pDynamicOffsets); -typedef void (VKAPI_PTR *PFN_vkCmdBindIndexBuffer)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, VkIndexType indexType); -typedef void (VKAPI_PTR *PFN_vkCmdBindVertexBuffers)(VkCommandBuffer commandBuffer, uint32_t firstBinding, uint32_t bindingCount, const VkBuffer* pBuffers, const VkDeviceSize* pOffsets); -typedef void (VKAPI_PTR *PFN_vkCmdDraw)(VkCommandBuffer commandBuffer, uint32_t vertexCount, uint32_t instanceCount, uint32_t firstVertex, uint32_t firstInstance); -typedef void (VKAPI_PTR *PFN_vkCmdDrawIndexed)(VkCommandBuffer commandBuffer, uint32_t indexCount, uint32_t instanceCount, uint32_t firstIndex, int32_t vertexOffset, uint32_t firstInstance); -typedef void (VKAPI_PTR *PFN_vkCmdDrawIndirect)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, uint32_t drawCount, uint32_t stride); -typedef void (VKAPI_PTR *PFN_vkCmdDrawIndexedIndirect)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, uint32_t drawCount, uint32_t stride); -typedef void (VKAPI_PTR *PFN_vkCmdDispatch)(VkCommandBuffer commandBuffer, uint32_t x, uint32_t y, uint32_t z); -typedef void (VKAPI_PTR *PFN_vkCmdDispatchIndirect)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset); -typedef void (VKAPI_PTR *PFN_vkCmdCopyBuffer)(VkCommandBuffer commandBuffer, VkBuffer srcBuffer, VkBuffer dstBuffer, uint32_t regionCount, const VkBufferCopy* pRegions); -typedef void (VKAPI_PTR *PFN_vkCmdCopyImage)(VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkImageCopy* pRegions); -typedef void (VKAPI_PTR *PFN_vkCmdBlitImage)(VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkImageBlit* pRegions, VkFilter filter); -typedef void (VKAPI_PTR *PFN_vkCmdCopyBufferToImage)(VkCommandBuffer commandBuffer, VkBuffer srcBuffer, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkBufferImageCopy* pRegions); -typedef void (VKAPI_PTR *PFN_vkCmdCopyImageToBuffer)(VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkBuffer dstBuffer, uint32_t regionCount, const VkBufferImageCopy* pRegions); -typedef void (VKAPI_PTR *PFN_vkCmdUpdateBuffer)(VkCommandBuffer commandBuffer, VkBuffer dstBuffer, VkDeviceSize dstOffset, VkDeviceSize dataSize, const void* pData); -typedef void (VKAPI_PTR *PFN_vkCmdFillBuffer)(VkCommandBuffer commandBuffer, VkBuffer dstBuffer, VkDeviceSize dstOffset, VkDeviceSize size, uint32_t data); -typedef void (VKAPI_PTR *PFN_vkCmdClearColorImage)(VkCommandBuffer commandBuffer, VkImage image, VkImageLayout imageLayout, const VkClearColorValue* pColor, uint32_t rangeCount, const VkImageSubresourceRange* pRanges); -typedef void (VKAPI_PTR *PFN_vkCmdClearDepthStencilImage)(VkCommandBuffer commandBuffer, VkImage image, VkImageLayout imageLayout, const VkClearDepthStencilValue* pDepthStencil, uint32_t rangeCount, const VkImageSubresourceRange* pRanges); -typedef void (VKAPI_PTR *PFN_vkCmdClearAttachments)(VkCommandBuffer commandBuffer, uint32_t attachmentCount, const VkClearAttachment* pAttachments, uint32_t rectCount, const VkClearRect* pRects); -typedef void (VKAPI_PTR *PFN_vkCmdResolveImage)(VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkImageResolve* pRegions); -typedef void (VKAPI_PTR *PFN_vkCmdSetEvent)(VkCommandBuffer commandBuffer, VkEvent event, VkPipelineStageFlags stageMask); -typedef void (VKAPI_PTR *PFN_vkCmdResetEvent)(VkCommandBuffer commandBuffer, VkEvent event, VkPipelineStageFlags stageMask); -typedef void (VKAPI_PTR *PFN_vkCmdWaitEvents)(VkCommandBuffer commandBuffer, uint32_t eventCount, const VkEvent* pEvents, VkPipelineStageFlags srcStageMask, VkPipelineStageFlags dstStageMask, uint32_t memoryBarrierCount, const VkMemoryBarrier* pMemoryBarriers, uint32_t bufferMemoryBarrierCount, const VkBufferMemoryBarrier* pBufferMemoryBarriers, uint32_t imageMemoryBarrierCount, const VkImageMemoryBarrier* pImageMemoryBarriers); -typedef void (VKAPI_PTR *PFN_vkCmdPipelineBarrier)(VkCommandBuffer commandBuffer, VkPipelineStageFlags srcStageMask, VkPipelineStageFlags dstStageMask, VkDependencyFlags dependencyFlags, uint32_t memoryBarrierCount, const VkMemoryBarrier* pMemoryBarriers, uint32_t bufferMemoryBarrierCount, const VkBufferMemoryBarrier* pBufferMemoryBarriers, uint32_t imageMemoryBarrierCount, const VkImageMemoryBarrier* pImageMemoryBarriers); -typedef void (VKAPI_PTR *PFN_vkCmdBeginQuery)(VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t query, VkQueryControlFlags flags); -typedef void (VKAPI_PTR *PFN_vkCmdEndQuery)(VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t query); -typedef void (VKAPI_PTR *PFN_vkCmdResetQueryPool)(VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t firstQuery, uint32_t queryCount); -typedef void (VKAPI_PTR *PFN_vkCmdWriteTimestamp)(VkCommandBuffer commandBuffer, VkPipelineStageFlagBits pipelineStage, VkQueryPool queryPool, uint32_t query); -typedef void (VKAPI_PTR *PFN_vkCmdCopyQueryPoolResults)(VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, VkBuffer dstBuffer, VkDeviceSize dstOffset, VkDeviceSize stride, VkQueryResultFlags flags); -typedef void (VKAPI_PTR *PFN_vkCmdPushConstants)(VkCommandBuffer commandBuffer, VkPipelineLayout layout, VkShaderStageFlags stageFlags, uint32_t offset, uint32_t size, const void* pValues); -typedef void (VKAPI_PTR *PFN_vkCmdBeginRenderPass)(VkCommandBuffer commandBuffer, const VkRenderPassBeginInfo* pRenderPassBegin, VkSubpassContents contents); -typedef void (VKAPI_PTR *PFN_vkCmdNextSubpass)(VkCommandBuffer commandBuffer, VkSubpassContents contents); -typedef void (VKAPI_PTR *PFN_vkCmdEndRenderPass)(VkCommandBuffer commandBuffer); -typedef void (VKAPI_PTR *PFN_vkCmdExecuteCommands)(VkCommandBuffer commandBuffer, uint32_t commandBufferCount, const VkCommandBuffer* pCommandBuffers); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkCreateInstance( - const VkInstanceCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkInstance* pInstance); - -VKAPI_ATTR void VKAPI_CALL vkDestroyInstance( - VkInstance instance, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkEnumeratePhysicalDevices( - VkInstance instance, - uint32_t* pPhysicalDeviceCount, - VkPhysicalDevice* pPhysicalDevices); - -VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFeatures( - VkPhysicalDevice physicalDevice, - VkPhysicalDeviceFeatures* pFeatures); - -VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFormatProperties( - VkPhysicalDevice physicalDevice, - VkFormat format, - VkFormatProperties* pFormatProperties); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceImageFormatProperties( - VkPhysicalDevice physicalDevice, - VkFormat format, - VkImageType type, - VkImageTiling tiling, - VkImageUsageFlags usage, - VkImageCreateFlags flags, - VkImageFormatProperties* pImageFormatProperties); - -VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceProperties( - VkPhysicalDevice physicalDevice, - VkPhysicalDeviceProperties* pProperties); - -VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceQueueFamilyProperties( - VkPhysicalDevice physicalDevice, - uint32_t* pQueueFamilyPropertyCount, - VkQueueFamilyProperties* pQueueFamilyProperties); - -VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceMemoryProperties( - VkPhysicalDevice physicalDevice, - VkPhysicalDeviceMemoryProperties* pMemoryProperties); - -VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL vkGetInstanceProcAddr( - VkInstance instance, - const char* pName); - -VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL vkGetDeviceProcAddr( - VkDevice device, - const char* pName); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateDevice( - VkPhysicalDevice physicalDevice, - const VkDeviceCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkDevice* pDevice); - -VKAPI_ATTR void VKAPI_CALL vkDestroyDevice( - VkDevice device, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkEnumerateInstanceExtensionProperties( - const char* pLayerName, - uint32_t* pPropertyCount, - VkExtensionProperties* pProperties); - -VKAPI_ATTR VkResult VKAPI_CALL vkEnumerateDeviceExtensionProperties( - VkPhysicalDevice physicalDevice, - const char* pLayerName, - uint32_t* pPropertyCount, - VkExtensionProperties* pProperties); - -VKAPI_ATTR VkResult VKAPI_CALL vkEnumerateInstanceLayerProperties( - uint32_t* pPropertyCount, - VkLayerProperties* pProperties); - -VKAPI_ATTR VkResult VKAPI_CALL vkEnumerateDeviceLayerProperties( - VkPhysicalDevice physicalDevice, - uint32_t* pPropertyCount, - VkLayerProperties* pProperties); - -VKAPI_ATTR void VKAPI_CALL vkGetDeviceQueue( - VkDevice device, - uint32_t queueFamilyIndex, - uint32_t queueIndex, - VkQueue* pQueue); - -VKAPI_ATTR VkResult VKAPI_CALL vkQueueSubmit( - VkQueue queue, - uint32_t submitCount, - const VkSubmitInfo* pSubmits, - VkFence fence); - -VKAPI_ATTR VkResult VKAPI_CALL vkQueueWaitIdle( - VkQueue queue); - -VKAPI_ATTR VkResult VKAPI_CALL vkDeviceWaitIdle( - VkDevice device); - -VKAPI_ATTR VkResult VKAPI_CALL vkAllocateMemory( - VkDevice device, - const VkMemoryAllocateInfo* pAllocateInfo, - const VkAllocationCallbacks* pAllocator, - VkDeviceMemory* pMemory); - -VKAPI_ATTR void VKAPI_CALL vkFreeMemory( - VkDevice device, - VkDeviceMemory memory, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkMapMemory( - VkDevice device, - VkDeviceMemory memory, - VkDeviceSize offset, - VkDeviceSize size, - VkMemoryMapFlags flags, - void** ppData); - -VKAPI_ATTR void VKAPI_CALL vkUnmapMemory( - VkDevice device, - VkDeviceMemory memory); - -VKAPI_ATTR VkResult VKAPI_CALL vkFlushMappedMemoryRanges( - VkDevice device, - uint32_t memoryRangeCount, - const VkMappedMemoryRange* pMemoryRanges); - -VKAPI_ATTR VkResult VKAPI_CALL vkInvalidateMappedMemoryRanges( - VkDevice device, - uint32_t memoryRangeCount, - const VkMappedMemoryRange* pMemoryRanges); - -VKAPI_ATTR void VKAPI_CALL vkGetDeviceMemoryCommitment( - VkDevice device, - VkDeviceMemory memory, - VkDeviceSize* pCommittedMemoryInBytes); - -VKAPI_ATTR VkResult VKAPI_CALL vkBindBufferMemory( - VkDevice device, - VkBuffer buffer, - VkDeviceMemory memory, - VkDeviceSize memoryOffset); - -VKAPI_ATTR VkResult VKAPI_CALL vkBindImageMemory( - VkDevice device, - VkImage image, - VkDeviceMemory memory, - VkDeviceSize memoryOffset); - -VKAPI_ATTR void VKAPI_CALL vkGetBufferMemoryRequirements( - VkDevice device, - VkBuffer buffer, - VkMemoryRequirements* pMemoryRequirements); - -VKAPI_ATTR void VKAPI_CALL vkGetImageMemoryRequirements( - VkDevice device, - VkImage image, - VkMemoryRequirements* pMemoryRequirements); - -VKAPI_ATTR void VKAPI_CALL vkGetImageSparseMemoryRequirements( - VkDevice device, - VkImage image, - uint32_t* pSparseMemoryRequirementCount, - VkSparseImageMemoryRequirements* pSparseMemoryRequirements); - -VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceSparseImageFormatProperties( - VkPhysicalDevice physicalDevice, - VkFormat format, - VkImageType type, - VkSampleCountFlagBits samples, - VkImageUsageFlags usage, - VkImageTiling tiling, - uint32_t* pPropertyCount, - VkSparseImageFormatProperties* pProperties); - -VKAPI_ATTR VkResult VKAPI_CALL vkQueueBindSparse( - VkQueue queue, - uint32_t bindInfoCount, - const VkBindSparseInfo* pBindInfo, - VkFence fence); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateFence( - VkDevice device, - const VkFenceCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkFence* pFence); - -VKAPI_ATTR void VKAPI_CALL vkDestroyFence( - VkDevice device, - VkFence fence, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkResetFences( - VkDevice device, - uint32_t fenceCount, - const VkFence* pFences); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetFenceStatus( - VkDevice device, - VkFence fence); - -VKAPI_ATTR VkResult VKAPI_CALL vkWaitForFences( - VkDevice device, - uint32_t fenceCount, - const VkFence* pFences, - VkBool32 waitAll, - uint64_t timeout); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateSemaphore( - VkDevice device, - const VkSemaphoreCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkSemaphore* pSemaphore); - -VKAPI_ATTR void VKAPI_CALL vkDestroySemaphore( - VkDevice device, - VkSemaphore semaphore, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateEvent( - VkDevice device, - const VkEventCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkEvent* pEvent); - -VKAPI_ATTR void VKAPI_CALL vkDestroyEvent( - VkDevice device, - VkEvent event, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetEventStatus( - VkDevice device, - VkEvent event); - -VKAPI_ATTR VkResult VKAPI_CALL vkSetEvent( - VkDevice device, - VkEvent event); - -VKAPI_ATTR VkResult VKAPI_CALL vkResetEvent( - VkDevice device, - VkEvent event); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateQueryPool( - VkDevice device, - const VkQueryPoolCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkQueryPool* pQueryPool); - -VKAPI_ATTR void VKAPI_CALL vkDestroyQueryPool( - VkDevice device, - VkQueryPool queryPool, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetQueryPoolResults( - VkDevice device, - VkQueryPool queryPool, - uint32_t firstQuery, - uint32_t queryCount, - size_t dataSize, - void* pData, - VkDeviceSize stride, - VkQueryResultFlags flags); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateBuffer( - VkDevice device, - const VkBufferCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkBuffer* pBuffer); - -VKAPI_ATTR void VKAPI_CALL vkDestroyBuffer( - VkDevice device, - VkBuffer buffer, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateBufferView( - VkDevice device, - const VkBufferViewCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkBufferView* pView); - -VKAPI_ATTR void VKAPI_CALL vkDestroyBufferView( - VkDevice device, - VkBufferView bufferView, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateImage( - VkDevice device, - const VkImageCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkImage* pImage); - -VKAPI_ATTR void VKAPI_CALL vkDestroyImage( - VkDevice device, - VkImage image, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR void VKAPI_CALL vkGetImageSubresourceLayout( - VkDevice device, - VkImage image, - const VkImageSubresource* pSubresource, - VkSubresourceLayout* pLayout); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateImageView( - VkDevice device, - const VkImageViewCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkImageView* pView); - -VKAPI_ATTR void VKAPI_CALL vkDestroyImageView( - VkDevice device, - VkImageView imageView, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateShaderModule( - VkDevice device, - const VkShaderModuleCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkShaderModule* pShaderModule); - -VKAPI_ATTR void VKAPI_CALL vkDestroyShaderModule( - VkDevice device, - VkShaderModule shaderModule, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreatePipelineCache( - VkDevice device, - const VkPipelineCacheCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkPipelineCache* pPipelineCache); - -VKAPI_ATTR void VKAPI_CALL vkDestroyPipelineCache( - VkDevice device, - VkPipelineCache pipelineCache, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetPipelineCacheData( - VkDevice device, - VkPipelineCache pipelineCache, - size_t* pDataSize, - void* pData); - -VKAPI_ATTR VkResult VKAPI_CALL vkMergePipelineCaches( - VkDevice device, - VkPipelineCache dstCache, - uint32_t srcCacheCount, - const VkPipelineCache* pSrcCaches); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateGraphicsPipelines( - VkDevice device, - VkPipelineCache pipelineCache, - uint32_t createInfoCount, - const VkGraphicsPipelineCreateInfo* pCreateInfos, - const VkAllocationCallbacks* pAllocator, - VkPipeline* pPipelines); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateComputePipelines( - VkDevice device, - VkPipelineCache pipelineCache, - uint32_t createInfoCount, - const VkComputePipelineCreateInfo* pCreateInfos, - const VkAllocationCallbacks* pAllocator, - VkPipeline* pPipelines); - -VKAPI_ATTR void VKAPI_CALL vkDestroyPipeline( - VkDevice device, - VkPipeline pipeline, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreatePipelineLayout( - VkDevice device, - const VkPipelineLayoutCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkPipelineLayout* pPipelineLayout); - -VKAPI_ATTR void VKAPI_CALL vkDestroyPipelineLayout( - VkDevice device, - VkPipelineLayout pipelineLayout, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateSampler( - VkDevice device, - const VkSamplerCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkSampler* pSampler); - -VKAPI_ATTR void VKAPI_CALL vkDestroySampler( - VkDevice device, - VkSampler sampler, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateDescriptorSetLayout( - VkDevice device, - const VkDescriptorSetLayoutCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkDescriptorSetLayout* pSetLayout); - -VKAPI_ATTR void VKAPI_CALL vkDestroyDescriptorSetLayout( - VkDevice device, - VkDescriptorSetLayout descriptorSetLayout, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateDescriptorPool( - VkDevice device, - const VkDescriptorPoolCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkDescriptorPool* pDescriptorPool); - -VKAPI_ATTR void VKAPI_CALL vkDestroyDescriptorPool( - VkDevice device, - VkDescriptorPool descriptorPool, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkResetDescriptorPool( - VkDevice device, - VkDescriptorPool descriptorPool, - VkDescriptorPoolResetFlags flags); - -VKAPI_ATTR VkResult VKAPI_CALL vkAllocateDescriptorSets( - VkDevice device, - const VkDescriptorSetAllocateInfo* pAllocateInfo, - VkDescriptorSet* pDescriptorSets); - -VKAPI_ATTR VkResult VKAPI_CALL vkFreeDescriptorSets( - VkDevice device, - VkDescriptorPool descriptorPool, - uint32_t descriptorSetCount, - const VkDescriptorSet* pDescriptorSets); - -VKAPI_ATTR void VKAPI_CALL vkUpdateDescriptorSets( - VkDevice device, - uint32_t descriptorWriteCount, - const VkWriteDescriptorSet* pDescriptorWrites, - uint32_t descriptorCopyCount, - const VkCopyDescriptorSet* pDescriptorCopies); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateFramebuffer( - VkDevice device, - const VkFramebufferCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkFramebuffer* pFramebuffer); - -VKAPI_ATTR void VKAPI_CALL vkDestroyFramebuffer( - VkDevice device, - VkFramebuffer framebuffer, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateRenderPass( - VkDevice device, - const VkRenderPassCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkRenderPass* pRenderPass); - -VKAPI_ATTR void VKAPI_CALL vkDestroyRenderPass( - VkDevice device, - VkRenderPass renderPass, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR void VKAPI_CALL vkGetRenderAreaGranularity( - VkDevice device, - VkRenderPass renderPass, - VkExtent2D* pGranularity); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateCommandPool( - VkDevice device, - const VkCommandPoolCreateInfo* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkCommandPool* pCommandPool); - -VKAPI_ATTR void VKAPI_CALL vkDestroyCommandPool( - VkDevice device, - VkCommandPool commandPool, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkResetCommandPool( - VkDevice device, - VkCommandPool commandPool, - VkCommandPoolResetFlags flags); - -VKAPI_ATTR VkResult VKAPI_CALL vkAllocateCommandBuffers( - VkDevice device, - const VkCommandBufferAllocateInfo* pAllocateInfo, - VkCommandBuffer* pCommandBuffers); - -VKAPI_ATTR void VKAPI_CALL vkFreeCommandBuffers( - VkDevice device, - VkCommandPool commandPool, - uint32_t commandBufferCount, - const VkCommandBuffer* pCommandBuffers); - -VKAPI_ATTR VkResult VKAPI_CALL vkBeginCommandBuffer( - VkCommandBuffer commandBuffer, - const VkCommandBufferBeginInfo* pBeginInfo); - -VKAPI_ATTR VkResult VKAPI_CALL vkEndCommandBuffer( - VkCommandBuffer commandBuffer); - -VKAPI_ATTR VkResult VKAPI_CALL vkResetCommandBuffer( - VkCommandBuffer commandBuffer, - VkCommandBufferResetFlags flags); - -VKAPI_ATTR void VKAPI_CALL vkCmdBindPipeline( - VkCommandBuffer commandBuffer, - VkPipelineBindPoint pipelineBindPoint, - VkPipeline pipeline); - -VKAPI_ATTR void VKAPI_CALL vkCmdSetViewport( - VkCommandBuffer commandBuffer, - uint32_t firstViewport, - uint32_t viewportCount, - const VkViewport* pViewports); - -VKAPI_ATTR void VKAPI_CALL vkCmdSetScissor( - VkCommandBuffer commandBuffer, - uint32_t firstScissor, - uint32_t scissorCount, - const VkRect2D* pScissors); - -VKAPI_ATTR void VKAPI_CALL vkCmdSetLineWidth( - VkCommandBuffer commandBuffer, - float lineWidth); - -VKAPI_ATTR void VKAPI_CALL vkCmdSetDepthBias( - VkCommandBuffer commandBuffer, - float depthBiasConstantFactor, - float depthBiasClamp, - float depthBiasSlopeFactor); - -VKAPI_ATTR void VKAPI_CALL vkCmdSetBlendConstants( - VkCommandBuffer commandBuffer, - const float blendConstants[4]); - -VKAPI_ATTR void VKAPI_CALL vkCmdSetDepthBounds( - VkCommandBuffer commandBuffer, - float minDepthBounds, - float maxDepthBounds); - -VKAPI_ATTR void VKAPI_CALL vkCmdSetStencilCompareMask( - VkCommandBuffer commandBuffer, - VkStencilFaceFlags faceMask, - uint32_t compareMask); - -VKAPI_ATTR void VKAPI_CALL vkCmdSetStencilWriteMask( - VkCommandBuffer commandBuffer, - VkStencilFaceFlags faceMask, - uint32_t writeMask); - -VKAPI_ATTR void VKAPI_CALL vkCmdSetStencilReference( - VkCommandBuffer commandBuffer, - VkStencilFaceFlags faceMask, - uint32_t reference); - -VKAPI_ATTR void VKAPI_CALL vkCmdBindDescriptorSets( - VkCommandBuffer commandBuffer, - VkPipelineBindPoint pipelineBindPoint, - VkPipelineLayout layout, - uint32_t firstSet, - uint32_t descriptorSetCount, - const VkDescriptorSet* pDescriptorSets, - uint32_t dynamicOffsetCount, - const uint32_t* pDynamicOffsets); - -VKAPI_ATTR void VKAPI_CALL vkCmdBindIndexBuffer( - VkCommandBuffer commandBuffer, - VkBuffer buffer, - VkDeviceSize offset, - VkIndexType indexType); - -VKAPI_ATTR void VKAPI_CALL vkCmdBindVertexBuffers( - VkCommandBuffer commandBuffer, - uint32_t firstBinding, - uint32_t bindingCount, - const VkBuffer* pBuffers, - const VkDeviceSize* pOffsets); - -VKAPI_ATTR void VKAPI_CALL vkCmdDraw( - VkCommandBuffer commandBuffer, - uint32_t vertexCount, - uint32_t instanceCount, - uint32_t firstVertex, - uint32_t firstInstance); - -VKAPI_ATTR void VKAPI_CALL vkCmdDrawIndexed( - VkCommandBuffer commandBuffer, - uint32_t indexCount, - uint32_t instanceCount, - uint32_t firstIndex, - int32_t vertexOffset, - uint32_t firstInstance); - -VKAPI_ATTR void VKAPI_CALL vkCmdDrawIndirect( - VkCommandBuffer commandBuffer, - VkBuffer buffer, - VkDeviceSize offset, - uint32_t drawCount, - uint32_t stride); - -VKAPI_ATTR void VKAPI_CALL vkCmdDrawIndexedIndirect( - VkCommandBuffer commandBuffer, - VkBuffer buffer, - VkDeviceSize offset, - uint32_t drawCount, - uint32_t stride); - -VKAPI_ATTR void VKAPI_CALL vkCmdDispatch( - VkCommandBuffer commandBuffer, - uint32_t x, - uint32_t y, - uint32_t z); - -VKAPI_ATTR void VKAPI_CALL vkCmdDispatchIndirect( - VkCommandBuffer commandBuffer, - VkBuffer buffer, - VkDeviceSize offset); - -VKAPI_ATTR void VKAPI_CALL vkCmdCopyBuffer( - VkCommandBuffer commandBuffer, - VkBuffer srcBuffer, - VkBuffer dstBuffer, - uint32_t regionCount, - const VkBufferCopy* pRegions); - -VKAPI_ATTR void VKAPI_CALL vkCmdCopyImage( - VkCommandBuffer commandBuffer, - VkImage srcImage, - VkImageLayout srcImageLayout, - VkImage dstImage, - VkImageLayout dstImageLayout, - uint32_t regionCount, - const VkImageCopy* pRegions); - -VKAPI_ATTR void VKAPI_CALL vkCmdBlitImage( - VkCommandBuffer commandBuffer, - VkImage srcImage, - VkImageLayout srcImageLayout, - VkImage dstImage, - VkImageLayout dstImageLayout, - uint32_t regionCount, - const VkImageBlit* pRegions, - VkFilter filter); - -VKAPI_ATTR void VKAPI_CALL vkCmdCopyBufferToImage( - VkCommandBuffer commandBuffer, - VkBuffer srcBuffer, - VkImage dstImage, - VkImageLayout dstImageLayout, - uint32_t regionCount, - const VkBufferImageCopy* pRegions); - -VKAPI_ATTR void VKAPI_CALL vkCmdCopyImageToBuffer( - VkCommandBuffer commandBuffer, - VkImage srcImage, - VkImageLayout srcImageLayout, - VkBuffer dstBuffer, - uint32_t regionCount, - const VkBufferImageCopy* pRegions); - -VKAPI_ATTR void VKAPI_CALL vkCmdUpdateBuffer( - VkCommandBuffer commandBuffer, - VkBuffer dstBuffer, - VkDeviceSize dstOffset, - VkDeviceSize dataSize, - const void* pData); - -VKAPI_ATTR void VKAPI_CALL vkCmdFillBuffer( - VkCommandBuffer commandBuffer, - VkBuffer dstBuffer, - VkDeviceSize dstOffset, - VkDeviceSize size, - uint32_t data); - -VKAPI_ATTR void VKAPI_CALL vkCmdClearColorImage( - VkCommandBuffer commandBuffer, - VkImage image, - VkImageLayout imageLayout, - const VkClearColorValue* pColor, - uint32_t rangeCount, - const VkImageSubresourceRange* pRanges); - -VKAPI_ATTR void VKAPI_CALL vkCmdClearDepthStencilImage( - VkCommandBuffer commandBuffer, - VkImage image, - VkImageLayout imageLayout, - const VkClearDepthStencilValue* pDepthStencil, - uint32_t rangeCount, - const VkImageSubresourceRange* pRanges); - -VKAPI_ATTR void VKAPI_CALL vkCmdClearAttachments( - VkCommandBuffer commandBuffer, - uint32_t attachmentCount, - const VkClearAttachment* pAttachments, - uint32_t rectCount, - const VkClearRect* pRects); - -VKAPI_ATTR void VKAPI_CALL vkCmdResolveImage( - VkCommandBuffer commandBuffer, - VkImage srcImage, - VkImageLayout srcImageLayout, - VkImage dstImage, - VkImageLayout dstImageLayout, - uint32_t regionCount, - const VkImageResolve* pRegions); - -VKAPI_ATTR void VKAPI_CALL vkCmdSetEvent( - VkCommandBuffer commandBuffer, - VkEvent event, - VkPipelineStageFlags stageMask); - -VKAPI_ATTR void VKAPI_CALL vkCmdResetEvent( - VkCommandBuffer commandBuffer, - VkEvent event, - VkPipelineStageFlags stageMask); - -VKAPI_ATTR void VKAPI_CALL vkCmdWaitEvents( - VkCommandBuffer commandBuffer, - uint32_t eventCount, - const VkEvent* pEvents, - VkPipelineStageFlags srcStageMask, - VkPipelineStageFlags dstStageMask, - uint32_t memoryBarrierCount, - const VkMemoryBarrier* pMemoryBarriers, - uint32_t bufferMemoryBarrierCount, - const VkBufferMemoryBarrier* pBufferMemoryBarriers, - uint32_t imageMemoryBarrierCount, - const VkImageMemoryBarrier* pImageMemoryBarriers); - -VKAPI_ATTR void VKAPI_CALL vkCmdPipelineBarrier( - VkCommandBuffer commandBuffer, - VkPipelineStageFlags srcStageMask, - VkPipelineStageFlags dstStageMask, - VkDependencyFlags dependencyFlags, - uint32_t memoryBarrierCount, - const VkMemoryBarrier* pMemoryBarriers, - uint32_t bufferMemoryBarrierCount, - const VkBufferMemoryBarrier* pBufferMemoryBarriers, - uint32_t imageMemoryBarrierCount, - const VkImageMemoryBarrier* pImageMemoryBarriers); - -VKAPI_ATTR void VKAPI_CALL vkCmdBeginQuery( - VkCommandBuffer commandBuffer, - VkQueryPool queryPool, - uint32_t query, - VkQueryControlFlags flags); - -VKAPI_ATTR void VKAPI_CALL vkCmdEndQuery( - VkCommandBuffer commandBuffer, - VkQueryPool queryPool, - uint32_t query); - -VKAPI_ATTR void VKAPI_CALL vkCmdResetQueryPool( - VkCommandBuffer commandBuffer, - VkQueryPool queryPool, - uint32_t firstQuery, - uint32_t queryCount); - -VKAPI_ATTR void VKAPI_CALL vkCmdWriteTimestamp( - VkCommandBuffer commandBuffer, - VkPipelineStageFlagBits pipelineStage, - VkQueryPool queryPool, - uint32_t query); - -VKAPI_ATTR void VKAPI_CALL vkCmdCopyQueryPoolResults( - VkCommandBuffer commandBuffer, - VkQueryPool queryPool, - uint32_t firstQuery, - uint32_t queryCount, - VkBuffer dstBuffer, - VkDeviceSize dstOffset, - VkDeviceSize stride, - VkQueryResultFlags flags); - -VKAPI_ATTR void VKAPI_CALL vkCmdPushConstants( - VkCommandBuffer commandBuffer, - VkPipelineLayout layout, - VkShaderStageFlags stageFlags, - uint32_t offset, - uint32_t size, - const void* pValues); - -VKAPI_ATTR void VKAPI_CALL vkCmdBeginRenderPass( - VkCommandBuffer commandBuffer, - const VkRenderPassBeginInfo* pRenderPassBegin, - VkSubpassContents contents); - -VKAPI_ATTR void VKAPI_CALL vkCmdNextSubpass( - VkCommandBuffer commandBuffer, - VkSubpassContents contents); - -VKAPI_ATTR void VKAPI_CALL vkCmdEndRenderPass( - VkCommandBuffer commandBuffer); - -VKAPI_ATTR void VKAPI_CALL vkCmdExecuteCommands( - VkCommandBuffer commandBuffer, - uint32_t commandBufferCount, - const VkCommandBuffer* pCommandBuffers); -#endif - -#define VK_KHR_surface 1 -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSurfaceKHR) - -#define VK_KHR_SURFACE_SPEC_VERSION 25 -#define VK_KHR_SURFACE_EXTENSION_NAME "VK_KHR_surface" -#define VK_COLORSPACE_SRGB_NONLINEAR_KHR VK_COLOR_SPACE_SRGB_NONLINEAR_KHR - - -typedef enum VkColorSpaceKHR { - VK_COLOR_SPACE_SRGB_NONLINEAR_KHR = 0, - VK_COLOR_SPACE_DISPLAY_P3_LINEAR_EXT = 1000104001, - VK_COLOR_SPACE_DISPLAY_P3_NONLINEAR_EXT = 1000104002, - VK_COLOR_SPACE_SCRGB_LINEAR_EXT = 1000104003, - VK_COLOR_SPACE_SCRGB_NONLINEAR_EXT = 1000104004, - VK_COLOR_SPACE_DCI_P3_LINEAR_EXT = 1000104005, - VK_COLOR_SPACE_DCI_P3_NONLINEAR_EXT = 1000104006, - VK_COLOR_SPACE_BT709_LINEAR_EXT = 1000104007, - VK_COLOR_SPACE_BT709_NONLINEAR_EXT = 1000104008, - VK_COLOR_SPACE_BT2020_LINEAR_EXT = 1000104009, - VK_COLOR_SPACE_BT2020_NONLINEAR_EXT = 1000104010, - VK_COLOR_SPACE_ADOBERGB_LINEAR_EXT = 1000104011, - VK_COLOR_SPACE_ADOBERGB_NONLINEAR_EXT = 1000104012, - VK_COLOR_SPACE_BEGIN_RANGE_KHR = VK_COLOR_SPACE_SRGB_NONLINEAR_KHR, - VK_COLOR_SPACE_END_RANGE_KHR = VK_COLOR_SPACE_SRGB_NONLINEAR_KHR, - VK_COLOR_SPACE_RANGE_SIZE_KHR = (VK_COLOR_SPACE_SRGB_NONLINEAR_KHR - VK_COLOR_SPACE_SRGB_NONLINEAR_KHR + 1), - VK_COLOR_SPACE_MAX_ENUM_KHR = 0x7FFFFFFF -} VkColorSpaceKHR; - -typedef enum VkPresentModeKHR { - VK_PRESENT_MODE_IMMEDIATE_KHR = 0, - VK_PRESENT_MODE_MAILBOX_KHR = 1, - VK_PRESENT_MODE_FIFO_KHR = 2, - VK_PRESENT_MODE_FIFO_RELAXED_KHR = 3, - VK_PRESENT_MODE_BEGIN_RANGE_KHR = VK_PRESENT_MODE_IMMEDIATE_KHR, - VK_PRESENT_MODE_END_RANGE_KHR = VK_PRESENT_MODE_FIFO_RELAXED_KHR, - VK_PRESENT_MODE_RANGE_SIZE_KHR = (VK_PRESENT_MODE_FIFO_RELAXED_KHR - VK_PRESENT_MODE_IMMEDIATE_KHR + 1), - VK_PRESENT_MODE_MAX_ENUM_KHR = 0x7FFFFFFF -} VkPresentModeKHR; - - -typedef enum VkSurfaceTransformFlagBitsKHR { - VK_SURFACE_TRANSFORM_IDENTITY_BIT_KHR = 0x00000001, - VK_SURFACE_TRANSFORM_ROTATE_90_BIT_KHR = 0x00000002, - VK_SURFACE_TRANSFORM_ROTATE_180_BIT_KHR = 0x00000004, - VK_SURFACE_TRANSFORM_ROTATE_270_BIT_KHR = 0x00000008, - VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_BIT_KHR = 0x00000010, - VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_90_BIT_KHR = 0x00000020, - VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_180_BIT_KHR = 0x00000040, - VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_270_BIT_KHR = 0x00000080, - VK_SURFACE_TRANSFORM_INHERIT_BIT_KHR = 0x00000100, - VK_SURFACE_TRANSFORM_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF -} VkSurfaceTransformFlagBitsKHR; -typedef VkFlags VkSurfaceTransformFlagsKHR; - -typedef enum VkCompositeAlphaFlagBitsKHR { - VK_COMPOSITE_ALPHA_OPAQUE_BIT_KHR = 0x00000001, - VK_COMPOSITE_ALPHA_PRE_MULTIPLIED_BIT_KHR = 0x00000002, - VK_COMPOSITE_ALPHA_POST_MULTIPLIED_BIT_KHR = 0x00000004, - VK_COMPOSITE_ALPHA_INHERIT_BIT_KHR = 0x00000008, - VK_COMPOSITE_ALPHA_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF -} VkCompositeAlphaFlagBitsKHR; -typedef VkFlags VkCompositeAlphaFlagsKHR; - -typedef struct VkSurfaceCapabilitiesKHR { - uint32_t minImageCount; - uint32_t maxImageCount; - VkExtent2D currentExtent; - VkExtent2D minImageExtent; - VkExtent2D maxImageExtent; - uint32_t maxImageArrayLayers; - VkSurfaceTransformFlagsKHR supportedTransforms; - VkSurfaceTransformFlagBitsKHR currentTransform; - VkCompositeAlphaFlagsKHR supportedCompositeAlpha; - VkImageUsageFlags supportedUsageFlags; -} VkSurfaceCapabilitiesKHR; - -typedef struct VkSurfaceFormatKHR { - VkFormat format; - VkColorSpaceKHR colorSpace; -} VkSurfaceFormatKHR; - - -typedef void (VKAPI_PTR *PFN_vkDestroySurfaceKHR)(VkInstance instance, VkSurfaceKHR surface, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceSupportKHR)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, VkSurfaceKHR surface, VkBool32* pSupported); -typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceCapabilitiesKHR)(VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, VkSurfaceCapabilitiesKHR* pSurfaceCapabilities); -typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceFormatsKHR)(VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, uint32_t* pSurfaceFormatCount, VkSurfaceFormatKHR* pSurfaceFormats); -typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfacePresentModesKHR)(VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, uint32_t* pPresentModeCount, VkPresentModeKHR* pPresentModes); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR void VKAPI_CALL vkDestroySurfaceKHR( - VkInstance instance, - VkSurfaceKHR surface, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceSupportKHR( - VkPhysicalDevice physicalDevice, - uint32_t queueFamilyIndex, - VkSurfaceKHR surface, - VkBool32* pSupported); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceCapabilitiesKHR( - VkPhysicalDevice physicalDevice, - VkSurfaceKHR surface, - VkSurfaceCapabilitiesKHR* pSurfaceCapabilities); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceFormatsKHR( - VkPhysicalDevice physicalDevice, - VkSurfaceKHR surface, - uint32_t* pSurfaceFormatCount, - VkSurfaceFormatKHR* pSurfaceFormats); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfacePresentModesKHR( - VkPhysicalDevice physicalDevice, - VkSurfaceKHR surface, - uint32_t* pPresentModeCount, - VkPresentModeKHR* pPresentModes); -#endif - -#define VK_KHR_swapchain 1 -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSwapchainKHR) - -#define VK_KHR_SWAPCHAIN_SPEC_VERSION 68 -#define VK_KHR_SWAPCHAIN_EXTENSION_NAME "VK_KHR_swapchain" - -typedef VkFlags VkSwapchainCreateFlagsKHR; - -typedef struct VkSwapchainCreateInfoKHR { - VkStructureType sType; - const void* pNext; - VkSwapchainCreateFlagsKHR flags; - VkSurfaceKHR surface; - uint32_t minImageCount; - VkFormat imageFormat; - VkColorSpaceKHR imageColorSpace; - VkExtent2D imageExtent; - uint32_t imageArrayLayers; - VkImageUsageFlags imageUsage; - VkSharingMode imageSharingMode; - uint32_t queueFamilyIndexCount; - const uint32_t* pQueueFamilyIndices; - VkSurfaceTransformFlagBitsKHR preTransform; - VkCompositeAlphaFlagBitsKHR compositeAlpha; - VkPresentModeKHR presentMode; - VkBool32 clipped; - VkSwapchainKHR oldSwapchain; -} VkSwapchainCreateInfoKHR; - -typedef struct VkPresentInfoKHR { - VkStructureType sType; - const void* pNext; - uint32_t waitSemaphoreCount; - const VkSemaphore* pWaitSemaphores; - uint32_t swapchainCount; - const VkSwapchainKHR* pSwapchains; - const uint32_t* pImageIndices; - VkResult* pResults; -} VkPresentInfoKHR; - - -typedef VkResult (VKAPI_PTR *PFN_vkCreateSwapchainKHR)(VkDevice device, const VkSwapchainCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSwapchainKHR* pSwapchain); -typedef void (VKAPI_PTR *PFN_vkDestroySwapchainKHR)(VkDevice device, VkSwapchainKHR swapchain, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkGetSwapchainImagesKHR)(VkDevice device, VkSwapchainKHR swapchain, uint32_t* pSwapchainImageCount, VkImage* pSwapchainImages); -typedef VkResult (VKAPI_PTR *PFN_vkAcquireNextImageKHR)(VkDevice device, VkSwapchainKHR swapchain, uint64_t timeout, VkSemaphore semaphore, VkFence fence, uint32_t* pImageIndex); -typedef VkResult (VKAPI_PTR *PFN_vkQueuePresentKHR)(VkQueue queue, const VkPresentInfoKHR* pPresentInfo); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkCreateSwapchainKHR( - VkDevice device, - const VkSwapchainCreateInfoKHR* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkSwapchainKHR* pSwapchain); - -VKAPI_ATTR void VKAPI_CALL vkDestroySwapchainKHR( - VkDevice device, - VkSwapchainKHR swapchain, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetSwapchainImagesKHR( - VkDevice device, - VkSwapchainKHR swapchain, - uint32_t* pSwapchainImageCount, - VkImage* pSwapchainImages); - -VKAPI_ATTR VkResult VKAPI_CALL vkAcquireNextImageKHR( - VkDevice device, - VkSwapchainKHR swapchain, - uint64_t timeout, - VkSemaphore semaphore, - VkFence fence, - uint32_t* pImageIndex); - -VKAPI_ATTR VkResult VKAPI_CALL vkQueuePresentKHR( - VkQueue queue, - const VkPresentInfoKHR* pPresentInfo); -#endif - -#define VK_KHR_display 1 -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDisplayKHR) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDisplayModeKHR) - -#define VK_KHR_DISPLAY_SPEC_VERSION 21 -#define VK_KHR_DISPLAY_EXTENSION_NAME "VK_KHR_display" - - -typedef enum VkDisplayPlaneAlphaFlagBitsKHR { - VK_DISPLAY_PLANE_ALPHA_OPAQUE_BIT_KHR = 0x00000001, - VK_DISPLAY_PLANE_ALPHA_GLOBAL_BIT_KHR = 0x00000002, - VK_DISPLAY_PLANE_ALPHA_PER_PIXEL_BIT_KHR = 0x00000004, - VK_DISPLAY_PLANE_ALPHA_PER_PIXEL_PREMULTIPLIED_BIT_KHR = 0x00000008, - VK_DISPLAY_PLANE_ALPHA_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF -} VkDisplayPlaneAlphaFlagBitsKHR; -typedef VkFlags VkDisplayPlaneAlphaFlagsKHR; -typedef VkFlags VkDisplayModeCreateFlagsKHR; -typedef VkFlags VkDisplaySurfaceCreateFlagsKHR; - -typedef struct VkDisplayPropertiesKHR { - VkDisplayKHR display; - const char* displayName; - VkExtent2D physicalDimensions; - VkExtent2D physicalResolution; - VkSurfaceTransformFlagsKHR supportedTransforms; - VkBool32 planeReorderPossible; - VkBool32 persistentContent; -} VkDisplayPropertiesKHR; - -typedef struct VkDisplayModeParametersKHR { - VkExtent2D visibleRegion; - uint32_t refreshRate; -} VkDisplayModeParametersKHR; - -typedef struct VkDisplayModePropertiesKHR { - VkDisplayModeKHR displayMode; - VkDisplayModeParametersKHR parameters; -} VkDisplayModePropertiesKHR; - -typedef struct VkDisplayModeCreateInfoKHR { - VkStructureType sType; - const void* pNext; - VkDisplayModeCreateFlagsKHR flags; - VkDisplayModeParametersKHR parameters; -} VkDisplayModeCreateInfoKHR; - -typedef struct VkDisplayPlaneCapabilitiesKHR { - VkDisplayPlaneAlphaFlagsKHR supportedAlpha; - VkOffset2D minSrcPosition; - VkOffset2D maxSrcPosition; - VkExtent2D minSrcExtent; - VkExtent2D maxSrcExtent; - VkOffset2D minDstPosition; - VkOffset2D maxDstPosition; - VkExtent2D minDstExtent; - VkExtent2D maxDstExtent; -} VkDisplayPlaneCapabilitiesKHR; - -typedef struct VkDisplayPlanePropertiesKHR { - VkDisplayKHR currentDisplay; - uint32_t currentStackIndex; -} VkDisplayPlanePropertiesKHR; - -typedef struct VkDisplaySurfaceCreateInfoKHR { - VkStructureType sType; - const void* pNext; - VkDisplaySurfaceCreateFlagsKHR flags; - VkDisplayModeKHR displayMode; - uint32_t planeIndex; - uint32_t planeStackIndex; - VkSurfaceTransformFlagBitsKHR transform; - float globalAlpha; - VkDisplayPlaneAlphaFlagBitsKHR alphaMode; - VkExtent2D imageExtent; -} VkDisplaySurfaceCreateInfoKHR; - - -typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceDisplayPropertiesKHR)(VkPhysicalDevice physicalDevice, uint32_t* pPropertyCount, VkDisplayPropertiesKHR* pProperties); -typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceDisplayPlanePropertiesKHR)(VkPhysicalDevice physicalDevice, uint32_t* pPropertyCount, VkDisplayPlanePropertiesKHR* pProperties); -typedef VkResult (VKAPI_PTR *PFN_vkGetDisplayPlaneSupportedDisplaysKHR)(VkPhysicalDevice physicalDevice, uint32_t planeIndex, uint32_t* pDisplayCount, VkDisplayKHR* pDisplays); -typedef VkResult (VKAPI_PTR *PFN_vkGetDisplayModePropertiesKHR)(VkPhysicalDevice physicalDevice, VkDisplayKHR display, uint32_t* pPropertyCount, VkDisplayModePropertiesKHR* pProperties); -typedef VkResult (VKAPI_PTR *PFN_vkCreateDisplayModeKHR)(VkPhysicalDevice physicalDevice, VkDisplayKHR display, const VkDisplayModeCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDisplayModeKHR* pMode); -typedef VkResult (VKAPI_PTR *PFN_vkGetDisplayPlaneCapabilitiesKHR)(VkPhysicalDevice physicalDevice, VkDisplayModeKHR mode, uint32_t planeIndex, VkDisplayPlaneCapabilitiesKHR* pCapabilities); -typedef VkResult (VKAPI_PTR *PFN_vkCreateDisplayPlaneSurfaceKHR)(VkInstance instance, const VkDisplaySurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceDisplayPropertiesKHR( - VkPhysicalDevice physicalDevice, - uint32_t* pPropertyCount, - VkDisplayPropertiesKHR* pProperties); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceDisplayPlanePropertiesKHR( - VkPhysicalDevice physicalDevice, - uint32_t* pPropertyCount, - VkDisplayPlanePropertiesKHR* pProperties); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetDisplayPlaneSupportedDisplaysKHR( - VkPhysicalDevice physicalDevice, - uint32_t planeIndex, - uint32_t* pDisplayCount, - VkDisplayKHR* pDisplays); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetDisplayModePropertiesKHR( - VkPhysicalDevice physicalDevice, - VkDisplayKHR display, - uint32_t* pPropertyCount, - VkDisplayModePropertiesKHR* pProperties); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateDisplayModeKHR( - VkPhysicalDevice physicalDevice, - VkDisplayKHR display, - const VkDisplayModeCreateInfoKHR* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkDisplayModeKHR* pMode); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetDisplayPlaneCapabilitiesKHR( - VkPhysicalDevice physicalDevice, - VkDisplayModeKHR mode, - uint32_t planeIndex, - VkDisplayPlaneCapabilitiesKHR* pCapabilities); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateDisplayPlaneSurfaceKHR( - VkInstance instance, - const VkDisplaySurfaceCreateInfoKHR* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkSurfaceKHR* pSurface); -#endif - -#define VK_KHR_display_swapchain 1 -#define VK_KHR_DISPLAY_SWAPCHAIN_SPEC_VERSION 9 -#define VK_KHR_DISPLAY_SWAPCHAIN_EXTENSION_NAME "VK_KHR_display_swapchain" - -typedef struct VkDisplayPresentInfoKHR { - VkStructureType sType; - const void* pNext; - VkRect2D srcRect; - VkRect2D dstRect; - VkBool32 persistent; -} VkDisplayPresentInfoKHR; - - -typedef VkResult (VKAPI_PTR *PFN_vkCreateSharedSwapchainsKHR)(VkDevice device, uint32_t swapchainCount, const VkSwapchainCreateInfoKHR* pCreateInfos, const VkAllocationCallbacks* pAllocator, VkSwapchainKHR* pSwapchains); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkCreateSharedSwapchainsKHR( - VkDevice device, - uint32_t swapchainCount, - const VkSwapchainCreateInfoKHR* pCreateInfos, - const VkAllocationCallbacks* pAllocator, - VkSwapchainKHR* pSwapchains); -#endif - -#ifdef VK_USE_PLATFORM_XLIB_KHR -#define VK_KHR_xlib_surface 1 -#include - -#define VK_KHR_XLIB_SURFACE_SPEC_VERSION 6 -#define VK_KHR_XLIB_SURFACE_EXTENSION_NAME "VK_KHR_xlib_surface" - -typedef VkFlags VkXlibSurfaceCreateFlagsKHR; - -typedef struct VkXlibSurfaceCreateInfoKHR { - VkStructureType sType; - const void* pNext; - VkXlibSurfaceCreateFlagsKHR flags; - Display* dpy; - Window window; -} VkXlibSurfaceCreateInfoKHR; - - -typedef VkResult (VKAPI_PTR *PFN_vkCreateXlibSurfaceKHR)(VkInstance instance, const VkXlibSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface); -typedef VkBool32 (VKAPI_PTR *PFN_vkGetPhysicalDeviceXlibPresentationSupportKHR)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, Display* dpy, VisualID visualID); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkCreateXlibSurfaceKHR( - VkInstance instance, - const VkXlibSurfaceCreateInfoKHR* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkSurfaceKHR* pSurface); - -VKAPI_ATTR VkBool32 VKAPI_CALL vkGetPhysicalDeviceXlibPresentationSupportKHR( - VkPhysicalDevice physicalDevice, - uint32_t queueFamilyIndex, - Display* dpy, - VisualID visualID); -#endif -#endif /* VK_USE_PLATFORM_XLIB_KHR */ - -#ifdef VK_USE_PLATFORM_XCB_KHR -#define VK_KHR_xcb_surface 1 -#include - -#define VK_KHR_XCB_SURFACE_SPEC_VERSION 6 -#define VK_KHR_XCB_SURFACE_EXTENSION_NAME "VK_KHR_xcb_surface" - -typedef VkFlags VkXcbSurfaceCreateFlagsKHR; - -typedef struct VkXcbSurfaceCreateInfoKHR { - VkStructureType sType; - const void* pNext; - VkXcbSurfaceCreateFlagsKHR flags; - xcb_connection_t* connection; - xcb_window_t window; -} VkXcbSurfaceCreateInfoKHR; - - -typedef VkResult (VKAPI_PTR *PFN_vkCreateXcbSurfaceKHR)(VkInstance instance, const VkXcbSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface); -typedef VkBool32 (VKAPI_PTR *PFN_vkGetPhysicalDeviceXcbPresentationSupportKHR)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, xcb_connection_t* connection, xcb_visualid_t visual_id); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkCreateXcbSurfaceKHR( - VkInstance instance, - const VkXcbSurfaceCreateInfoKHR* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkSurfaceKHR* pSurface); - -VKAPI_ATTR VkBool32 VKAPI_CALL vkGetPhysicalDeviceXcbPresentationSupportKHR( - VkPhysicalDevice physicalDevice, - uint32_t queueFamilyIndex, - xcb_connection_t* connection, - xcb_visualid_t visual_id); -#endif -#endif /* VK_USE_PLATFORM_XCB_KHR */ - -#ifdef VK_USE_PLATFORM_WAYLAND_KHR -#define VK_KHR_wayland_surface 1 -#include - -#define VK_KHR_WAYLAND_SURFACE_SPEC_VERSION 5 -#define VK_KHR_WAYLAND_SURFACE_EXTENSION_NAME "VK_KHR_wayland_surface" - -typedef VkFlags VkWaylandSurfaceCreateFlagsKHR; - -typedef struct VkWaylandSurfaceCreateInfoKHR { - VkStructureType sType; - const void* pNext; - VkWaylandSurfaceCreateFlagsKHR flags; - struct wl_display* display; - struct wl_surface* surface; -} VkWaylandSurfaceCreateInfoKHR; - - -typedef VkResult (VKAPI_PTR *PFN_vkCreateWaylandSurfaceKHR)(VkInstance instance, const VkWaylandSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface); -typedef VkBool32 (VKAPI_PTR *PFN_vkGetPhysicalDeviceWaylandPresentationSupportKHR)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, struct wl_display* display); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkCreateWaylandSurfaceKHR( - VkInstance instance, - const VkWaylandSurfaceCreateInfoKHR* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkSurfaceKHR* pSurface); - -VKAPI_ATTR VkBool32 VKAPI_CALL vkGetPhysicalDeviceWaylandPresentationSupportKHR( - VkPhysicalDevice physicalDevice, - uint32_t queueFamilyIndex, - struct wl_display* display); -#endif -#endif /* VK_USE_PLATFORM_WAYLAND_KHR */ - -#ifdef VK_USE_PLATFORM_MIR_KHR -#define VK_KHR_mir_surface 1 -#include - -#define VK_KHR_MIR_SURFACE_SPEC_VERSION 4 -#define VK_KHR_MIR_SURFACE_EXTENSION_NAME "VK_KHR_mir_surface" - -typedef VkFlags VkMirSurfaceCreateFlagsKHR; - -typedef struct VkMirSurfaceCreateInfoKHR { - VkStructureType sType; - const void* pNext; - VkMirSurfaceCreateFlagsKHR flags; - MirConnection* connection; - MirSurface* mirSurface; -} VkMirSurfaceCreateInfoKHR; - - -typedef VkResult (VKAPI_PTR *PFN_vkCreateMirSurfaceKHR)(VkInstance instance, const VkMirSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface); -typedef VkBool32 (VKAPI_PTR *PFN_vkGetPhysicalDeviceMirPresentationSupportKHR)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, MirConnection* connection); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkCreateMirSurfaceKHR( - VkInstance instance, - const VkMirSurfaceCreateInfoKHR* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkSurfaceKHR* pSurface); - -VKAPI_ATTR VkBool32 VKAPI_CALL vkGetPhysicalDeviceMirPresentationSupportKHR( - VkPhysicalDevice physicalDevice, - uint32_t queueFamilyIndex, - MirConnection* connection); -#endif -#endif /* VK_USE_PLATFORM_MIR_KHR */ - -#ifdef VK_USE_PLATFORM_ANDROID_KHR -#define VK_KHR_android_surface 1 -#include - -#define VK_KHR_ANDROID_SURFACE_SPEC_VERSION 6 -#define VK_KHR_ANDROID_SURFACE_EXTENSION_NAME "VK_KHR_android_surface" - -typedef VkFlags VkAndroidSurfaceCreateFlagsKHR; - -typedef struct VkAndroidSurfaceCreateInfoKHR { - VkStructureType sType; - const void* pNext; - VkAndroidSurfaceCreateFlagsKHR flags; - ANativeWindow* window; -} VkAndroidSurfaceCreateInfoKHR; - - -typedef VkResult (VKAPI_PTR *PFN_vkCreateAndroidSurfaceKHR)(VkInstance instance, const VkAndroidSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkCreateAndroidSurfaceKHR( - VkInstance instance, - const VkAndroidSurfaceCreateInfoKHR* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkSurfaceKHR* pSurface); -#endif -#endif /* VK_USE_PLATFORM_ANDROID_KHR */ - -#ifdef VK_USE_PLATFORM_WIN32_KHR -#define VK_KHR_win32_surface 1 -#include - -#define VK_KHR_WIN32_SURFACE_SPEC_VERSION 5 -#define VK_KHR_WIN32_SURFACE_EXTENSION_NAME "VK_KHR_win32_surface" - -typedef VkFlags VkWin32SurfaceCreateFlagsKHR; - -typedef struct VkWin32SurfaceCreateInfoKHR { - VkStructureType sType; - const void* pNext; - VkWin32SurfaceCreateFlagsKHR flags; - HINSTANCE hinstance; - HWND hwnd; -} VkWin32SurfaceCreateInfoKHR; - - -typedef VkResult (VKAPI_PTR *PFN_vkCreateWin32SurfaceKHR)(VkInstance instance, const VkWin32SurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface); -typedef VkBool32 (VKAPI_PTR *PFN_vkGetPhysicalDeviceWin32PresentationSupportKHR)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkCreateWin32SurfaceKHR( - VkInstance instance, - const VkWin32SurfaceCreateInfoKHR* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkSurfaceKHR* pSurface); - -VKAPI_ATTR VkBool32 VKAPI_CALL vkGetPhysicalDeviceWin32PresentationSupportKHR( - VkPhysicalDevice physicalDevice, - uint32_t queueFamilyIndex); -#endif -#endif /* VK_USE_PLATFORM_WIN32_KHR */ - -#define VK_KHR_sampler_mirror_clamp_to_edge 1 -#define VK_KHR_SAMPLER_MIRROR_CLAMP_TO_EDGE_SPEC_VERSION 1 -#define VK_KHR_SAMPLER_MIRROR_CLAMP_TO_EDGE_EXTENSION_NAME "VK_KHR_sampler_mirror_clamp_to_edge" - - -#define VK_KHR_get_physical_device_properties2 1 -#define VK_KHR_GET_PHYSICAL_DEVICE_PROPERTIES_2_SPEC_VERSION 1 -#define VK_KHR_GET_PHYSICAL_DEVICE_PROPERTIES_2_EXTENSION_NAME "VK_KHR_get_physical_device_properties2" - -typedef struct VkPhysicalDeviceFeatures2KHR { - VkStructureType sType; - void* pNext; - VkPhysicalDeviceFeatures features; -} VkPhysicalDeviceFeatures2KHR; - -typedef struct VkPhysicalDeviceProperties2KHR { - VkStructureType sType; - void* pNext; - VkPhysicalDeviceProperties properties; -} VkPhysicalDeviceProperties2KHR; - -typedef struct VkFormatProperties2KHR { - VkStructureType sType; - void* pNext; - VkFormatProperties formatProperties; -} VkFormatProperties2KHR; - -typedef struct VkImageFormatProperties2KHR { - VkStructureType sType; - void* pNext; - VkImageFormatProperties imageFormatProperties; -} VkImageFormatProperties2KHR; - -typedef struct VkPhysicalDeviceImageFormatInfo2KHR { - VkStructureType sType; - const void* pNext; - VkFormat format; - VkImageType type; - VkImageTiling tiling; - VkImageUsageFlags usage; - VkImageCreateFlags flags; -} VkPhysicalDeviceImageFormatInfo2KHR; - -typedef struct VkQueueFamilyProperties2KHR { - VkStructureType sType; - void* pNext; - VkQueueFamilyProperties queueFamilyProperties; -} VkQueueFamilyProperties2KHR; - -typedef struct VkPhysicalDeviceMemoryProperties2KHR { - VkStructureType sType; - void* pNext; - VkPhysicalDeviceMemoryProperties memoryProperties; -} VkPhysicalDeviceMemoryProperties2KHR; - -typedef struct VkSparseImageFormatProperties2KHR { - VkStructureType sType; - void* pNext; - VkSparseImageFormatProperties properties; -} VkSparseImageFormatProperties2KHR; - -typedef struct VkPhysicalDeviceSparseImageFormatInfo2KHR { - VkStructureType sType; - const void* pNext; - VkFormat format; - VkImageType type; - VkSampleCountFlagBits samples; - VkImageUsageFlags usage; - VkImageTiling tiling; -} VkPhysicalDeviceSparseImageFormatInfo2KHR; - - -typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFeatures2KHR)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceFeatures2KHR* pFeatures); -typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceProperties2KHR)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceProperties2KHR* pProperties); -typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFormatProperties2KHR)(VkPhysicalDevice physicalDevice, VkFormat format, VkFormatProperties2KHR* pFormatProperties); -typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceImageFormatProperties2KHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceImageFormatInfo2KHR* pImageFormatInfo, VkImageFormatProperties2KHR* pImageFormatProperties); -typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceQueueFamilyProperties2KHR)(VkPhysicalDevice physicalDevice, uint32_t* pQueueFamilyPropertyCount, VkQueueFamilyProperties2KHR* pQueueFamilyProperties); -typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceMemoryProperties2KHR)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceMemoryProperties2KHR* pMemoryProperties); -typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceSparseImageFormatProperties2KHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceSparseImageFormatInfo2KHR* pFormatInfo, uint32_t* pPropertyCount, VkSparseImageFormatProperties2KHR* pProperties); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFeatures2KHR( - VkPhysicalDevice physicalDevice, - VkPhysicalDeviceFeatures2KHR* pFeatures); - -VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceProperties2KHR( - VkPhysicalDevice physicalDevice, - VkPhysicalDeviceProperties2KHR* pProperties); - -VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFormatProperties2KHR( - VkPhysicalDevice physicalDevice, - VkFormat format, - VkFormatProperties2KHR* pFormatProperties); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceImageFormatProperties2KHR( - VkPhysicalDevice physicalDevice, - const VkPhysicalDeviceImageFormatInfo2KHR* pImageFormatInfo, - VkImageFormatProperties2KHR* pImageFormatProperties); - -VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceQueueFamilyProperties2KHR( - VkPhysicalDevice physicalDevice, - uint32_t* pQueueFamilyPropertyCount, - VkQueueFamilyProperties2KHR* pQueueFamilyProperties); - -VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceMemoryProperties2KHR( - VkPhysicalDevice physicalDevice, - VkPhysicalDeviceMemoryProperties2KHR* pMemoryProperties); - -VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceSparseImageFormatProperties2KHR( - VkPhysicalDevice physicalDevice, - const VkPhysicalDeviceSparseImageFormatInfo2KHR* pFormatInfo, - uint32_t* pPropertyCount, - VkSparseImageFormatProperties2KHR* pProperties); -#endif - -#define VK_KHR_shader_draw_parameters 1 -#define VK_KHR_SHADER_DRAW_PARAMETERS_SPEC_VERSION 1 -#define VK_KHR_SHADER_DRAW_PARAMETERS_EXTENSION_NAME "VK_KHR_shader_draw_parameters" - - -#define VK_KHR_maintenance1 1 -#define VK_KHR_MAINTENANCE1_SPEC_VERSION 1 -#define VK_KHR_MAINTENANCE1_EXTENSION_NAME "VK_KHR_maintenance1" - -typedef VkFlags VkCommandPoolTrimFlagsKHR; - -typedef void (VKAPI_PTR *PFN_vkTrimCommandPoolKHR)(VkDevice device, VkCommandPool commandPool, VkCommandPoolTrimFlagsKHR flags); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR void VKAPI_CALL vkTrimCommandPoolKHR( - VkDevice device, - VkCommandPool commandPool, - VkCommandPoolTrimFlagsKHR flags); -#endif - -#define VK_EXT_debug_report 1 -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDebugReportCallbackEXT) - -#define VK_EXT_DEBUG_REPORT_SPEC_VERSION 4 -#define VK_EXT_DEBUG_REPORT_EXTENSION_NAME "VK_EXT_debug_report" -#define VK_STRUCTURE_TYPE_DEBUG_REPORT_CREATE_INFO_EXT VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT - - -typedef enum VkDebugReportObjectTypeEXT { - VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT = 0, - VK_DEBUG_REPORT_OBJECT_TYPE_INSTANCE_EXT = 1, - VK_DEBUG_REPORT_OBJECT_TYPE_PHYSICAL_DEVICE_EXT = 2, - VK_DEBUG_REPORT_OBJECT_TYPE_DEVICE_EXT = 3, - VK_DEBUG_REPORT_OBJECT_TYPE_QUEUE_EXT = 4, - VK_DEBUG_REPORT_OBJECT_TYPE_SEMAPHORE_EXT = 5, - VK_DEBUG_REPORT_OBJECT_TYPE_COMMAND_BUFFER_EXT = 6, - VK_DEBUG_REPORT_OBJECT_TYPE_FENCE_EXT = 7, - VK_DEBUG_REPORT_OBJECT_TYPE_DEVICE_MEMORY_EXT = 8, - VK_DEBUG_REPORT_OBJECT_TYPE_BUFFER_EXT = 9, - VK_DEBUG_REPORT_OBJECT_TYPE_IMAGE_EXT = 10, - VK_DEBUG_REPORT_OBJECT_TYPE_EVENT_EXT = 11, - VK_DEBUG_REPORT_OBJECT_TYPE_QUERY_POOL_EXT = 12, - VK_DEBUG_REPORT_OBJECT_TYPE_BUFFER_VIEW_EXT = 13, - VK_DEBUG_REPORT_OBJECT_TYPE_IMAGE_VIEW_EXT = 14, - VK_DEBUG_REPORT_OBJECT_TYPE_SHADER_MODULE_EXT = 15, - VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_CACHE_EXT = 16, - VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_LAYOUT_EXT = 17, - VK_DEBUG_REPORT_OBJECT_TYPE_RENDER_PASS_EXT = 18, - VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_EXT = 19, - VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_SET_LAYOUT_EXT = 20, - VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_EXT = 21, - VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_POOL_EXT = 22, - VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_SET_EXT = 23, - VK_DEBUG_REPORT_OBJECT_TYPE_FRAMEBUFFER_EXT = 24, - VK_DEBUG_REPORT_OBJECT_TYPE_COMMAND_POOL_EXT = 25, - VK_DEBUG_REPORT_OBJECT_TYPE_SURFACE_KHR_EXT = 26, - VK_DEBUG_REPORT_OBJECT_TYPE_SWAPCHAIN_KHR_EXT = 27, - VK_DEBUG_REPORT_OBJECT_TYPE_DEBUG_REPORT_EXT = 28, - VK_DEBUG_REPORT_OBJECT_TYPE_DISPLAY_KHR_EXT = 29, - VK_DEBUG_REPORT_OBJECT_TYPE_DISPLAY_MODE_KHR_EXT = 30, - VK_DEBUG_REPORT_OBJECT_TYPE_OBJECT_TABLE_NVX_EXT = 31, - VK_DEBUG_REPORT_OBJECT_TYPE_INDIRECT_COMMANDS_LAYOUT_NVX_EXT = 32, - VK_DEBUG_REPORT_OBJECT_TYPE_BEGIN_RANGE_EXT = VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT, - VK_DEBUG_REPORT_OBJECT_TYPE_END_RANGE_EXT = VK_DEBUG_REPORT_OBJECT_TYPE_INDIRECT_COMMANDS_LAYOUT_NVX_EXT, - VK_DEBUG_REPORT_OBJECT_TYPE_RANGE_SIZE_EXT = (VK_DEBUG_REPORT_OBJECT_TYPE_INDIRECT_COMMANDS_LAYOUT_NVX_EXT - VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT + 1), - VK_DEBUG_REPORT_OBJECT_TYPE_MAX_ENUM_EXT = 0x7FFFFFFF -} VkDebugReportObjectTypeEXT; - -typedef enum VkDebugReportErrorEXT { - VK_DEBUG_REPORT_ERROR_NONE_EXT = 0, - VK_DEBUG_REPORT_ERROR_CALLBACK_REF_EXT = 1, - VK_DEBUG_REPORT_ERROR_BEGIN_RANGE_EXT = VK_DEBUG_REPORT_ERROR_NONE_EXT, - VK_DEBUG_REPORT_ERROR_END_RANGE_EXT = VK_DEBUG_REPORT_ERROR_CALLBACK_REF_EXT, - VK_DEBUG_REPORT_ERROR_RANGE_SIZE_EXT = (VK_DEBUG_REPORT_ERROR_CALLBACK_REF_EXT - VK_DEBUG_REPORT_ERROR_NONE_EXT + 1), - VK_DEBUG_REPORT_ERROR_MAX_ENUM_EXT = 0x7FFFFFFF -} VkDebugReportErrorEXT; - - -typedef enum VkDebugReportFlagBitsEXT { - VK_DEBUG_REPORT_INFORMATION_BIT_EXT = 0x00000001, - VK_DEBUG_REPORT_WARNING_BIT_EXT = 0x00000002, - VK_DEBUG_REPORT_PERFORMANCE_WARNING_BIT_EXT = 0x00000004, - VK_DEBUG_REPORT_ERROR_BIT_EXT = 0x00000008, - VK_DEBUG_REPORT_DEBUG_BIT_EXT = 0x00000010, - VK_DEBUG_REPORT_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF -} VkDebugReportFlagBitsEXT; -typedef VkFlags VkDebugReportFlagsEXT; - -typedef VkBool32 (VKAPI_PTR *PFN_vkDebugReportCallbackEXT)( - VkDebugReportFlagsEXT flags, - VkDebugReportObjectTypeEXT objectType, - uint64_t object, - size_t location, - int32_t messageCode, - const char* pLayerPrefix, - const char* pMessage, - void* pUserData); - - -typedef struct VkDebugReportCallbackCreateInfoEXT { - VkStructureType sType; - const void* pNext; - VkDebugReportFlagsEXT flags; - PFN_vkDebugReportCallbackEXT pfnCallback; - void* pUserData; -} VkDebugReportCallbackCreateInfoEXT; - - -typedef VkResult (VKAPI_PTR *PFN_vkCreateDebugReportCallbackEXT)(VkInstance instance, const VkDebugReportCallbackCreateInfoEXT* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDebugReportCallbackEXT* pCallback); -typedef void (VKAPI_PTR *PFN_vkDestroyDebugReportCallbackEXT)(VkInstance instance, VkDebugReportCallbackEXT callback, const VkAllocationCallbacks* pAllocator); -typedef void (VKAPI_PTR *PFN_vkDebugReportMessageEXT)(VkInstance instance, VkDebugReportFlagsEXT flags, VkDebugReportObjectTypeEXT objectType, uint64_t object, size_t location, int32_t messageCode, const char* pLayerPrefix, const char* pMessage); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkCreateDebugReportCallbackEXT( - VkInstance instance, - const VkDebugReportCallbackCreateInfoEXT* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkDebugReportCallbackEXT* pCallback); - -VKAPI_ATTR void VKAPI_CALL vkDestroyDebugReportCallbackEXT( - VkInstance instance, - VkDebugReportCallbackEXT callback, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR void VKAPI_CALL vkDebugReportMessageEXT( - VkInstance instance, - VkDebugReportFlagsEXT flags, - VkDebugReportObjectTypeEXT objectType, - uint64_t object, - size_t location, - int32_t messageCode, - const char* pLayerPrefix, - const char* pMessage); -#endif - -#define VK_NV_glsl_shader 1 -#define VK_NV_GLSL_SHADER_SPEC_VERSION 1 -#define VK_NV_GLSL_SHADER_EXTENSION_NAME "VK_NV_glsl_shader" - - -#define VK_IMG_filter_cubic 1 -#define VK_IMG_FILTER_CUBIC_SPEC_VERSION 1 -#define VK_IMG_FILTER_CUBIC_EXTENSION_NAME "VK_IMG_filter_cubic" - - -#define VK_AMD_rasterization_order 1 -#define VK_AMD_RASTERIZATION_ORDER_SPEC_VERSION 1 -#define VK_AMD_RASTERIZATION_ORDER_EXTENSION_NAME "VK_AMD_rasterization_order" - - -typedef enum VkRasterizationOrderAMD { - VK_RASTERIZATION_ORDER_STRICT_AMD = 0, - VK_RASTERIZATION_ORDER_RELAXED_AMD = 1, - VK_RASTERIZATION_ORDER_BEGIN_RANGE_AMD = VK_RASTERIZATION_ORDER_STRICT_AMD, - VK_RASTERIZATION_ORDER_END_RANGE_AMD = VK_RASTERIZATION_ORDER_RELAXED_AMD, - VK_RASTERIZATION_ORDER_RANGE_SIZE_AMD = (VK_RASTERIZATION_ORDER_RELAXED_AMD - VK_RASTERIZATION_ORDER_STRICT_AMD + 1), - VK_RASTERIZATION_ORDER_MAX_ENUM_AMD = 0x7FFFFFFF -} VkRasterizationOrderAMD; - -typedef struct VkPipelineRasterizationStateRasterizationOrderAMD { - VkStructureType sType; - const void* pNext; - VkRasterizationOrderAMD rasterizationOrder; -} VkPipelineRasterizationStateRasterizationOrderAMD; - - - -#define VK_AMD_shader_trinary_minmax 1 -#define VK_AMD_SHADER_TRINARY_MINMAX_SPEC_VERSION 1 -#define VK_AMD_SHADER_TRINARY_MINMAX_EXTENSION_NAME "VK_AMD_shader_trinary_minmax" - - -#define VK_AMD_shader_explicit_vertex_parameter 1 -#define VK_AMD_SHADER_EXPLICIT_VERTEX_PARAMETER_SPEC_VERSION 1 -#define VK_AMD_SHADER_EXPLICIT_VERTEX_PARAMETER_EXTENSION_NAME "VK_AMD_shader_explicit_vertex_parameter" - - -#define VK_EXT_debug_marker 1 -#define VK_EXT_DEBUG_MARKER_SPEC_VERSION 3 -#define VK_EXT_DEBUG_MARKER_EXTENSION_NAME "VK_EXT_debug_marker" - -typedef struct VkDebugMarkerObjectNameInfoEXT { - VkStructureType sType; - const void* pNext; - VkDebugReportObjectTypeEXT objectType; - uint64_t object; - const char* pObjectName; -} VkDebugMarkerObjectNameInfoEXT; - -typedef struct VkDebugMarkerObjectTagInfoEXT { - VkStructureType sType; - const void* pNext; - VkDebugReportObjectTypeEXT objectType; - uint64_t object; - uint64_t tagName; - size_t tagSize; - const void* pTag; -} VkDebugMarkerObjectTagInfoEXT; - -typedef struct VkDebugMarkerMarkerInfoEXT { - VkStructureType sType; - const void* pNext; - const char* pMarkerName; - float color[4]; -} VkDebugMarkerMarkerInfoEXT; - - -typedef VkResult (VKAPI_PTR *PFN_vkDebugMarkerSetObjectTagEXT)(VkDevice device, VkDebugMarkerObjectTagInfoEXT* pTagInfo); -typedef VkResult (VKAPI_PTR *PFN_vkDebugMarkerSetObjectNameEXT)(VkDevice device, VkDebugMarkerObjectNameInfoEXT* pNameInfo); -typedef void (VKAPI_PTR *PFN_vkCmdDebugMarkerBeginEXT)(VkCommandBuffer commandBuffer, VkDebugMarkerMarkerInfoEXT* pMarkerInfo); -typedef void (VKAPI_PTR *PFN_vkCmdDebugMarkerEndEXT)(VkCommandBuffer commandBuffer); -typedef void (VKAPI_PTR *PFN_vkCmdDebugMarkerInsertEXT)(VkCommandBuffer commandBuffer, VkDebugMarkerMarkerInfoEXT* pMarkerInfo); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkDebugMarkerSetObjectTagEXT( - VkDevice device, - VkDebugMarkerObjectTagInfoEXT* pTagInfo); - -VKAPI_ATTR VkResult VKAPI_CALL vkDebugMarkerSetObjectNameEXT( - VkDevice device, - VkDebugMarkerObjectNameInfoEXT* pNameInfo); - -VKAPI_ATTR void VKAPI_CALL vkCmdDebugMarkerBeginEXT( - VkCommandBuffer commandBuffer, - VkDebugMarkerMarkerInfoEXT* pMarkerInfo); - -VKAPI_ATTR void VKAPI_CALL vkCmdDebugMarkerEndEXT( - VkCommandBuffer commandBuffer); - -VKAPI_ATTR void VKAPI_CALL vkCmdDebugMarkerInsertEXT( - VkCommandBuffer commandBuffer, - VkDebugMarkerMarkerInfoEXT* pMarkerInfo); -#endif - -#define VK_AMD_gcn_shader 1 -#define VK_AMD_GCN_SHADER_SPEC_VERSION 1 -#define VK_AMD_GCN_SHADER_EXTENSION_NAME "VK_AMD_gcn_shader" - - -#define VK_NV_dedicated_allocation 1 -#define VK_NV_DEDICATED_ALLOCATION_SPEC_VERSION 1 -#define VK_NV_DEDICATED_ALLOCATION_EXTENSION_NAME "VK_NV_dedicated_allocation" - -typedef struct VkDedicatedAllocationImageCreateInfoNV { - VkStructureType sType; - const void* pNext; - VkBool32 dedicatedAllocation; -} VkDedicatedAllocationImageCreateInfoNV; - -typedef struct VkDedicatedAllocationBufferCreateInfoNV { - VkStructureType sType; - const void* pNext; - VkBool32 dedicatedAllocation; -} VkDedicatedAllocationBufferCreateInfoNV; - -typedef struct VkDedicatedAllocationMemoryAllocateInfoNV { - VkStructureType sType; - const void* pNext; - VkImage image; - VkBuffer buffer; -} VkDedicatedAllocationMemoryAllocateInfoNV; - - - -#define VK_AMD_draw_indirect_count 1 -#define VK_AMD_DRAW_INDIRECT_COUNT_SPEC_VERSION 1 -#define VK_AMD_DRAW_INDIRECT_COUNT_EXTENSION_NAME "VK_AMD_draw_indirect_count" - -typedef void (VKAPI_PTR *PFN_vkCmdDrawIndirectCountAMD)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, VkBuffer countBuffer, VkDeviceSize countBufferOffset, uint32_t maxDrawCount, uint32_t stride); -typedef void (VKAPI_PTR *PFN_vkCmdDrawIndexedIndirectCountAMD)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, VkBuffer countBuffer, VkDeviceSize countBufferOffset, uint32_t maxDrawCount, uint32_t stride); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR void VKAPI_CALL vkCmdDrawIndirectCountAMD( - VkCommandBuffer commandBuffer, - VkBuffer buffer, - VkDeviceSize offset, - VkBuffer countBuffer, - VkDeviceSize countBufferOffset, - uint32_t maxDrawCount, - uint32_t stride); - -VKAPI_ATTR void VKAPI_CALL vkCmdDrawIndexedIndirectCountAMD( - VkCommandBuffer commandBuffer, - VkBuffer buffer, - VkDeviceSize offset, - VkBuffer countBuffer, - VkDeviceSize countBufferOffset, - uint32_t maxDrawCount, - uint32_t stride); -#endif - -#define VK_AMD_negative_viewport_height 1 -#define VK_AMD_NEGATIVE_VIEWPORT_HEIGHT_SPEC_VERSION 1 -#define VK_AMD_NEGATIVE_VIEWPORT_HEIGHT_EXTENSION_NAME "VK_AMD_negative_viewport_height" - - -#define VK_AMD_gpu_shader_half_float 1 -#define VK_AMD_GPU_SHADER_HALF_FLOAT_SPEC_VERSION 1 -#define VK_AMD_GPU_SHADER_HALF_FLOAT_EXTENSION_NAME "VK_AMD_gpu_shader_half_float" - - -#define VK_AMD_shader_ballot 1 -#define VK_AMD_SHADER_BALLOT_SPEC_VERSION 1 -#define VK_AMD_SHADER_BALLOT_EXTENSION_NAME "VK_AMD_shader_ballot" - - -#define VK_IMG_format_pvrtc 1 -#define VK_IMG_FORMAT_PVRTC_SPEC_VERSION 1 -#define VK_IMG_FORMAT_PVRTC_EXTENSION_NAME "VK_IMG_format_pvrtc" - - -#define VK_NV_external_memory_capabilities 1 -#define VK_NV_EXTERNAL_MEMORY_CAPABILITIES_SPEC_VERSION 1 -#define VK_NV_EXTERNAL_MEMORY_CAPABILITIES_EXTENSION_NAME "VK_NV_external_memory_capabilities" - - -typedef enum VkExternalMemoryHandleTypeFlagBitsNV { - VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT_NV = 0x00000001, - VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_NV = 0x00000002, - VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_IMAGE_BIT_NV = 0x00000004, - VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_IMAGE_KMT_BIT_NV = 0x00000008, - VK_EXTERNAL_MEMORY_HANDLE_TYPE_FLAG_BITS_MAX_ENUM_NV = 0x7FFFFFFF -} VkExternalMemoryHandleTypeFlagBitsNV; -typedef VkFlags VkExternalMemoryHandleTypeFlagsNV; - -typedef enum VkExternalMemoryFeatureFlagBitsNV { - VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT_NV = 0x00000001, - VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT_NV = 0x00000002, - VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT_NV = 0x00000004, - VK_EXTERNAL_MEMORY_FEATURE_FLAG_BITS_MAX_ENUM_NV = 0x7FFFFFFF -} VkExternalMemoryFeatureFlagBitsNV; -typedef VkFlags VkExternalMemoryFeatureFlagsNV; - -typedef struct VkExternalImageFormatPropertiesNV { - VkImageFormatProperties imageFormatProperties; - VkExternalMemoryFeatureFlagsNV externalMemoryFeatures; - VkExternalMemoryHandleTypeFlagsNV exportFromImportedHandleTypes; - VkExternalMemoryHandleTypeFlagsNV compatibleHandleTypes; -} VkExternalImageFormatPropertiesNV; - - -typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceExternalImageFormatPropertiesNV)(VkPhysicalDevice physicalDevice, VkFormat format, VkImageType type, VkImageTiling tiling, VkImageUsageFlags usage, VkImageCreateFlags flags, VkExternalMemoryHandleTypeFlagsNV externalHandleType, VkExternalImageFormatPropertiesNV* pExternalImageFormatProperties); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceExternalImageFormatPropertiesNV( - VkPhysicalDevice physicalDevice, - VkFormat format, - VkImageType type, - VkImageTiling tiling, - VkImageUsageFlags usage, - VkImageCreateFlags flags, - VkExternalMemoryHandleTypeFlagsNV externalHandleType, - VkExternalImageFormatPropertiesNV* pExternalImageFormatProperties); -#endif - -#define VK_NV_external_memory 1 -#define VK_NV_EXTERNAL_MEMORY_SPEC_VERSION 1 -#define VK_NV_EXTERNAL_MEMORY_EXTENSION_NAME "VK_NV_external_memory" - -typedef struct VkExternalMemoryImageCreateInfoNV { - VkStructureType sType; - const void* pNext; - VkExternalMemoryHandleTypeFlagsNV handleTypes; -} VkExternalMemoryImageCreateInfoNV; - -typedef struct VkExportMemoryAllocateInfoNV { - VkStructureType sType; - const void* pNext; - VkExternalMemoryHandleTypeFlagsNV handleTypes; -} VkExportMemoryAllocateInfoNV; - - - -#ifdef VK_USE_PLATFORM_WIN32_KHR -#define VK_NV_external_memory_win32 1 -#define VK_NV_EXTERNAL_MEMORY_WIN32_SPEC_VERSION 1 -#define VK_NV_EXTERNAL_MEMORY_WIN32_EXTENSION_NAME "VK_NV_external_memory_win32" - -typedef struct VkImportMemoryWin32HandleInfoNV { - VkStructureType sType; - const void* pNext; - VkExternalMemoryHandleTypeFlagsNV handleType; - HANDLE handle; -} VkImportMemoryWin32HandleInfoNV; - -typedef struct VkExportMemoryWin32HandleInfoNV { - VkStructureType sType; - const void* pNext; - const SECURITY_ATTRIBUTES* pAttributes; - DWORD dwAccess; -} VkExportMemoryWin32HandleInfoNV; - - -typedef VkResult (VKAPI_PTR *PFN_vkGetMemoryWin32HandleNV)(VkDevice device, VkDeviceMemory memory, VkExternalMemoryHandleTypeFlagsNV handleType, HANDLE* pHandle); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryWin32HandleNV( - VkDevice device, - VkDeviceMemory memory, - VkExternalMemoryHandleTypeFlagsNV handleType, - HANDLE* pHandle); -#endif -#endif /* VK_USE_PLATFORM_WIN32_KHR */ - -#ifdef VK_USE_PLATFORM_WIN32_KHR -#define VK_NV_win32_keyed_mutex 1 -#define VK_NV_WIN32_KEYED_MUTEX_SPEC_VERSION 1 -#define VK_NV_WIN32_KEYED_MUTEX_EXTENSION_NAME "VK_NV_win32_keyed_mutex" - -typedef struct VkWin32KeyedMutexAcquireReleaseInfoNV { - VkStructureType sType; - const void* pNext; - uint32_t acquireCount; - const VkDeviceMemory* pAcquireSyncs; - const uint64_t* pAcquireKeys; - const uint32_t* pAcquireTimeoutMilliseconds; - uint32_t releaseCount; - const VkDeviceMemory* pReleaseSyncs; - const uint64_t* pReleaseKeys; -} VkWin32KeyedMutexAcquireReleaseInfoNV; - - -#endif /* VK_USE_PLATFORM_WIN32_KHR */ - -#define VK_EXT_validation_flags 1 -#define VK_EXT_VALIDATION_FLAGS_SPEC_VERSION 1 -#define VK_EXT_VALIDATION_FLAGS_EXTENSION_NAME "VK_EXT_validation_flags" - - -typedef enum VkValidationCheckEXT { - VK_VALIDATION_CHECK_ALL_EXT = 0, - VK_VALIDATION_CHECK_BEGIN_RANGE_EXT = VK_VALIDATION_CHECK_ALL_EXT, - VK_VALIDATION_CHECK_END_RANGE_EXT = VK_VALIDATION_CHECK_ALL_EXT, - VK_VALIDATION_CHECK_RANGE_SIZE_EXT = (VK_VALIDATION_CHECK_ALL_EXT - VK_VALIDATION_CHECK_ALL_EXT + 1), - VK_VALIDATION_CHECK_MAX_ENUM_EXT = 0x7FFFFFFF -} VkValidationCheckEXT; - -typedef struct VkValidationFlagsEXT { - VkStructureType sType; - const void* pNext; - uint32_t disabledValidationCheckCount; - VkValidationCheckEXT* pDisabledValidationChecks; -} VkValidationFlagsEXT; - - - -#ifdef VK_USE_PLATFORM_VI_NN -#define VK_NN_vi_surface 1 -#define VK_NN_VI_SURFACE_SPEC_VERSION 1 -#define VK_NN_VI_SURFACE_EXTENSION_NAME "VK_NN_vi_surface" - -typedef VkFlags VkViSurfaceCreateFlagsNN; - -typedef struct VkViSurfaceCreateInfoNN { - VkStructureType sType; - const void* pNext; - VkViSurfaceCreateFlagsNN flags; - void* window; -} VkViSurfaceCreateInfoNN; - - -typedef VkResult (VKAPI_PTR *PFN_vkCreateViSurfaceNN)(VkInstance instance, const VkViSurfaceCreateInfoNN* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkCreateViSurfaceNN( - VkInstance instance, - const VkViSurfaceCreateInfoNN* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkSurfaceKHR* pSurface); -#endif -#endif /* VK_USE_PLATFORM_VI_NN */ - -#define VK_EXT_shader_subgroup_ballot 1 -#define VK_EXT_SHADER_SUBGROUP_BALLOT_SPEC_VERSION 1 -#define VK_EXT_SHADER_SUBGROUP_BALLOT_EXTENSION_NAME "VK_EXT_shader_subgroup_ballot" - - -#define VK_EXT_shader_subgroup_vote 1 -#define VK_EXT_SHADER_SUBGROUP_VOTE_SPEC_VERSION 1 -#define VK_EXT_SHADER_SUBGROUP_VOTE_EXTENSION_NAME "VK_EXT_shader_subgroup_vote" - - -#define VK_NVX_device_generated_commands 1 -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkObjectTableNVX) -VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkIndirectCommandsLayoutNVX) - -#define VK_NVX_DEVICE_GENERATED_COMMANDS_SPEC_VERSION 1 -#define VK_NVX_DEVICE_GENERATED_COMMANDS_EXTENSION_NAME "VK_NVX_device_generated_commands" - - -typedef enum VkIndirectCommandsTokenTypeNVX { - VK_INDIRECT_COMMANDS_TOKEN_PIPELINE_NVX = 0, - VK_INDIRECT_COMMANDS_TOKEN_DESCRIPTOR_SET_NVX = 1, - VK_INDIRECT_COMMANDS_TOKEN_INDEX_BUFFER_NVX = 2, - VK_INDIRECT_COMMANDS_TOKEN_VERTEX_BUFFER_NVX = 3, - VK_INDIRECT_COMMANDS_TOKEN_PUSH_CONSTANT_NVX = 4, - VK_INDIRECT_COMMANDS_TOKEN_DRAW_INDEXED_NVX = 5, - VK_INDIRECT_COMMANDS_TOKEN_DRAW_NVX = 6, - VK_INDIRECT_COMMANDS_TOKEN_DISPATCH_NVX = 7, - VK_INDIRECT_COMMANDS_TOKEN_TYPE_BEGIN_RANGE_NVX = VK_INDIRECT_COMMANDS_TOKEN_PIPELINE_NVX, - VK_INDIRECT_COMMANDS_TOKEN_TYPE_END_RANGE_NVX = VK_INDIRECT_COMMANDS_TOKEN_DISPATCH_NVX, - VK_INDIRECT_COMMANDS_TOKEN_TYPE_RANGE_SIZE_NVX = (VK_INDIRECT_COMMANDS_TOKEN_DISPATCH_NVX - VK_INDIRECT_COMMANDS_TOKEN_PIPELINE_NVX + 1), - VK_INDIRECT_COMMANDS_TOKEN_TYPE_MAX_ENUM_NVX = 0x7FFFFFFF -} VkIndirectCommandsTokenTypeNVX; - -typedef enum VkObjectEntryTypeNVX { - VK_OBJECT_ENTRY_DESCRIPTOR_SET_NVX = 0, - VK_OBJECT_ENTRY_PIPELINE_NVX = 1, - VK_OBJECT_ENTRY_INDEX_BUFFER_NVX = 2, - VK_OBJECT_ENTRY_VERTEX_BUFFER_NVX = 3, - VK_OBJECT_ENTRY_PUSH_CONSTANT_NVX = 4, - VK_OBJECT_ENTRY_TYPE_BEGIN_RANGE_NVX = VK_OBJECT_ENTRY_DESCRIPTOR_SET_NVX, - VK_OBJECT_ENTRY_TYPE_END_RANGE_NVX = VK_OBJECT_ENTRY_PUSH_CONSTANT_NVX, - VK_OBJECT_ENTRY_TYPE_RANGE_SIZE_NVX = (VK_OBJECT_ENTRY_PUSH_CONSTANT_NVX - VK_OBJECT_ENTRY_DESCRIPTOR_SET_NVX + 1), - VK_OBJECT_ENTRY_TYPE_MAX_ENUM_NVX = 0x7FFFFFFF -} VkObjectEntryTypeNVX; - - -typedef enum VkIndirectCommandsLayoutUsageFlagBitsNVX { - VK_INDIRECT_COMMANDS_LAYOUT_USAGE_UNORDERED_SEQUENCES_BIT_NVX = 0x00000001, - VK_INDIRECT_COMMANDS_LAYOUT_USAGE_SPARSE_SEQUENCES_BIT_NVX = 0x00000002, - VK_INDIRECT_COMMANDS_LAYOUT_USAGE_EMPTY_EXECUTIONS_BIT_NVX = 0x00000004, - VK_INDIRECT_COMMANDS_LAYOUT_USAGE_INDEXED_SEQUENCES_BIT_NVX = 0x00000008, - VK_INDIRECT_COMMANDS_LAYOUT_USAGE_FLAG_BITS_MAX_ENUM_NVX = 0x7FFFFFFF -} VkIndirectCommandsLayoutUsageFlagBitsNVX; -typedef VkFlags VkIndirectCommandsLayoutUsageFlagsNVX; - -typedef enum VkObjectEntryUsageFlagBitsNVX { - VK_OBJECT_ENTRY_USAGE_GRAPHICS_BIT_NVX = 0x00000001, - VK_OBJECT_ENTRY_USAGE_COMPUTE_BIT_NVX = 0x00000002, - VK_OBJECT_ENTRY_USAGE_FLAG_BITS_MAX_ENUM_NVX = 0x7FFFFFFF -} VkObjectEntryUsageFlagBitsNVX; -typedef VkFlags VkObjectEntryUsageFlagsNVX; - -typedef struct VkDeviceGeneratedCommandsFeaturesNVX { - VkStructureType sType; - const void* pNext; - VkBool32 computeBindingPointSupport; -} VkDeviceGeneratedCommandsFeaturesNVX; - -typedef struct VkDeviceGeneratedCommandsLimitsNVX { - VkStructureType sType; - const void* pNext; - uint32_t maxIndirectCommandsLayoutTokenCount; - uint32_t maxObjectEntryCounts; - uint32_t minSequenceCountBufferOffsetAlignment; - uint32_t minSequenceIndexBufferOffsetAlignment; - uint32_t minCommandsTokenBufferOffsetAlignment; -} VkDeviceGeneratedCommandsLimitsNVX; - -typedef struct VkIndirectCommandsTokenNVX { - VkIndirectCommandsTokenTypeNVX tokenType; - VkBuffer buffer; - VkDeviceSize offset; -} VkIndirectCommandsTokenNVX; - -typedef struct VkIndirectCommandsLayoutTokenNVX { - VkIndirectCommandsTokenTypeNVX tokenType; - uint32_t bindingUnit; - uint32_t dynamicCount; - uint32_t divisor; -} VkIndirectCommandsLayoutTokenNVX; - -typedef struct VkIndirectCommandsLayoutCreateInfoNVX { - VkStructureType sType; - const void* pNext; - VkPipelineBindPoint pipelineBindPoint; - VkIndirectCommandsLayoutUsageFlagsNVX flags; - uint32_t tokenCount; - const VkIndirectCommandsLayoutTokenNVX* pTokens; -} VkIndirectCommandsLayoutCreateInfoNVX; - -typedef struct VkCmdProcessCommandsInfoNVX { - VkStructureType sType; - const void* pNext; - VkObjectTableNVX objectTable; - VkIndirectCommandsLayoutNVX indirectCommandsLayout; - uint32_t indirectCommandsTokenCount; - const VkIndirectCommandsTokenNVX* pIndirectCommandsTokens; - uint32_t maxSequencesCount; - VkCommandBuffer targetCommandBuffer; - VkBuffer sequencesCountBuffer; - VkDeviceSize sequencesCountOffset; - VkBuffer sequencesIndexBuffer; - VkDeviceSize sequencesIndexOffset; -} VkCmdProcessCommandsInfoNVX; - -typedef struct VkCmdReserveSpaceForCommandsInfoNVX { - VkStructureType sType; - const void* pNext; - VkObjectTableNVX objectTable; - VkIndirectCommandsLayoutNVX indirectCommandsLayout; - uint32_t maxSequencesCount; -} VkCmdReserveSpaceForCommandsInfoNVX; - -typedef struct VkObjectTableCreateInfoNVX { - VkStructureType sType; - const void* pNext; - uint32_t objectCount; - const VkObjectEntryTypeNVX* pObjectEntryTypes; - const uint32_t* pObjectEntryCounts; - const VkObjectEntryUsageFlagsNVX* pObjectEntryUsageFlags; - uint32_t maxUniformBuffersPerDescriptor; - uint32_t maxStorageBuffersPerDescriptor; - uint32_t maxStorageImagesPerDescriptor; - uint32_t maxSampledImagesPerDescriptor; - uint32_t maxPipelineLayouts; -} VkObjectTableCreateInfoNVX; - -typedef struct VkObjectTableEntryNVX { - VkObjectEntryTypeNVX type; - VkObjectEntryUsageFlagsNVX flags; -} VkObjectTableEntryNVX; - -typedef struct VkObjectTablePipelineEntryNVX { - VkObjectEntryTypeNVX type; - VkObjectEntryUsageFlagsNVX flags; - VkPipeline pipeline; -} VkObjectTablePipelineEntryNVX; - -typedef struct VkObjectTableDescriptorSetEntryNVX { - VkObjectEntryTypeNVX type; - VkObjectEntryUsageFlagsNVX flags; - VkPipelineLayout pipelineLayout; - VkDescriptorSet descriptorSet; -} VkObjectTableDescriptorSetEntryNVX; - -typedef struct VkObjectTableVertexBufferEntryNVX { - VkObjectEntryTypeNVX type; - VkObjectEntryUsageFlagsNVX flags; - VkBuffer buffer; -} VkObjectTableVertexBufferEntryNVX; - -typedef struct VkObjectTableIndexBufferEntryNVX { - VkObjectEntryTypeNVX type; - VkObjectEntryUsageFlagsNVX flags; - VkBuffer buffer; - VkIndexType indexType; -} VkObjectTableIndexBufferEntryNVX; - -typedef struct VkObjectTablePushConstantEntryNVX { - VkObjectEntryTypeNVX type; - VkObjectEntryUsageFlagsNVX flags; - VkPipelineLayout pipelineLayout; - VkShaderStageFlags stageFlags; -} VkObjectTablePushConstantEntryNVX; - - -typedef void (VKAPI_PTR *PFN_vkCmdProcessCommandsNVX)(VkCommandBuffer commandBuffer, const VkCmdProcessCommandsInfoNVX* pProcessCommandsInfo); -typedef void (VKAPI_PTR *PFN_vkCmdReserveSpaceForCommandsNVX)(VkCommandBuffer commandBuffer, const VkCmdReserveSpaceForCommandsInfoNVX* pReserveSpaceInfo); -typedef VkResult (VKAPI_PTR *PFN_vkCreateIndirectCommandsLayoutNVX)(VkDevice device, const VkIndirectCommandsLayoutCreateInfoNVX* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkIndirectCommandsLayoutNVX* pIndirectCommandsLayout); -typedef void (VKAPI_PTR *PFN_vkDestroyIndirectCommandsLayoutNVX)(VkDevice device, VkIndirectCommandsLayoutNVX indirectCommandsLayout, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkCreateObjectTableNVX)(VkDevice device, const VkObjectTableCreateInfoNVX* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkObjectTableNVX* pObjectTable); -typedef void (VKAPI_PTR *PFN_vkDestroyObjectTableNVX)(VkDevice device, VkObjectTableNVX objectTable, const VkAllocationCallbacks* pAllocator); -typedef VkResult (VKAPI_PTR *PFN_vkRegisterObjectsNVX)(VkDevice device, VkObjectTableNVX objectTable, uint32_t objectCount, const VkObjectTableEntryNVX* const* ppObjectTableEntries, const uint32_t* pObjectIndices); -typedef VkResult (VKAPI_PTR *PFN_vkUnregisterObjectsNVX)(VkDevice device, VkObjectTableNVX objectTable, uint32_t objectCount, const VkObjectEntryTypeNVX* pObjectEntryTypes, const uint32_t* pObjectIndices); -typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX)(VkPhysicalDevice physicalDevice, VkDeviceGeneratedCommandsFeaturesNVX* pFeatures, VkDeviceGeneratedCommandsLimitsNVX* pLimits); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR void VKAPI_CALL vkCmdProcessCommandsNVX( - VkCommandBuffer commandBuffer, - const VkCmdProcessCommandsInfoNVX* pProcessCommandsInfo); - -VKAPI_ATTR void VKAPI_CALL vkCmdReserveSpaceForCommandsNVX( - VkCommandBuffer commandBuffer, - const VkCmdReserveSpaceForCommandsInfoNVX* pReserveSpaceInfo); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateIndirectCommandsLayoutNVX( - VkDevice device, - const VkIndirectCommandsLayoutCreateInfoNVX* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkIndirectCommandsLayoutNVX* pIndirectCommandsLayout); - -VKAPI_ATTR void VKAPI_CALL vkDestroyIndirectCommandsLayoutNVX( - VkDevice device, - VkIndirectCommandsLayoutNVX indirectCommandsLayout, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkCreateObjectTableNVX( - VkDevice device, - const VkObjectTableCreateInfoNVX* pCreateInfo, - const VkAllocationCallbacks* pAllocator, - VkObjectTableNVX* pObjectTable); - -VKAPI_ATTR void VKAPI_CALL vkDestroyObjectTableNVX( - VkDevice device, - VkObjectTableNVX objectTable, - const VkAllocationCallbacks* pAllocator); - -VKAPI_ATTR VkResult VKAPI_CALL vkRegisterObjectsNVX( - VkDevice device, - VkObjectTableNVX objectTable, - uint32_t objectCount, - const VkObjectTableEntryNVX* const* ppObjectTableEntries, - const uint32_t* pObjectIndices); - -VKAPI_ATTR VkResult VKAPI_CALL vkUnregisterObjectsNVX( - VkDevice device, - VkObjectTableNVX objectTable, - uint32_t objectCount, - const VkObjectEntryTypeNVX* pObjectEntryTypes, - const uint32_t* pObjectIndices); - -VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX( - VkPhysicalDevice physicalDevice, - VkDeviceGeneratedCommandsFeaturesNVX* pFeatures, - VkDeviceGeneratedCommandsLimitsNVX* pLimits); -#endif - -#define VK_EXT_direct_mode_display 1 -#define VK_EXT_DIRECT_MODE_DISPLAY_SPEC_VERSION 1 -#define VK_EXT_DIRECT_MODE_DISPLAY_EXTENSION_NAME "VK_EXT_direct_mode_display" - -typedef VkResult (VKAPI_PTR *PFN_vkReleaseDisplayEXT)(VkPhysicalDevice physicalDevice, VkDisplayKHR display); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkReleaseDisplayEXT( - VkPhysicalDevice physicalDevice, - VkDisplayKHR display); -#endif - -#ifdef VK_USE_PLATFORM_XLIB_XRANDR_EXT -#define VK_EXT_acquire_xlib_display 1 -#include - -#define VK_EXT_ACQUIRE_XLIB_DISPLAY_SPEC_VERSION 1 -#define VK_EXT_ACQUIRE_XLIB_DISPLAY_EXTENSION_NAME "VK_EXT_acquire_xlib_display" - -typedef VkResult (VKAPI_PTR *PFN_vkAcquireXlibDisplayEXT)(VkPhysicalDevice physicalDevice, Display* dpy, VkDisplayKHR display); -typedef VkResult (VKAPI_PTR *PFN_vkGetRandROutputDisplayEXT)(VkPhysicalDevice physicalDevice, Display* dpy, RROutput rrOutput, VkDisplayKHR* pDisplay); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkAcquireXlibDisplayEXT( - VkPhysicalDevice physicalDevice, - Display* dpy, - VkDisplayKHR display); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetRandROutputDisplayEXT( - VkPhysicalDevice physicalDevice, - Display* dpy, - RROutput rrOutput, - VkDisplayKHR* pDisplay); -#endif -#endif /* VK_USE_PLATFORM_XLIB_XRANDR_EXT */ - -#define VK_EXT_display_surface_counter 1 -#define VK_EXT_DISPLAY_SURFACE_COUNTER_SPEC_VERSION 1 -#define VK_EXT_DISPLAY_SURFACE_COUNTER_EXTENSION_NAME "VK_EXT_display_surface_counter" - - -typedef enum VkSurfaceCounterFlagBitsEXT { - VK_SURFACE_COUNTER_VBLANK_EXT = 0x00000001, - VK_SURFACE_COUNTER_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF -} VkSurfaceCounterFlagBitsEXT; -typedef VkFlags VkSurfaceCounterFlagsEXT; - -typedef struct VkSurfaceCapabilities2EXT { - VkStructureType sType; - void* pNext; - uint32_t minImageCount; - uint32_t maxImageCount; - VkExtent2D currentExtent; - VkExtent2D minImageExtent; - VkExtent2D maxImageExtent; - uint32_t maxImageArrayLayers; - VkSurfaceTransformFlagsKHR supportedTransforms; - VkSurfaceTransformFlagBitsKHR currentTransform; - VkCompositeAlphaFlagsKHR supportedCompositeAlpha; - VkImageUsageFlags supportedUsageFlags; - VkSurfaceCounterFlagsEXT supportedSurfaceCounters; -} VkSurfaceCapabilities2EXT; - - -typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceCapabilities2EXT)(VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, VkSurfaceCapabilities2EXT* pSurfaceCapabilities); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceCapabilities2EXT( - VkPhysicalDevice physicalDevice, - VkSurfaceKHR surface, - VkSurfaceCapabilities2EXT* pSurfaceCapabilities); -#endif - -#define VK_EXT_display_control 1 -#define VK_EXT_DISPLAY_CONTROL_SPEC_VERSION 1 -#define VK_EXT_DISPLAY_CONTROL_EXTENSION_NAME "VK_EXT_display_control" - - -typedef enum VkDisplayPowerStateEXT { - VK_DISPLAY_POWER_STATE_OFF_EXT = 0, - VK_DISPLAY_POWER_STATE_SUSPEND_EXT = 1, - VK_DISPLAY_POWER_STATE_ON_EXT = 2, - VK_DISPLAY_POWER_STATE_BEGIN_RANGE_EXT = VK_DISPLAY_POWER_STATE_OFF_EXT, - VK_DISPLAY_POWER_STATE_END_RANGE_EXT = VK_DISPLAY_POWER_STATE_ON_EXT, - VK_DISPLAY_POWER_STATE_RANGE_SIZE_EXT = (VK_DISPLAY_POWER_STATE_ON_EXT - VK_DISPLAY_POWER_STATE_OFF_EXT + 1), - VK_DISPLAY_POWER_STATE_MAX_ENUM_EXT = 0x7FFFFFFF -} VkDisplayPowerStateEXT; - -typedef enum VkDeviceEventTypeEXT { - VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT = 0, - VK_DEVICE_EVENT_TYPE_BEGIN_RANGE_EXT = VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT, - VK_DEVICE_EVENT_TYPE_END_RANGE_EXT = VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT, - VK_DEVICE_EVENT_TYPE_RANGE_SIZE_EXT = (VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT - VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT + 1), - VK_DEVICE_EVENT_TYPE_MAX_ENUM_EXT = 0x7FFFFFFF -} VkDeviceEventTypeEXT; - -typedef enum VkDisplayEventTypeEXT { - VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT = 0, - VK_DISPLAY_EVENT_TYPE_BEGIN_RANGE_EXT = VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT, - VK_DISPLAY_EVENT_TYPE_END_RANGE_EXT = VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT, - VK_DISPLAY_EVENT_TYPE_RANGE_SIZE_EXT = (VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT - VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT + 1), - VK_DISPLAY_EVENT_TYPE_MAX_ENUM_EXT = 0x7FFFFFFF -} VkDisplayEventTypeEXT; - -typedef struct VkDisplayPowerInfoEXT { - VkStructureType sType; - const void* pNext; - VkDisplayPowerStateEXT powerState; -} VkDisplayPowerInfoEXT; - -typedef struct VkDeviceEventInfoEXT { - VkStructureType sType; - const void* pNext; - VkDeviceEventTypeEXT deviceEvent; -} VkDeviceEventInfoEXT; - -typedef struct VkDisplayEventInfoEXT { - VkStructureType sType; - const void* pNext; - VkDisplayEventTypeEXT displayEvent; -} VkDisplayEventInfoEXT; - -typedef struct VkSwapchainCounterCreateInfoEXT { - VkStructureType sType; - const void* pNext; - VkSurfaceCounterFlagsEXT surfaceCounters; -} VkSwapchainCounterCreateInfoEXT; - - -typedef VkResult (VKAPI_PTR *PFN_vkDisplayPowerControlEXT)(VkDevice device, VkDisplayKHR display, const VkDisplayPowerInfoEXT* pDisplayPowerInfo); -typedef VkResult (VKAPI_PTR *PFN_vkRegisterDeviceEventEXT)(VkDevice device, const VkDeviceEventInfoEXT* pDeviceEventInfo, const VkAllocationCallbacks* pAllocator, VkFence* pFence); -typedef VkResult (VKAPI_PTR *PFN_vkRegisterDisplayEventEXT)(VkDevice device, VkDisplayKHR display, const VkDisplayEventInfoEXT* pDisplayEventInfo, const VkAllocationCallbacks* pAllocator, VkFence* pFence); -typedef VkResult (VKAPI_PTR *PFN_vkGetSwapchainCounterEXT)(VkDevice device, VkSwapchainKHR swapchain, VkSurfaceCounterFlagBitsEXT counter, uint64_t* pCounterValue); - -#ifndef VK_NO_PROTOTYPES -VKAPI_ATTR VkResult VKAPI_CALL vkDisplayPowerControlEXT( - VkDevice device, - VkDisplayKHR display, - const VkDisplayPowerInfoEXT* pDisplayPowerInfo); - -VKAPI_ATTR VkResult VKAPI_CALL vkRegisterDeviceEventEXT( - VkDevice device, - const VkDeviceEventInfoEXT* pDeviceEventInfo, - const VkAllocationCallbacks* pAllocator, - VkFence* pFence); - -VKAPI_ATTR VkResult VKAPI_CALL vkRegisterDisplayEventEXT( - VkDevice device, - VkDisplayKHR display, - const VkDisplayEventInfoEXT* pDisplayEventInfo, - const VkAllocationCallbacks* pAllocator, - VkFence* pFence); - -VKAPI_ATTR VkResult VKAPI_CALL vkGetSwapchainCounterEXT( - VkDevice device, - VkSwapchainKHR swapchain, - VkSurfaceCounterFlagBitsEXT counter, - uint64_t* pCounterValue); -#endif - -#define VK_EXT_swapchain_colorspace 1 -#define VK_SWAPCHAIN_COLOR_SPACE_SPEC_VERSION 1 -#define VK_SWAPCHAIN_COLOR_SPACE_EXTENSION_NAME "VK_EXT_swapchain_colorspace" - - -#ifdef __cplusplus -} -#endif - -#endif +#ifndef VULKAN_H_ +#define VULKAN_H_ 1 + +/* +** Copyright (c) 2015-2018 The Khronos Group Inc. +** +** Licensed under the Apache License, Version 2.0 (the "License"); +** you may not use this file except in compliance with the License. +** You may obtain a copy of the License at +** +** http://www.apache.org/licenses/LICENSE-2.0 +** +** Unless required by applicable law or agreed to in writing, software +** distributed under the License is distributed on an "AS IS" BASIS, +** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +** See the License for the specific language governing permissions and +** limitations under the License. +*/ + +#include "vk_platform.h" +#include "vulkan_core.h" + +#ifdef VK_USE_PLATFORM_ANDROID_KHR +#include "vulkan_android.h" +#endif + + +#ifdef VK_USE_PLATFORM_IOS_MVK +#include "vulkan_ios.h" +#endif + + +#ifdef VK_USE_PLATFORM_MACOS_MVK +#include "vulkan_macos.h" +#endif + + +#ifdef VK_USE_PLATFORM_MIR_KHR +#include +#include "vulkan_mir.h" +#endif + + +#ifdef VK_USE_PLATFORM_VI_NN +#include "vulkan_vi.h" +#endif + + +#ifdef VK_USE_PLATFORM_WAYLAND_KHR +#include +#include "vulkan_wayland.h" +#endif + + +#ifdef VK_USE_PLATFORM_WIN32_KHR +#include +#include "vulkan_win32.h" +#endif + + +#ifdef VK_USE_PLATFORM_XCB_KHR +#include +#include "vulkan_xcb.h" +#endif + + +#ifdef VK_USE_PLATFORM_XLIB_KHR +#include +#include "vulkan_xlib.h" +#endif + + +#ifdef VK_USE_PLATFORM_XLIB_XRANDR_EXT +#include +#include +#include "vulkan_xlib_xrandr.h" +#endif + +#endif // VULKAN_H_ diff --git a/src/external/glfw/deps/vulkan/vulkan_core.h b/src/external/glfw/deps/vulkan/vulkan_core.h new file mode 100644 index 000000000..20dccc116 --- /dev/null +++ b/src/external/glfw/deps/vulkan/vulkan_core.h @@ -0,0 +1,7334 @@ +#ifndef VULKAN_CORE_H_ +#define VULKAN_CORE_H_ 1 + +#ifdef __cplusplus +extern "C" { +#endif + +/* +** Copyright (c) 2015-2018 The Khronos Group Inc. +** +** Licensed under the Apache License, Version 2.0 (the "License"); +** you may not use this file except in compliance with the License. +** You may obtain a copy of the License at +** +** http://www.apache.org/licenses/LICENSE-2.0 +** +** Unless required by applicable law or agreed to in writing, software +** distributed under the License is distributed on an "AS IS" BASIS, +** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +** See the License for the specific language governing permissions and +** limitations under the License. +*/ + +/* +** This header is generated from the Khronos Vulkan XML API Registry. +** +*/ + + +#define VK_VERSION_1_0 1 +#include "vk_platform.h" + +#define VK_MAKE_VERSION(major, minor, patch) \ + (((major) << 22) | ((minor) << 12) | (patch)) + +// DEPRECATED: This define has been removed. Specific version defines (e.g. VK_API_VERSION_1_0), or the VK_MAKE_VERSION macro, should be used instead. +//#define VK_API_VERSION VK_MAKE_VERSION(1, 0, 0) // Patch version should always be set to 0 + +// Vulkan 1.0 version number +#define VK_API_VERSION_1_0 VK_MAKE_VERSION(1, 0, 0)// Patch version should always be set to 0 + +#define VK_VERSION_MAJOR(version) ((uint32_t)(version) >> 22) +#define VK_VERSION_MINOR(version) (((uint32_t)(version) >> 12) & 0x3ff) +#define VK_VERSION_PATCH(version) ((uint32_t)(version) & 0xfff) +// Version of this file +#define VK_HEADER_VERSION 70 + + +#define VK_NULL_HANDLE 0 + + + +#define VK_DEFINE_HANDLE(object) typedef struct object##_T* object; + + +#if !defined(VK_DEFINE_NON_DISPATCHABLE_HANDLE) +#if defined(__LP64__) || defined(_WIN64) || (defined(__x86_64__) && !defined(__ILP32__) ) || defined(_M_X64) || defined(__ia64) || defined (_M_IA64) || defined(__aarch64__) || defined(__powerpc64__) + #define VK_DEFINE_NON_DISPATCHABLE_HANDLE(object) typedef struct object##_T *object; +#else + #define VK_DEFINE_NON_DISPATCHABLE_HANDLE(object) typedef uint64_t object; +#endif +#endif + + + +typedef uint32_t VkFlags; +typedef uint32_t VkBool32; +typedef uint64_t VkDeviceSize; +typedef uint32_t VkSampleMask; + +VK_DEFINE_HANDLE(VkInstance) +VK_DEFINE_HANDLE(VkPhysicalDevice) +VK_DEFINE_HANDLE(VkDevice) +VK_DEFINE_HANDLE(VkQueue) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSemaphore) +VK_DEFINE_HANDLE(VkCommandBuffer) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkFence) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDeviceMemory) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkBuffer) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkImage) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkEvent) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkQueryPool) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkBufferView) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkImageView) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkShaderModule) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkPipelineCache) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkPipelineLayout) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkRenderPass) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkPipeline) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDescriptorSetLayout) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSampler) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDescriptorPool) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDescriptorSet) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkFramebuffer) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkCommandPool) + +#define VK_LOD_CLAMP_NONE 1000.0f +#define VK_REMAINING_MIP_LEVELS (~0U) +#define VK_REMAINING_ARRAY_LAYERS (~0U) +#define VK_WHOLE_SIZE (~0ULL) +#define VK_ATTACHMENT_UNUSED (~0U) +#define VK_TRUE 1 +#define VK_FALSE 0 +#define VK_QUEUE_FAMILY_IGNORED (~0U) +#define VK_SUBPASS_EXTERNAL (~0U) +#define VK_MAX_PHYSICAL_DEVICE_NAME_SIZE 256 +#define VK_UUID_SIZE 16 +#define VK_MAX_MEMORY_TYPES 32 +#define VK_MAX_MEMORY_HEAPS 16 +#define VK_MAX_EXTENSION_NAME_SIZE 256 +#define VK_MAX_DESCRIPTION_SIZE 256 + + +typedef enum VkPipelineCacheHeaderVersion { + VK_PIPELINE_CACHE_HEADER_VERSION_ONE = 1, + VK_PIPELINE_CACHE_HEADER_VERSION_BEGIN_RANGE = VK_PIPELINE_CACHE_HEADER_VERSION_ONE, + VK_PIPELINE_CACHE_HEADER_VERSION_END_RANGE = VK_PIPELINE_CACHE_HEADER_VERSION_ONE, + VK_PIPELINE_CACHE_HEADER_VERSION_RANGE_SIZE = (VK_PIPELINE_CACHE_HEADER_VERSION_ONE - VK_PIPELINE_CACHE_HEADER_VERSION_ONE + 1), + VK_PIPELINE_CACHE_HEADER_VERSION_MAX_ENUM = 0x7FFFFFFF +} VkPipelineCacheHeaderVersion; + +typedef enum VkResult { + VK_SUCCESS = 0, + VK_NOT_READY = 1, + VK_TIMEOUT = 2, + VK_EVENT_SET = 3, + VK_EVENT_RESET = 4, + VK_INCOMPLETE = 5, + VK_ERROR_OUT_OF_HOST_MEMORY = -1, + VK_ERROR_OUT_OF_DEVICE_MEMORY = -2, + VK_ERROR_INITIALIZATION_FAILED = -3, + VK_ERROR_DEVICE_LOST = -4, + VK_ERROR_MEMORY_MAP_FAILED = -5, + VK_ERROR_LAYER_NOT_PRESENT = -6, + VK_ERROR_EXTENSION_NOT_PRESENT = -7, + VK_ERROR_FEATURE_NOT_PRESENT = -8, + VK_ERROR_INCOMPATIBLE_DRIVER = -9, + VK_ERROR_TOO_MANY_OBJECTS = -10, + VK_ERROR_FORMAT_NOT_SUPPORTED = -11, + VK_ERROR_FRAGMENTED_POOL = -12, + VK_ERROR_OUT_OF_POOL_MEMORY = -1000069000, + VK_ERROR_INVALID_EXTERNAL_HANDLE = -1000072003, + VK_ERROR_SURFACE_LOST_KHR = -1000000000, + VK_ERROR_NATIVE_WINDOW_IN_USE_KHR = -1000000001, + VK_SUBOPTIMAL_KHR = 1000001003, + VK_ERROR_OUT_OF_DATE_KHR = -1000001004, + VK_ERROR_INCOMPATIBLE_DISPLAY_KHR = -1000003001, + VK_ERROR_VALIDATION_FAILED_EXT = -1000011001, + VK_ERROR_INVALID_SHADER_NV = -1000012000, + VK_ERROR_NOT_PERMITTED_EXT = -1000174001, + VK_ERROR_OUT_OF_POOL_MEMORY_KHR = VK_ERROR_OUT_OF_POOL_MEMORY, + VK_ERROR_INVALID_EXTERNAL_HANDLE_KHR = VK_ERROR_INVALID_EXTERNAL_HANDLE, + VK_RESULT_BEGIN_RANGE = VK_ERROR_FRAGMENTED_POOL, + VK_RESULT_END_RANGE = VK_INCOMPLETE, + VK_RESULT_RANGE_SIZE = (VK_INCOMPLETE - VK_ERROR_FRAGMENTED_POOL + 1), + VK_RESULT_MAX_ENUM = 0x7FFFFFFF +} VkResult; + +typedef enum VkStructureType { + VK_STRUCTURE_TYPE_APPLICATION_INFO = 0, + VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO = 1, + VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO = 2, + VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO = 3, + VK_STRUCTURE_TYPE_SUBMIT_INFO = 4, + VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_INFO = 5, + VK_STRUCTURE_TYPE_MAPPED_MEMORY_RANGE = 6, + VK_STRUCTURE_TYPE_BIND_SPARSE_INFO = 7, + VK_STRUCTURE_TYPE_FENCE_CREATE_INFO = 8, + VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO = 9, + VK_STRUCTURE_TYPE_EVENT_CREATE_INFO = 10, + VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO = 11, + VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO = 12, + VK_STRUCTURE_TYPE_BUFFER_VIEW_CREATE_INFO = 13, + VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO = 14, + VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO = 15, + VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO = 16, + VK_STRUCTURE_TYPE_PIPELINE_CACHE_CREATE_INFO = 17, + VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO = 18, + VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO = 19, + VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO = 20, + VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_STATE_CREATE_INFO = 21, + VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO = 22, + VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO = 23, + VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO = 24, + VK_STRUCTURE_TYPE_PIPELINE_DEPTH_STENCIL_STATE_CREATE_INFO = 25, + VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO = 26, + VK_STRUCTURE_TYPE_PIPELINE_DYNAMIC_STATE_CREATE_INFO = 27, + VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO = 28, + VK_STRUCTURE_TYPE_COMPUTE_PIPELINE_CREATE_INFO = 29, + VK_STRUCTURE_TYPE_PIPELINE_LAYOUT_CREATE_INFO = 30, + VK_STRUCTURE_TYPE_SAMPLER_CREATE_INFO = 31, + VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO = 32, + VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO = 33, + VK_STRUCTURE_TYPE_DESCRIPTOR_SET_ALLOCATE_INFO = 34, + VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET = 35, + VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET = 36, + VK_STRUCTURE_TYPE_FRAMEBUFFER_CREATE_INFO = 37, + VK_STRUCTURE_TYPE_RENDER_PASS_CREATE_INFO = 38, + VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO = 39, + VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO = 40, + VK_STRUCTURE_TYPE_COMMAND_BUFFER_INHERITANCE_INFO = 41, + VK_STRUCTURE_TYPE_COMMAND_BUFFER_BEGIN_INFO = 42, + VK_STRUCTURE_TYPE_RENDER_PASS_BEGIN_INFO = 43, + VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER = 44, + VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER = 45, + VK_STRUCTURE_TYPE_MEMORY_BARRIER = 46, + VK_STRUCTURE_TYPE_LOADER_INSTANCE_CREATE_INFO = 47, + VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO = 48, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SUBGROUP_PROPERTIES = 1000094000, + VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO = 1000157000, + VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO = 1000157001, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_16BIT_STORAGE_FEATURES = 1000083000, + VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS = 1000127000, + VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO = 1000127001, + VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_FLAGS_INFO = 1000060000, + VK_STRUCTURE_TYPE_DEVICE_GROUP_RENDER_PASS_BEGIN_INFO = 1000060003, + VK_STRUCTURE_TYPE_DEVICE_GROUP_COMMAND_BUFFER_BEGIN_INFO = 1000060004, + VK_STRUCTURE_TYPE_DEVICE_GROUP_SUBMIT_INFO = 1000060005, + VK_STRUCTURE_TYPE_DEVICE_GROUP_BIND_SPARSE_INFO = 1000060006, + VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_DEVICE_GROUP_INFO = 1000060013, + VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFO = 1000060014, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_GROUP_PROPERTIES = 1000070000, + VK_STRUCTURE_TYPE_DEVICE_GROUP_DEVICE_CREATE_INFO = 1000070001, + VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2 = 1000146000, + VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2 = 1000146001, + VK_STRUCTURE_TYPE_IMAGE_SPARSE_MEMORY_REQUIREMENTS_INFO_2 = 1000146002, + VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2 = 1000146003, + VK_STRUCTURE_TYPE_SPARSE_IMAGE_MEMORY_REQUIREMENTS_2 = 1000146004, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2 = 1000059000, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2 = 1000059001, + VK_STRUCTURE_TYPE_FORMAT_PROPERTIES_2 = 1000059002, + VK_STRUCTURE_TYPE_IMAGE_FORMAT_PROPERTIES_2 = 1000059003, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2 = 1000059004, + VK_STRUCTURE_TYPE_QUEUE_FAMILY_PROPERTIES_2 = 1000059005, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2 = 1000059006, + VK_STRUCTURE_TYPE_SPARSE_IMAGE_FORMAT_PROPERTIES_2 = 1000059007, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SPARSE_IMAGE_FORMAT_INFO_2 = 1000059008, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_POINT_CLIPPING_PROPERTIES = 1000117000, + VK_STRUCTURE_TYPE_RENDER_PASS_INPUT_ATTACHMENT_ASPECT_CREATE_INFO = 1000117001, + VK_STRUCTURE_TYPE_IMAGE_VIEW_USAGE_CREATE_INFO = 1000117002, + VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_DOMAIN_ORIGIN_STATE_CREATE_INFO = 1000117003, + VK_STRUCTURE_TYPE_RENDER_PASS_MULTIVIEW_CREATE_INFO = 1000053000, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_FEATURES = 1000053001, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PROPERTIES = 1000053002, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VARIABLE_POINTER_FEATURES = 1000120000, + VK_STRUCTURE_TYPE_PROTECTED_SUBMIT_INFO = 1000145000, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROTECTED_MEMORY_FEATURES = 1000145001, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROTECTED_MEMORY_PROPERTIES = 1000145002, + VK_STRUCTURE_TYPE_DEVICE_QUEUE_INFO_2 = 1000145003, + VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO = 1000156000, + VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_INFO = 1000156001, + VK_STRUCTURE_TYPE_BIND_IMAGE_PLANE_MEMORY_INFO = 1000156002, + VK_STRUCTURE_TYPE_IMAGE_PLANE_MEMORY_REQUIREMENTS_INFO = 1000156003, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_YCBCR_CONVERSION_FEATURES = 1000156004, + VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_IMAGE_FORMAT_PROPERTIES = 1000156005, + VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO = 1000085000, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO = 1000071000, + VK_STRUCTURE_TYPE_EXTERNAL_IMAGE_FORMAT_PROPERTIES = 1000071001, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_BUFFER_INFO = 1000071002, + VK_STRUCTURE_TYPE_EXTERNAL_BUFFER_PROPERTIES = 1000071003, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_ID_PROPERTIES = 1000071004, + VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_BUFFER_CREATE_INFO = 1000072000, + VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO = 1000072001, + VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO = 1000072002, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_FENCE_INFO = 1000112000, + VK_STRUCTURE_TYPE_EXTERNAL_FENCE_PROPERTIES = 1000112001, + VK_STRUCTURE_TYPE_EXPORT_FENCE_CREATE_INFO = 1000113000, + VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_CREATE_INFO = 1000077000, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_SEMAPHORE_INFO = 1000076000, + VK_STRUCTURE_TYPE_EXTERNAL_SEMAPHORE_PROPERTIES = 1000076001, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MAINTENANCE_3_PROPERTIES = 1000168000, + VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_SUPPORT = 1000168001, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_DRAW_PARAMETER_FEATURES = 1000063000, + VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR = 1000001000, + VK_STRUCTURE_TYPE_PRESENT_INFO_KHR = 1000001001, + VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_CAPABILITIES_KHR = 1000060007, + VK_STRUCTURE_TYPE_IMAGE_SWAPCHAIN_CREATE_INFO_KHR = 1000060008, + VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_SWAPCHAIN_INFO_KHR = 1000060009, + VK_STRUCTURE_TYPE_ACQUIRE_NEXT_IMAGE_INFO_KHR = 1000060010, + VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_INFO_KHR = 1000060011, + VK_STRUCTURE_TYPE_DEVICE_GROUP_SWAPCHAIN_CREATE_INFO_KHR = 1000060012, + VK_STRUCTURE_TYPE_DISPLAY_MODE_CREATE_INFO_KHR = 1000002000, + VK_STRUCTURE_TYPE_DISPLAY_SURFACE_CREATE_INFO_KHR = 1000002001, + VK_STRUCTURE_TYPE_DISPLAY_PRESENT_INFO_KHR = 1000003000, + VK_STRUCTURE_TYPE_XLIB_SURFACE_CREATE_INFO_KHR = 1000004000, + VK_STRUCTURE_TYPE_XCB_SURFACE_CREATE_INFO_KHR = 1000005000, + VK_STRUCTURE_TYPE_WAYLAND_SURFACE_CREATE_INFO_KHR = 1000006000, + VK_STRUCTURE_TYPE_MIR_SURFACE_CREATE_INFO_KHR = 1000007000, + VK_STRUCTURE_TYPE_ANDROID_SURFACE_CREATE_INFO_KHR = 1000008000, + VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR = 1000009000, + VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT = 1000011000, + VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_RASTERIZATION_ORDER_AMD = 1000018000, + VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_NAME_INFO_EXT = 1000022000, + VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_TAG_INFO_EXT = 1000022001, + VK_STRUCTURE_TYPE_DEBUG_MARKER_MARKER_INFO_EXT = 1000022002, + VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_IMAGE_CREATE_INFO_NV = 1000026000, + VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_BUFFER_CREATE_INFO_NV = 1000026001, + VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_MEMORY_ALLOCATE_INFO_NV = 1000026002, + VK_STRUCTURE_TYPE_TEXTURE_LOD_GATHER_FORMAT_PROPERTIES_AMD = 1000041000, + VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO_NV = 1000056000, + VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO_NV = 1000056001, + VK_STRUCTURE_TYPE_IMPORT_MEMORY_WIN32_HANDLE_INFO_NV = 1000057000, + VK_STRUCTURE_TYPE_EXPORT_MEMORY_WIN32_HANDLE_INFO_NV = 1000057001, + VK_STRUCTURE_TYPE_WIN32_KEYED_MUTEX_ACQUIRE_RELEASE_INFO_NV = 1000058000, + VK_STRUCTURE_TYPE_VALIDATION_FLAGS_EXT = 1000061000, + VK_STRUCTURE_TYPE_VI_SURFACE_CREATE_INFO_NN = 1000062000, + VK_STRUCTURE_TYPE_IMPORT_MEMORY_WIN32_HANDLE_INFO_KHR = 1000073000, + VK_STRUCTURE_TYPE_EXPORT_MEMORY_WIN32_HANDLE_INFO_KHR = 1000073001, + VK_STRUCTURE_TYPE_MEMORY_WIN32_HANDLE_PROPERTIES_KHR = 1000073002, + VK_STRUCTURE_TYPE_MEMORY_GET_WIN32_HANDLE_INFO_KHR = 1000073003, + VK_STRUCTURE_TYPE_IMPORT_MEMORY_FD_INFO_KHR = 1000074000, + VK_STRUCTURE_TYPE_MEMORY_FD_PROPERTIES_KHR = 1000074001, + VK_STRUCTURE_TYPE_MEMORY_GET_FD_INFO_KHR = 1000074002, + VK_STRUCTURE_TYPE_WIN32_KEYED_MUTEX_ACQUIRE_RELEASE_INFO_KHR = 1000075000, + VK_STRUCTURE_TYPE_IMPORT_SEMAPHORE_WIN32_HANDLE_INFO_KHR = 1000078000, + VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_WIN32_HANDLE_INFO_KHR = 1000078001, + VK_STRUCTURE_TYPE_D3D12_FENCE_SUBMIT_INFO_KHR = 1000078002, + VK_STRUCTURE_TYPE_SEMAPHORE_GET_WIN32_HANDLE_INFO_KHR = 1000078003, + VK_STRUCTURE_TYPE_IMPORT_SEMAPHORE_FD_INFO_KHR = 1000079000, + VK_STRUCTURE_TYPE_SEMAPHORE_GET_FD_INFO_KHR = 1000079001, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PUSH_DESCRIPTOR_PROPERTIES_KHR = 1000080000, + VK_STRUCTURE_TYPE_PRESENT_REGIONS_KHR = 1000084000, + VK_STRUCTURE_TYPE_OBJECT_TABLE_CREATE_INFO_NVX = 1000086000, + VK_STRUCTURE_TYPE_INDIRECT_COMMANDS_LAYOUT_CREATE_INFO_NVX = 1000086001, + VK_STRUCTURE_TYPE_CMD_PROCESS_COMMANDS_INFO_NVX = 1000086002, + VK_STRUCTURE_TYPE_CMD_RESERVE_SPACE_FOR_COMMANDS_INFO_NVX = 1000086003, + VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_LIMITS_NVX = 1000086004, + VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_FEATURES_NVX = 1000086005, + VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_W_SCALING_STATE_CREATE_INFO_NV = 1000087000, + VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_EXT = 1000090000, + VK_STRUCTURE_TYPE_DISPLAY_POWER_INFO_EXT = 1000091000, + VK_STRUCTURE_TYPE_DEVICE_EVENT_INFO_EXT = 1000091001, + VK_STRUCTURE_TYPE_DISPLAY_EVENT_INFO_EXT = 1000091002, + VK_STRUCTURE_TYPE_SWAPCHAIN_COUNTER_CREATE_INFO_EXT = 1000091003, + VK_STRUCTURE_TYPE_PRESENT_TIMES_INFO_GOOGLE = 1000092000, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PER_VIEW_ATTRIBUTES_PROPERTIES_NVX = 1000097000, + VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_SWIZZLE_STATE_CREATE_INFO_NV = 1000098000, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DISCARD_RECTANGLE_PROPERTIES_EXT = 1000099000, + VK_STRUCTURE_TYPE_PIPELINE_DISCARD_RECTANGLE_STATE_CREATE_INFO_EXT = 1000099001, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_CONSERVATIVE_RASTERIZATION_PROPERTIES_EXT = 1000101000, + VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_CONSERVATIVE_STATE_CREATE_INFO_EXT = 1000101001, + VK_STRUCTURE_TYPE_HDR_METADATA_EXT = 1000105000, + VK_STRUCTURE_TYPE_SHARED_PRESENT_SURFACE_CAPABILITIES_KHR = 1000111000, + VK_STRUCTURE_TYPE_IMPORT_FENCE_WIN32_HANDLE_INFO_KHR = 1000114000, + VK_STRUCTURE_TYPE_EXPORT_FENCE_WIN32_HANDLE_INFO_KHR = 1000114001, + VK_STRUCTURE_TYPE_FENCE_GET_WIN32_HANDLE_INFO_KHR = 1000114002, + VK_STRUCTURE_TYPE_IMPORT_FENCE_FD_INFO_KHR = 1000115000, + VK_STRUCTURE_TYPE_FENCE_GET_FD_INFO_KHR = 1000115001, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SURFACE_INFO_2_KHR = 1000119000, + VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_KHR = 1000119001, + VK_STRUCTURE_TYPE_SURFACE_FORMAT_2_KHR = 1000119002, + VK_STRUCTURE_TYPE_IOS_SURFACE_CREATE_INFO_MVK = 1000122000, + VK_STRUCTURE_TYPE_MACOS_SURFACE_CREATE_INFO_MVK = 1000123000, + VK_STRUCTURE_TYPE_DEBUG_UTILS_OBJECT_NAME_INFO_EXT = 1000128000, + VK_STRUCTURE_TYPE_DEBUG_UTILS_OBJECT_TAG_INFO_EXT = 1000128001, + VK_STRUCTURE_TYPE_DEBUG_UTILS_LABEL_EXT = 1000128002, + VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CALLBACK_DATA_EXT = 1000128003, + VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CREATE_INFO_EXT = 1000128004, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_FILTER_MINMAX_PROPERTIES_EXT = 1000130000, + VK_STRUCTURE_TYPE_SAMPLER_REDUCTION_MODE_CREATE_INFO_EXT = 1000130001, + VK_STRUCTURE_TYPE_SAMPLE_LOCATIONS_INFO_EXT = 1000143000, + VK_STRUCTURE_TYPE_RENDER_PASS_SAMPLE_LOCATIONS_BEGIN_INFO_EXT = 1000143001, + VK_STRUCTURE_TYPE_PIPELINE_SAMPLE_LOCATIONS_STATE_CREATE_INFO_EXT = 1000143002, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLE_LOCATIONS_PROPERTIES_EXT = 1000143003, + VK_STRUCTURE_TYPE_MULTISAMPLE_PROPERTIES_EXT = 1000143004, + VK_STRUCTURE_TYPE_IMAGE_FORMAT_LIST_CREATE_INFO_KHR = 1000147000, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_BLEND_OPERATION_ADVANCED_FEATURES_EXT = 1000148000, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_BLEND_OPERATION_ADVANCED_PROPERTIES_EXT = 1000148001, + VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_ADVANCED_STATE_CREATE_INFO_EXT = 1000148002, + VK_STRUCTURE_TYPE_PIPELINE_COVERAGE_TO_COLOR_STATE_CREATE_INFO_NV = 1000149000, + VK_STRUCTURE_TYPE_PIPELINE_COVERAGE_MODULATION_STATE_CREATE_INFO_NV = 1000152000, + VK_STRUCTURE_TYPE_VALIDATION_CACHE_CREATE_INFO_EXT = 1000160000, + VK_STRUCTURE_TYPE_SHADER_MODULE_VALIDATION_CACHE_CREATE_INFO_EXT = 1000160001, + VK_STRUCTURE_TYPE_DEVICE_QUEUE_GLOBAL_PRIORITY_CREATE_INFO_EXT = 1000174000, + VK_STRUCTURE_TYPE_IMPORT_MEMORY_HOST_POINTER_INFO_EXT = 1000178000, + VK_STRUCTURE_TYPE_MEMORY_HOST_POINTER_PROPERTIES_EXT = 1000178001, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_MEMORY_HOST_PROPERTIES_EXT = 1000178002, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VERTEX_ATTRIBUTE_DIVISOR_PROPERTIES_EXT = 1000190000, + VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_DIVISOR_STATE_CREATE_INFO_EXT = 1000190001, + VK_STRUCTURE_TYPE_RENDER_PASS_MULTIVIEW_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_RENDER_PASS_MULTIVIEW_CREATE_INFO, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_FEATURES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_FEATURES, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PROPERTIES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PROPERTIES, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2, + VK_STRUCTURE_TYPE_FORMAT_PROPERTIES_2_KHR = VK_STRUCTURE_TYPE_FORMAT_PROPERTIES_2, + VK_STRUCTURE_TYPE_IMAGE_FORMAT_PROPERTIES_2_KHR = VK_STRUCTURE_TYPE_IMAGE_FORMAT_PROPERTIES_2, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2, + VK_STRUCTURE_TYPE_QUEUE_FAMILY_PROPERTIES_2_KHR = VK_STRUCTURE_TYPE_QUEUE_FAMILY_PROPERTIES_2, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2, + VK_STRUCTURE_TYPE_SPARSE_IMAGE_FORMAT_PROPERTIES_2_KHR = VK_STRUCTURE_TYPE_SPARSE_IMAGE_FORMAT_PROPERTIES_2, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SPARSE_IMAGE_FORMAT_INFO_2_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SPARSE_IMAGE_FORMAT_INFO_2, + VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_FLAGS_INFO_KHR = VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_FLAGS_INFO, + VK_STRUCTURE_TYPE_DEVICE_GROUP_RENDER_PASS_BEGIN_INFO_KHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_RENDER_PASS_BEGIN_INFO, + VK_STRUCTURE_TYPE_DEVICE_GROUP_COMMAND_BUFFER_BEGIN_INFO_KHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_COMMAND_BUFFER_BEGIN_INFO, + VK_STRUCTURE_TYPE_DEVICE_GROUP_SUBMIT_INFO_KHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_SUBMIT_INFO, + VK_STRUCTURE_TYPE_DEVICE_GROUP_BIND_SPARSE_INFO_KHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_BIND_SPARSE_INFO, + VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_DEVICE_GROUP_INFO_KHR = VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_DEVICE_GROUP_INFO, + VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFO_KHR = VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFO, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_GROUP_PROPERTIES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_GROUP_PROPERTIES, + VK_STRUCTURE_TYPE_DEVICE_GROUP_DEVICE_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_DEVICE_CREATE_INFO, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO, + VK_STRUCTURE_TYPE_EXTERNAL_IMAGE_FORMAT_PROPERTIES_KHR = VK_STRUCTURE_TYPE_EXTERNAL_IMAGE_FORMAT_PROPERTIES, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_BUFFER_INFO_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_BUFFER_INFO, + VK_STRUCTURE_TYPE_EXTERNAL_BUFFER_PROPERTIES_KHR = VK_STRUCTURE_TYPE_EXTERNAL_BUFFER_PROPERTIES, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_ID_PROPERTIES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_ID_PROPERTIES, + VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_BUFFER_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_BUFFER_CREATE_INFO, + VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO, + VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO_KHR = VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_SEMAPHORE_INFO_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_SEMAPHORE_INFO, + VK_STRUCTURE_TYPE_EXTERNAL_SEMAPHORE_PROPERTIES_KHR = VK_STRUCTURE_TYPE_EXTERNAL_SEMAPHORE_PROPERTIES, + VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_CREATE_INFO, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_16BIT_STORAGE_FEATURES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_16BIT_STORAGE_FEATURES, + VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_FENCE_INFO_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_FENCE_INFO, + VK_STRUCTURE_TYPE_EXTERNAL_FENCE_PROPERTIES_KHR = VK_STRUCTURE_TYPE_EXTERNAL_FENCE_PROPERTIES, + VK_STRUCTURE_TYPE_EXPORT_FENCE_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_EXPORT_FENCE_CREATE_INFO, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_POINT_CLIPPING_PROPERTIES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_POINT_CLIPPING_PROPERTIES, + VK_STRUCTURE_TYPE_RENDER_PASS_INPUT_ATTACHMENT_ASPECT_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_RENDER_PASS_INPUT_ATTACHMENT_ASPECT_CREATE_INFO, + VK_STRUCTURE_TYPE_IMAGE_VIEW_USAGE_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_IMAGE_VIEW_USAGE_CREATE_INFO, + VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_DOMAIN_ORIGIN_STATE_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_DOMAIN_ORIGIN_STATE_CREATE_INFO, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VARIABLE_POINTER_FEATURES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VARIABLE_POINTER_FEATURES, + VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS_KHR = VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS, + VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO_KHR = VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO, + VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2_KHR = VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2, + VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2_KHR = VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2, + VK_STRUCTURE_TYPE_IMAGE_SPARSE_MEMORY_REQUIREMENTS_INFO_2_KHR = VK_STRUCTURE_TYPE_IMAGE_SPARSE_MEMORY_REQUIREMENTS_INFO_2, + VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2_KHR = VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2, + VK_STRUCTURE_TYPE_SPARSE_IMAGE_MEMORY_REQUIREMENTS_2_KHR = VK_STRUCTURE_TYPE_SPARSE_IMAGE_MEMORY_REQUIREMENTS_2, + VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO, + VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_INFO_KHR = VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_INFO, + VK_STRUCTURE_TYPE_BIND_IMAGE_PLANE_MEMORY_INFO_KHR = VK_STRUCTURE_TYPE_BIND_IMAGE_PLANE_MEMORY_INFO, + VK_STRUCTURE_TYPE_IMAGE_PLANE_MEMORY_REQUIREMENTS_INFO_KHR = VK_STRUCTURE_TYPE_IMAGE_PLANE_MEMORY_REQUIREMENTS_INFO, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_YCBCR_CONVERSION_FEATURES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_YCBCR_CONVERSION_FEATURES, + VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_IMAGE_FORMAT_PROPERTIES_KHR = VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_IMAGE_FORMAT_PROPERTIES, + VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO_KHR = VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO, + VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO_KHR = VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO, + VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MAINTENANCE_3_PROPERTIES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MAINTENANCE_3_PROPERTIES, + VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_SUPPORT_KHR = VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_SUPPORT, + VK_STRUCTURE_TYPE_BEGIN_RANGE = VK_STRUCTURE_TYPE_APPLICATION_INFO, + VK_STRUCTURE_TYPE_END_RANGE = VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO, + VK_STRUCTURE_TYPE_RANGE_SIZE = (VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO - VK_STRUCTURE_TYPE_APPLICATION_INFO + 1), + VK_STRUCTURE_TYPE_MAX_ENUM = 0x7FFFFFFF +} VkStructureType; + +typedef enum VkSystemAllocationScope { + VK_SYSTEM_ALLOCATION_SCOPE_COMMAND = 0, + VK_SYSTEM_ALLOCATION_SCOPE_OBJECT = 1, + VK_SYSTEM_ALLOCATION_SCOPE_CACHE = 2, + VK_SYSTEM_ALLOCATION_SCOPE_DEVICE = 3, + VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE = 4, + VK_SYSTEM_ALLOCATION_SCOPE_BEGIN_RANGE = VK_SYSTEM_ALLOCATION_SCOPE_COMMAND, + VK_SYSTEM_ALLOCATION_SCOPE_END_RANGE = VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE, + VK_SYSTEM_ALLOCATION_SCOPE_RANGE_SIZE = (VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE - VK_SYSTEM_ALLOCATION_SCOPE_COMMAND + 1), + VK_SYSTEM_ALLOCATION_SCOPE_MAX_ENUM = 0x7FFFFFFF +} VkSystemAllocationScope; + +typedef enum VkInternalAllocationType { + VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE = 0, + VK_INTERNAL_ALLOCATION_TYPE_BEGIN_RANGE = VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE, + VK_INTERNAL_ALLOCATION_TYPE_END_RANGE = VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE, + VK_INTERNAL_ALLOCATION_TYPE_RANGE_SIZE = (VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE - VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE + 1), + VK_INTERNAL_ALLOCATION_TYPE_MAX_ENUM = 0x7FFFFFFF +} VkInternalAllocationType; + +typedef enum VkFormat { + VK_FORMAT_UNDEFINED = 0, + VK_FORMAT_R4G4_UNORM_PACK8 = 1, + VK_FORMAT_R4G4B4A4_UNORM_PACK16 = 2, + VK_FORMAT_B4G4R4A4_UNORM_PACK16 = 3, + VK_FORMAT_R5G6B5_UNORM_PACK16 = 4, + VK_FORMAT_B5G6R5_UNORM_PACK16 = 5, + VK_FORMAT_R5G5B5A1_UNORM_PACK16 = 6, + VK_FORMAT_B5G5R5A1_UNORM_PACK16 = 7, + VK_FORMAT_A1R5G5B5_UNORM_PACK16 = 8, + VK_FORMAT_R8_UNORM = 9, + VK_FORMAT_R8_SNORM = 10, + VK_FORMAT_R8_USCALED = 11, + VK_FORMAT_R8_SSCALED = 12, + VK_FORMAT_R8_UINT = 13, + VK_FORMAT_R8_SINT = 14, + VK_FORMAT_R8_SRGB = 15, + VK_FORMAT_R8G8_UNORM = 16, + VK_FORMAT_R8G8_SNORM = 17, + VK_FORMAT_R8G8_USCALED = 18, + VK_FORMAT_R8G8_SSCALED = 19, + VK_FORMAT_R8G8_UINT = 20, + VK_FORMAT_R8G8_SINT = 21, + VK_FORMAT_R8G8_SRGB = 22, + VK_FORMAT_R8G8B8_UNORM = 23, + VK_FORMAT_R8G8B8_SNORM = 24, + VK_FORMAT_R8G8B8_USCALED = 25, + VK_FORMAT_R8G8B8_SSCALED = 26, + VK_FORMAT_R8G8B8_UINT = 27, + VK_FORMAT_R8G8B8_SINT = 28, + VK_FORMAT_R8G8B8_SRGB = 29, + VK_FORMAT_B8G8R8_UNORM = 30, + VK_FORMAT_B8G8R8_SNORM = 31, + VK_FORMAT_B8G8R8_USCALED = 32, + VK_FORMAT_B8G8R8_SSCALED = 33, + VK_FORMAT_B8G8R8_UINT = 34, + VK_FORMAT_B8G8R8_SINT = 35, + VK_FORMAT_B8G8R8_SRGB = 36, + VK_FORMAT_R8G8B8A8_UNORM = 37, + VK_FORMAT_R8G8B8A8_SNORM = 38, + VK_FORMAT_R8G8B8A8_USCALED = 39, + VK_FORMAT_R8G8B8A8_SSCALED = 40, + VK_FORMAT_R8G8B8A8_UINT = 41, + VK_FORMAT_R8G8B8A8_SINT = 42, + VK_FORMAT_R8G8B8A8_SRGB = 43, + VK_FORMAT_B8G8R8A8_UNORM = 44, + VK_FORMAT_B8G8R8A8_SNORM = 45, + VK_FORMAT_B8G8R8A8_USCALED = 46, + VK_FORMAT_B8G8R8A8_SSCALED = 47, + VK_FORMAT_B8G8R8A8_UINT = 48, + VK_FORMAT_B8G8R8A8_SINT = 49, + VK_FORMAT_B8G8R8A8_SRGB = 50, + VK_FORMAT_A8B8G8R8_UNORM_PACK32 = 51, + VK_FORMAT_A8B8G8R8_SNORM_PACK32 = 52, + VK_FORMAT_A8B8G8R8_USCALED_PACK32 = 53, + VK_FORMAT_A8B8G8R8_SSCALED_PACK32 = 54, + VK_FORMAT_A8B8G8R8_UINT_PACK32 = 55, + VK_FORMAT_A8B8G8R8_SINT_PACK32 = 56, + VK_FORMAT_A8B8G8R8_SRGB_PACK32 = 57, + VK_FORMAT_A2R10G10B10_UNORM_PACK32 = 58, + VK_FORMAT_A2R10G10B10_SNORM_PACK32 = 59, + VK_FORMAT_A2R10G10B10_USCALED_PACK32 = 60, + VK_FORMAT_A2R10G10B10_SSCALED_PACK32 = 61, + VK_FORMAT_A2R10G10B10_UINT_PACK32 = 62, + VK_FORMAT_A2R10G10B10_SINT_PACK32 = 63, + VK_FORMAT_A2B10G10R10_UNORM_PACK32 = 64, + VK_FORMAT_A2B10G10R10_SNORM_PACK32 = 65, + VK_FORMAT_A2B10G10R10_USCALED_PACK32 = 66, + VK_FORMAT_A2B10G10R10_SSCALED_PACK32 = 67, + VK_FORMAT_A2B10G10R10_UINT_PACK32 = 68, + VK_FORMAT_A2B10G10R10_SINT_PACK32 = 69, + VK_FORMAT_R16_UNORM = 70, + VK_FORMAT_R16_SNORM = 71, + VK_FORMAT_R16_USCALED = 72, + VK_FORMAT_R16_SSCALED = 73, + VK_FORMAT_R16_UINT = 74, + VK_FORMAT_R16_SINT = 75, + VK_FORMAT_R16_SFLOAT = 76, + VK_FORMAT_R16G16_UNORM = 77, + VK_FORMAT_R16G16_SNORM = 78, + VK_FORMAT_R16G16_USCALED = 79, + VK_FORMAT_R16G16_SSCALED = 80, + VK_FORMAT_R16G16_UINT = 81, + VK_FORMAT_R16G16_SINT = 82, + VK_FORMAT_R16G16_SFLOAT = 83, + VK_FORMAT_R16G16B16_UNORM = 84, + VK_FORMAT_R16G16B16_SNORM = 85, + VK_FORMAT_R16G16B16_USCALED = 86, + VK_FORMAT_R16G16B16_SSCALED = 87, + VK_FORMAT_R16G16B16_UINT = 88, + VK_FORMAT_R16G16B16_SINT = 89, + VK_FORMAT_R16G16B16_SFLOAT = 90, + VK_FORMAT_R16G16B16A16_UNORM = 91, + VK_FORMAT_R16G16B16A16_SNORM = 92, + VK_FORMAT_R16G16B16A16_USCALED = 93, + VK_FORMAT_R16G16B16A16_SSCALED = 94, + VK_FORMAT_R16G16B16A16_UINT = 95, + VK_FORMAT_R16G16B16A16_SINT = 96, + VK_FORMAT_R16G16B16A16_SFLOAT = 97, + VK_FORMAT_R32_UINT = 98, + VK_FORMAT_R32_SINT = 99, + VK_FORMAT_R32_SFLOAT = 100, + VK_FORMAT_R32G32_UINT = 101, + VK_FORMAT_R32G32_SINT = 102, + VK_FORMAT_R32G32_SFLOAT = 103, + VK_FORMAT_R32G32B32_UINT = 104, + VK_FORMAT_R32G32B32_SINT = 105, + VK_FORMAT_R32G32B32_SFLOAT = 106, + VK_FORMAT_R32G32B32A32_UINT = 107, + VK_FORMAT_R32G32B32A32_SINT = 108, + VK_FORMAT_R32G32B32A32_SFLOAT = 109, + VK_FORMAT_R64_UINT = 110, + VK_FORMAT_R64_SINT = 111, + VK_FORMAT_R64_SFLOAT = 112, + VK_FORMAT_R64G64_UINT = 113, + VK_FORMAT_R64G64_SINT = 114, + VK_FORMAT_R64G64_SFLOAT = 115, + VK_FORMAT_R64G64B64_UINT = 116, + VK_FORMAT_R64G64B64_SINT = 117, + VK_FORMAT_R64G64B64_SFLOAT = 118, + VK_FORMAT_R64G64B64A64_UINT = 119, + VK_FORMAT_R64G64B64A64_SINT = 120, + VK_FORMAT_R64G64B64A64_SFLOAT = 121, + VK_FORMAT_B10G11R11_UFLOAT_PACK32 = 122, + VK_FORMAT_E5B9G9R9_UFLOAT_PACK32 = 123, + VK_FORMAT_D16_UNORM = 124, + VK_FORMAT_X8_D24_UNORM_PACK32 = 125, + VK_FORMAT_D32_SFLOAT = 126, + VK_FORMAT_S8_UINT = 127, + VK_FORMAT_D16_UNORM_S8_UINT = 128, + VK_FORMAT_D24_UNORM_S8_UINT = 129, + VK_FORMAT_D32_SFLOAT_S8_UINT = 130, + VK_FORMAT_BC1_RGB_UNORM_BLOCK = 131, + VK_FORMAT_BC1_RGB_SRGB_BLOCK = 132, + VK_FORMAT_BC1_RGBA_UNORM_BLOCK = 133, + VK_FORMAT_BC1_RGBA_SRGB_BLOCK = 134, + VK_FORMAT_BC2_UNORM_BLOCK = 135, + VK_FORMAT_BC2_SRGB_BLOCK = 136, + VK_FORMAT_BC3_UNORM_BLOCK = 137, + VK_FORMAT_BC3_SRGB_BLOCK = 138, + VK_FORMAT_BC4_UNORM_BLOCK = 139, + VK_FORMAT_BC4_SNORM_BLOCK = 140, + VK_FORMAT_BC5_UNORM_BLOCK = 141, + VK_FORMAT_BC5_SNORM_BLOCK = 142, + VK_FORMAT_BC6H_UFLOAT_BLOCK = 143, + VK_FORMAT_BC6H_SFLOAT_BLOCK = 144, + VK_FORMAT_BC7_UNORM_BLOCK = 145, + VK_FORMAT_BC7_SRGB_BLOCK = 146, + VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK = 147, + VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK = 148, + VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK = 149, + VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK = 150, + VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK = 151, + VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK = 152, + VK_FORMAT_EAC_R11_UNORM_BLOCK = 153, + VK_FORMAT_EAC_R11_SNORM_BLOCK = 154, + VK_FORMAT_EAC_R11G11_UNORM_BLOCK = 155, + VK_FORMAT_EAC_R11G11_SNORM_BLOCK = 156, + VK_FORMAT_ASTC_4x4_UNORM_BLOCK = 157, + VK_FORMAT_ASTC_4x4_SRGB_BLOCK = 158, + VK_FORMAT_ASTC_5x4_UNORM_BLOCK = 159, + VK_FORMAT_ASTC_5x4_SRGB_BLOCK = 160, + VK_FORMAT_ASTC_5x5_UNORM_BLOCK = 161, + VK_FORMAT_ASTC_5x5_SRGB_BLOCK = 162, + VK_FORMAT_ASTC_6x5_UNORM_BLOCK = 163, + VK_FORMAT_ASTC_6x5_SRGB_BLOCK = 164, + VK_FORMAT_ASTC_6x6_UNORM_BLOCK = 165, + VK_FORMAT_ASTC_6x6_SRGB_BLOCK = 166, + VK_FORMAT_ASTC_8x5_UNORM_BLOCK = 167, + VK_FORMAT_ASTC_8x5_SRGB_BLOCK = 168, + VK_FORMAT_ASTC_8x6_UNORM_BLOCK = 169, + VK_FORMAT_ASTC_8x6_SRGB_BLOCK = 170, + VK_FORMAT_ASTC_8x8_UNORM_BLOCK = 171, + VK_FORMAT_ASTC_8x8_SRGB_BLOCK = 172, + VK_FORMAT_ASTC_10x5_UNORM_BLOCK = 173, + VK_FORMAT_ASTC_10x5_SRGB_BLOCK = 174, + VK_FORMAT_ASTC_10x6_UNORM_BLOCK = 175, + VK_FORMAT_ASTC_10x6_SRGB_BLOCK = 176, + VK_FORMAT_ASTC_10x8_UNORM_BLOCK = 177, + VK_FORMAT_ASTC_10x8_SRGB_BLOCK = 178, + VK_FORMAT_ASTC_10x10_UNORM_BLOCK = 179, + VK_FORMAT_ASTC_10x10_SRGB_BLOCK = 180, + VK_FORMAT_ASTC_12x10_UNORM_BLOCK = 181, + VK_FORMAT_ASTC_12x10_SRGB_BLOCK = 182, + VK_FORMAT_ASTC_12x12_UNORM_BLOCK = 183, + VK_FORMAT_ASTC_12x12_SRGB_BLOCK = 184, + VK_FORMAT_G8B8G8R8_422_UNORM = 1000156000, + VK_FORMAT_B8G8R8G8_422_UNORM = 1000156001, + VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM = 1000156002, + VK_FORMAT_G8_B8R8_2PLANE_420_UNORM = 1000156003, + VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM = 1000156004, + VK_FORMAT_G8_B8R8_2PLANE_422_UNORM = 1000156005, + VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM = 1000156006, + VK_FORMAT_R10X6_UNORM_PACK16 = 1000156007, + VK_FORMAT_R10X6G10X6_UNORM_2PACK16 = 1000156008, + VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16 = 1000156009, + VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16 = 1000156010, + VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16 = 1000156011, + VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16 = 1000156012, + VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16 = 1000156013, + VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16 = 1000156014, + VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16 = 1000156015, + VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16 = 1000156016, + VK_FORMAT_R12X4_UNORM_PACK16 = 1000156017, + VK_FORMAT_R12X4G12X4_UNORM_2PACK16 = 1000156018, + VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16 = 1000156019, + VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16 = 1000156020, + VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16 = 1000156021, + VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16 = 1000156022, + VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16 = 1000156023, + VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16 = 1000156024, + VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16 = 1000156025, + VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16 = 1000156026, + VK_FORMAT_G16B16G16R16_422_UNORM = 1000156027, + VK_FORMAT_B16G16R16G16_422_UNORM = 1000156028, + VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM = 1000156029, + VK_FORMAT_G16_B16R16_2PLANE_420_UNORM = 1000156030, + VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM = 1000156031, + VK_FORMAT_G16_B16R16_2PLANE_422_UNORM = 1000156032, + VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM = 1000156033, + VK_FORMAT_PVRTC1_2BPP_UNORM_BLOCK_IMG = 1000054000, + VK_FORMAT_PVRTC1_4BPP_UNORM_BLOCK_IMG = 1000054001, + VK_FORMAT_PVRTC2_2BPP_UNORM_BLOCK_IMG = 1000054002, + VK_FORMAT_PVRTC2_4BPP_UNORM_BLOCK_IMG = 1000054003, + VK_FORMAT_PVRTC1_2BPP_SRGB_BLOCK_IMG = 1000054004, + VK_FORMAT_PVRTC1_4BPP_SRGB_BLOCK_IMG = 1000054005, + VK_FORMAT_PVRTC2_2BPP_SRGB_BLOCK_IMG = 1000054006, + VK_FORMAT_PVRTC2_4BPP_SRGB_BLOCK_IMG = 1000054007, + VK_FORMAT_G8B8G8R8_422_UNORM_KHR = VK_FORMAT_G8B8G8R8_422_UNORM, + VK_FORMAT_B8G8R8G8_422_UNORM_KHR = VK_FORMAT_B8G8R8G8_422_UNORM, + VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM_KHR = VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM, + VK_FORMAT_G8_B8R8_2PLANE_420_UNORM_KHR = VK_FORMAT_G8_B8R8_2PLANE_420_UNORM, + VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM_KHR = VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM, + VK_FORMAT_G8_B8R8_2PLANE_422_UNORM_KHR = VK_FORMAT_G8_B8R8_2PLANE_422_UNORM, + VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM_KHR = VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM, + VK_FORMAT_R10X6_UNORM_PACK16_KHR = VK_FORMAT_R10X6_UNORM_PACK16, + VK_FORMAT_R10X6G10X6_UNORM_2PACK16_KHR = VK_FORMAT_R10X6G10X6_UNORM_2PACK16, + VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16_KHR = VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16, + VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16_KHR = VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16, + VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16_KHR = VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16, + VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16_KHR = VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16, + VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16_KHR = VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16, + VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16_KHR = VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16, + VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16_KHR = VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16, + VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16_KHR = VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16, + VK_FORMAT_R12X4_UNORM_PACK16_KHR = VK_FORMAT_R12X4_UNORM_PACK16, + VK_FORMAT_R12X4G12X4_UNORM_2PACK16_KHR = VK_FORMAT_R12X4G12X4_UNORM_2PACK16, + VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16_KHR = VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16, + VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16_KHR = VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16, + VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16_KHR = VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16, + VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16_KHR = VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16, + VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16_KHR = VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16, + VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16_KHR = VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16, + VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16_KHR = VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16, + VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16_KHR = VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16, + VK_FORMAT_G16B16G16R16_422_UNORM_KHR = VK_FORMAT_G16B16G16R16_422_UNORM, + VK_FORMAT_B16G16R16G16_422_UNORM_KHR = VK_FORMAT_B16G16R16G16_422_UNORM, + VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM_KHR = VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM, + VK_FORMAT_G16_B16R16_2PLANE_420_UNORM_KHR = VK_FORMAT_G16_B16R16_2PLANE_420_UNORM, + VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM_KHR = VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM, + VK_FORMAT_G16_B16R16_2PLANE_422_UNORM_KHR = VK_FORMAT_G16_B16R16_2PLANE_422_UNORM, + VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM_KHR = VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM, + VK_FORMAT_BEGIN_RANGE = VK_FORMAT_UNDEFINED, + VK_FORMAT_END_RANGE = VK_FORMAT_ASTC_12x12_SRGB_BLOCK, + VK_FORMAT_RANGE_SIZE = (VK_FORMAT_ASTC_12x12_SRGB_BLOCK - VK_FORMAT_UNDEFINED + 1), + VK_FORMAT_MAX_ENUM = 0x7FFFFFFF +} VkFormat; + +typedef enum VkImageType { + VK_IMAGE_TYPE_1D = 0, + VK_IMAGE_TYPE_2D = 1, + VK_IMAGE_TYPE_3D = 2, + VK_IMAGE_TYPE_BEGIN_RANGE = VK_IMAGE_TYPE_1D, + VK_IMAGE_TYPE_END_RANGE = VK_IMAGE_TYPE_3D, + VK_IMAGE_TYPE_RANGE_SIZE = (VK_IMAGE_TYPE_3D - VK_IMAGE_TYPE_1D + 1), + VK_IMAGE_TYPE_MAX_ENUM = 0x7FFFFFFF +} VkImageType; + +typedef enum VkImageTiling { + VK_IMAGE_TILING_OPTIMAL = 0, + VK_IMAGE_TILING_LINEAR = 1, + VK_IMAGE_TILING_BEGIN_RANGE = VK_IMAGE_TILING_OPTIMAL, + VK_IMAGE_TILING_END_RANGE = VK_IMAGE_TILING_LINEAR, + VK_IMAGE_TILING_RANGE_SIZE = (VK_IMAGE_TILING_LINEAR - VK_IMAGE_TILING_OPTIMAL + 1), + VK_IMAGE_TILING_MAX_ENUM = 0x7FFFFFFF +} VkImageTiling; + +typedef enum VkPhysicalDeviceType { + VK_PHYSICAL_DEVICE_TYPE_OTHER = 0, + VK_PHYSICAL_DEVICE_TYPE_INTEGRATED_GPU = 1, + VK_PHYSICAL_DEVICE_TYPE_DISCRETE_GPU = 2, + VK_PHYSICAL_DEVICE_TYPE_VIRTUAL_GPU = 3, + VK_PHYSICAL_DEVICE_TYPE_CPU = 4, + VK_PHYSICAL_DEVICE_TYPE_BEGIN_RANGE = VK_PHYSICAL_DEVICE_TYPE_OTHER, + VK_PHYSICAL_DEVICE_TYPE_END_RANGE = VK_PHYSICAL_DEVICE_TYPE_CPU, + VK_PHYSICAL_DEVICE_TYPE_RANGE_SIZE = (VK_PHYSICAL_DEVICE_TYPE_CPU - VK_PHYSICAL_DEVICE_TYPE_OTHER + 1), + VK_PHYSICAL_DEVICE_TYPE_MAX_ENUM = 0x7FFFFFFF +} VkPhysicalDeviceType; + +typedef enum VkQueryType { + VK_QUERY_TYPE_OCCLUSION = 0, + VK_QUERY_TYPE_PIPELINE_STATISTICS = 1, + VK_QUERY_TYPE_TIMESTAMP = 2, + VK_QUERY_TYPE_BEGIN_RANGE = VK_QUERY_TYPE_OCCLUSION, + VK_QUERY_TYPE_END_RANGE = VK_QUERY_TYPE_TIMESTAMP, + VK_QUERY_TYPE_RANGE_SIZE = (VK_QUERY_TYPE_TIMESTAMP - VK_QUERY_TYPE_OCCLUSION + 1), + VK_QUERY_TYPE_MAX_ENUM = 0x7FFFFFFF +} VkQueryType; + +typedef enum VkSharingMode { + VK_SHARING_MODE_EXCLUSIVE = 0, + VK_SHARING_MODE_CONCURRENT = 1, + VK_SHARING_MODE_BEGIN_RANGE = VK_SHARING_MODE_EXCLUSIVE, + VK_SHARING_MODE_END_RANGE = VK_SHARING_MODE_CONCURRENT, + VK_SHARING_MODE_RANGE_SIZE = (VK_SHARING_MODE_CONCURRENT - VK_SHARING_MODE_EXCLUSIVE + 1), + VK_SHARING_MODE_MAX_ENUM = 0x7FFFFFFF +} VkSharingMode; + +typedef enum VkImageLayout { + VK_IMAGE_LAYOUT_UNDEFINED = 0, + VK_IMAGE_LAYOUT_GENERAL = 1, + VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL = 2, + VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL = 3, + VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL = 4, + VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL = 5, + VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL = 6, + VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL = 7, + VK_IMAGE_LAYOUT_PREINITIALIZED = 8, + VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL = 1000117000, + VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL = 1000117001, + VK_IMAGE_LAYOUT_PRESENT_SRC_KHR = 1000001002, + VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR = 1000111000, + VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL_KHR = VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL, + VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL_KHR = VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL, + VK_IMAGE_LAYOUT_BEGIN_RANGE = VK_IMAGE_LAYOUT_UNDEFINED, + VK_IMAGE_LAYOUT_END_RANGE = VK_IMAGE_LAYOUT_PREINITIALIZED, + VK_IMAGE_LAYOUT_RANGE_SIZE = (VK_IMAGE_LAYOUT_PREINITIALIZED - VK_IMAGE_LAYOUT_UNDEFINED + 1), + VK_IMAGE_LAYOUT_MAX_ENUM = 0x7FFFFFFF +} VkImageLayout; + +typedef enum VkImageViewType { + VK_IMAGE_VIEW_TYPE_1D = 0, + VK_IMAGE_VIEW_TYPE_2D = 1, + VK_IMAGE_VIEW_TYPE_3D = 2, + VK_IMAGE_VIEW_TYPE_CUBE = 3, + VK_IMAGE_VIEW_TYPE_1D_ARRAY = 4, + VK_IMAGE_VIEW_TYPE_2D_ARRAY = 5, + VK_IMAGE_VIEW_TYPE_CUBE_ARRAY = 6, + VK_IMAGE_VIEW_TYPE_BEGIN_RANGE = VK_IMAGE_VIEW_TYPE_1D, + VK_IMAGE_VIEW_TYPE_END_RANGE = VK_IMAGE_VIEW_TYPE_CUBE_ARRAY, + VK_IMAGE_VIEW_TYPE_RANGE_SIZE = (VK_IMAGE_VIEW_TYPE_CUBE_ARRAY - VK_IMAGE_VIEW_TYPE_1D + 1), + VK_IMAGE_VIEW_TYPE_MAX_ENUM = 0x7FFFFFFF +} VkImageViewType; + +typedef enum VkComponentSwizzle { + VK_COMPONENT_SWIZZLE_IDENTITY = 0, + VK_COMPONENT_SWIZZLE_ZERO = 1, + VK_COMPONENT_SWIZZLE_ONE = 2, + VK_COMPONENT_SWIZZLE_R = 3, + VK_COMPONENT_SWIZZLE_G = 4, + VK_COMPONENT_SWIZZLE_B = 5, + VK_COMPONENT_SWIZZLE_A = 6, + VK_COMPONENT_SWIZZLE_BEGIN_RANGE = VK_COMPONENT_SWIZZLE_IDENTITY, + VK_COMPONENT_SWIZZLE_END_RANGE = VK_COMPONENT_SWIZZLE_A, + VK_COMPONENT_SWIZZLE_RANGE_SIZE = (VK_COMPONENT_SWIZZLE_A - VK_COMPONENT_SWIZZLE_IDENTITY + 1), + VK_COMPONENT_SWIZZLE_MAX_ENUM = 0x7FFFFFFF +} VkComponentSwizzle; + +typedef enum VkVertexInputRate { + VK_VERTEX_INPUT_RATE_VERTEX = 0, + VK_VERTEX_INPUT_RATE_INSTANCE = 1, + VK_VERTEX_INPUT_RATE_BEGIN_RANGE = VK_VERTEX_INPUT_RATE_VERTEX, + VK_VERTEX_INPUT_RATE_END_RANGE = VK_VERTEX_INPUT_RATE_INSTANCE, + VK_VERTEX_INPUT_RATE_RANGE_SIZE = (VK_VERTEX_INPUT_RATE_INSTANCE - VK_VERTEX_INPUT_RATE_VERTEX + 1), + VK_VERTEX_INPUT_RATE_MAX_ENUM = 0x7FFFFFFF +} VkVertexInputRate; + +typedef enum VkPrimitiveTopology { + VK_PRIMITIVE_TOPOLOGY_POINT_LIST = 0, + VK_PRIMITIVE_TOPOLOGY_LINE_LIST = 1, + VK_PRIMITIVE_TOPOLOGY_LINE_STRIP = 2, + VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST = 3, + VK_PRIMITIVE_TOPOLOGY_TRIANGLE_STRIP = 4, + VK_PRIMITIVE_TOPOLOGY_TRIANGLE_FAN = 5, + VK_PRIMITIVE_TOPOLOGY_LINE_LIST_WITH_ADJACENCY = 6, + VK_PRIMITIVE_TOPOLOGY_LINE_STRIP_WITH_ADJACENCY = 7, + VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST_WITH_ADJACENCY = 8, + VK_PRIMITIVE_TOPOLOGY_TRIANGLE_STRIP_WITH_ADJACENCY = 9, + VK_PRIMITIVE_TOPOLOGY_PATCH_LIST = 10, + VK_PRIMITIVE_TOPOLOGY_BEGIN_RANGE = VK_PRIMITIVE_TOPOLOGY_POINT_LIST, + VK_PRIMITIVE_TOPOLOGY_END_RANGE = VK_PRIMITIVE_TOPOLOGY_PATCH_LIST, + VK_PRIMITIVE_TOPOLOGY_RANGE_SIZE = (VK_PRIMITIVE_TOPOLOGY_PATCH_LIST - VK_PRIMITIVE_TOPOLOGY_POINT_LIST + 1), + VK_PRIMITIVE_TOPOLOGY_MAX_ENUM = 0x7FFFFFFF +} VkPrimitiveTopology; + +typedef enum VkPolygonMode { + VK_POLYGON_MODE_FILL = 0, + VK_POLYGON_MODE_LINE = 1, + VK_POLYGON_MODE_POINT = 2, + VK_POLYGON_MODE_FILL_RECTANGLE_NV = 1000153000, + VK_POLYGON_MODE_BEGIN_RANGE = VK_POLYGON_MODE_FILL, + VK_POLYGON_MODE_END_RANGE = VK_POLYGON_MODE_POINT, + VK_POLYGON_MODE_RANGE_SIZE = (VK_POLYGON_MODE_POINT - VK_POLYGON_MODE_FILL + 1), + VK_POLYGON_MODE_MAX_ENUM = 0x7FFFFFFF +} VkPolygonMode; + +typedef enum VkFrontFace { + VK_FRONT_FACE_COUNTER_CLOCKWISE = 0, + VK_FRONT_FACE_CLOCKWISE = 1, + VK_FRONT_FACE_BEGIN_RANGE = VK_FRONT_FACE_COUNTER_CLOCKWISE, + VK_FRONT_FACE_END_RANGE = VK_FRONT_FACE_CLOCKWISE, + VK_FRONT_FACE_RANGE_SIZE = (VK_FRONT_FACE_CLOCKWISE - VK_FRONT_FACE_COUNTER_CLOCKWISE + 1), + VK_FRONT_FACE_MAX_ENUM = 0x7FFFFFFF +} VkFrontFace; + +typedef enum VkCompareOp { + VK_COMPARE_OP_NEVER = 0, + VK_COMPARE_OP_LESS = 1, + VK_COMPARE_OP_EQUAL = 2, + VK_COMPARE_OP_LESS_OR_EQUAL = 3, + VK_COMPARE_OP_GREATER = 4, + VK_COMPARE_OP_NOT_EQUAL = 5, + VK_COMPARE_OP_GREATER_OR_EQUAL = 6, + VK_COMPARE_OP_ALWAYS = 7, + VK_COMPARE_OP_BEGIN_RANGE = VK_COMPARE_OP_NEVER, + VK_COMPARE_OP_END_RANGE = VK_COMPARE_OP_ALWAYS, + VK_COMPARE_OP_RANGE_SIZE = (VK_COMPARE_OP_ALWAYS - VK_COMPARE_OP_NEVER + 1), + VK_COMPARE_OP_MAX_ENUM = 0x7FFFFFFF +} VkCompareOp; + +typedef enum VkStencilOp { + VK_STENCIL_OP_KEEP = 0, + VK_STENCIL_OP_ZERO = 1, + VK_STENCIL_OP_REPLACE = 2, + VK_STENCIL_OP_INCREMENT_AND_CLAMP = 3, + VK_STENCIL_OP_DECREMENT_AND_CLAMP = 4, + VK_STENCIL_OP_INVERT = 5, + VK_STENCIL_OP_INCREMENT_AND_WRAP = 6, + VK_STENCIL_OP_DECREMENT_AND_WRAP = 7, + VK_STENCIL_OP_BEGIN_RANGE = VK_STENCIL_OP_KEEP, + VK_STENCIL_OP_END_RANGE = VK_STENCIL_OP_DECREMENT_AND_WRAP, + VK_STENCIL_OP_RANGE_SIZE = (VK_STENCIL_OP_DECREMENT_AND_WRAP - VK_STENCIL_OP_KEEP + 1), + VK_STENCIL_OP_MAX_ENUM = 0x7FFFFFFF +} VkStencilOp; + +typedef enum VkLogicOp { + VK_LOGIC_OP_CLEAR = 0, + VK_LOGIC_OP_AND = 1, + VK_LOGIC_OP_AND_REVERSE = 2, + VK_LOGIC_OP_COPY = 3, + VK_LOGIC_OP_AND_INVERTED = 4, + VK_LOGIC_OP_NO_OP = 5, + VK_LOGIC_OP_XOR = 6, + VK_LOGIC_OP_OR = 7, + VK_LOGIC_OP_NOR = 8, + VK_LOGIC_OP_EQUIVALENT = 9, + VK_LOGIC_OP_INVERT = 10, + VK_LOGIC_OP_OR_REVERSE = 11, + VK_LOGIC_OP_COPY_INVERTED = 12, + VK_LOGIC_OP_OR_INVERTED = 13, + VK_LOGIC_OP_NAND = 14, + VK_LOGIC_OP_SET = 15, + VK_LOGIC_OP_BEGIN_RANGE = VK_LOGIC_OP_CLEAR, + VK_LOGIC_OP_END_RANGE = VK_LOGIC_OP_SET, + VK_LOGIC_OP_RANGE_SIZE = (VK_LOGIC_OP_SET - VK_LOGIC_OP_CLEAR + 1), + VK_LOGIC_OP_MAX_ENUM = 0x7FFFFFFF +} VkLogicOp; + +typedef enum VkBlendFactor { + VK_BLEND_FACTOR_ZERO = 0, + VK_BLEND_FACTOR_ONE = 1, + VK_BLEND_FACTOR_SRC_COLOR = 2, + VK_BLEND_FACTOR_ONE_MINUS_SRC_COLOR = 3, + VK_BLEND_FACTOR_DST_COLOR = 4, + VK_BLEND_FACTOR_ONE_MINUS_DST_COLOR = 5, + VK_BLEND_FACTOR_SRC_ALPHA = 6, + VK_BLEND_FACTOR_ONE_MINUS_SRC_ALPHA = 7, + VK_BLEND_FACTOR_DST_ALPHA = 8, + VK_BLEND_FACTOR_ONE_MINUS_DST_ALPHA = 9, + VK_BLEND_FACTOR_CONSTANT_COLOR = 10, + VK_BLEND_FACTOR_ONE_MINUS_CONSTANT_COLOR = 11, + VK_BLEND_FACTOR_CONSTANT_ALPHA = 12, + VK_BLEND_FACTOR_ONE_MINUS_CONSTANT_ALPHA = 13, + VK_BLEND_FACTOR_SRC_ALPHA_SATURATE = 14, + VK_BLEND_FACTOR_SRC1_COLOR = 15, + VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR = 16, + VK_BLEND_FACTOR_SRC1_ALPHA = 17, + VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA = 18, + VK_BLEND_FACTOR_BEGIN_RANGE = VK_BLEND_FACTOR_ZERO, + VK_BLEND_FACTOR_END_RANGE = VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA, + VK_BLEND_FACTOR_RANGE_SIZE = (VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA - VK_BLEND_FACTOR_ZERO + 1), + VK_BLEND_FACTOR_MAX_ENUM = 0x7FFFFFFF +} VkBlendFactor; + +typedef enum VkBlendOp { + VK_BLEND_OP_ADD = 0, + VK_BLEND_OP_SUBTRACT = 1, + VK_BLEND_OP_REVERSE_SUBTRACT = 2, + VK_BLEND_OP_MIN = 3, + VK_BLEND_OP_MAX = 4, + VK_BLEND_OP_ZERO_EXT = 1000148000, + VK_BLEND_OP_SRC_EXT = 1000148001, + VK_BLEND_OP_DST_EXT = 1000148002, + VK_BLEND_OP_SRC_OVER_EXT = 1000148003, + VK_BLEND_OP_DST_OVER_EXT = 1000148004, + VK_BLEND_OP_SRC_IN_EXT = 1000148005, + VK_BLEND_OP_DST_IN_EXT = 1000148006, + VK_BLEND_OP_SRC_OUT_EXT = 1000148007, + VK_BLEND_OP_DST_OUT_EXT = 1000148008, + VK_BLEND_OP_SRC_ATOP_EXT = 1000148009, + VK_BLEND_OP_DST_ATOP_EXT = 1000148010, + VK_BLEND_OP_XOR_EXT = 1000148011, + VK_BLEND_OP_MULTIPLY_EXT = 1000148012, + VK_BLEND_OP_SCREEN_EXT = 1000148013, + VK_BLEND_OP_OVERLAY_EXT = 1000148014, + VK_BLEND_OP_DARKEN_EXT = 1000148015, + VK_BLEND_OP_LIGHTEN_EXT = 1000148016, + VK_BLEND_OP_COLORDODGE_EXT = 1000148017, + VK_BLEND_OP_COLORBURN_EXT = 1000148018, + VK_BLEND_OP_HARDLIGHT_EXT = 1000148019, + VK_BLEND_OP_SOFTLIGHT_EXT = 1000148020, + VK_BLEND_OP_DIFFERENCE_EXT = 1000148021, + VK_BLEND_OP_EXCLUSION_EXT = 1000148022, + VK_BLEND_OP_INVERT_EXT = 1000148023, + VK_BLEND_OP_INVERT_RGB_EXT = 1000148024, + VK_BLEND_OP_LINEARDODGE_EXT = 1000148025, + VK_BLEND_OP_LINEARBURN_EXT = 1000148026, + VK_BLEND_OP_VIVIDLIGHT_EXT = 1000148027, + VK_BLEND_OP_LINEARLIGHT_EXT = 1000148028, + VK_BLEND_OP_PINLIGHT_EXT = 1000148029, + VK_BLEND_OP_HARDMIX_EXT = 1000148030, + VK_BLEND_OP_HSL_HUE_EXT = 1000148031, + VK_BLEND_OP_HSL_SATURATION_EXT = 1000148032, + VK_BLEND_OP_HSL_COLOR_EXT = 1000148033, + VK_BLEND_OP_HSL_LUMINOSITY_EXT = 1000148034, + VK_BLEND_OP_PLUS_EXT = 1000148035, + VK_BLEND_OP_PLUS_CLAMPED_EXT = 1000148036, + VK_BLEND_OP_PLUS_CLAMPED_ALPHA_EXT = 1000148037, + VK_BLEND_OP_PLUS_DARKER_EXT = 1000148038, + VK_BLEND_OP_MINUS_EXT = 1000148039, + VK_BLEND_OP_MINUS_CLAMPED_EXT = 1000148040, + VK_BLEND_OP_CONTRAST_EXT = 1000148041, + VK_BLEND_OP_INVERT_OVG_EXT = 1000148042, + VK_BLEND_OP_RED_EXT = 1000148043, + VK_BLEND_OP_GREEN_EXT = 1000148044, + VK_BLEND_OP_BLUE_EXT = 1000148045, + VK_BLEND_OP_BEGIN_RANGE = VK_BLEND_OP_ADD, + VK_BLEND_OP_END_RANGE = VK_BLEND_OP_MAX, + VK_BLEND_OP_RANGE_SIZE = (VK_BLEND_OP_MAX - VK_BLEND_OP_ADD + 1), + VK_BLEND_OP_MAX_ENUM = 0x7FFFFFFF +} VkBlendOp; + +typedef enum VkDynamicState { + VK_DYNAMIC_STATE_VIEWPORT = 0, + VK_DYNAMIC_STATE_SCISSOR = 1, + VK_DYNAMIC_STATE_LINE_WIDTH = 2, + VK_DYNAMIC_STATE_DEPTH_BIAS = 3, + VK_DYNAMIC_STATE_BLEND_CONSTANTS = 4, + VK_DYNAMIC_STATE_DEPTH_BOUNDS = 5, + VK_DYNAMIC_STATE_STENCIL_COMPARE_MASK = 6, + VK_DYNAMIC_STATE_STENCIL_WRITE_MASK = 7, + VK_DYNAMIC_STATE_STENCIL_REFERENCE = 8, + VK_DYNAMIC_STATE_VIEWPORT_W_SCALING_NV = 1000087000, + VK_DYNAMIC_STATE_DISCARD_RECTANGLE_EXT = 1000099000, + VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT = 1000143000, + VK_DYNAMIC_STATE_BEGIN_RANGE = VK_DYNAMIC_STATE_VIEWPORT, + VK_DYNAMIC_STATE_END_RANGE = VK_DYNAMIC_STATE_STENCIL_REFERENCE, + VK_DYNAMIC_STATE_RANGE_SIZE = (VK_DYNAMIC_STATE_STENCIL_REFERENCE - VK_DYNAMIC_STATE_VIEWPORT + 1), + VK_DYNAMIC_STATE_MAX_ENUM = 0x7FFFFFFF +} VkDynamicState; + +typedef enum VkFilter { + VK_FILTER_NEAREST = 0, + VK_FILTER_LINEAR = 1, + VK_FILTER_CUBIC_IMG = 1000015000, + VK_FILTER_BEGIN_RANGE = VK_FILTER_NEAREST, + VK_FILTER_END_RANGE = VK_FILTER_LINEAR, + VK_FILTER_RANGE_SIZE = (VK_FILTER_LINEAR - VK_FILTER_NEAREST + 1), + VK_FILTER_MAX_ENUM = 0x7FFFFFFF +} VkFilter; + +typedef enum VkSamplerMipmapMode { + VK_SAMPLER_MIPMAP_MODE_NEAREST = 0, + VK_SAMPLER_MIPMAP_MODE_LINEAR = 1, + VK_SAMPLER_MIPMAP_MODE_BEGIN_RANGE = VK_SAMPLER_MIPMAP_MODE_NEAREST, + VK_SAMPLER_MIPMAP_MODE_END_RANGE = VK_SAMPLER_MIPMAP_MODE_LINEAR, + VK_SAMPLER_MIPMAP_MODE_RANGE_SIZE = (VK_SAMPLER_MIPMAP_MODE_LINEAR - VK_SAMPLER_MIPMAP_MODE_NEAREST + 1), + VK_SAMPLER_MIPMAP_MODE_MAX_ENUM = 0x7FFFFFFF +} VkSamplerMipmapMode; + +typedef enum VkSamplerAddressMode { + VK_SAMPLER_ADDRESS_MODE_REPEAT = 0, + VK_SAMPLER_ADDRESS_MODE_MIRRORED_REPEAT = 1, + VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE = 2, + VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER = 3, + VK_SAMPLER_ADDRESS_MODE_MIRROR_CLAMP_TO_EDGE = 4, + VK_SAMPLER_ADDRESS_MODE_BEGIN_RANGE = VK_SAMPLER_ADDRESS_MODE_REPEAT, + VK_SAMPLER_ADDRESS_MODE_END_RANGE = VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER, + VK_SAMPLER_ADDRESS_MODE_RANGE_SIZE = (VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER - VK_SAMPLER_ADDRESS_MODE_REPEAT + 1), + VK_SAMPLER_ADDRESS_MODE_MAX_ENUM = 0x7FFFFFFF +} VkSamplerAddressMode; + +typedef enum VkBorderColor { + VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK = 0, + VK_BORDER_COLOR_INT_TRANSPARENT_BLACK = 1, + VK_BORDER_COLOR_FLOAT_OPAQUE_BLACK = 2, + VK_BORDER_COLOR_INT_OPAQUE_BLACK = 3, + VK_BORDER_COLOR_FLOAT_OPAQUE_WHITE = 4, + VK_BORDER_COLOR_INT_OPAQUE_WHITE = 5, + VK_BORDER_COLOR_BEGIN_RANGE = VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK, + VK_BORDER_COLOR_END_RANGE = VK_BORDER_COLOR_INT_OPAQUE_WHITE, + VK_BORDER_COLOR_RANGE_SIZE = (VK_BORDER_COLOR_INT_OPAQUE_WHITE - VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK + 1), + VK_BORDER_COLOR_MAX_ENUM = 0x7FFFFFFF +} VkBorderColor; + +typedef enum VkDescriptorType { + VK_DESCRIPTOR_TYPE_SAMPLER = 0, + VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER = 1, + VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE = 2, + VK_DESCRIPTOR_TYPE_STORAGE_IMAGE = 3, + VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER = 4, + VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER = 5, + VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER = 6, + VK_DESCRIPTOR_TYPE_STORAGE_BUFFER = 7, + VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC = 8, + VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC = 9, + VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT = 10, + VK_DESCRIPTOR_TYPE_BEGIN_RANGE = VK_DESCRIPTOR_TYPE_SAMPLER, + VK_DESCRIPTOR_TYPE_END_RANGE = VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT, + VK_DESCRIPTOR_TYPE_RANGE_SIZE = (VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT - VK_DESCRIPTOR_TYPE_SAMPLER + 1), + VK_DESCRIPTOR_TYPE_MAX_ENUM = 0x7FFFFFFF +} VkDescriptorType; + +typedef enum VkAttachmentLoadOp { + VK_ATTACHMENT_LOAD_OP_LOAD = 0, + VK_ATTACHMENT_LOAD_OP_CLEAR = 1, + VK_ATTACHMENT_LOAD_OP_DONT_CARE = 2, + VK_ATTACHMENT_LOAD_OP_BEGIN_RANGE = VK_ATTACHMENT_LOAD_OP_LOAD, + VK_ATTACHMENT_LOAD_OP_END_RANGE = VK_ATTACHMENT_LOAD_OP_DONT_CARE, + VK_ATTACHMENT_LOAD_OP_RANGE_SIZE = (VK_ATTACHMENT_LOAD_OP_DONT_CARE - VK_ATTACHMENT_LOAD_OP_LOAD + 1), + VK_ATTACHMENT_LOAD_OP_MAX_ENUM = 0x7FFFFFFF +} VkAttachmentLoadOp; + +typedef enum VkAttachmentStoreOp { + VK_ATTACHMENT_STORE_OP_STORE = 0, + VK_ATTACHMENT_STORE_OP_DONT_CARE = 1, + VK_ATTACHMENT_STORE_OP_BEGIN_RANGE = VK_ATTACHMENT_STORE_OP_STORE, + VK_ATTACHMENT_STORE_OP_END_RANGE = VK_ATTACHMENT_STORE_OP_DONT_CARE, + VK_ATTACHMENT_STORE_OP_RANGE_SIZE = (VK_ATTACHMENT_STORE_OP_DONT_CARE - VK_ATTACHMENT_STORE_OP_STORE + 1), + VK_ATTACHMENT_STORE_OP_MAX_ENUM = 0x7FFFFFFF +} VkAttachmentStoreOp; + +typedef enum VkPipelineBindPoint { + VK_PIPELINE_BIND_POINT_GRAPHICS = 0, + VK_PIPELINE_BIND_POINT_COMPUTE = 1, + VK_PIPELINE_BIND_POINT_BEGIN_RANGE = VK_PIPELINE_BIND_POINT_GRAPHICS, + VK_PIPELINE_BIND_POINT_END_RANGE = VK_PIPELINE_BIND_POINT_COMPUTE, + VK_PIPELINE_BIND_POINT_RANGE_SIZE = (VK_PIPELINE_BIND_POINT_COMPUTE - VK_PIPELINE_BIND_POINT_GRAPHICS + 1), + VK_PIPELINE_BIND_POINT_MAX_ENUM = 0x7FFFFFFF +} VkPipelineBindPoint; + +typedef enum VkCommandBufferLevel { + VK_COMMAND_BUFFER_LEVEL_PRIMARY = 0, + VK_COMMAND_BUFFER_LEVEL_SECONDARY = 1, + VK_COMMAND_BUFFER_LEVEL_BEGIN_RANGE = VK_COMMAND_BUFFER_LEVEL_PRIMARY, + VK_COMMAND_BUFFER_LEVEL_END_RANGE = VK_COMMAND_BUFFER_LEVEL_SECONDARY, + VK_COMMAND_BUFFER_LEVEL_RANGE_SIZE = (VK_COMMAND_BUFFER_LEVEL_SECONDARY - VK_COMMAND_BUFFER_LEVEL_PRIMARY + 1), + VK_COMMAND_BUFFER_LEVEL_MAX_ENUM = 0x7FFFFFFF +} VkCommandBufferLevel; + +typedef enum VkIndexType { + VK_INDEX_TYPE_UINT16 = 0, + VK_INDEX_TYPE_UINT32 = 1, + VK_INDEX_TYPE_BEGIN_RANGE = VK_INDEX_TYPE_UINT16, + VK_INDEX_TYPE_END_RANGE = VK_INDEX_TYPE_UINT32, + VK_INDEX_TYPE_RANGE_SIZE = (VK_INDEX_TYPE_UINT32 - VK_INDEX_TYPE_UINT16 + 1), + VK_INDEX_TYPE_MAX_ENUM = 0x7FFFFFFF +} VkIndexType; + +typedef enum VkSubpassContents { + VK_SUBPASS_CONTENTS_INLINE = 0, + VK_SUBPASS_CONTENTS_SECONDARY_COMMAND_BUFFERS = 1, + VK_SUBPASS_CONTENTS_BEGIN_RANGE = VK_SUBPASS_CONTENTS_INLINE, + VK_SUBPASS_CONTENTS_END_RANGE = VK_SUBPASS_CONTENTS_SECONDARY_COMMAND_BUFFERS, + VK_SUBPASS_CONTENTS_RANGE_SIZE = (VK_SUBPASS_CONTENTS_SECONDARY_COMMAND_BUFFERS - VK_SUBPASS_CONTENTS_INLINE + 1), + VK_SUBPASS_CONTENTS_MAX_ENUM = 0x7FFFFFFF +} VkSubpassContents; + +typedef enum VkObjectType { + VK_OBJECT_TYPE_UNKNOWN = 0, + VK_OBJECT_TYPE_INSTANCE = 1, + VK_OBJECT_TYPE_PHYSICAL_DEVICE = 2, + VK_OBJECT_TYPE_DEVICE = 3, + VK_OBJECT_TYPE_QUEUE = 4, + VK_OBJECT_TYPE_SEMAPHORE = 5, + VK_OBJECT_TYPE_COMMAND_BUFFER = 6, + VK_OBJECT_TYPE_FENCE = 7, + VK_OBJECT_TYPE_DEVICE_MEMORY = 8, + VK_OBJECT_TYPE_BUFFER = 9, + VK_OBJECT_TYPE_IMAGE = 10, + VK_OBJECT_TYPE_EVENT = 11, + VK_OBJECT_TYPE_QUERY_POOL = 12, + VK_OBJECT_TYPE_BUFFER_VIEW = 13, + VK_OBJECT_TYPE_IMAGE_VIEW = 14, + VK_OBJECT_TYPE_SHADER_MODULE = 15, + VK_OBJECT_TYPE_PIPELINE_CACHE = 16, + VK_OBJECT_TYPE_PIPELINE_LAYOUT = 17, + VK_OBJECT_TYPE_RENDER_PASS = 18, + VK_OBJECT_TYPE_PIPELINE = 19, + VK_OBJECT_TYPE_DESCRIPTOR_SET_LAYOUT = 20, + VK_OBJECT_TYPE_SAMPLER = 21, + VK_OBJECT_TYPE_DESCRIPTOR_POOL = 22, + VK_OBJECT_TYPE_DESCRIPTOR_SET = 23, + VK_OBJECT_TYPE_FRAMEBUFFER = 24, + VK_OBJECT_TYPE_COMMAND_POOL = 25, + VK_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION = 1000156000, + VK_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE = 1000085000, + VK_OBJECT_TYPE_SURFACE_KHR = 1000000000, + VK_OBJECT_TYPE_SWAPCHAIN_KHR = 1000001000, + VK_OBJECT_TYPE_DISPLAY_KHR = 1000002000, + VK_OBJECT_TYPE_DISPLAY_MODE_KHR = 1000002001, + VK_OBJECT_TYPE_DEBUG_REPORT_CALLBACK_EXT = 1000011000, + VK_OBJECT_TYPE_OBJECT_TABLE_NVX = 1000086000, + VK_OBJECT_TYPE_INDIRECT_COMMANDS_LAYOUT_NVX = 1000086001, + VK_OBJECT_TYPE_DEBUG_UTILS_MESSENGER_EXT = 1000128000, + VK_OBJECT_TYPE_VALIDATION_CACHE_EXT = 1000160000, + VK_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_KHR = VK_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE, + VK_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION_KHR = VK_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION, + VK_OBJECT_TYPE_BEGIN_RANGE = VK_OBJECT_TYPE_UNKNOWN, + VK_OBJECT_TYPE_END_RANGE = VK_OBJECT_TYPE_COMMAND_POOL, + VK_OBJECT_TYPE_RANGE_SIZE = (VK_OBJECT_TYPE_COMMAND_POOL - VK_OBJECT_TYPE_UNKNOWN + 1), + VK_OBJECT_TYPE_MAX_ENUM = 0x7FFFFFFF +} VkObjectType; + +typedef VkFlags VkInstanceCreateFlags; + +typedef enum VkFormatFeatureFlagBits { + VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT = 0x00000001, + VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT = 0x00000002, + VK_FORMAT_FEATURE_STORAGE_IMAGE_ATOMIC_BIT = 0x00000004, + VK_FORMAT_FEATURE_UNIFORM_TEXEL_BUFFER_BIT = 0x00000008, + VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_BIT = 0x00000010, + VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_ATOMIC_BIT = 0x00000020, + VK_FORMAT_FEATURE_VERTEX_BUFFER_BIT = 0x00000040, + VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT = 0x00000080, + VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BLEND_BIT = 0x00000100, + VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT = 0x00000200, + VK_FORMAT_FEATURE_BLIT_SRC_BIT = 0x00000400, + VK_FORMAT_FEATURE_BLIT_DST_BIT = 0x00000800, + VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT = 0x00001000, + VK_FORMAT_FEATURE_TRANSFER_SRC_BIT = 0x00004000, + VK_FORMAT_FEATURE_TRANSFER_DST_BIT = 0x00008000, + VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT = 0x00020000, + VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_LINEAR_FILTER_BIT = 0x00040000, + VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_SEPARATE_RECONSTRUCTION_FILTER_BIT = 0x00080000, + VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_BIT = 0x00100000, + VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_FORCEABLE_BIT = 0x00200000, + VK_FORMAT_FEATURE_DISJOINT_BIT = 0x00400000, + VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT = 0x00800000, + VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG = 0x00002000, + VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_MINMAX_BIT_EXT = 0x00010000, + VK_FORMAT_FEATURE_TRANSFER_SRC_BIT_KHR = VK_FORMAT_FEATURE_TRANSFER_SRC_BIT, + VK_FORMAT_FEATURE_TRANSFER_DST_BIT_KHR = VK_FORMAT_FEATURE_TRANSFER_DST_BIT, + VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT_KHR = VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT, + VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_LINEAR_FILTER_BIT_KHR = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_LINEAR_FILTER_BIT, + VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_SEPARATE_RECONSTRUCTION_FILTER_BIT_KHR = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_SEPARATE_RECONSTRUCTION_FILTER_BIT, + VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_BIT_KHR = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_BIT, + VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_FORCEABLE_BIT_KHR = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_FORCEABLE_BIT, + VK_FORMAT_FEATURE_DISJOINT_BIT_KHR = VK_FORMAT_FEATURE_DISJOINT_BIT, + VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT_KHR = VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT, + VK_FORMAT_FEATURE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkFormatFeatureFlagBits; +typedef VkFlags VkFormatFeatureFlags; + +typedef enum VkImageUsageFlagBits { + VK_IMAGE_USAGE_TRANSFER_SRC_BIT = 0x00000001, + VK_IMAGE_USAGE_TRANSFER_DST_BIT = 0x00000002, + VK_IMAGE_USAGE_SAMPLED_BIT = 0x00000004, + VK_IMAGE_USAGE_STORAGE_BIT = 0x00000008, + VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT = 0x00000010, + VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT = 0x00000020, + VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT = 0x00000040, + VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT = 0x00000080, + VK_IMAGE_USAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkImageUsageFlagBits; +typedef VkFlags VkImageUsageFlags; + +typedef enum VkImageCreateFlagBits { + VK_IMAGE_CREATE_SPARSE_BINDING_BIT = 0x00000001, + VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT = 0x00000002, + VK_IMAGE_CREATE_SPARSE_ALIASED_BIT = 0x00000004, + VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT = 0x00000008, + VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT = 0x00000010, + VK_IMAGE_CREATE_ALIAS_BIT = 0x00000400, + VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT = 0x00000040, + VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT = 0x00000020, + VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT = 0x00000080, + VK_IMAGE_CREATE_EXTENDED_USAGE_BIT = 0x00000100, + VK_IMAGE_CREATE_PROTECTED_BIT = 0x00000800, + VK_IMAGE_CREATE_DISJOINT_BIT = 0x00000200, + VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT = 0x00001000, + VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT_KHR = VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT, + VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT_KHR = VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT, + VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT_KHR = VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT, + VK_IMAGE_CREATE_EXTENDED_USAGE_BIT_KHR = VK_IMAGE_CREATE_EXTENDED_USAGE_BIT, + VK_IMAGE_CREATE_DISJOINT_BIT_KHR = VK_IMAGE_CREATE_DISJOINT_BIT, + VK_IMAGE_CREATE_ALIAS_BIT_KHR = VK_IMAGE_CREATE_ALIAS_BIT, + VK_IMAGE_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkImageCreateFlagBits; +typedef VkFlags VkImageCreateFlags; + +typedef enum VkSampleCountFlagBits { + VK_SAMPLE_COUNT_1_BIT = 0x00000001, + VK_SAMPLE_COUNT_2_BIT = 0x00000002, + VK_SAMPLE_COUNT_4_BIT = 0x00000004, + VK_SAMPLE_COUNT_8_BIT = 0x00000008, + VK_SAMPLE_COUNT_16_BIT = 0x00000010, + VK_SAMPLE_COUNT_32_BIT = 0x00000020, + VK_SAMPLE_COUNT_64_BIT = 0x00000040, + VK_SAMPLE_COUNT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkSampleCountFlagBits; +typedef VkFlags VkSampleCountFlags; + +typedef enum VkQueueFlagBits { + VK_QUEUE_GRAPHICS_BIT = 0x00000001, + VK_QUEUE_COMPUTE_BIT = 0x00000002, + VK_QUEUE_TRANSFER_BIT = 0x00000004, + VK_QUEUE_SPARSE_BINDING_BIT = 0x00000008, + VK_QUEUE_PROTECTED_BIT = 0x00000010, + VK_QUEUE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkQueueFlagBits; +typedef VkFlags VkQueueFlags; + +typedef enum VkMemoryPropertyFlagBits { + VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT = 0x00000001, + VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT = 0x00000002, + VK_MEMORY_PROPERTY_HOST_COHERENT_BIT = 0x00000004, + VK_MEMORY_PROPERTY_HOST_CACHED_BIT = 0x00000008, + VK_MEMORY_PROPERTY_LAZILY_ALLOCATED_BIT = 0x00000010, + VK_MEMORY_PROPERTY_PROTECTED_BIT = 0x00000020, + VK_MEMORY_PROPERTY_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkMemoryPropertyFlagBits; +typedef VkFlags VkMemoryPropertyFlags; + +typedef enum VkMemoryHeapFlagBits { + VK_MEMORY_HEAP_DEVICE_LOCAL_BIT = 0x00000001, + VK_MEMORY_HEAP_MULTI_INSTANCE_BIT = 0x00000002, + VK_MEMORY_HEAP_MULTI_INSTANCE_BIT_KHR = VK_MEMORY_HEAP_MULTI_INSTANCE_BIT, + VK_MEMORY_HEAP_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkMemoryHeapFlagBits; +typedef VkFlags VkMemoryHeapFlags; +typedef VkFlags VkDeviceCreateFlags; + +typedef enum VkDeviceQueueCreateFlagBits { + VK_DEVICE_QUEUE_CREATE_PROTECTED_BIT = 0x00000001, + VK_DEVICE_QUEUE_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkDeviceQueueCreateFlagBits; +typedef VkFlags VkDeviceQueueCreateFlags; + +typedef enum VkPipelineStageFlagBits { + VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT = 0x00000001, + VK_PIPELINE_STAGE_DRAW_INDIRECT_BIT = 0x00000002, + VK_PIPELINE_STAGE_VERTEX_INPUT_BIT = 0x00000004, + VK_PIPELINE_STAGE_VERTEX_SHADER_BIT = 0x00000008, + VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT = 0x00000010, + VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT = 0x00000020, + VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT = 0x00000040, + VK_PIPELINE_STAGE_FRAGMENT_SHADER_BIT = 0x00000080, + VK_PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT = 0x00000100, + VK_PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT = 0x00000200, + VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT = 0x00000400, + VK_PIPELINE_STAGE_COMPUTE_SHADER_BIT = 0x00000800, + VK_PIPELINE_STAGE_TRANSFER_BIT = 0x00001000, + VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT = 0x00002000, + VK_PIPELINE_STAGE_HOST_BIT = 0x00004000, + VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT = 0x00008000, + VK_PIPELINE_STAGE_ALL_COMMANDS_BIT = 0x00010000, + VK_PIPELINE_STAGE_COMMAND_PROCESS_BIT_NVX = 0x00020000, + VK_PIPELINE_STAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkPipelineStageFlagBits; +typedef VkFlags VkPipelineStageFlags; +typedef VkFlags VkMemoryMapFlags; + +typedef enum VkImageAspectFlagBits { + VK_IMAGE_ASPECT_COLOR_BIT = 0x00000001, + VK_IMAGE_ASPECT_DEPTH_BIT = 0x00000002, + VK_IMAGE_ASPECT_STENCIL_BIT = 0x00000004, + VK_IMAGE_ASPECT_METADATA_BIT = 0x00000008, + VK_IMAGE_ASPECT_PLANE_0_BIT = 0x00000010, + VK_IMAGE_ASPECT_PLANE_1_BIT = 0x00000020, + VK_IMAGE_ASPECT_PLANE_2_BIT = 0x00000040, + VK_IMAGE_ASPECT_PLANE_0_BIT_KHR = VK_IMAGE_ASPECT_PLANE_0_BIT, + VK_IMAGE_ASPECT_PLANE_1_BIT_KHR = VK_IMAGE_ASPECT_PLANE_1_BIT, + VK_IMAGE_ASPECT_PLANE_2_BIT_KHR = VK_IMAGE_ASPECT_PLANE_2_BIT, + VK_IMAGE_ASPECT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkImageAspectFlagBits; +typedef VkFlags VkImageAspectFlags; + +typedef enum VkSparseImageFormatFlagBits { + VK_SPARSE_IMAGE_FORMAT_SINGLE_MIPTAIL_BIT = 0x00000001, + VK_SPARSE_IMAGE_FORMAT_ALIGNED_MIP_SIZE_BIT = 0x00000002, + VK_SPARSE_IMAGE_FORMAT_NONSTANDARD_BLOCK_SIZE_BIT = 0x00000004, + VK_SPARSE_IMAGE_FORMAT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkSparseImageFormatFlagBits; +typedef VkFlags VkSparseImageFormatFlags; + +typedef enum VkSparseMemoryBindFlagBits { + VK_SPARSE_MEMORY_BIND_METADATA_BIT = 0x00000001, + VK_SPARSE_MEMORY_BIND_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkSparseMemoryBindFlagBits; +typedef VkFlags VkSparseMemoryBindFlags; + +typedef enum VkFenceCreateFlagBits { + VK_FENCE_CREATE_SIGNALED_BIT = 0x00000001, + VK_FENCE_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkFenceCreateFlagBits; +typedef VkFlags VkFenceCreateFlags; +typedef VkFlags VkSemaphoreCreateFlags; +typedef VkFlags VkEventCreateFlags; +typedef VkFlags VkQueryPoolCreateFlags; + +typedef enum VkQueryPipelineStatisticFlagBits { + VK_QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_VERTICES_BIT = 0x00000001, + VK_QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_PRIMITIVES_BIT = 0x00000002, + VK_QUERY_PIPELINE_STATISTIC_VERTEX_SHADER_INVOCATIONS_BIT = 0x00000004, + VK_QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_INVOCATIONS_BIT = 0x00000008, + VK_QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_PRIMITIVES_BIT = 0x00000010, + VK_QUERY_PIPELINE_STATISTIC_CLIPPING_INVOCATIONS_BIT = 0x00000020, + VK_QUERY_PIPELINE_STATISTIC_CLIPPING_PRIMITIVES_BIT = 0x00000040, + VK_QUERY_PIPELINE_STATISTIC_FRAGMENT_SHADER_INVOCATIONS_BIT = 0x00000080, + VK_QUERY_PIPELINE_STATISTIC_TESSELLATION_CONTROL_SHADER_PATCHES_BIT = 0x00000100, + VK_QUERY_PIPELINE_STATISTIC_TESSELLATION_EVALUATION_SHADER_INVOCATIONS_BIT = 0x00000200, + VK_QUERY_PIPELINE_STATISTIC_COMPUTE_SHADER_INVOCATIONS_BIT = 0x00000400, + VK_QUERY_PIPELINE_STATISTIC_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkQueryPipelineStatisticFlagBits; +typedef VkFlags VkQueryPipelineStatisticFlags; + +typedef enum VkQueryResultFlagBits { + VK_QUERY_RESULT_64_BIT = 0x00000001, + VK_QUERY_RESULT_WAIT_BIT = 0x00000002, + VK_QUERY_RESULT_WITH_AVAILABILITY_BIT = 0x00000004, + VK_QUERY_RESULT_PARTIAL_BIT = 0x00000008, + VK_QUERY_RESULT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkQueryResultFlagBits; +typedef VkFlags VkQueryResultFlags; + +typedef enum VkBufferCreateFlagBits { + VK_BUFFER_CREATE_SPARSE_BINDING_BIT = 0x00000001, + VK_BUFFER_CREATE_SPARSE_RESIDENCY_BIT = 0x00000002, + VK_BUFFER_CREATE_SPARSE_ALIASED_BIT = 0x00000004, + VK_BUFFER_CREATE_PROTECTED_BIT = 0x00000008, + VK_BUFFER_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkBufferCreateFlagBits; +typedef VkFlags VkBufferCreateFlags; + +typedef enum VkBufferUsageFlagBits { + VK_BUFFER_USAGE_TRANSFER_SRC_BIT = 0x00000001, + VK_BUFFER_USAGE_TRANSFER_DST_BIT = 0x00000002, + VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT = 0x00000004, + VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT = 0x00000008, + VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT = 0x00000010, + VK_BUFFER_USAGE_STORAGE_BUFFER_BIT = 0x00000020, + VK_BUFFER_USAGE_INDEX_BUFFER_BIT = 0x00000040, + VK_BUFFER_USAGE_VERTEX_BUFFER_BIT = 0x00000080, + VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT = 0x00000100, + VK_BUFFER_USAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkBufferUsageFlagBits; +typedef VkFlags VkBufferUsageFlags; +typedef VkFlags VkBufferViewCreateFlags; +typedef VkFlags VkImageViewCreateFlags; +typedef VkFlags VkShaderModuleCreateFlags; +typedef VkFlags VkPipelineCacheCreateFlags; + +typedef enum VkPipelineCreateFlagBits { + VK_PIPELINE_CREATE_DISABLE_OPTIMIZATION_BIT = 0x00000001, + VK_PIPELINE_CREATE_ALLOW_DERIVATIVES_BIT = 0x00000002, + VK_PIPELINE_CREATE_DERIVATIVE_BIT = 0x00000004, + VK_PIPELINE_CREATE_VIEW_INDEX_FROM_DEVICE_INDEX_BIT = 0x00000008, + VK_PIPELINE_CREATE_DISPATCH_BASE = 0x00000010, + VK_PIPELINE_CREATE_VIEW_INDEX_FROM_DEVICE_INDEX_BIT_KHR = VK_PIPELINE_CREATE_VIEW_INDEX_FROM_DEVICE_INDEX_BIT, + VK_PIPELINE_CREATE_DISPATCH_BASE_KHR = VK_PIPELINE_CREATE_DISPATCH_BASE, + VK_PIPELINE_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkPipelineCreateFlagBits; +typedef VkFlags VkPipelineCreateFlags; +typedef VkFlags VkPipelineShaderStageCreateFlags; + +typedef enum VkShaderStageFlagBits { + VK_SHADER_STAGE_VERTEX_BIT = 0x00000001, + VK_SHADER_STAGE_TESSELLATION_CONTROL_BIT = 0x00000002, + VK_SHADER_STAGE_TESSELLATION_EVALUATION_BIT = 0x00000004, + VK_SHADER_STAGE_GEOMETRY_BIT = 0x00000008, + VK_SHADER_STAGE_FRAGMENT_BIT = 0x00000010, + VK_SHADER_STAGE_COMPUTE_BIT = 0x00000020, + VK_SHADER_STAGE_ALL_GRAPHICS = 0x0000001F, + VK_SHADER_STAGE_ALL = 0x7FFFFFFF, + VK_SHADER_STAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkShaderStageFlagBits; +typedef VkFlags VkPipelineVertexInputStateCreateFlags; +typedef VkFlags VkPipelineInputAssemblyStateCreateFlags; +typedef VkFlags VkPipelineTessellationStateCreateFlags; +typedef VkFlags VkPipelineViewportStateCreateFlags; +typedef VkFlags VkPipelineRasterizationStateCreateFlags; + +typedef enum VkCullModeFlagBits { + VK_CULL_MODE_NONE = 0, + VK_CULL_MODE_FRONT_BIT = 0x00000001, + VK_CULL_MODE_BACK_BIT = 0x00000002, + VK_CULL_MODE_FRONT_AND_BACK = 0x00000003, + VK_CULL_MODE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkCullModeFlagBits; +typedef VkFlags VkCullModeFlags; +typedef VkFlags VkPipelineMultisampleStateCreateFlags; +typedef VkFlags VkPipelineDepthStencilStateCreateFlags; +typedef VkFlags VkPipelineColorBlendStateCreateFlags; + +typedef enum VkColorComponentFlagBits { + VK_COLOR_COMPONENT_R_BIT = 0x00000001, + VK_COLOR_COMPONENT_G_BIT = 0x00000002, + VK_COLOR_COMPONENT_B_BIT = 0x00000004, + VK_COLOR_COMPONENT_A_BIT = 0x00000008, + VK_COLOR_COMPONENT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkColorComponentFlagBits; +typedef VkFlags VkColorComponentFlags; +typedef VkFlags VkPipelineDynamicStateCreateFlags; +typedef VkFlags VkPipelineLayoutCreateFlags; +typedef VkFlags VkShaderStageFlags; +typedef VkFlags VkSamplerCreateFlags; + +typedef enum VkDescriptorSetLayoutCreateFlagBits { + VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR = 0x00000001, + VK_DESCRIPTOR_SET_LAYOUT_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkDescriptorSetLayoutCreateFlagBits; +typedef VkFlags VkDescriptorSetLayoutCreateFlags; + +typedef enum VkDescriptorPoolCreateFlagBits { + VK_DESCRIPTOR_POOL_CREATE_FREE_DESCRIPTOR_SET_BIT = 0x00000001, + VK_DESCRIPTOR_POOL_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkDescriptorPoolCreateFlagBits; +typedef VkFlags VkDescriptorPoolCreateFlags; +typedef VkFlags VkDescriptorPoolResetFlags; +typedef VkFlags VkFramebufferCreateFlags; +typedef VkFlags VkRenderPassCreateFlags; + +typedef enum VkAttachmentDescriptionFlagBits { + VK_ATTACHMENT_DESCRIPTION_MAY_ALIAS_BIT = 0x00000001, + VK_ATTACHMENT_DESCRIPTION_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkAttachmentDescriptionFlagBits; +typedef VkFlags VkAttachmentDescriptionFlags; + +typedef enum VkSubpassDescriptionFlagBits { + VK_SUBPASS_DESCRIPTION_PER_VIEW_ATTRIBUTES_BIT_NVX = 0x00000001, + VK_SUBPASS_DESCRIPTION_PER_VIEW_POSITION_X_ONLY_BIT_NVX = 0x00000002, + VK_SUBPASS_DESCRIPTION_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkSubpassDescriptionFlagBits; +typedef VkFlags VkSubpassDescriptionFlags; + +typedef enum VkAccessFlagBits { + VK_ACCESS_INDIRECT_COMMAND_READ_BIT = 0x00000001, + VK_ACCESS_INDEX_READ_BIT = 0x00000002, + VK_ACCESS_VERTEX_ATTRIBUTE_READ_BIT = 0x00000004, + VK_ACCESS_UNIFORM_READ_BIT = 0x00000008, + VK_ACCESS_INPUT_ATTACHMENT_READ_BIT = 0x00000010, + VK_ACCESS_SHADER_READ_BIT = 0x00000020, + VK_ACCESS_SHADER_WRITE_BIT = 0x00000040, + VK_ACCESS_COLOR_ATTACHMENT_READ_BIT = 0x00000080, + VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT = 0x00000100, + VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_READ_BIT = 0x00000200, + VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT = 0x00000400, + VK_ACCESS_TRANSFER_READ_BIT = 0x00000800, + VK_ACCESS_TRANSFER_WRITE_BIT = 0x00001000, + VK_ACCESS_HOST_READ_BIT = 0x00002000, + VK_ACCESS_HOST_WRITE_BIT = 0x00004000, + VK_ACCESS_MEMORY_READ_BIT = 0x00008000, + VK_ACCESS_MEMORY_WRITE_BIT = 0x00010000, + VK_ACCESS_COMMAND_PROCESS_READ_BIT_NVX = 0x00020000, + VK_ACCESS_COMMAND_PROCESS_WRITE_BIT_NVX = 0x00040000, + VK_ACCESS_COLOR_ATTACHMENT_READ_NONCOHERENT_BIT_EXT = 0x00080000, + VK_ACCESS_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkAccessFlagBits; +typedef VkFlags VkAccessFlags; + +typedef enum VkDependencyFlagBits { + VK_DEPENDENCY_BY_REGION_BIT = 0x00000001, + VK_DEPENDENCY_DEVICE_GROUP_BIT = 0x00000004, + VK_DEPENDENCY_VIEW_LOCAL_BIT = 0x00000002, + VK_DEPENDENCY_VIEW_LOCAL_BIT_KHR = VK_DEPENDENCY_VIEW_LOCAL_BIT, + VK_DEPENDENCY_DEVICE_GROUP_BIT_KHR = VK_DEPENDENCY_DEVICE_GROUP_BIT, + VK_DEPENDENCY_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkDependencyFlagBits; +typedef VkFlags VkDependencyFlags; + +typedef enum VkCommandPoolCreateFlagBits { + VK_COMMAND_POOL_CREATE_TRANSIENT_BIT = 0x00000001, + VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT = 0x00000002, + VK_COMMAND_POOL_CREATE_PROTECTED_BIT = 0x00000004, + VK_COMMAND_POOL_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkCommandPoolCreateFlagBits; +typedef VkFlags VkCommandPoolCreateFlags; + +typedef enum VkCommandPoolResetFlagBits { + VK_COMMAND_POOL_RESET_RELEASE_RESOURCES_BIT = 0x00000001, + VK_COMMAND_POOL_RESET_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkCommandPoolResetFlagBits; +typedef VkFlags VkCommandPoolResetFlags; + +typedef enum VkCommandBufferUsageFlagBits { + VK_COMMAND_BUFFER_USAGE_ONE_TIME_SUBMIT_BIT = 0x00000001, + VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT = 0x00000002, + VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT = 0x00000004, + VK_COMMAND_BUFFER_USAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkCommandBufferUsageFlagBits; +typedef VkFlags VkCommandBufferUsageFlags; + +typedef enum VkQueryControlFlagBits { + VK_QUERY_CONTROL_PRECISE_BIT = 0x00000001, + VK_QUERY_CONTROL_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkQueryControlFlagBits; +typedef VkFlags VkQueryControlFlags; + +typedef enum VkCommandBufferResetFlagBits { + VK_COMMAND_BUFFER_RESET_RELEASE_RESOURCES_BIT = 0x00000001, + VK_COMMAND_BUFFER_RESET_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkCommandBufferResetFlagBits; +typedef VkFlags VkCommandBufferResetFlags; + +typedef enum VkStencilFaceFlagBits { + VK_STENCIL_FACE_FRONT_BIT = 0x00000001, + VK_STENCIL_FACE_BACK_BIT = 0x00000002, + VK_STENCIL_FRONT_AND_BACK = 0x00000003, + VK_STENCIL_FACE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkStencilFaceFlagBits; +typedef VkFlags VkStencilFaceFlags; + +typedef struct VkApplicationInfo { + VkStructureType sType; + const void* pNext; + const char* pApplicationName; + uint32_t applicationVersion; + const char* pEngineName; + uint32_t engineVersion; + uint32_t apiVersion; +} VkApplicationInfo; + +typedef struct VkInstanceCreateInfo { + VkStructureType sType; + const void* pNext; + VkInstanceCreateFlags flags; + const VkApplicationInfo* pApplicationInfo; + uint32_t enabledLayerCount; + const char* const* ppEnabledLayerNames; + uint32_t enabledExtensionCount; + const char* const* ppEnabledExtensionNames; +} VkInstanceCreateInfo; + +typedef void* (VKAPI_PTR *PFN_vkAllocationFunction)( + void* pUserData, + size_t size, + size_t alignment, + VkSystemAllocationScope allocationScope); + +typedef void* (VKAPI_PTR *PFN_vkReallocationFunction)( + void* pUserData, + void* pOriginal, + size_t size, + size_t alignment, + VkSystemAllocationScope allocationScope); + +typedef void (VKAPI_PTR *PFN_vkFreeFunction)( + void* pUserData, + void* pMemory); + +typedef void (VKAPI_PTR *PFN_vkInternalAllocationNotification)( + void* pUserData, + size_t size, + VkInternalAllocationType allocationType, + VkSystemAllocationScope allocationScope); + +typedef void (VKAPI_PTR *PFN_vkInternalFreeNotification)( + void* pUserData, + size_t size, + VkInternalAllocationType allocationType, + VkSystemAllocationScope allocationScope); + +typedef struct VkAllocationCallbacks { + void* pUserData; + PFN_vkAllocationFunction pfnAllocation; + PFN_vkReallocationFunction pfnReallocation; + PFN_vkFreeFunction pfnFree; + PFN_vkInternalAllocationNotification pfnInternalAllocation; + PFN_vkInternalFreeNotification pfnInternalFree; +} VkAllocationCallbacks; + +typedef struct VkPhysicalDeviceFeatures { + VkBool32 robustBufferAccess; + VkBool32 fullDrawIndexUint32; + VkBool32 imageCubeArray; + VkBool32 independentBlend; + VkBool32 geometryShader; + VkBool32 tessellationShader; + VkBool32 sampleRateShading; + VkBool32 dualSrcBlend; + VkBool32 logicOp; + VkBool32 multiDrawIndirect; + VkBool32 drawIndirectFirstInstance; + VkBool32 depthClamp; + VkBool32 depthBiasClamp; + VkBool32 fillModeNonSolid; + VkBool32 depthBounds; + VkBool32 wideLines; + VkBool32 largePoints; + VkBool32 alphaToOne; + VkBool32 multiViewport; + VkBool32 samplerAnisotropy; + VkBool32 textureCompressionETC2; + VkBool32 textureCompressionASTC_LDR; + VkBool32 textureCompressionBC; + VkBool32 occlusionQueryPrecise; + VkBool32 pipelineStatisticsQuery; + VkBool32 vertexPipelineStoresAndAtomics; + VkBool32 fragmentStoresAndAtomics; + VkBool32 shaderTessellationAndGeometryPointSize; + VkBool32 shaderImageGatherExtended; + VkBool32 shaderStorageImageExtendedFormats; + VkBool32 shaderStorageImageMultisample; + VkBool32 shaderStorageImageReadWithoutFormat; + VkBool32 shaderStorageImageWriteWithoutFormat; + VkBool32 shaderUniformBufferArrayDynamicIndexing; + VkBool32 shaderSampledImageArrayDynamicIndexing; + VkBool32 shaderStorageBufferArrayDynamicIndexing; + VkBool32 shaderStorageImageArrayDynamicIndexing; + VkBool32 shaderClipDistance; + VkBool32 shaderCullDistance; + VkBool32 shaderFloat64; + VkBool32 shaderInt64; + VkBool32 shaderInt16; + VkBool32 shaderResourceResidency; + VkBool32 shaderResourceMinLod; + VkBool32 sparseBinding; + VkBool32 sparseResidencyBuffer; + VkBool32 sparseResidencyImage2D; + VkBool32 sparseResidencyImage3D; + VkBool32 sparseResidency2Samples; + VkBool32 sparseResidency4Samples; + VkBool32 sparseResidency8Samples; + VkBool32 sparseResidency16Samples; + VkBool32 sparseResidencyAliased; + VkBool32 variableMultisampleRate; + VkBool32 inheritedQueries; +} VkPhysicalDeviceFeatures; + +typedef struct VkFormatProperties { + VkFormatFeatureFlags linearTilingFeatures; + VkFormatFeatureFlags optimalTilingFeatures; + VkFormatFeatureFlags bufferFeatures; +} VkFormatProperties; + +typedef struct VkExtent3D { + uint32_t width; + uint32_t height; + uint32_t depth; +} VkExtent3D; + +typedef struct VkImageFormatProperties { + VkExtent3D maxExtent; + uint32_t maxMipLevels; + uint32_t maxArrayLayers; + VkSampleCountFlags sampleCounts; + VkDeviceSize maxResourceSize; +} VkImageFormatProperties; + +typedef struct VkPhysicalDeviceLimits { + uint32_t maxImageDimension1D; + uint32_t maxImageDimension2D; + uint32_t maxImageDimension3D; + uint32_t maxImageDimensionCube; + uint32_t maxImageArrayLayers; + uint32_t maxTexelBufferElements; + uint32_t maxUniformBufferRange; + uint32_t maxStorageBufferRange; + uint32_t maxPushConstantsSize; + uint32_t maxMemoryAllocationCount; + uint32_t maxSamplerAllocationCount; + VkDeviceSize bufferImageGranularity; + VkDeviceSize sparseAddressSpaceSize; + uint32_t maxBoundDescriptorSets; + uint32_t maxPerStageDescriptorSamplers; + uint32_t maxPerStageDescriptorUniformBuffers; + uint32_t maxPerStageDescriptorStorageBuffers; + uint32_t maxPerStageDescriptorSampledImages; + uint32_t maxPerStageDescriptorStorageImages; + uint32_t maxPerStageDescriptorInputAttachments; + uint32_t maxPerStageResources; + uint32_t maxDescriptorSetSamplers; + uint32_t maxDescriptorSetUniformBuffers; + uint32_t maxDescriptorSetUniformBuffersDynamic; + uint32_t maxDescriptorSetStorageBuffers; + uint32_t maxDescriptorSetStorageBuffersDynamic; + uint32_t maxDescriptorSetSampledImages; + uint32_t maxDescriptorSetStorageImages; + uint32_t maxDescriptorSetInputAttachments; + uint32_t maxVertexInputAttributes; + uint32_t maxVertexInputBindings; + uint32_t maxVertexInputAttributeOffset; + uint32_t maxVertexInputBindingStride; + uint32_t maxVertexOutputComponents; + uint32_t maxTessellationGenerationLevel; + uint32_t maxTessellationPatchSize; + uint32_t maxTessellationControlPerVertexInputComponents; + uint32_t maxTessellationControlPerVertexOutputComponents; + uint32_t maxTessellationControlPerPatchOutputComponents; + uint32_t maxTessellationControlTotalOutputComponents; + uint32_t maxTessellationEvaluationInputComponents; + uint32_t maxTessellationEvaluationOutputComponents; + uint32_t maxGeometryShaderInvocations; + uint32_t maxGeometryInputComponents; + uint32_t maxGeometryOutputComponents; + uint32_t maxGeometryOutputVertices; + uint32_t maxGeometryTotalOutputComponents; + uint32_t maxFragmentInputComponents; + uint32_t maxFragmentOutputAttachments; + uint32_t maxFragmentDualSrcAttachments; + uint32_t maxFragmentCombinedOutputResources; + uint32_t maxComputeSharedMemorySize; + uint32_t maxComputeWorkGroupCount[3]; + uint32_t maxComputeWorkGroupInvocations; + uint32_t maxComputeWorkGroupSize[3]; + uint32_t subPixelPrecisionBits; + uint32_t subTexelPrecisionBits; + uint32_t mipmapPrecisionBits; + uint32_t maxDrawIndexedIndexValue; + uint32_t maxDrawIndirectCount; + float maxSamplerLodBias; + float maxSamplerAnisotropy; + uint32_t maxViewports; + uint32_t maxViewportDimensions[2]; + float viewportBoundsRange[2]; + uint32_t viewportSubPixelBits; + size_t minMemoryMapAlignment; + VkDeviceSize minTexelBufferOffsetAlignment; + VkDeviceSize minUniformBufferOffsetAlignment; + VkDeviceSize minStorageBufferOffsetAlignment; + int32_t minTexelOffset; + uint32_t maxTexelOffset; + int32_t minTexelGatherOffset; + uint32_t maxTexelGatherOffset; + float minInterpolationOffset; + float maxInterpolationOffset; + uint32_t subPixelInterpolationOffsetBits; + uint32_t maxFramebufferWidth; + uint32_t maxFramebufferHeight; + uint32_t maxFramebufferLayers; + VkSampleCountFlags framebufferColorSampleCounts; + VkSampleCountFlags framebufferDepthSampleCounts; + VkSampleCountFlags framebufferStencilSampleCounts; + VkSampleCountFlags framebufferNoAttachmentsSampleCounts; + uint32_t maxColorAttachments; + VkSampleCountFlags sampledImageColorSampleCounts; + VkSampleCountFlags sampledImageIntegerSampleCounts; + VkSampleCountFlags sampledImageDepthSampleCounts; + VkSampleCountFlags sampledImageStencilSampleCounts; + VkSampleCountFlags storageImageSampleCounts; + uint32_t maxSampleMaskWords; + VkBool32 timestampComputeAndGraphics; + float timestampPeriod; + uint32_t maxClipDistances; + uint32_t maxCullDistances; + uint32_t maxCombinedClipAndCullDistances; + uint32_t discreteQueuePriorities; + float pointSizeRange[2]; + float lineWidthRange[2]; + float pointSizeGranularity; + float lineWidthGranularity; + VkBool32 strictLines; + VkBool32 standardSampleLocations; + VkDeviceSize optimalBufferCopyOffsetAlignment; + VkDeviceSize optimalBufferCopyRowPitchAlignment; + VkDeviceSize nonCoherentAtomSize; +} VkPhysicalDeviceLimits; + +typedef struct VkPhysicalDeviceSparseProperties { + VkBool32 residencyStandard2DBlockShape; + VkBool32 residencyStandard2DMultisampleBlockShape; + VkBool32 residencyStandard3DBlockShape; + VkBool32 residencyAlignedMipSize; + VkBool32 residencyNonResidentStrict; +} VkPhysicalDeviceSparseProperties; + +typedef struct VkPhysicalDeviceProperties { + uint32_t apiVersion; + uint32_t driverVersion; + uint32_t vendorID; + uint32_t deviceID; + VkPhysicalDeviceType deviceType; + char deviceName[VK_MAX_PHYSICAL_DEVICE_NAME_SIZE]; + uint8_t pipelineCacheUUID[VK_UUID_SIZE]; + VkPhysicalDeviceLimits limits; + VkPhysicalDeviceSparseProperties sparseProperties; +} VkPhysicalDeviceProperties; + +typedef struct VkQueueFamilyProperties { + VkQueueFlags queueFlags; + uint32_t queueCount; + uint32_t timestampValidBits; + VkExtent3D minImageTransferGranularity; +} VkQueueFamilyProperties; + +typedef struct VkMemoryType { + VkMemoryPropertyFlags propertyFlags; + uint32_t heapIndex; +} VkMemoryType; + +typedef struct VkMemoryHeap { + VkDeviceSize size; + VkMemoryHeapFlags flags; +} VkMemoryHeap; + +typedef struct VkPhysicalDeviceMemoryProperties { + uint32_t memoryTypeCount; + VkMemoryType memoryTypes[VK_MAX_MEMORY_TYPES]; + uint32_t memoryHeapCount; + VkMemoryHeap memoryHeaps[VK_MAX_MEMORY_HEAPS]; +} VkPhysicalDeviceMemoryProperties; + +typedef void (VKAPI_PTR *PFN_vkVoidFunction)(void); +typedef struct VkDeviceQueueCreateInfo { + VkStructureType sType; + const void* pNext; + VkDeviceQueueCreateFlags flags; + uint32_t queueFamilyIndex; + uint32_t queueCount; + const float* pQueuePriorities; +} VkDeviceQueueCreateInfo; + +typedef struct VkDeviceCreateInfo { + VkStructureType sType; + const void* pNext; + VkDeviceCreateFlags flags; + uint32_t queueCreateInfoCount; + const VkDeviceQueueCreateInfo* pQueueCreateInfos; + uint32_t enabledLayerCount; + const char* const* ppEnabledLayerNames; + uint32_t enabledExtensionCount; + const char* const* ppEnabledExtensionNames; + const VkPhysicalDeviceFeatures* pEnabledFeatures; +} VkDeviceCreateInfo; + +typedef struct VkExtensionProperties { + char extensionName[VK_MAX_EXTENSION_NAME_SIZE]; + uint32_t specVersion; +} VkExtensionProperties; + +typedef struct VkLayerProperties { + char layerName[VK_MAX_EXTENSION_NAME_SIZE]; + uint32_t specVersion; + uint32_t implementationVersion; + char description[VK_MAX_DESCRIPTION_SIZE]; +} VkLayerProperties; + +typedef struct VkSubmitInfo { + VkStructureType sType; + const void* pNext; + uint32_t waitSemaphoreCount; + const VkSemaphore* pWaitSemaphores; + const VkPipelineStageFlags* pWaitDstStageMask; + uint32_t commandBufferCount; + const VkCommandBuffer* pCommandBuffers; + uint32_t signalSemaphoreCount; + const VkSemaphore* pSignalSemaphores; +} VkSubmitInfo; + +typedef struct VkMemoryAllocateInfo { + VkStructureType sType; + const void* pNext; + VkDeviceSize allocationSize; + uint32_t memoryTypeIndex; +} VkMemoryAllocateInfo; + +typedef struct VkMappedMemoryRange { + VkStructureType sType; + const void* pNext; + VkDeviceMemory memory; + VkDeviceSize offset; + VkDeviceSize size; +} VkMappedMemoryRange; + +typedef struct VkMemoryRequirements { + VkDeviceSize size; + VkDeviceSize alignment; + uint32_t memoryTypeBits; +} VkMemoryRequirements; + +typedef struct VkSparseImageFormatProperties { + VkImageAspectFlags aspectMask; + VkExtent3D imageGranularity; + VkSparseImageFormatFlags flags; +} VkSparseImageFormatProperties; + +typedef struct VkSparseImageMemoryRequirements { + VkSparseImageFormatProperties formatProperties; + uint32_t imageMipTailFirstLod; + VkDeviceSize imageMipTailSize; + VkDeviceSize imageMipTailOffset; + VkDeviceSize imageMipTailStride; +} VkSparseImageMemoryRequirements; + +typedef struct VkSparseMemoryBind { + VkDeviceSize resourceOffset; + VkDeviceSize size; + VkDeviceMemory memory; + VkDeviceSize memoryOffset; + VkSparseMemoryBindFlags flags; +} VkSparseMemoryBind; + +typedef struct VkSparseBufferMemoryBindInfo { + VkBuffer buffer; + uint32_t bindCount; + const VkSparseMemoryBind* pBinds; +} VkSparseBufferMemoryBindInfo; + +typedef struct VkSparseImageOpaqueMemoryBindInfo { + VkImage image; + uint32_t bindCount; + const VkSparseMemoryBind* pBinds; +} VkSparseImageOpaqueMemoryBindInfo; + +typedef struct VkImageSubresource { + VkImageAspectFlags aspectMask; + uint32_t mipLevel; + uint32_t arrayLayer; +} VkImageSubresource; + +typedef struct VkOffset3D { + int32_t x; + int32_t y; + int32_t z; +} VkOffset3D; + +typedef struct VkSparseImageMemoryBind { + VkImageSubresource subresource; + VkOffset3D offset; + VkExtent3D extent; + VkDeviceMemory memory; + VkDeviceSize memoryOffset; + VkSparseMemoryBindFlags flags; +} VkSparseImageMemoryBind; + +typedef struct VkSparseImageMemoryBindInfo { + VkImage image; + uint32_t bindCount; + const VkSparseImageMemoryBind* pBinds; +} VkSparseImageMemoryBindInfo; + +typedef struct VkBindSparseInfo { + VkStructureType sType; + const void* pNext; + uint32_t waitSemaphoreCount; + const VkSemaphore* pWaitSemaphores; + uint32_t bufferBindCount; + const VkSparseBufferMemoryBindInfo* pBufferBinds; + uint32_t imageOpaqueBindCount; + const VkSparseImageOpaqueMemoryBindInfo* pImageOpaqueBinds; + uint32_t imageBindCount; + const VkSparseImageMemoryBindInfo* pImageBinds; + uint32_t signalSemaphoreCount; + const VkSemaphore* pSignalSemaphores; +} VkBindSparseInfo; + +typedef struct VkFenceCreateInfo { + VkStructureType sType; + const void* pNext; + VkFenceCreateFlags flags; +} VkFenceCreateInfo; + +typedef struct VkSemaphoreCreateInfo { + VkStructureType sType; + const void* pNext; + VkSemaphoreCreateFlags flags; +} VkSemaphoreCreateInfo; + +typedef struct VkEventCreateInfo { + VkStructureType sType; + const void* pNext; + VkEventCreateFlags flags; +} VkEventCreateInfo; + +typedef struct VkQueryPoolCreateInfo { + VkStructureType sType; + const void* pNext; + VkQueryPoolCreateFlags flags; + VkQueryType queryType; + uint32_t queryCount; + VkQueryPipelineStatisticFlags pipelineStatistics; +} VkQueryPoolCreateInfo; + +typedef struct VkBufferCreateInfo { + VkStructureType sType; + const void* pNext; + VkBufferCreateFlags flags; + VkDeviceSize size; + VkBufferUsageFlags usage; + VkSharingMode sharingMode; + uint32_t queueFamilyIndexCount; + const uint32_t* pQueueFamilyIndices; +} VkBufferCreateInfo; + +typedef struct VkBufferViewCreateInfo { + VkStructureType sType; + const void* pNext; + VkBufferViewCreateFlags flags; + VkBuffer buffer; + VkFormat format; + VkDeviceSize offset; + VkDeviceSize range; +} VkBufferViewCreateInfo; + +typedef struct VkImageCreateInfo { + VkStructureType sType; + const void* pNext; + VkImageCreateFlags flags; + VkImageType imageType; + VkFormat format; + VkExtent3D extent; + uint32_t mipLevels; + uint32_t arrayLayers; + VkSampleCountFlagBits samples; + VkImageTiling tiling; + VkImageUsageFlags usage; + VkSharingMode sharingMode; + uint32_t queueFamilyIndexCount; + const uint32_t* pQueueFamilyIndices; + VkImageLayout initialLayout; +} VkImageCreateInfo; + +typedef struct VkSubresourceLayout { + VkDeviceSize offset; + VkDeviceSize size; + VkDeviceSize rowPitch; + VkDeviceSize arrayPitch; + VkDeviceSize depthPitch; +} VkSubresourceLayout; + +typedef struct VkComponentMapping { + VkComponentSwizzle r; + VkComponentSwizzle g; + VkComponentSwizzle b; + VkComponentSwizzle a; +} VkComponentMapping; + +typedef struct VkImageSubresourceRange { + VkImageAspectFlags aspectMask; + uint32_t baseMipLevel; + uint32_t levelCount; + uint32_t baseArrayLayer; + uint32_t layerCount; +} VkImageSubresourceRange; + +typedef struct VkImageViewCreateInfo { + VkStructureType sType; + const void* pNext; + VkImageViewCreateFlags flags; + VkImage image; + VkImageViewType viewType; + VkFormat format; + VkComponentMapping components; + VkImageSubresourceRange subresourceRange; +} VkImageViewCreateInfo; + +typedef struct VkShaderModuleCreateInfo { + VkStructureType sType; + const void* pNext; + VkShaderModuleCreateFlags flags; + size_t codeSize; + const uint32_t* pCode; +} VkShaderModuleCreateInfo; + +typedef struct VkPipelineCacheCreateInfo { + VkStructureType sType; + const void* pNext; + VkPipelineCacheCreateFlags flags; + size_t initialDataSize; + const void* pInitialData; +} VkPipelineCacheCreateInfo; + +typedef struct VkSpecializationMapEntry { + uint32_t constantID; + uint32_t offset; + size_t size; +} VkSpecializationMapEntry; + +typedef struct VkSpecializationInfo { + uint32_t mapEntryCount; + const VkSpecializationMapEntry* pMapEntries; + size_t dataSize; + const void* pData; +} VkSpecializationInfo; + +typedef struct VkPipelineShaderStageCreateInfo { + VkStructureType sType; + const void* pNext; + VkPipelineShaderStageCreateFlags flags; + VkShaderStageFlagBits stage; + VkShaderModule module; + const char* pName; + const VkSpecializationInfo* pSpecializationInfo; +} VkPipelineShaderStageCreateInfo; + +typedef struct VkVertexInputBindingDescription { + uint32_t binding; + uint32_t stride; + VkVertexInputRate inputRate; +} VkVertexInputBindingDescription; + +typedef struct VkVertexInputAttributeDescription { + uint32_t location; + uint32_t binding; + VkFormat format; + uint32_t offset; +} VkVertexInputAttributeDescription; + +typedef struct VkPipelineVertexInputStateCreateInfo { + VkStructureType sType; + const void* pNext; + VkPipelineVertexInputStateCreateFlags flags; + uint32_t vertexBindingDescriptionCount; + const VkVertexInputBindingDescription* pVertexBindingDescriptions; + uint32_t vertexAttributeDescriptionCount; + const VkVertexInputAttributeDescription* pVertexAttributeDescriptions; +} VkPipelineVertexInputStateCreateInfo; + +typedef struct VkPipelineInputAssemblyStateCreateInfo { + VkStructureType sType; + const void* pNext; + VkPipelineInputAssemblyStateCreateFlags flags; + VkPrimitiveTopology topology; + VkBool32 primitiveRestartEnable; +} VkPipelineInputAssemblyStateCreateInfo; + +typedef struct VkPipelineTessellationStateCreateInfo { + VkStructureType sType; + const void* pNext; + VkPipelineTessellationStateCreateFlags flags; + uint32_t patchControlPoints; +} VkPipelineTessellationStateCreateInfo; + +typedef struct VkViewport { + float x; + float y; + float width; + float height; + float minDepth; + float maxDepth; +} VkViewport; + +typedef struct VkOffset2D { + int32_t x; + int32_t y; +} VkOffset2D; + +typedef struct VkExtent2D { + uint32_t width; + uint32_t height; +} VkExtent2D; + +typedef struct VkRect2D { + VkOffset2D offset; + VkExtent2D extent; +} VkRect2D; + +typedef struct VkPipelineViewportStateCreateInfo { + VkStructureType sType; + const void* pNext; + VkPipelineViewportStateCreateFlags flags; + uint32_t viewportCount; + const VkViewport* pViewports; + uint32_t scissorCount; + const VkRect2D* pScissors; +} VkPipelineViewportStateCreateInfo; + +typedef struct VkPipelineRasterizationStateCreateInfo { + VkStructureType sType; + const void* pNext; + VkPipelineRasterizationStateCreateFlags flags; + VkBool32 depthClampEnable; + VkBool32 rasterizerDiscardEnable; + VkPolygonMode polygonMode; + VkCullModeFlags cullMode; + VkFrontFace frontFace; + VkBool32 depthBiasEnable; + float depthBiasConstantFactor; + float depthBiasClamp; + float depthBiasSlopeFactor; + float lineWidth; +} VkPipelineRasterizationStateCreateInfo; + +typedef struct VkPipelineMultisampleStateCreateInfo { + VkStructureType sType; + const void* pNext; + VkPipelineMultisampleStateCreateFlags flags; + VkSampleCountFlagBits rasterizationSamples; + VkBool32 sampleShadingEnable; + float minSampleShading; + const VkSampleMask* pSampleMask; + VkBool32 alphaToCoverageEnable; + VkBool32 alphaToOneEnable; +} VkPipelineMultisampleStateCreateInfo; + +typedef struct VkStencilOpState { + VkStencilOp failOp; + VkStencilOp passOp; + VkStencilOp depthFailOp; + VkCompareOp compareOp; + uint32_t compareMask; + uint32_t writeMask; + uint32_t reference; +} VkStencilOpState; + +typedef struct VkPipelineDepthStencilStateCreateInfo { + VkStructureType sType; + const void* pNext; + VkPipelineDepthStencilStateCreateFlags flags; + VkBool32 depthTestEnable; + VkBool32 depthWriteEnable; + VkCompareOp depthCompareOp; + VkBool32 depthBoundsTestEnable; + VkBool32 stencilTestEnable; + VkStencilOpState front; + VkStencilOpState back; + float minDepthBounds; + float maxDepthBounds; +} VkPipelineDepthStencilStateCreateInfo; + +typedef struct VkPipelineColorBlendAttachmentState { + VkBool32 blendEnable; + VkBlendFactor srcColorBlendFactor; + VkBlendFactor dstColorBlendFactor; + VkBlendOp colorBlendOp; + VkBlendFactor srcAlphaBlendFactor; + VkBlendFactor dstAlphaBlendFactor; + VkBlendOp alphaBlendOp; + VkColorComponentFlags colorWriteMask; +} VkPipelineColorBlendAttachmentState; + +typedef struct VkPipelineColorBlendStateCreateInfo { + VkStructureType sType; + const void* pNext; + VkPipelineColorBlendStateCreateFlags flags; + VkBool32 logicOpEnable; + VkLogicOp logicOp; + uint32_t attachmentCount; + const VkPipelineColorBlendAttachmentState* pAttachments; + float blendConstants[4]; +} VkPipelineColorBlendStateCreateInfo; + +typedef struct VkPipelineDynamicStateCreateInfo { + VkStructureType sType; + const void* pNext; + VkPipelineDynamicStateCreateFlags flags; + uint32_t dynamicStateCount; + const VkDynamicState* pDynamicStates; +} VkPipelineDynamicStateCreateInfo; + +typedef struct VkGraphicsPipelineCreateInfo { + VkStructureType sType; + const void* pNext; + VkPipelineCreateFlags flags; + uint32_t stageCount; + const VkPipelineShaderStageCreateInfo* pStages; + const VkPipelineVertexInputStateCreateInfo* pVertexInputState; + const VkPipelineInputAssemblyStateCreateInfo* pInputAssemblyState; + const VkPipelineTessellationStateCreateInfo* pTessellationState; + const VkPipelineViewportStateCreateInfo* pViewportState; + const VkPipelineRasterizationStateCreateInfo* pRasterizationState; + const VkPipelineMultisampleStateCreateInfo* pMultisampleState; + const VkPipelineDepthStencilStateCreateInfo* pDepthStencilState; + const VkPipelineColorBlendStateCreateInfo* pColorBlendState; + const VkPipelineDynamicStateCreateInfo* pDynamicState; + VkPipelineLayout layout; + VkRenderPass renderPass; + uint32_t subpass; + VkPipeline basePipelineHandle; + int32_t basePipelineIndex; +} VkGraphicsPipelineCreateInfo; + +typedef struct VkComputePipelineCreateInfo { + VkStructureType sType; + const void* pNext; + VkPipelineCreateFlags flags; + VkPipelineShaderStageCreateInfo stage; + VkPipelineLayout layout; + VkPipeline basePipelineHandle; + int32_t basePipelineIndex; +} VkComputePipelineCreateInfo; + +typedef struct VkPushConstantRange { + VkShaderStageFlags stageFlags; + uint32_t offset; + uint32_t size; +} VkPushConstantRange; + +typedef struct VkPipelineLayoutCreateInfo { + VkStructureType sType; + const void* pNext; + VkPipelineLayoutCreateFlags flags; + uint32_t setLayoutCount; + const VkDescriptorSetLayout* pSetLayouts; + uint32_t pushConstantRangeCount; + const VkPushConstantRange* pPushConstantRanges; +} VkPipelineLayoutCreateInfo; + +typedef struct VkSamplerCreateInfo { + VkStructureType sType; + const void* pNext; + VkSamplerCreateFlags flags; + VkFilter magFilter; + VkFilter minFilter; + VkSamplerMipmapMode mipmapMode; + VkSamplerAddressMode addressModeU; + VkSamplerAddressMode addressModeV; + VkSamplerAddressMode addressModeW; + float mipLodBias; + VkBool32 anisotropyEnable; + float maxAnisotropy; + VkBool32 compareEnable; + VkCompareOp compareOp; + float minLod; + float maxLod; + VkBorderColor borderColor; + VkBool32 unnormalizedCoordinates; +} VkSamplerCreateInfo; + +typedef struct VkDescriptorSetLayoutBinding { + uint32_t binding; + VkDescriptorType descriptorType; + uint32_t descriptorCount; + VkShaderStageFlags stageFlags; + const VkSampler* pImmutableSamplers; +} VkDescriptorSetLayoutBinding; + +typedef struct VkDescriptorSetLayoutCreateInfo { + VkStructureType sType; + const void* pNext; + VkDescriptorSetLayoutCreateFlags flags; + uint32_t bindingCount; + const VkDescriptorSetLayoutBinding* pBindings; +} VkDescriptorSetLayoutCreateInfo; + +typedef struct VkDescriptorPoolSize { + VkDescriptorType type; + uint32_t descriptorCount; +} VkDescriptorPoolSize; + +typedef struct VkDescriptorPoolCreateInfo { + VkStructureType sType; + const void* pNext; + VkDescriptorPoolCreateFlags flags; + uint32_t maxSets; + uint32_t poolSizeCount; + const VkDescriptorPoolSize* pPoolSizes; +} VkDescriptorPoolCreateInfo; + +typedef struct VkDescriptorSetAllocateInfo { + VkStructureType sType; + const void* pNext; + VkDescriptorPool descriptorPool; + uint32_t descriptorSetCount; + const VkDescriptorSetLayout* pSetLayouts; +} VkDescriptorSetAllocateInfo; + +typedef struct VkDescriptorImageInfo { + VkSampler sampler; + VkImageView imageView; + VkImageLayout imageLayout; +} VkDescriptorImageInfo; + +typedef struct VkDescriptorBufferInfo { + VkBuffer buffer; + VkDeviceSize offset; + VkDeviceSize range; +} VkDescriptorBufferInfo; + +typedef struct VkWriteDescriptorSet { + VkStructureType sType; + const void* pNext; + VkDescriptorSet dstSet; + uint32_t dstBinding; + uint32_t dstArrayElement; + uint32_t descriptorCount; + VkDescriptorType descriptorType; + const VkDescriptorImageInfo* pImageInfo; + const VkDescriptorBufferInfo* pBufferInfo; + const VkBufferView* pTexelBufferView; +} VkWriteDescriptorSet; + +typedef struct VkCopyDescriptorSet { + VkStructureType sType; + const void* pNext; + VkDescriptorSet srcSet; + uint32_t srcBinding; + uint32_t srcArrayElement; + VkDescriptorSet dstSet; + uint32_t dstBinding; + uint32_t dstArrayElement; + uint32_t descriptorCount; +} VkCopyDescriptorSet; + +typedef struct VkFramebufferCreateInfo { + VkStructureType sType; + const void* pNext; + VkFramebufferCreateFlags flags; + VkRenderPass renderPass; + uint32_t attachmentCount; + const VkImageView* pAttachments; + uint32_t width; + uint32_t height; + uint32_t layers; +} VkFramebufferCreateInfo; + +typedef struct VkAttachmentDescription { + VkAttachmentDescriptionFlags flags; + VkFormat format; + VkSampleCountFlagBits samples; + VkAttachmentLoadOp loadOp; + VkAttachmentStoreOp storeOp; + VkAttachmentLoadOp stencilLoadOp; + VkAttachmentStoreOp stencilStoreOp; + VkImageLayout initialLayout; + VkImageLayout finalLayout; +} VkAttachmentDescription; + +typedef struct VkAttachmentReference { + uint32_t attachment; + VkImageLayout layout; +} VkAttachmentReference; + +typedef struct VkSubpassDescription { + VkSubpassDescriptionFlags flags; + VkPipelineBindPoint pipelineBindPoint; + uint32_t inputAttachmentCount; + const VkAttachmentReference* pInputAttachments; + uint32_t colorAttachmentCount; + const VkAttachmentReference* pColorAttachments; + const VkAttachmentReference* pResolveAttachments; + const VkAttachmentReference* pDepthStencilAttachment; + uint32_t preserveAttachmentCount; + const uint32_t* pPreserveAttachments; +} VkSubpassDescription; + +typedef struct VkSubpassDependency { + uint32_t srcSubpass; + uint32_t dstSubpass; + VkPipelineStageFlags srcStageMask; + VkPipelineStageFlags dstStageMask; + VkAccessFlags srcAccessMask; + VkAccessFlags dstAccessMask; + VkDependencyFlags dependencyFlags; +} VkSubpassDependency; + +typedef struct VkRenderPassCreateInfo { + VkStructureType sType; + const void* pNext; + VkRenderPassCreateFlags flags; + uint32_t attachmentCount; + const VkAttachmentDescription* pAttachments; + uint32_t subpassCount; + const VkSubpassDescription* pSubpasses; + uint32_t dependencyCount; + const VkSubpassDependency* pDependencies; +} VkRenderPassCreateInfo; + +typedef struct VkCommandPoolCreateInfo { + VkStructureType sType; + const void* pNext; + VkCommandPoolCreateFlags flags; + uint32_t queueFamilyIndex; +} VkCommandPoolCreateInfo; + +typedef struct VkCommandBufferAllocateInfo { + VkStructureType sType; + const void* pNext; + VkCommandPool commandPool; + VkCommandBufferLevel level; + uint32_t commandBufferCount; +} VkCommandBufferAllocateInfo; + +typedef struct VkCommandBufferInheritanceInfo { + VkStructureType sType; + const void* pNext; + VkRenderPass renderPass; + uint32_t subpass; + VkFramebuffer framebuffer; + VkBool32 occlusionQueryEnable; + VkQueryControlFlags queryFlags; + VkQueryPipelineStatisticFlags pipelineStatistics; +} VkCommandBufferInheritanceInfo; + +typedef struct VkCommandBufferBeginInfo { + VkStructureType sType; + const void* pNext; + VkCommandBufferUsageFlags flags; + const VkCommandBufferInheritanceInfo* pInheritanceInfo; +} VkCommandBufferBeginInfo; + +typedef struct VkBufferCopy { + VkDeviceSize srcOffset; + VkDeviceSize dstOffset; + VkDeviceSize size; +} VkBufferCopy; + +typedef struct VkImageSubresourceLayers { + VkImageAspectFlags aspectMask; + uint32_t mipLevel; + uint32_t baseArrayLayer; + uint32_t layerCount; +} VkImageSubresourceLayers; + +typedef struct VkImageCopy { + VkImageSubresourceLayers srcSubresource; + VkOffset3D srcOffset; + VkImageSubresourceLayers dstSubresource; + VkOffset3D dstOffset; + VkExtent3D extent; +} VkImageCopy; + +typedef struct VkImageBlit { + VkImageSubresourceLayers srcSubresource; + VkOffset3D srcOffsets[2]; + VkImageSubresourceLayers dstSubresource; + VkOffset3D dstOffsets[2]; +} VkImageBlit; + +typedef struct VkBufferImageCopy { + VkDeviceSize bufferOffset; + uint32_t bufferRowLength; + uint32_t bufferImageHeight; + VkImageSubresourceLayers imageSubresource; + VkOffset3D imageOffset; + VkExtent3D imageExtent; +} VkBufferImageCopy; + +typedef union VkClearColorValue { + float float32[4]; + int32_t int32[4]; + uint32_t uint32[4]; +} VkClearColorValue; + +typedef struct VkClearDepthStencilValue { + float depth; + uint32_t stencil; +} VkClearDepthStencilValue; + +typedef union VkClearValue { + VkClearColorValue color; + VkClearDepthStencilValue depthStencil; +} VkClearValue; + +typedef struct VkClearAttachment { + VkImageAspectFlags aspectMask; + uint32_t colorAttachment; + VkClearValue clearValue; +} VkClearAttachment; + +typedef struct VkClearRect { + VkRect2D rect; + uint32_t baseArrayLayer; + uint32_t layerCount; +} VkClearRect; + +typedef struct VkImageResolve { + VkImageSubresourceLayers srcSubresource; + VkOffset3D srcOffset; + VkImageSubresourceLayers dstSubresource; + VkOffset3D dstOffset; + VkExtent3D extent; +} VkImageResolve; + +typedef struct VkMemoryBarrier { + VkStructureType sType; + const void* pNext; + VkAccessFlags srcAccessMask; + VkAccessFlags dstAccessMask; +} VkMemoryBarrier; + +typedef struct VkBufferMemoryBarrier { + VkStructureType sType; + const void* pNext; + VkAccessFlags srcAccessMask; + VkAccessFlags dstAccessMask; + uint32_t srcQueueFamilyIndex; + uint32_t dstQueueFamilyIndex; + VkBuffer buffer; + VkDeviceSize offset; + VkDeviceSize size; +} VkBufferMemoryBarrier; + +typedef struct VkImageMemoryBarrier { + VkStructureType sType; + const void* pNext; + VkAccessFlags srcAccessMask; + VkAccessFlags dstAccessMask; + VkImageLayout oldLayout; + VkImageLayout newLayout; + uint32_t srcQueueFamilyIndex; + uint32_t dstQueueFamilyIndex; + VkImage image; + VkImageSubresourceRange subresourceRange; +} VkImageMemoryBarrier; + +typedef struct VkRenderPassBeginInfo { + VkStructureType sType; + const void* pNext; + VkRenderPass renderPass; + VkFramebuffer framebuffer; + VkRect2D renderArea; + uint32_t clearValueCount; + const VkClearValue* pClearValues; +} VkRenderPassBeginInfo; + +typedef struct VkDispatchIndirectCommand { + uint32_t x; + uint32_t y; + uint32_t z; +} VkDispatchIndirectCommand; + +typedef struct VkDrawIndexedIndirectCommand { + uint32_t indexCount; + uint32_t instanceCount; + uint32_t firstIndex; + int32_t vertexOffset; + uint32_t firstInstance; +} VkDrawIndexedIndirectCommand; + +typedef struct VkDrawIndirectCommand { + uint32_t vertexCount; + uint32_t instanceCount; + uint32_t firstVertex; + uint32_t firstInstance; +} VkDrawIndirectCommand; + + +typedef VkResult (VKAPI_PTR *PFN_vkCreateInstance)(const VkInstanceCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkInstance* pInstance); +typedef void (VKAPI_PTR *PFN_vkDestroyInstance)(VkInstance instance, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkEnumeratePhysicalDevices)(VkInstance instance, uint32_t* pPhysicalDeviceCount, VkPhysicalDevice* pPhysicalDevices); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFeatures)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceFeatures* pFeatures); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFormatProperties)(VkPhysicalDevice physicalDevice, VkFormat format, VkFormatProperties* pFormatProperties); +typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceImageFormatProperties)(VkPhysicalDevice physicalDevice, VkFormat format, VkImageType type, VkImageTiling tiling, VkImageUsageFlags usage, VkImageCreateFlags flags, VkImageFormatProperties* pImageFormatProperties); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceProperties)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceProperties* pProperties); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceQueueFamilyProperties)(VkPhysicalDevice physicalDevice, uint32_t* pQueueFamilyPropertyCount, VkQueueFamilyProperties* pQueueFamilyProperties); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceMemoryProperties)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceMemoryProperties* pMemoryProperties); +typedef PFN_vkVoidFunction (VKAPI_PTR *PFN_vkGetInstanceProcAddr)(VkInstance instance, const char* pName); +typedef PFN_vkVoidFunction (VKAPI_PTR *PFN_vkGetDeviceProcAddr)(VkDevice device, const char* pName); +typedef VkResult (VKAPI_PTR *PFN_vkCreateDevice)(VkPhysicalDevice physicalDevice, const VkDeviceCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDevice* pDevice); +typedef void (VKAPI_PTR *PFN_vkDestroyDevice)(VkDevice device, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkEnumerateInstanceExtensionProperties)(const char* pLayerName, uint32_t* pPropertyCount, VkExtensionProperties* pProperties); +typedef VkResult (VKAPI_PTR *PFN_vkEnumerateDeviceExtensionProperties)(VkPhysicalDevice physicalDevice, const char* pLayerName, uint32_t* pPropertyCount, VkExtensionProperties* pProperties); +typedef VkResult (VKAPI_PTR *PFN_vkEnumerateInstanceLayerProperties)(uint32_t* pPropertyCount, VkLayerProperties* pProperties); +typedef VkResult (VKAPI_PTR *PFN_vkEnumerateDeviceLayerProperties)(VkPhysicalDevice physicalDevice, uint32_t* pPropertyCount, VkLayerProperties* pProperties); +typedef void (VKAPI_PTR *PFN_vkGetDeviceQueue)(VkDevice device, uint32_t queueFamilyIndex, uint32_t queueIndex, VkQueue* pQueue); +typedef VkResult (VKAPI_PTR *PFN_vkQueueSubmit)(VkQueue queue, uint32_t submitCount, const VkSubmitInfo* pSubmits, VkFence fence); +typedef VkResult (VKAPI_PTR *PFN_vkQueueWaitIdle)(VkQueue queue); +typedef VkResult (VKAPI_PTR *PFN_vkDeviceWaitIdle)(VkDevice device); +typedef VkResult (VKAPI_PTR *PFN_vkAllocateMemory)(VkDevice device, const VkMemoryAllocateInfo* pAllocateInfo, const VkAllocationCallbacks* pAllocator, VkDeviceMemory* pMemory); +typedef void (VKAPI_PTR *PFN_vkFreeMemory)(VkDevice device, VkDeviceMemory memory, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkMapMemory)(VkDevice device, VkDeviceMemory memory, VkDeviceSize offset, VkDeviceSize size, VkMemoryMapFlags flags, void** ppData); +typedef void (VKAPI_PTR *PFN_vkUnmapMemory)(VkDevice device, VkDeviceMemory memory); +typedef VkResult (VKAPI_PTR *PFN_vkFlushMappedMemoryRanges)(VkDevice device, uint32_t memoryRangeCount, const VkMappedMemoryRange* pMemoryRanges); +typedef VkResult (VKAPI_PTR *PFN_vkInvalidateMappedMemoryRanges)(VkDevice device, uint32_t memoryRangeCount, const VkMappedMemoryRange* pMemoryRanges); +typedef void (VKAPI_PTR *PFN_vkGetDeviceMemoryCommitment)(VkDevice device, VkDeviceMemory memory, VkDeviceSize* pCommittedMemoryInBytes); +typedef VkResult (VKAPI_PTR *PFN_vkBindBufferMemory)(VkDevice device, VkBuffer buffer, VkDeviceMemory memory, VkDeviceSize memoryOffset); +typedef VkResult (VKAPI_PTR *PFN_vkBindImageMemory)(VkDevice device, VkImage image, VkDeviceMemory memory, VkDeviceSize memoryOffset); +typedef void (VKAPI_PTR *PFN_vkGetBufferMemoryRequirements)(VkDevice device, VkBuffer buffer, VkMemoryRequirements* pMemoryRequirements); +typedef void (VKAPI_PTR *PFN_vkGetImageMemoryRequirements)(VkDevice device, VkImage image, VkMemoryRequirements* pMemoryRequirements); +typedef void (VKAPI_PTR *PFN_vkGetImageSparseMemoryRequirements)(VkDevice device, VkImage image, uint32_t* pSparseMemoryRequirementCount, VkSparseImageMemoryRequirements* pSparseMemoryRequirements); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceSparseImageFormatProperties)(VkPhysicalDevice physicalDevice, VkFormat format, VkImageType type, VkSampleCountFlagBits samples, VkImageUsageFlags usage, VkImageTiling tiling, uint32_t* pPropertyCount, VkSparseImageFormatProperties* pProperties); +typedef VkResult (VKAPI_PTR *PFN_vkQueueBindSparse)(VkQueue queue, uint32_t bindInfoCount, const VkBindSparseInfo* pBindInfo, VkFence fence); +typedef VkResult (VKAPI_PTR *PFN_vkCreateFence)(VkDevice device, const VkFenceCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkFence* pFence); +typedef void (VKAPI_PTR *PFN_vkDestroyFence)(VkDevice device, VkFence fence, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkResetFences)(VkDevice device, uint32_t fenceCount, const VkFence* pFences); +typedef VkResult (VKAPI_PTR *PFN_vkGetFenceStatus)(VkDevice device, VkFence fence); +typedef VkResult (VKAPI_PTR *PFN_vkWaitForFences)(VkDevice device, uint32_t fenceCount, const VkFence* pFences, VkBool32 waitAll, uint64_t timeout); +typedef VkResult (VKAPI_PTR *PFN_vkCreateSemaphore)(VkDevice device, const VkSemaphoreCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSemaphore* pSemaphore); +typedef void (VKAPI_PTR *PFN_vkDestroySemaphore)(VkDevice device, VkSemaphore semaphore, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkCreateEvent)(VkDevice device, const VkEventCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkEvent* pEvent); +typedef void (VKAPI_PTR *PFN_vkDestroyEvent)(VkDevice device, VkEvent event, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkGetEventStatus)(VkDevice device, VkEvent event); +typedef VkResult (VKAPI_PTR *PFN_vkSetEvent)(VkDevice device, VkEvent event); +typedef VkResult (VKAPI_PTR *PFN_vkResetEvent)(VkDevice device, VkEvent event); +typedef VkResult (VKAPI_PTR *PFN_vkCreateQueryPool)(VkDevice device, const VkQueryPoolCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkQueryPool* pQueryPool); +typedef void (VKAPI_PTR *PFN_vkDestroyQueryPool)(VkDevice device, VkQueryPool queryPool, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkGetQueryPoolResults)(VkDevice device, VkQueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, size_t dataSize, void* pData, VkDeviceSize stride, VkQueryResultFlags flags); +typedef VkResult (VKAPI_PTR *PFN_vkCreateBuffer)(VkDevice device, const VkBufferCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkBuffer* pBuffer); +typedef void (VKAPI_PTR *PFN_vkDestroyBuffer)(VkDevice device, VkBuffer buffer, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkCreateBufferView)(VkDevice device, const VkBufferViewCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkBufferView* pView); +typedef void (VKAPI_PTR *PFN_vkDestroyBufferView)(VkDevice device, VkBufferView bufferView, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkCreateImage)(VkDevice device, const VkImageCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkImage* pImage); +typedef void (VKAPI_PTR *PFN_vkDestroyImage)(VkDevice device, VkImage image, const VkAllocationCallbacks* pAllocator); +typedef void (VKAPI_PTR *PFN_vkGetImageSubresourceLayout)(VkDevice device, VkImage image, const VkImageSubresource* pSubresource, VkSubresourceLayout* pLayout); +typedef VkResult (VKAPI_PTR *PFN_vkCreateImageView)(VkDevice device, const VkImageViewCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkImageView* pView); +typedef void (VKAPI_PTR *PFN_vkDestroyImageView)(VkDevice device, VkImageView imageView, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkCreateShaderModule)(VkDevice device, const VkShaderModuleCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkShaderModule* pShaderModule); +typedef void (VKAPI_PTR *PFN_vkDestroyShaderModule)(VkDevice device, VkShaderModule shaderModule, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkCreatePipelineCache)(VkDevice device, const VkPipelineCacheCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkPipelineCache* pPipelineCache); +typedef void (VKAPI_PTR *PFN_vkDestroyPipelineCache)(VkDevice device, VkPipelineCache pipelineCache, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkGetPipelineCacheData)(VkDevice device, VkPipelineCache pipelineCache, size_t* pDataSize, void* pData); +typedef VkResult (VKAPI_PTR *PFN_vkMergePipelineCaches)(VkDevice device, VkPipelineCache dstCache, uint32_t srcCacheCount, const VkPipelineCache* pSrcCaches); +typedef VkResult (VKAPI_PTR *PFN_vkCreateGraphicsPipelines)(VkDevice device, VkPipelineCache pipelineCache, uint32_t createInfoCount, const VkGraphicsPipelineCreateInfo* pCreateInfos, const VkAllocationCallbacks* pAllocator, VkPipeline* pPipelines); +typedef VkResult (VKAPI_PTR *PFN_vkCreateComputePipelines)(VkDevice device, VkPipelineCache pipelineCache, uint32_t createInfoCount, const VkComputePipelineCreateInfo* pCreateInfos, const VkAllocationCallbacks* pAllocator, VkPipeline* pPipelines); +typedef void (VKAPI_PTR *PFN_vkDestroyPipeline)(VkDevice device, VkPipeline pipeline, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkCreatePipelineLayout)(VkDevice device, const VkPipelineLayoutCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkPipelineLayout* pPipelineLayout); +typedef void (VKAPI_PTR *PFN_vkDestroyPipelineLayout)(VkDevice device, VkPipelineLayout pipelineLayout, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkCreateSampler)(VkDevice device, const VkSamplerCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSampler* pSampler); +typedef void (VKAPI_PTR *PFN_vkDestroySampler)(VkDevice device, VkSampler sampler, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkCreateDescriptorSetLayout)(VkDevice device, const VkDescriptorSetLayoutCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDescriptorSetLayout* pSetLayout); +typedef void (VKAPI_PTR *PFN_vkDestroyDescriptorSetLayout)(VkDevice device, VkDescriptorSetLayout descriptorSetLayout, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkCreateDescriptorPool)(VkDevice device, const VkDescriptorPoolCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDescriptorPool* pDescriptorPool); +typedef void (VKAPI_PTR *PFN_vkDestroyDescriptorPool)(VkDevice device, VkDescriptorPool descriptorPool, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkResetDescriptorPool)(VkDevice device, VkDescriptorPool descriptorPool, VkDescriptorPoolResetFlags flags); +typedef VkResult (VKAPI_PTR *PFN_vkAllocateDescriptorSets)(VkDevice device, const VkDescriptorSetAllocateInfo* pAllocateInfo, VkDescriptorSet* pDescriptorSets); +typedef VkResult (VKAPI_PTR *PFN_vkFreeDescriptorSets)(VkDevice device, VkDescriptorPool descriptorPool, uint32_t descriptorSetCount, const VkDescriptorSet* pDescriptorSets); +typedef void (VKAPI_PTR *PFN_vkUpdateDescriptorSets)(VkDevice device, uint32_t descriptorWriteCount, const VkWriteDescriptorSet* pDescriptorWrites, uint32_t descriptorCopyCount, const VkCopyDescriptorSet* pDescriptorCopies); +typedef VkResult (VKAPI_PTR *PFN_vkCreateFramebuffer)(VkDevice device, const VkFramebufferCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkFramebuffer* pFramebuffer); +typedef void (VKAPI_PTR *PFN_vkDestroyFramebuffer)(VkDevice device, VkFramebuffer framebuffer, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkCreateRenderPass)(VkDevice device, const VkRenderPassCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkRenderPass* pRenderPass); +typedef void (VKAPI_PTR *PFN_vkDestroyRenderPass)(VkDevice device, VkRenderPass renderPass, const VkAllocationCallbacks* pAllocator); +typedef void (VKAPI_PTR *PFN_vkGetRenderAreaGranularity)(VkDevice device, VkRenderPass renderPass, VkExtent2D* pGranularity); +typedef VkResult (VKAPI_PTR *PFN_vkCreateCommandPool)(VkDevice device, const VkCommandPoolCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkCommandPool* pCommandPool); +typedef void (VKAPI_PTR *PFN_vkDestroyCommandPool)(VkDevice device, VkCommandPool commandPool, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkResetCommandPool)(VkDevice device, VkCommandPool commandPool, VkCommandPoolResetFlags flags); +typedef VkResult (VKAPI_PTR *PFN_vkAllocateCommandBuffers)(VkDevice device, const VkCommandBufferAllocateInfo* pAllocateInfo, VkCommandBuffer* pCommandBuffers); +typedef void (VKAPI_PTR *PFN_vkFreeCommandBuffers)(VkDevice device, VkCommandPool commandPool, uint32_t commandBufferCount, const VkCommandBuffer* pCommandBuffers); +typedef VkResult (VKAPI_PTR *PFN_vkBeginCommandBuffer)(VkCommandBuffer commandBuffer, const VkCommandBufferBeginInfo* pBeginInfo); +typedef VkResult (VKAPI_PTR *PFN_vkEndCommandBuffer)(VkCommandBuffer commandBuffer); +typedef VkResult (VKAPI_PTR *PFN_vkResetCommandBuffer)(VkCommandBuffer commandBuffer, VkCommandBufferResetFlags flags); +typedef void (VKAPI_PTR *PFN_vkCmdBindPipeline)(VkCommandBuffer commandBuffer, VkPipelineBindPoint pipelineBindPoint, VkPipeline pipeline); +typedef void (VKAPI_PTR *PFN_vkCmdSetViewport)(VkCommandBuffer commandBuffer, uint32_t firstViewport, uint32_t viewportCount, const VkViewport* pViewports); +typedef void (VKAPI_PTR *PFN_vkCmdSetScissor)(VkCommandBuffer commandBuffer, uint32_t firstScissor, uint32_t scissorCount, const VkRect2D* pScissors); +typedef void (VKAPI_PTR *PFN_vkCmdSetLineWidth)(VkCommandBuffer commandBuffer, float lineWidth); +typedef void (VKAPI_PTR *PFN_vkCmdSetDepthBias)(VkCommandBuffer commandBuffer, float depthBiasConstantFactor, float depthBiasClamp, float depthBiasSlopeFactor); +typedef void (VKAPI_PTR *PFN_vkCmdSetBlendConstants)(VkCommandBuffer commandBuffer, const float blendConstants[4]); +typedef void (VKAPI_PTR *PFN_vkCmdSetDepthBounds)(VkCommandBuffer commandBuffer, float minDepthBounds, float maxDepthBounds); +typedef void (VKAPI_PTR *PFN_vkCmdSetStencilCompareMask)(VkCommandBuffer commandBuffer, VkStencilFaceFlags faceMask, uint32_t compareMask); +typedef void (VKAPI_PTR *PFN_vkCmdSetStencilWriteMask)(VkCommandBuffer commandBuffer, VkStencilFaceFlags faceMask, uint32_t writeMask); +typedef void (VKAPI_PTR *PFN_vkCmdSetStencilReference)(VkCommandBuffer commandBuffer, VkStencilFaceFlags faceMask, uint32_t reference); +typedef void (VKAPI_PTR *PFN_vkCmdBindDescriptorSets)(VkCommandBuffer commandBuffer, VkPipelineBindPoint pipelineBindPoint, VkPipelineLayout layout, uint32_t firstSet, uint32_t descriptorSetCount, const VkDescriptorSet* pDescriptorSets, uint32_t dynamicOffsetCount, const uint32_t* pDynamicOffsets); +typedef void (VKAPI_PTR *PFN_vkCmdBindIndexBuffer)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, VkIndexType indexType); +typedef void (VKAPI_PTR *PFN_vkCmdBindVertexBuffers)(VkCommandBuffer commandBuffer, uint32_t firstBinding, uint32_t bindingCount, const VkBuffer* pBuffers, const VkDeviceSize* pOffsets); +typedef void (VKAPI_PTR *PFN_vkCmdDraw)(VkCommandBuffer commandBuffer, uint32_t vertexCount, uint32_t instanceCount, uint32_t firstVertex, uint32_t firstInstance); +typedef void (VKAPI_PTR *PFN_vkCmdDrawIndexed)(VkCommandBuffer commandBuffer, uint32_t indexCount, uint32_t instanceCount, uint32_t firstIndex, int32_t vertexOffset, uint32_t firstInstance); +typedef void (VKAPI_PTR *PFN_vkCmdDrawIndirect)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, uint32_t drawCount, uint32_t stride); +typedef void (VKAPI_PTR *PFN_vkCmdDrawIndexedIndirect)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, uint32_t drawCount, uint32_t stride); +typedef void (VKAPI_PTR *PFN_vkCmdDispatch)(VkCommandBuffer commandBuffer, uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ); +typedef void (VKAPI_PTR *PFN_vkCmdDispatchIndirect)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset); +typedef void (VKAPI_PTR *PFN_vkCmdCopyBuffer)(VkCommandBuffer commandBuffer, VkBuffer srcBuffer, VkBuffer dstBuffer, uint32_t regionCount, const VkBufferCopy* pRegions); +typedef void (VKAPI_PTR *PFN_vkCmdCopyImage)(VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkImageCopy* pRegions); +typedef void (VKAPI_PTR *PFN_vkCmdBlitImage)(VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkImageBlit* pRegions, VkFilter filter); +typedef void (VKAPI_PTR *PFN_vkCmdCopyBufferToImage)(VkCommandBuffer commandBuffer, VkBuffer srcBuffer, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkBufferImageCopy* pRegions); +typedef void (VKAPI_PTR *PFN_vkCmdCopyImageToBuffer)(VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkBuffer dstBuffer, uint32_t regionCount, const VkBufferImageCopy* pRegions); +typedef void (VKAPI_PTR *PFN_vkCmdUpdateBuffer)(VkCommandBuffer commandBuffer, VkBuffer dstBuffer, VkDeviceSize dstOffset, VkDeviceSize dataSize, const void* pData); +typedef void (VKAPI_PTR *PFN_vkCmdFillBuffer)(VkCommandBuffer commandBuffer, VkBuffer dstBuffer, VkDeviceSize dstOffset, VkDeviceSize size, uint32_t data); +typedef void (VKAPI_PTR *PFN_vkCmdClearColorImage)(VkCommandBuffer commandBuffer, VkImage image, VkImageLayout imageLayout, const VkClearColorValue* pColor, uint32_t rangeCount, const VkImageSubresourceRange* pRanges); +typedef void (VKAPI_PTR *PFN_vkCmdClearDepthStencilImage)(VkCommandBuffer commandBuffer, VkImage image, VkImageLayout imageLayout, const VkClearDepthStencilValue* pDepthStencil, uint32_t rangeCount, const VkImageSubresourceRange* pRanges); +typedef void (VKAPI_PTR *PFN_vkCmdClearAttachments)(VkCommandBuffer commandBuffer, uint32_t attachmentCount, const VkClearAttachment* pAttachments, uint32_t rectCount, const VkClearRect* pRects); +typedef void (VKAPI_PTR *PFN_vkCmdResolveImage)(VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkImageResolve* pRegions); +typedef void (VKAPI_PTR *PFN_vkCmdSetEvent)(VkCommandBuffer commandBuffer, VkEvent event, VkPipelineStageFlags stageMask); +typedef void (VKAPI_PTR *PFN_vkCmdResetEvent)(VkCommandBuffer commandBuffer, VkEvent event, VkPipelineStageFlags stageMask); +typedef void (VKAPI_PTR *PFN_vkCmdWaitEvents)(VkCommandBuffer commandBuffer, uint32_t eventCount, const VkEvent* pEvents, VkPipelineStageFlags srcStageMask, VkPipelineStageFlags dstStageMask, uint32_t memoryBarrierCount, const VkMemoryBarrier* pMemoryBarriers, uint32_t bufferMemoryBarrierCount, const VkBufferMemoryBarrier* pBufferMemoryBarriers, uint32_t imageMemoryBarrierCount, const VkImageMemoryBarrier* pImageMemoryBarriers); +typedef void (VKAPI_PTR *PFN_vkCmdPipelineBarrier)(VkCommandBuffer commandBuffer, VkPipelineStageFlags srcStageMask, VkPipelineStageFlags dstStageMask, VkDependencyFlags dependencyFlags, uint32_t memoryBarrierCount, const VkMemoryBarrier* pMemoryBarriers, uint32_t bufferMemoryBarrierCount, const VkBufferMemoryBarrier* pBufferMemoryBarriers, uint32_t imageMemoryBarrierCount, const VkImageMemoryBarrier* pImageMemoryBarriers); +typedef void (VKAPI_PTR *PFN_vkCmdBeginQuery)(VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t query, VkQueryControlFlags flags); +typedef void (VKAPI_PTR *PFN_vkCmdEndQuery)(VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t query); +typedef void (VKAPI_PTR *PFN_vkCmdResetQueryPool)(VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t firstQuery, uint32_t queryCount); +typedef void (VKAPI_PTR *PFN_vkCmdWriteTimestamp)(VkCommandBuffer commandBuffer, VkPipelineStageFlagBits pipelineStage, VkQueryPool queryPool, uint32_t query); +typedef void (VKAPI_PTR *PFN_vkCmdCopyQueryPoolResults)(VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, VkBuffer dstBuffer, VkDeviceSize dstOffset, VkDeviceSize stride, VkQueryResultFlags flags); +typedef void (VKAPI_PTR *PFN_vkCmdPushConstants)(VkCommandBuffer commandBuffer, VkPipelineLayout layout, VkShaderStageFlags stageFlags, uint32_t offset, uint32_t size, const void* pValues); +typedef void (VKAPI_PTR *PFN_vkCmdBeginRenderPass)(VkCommandBuffer commandBuffer, const VkRenderPassBeginInfo* pRenderPassBegin, VkSubpassContents contents); +typedef void (VKAPI_PTR *PFN_vkCmdNextSubpass)(VkCommandBuffer commandBuffer, VkSubpassContents contents); +typedef void (VKAPI_PTR *PFN_vkCmdEndRenderPass)(VkCommandBuffer commandBuffer); +typedef void (VKAPI_PTR *PFN_vkCmdExecuteCommands)(VkCommandBuffer commandBuffer, uint32_t commandBufferCount, const VkCommandBuffer* pCommandBuffers); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkCreateInstance( + const VkInstanceCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkInstance* pInstance); + +VKAPI_ATTR void VKAPI_CALL vkDestroyInstance( + VkInstance instance, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkEnumeratePhysicalDevices( + VkInstance instance, + uint32_t* pPhysicalDeviceCount, + VkPhysicalDevice* pPhysicalDevices); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFeatures( + VkPhysicalDevice physicalDevice, + VkPhysicalDeviceFeatures* pFeatures); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFormatProperties( + VkPhysicalDevice physicalDevice, + VkFormat format, + VkFormatProperties* pFormatProperties); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceImageFormatProperties( + VkPhysicalDevice physicalDevice, + VkFormat format, + VkImageType type, + VkImageTiling tiling, + VkImageUsageFlags usage, + VkImageCreateFlags flags, + VkImageFormatProperties* pImageFormatProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceProperties( + VkPhysicalDevice physicalDevice, + VkPhysicalDeviceProperties* pProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceQueueFamilyProperties( + VkPhysicalDevice physicalDevice, + uint32_t* pQueueFamilyPropertyCount, + VkQueueFamilyProperties* pQueueFamilyProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceMemoryProperties( + VkPhysicalDevice physicalDevice, + VkPhysicalDeviceMemoryProperties* pMemoryProperties); + +VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL vkGetInstanceProcAddr( + VkInstance instance, + const char* pName); + +VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL vkGetDeviceProcAddr( + VkDevice device, + const char* pName); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateDevice( + VkPhysicalDevice physicalDevice, + const VkDeviceCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkDevice* pDevice); + +VKAPI_ATTR void VKAPI_CALL vkDestroyDevice( + VkDevice device, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkEnumerateInstanceExtensionProperties( + const char* pLayerName, + uint32_t* pPropertyCount, + VkExtensionProperties* pProperties); + +VKAPI_ATTR VkResult VKAPI_CALL vkEnumerateDeviceExtensionProperties( + VkPhysicalDevice physicalDevice, + const char* pLayerName, + uint32_t* pPropertyCount, + VkExtensionProperties* pProperties); + +VKAPI_ATTR VkResult VKAPI_CALL vkEnumerateInstanceLayerProperties( + uint32_t* pPropertyCount, + VkLayerProperties* pProperties); + +VKAPI_ATTR VkResult VKAPI_CALL vkEnumerateDeviceLayerProperties( + VkPhysicalDevice physicalDevice, + uint32_t* pPropertyCount, + VkLayerProperties* pProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetDeviceQueue( + VkDevice device, + uint32_t queueFamilyIndex, + uint32_t queueIndex, + VkQueue* pQueue); + +VKAPI_ATTR VkResult VKAPI_CALL vkQueueSubmit( + VkQueue queue, + uint32_t submitCount, + const VkSubmitInfo* pSubmits, + VkFence fence); + +VKAPI_ATTR VkResult VKAPI_CALL vkQueueWaitIdle( + VkQueue queue); + +VKAPI_ATTR VkResult VKAPI_CALL vkDeviceWaitIdle( + VkDevice device); + +VKAPI_ATTR VkResult VKAPI_CALL vkAllocateMemory( + VkDevice device, + const VkMemoryAllocateInfo* pAllocateInfo, + const VkAllocationCallbacks* pAllocator, + VkDeviceMemory* pMemory); + +VKAPI_ATTR void VKAPI_CALL vkFreeMemory( + VkDevice device, + VkDeviceMemory memory, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkMapMemory( + VkDevice device, + VkDeviceMemory memory, + VkDeviceSize offset, + VkDeviceSize size, + VkMemoryMapFlags flags, + void** ppData); + +VKAPI_ATTR void VKAPI_CALL vkUnmapMemory( + VkDevice device, + VkDeviceMemory memory); + +VKAPI_ATTR VkResult VKAPI_CALL vkFlushMappedMemoryRanges( + VkDevice device, + uint32_t memoryRangeCount, + const VkMappedMemoryRange* pMemoryRanges); + +VKAPI_ATTR VkResult VKAPI_CALL vkInvalidateMappedMemoryRanges( + VkDevice device, + uint32_t memoryRangeCount, + const VkMappedMemoryRange* pMemoryRanges); + +VKAPI_ATTR void VKAPI_CALL vkGetDeviceMemoryCommitment( + VkDevice device, + VkDeviceMemory memory, + VkDeviceSize* pCommittedMemoryInBytes); + +VKAPI_ATTR VkResult VKAPI_CALL vkBindBufferMemory( + VkDevice device, + VkBuffer buffer, + VkDeviceMemory memory, + VkDeviceSize memoryOffset); + +VKAPI_ATTR VkResult VKAPI_CALL vkBindImageMemory( + VkDevice device, + VkImage image, + VkDeviceMemory memory, + VkDeviceSize memoryOffset); + +VKAPI_ATTR void VKAPI_CALL vkGetBufferMemoryRequirements( + VkDevice device, + VkBuffer buffer, + VkMemoryRequirements* pMemoryRequirements); + +VKAPI_ATTR void VKAPI_CALL vkGetImageMemoryRequirements( + VkDevice device, + VkImage image, + VkMemoryRequirements* pMemoryRequirements); + +VKAPI_ATTR void VKAPI_CALL vkGetImageSparseMemoryRequirements( + VkDevice device, + VkImage image, + uint32_t* pSparseMemoryRequirementCount, + VkSparseImageMemoryRequirements* pSparseMemoryRequirements); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceSparseImageFormatProperties( + VkPhysicalDevice physicalDevice, + VkFormat format, + VkImageType type, + VkSampleCountFlagBits samples, + VkImageUsageFlags usage, + VkImageTiling tiling, + uint32_t* pPropertyCount, + VkSparseImageFormatProperties* pProperties); + +VKAPI_ATTR VkResult VKAPI_CALL vkQueueBindSparse( + VkQueue queue, + uint32_t bindInfoCount, + const VkBindSparseInfo* pBindInfo, + VkFence fence); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateFence( + VkDevice device, + const VkFenceCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkFence* pFence); + +VKAPI_ATTR void VKAPI_CALL vkDestroyFence( + VkDevice device, + VkFence fence, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkResetFences( + VkDevice device, + uint32_t fenceCount, + const VkFence* pFences); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetFenceStatus( + VkDevice device, + VkFence fence); + +VKAPI_ATTR VkResult VKAPI_CALL vkWaitForFences( + VkDevice device, + uint32_t fenceCount, + const VkFence* pFences, + VkBool32 waitAll, + uint64_t timeout); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateSemaphore( + VkDevice device, + const VkSemaphoreCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkSemaphore* pSemaphore); + +VKAPI_ATTR void VKAPI_CALL vkDestroySemaphore( + VkDevice device, + VkSemaphore semaphore, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateEvent( + VkDevice device, + const VkEventCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkEvent* pEvent); + +VKAPI_ATTR void VKAPI_CALL vkDestroyEvent( + VkDevice device, + VkEvent event, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetEventStatus( + VkDevice device, + VkEvent event); + +VKAPI_ATTR VkResult VKAPI_CALL vkSetEvent( + VkDevice device, + VkEvent event); + +VKAPI_ATTR VkResult VKAPI_CALL vkResetEvent( + VkDevice device, + VkEvent event); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateQueryPool( + VkDevice device, + const VkQueryPoolCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkQueryPool* pQueryPool); + +VKAPI_ATTR void VKAPI_CALL vkDestroyQueryPool( + VkDevice device, + VkQueryPool queryPool, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetQueryPoolResults( + VkDevice device, + VkQueryPool queryPool, + uint32_t firstQuery, + uint32_t queryCount, + size_t dataSize, + void* pData, + VkDeviceSize stride, + VkQueryResultFlags flags); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateBuffer( + VkDevice device, + const VkBufferCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkBuffer* pBuffer); + +VKAPI_ATTR void VKAPI_CALL vkDestroyBuffer( + VkDevice device, + VkBuffer buffer, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateBufferView( + VkDevice device, + const VkBufferViewCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkBufferView* pView); + +VKAPI_ATTR void VKAPI_CALL vkDestroyBufferView( + VkDevice device, + VkBufferView bufferView, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateImage( + VkDevice device, + const VkImageCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkImage* pImage); + +VKAPI_ATTR void VKAPI_CALL vkDestroyImage( + VkDevice device, + VkImage image, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR void VKAPI_CALL vkGetImageSubresourceLayout( + VkDevice device, + VkImage image, + const VkImageSubresource* pSubresource, + VkSubresourceLayout* pLayout); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateImageView( + VkDevice device, + const VkImageViewCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkImageView* pView); + +VKAPI_ATTR void VKAPI_CALL vkDestroyImageView( + VkDevice device, + VkImageView imageView, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateShaderModule( + VkDevice device, + const VkShaderModuleCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkShaderModule* pShaderModule); + +VKAPI_ATTR void VKAPI_CALL vkDestroyShaderModule( + VkDevice device, + VkShaderModule shaderModule, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreatePipelineCache( + VkDevice device, + const VkPipelineCacheCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkPipelineCache* pPipelineCache); + +VKAPI_ATTR void VKAPI_CALL vkDestroyPipelineCache( + VkDevice device, + VkPipelineCache pipelineCache, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetPipelineCacheData( + VkDevice device, + VkPipelineCache pipelineCache, + size_t* pDataSize, + void* pData); + +VKAPI_ATTR VkResult VKAPI_CALL vkMergePipelineCaches( + VkDevice device, + VkPipelineCache dstCache, + uint32_t srcCacheCount, + const VkPipelineCache* pSrcCaches); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateGraphicsPipelines( + VkDevice device, + VkPipelineCache pipelineCache, + uint32_t createInfoCount, + const VkGraphicsPipelineCreateInfo* pCreateInfos, + const VkAllocationCallbacks* pAllocator, + VkPipeline* pPipelines); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateComputePipelines( + VkDevice device, + VkPipelineCache pipelineCache, + uint32_t createInfoCount, + const VkComputePipelineCreateInfo* pCreateInfos, + const VkAllocationCallbacks* pAllocator, + VkPipeline* pPipelines); + +VKAPI_ATTR void VKAPI_CALL vkDestroyPipeline( + VkDevice device, + VkPipeline pipeline, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreatePipelineLayout( + VkDevice device, + const VkPipelineLayoutCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkPipelineLayout* pPipelineLayout); + +VKAPI_ATTR void VKAPI_CALL vkDestroyPipelineLayout( + VkDevice device, + VkPipelineLayout pipelineLayout, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateSampler( + VkDevice device, + const VkSamplerCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkSampler* pSampler); + +VKAPI_ATTR void VKAPI_CALL vkDestroySampler( + VkDevice device, + VkSampler sampler, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateDescriptorSetLayout( + VkDevice device, + const VkDescriptorSetLayoutCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkDescriptorSetLayout* pSetLayout); + +VKAPI_ATTR void VKAPI_CALL vkDestroyDescriptorSetLayout( + VkDevice device, + VkDescriptorSetLayout descriptorSetLayout, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateDescriptorPool( + VkDevice device, + const VkDescriptorPoolCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkDescriptorPool* pDescriptorPool); + +VKAPI_ATTR void VKAPI_CALL vkDestroyDescriptorPool( + VkDevice device, + VkDescriptorPool descriptorPool, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkResetDescriptorPool( + VkDevice device, + VkDescriptorPool descriptorPool, + VkDescriptorPoolResetFlags flags); + +VKAPI_ATTR VkResult VKAPI_CALL vkAllocateDescriptorSets( + VkDevice device, + const VkDescriptorSetAllocateInfo* pAllocateInfo, + VkDescriptorSet* pDescriptorSets); + +VKAPI_ATTR VkResult VKAPI_CALL vkFreeDescriptorSets( + VkDevice device, + VkDescriptorPool descriptorPool, + uint32_t descriptorSetCount, + const VkDescriptorSet* pDescriptorSets); + +VKAPI_ATTR void VKAPI_CALL vkUpdateDescriptorSets( + VkDevice device, + uint32_t descriptorWriteCount, + const VkWriteDescriptorSet* pDescriptorWrites, + uint32_t descriptorCopyCount, + const VkCopyDescriptorSet* pDescriptorCopies); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateFramebuffer( + VkDevice device, + const VkFramebufferCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkFramebuffer* pFramebuffer); + +VKAPI_ATTR void VKAPI_CALL vkDestroyFramebuffer( + VkDevice device, + VkFramebuffer framebuffer, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateRenderPass( + VkDevice device, + const VkRenderPassCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkRenderPass* pRenderPass); + +VKAPI_ATTR void VKAPI_CALL vkDestroyRenderPass( + VkDevice device, + VkRenderPass renderPass, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR void VKAPI_CALL vkGetRenderAreaGranularity( + VkDevice device, + VkRenderPass renderPass, + VkExtent2D* pGranularity); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateCommandPool( + VkDevice device, + const VkCommandPoolCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkCommandPool* pCommandPool); + +VKAPI_ATTR void VKAPI_CALL vkDestroyCommandPool( + VkDevice device, + VkCommandPool commandPool, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkResetCommandPool( + VkDevice device, + VkCommandPool commandPool, + VkCommandPoolResetFlags flags); + +VKAPI_ATTR VkResult VKAPI_CALL vkAllocateCommandBuffers( + VkDevice device, + const VkCommandBufferAllocateInfo* pAllocateInfo, + VkCommandBuffer* pCommandBuffers); + +VKAPI_ATTR void VKAPI_CALL vkFreeCommandBuffers( + VkDevice device, + VkCommandPool commandPool, + uint32_t commandBufferCount, + const VkCommandBuffer* pCommandBuffers); + +VKAPI_ATTR VkResult VKAPI_CALL vkBeginCommandBuffer( + VkCommandBuffer commandBuffer, + const VkCommandBufferBeginInfo* pBeginInfo); + +VKAPI_ATTR VkResult VKAPI_CALL vkEndCommandBuffer( + VkCommandBuffer commandBuffer); + +VKAPI_ATTR VkResult VKAPI_CALL vkResetCommandBuffer( + VkCommandBuffer commandBuffer, + VkCommandBufferResetFlags flags); + +VKAPI_ATTR void VKAPI_CALL vkCmdBindPipeline( + VkCommandBuffer commandBuffer, + VkPipelineBindPoint pipelineBindPoint, + VkPipeline pipeline); + +VKAPI_ATTR void VKAPI_CALL vkCmdSetViewport( + VkCommandBuffer commandBuffer, + uint32_t firstViewport, + uint32_t viewportCount, + const VkViewport* pViewports); + +VKAPI_ATTR void VKAPI_CALL vkCmdSetScissor( + VkCommandBuffer commandBuffer, + uint32_t firstScissor, + uint32_t scissorCount, + const VkRect2D* pScissors); + +VKAPI_ATTR void VKAPI_CALL vkCmdSetLineWidth( + VkCommandBuffer commandBuffer, + float lineWidth); + +VKAPI_ATTR void VKAPI_CALL vkCmdSetDepthBias( + VkCommandBuffer commandBuffer, + float depthBiasConstantFactor, + float depthBiasClamp, + float depthBiasSlopeFactor); + +VKAPI_ATTR void VKAPI_CALL vkCmdSetBlendConstants( + VkCommandBuffer commandBuffer, + const float blendConstants[4]); + +VKAPI_ATTR void VKAPI_CALL vkCmdSetDepthBounds( + VkCommandBuffer commandBuffer, + float minDepthBounds, + float maxDepthBounds); + +VKAPI_ATTR void VKAPI_CALL vkCmdSetStencilCompareMask( + VkCommandBuffer commandBuffer, + VkStencilFaceFlags faceMask, + uint32_t compareMask); + +VKAPI_ATTR void VKAPI_CALL vkCmdSetStencilWriteMask( + VkCommandBuffer commandBuffer, + VkStencilFaceFlags faceMask, + uint32_t writeMask); + +VKAPI_ATTR void VKAPI_CALL vkCmdSetStencilReference( + VkCommandBuffer commandBuffer, + VkStencilFaceFlags faceMask, + uint32_t reference); + +VKAPI_ATTR void VKAPI_CALL vkCmdBindDescriptorSets( + VkCommandBuffer commandBuffer, + VkPipelineBindPoint pipelineBindPoint, + VkPipelineLayout layout, + uint32_t firstSet, + uint32_t descriptorSetCount, + const VkDescriptorSet* pDescriptorSets, + uint32_t dynamicOffsetCount, + const uint32_t* pDynamicOffsets); + +VKAPI_ATTR void VKAPI_CALL vkCmdBindIndexBuffer( + VkCommandBuffer commandBuffer, + VkBuffer buffer, + VkDeviceSize offset, + VkIndexType indexType); + +VKAPI_ATTR void VKAPI_CALL vkCmdBindVertexBuffers( + VkCommandBuffer commandBuffer, + uint32_t firstBinding, + uint32_t bindingCount, + const VkBuffer* pBuffers, + const VkDeviceSize* pOffsets); + +VKAPI_ATTR void VKAPI_CALL vkCmdDraw( + VkCommandBuffer commandBuffer, + uint32_t vertexCount, + uint32_t instanceCount, + uint32_t firstVertex, + uint32_t firstInstance); + +VKAPI_ATTR void VKAPI_CALL vkCmdDrawIndexed( + VkCommandBuffer commandBuffer, + uint32_t indexCount, + uint32_t instanceCount, + uint32_t firstIndex, + int32_t vertexOffset, + uint32_t firstInstance); + +VKAPI_ATTR void VKAPI_CALL vkCmdDrawIndirect( + VkCommandBuffer commandBuffer, + VkBuffer buffer, + VkDeviceSize offset, + uint32_t drawCount, + uint32_t stride); + +VKAPI_ATTR void VKAPI_CALL vkCmdDrawIndexedIndirect( + VkCommandBuffer commandBuffer, + VkBuffer buffer, + VkDeviceSize offset, + uint32_t drawCount, + uint32_t stride); + +VKAPI_ATTR void VKAPI_CALL vkCmdDispatch( + VkCommandBuffer commandBuffer, + uint32_t groupCountX, + uint32_t groupCountY, + uint32_t groupCountZ); + +VKAPI_ATTR void VKAPI_CALL vkCmdDispatchIndirect( + VkCommandBuffer commandBuffer, + VkBuffer buffer, + VkDeviceSize offset); + +VKAPI_ATTR void VKAPI_CALL vkCmdCopyBuffer( + VkCommandBuffer commandBuffer, + VkBuffer srcBuffer, + VkBuffer dstBuffer, + uint32_t regionCount, + const VkBufferCopy* pRegions); + +VKAPI_ATTR void VKAPI_CALL vkCmdCopyImage( + VkCommandBuffer commandBuffer, + VkImage srcImage, + VkImageLayout srcImageLayout, + VkImage dstImage, + VkImageLayout dstImageLayout, + uint32_t regionCount, + const VkImageCopy* pRegions); + +VKAPI_ATTR void VKAPI_CALL vkCmdBlitImage( + VkCommandBuffer commandBuffer, + VkImage srcImage, + VkImageLayout srcImageLayout, + VkImage dstImage, + VkImageLayout dstImageLayout, + uint32_t regionCount, + const VkImageBlit* pRegions, + VkFilter filter); + +VKAPI_ATTR void VKAPI_CALL vkCmdCopyBufferToImage( + VkCommandBuffer commandBuffer, + VkBuffer srcBuffer, + VkImage dstImage, + VkImageLayout dstImageLayout, + uint32_t regionCount, + const VkBufferImageCopy* pRegions); + +VKAPI_ATTR void VKAPI_CALL vkCmdCopyImageToBuffer( + VkCommandBuffer commandBuffer, + VkImage srcImage, + VkImageLayout srcImageLayout, + VkBuffer dstBuffer, + uint32_t regionCount, + const VkBufferImageCopy* pRegions); + +VKAPI_ATTR void VKAPI_CALL vkCmdUpdateBuffer( + VkCommandBuffer commandBuffer, + VkBuffer dstBuffer, + VkDeviceSize dstOffset, + VkDeviceSize dataSize, + const void* pData); + +VKAPI_ATTR void VKAPI_CALL vkCmdFillBuffer( + VkCommandBuffer commandBuffer, + VkBuffer dstBuffer, + VkDeviceSize dstOffset, + VkDeviceSize size, + uint32_t data); + +VKAPI_ATTR void VKAPI_CALL vkCmdClearColorImage( + VkCommandBuffer commandBuffer, + VkImage image, + VkImageLayout imageLayout, + const VkClearColorValue* pColor, + uint32_t rangeCount, + const VkImageSubresourceRange* pRanges); + +VKAPI_ATTR void VKAPI_CALL vkCmdClearDepthStencilImage( + VkCommandBuffer commandBuffer, + VkImage image, + VkImageLayout imageLayout, + const VkClearDepthStencilValue* pDepthStencil, + uint32_t rangeCount, + const VkImageSubresourceRange* pRanges); + +VKAPI_ATTR void VKAPI_CALL vkCmdClearAttachments( + VkCommandBuffer commandBuffer, + uint32_t attachmentCount, + const VkClearAttachment* pAttachments, + uint32_t rectCount, + const VkClearRect* pRects); + +VKAPI_ATTR void VKAPI_CALL vkCmdResolveImage( + VkCommandBuffer commandBuffer, + VkImage srcImage, + VkImageLayout srcImageLayout, + VkImage dstImage, + VkImageLayout dstImageLayout, + uint32_t regionCount, + const VkImageResolve* pRegions); + +VKAPI_ATTR void VKAPI_CALL vkCmdSetEvent( + VkCommandBuffer commandBuffer, + VkEvent event, + VkPipelineStageFlags stageMask); + +VKAPI_ATTR void VKAPI_CALL vkCmdResetEvent( + VkCommandBuffer commandBuffer, + VkEvent event, + VkPipelineStageFlags stageMask); + +VKAPI_ATTR void VKAPI_CALL vkCmdWaitEvents( + VkCommandBuffer commandBuffer, + uint32_t eventCount, + const VkEvent* pEvents, + VkPipelineStageFlags srcStageMask, + VkPipelineStageFlags dstStageMask, + uint32_t memoryBarrierCount, + const VkMemoryBarrier* pMemoryBarriers, + uint32_t bufferMemoryBarrierCount, + const VkBufferMemoryBarrier* pBufferMemoryBarriers, + uint32_t imageMemoryBarrierCount, + const VkImageMemoryBarrier* pImageMemoryBarriers); + +VKAPI_ATTR void VKAPI_CALL vkCmdPipelineBarrier( + VkCommandBuffer commandBuffer, + VkPipelineStageFlags srcStageMask, + VkPipelineStageFlags dstStageMask, + VkDependencyFlags dependencyFlags, + uint32_t memoryBarrierCount, + const VkMemoryBarrier* pMemoryBarriers, + uint32_t bufferMemoryBarrierCount, + const VkBufferMemoryBarrier* pBufferMemoryBarriers, + uint32_t imageMemoryBarrierCount, + const VkImageMemoryBarrier* pImageMemoryBarriers); + +VKAPI_ATTR void VKAPI_CALL vkCmdBeginQuery( + VkCommandBuffer commandBuffer, + VkQueryPool queryPool, + uint32_t query, + VkQueryControlFlags flags); + +VKAPI_ATTR void VKAPI_CALL vkCmdEndQuery( + VkCommandBuffer commandBuffer, + VkQueryPool queryPool, + uint32_t query); + +VKAPI_ATTR void VKAPI_CALL vkCmdResetQueryPool( + VkCommandBuffer commandBuffer, + VkQueryPool queryPool, + uint32_t firstQuery, + uint32_t queryCount); + +VKAPI_ATTR void VKAPI_CALL vkCmdWriteTimestamp( + VkCommandBuffer commandBuffer, + VkPipelineStageFlagBits pipelineStage, + VkQueryPool queryPool, + uint32_t query); + +VKAPI_ATTR void VKAPI_CALL vkCmdCopyQueryPoolResults( + VkCommandBuffer commandBuffer, + VkQueryPool queryPool, + uint32_t firstQuery, + uint32_t queryCount, + VkBuffer dstBuffer, + VkDeviceSize dstOffset, + VkDeviceSize stride, + VkQueryResultFlags flags); + +VKAPI_ATTR void VKAPI_CALL vkCmdPushConstants( + VkCommandBuffer commandBuffer, + VkPipelineLayout layout, + VkShaderStageFlags stageFlags, + uint32_t offset, + uint32_t size, + const void* pValues); + +VKAPI_ATTR void VKAPI_CALL vkCmdBeginRenderPass( + VkCommandBuffer commandBuffer, + const VkRenderPassBeginInfo* pRenderPassBegin, + VkSubpassContents contents); + +VKAPI_ATTR void VKAPI_CALL vkCmdNextSubpass( + VkCommandBuffer commandBuffer, + VkSubpassContents contents); + +VKAPI_ATTR void VKAPI_CALL vkCmdEndRenderPass( + VkCommandBuffer commandBuffer); + +VKAPI_ATTR void VKAPI_CALL vkCmdExecuteCommands( + VkCommandBuffer commandBuffer, + uint32_t commandBufferCount, + const VkCommandBuffer* pCommandBuffers); +#endif + +#define VK_VERSION_1_1 1 +// Vulkan 1.1 version number +#define VK_API_VERSION_1_1 VK_MAKE_VERSION(1, 1, 0)// Patch version should always be set to 0 + + +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSamplerYcbcrConversion) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDescriptorUpdateTemplate) + +#define VK_MAX_DEVICE_GROUP_SIZE 32 +#define VK_LUID_SIZE 8 +#define VK_QUEUE_FAMILY_EXTERNAL (~0U-1) + + +typedef enum VkPointClippingBehavior { + VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES = 0, + VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY = 1, + VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES_KHR = VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES, + VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY_KHR = VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY, + VK_POINT_CLIPPING_BEHAVIOR_BEGIN_RANGE = VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES, + VK_POINT_CLIPPING_BEHAVIOR_END_RANGE = VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY, + VK_POINT_CLIPPING_BEHAVIOR_RANGE_SIZE = (VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY - VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES + 1), + VK_POINT_CLIPPING_BEHAVIOR_MAX_ENUM = 0x7FFFFFFF +} VkPointClippingBehavior; + +typedef enum VkTessellationDomainOrigin { + VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT = 0, + VK_TESSELLATION_DOMAIN_ORIGIN_LOWER_LEFT = 1, + VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT_KHR = VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT, + VK_TESSELLATION_DOMAIN_ORIGIN_LOWER_LEFT_KHR = VK_TESSELLATION_DOMAIN_ORIGIN_LOWER_LEFT, + VK_TESSELLATION_DOMAIN_ORIGIN_BEGIN_RANGE = VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT, + VK_TESSELLATION_DOMAIN_ORIGIN_END_RANGE = VK_TESSELLATION_DOMAIN_ORIGIN_LOWER_LEFT, + VK_TESSELLATION_DOMAIN_ORIGIN_RANGE_SIZE = (VK_TESSELLATION_DOMAIN_ORIGIN_LOWER_LEFT - VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT + 1), + VK_TESSELLATION_DOMAIN_ORIGIN_MAX_ENUM = 0x7FFFFFFF +} VkTessellationDomainOrigin; + +typedef enum VkSamplerYcbcrModelConversion { + VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY = 0, + VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_IDENTITY = 1, + VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_709 = 2, + VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_601 = 3, + VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020 = 4, + VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY_KHR = VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY, + VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_IDENTITY_KHR = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_IDENTITY, + VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_709_KHR = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_709, + VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_601_KHR = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_601, + VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020_KHR = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020, + VK_SAMPLER_YCBCR_MODEL_CONVERSION_BEGIN_RANGE = VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY, + VK_SAMPLER_YCBCR_MODEL_CONVERSION_END_RANGE = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020, + VK_SAMPLER_YCBCR_MODEL_CONVERSION_RANGE_SIZE = (VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020 - VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY + 1), + VK_SAMPLER_YCBCR_MODEL_CONVERSION_MAX_ENUM = 0x7FFFFFFF +} VkSamplerYcbcrModelConversion; + +typedef enum VkSamplerYcbcrRange { + VK_SAMPLER_YCBCR_RANGE_ITU_FULL = 0, + VK_SAMPLER_YCBCR_RANGE_ITU_NARROW = 1, + VK_SAMPLER_YCBCR_RANGE_ITU_FULL_KHR = VK_SAMPLER_YCBCR_RANGE_ITU_FULL, + VK_SAMPLER_YCBCR_RANGE_ITU_NARROW_KHR = VK_SAMPLER_YCBCR_RANGE_ITU_NARROW, + VK_SAMPLER_YCBCR_RANGE_BEGIN_RANGE = VK_SAMPLER_YCBCR_RANGE_ITU_FULL, + VK_SAMPLER_YCBCR_RANGE_END_RANGE = VK_SAMPLER_YCBCR_RANGE_ITU_NARROW, + VK_SAMPLER_YCBCR_RANGE_RANGE_SIZE = (VK_SAMPLER_YCBCR_RANGE_ITU_NARROW - VK_SAMPLER_YCBCR_RANGE_ITU_FULL + 1), + VK_SAMPLER_YCBCR_RANGE_MAX_ENUM = 0x7FFFFFFF +} VkSamplerYcbcrRange; + +typedef enum VkChromaLocation { + VK_CHROMA_LOCATION_COSITED_EVEN = 0, + VK_CHROMA_LOCATION_MIDPOINT = 1, + VK_CHROMA_LOCATION_COSITED_EVEN_KHR = VK_CHROMA_LOCATION_COSITED_EVEN, + VK_CHROMA_LOCATION_MIDPOINT_KHR = VK_CHROMA_LOCATION_MIDPOINT, + VK_CHROMA_LOCATION_BEGIN_RANGE = VK_CHROMA_LOCATION_COSITED_EVEN, + VK_CHROMA_LOCATION_END_RANGE = VK_CHROMA_LOCATION_MIDPOINT, + VK_CHROMA_LOCATION_RANGE_SIZE = (VK_CHROMA_LOCATION_MIDPOINT - VK_CHROMA_LOCATION_COSITED_EVEN + 1), + VK_CHROMA_LOCATION_MAX_ENUM = 0x7FFFFFFF +} VkChromaLocation; + +typedef enum VkDescriptorUpdateTemplateType { + VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET = 0, + VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR = 1, + VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET_KHR = VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET, + VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_BEGIN_RANGE = VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET, + VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_END_RANGE = VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET, + VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_RANGE_SIZE = (VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET - VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET + 1), + VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_MAX_ENUM = 0x7FFFFFFF +} VkDescriptorUpdateTemplateType; + + +typedef enum VkSubgroupFeatureFlagBits { + VK_SUBGROUP_FEATURE_BASIC_BIT = 0x00000001, + VK_SUBGROUP_FEATURE_VOTE_BIT = 0x00000002, + VK_SUBGROUP_FEATURE_ARITHMETIC_BIT = 0x00000004, + VK_SUBGROUP_FEATURE_BALLOT_BIT = 0x00000008, + VK_SUBGROUP_FEATURE_SHUFFLE_BIT = 0x00000010, + VK_SUBGROUP_FEATURE_SHUFFLE_RELATIVE_BIT = 0x00000020, + VK_SUBGROUP_FEATURE_CLUSTERED_BIT = 0x00000040, + VK_SUBGROUP_FEATURE_QUAD_BIT = 0x00000080, + VK_SUBGROUP_FEATURE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkSubgroupFeatureFlagBits; +typedef VkFlags VkSubgroupFeatureFlags; + +typedef enum VkPeerMemoryFeatureFlagBits { + VK_PEER_MEMORY_FEATURE_COPY_SRC_BIT = 0x00000001, + VK_PEER_MEMORY_FEATURE_COPY_DST_BIT = 0x00000002, + VK_PEER_MEMORY_FEATURE_GENERIC_SRC_BIT = 0x00000004, + VK_PEER_MEMORY_FEATURE_GENERIC_DST_BIT = 0x00000008, + VK_PEER_MEMORY_FEATURE_COPY_SRC_BIT_KHR = VK_PEER_MEMORY_FEATURE_COPY_SRC_BIT, + VK_PEER_MEMORY_FEATURE_COPY_DST_BIT_KHR = VK_PEER_MEMORY_FEATURE_COPY_DST_BIT, + VK_PEER_MEMORY_FEATURE_GENERIC_SRC_BIT_KHR = VK_PEER_MEMORY_FEATURE_GENERIC_SRC_BIT, + VK_PEER_MEMORY_FEATURE_GENERIC_DST_BIT_KHR = VK_PEER_MEMORY_FEATURE_GENERIC_DST_BIT, + VK_PEER_MEMORY_FEATURE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkPeerMemoryFeatureFlagBits; +typedef VkFlags VkPeerMemoryFeatureFlags; + +typedef enum VkMemoryAllocateFlagBits { + VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT = 0x00000001, + VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT_KHR = VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT, + VK_MEMORY_ALLOCATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkMemoryAllocateFlagBits; +typedef VkFlags VkMemoryAllocateFlags; +typedef VkFlags VkCommandPoolTrimFlags; +typedef VkFlags VkDescriptorUpdateTemplateCreateFlags; + +typedef enum VkExternalMemoryHandleTypeFlagBits { + VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT = 0x00000001, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT = 0x00000002, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT = 0x00000004, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT = 0x00000008, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT = 0x00000010, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT = 0x00000020, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT = 0x00000040, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_DMA_BUF_BIT_EXT = 0x00000200, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT = 0x00000080, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT = 0x00000100, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT_KHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT_KHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_KHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT_KHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT_KHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT_KHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT_KHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkExternalMemoryHandleTypeFlagBits; +typedef VkFlags VkExternalMemoryHandleTypeFlags; + +typedef enum VkExternalMemoryFeatureFlagBits { + VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT = 0x00000001, + VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT = 0x00000002, + VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT = 0x00000004, + VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT_KHR = VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT, + VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT_KHR = VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT, + VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT_KHR = VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT, + VK_EXTERNAL_MEMORY_FEATURE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkExternalMemoryFeatureFlagBits; +typedef VkFlags VkExternalMemoryFeatureFlags; + +typedef enum VkExternalFenceHandleTypeFlagBits { + VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_FD_BIT = 0x00000001, + VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_BIT = 0x00000002, + VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT = 0x00000004, + VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT = 0x00000008, + VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_FD_BIT_KHR = VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_FD_BIT, + VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_BIT_KHR = VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_BIT, + VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_KHR = VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT, + VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT_KHR = VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT, + VK_EXTERNAL_FENCE_HANDLE_TYPE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkExternalFenceHandleTypeFlagBits; +typedef VkFlags VkExternalFenceHandleTypeFlags; + +typedef enum VkExternalFenceFeatureFlagBits { + VK_EXTERNAL_FENCE_FEATURE_EXPORTABLE_BIT = 0x00000001, + VK_EXTERNAL_FENCE_FEATURE_IMPORTABLE_BIT = 0x00000002, + VK_EXTERNAL_FENCE_FEATURE_EXPORTABLE_BIT_KHR = VK_EXTERNAL_FENCE_FEATURE_EXPORTABLE_BIT, + VK_EXTERNAL_FENCE_FEATURE_IMPORTABLE_BIT_KHR = VK_EXTERNAL_FENCE_FEATURE_IMPORTABLE_BIT, + VK_EXTERNAL_FENCE_FEATURE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkExternalFenceFeatureFlagBits; +typedef VkFlags VkExternalFenceFeatureFlags; + +typedef enum VkFenceImportFlagBits { + VK_FENCE_IMPORT_TEMPORARY_BIT = 0x00000001, + VK_FENCE_IMPORT_TEMPORARY_BIT_KHR = VK_FENCE_IMPORT_TEMPORARY_BIT, + VK_FENCE_IMPORT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkFenceImportFlagBits; +typedef VkFlags VkFenceImportFlags; + +typedef enum VkSemaphoreImportFlagBits { + VK_SEMAPHORE_IMPORT_TEMPORARY_BIT = 0x00000001, + VK_SEMAPHORE_IMPORT_TEMPORARY_BIT_KHR = VK_SEMAPHORE_IMPORT_TEMPORARY_BIT, + VK_SEMAPHORE_IMPORT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkSemaphoreImportFlagBits; +typedef VkFlags VkSemaphoreImportFlags; + +typedef enum VkExternalSemaphoreHandleTypeFlagBits { + VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD_BIT = 0x00000001, + VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_BIT = 0x00000002, + VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT = 0x00000004, + VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE_BIT = 0x00000008, + VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT = 0x00000010, + VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD_BIT_KHR = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD_BIT, + VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_BIT_KHR = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_BIT, + VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_KHR = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT, + VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE_BIT_KHR = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE_BIT, + VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT_KHR = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT, + VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkExternalSemaphoreHandleTypeFlagBits; +typedef VkFlags VkExternalSemaphoreHandleTypeFlags; + +typedef enum VkExternalSemaphoreFeatureFlagBits { + VK_EXTERNAL_SEMAPHORE_FEATURE_EXPORTABLE_BIT = 0x00000001, + VK_EXTERNAL_SEMAPHORE_FEATURE_IMPORTABLE_BIT = 0x00000002, + VK_EXTERNAL_SEMAPHORE_FEATURE_EXPORTABLE_BIT_KHR = VK_EXTERNAL_SEMAPHORE_FEATURE_EXPORTABLE_BIT, + VK_EXTERNAL_SEMAPHORE_FEATURE_IMPORTABLE_BIT_KHR = VK_EXTERNAL_SEMAPHORE_FEATURE_IMPORTABLE_BIT, + VK_EXTERNAL_SEMAPHORE_FEATURE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkExternalSemaphoreFeatureFlagBits; +typedef VkFlags VkExternalSemaphoreFeatureFlags; + +typedef struct VkPhysicalDeviceSubgroupProperties { + VkStructureType sType; + void* pNext; + uint32_t subgroupSize; + VkShaderStageFlags supportedStages; + VkSubgroupFeatureFlags supportedOperations; + VkBool32 quadOperationsInAllStages; +} VkPhysicalDeviceSubgroupProperties; + +typedef struct VkBindBufferMemoryInfo { + VkStructureType sType; + const void* pNext; + VkBuffer buffer; + VkDeviceMemory memory; + VkDeviceSize memoryOffset; +} VkBindBufferMemoryInfo; + +typedef struct VkBindImageMemoryInfo { + VkStructureType sType; + const void* pNext; + VkImage image; + VkDeviceMemory memory; + VkDeviceSize memoryOffset; +} VkBindImageMemoryInfo; + +typedef struct VkPhysicalDevice16BitStorageFeatures { + VkStructureType sType; + void* pNext; + VkBool32 storageBuffer16BitAccess; + VkBool32 uniformAndStorageBuffer16BitAccess; + VkBool32 storagePushConstant16; + VkBool32 storageInputOutput16; +} VkPhysicalDevice16BitStorageFeatures; + +typedef struct VkMemoryDedicatedRequirements { + VkStructureType sType; + void* pNext; + VkBool32 prefersDedicatedAllocation; + VkBool32 requiresDedicatedAllocation; +} VkMemoryDedicatedRequirements; + +typedef struct VkMemoryDedicatedAllocateInfo { + VkStructureType sType; + const void* pNext; + VkImage image; + VkBuffer buffer; +} VkMemoryDedicatedAllocateInfo; + +typedef struct VkMemoryAllocateFlagsInfo { + VkStructureType sType; + const void* pNext; + VkMemoryAllocateFlags flags; + uint32_t deviceMask; +} VkMemoryAllocateFlagsInfo; + +typedef struct VkDeviceGroupRenderPassBeginInfo { + VkStructureType sType; + const void* pNext; + uint32_t deviceMask; + uint32_t deviceRenderAreaCount; + const VkRect2D* pDeviceRenderAreas; +} VkDeviceGroupRenderPassBeginInfo; + +typedef struct VkDeviceGroupCommandBufferBeginInfo { + VkStructureType sType; + const void* pNext; + uint32_t deviceMask; +} VkDeviceGroupCommandBufferBeginInfo; + +typedef struct VkDeviceGroupSubmitInfo { + VkStructureType sType; + const void* pNext; + uint32_t waitSemaphoreCount; + const uint32_t* pWaitSemaphoreDeviceIndices; + uint32_t commandBufferCount; + const uint32_t* pCommandBufferDeviceMasks; + uint32_t signalSemaphoreCount; + const uint32_t* pSignalSemaphoreDeviceIndices; +} VkDeviceGroupSubmitInfo; + +typedef struct VkDeviceGroupBindSparseInfo { + VkStructureType sType; + const void* pNext; + uint32_t resourceDeviceIndex; + uint32_t memoryDeviceIndex; +} VkDeviceGroupBindSparseInfo; + +typedef struct VkBindBufferMemoryDeviceGroupInfo { + VkStructureType sType; + const void* pNext; + uint32_t deviceIndexCount; + const uint32_t* pDeviceIndices; +} VkBindBufferMemoryDeviceGroupInfo; + +typedef struct VkBindImageMemoryDeviceGroupInfo { + VkStructureType sType; + const void* pNext; + uint32_t deviceIndexCount; + const uint32_t* pDeviceIndices; + uint32_t splitInstanceBindRegionCount; + const VkRect2D* pSplitInstanceBindRegions; +} VkBindImageMemoryDeviceGroupInfo; + +typedef struct VkPhysicalDeviceGroupProperties { + VkStructureType sType; + void* pNext; + uint32_t physicalDeviceCount; + VkPhysicalDevice physicalDevices[VK_MAX_DEVICE_GROUP_SIZE]; + VkBool32 subsetAllocation; +} VkPhysicalDeviceGroupProperties; + +typedef struct VkDeviceGroupDeviceCreateInfo { + VkStructureType sType; + const void* pNext; + uint32_t physicalDeviceCount; + const VkPhysicalDevice* pPhysicalDevices; +} VkDeviceGroupDeviceCreateInfo; + +typedef struct VkBufferMemoryRequirementsInfo2 { + VkStructureType sType; + const void* pNext; + VkBuffer buffer; +} VkBufferMemoryRequirementsInfo2; + +typedef struct VkImageMemoryRequirementsInfo2 { + VkStructureType sType; + const void* pNext; + VkImage image; +} VkImageMemoryRequirementsInfo2; + +typedef struct VkImageSparseMemoryRequirementsInfo2 { + VkStructureType sType; + const void* pNext; + VkImage image; +} VkImageSparseMemoryRequirementsInfo2; + +typedef struct VkMemoryRequirements2 { + VkStructureType sType; + void* pNext; + VkMemoryRequirements memoryRequirements; +} VkMemoryRequirements2; + +typedef struct VkSparseImageMemoryRequirements2 { + VkStructureType sType; + void* pNext; + VkSparseImageMemoryRequirements memoryRequirements; +} VkSparseImageMemoryRequirements2; + +typedef struct VkPhysicalDeviceFeatures2 { + VkStructureType sType; + void* pNext; + VkPhysicalDeviceFeatures features; +} VkPhysicalDeviceFeatures2; + +typedef struct VkPhysicalDeviceProperties2 { + VkStructureType sType; + void* pNext; + VkPhysicalDeviceProperties properties; +} VkPhysicalDeviceProperties2; + +typedef struct VkFormatProperties2 { + VkStructureType sType; + void* pNext; + VkFormatProperties formatProperties; +} VkFormatProperties2; + +typedef struct VkImageFormatProperties2 { + VkStructureType sType; + void* pNext; + VkImageFormatProperties imageFormatProperties; +} VkImageFormatProperties2; + +typedef struct VkPhysicalDeviceImageFormatInfo2 { + VkStructureType sType; + const void* pNext; + VkFormat format; + VkImageType type; + VkImageTiling tiling; + VkImageUsageFlags usage; + VkImageCreateFlags flags; +} VkPhysicalDeviceImageFormatInfo2; + +typedef struct VkQueueFamilyProperties2 { + VkStructureType sType; + void* pNext; + VkQueueFamilyProperties queueFamilyProperties; +} VkQueueFamilyProperties2; + +typedef struct VkPhysicalDeviceMemoryProperties2 { + VkStructureType sType; + void* pNext; + VkPhysicalDeviceMemoryProperties memoryProperties; +} VkPhysicalDeviceMemoryProperties2; + +typedef struct VkSparseImageFormatProperties2 { + VkStructureType sType; + void* pNext; + VkSparseImageFormatProperties properties; +} VkSparseImageFormatProperties2; + +typedef struct VkPhysicalDeviceSparseImageFormatInfo2 { + VkStructureType sType; + const void* pNext; + VkFormat format; + VkImageType type; + VkSampleCountFlagBits samples; + VkImageUsageFlags usage; + VkImageTiling tiling; +} VkPhysicalDeviceSparseImageFormatInfo2; + +typedef struct VkPhysicalDevicePointClippingProperties { + VkStructureType sType; + void* pNext; + VkPointClippingBehavior pointClippingBehavior; +} VkPhysicalDevicePointClippingProperties; + +typedef struct VkInputAttachmentAspectReference { + uint32_t subpass; + uint32_t inputAttachmentIndex; + VkImageAspectFlags aspectMask; +} VkInputAttachmentAspectReference; + +typedef struct VkRenderPassInputAttachmentAspectCreateInfo { + VkStructureType sType; + const void* pNext; + uint32_t aspectReferenceCount; + const VkInputAttachmentAspectReference* pAspectReferences; +} VkRenderPassInputAttachmentAspectCreateInfo; + +typedef struct VkImageViewUsageCreateInfo { + VkStructureType sType; + const void* pNext; + VkImageUsageFlags usage; +} VkImageViewUsageCreateInfo; + +typedef struct VkPipelineTessellationDomainOriginStateCreateInfo { + VkStructureType sType; + const void* pNext; + VkTessellationDomainOrigin domainOrigin; +} VkPipelineTessellationDomainOriginStateCreateInfo; + +typedef struct VkRenderPassMultiviewCreateInfo { + VkStructureType sType; + const void* pNext; + uint32_t subpassCount; + const uint32_t* pViewMasks; + uint32_t dependencyCount; + const int32_t* pViewOffsets; + uint32_t correlationMaskCount; + const uint32_t* pCorrelationMasks; +} VkRenderPassMultiviewCreateInfo; + +typedef struct VkPhysicalDeviceMultiviewFeatures { + VkStructureType sType; + void* pNext; + VkBool32 multiview; + VkBool32 multiviewGeometryShader; + VkBool32 multiviewTessellationShader; +} VkPhysicalDeviceMultiviewFeatures; + +typedef struct VkPhysicalDeviceMultiviewProperties { + VkStructureType sType; + void* pNext; + uint32_t maxMultiviewViewCount; + uint32_t maxMultiviewInstanceIndex; +} VkPhysicalDeviceMultiviewProperties; + +typedef struct VkPhysicalDeviceVariablePointerFeatures { + VkStructureType sType; + void* pNext; + VkBool32 variablePointersStorageBuffer; + VkBool32 variablePointers; +} VkPhysicalDeviceVariablePointerFeatures; + +typedef struct VkPhysicalDeviceProtectedMemoryFeatures { + VkStructureType sType; + void* pNext; + VkBool32 protectedMemory; +} VkPhysicalDeviceProtectedMemoryFeatures; + +typedef struct VkPhysicalDeviceProtectedMemoryProperties { + VkStructureType sType; + void* pNext; + VkBool32 protectedNoFault; +} VkPhysicalDeviceProtectedMemoryProperties; + +typedef struct VkDeviceQueueInfo2 { + VkStructureType sType; + const void* pNext; + VkDeviceQueueCreateFlags flags; + uint32_t queueFamilyIndex; + uint32_t queueIndex; +} VkDeviceQueueInfo2; + +typedef struct VkProtectedSubmitInfo { + VkStructureType sType; + const void* pNext; + VkBool32 protectedSubmit; +} VkProtectedSubmitInfo; + +typedef struct VkSamplerYcbcrConversionCreateInfo { + VkStructureType sType; + const void* pNext; + VkFormat format; + VkSamplerYcbcrModelConversion ycbcrModel; + VkSamplerYcbcrRange ycbcrRange; + VkComponentMapping components; + VkChromaLocation xChromaOffset; + VkChromaLocation yChromaOffset; + VkFilter chromaFilter; + VkBool32 forceExplicitReconstruction; +} VkSamplerYcbcrConversionCreateInfo; + +typedef struct VkSamplerYcbcrConversionInfo { + VkStructureType sType; + const void* pNext; + VkSamplerYcbcrConversion conversion; +} VkSamplerYcbcrConversionInfo; + +typedef struct VkBindImagePlaneMemoryInfo { + VkStructureType sType; + const void* pNext; + VkImageAspectFlagBits planeAspect; +} VkBindImagePlaneMemoryInfo; + +typedef struct VkImagePlaneMemoryRequirementsInfo { + VkStructureType sType; + const void* pNext; + VkImageAspectFlagBits planeAspect; +} VkImagePlaneMemoryRequirementsInfo; + +typedef struct VkPhysicalDeviceSamplerYcbcrConversionFeatures { + VkStructureType sType; + void* pNext; + VkBool32 samplerYcbcrConversion; +} VkPhysicalDeviceSamplerYcbcrConversionFeatures; + +typedef struct VkSamplerYcbcrConversionImageFormatProperties { + VkStructureType sType; + void* pNext; + uint32_t combinedImageSamplerDescriptorCount; +} VkSamplerYcbcrConversionImageFormatProperties; + +typedef struct VkDescriptorUpdateTemplateEntry { + uint32_t dstBinding; + uint32_t dstArrayElement; + uint32_t descriptorCount; + VkDescriptorType descriptorType; + size_t offset; + size_t stride; +} VkDescriptorUpdateTemplateEntry; + +typedef struct VkDescriptorUpdateTemplateCreateInfo { + VkStructureType sType; + void* pNext; + VkDescriptorUpdateTemplateCreateFlags flags; + uint32_t descriptorUpdateEntryCount; + const VkDescriptorUpdateTemplateEntry* pDescriptorUpdateEntries; + VkDescriptorUpdateTemplateType templateType; + VkDescriptorSetLayout descriptorSetLayout; + VkPipelineBindPoint pipelineBindPoint; + VkPipelineLayout pipelineLayout; + uint32_t set; +} VkDescriptorUpdateTemplateCreateInfo; + +typedef struct VkExternalMemoryProperties { + VkExternalMemoryFeatureFlags externalMemoryFeatures; + VkExternalMemoryHandleTypeFlags exportFromImportedHandleTypes; + VkExternalMemoryHandleTypeFlags compatibleHandleTypes; +} VkExternalMemoryProperties; + +typedef struct VkPhysicalDeviceExternalImageFormatInfo { + VkStructureType sType; + const void* pNext; + VkExternalMemoryHandleTypeFlagBits handleType; +} VkPhysicalDeviceExternalImageFormatInfo; + +typedef struct VkExternalImageFormatProperties { + VkStructureType sType; + void* pNext; + VkExternalMemoryProperties externalMemoryProperties; +} VkExternalImageFormatProperties; + +typedef struct VkPhysicalDeviceExternalBufferInfo { + VkStructureType sType; + const void* pNext; + VkBufferCreateFlags flags; + VkBufferUsageFlags usage; + VkExternalMemoryHandleTypeFlagBits handleType; +} VkPhysicalDeviceExternalBufferInfo; + +typedef struct VkExternalBufferProperties { + VkStructureType sType; + void* pNext; + VkExternalMemoryProperties externalMemoryProperties; +} VkExternalBufferProperties; + +typedef struct VkPhysicalDeviceIDProperties { + VkStructureType sType; + void* pNext; + uint8_t deviceUUID[VK_UUID_SIZE]; + uint8_t driverUUID[VK_UUID_SIZE]; + uint8_t deviceLUID[VK_LUID_SIZE]; + uint32_t deviceNodeMask; + VkBool32 deviceLUIDValid; +} VkPhysicalDeviceIDProperties; + +typedef struct VkExternalMemoryImageCreateInfo { + VkStructureType sType; + const void* pNext; + VkExternalMemoryHandleTypeFlags handleTypes; +} VkExternalMemoryImageCreateInfo; + +typedef struct VkExternalMemoryBufferCreateInfo { + VkStructureType sType; + const void* pNext; + VkExternalMemoryHandleTypeFlags handleTypes; +} VkExternalMemoryBufferCreateInfo; + +typedef struct VkExportMemoryAllocateInfo { + VkStructureType sType; + const void* pNext; + VkExternalMemoryHandleTypeFlags handleTypes; +} VkExportMemoryAllocateInfo; + +typedef struct VkPhysicalDeviceExternalFenceInfo { + VkStructureType sType; + const void* pNext; + VkExternalFenceHandleTypeFlagBits handleType; +} VkPhysicalDeviceExternalFenceInfo; + +typedef struct VkExternalFenceProperties { + VkStructureType sType; + void* pNext; + VkExternalFenceHandleTypeFlags exportFromImportedHandleTypes; + VkExternalFenceHandleTypeFlags compatibleHandleTypes; + VkExternalFenceFeatureFlags externalFenceFeatures; +} VkExternalFenceProperties; + +typedef struct VkExportFenceCreateInfo { + VkStructureType sType; + const void* pNext; + VkExternalFenceHandleTypeFlags handleTypes; +} VkExportFenceCreateInfo; + +typedef struct VkExportSemaphoreCreateInfo { + VkStructureType sType; + const void* pNext; + VkExternalSemaphoreHandleTypeFlags handleTypes; +} VkExportSemaphoreCreateInfo; + +typedef struct VkPhysicalDeviceExternalSemaphoreInfo { + VkStructureType sType; + const void* pNext; + VkExternalSemaphoreHandleTypeFlagBits handleType; +} VkPhysicalDeviceExternalSemaphoreInfo; + +typedef struct VkExternalSemaphoreProperties { + VkStructureType sType; + void* pNext; + VkExternalSemaphoreHandleTypeFlags exportFromImportedHandleTypes; + VkExternalSemaphoreHandleTypeFlags compatibleHandleTypes; + VkExternalSemaphoreFeatureFlags externalSemaphoreFeatures; +} VkExternalSemaphoreProperties; + +typedef struct VkPhysicalDeviceMaintenance3Properties { + VkStructureType sType; + void* pNext; + uint32_t maxPerSetDescriptors; + VkDeviceSize maxMemoryAllocationSize; +} VkPhysicalDeviceMaintenance3Properties; + +typedef struct VkDescriptorSetLayoutSupport { + VkStructureType sType; + void* pNext; + VkBool32 supported; +} VkDescriptorSetLayoutSupport; + +typedef struct VkPhysicalDeviceShaderDrawParameterFeatures { + VkStructureType sType; + void* pNext; + VkBool32 shaderDrawParameters; +} VkPhysicalDeviceShaderDrawParameterFeatures; + + +typedef VkResult (VKAPI_PTR *PFN_vkEnumerateInstanceVersion)(uint32_t* pApiVersion); +typedef VkResult (VKAPI_PTR *PFN_vkBindBufferMemory2)(VkDevice device, uint32_t bindInfoCount, const VkBindBufferMemoryInfo* pBindInfos); +typedef VkResult (VKAPI_PTR *PFN_vkBindImageMemory2)(VkDevice device, uint32_t bindInfoCount, const VkBindImageMemoryInfo* pBindInfos); +typedef void (VKAPI_PTR *PFN_vkGetDeviceGroupPeerMemoryFeatures)(VkDevice device, uint32_t heapIndex, uint32_t localDeviceIndex, uint32_t remoteDeviceIndex, VkPeerMemoryFeatureFlags* pPeerMemoryFeatures); +typedef void (VKAPI_PTR *PFN_vkCmdSetDeviceMask)(VkCommandBuffer commandBuffer, uint32_t deviceMask); +typedef void (VKAPI_PTR *PFN_vkCmdDispatchBase)(VkCommandBuffer commandBuffer, uint32_t baseGroupX, uint32_t baseGroupY, uint32_t baseGroupZ, uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ); +typedef VkResult (VKAPI_PTR *PFN_vkEnumeratePhysicalDeviceGroups)(VkInstance instance, uint32_t* pPhysicalDeviceGroupCount, VkPhysicalDeviceGroupProperties* pPhysicalDeviceGroupProperties); +typedef void (VKAPI_PTR *PFN_vkGetImageMemoryRequirements2)(VkDevice device, const VkImageMemoryRequirementsInfo2* pInfo, VkMemoryRequirements2* pMemoryRequirements); +typedef void (VKAPI_PTR *PFN_vkGetBufferMemoryRequirements2)(VkDevice device, const VkBufferMemoryRequirementsInfo2* pInfo, VkMemoryRequirements2* pMemoryRequirements); +typedef void (VKAPI_PTR *PFN_vkGetImageSparseMemoryRequirements2)(VkDevice device, const VkImageSparseMemoryRequirementsInfo2* pInfo, uint32_t* pSparseMemoryRequirementCount, VkSparseImageMemoryRequirements2* pSparseMemoryRequirements); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFeatures2)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceFeatures2* pFeatures); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceProperties2)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceProperties2* pProperties); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFormatProperties2)(VkPhysicalDevice physicalDevice, VkFormat format, VkFormatProperties2* pFormatProperties); +typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceImageFormatProperties2)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceImageFormatInfo2* pImageFormatInfo, VkImageFormatProperties2* pImageFormatProperties); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceQueueFamilyProperties2)(VkPhysicalDevice physicalDevice, uint32_t* pQueueFamilyPropertyCount, VkQueueFamilyProperties2* pQueueFamilyProperties); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceMemoryProperties2)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceMemoryProperties2* pMemoryProperties); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceSparseImageFormatProperties2)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceSparseImageFormatInfo2* pFormatInfo, uint32_t* pPropertyCount, VkSparseImageFormatProperties2* pProperties); +typedef void (VKAPI_PTR *PFN_vkTrimCommandPool)(VkDevice device, VkCommandPool commandPool, VkCommandPoolTrimFlags flags); +typedef void (VKAPI_PTR *PFN_vkGetDeviceQueue2)(VkDevice device, const VkDeviceQueueInfo2* pQueueInfo, VkQueue* pQueue); +typedef VkResult (VKAPI_PTR *PFN_vkCreateSamplerYcbcrConversion)(VkDevice device, const VkSamplerYcbcrConversionCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSamplerYcbcrConversion* pYcbcrConversion); +typedef void (VKAPI_PTR *PFN_vkDestroySamplerYcbcrConversion)(VkDevice device, VkSamplerYcbcrConversion ycbcrConversion, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkCreateDescriptorUpdateTemplate)(VkDevice device, const VkDescriptorUpdateTemplateCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDescriptorUpdateTemplate* pDescriptorUpdateTemplate); +typedef void (VKAPI_PTR *PFN_vkDestroyDescriptorUpdateTemplate)(VkDevice device, VkDescriptorUpdateTemplate descriptorUpdateTemplate, const VkAllocationCallbacks* pAllocator); +typedef void (VKAPI_PTR *PFN_vkUpdateDescriptorSetWithTemplate)(VkDevice device, VkDescriptorSet descriptorSet, VkDescriptorUpdateTemplate descriptorUpdateTemplate, const void* pData); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceExternalBufferProperties)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalBufferInfo* pExternalBufferInfo, VkExternalBufferProperties* pExternalBufferProperties); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceExternalFenceProperties)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalFenceInfo* pExternalFenceInfo, VkExternalFenceProperties* pExternalFenceProperties); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceExternalSemaphoreProperties)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalSemaphoreInfo* pExternalSemaphoreInfo, VkExternalSemaphoreProperties* pExternalSemaphoreProperties); +typedef void (VKAPI_PTR *PFN_vkGetDescriptorSetLayoutSupport)(VkDevice device, const VkDescriptorSetLayoutCreateInfo* pCreateInfo, VkDescriptorSetLayoutSupport* pSupport); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkEnumerateInstanceVersion( + uint32_t* pApiVersion); + +VKAPI_ATTR VkResult VKAPI_CALL vkBindBufferMemory2( + VkDevice device, + uint32_t bindInfoCount, + const VkBindBufferMemoryInfo* pBindInfos); + +VKAPI_ATTR VkResult VKAPI_CALL vkBindImageMemory2( + VkDevice device, + uint32_t bindInfoCount, + const VkBindImageMemoryInfo* pBindInfos); + +VKAPI_ATTR void VKAPI_CALL vkGetDeviceGroupPeerMemoryFeatures( + VkDevice device, + uint32_t heapIndex, + uint32_t localDeviceIndex, + uint32_t remoteDeviceIndex, + VkPeerMemoryFeatureFlags* pPeerMemoryFeatures); + +VKAPI_ATTR void VKAPI_CALL vkCmdSetDeviceMask( + VkCommandBuffer commandBuffer, + uint32_t deviceMask); + +VKAPI_ATTR void VKAPI_CALL vkCmdDispatchBase( + VkCommandBuffer commandBuffer, + uint32_t baseGroupX, + uint32_t baseGroupY, + uint32_t baseGroupZ, + uint32_t groupCountX, + uint32_t groupCountY, + uint32_t groupCountZ); + +VKAPI_ATTR VkResult VKAPI_CALL vkEnumeratePhysicalDeviceGroups( + VkInstance instance, + uint32_t* pPhysicalDeviceGroupCount, + VkPhysicalDeviceGroupProperties* pPhysicalDeviceGroupProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetImageMemoryRequirements2( + VkDevice device, + const VkImageMemoryRequirementsInfo2* pInfo, + VkMemoryRequirements2* pMemoryRequirements); + +VKAPI_ATTR void VKAPI_CALL vkGetBufferMemoryRequirements2( + VkDevice device, + const VkBufferMemoryRequirementsInfo2* pInfo, + VkMemoryRequirements2* pMemoryRequirements); + +VKAPI_ATTR void VKAPI_CALL vkGetImageSparseMemoryRequirements2( + VkDevice device, + const VkImageSparseMemoryRequirementsInfo2* pInfo, + uint32_t* pSparseMemoryRequirementCount, + VkSparseImageMemoryRequirements2* pSparseMemoryRequirements); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFeatures2( + VkPhysicalDevice physicalDevice, + VkPhysicalDeviceFeatures2* pFeatures); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceProperties2( + VkPhysicalDevice physicalDevice, + VkPhysicalDeviceProperties2* pProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFormatProperties2( + VkPhysicalDevice physicalDevice, + VkFormat format, + VkFormatProperties2* pFormatProperties); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceImageFormatProperties2( + VkPhysicalDevice physicalDevice, + const VkPhysicalDeviceImageFormatInfo2* pImageFormatInfo, + VkImageFormatProperties2* pImageFormatProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceQueueFamilyProperties2( + VkPhysicalDevice physicalDevice, + uint32_t* pQueueFamilyPropertyCount, + VkQueueFamilyProperties2* pQueueFamilyProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceMemoryProperties2( + VkPhysicalDevice physicalDevice, + VkPhysicalDeviceMemoryProperties2* pMemoryProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceSparseImageFormatProperties2( + VkPhysicalDevice physicalDevice, + const VkPhysicalDeviceSparseImageFormatInfo2* pFormatInfo, + uint32_t* pPropertyCount, + VkSparseImageFormatProperties2* pProperties); + +VKAPI_ATTR void VKAPI_CALL vkTrimCommandPool( + VkDevice device, + VkCommandPool commandPool, + VkCommandPoolTrimFlags flags); + +VKAPI_ATTR void VKAPI_CALL vkGetDeviceQueue2( + VkDevice device, + const VkDeviceQueueInfo2* pQueueInfo, + VkQueue* pQueue); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateSamplerYcbcrConversion( + VkDevice device, + const VkSamplerYcbcrConversionCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkSamplerYcbcrConversion* pYcbcrConversion); + +VKAPI_ATTR void VKAPI_CALL vkDestroySamplerYcbcrConversion( + VkDevice device, + VkSamplerYcbcrConversion ycbcrConversion, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateDescriptorUpdateTemplate( + VkDevice device, + const VkDescriptorUpdateTemplateCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkDescriptorUpdateTemplate* pDescriptorUpdateTemplate); + +VKAPI_ATTR void VKAPI_CALL vkDestroyDescriptorUpdateTemplate( + VkDevice device, + VkDescriptorUpdateTemplate descriptorUpdateTemplate, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR void VKAPI_CALL vkUpdateDescriptorSetWithTemplate( + VkDevice device, + VkDescriptorSet descriptorSet, + VkDescriptorUpdateTemplate descriptorUpdateTemplate, + const void* pData); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceExternalBufferProperties( + VkPhysicalDevice physicalDevice, + const VkPhysicalDeviceExternalBufferInfo* pExternalBufferInfo, + VkExternalBufferProperties* pExternalBufferProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceExternalFenceProperties( + VkPhysicalDevice physicalDevice, + const VkPhysicalDeviceExternalFenceInfo* pExternalFenceInfo, + VkExternalFenceProperties* pExternalFenceProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceExternalSemaphoreProperties( + VkPhysicalDevice physicalDevice, + const VkPhysicalDeviceExternalSemaphoreInfo* pExternalSemaphoreInfo, + VkExternalSemaphoreProperties* pExternalSemaphoreProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetDescriptorSetLayoutSupport( + VkDevice device, + const VkDescriptorSetLayoutCreateInfo* pCreateInfo, + VkDescriptorSetLayoutSupport* pSupport); +#endif + +#define VK_KHR_surface 1 +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSurfaceKHR) + +#define VK_KHR_SURFACE_SPEC_VERSION 25 +#define VK_KHR_SURFACE_EXTENSION_NAME "VK_KHR_surface" +#define VK_COLORSPACE_SRGB_NONLINEAR_KHR VK_COLOR_SPACE_SRGB_NONLINEAR_KHR + + +typedef enum VkColorSpaceKHR { + VK_COLOR_SPACE_SRGB_NONLINEAR_KHR = 0, + VK_COLOR_SPACE_DISPLAY_P3_NONLINEAR_EXT = 1000104001, + VK_COLOR_SPACE_EXTENDED_SRGB_LINEAR_EXT = 1000104002, + VK_COLOR_SPACE_DCI_P3_LINEAR_EXT = 1000104003, + VK_COLOR_SPACE_DCI_P3_NONLINEAR_EXT = 1000104004, + VK_COLOR_SPACE_BT709_LINEAR_EXT = 1000104005, + VK_COLOR_SPACE_BT709_NONLINEAR_EXT = 1000104006, + VK_COLOR_SPACE_BT2020_LINEAR_EXT = 1000104007, + VK_COLOR_SPACE_HDR10_ST2084_EXT = 1000104008, + VK_COLOR_SPACE_DOLBYVISION_EXT = 1000104009, + VK_COLOR_SPACE_HDR10_HLG_EXT = 1000104010, + VK_COLOR_SPACE_ADOBERGB_LINEAR_EXT = 1000104011, + VK_COLOR_SPACE_ADOBERGB_NONLINEAR_EXT = 1000104012, + VK_COLOR_SPACE_PASS_THROUGH_EXT = 1000104013, + VK_COLOR_SPACE_EXTENDED_SRGB_NONLINEAR_EXT = 1000104014, + VK_COLOR_SPACE_BEGIN_RANGE_KHR = VK_COLOR_SPACE_SRGB_NONLINEAR_KHR, + VK_COLOR_SPACE_END_RANGE_KHR = VK_COLOR_SPACE_SRGB_NONLINEAR_KHR, + VK_COLOR_SPACE_RANGE_SIZE_KHR = (VK_COLOR_SPACE_SRGB_NONLINEAR_KHR - VK_COLOR_SPACE_SRGB_NONLINEAR_KHR + 1), + VK_COLOR_SPACE_MAX_ENUM_KHR = 0x7FFFFFFF +} VkColorSpaceKHR; + +typedef enum VkPresentModeKHR { + VK_PRESENT_MODE_IMMEDIATE_KHR = 0, + VK_PRESENT_MODE_MAILBOX_KHR = 1, + VK_PRESENT_MODE_FIFO_KHR = 2, + VK_PRESENT_MODE_FIFO_RELAXED_KHR = 3, + VK_PRESENT_MODE_SHARED_DEMAND_REFRESH_KHR = 1000111000, + VK_PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR = 1000111001, + VK_PRESENT_MODE_BEGIN_RANGE_KHR = VK_PRESENT_MODE_IMMEDIATE_KHR, + VK_PRESENT_MODE_END_RANGE_KHR = VK_PRESENT_MODE_FIFO_RELAXED_KHR, + VK_PRESENT_MODE_RANGE_SIZE_KHR = (VK_PRESENT_MODE_FIFO_RELAXED_KHR - VK_PRESENT_MODE_IMMEDIATE_KHR + 1), + VK_PRESENT_MODE_MAX_ENUM_KHR = 0x7FFFFFFF +} VkPresentModeKHR; + + +typedef enum VkSurfaceTransformFlagBitsKHR { + VK_SURFACE_TRANSFORM_IDENTITY_BIT_KHR = 0x00000001, + VK_SURFACE_TRANSFORM_ROTATE_90_BIT_KHR = 0x00000002, + VK_SURFACE_TRANSFORM_ROTATE_180_BIT_KHR = 0x00000004, + VK_SURFACE_TRANSFORM_ROTATE_270_BIT_KHR = 0x00000008, + VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_BIT_KHR = 0x00000010, + VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_90_BIT_KHR = 0x00000020, + VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_180_BIT_KHR = 0x00000040, + VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_270_BIT_KHR = 0x00000080, + VK_SURFACE_TRANSFORM_INHERIT_BIT_KHR = 0x00000100, + VK_SURFACE_TRANSFORM_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF +} VkSurfaceTransformFlagBitsKHR; +typedef VkFlags VkSurfaceTransformFlagsKHR; + +typedef enum VkCompositeAlphaFlagBitsKHR { + VK_COMPOSITE_ALPHA_OPAQUE_BIT_KHR = 0x00000001, + VK_COMPOSITE_ALPHA_PRE_MULTIPLIED_BIT_KHR = 0x00000002, + VK_COMPOSITE_ALPHA_POST_MULTIPLIED_BIT_KHR = 0x00000004, + VK_COMPOSITE_ALPHA_INHERIT_BIT_KHR = 0x00000008, + VK_COMPOSITE_ALPHA_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF +} VkCompositeAlphaFlagBitsKHR; +typedef VkFlags VkCompositeAlphaFlagsKHR; + +typedef struct VkSurfaceCapabilitiesKHR { + uint32_t minImageCount; + uint32_t maxImageCount; + VkExtent2D currentExtent; + VkExtent2D minImageExtent; + VkExtent2D maxImageExtent; + uint32_t maxImageArrayLayers; + VkSurfaceTransformFlagsKHR supportedTransforms; + VkSurfaceTransformFlagBitsKHR currentTransform; + VkCompositeAlphaFlagsKHR supportedCompositeAlpha; + VkImageUsageFlags supportedUsageFlags; +} VkSurfaceCapabilitiesKHR; + +typedef struct VkSurfaceFormatKHR { + VkFormat format; + VkColorSpaceKHR colorSpace; +} VkSurfaceFormatKHR; + + +typedef void (VKAPI_PTR *PFN_vkDestroySurfaceKHR)(VkInstance instance, VkSurfaceKHR surface, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceSupportKHR)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, VkSurfaceKHR surface, VkBool32* pSupported); +typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceCapabilitiesKHR)(VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, VkSurfaceCapabilitiesKHR* pSurfaceCapabilities); +typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceFormatsKHR)(VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, uint32_t* pSurfaceFormatCount, VkSurfaceFormatKHR* pSurfaceFormats); +typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfacePresentModesKHR)(VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, uint32_t* pPresentModeCount, VkPresentModeKHR* pPresentModes); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkDestroySurfaceKHR( + VkInstance instance, + VkSurfaceKHR surface, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceSupportKHR( + VkPhysicalDevice physicalDevice, + uint32_t queueFamilyIndex, + VkSurfaceKHR surface, + VkBool32* pSupported); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceCapabilitiesKHR( + VkPhysicalDevice physicalDevice, + VkSurfaceKHR surface, + VkSurfaceCapabilitiesKHR* pSurfaceCapabilities); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceFormatsKHR( + VkPhysicalDevice physicalDevice, + VkSurfaceKHR surface, + uint32_t* pSurfaceFormatCount, + VkSurfaceFormatKHR* pSurfaceFormats); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfacePresentModesKHR( + VkPhysicalDevice physicalDevice, + VkSurfaceKHR surface, + uint32_t* pPresentModeCount, + VkPresentModeKHR* pPresentModes); +#endif + +#define VK_KHR_swapchain 1 +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSwapchainKHR) + +#define VK_KHR_SWAPCHAIN_SPEC_VERSION 70 +#define VK_KHR_SWAPCHAIN_EXTENSION_NAME "VK_KHR_swapchain" + + +typedef enum VkSwapchainCreateFlagBitsKHR { + VK_SWAPCHAIN_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT_KHR = 0x00000001, + VK_SWAPCHAIN_CREATE_PROTECTED_BIT_KHR = 0x00000002, + VK_SWAPCHAIN_CREATE_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF +} VkSwapchainCreateFlagBitsKHR; +typedef VkFlags VkSwapchainCreateFlagsKHR; + +typedef enum VkDeviceGroupPresentModeFlagBitsKHR { + VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_BIT_KHR = 0x00000001, + VK_DEVICE_GROUP_PRESENT_MODE_REMOTE_BIT_KHR = 0x00000002, + VK_DEVICE_GROUP_PRESENT_MODE_SUM_BIT_KHR = 0x00000004, + VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_MULTI_DEVICE_BIT_KHR = 0x00000008, + VK_DEVICE_GROUP_PRESENT_MODE_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF +} VkDeviceGroupPresentModeFlagBitsKHR; +typedef VkFlags VkDeviceGroupPresentModeFlagsKHR; + +typedef struct VkSwapchainCreateInfoKHR { + VkStructureType sType; + const void* pNext; + VkSwapchainCreateFlagsKHR flags; + VkSurfaceKHR surface; + uint32_t minImageCount; + VkFormat imageFormat; + VkColorSpaceKHR imageColorSpace; + VkExtent2D imageExtent; + uint32_t imageArrayLayers; + VkImageUsageFlags imageUsage; + VkSharingMode imageSharingMode; + uint32_t queueFamilyIndexCount; + const uint32_t* pQueueFamilyIndices; + VkSurfaceTransformFlagBitsKHR preTransform; + VkCompositeAlphaFlagBitsKHR compositeAlpha; + VkPresentModeKHR presentMode; + VkBool32 clipped; + VkSwapchainKHR oldSwapchain; +} VkSwapchainCreateInfoKHR; + +typedef struct VkPresentInfoKHR { + VkStructureType sType; + const void* pNext; + uint32_t waitSemaphoreCount; + const VkSemaphore* pWaitSemaphores; + uint32_t swapchainCount; + const VkSwapchainKHR* pSwapchains; + const uint32_t* pImageIndices; + VkResult* pResults; +} VkPresentInfoKHR; + +typedef struct VkImageSwapchainCreateInfoKHR { + VkStructureType sType; + const void* pNext; + VkSwapchainKHR swapchain; +} VkImageSwapchainCreateInfoKHR; + +typedef struct VkBindImageMemorySwapchainInfoKHR { + VkStructureType sType; + const void* pNext; + VkSwapchainKHR swapchain; + uint32_t imageIndex; +} VkBindImageMemorySwapchainInfoKHR; + +typedef struct VkAcquireNextImageInfoKHR { + VkStructureType sType; + const void* pNext; + VkSwapchainKHR swapchain; + uint64_t timeout; + VkSemaphore semaphore; + VkFence fence; + uint32_t deviceMask; +} VkAcquireNextImageInfoKHR; + +typedef struct VkDeviceGroupPresentCapabilitiesKHR { + VkStructureType sType; + const void* pNext; + uint32_t presentMask[VK_MAX_DEVICE_GROUP_SIZE]; + VkDeviceGroupPresentModeFlagsKHR modes; +} VkDeviceGroupPresentCapabilitiesKHR; + +typedef struct VkDeviceGroupPresentInfoKHR { + VkStructureType sType; + const void* pNext; + uint32_t swapchainCount; + const uint32_t* pDeviceMasks; + VkDeviceGroupPresentModeFlagBitsKHR mode; +} VkDeviceGroupPresentInfoKHR; + +typedef struct VkDeviceGroupSwapchainCreateInfoKHR { + VkStructureType sType; + const void* pNext; + VkDeviceGroupPresentModeFlagsKHR modes; +} VkDeviceGroupSwapchainCreateInfoKHR; + + +typedef VkResult (VKAPI_PTR *PFN_vkCreateSwapchainKHR)(VkDevice device, const VkSwapchainCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSwapchainKHR* pSwapchain); +typedef void (VKAPI_PTR *PFN_vkDestroySwapchainKHR)(VkDevice device, VkSwapchainKHR swapchain, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkGetSwapchainImagesKHR)(VkDevice device, VkSwapchainKHR swapchain, uint32_t* pSwapchainImageCount, VkImage* pSwapchainImages); +typedef VkResult (VKAPI_PTR *PFN_vkAcquireNextImageKHR)(VkDevice device, VkSwapchainKHR swapchain, uint64_t timeout, VkSemaphore semaphore, VkFence fence, uint32_t* pImageIndex); +typedef VkResult (VKAPI_PTR *PFN_vkQueuePresentKHR)(VkQueue queue, const VkPresentInfoKHR* pPresentInfo); +typedef VkResult (VKAPI_PTR *PFN_vkGetDeviceGroupPresentCapabilitiesKHR)(VkDevice device, VkDeviceGroupPresentCapabilitiesKHR* pDeviceGroupPresentCapabilities); +typedef VkResult (VKAPI_PTR *PFN_vkGetDeviceGroupSurfacePresentModesKHR)(VkDevice device, VkSurfaceKHR surface, VkDeviceGroupPresentModeFlagsKHR* pModes); +typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDevicePresentRectanglesKHR)(VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, uint32_t* pRectCount, VkRect2D* pRects); +typedef VkResult (VKAPI_PTR *PFN_vkAcquireNextImage2KHR)(VkDevice device, const VkAcquireNextImageInfoKHR* pAcquireInfo, uint32_t* pImageIndex); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkCreateSwapchainKHR( + VkDevice device, + const VkSwapchainCreateInfoKHR* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkSwapchainKHR* pSwapchain); + +VKAPI_ATTR void VKAPI_CALL vkDestroySwapchainKHR( + VkDevice device, + VkSwapchainKHR swapchain, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetSwapchainImagesKHR( + VkDevice device, + VkSwapchainKHR swapchain, + uint32_t* pSwapchainImageCount, + VkImage* pSwapchainImages); + +VKAPI_ATTR VkResult VKAPI_CALL vkAcquireNextImageKHR( + VkDevice device, + VkSwapchainKHR swapchain, + uint64_t timeout, + VkSemaphore semaphore, + VkFence fence, + uint32_t* pImageIndex); + +VKAPI_ATTR VkResult VKAPI_CALL vkQueuePresentKHR( + VkQueue queue, + const VkPresentInfoKHR* pPresentInfo); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetDeviceGroupPresentCapabilitiesKHR( + VkDevice device, + VkDeviceGroupPresentCapabilitiesKHR* pDeviceGroupPresentCapabilities); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetDeviceGroupSurfacePresentModesKHR( + VkDevice device, + VkSurfaceKHR surface, + VkDeviceGroupPresentModeFlagsKHR* pModes); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDevicePresentRectanglesKHR( + VkPhysicalDevice physicalDevice, + VkSurfaceKHR surface, + uint32_t* pRectCount, + VkRect2D* pRects); + +VKAPI_ATTR VkResult VKAPI_CALL vkAcquireNextImage2KHR( + VkDevice device, + const VkAcquireNextImageInfoKHR* pAcquireInfo, + uint32_t* pImageIndex); +#endif + +#define VK_KHR_display 1 +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDisplayKHR) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDisplayModeKHR) + +#define VK_KHR_DISPLAY_SPEC_VERSION 21 +#define VK_KHR_DISPLAY_EXTENSION_NAME "VK_KHR_display" + + +typedef enum VkDisplayPlaneAlphaFlagBitsKHR { + VK_DISPLAY_PLANE_ALPHA_OPAQUE_BIT_KHR = 0x00000001, + VK_DISPLAY_PLANE_ALPHA_GLOBAL_BIT_KHR = 0x00000002, + VK_DISPLAY_PLANE_ALPHA_PER_PIXEL_BIT_KHR = 0x00000004, + VK_DISPLAY_PLANE_ALPHA_PER_PIXEL_PREMULTIPLIED_BIT_KHR = 0x00000008, + VK_DISPLAY_PLANE_ALPHA_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF +} VkDisplayPlaneAlphaFlagBitsKHR; +typedef VkFlags VkDisplayPlaneAlphaFlagsKHR; +typedef VkFlags VkDisplayModeCreateFlagsKHR; +typedef VkFlags VkDisplaySurfaceCreateFlagsKHR; + +typedef struct VkDisplayPropertiesKHR { + VkDisplayKHR display; + const char* displayName; + VkExtent2D physicalDimensions; + VkExtent2D physicalResolution; + VkSurfaceTransformFlagsKHR supportedTransforms; + VkBool32 planeReorderPossible; + VkBool32 persistentContent; +} VkDisplayPropertiesKHR; + +typedef struct VkDisplayModeParametersKHR { + VkExtent2D visibleRegion; + uint32_t refreshRate; +} VkDisplayModeParametersKHR; + +typedef struct VkDisplayModePropertiesKHR { + VkDisplayModeKHR displayMode; + VkDisplayModeParametersKHR parameters; +} VkDisplayModePropertiesKHR; + +typedef struct VkDisplayModeCreateInfoKHR { + VkStructureType sType; + const void* pNext; + VkDisplayModeCreateFlagsKHR flags; + VkDisplayModeParametersKHR parameters; +} VkDisplayModeCreateInfoKHR; + +typedef struct VkDisplayPlaneCapabilitiesKHR { + VkDisplayPlaneAlphaFlagsKHR supportedAlpha; + VkOffset2D minSrcPosition; + VkOffset2D maxSrcPosition; + VkExtent2D minSrcExtent; + VkExtent2D maxSrcExtent; + VkOffset2D minDstPosition; + VkOffset2D maxDstPosition; + VkExtent2D minDstExtent; + VkExtent2D maxDstExtent; +} VkDisplayPlaneCapabilitiesKHR; + +typedef struct VkDisplayPlanePropertiesKHR { + VkDisplayKHR currentDisplay; + uint32_t currentStackIndex; +} VkDisplayPlanePropertiesKHR; + +typedef struct VkDisplaySurfaceCreateInfoKHR { + VkStructureType sType; + const void* pNext; + VkDisplaySurfaceCreateFlagsKHR flags; + VkDisplayModeKHR displayMode; + uint32_t planeIndex; + uint32_t planeStackIndex; + VkSurfaceTransformFlagBitsKHR transform; + float globalAlpha; + VkDisplayPlaneAlphaFlagBitsKHR alphaMode; + VkExtent2D imageExtent; +} VkDisplaySurfaceCreateInfoKHR; + + +typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceDisplayPropertiesKHR)(VkPhysicalDevice physicalDevice, uint32_t* pPropertyCount, VkDisplayPropertiesKHR* pProperties); +typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceDisplayPlanePropertiesKHR)(VkPhysicalDevice physicalDevice, uint32_t* pPropertyCount, VkDisplayPlanePropertiesKHR* pProperties); +typedef VkResult (VKAPI_PTR *PFN_vkGetDisplayPlaneSupportedDisplaysKHR)(VkPhysicalDevice physicalDevice, uint32_t planeIndex, uint32_t* pDisplayCount, VkDisplayKHR* pDisplays); +typedef VkResult (VKAPI_PTR *PFN_vkGetDisplayModePropertiesKHR)(VkPhysicalDevice physicalDevice, VkDisplayKHR display, uint32_t* pPropertyCount, VkDisplayModePropertiesKHR* pProperties); +typedef VkResult (VKAPI_PTR *PFN_vkCreateDisplayModeKHR)(VkPhysicalDevice physicalDevice, VkDisplayKHR display, const VkDisplayModeCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDisplayModeKHR* pMode); +typedef VkResult (VKAPI_PTR *PFN_vkGetDisplayPlaneCapabilitiesKHR)(VkPhysicalDevice physicalDevice, VkDisplayModeKHR mode, uint32_t planeIndex, VkDisplayPlaneCapabilitiesKHR* pCapabilities); +typedef VkResult (VKAPI_PTR *PFN_vkCreateDisplayPlaneSurfaceKHR)(VkInstance instance, const VkDisplaySurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceDisplayPropertiesKHR( + VkPhysicalDevice physicalDevice, + uint32_t* pPropertyCount, + VkDisplayPropertiesKHR* pProperties); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceDisplayPlanePropertiesKHR( + VkPhysicalDevice physicalDevice, + uint32_t* pPropertyCount, + VkDisplayPlanePropertiesKHR* pProperties); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetDisplayPlaneSupportedDisplaysKHR( + VkPhysicalDevice physicalDevice, + uint32_t planeIndex, + uint32_t* pDisplayCount, + VkDisplayKHR* pDisplays); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetDisplayModePropertiesKHR( + VkPhysicalDevice physicalDevice, + VkDisplayKHR display, + uint32_t* pPropertyCount, + VkDisplayModePropertiesKHR* pProperties); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateDisplayModeKHR( + VkPhysicalDevice physicalDevice, + VkDisplayKHR display, + const VkDisplayModeCreateInfoKHR* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkDisplayModeKHR* pMode); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetDisplayPlaneCapabilitiesKHR( + VkPhysicalDevice physicalDevice, + VkDisplayModeKHR mode, + uint32_t planeIndex, + VkDisplayPlaneCapabilitiesKHR* pCapabilities); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateDisplayPlaneSurfaceKHR( + VkInstance instance, + const VkDisplaySurfaceCreateInfoKHR* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkSurfaceKHR* pSurface); +#endif + +#define VK_KHR_display_swapchain 1 +#define VK_KHR_DISPLAY_SWAPCHAIN_SPEC_VERSION 9 +#define VK_KHR_DISPLAY_SWAPCHAIN_EXTENSION_NAME "VK_KHR_display_swapchain" + +typedef struct VkDisplayPresentInfoKHR { + VkStructureType sType; + const void* pNext; + VkRect2D srcRect; + VkRect2D dstRect; + VkBool32 persistent; +} VkDisplayPresentInfoKHR; + + +typedef VkResult (VKAPI_PTR *PFN_vkCreateSharedSwapchainsKHR)(VkDevice device, uint32_t swapchainCount, const VkSwapchainCreateInfoKHR* pCreateInfos, const VkAllocationCallbacks* pAllocator, VkSwapchainKHR* pSwapchains); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkCreateSharedSwapchainsKHR( + VkDevice device, + uint32_t swapchainCount, + const VkSwapchainCreateInfoKHR* pCreateInfos, + const VkAllocationCallbacks* pAllocator, + VkSwapchainKHR* pSwapchains); +#endif + +#define VK_KHR_sampler_mirror_clamp_to_edge 1 +#define VK_KHR_SAMPLER_MIRROR_CLAMP_TO_EDGE_SPEC_VERSION 1 +#define VK_KHR_SAMPLER_MIRROR_CLAMP_TO_EDGE_EXTENSION_NAME "VK_KHR_sampler_mirror_clamp_to_edge" + + +#define VK_KHR_multiview 1 +#define VK_KHR_MULTIVIEW_SPEC_VERSION 1 +#define VK_KHR_MULTIVIEW_EXTENSION_NAME "VK_KHR_multiview" + +typedef VkRenderPassMultiviewCreateInfo VkRenderPassMultiviewCreateInfoKHR; + +typedef VkPhysicalDeviceMultiviewFeatures VkPhysicalDeviceMultiviewFeaturesKHR; + +typedef VkPhysicalDeviceMultiviewProperties VkPhysicalDeviceMultiviewPropertiesKHR; + + + +#define VK_KHR_get_physical_device_properties2 1 +#define VK_KHR_GET_PHYSICAL_DEVICE_PROPERTIES_2_SPEC_VERSION 1 +#define VK_KHR_GET_PHYSICAL_DEVICE_PROPERTIES_2_EXTENSION_NAME "VK_KHR_get_physical_device_properties2" + +typedef VkPhysicalDeviceFeatures2 VkPhysicalDeviceFeatures2KHR; + +typedef VkPhysicalDeviceProperties2 VkPhysicalDeviceProperties2KHR; + +typedef VkFormatProperties2 VkFormatProperties2KHR; + +typedef VkImageFormatProperties2 VkImageFormatProperties2KHR; + +typedef VkPhysicalDeviceImageFormatInfo2 VkPhysicalDeviceImageFormatInfo2KHR; + +typedef VkQueueFamilyProperties2 VkQueueFamilyProperties2KHR; + +typedef VkPhysicalDeviceMemoryProperties2 VkPhysicalDeviceMemoryProperties2KHR; + +typedef VkSparseImageFormatProperties2 VkSparseImageFormatProperties2KHR; + +typedef VkPhysicalDeviceSparseImageFormatInfo2 VkPhysicalDeviceSparseImageFormatInfo2KHR; + + +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFeatures2KHR)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceFeatures2* pFeatures); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceProperties2KHR)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceProperties2* pProperties); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFormatProperties2KHR)(VkPhysicalDevice physicalDevice, VkFormat format, VkFormatProperties2* pFormatProperties); +typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceImageFormatProperties2KHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceImageFormatInfo2* pImageFormatInfo, VkImageFormatProperties2* pImageFormatProperties); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceQueueFamilyProperties2KHR)(VkPhysicalDevice physicalDevice, uint32_t* pQueueFamilyPropertyCount, VkQueueFamilyProperties2* pQueueFamilyProperties); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceMemoryProperties2KHR)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceMemoryProperties2* pMemoryProperties); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceSparseImageFormatProperties2KHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceSparseImageFormatInfo2* pFormatInfo, uint32_t* pPropertyCount, VkSparseImageFormatProperties2* pProperties); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFeatures2KHR( + VkPhysicalDevice physicalDevice, + VkPhysicalDeviceFeatures2* pFeatures); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceProperties2KHR( + VkPhysicalDevice physicalDevice, + VkPhysicalDeviceProperties2* pProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFormatProperties2KHR( + VkPhysicalDevice physicalDevice, + VkFormat format, + VkFormatProperties2* pFormatProperties); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceImageFormatProperties2KHR( + VkPhysicalDevice physicalDevice, + const VkPhysicalDeviceImageFormatInfo2* pImageFormatInfo, + VkImageFormatProperties2* pImageFormatProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceQueueFamilyProperties2KHR( + VkPhysicalDevice physicalDevice, + uint32_t* pQueueFamilyPropertyCount, + VkQueueFamilyProperties2* pQueueFamilyProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceMemoryProperties2KHR( + VkPhysicalDevice physicalDevice, + VkPhysicalDeviceMemoryProperties2* pMemoryProperties); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceSparseImageFormatProperties2KHR( + VkPhysicalDevice physicalDevice, + const VkPhysicalDeviceSparseImageFormatInfo2* pFormatInfo, + uint32_t* pPropertyCount, + VkSparseImageFormatProperties2* pProperties); +#endif + +#define VK_KHR_device_group 1 +#define VK_KHR_DEVICE_GROUP_SPEC_VERSION 3 +#define VK_KHR_DEVICE_GROUP_EXTENSION_NAME "VK_KHR_device_group" + +typedef VkPeerMemoryFeatureFlags VkPeerMemoryFeatureFlagsKHR; + +typedef VkPeerMemoryFeatureFlagBits VkPeerMemoryFeatureFlagBitsKHR; + +typedef VkMemoryAllocateFlags VkMemoryAllocateFlagsKHR; + +typedef VkMemoryAllocateFlagBits VkMemoryAllocateFlagBitsKHR; + + +typedef VkMemoryAllocateFlagsInfo VkMemoryAllocateFlagsInfoKHR; + +typedef VkDeviceGroupRenderPassBeginInfo VkDeviceGroupRenderPassBeginInfoKHR; + +typedef VkDeviceGroupCommandBufferBeginInfo VkDeviceGroupCommandBufferBeginInfoKHR; + +typedef VkDeviceGroupSubmitInfo VkDeviceGroupSubmitInfoKHR; + +typedef VkDeviceGroupBindSparseInfo VkDeviceGroupBindSparseInfoKHR; + +typedef VkBindBufferMemoryDeviceGroupInfo VkBindBufferMemoryDeviceGroupInfoKHR; + +typedef VkBindImageMemoryDeviceGroupInfo VkBindImageMemoryDeviceGroupInfoKHR; + + +typedef void (VKAPI_PTR *PFN_vkGetDeviceGroupPeerMemoryFeaturesKHR)(VkDevice device, uint32_t heapIndex, uint32_t localDeviceIndex, uint32_t remoteDeviceIndex, VkPeerMemoryFeatureFlags* pPeerMemoryFeatures); +typedef void (VKAPI_PTR *PFN_vkCmdSetDeviceMaskKHR)(VkCommandBuffer commandBuffer, uint32_t deviceMask); +typedef void (VKAPI_PTR *PFN_vkCmdDispatchBaseKHR)(VkCommandBuffer commandBuffer, uint32_t baseGroupX, uint32_t baseGroupY, uint32_t baseGroupZ, uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkGetDeviceGroupPeerMemoryFeaturesKHR( + VkDevice device, + uint32_t heapIndex, + uint32_t localDeviceIndex, + uint32_t remoteDeviceIndex, + VkPeerMemoryFeatureFlags* pPeerMemoryFeatures); + +VKAPI_ATTR void VKAPI_CALL vkCmdSetDeviceMaskKHR( + VkCommandBuffer commandBuffer, + uint32_t deviceMask); + +VKAPI_ATTR void VKAPI_CALL vkCmdDispatchBaseKHR( + VkCommandBuffer commandBuffer, + uint32_t baseGroupX, + uint32_t baseGroupY, + uint32_t baseGroupZ, + uint32_t groupCountX, + uint32_t groupCountY, + uint32_t groupCountZ); +#endif + +#define VK_KHR_shader_draw_parameters 1 +#define VK_KHR_SHADER_DRAW_PARAMETERS_SPEC_VERSION 1 +#define VK_KHR_SHADER_DRAW_PARAMETERS_EXTENSION_NAME "VK_KHR_shader_draw_parameters" + + +#define VK_KHR_maintenance1 1 +#define VK_KHR_MAINTENANCE1_SPEC_VERSION 1 +#define VK_KHR_MAINTENANCE1_EXTENSION_NAME "VK_KHR_maintenance1" + +typedef VkCommandPoolTrimFlags VkCommandPoolTrimFlagsKHR; + + +typedef void (VKAPI_PTR *PFN_vkTrimCommandPoolKHR)(VkDevice device, VkCommandPool commandPool, VkCommandPoolTrimFlags flags); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkTrimCommandPoolKHR( + VkDevice device, + VkCommandPool commandPool, + VkCommandPoolTrimFlags flags); +#endif + +#define VK_KHR_device_group_creation 1 +#define VK_KHR_DEVICE_GROUP_CREATION_SPEC_VERSION 1 +#define VK_KHR_DEVICE_GROUP_CREATION_EXTENSION_NAME "VK_KHR_device_group_creation" +#define VK_MAX_DEVICE_GROUP_SIZE_KHR VK_MAX_DEVICE_GROUP_SIZE + +typedef VkPhysicalDeviceGroupProperties VkPhysicalDeviceGroupPropertiesKHR; + +typedef VkDeviceGroupDeviceCreateInfo VkDeviceGroupDeviceCreateInfoKHR; + + +typedef VkResult (VKAPI_PTR *PFN_vkEnumeratePhysicalDeviceGroupsKHR)(VkInstance instance, uint32_t* pPhysicalDeviceGroupCount, VkPhysicalDeviceGroupProperties* pPhysicalDeviceGroupProperties); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkEnumeratePhysicalDeviceGroupsKHR( + VkInstance instance, + uint32_t* pPhysicalDeviceGroupCount, + VkPhysicalDeviceGroupProperties* pPhysicalDeviceGroupProperties); +#endif + +#define VK_KHR_external_memory_capabilities 1 +#define VK_KHR_EXTERNAL_MEMORY_CAPABILITIES_SPEC_VERSION 1 +#define VK_KHR_EXTERNAL_MEMORY_CAPABILITIES_EXTENSION_NAME "VK_KHR_external_memory_capabilities" +#define VK_LUID_SIZE_KHR VK_LUID_SIZE + +typedef VkExternalMemoryHandleTypeFlags VkExternalMemoryHandleTypeFlagsKHR; + +typedef VkExternalMemoryHandleTypeFlagBits VkExternalMemoryHandleTypeFlagBitsKHR; + +typedef VkExternalMemoryFeatureFlags VkExternalMemoryFeatureFlagsKHR; + +typedef VkExternalMemoryFeatureFlagBits VkExternalMemoryFeatureFlagBitsKHR; + + +typedef VkExternalMemoryProperties VkExternalMemoryPropertiesKHR; + +typedef VkPhysicalDeviceExternalImageFormatInfo VkPhysicalDeviceExternalImageFormatInfoKHR; + +typedef VkExternalImageFormatProperties VkExternalImageFormatPropertiesKHR; + +typedef VkPhysicalDeviceExternalBufferInfo VkPhysicalDeviceExternalBufferInfoKHR; + +typedef VkExternalBufferProperties VkExternalBufferPropertiesKHR; + +typedef VkPhysicalDeviceIDProperties VkPhysicalDeviceIDPropertiesKHR; + + +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceExternalBufferPropertiesKHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalBufferInfo* pExternalBufferInfo, VkExternalBufferProperties* pExternalBufferProperties); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceExternalBufferPropertiesKHR( + VkPhysicalDevice physicalDevice, + const VkPhysicalDeviceExternalBufferInfo* pExternalBufferInfo, + VkExternalBufferProperties* pExternalBufferProperties); +#endif + +#define VK_KHR_external_memory 1 +#define VK_KHR_EXTERNAL_MEMORY_SPEC_VERSION 1 +#define VK_KHR_EXTERNAL_MEMORY_EXTENSION_NAME "VK_KHR_external_memory" +#define VK_QUEUE_FAMILY_EXTERNAL_KHR VK_QUEUE_FAMILY_EXTERNAL + +typedef VkExternalMemoryImageCreateInfo VkExternalMemoryImageCreateInfoKHR; + +typedef VkExternalMemoryBufferCreateInfo VkExternalMemoryBufferCreateInfoKHR; + +typedef VkExportMemoryAllocateInfo VkExportMemoryAllocateInfoKHR; + + + +#define VK_KHR_external_memory_fd 1 +#define VK_KHR_EXTERNAL_MEMORY_FD_SPEC_VERSION 1 +#define VK_KHR_EXTERNAL_MEMORY_FD_EXTENSION_NAME "VK_KHR_external_memory_fd" + +typedef struct VkImportMemoryFdInfoKHR { + VkStructureType sType; + const void* pNext; + VkExternalMemoryHandleTypeFlagBits handleType; + int fd; +} VkImportMemoryFdInfoKHR; + +typedef struct VkMemoryFdPropertiesKHR { + VkStructureType sType; + void* pNext; + uint32_t memoryTypeBits; +} VkMemoryFdPropertiesKHR; + +typedef struct VkMemoryGetFdInfoKHR { + VkStructureType sType; + const void* pNext; + VkDeviceMemory memory; + VkExternalMemoryHandleTypeFlagBits handleType; +} VkMemoryGetFdInfoKHR; + + +typedef VkResult (VKAPI_PTR *PFN_vkGetMemoryFdKHR)(VkDevice device, const VkMemoryGetFdInfoKHR* pGetFdInfo, int* pFd); +typedef VkResult (VKAPI_PTR *PFN_vkGetMemoryFdPropertiesKHR)(VkDevice device, VkExternalMemoryHandleTypeFlagBits handleType, int fd, VkMemoryFdPropertiesKHR* pMemoryFdProperties); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryFdKHR( + VkDevice device, + const VkMemoryGetFdInfoKHR* pGetFdInfo, + int* pFd); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryFdPropertiesKHR( + VkDevice device, + VkExternalMemoryHandleTypeFlagBits handleType, + int fd, + VkMemoryFdPropertiesKHR* pMemoryFdProperties); +#endif + +#define VK_KHR_external_semaphore_capabilities 1 +#define VK_KHR_EXTERNAL_SEMAPHORE_CAPABILITIES_SPEC_VERSION 1 +#define VK_KHR_EXTERNAL_SEMAPHORE_CAPABILITIES_EXTENSION_NAME "VK_KHR_external_semaphore_capabilities" + +typedef VkExternalSemaphoreHandleTypeFlags VkExternalSemaphoreHandleTypeFlagsKHR; + +typedef VkExternalSemaphoreHandleTypeFlagBits VkExternalSemaphoreHandleTypeFlagBitsKHR; + +typedef VkExternalSemaphoreFeatureFlags VkExternalSemaphoreFeatureFlagsKHR; + +typedef VkExternalSemaphoreFeatureFlagBits VkExternalSemaphoreFeatureFlagBitsKHR; + + +typedef VkPhysicalDeviceExternalSemaphoreInfo VkPhysicalDeviceExternalSemaphoreInfoKHR; + +typedef VkExternalSemaphoreProperties VkExternalSemaphorePropertiesKHR; + + +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceExternalSemaphorePropertiesKHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalSemaphoreInfo* pExternalSemaphoreInfo, VkExternalSemaphoreProperties* pExternalSemaphoreProperties); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceExternalSemaphorePropertiesKHR( + VkPhysicalDevice physicalDevice, + const VkPhysicalDeviceExternalSemaphoreInfo* pExternalSemaphoreInfo, + VkExternalSemaphoreProperties* pExternalSemaphoreProperties); +#endif + +#define VK_KHR_external_semaphore 1 +#define VK_KHR_EXTERNAL_SEMAPHORE_SPEC_VERSION 1 +#define VK_KHR_EXTERNAL_SEMAPHORE_EXTENSION_NAME "VK_KHR_external_semaphore" + +typedef VkSemaphoreImportFlags VkSemaphoreImportFlagsKHR; + +typedef VkSemaphoreImportFlagBits VkSemaphoreImportFlagBitsKHR; + + +typedef VkExportSemaphoreCreateInfo VkExportSemaphoreCreateInfoKHR; + + + +#define VK_KHR_external_semaphore_fd 1 +#define VK_KHR_EXTERNAL_SEMAPHORE_FD_SPEC_VERSION 1 +#define VK_KHR_EXTERNAL_SEMAPHORE_FD_EXTENSION_NAME "VK_KHR_external_semaphore_fd" + +typedef struct VkImportSemaphoreFdInfoKHR { + VkStructureType sType; + const void* pNext; + VkSemaphore semaphore; + VkSemaphoreImportFlags flags; + VkExternalSemaphoreHandleTypeFlagBits handleType; + int fd; +} VkImportSemaphoreFdInfoKHR; + +typedef struct VkSemaphoreGetFdInfoKHR { + VkStructureType sType; + const void* pNext; + VkSemaphore semaphore; + VkExternalSemaphoreHandleTypeFlagBits handleType; +} VkSemaphoreGetFdInfoKHR; + + +typedef VkResult (VKAPI_PTR *PFN_vkImportSemaphoreFdKHR)(VkDevice device, const VkImportSemaphoreFdInfoKHR* pImportSemaphoreFdInfo); +typedef VkResult (VKAPI_PTR *PFN_vkGetSemaphoreFdKHR)(VkDevice device, const VkSemaphoreGetFdInfoKHR* pGetFdInfo, int* pFd); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkImportSemaphoreFdKHR( + VkDevice device, + const VkImportSemaphoreFdInfoKHR* pImportSemaphoreFdInfo); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetSemaphoreFdKHR( + VkDevice device, + const VkSemaphoreGetFdInfoKHR* pGetFdInfo, + int* pFd); +#endif + +#define VK_KHR_push_descriptor 1 +#define VK_KHR_PUSH_DESCRIPTOR_SPEC_VERSION 2 +#define VK_KHR_PUSH_DESCRIPTOR_EXTENSION_NAME "VK_KHR_push_descriptor" + +typedef struct VkPhysicalDevicePushDescriptorPropertiesKHR { + VkStructureType sType; + void* pNext; + uint32_t maxPushDescriptors; +} VkPhysicalDevicePushDescriptorPropertiesKHR; + + +typedef void (VKAPI_PTR *PFN_vkCmdPushDescriptorSetKHR)(VkCommandBuffer commandBuffer, VkPipelineBindPoint pipelineBindPoint, VkPipelineLayout layout, uint32_t set, uint32_t descriptorWriteCount, const VkWriteDescriptorSet* pDescriptorWrites); +typedef void (VKAPI_PTR *PFN_vkCmdPushDescriptorSetWithTemplateKHR)(VkCommandBuffer commandBuffer, VkDescriptorUpdateTemplate descriptorUpdateTemplate, VkPipelineLayout layout, uint32_t set, const void* pData); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkCmdPushDescriptorSetKHR( + VkCommandBuffer commandBuffer, + VkPipelineBindPoint pipelineBindPoint, + VkPipelineLayout layout, + uint32_t set, + uint32_t descriptorWriteCount, + const VkWriteDescriptorSet* pDescriptorWrites); + +VKAPI_ATTR void VKAPI_CALL vkCmdPushDescriptorSetWithTemplateKHR( + VkCommandBuffer commandBuffer, + VkDescriptorUpdateTemplate descriptorUpdateTemplate, + VkPipelineLayout layout, + uint32_t set, + const void* pData); +#endif + +#define VK_KHR_16bit_storage 1 +#define VK_KHR_16BIT_STORAGE_SPEC_VERSION 1 +#define VK_KHR_16BIT_STORAGE_EXTENSION_NAME "VK_KHR_16bit_storage" + +typedef VkPhysicalDevice16BitStorageFeatures VkPhysicalDevice16BitStorageFeaturesKHR; + + + +#define VK_KHR_incremental_present 1 +#define VK_KHR_INCREMENTAL_PRESENT_SPEC_VERSION 1 +#define VK_KHR_INCREMENTAL_PRESENT_EXTENSION_NAME "VK_KHR_incremental_present" + +typedef struct VkRectLayerKHR { + VkOffset2D offset; + VkExtent2D extent; + uint32_t layer; +} VkRectLayerKHR; + +typedef struct VkPresentRegionKHR { + uint32_t rectangleCount; + const VkRectLayerKHR* pRectangles; +} VkPresentRegionKHR; + +typedef struct VkPresentRegionsKHR { + VkStructureType sType; + const void* pNext; + uint32_t swapchainCount; + const VkPresentRegionKHR* pRegions; +} VkPresentRegionsKHR; + + + +#define VK_KHR_descriptor_update_template 1 +typedef VkDescriptorUpdateTemplate VkDescriptorUpdateTemplateKHR; + + +#define VK_KHR_DESCRIPTOR_UPDATE_TEMPLATE_SPEC_VERSION 1 +#define VK_KHR_DESCRIPTOR_UPDATE_TEMPLATE_EXTENSION_NAME "VK_KHR_descriptor_update_template" + +typedef VkDescriptorUpdateTemplateType VkDescriptorUpdateTemplateTypeKHR; + + +typedef VkDescriptorUpdateTemplateCreateFlags VkDescriptorUpdateTemplateCreateFlagsKHR; + + +typedef VkDescriptorUpdateTemplateEntry VkDescriptorUpdateTemplateEntryKHR; + +typedef VkDescriptorUpdateTemplateCreateInfo VkDescriptorUpdateTemplateCreateInfoKHR; + + +typedef VkResult (VKAPI_PTR *PFN_vkCreateDescriptorUpdateTemplateKHR)(VkDevice device, const VkDescriptorUpdateTemplateCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDescriptorUpdateTemplate* pDescriptorUpdateTemplate); +typedef void (VKAPI_PTR *PFN_vkDestroyDescriptorUpdateTemplateKHR)(VkDevice device, VkDescriptorUpdateTemplate descriptorUpdateTemplate, const VkAllocationCallbacks* pAllocator); +typedef void (VKAPI_PTR *PFN_vkUpdateDescriptorSetWithTemplateKHR)(VkDevice device, VkDescriptorSet descriptorSet, VkDescriptorUpdateTemplate descriptorUpdateTemplate, const void* pData); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkCreateDescriptorUpdateTemplateKHR( + VkDevice device, + const VkDescriptorUpdateTemplateCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkDescriptorUpdateTemplate* pDescriptorUpdateTemplate); + +VKAPI_ATTR void VKAPI_CALL vkDestroyDescriptorUpdateTemplateKHR( + VkDevice device, + VkDescriptorUpdateTemplate descriptorUpdateTemplate, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR void VKAPI_CALL vkUpdateDescriptorSetWithTemplateKHR( + VkDevice device, + VkDescriptorSet descriptorSet, + VkDescriptorUpdateTemplate descriptorUpdateTemplate, + const void* pData); +#endif + +#define VK_KHR_shared_presentable_image 1 +#define VK_KHR_SHARED_PRESENTABLE_IMAGE_SPEC_VERSION 1 +#define VK_KHR_SHARED_PRESENTABLE_IMAGE_EXTENSION_NAME "VK_KHR_shared_presentable_image" + +typedef struct VkSharedPresentSurfaceCapabilitiesKHR { + VkStructureType sType; + void* pNext; + VkImageUsageFlags sharedPresentSupportedUsageFlags; +} VkSharedPresentSurfaceCapabilitiesKHR; + + +typedef VkResult (VKAPI_PTR *PFN_vkGetSwapchainStatusKHR)(VkDevice device, VkSwapchainKHR swapchain); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkGetSwapchainStatusKHR( + VkDevice device, + VkSwapchainKHR swapchain); +#endif + +#define VK_KHR_external_fence_capabilities 1 +#define VK_KHR_EXTERNAL_FENCE_CAPABILITIES_SPEC_VERSION 1 +#define VK_KHR_EXTERNAL_FENCE_CAPABILITIES_EXTENSION_NAME "VK_KHR_external_fence_capabilities" + +typedef VkExternalFenceHandleTypeFlags VkExternalFenceHandleTypeFlagsKHR; + +typedef VkExternalFenceHandleTypeFlagBits VkExternalFenceHandleTypeFlagBitsKHR; + +typedef VkExternalFenceFeatureFlags VkExternalFenceFeatureFlagsKHR; + +typedef VkExternalFenceFeatureFlagBits VkExternalFenceFeatureFlagBitsKHR; + + +typedef VkPhysicalDeviceExternalFenceInfo VkPhysicalDeviceExternalFenceInfoKHR; + +typedef VkExternalFenceProperties VkExternalFencePropertiesKHR; + + +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceExternalFencePropertiesKHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalFenceInfo* pExternalFenceInfo, VkExternalFenceProperties* pExternalFenceProperties); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceExternalFencePropertiesKHR( + VkPhysicalDevice physicalDevice, + const VkPhysicalDeviceExternalFenceInfo* pExternalFenceInfo, + VkExternalFenceProperties* pExternalFenceProperties); +#endif + +#define VK_KHR_external_fence 1 +#define VK_KHR_EXTERNAL_FENCE_SPEC_VERSION 1 +#define VK_KHR_EXTERNAL_FENCE_EXTENSION_NAME "VK_KHR_external_fence" + +typedef VkFenceImportFlags VkFenceImportFlagsKHR; + +typedef VkFenceImportFlagBits VkFenceImportFlagBitsKHR; + + +typedef VkExportFenceCreateInfo VkExportFenceCreateInfoKHR; + + + +#define VK_KHR_external_fence_fd 1 +#define VK_KHR_EXTERNAL_FENCE_FD_SPEC_VERSION 1 +#define VK_KHR_EXTERNAL_FENCE_FD_EXTENSION_NAME "VK_KHR_external_fence_fd" + +typedef struct VkImportFenceFdInfoKHR { + VkStructureType sType; + const void* pNext; + VkFence fence; + VkFenceImportFlags flags; + VkExternalFenceHandleTypeFlagBits handleType; + int fd; +} VkImportFenceFdInfoKHR; + +typedef struct VkFenceGetFdInfoKHR { + VkStructureType sType; + const void* pNext; + VkFence fence; + VkExternalFenceHandleTypeFlagBits handleType; +} VkFenceGetFdInfoKHR; + + +typedef VkResult (VKAPI_PTR *PFN_vkImportFenceFdKHR)(VkDevice device, const VkImportFenceFdInfoKHR* pImportFenceFdInfo); +typedef VkResult (VKAPI_PTR *PFN_vkGetFenceFdKHR)(VkDevice device, const VkFenceGetFdInfoKHR* pGetFdInfo, int* pFd); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkImportFenceFdKHR( + VkDevice device, + const VkImportFenceFdInfoKHR* pImportFenceFdInfo); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetFenceFdKHR( + VkDevice device, + const VkFenceGetFdInfoKHR* pGetFdInfo, + int* pFd); +#endif + +#define VK_KHR_maintenance2 1 +#define VK_KHR_MAINTENANCE2_SPEC_VERSION 1 +#define VK_KHR_MAINTENANCE2_EXTENSION_NAME "VK_KHR_maintenance2" + +typedef VkPointClippingBehavior VkPointClippingBehaviorKHR; + +typedef VkTessellationDomainOrigin VkTessellationDomainOriginKHR; + + +typedef VkPhysicalDevicePointClippingProperties VkPhysicalDevicePointClippingPropertiesKHR; + +typedef VkRenderPassInputAttachmentAspectCreateInfo VkRenderPassInputAttachmentAspectCreateInfoKHR; + +typedef VkInputAttachmentAspectReference VkInputAttachmentAspectReferenceKHR; + +typedef VkImageViewUsageCreateInfo VkImageViewUsageCreateInfoKHR; + +typedef VkPipelineTessellationDomainOriginStateCreateInfo VkPipelineTessellationDomainOriginStateCreateInfoKHR; + + + +#define VK_KHR_get_surface_capabilities2 1 +#define VK_KHR_GET_SURFACE_CAPABILITIES_2_SPEC_VERSION 1 +#define VK_KHR_GET_SURFACE_CAPABILITIES_2_EXTENSION_NAME "VK_KHR_get_surface_capabilities2" + +typedef struct VkPhysicalDeviceSurfaceInfo2KHR { + VkStructureType sType; + const void* pNext; + VkSurfaceKHR surface; +} VkPhysicalDeviceSurfaceInfo2KHR; + +typedef struct VkSurfaceCapabilities2KHR { + VkStructureType sType; + void* pNext; + VkSurfaceCapabilitiesKHR surfaceCapabilities; +} VkSurfaceCapabilities2KHR; + +typedef struct VkSurfaceFormat2KHR { + VkStructureType sType; + void* pNext; + VkSurfaceFormatKHR surfaceFormat; +} VkSurfaceFormat2KHR; + + +typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceCapabilities2KHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceSurfaceInfo2KHR* pSurfaceInfo, VkSurfaceCapabilities2KHR* pSurfaceCapabilities); +typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceFormats2KHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceSurfaceInfo2KHR* pSurfaceInfo, uint32_t* pSurfaceFormatCount, VkSurfaceFormat2KHR* pSurfaceFormats); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceCapabilities2KHR( + VkPhysicalDevice physicalDevice, + const VkPhysicalDeviceSurfaceInfo2KHR* pSurfaceInfo, + VkSurfaceCapabilities2KHR* pSurfaceCapabilities); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceFormats2KHR( + VkPhysicalDevice physicalDevice, + const VkPhysicalDeviceSurfaceInfo2KHR* pSurfaceInfo, + uint32_t* pSurfaceFormatCount, + VkSurfaceFormat2KHR* pSurfaceFormats); +#endif + +#define VK_KHR_variable_pointers 1 +#define VK_KHR_VARIABLE_POINTERS_SPEC_VERSION 1 +#define VK_KHR_VARIABLE_POINTERS_EXTENSION_NAME "VK_KHR_variable_pointers" + +typedef VkPhysicalDeviceVariablePointerFeatures VkPhysicalDeviceVariablePointerFeaturesKHR; + + + +#define VK_KHR_dedicated_allocation 1 +#define VK_KHR_DEDICATED_ALLOCATION_SPEC_VERSION 3 +#define VK_KHR_DEDICATED_ALLOCATION_EXTENSION_NAME "VK_KHR_dedicated_allocation" + +typedef VkMemoryDedicatedRequirements VkMemoryDedicatedRequirementsKHR; + +typedef VkMemoryDedicatedAllocateInfo VkMemoryDedicatedAllocateInfoKHR; + + + +#define VK_KHR_storage_buffer_storage_class 1 +#define VK_KHR_STORAGE_BUFFER_STORAGE_CLASS_SPEC_VERSION 1 +#define VK_KHR_STORAGE_BUFFER_STORAGE_CLASS_EXTENSION_NAME "VK_KHR_storage_buffer_storage_class" + + +#define VK_KHR_relaxed_block_layout 1 +#define VK_KHR_RELAXED_BLOCK_LAYOUT_SPEC_VERSION 1 +#define VK_KHR_RELAXED_BLOCK_LAYOUT_EXTENSION_NAME "VK_KHR_relaxed_block_layout" + + +#define VK_KHR_get_memory_requirements2 1 +#define VK_KHR_GET_MEMORY_REQUIREMENTS_2_SPEC_VERSION 1 +#define VK_KHR_GET_MEMORY_REQUIREMENTS_2_EXTENSION_NAME "VK_KHR_get_memory_requirements2" + +typedef VkBufferMemoryRequirementsInfo2 VkBufferMemoryRequirementsInfo2KHR; + +typedef VkImageMemoryRequirementsInfo2 VkImageMemoryRequirementsInfo2KHR; + +typedef VkImageSparseMemoryRequirementsInfo2 VkImageSparseMemoryRequirementsInfo2KHR; + +typedef VkMemoryRequirements2 VkMemoryRequirements2KHR; + +typedef VkSparseImageMemoryRequirements2 VkSparseImageMemoryRequirements2KHR; + + +typedef void (VKAPI_PTR *PFN_vkGetImageMemoryRequirements2KHR)(VkDevice device, const VkImageMemoryRequirementsInfo2* pInfo, VkMemoryRequirements2* pMemoryRequirements); +typedef void (VKAPI_PTR *PFN_vkGetBufferMemoryRequirements2KHR)(VkDevice device, const VkBufferMemoryRequirementsInfo2* pInfo, VkMemoryRequirements2* pMemoryRequirements); +typedef void (VKAPI_PTR *PFN_vkGetImageSparseMemoryRequirements2KHR)(VkDevice device, const VkImageSparseMemoryRequirementsInfo2* pInfo, uint32_t* pSparseMemoryRequirementCount, VkSparseImageMemoryRequirements2* pSparseMemoryRequirements); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkGetImageMemoryRequirements2KHR( + VkDevice device, + const VkImageMemoryRequirementsInfo2* pInfo, + VkMemoryRequirements2* pMemoryRequirements); + +VKAPI_ATTR void VKAPI_CALL vkGetBufferMemoryRequirements2KHR( + VkDevice device, + const VkBufferMemoryRequirementsInfo2* pInfo, + VkMemoryRequirements2* pMemoryRequirements); + +VKAPI_ATTR void VKAPI_CALL vkGetImageSparseMemoryRequirements2KHR( + VkDevice device, + const VkImageSparseMemoryRequirementsInfo2* pInfo, + uint32_t* pSparseMemoryRequirementCount, + VkSparseImageMemoryRequirements2* pSparseMemoryRequirements); +#endif + +#define VK_KHR_image_format_list 1 +#define VK_KHR_IMAGE_FORMAT_LIST_SPEC_VERSION 1 +#define VK_KHR_IMAGE_FORMAT_LIST_EXTENSION_NAME "VK_KHR_image_format_list" + +typedef struct VkImageFormatListCreateInfoKHR { + VkStructureType sType; + const void* pNext; + uint32_t viewFormatCount; + const VkFormat* pViewFormats; +} VkImageFormatListCreateInfoKHR; + + + +#define VK_KHR_sampler_ycbcr_conversion 1 +typedef VkSamplerYcbcrConversion VkSamplerYcbcrConversionKHR; + + +#define VK_KHR_SAMPLER_YCBCR_CONVERSION_SPEC_VERSION 1 +#define VK_KHR_SAMPLER_YCBCR_CONVERSION_EXTENSION_NAME "VK_KHR_sampler_ycbcr_conversion" + +typedef VkSamplerYcbcrModelConversion VkSamplerYcbcrModelConversionKHR; + +typedef VkSamplerYcbcrRange VkSamplerYcbcrRangeKHR; + +typedef VkChromaLocation VkChromaLocationKHR; + + +typedef VkSamplerYcbcrConversionCreateInfo VkSamplerYcbcrConversionCreateInfoKHR; + +typedef VkSamplerYcbcrConversionInfo VkSamplerYcbcrConversionInfoKHR; + +typedef VkBindImagePlaneMemoryInfo VkBindImagePlaneMemoryInfoKHR; + +typedef VkImagePlaneMemoryRequirementsInfo VkImagePlaneMemoryRequirementsInfoKHR; + +typedef VkPhysicalDeviceSamplerYcbcrConversionFeatures VkPhysicalDeviceSamplerYcbcrConversionFeaturesKHR; + +typedef VkSamplerYcbcrConversionImageFormatProperties VkSamplerYcbcrConversionImageFormatPropertiesKHR; + + +typedef VkResult (VKAPI_PTR *PFN_vkCreateSamplerYcbcrConversionKHR)(VkDevice device, const VkSamplerYcbcrConversionCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSamplerYcbcrConversion* pYcbcrConversion); +typedef void (VKAPI_PTR *PFN_vkDestroySamplerYcbcrConversionKHR)(VkDevice device, VkSamplerYcbcrConversion ycbcrConversion, const VkAllocationCallbacks* pAllocator); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkCreateSamplerYcbcrConversionKHR( + VkDevice device, + const VkSamplerYcbcrConversionCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkSamplerYcbcrConversion* pYcbcrConversion); + +VKAPI_ATTR void VKAPI_CALL vkDestroySamplerYcbcrConversionKHR( + VkDevice device, + VkSamplerYcbcrConversion ycbcrConversion, + const VkAllocationCallbacks* pAllocator); +#endif + +#define VK_KHR_bind_memory2 1 +#define VK_KHR_BIND_MEMORY_2_SPEC_VERSION 1 +#define VK_KHR_BIND_MEMORY_2_EXTENSION_NAME "VK_KHR_bind_memory2" + +typedef VkBindBufferMemoryInfo VkBindBufferMemoryInfoKHR; + +typedef VkBindImageMemoryInfo VkBindImageMemoryInfoKHR; + + +typedef VkResult (VKAPI_PTR *PFN_vkBindBufferMemory2KHR)(VkDevice device, uint32_t bindInfoCount, const VkBindBufferMemoryInfo* pBindInfos); +typedef VkResult (VKAPI_PTR *PFN_vkBindImageMemory2KHR)(VkDevice device, uint32_t bindInfoCount, const VkBindImageMemoryInfo* pBindInfos); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkBindBufferMemory2KHR( + VkDevice device, + uint32_t bindInfoCount, + const VkBindBufferMemoryInfo* pBindInfos); + +VKAPI_ATTR VkResult VKAPI_CALL vkBindImageMemory2KHR( + VkDevice device, + uint32_t bindInfoCount, + const VkBindImageMemoryInfo* pBindInfos); +#endif + +#define VK_KHR_maintenance3 1 +#define VK_KHR_MAINTENANCE3_SPEC_VERSION 1 +#define VK_KHR_MAINTENANCE3_EXTENSION_NAME "VK_KHR_maintenance3" + +typedef VkPhysicalDeviceMaintenance3Properties VkPhysicalDeviceMaintenance3PropertiesKHR; + +typedef VkDescriptorSetLayoutSupport VkDescriptorSetLayoutSupportKHR; + + +typedef void (VKAPI_PTR *PFN_vkGetDescriptorSetLayoutSupportKHR)(VkDevice device, const VkDescriptorSetLayoutCreateInfo* pCreateInfo, VkDescriptorSetLayoutSupport* pSupport); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkGetDescriptorSetLayoutSupportKHR( + VkDevice device, + const VkDescriptorSetLayoutCreateInfo* pCreateInfo, + VkDescriptorSetLayoutSupport* pSupport); +#endif + +#define VK_EXT_debug_report 1 +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDebugReportCallbackEXT) + +#define VK_EXT_DEBUG_REPORT_SPEC_VERSION 9 +#define VK_EXT_DEBUG_REPORT_EXTENSION_NAME "VK_EXT_debug_report" +#define VK_STRUCTURE_TYPE_DEBUG_REPORT_CREATE_INFO_EXT VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT +#define VK_DEBUG_REPORT_OBJECT_TYPE_DEBUG_REPORT_EXT VK_DEBUG_REPORT_OBJECT_TYPE_DEBUG_REPORT_CALLBACK_EXT_EXT + + +typedef enum VkDebugReportObjectTypeEXT { + VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT = 0, + VK_DEBUG_REPORT_OBJECT_TYPE_INSTANCE_EXT = 1, + VK_DEBUG_REPORT_OBJECT_TYPE_PHYSICAL_DEVICE_EXT = 2, + VK_DEBUG_REPORT_OBJECT_TYPE_DEVICE_EXT = 3, + VK_DEBUG_REPORT_OBJECT_TYPE_QUEUE_EXT = 4, + VK_DEBUG_REPORT_OBJECT_TYPE_SEMAPHORE_EXT = 5, + VK_DEBUG_REPORT_OBJECT_TYPE_COMMAND_BUFFER_EXT = 6, + VK_DEBUG_REPORT_OBJECT_TYPE_FENCE_EXT = 7, + VK_DEBUG_REPORT_OBJECT_TYPE_DEVICE_MEMORY_EXT = 8, + VK_DEBUG_REPORT_OBJECT_TYPE_BUFFER_EXT = 9, + VK_DEBUG_REPORT_OBJECT_TYPE_IMAGE_EXT = 10, + VK_DEBUG_REPORT_OBJECT_TYPE_EVENT_EXT = 11, + VK_DEBUG_REPORT_OBJECT_TYPE_QUERY_POOL_EXT = 12, + VK_DEBUG_REPORT_OBJECT_TYPE_BUFFER_VIEW_EXT = 13, + VK_DEBUG_REPORT_OBJECT_TYPE_IMAGE_VIEW_EXT = 14, + VK_DEBUG_REPORT_OBJECT_TYPE_SHADER_MODULE_EXT = 15, + VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_CACHE_EXT = 16, + VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_LAYOUT_EXT = 17, + VK_DEBUG_REPORT_OBJECT_TYPE_RENDER_PASS_EXT = 18, + VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_EXT = 19, + VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_SET_LAYOUT_EXT = 20, + VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_EXT = 21, + VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_POOL_EXT = 22, + VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_SET_EXT = 23, + VK_DEBUG_REPORT_OBJECT_TYPE_FRAMEBUFFER_EXT = 24, + VK_DEBUG_REPORT_OBJECT_TYPE_COMMAND_POOL_EXT = 25, + VK_DEBUG_REPORT_OBJECT_TYPE_SURFACE_KHR_EXT = 26, + VK_DEBUG_REPORT_OBJECT_TYPE_SWAPCHAIN_KHR_EXT = 27, + VK_DEBUG_REPORT_OBJECT_TYPE_DEBUG_REPORT_CALLBACK_EXT_EXT = 28, + VK_DEBUG_REPORT_OBJECT_TYPE_DISPLAY_KHR_EXT = 29, + VK_DEBUG_REPORT_OBJECT_TYPE_DISPLAY_MODE_KHR_EXT = 30, + VK_DEBUG_REPORT_OBJECT_TYPE_OBJECT_TABLE_NVX_EXT = 31, + VK_DEBUG_REPORT_OBJECT_TYPE_INDIRECT_COMMANDS_LAYOUT_NVX_EXT = 32, + VK_DEBUG_REPORT_OBJECT_TYPE_VALIDATION_CACHE_EXT_EXT = 33, + VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION_EXT = 1000156000, + VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_EXT = 1000085000, + VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_KHR_EXT = VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_EXT, + VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION_KHR_EXT = VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION_EXT, + VK_DEBUG_REPORT_OBJECT_TYPE_BEGIN_RANGE_EXT = VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT, + VK_DEBUG_REPORT_OBJECT_TYPE_END_RANGE_EXT = VK_DEBUG_REPORT_OBJECT_TYPE_VALIDATION_CACHE_EXT_EXT, + VK_DEBUG_REPORT_OBJECT_TYPE_RANGE_SIZE_EXT = (VK_DEBUG_REPORT_OBJECT_TYPE_VALIDATION_CACHE_EXT_EXT - VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT + 1), + VK_DEBUG_REPORT_OBJECT_TYPE_MAX_ENUM_EXT = 0x7FFFFFFF +} VkDebugReportObjectTypeEXT; + + +typedef enum VkDebugReportFlagBitsEXT { + VK_DEBUG_REPORT_INFORMATION_BIT_EXT = 0x00000001, + VK_DEBUG_REPORT_WARNING_BIT_EXT = 0x00000002, + VK_DEBUG_REPORT_PERFORMANCE_WARNING_BIT_EXT = 0x00000004, + VK_DEBUG_REPORT_ERROR_BIT_EXT = 0x00000008, + VK_DEBUG_REPORT_DEBUG_BIT_EXT = 0x00000010, + VK_DEBUG_REPORT_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF +} VkDebugReportFlagBitsEXT; +typedef VkFlags VkDebugReportFlagsEXT; + +typedef VkBool32 (VKAPI_PTR *PFN_vkDebugReportCallbackEXT)( + VkDebugReportFlagsEXT flags, + VkDebugReportObjectTypeEXT objectType, + uint64_t object, + size_t location, + int32_t messageCode, + const char* pLayerPrefix, + const char* pMessage, + void* pUserData); + +typedef struct VkDebugReportCallbackCreateInfoEXT { + VkStructureType sType; + const void* pNext; + VkDebugReportFlagsEXT flags; + PFN_vkDebugReportCallbackEXT pfnCallback; + void* pUserData; +} VkDebugReportCallbackCreateInfoEXT; + + +typedef VkResult (VKAPI_PTR *PFN_vkCreateDebugReportCallbackEXT)(VkInstance instance, const VkDebugReportCallbackCreateInfoEXT* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDebugReportCallbackEXT* pCallback); +typedef void (VKAPI_PTR *PFN_vkDestroyDebugReportCallbackEXT)(VkInstance instance, VkDebugReportCallbackEXT callback, const VkAllocationCallbacks* pAllocator); +typedef void (VKAPI_PTR *PFN_vkDebugReportMessageEXT)(VkInstance instance, VkDebugReportFlagsEXT flags, VkDebugReportObjectTypeEXT objectType, uint64_t object, size_t location, int32_t messageCode, const char* pLayerPrefix, const char* pMessage); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkCreateDebugReportCallbackEXT( + VkInstance instance, + const VkDebugReportCallbackCreateInfoEXT* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkDebugReportCallbackEXT* pCallback); + +VKAPI_ATTR void VKAPI_CALL vkDestroyDebugReportCallbackEXT( + VkInstance instance, + VkDebugReportCallbackEXT callback, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR void VKAPI_CALL vkDebugReportMessageEXT( + VkInstance instance, + VkDebugReportFlagsEXT flags, + VkDebugReportObjectTypeEXT objectType, + uint64_t object, + size_t location, + int32_t messageCode, + const char* pLayerPrefix, + const char* pMessage); +#endif + +#define VK_NV_glsl_shader 1 +#define VK_NV_GLSL_SHADER_SPEC_VERSION 1 +#define VK_NV_GLSL_SHADER_EXTENSION_NAME "VK_NV_glsl_shader" + + +#define VK_EXT_depth_range_unrestricted 1 +#define VK_EXT_DEPTH_RANGE_UNRESTRICTED_SPEC_VERSION 1 +#define VK_EXT_DEPTH_RANGE_UNRESTRICTED_EXTENSION_NAME "VK_EXT_depth_range_unrestricted" + + +#define VK_IMG_filter_cubic 1 +#define VK_IMG_FILTER_CUBIC_SPEC_VERSION 1 +#define VK_IMG_FILTER_CUBIC_EXTENSION_NAME "VK_IMG_filter_cubic" + + +#define VK_AMD_rasterization_order 1 +#define VK_AMD_RASTERIZATION_ORDER_SPEC_VERSION 1 +#define VK_AMD_RASTERIZATION_ORDER_EXTENSION_NAME "VK_AMD_rasterization_order" + + +typedef enum VkRasterizationOrderAMD { + VK_RASTERIZATION_ORDER_STRICT_AMD = 0, + VK_RASTERIZATION_ORDER_RELAXED_AMD = 1, + VK_RASTERIZATION_ORDER_BEGIN_RANGE_AMD = VK_RASTERIZATION_ORDER_STRICT_AMD, + VK_RASTERIZATION_ORDER_END_RANGE_AMD = VK_RASTERIZATION_ORDER_RELAXED_AMD, + VK_RASTERIZATION_ORDER_RANGE_SIZE_AMD = (VK_RASTERIZATION_ORDER_RELAXED_AMD - VK_RASTERIZATION_ORDER_STRICT_AMD + 1), + VK_RASTERIZATION_ORDER_MAX_ENUM_AMD = 0x7FFFFFFF +} VkRasterizationOrderAMD; + +typedef struct VkPipelineRasterizationStateRasterizationOrderAMD { + VkStructureType sType; + const void* pNext; + VkRasterizationOrderAMD rasterizationOrder; +} VkPipelineRasterizationStateRasterizationOrderAMD; + + + +#define VK_AMD_shader_trinary_minmax 1 +#define VK_AMD_SHADER_TRINARY_MINMAX_SPEC_VERSION 1 +#define VK_AMD_SHADER_TRINARY_MINMAX_EXTENSION_NAME "VK_AMD_shader_trinary_minmax" + + +#define VK_AMD_shader_explicit_vertex_parameter 1 +#define VK_AMD_SHADER_EXPLICIT_VERTEX_PARAMETER_SPEC_VERSION 1 +#define VK_AMD_SHADER_EXPLICIT_VERTEX_PARAMETER_EXTENSION_NAME "VK_AMD_shader_explicit_vertex_parameter" + + +#define VK_EXT_debug_marker 1 +#define VK_EXT_DEBUG_MARKER_SPEC_VERSION 4 +#define VK_EXT_DEBUG_MARKER_EXTENSION_NAME "VK_EXT_debug_marker" + +typedef struct VkDebugMarkerObjectNameInfoEXT { + VkStructureType sType; + const void* pNext; + VkDebugReportObjectTypeEXT objectType; + uint64_t object; + const char* pObjectName; +} VkDebugMarkerObjectNameInfoEXT; + +typedef struct VkDebugMarkerObjectTagInfoEXT { + VkStructureType sType; + const void* pNext; + VkDebugReportObjectTypeEXT objectType; + uint64_t object; + uint64_t tagName; + size_t tagSize; + const void* pTag; +} VkDebugMarkerObjectTagInfoEXT; + +typedef struct VkDebugMarkerMarkerInfoEXT { + VkStructureType sType; + const void* pNext; + const char* pMarkerName; + float color[4]; +} VkDebugMarkerMarkerInfoEXT; + + +typedef VkResult (VKAPI_PTR *PFN_vkDebugMarkerSetObjectTagEXT)(VkDevice device, const VkDebugMarkerObjectTagInfoEXT* pTagInfo); +typedef VkResult (VKAPI_PTR *PFN_vkDebugMarkerSetObjectNameEXT)(VkDevice device, const VkDebugMarkerObjectNameInfoEXT* pNameInfo); +typedef void (VKAPI_PTR *PFN_vkCmdDebugMarkerBeginEXT)(VkCommandBuffer commandBuffer, const VkDebugMarkerMarkerInfoEXT* pMarkerInfo); +typedef void (VKAPI_PTR *PFN_vkCmdDebugMarkerEndEXT)(VkCommandBuffer commandBuffer); +typedef void (VKAPI_PTR *PFN_vkCmdDebugMarkerInsertEXT)(VkCommandBuffer commandBuffer, const VkDebugMarkerMarkerInfoEXT* pMarkerInfo); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkDebugMarkerSetObjectTagEXT( + VkDevice device, + const VkDebugMarkerObjectTagInfoEXT* pTagInfo); + +VKAPI_ATTR VkResult VKAPI_CALL vkDebugMarkerSetObjectNameEXT( + VkDevice device, + const VkDebugMarkerObjectNameInfoEXT* pNameInfo); + +VKAPI_ATTR void VKAPI_CALL vkCmdDebugMarkerBeginEXT( + VkCommandBuffer commandBuffer, + const VkDebugMarkerMarkerInfoEXT* pMarkerInfo); + +VKAPI_ATTR void VKAPI_CALL vkCmdDebugMarkerEndEXT( + VkCommandBuffer commandBuffer); + +VKAPI_ATTR void VKAPI_CALL vkCmdDebugMarkerInsertEXT( + VkCommandBuffer commandBuffer, + const VkDebugMarkerMarkerInfoEXT* pMarkerInfo); +#endif + +#define VK_AMD_gcn_shader 1 +#define VK_AMD_GCN_SHADER_SPEC_VERSION 1 +#define VK_AMD_GCN_SHADER_EXTENSION_NAME "VK_AMD_gcn_shader" + + +#define VK_NV_dedicated_allocation 1 +#define VK_NV_DEDICATED_ALLOCATION_SPEC_VERSION 1 +#define VK_NV_DEDICATED_ALLOCATION_EXTENSION_NAME "VK_NV_dedicated_allocation" + +typedef struct VkDedicatedAllocationImageCreateInfoNV { + VkStructureType sType; + const void* pNext; + VkBool32 dedicatedAllocation; +} VkDedicatedAllocationImageCreateInfoNV; + +typedef struct VkDedicatedAllocationBufferCreateInfoNV { + VkStructureType sType; + const void* pNext; + VkBool32 dedicatedAllocation; +} VkDedicatedAllocationBufferCreateInfoNV; + +typedef struct VkDedicatedAllocationMemoryAllocateInfoNV { + VkStructureType sType; + const void* pNext; + VkImage image; + VkBuffer buffer; +} VkDedicatedAllocationMemoryAllocateInfoNV; + + + +#define VK_AMD_draw_indirect_count 1 +#define VK_AMD_DRAW_INDIRECT_COUNT_SPEC_VERSION 1 +#define VK_AMD_DRAW_INDIRECT_COUNT_EXTENSION_NAME "VK_AMD_draw_indirect_count" + +typedef void (VKAPI_PTR *PFN_vkCmdDrawIndirectCountAMD)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, VkBuffer countBuffer, VkDeviceSize countBufferOffset, uint32_t maxDrawCount, uint32_t stride); +typedef void (VKAPI_PTR *PFN_vkCmdDrawIndexedIndirectCountAMD)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, VkBuffer countBuffer, VkDeviceSize countBufferOffset, uint32_t maxDrawCount, uint32_t stride); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkCmdDrawIndirectCountAMD( + VkCommandBuffer commandBuffer, + VkBuffer buffer, + VkDeviceSize offset, + VkBuffer countBuffer, + VkDeviceSize countBufferOffset, + uint32_t maxDrawCount, + uint32_t stride); + +VKAPI_ATTR void VKAPI_CALL vkCmdDrawIndexedIndirectCountAMD( + VkCommandBuffer commandBuffer, + VkBuffer buffer, + VkDeviceSize offset, + VkBuffer countBuffer, + VkDeviceSize countBufferOffset, + uint32_t maxDrawCount, + uint32_t stride); +#endif + +#define VK_AMD_negative_viewport_height 1 +#define VK_AMD_NEGATIVE_VIEWPORT_HEIGHT_SPEC_VERSION 1 +#define VK_AMD_NEGATIVE_VIEWPORT_HEIGHT_EXTENSION_NAME "VK_AMD_negative_viewport_height" + + +#define VK_AMD_gpu_shader_half_float 1 +#define VK_AMD_GPU_SHADER_HALF_FLOAT_SPEC_VERSION 1 +#define VK_AMD_GPU_SHADER_HALF_FLOAT_EXTENSION_NAME "VK_AMD_gpu_shader_half_float" + + +#define VK_AMD_shader_ballot 1 +#define VK_AMD_SHADER_BALLOT_SPEC_VERSION 1 +#define VK_AMD_SHADER_BALLOT_EXTENSION_NAME "VK_AMD_shader_ballot" + + +#define VK_AMD_texture_gather_bias_lod 1 +#define VK_AMD_TEXTURE_GATHER_BIAS_LOD_SPEC_VERSION 1 +#define VK_AMD_TEXTURE_GATHER_BIAS_LOD_EXTENSION_NAME "VK_AMD_texture_gather_bias_lod" + +typedef struct VkTextureLODGatherFormatPropertiesAMD { + VkStructureType sType; + void* pNext; + VkBool32 supportsTextureGatherLODBiasAMD; +} VkTextureLODGatherFormatPropertiesAMD; + + + +#define VK_AMD_shader_info 1 +#define VK_AMD_SHADER_INFO_SPEC_VERSION 1 +#define VK_AMD_SHADER_INFO_EXTENSION_NAME "VK_AMD_shader_info" + + +typedef enum VkShaderInfoTypeAMD { + VK_SHADER_INFO_TYPE_STATISTICS_AMD = 0, + VK_SHADER_INFO_TYPE_BINARY_AMD = 1, + VK_SHADER_INFO_TYPE_DISASSEMBLY_AMD = 2, + VK_SHADER_INFO_TYPE_BEGIN_RANGE_AMD = VK_SHADER_INFO_TYPE_STATISTICS_AMD, + VK_SHADER_INFO_TYPE_END_RANGE_AMD = VK_SHADER_INFO_TYPE_DISASSEMBLY_AMD, + VK_SHADER_INFO_TYPE_RANGE_SIZE_AMD = (VK_SHADER_INFO_TYPE_DISASSEMBLY_AMD - VK_SHADER_INFO_TYPE_STATISTICS_AMD + 1), + VK_SHADER_INFO_TYPE_MAX_ENUM_AMD = 0x7FFFFFFF +} VkShaderInfoTypeAMD; + +typedef struct VkShaderResourceUsageAMD { + uint32_t numUsedVgprs; + uint32_t numUsedSgprs; + uint32_t ldsSizePerLocalWorkGroup; + size_t ldsUsageSizeInBytes; + size_t scratchMemUsageInBytes; +} VkShaderResourceUsageAMD; + +typedef struct VkShaderStatisticsInfoAMD { + VkShaderStageFlags shaderStageMask; + VkShaderResourceUsageAMD resourceUsage; + uint32_t numPhysicalVgprs; + uint32_t numPhysicalSgprs; + uint32_t numAvailableVgprs; + uint32_t numAvailableSgprs; + uint32_t computeWorkGroupSize[3]; +} VkShaderStatisticsInfoAMD; + + +typedef VkResult (VKAPI_PTR *PFN_vkGetShaderInfoAMD)(VkDevice device, VkPipeline pipeline, VkShaderStageFlagBits shaderStage, VkShaderInfoTypeAMD infoType, size_t* pInfoSize, void* pInfo); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkGetShaderInfoAMD( + VkDevice device, + VkPipeline pipeline, + VkShaderStageFlagBits shaderStage, + VkShaderInfoTypeAMD infoType, + size_t* pInfoSize, + void* pInfo); +#endif + +#define VK_AMD_shader_image_load_store_lod 1 +#define VK_AMD_SHADER_IMAGE_LOAD_STORE_LOD_SPEC_VERSION 1 +#define VK_AMD_SHADER_IMAGE_LOAD_STORE_LOD_EXTENSION_NAME "VK_AMD_shader_image_load_store_lod" + + +#define VK_IMG_format_pvrtc 1 +#define VK_IMG_FORMAT_PVRTC_SPEC_VERSION 1 +#define VK_IMG_FORMAT_PVRTC_EXTENSION_NAME "VK_IMG_format_pvrtc" + + +#define VK_NV_external_memory_capabilities 1 +#define VK_NV_EXTERNAL_MEMORY_CAPABILITIES_SPEC_VERSION 1 +#define VK_NV_EXTERNAL_MEMORY_CAPABILITIES_EXTENSION_NAME "VK_NV_external_memory_capabilities" + + +typedef enum VkExternalMemoryHandleTypeFlagBitsNV { + VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT_NV = 0x00000001, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_NV = 0x00000002, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_IMAGE_BIT_NV = 0x00000004, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_IMAGE_KMT_BIT_NV = 0x00000008, + VK_EXTERNAL_MEMORY_HANDLE_TYPE_FLAG_BITS_MAX_ENUM_NV = 0x7FFFFFFF +} VkExternalMemoryHandleTypeFlagBitsNV; +typedef VkFlags VkExternalMemoryHandleTypeFlagsNV; + +typedef enum VkExternalMemoryFeatureFlagBitsNV { + VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT_NV = 0x00000001, + VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT_NV = 0x00000002, + VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT_NV = 0x00000004, + VK_EXTERNAL_MEMORY_FEATURE_FLAG_BITS_MAX_ENUM_NV = 0x7FFFFFFF +} VkExternalMemoryFeatureFlagBitsNV; +typedef VkFlags VkExternalMemoryFeatureFlagsNV; + +typedef struct VkExternalImageFormatPropertiesNV { + VkImageFormatProperties imageFormatProperties; + VkExternalMemoryFeatureFlagsNV externalMemoryFeatures; + VkExternalMemoryHandleTypeFlagsNV exportFromImportedHandleTypes; + VkExternalMemoryHandleTypeFlagsNV compatibleHandleTypes; +} VkExternalImageFormatPropertiesNV; + + +typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceExternalImageFormatPropertiesNV)(VkPhysicalDevice physicalDevice, VkFormat format, VkImageType type, VkImageTiling tiling, VkImageUsageFlags usage, VkImageCreateFlags flags, VkExternalMemoryHandleTypeFlagsNV externalHandleType, VkExternalImageFormatPropertiesNV* pExternalImageFormatProperties); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceExternalImageFormatPropertiesNV( + VkPhysicalDevice physicalDevice, + VkFormat format, + VkImageType type, + VkImageTiling tiling, + VkImageUsageFlags usage, + VkImageCreateFlags flags, + VkExternalMemoryHandleTypeFlagsNV externalHandleType, + VkExternalImageFormatPropertiesNV* pExternalImageFormatProperties); +#endif + +#define VK_NV_external_memory 1 +#define VK_NV_EXTERNAL_MEMORY_SPEC_VERSION 1 +#define VK_NV_EXTERNAL_MEMORY_EXTENSION_NAME "VK_NV_external_memory" + +typedef struct VkExternalMemoryImageCreateInfoNV { + VkStructureType sType; + const void* pNext; + VkExternalMemoryHandleTypeFlagsNV handleTypes; +} VkExternalMemoryImageCreateInfoNV; + +typedef struct VkExportMemoryAllocateInfoNV { + VkStructureType sType; + const void* pNext; + VkExternalMemoryHandleTypeFlagsNV handleTypes; +} VkExportMemoryAllocateInfoNV; + + + +#define VK_EXT_validation_flags 1 +#define VK_EXT_VALIDATION_FLAGS_SPEC_VERSION 1 +#define VK_EXT_VALIDATION_FLAGS_EXTENSION_NAME "VK_EXT_validation_flags" + + +typedef enum VkValidationCheckEXT { + VK_VALIDATION_CHECK_ALL_EXT = 0, + VK_VALIDATION_CHECK_SHADERS_EXT = 1, + VK_VALIDATION_CHECK_BEGIN_RANGE_EXT = VK_VALIDATION_CHECK_ALL_EXT, + VK_VALIDATION_CHECK_END_RANGE_EXT = VK_VALIDATION_CHECK_SHADERS_EXT, + VK_VALIDATION_CHECK_RANGE_SIZE_EXT = (VK_VALIDATION_CHECK_SHADERS_EXT - VK_VALIDATION_CHECK_ALL_EXT + 1), + VK_VALIDATION_CHECK_MAX_ENUM_EXT = 0x7FFFFFFF +} VkValidationCheckEXT; + +typedef struct VkValidationFlagsEXT { + VkStructureType sType; + const void* pNext; + uint32_t disabledValidationCheckCount; + VkValidationCheckEXT* pDisabledValidationChecks; +} VkValidationFlagsEXT; + + + +#define VK_EXT_shader_subgroup_ballot 1 +#define VK_EXT_SHADER_SUBGROUP_BALLOT_SPEC_VERSION 1 +#define VK_EXT_SHADER_SUBGROUP_BALLOT_EXTENSION_NAME "VK_EXT_shader_subgroup_ballot" + + +#define VK_EXT_shader_subgroup_vote 1 +#define VK_EXT_SHADER_SUBGROUP_VOTE_SPEC_VERSION 1 +#define VK_EXT_SHADER_SUBGROUP_VOTE_EXTENSION_NAME "VK_EXT_shader_subgroup_vote" + + +#define VK_NVX_device_generated_commands 1 +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkObjectTableNVX) +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkIndirectCommandsLayoutNVX) + +#define VK_NVX_DEVICE_GENERATED_COMMANDS_SPEC_VERSION 3 +#define VK_NVX_DEVICE_GENERATED_COMMANDS_EXTENSION_NAME "VK_NVX_device_generated_commands" + + +typedef enum VkIndirectCommandsTokenTypeNVX { + VK_INDIRECT_COMMANDS_TOKEN_TYPE_PIPELINE_NVX = 0, + VK_INDIRECT_COMMANDS_TOKEN_TYPE_DESCRIPTOR_SET_NVX = 1, + VK_INDIRECT_COMMANDS_TOKEN_TYPE_INDEX_BUFFER_NVX = 2, + VK_INDIRECT_COMMANDS_TOKEN_TYPE_VERTEX_BUFFER_NVX = 3, + VK_INDIRECT_COMMANDS_TOKEN_TYPE_PUSH_CONSTANT_NVX = 4, + VK_INDIRECT_COMMANDS_TOKEN_TYPE_DRAW_INDEXED_NVX = 5, + VK_INDIRECT_COMMANDS_TOKEN_TYPE_DRAW_NVX = 6, + VK_INDIRECT_COMMANDS_TOKEN_TYPE_DISPATCH_NVX = 7, + VK_INDIRECT_COMMANDS_TOKEN_TYPE_BEGIN_RANGE_NVX = VK_INDIRECT_COMMANDS_TOKEN_TYPE_PIPELINE_NVX, + VK_INDIRECT_COMMANDS_TOKEN_TYPE_END_RANGE_NVX = VK_INDIRECT_COMMANDS_TOKEN_TYPE_DISPATCH_NVX, + VK_INDIRECT_COMMANDS_TOKEN_TYPE_RANGE_SIZE_NVX = (VK_INDIRECT_COMMANDS_TOKEN_TYPE_DISPATCH_NVX - VK_INDIRECT_COMMANDS_TOKEN_TYPE_PIPELINE_NVX + 1), + VK_INDIRECT_COMMANDS_TOKEN_TYPE_MAX_ENUM_NVX = 0x7FFFFFFF +} VkIndirectCommandsTokenTypeNVX; + +typedef enum VkObjectEntryTypeNVX { + VK_OBJECT_ENTRY_TYPE_DESCRIPTOR_SET_NVX = 0, + VK_OBJECT_ENTRY_TYPE_PIPELINE_NVX = 1, + VK_OBJECT_ENTRY_TYPE_INDEX_BUFFER_NVX = 2, + VK_OBJECT_ENTRY_TYPE_VERTEX_BUFFER_NVX = 3, + VK_OBJECT_ENTRY_TYPE_PUSH_CONSTANT_NVX = 4, + VK_OBJECT_ENTRY_TYPE_BEGIN_RANGE_NVX = VK_OBJECT_ENTRY_TYPE_DESCRIPTOR_SET_NVX, + VK_OBJECT_ENTRY_TYPE_END_RANGE_NVX = VK_OBJECT_ENTRY_TYPE_PUSH_CONSTANT_NVX, + VK_OBJECT_ENTRY_TYPE_RANGE_SIZE_NVX = (VK_OBJECT_ENTRY_TYPE_PUSH_CONSTANT_NVX - VK_OBJECT_ENTRY_TYPE_DESCRIPTOR_SET_NVX + 1), + VK_OBJECT_ENTRY_TYPE_MAX_ENUM_NVX = 0x7FFFFFFF +} VkObjectEntryTypeNVX; + + +typedef enum VkIndirectCommandsLayoutUsageFlagBitsNVX { + VK_INDIRECT_COMMANDS_LAYOUT_USAGE_UNORDERED_SEQUENCES_BIT_NVX = 0x00000001, + VK_INDIRECT_COMMANDS_LAYOUT_USAGE_SPARSE_SEQUENCES_BIT_NVX = 0x00000002, + VK_INDIRECT_COMMANDS_LAYOUT_USAGE_EMPTY_EXECUTIONS_BIT_NVX = 0x00000004, + VK_INDIRECT_COMMANDS_LAYOUT_USAGE_INDEXED_SEQUENCES_BIT_NVX = 0x00000008, + VK_INDIRECT_COMMANDS_LAYOUT_USAGE_FLAG_BITS_MAX_ENUM_NVX = 0x7FFFFFFF +} VkIndirectCommandsLayoutUsageFlagBitsNVX; +typedef VkFlags VkIndirectCommandsLayoutUsageFlagsNVX; + +typedef enum VkObjectEntryUsageFlagBitsNVX { + VK_OBJECT_ENTRY_USAGE_GRAPHICS_BIT_NVX = 0x00000001, + VK_OBJECT_ENTRY_USAGE_COMPUTE_BIT_NVX = 0x00000002, + VK_OBJECT_ENTRY_USAGE_FLAG_BITS_MAX_ENUM_NVX = 0x7FFFFFFF +} VkObjectEntryUsageFlagBitsNVX; +typedef VkFlags VkObjectEntryUsageFlagsNVX; + +typedef struct VkDeviceGeneratedCommandsFeaturesNVX { + VkStructureType sType; + const void* pNext; + VkBool32 computeBindingPointSupport; +} VkDeviceGeneratedCommandsFeaturesNVX; + +typedef struct VkDeviceGeneratedCommandsLimitsNVX { + VkStructureType sType; + const void* pNext; + uint32_t maxIndirectCommandsLayoutTokenCount; + uint32_t maxObjectEntryCounts; + uint32_t minSequenceCountBufferOffsetAlignment; + uint32_t minSequenceIndexBufferOffsetAlignment; + uint32_t minCommandsTokenBufferOffsetAlignment; +} VkDeviceGeneratedCommandsLimitsNVX; + +typedef struct VkIndirectCommandsTokenNVX { + VkIndirectCommandsTokenTypeNVX tokenType; + VkBuffer buffer; + VkDeviceSize offset; +} VkIndirectCommandsTokenNVX; + +typedef struct VkIndirectCommandsLayoutTokenNVX { + VkIndirectCommandsTokenTypeNVX tokenType; + uint32_t bindingUnit; + uint32_t dynamicCount; + uint32_t divisor; +} VkIndirectCommandsLayoutTokenNVX; + +typedef struct VkIndirectCommandsLayoutCreateInfoNVX { + VkStructureType sType; + const void* pNext; + VkPipelineBindPoint pipelineBindPoint; + VkIndirectCommandsLayoutUsageFlagsNVX flags; + uint32_t tokenCount; + const VkIndirectCommandsLayoutTokenNVX* pTokens; +} VkIndirectCommandsLayoutCreateInfoNVX; + +typedef struct VkCmdProcessCommandsInfoNVX { + VkStructureType sType; + const void* pNext; + VkObjectTableNVX objectTable; + VkIndirectCommandsLayoutNVX indirectCommandsLayout; + uint32_t indirectCommandsTokenCount; + const VkIndirectCommandsTokenNVX* pIndirectCommandsTokens; + uint32_t maxSequencesCount; + VkCommandBuffer targetCommandBuffer; + VkBuffer sequencesCountBuffer; + VkDeviceSize sequencesCountOffset; + VkBuffer sequencesIndexBuffer; + VkDeviceSize sequencesIndexOffset; +} VkCmdProcessCommandsInfoNVX; + +typedef struct VkCmdReserveSpaceForCommandsInfoNVX { + VkStructureType sType; + const void* pNext; + VkObjectTableNVX objectTable; + VkIndirectCommandsLayoutNVX indirectCommandsLayout; + uint32_t maxSequencesCount; +} VkCmdReserveSpaceForCommandsInfoNVX; + +typedef struct VkObjectTableCreateInfoNVX { + VkStructureType sType; + const void* pNext; + uint32_t objectCount; + const VkObjectEntryTypeNVX* pObjectEntryTypes; + const uint32_t* pObjectEntryCounts; + const VkObjectEntryUsageFlagsNVX* pObjectEntryUsageFlags; + uint32_t maxUniformBuffersPerDescriptor; + uint32_t maxStorageBuffersPerDescriptor; + uint32_t maxStorageImagesPerDescriptor; + uint32_t maxSampledImagesPerDescriptor; + uint32_t maxPipelineLayouts; +} VkObjectTableCreateInfoNVX; + +typedef struct VkObjectTableEntryNVX { + VkObjectEntryTypeNVX type; + VkObjectEntryUsageFlagsNVX flags; +} VkObjectTableEntryNVX; + +typedef struct VkObjectTablePipelineEntryNVX { + VkObjectEntryTypeNVX type; + VkObjectEntryUsageFlagsNVX flags; + VkPipeline pipeline; +} VkObjectTablePipelineEntryNVX; + +typedef struct VkObjectTableDescriptorSetEntryNVX { + VkObjectEntryTypeNVX type; + VkObjectEntryUsageFlagsNVX flags; + VkPipelineLayout pipelineLayout; + VkDescriptorSet descriptorSet; +} VkObjectTableDescriptorSetEntryNVX; + +typedef struct VkObjectTableVertexBufferEntryNVX { + VkObjectEntryTypeNVX type; + VkObjectEntryUsageFlagsNVX flags; + VkBuffer buffer; +} VkObjectTableVertexBufferEntryNVX; + +typedef struct VkObjectTableIndexBufferEntryNVX { + VkObjectEntryTypeNVX type; + VkObjectEntryUsageFlagsNVX flags; + VkBuffer buffer; + VkIndexType indexType; +} VkObjectTableIndexBufferEntryNVX; + +typedef struct VkObjectTablePushConstantEntryNVX { + VkObjectEntryTypeNVX type; + VkObjectEntryUsageFlagsNVX flags; + VkPipelineLayout pipelineLayout; + VkShaderStageFlags stageFlags; +} VkObjectTablePushConstantEntryNVX; + + +typedef void (VKAPI_PTR *PFN_vkCmdProcessCommandsNVX)(VkCommandBuffer commandBuffer, const VkCmdProcessCommandsInfoNVX* pProcessCommandsInfo); +typedef void (VKAPI_PTR *PFN_vkCmdReserveSpaceForCommandsNVX)(VkCommandBuffer commandBuffer, const VkCmdReserveSpaceForCommandsInfoNVX* pReserveSpaceInfo); +typedef VkResult (VKAPI_PTR *PFN_vkCreateIndirectCommandsLayoutNVX)(VkDevice device, const VkIndirectCommandsLayoutCreateInfoNVX* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkIndirectCommandsLayoutNVX* pIndirectCommandsLayout); +typedef void (VKAPI_PTR *PFN_vkDestroyIndirectCommandsLayoutNVX)(VkDevice device, VkIndirectCommandsLayoutNVX indirectCommandsLayout, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkCreateObjectTableNVX)(VkDevice device, const VkObjectTableCreateInfoNVX* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkObjectTableNVX* pObjectTable); +typedef void (VKAPI_PTR *PFN_vkDestroyObjectTableNVX)(VkDevice device, VkObjectTableNVX objectTable, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkRegisterObjectsNVX)(VkDevice device, VkObjectTableNVX objectTable, uint32_t objectCount, const VkObjectTableEntryNVX* const* ppObjectTableEntries, const uint32_t* pObjectIndices); +typedef VkResult (VKAPI_PTR *PFN_vkUnregisterObjectsNVX)(VkDevice device, VkObjectTableNVX objectTable, uint32_t objectCount, const VkObjectEntryTypeNVX* pObjectEntryTypes, const uint32_t* pObjectIndices); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX)(VkPhysicalDevice physicalDevice, VkDeviceGeneratedCommandsFeaturesNVX* pFeatures, VkDeviceGeneratedCommandsLimitsNVX* pLimits); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkCmdProcessCommandsNVX( + VkCommandBuffer commandBuffer, + const VkCmdProcessCommandsInfoNVX* pProcessCommandsInfo); + +VKAPI_ATTR void VKAPI_CALL vkCmdReserveSpaceForCommandsNVX( + VkCommandBuffer commandBuffer, + const VkCmdReserveSpaceForCommandsInfoNVX* pReserveSpaceInfo); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateIndirectCommandsLayoutNVX( + VkDevice device, + const VkIndirectCommandsLayoutCreateInfoNVX* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkIndirectCommandsLayoutNVX* pIndirectCommandsLayout); + +VKAPI_ATTR void VKAPI_CALL vkDestroyIndirectCommandsLayoutNVX( + VkDevice device, + VkIndirectCommandsLayoutNVX indirectCommandsLayout, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateObjectTableNVX( + VkDevice device, + const VkObjectTableCreateInfoNVX* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkObjectTableNVX* pObjectTable); + +VKAPI_ATTR void VKAPI_CALL vkDestroyObjectTableNVX( + VkDevice device, + VkObjectTableNVX objectTable, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkRegisterObjectsNVX( + VkDevice device, + VkObjectTableNVX objectTable, + uint32_t objectCount, + const VkObjectTableEntryNVX* const* ppObjectTableEntries, + const uint32_t* pObjectIndices); + +VKAPI_ATTR VkResult VKAPI_CALL vkUnregisterObjectsNVX( + VkDevice device, + VkObjectTableNVX objectTable, + uint32_t objectCount, + const VkObjectEntryTypeNVX* pObjectEntryTypes, + const uint32_t* pObjectIndices); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX( + VkPhysicalDevice physicalDevice, + VkDeviceGeneratedCommandsFeaturesNVX* pFeatures, + VkDeviceGeneratedCommandsLimitsNVX* pLimits); +#endif + +#define VK_NV_clip_space_w_scaling 1 +#define VK_NV_CLIP_SPACE_W_SCALING_SPEC_VERSION 1 +#define VK_NV_CLIP_SPACE_W_SCALING_EXTENSION_NAME "VK_NV_clip_space_w_scaling" + +typedef struct VkViewportWScalingNV { + float xcoeff; + float ycoeff; +} VkViewportWScalingNV; + +typedef struct VkPipelineViewportWScalingStateCreateInfoNV { + VkStructureType sType; + const void* pNext; + VkBool32 viewportWScalingEnable; + uint32_t viewportCount; + const VkViewportWScalingNV* pViewportWScalings; +} VkPipelineViewportWScalingStateCreateInfoNV; + + +typedef void (VKAPI_PTR *PFN_vkCmdSetViewportWScalingNV)(VkCommandBuffer commandBuffer, uint32_t firstViewport, uint32_t viewportCount, const VkViewportWScalingNV* pViewportWScalings); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkCmdSetViewportWScalingNV( + VkCommandBuffer commandBuffer, + uint32_t firstViewport, + uint32_t viewportCount, + const VkViewportWScalingNV* pViewportWScalings); +#endif + +#define VK_EXT_direct_mode_display 1 +#define VK_EXT_DIRECT_MODE_DISPLAY_SPEC_VERSION 1 +#define VK_EXT_DIRECT_MODE_DISPLAY_EXTENSION_NAME "VK_EXT_direct_mode_display" + +typedef VkResult (VKAPI_PTR *PFN_vkReleaseDisplayEXT)(VkPhysicalDevice physicalDevice, VkDisplayKHR display); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkReleaseDisplayEXT( + VkPhysicalDevice physicalDevice, + VkDisplayKHR display); +#endif + +#define VK_EXT_display_surface_counter 1 +#define VK_EXT_DISPLAY_SURFACE_COUNTER_SPEC_VERSION 1 +#define VK_EXT_DISPLAY_SURFACE_COUNTER_EXTENSION_NAME "VK_EXT_display_surface_counter" +#define VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES2_EXT VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_EXT + + +typedef enum VkSurfaceCounterFlagBitsEXT { + VK_SURFACE_COUNTER_VBLANK_EXT = 0x00000001, + VK_SURFACE_COUNTER_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF +} VkSurfaceCounterFlagBitsEXT; +typedef VkFlags VkSurfaceCounterFlagsEXT; + +typedef struct VkSurfaceCapabilities2EXT { + VkStructureType sType; + void* pNext; + uint32_t minImageCount; + uint32_t maxImageCount; + VkExtent2D currentExtent; + VkExtent2D minImageExtent; + VkExtent2D maxImageExtent; + uint32_t maxImageArrayLayers; + VkSurfaceTransformFlagsKHR supportedTransforms; + VkSurfaceTransformFlagBitsKHR currentTransform; + VkCompositeAlphaFlagsKHR supportedCompositeAlpha; + VkImageUsageFlags supportedUsageFlags; + VkSurfaceCounterFlagsEXT supportedSurfaceCounters; +} VkSurfaceCapabilities2EXT; + + +typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceCapabilities2EXT)(VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, VkSurfaceCapabilities2EXT* pSurfaceCapabilities); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceCapabilities2EXT( + VkPhysicalDevice physicalDevice, + VkSurfaceKHR surface, + VkSurfaceCapabilities2EXT* pSurfaceCapabilities); +#endif + +#define VK_EXT_display_control 1 +#define VK_EXT_DISPLAY_CONTROL_SPEC_VERSION 1 +#define VK_EXT_DISPLAY_CONTROL_EXTENSION_NAME "VK_EXT_display_control" + + +typedef enum VkDisplayPowerStateEXT { + VK_DISPLAY_POWER_STATE_OFF_EXT = 0, + VK_DISPLAY_POWER_STATE_SUSPEND_EXT = 1, + VK_DISPLAY_POWER_STATE_ON_EXT = 2, + VK_DISPLAY_POWER_STATE_BEGIN_RANGE_EXT = VK_DISPLAY_POWER_STATE_OFF_EXT, + VK_DISPLAY_POWER_STATE_END_RANGE_EXT = VK_DISPLAY_POWER_STATE_ON_EXT, + VK_DISPLAY_POWER_STATE_RANGE_SIZE_EXT = (VK_DISPLAY_POWER_STATE_ON_EXT - VK_DISPLAY_POWER_STATE_OFF_EXT + 1), + VK_DISPLAY_POWER_STATE_MAX_ENUM_EXT = 0x7FFFFFFF +} VkDisplayPowerStateEXT; + +typedef enum VkDeviceEventTypeEXT { + VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT = 0, + VK_DEVICE_EVENT_TYPE_BEGIN_RANGE_EXT = VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT, + VK_DEVICE_EVENT_TYPE_END_RANGE_EXT = VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT, + VK_DEVICE_EVENT_TYPE_RANGE_SIZE_EXT = (VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT - VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT + 1), + VK_DEVICE_EVENT_TYPE_MAX_ENUM_EXT = 0x7FFFFFFF +} VkDeviceEventTypeEXT; + +typedef enum VkDisplayEventTypeEXT { + VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT = 0, + VK_DISPLAY_EVENT_TYPE_BEGIN_RANGE_EXT = VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT, + VK_DISPLAY_EVENT_TYPE_END_RANGE_EXT = VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT, + VK_DISPLAY_EVENT_TYPE_RANGE_SIZE_EXT = (VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT - VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT + 1), + VK_DISPLAY_EVENT_TYPE_MAX_ENUM_EXT = 0x7FFFFFFF +} VkDisplayEventTypeEXT; + +typedef struct VkDisplayPowerInfoEXT { + VkStructureType sType; + const void* pNext; + VkDisplayPowerStateEXT powerState; +} VkDisplayPowerInfoEXT; + +typedef struct VkDeviceEventInfoEXT { + VkStructureType sType; + const void* pNext; + VkDeviceEventTypeEXT deviceEvent; +} VkDeviceEventInfoEXT; + +typedef struct VkDisplayEventInfoEXT { + VkStructureType sType; + const void* pNext; + VkDisplayEventTypeEXT displayEvent; +} VkDisplayEventInfoEXT; + +typedef struct VkSwapchainCounterCreateInfoEXT { + VkStructureType sType; + const void* pNext; + VkSurfaceCounterFlagsEXT surfaceCounters; +} VkSwapchainCounterCreateInfoEXT; + + +typedef VkResult (VKAPI_PTR *PFN_vkDisplayPowerControlEXT)(VkDevice device, VkDisplayKHR display, const VkDisplayPowerInfoEXT* pDisplayPowerInfo); +typedef VkResult (VKAPI_PTR *PFN_vkRegisterDeviceEventEXT)(VkDevice device, const VkDeviceEventInfoEXT* pDeviceEventInfo, const VkAllocationCallbacks* pAllocator, VkFence* pFence); +typedef VkResult (VKAPI_PTR *PFN_vkRegisterDisplayEventEXT)(VkDevice device, VkDisplayKHR display, const VkDisplayEventInfoEXT* pDisplayEventInfo, const VkAllocationCallbacks* pAllocator, VkFence* pFence); +typedef VkResult (VKAPI_PTR *PFN_vkGetSwapchainCounterEXT)(VkDevice device, VkSwapchainKHR swapchain, VkSurfaceCounterFlagBitsEXT counter, uint64_t* pCounterValue); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkDisplayPowerControlEXT( + VkDevice device, + VkDisplayKHR display, + const VkDisplayPowerInfoEXT* pDisplayPowerInfo); + +VKAPI_ATTR VkResult VKAPI_CALL vkRegisterDeviceEventEXT( + VkDevice device, + const VkDeviceEventInfoEXT* pDeviceEventInfo, + const VkAllocationCallbacks* pAllocator, + VkFence* pFence); + +VKAPI_ATTR VkResult VKAPI_CALL vkRegisterDisplayEventEXT( + VkDevice device, + VkDisplayKHR display, + const VkDisplayEventInfoEXT* pDisplayEventInfo, + const VkAllocationCallbacks* pAllocator, + VkFence* pFence); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetSwapchainCounterEXT( + VkDevice device, + VkSwapchainKHR swapchain, + VkSurfaceCounterFlagBitsEXT counter, + uint64_t* pCounterValue); +#endif + +#define VK_GOOGLE_display_timing 1 +#define VK_GOOGLE_DISPLAY_TIMING_SPEC_VERSION 1 +#define VK_GOOGLE_DISPLAY_TIMING_EXTENSION_NAME "VK_GOOGLE_display_timing" + +typedef struct VkRefreshCycleDurationGOOGLE { + uint64_t refreshDuration; +} VkRefreshCycleDurationGOOGLE; + +typedef struct VkPastPresentationTimingGOOGLE { + uint32_t presentID; + uint64_t desiredPresentTime; + uint64_t actualPresentTime; + uint64_t earliestPresentTime; + uint64_t presentMargin; +} VkPastPresentationTimingGOOGLE; + +typedef struct VkPresentTimeGOOGLE { + uint32_t presentID; + uint64_t desiredPresentTime; +} VkPresentTimeGOOGLE; + +typedef struct VkPresentTimesInfoGOOGLE { + VkStructureType sType; + const void* pNext; + uint32_t swapchainCount; + const VkPresentTimeGOOGLE* pTimes; +} VkPresentTimesInfoGOOGLE; + + +typedef VkResult (VKAPI_PTR *PFN_vkGetRefreshCycleDurationGOOGLE)(VkDevice device, VkSwapchainKHR swapchain, VkRefreshCycleDurationGOOGLE* pDisplayTimingProperties); +typedef VkResult (VKAPI_PTR *PFN_vkGetPastPresentationTimingGOOGLE)(VkDevice device, VkSwapchainKHR swapchain, uint32_t* pPresentationTimingCount, VkPastPresentationTimingGOOGLE* pPresentationTimings); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkGetRefreshCycleDurationGOOGLE( + VkDevice device, + VkSwapchainKHR swapchain, + VkRefreshCycleDurationGOOGLE* pDisplayTimingProperties); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetPastPresentationTimingGOOGLE( + VkDevice device, + VkSwapchainKHR swapchain, + uint32_t* pPresentationTimingCount, + VkPastPresentationTimingGOOGLE* pPresentationTimings); +#endif + +#define VK_NV_sample_mask_override_coverage 1 +#define VK_NV_SAMPLE_MASK_OVERRIDE_COVERAGE_SPEC_VERSION 1 +#define VK_NV_SAMPLE_MASK_OVERRIDE_COVERAGE_EXTENSION_NAME "VK_NV_sample_mask_override_coverage" + + +#define VK_NV_geometry_shader_passthrough 1 +#define VK_NV_GEOMETRY_SHADER_PASSTHROUGH_SPEC_VERSION 1 +#define VK_NV_GEOMETRY_SHADER_PASSTHROUGH_EXTENSION_NAME "VK_NV_geometry_shader_passthrough" + + +#define VK_NV_viewport_array2 1 +#define VK_NV_VIEWPORT_ARRAY2_SPEC_VERSION 1 +#define VK_NV_VIEWPORT_ARRAY2_EXTENSION_NAME "VK_NV_viewport_array2" + + +#define VK_NVX_multiview_per_view_attributes 1 +#define VK_NVX_MULTIVIEW_PER_VIEW_ATTRIBUTES_SPEC_VERSION 1 +#define VK_NVX_MULTIVIEW_PER_VIEW_ATTRIBUTES_EXTENSION_NAME "VK_NVX_multiview_per_view_attributes" + +typedef struct VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX { + VkStructureType sType; + void* pNext; + VkBool32 perViewPositionAllComponents; +} VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX; + + + +#define VK_NV_viewport_swizzle 1 +#define VK_NV_VIEWPORT_SWIZZLE_SPEC_VERSION 1 +#define VK_NV_VIEWPORT_SWIZZLE_EXTENSION_NAME "VK_NV_viewport_swizzle" + + +typedef enum VkViewportCoordinateSwizzleNV { + VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_X_NV = 0, + VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_X_NV = 1, + VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_Y_NV = 2, + VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_Y_NV = 3, + VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_Z_NV = 4, + VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_Z_NV = 5, + VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_W_NV = 6, + VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_W_NV = 7, + VK_VIEWPORT_COORDINATE_SWIZZLE_BEGIN_RANGE_NV = VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_X_NV, + VK_VIEWPORT_COORDINATE_SWIZZLE_END_RANGE_NV = VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_W_NV, + VK_VIEWPORT_COORDINATE_SWIZZLE_RANGE_SIZE_NV = (VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_W_NV - VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_X_NV + 1), + VK_VIEWPORT_COORDINATE_SWIZZLE_MAX_ENUM_NV = 0x7FFFFFFF +} VkViewportCoordinateSwizzleNV; + +typedef VkFlags VkPipelineViewportSwizzleStateCreateFlagsNV; + +typedef struct VkViewportSwizzleNV { + VkViewportCoordinateSwizzleNV x; + VkViewportCoordinateSwizzleNV y; + VkViewportCoordinateSwizzleNV z; + VkViewportCoordinateSwizzleNV w; +} VkViewportSwizzleNV; + +typedef struct VkPipelineViewportSwizzleStateCreateInfoNV { + VkStructureType sType; + const void* pNext; + VkPipelineViewportSwizzleStateCreateFlagsNV flags; + uint32_t viewportCount; + const VkViewportSwizzleNV* pViewportSwizzles; +} VkPipelineViewportSwizzleStateCreateInfoNV; + + + +#define VK_EXT_discard_rectangles 1 +#define VK_EXT_DISCARD_RECTANGLES_SPEC_VERSION 1 +#define VK_EXT_DISCARD_RECTANGLES_EXTENSION_NAME "VK_EXT_discard_rectangles" + + +typedef enum VkDiscardRectangleModeEXT { + VK_DISCARD_RECTANGLE_MODE_INCLUSIVE_EXT = 0, + VK_DISCARD_RECTANGLE_MODE_EXCLUSIVE_EXT = 1, + VK_DISCARD_RECTANGLE_MODE_BEGIN_RANGE_EXT = VK_DISCARD_RECTANGLE_MODE_INCLUSIVE_EXT, + VK_DISCARD_RECTANGLE_MODE_END_RANGE_EXT = VK_DISCARD_RECTANGLE_MODE_EXCLUSIVE_EXT, + VK_DISCARD_RECTANGLE_MODE_RANGE_SIZE_EXT = (VK_DISCARD_RECTANGLE_MODE_EXCLUSIVE_EXT - VK_DISCARD_RECTANGLE_MODE_INCLUSIVE_EXT + 1), + VK_DISCARD_RECTANGLE_MODE_MAX_ENUM_EXT = 0x7FFFFFFF +} VkDiscardRectangleModeEXT; + +typedef VkFlags VkPipelineDiscardRectangleStateCreateFlagsEXT; + +typedef struct VkPhysicalDeviceDiscardRectanglePropertiesEXT { + VkStructureType sType; + void* pNext; + uint32_t maxDiscardRectangles; +} VkPhysicalDeviceDiscardRectanglePropertiesEXT; + +typedef struct VkPipelineDiscardRectangleStateCreateInfoEXT { + VkStructureType sType; + const void* pNext; + VkPipelineDiscardRectangleStateCreateFlagsEXT flags; + VkDiscardRectangleModeEXT discardRectangleMode; + uint32_t discardRectangleCount; + const VkRect2D* pDiscardRectangles; +} VkPipelineDiscardRectangleStateCreateInfoEXT; + + +typedef void (VKAPI_PTR *PFN_vkCmdSetDiscardRectangleEXT)(VkCommandBuffer commandBuffer, uint32_t firstDiscardRectangle, uint32_t discardRectangleCount, const VkRect2D* pDiscardRectangles); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkCmdSetDiscardRectangleEXT( + VkCommandBuffer commandBuffer, + uint32_t firstDiscardRectangle, + uint32_t discardRectangleCount, + const VkRect2D* pDiscardRectangles); +#endif + +#define VK_EXT_conservative_rasterization 1 +#define VK_EXT_CONSERVATIVE_RASTERIZATION_SPEC_VERSION 1 +#define VK_EXT_CONSERVATIVE_RASTERIZATION_EXTENSION_NAME "VK_EXT_conservative_rasterization" + + +typedef enum VkConservativeRasterizationModeEXT { + VK_CONSERVATIVE_RASTERIZATION_MODE_DISABLED_EXT = 0, + VK_CONSERVATIVE_RASTERIZATION_MODE_OVERESTIMATE_EXT = 1, + VK_CONSERVATIVE_RASTERIZATION_MODE_UNDERESTIMATE_EXT = 2, + VK_CONSERVATIVE_RASTERIZATION_MODE_BEGIN_RANGE_EXT = VK_CONSERVATIVE_RASTERIZATION_MODE_DISABLED_EXT, + VK_CONSERVATIVE_RASTERIZATION_MODE_END_RANGE_EXT = VK_CONSERVATIVE_RASTERIZATION_MODE_UNDERESTIMATE_EXT, + VK_CONSERVATIVE_RASTERIZATION_MODE_RANGE_SIZE_EXT = (VK_CONSERVATIVE_RASTERIZATION_MODE_UNDERESTIMATE_EXT - VK_CONSERVATIVE_RASTERIZATION_MODE_DISABLED_EXT + 1), + VK_CONSERVATIVE_RASTERIZATION_MODE_MAX_ENUM_EXT = 0x7FFFFFFF +} VkConservativeRasterizationModeEXT; + +typedef VkFlags VkPipelineRasterizationConservativeStateCreateFlagsEXT; + +typedef struct VkPhysicalDeviceConservativeRasterizationPropertiesEXT { + VkStructureType sType; + void* pNext; + float primitiveOverestimationSize; + float maxExtraPrimitiveOverestimationSize; + float extraPrimitiveOverestimationSizeGranularity; + VkBool32 primitiveUnderestimation; + VkBool32 conservativePointAndLineRasterization; + VkBool32 degenerateTrianglesRasterized; + VkBool32 degenerateLinesRasterized; + VkBool32 fullyCoveredFragmentShaderInputVariable; + VkBool32 conservativeRasterizationPostDepthCoverage; +} VkPhysicalDeviceConservativeRasterizationPropertiesEXT; + +typedef struct VkPipelineRasterizationConservativeStateCreateInfoEXT { + VkStructureType sType; + const void* pNext; + VkPipelineRasterizationConservativeStateCreateFlagsEXT flags; + VkConservativeRasterizationModeEXT conservativeRasterizationMode; + float extraPrimitiveOverestimationSize; +} VkPipelineRasterizationConservativeStateCreateInfoEXT; + + + +#define VK_EXT_swapchain_colorspace 1 +#define VK_EXT_SWAPCHAIN_COLOR_SPACE_SPEC_VERSION 3 +#define VK_EXT_SWAPCHAIN_COLOR_SPACE_EXTENSION_NAME "VK_EXT_swapchain_colorspace" + + +#define VK_EXT_hdr_metadata 1 +#define VK_EXT_HDR_METADATA_SPEC_VERSION 1 +#define VK_EXT_HDR_METADATA_EXTENSION_NAME "VK_EXT_hdr_metadata" + +typedef struct VkXYColorEXT { + float x; + float y; +} VkXYColorEXT; + +typedef struct VkHdrMetadataEXT { + VkStructureType sType; + const void* pNext; + VkXYColorEXT displayPrimaryRed; + VkXYColorEXT displayPrimaryGreen; + VkXYColorEXT displayPrimaryBlue; + VkXYColorEXT whitePoint; + float maxLuminance; + float minLuminance; + float maxContentLightLevel; + float maxFrameAverageLightLevel; +} VkHdrMetadataEXT; + + +typedef void (VKAPI_PTR *PFN_vkSetHdrMetadataEXT)(VkDevice device, uint32_t swapchainCount, const VkSwapchainKHR* pSwapchains, const VkHdrMetadataEXT* pMetadata); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkSetHdrMetadataEXT( + VkDevice device, + uint32_t swapchainCount, + const VkSwapchainKHR* pSwapchains, + const VkHdrMetadataEXT* pMetadata); +#endif + +#define VK_EXT_external_memory_dma_buf 1 +#define VK_EXT_EXTERNAL_MEMORY_DMA_BUF_SPEC_VERSION 1 +#define VK_EXT_EXTERNAL_MEMORY_DMA_BUF_EXTENSION_NAME "VK_EXT_external_memory_dma_buf" + + +#define VK_EXT_queue_family_foreign 1 +#define VK_EXT_QUEUE_FAMILY_FOREIGN_SPEC_VERSION 1 +#define VK_EXT_QUEUE_FAMILY_FOREIGN_EXTENSION_NAME "VK_EXT_queue_family_foreign" +#define VK_QUEUE_FAMILY_FOREIGN_EXT (~0U-2) + + +#define VK_EXT_debug_utils 1 +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDebugUtilsMessengerEXT) + +#define VK_EXT_DEBUG_UTILS_SPEC_VERSION 1 +#define VK_EXT_DEBUG_UTILS_EXTENSION_NAME "VK_EXT_debug_utils" + +typedef VkFlags VkDebugUtilsMessengerCallbackDataFlagsEXT; +typedef VkFlags VkDebugUtilsMessengerCreateFlagsEXT; + +typedef enum VkDebugUtilsMessageSeverityFlagBitsEXT { + VK_DEBUG_UTILS_MESSAGE_SEVERITY_VERBOSE_BIT_EXT = 0x00000001, + VK_DEBUG_UTILS_MESSAGE_SEVERITY_INFO_BIT_EXT = 0x00000010, + VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT = 0x00000100, + VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT = 0x00001000, + VK_DEBUG_UTILS_MESSAGE_SEVERITY_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF +} VkDebugUtilsMessageSeverityFlagBitsEXT; +typedef VkFlags VkDebugUtilsMessageSeverityFlagsEXT; + +typedef enum VkDebugUtilsMessageTypeFlagBitsEXT { + VK_DEBUG_UTILS_MESSAGE_TYPE_GENERAL_BIT_EXT = 0x00000001, + VK_DEBUG_UTILS_MESSAGE_TYPE_VALIDATION_BIT_EXT = 0x00000002, + VK_DEBUG_UTILS_MESSAGE_TYPE_PERFORMANCE_BIT_EXT = 0x00000004, + VK_DEBUG_UTILS_MESSAGE_TYPE_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF +} VkDebugUtilsMessageTypeFlagBitsEXT; +typedef VkFlags VkDebugUtilsMessageTypeFlagsEXT; + +typedef struct VkDebugUtilsObjectNameInfoEXT { + VkStructureType sType; + const void* pNext; + VkObjectType objectType; + uint64_t objectHandle; + const char* pObjectName; +} VkDebugUtilsObjectNameInfoEXT; + +typedef struct VkDebugUtilsObjectTagInfoEXT { + VkStructureType sType; + const void* pNext; + VkObjectType objectType; + uint64_t objectHandle; + uint64_t tagName; + size_t tagSize; + const void* pTag; +} VkDebugUtilsObjectTagInfoEXT; + +typedef struct VkDebugUtilsLabelEXT { + VkStructureType sType; + const void* pNext; + const char* pLabelName; + float color[4]; +} VkDebugUtilsLabelEXT; + +typedef struct VkDebugUtilsMessengerCallbackDataEXT { + VkStructureType sType; + const void* pNext; + VkDebugUtilsMessengerCallbackDataFlagsEXT flags; + const char* pMessageIdName; + int32_t messageIdNumber; + const char* pMessage; + uint32_t queueLabelCount; + VkDebugUtilsLabelEXT* pQueueLabels; + uint32_t cmdBufLabelCount; + VkDebugUtilsLabelEXT* pCmdBufLabels; + uint32_t objectCount; + VkDebugUtilsObjectNameInfoEXT* pObjects; +} VkDebugUtilsMessengerCallbackDataEXT; + +typedef VkBool32 (VKAPI_PTR *PFN_vkDebugUtilsMessengerCallbackEXT)( + VkDebugUtilsMessageSeverityFlagBitsEXT messageSeverity, + VkDebugUtilsMessageTypeFlagsEXT messageType, + const VkDebugUtilsMessengerCallbackDataEXT* pCallbackData, + void* pUserData); + +typedef struct VkDebugUtilsMessengerCreateInfoEXT { + VkStructureType sType; + const void* pNext; + VkDebugUtilsMessengerCreateFlagsEXT flags; + VkDebugUtilsMessageSeverityFlagsEXT messageSeverity; + VkDebugUtilsMessageTypeFlagsEXT messageType; + PFN_vkDebugUtilsMessengerCallbackEXT pfnUserCallback; + void* pUserData; +} VkDebugUtilsMessengerCreateInfoEXT; + + +typedef VkResult (VKAPI_PTR *PFN_vkSetDebugUtilsObjectNameEXT)(VkDevice device, const VkDebugUtilsObjectNameInfoEXT* pNameInfo); +typedef VkResult (VKAPI_PTR *PFN_vkSetDebugUtilsObjectTagEXT)(VkDevice device, const VkDebugUtilsObjectTagInfoEXT* pTagInfo); +typedef void (VKAPI_PTR *PFN_vkQueueBeginDebugUtilsLabelEXT)(VkQueue queue, const VkDebugUtilsLabelEXT* pLabelInfo); +typedef void (VKAPI_PTR *PFN_vkQueueEndDebugUtilsLabelEXT)(VkQueue queue); +typedef void (VKAPI_PTR *PFN_vkQueueInsertDebugUtilsLabelEXT)(VkQueue queue, const VkDebugUtilsLabelEXT* pLabelInfo); +typedef void (VKAPI_PTR *PFN_vkCmdBeginDebugUtilsLabelEXT)(VkCommandBuffer commandBuffer, const VkDebugUtilsLabelEXT* pLabelInfo); +typedef void (VKAPI_PTR *PFN_vkCmdEndDebugUtilsLabelEXT)(VkCommandBuffer commandBuffer); +typedef void (VKAPI_PTR *PFN_vkCmdInsertDebugUtilsLabelEXT)(VkCommandBuffer commandBuffer, const VkDebugUtilsLabelEXT* pLabelInfo); +typedef VkResult (VKAPI_PTR *PFN_vkCreateDebugUtilsMessengerEXT)(VkInstance instance, const VkDebugUtilsMessengerCreateInfoEXT* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDebugUtilsMessengerEXT* pMessenger); +typedef void (VKAPI_PTR *PFN_vkDestroyDebugUtilsMessengerEXT)(VkInstance instance, VkDebugUtilsMessengerEXT messenger, const VkAllocationCallbacks* pAllocator); +typedef void (VKAPI_PTR *PFN_vkSubmitDebugUtilsMessageEXT)(VkInstance instance, VkDebugUtilsMessageSeverityFlagBitsEXT messageSeverity, VkDebugUtilsMessageTypeFlagsEXT messageTypes, const VkDebugUtilsMessengerCallbackDataEXT* pCallbackData); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkSetDebugUtilsObjectNameEXT( + VkDevice device, + const VkDebugUtilsObjectNameInfoEXT* pNameInfo); + +VKAPI_ATTR VkResult VKAPI_CALL vkSetDebugUtilsObjectTagEXT( + VkDevice device, + const VkDebugUtilsObjectTagInfoEXT* pTagInfo); + +VKAPI_ATTR void VKAPI_CALL vkQueueBeginDebugUtilsLabelEXT( + VkQueue queue, + const VkDebugUtilsLabelEXT* pLabelInfo); + +VKAPI_ATTR void VKAPI_CALL vkQueueEndDebugUtilsLabelEXT( + VkQueue queue); + +VKAPI_ATTR void VKAPI_CALL vkQueueInsertDebugUtilsLabelEXT( + VkQueue queue, + const VkDebugUtilsLabelEXT* pLabelInfo); + +VKAPI_ATTR void VKAPI_CALL vkCmdBeginDebugUtilsLabelEXT( + VkCommandBuffer commandBuffer, + const VkDebugUtilsLabelEXT* pLabelInfo); + +VKAPI_ATTR void VKAPI_CALL vkCmdEndDebugUtilsLabelEXT( + VkCommandBuffer commandBuffer); + +VKAPI_ATTR void VKAPI_CALL vkCmdInsertDebugUtilsLabelEXT( + VkCommandBuffer commandBuffer, + const VkDebugUtilsLabelEXT* pLabelInfo); + +VKAPI_ATTR VkResult VKAPI_CALL vkCreateDebugUtilsMessengerEXT( + VkInstance instance, + const VkDebugUtilsMessengerCreateInfoEXT* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkDebugUtilsMessengerEXT* pMessenger); + +VKAPI_ATTR void VKAPI_CALL vkDestroyDebugUtilsMessengerEXT( + VkInstance instance, + VkDebugUtilsMessengerEXT messenger, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR void VKAPI_CALL vkSubmitDebugUtilsMessageEXT( + VkInstance instance, + VkDebugUtilsMessageSeverityFlagBitsEXT messageSeverity, + VkDebugUtilsMessageTypeFlagsEXT messageTypes, + const VkDebugUtilsMessengerCallbackDataEXT* pCallbackData); +#endif + +#define VK_EXT_sampler_filter_minmax 1 +#define VK_EXT_SAMPLER_FILTER_MINMAX_SPEC_VERSION 1 +#define VK_EXT_SAMPLER_FILTER_MINMAX_EXTENSION_NAME "VK_EXT_sampler_filter_minmax" + + +typedef enum VkSamplerReductionModeEXT { + VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT = 0, + VK_SAMPLER_REDUCTION_MODE_MIN_EXT = 1, + VK_SAMPLER_REDUCTION_MODE_MAX_EXT = 2, + VK_SAMPLER_REDUCTION_MODE_BEGIN_RANGE_EXT = VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT, + VK_SAMPLER_REDUCTION_MODE_END_RANGE_EXT = VK_SAMPLER_REDUCTION_MODE_MAX_EXT, + VK_SAMPLER_REDUCTION_MODE_RANGE_SIZE_EXT = (VK_SAMPLER_REDUCTION_MODE_MAX_EXT - VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT + 1), + VK_SAMPLER_REDUCTION_MODE_MAX_ENUM_EXT = 0x7FFFFFFF +} VkSamplerReductionModeEXT; + +typedef struct VkSamplerReductionModeCreateInfoEXT { + VkStructureType sType; + const void* pNext; + VkSamplerReductionModeEXT reductionMode; +} VkSamplerReductionModeCreateInfoEXT; + +typedef struct VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT { + VkStructureType sType; + void* pNext; + VkBool32 filterMinmaxSingleComponentFormats; + VkBool32 filterMinmaxImageComponentMapping; +} VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT; + + + +#define VK_AMD_gpu_shader_int16 1 +#define VK_AMD_GPU_SHADER_INT16_SPEC_VERSION 1 +#define VK_AMD_GPU_SHADER_INT16_EXTENSION_NAME "VK_AMD_gpu_shader_int16" + + +#define VK_AMD_mixed_attachment_samples 1 +#define VK_AMD_MIXED_ATTACHMENT_SAMPLES_SPEC_VERSION 1 +#define VK_AMD_MIXED_ATTACHMENT_SAMPLES_EXTENSION_NAME "VK_AMD_mixed_attachment_samples" + + +#define VK_AMD_shader_fragment_mask 1 +#define VK_AMD_SHADER_FRAGMENT_MASK_SPEC_VERSION 1 +#define VK_AMD_SHADER_FRAGMENT_MASK_EXTENSION_NAME "VK_AMD_shader_fragment_mask" + + +#define VK_EXT_shader_stencil_export 1 +#define VK_EXT_SHADER_STENCIL_EXPORT_SPEC_VERSION 1 +#define VK_EXT_SHADER_STENCIL_EXPORT_EXTENSION_NAME "VK_EXT_shader_stencil_export" + + +#define VK_EXT_sample_locations 1 +#define VK_EXT_SAMPLE_LOCATIONS_SPEC_VERSION 1 +#define VK_EXT_SAMPLE_LOCATIONS_EXTENSION_NAME "VK_EXT_sample_locations" + +typedef struct VkSampleLocationEXT { + float x; + float y; +} VkSampleLocationEXT; + +typedef struct VkSampleLocationsInfoEXT { + VkStructureType sType; + const void* pNext; + VkSampleCountFlagBits sampleLocationsPerPixel; + VkExtent2D sampleLocationGridSize; + uint32_t sampleLocationsCount; + const VkSampleLocationEXT* pSampleLocations; +} VkSampleLocationsInfoEXT; + +typedef struct VkAttachmentSampleLocationsEXT { + uint32_t attachmentIndex; + VkSampleLocationsInfoEXT sampleLocationsInfo; +} VkAttachmentSampleLocationsEXT; + +typedef struct VkSubpassSampleLocationsEXT { + uint32_t subpassIndex; + VkSampleLocationsInfoEXT sampleLocationsInfo; +} VkSubpassSampleLocationsEXT; + +typedef struct VkRenderPassSampleLocationsBeginInfoEXT { + VkStructureType sType; + const void* pNext; + uint32_t attachmentInitialSampleLocationsCount; + const VkAttachmentSampleLocationsEXT* pAttachmentInitialSampleLocations; + uint32_t postSubpassSampleLocationsCount; + const VkSubpassSampleLocationsEXT* pPostSubpassSampleLocations; +} VkRenderPassSampleLocationsBeginInfoEXT; + +typedef struct VkPipelineSampleLocationsStateCreateInfoEXT { + VkStructureType sType; + const void* pNext; + VkBool32 sampleLocationsEnable; + VkSampleLocationsInfoEXT sampleLocationsInfo; +} VkPipelineSampleLocationsStateCreateInfoEXT; + +typedef struct VkPhysicalDeviceSampleLocationsPropertiesEXT { + VkStructureType sType; + void* pNext; + VkSampleCountFlags sampleLocationSampleCounts; + VkExtent2D maxSampleLocationGridSize; + float sampleLocationCoordinateRange[2]; + uint32_t sampleLocationSubPixelBits; + VkBool32 variableSampleLocations; +} VkPhysicalDeviceSampleLocationsPropertiesEXT; + +typedef struct VkMultisamplePropertiesEXT { + VkStructureType sType; + void* pNext; + VkExtent2D maxSampleLocationGridSize; +} VkMultisamplePropertiesEXT; + + +typedef void (VKAPI_PTR *PFN_vkCmdSetSampleLocationsEXT)(VkCommandBuffer commandBuffer, const VkSampleLocationsInfoEXT* pSampleLocationsInfo); +typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceMultisamplePropertiesEXT)(VkPhysicalDevice physicalDevice, VkSampleCountFlagBits samples, VkMultisamplePropertiesEXT* pMultisampleProperties); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkCmdSetSampleLocationsEXT( + VkCommandBuffer commandBuffer, + const VkSampleLocationsInfoEXT* pSampleLocationsInfo); + +VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceMultisamplePropertiesEXT( + VkPhysicalDevice physicalDevice, + VkSampleCountFlagBits samples, + VkMultisamplePropertiesEXT* pMultisampleProperties); +#endif + +#define VK_EXT_blend_operation_advanced 1 +#define VK_EXT_BLEND_OPERATION_ADVANCED_SPEC_VERSION 2 +#define VK_EXT_BLEND_OPERATION_ADVANCED_EXTENSION_NAME "VK_EXT_blend_operation_advanced" + + +typedef enum VkBlendOverlapEXT { + VK_BLEND_OVERLAP_UNCORRELATED_EXT = 0, + VK_BLEND_OVERLAP_DISJOINT_EXT = 1, + VK_BLEND_OVERLAP_CONJOINT_EXT = 2, + VK_BLEND_OVERLAP_BEGIN_RANGE_EXT = VK_BLEND_OVERLAP_UNCORRELATED_EXT, + VK_BLEND_OVERLAP_END_RANGE_EXT = VK_BLEND_OVERLAP_CONJOINT_EXT, + VK_BLEND_OVERLAP_RANGE_SIZE_EXT = (VK_BLEND_OVERLAP_CONJOINT_EXT - VK_BLEND_OVERLAP_UNCORRELATED_EXT + 1), + VK_BLEND_OVERLAP_MAX_ENUM_EXT = 0x7FFFFFFF +} VkBlendOverlapEXT; + +typedef struct VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT { + VkStructureType sType; + void* pNext; + VkBool32 advancedBlendCoherentOperations; +} VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT; + +typedef struct VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT { + VkStructureType sType; + void* pNext; + uint32_t advancedBlendMaxColorAttachments; + VkBool32 advancedBlendIndependentBlend; + VkBool32 advancedBlendNonPremultipliedSrcColor; + VkBool32 advancedBlendNonPremultipliedDstColor; + VkBool32 advancedBlendCorrelatedOverlap; + VkBool32 advancedBlendAllOperations; +} VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT; + +typedef struct VkPipelineColorBlendAdvancedStateCreateInfoEXT { + VkStructureType sType; + const void* pNext; + VkBool32 srcPremultiplied; + VkBool32 dstPremultiplied; + VkBlendOverlapEXT blendOverlap; +} VkPipelineColorBlendAdvancedStateCreateInfoEXT; + + + +#define VK_NV_fragment_coverage_to_color 1 +#define VK_NV_FRAGMENT_COVERAGE_TO_COLOR_SPEC_VERSION 1 +#define VK_NV_FRAGMENT_COVERAGE_TO_COLOR_EXTENSION_NAME "VK_NV_fragment_coverage_to_color" + +typedef VkFlags VkPipelineCoverageToColorStateCreateFlagsNV; + +typedef struct VkPipelineCoverageToColorStateCreateInfoNV { + VkStructureType sType; + const void* pNext; + VkPipelineCoverageToColorStateCreateFlagsNV flags; + VkBool32 coverageToColorEnable; + uint32_t coverageToColorLocation; +} VkPipelineCoverageToColorStateCreateInfoNV; + + + +#define VK_NV_framebuffer_mixed_samples 1 +#define VK_NV_FRAMEBUFFER_MIXED_SAMPLES_SPEC_VERSION 1 +#define VK_NV_FRAMEBUFFER_MIXED_SAMPLES_EXTENSION_NAME "VK_NV_framebuffer_mixed_samples" + + +typedef enum VkCoverageModulationModeNV { + VK_COVERAGE_MODULATION_MODE_NONE_NV = 0, + VK_COVERAGE_MODULATION_MODE_RGB_NV = 1, + VK_COVERAGE_MODULATION_MODE_ALPHA_NV = 2, + VK_COVERAGE_MODULATION_MODE_RGBA_NV = 3, + VK_COVERAGE_MODULATION_MODE_BEGIN_RANGE_NV = VK_COVERAGE_MODULATION_MODE_NONE_NV, + VK_COVERAGE_MODULATION_MODE_END_RANGE_NV = VK_COVERAGE_MODULATION_MODE_RGBA_NV, + VK_COVERAGE_MODULATION_MODE_RANGE_SIZE_NV = (VK_COVERAGE_MODULATION_MODE_RGBA_NV - VK_COVERAGE_MODULATION_MODE_NONE_NV + 1), + VK_COVERAGE_MODULATION_MODE_MAX_ENUM_NV = 0x7FFFFFFF +} VkCoverageModulationModeNV; + +typedef VkFlags VkPipelineCoverageModulationStateCreateFlagsNV; + +typedef struct VkPipelineCoverageModulationStateCreateInfoNV { + VkStructureType sType; + const void* pNext; + VkPipelineCoverageModulationStateCreateFlagsNV flags; + VkCoverageModulationModeNV coverageModulationMode; + VkBool32 coverageModulationTableEnable; + uint32_t coverageModulationTableCount; + const float* pCoverageModulationTable; +} VkPipelineCoverageModulationStateCreateInfoNV; + + + +#define VK_NV_fill_rectangle 1 +#define VK_NV_FILL_RECTANGLE_SPEC_VERSION 1 +#define VK_NV_FILL_RECTANGLE_EXTENSION_NAME "VK_NV_fill_rectangle" + + +#define VK_EXT_post_depth_coverage 1 +#define VK_EXT_POST_DEPTH_COVERAGE_SPEC_VERSION 1 +#define VK_EXT_POST_DEPTH_COVERAGE_EXTENSION_NAME "VK_EXT_post_depth_coverage" + + +#define VK_EXT_validation_cache 1 +VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkValidationCacheEXT) + +#define VK_EXT_VALIDATION_CACHE_SPEC_VERSION 1 +#define VK_EXT_VALIDATION_CACHE_EXTENSION_NAME "VK_EXT_validation_cache" +#define VK_DEBUG_REPORT_OBJECT_TYPE_VALIDATION_CACHE_EXT VK_DEBUG_REPORT_OBJECT_TYPE_VALIDATION_CACHE_EXT_EXT + + +typedef enum VkValidationCacheHeaderVersionEXT { + VK_VALIDATION_CACHE_HEADER_VERSION_ONE_EXT = 1, + VK_VALIDATION_CACHE_HEADER_VERSION_BEGIN_RANGE_EXT = VK_VALIDATION_CACHE_HEADER_VERSION_ONE_EXT, + VK_VALIDATION_CACHE_HEADER_VERSION_END_RANGE_EXT = VK_VALIDATION_CACHE_HEADER_VERSION_ONE_EXT, + VK_VALIDATION_CACHE_HEADER_VERSION_RANGE_SIZE_EXT = (VK_VALIDATION_CACHE_HEADER_VERSION_ONE_EXT - VK_VALIDATION_CACHE_HEADER_VERSION_ONE_EXT + 1), + VK_VALIDATION_CACHE_HEADER_VERSION_MAX_ENUM_EXT = 0x7FFFFFFF +} VkValidationCacheHeaderVersionEXT; + +typedef VkFlags VkValidationCacheCreateFlagsEXT; + +typedef struct VkValidationCacheCreateInfoEXT { + VkStructureType sType; + const void* pNext; + VkValidationCacheCreateFlagsEXT flags; + size_t initialDataSize; + const void* pInitialData; +} VkValidationCacheCreateInfoEXT; + +typedef struct VkShaderModuleValidationCacheCreateInfoEXT { + VkStructureType sType; + const void* pNext; + VkValidationCacheEXT validationCache; +} VkShaderModuleValidationCacheCreateInfoEXT; + + +typedef VkResult (VKAPI_PTR *PFN_vkCreateValidationCacheEXT)(VkDevice device, const VkValidationCacheCreateInfoEXT* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkValidationCacheEXT* pValidationCache); +typedef void (VKAPI_PTR *PFN_vkDestroyValidationCacheEXT)(VkDevice device, VkValidationCacheEXT validationCache, const VkAllocationCallbacks* pAllocator); +typedef VkResult (VKAPI_PTR *PFN_vkMergeValidationCachesEXT)(VkDevice device, VkValidationCacheEXT dstCache, uint32_t srcCacheCount, const VkValidationCacheEXT* pSrcCaches); +typedef VkResult (VKAPI_PTR *PFN_vkGetValidationCacheDataEXT)(VkDevice device, VkValidationCacheEXT validationCache, size_t* pDataSize, void* pData); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkCreateValidationCacheEXT( + VkDevice device, + const VkValidationCacheCreateInfoEXT* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkValidationCacheEXT* pValidationCache); + +VKAPI_ATTR void VKAPI_CALL vkDestroyValidationCacheEXT( + VkDevice device, + VkValidationCacheEXT validationCache, + const VkAllocationCallbacks* pAllocator); + +VKAPI_ATTR VkResult VKAPI_CALL vkMergeValidationCachesEXT( + VkDevice device, + VkValidationCacheEXT dstCache, + uint32_t srcCacheCount, + const VkValidationCacheEXT* pSrcCaches); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetValidationCacheDataEXT( + VkDevice device, + VkValidationCacheEXT validationCache, + size_t* pDataSize, + void* pData); +#endif + +#define VK_EXT_shader_viewport_index_layer 1 +#define VK_EXT_SHADER_VIEWPORT_INDEX_LAYER_SPEC_VERSION 1 +#define VK_EXT_SHADER_VIEWPORT_INDEX_LAYER_EXTENSION_NAME "VK_EXT_shader_viewport_index_layer" + + +#define VK_EXT_global_priority 1 +#define VK_EXT_GLOBAL_PRIORITY_SPEC_VERSION 2 +#define VK_EXT_GLOBAL_PRIORITY_EXTENSION_NAME "VK_EXT_global_priority" + + +typedef enum VkQueueGlobalPriorityEXT { + VK_QUEUE_GLOBAL_PRIORITY_LOW_EXT = 128, + VK_QUEUE_GLOBAL_PRIORITY_MEDIUM_EXT = 256, + VK_QUEUE_GLOBAL_PRIORITY_HIGH_EXT = 512, + VK_QUEUE_GLOBAL_PRIORITY_REALTIME_EXT = 1024, + VK_QUEUE_GLOBAL_PRIORITY_BEGIN_RANGE_EXT = VK_QUEUE_GLOBAL_PRIORITY_LOW_EXT, + VK_QUEUE_GLOBAL_PRIORITY_END_RANGE_EXT = VK_QUEUE_GLOBAL_PRIORITY_REALTIME_EXT, + VK_QUEUE_GLOBAL_PRIORITY_RANGE_SIZE_EXT = (VK_QUEUE_GLOBAL_PRIORITY_REALTIME_EXT - VK_QUEUE_GLOBAL_PRIORITY_LOW_EXT + 1), + VK_QUEUE_GLOBAL_PRIORITY_MAX_ENUM_EXT = 0x7FFFFFFF +} VkQueueGlobalPriorityEXT; + +typedef struct VkDeviceQueueGlobalPriorityCreateInfoEXT { + VkStructureType sType; + const void* pNext; + VkQueueGlobalPriorityEXT globalPriority; +} VkDeviceQueueGlobalPriorityCreateInfoEXT; + + + +#define VK_EXT_external_memory_host 1 +#define VK_EXT_EXTERNAL_MEMORY_HOST_SPEC_VERSION 1 +#define VK_EXT_EXTERNAL_MEMORY_HOST_EXTENSION_NAME "VK_EXT_external_memory_host" + +typedef struct VkImportMemoryHostPointerInfoEXT { + VkStructureType sType; + const void* pNext; + VkExternalMemoryHandleTypeFlagBits handleType; + void* pHostPointer; +} VkImportMemoryHostPointerInfoEXT; + +typedef struct VkMemoryHostPointerPropertiesEXT { + VkStructureType sType; + void* pNext; + uint32_t memoryTypeBits; +} VkMemoryHostPointerPropertiesEXT; + +typedef struct VkPhysicalDeviceExternalMemoryHostPropertiesEXT { + VkStructureType sType; + void* pNext; + VkDeviceSize minImportedHostPointerAlignment; +} VkPhysicalDeviceExternalMemoryHostPropertiesEXT; + + +typedef VkResult (VKAPI_PTR *PFN_vkGetMemoryHostPointerPropertiesEXT)(VkDevice device, VkExternalMemoryHandleTypeFlagBits handleType, const void* pHostPointer, VkMemoryHostPointerPropertiesEXT* pMemoryHostPointerProperties); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryHostPointerPropertiesEXT( + VkDevice device, + VkExternalMemoryHandleTypeFlagBits handleType, + const void* pHostPointer, + VkMemoryHostPointerPropertiesEXT* pMemoryHostPointerProperties); +#endif + +#define VK_AMD_buffer_marker 1 +#define VK_AMD_BUFFER_MARKER_SPEC_VERSION 1 +#define VK_AMD_BUFFER_MARKER_EXTENSION_NAME "VK_AMD_buffer_marker" + +typedef void (VKAPI_PTR *PFN_vkCmdWriteBufferMarkerAMD)(VkCommandBuffer commandBuffer, VkPipelineStageFlagBits pipelineStage, VkBuffer dstBuffer, VkDeviceSize dstOffset, uint32_t marker); + +#ifndef VK_NO_PROTOTYPES +VKAPI_ATTR void VKAPI_CALL vkCmdWriteBufferMarkerAMD( + VkCommandBuffer commandBuffer, + VkPipelineStageFlagBits pipelineStage, + VkBuffer dstBuffer, + VkDeviceSize dstOffset, + uint32_t marker); +#endif + +#define VK_EXT_vertex_attribute_divisor 1 +#define VK_EXT_VERTEX_ATTRIBUTE_DIVISOR_SPEC_VERSION 1 +#define VK_EXT_VERTEX_ATTRIBUTE_DIVISOR_EXTENSION_NAME "VK_EXT_vertex_attribute_divisor" + +typedef struct VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT { + VkStructureType sType; + void* pNext; + uint32_t maxVertexAttribDivisor; +} VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT; + +typedef struct VkVertexInputBindingDivisorDescriptionEXT { + uint32_t binding; + uint32_t divisor; +} VkVertexInputBindingDivisorDescriptionEXT; + +typedef struct VkPipelineVertexInputDivisorStateCreateInfoEXT { + VkStructureType sType; + const void* pNext; + uint32_t vertexBindingDivisorCount; + const VkVertexInputBindingDivisorDescriptionEXT* pVertexBindingDivisors; +} VkPipelineVertexInputDivisorStateCreateInfoEXT; + + + +#ifdef __cplusplus +} +#endif + +#endif diff --git a/src/external/glfw/include/GLFW/glfw3.h b/src/external/glfw/include/GLFW/glfw3.h index 217b2c5dd..00256d4df 100644 --- a/src/external/glfw/include/GLFW/glfw3.h +++ b/src/external/glfw/include/GLFW/glfw3.h @@ -4697,7 +4697,7 @@ GLFWAPI const char* glfwGetJoystickGUID(int jid); * This function may be called from the joystick callback, even for a joystick * that is being disconnected. * - * @param[in] joystick The joystick whose pointer to set. + * @param[in] jid The joystick whose pointer to set. * @param[in] pointer The new value. * * @errors Possible errors include @ref GLFW_NOT_INITIALIZED. @@ -4722,7 +4722,7 @@ GLFWAPI void glfwSetJoystickUserPointer(int jid, void* pointer); * This function may be called from the joystick callback, even for a joystick * that is being disconnected. * - * @param[in] joystick The joystick whose pointer to return. + * @param[in] jid The joystick whose pointer to return. * * @errors Possible errors include @ref GLFW_NOT_INITIALIZED. * @@ -4874,7 +4874,7 @@ GLFWAPI const char* glfwGetGamepadName(int jid); * * Not all devices have all the buttons or axes provided by @ref * GLFWgamepadstate. Unavailable buttons and axes will always report - * `GLFW_RELEASE` and 1.0 respectively. + * `GLFW_RELEASE` and 0.0 respectively. * * @param[in] jid The [joystick](@ref joysticks) to query. * @param[out] state The gamepad input state of the joystick. diff --git a/src/external/glfw/src/CMakeLists.txt b/src/external/glfw/src/CMakeLists.txt index f886ff217..22ce68f1b 100644 --- a/src/external/glfw/src/CMakeLists.txt +++ b/src/external/glfw/src/CMakeLists.txt @@ -23,20 +23,12 @@ elseif (_GLFW_X11) set(glfw_SOURCES ${common_SOURCES} x11_init.c x11_monitor.c x11_window.c xkb_unicode.c posix_time.c posix_thread.c glx_context.c egl_context.c osmesa_context.c) - - if ("${CMAKE_SYSTEM_NAME}" STREQUAL "Linux") - set(glfw_HEADERS ${glfw_HEADERS} linux_joystick.h) - set(glfw_SOURCES ${glfw_SOURCES} linux_joystick.c) - else() - set(glfw_HEADERS ${glfw_HEADERS} null_joystick.h) - set(glfw_SOURCES ${glfw_SOURCES} null_joystick.c) - endif() elseif (_GLFW_WAYLAND) - set(glfw_HEADERS ${common_HEADERS} wl_platform.h linux_joystick.h + set(glfw_HEADERS ${common_HEADERS} wl_platform.h posix_time.h posix_thread.h xkb_unicode.h egl_context.h osmesa_context.h) set(glfw_SOURCES ${common_SOURCES} wl_init.c wl_monitor.c wl_window.c - linux_joystick.c posix_time.c posix_thread.c xkb_unicode.c + posix_time.c posix_thread.c xkb_unicode.c egl_context.c osmesa_context.c) ecm_add_wayland_client_protocol(glfw_SOURCES @@ -73,6 +65,16 @@ elseif (_GLFW_OSMESA) null_joystick.c posix_time.c posix_thread.c osmesa_context.c) endif() +if (_GLFW_X11 OR _GLFW_WAYLAND) + if ("${CMAKE_SYSTEM_NAME}" STREQUAL "Linux") + set(glfw_HEADERS ${glfw_HEADERS} linux_joystick.h) + set(glfw_SOURCES ${glfw_SOURCES} linux_joystick.c) + else() + set(glfw_HEADERS ${glfw_HEADERS} null_joystick.h) + set(glfw_SOURCES ${glfw_SOURCES} null_joystick.c) + endif() +endif() + if (APPLE) # For some reason, CMake doesn't know about .m set_source_files_properties(${glfw_SOURCES} PROPERTIES LANGUAGE C) diff --git a/src/external/glfw/src/cocoa_window.m b/src/external/glfw/src/cocoa_window.m index 077c9e893..7cf4a593d 100644 --- a/src/external/glfw/src/cocoa_window.m +++ b/src/external/glfw/src/cocoa_window.m @@ -128,6 +128,32 @@ static void updateCursorImage(_GLFWwindow* window) hideCursor(window); } +// Apply chosen cursor mode to a focused window +// +static void updateCursorMode(_GLFWwindow* window) +{ + if (window->cursorMode == GLFW_CURSOR_DISABLED) + { + _glfw.ns.disabledCursorWindow = window; + _glfwPlatformGetCursorPos(window, + &_glfw.ns.restoreCursorPosX, + &_glfw.ns.restoreCursorPosY); + centerCursor(window); + CGAssociateMouseAndMouseCursorPosition(false); + } + else if (_glfw.ns.disabledCursorWindow == window) + { + _glfw.ns.disabledCursorWindow = NULL; + CGAssociateMouseAndMouseCursorPosition(true); + _glfwPlatformSetCursorPos(window, + _glfw.ns.restoreCursorPosX, + _glfw.ns.restoreCursorPosY); + } + + if (cursorInClientArea(window)) + updateCursorImage(window); +} + // Transforms the specified y-coordinate between the CG display and NS screen // coordinate systems // @@ -321,7 +347,7 @@ static const NSRange kEmptyRange = { NSNotFound, 0 }; centerCursor(window); _glfwInputWindowFocus(window, GLFW_TRUE); - _glfwPlatformSetCursorMode(window, window->cursorMode); + updateCursorMode(window); } - (void)windowDidResignKey:(NSNotification *)notification @@ -582,6 +608,9 @@ static const NSRange kEmptyRange = { NSNotFound, 0 }; window->ns.xscale = xscale; window->ns.yscale = yscale; _glfwInputWindowContentScale(window, xscale, yscale); + + if (window->ns.layer) + [window->ns.layer setContentsScale:[window->ns.object backingScaleFactor]]; } } @@ -872,7 +901,7 @@ static const NSRange kEmptyRange = { NSNotFound, 0 }; - (void)loadMainMenu { -#if MAC_OS_X_VERSION_MAX_ALLOWED >= 100800 +#if MAC_OS_X_VERSION_MAX_ALLOWED >= 1080 [[NSBundle mainBundle] loadNibNamed:@"MainMenu" owner:NSApp topLevelObjects:&nibObjects]; @@ -1635,26 +1664,8 @@ void _glfwPlatformSetCursorPos(_GLFWwindow* window, double x, double y) void _glfwPlatformSetCursorMode(_GLFWwindow* window, int mode) { - if (mode == GLFW_CURSOR_DISABLED) - { - _glfw.ns.disabledCursorWindow = window; - _glfwPlatformGetCursorPos(window, - &_glfw.ns.restoreCursorPosX, - &_glfw.ns.restoreCursorPosY); - centerCursor(window); - CGAssociateMouseAndMouseCursorPosition(false); - } - else if (_glfw.ns.disabledCursorWindow == window) - { - _glfw.ns.disabledCursorWindow = NULL; - CGAssociateMouseAndMouseCursorPosition(true); - _glfwPlatformSetCursorPos(window, - _glfw.ns.restoreCursorPosX, - _glfw.ns.restoreCursorPosY); - } - - if (cursorInClientArea(window)) - updateCursorImage(window); + if (_glfwPlatformWindowFocused(window)) + updateCursorMode(window); } const char* _glfwPlatformGetScancodeName(int scancode) @@ -1871,6 +1882,7 @@ VkResult _glfwPlatformCreateWindowSurface(VkInstance instance, return VK_ERROR_EXTENSION_NOT_PRESENT; } + [window->ns.layer setContentsScale:[window->ns.object backingScaleFactor]]; [window->ns.view setWantsLayer:YES]; memset(&sci, 0, sizeof(sci)); diff --git a/src/external/glfw/src/init.c b/src/external/glfw/src/init.c index 4ed929511..9e670d423 100644 --- a/src/external/glfw/src/init.c +++ b/src/external/glfw/src/init.c @@ -57,37 +57,6 @@ static _GLFWinitconfig _glfwInitHints = } }; -// Returns a generic string representation of the specified error -// -static const char* getErrorString(int code) -{ - switch (code) - { - case GLFW_NOT_INITIALIZED: - return "The GLFW library is not initialized"; - case GLFW_NO_CURRENT_CONTEXT: - return "There is no current context"; - case GLFW_INVALID_ENUM: - return "Invalid argument for enum parameter"; - case GLFW_INVALID_VALUE: - return "Invalid value for parameter"; - case GLFW_OUT_OF_MEMORY: - return "Out of memory"; - case GLFW_API_UNAVAILABLE: - return "The requested API is unavailable"; - case GLFW_VERSION_UNAVAILABLE: - return "The requested API version is unavailable"; - case GLFW_PLATFORM_ERROR: - return "An undocumented platform-specific error occurred"; - case GLFW_FORMAT_UNAVAILABLE: - return "The requested format is unavailable"; - case GLFW_NO_WINDOW_CONTEXT: - return "The specified window has no context"; - default: - return "ERROR: UNKNOWN GLFW ERROR"; - } -} - // Terminate the library // static void terminate(void) @@ -173,7 +142,30 @@ void _glfwInputError(int code, const char* format, ...) description[sizeof(description) - 1] = '\0'; } else - strcpy(description, getErrorString(code)); + { + if (code == GLFW_NOT_INITIALIZED) + strcpy(description, "The GLFW library is not initialized"); + else if (code == GLFW_NO_CURRENT_CONTEXT) + strcpy(description, "There is no current context"); + else if (code == GLFW_INVALID_ENUM) + strcpy(description, "Invalid argument for enum parameter"); + else if (code == GLFW_INVALID_VALUE) + strcpy(description, "Invalid value for parameter"); + else if (code == GLFW_OUT_OF_MEMORY) + strcpy(description, "Out of memory"); + else if (code == GLFW_API_UNAVAILABLE) + strcpy(description, "The requested API is unavailable"); + else if (code == GLFW_VERSION_UNAVAILABLE) + strcpy(description, "The requested API version is unavailable"); + else if (code == GLFW_PLATFORM_ERROR) + strcpy(description, "A platform-specific error occurred"); + else if (code == GLFW_FORMAT_UNAVAILABLE) + strcpy(description, "The requested format is unavailable"); + else if (code == GLFW_NO_WINDOW_CONTEXT) + strcpy(description, "The specified window has no context"); + else + strcpy(description, "ERROR: UNKNOWN GLFW ERROR"); + } if (_glfw.initialized) { diff --git a/src/external/glfw/src/input.c b/src/external/glfw/src/input.c index c4f1e3037..429754521 100644 --- a/src/external/glfw/src/input.c +++ b/src/external/glfw/src/input.c @@ -509,9 +509,7 @@ GLFWAPI void glfwSetInputMode(GLFWwindow* handle, int mode, int value) _glfwPlatformGetCursorPos(window, &window->virtualCursorPosX, &window->virtualCursorPosY); - - if (_glfwPlatformWindowFocused(window)) - _glfwPlatformSetCursorMode(window, value); + _glfwPlatformSetCursorMode(window, value); } else if (mode == GLFW_STICKY_KEYS) { diff --git a/src/external/glfw/src/internal.h b/src/external/glfw/src/internal.h index 5293c71ad..92bbfccec 100644 --- a/src/external/glfw/src/internal.h +++ b/src/external/glfw/src/internal.h @@ -128,7 +128,7 @@ typedef enum VkStructureType VK_STRUCTURE_TYPE_WAYLAND_SURFACE_CREATE_INFO_KHR = 1000006000, VK_STRUCTURE_TYPE_MIR_SURFACE_CREATE_INFO_KHR = 1000007000, VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR = 1000009000, - VK_STRUCTURE_TYPE_MACOS_SURFACE_CREATE_INFO_MVK = 1000053000, + VK_STRUCTURE_TYPE_MACOS_SURFACE_CREATE_INFO_MVK = 1000123000, VK_STRUCTURE_TYPE_MAX_ENUM = 0x7FFFFFFF } VkStructureType; diff --git a/src/external/glfw/src/nsgl_context.m b/src/external/glfw/src/nsgl_context.m index a7cbf00f3..82af90636 100644 --- a/src/external/glfw/src/nsgl_context.m +++ b/src/external/glfw/src/nsgl_context.m @@ -175,7 +175,7 @@ GLFWbool _glfwCreateContextNSGL(_GLFWwindow* window, // Info.plist for unbundled applications // HACK: This assumes that NSOpenGLPixelFormat will remain // a straightforward wrapper of its CGL counterpart -#if MAC_OS_X_VERSION_MAX_ALLOWED >= 100800 +#if MAC_OS_X_VERSION_MAX_ALLOWED >= 1080 addAttrib(kCGLPFASupportsAutomaticGraphicsSwitching); #endif /*MAC_OS_X_VERSION_MAX_ALLOWED*/ } diff --git a/src/external/glfw/src/win32_platform.h b/src/external/glfw/src/win32_platform.h index 607ac13ae..9a669215f 100644 --- a/src/external/glfw/src/win32_platform.h +++ b/src/external/glfw/src/win32_platform.h @@ -120,6 +120,8 @@ typedef struct HRGN hRgnBlur; BOOL fTransitionOnMaximized; } DWM_BLURBEHIND; +#else + #include #endif /*Windows Vista*/ #ifndef DPI_ENUMS_DECLARED diff --git a/src/external/glfw/src/win32_window.c b/src/external/glfw/src/win32_window.c index 4506c8a72..d467f2ae3 100644 --- a/src/external/glfw/src/win32_window.c +++ b/src/external/glfw/src/win32_window.c @@ -235,26 +235,6 @@ static void centerCursor(_GLFWwindow* window) _glfwPlatformSetCursorPos(window, width / 2.0, height / 2.0); } -// Returns whether the cursor is in the client area of the specified window -// -static GLFWbool cursorInClientArea(_GLFWwindow* window) -{ - RECT area; - POINT pos; - - if (!GetCursorPos(&pos)) - return GLFW_FALSE; - - if (WindowFromPoint(pos) != window->win32.handle) - return GLFW_FALSE; - - GetClientRect(window->win32.handle, &area); - ClientToScreen(window->win32.handle, (POINT*) &area.left); - ClientToScreen(window->win32.handle, (POINT*) &area.right); - - return PtInRect(&area, pos); -} - // Updates the cursor image according to its cursor mode // static void updateCursorImage(_GLFWwindow* window) @@ -286,6 +266,67 @@ static void updateClipRect(_GLFWwindow* window) ClipCursor(NULL); } +// Apply disabled cursor mode to a focused window +// +static void disableCursor(_GLFWwindow* window) +{ + const RAWINPUTDEVICE rid = { 0x01, 0x02, 0, window->win32.handle }; + + _glfw.win32.disabledCursorWindow = window; + _glfwPlatformGetCursorPos(window, + &_glfw.win32.restoreCursorPosX, + &_glfw.win32.restoreCursorPosY); + updateCursorImage(window); + centerCursor(window); + updateClipRect(window); + + if (!RegisterRawInputDevices(&rid, 1, sizeof(rid))) + { + _glfwInputErrorWin32(GLFW_PLATFORM_ERROR, + "Win32: Failed to register raw input device"); + } +} + +// Exit disabled cursor mode for the specified window +// +static void enableCursor(_GLFWwindow* window) +{ + const RAWINPUTDEVICE rid = { 0x01, 0x02, RIDEV_REMOVE, NULL }; + + _glfw.win32.disabledCursorWindow = NULL; + updateClipRect(NULL); + _glfwPlatformSetCursorPos(window, + _glfw.win32.restoreCursorPosX, + _glfw.win32.restoreCursorPosY); + updateCursorImage(window); + + if (!RegisterRawInputDevices(&rid, 1, sizeof(rid))) + { + _glfwInputErrorWin32(GLFW_PLATFORM_ERROR, + "Win32: Failed to remove raw input device"); + } +} + +// Returns whether the cursor is in the client area of the specified window +// +static GLFWbool cursorInClientArea(_GLFWwindow* window) +{ + RECT area; + POINT pos; + + if (!GetCursorPos(&pos)) + return GLFW_FALSE; + + if (WindowFromPoint(pos) != window->win32.handle) + return GLFW_FALSE; + + GetClientRect(window->win32.handle, &area); + ClientToScreen(window->win32.handle, (POINT*) &area.left); + ClientToScreen(window->win32.handle, (POINT*) &area.right); + + return PtInRect(&area, pos); +} + // Update native window styles to match attributes // static void updateWindowStyles(const _GLFWwindow* window) @@ -575,7 +616,7 @@ static LRESULT CALLBACK windowProc(HWND hWnd, UINT uMsg, if (lParam == 0 && window->win32.frameAction) { if (window->cursorMode == GLFW_CURSOR_DISABLED) - _glfwPlatformSetCursorMode(window, GLFW_CURSOR_DISABLED); + disableCursor(window); window->win32.frameAction = GLFW_FALSE; } @@ -593,7 +634,7 @@ static LRESULT CALLBACK windowProc(HWND hWnd, UINT uMsg, break; if (window->cursorMode == GLFW_CURSOR_DISABLED) - _glfwPlatformSetCursorMode(window, GLFW_CURSOR_DISABLED); + disableCursor(window); return 0; } @@ -601,7 +642,7 @@ static LRESULT CALLBACK windowProc(HWND hWnd, UINT uMsg, case WM_KILLFOCUS: { if (window->cursorMode == GLFW_CURSOR_DISABLED) - _glfwPlatformSetCursorMode(window, GLFW_CURSOR_NORMAL); + enableCursor(window); if (window->monitor && window->autoIconify) _glfwPlatformIconifyWindow(window); @@ -857,10 +898,10 @@ static LRESULT CALLBACK windowProc(HWND hWnd, UINT uMsg, case WM_ENTERSIZEMOVE: case WM_ENTERMENULOOP: { - // HACK: Postpone cursor disabling while the user is moving or - // resizing the window or using the menu + // HACK: Enable the cursor while the user is moving or + // resizing the window or using the window menu if (window->cursorMode == GLFW_CURSOR_DISABLED) - _glfwPlatformSetCursorMode(window, GLFW_CURSOR_NORMAL); + enableCursor(window); break; } @@ -871,7 +912,7 @@ static LRESULT CALLBACK windowProc(HWND hWnd, UINT uMsg, // HACK: Disable the cursor once the user is done moving or // resizing the window or using the menu if (window->cursorMode == GLFW_CURSOR_DISABLED) - _glfwPlatformSetCursorMode(window, GLFW_CURSOR_DISABLED); + disableCursor(window); break; } @@ -1772,39 +1813,12 @@ void _glfwPlatformSetCursorMode(_GLFWwindow* window, int mode) { if (mode == GLFW_CURSOR_DISABLED) { - const RAWINPUTDEVICE rid = { 0x01, 0x02, 0, window->win32.handle }; - - _glfw.win32.disabledCursorWindow = window; - _glfwPlatformGetCursorPos(window, - &_glfw.win32.restoreCursorPosX, - &_glfw.win32.restoreCursorPosY); - centerCursor(window); - updateClipRect(window); - - if (!RegisterRawInputDevices(&rid, 1, sizeof(rid))) - { - _glfwInputErrorWin32(GLFW_PLATFORM_ERROR, - "Win32: Failed to register raw input device"); - } + if (_glfwPlatformWindowFocused(window)) + disableCursor(window); } else if (_glfw.win32.disabledCursorWindow == window) - { - const RAWINPUTDEVICE rid = { 0x01, 0x02, RIDEV_REMOVE, NULL }; - - _glfw.win32.disabledCursorWindow = NULL; - updateClipRect(NULL); - _glfwPlatformSetCursorPos(window, - _glfw.win32.restoreCursorPosX, - _glfw.win32.restoreCursorPosY); - - if (!RegisterRawInputDevices(&rid, 1, sizeof(rid))) - { - _glfwInputErrorWin32(GLFW_PLATFORM_ERROR, - "Win32: Failed to remove raw input device"); - } - } - - if (cursorInClientArea(window)) + enableCursor(window); + else if (cursorInClientArea(window)) updateCursorImage(window); } diff --git a/src/external/glfw/src/wl_init.c b/src/external/glfw/src/wl_init.c index 6cd3df720..c19184d0d 100644 --- a/src/external/glfw/src/wl_init.c +++ b/src/external/glfw/src/wl_init.c @@ -1046,8 +1046,10 @@ int _glfwPlatformInit(void) // Sync so we got all initial output events wl_display_roundtrip(_glfw.wl.display); +#ifdef __linux__ if (!_glfwInitJoysticksLinux()) return GLFW_FALSE; +#endif _glfwInitTimerPOSIX(); @@ -1073,7 +1075,9 @@ int _glfwPlatformInit(void) void _glfwPlatformTerminate(void) { +#ifdef __linux__ _glfwTerminateJoysticksLinux(); +#endif _glfwTerminateEGL(); if (_glfw.wl.egl.handle) { diff --git a/src/external/glfw/src/wl_platform.h b/src/external/glfw/src/wl_platform.h index e84d1b57c..ef8419e7b 100644 --- a/src/external/glfw/src/wl_platform.h +++ b/src/external/glfw/src/wl_platform.h @@ -47,7 +47,11 @@ typedef VkBool32 (APIENTRY *PFN_vkGetPhysicalDeviceWaylandPresentationSupportKHR #include "posix_thread.h" #include "posix_time.h" +#ifdef __linux__ #include "linux_joystick.h" +#else +#include "null_joystick.h" +#endif #include "xkb_unicode.h" #include "egl_context.h" #include "osmesa_context.h" diff --git a/src/external/glfw/src/x11_init.c b/src/external/glfw/src/x11_init.c index af4fb7ed6..c949916d3 100644 --- a/src/external/glfw/src/x11_init.c +++ b/src/external/glfw/src/x11_init.c @@ -479,7 +479,11 @@ static GLFWbool initExtensions(void) &_glfw.x11.vidmode.errorBase); } +#if defined(__CYGWIN__) + _glfw.x11.xi.handle = _glfw_dlopen("libXi-6.so"); +#else _glfw.x11.xi.handle = _glfw_dlopen("libXi.so.6"); +#endif if (_glfw.x11.xi.handle) { _glfw.x11.xi.QueryVersion = (PFN_XIQueryVersion) @@ -505,7 +509,11 @@ static GLFWbool initExtensions(void) } } +#if defined(__CYGWIN__) + _glfw.x11.randr.handle = _glfw_dlopen("libXrandr-2.so"); +#else _glfw.x11.randr.handle = _glfw_dlopen("libXrandr.so.2"); +#endif if (_glfw.x11.randr.handle) { _glfw.x11.randr.AllocGamma = (PFN_XRRAllocGamma) @@ -593,7 +601,11 @@ static GLFWbool initExtensions(void) RROutputChangeNotifyMask); } +#if defined(__CYGWIN__) + _glfw.x11.xcursor.handle = _glfw_dlopen("libXcursor-1.so"); +#else _glfw.x11.xcursor.handle = _glfw_dlopen("libXcursor.so.1"); +#endif if (_glfw.x11.xcursor.handle) { _glfw.x11.xcursor.ImageCreate = (PFN_XcursorImageCreate) @@ -604,7 +616,11 @@ static GLFWbool initExtensions(void) _glfw_dlsym(_glfw.x11.xcursor.handle, "XcursorImageLoadCursor"); } +#if defined(__CYGWIN__) + _glfw.x11.xinerama.handle = _glfw_dlopen("libXinerama-1.so"); +#else _glfw.x11.xinerama.handle = _glfw_dlopen("libXinerama.so.1"); +#endif if (_glfw.x11.xinerama.handle) { _glfw.x11.xinerama.IsActive = (PFN_XineramaIsActive) @@ -644,14 +660,22 @@ static GLFWbool initExtensions(void) } } +#if defined(__CYGWIN__) + _glfw.x11.x11xcb.handle = _glfw_dlopen("libX11-xcb-1.so"); +#else _glfw.x11.x11xcb.handle = _glfw_dlopen("libX11-xcb.so.1"); +#endif if (_glfw.x11.x11xcb.handle) { _glfw.x11.x11xcb.GetXCBConnection = (PFN_XGetXCBConnection) _glfw_dlsym(_glfw.x11.x11xcb.handle, "XGetXCBConnection"); } +#if defined(__CYGWIN__) + _glfw.x11.xrender.handle = _glfw_dlopen("libXrender-1.so"); +#else _glfw.x11.xrender.handle = _glfw_dlopen("libXrender.so.1"); +#endif if (_glfw.x11.xrender.handle) { _glfw.x11.xrender.QueryExtension = (PFN_XRenderQueryExtension) @@ -1024,6 +1048,24 @@ void _glfwPlatformTerminate(void) _glfw.x11.xinerama.handle = NULL; } + if (_glfw.x11.xrender.handle) + { + _glfw_dlclose(_glfw.x11.xrender.handle); + _glfw.x11.xrender.handle = NULL; + } + + if (_glfw.x11.vidmode.handle) + { + _glfw_dlclose(_glfw.x11.vidmode.handle); + _glfw.x11.vidmode.handle = NULL; + } + + if (_glfw.x11.xi.handle) + { + _glfw_dlclose(_glfw.x11.xi.handle); + _glfw.x11.xi.handle = NULL; + } + // NOTE: These need to be unloaded after XCloseDisplay, as they register // cleanup callbacks that get called by that function _glfwTerminateEGL(); diff --git a/src/external/glfw/src/x11_window.c b/src/external/glfw/src/x11_window.c index f3014ec9f..fc24f2851 100644 --- a/src/external/glfw/src/x11_window.c +++ b/src/external/glfw/src/x11_window.c @@ -571,6 +571,61 @@ static void updateCursorImage(_GLFWwindow* window) } } +// Apply disabled cursor mode to a focused window +// +static void disableCursor(_GLFWwindow* window) +{ + if (_glfw.x11.xi.available) + { + XIEventMask em; + unsigned char mask[XIMaskLen(XI_RawMotion)] = { 0 }; + + em.deviceid = XIAllMasterDevices; + em.mask_len = sizeof(mask); + em.mask = mask; + XISetMask(mask, XI_RawMotion); + + XISelectEvents(_glfw.x11.display, _glfw.x11.root, &em, 1); + } + + _glfw.x11.disabledCursorWindow = window; + _glfwPlatformGetCursorPos(window, + &_glfw.x11.restoreCursorPosX, + &_glfw.x11.restoreCursorPosY); + updateCursorImage(window); + centerCursor(window); + XGrabPointer(_glfw.x11.display, window->x11.handle, True, + ButtonPressMask | ButtonReleaseMask | PointerMotionMask, + GrabModeAsync, GrabModeAsync, + window->x11.handle, + _glfw.x11.hiddenCursorHandle, + CurrentTime); +} + +// Exit disabled cursor mode for the specified window +// +static void enableCursor(_GLFWwindow* window) +{ + if (_glfw.x11.xi.available) + { + XIEventMask em; + unsigned char mask[] = { 0 }; + + em.deviceid = XIAllMasterDevices; + em.mask_len = sizeof(mask); + em.mask = mask; + + XISelectEvents(_glfw.x11.display, _glfw.x11.root, &em, 1); + } + + _glfw.x11.disabledCursorWindow = NULL; + XUngrabPointer(_glfw.x11.display, CurrentTime); + _glfwPlatformSetCursorPos(window, + _glfw.x11.restoreCursorPosX, + _glfw.x11.restoreCursorPosY); + updateCursorImage(window); +} + // Create the X11 window (and its colormap) // static GLFWbool createNativeWindow(_GLFWwindow* window, @@ -1432,7 +1487,7 @@ static void processEvent(XEvent *event) // HACK: This is a workaround for WMs (KWM, Fluxbox) that otherwise // ignore the defined cursor for hidden cursor mode if (window->cursorMode == GLFW_CURSOR_HIDDEN) - _glfwPlatformSetCursorMode(window, GLFW_CURSOR_HIDDEN); + updateCursorImage(window); _glfwInputCursorEnter(window, GLFW_TRUE); return; @@ -1725,7 +1780,7 @@ static void processEvent(XEvent *event) case FocusIn: { if (window->cursorMode == GLFW_CURSOR_DISABLED) - _glfwPlatformSetCursorMode(window, GLFW_CURSOR_DISABLED); + disableCursor(window); if (event->xfocus.mode == NotifyGrab || event->xfocus.mode == NotifyUngrab) @@ -1745,7 +1800,7 @@ static void processEvent(XEvent *event) case FocusOut: { if (window->cursorMode == GLFW_CURSOR_DISABLED) - _glfwPlatformSetCursorMode(window, GLFW_CURSOR_NORMAL); + enableCursor(window); if (event->xfocus.mode == NotifyGrab || event->xfocus.mode == NotifyUngrab) @@ -2708,53 +2763,14 @@ void _glfwPlatformSetCursorMode(_GLFWwindow* window, int mode) { if (mode == GLFW_CURSOR_DISABLED) { - if (_glfw.x11.xi.available) - { - XIEventMask em; - unsigned char mask[XIMaskLen(XI_RawMotion)] = { 0 }; - - em.deviceid = XIAllMasterDevices; - em.mask_len = sizeof(mask); - em.mask = mask; - XISetMask(mask, XI_RawMotion); - - XISelectEvents(_glfw.x11.display, _glfw.x11.root, &em, 1); - } - - _glfw.x11.disabledCursorWindow = window; - _glfwPlatformGetCursorPos(window, - &_glfw.x11.restoreCursorPosX, - &_glfw.x11.restoreCursorPosY); - centerCursor(window); - XGrabPointer(_glfw.x11.display, window->x11.handle, True, - ButtonPressMask | ButtonReleaseMask | PointerMotionMask, - GrabModeAsync, GrabModeAsync, - window->x11.handle, - _glfw.x11.hiddenCursorHandle, - CurrentTime); + if (_glfwPlatformWindowFocused(window)) + disableCursor(window); } else if (_glfw.x11.disabledCursorWindow == window) - { - if (_glfw.x11.xi.available) - { - XIEventMask em; - unsigned char mask[] = { 0 }; + enableCursor(window); + else + updateCursorImage(window); - em.deviceid = XIAllMasterDevices; - em.mask_len = sizeof(mask); - em.mask = mask; - - XISelectEvents(_glfw.x11.display, _glfw.x11.root, &em, 1); - } - - _glfw.x11.disabledCursorWindow = NULL; - XUngrabPointer(_glfw.x11.display, CurrentTime); - _glfwPlatformSetCursorPos(window, - _glfw.x11.restoreCursorPosX, - _glfw.x11.restoreCursorPosY); - } - - updateCursorImage(window); XFlush(_glfw.x11.display); } From 0adb4b67de6dfe3f7a0a557130dffc3b8f4d6a43 Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Thu, 10 May 2018 22:51:17 +0200 Subject: [PATCH 24/53] CMake: Build glfw separately with CMake Makes it easier to support Wayland later on. --- .travis.yml | 9 ++++---- src/CMakeLists.txt | 36 +++++++++++++++++--------------- utils.cmake | 51 +++++++++++++--------------------------------- 3 files changed, 39 insertions(+), 57 deletions(-) mode change 100644 => 100755 src/CMakeLists.txt mode change 100644 => 100755 utils.cmake diff --git a/.travis.yml b/.travis.yml index 5037a717d..4cb6b0ea4 100644 --- a/.travis.yml +++ b/.travis.yml @@ -25,11 +25,12 @@ before_install: sudo apt-get install -y gcc-multilib libasound2-dev:$ARCH libxcursor-dev:$ARCH libxinerama-dev:$ARCH mesa-common-dev:$ARCH - libx11-dev:$ARCH libxrandr-dev:$ARCH libxi-dev:$ARCH + libx11-dev:$ARCH libxrandr-dev:$ARCH libxrandr2:$ARCH libxi-dev:$ARCH libgl1-mesa-dev:$ARCH libglu1-mesa-dev:$ARCH; + if [ "$ARCH" == "i386" ]; then + export CMAKE_ARCH_ARGS='-DCMAKE_C_FLAGS=-m32 -DCMAKE_SYSTEM_LIBRARY_PATH=/usr/lib/i386-linux-gnu'; + fi; export RAYLIB_PACKAGE_SUFFIX="-Linux-$ARCH"; - if [ "$ARCH" == "i386" ]; then export CFLAGS="-m32"; fi; - if [ "$ARCH" == "amd64" ]; then export CFLAGS="-m64"; fi; if [ "$GLFW" == "SYSTEM" ]; then wget 'http://ftp.de.debian.org/debian/pool/main/g/glfw3/libglfw3_3.2.1-1_amd64.deb'; wget 'http://ftp.de.debian.org/debian/pool/main/g/glfw3/libglfw3-dev_3.2.1-1_amd64.deb'; @@ -45,7 +46,7 @@ before_install: script: - mkdir build - cd build - - cmake -DMACOS_FATLIB=ON -DSTATIC=ON -DSHARED=ON -DBUILD_EXAMPLES=ON -DBUILD_GAMES=ON -DUSE_EXTERNAL_GLFW=IF_POSSIBLE .. + - cmake $CMAKE_ARCH_ARGS -DMACOS_FATLIB=ON -DSTATIC=ON -DSHARED=ON -DBUILD_EXAMPLES=ON -DBUILD_GAMES=ON -DUSE_EXTERNAL_GLFW=IF_POSSIBLE .. - make VERBOSE=1 - make package diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt old mode 100644 new mode 100755 index f04e88f34..98b6b0e98 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -10,16 +10,28 @@ include("CMakeOptions.txt") configure_file(config.h.in ${CMAKE_BINARY_DIR}/cmake/config.h) include_directories(${CMAKE_BINARY_DIR}) +if(MACOS_FATLIB) + if (CMAKE_OSX_ARCHITECTURES) + message(FATAL_ERROR "User supplied -DCMAKE_OSX_ARCHITECTURES overrides -DMACOS_FATLIB=ON") + else() + SET(CMAKE_OSX_ARCHITECTURES "x86_64;i386") + endif() +endif() + +if(NOT glfw3_FOUND) + set(GLFW_BUILD_DOCS OFF CACHE BOOL "" FORCE) + set(GLFW_BUILD_TESTS OFF CACHE BOOL "" FORCE) + set(GLFW_BUILD_EXAMPLES OFF CACHE BOOL "" FORCE) + set(GLFW_USE_WAYLAND ${USE_WAYLAND} CACHE BOOL "" FORCE) + + add_subdirectory(external/glfw) +endif() + include("../utils.cmake") # Get the sources together file(GLOB raylib_sources *.c) - -if(glfw3_FOUND) - list(REMOVE_ITEM raylib_sources ${CMAKE_CURRENT_SOURCE_DIR}/rglfw.c) -else() - include_directories(external/glfw/include) -endif() +list(REMOVE_ITEM raylib_sources ${CMAKE_CURRENT_SOURCE_DIR}/rglfw.c) if(USE_AUDIO) file(GLOB stb_vorbis external/stb_vorbis.c) @@ -51,7 +63,6 @@ if(${PLATFORM} MATCHES "Desktop") # See: https://github.com/raysan5/raylib/issues/341 if(APPLE) set(GRAPHICS "GRAPHICS_API_OPENGL_33") - set_source_files_properties(rglfw.c PROPERTIES COMPILE_FLAGS "-x objective-c") link_libraries("${LIBS_PRIVATE}") elseif(WIN32) add_definitions(-D_CRT_SECURE_NO_WARNINGS) @@ -76,14 +87,6 @@ elseif(${PLATFORM} MATCHES "Raspberry Pi") set(GRAPHICS "GRAPHICS_API_OPENGL_ES2") endif() -if(MACOS_FATLIB) - if (CMAKE_OSX_ARCHITECTURES) - message(FATAL_ERROR "User supplied -DCMAKE_OSX_ARCHITECTURES overrides -DMACOS_FATLIB=ON") - else() - SET(CMAKE_OSX_ARCHITECTURES "x86_64;i386") - endif() -endif() - # Which platform? if(${PLATFORM} MATCHES "PLATFORM_DESKTOP") @@ -100,7 +103,7 @@ if(${PLATFORM} MATCHES "PLATFORM_DESKTOP") set(CMAKE_INSTALL_RPATH_USE_LINK_PATH TRUE) set(CMAKE_MACOSX_RPATH ON) - target_link_libraries(${RAYLIB}_shared ${LIBS_PRIVATE}) + target_link_libraries(${RAYLIB}_shared ${LIBS_PRIVATE} glfw) if (UNIX AND ${FILESYSTEM_LACKS_SYMLINKS}) MESSAGE(WARNING "Can't version UNIX shared library on file system without symlink support") else() @@ -137,6 +140,7 @@ if(${PLATFORM} MATCHES "PLATFORM_DESKTOP") ) set(PKG_CONFIG_LIBS_PRIVATE ${__PKG_CONFIG_LIBS_PRIVATE}) + target_link_libraries(${RAYLIB} glfw) if (WITH_PIC) set_property(TARGET ${RAYLIB} PROPERTY POSITION_INDEPENDENT_CODE ON) diff --git a/utils.cmake b/utils.cmake old mode 100644 new mode 100755 index 71e34e016..27f74e682 --- a/utils.cmake +++ b/utils.cmake @@ -17,47 +17,24 @@ if(APPLE) elseif(WIN32) # no pkg-config --static on Windows yet... else() - if(USE_WAYLAND) - set(_GLFW_WAYLAND 1) - else() - set(_GLFW_X11 1) - endif() - find_library(pthread NAMES pthread) find_package(OpenGL QUIET) if ("${OPENGL_LIBRARIES}" STREQUAL "") - if(NOT USE_WAYLAND) - # CFLAGS=-m32 cmake on Linux fails for some reason, so fallback to hardcoding - set(LIBS_PRIVATE m pthread GL X11 Xrandr Xinerama Xi Xxf86vm Xcursor) - else() - # CFLAGS=-m32 cmake on Linux fails for some reason, so fallback to hardcoding - set(LIBS_PRIVATE m pthread GL wayland-client wayland-cursor wayland-egl) - endif() + set(OPENGL_LIBRARIES "GL") + endif() + + include_directories(${OPENGL_INCLUDE_DIR}) + + if ("${CMAKE_SYSTEM_NAME}" MATCHES "(Net|Open)BSD") + find_library(OSS_LIBRARY ossaudio) + endif() + + set(LIBS_PRIVATE m pthread ${OPENGL_LIBRARIES} ${OSS_LIBRARY}) + # TODO: maybe read those out of glfw's cmake config? + if(USE_WAYLAND) + set(LIBS_PRIVATE ${LIBS_PRIVATE} wayland-client wayland-cursor wayland-egl) else() - if(NOT USE_WAYLAND) - find_package(X11 REQUIRED X11) - find_library(XRANDR_LIBRARY Xrandr) - find_library(XI_LIBRARY Xi) - find_library(XINERAMA_LIBRARY Xinerama) - find_library(XXF86VM_LIBRARY Xxf86vm) - find_library(XCURSOR_LIBRARY Xcursor) - else() - find_library(WAYLAND_CLIENT_LIBRARY wayland-client) - find_library(WAYLAND_CURSOR_LIBRARY wayland-cursor) - find_library(WAYLAND_EGL_LIBRARY wayland-egl) - endif() - - include_directories(${OPENGL_INCLUDE_DIR}) - - if ("${CMAKE_SYSTEM_NAME}" MATCHES "(Net|Open)BSD") - find_library(OSS_LIBRARY ossaudio) - endif() - - if(NOT USE_WAYLAND) - set(LIBS_PRIVATE m ${pthread} ${OPENGL_LIBRARIES} ${X11_LIBRARIES} ${XRANDR_LIBRARY} ${XINERAMA_LIBRARY} ${XI_LIBRARY} ${XXF86VM_LIBRARY} ${XCURSOR_LIBRARY} ${OSS_LIBRARY}) - else() - set(LIBS_PRIVATE m ${pthread} ${OPENGL_LIBRARIES} ${WAYLAND_CLIENT_LIBRARY} ${WAYLAND_CURSOR_LIBRARY} ${WAYLAND_EGL_LIBRARY} ${OSS_LIBRARY}) - endif() + set(LIBS_PRIVATE ${LIBS_PRIVATE} X11 Xrandr Xinerama Xi Xxf86vm Xcursor) endif() endif() From 7243cebad1e80eba932cfab8d512133a194a01cb Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Thu, 10 May 2018 23:47:38 +0200 Subject: [PATCH 25/53] Travis CI: Test building with external GLFW --- .travis.yml | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/.travis.yml b/.travis.yml index 4cb6b0ea4..131230452 100644 --- a/.travis.yml +++ b/.travis.yml @@ -15,6 +15,9 @@ matrix: - os: linux env: ARCH=amd64 sudo: required + - os: linux + env: ARCH=amd64 GLFW=SYSTEM + sudo: required - os: osx env: ARCH=universal @@ -48,7 +51,9 @@ script: - cd build - cmake $CMAKE_ARCH_ARGS -DMACOS_FATLIB=ON -DSTATIC=ON -DSHARED=ON -DBUILD_EXAMPLES=ON -DBUILD_GAMES=ON -DUSE_EXTERNAL_GLFW=IF_POSSIBLE .. - make VERBOSE=1 - - make package + - if [ "$GLFW" != "SYSTEM" ]; then make package; fi; + - sudo make install + - pkg-config --static --libs raylib deploy: provider: releases From a0f9c2b1eb4fbc25472a3f164c7af349fcc0562e Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Wed, 9 May 2018 17:59:09 +0200 Subject: [PATCH 26/53] Travis CI: Test Wayland configuration as well --- .travis.yml | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/.travis.yml b/.travis.yml index 131230452..2d9a774f3 100644 --- a/.travis.yml +++ b/.travis.yml @@ -18,6 +18,15 @@ matrix: - os: linux env: ARCH=amd64 GLFW=SYSTEM sudo: required + - os: linux + env: USE_WAYLAND=ON ARCH=amd64 + sudo: required + addons: + apt: + packages: + - libwayland-dev + - libxkbcommon-dev + - libegl1-mesa-dev - os: osx env: ARCH=universal @@ -49,7 +58,15 @@ before_install: script: - mkdir build - cd build - - cmake $CMAKE_ARCH_ARGS -DMACOS_FATLIB=ON -DSTATIC=ON -DSHARED=ON -DBUILD_EXAMPLES=ON -DBUILD_GAMES=ON -DUSE_EXTERNAL_GLFW=IF_POSSIBLE .. + - if test -n "${USE_WAYLAND}"; + then wget https://mirrors.kernel.org/ubuntu/pool/universe/e/extra-cmake-modules/extra-cmake-modules_5.38.0a-0ubuntu1_amd64.deb; + sudo dpkg -i extra-cmake-modules_5.38.0a-0ubuntu1_amd64.deb; + git clone git://anongit.freedesktop.org/wayland/wayland-protocols; + pushd wayland-protocols; + git checkout 1.12 && ./autogen.sh --prefix=/usr && make && sudo make install; + popd; + fi + - cmake $CMAKE_ARCH_ARGS -DMACOS_FATLIB=ON -DSTATIC=ON -DSHARED=ON -DBUILD_EXAMPLES=ON -DBUILD_GAMES=ON -DUSE_EXTERNAL_GLFW=IF_POSSIBLE -DUSE_WAYLAND=${USE_WAYLAND} .. - make VERBOSE=1 - if [ "$GLFW" != "SYSTEM" ]; then make package; fi; - sudo make install From aa76985c0da1dab965b41c98e87db341c73e9538 Mon Sep 17 00:00:00 2001 From: Ray Date: Fri, 11 May 2018 18:14:19 +0200 Subject: [PATCH 27/53] Review raylib version to 2.0 Review raylib_icon resource --- .gitignore | 1 - examples/Makefile | 4 ++-- release/libs/win32/mingw32/libraylib.a | Bin 1218614 -> 1100766 bytes src/CMakeLists.txt | 2 +- src/Makefile | 2 +- src/raylib.rc | 14 +++++++------- src/{resources => raylib_icon} | Bin 107260 -> 107340 bytes templates/advance_game/Makefile | 2 +- templates/simple_game/Makefile | 2 +- templates/standard_game/Makefile | 2 +- 10 files changed, 14 insertions(+), 15 deletions(-) rename src/{resources => raylib_icon} (99%) diff --git a/.gitignore b/.gitignore index 1b4d5e411..6caeaeada 100644 --- a/.gitignore +++ b/.gitignore @@ -45,7 +45,6 @@ ipch/ # Ignore compiled binaries *.o *.exe -!tools/rREM/rrem.exe # Ignore all examples files examples/* diff --git a/examples/Makefile b/examples/Makefile index becb91dc4..d283e8077 100644 --- a/examples/Makefile +++ b/examples/Makefile @@ -25,7 +25,7 @@ # Define required raylib variables PROJECT_NAME ?= raylib_examples -RAYLIB_VERSION ?= 1.9.7 +RAYLIB_VERSION ?= 2.0.0 RAYLIB_API_VERSION ?= 1 RAYLIB_PATH ?= .. @@ -207,7 +207,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) ifeq ($(PLATFORM_OS),WINDOWS) # resources file contains windows exe icon # -Wl,--subsystem,windows hides the console window - CFLAGS += $(RAYLIB_PATH)/src/resources -Wl,--subsystem,windows + CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) ifeq ($(RAYLIB_BUILD_MODE),DEBUG) diff --git a/release/libs/win32/mingw32/libraylib.a b/release/libs/win32/mingw32/libraylib.a index b188e3298a57733d17614b3ad06a1e11e2179a83..3aac1c0cba6b6f536097e4eb5869993d45d44736 100644 GIT binary patch literal 1100766 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�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�TxAx1rn4m0Xy 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 literal 1218614 zcmeFa4|J8+btft?N@PcglvebqQ(P+@x&}8m1tjO;F`dUBeHgW1DS5j za_cE}o!21>-sJZ)hR|a==;I0nb)q%S@a90QJ>cCwcxT^zqb>RD}1NSca zY|Z!W?^EBYx%ckhKPnk~pg3Oh-Tc*`YOA^X_xC4*5AFW7n!A7B9~m@^e5mH`-#1-&-D#?8130Yv1g#yqc^avKfc@0+vD9mp4rw@j5FJ_JF|W9 z?c=%pj-LMP^A6JLGu`Sj-Rd#jnq<0l-B5oqJJ`S5vh4s*I>@Sgu24ucrL{AYAIuE& zWqXJEd-4u76hUjH2wIaOXbl?O8aBGMvXxKdi`#RR;I4enKw&Fn;<1u<9oo7+v$Y>x z>oV762jX&8 zfx=*}-~b&1J2QEQ>#?r*9et=TTSN!wz4VqQ(OCtfVjk^&(Fz5u&lM}~Hd#uV`SaoJ zFW6fnccl|+f!?pq4;6|-5T@RuvkQZeUv{T!mGpznUz^K4yTUawme?nTz+HYIn;VE* z8N;ly#1Kz7G0@5{hQ!>)u(i;~n(p}i@%{v0LlUq$pWC71y|pW65_a!$;x*lmWr|(7q2BGCx$Ho(uqro1BmgU@#jrKG{=W91d`}Tw z8Q|u7wyEfnP$P?&L}zxOcY7tSfDJMlxvFPJCf~CzM@y%CE2O5|Wp?%qtjY}(^SOQx zxT3#U3EZ$Fmn&}ngFL85)|(C6b3^@og2!%BAZ$){2Mji-b>+6f?ynx|?=SS` zGZ|Ei)+ts;FD2}5yRt>P1b5$=D`d439B5q*yyc)vF(f;%K|F(l=q);9gVgs_wvUd= z-LJ`Hw{3?KfbZv44dn}@wg%qDraKCn0u0uwrdw6e=E9^?Bkk>~{!CAPWl!(3+wxE? zv{oeBp6_`sJFtyq`&?Rb*x5_kCBr5iyfub1De$h$E{+4$5l{>6(WG^`p+aVT4>|)k zPv!FceO)hQ8DM;S&%m~f2hcj& z^SQx6>L!>sX_5v{(w`w{1N5zDTV_Mg&Wvf8fvnB-^chG;;pZ~DJ7KR1YO8S9o_h|; zBN^*6(2_W3BWyP+_DeuC(XK2(EbBInx^h|zd4;&3C#?=fB4(9UW za0v%R`dtKW)ON#LHzK#bA*i(!?HCvwDn|J{4Xa22CRh&Xhvmujqp>kWRAp6vHYB5#9vbAM zDlpR6Ii^6v;iLU*Zg-)Wpl4wmscE=6O44%H^gvQl*^2)DT(2c$V5{LFqoVuaYA@Uy-LORRN|}gh1O* zw2=N-weS_Y=!=YOEl@>X35Qx#0)rm46dv2yfw;m5%K|qRGI)a zIBnBd0b%rfYA7?%3;!!ZFvG+In-w4pU;WYO0#m`|U<@HLWYM@CJuCA0p52g*L#%|V zb9fR#X-)^P;I7K;ptEscOJl=ef3~=?v(w4d)EsL?XFj_FlYPgLX}P%<+m--r-(AS| z_VjBg9p;HA89;C?>o;Lu+?D7xL%u?Z&<)kH;!>e{p@`pXQ>gGnF5xOd@WS?h6*RS9{Pj;wXb79SHYY=jeEsr z1^(1Dt^wT#H<)Not`2C3D+*b|BjJ32Id`!K75-9V&AJ z)%K;La%#_P?Lo&WC59ZP7h-_o#rJ+68;7KsK4LKSH7cf9)pN`wH^A0;u<3dw;07hM zHUWV)no6Xz0!s0Kb>#?Ji(ayAb{Q*VnQJ|@N*e{j6`dC_CAo1Gj*+lOgCb81_Vmhv zU%+MnHQJ?ZQcf_=Fza&b4lHX`%}3+h(!V$Ap&*3M@U1SKl~LgXTx&G$Rz_lB zNigo@qy+=5bExUiG&87FDsmj9v;aiQuoFTP=?cj}sgh?W7%p56dPPK1rKIVkD!I0E zDzX#$RFSW(@%1M}=|qe!D|>dp_GF9c_jKdAAv2eN;EK_X!QyVSDrlFb3T8&}ME)@e zNbQWkT8zGoj(aXzZtPmU6zsJwG1f+L2xTr-l?<+rBj#0RBtBGwBNJzHfy~kD#QHWD z^10$>s<9yFi4t(AX<}MrENIq+Wj*Y{DTwP7IS?GrWu6*YPd?rI2EP(Zu3r=Msj zJIO|G*7bS>TwZ0dWQ1Z%K@?tAY+_rNtmx|*EPBDaG}YN4ryLUIrilT(`cbiVh|x=% zmkf_BS2`xT`jc%m9HVq*IE``O%H^d2rGg-XU$Exke;b=Ly!jn zYm+K9*U_xZa;4O{2NYeg+vV9HBfWGGZ3HN&JmDr19qzdE;*TT+(~n$fb90jbClO@? zd5Lf%$g{3ZD@btW2OvQyKiUW~s)Z;4QV^R2Ij%Fp0dB{mGAYHm5FHfNJQYK>O74@{ zLRJ=>Q%YJvq|;r4#Zydo5_Nk0>MfQgkX)P44cX^)!8@qmA+%?Du@*0Dk?9EX^je<0 z1o=*ZT-+ICJNoI_ehd6%I9_nx0-z?iQU0eJ1F8?bT{Yr z9dckPwwvvqQD3PSB zbxDf5F_eJZx~(JmezQj;-~VJb^BkX;kcK?NWkQ~-BM+NnGP_!(tfrUv=`2z4h<8;k zm+#XYed?+uM2u}iTZpA;DJ)6F&_Dzf_|TYW=5e(LG0DyzKJ!HYgwT!b(d@3z;3-z# z!!@NV;EFDN*Cop_uA%^@Xis4o%yxz$7=Z9_w3soK3N!5j2`csA8@AhiRy-A>T~q}l zQrbP;f~5F}USuS4kKU4zYX}ZpNUC6yJsPo98{x^rtgCY^) zVR&M918S6wFZPa{+cbmU7>|25wEdmgT^YvWP<6lzKNg548;BWm@?=zn?;xz7ST)^D z*`A5ht8{CN)NgZTNa&4f1%`%yOJ^lrj9A`m!GXXPWESqjdkmToU;f@)n+fp z%6^P5*JkgI>Xp}(-j0E-Sd61GKAGQ;-GTjvvfD*;GJxRGa*V+KgK0+a7kM2OS)5PZ%xB& zO~*{(v$Y$18WF9^4eo|Qb#QTeu{?zn$rbVccOpD~k&;d?jYc8}JZCw(uDW zYqJAbOqG3Au6@`p6cU7<7_G>5$K=Qy_S#tGG{u1{-j|DEt23ECKFog-kE}#N4UW%X zhxf=*1S#7j{f4>LYO&5XPq^xsVqyD~14IpN61;X4;(*1fzf@lkDQ%703ftg!5NxfJ zmS}_R8}0~mIbPpM$9b7PpNrx9O&KvItA_@9D>TLKuBgzp#W641w^X#GKsuLrGTVqJ zKE@$m?{=~O6D`uu_Ts=lc#SYedJcGJQ%VfQ+J1^uaLdmrZ)S8T1G@iK`lXC z*qGfX;O-4MuQlL;akV!fRj@k{4RSLT9vt=bZs#sL*9%@J`0PT<5yhJtyxxgp9+QVE zlP&|GH1eQgk$uXa7|P^#Ke0vPpO3fs>O0`IEbb@DOPY}}QCXbTQSgVOt3*59v@TRw z1SvA%k&cfG=oVUE9w7pF5Vk$x0hCm5Pa~0Qx)X+@K1-oe>9x|)@F~jzG^R*;Ro(Z0eCyzT~H6ou(VA;iT1|skq)#?W;+}Mt#gFe|f z-h-J9r?ftI7$j>mJ2U-hoQ0hM%N8?b3`44yg}pY)87rQ=V`XNYW-OaNYxAgzzzu1~ zBskRY43;rwAf9K$l|YidHR$m1eF?Qa?&*0)A&_lSomcWnNnj-n-<~Od0&XeV*P${4;Nh{}1kCJmE)6;%jX{K)J>f*O0 z$+mAdojm*kKI^tM9uXr@owplt##TEp1A#}9A?(q?29spS9S=>eIN<#Z#~-`c@JMIw z;3^muWn6XADfDI2npJHo8n-*<+cm|nvLiXu5XDSKZ5#5~!!UG?DX^{%8ru#xKsV%u@_Z-L zv^=v>7|v$ChsC`fY9#!8XQi8(e3@2xsODSWOxSA(2j z42z9*J!2`wwE|!5SG@C1re~0aHM*X6HO~+nJs7WSuQy>c^!-4@xGg(Rb46F-rNq^; zXVyqYr#=bY62+32s=QDHI=nN-^;4CBBkA{u1Nw66X!C}xZ341MD?Oi;T3&87)dUu2ju)&0>+Bc zi#5u}UE&R8w+QR%)WzeZGC>KFF(+P1<-^!5;VM2~+Q2M!Cmze<6@t8b#n7$XxtU6= z1si&^1$m*_s0%97sbrwxl#;shxTH3VE50$zs7A0TAv4x+4Eqvkd)zDUEhl(T*GF+k z<1b7(^@#cKE1=_!b7Bsi)C1(8*$LB8LB(IvrsgFVRQ-yn)T$ZbY$F&=OM*3MkPLY9 z$@v*r8}!sl0!OYoxCREUHN`*rv^v^6a|H%`hv5zNFp~2J0Cw77IkRG^J*>l9nv&k* z8n_Uns1)<#rnKCL&ZLAN+s2?*i$wv zoTy49P^$)+JjKQzjX}>Pmvs}fOmDtJLo8Zm*Wgl&@T%>Z-e)~4!uRL+(vPtNkX`jf zF_j%#5f2IKca@dQK*igF2SI)>EcO;TD_YDpk>2 zj_fFe9q3o?Pb1KBF(=+E$wXy=DNcGcuelus&1TflF{mC-u;Nyru=C~~RWv(U zr>D2Hc()(U9l`Q}&%%;;;v9hE5ZDK|diDr>1y;w8Kg8h%V)LmiiHE2adTV=HSdA)- z1SJUWFy}*P@MeoHsa7;t&U3nl_l^dNI$yP0VpgnQ*+Ut{nzGL+4WaN{_W9>| zoQTWp>ge8zr2#&&>@JuUG@BW1>T;wD>mOU`6+@+&U3lvlZ}xTf$ljH1JT)-8wQPB^ z7Hw!1wve?Yi&b$fC)#Y1-@+YHK)}|KFau24c(^;Po5kRpGP}BaxIEd-Jqhvxyrs)( zcgj=8iWYfUhU+aLC3BOM(t~yuX!Cr5c(U#;v=$Ma`B;63<+pX?m224_=;zqJs_Y7{ zBX{tax`LUe+0uSb=doOy2H%Q}epq?;vn->TKG&Ip-1mngJLFiK5WBkEec6fNbMj0% zEZ)c6yxqNeyr9oTRV7;i4K%%_{h3DAAZ(HOQFj`Kqo3Moeygg=)<;UKq7PA6x3W-B z#f{re&8VVtv6^p15Z_&JQ%_$!Rx1W_1KoqU=Q8>3+}7^mbJz)Ju{_<2f$S3_l+@mI zV{}OO?xYM-(!Ev7llh+bAOsBmLNAU1fFZVwu2|RJt?G}LG4TqzmjiB9K@86++Uk)H z3sQ|!j0h#5G>r(uQaXlQvthd(ncC4Yhe7iUcrb?@qpB^!=OT3753X=xdYyA zwfF#sARb%-{x}klr3lH0VJpR+n58kVG`DuEEcgxrP6>i&Q?rdQs^mIhc=;*9@Nzj# zQl<)imBCCoTQ$e7YE@!z`5+ydTE?tc>F(X2I(SQy>4SA1V=@BHv3!;WHn3=5rwba} z`h1G12s>|wvGukHX(YJL5N`%atE)yS#HvOs zTZNBG9dWDYerM<;z&?lab5_TJo+6PSuF)1kR=6RByCG~;cuV96rK-Xf3n`b++X2ZbhA#fYrz`K+r^NwJ3UlDv;@_hkDpEzISJN~l>t@-rY! zEs>Jv){*=I-s34B?C3b-Rxx_C9=jIc7xtyUIIxLfPB0#WtibYwIn@gV<0B|ks9I=A zRravsyIPx;RAmoqGgS*!We*QvsugOj${tn%surrs9=7UKEmV~~>`bgyh+Fci=Y<;M zcL+DLR4+HQ!Ns@8TXKuMRzGh=|KRqXDl`*$ z0nJ2SKof5wT8egRC+FZ5{fZyYJokhwBB?v{vpNdZa`g4ZYPnEaKMU&a^>HE->h5Lo zFd)CEpC`JcnLZfwyqt=9e~KSu_h@e@8=hJ$e{ zKAdhv$^_z!`nF|wP<=`PaBAJ5Pp5;AB~sAMzEFOEA{-dj?5C7bkDihtu10g!vicmr z(NxQ#T2;$~=J;8G7*yx{Y`;Qf0gfmQxFikO8UXcyln;{cQSkAb4^+#;xo&O%kE;Bv zXjhTnB}&ahyEg3Ju_f0Zv{9|<7DKS;$0J*VT8z2fvePeMfQ2+*HVwEn z4cM0kL;#vn6T-_hXlh+4s$=3!ZMkmj;Wm+sPtyjRw?v{Yt>s5FoNe<-Fc-TC@g9!1 zu9ifA>Z5n6mNzyCPf)AZky@B1?u&QT#`gL3V%VBYyZbFY*X*kcWF42)O$X^EjnI=N zow`-2*X38K+2yC!9Vl&;8UmauwFEd`O*D_P3$>=(C7;wZj{%5N9x%e0eMBb0%FOdw zZk*=*s%*ZO51`}pV?0R%W7>xqLW)chcyPlK>v4z&Uih*E+^xZP_edlPU}-f0vGpd) zTKJkO__k%PvNZk#W-+^{kB(`3=N02?K3W@7wwR_3nmBOyuYP&nA!;U#Oo3Ywr)1f> z`CSxj7jyJL3K9-sN~Q`}>c)`pDb(PJ@|NzwOuj!m&^?gL7BZ~?D4&HxP0QH2Wk(tq zF~}BtHVUtT`nlQet@tPk!jtYiKB>a52cgz%cb3O$;6Y{vx+MU-f!4hhr-aF4IG$wQ zzq=a`SMhut&ng8YkwoF#j&7XaVks~`26iw0xL2;?P7!xxcI5b=%Fzd&=8yp%X#si0 znNnkA83Csi*jl9)15YjD)o0MWCT0uW+xzk>`cmYQT+ODfaF*Q|Y#AUm;W4C=K zzZD^03icMWH(PqoCo_=Ka)y_bq7EaVK?NPcAyFB5@4eRp1LfPor_zd4pfcjV5)+itbijd=y$gl#Nd+35$V(K> zW7M*rx`z-8FICPQ%xniBw+<$F-38a|l#K2S?8*)~Xey=XHookVg*&LoLle?7g^%>S z1ewCn7THUa0Q2NnTBfzIAo6(0OVYYKxOgRZx1MK>@y-N4!40;4?eJ*n9Lgc;3122( zZxVTl0dW;JohJa!ujx39I@qjy1pIo??59e0V40q)^pTLrXr0p{z zxse4U-B}mk%Y%7?EeQAkCl23;5%84X4iN+PFz{-G40}P>o5vqFXzrXe$!yOSw=)XS z8w3+3$!2;<_K!nxKHh_Q_zX#S>&mQ#!{JPc{>Bs`XiYAkeI7dr98e~rT^IreN$wHk zp{Nf*D6-pFK4D4FWJ^L1KYk z42K`wn5fN^wjq4up(w{A810v}wIQ|ST_v_81!U{qwAVoh35;kK5TIbx{R zlN+4LHnc?(>kzM?85K7yfQldM-#xfpRuGhye41~tC(licgPB5iFXEkIrn`4HWGp9I zROSJKMI4;WhHYkpP+g_I1(bdbwXu6u_ZZRnN3hBi4^(*xmiK0E=!gBVHmW%&|HB|O8= z0t6XYKo}_S*v|l(H(#6eD44e8LJ2l(DCm)r-}NA@o>J&ldP>FC%LPx(6~W zXM1ynp6!`FZ1W9D*cQRb_1+>shuKl}(nV;-EwX!Y%3)fi{RMo&EQ7PUJa&f$p3C$j zj`l#dwFBIW#X}|iJXKwI%Rc$6bKfo06Q7n#^jbf{pMYFN-Ea_i!x=H*HuGkyjv!8* zxR;(|RA)2pPTDGPq>L@$F^@c#6ujFUV^0*Y!3-K^YTB9|z4ObuK`NBYori#fneD`R zJ&#x*+GCg?nN;@q9hk1t=J4nT*kPAs7@)^`sul9{Ww02qq}59+I;<}frebr)CX4-M zmTjNOTLU|h0IhP(GB{moEzI4|$5}mJuA`62vb_S3)|dq%(>8PG4i+`da7Yx8 zX{$?G@eAA&ZhUVsR%S8#;^)IuzV6mJik19!D>kgG%)uCk^I(+$lp+KJlbTWiv?2>L z(8;&SAgdK+gdO;Xc$(dVZ+MADB%txkK9Ru(FZ?VmdpKw%0bM*jN4|w5*;zMuKMB9H zYlp_b=!5Qp>_unTFB6Jt*-QOg>#*Q##Sxl9AsCdmLIq8p7=289f&!c51Ga0Qsf%5Hv$yJsDI8_DCt_5E08fcFgGTv^7mtjdgm zp&eUvleVb_s^IZt=wb0<8^28J<-`TCn;A=_17X29JD+>5T2|bMY8a-wf|_~wH#8ik z7pH56IqoaV9;0-Jg<>~?iETL5mD|zdYJ<|1h+6w?kdocg%LOTD0~UODcVkxE598-Z zgqb)yKgg9Hl$Dq60kjP-I&975p(&vnv54ttM;FR3Cm~q<_A-i?sqW~(K{FJYYQM`( zsIaWp=**h}MCU_RoOjzhXmIaVEGpQ0;P%_K01F$EXf(zVc0;1Q`XSel9oELt5%5T0 zA(MeT`QA8Y3Sei&P+vBuXAHyA@QCXG(oyhk*Sq6{F|sx_ z8@;HcEXa`3TR0p&!RA+$4F?8UI_;^_5| z8M(`d4q$7c7f<2S&gzJmqA4a6Z)?(Wx+HzCVybuY(*{?k$>xSFwn;Y4q_t7zhC(n& zyj{!+oxsp00eEdx1Z^E_x3g=ebpkFanLxu2@J6TaY{R-Ce9;m6bu&D8)%aH*#EJtP z>5l-StOp=AAONTc0#HXmZvB=Cz-yTzXv@%Wxm^o`AAibPK>V7(34HBleo^)uZk8rm!1|ASAX!DexMe zjPCC4=k)tzUe0qkX*Ylu`ZJlq07Cb=OV~;QKC25_8F2)B}{%rQOEQ|KAQ%gyX;OUssdE+tP(^%c}Krj_#Z^76G*U0YtaZhf?2 z3`jx&2efTb3Kd{mr^`rT)#WAlOu`dYbYmIbL|70I9)j^J^eU_8a@?NP zU6e7uyiI|II*XAK*8Z@nY6{p^7-p*H+PIq9A5`>SUHJCe+xc7^rWWZsmtai9<0BEftf-2i*zK z5@RMjtjdA`tpc8|!9ETxjcFNB!6#;6J~aai$t`KCAg3T;dsP@%Ku%#Hxz;5Wr_f2(AFw8M|Lxrfl81m;@sgPxWt! zWG4Y0k}xSYD1Ov#r6o<{dIP5q`lTeVq{|H$c2G4dNqlc#fUPCwps-yY-b)&$Y@EOY+`paDH<8*BEqKwpyJ{bG(9H=kkyBA(}2?na%v0hwJun zd#6{{`_pYnSWV5oO1$Miz4+k(vFXQZYR&?$=q=wk^56DOHI}2ga#a77 zYgaDrtVQDbJp^pNS&oo%(}EibzWLT4m?B>6ZUG{5 z6g5!dEL9y=OQ8cL&bm!~PoImXIbP32GkUqf3v2i)EfRYFDivmuKVYK~U}K^l)H@&{ z>mo5PGlgM)aU_CXULJ`i#RQ;OQ(WvLM0%S)<1BNb6um9zOTR z(Q%eh<(AT+2}2i&=|OKb1D_o+jgDkp+LOqbAt^worFxj>XsS9RljUeKwxH;FPd!0P z``hZsdsSeRt}nwh2_ZFAO}xL2)~qQ-_0nsN(rZoVHA3dhFGY5o+pQM%dDLo>L$y=_$(nrU8zL%n2IK{m{YcaN$p>LBskQe|X;*>yiIG((!X`

5-f7zB?LSRE346POGNQSWW#uL{l+7KpW#@T3uvmbG^r4MQu|m(P>Jw z6wO$!|LCt%xIVb|Z2K>6)|g@bxky~`xoAp`=rWB!w7_64beM}AW?PJj9$IQJmpRPk4zoSRgb2`klk7e8n~2OGxJ{v5 zIv3rv<|&$Q2bc~WREaQ0^q5&X;QTBd8puN15K{PAx6$@RsW!3{HM1*9(L7ulOHm6h zO{t^ci|8pxuM|y=L^sujl*cGr2t78`(`r*va?q$IvRzr`hDfiv*$cbg$kK4&g+V5c z;K0JroaaYKHVfPd4=JS(WS|SD*oD*5g|NWB?fpSuqBt5|E^TbaI0TpTaDh{4!39o5 z!l}~61-L^q7UCjKW!JYjl*g+SS_CvGYnv8YY74EBLT9TKs^Y#rghDh2qD&L2ObqIv zOqa!^5(cXzf!^dNzfEO2UW$%GnP^z0*aa~ zkcyTwrlK`J4~t#ie6}35l{ceR?b3VzFR=L&{1HK*_*ox9kpSx|VdDl%#ANUs3|0$e z1#isa0R}du1_x7m0+XJ(tYWwIIvC2LUg>73gLr`5@av7s3ZB$qV8Dy(HDzr(q>i_h z9{7{?I+*e&^h7Ge1I*UzVA{60UPBLfu?$Sviv}ijoK|{PE)E8Iz>Di8p0-!oA@#;( z1#g^kHZWVSgTXmNf$S6-Cb|v^LyC*|BaYVPKecyi`RK;eGJ<}m5hG{h&;P&Qlz0F` z1UjV}beVpYu|D(;8U!taenF?8eX5(#MCcdv4%!DTyGmbAt%q(x^w2~!5PFBEuYq36 zI6BR7gb@Ujd6wg7+u?AL)cOzA(}WV|;O>b6#oV<&n;o(#DCA&iM@N zIu}S}w@@O4MdD=IB+Oqb6W3*^Vei@H-4gXY_0rT?G;H+n8pL!d4Tb#BEHH~kz@>p@ zG!#t-vuG%qf@YziXavN7;e@83>Do|;0nLJtARaUn!hjgibO;Fzg$Qlufc&I%|K?Ky zluku$26$3{mu2)g;0Y*&8KA&~Zb2JqiU72j26!B{E(U@&F^`E_iHcvqh*IDY0gkbv zaR+=wfKaD$gr*qGmld9oZG6kv3s934Um zT8L)6tSRvRispjhBLb7Ke?OXR2tfLV0D8a>*bmCDE=7-)hvoNG_AX@uWT_PbVIkBt zrG>7Qql!YCq!9Y-7#T&c9amP+bFXXRiXz*k$OYCTg&;;2LOqZj3#HYwOA1Xo=1|x) zA1yM?uc&FQ6oLlX_OJ-3qdhEw8Y_xCEk({d=Fp-Oii#GUtioKs6uKC7SYNcW(UyF9wzIwwTG$wG`EMTHng~hDQ_Cx z!{n8A_b}C+ruQ(lgx2>k1xy2cn5>O-E-W3Uc8_!}DjlX;jC8^h?-}WYCEhpENlX0F zS=wJ`j9;cP-gqjs#A%bHDzmBi2q&9M(E?oNm7;~Xw3MPnxXdp_ZMZBbMN4s6Sc;b6 zvZxd-$EB?lwd1n16s^H!+2p}*GKf7^ijIxYM%TmsGCG7YI$oxUo)-Yl(>eGU7%a;I zz@$u*JQ~o@mH-3Vwen0qFlH760I1N? z0C1JQ%BP`|w`814FAe_;FAe_;FAe_;FAe_;FAe_;FAe_;FAe_;FAe_;FAe{U^%wYO z%;TXImxoQVWeKweiQ8$y%tAIY zZc2J;lNO{Ttz!L2yirZhR$lS~5>UuYzr;i15kae1^^)fN70TAp9vwF?v2^ zA2XIWA1p-&u~g2;W0DUUpZ|bM7FRGSj~*2&$>K)^fotL@g^DIo5hpIFOOm*vGD+gv zoU95uSpkEtPv{y4l*aOYnGKlWcovQ~zamvgvm^_|uX-)woCKgaAAB$$s;1>nv-{o_ z`jAOHQ3;TaSeco8ul^H4KQ0PBgZjm9j0=58+LSj;xJDck`f3%MXmwAO==7@NiW8!6winV4QMknZOWIYYT$UR)wUqfI$>9GBceW%+$30pn*@t+lVA}Ifcr!P;6Bj+ zxKA_y?h_4w`(y)*o3xyN;D%b|JLVky5025n!v860&G&`#PheR#MZVQ#E}TQ=W6}bs z82dq#=6fXb*4DnV>E#M_rm)R*p8Q zZGxVh5~p9!_)F2Bap-*xeY=kiD+Tm^gFficiw=F4j}D^=^cNIe<1fRHMp1IJ%)~;x z;oJgTO-YC+jc9R=SmYXkUJDul^=UMX0J>=e&`l$N9yDTH(4`STH;n+gX#~)NMob90 zG@``>k;3;P6AH==!b=J0yhcn*fGLfb?;6qO8quC;#92X?o&dUO1kg<*fF3mBf}l$y zfNmNAbkhi+2aUKY=+cP!ek0oaMj*INHeyD?TWQ1s*NCOA5o;2SI4|hZ2%wur0NpeK z=s_bc3c54`=%x`sH;n*#(1=Mvmqsk`8?n@Hgbl5|p12_<pt2 z^_RZDY(l56MEL(Qlaol6A$3S+G&)WRKRtgTXyG!SSWnNNSAGk>O+dk=9)EKf02MH~ z6UiK>WL_7^Kt7NRkPPGl z$v{3Xe8C*x2Sn$gmzN&uq;$V=2PzLuO~>{$o7h)vNCaFku&t;R5wP zj*IM9==173V(WvcMt#ReVVf~&kaguxtP& zmB5ujsw@J|j7Fz8+=Zvp%F`Hm;)s_9p2r0Zd>a=ua2yxdfeX065M0Csmf$ijFa;C1 zz!qG^1;$_!mo`pgy0CIAJGYi`9k6TuavGo`|Ccd9|L{wtR8ix5Z}q?y&oRg3IVNO; z=a}b3Qg7P_wu@x$x16G<>=3)+IVQ$xn>^*jb4&?87@IB-S>rh-qN6q6^9Q!v4KKZo zpBbjS&Bn=nO&f30*1IVtLaRD%wnVgFkN+C9H$n`WYC^-AxAX+3~+kdHAX4se1F5Y7ri z63!eW67z0PC~G88yDWj)gam3=B~XL0t=yk!9=c3^A-PRc)^|7ru?}aKt4y-kMW{Tr zh4MhJrpgm>vvALF$OqvbZ3{rSN9(5IV(JPmvuW_gXc`)brlEme)7s8Oc%y>7#SwxF z;}%>l^CH&bri_6bqVdq?X3=bn6ENB$8jmr6x}ou43dm#}jWJ7h=J`E5o>^~W)cH0a zjdD2xR4w|XDi~@&6NnB{SCMk)=wf7AbY>}%DF{+5=+G|;6M_y(n#KBveoaUP)X}++ z%{YaHUUxYLeHMfM+7PINZfqSf8ps+NfX#4MHY3hE6=#Z$eD%^p zd%z7@Y53(49eQ>K0F|;ys64&*SuuEx77CfzWQ=eT3T2@Xl}*M7m!Vb`3JKa|j4*NS zbzx+oEN`pPl*;Y0BSsaT_==KM&4p#C*A;axHtDGKnqaapFoG;HZ?Z5jf-JIavM?}$ zESP3!<^_&nj9%y}MlS#`ex9OjO7%--U>nmn5^)h-gb(`n8=q$2oZsEw1!uWgHJ@DE^ito5=xMhT*qp;zZhehK=3|BT|wc$iO zPF_byi%GsZ4{?>};YKb!bP(f)PLKIAIu_9~z{H=Ap{LZ$CZMOqSj)R{9`4w+ugUmD zpp0<~7l(d9fCn{4Vp>P&uM3+1nfqUrdwOvAq$yT2`OdX!4Zx5<)Xj%b6Y>;Vn5CnN zn{YMREHnV7Pxc^sm}mfo$wF4@LC3D)olzJda;)qsdsE8Z^ljJ^{(Vk zC>XquWE$*Y^va$|4|D9=uNdixw1gdqteUhi-Y=`PF2>z;F<{5az=MJvTeSxTLzk0G zj>+&zpMaRC7&F|HV0lzF?u1Kh5+ThSJBneyrQG0c!mF|9x%Qz zgE8?cHxQMEWg8JUwemk3i(WxBFn5qMtuFco_w04Oe_QS^yZiHT_#^mdl7^ugcD>VflTPD^#-g?F2N<&*3I9@O2V}0`Ngj zQI41*VV>E&h1RB3wRxXxIXsoD=MV`VGnIuryvik0Q!1=#^M2Wdc{Zg#{~vYfVGmeUT%a@s*zPCF#a zX)nui+AFf0c0`ubj>&S`aam5o65TS?_R?9ZqkWvYiJZvn-n>)@o~F|DY;yH^G#yiq z=kL=ANb!fR&%Oc$i^G7;&7*idD=i|V*Lw0Tiq3li?&fM0FbsxzXr$3xH#PGB7#d9h z2GngDoR3Bmx`+U$$3+AIZ4;|-;o#1H0nuUW+8oM8-ui09 z1wOI~m&Q@#p^5(zq$y7$N~C1x1cq8u?1?U5%yBdmivMV&gmveyMCW59EE*n>_)=WN z&WB}Q%|$)q-O+wX$OEALjR9cly1d87sU}5%s0LFvNCk7#Iyhwx_~wJ=$uOdtTTbI_ zbZ5dx8^LXc^&6A72gMkLd5osz7>cp-2fFT7dn9Uhmg)YE^ zP7D={fC((e#TE)&44N$gYlgucN1rGxl*Gyb$(D#IVQ^R^OUYH|D8Z;hNpCZC#Hxrt zvvw1kW~c!h&?t)Z&KaXuPz?)iB-a4TdoL3%wj!`6)Km~Zs# zRpooK8c~hjFH+ADw?oenw?ohE-iO=Fy)hg_U@e9p@&CdCmnP)xZFCrvROjOh4f-O7 z-ex*Lw&FFbrYJfzV3|Q*?$FyE`kDmw8|7%NLGN_vT@HOy0{y0F&n@Tjz<3R&q~@T! zjd7I8(%e1x{m7fhdgRTa_n$(*S985qViWVC>H?U#*A@YMls|iK%xd`6dXz)~riW*k zvz$3&vtHx%=pOtGj}3iNp*LoI`kBe!#2F-4YL_D8ookmKI)UP%Kab(bBv;j8L}{6i zA|DKqEtpV1=1jiyd+)w`>7g-O;788Y?m_Ns{GF>^j$i(}-lS==uK7$U>DP!bA|wr< zQ2;Wb$1cN^<3X@{0Msl!qO^zZ3VocHw&M^Ee*`?H?X%82%g7B`w~2 zqi*QKrjD4}Q6@`sN%$76{CB6}EaVl`*PdoQwfw#G;^bt3ywq;T9Zd=JXXerliKv+@ z-~S9U&eitem;Ww3G!8kHYo9?{!}SNi9M)r`p^v=TFx)_9?}(#MfFpCt##goC^8K4Y zw_K~gmraj6_e15{38|HE>C^`81Iqc@D^i5WT2K&v+!DEJi0rJ_BFlk&y}w*bcpCm> z0>6d$%gVKcr{PZ}@b?hk)P-ct_4(I-f_*A7$MqS&c+aLNM@R^SjbRSe=3MO}g7NR# z|9p?=!QLCQ8-|CGc8c(U$=^ZUszpcpfQs=jck(v`#@^IULvL6$Z9#Hm?tJ_j8gqs| zb+jF~!(&CORk$;%e6E&R{CBhkKP4%63;lZZciEfMsNO7S&7J&F+$ewA(mK#7*OFSf zmaVn=W;DNczT~j|agL0IQ4B`41w(@=V{QRn+I@}0N9NWG39Sf8kIJza*DW9 z1___+g^;h@zXr)`b8Wql{U1}W7XVtCyAZ!l5-kEE>(-tu{v9{cUI6%L3w~65GSbyj zc%(emP2*TXdkR}A*f`cZBK4MQnN}&rQqsneud+xn&SB$@w&3Ts9r*kyc3@2{Xvm6W zVX4QXYi^y8q8M#+S0>8k*Qb^9STJVyK9nohQbOQXo-x=lS_4sE|A-kK=z{BWz3w@S zOzoaKtLFL_E3M2fRC@hUv93dH9CPG?S7z`k^2AkDV-cYIXE;L2MzVEB_uvjbs(7DC z%^rHd`moRVY=6+PJvp1nz)_iqrq$4>8+y>uc))8qPqEUb>)-?(JCqxXEvE4D;*XeA zOR-*3KSLge?n`nnRa7|XaqE%GU&po$Lut-XjvO4tb_{Sz`L5oq(6- zagoXWey(mdxA(fN^$Z+~US`Qbm? zU3clB##(TJ$9m&e@OnNL@iEJ&j_}U6amEu1VDkytwv!NaKUUW{zv5Xn*wr*CtL|8V z$ErJ4;IXR-q2mRH>*^OTGK@zOVJ$MSW+ovTy(D8xK&K@TL(s-Z-39N#)Z?`SXe2bu z?uKW?F2!$EXoTZD|xh+oC(1m|vNx$F^EzmL^}SD=hnpiGqS-!J*~<@-6# z_rBP6Pw{>Doip_Q$qOIHn5mt76&LL0dhHE2WmTN@?Bmj|6 z<(KxpI90QIlfo}Sdps@>9*O2Ac)LF)p~Xn3;g`FCYa$!Lxb`>zQ1kL~EF<8zQSD5_ zFEd69`Dpl+Z$lnhScnbtm_BmWF!EKTqWoN(knsL&iub=*I^p#qR6%#0>>g#X8w`1&4YgJ$Wy~bOvenq>htsF({gH27> z{xyS#KwDKvU$>fx%`~d3mo4O<G$-! z1IOB>-`m7T5X!M#VEY1Lu&$a%77v0L0c%o_35)ZjRgRF!Q-WtqUp;h$)V_@}Um!QP za3h9Wj{)U2tVFrJW8&7e#GB_yx<+T6$eS4$nS$kicuKn~^JbyAy1?1E-@H`2Bl8!`$GSiqj4a46+C6^wW z;9!rv%ZJLfQ!@OCdmT%xykajHVB&q?DPylx&Q=9q5sIXAbW z982q)OV(2vM`CqQ%b#G;ll(b_xAg9$yf0QVWacw-%C$;SUO*ZnMNGZN!fp_J^(}5J zXsPoo@HT%idmq0OKEiffU{QH>i0c)1Q2whG?P$98qX@k#!U=SE98TP>!-F33M>!T1 z@rc2>^UB(FRyfDD$~SF^vVmf!N%TF{+qCz^nVRAUk9NV4@yQae<=Q$bwK#vtP#btj zETJzqtU|F>;d^K{uz9FO@{A{_Z1EgJn(@u0Vg81s7u|yN@`^kWMDuq|vOIxFSvt{{ z>vIlXpQVc>T+nE?3mwG|#kOJvY(*F$>e#1um!@ebYh|Nj@hvjFyuNabG^<(BSxo+M zb7uKs`v+L2qhEl1}N|ocS0*HIw+miZAJbyM{OTa*n*h z7r@U<)>X-BtOl@Q6%g`<|n#ftSl)N_<%v6E--i}PxRYH^~q z*$psyc=|ioh$gRXnU?^}MrH2zH+#LXeT7f*MWg;2Lx4nz4+}|G9&dlK1a@a|PqW!U zW%g6eP?>)ia=G669t%zUF!h?eOPfYVh1<1wyKG$(4is-Lt!u=kskE*hmqv5~2PiwE zj#ta`cYdU%CYBLKq!rNnW#nC7<7>mCDCl(xI43EUpSd|#%aO)^=OAtU=hNQ=Gg7Mg z-C4*PIrCrsVq|>p`H%>l?jUiWgb7tgx zYjpL&^P}~%@!03{Bjc^n#Dn9r&daM1^GY?3M3);zKZTlPlNpbjj__g#-Wj^~v;grW zXI!4-;293ypTKJ%;I3uXc}7%-2Mm)lLU=+&Wd4w zYhma|i}yDchBNjp4BLssyLjaOT0sH1?^u{e?%OHkZYWH-d$Zw<=&$#qgvT9W--%&D zj<9dXFyW4{8-&H&5%jJF8SV)C+Zg7^{Y?yW|$#0&EZfI%T%v}4d5SqCK$tjHAN2BQ%A1FmPmF|p3_a{Ji zZ*+6k^`(k7v}o^(H)@J_At?ph{CQ8GhG2!^eUQ9}r>qjtt4&)He`i&qN+lc=p zukqW{icurm`Ut{=(PPq##*bo5y?N$q56l|>(;JjbJp{zJvdHl*hu;x2LopwXnm>*G zv*Cbc`NV+TEqu-Z{l%X`1=6cwAsOW~+|XGL@yAd?yYa~lFHN1$9(*)vZ1@~!^?P5e zheLk@DK={i&1z~GZiVgH`{I0L{BJN)dtYqCezrGJ5EFTNb-c@?mnpr7eZRh$=FuN# zkTXTQ8e*U@nCT4>$(=^-w5X5fiaK(PO70YLr(oLmMw95O$w#C57yccEdIoRSfm^Ze z`yrp{7$QcUuqht~TfV>U+MmI0a&Jn7Uum?hyNbr4brX8w!wB46o1 z^^PV3c}IA;_M7-AMMwM|pz6!%Gla&HSMVN19__Re7qBd}m7;x*Mkhc0K3s8DgWR2Z zQSVM+&GOOcb>{8iu@1aD!93iZ&}H05qhp`G*Pe%P%)*Yp=wQe9Mn}+@N6?uK2Rg(E zo&0EYN>0>y{i8VVjR)x*`zXKfaPVC83d{x?cJR^Y(5K&zTL=fYFFzU`{B(m{6$~iA z%^!s^`YpZ|(KPa3KRVR-`EUKL9K}=rQ7roMWS#?RMqj}NDj< zlp`8maAe{tvT2R(=Y%1IW22iOHIM3-@a8W75-uKa{r;vN7Tm(Kh;U{wYG@uQq85bY zE_!2SXwZJv!teil6jflIA(0(W_J=k@o-ZG13!Ditjk{C4PVgk1|uQZ)}?O_ zEyO*Hy@Dh`=#L0=wuK@AXmPQWLfISp`6DU`GRtRCYPiKOZ)fkHEj~87F=ua7hrfFK z(Z#}7H8vdh*P=4khi-zr`3f`$vg?~D2nG?;bXa6xUT~h)7Mpl=%I29ea4LIWtg9)` zQ$GvQOi?t(>;1phvo?FP2-z<+8Fw)a_f_w90&IZ>x?vtJ^PptSs>l<#ZPIUrT6PfFY{%`Rlzg9#VwMQVZ(&}G{{K7t#M z2&l~zTDGoTE@3_MGouG-C9#2g&6{U#fUygB*&T*BHE&$J>jD+E9_7r@&?i$GD|Z;mdH;tdJ7186srP_DNnxp%By+#}|1KZ$NU7adx@ zvY|%io-}+$VQ_K{6=oDqqa*-)n+ii}GJ-GQ0^0Ma&mWREtuB{P!9l#*-0(*GY)n|k z&?ygMW{Dkwru{B|-)x<>#wcfv7Gonh&*Cddc6d{g;kXE zBhavW9vmO-Y%oe9IIov#zI73k*L81>HbG~35Lxs(^#(=GRw*KCC8gFvBE+8cWm68{ zT;qXU=~e9=gUb2k>a^UcM-z^<{WmTvPj4}v6Tm;EbCRu z`MeWb%bgJ3|E&o9gwOjC#423XI6t~ZH08{h8*>mI0LZ>O)3ELgt=tjvd_;MU&L)&f z;Bim$Rx3q{%tm9C1$-`v#sYg`7hxM8#mwrne*&k?r=S=Wn8G!D_P23wK6rN>Gu=sN z9brJh{<=vxyIJS=g9fKSYKtdd_^+H57*DAl0ACDjL!_Ygf7+P)YafT75JUJ}!vAke z_5Ytp^Z!HKb1or4BmIA)hNRa2;}*sM`Skx{8G*8Q?4JFN*Iq-Xz)#RVqJ`=z>-UbS zxjhdrWNq=d1Q0Y>&VFv5Vvseuc@h_{PjW@nEQN~M{PXK{vy);myJo|f3U9b?9R1l@ z0#&oNA3{^;Yzu`=19T$=D}0K4Ovut0hAq<#pZ$G=5%@Y`oB29nrXB>*S~81;$qcL^ z?zoIpe=pRjZojN3Az!6Lff0Mz`*&ipj*mCa8C`?A>qdSSZ{HzesI~%%G_a!>_ zx-TuC6+iX>RTQB+m9{hJgG_-&FcvgNe->s+CPs8D42db_k$Q(FH0wzdWzH>^h}o{_ zEU+=bQbp}C>k^@){{-kD@)!6 z1XjrT_2ES*8rW(; z($ch`g)xYarV`}PoK2xFh(mKwOpr<3U zCX~_}-_wssx$Rx~Z)r^(!&9JQ3qbOCHv8de%!XPQBXzBhiWcTM6Oc zfc!0FUMXzT=)I5&WFy}4Pato%7&s5!6ZdHKty1#+8(~Vg$AT)TD zJ^3c*+&@A~%WgLv4P~6bcPbm+kbd7cHuRN}Xa@RZZiO!Vgj8mSDXAC(;k3`0Q%dWf z0fE*11g~@ELt!j_<7>xo6I$lQAH#$3R{%cBAJjiMIrfMtag+fb%;_b*1jQF~%$cir z=Z1IX`>*1$_))H0-3n=vNXziV9K@Tz&@$jpPT!B8|9b@t_$NzT*H@H2 zC{*T>N?06^TA^GO#o2Newc9;k^Rmy;2LGw1QX>MsRy5bW~9Ud zY`i099)&dvQoPmB&E4?>&N>h!cxpZ@Y zHI?ShXsWq1_lBnCmF9AJ6S*ze)d1lkHNP~M+K$wM(%d>tEiBEg*VLlY+(u2cmF6~S zYH4XM7xqwM8O|Wk)N*R;zxt0ni}93IT9l(79GM$|@hUJ_u5C7TF)1|pI4QhJ-rV~a zv&b1X$2ANe0@W`?7yt6qgGiLtUEKeNFMSn3&ATJ#KUh=qKi1#}=`+IH-bpS<^VJeK z0h~2ro!E~9N96O{zkli@Nbf&4a`7igLnw^=!N^6W@&|^>k8)CnmT8NOQCNb4FbZTx zXz9=2K8)L6YsJrk=4x6e=j7hs0{I(#6s@~bt9nSdJ5Bfg1%jo&i;$MLOJ-m1y;94& zE49qwNgOQ*)A52V4n^bT1tlxXlj1x@Ig&2C>=heDSV~!Wlb$A9ezbqZKcDqMSzEUA3mnAWu?Q%H6nfAKN} zI>qVb;f2aYJI0NsAka2VL7+=D1%WQp6a>0lQxIsorXbKYnu0*rY6=4F)YNu}TT>9| zCQU)0PiqPSeMVCdXrHDa(CtiFf$mb)A`_fEMUQHVJ*p{T zb^B3a)w)R=s@26NSV1pMF)9!!<5QUX7(-I(wud>SF3E5CRSv51Fn`s5SIOkL1$gqd z2-B3^I8fA{!Dj9G75Pr|6|sxGx++!3Dk!u@?zr@2raXGTv5AvCvo3+) zNv4aWgn#MPaN_`G`J6CemdHez{kH(empnbcMSg8xGSK+C)sqVLY;%+|sciCHR1Cz# z7#aKT5V$Nc;MkJM<8n8}^A0L1*01I?QiX0?^Gj0;5HBJ0xHyKFGcc|vA1CGEB9fQn zxBTi^q|3wn#rrGx#o@nl*a?<48eOrE+*vUk?1h7d%|R(V0Tl}-`{i7_1NhK6K51T# z_LaX3)|>GsO<;cbhGX%qjsCXA!V9nh^#~!}DL?h(By+qsRn7s~W@g*CS9FgW>Pm`n> zI+TX@NSeVzX?UNc89tPT_e+`qL}~bdq!~h#h7U@bK}2czkfa$#l!jlH^n6LbB58&a zrQsuzUMT5fl3pa~@`}w*cUYI*EI(!3}KOmu; zL>`CcQz?zTJT!klZ(uSH%|9SuDi#zOX4!;nFv})ngZrne@YoJxPQtRDY$=17^&q5(lphMAWc(iyqH)%D1y`_@`(NPV4OKuJHffgnts^hVW0R@K09=e@ujb7Q&yvmx4xzC+_M# zWc2qY{xKE*Srz|zU;Lxd+qavHP0>ne*sm#sV>6nPA@uc6A}|`hz%G-oTA`!IwWbTU zrfmbrq-PsKaD!mwAoss>A1RJ8d-?i5S1&X4V4U<;{Og=6NHL;usDe5Y-w2h z1NOiTi+g}h4vTldF7RP-4%i+zEWQEnO%01{z-B!;+W+q%?)vOO_GDf8)lTWs`tqw? zl4vZyx`_!avptQgndp2EryV+nZ`V2e8lA(h)j53UolcWDxp?3IO71z5bmosp^caRF zBGKcxAZDdkM9fOBIA3S}3)EU;jeyn~lOx&?Opa(nFgclIGj)942KMEOx>!T{)4Cu|}|^ zk5ehEmHc-8VvW~Eub0$5{PusN*@*3fU%9arSiSWbVpvj^qfk=F4ZLS^j2lbCB&uJ`l?v3Qbv+r}F07k;O#V1?Itz2lxg@PF{^CbzlMmpI^vW-O zv*C-;H&51Y#YDEeW9AYjXgj`%=Z>avbysBNzP$M+zG`M+LQ8JUBd#+O%_H0~fu~;B zJ==IM(|8cZowSn1v$3&z?OCGO+rn+_W2o_KUx~hkV z_3RtSZm6DpQ~K(bCzkJ>S{gI><*!6vjv0KL-}%@)88eucJry&UmW{9G@!UVZk>HHo!Ne1|)9sd{W(; zum|E6)PL@{xGZ8xd~WaBcc>%yzL64sfLj@&8|)~R10Jk^urO12@cRFx#A=%{;gpZX zU`!+l{znpI3*^H&{D!O{b@}?w3NevGzD1hDMFu!i9M>vySe$^b)n3NQBl3M9mw%A@ z6X(l^a*hy&$4sUSA2#Ws!cCIBh|}V@NLusbvDk>@nH$afBWll?8;$#;zmY`U{s^zO z;uqsq#|9q-1A;esJ}o=@xI%;-1lYbbGZN{dC|`cT>o;|uUp$Vz)@x>sT>SjE@b)UU z?7OGIpi;-jLCWy^DcJh!jqr+5z3F1inJ|LZ)$L#RR}F7$#;99&A2N-izEytlI}Kml z_?H_rS@^jG^YH@xwuXa1s5o+RFj$J85V&iq9)?%u7r z7hKfoGwE}++>AogVGoPI&Hyy_CiMH}e^`pVhBs>UGPZYO7Iv-ROkrEZ&zh}S=RrxR zIkP$UG(bmB;fEIS|L5&p;G(LwKkzd=bSereEG^5a(9ldx&3qOr<0D_B_{dB^7+?|^ z9AWEz0Y3fYzC}; zpa1{QM`yn0yVhQN?X{n0pU0?8IgCT4mIR|%4C;zB#C<~)NepZhR&x`N7>0Z&1YPJ3 z9r+O1IP>OA8Xj>^4>nxb5^npTw*&^3m^V$*ogk)V@pwxkAK_-EI{bD)viaaf!*JXu zh1(&;!ynN*E1|aurj0WPQQIVuH=Svc0ei&Tn@Fu8itk&lTl@;jQ&<&e-WA&@?obKw z6OZTMRW(ki4stv36AHo#o;qv7RdX}EBH;`Ov;yi0@va4DgFTrZA1Bop#fi)#n5n39 zG4vA`YTBL=8adZWS6rs1JHK!_npBY1ZtHBR_7zZ;Mg@J^VnQ!13GvNo^NsEtq&&cx z^-w|Bj7)o(r76K#iFj^V2satXskm}!=#Nt1mI#O_Wz4427+cIcOX5`ux7n;3E*D}v z47BT0+@x>asY7?d3grQK;^(MPQq2i3YM^4`PhBk80&E&AE6zj5tTyrkK0od=PRsK2 zs7`QZqy^IUB}9qZi9{_)EoBg0h#E++1635&-dV(SF9%}9HwV@Knes+}iJ|oPLbq9$5Xbm9h$0eH?_+|}2&Sw0Q7Aec~47G$s1vcY`}Bqa~X5g5RITHGaVj_6^d zyIoM?oZkrBG!Zt^YB6lI0jtI3De1=Vi;K-USR+?QwD&jRNOR=M-QnJm=a^KBZwEtohJJYc%+o>0z!?e)t=d1>Uv*@PKawcFr0%_}Vt^BhzBgrt*Y1w#i zyJ{lo4rk0rk*T6Jh}8|qT}1AWtbtY8L|iRtQ)3AYrj~PGE$1#G=l`p%|F24cHu(Qq zDO#|#sXyw;oFY_g5S7U5L~tqMk?|a7dN$aUv>aX4RG~+$axd=r5*?A3DXP`|p{!bP zyAaC_cav;mBCF}h3VVnMm3WH8YTr)08y;=W1YR^SDZ!uD$XKLADMIdD1Nnl z4%Wt}%<%#0bbIq3P}i)Blh0-*B!?CLDP%*RlT~K%h!f7T%gIDZJCQHlM-?S*X|?aM zQ9Z1_-LcQ2GKPA7Y(;C6^>W0!(;yzU}8K((w zM~#2m2yzLpJ#@dtOhqQ2$y}77B(nyumuH=G}SVoH#NJQNEF{XV=_!n7V z%396p-w9fCAV?mcFy6#-O>?pPCI9o zwTaX`kH8{j6=!hO7^o;YRf zfy$8u+_h;l#L`sB`=#wj3o*nx0*UBBN313BkO2pvd_4s9`|(kFzD!9SQ)o zO766uql%i!9lQWRq%YaEtG<(C|2wDT>&;FI$Ay%#XePx;=SgEB##rj) zc&HRV|AB)>Ixrt9Xhhx^(oWi45c!l-mlPFIjvg%4(R;5E0ipIo!#1@k2n8p*@B=s| zX?yy%Z4b6m4GAG?A~UjOudOK|Y8+3y+UyXuDssKDnYDsuY9bWmbQLt!fWqX{Es?*% z%@EC^oh^{7-)whG9mVZp#{;xVRm`MibbLU_Jr@da`$!>)AMc*NKiL;3PXyu;CnAt1)y zjJL_kz^AN9+MgFck1GcNcfnD2fh5G%_EGHTNwF9Knu)Qshh0&zmFlMl$gN5(v1vl- zBiz5E{Z{Xicd_t#S1h~^9+`9SC~m5n^DbUdB*ug4$Vw_W{x(q{u_&TyE~m&fctZSy z1Ha!qwGmp&hzb%1lbynNB?Q%xlm-3C-91|wLUN_()RxhmU-ToZQSuARHSv?HRCT>) z(-LV_c@50rr9B>xDSmm$Tq3P6mrJA#kvBH z+xP;7_(Bw-_Q;&tqquN8=L^((Nwpl*_Q}zA&!z+`|@)oiZaYnweWD?)val?|u zI1vfpY{Go{Y~Itj&4?1x^N#f0q7_vM$C{O(VUS(@7nLbh=X#7yn&Ae#9#FhWEK2nD zRWVo(4ZdS$irC#)-nbr4QYF&fpy=YOV$`sBI`yZaeDUW{yDa!?^W;ZUNnn->RtlEJS?F664x5T~Nbr z2E`Ve859icW#9|#^B}&^x9G)Rxbk`!U)Xx3cSUrh8WJy@tHl?R*Wn9WLyh?AE?-;F zi+1S~!){Sp-FESO?r!H(pynZn%nhq9;ZTW#!rqMcW;pZ&llnc zIPQewhj9(Oyb;Z)q}@q;)}7o`R;W18LWgD@ zb8CG`lp}~=v8M4>v;bV`B}{*6^SwWXOH_$C(Wd@JV%1bkte<}zb>p`mqyCTQ7NUER zpR^7@=3db3Px?<6KI^)n%fJ9GN~!U%oG$gLiE^y% z%3fJV(K}#FxKV-^i&$^@!|QYL06irw9oMw$lQ74ATn4mV;g&lexO5w}cq=(fSO3r% z&1=3G5SKS@fM=!RB?oxS84niY?Z<_c1tqw1PdwzTla=NiXuV!H2FdYyUHNrLejSuw z2dL24xV&?J{R4Ouw{Xb;BY2fLBPK@|KPghu#tRIHnYF$Y7;28-WteC1Vv@rV%aZ$4cue>x1K;bf!{MV(zbuJ-j8UwEM#J;wdcPy7J4xPu|OXc2PQ=PoeB+*~@Y zKzn8zk89(-t{897xT8cgF%r=?jZk82s!|Q7{stJLphXu``1ZMrOp|vOt*W*;N+yf! zCgtFT@vXVVeePAtt5qRhts)b0_!E~*TXAXwDuZe&x|p^F_qkUqr&fnJwfc8DwN^Q` zHpHp5zssq8?sdwGbfES&-Pqh$%np{t#-p%^mE7U7q#6{Uu##TdCUzoF0@3=AAErfieV==?@^y2Fub4{M z*9XWlZq&eCNMyMTH*UMDB2}nq$CPuh4PN`)TTJtlx2)Q?{8Q2A4$9XMU;?zv_aXCG zO;nbx5;o0uv&g1N^EGX$=#FnSJM_4%T1ZrHc5k(rKlGvSULOw2My+i=YS!hccOulF zUa3U%OD8<|uCb=kB-a_u43&5+O}NH;Ob zsbaBgd-PTY`$CZP>gso3c|Ny-mRrGd(flH!i|@c&jpTh*q=9!5)6^iAZMcaVf9TTx zI?#B_RIroqKN0_j;=ddJZ^M5Yo~NL*PsV>5lSLYQ7)HS@V2t^*jFF>9^dFFBjCUtb z8a_11-MdFG1OKnj@XRwt=XwL)v>fjuZ*G>$pSCc^JImEM-DV~s1*n?uKOv5k)KP^Sl`z-yB~C zg~RJwfDh=Ab(dw`manW-ibbL~KQAY3p$jd5;&16Rt81l~?_FfeW1=TF0~Mi@GW5;J zDPGU~JfA<{@?~b`djhE4&R$fmH?*8nCfz=MxRE$v>UcEKv1lCwT@yWXgI+&1KiSAA zKeP_-g3jKqE^oeTmNzR4ZUnN^a$Ol_f$Ta|PT&08{PZ-$aZXym?_J=^^5lB_RL|W} zt+@eDZooAk4akKC;1{Jrc4+~7IE~3kXZ476UDx02YB^r$%~UCUTyDSL=fBf6T-8{j zC*AMOqeccR`Gz|endf@pD!f3Sg-hw8V`LdJ1UT;8tBxKAuqaNbW_2-#1JDi+SAL)8W%;m;UXYZ*=*?D*rXRzmK1RkN=r+Wv@vbpTscu z%y7dvIm|F7;``y@O8=Cpf9?n6c|-8=qi(<8mIUdq`T3JmKdwAu>Oc0V{3CyXZ~oT- z`S(*Z`={QNmR2s^_tN6=wQo>*eBHvwkmLAG<&W~uj90nC%wOe4>4EVn{x*i2@+1HL zanfhcJYMw!?9tzc1LFox-CgnW&(Orz5cqeqlxUy(ReF=%sPZ$9Pd1l_C72TVwZDxx zb`Aa0{`z$n-T2desy>7`VNJr_v40x*$)Y0V?-{9Y7}peyynN)=z0aLc5^1lXdH$;X zsrV@SuIn*1W#y*(=FAy*bqbpO2pasa?oLzd$l=2=S$O;P?{_^7)eElAn4jj)yx#Ab zcSCpAu%I_5;F`72HO`wma_aR{`}K9@`F(d`;_B+UsRvDfhS;=$9mk@HhGVhQad}ik z#43kjbOcBLBk&(DPr_t-fwMSl*!hvZz0i=d!Ju!#|MqryvL&AZe!^Mgiy_Oxf4E`U z&#}^P0R6~WlWU+d@$sT&mx}z`M=L1C*NIYOL={Z*6oZY>ne8-; zD!WctCHq(jdCzlj4~!;X&hi?_w?qD#CVz$H)WPTAy>P9ir~3K!Eb;`%=bvX7Nr)wv zA$)9@@;?>wYMeEV(DEO~`4>Qb{smaWYw5>v`i+p!jA^+KyI`{t@}-b}X1AZXGCb_V zY7xUY@U_rM!(F{)sB89d@B+xo zAb-y;4||*IXd~pQm>`a7@();E3Hc!0zfD(*IREgj+}3I!&&ERGB`y8)oZi6L(hd{+ zpEUUkEO$Y^2Xe1HR^cA*p9zq6?`If4Xz9P@^r?_vjREo&dm9KJ6iy0M7X^@~4U}U& z`%iVT)~XAN^A_m+GT1OK)5>`XmvcYlmtrDl(ERw4{iuUH4C}8=TKXqAy%S?(c>+SH z$%n8!9`f3u@IkZxKej&#@=s977|N`AxK)TnJIIFozmRvf%hN3RD#&Ap;~5~dO^!qO z_BNy;$`AR0(T1_po<8h#&VN7T_uh*2gk3(uvR?=JI>;}w%jHxr{Bt7Vvyh{yS^3-6 zV)2l_4>^WfOFq`JKML|MAjec-$wyl9Y{LwVlqJSb;9v0Q(LdUc*wh-MLr7hfoG9tLp};}bQLQ; zek(q!AYTf3uGY`);(oRT^2S-1r?m39xP1E|kIBGTVYeS97rRuxI>_@NAFJ6P#rB=J z|8qws_R}=`L)m^jq#uJxr~Bgudm{~<4* zZy1^O^jLR=-|3JGFXTb_bi}&loP~ywqxq4|ehh{@2>DD+E*JQeeg@?4LEhT>dNJgk z7hw&mrT>uaZ-6`;4SsF}6x8}Qd`<)@ko_Hy2bQ(I4mk$-4Fz(4l+%ZeWBaEeUjaF~ zhGpM2W^}}0wi@yq?ee)IxronT$ag{BQhJK>49Ncp`OEh7ZmRRJ=TwzbIf|gSWVvD7 zYS#;sj*xsayX8j}MM3(GFL}Ofme558H z&T)!^d^hB+*-wQ03&>lF1KH1j{N!2WMUejld23_uX2`o0wl1%Nd^+T<?vhkzrb& zTMNAjD-Giw`#2H4LiAnAXB*`IS&cQIJ)a3yUDMUyI>_n%R&ER7xAHi567qg)T5r=a zI8T@j`D1qbVGna#=mmM?TEjrMwd{w@V|fzf%OKCddc(>;)kzBEe;(wYt;dTABJA>` z+^5$ZF$z!lU z_$%ZX8m#9zS3=&~F3+{(NsxaF`6jzO>L-fpXD#IANZj3? zUJkj23*0uy--djIU5<9N#B4>Ra|k-^o<n97j%@qKji;|e4Zwk6S@oBG{}AB@YgPfpEUAOFv!MY=yclL`nkgf$frTx(*6SF zu>E(@(L|CqVu@ICOFt%y(HY~4%e99KA`!xG< z;Yl&BfqWC>adx?FZXn0^o+Z5t@|fqbhigxtVk`jGy2;`W8tn%5;3ko0~ z1NrrKx!1D45%L9)&$P?KtTjd@1!bW74p{nGcLj0_(HR>eVLWs1^F1r zTO02ZAm0o5SbP3qql5v9e=6h`zSw&D0?11tZ!P^s$UlI*HUBFi{{-@3_WW(<*ENt| zvlTZ`+vOgseDuoUv5>cx-Ua!6khd1!1jt{7yrje~t;LTv?>C-B?t=VuQ|La%>crS~|{aKTjoN$Eb89${3==qE;z7|Nsvmow_ZXfUIZjPikGDeq@gbCb&V zS0HI`Q-8(%2S{=W0~B{JkmTNGuIE6-4IiRVK9J09C6J8YT{o-pt^tzeT@NJfb;jaK zq8ou^ijmAs1(No>%q?WSQsy3Ky_cAKgZ18K?qk;bDM7VKx)n-#a3@frsF`%;UIvnF zw}QD^3?5yf*GBA0O7uOr>jZZhPW2?}#ApDcp^Qc_n!qT9Q5KN&s(`tB7_DdNX6F9H z=ygU_jNW5(gi$S{uNeK8(f5pgVnnx&$+Dft=wculgUgw_hEab;qZo~6G>Osej4~PJ zFe+qJ!sro3+Zesds1iuVZy$4qfuyIOGuOcA6r*1m#kiG~D}iLm;}~^gX+K7TSvrc* zRF>Y!oR^W0rFS#8lDRVG9%b|tOJ8K}Z_K^H+*^#^X6aGpzGU(G85J>lfYEwJ&oO#~(H=$z8NJWw zYewHPI>qQ0M&YAW44jNEV01B~4vgX$bz^iRqd|;@G8)NfGNU^fr7`j`3NTv4XeFaE zMo$6B`rXRh%Z%P+w3pEbKr%%wb6+v~kVDt>5ml*w((Ho53W^{znXN*oT`h}76R#mnbAnD5$%w5Z079Mlwob zG@Vffqg+OJGrE@%U1O8u^JC2YiP26*bS+Kx)nkmlWJFiWr1VEdVPh0`84z8ki8bPZ zMhKJ$B+Khz6lBx{B-fK?fTZQFV-+`%Q9h7dJuC&1dJi-ABy-OJ$x>D`_dRow<$M?=uR+2A)jo1dMy^Pkf^hrj?7}c^~=LyP#>w%z%% z(Fq{wK@;m;eW&uT8<3Rt0+JD$$f`OGa~ZWVK7%ss)})6Bih+~1h1X6^uU$C&$s zxo?>Jfw?xbRN2}A$w+o)t{Za$nY)F#3Ctxk=L3?_4FJjLE@Wv5kc{Mg%st6mIdgwy zu7bJ!%>9eGKkjk&gdgXxp}Ic-U~#pM8Q7wTxIWdAlZu7&sW^N3zb)Y0g}<} zw@7iL8O>nyH%4zUI?CwMyH(n5jD|2uV&q}8gwg$sHZ%GgqXUd;8U2sZg^N|bT^QZW zXcD8@j8-t(#pqu^GC~bN<3;>ZmMS!JnaaZpBYdpo=7Dn5E=*i+(aj%<9dyu8a8GXvAkl-66OynfnE3hTtw- zfw%q&Gze&>K;waAtfm9WSYT+)Q8akMmGa_gq4xZ-Nxt+Mjl2!Mhh7gGAd*A2%}AmUS#wNqc<77#ppdo z#~C#N(LJ!SMtCuv#1qH~BxBl+(G`rYVKk1>L`E}#vW1mQ=H@Ue2O1-!&odWxkIF3? zNVdOgfV@I)6ie@7sSoHbAq@aYpG#P84Wow`l{0#t(VrQ;!szde-eUANqyI4aj8Q$K zZ-AutQ7cu6E@IT4(KU>^GU~}Ffzf0jS+?mwvNe?g$vpnCTGiWOAgOm8Na~$n?kAwx zB35UBas-MfQ+nqB$(ruMXcCaj;|@l1frg5-^O<{u(I!T_faVCjL(DZX`jyd@_u(#g zq1O#a`qvXkdf#P@D%*8HKA|@NNS4wKBvaf9lqaN9n7ac=T1f?(E2OzVGVMYjzu=Yv z$$q{OC|__}fu!ZX07)zLK+@CiS^5)8ookil^ML}w%9TLU$~8dJN;;6V;$vxmrE&MG zi1z}L!wP-EeUXN>YUDl6|Wirb{PL`KsX&1dvA(0m7to#UTYDK-GfSXD53lhNCZ zK4kP2qhA<>l`AV30Lk(6Qsz1`x*2GJ@L)917=fk%$w+1Z$@r}TS}3IDK#K(W3!@`I z{lT>{zGKvDvr6G*v=vB}?Jq#%g_SCnz6&HRf6V9ZlHmJqq|k5y%!j5XS9padyGB@8YBEW!Q3fE^caeiwgHls zhXctt-v%^Nq@BfF9&^i?D+7}C@e z=Ua<_WQtWl(w9e>dj?2a*$X7|JqRT8{Rn8Ou=fp+wDJp(OwnR97sMno%sH4vem5bSXLJRS^u8;Q^u7m6Z)7wANaj0^xk-%fU^E}7M0mBB zxs{B{7(Kw~Wgwa2Z_Mpr^cJIc8GXs0Xxp3+R3!eV3&lvh-7+2ZZ!Xmi`y$ zLBahDv`(O~?YIvdsEyGU=wZQK03_=-4oK>C2a<8_4mAbCEsjP;5btz+~kqql(MdCz}?E5k287=NJeNckc`lKEd7?zrLQWlIx-prv|hyEcIHwTWitvex|`8sKr(Fw zbCrztGJ1#62aIYMeZ#2R-;{s784YAKjM1%(CNi4NXcnWp82K43Vzh$My^J1U^cbV3 z8NI;hWkwZ@-eB}EAXy(rfMk7q#?r4Doo3{yP$lmKB-368B-4&$=`==*7%gK|#E9OW zENf;LbJdLAVe~$uj~Uf7a=xalbODn6@;XMn81-W`h*2V=TNzDeG@VfjqYOrOF$yp$ z1A0`n(}#c_6KEq#-vN?Q`;xgIfF2im;jb(2F9O;ixXwUwCD@bE0M;AEXd2KHB1IN+ z^BApU^dO_ZGJ2EIK}P>!bd=F|Ku?N19Di4yUdZT1M$;JOGFlDvlt}v;b5%gHY=@b< zU5)3IJ^q(iP0z3-q+$o(GcAeFaFi$sbwI`G(4^3sAX8aT}1#Bb8AO zkhHP@NLndmX&IvpthbZ7y^Ibp`hfM00c{rfM($Mkp3mqaMppny53UB1DS9wB5J-A8 z6i9kMmZi4=$rLkLn#m~0=wU{my{W9!GkUyI#p)#>na694>VV|P-vl&Ul<0pza!%>I zOU*bp07+>-ASoRLl;NN?^>83*c?_dTjP77GhtWbtj{%Kxkd>#Hdx_C*mVU_GNuXyO zlpMg@#EGOA=$!^j9{dyEnor7|jDw3$&AqgqDv zc12m8}4EJ9T+FiK#Q%4iiMdcVCa z$3aG?7`fUiDg79U)XQL0#Aq|4Dn_-8BAhC19HT@=8H|b;ZDn+TQ6rlsxrI?U)4BiH%LUIL?3Mg@#EGOA=$!-yW1H+wvz1V*WhRx#SbXg{MmM$Twu zFP_mTM%j#3G1|gtKchNE^fr3wUp%9+jB*&QW3-(S{YZsO+r%jLLdErEl*}l=XdR>N zj1DnsVibE3+hdf>D8OhPqwS0iGdj(vPFaa#l*lN9Q4yofjH(#bGK#o_?J-JZl)PXQqLo>^hgDPh5GEow)(bodfNR8_fR(+nJeQF2;~! z>r2-YwX!1Ond$R~`uU=r|cc{mkJqQ=YuGfHD}z$9r5ov}>Q zm_jf!H0FLVsT#8pOoqn11SVT!=)5OSWA=hspfT@&S*$U1j#QvAC&3`FwrDsoh8-Vf zudjAs8Z;&zOw4e*4!wJP|7bfi4$M8b+L>8k)@sZ=Fi&gDePG_zn9X25)tJ}7e62Bb z*7l3Wd;!LZ>66;3tkWOB6lrA-$Jo4DV>*DLc4)PY>%riZ!Nw$jiPMVmVAm}V&9f%A!n7UaiuauGAO#A|h5tX4B(n*F+j>*W#`@mFW zN*&281@lXmommaW>9sRYgQ?P(zk+$zXV-ZP%vf{-tCo*|c>)U@i>U|m)OM2lQLiY0+X>GF|g`uG;}s-%oH#iH6{zpW{nAe z*`hHkz--l+`@w9}m?yz(*BCnEuh5v+!0gbNYA}@=^FEj=jrknRevSDCOpV6SYr9+y zd)Y4l6Q?m(f{E9d-e714&We~DOfQX@4yLchZYRr9LYBXju>7c90yiz<1 zyn!*Eg}qP;tLMH(saOXhY^%2$&x< z=5sJz3hjA)17?cGIIy};)tG27Yc=LdFqIn96HIuK-SQAHKWofrFk@EQb*6xMXSJP4 z15>LpxnO#)vFj`Zlch1GU>ukTtu^H1VD8qKEnq&zFly<%4rb>QcIKa8F2*UT)JYlX z35-aZWXxs8z~2$*JkAX1B;zOP{>%*NdeNz{p1I$EBdse*<2J?i*j0CfbnUvA_7{Mp!MLlm%H3d37HO2#GfX2)PGg4!U!2~pB z9hi4DW;2+dH0Cuh5ii(te+SG+jj0E-OJjZobN-9=RF}r!t~ZV82If7D84l*S#@r63 z(^k73+R+`QF@<36)fn3AeOY6k0`rN+yZ|QVCA;MvV8(0Azrhr0%yBReXbio>dV|LN z4CYylX@lK`Z5q=a%yE;E?XWwTcCSc(Br^z1zQ)`JX4z{>CuM4yH-HxW95d9OXF#V$ zW9|ZTT4M^pw0~XMp;Y&Sxf{zSYMCE8=K&G@R?W7>6xxE!dmQyn4cykpY@&c2#Kxgu8DpDuim(MDa zfnk-CnHS~Gl*lU$$(k{C)2gKJaVZpYQe#pweR&?vO<10jmXqU4H*E_hGcOoWgjp`} z3$>aKevnr8XO3r1dfq}!XTIMXP+BrC&m8qtV+iw82;;=nGx;alk3VOEKalOS7(y3oI>dAdVfutHBSV;( zAYH_{Gn8+ww}G-{@AEn{{e$cFLaxnjK0&SAylA(pewEyb!{?8Nz%J!Ze03r$deKSGU(JKbh4Hw#ymRkoAT z@q5^OG~SbipPS~xL@)iOI3JGp`7sOQcefSO$L@3=o6~)4PWNfw%yv_kjM3*9HQlwvRsrIXQ` z^D_|>n=Af2KA7mq%t6)iF@Ag4!f6W_4@>heOvg`;d#oZQ`$pvW(gFy_IPpW}i5^I? zic8CdIY}XNs#8A5&BxCkGch`Mo(D@aQ*3ix>W|Jqe%=5oKpuuc%w4v^dpREXEcbi&XKm7|UCW8;ka6q*%w}bD9y8niC`ZzB#hL z_eu7dz;1!$viNp3*%!)@=FkP+{GqZpTTUeVTBJ$e9fUu+;ZVwI)B#^GJv-4iKQ{?K zs7*ghZ={4!y=`2gKP{`7>f}6&nB$x0(XBOSU@Xt)%?%94RDzn#^!oDy$>hXnjDVhb zXtT7(h8)xKgbEeL@4-raln)n$#C#)B20W3`HBtzhK_Y041#~nT-7Xh}Lr=gc=?{$a z&GY7F;b6Wu&m%L-^X8^!D`Voov?j1+Ea2W_0y>$FQyFbko%7f%If0id;1uicqZK22SUg*iU z+KSXfZFq+Jasz%}j*%j%q_kX+ zx&+-v63N~Gt!gs7`P90mdNXK^WFC$3c(bzMM}9i?269cAJWwKZtzOWa-=C_hmkX%R##KJp8061L4Ur_KgyedxmO)c$ekpdXx7{&$qCjR zQA7(gDXmpb&GvY5kf~iyaam~Cd1)DDl*}WV7@8RxDfRRmbyDStzNM>KL{3^hUF}Rl zt>;rE(6MP`STGRq<+8-)i8*S`v3D>dMI4&z1TovFzDFauFK+~HB*;%n6V<5>O+#iF z%u(CyzVaw2hEItx?9Z1-tiL71*pD$u;&fkbrZ;OuPFfcF4O;R1vA!&<%w@IWSWZtg z_hfl9MMsnau*ppH;6}|1F^i1O^#-QO3-`EH6P;8YjLw(HtR8tVDccv!$q;%pF-X$Z zvXgyTSh$a{wJ;1|QfoAP7NdteG+RH5tq?Lb&IjLUoUj;g?j*6aXGR`kfRT;V><)aa zdIbEQKU_3!BL&Udqwwf_iByx9lb(`d{HOU*9S+a&r1^)XrO(ci=aDI5z{A`$Uqljj zf-n{m8nSyQ8YvJc$b27*Cn$J28N;+JM|vdEj!`7h$tI>@M8UySpFbxf*{Av@7;~Nw zi*XS%If>C_L2-G|k8UJej~ITFeOOo+DFWNpm!@pgBrNR7s5w%50u!+tgN0#QPLQT0 zZgQvz%w1MvOvbP)ouXz)jfA>`dx2QPPz!)j{fOk_;hPX8dTA5f=U*uM58Yr)sK}jYkb}L~BPXGX|Q89#|D44f3-OJcyWE-gzO`R&sC~Ixo$eLygVGaZt=* zs`)Vum9}M-X$U0E%yYz=3~M(@Hyh%b@ycyY*(yLY?a4TyK$$dUTNp$$4av{Os@!ap zJue$=<|G(QWXM!N%qI$J!-f!sGUiCFl8EVtLL{t+C91S7ptNl+T-7NB4U!}MX?fY+ z^!!Aux#+AG)fmj9X*179XR+c?jI^_YnVBBH9GEB}^*LJXh*m(eQ;^m=W>I9E6r1GB z$r+uCO9o;|4K-RG4HNco;P(4{{^7X9FbiW4Wa(IQ=2*vQW7dH!h|NejnjuOSj}BwA zD;3;yvTv!#L7NKIoTG8wn`z5hs#15dRB3t|iuI3N*|)sMgqce0R^+8&!4epa)y)EH z`Z7{dQi2)Yc^Te5fZjQIDLBu|@y(~m%EOc_Pau6hy0>|lo}J-^@V1}_gNesadmyyM zG{Wzh8}#I+FHGngDm2&2BoccUaN9_s9-rvROv8rI2&~|7qLYh_51sPoWaXH%VpdM( z{6s8u{XVSeFl1s`MO3of9HEUXI;3l}s*=UAP}QbaqR~u}{0N(WAy0-xqp?Zb%!+mA z2r45S)KuiWt5N3Mt8r)$GNEXhV&V-UcbP6kLa-0M%L z!IiMs^n|8NuAE2;=4VTWtnfyUKS!}1p{Nt1kema4f*&=h2viDHRvPUDo$ z8ZP`fX0i~S$+>xc-(6x;&WyC2w9SKCeGBsgIN`DC0s-be&2`^wtf0g+7D>6;nq?Cj zMQ7)dw+M2U>KOZ5Vo$})oa@|7Fx>CKDZjm$Yqf3le@f4OHXB+@nKpcxT#KWaW=k8# zltdfOOtSfCY0}d7kTJ}Z>Vp`ObXJM=P5?_a1f2#dGvpYkX`{wJFAe(uq$#?tFCE*K zbjCper6$ZvAHif{v{#h^eT0D1+KSFxvuajNf#zOz1ZEU3=N7Z7Z2Zs#9+RZ`#y$#Z z(~TA(ZDf+;jO<3#p>R5Z?R(m>_fw)CzMd}g?}i(D-`KbBjs0&N;Bxg6ocz3@SFe8k z`ng=aZ|ZeZ@7^RxJ$EeKc#ppe-o;%M;$l{WqXz|AUFyJhEN+aYC!w}Xp*t<`n@G6R z!e#VIwcn>fd;<9PH#m$RUY2@WkS4)Mt+d~(L3*w$=~MqJAU)gt8YEr&jl-CRR~Fv0 zN80NOF2P7j=-F3Kn}EZ*>!gm7BpAICdfsrOIuzdp-EgOA_i)3tSL%)t{`E?jT=IEg zWBXEfY)N8VRH-`#U(Ql@6uu%#-OiGTxH?My)*hwjEKP_nt_<7+VW|NSLm(l(w4eqC ziz|ayRwE@Psg8&{*Kinh_u;a61rhb!w}3C`lm zrDFw(Dz020y>%9zasda7R4tJ>Xk27lG=M)_4MziOajRJ%{pS3Nz6S?WGL`(Pq^r{iFW`hI|6b+ zDGm~VqKoKRIpUN03$Fiw-O$i`zB zSb7a*lO&s8{D9p{E*6>N7!JjE-Cc6f;XWmd_hKVJmXRb>D^v#$*c}j#RJ%_qKaIju zX98DKVhl0IN{y0ty6&=$$aeIfcRAcAh4~0l?m{pL!xk(?D0Ow*ECKqlO5hX;oSeWs zwh~mk#TY0uLN8J2(2xCX?xVmcp{au z6Z32W79-ST3gR&#L51E*b>?8nZW6DJF()Y{e9111RYKB2V9pn2h(&C=(zv{X9E-pc zXqaJsIgj#bq^bR1xa(7nlEZ;G6*R*-QRan>5hd=Eg-cEv!7&(iO6eEN!;Ro2Wb&BJ zLoY-Wx^a>={fD zQK*5gt*i;QQtd>|$+G6y*ezhqpe{fOWl&F;qw!kGn&Ow>9I$(F56VHKqKkJU9D

LAr$PLoZwp97_$XJ6|%KR}K2W>WX zV5w`Cbu~&T%Nk~uwSYXL1;!*1NV6?RLdtD93burhKuaz34l4s%*~$#)VRn&<>n6Hb zyb^%AjG1ZlefO$BQdcN*AEXw9_ITwAeQ1mfNQKZLu(WFnaS@tb_8OB!YD7a7@Q9WYawRAQe ziB4YTK4ALX<$m`0fZaI*C8JeeL%&it1XLL5H3?{K*l-2Brgu5i{T(0dlu8HTAQC<) zgw|5d%znR_{S+%?`-e=#K~UxrLD|P3mtd)T|By5ikoVOEB%pOw!wlpwj&c|*vqv}Q z!c~P@uWHdcB3&h|(`aT{hwT)yU4z_Ew9z)(m8R{V;gea}m1thlZ5o(pvDN^?l|xQL zB`6J(fEI3KNR6)a@&GhfcP(-=5~z99iosCmbVP#E$ z6JI*HNkmVbRVvpmry0cV+C(*NG(@S=#G*7-h^d@pJlGLQokf%J7G(#+?0J$ zBD?)>q0!Jcq|ou8RiWP|73sRHc+K_rR!u)b=>{vWXTCsnAYBz+ zWtOsk;S#4=zGwCFRUn;KKKr@1sM?F5AxFfgw0K>^6wxke zRfIB#Y~=c;v2aPF5fp9Dp3VDElwA}Pb|ZOb_S7q|3dG1`=7FYxqQ^m5jR~rCTJ=^( zd0Op~UQwadTS&W~&Up`2l}5j|pjwd7-ylOGT2MFEmo1fMUCkZ1j#n}|FxQ+je?n-ZW{5l3JBDn`*)&x#ECimwRJ*Hsnk>FctJD*C#(;uL*F zRdj@vhRBKpeBCKGh~lXmI#DfDT(hU0!jeN2x8eLvm8d(ar@mA0?gctPWqk#HhspQC zb3@{Qc-2f2HdR54L1WjaVUB}16QuF6u{0q8wSe_tV_{`qSv_J+o3NQ0pMbOlMonPT zex#>H@T#z+8cKB}*%e+!k_P>4S`BY41v;X?>d3Vwsv9*N#rgL#;-n1y{EAH#NRL65 z8iP?z2SCb<5TZaIs=ADM7O5lR)=^+0B&G-D>tgV1CI#>m9>cN)kg^d0T&tRv*%C>B zHi7Z0u+l*Z&=c8t;Z5@uG`tcvmN(KESGXj~2=pt%reE>NpK)p3O(*iDSQ7Knr zTMdmMy6!!UA9DQq3wTwAeVc_-E>--+<>EL7$6^-G5y!!(x^*gfLr}C46j`Mi02{JZ zinumCjl3(-uu9rhQS*u$3$c0Xg|p)(j012$G?@3U5za-`^<(Ros*@_I1=kPQ7a2|! zowjvhNP{zFvvJ}~+KK(ONF&f5J8Ss5949W37{}45$|*z*Jqb}@8n9OuRZhWbxSZOP z+2o2ao}fr#?=1=KOB%*37&r%7)dqT(Y`Qp%Qim}@8dFUrGS-^Ik+Y6|@>2C0b90Ht zWz!Prs&ZVYqWChxhUUl(N-SQwQM|CLL|we8I)Q2#KETk0Vm)*oSTr^&1X`!;V}*?| zqJ@>XPlGR~R)>v*5-c;_PRk{ECOovX9St?G;;sB1rX2^%))wHK4BDD5D&gV~&4!D` z7)JvXjd8Dtwk0w^YFaRcQ|y5f9F=tu(XSpv)UZi}Gf{I1I>FQn3sNnRo>Gdjln?-6 z%n_nQ=d`9Jxvi<@0;DLcjH6*A8XKAj9fc~oXdlX@nqe}6RkoI@07c(b6Xp=R9cGCK zA{9#99Xh3xPZoYvfKWuywg9#Jjk1x5wa9fCo#a%VN1;H4U9j|7J&WTlXYs+WXUXD# zEsOm>sVvSnvxr>!tg7ir%NuKjeXRJ8RTp=M-%XUZxEBxvKz)IJ0f(4GQgKU)`-7=2 z9*oa3HomYjqNF%Mh!XMXz{ZVAQdsFMDIO(6WAPcTiK0r1lY}T4pOKoVeM#{&A)0~D zb2U-NlHyb$%D`ugCUTV&XA4mdJ}=Qkm@e{!D1gsvG*N6x@d6=QjL#c1QCx|;pxRwD zNF(D*+^eeHt4C;L_Y(KoYWKP^8riGFy}sJLVUkAnEpczGc5j}pk^M{DTdLh#(@c_T zzOXW;#J#QBy?u^G#+JA%s@*#l*~k)iWwpDiz{XIGxc67P58R`XSf3um{$H6!qW%wK zLy_9&ItbJP01FnZF8I4p@Ce2@7{ZiPc5eX+P&&C$ z?T3{_$!Sc88w+i7U;Hw ztPGB=^kklT8(jpMBjk#~c?4E0ShakMEkfyUFq+mdIKr|CJ(jivgy8z%`B1Y2CY=_< zkX^UWaL}HzP@H8lVGTGb7fg0^F)schDfGheDaYN(kd`GmXw`tx8T(Pk?4vpM7k)!t zgN=t>H4(HgP;(AG>Q*H=Xwp2JQB%$I!4X}&0XawSocwL{PWN{u?{(c%f%-5W{qbkA z3WH(MuR`{!`#Zwi zfa)LtmkV`f#4?x86jr)QcG;*^PIH9sH1B1a!s-gB&1SB`=^$#@SYAbA{T=2chqLo2 zBYM?+Bv=wP0}9b=mgB(mr*KIuw#$WaT(m2!%z;mExo8ViAaeve=(53%AgyC5ACdGj z>Wc}yIA}jBjXj{BT3qam+(bD)xFx zEO6cN^`tLcqn$Do>uNq|IZ(FB7n-YNvi5w?te!ZqLV>P3AQRaR=%D3xpb}A2c>MsT zpsojZoeJ|-Ui{&hY*g~5(-=BoCRPB>P;SG?w3J%{YBx%35FByG9BHr40B{xQIMl>E_~XtzwlGXsu&EQjqjX7wUaWs z%V{zB7JlL=`G*w3ZB2^Z3QZcWNyAx629w~4^sdqJE?y05*yd=OU6~U};So2yM44k$ z^wQ7iBIS~%=%wb=`!CV?SzC0LlhxS!5miq^S;c=b4P)>>S(4Nd#izlV&S!XLmLf#1 zeOatHLqtDw93(X|(o7BUY2S(nCBnizri9Lm0Afp$=-h|~og}oNlVwS9)R|#cotc9q z>pQ<=|3-l_&y_@@OX#SwmvyckMQKN|>ImLB=|v0VCBCQwD3NLf)b!BQXaJQv$?u?~ zq`wi97|shrc9KJO?6#ax=LdJ8P(#9cg=1_JU(3!J;-I688hQ;0C(vO?1btoB;6kOA zCZsm>7vISZ7?^Q9tpVQPdj`pQ8|IL7M4S^3R(YwjNa4NQ#uWSDv=MtY?>neaplD*B z_^YqaoT=Z7R2bID+34a;2-NZ=F^&Xy+8ZE@Kv#fp0`N@SC`NWp*gSih>@0yDu|JnO z02j@RXy=&@sUf5Sl&zJcP-7&GOf=(A6M%p!rT&0WCU`zh1RH8jZVa80MMGD9v2WpdCfC z-&c7}Yq$j&Q4u$us~P( z8FEc-W?W+>zMUqy6oNU^7}i?&BDPe30tY6RVtx5539k$Sl7mo=^3);^pf>0wi9CE zQo}@qh&t!aU1AkA%pO>*Z<{Esxkdy&EZ2w)9i?R~oXIi&z{Dq11EZsC`z*QHZ$bwXDRPPVH7?dX~iWsCv6sazgV<%-b;MZ#0cU5;=#m2Fb}O}S&=c#-qp7p6P)FCihuK5>8Y1c0zqOm`yy#C^#_03wL# z3lK@*I)F9=?88@%tOPMxuTiEOCjXI=nvdxKWibq*poNM#Cby z(izAX7v9j?X*&Z8js630SKP(q91M$yqq&TikS?~#0qPLVKoC3xXE3`_eKepBaJfsa zFiWxd+!#DTvluGuB-NVGC!4l5Bm0@?h1d>O%dHDxjT~rgxfN2J0iUBdI9h|%7vRF=p;H{;f=J_@kMA{+V74s1A@Y1QjEmN@*(7YkhT(VG{y!iF(R;#%L8qrIIM!v4GLushNFQgBj#}1`XKD11N zE&GUl(l%lruTk#bfYC#pbz>Z){!i;^a}nHp$b2l<8g{JWtkRurp*SVF1{a4`J#u=z zSJ!avG^bY#qw;!Zt0ljX%Yt35-z@oOAFGm&J8Q{%(pc@VCX0=8!~|u=Mcjfy=loG( z>c-BD8W*joJfoMWg{VBMYqSuR=X8zMqY^UR|NN0z&U)G#{~dw(hf2_pd)B}tQDD&8 z(W%5tv=aLcR)guiiDua1$^f=9no4Oi1ha2@^QtF;)j(H~1+O9(6&ksHdZ}B8T(z#z zLgeUX7yESk``gp5|8MB3=TI8*oEw3zZQN9SzI3B$sVz zYK=~v^}Jf}ri-o-;!VgDwCY0@ZEWGR;F6kDWD9Vq2({We`?I|cVqaWLPtJ1MD@Pl$ z-DEO#3hqwm9!WILaBHZLa#9(h7a>j!0%n%c#qVQ;SFKg;9PK({7Ng!NmJT&?TL32p zBH5XPv|~5dOgIcCap98A8mPtNTzmPF!)MS=qgRfAN?Gy8xT)eby4~gPLf*b)hVyh; zQbggWr@J0>>?-`^^sf4_k`GD_fA?ak`!MYdku~(6vf@Ly<3rgkdx(yp;W&t$i~ona z_m7XNxcbNMhK(#3+=xM=MhzM@R8Uk@P}0UWt5Ly5OB59p6;Z3S)Fy(JAHigm?Xnsz zSn7iLr>=8WDOxzbzz?%oN123@adx?T>w6?!rB+DAW5E{$^U4c3x3@+*#;+gL2Mnb5I@ zzLA@J#5X*Sac}-Tqpkd_+VbgsFE&Yx6My4@{hS(?&f zcZ_{ErLsSnrnF=jirH_+zHrEfCk!MX*nCjjUGtrai^ivLc_oBMtjwl)rpkGryA)Z< z+31duQO=A}O7-iet*r!E!zgNrNs#2(n^aY%4_wbMty&lL?dzRI#byXqRJTg1)McKX zD)Sb1iL#XWXYLqwnNvgCpSxq6XS5JV^p&F6DN@D6%nA}sgHcrm!%F^W7{=`<4ulkRZ=N>l1n53w*m%KQneMZN$pqCxz%_1p$vtF0#T<_ z?oTxx7ubz4>zPh;u)7M$Iki~a1WFuAb-;Al5$NhDQXNpo z+$Nm;K>)l>=Rv<}c;|&@_SNseO601lLhrVy~wYqF?ohAS5ECohGV8&CZVp}RKg-0K9${!x&C`!1@~k*K{rDf)6MLV zuXIv0wec*yBhNhWv-dTOj4%X}7In}s?OAJ~X;~SgmzR-38NqVnUwcX?zzNtXCWR~k zgKzc{(>kQ+_#k;h{F}F<=id?fLzEkl!?F>1!j8lL5Skee&Fy(>AzoCS_!>&2dhu{U4ZGpP&NbiA}D@kYnDkM3CZ zp8x59A4jCb=B3n`?lqv*l1rf{M-3EEeCk22P1~u`297R(vy*Db$Y7C zRH|aBt-VrP{n%;|rr}^OwpVZ`FuwWR-G~mXUjq7d0KO7{THZ@@Ga`EZkM9)q(N7OV zP#$Qnedh#vc~GwJq(Cp%)O*ee#O2`JNr8A$5_9hbQWWrvx#`+L7kto?^*NuLBhdP2 zWuzCwgA-uv0bydo)^?Bc(Xhd=yzf*}vQU_6 z;Sl5stVH7O87#)*AgCp0SUASyc)JK~pi1-UFBF_$ zCF8!kQG#%jhI}PzM5YDEq1%zeAyMYgg+Xm6IPn!HZBlvq9i`%?5MW z2*s$q$nY`6{FAWX-^o;}dXI2OrJvik>grUC?o_{`aCh90egO5P&NR zj;(i^!*a02-9P<{VGSXMl(0(}AWfPEH7L0aLKp9P5myCW5#>T#p$iU%VNodMFkot`ExiTC zMu=*U>NvH4=&=l0L#n)k2ccxLZLuoPZ0Lct$V~+FfuVyzI4G|Pq?l2dh+R`}f)p~g zL@angL?9zrQRN3#Rem}h30}k;6oXPd8vG`!L67_{0n9ur(a!rqZ5|Afc65#Kv|{X~ zr(R$KDB=|upu1f(9X+UyesF3V=A2xshL2o6qM~pW6doB-J1ngVf<+~3_0a5`^pfBb@{zd%o(Dde29KAx7dny4$t&Gb6ItDb*S~@ zzlK_O^dB<;LRdhnbphFwPbgm)Mu=S7i9skM`PeP(tzWj+T8=Z?`C%(k1(J{eUO7Bi zj>zH#o24z2Y<9}_@&$?q1g=Jn9~`D@9B<;kD1RVM86&asRx=XI509g6W*PHE=a{BD zXj-qG_At>vDa-UorL+cJH9gl&?-nyllZ_dpP+CQ`Z18|npTaVPWSHjeY{39D`(BL` z7uW*|$b)-NM%Di<75{t@R2(ZsfRw`U4uM2;<3n8m!+3-VA~-0bWJ0GK|`o4J8>VjEFarZQvlAK67pqAGBQ+f>7su^@%#wtfT6E_V)<)AFdv$N)o ziTWnq69*kHL_{E7%2ULAWltq~-;|>Ig*&fZrr~#BM^_+EW=#Y%TqEt`33r;m+G${( zkR;!hXivJM`F^7pHHj{_2QwjJS5ddQqn4PcQLQC2W_L$CkGa_8NR^`PJ13;z+9L?d z?C#rsl^Hyk-|fW!%FvlZ0@$HuqqmRJP9p2=c=q?m!2fiR zAI=GbZOry({N3~LE`b>o4ie^As&7GPO`sPJ_LkVt%5#YRdoRSeB@(1}DA)jaG56x9`#(OSQ?!?X&RlpvZiq&)jy?9j!P z64cQ3T2Lzn)5q@(l6k82zVD84wUHxs*X4QW4n;7{?rE)6mpEgwPnJjtH>!2cNabD= z>#y!u+g-76U68_+bjRv;#Ufe7ia=C?m@r2-rQ~vQ6BKV%RP#4OFCWZcY-4~$w;YIg zjKIDvLE8Umm{d^bq!?|1(T2s*b~QcGC*UuFZa{-L9{Ed-awpElPQ;1w2N{$=b>!5_ zO<<=fDi44V#lQO-UCpv=B#|j57a3%6tcw3Sf!91ZGK(kieD= z6_@eWt9axCsq$@%6BB<7re+7GPoD#(6*i`C0}790WT28sr<$|!E&{=b`$%9-lG$R- zR4F1B7G*MdHIkZo@$Ha$krJ0p- zy}})PbW3iZj;%)JaSX|Cd&ogZOD<)I=)lY_fbq{B0cG^iQdX#ir)I1GPJ!^Mu`_zW z`u>0W8?Hhs0{8Lam-_yH`Wskt09I6%6`XcMv%g^p+ybsRvTWpm^tqEh=YN6VbpR8$ z(LHbm-B%E_&LnsmgV~7XzFe04?L+7I8(8kdR{X@)pdQ575?fCwO21}8yzVsiA3~g&$Hwji zR8MFkpyblnY<_BEOZoXmY!g2>#`f|vFE;Uce6EPi;^)%XYJM(?ZR4jR*2zyvzc#%AuX_SV zt#}Ql)kaQI!;<$9B-#O35pzH0PnMm<8Au3yX2lOyGj}}>J32}sMMKbTto&h4#)vTn z7|odKR6cdnvhT}%mOW!idAT9sUMy6nvMdjeqYAXuGP_-UC6YcYAPq%Zi=6F+^Ch&| zOokPJnGS}n2j9e2lPbnIcZ}U81|^H^$f&HRer1X=%M_yp6YW$n$_ytZsjnra9PhM~ zX3TkHh;bl}mKsKr3+S}$sWXoQWiN@@OnizvhJAKR4%ABLJ=qRe_qw>I*(h z*)vuepTP;17zRiK(zHzRTXB3}iqDYbt%DYSDN}=01IbEMmbq`OM%Xk@u}M}GW-%UB z6|L5^jmmr!-2_s>WlYg$!IY}GH5I}duH!Kh=oQQ*v?I-~$V&GIe?qy{x53P`k3Y)^ zWvsrP#XQiLyz>KeH)5o9SzL90^JZB<0hLdQKlaF+y@zG6JjWaeKL&jdB zVyjZnF&u)HIup^sqpnzr;%p<^@n&JsO)3#~(LoyMKxN47drtCO%BdlsauA0r*$^L< zK$f*#2^fdwU5H?(tji?(C$0VoGHG+Jq7f8S=(eTs5N0vmo!L4O9< zhg+eR(3{-g6Kw!Sb>~TRm4LkXB)VF_B?KD*c#DxqG5dXoU9;p)u- zObn0PrqfqVmiRc~J0-k!hR}p0-tgL42KI&5&M|Oac?2Ir^sj4Z*y zi3r-GekT>v67b0z4^M{Q8$tetRnmRL>Uaqz3z{uV23`yllV1o2tAGNfD%NGW_a5du zTY197DFyt1o`LR_&1}S}JzTc2GQ+s?>@U#ojfJ{^SotQSq!cfFC|+zS(v`O4669^s zExBwnJW$n=%O*oTgX{DF@t@!T?7%_U*Er?@RPpEA&`maUs|_u(p```_Z54nWc-gKs zUV=V`<`&pcp$!$;P%$9-x8!mjs8Un{QZ!NeDSR!tb=uDiyrOVZ+A?^zaw~Xu4Y-B& zTsAsC$MQGaf`+NU`~HnoWur0J^f!E8d;zYwxhz+FUZoGg6(^L95TDKT5%9ioAf?PB zzR$on@iyHf#r=E65^(jC1byP$MsSpXOq-zkDa#dtet^;mxS|XfxRIE7^dYz+A2++v z=Un(CmNLxzT|#t)lM;0q+Nx zC`S-f`9?}&;$rQfFeZqaA(Xqs6z!l$CQj6jVmgk{4hp8eVkvK9DIJy$nMlV+$c)$~ z)A62mOre9eI)+T8V;3AUER^ky8>iEcb99FvRSrLbp25agdO_%HhG$Lh?d~ z2Zs&GX-vF<&?$sCWKdToQuDa3OuSN!XynA{QCpl-X0uD|VK9iwP!Gy(PajZasH)c= zgR1(jl*L!(fxOn7RF=cfxwzIM$Ev-Ys+(42kj8$N+8?es{wz7`njQ!ORN&MsDIv2e zkaqyF(L( zv1DuUu_>m=x~ri{sy+IUr*m5nE-sHgqLr6|sJ z=WI7SQ*jwuyBIkqxJCdj57bP9%n!hr4Eg7wSCj{f&#XzzhFO!MWqnvufy$HF@Y_E| z@}Eocf`OXz>X#J`)Rfb3wgeZ!6k1E5n6+Rk6FpBKS-X<>_njv?&3uDU@Df}Gj=!uOWH+!4BEu|DQr22u+MTOiK z2)&_gw3J7ZT-d_SRxL$CikL3wuO5Ip1D z&7r02nloaUF=RLt`9!y3LxQ|s!NE?>GFS}fc5~j3E#-mk!3w*5kgRBC9Bk9av+gt- zOe^7;6vw6yzS-y~#fx?{?w3ey`1p-GTDOU23Y$^M6QW@1TnB;2rr_E`39G&Q2jVn_ z-sy1^0JGC0=jD_Nd=uug&Q1~o25n0Dm4{Z1Vpuiq`#uz}Hc#C}UolU?YJ^d*zkw@?0@7+EJ|7`^ z;uCr+1J+jvdL^izL2uHn>{E0L2$RnN65}ieDwEcDfQetwt&C+!Mm|ttwGq#Q3{s|? zSq5Bjs@RnL4NR=S)ifHEd5cNxp#+t!hhXAsbSwK1SNxTI2zv@7@@V=f>kq-i33QK^ zpnQVL5QIfcWtY&RJ01Ot>=V%LOXwyE+I@44QE+%uAo*4=IVpEJa_fbO+-5-hP${%g;a*gpG4NP`7qX06x0tpNe77o^+ezgz08P(qMeRs7Fika_~J1Q%K z;tb3SZOrP1HQMUr#D^52kxp9Sutzgs--naVrdRhj)BXodaa5-B+?mq3&rCb^H`DsG zOy|2ZrE{N|cJFVd2c>1oEdUPo(z(w}|GvMO{$Q<}z1))G$dt}~X8P&=W?GV#=^}Tg zbnY|LT$qOUOL`w)<1Q(8emF`h8$tFZz4`l_>Dg(Sas!DYQ`t|luS}2J-%MZlp1Y(= z-I>yv&fdZ(bTDo78IzzTK!)?fBe9^PRn*{dXE5%;a>NvNkCE|%ZbPSMzc;0Nv|jds zL!9^a0Y{<>#H7x6e@C7LP`mBb$%QlAESUwZFUBC;SF56_;|OQEqkYFjBWk(TH8qhv z%N=!{GwME1oo~jdOJ{uhQAD2Q)cNEGz?%aZh)WJee`^@r{Oo==H@|{JhMSkK?BReJ z=i*?v#7JX7DAN4dz`%mg+9vq~x8oC8y9>WD*6gp&$4}@_A3fF*q+b!z;*0{5;D7>t z;b6j0aJOQK$52Eo@fp}6(TMvD zL~-NpGFTW~nGxKLVBnnZ&bpb2_=C20i~vl%C?j<%Q{xyW0&qa~e))9&NIvn$<#@!|!gWt{wZbz{5aqv!X?>>~U z7cm{V#fgPK$Zf6wMECCubUh{>gAc)yxto|?XK+zQa36w^_n8QAepreU`EZedG<(@j<1HybYf)>n2;+tpmfD2*b=ZQI+%F*BWD7tcfKv$^ z0pK(OMF37Ga5R7^1d0KiLEu;bXA&p@a2A0R08AxN3Sb(6Dgfsar~&Y00*e5Ag}^KT z6$IF(0|YJua2|o#0L~|HC4fo-Uj}difjIy!Bycr=iwMjEFoVDn05b{P4&Y(}6#%|U z;5-0T1f~GEguvMVE+ud&fUgml4qz66asbr?ZUb-`finSIPT(5=W)t`#fGY^x3gAit z^8uVl;OhY95cm#&i3CmtP)1+@fO!Ne0bE63B7jK*mI64Lz=Z(j61Wb)IRusiIE6qH zfJX>S1~9?{;F&R&l}q3W0AmQuK#+&Pp#Urbk021Rw z!Gy~R+y&rB0u2DJBycf+D+tsf@@xXT;Bys$Z2)`(9tALxz|R33KwuMqQ3PU0RZidu z0Ou0e2H?vCo&xX{0*?ZyAg~2MfWXfIoJZgh0Ou3f1fY_@PXJs%U@L%&2|NSfLITT? z=|u!)0Qf3_yAU*kz-9n5J*J~M8y!vVs$33G8mMio1;M7}ocp;v*WrqW+*KnH8d@W< z%;`xF9=~|jsH`Q>Z#AnFs7J(aC2b9Z=wDcX#afuMRi#RAl!E= zG&{cDHT)tIjE?L~CYzOE8C+~qF=TMD2O2U)REdA!hw16yFviiV(&FJOc7#U)F@!5M z8;D6rU^^IuzPb5{>Z4~aXbH4_^F#c;{JVo+4D4Fa2u zP>7nrS@s&V761!^g)v}k;y(_?V*9k(D|1l>bpW;_YUJ%Nu z-4NhvPRa% zF{4tYE7zq15x&oCcxUlt$mH?$xWC&s^o zkN@7M5g!gd2IRkwiwP~kEy#18KwAM_E6_GT*9jB@biF{F?add6lfWAUlIf&Ct?;{1 zAWj``5{Prgn+4*85oS^3)(+^K0(AoVx6%e%sjIB~kn0BH4qo2^PbQNU=x}RnVbCN<9bVIFjYR_W+d9mZJI|-o#{US)bCrMry2L zhpbD3pz@=5;lr~_<7(Sl1BO_{{yup9YCz~kNN;D)PcSbv%cTA_)LgYT~Za1+!(4?j38Kl+Cmj_W- zE24wrsi6y&!f@l-Ea1S}CZVtu=6V@HP|u^ykSY^^Wzw_&mhh8^C=ZOkyx_HTh%I5$ zIO=<__(=0FYC$9vi={r^v4%^!pz49HQ0{9T!LwPXqJ6>-&w7)e)cmZOZD=)ylh73) z894Imn+||-=5;E)xD|1{us1#BEO$z@f!-D%g@k>GpUj-*XN%AJOzg-Szb0FJHU_eO7hoFLLU3 zFWIdwZ`YsX1=!q|y7;>j*W$???k9r`T&&Mq@|xxtu?IuFrfQ_W20AP86^t|N>)n5W zboEUIjCHD9Q2@Oxv5rEl=q}VIs|W*DUu3pd+(1rQLxruA0hGFGnU#g&-yw637_kbTG1>-AVd^oU1&MVMD2;U#3aS!??@r)j zNhg9BCKRFqTTOvm0$UlPlCuQsBGp?pM@X&DWN7^=u-TN4r(X z5w6~jYq5E?YqPo$#@*A_Y3d;5td+cDfHAUGFzFV#<3YPcvXZAWzgZ4KS1-=Wws4@% z(4wlWRWx%0)omSfI(&^PgV5s;RuSe>#K@d{L6joFtJo_#rsIa8WOe%7pL0(H86&AZ3>2d3C+PR zxHC%l61zPKi~%7^<)}NkKgR!5@CKCB|6Dtu`2zI=x?Z5BP;eH3r-IjsyEpX9D&@Xb z+^wO=4CS6D?zYg{O69&r+(=)c+*gac7ntS>)Cy>hKy84?YrG2zvL}a@mP`yk%Ul7K zhM#4AfJ(y8GABUA;fI+A;ueLUC3g4~hH5ek+?`S2aP^vSpfNmmRe0uVPY0MIo9KDF zu4WAQt}7n8stHqNbS(ADx~y7km=~qu)DTX|V?`z}30JQR;}YSjS@`8;6&HF#m2<)u z`a+fS!WZU+D(8nU#Wwt#!qsREh&Cf!-5@{}E1Z`!(}kQ*uh;r4azh`_QY&qZD`ZQ| zs>|i!qgtUiA&1O4${(5N01*`fB`A-I6<=Qk6d*I;$zxz2_(OdUOkQ`$^;$*kDZO+O z?jwj-BQZE+7AWnf!}*?r-6ep;oByS5>A-0;|MGW5X`^F0%xLo}pFqrx%G5S_>g70p zgPi={Aj(Z0ijE+$benbLKvl2*-9(L@)1S+%> z7;KXw)=Gu9Y^{tB_VNPk$Xyf}c|*IV1fy8Fn0q#}R<$b=iRzUYh95$GnHgE22SIQN^Hdae#q$+tq`?lT z1dpKAW<}QW`URt4tAK)0IW)r&gO$s=^Q@6|HF#3F`)B~Q^X&B8H^=lDi2u7B@g|LR z2c~^8Kd3W?zr<#6T8{ka(aSox^}0YJh%Q5DL7T>%-LHdS6ZM<5o^AQ zdE$!EVB)HCksh~t_mA*5+>PQVP8EE+fFxK96no^ibAeYV^_**^q8}vDdpvSISW9ps zasnl=pG^iNrk3CoKpa%G1g8R$?kYGP5aqBXSPqCH+7he)#6Gtr$on=%3B>z00FaO{ z%&<*2H{~WQYezhP!H#$y+*;l8lv$T=IWAc4A_i*H2BC$0gwPy!(EOd{EMgoj-`wb2 zB{w?XiUyUC!vleKW{Ne44OTvWAF+z@yU8lY?@z2c{BGt_Vc=0K2ftgm+!y$HK7Y5C z^Y@85D?Emi4ynZ1k?L&_RStS(h-Y4YI(p@@-F&~tzG(ft54BM>@eT0HDLGfejb|CQ z!vf9PeM{A`zQWV4QAcgFUfHf$3|+AoE#tFG7} zxcG*ykv$|@k!;Y@#>Rp5l%Z~y=@HkMRe-<8gD?s$&Z~8|)D^-9|Fw+3ixTXbS9V7l z+2Ppokukw6Mkr?=sMtIaD=lL1&YW6`uzwxGE~c06+;u9kZFB(zk;Z;_N_(I@{&)F> zgR>~%mWrc_3371k)BFr%uu>2 zxMpvv-M5HKhf8aYsBn=I86Tz3v|ys}H(ZQfFdS^hid20URJy+bH=5WU)YcfmbSo+p zO&L_o_{2#CU2ZBQT&R!{k0Og&+MyzZl)oaIaIg{PHBHJcmReuTcnw5dvkS7%u_Wg7aJ6F?^pWt~o9?!{*`@H$f0(jVyW<&mJK8!FWB`AZ-T?{J_a zv}$SUG}W273H76-Mus?Qq9kucp7VWnyHbB<4KnUYJPldIBrlH3Ctq-sac&xYQpSo5 zPc+uZTGI5nO87szgcnmNS+S||UBjBpR=!n;mc4ve;Y@`o7>3-JK#m$sm3=vba#R@& z#?Cqji(Hcq(!)g!a@7m8j#_!j!ED{&N`>XL3_%zAnC8kKkow*T9xqLKK8+!e(v|3* zcQaZy&Vo_SF9QNLDR);&jbW-4UFmeFgHAmq;GRIB;)OSx_{F<0fz1T?Tn3!-P#3=P z9@hr(!uVioIIy9<|Df9u2j9bPM|0XxEbK)0%xSefDQ0DmAbhNp&T)3vKqvF^TG$VK zEp=R+!+%`I#gu`*SJ7W%u<&W^C^$OdNaBggp1tDyC!H6-`I$IJ;LfY$*>L__oX604 z5}X6#JeAHOIR7Kg^XMD{r-$#w^j!xhDiKT;VP6U-G>aIqw_GP{UwY(L3M#`wCF;Fg zx{^T)%*toM!TTt`RIdegDd}VEFH;SVn8Y~>Ij>DdArr#mxCdB0vV~!w^pgfXFd_%q zbMlkdrRzh~r;Jn7pn@hAn-uPpAP&{Prw8>Yc9=`jQ>moigT(jB3rCbR>#c?DxOo6~ z4(ypUPtSVkLdU0{NI~?TVMNdGC{!F#myaro23g~l=OXrfka}hfd7dZo3@#|y%OlSt zL5ZZR6A@fP#C$2kf#J0`Aplg`&%&&|RXp%4jH#JI;0>40a^K&|%xU2?qwcAYSgj!3 z78l@F`Z%)?9Q!#6!8tp}w>TB&i(Cj@DB&={v)zaCQng0w7@A5R^{Bt07C9##!H-fb z>(MIxcXKxnT4pE!!}BJ2$!Uv>pw`3k5ooJ#66>l!R5iGk9)2nxn981nmePhI+%Z`l z51A*eXt?k35QC6}sNXTjuAb~XZ~PNFbUq?+GFb%_SWHDy%cds;us=ArwBo^x+YJqAYllb7WDI6 zk*YWg(-y97!}?zJZr)~!HApDEYCM3Phlk~`Y8b{Ee^o)^Tvl}A9Qi#%eow(K8%`l9 zcU`)QTxC>(QnGFjQZ%>dacPg}5Ior3$AtSM)%{;^M&U&!@SP-=v2kyc+oR!P)=iEUfENM!5@l&ei@X?*vnKBs~^QqpGozh z^4Ql(O}MoQ#2V~~qSUrEoc9p{e;(QNBF-!U)V(I;0n$%Qj={Ua%>&pL&n{gmtNU~r zStM=~2?{_WQI+$)0aql`W>xw4GDsOosgYC08ytFn+Z>pwb^xu5H0GxZsx=UUIVUB_ zLZF?igMNwRGm$`G_DKJ4*zM@L&>KiKK#63W)O{XnP%-jR?!e1!2QtFII1PL6?S?s9jxtzU3Oy|oS|{M@tZta1tJXBveG}!*+DMD_|K^2(kM{?Sz&qx z3S}}c%A-~TZO<^36eCJ(SbD&(d8&Y#iAcEB({~~w;_GeJGVo`8JW%*G(8jg|s|T7D z`U7kv8c+gW%yD2f8yU>j%<{%_(N<{7%Z3x!8 z$kKdCPeHzL;yir5%yyIG-J>fKd8Z?Hm&azz)%%Yjza_92sc?TIYIX|BGHT^adekLP z6JRte6#JGCa)fv^DG$y@^Ti|AN{-ZNu+dJlMxm8WQG&L1w4lM%k~YY_7=Sxs_G1jO z!XAe(cRT_TuHI|9J=v0yhh7ieT&5?V)Ri|P^Zkzp0j)I9drqK# zSy7gRVlKpBu)jXA7sG(P=LCF9zZ=%u_E+{$jVSXS=}}Bj15e*l25E7R1m}Z#_6CgB zA})qA0Tx@-K#h&&x6I!HPssb~nZZ3t@o{SjYMGn-zz-%GS80n3X zd|9{Bl99YBEXBj{$^X=)Iji!OQ-(_LDfg_(F+Mq{b}US#Ja}S(kFgscwkJV`m0qt| z=D|RN6@?d@vD~xt0Tx5{#@IDoMdsSQXF*6-2Ac^Sl3FtryIogDEy@!q>Gt1x`w8FC)m?P~8=(&{mR5^Y4 z_8byRzwqY2!NcdZ<2!U@g}cD79%8!18S?81%$BI zlmfZsLm*iUFg~*wFYU7!zNF)6=K7vWJp+#zOSM!sOAJ*nSaA z=+e{)>R2b(S77~49-w#WA|w_v(6$jIFPu3@HW#|cz@>a1?wKB8)n3T_%BP|SQ{Ge4 zM?%SI)N9rX$Zpy;8uG~2yx!!&>EZT%mQp@OQgiFDOO~ZrDV}62HutsBD{p@mZC28dieFFoNS0Em+#vj9BqETFgvuWUF^K`yT)IX_nM-B}nYbSgw-9esc zWRVHAZ#@H*5*P$#E30TMO$sYHTOlxIrj84}KH)`N+CUBb2Rtu56E`??+r>b-!YR~5 z+!Hnjd%W}nRBD_44vLE!BRBM4b+sO-yUb&VNx|U4Tl~almEChK`pNjaM{q{qZ#WPR z;FJ{{e7TS)({-JYADj79<$47fn;ImBdu1Td$pM8l>u$sVYV0}SVSl?=5ts~A?dYAQ zOYXG8ShSwZ`tDgdvxg5(*ztJLh30H}bSN*)dzOj$OPSQyYweiq;v3bTlaJoya%cK% z#391?5bCodM{Cs)QWA`9GWXGXYQ8LZh=>BW-&9T*h%c_1A)ZI!BI zJ0u4oIO3NjgoC%MTp^+7;WfwQHLBfY;X@e5G^xzj$?^^d<$d`GY#c1G7+rxevi$$5 zFz6MbbPrZ9k6|!(JUGDZ6r*ETKxh-&Qw)K=gS6O71PI8GBDKHI<}M6?H5Xx2p)57n z=iga|jeAy20U-||Op7|paskz1Ut(8%|5#pX-fd{`Lp5P6iqm7T+zlj8k5waPa^lKm zzP})IiAr1a%%Y&{PVL4XAud7~AHm zo3uuV!dpyUm~pkyN+M&=!rhb$ysLx~b1rGW} z^W^wiExSZ?{dIQ6n6D_RFlDSABhl)cJR2DuArZY(Z;GZjUW@G+It3nzQfe)}5Sx)) zGi8<%R~Y(gXDWnoh0sX^%AG-kLr2692Tqj{iWQH(ms(><*+;!S&=ZK{EI4{gS*uiM zrch(`{mW}cl^u>k*NjTeiht#8V4ArS*Fx5zW+5sVrZ?0tYp`n03I`f6)PN4Eoftm= zrkdpOh~{N9)I6fCs$aIss(}VwrK9D>uX&v|Q3OKua-<1m$9W2LT^d>WiHji62rHw# z(ciEP-ID_E`6pOW-(TWyXadgxEUu~V_xl?z#~w}qi}4m{uD{``zb3$K zmRSCXo*u!M1V!;3f&IgIi22#%*^Z!jTvvMn{7;6MgkcoY{Y*!GB7N7{k| zcSK^a1~1tM){}u%nG&wc7E`_OCi#0+{>lo5-MXL@YgRQlsV2eS#wg7w0_}ASh*7u? z5Zw94_d+1c%5lQ3=8&>Q{GeU&b9mx6;Jo0ZjjceXYJ;DGUIf&b_#YLA%=qM9gZeRe z#y2#+q%zTJFNo1zBqZ(*$q<#|nW_`fauVku!_Jh{Xp!mG-lV88!Gj5irD_>< zmEIRD1kM=!6Q4> z!=*vgX$-tV|AzfZ`4)_LYz2B2915&9LeB#YLglExsd}i}hGf$Mjl8>|(V=Qa-lM~b zc3NOH!&f`P$4NL9h5zX`G%OzYKriQrF@B#hzHzt8L)N}9)J7o;H52NWHCi0)2(eG$ z+zu3~a(oF64L*#sTufHo7;0onfmeqbNwX4&1k`v&*~h?MqLiHfH>6#iOHOrQ(V&rp zN0FRJ%V(g?`5SIG&MI-IgH%khroppi+0}x1o!b06JqZ_Rq z7I`UU{9QP9Mr7Rzd@P8_niZfy?eh1(uNgQU^wgX#S(FnjC0I2*EEw39)`hBIIfY+2 zo}@*)(0-x~$}3W-D^sZ}T&YDv;87-L>JrHi%ai`#lPD}*qN*w4r~#Le33ISD@b{I% zpW*mecn=q(7#*q3ATeC~ONFd)>Rvnb3)L3`ieJ8VOk?F{p9a0+hCq-;ReT zBBKsD>Xh2z)(&AAR>a*Mf!#bQ)Pbd)l#a?FdAxH2Qp+KWKlqL~M1EedrA|HZ2|HyQ zSSp>R8zs<>5M1_H27eiSyrbksb=j;;tQ+QS4WYS3`(+;ecgZuMMYRVzrsNNks)On6!CKn?Fe*_Xm+VqV6!Tm0K)II#UbwSN*~$h$E$e z+GcVZ$Yd@?I~9r?C0X3$>l$|=jlEv6c#~SMh`=vAt{bCAJ7*AVw{A&-0?^n1yt1`- z7}2>8XFsA};EZkKy2dZLc>Sp^RkG2CeKC^QK%xONWp4>+9WpHAx&c**V2Rm9XY2r85F{BOL9}G zsiEM>LfW481}wG)yAxnK#Kbt$ijTv)aHyyw!sB?KH5aIr{CI;+OLEaf^f1!os&o-5 zIFH%s+Pw$c2|&7TriGxA0)Rf#-_V9UL>jzhT+pfgVtgLzFcmo|;cSl-8VAnvu)U6h zi~A5k_0&x%R5?U-R@`@{6V(O@&w}d5XG^q7L6cmn$r(W$Q{rcyCxLq5`x?7^PFj4G z&N%0=3Cgf_qAq^`oYmmtDe!yflC|%L7^}G|&qjeExipYA6**it5ltBN!4r_mf&Jas z+dR;wN3y=!(YW{)RmFc2iK+=H&b1w=YO#bnB^KP(YRKu!3TzQQW@Fo=uwlTB_;jSl z57%vWMxnzM#TfoeDI-wpi||%4x*)!GT=NB+3bkgKzOF3&07)?mfzA~#W$MAc4NHj? zB$y4=mUXYJz`>;C^uk2XC0jz$-gfC*fB@SkoUyrtcdFYfD}rAO0`@lc0xMF<0E=I4 zRzb-pp~F;bSA)cgGuB9n)yro-bq%rpFu8H9-*D0272(ay2;3TL$Kim8Z61wL=&Hll zSx;({k&y`<8F2=QY@`8#_W4DFb*DCQV8ytR!bNhiE5DIaWbY-f@4*hLUZF*ud$S7_ zLEQ9>4T6+dC~r8ZfeA2NU_`!SyVMj0a^oFFlRW|>I$-jPmC%F%kG(r;4jrg>vX4|y zE2Zt<$Pdr#!C42JFhngJr&Hx9``5r`hOnu^lJ z)oN;b6>>3^L&toU5G0xfO}i!vp_fvF7MmP@Ll_B3lD}akpdm?7w_M6FkkX}V<^*Vz z|0hIZt(TH6{j0Oj4*tii(SoTJ+&YFR+y;ai&@^3#C^*@|%{izl1lTRYR8v~3D9{OS z`-4Mb4x(cp5+eeR2~HfFbur#H?HE2i$_H&(_G6BbcHYfteF44j<}bX^io58A-IBJf zINKD-h0wXAN-0z~W2F08-)a~mtV;>59Nl-SPt> z2LrUc+>Cjt23ydtB?=`-P5fa#YsFzYRIa*yhbFfof^9lQF1AP8>M7cmP1u^9)T84= z($BxMBAwGkiJKu?szrJ`qB^P}QoUNnqmE4>t4o0!lj$l1 z3qEfC$B5J+TfLdR{_d4G?8aU|!@wW?j(Y)juezo%n&+SG-FT^!&1)@Y9+x0-UYdBMs zI714FI^M>njO8Y~j<<_hRqD9O#?2<2PCuG(J8utlvg?a0Z-6EpSfPt`|EuIiJI?Ca zn1jV ziiH6q8{c@SFm13?B>j)Qj|ZAtTIf1X0iqPlfwpPStM!5UX75$bV@qls&C&F|sVQBy zHa_f7O3za0c%8r}#nL9z{P>CwWqRpal5n7A;*l6qI8`M5K7vRazp0`+M#iK%a%D$W z+F-cw5H=i4#K{7DGv@L1M>mndPCE;`E+}VMA#e$+58J|goMPc>0?jHl5Y3BJe{95w zS-2`5@i7qVRd;G1hZ~VTmQ|asJ%KKB_PH0?VM_e;zDqkCy=g<9j{}^cD z+%rkyV&nOH*gyZC?4R%MSlIp6+;=(_((9d7fsbtJvK9gZU$cvp8*WXV8;ew0ne+Tl zRl5-8Ne8N9XB0L$)5bVR=Ju{p_Z&qOQ#!-*RK2Y1S%r*pwL$dizi;taz{@|Tpj&5EU9OGU> z=y2@$kThz`S+6rs4lPKIzv0h}Y6+jHW9#h@-c_sfo?o}vHf7n!ZLjqM`tLKDGo+La0*w|h7V!Xyh+exRdT!tyXlFs zSz(+W|FK}iEm*nD3L`WnFTQeMw69&9jYOLD2LYp4B;p8S52Ri7bS&(7YZ*?b zd;n&`tW1gd4P*mM$ru2m0-1}>3b!@HD;&Au4NI6KOx57a!JI8=PLZ*%55OS~mn^{y zR}-+?)}ZrWoFDClTwrk?V~#fpWfly-KI51FhQ264Sb)MqZqWB4Hu_%FIINMKICj#p z>~*l=bz#Hqj)lAT%x&vf_&S#?@S-FZqg+0?d7ziX6`(njx~??pYUKpl76)Z~uUeP&@2^OgYX+i^ zq3DXc2zTvK#sYY#E%UVz88t{;Y$&mxgE3X-Ke}7DCH=6yQBE=?`JoXgB0w|MH@nwLCA&H$QXq?pQeK-Y3MOMHfLtZwPw9-EAXKTTxh{5H8?nyoLZ`g z9EA;I@h6c^=NUsnD_NsDH@jMpR8@;4buxKLdeUjGS6md+;+L+$n=^dfB^|HMLDI;e zFWQUkjS$n~XrBTOgJ88-i+0Fr2?FopE(?uKY=tQ*02K59@th$ z8`&CBJ6s52wpRMLht5fF?cg&^sd?JcKm#pTabW!s^9<7qv23K8SoB>|Gc`E9K~azY zKa@>GVoaGFUnTS}(EL_K%>9-vijX{&$*kEWS+O&M+nhb4#9r{j)xk~2nj2N${Vo(ZwM`py>mWm+*$zwBOJdlbZbR3rvV^Jyw#{j;g zGh$qvic!cI$7IBqn2I4%T$~YObSj1j*Z7PW@x3-bN|+0`Shy?r#Z-(^#u%FsV-sRP z=iw+;drSF5(AD*0E_?NIEUKWD4KX{HC0n2H( zNA<{v2m_lVFOy2M_{g1*%EGm+z6&E6e?zWdfUB6UkC`s8?RYC+)Di~$2r1_PwhJLJ zJH#3Q|4G5Pl(|iW9RAxiT;+x1Ipe_V69H^5l~`3U0t8x&BOeYt_Mk!v;CS9R@RCKK z**J>ec)>V|;ds$FO5k|OIG~9^C$C0!RKNJi89?Eb!CR&nXd52pyAcA zS@58@?hcoi%e2bQ0<%ZmcVIq-)8#jY#}q?wSow`p&@0$dpzB6s*#yB=yMN(rW-1eiUj8(;b+z$!B`+Kc(j00g8jQZ*2&?n7L3<+=|9 zW21(W)UkU*`OK%ua!lxWon5Gr$m10%W9)>$<4VjJrdS_QM5jyp!ybuorHY|I?s%Sp zn+BqjRh&rz;5H^T2&}<=J&uAg^pPR|ywOrPZJxX!Iz^>ACwvs4Xd!-(7TEs)!_6Q# zid;C<*< zefl=$87vI`M@BG-wo{M5T-lwP46=jAWdySp?BL@wf{UENXJ-VnHQ1>y$OtZBaK;mk zs3Vlbyo`c;e>z;!EEWxH@)tdz$kho@^ zv=;L(IRRxFA8)M591*GJ((K4QZlBsXH!DJHp2&d+>OjFpEor zCq^kTh6SbX3JXSBsKzJI6R1}3Yn`~f2npszDN#spIosDNM}n1hg6|@M#*1oH@oPp! zDS0NRc9l>@GnID2OHv8_4cF#E>de-u9(D$LcaLKfJjE^u?w*L}h^wf~Q#`_|J)nLj z##k84KrD*Na_BW0UO7p`^a2#)ims1 z`7f|v3hXGDDrO1G(!zqVRnqZ{DOgEaPF0qIT{6t9zh9hLFrYRCD=G63dwRhx`!BGs zlN?cZFfG)~j#5O$c#4hhDRj8B>)SCna}+~ zwH69>J8Ni-h(=nS-#AQ!4`d+B(+IgPR&#M0+FOQ+c8wct+{W3HiSrx7#CgK~4j%KW zpR5I6G)!!$gNzyzzcK7-Wq2t@s9rvnX3(kUa=wvMstSJdVRqd!(->C>%k`NGqr1{t=uCXM)CWHS%2t$=e%(b`^AC3caw4)e~n~kFcjvdBP3df8QIvV$#uZBbB3d1y) z?i^u=fQhj$T-ODOFvOy4tm4t+`$Kj-WmY9?Bnyx}$%2&xw~#Ns4fi~4O2|D=Yj(iY zePgWfJ$&ZH%K5n>b`w9B#y0bFQLLYzirDn`@hOX~;^)j*FF&Wmro{0njRpA`AKSps z5wTW&4vFO<2V4_X#ZPW5jE`+lAF~d15M6{HWv|6~GIe=_Jvn1@$VW+qcFZ!TgvYE; zrD>;xL%L;-N+~A`ScfWAJ2)f5^)6%z&PYFA2UCNRtQFu1tsY3ngh(g-BDX6a#Z0h; zNzpd5-E1mWmw<6ii_=pOCaEi2sbRG3B^}y&op=^igc3vwg7k&?LyoL*Ik-1vzwIOy zUqZcbHvtIQLlf$~aQlO|Aw5G+PlY~ z*m`O&P8_dsI)ZODIBQQy9AG0AE1vMs5ta7c`Ys+sZP>$tBA=2}KE(*70_zmRuJ^c9 z$N_eUSaiL|rh<~%{E4gGWkF$lDyS_L#Jct#p9=bADu~8g?+K}(hf+aefjKo5v?3KW z8DzGUYpWM(1lhyt)$6ej0xC;ayF7|_7RX1XK~$+UzVNCF4KxxEndBZg$9Cy~*O4Ce z5nPG-h;9M`v7y8dq*)g9k~w=-BM@D7=fGzJ$y>tXn3do|1bdl+V#);kQquWq1*B$z z1MicVJsG?uf0f21c#k7qF8orTqQ!|dt>ni81F0?CSZ^@_FK-$cz{XT{?jq?iNE5*qAKy?AkL+-_AqO^SPaphk$*HuQRQ zAeN1Z#qbM z&u01bGBmmdn1EB;!O9^^<|367$f1fLZMLc6Y-D_$sP#Y z+WZMTucfp(FM-skQN=#EM2K4u8Ci*DM+1?I95yaBxltHiQ88>{d>f@#B1H^-Gb30! zAQRk^5xl{P{L_qJHclxHkspvuH_UBz1{Y)mZ*c~X&j{Y?44#+~yv-S0mJv+Bu}S-C zMlhwr4!$-cxXBs3BqLZoQmI%O+QPK`zY?M?27!@TwknH0q0&O z|CvHwhz(+(NRXdKZQCbxhxX@i70{BMFO~VO-t??9ZBi1%W#_^ zm6ldeEo$^;I4m0HC6HrET#l!@6eqW1*eMe&mt~I%5}ks5sRqUhj-4OzGr&mjRt-xP zT3O^upubUQZ_sG%CXiqP-d7!LtPgXIwimQx*A z-lm~Yj}#_5uv}te`7O+RQC2A%(T6Cdy*WXYt7DFLns9}NyFu(-SYX2ZRNK2~=~6ba z0-ZvxF;JGSeHpjLkPft>Dn)WuCoY7yEC3-8OD1I}pVm zMNGE?9XZTg((OPj12lw^!C}~eiiercI*14cD9Si!+ku!He4UoX@xw&;?+k>r0}&w? zjx+2)#}5hKYM{ z-bShE*tGU#_B>;lS*4pjSq3o0i2NXC&$Isv?CXj}aGWAyjL-XOpHrPYhe4Xeir-P} zbHi(=!YwK}5@8VMYuCPlAG)0SKi@aL?srZ$^FZTn+E44$5G~{T2HKfoi zwdyIp+ z{Tz%OC8Pw7tBr$NZ;Nrzp2~s(E?MZ)h)GKg<4PQ~8^Np3cnHoj;*{9A zy-;?NkwhjrGnj*Zp@9PI!Tw*fs|m&+45gH9x{<_k7pTTHi#rAg5va1hxdv{9T$vEdsGBido}g;7~x9kr#7CFVahE?4`m)vq)H zV>X7x;To1I(6dlJy-X8r2RR^2TO8I==jbP#vs)Y(Unk0HaZvcwKz)g$O_t-8chymF zd!k_ApyB~Uaq0x$#!iy~ga0=pxXT&boDod!+Q>UHf+-eua55vf#~Ez>J)N{(XYja; zVAg+>-awqVyuJ`I|H>Y*=Uga5#1)x&}QbOdI}ok|Gp%wZfit?lA*e{#eAb$I}=O z(9Z|#Y3SYD1R;hV!mh>1!X!h-Awd8xo~3d}2h>;kLBR7IXl z`effj`uO?XVWK|WiCXh=3jFjuPERS*XIRwk!y!By_A?|$E~oB$rJegfhLg{kf-`-F zm8A-K3~4wB&&oi^8J5j-PQ|4m>{g;GBi_aDn})#GKhk7}dz^=pF`}iaTGxm8jbr;k z7s*afztyL@2=)9`sFCd~i7R9%6NWq=PG>`P2zl-A8S-R8bQJZGH2eZ-@VE|$!++ii z#K{1%D~l7T^#9E3WRDkBV@c(|(D z{1?L$-q98wLq$xRxAeH`q-wspS`z2vZ(cd&klVx)3 z9~-x*KvNex#ldiW84Ndd@u(2is&EesT)lDyjMG3@3AX9|w(7*rjQuU;o89hGvX}W> zrCj1DWym1?zbR#@Dy6BZj8XFuc6LLLP5<$(E^AVaO(~-S@kU1gQnW_A;7ZmVFu zn}{23;`r;w?(|YD)V1QT4`=T3@rK9LeC$Iw*s^ZLvq|$0L41q^SL0@^Er(jx*265T zs}N)UBM={dokv<$Q;}tDILflNAC2!ZmepL0cVNa_*7{@NcO2rw)|`KWW$ndZK`HXa zk*mTl;57V6mNjppWi?E)tW785cKcH-Yce{cS?E8OK;=(`_AG`j&WFaF2n|;Or8Ivk z;!i{Tvn^})IhN%u10DD){gP$PDM#;qF2cTy;lWoBUSV0i0mM1qvPvo~tNa4U_=Sj% zzlk&8HxqeWjJ&>TSyQUukH6AOQTDGPpIP8nHNKaj{FhtS=Gm6D>k5?RO2osXQH67n z_G-kv2IZKCa$F0#u0y=*!GrnW*A14nbOFk9BXHgXJU4@`uY-rT;O|z@wh;XI254A> z{Ttr`p4&kGw}GPu;kDrX?I`zRlmmb9CCKkP$nQ?XTMFJT1Fq$uX9dbv2cF&q`syg;r*cR0p$NZ@O}-_uSNKSsN?U0 zzI7<)4}klBP`~(Fy56$ZJdASv5Ow+^%WB_%`!pT_?u{t_Ce+!F!Ka@f?5E(-W`sQo z+>as8Ey(9*h>yS3KS$Xf2i;pi-!I_*B?Ld9)gls(zx|%Jk`vv6H0v@-b94~=yF9Yu@z=c2GZxN2aHLrpvze63h z;kt#_ENk2EQBQwBJ?)13j|hJqa`Pwfr5&_)!2i#v`#r$biF9wE?%qVbyam2=LEhg6 z-gn{O4Sat=y7!RoedH4dul@=dOM;I*pz&{@@dLE0zoX6dBF%@O7k~5qfjmC~zCM)s zpJ*%p0?v=Y?|#d&J_TL)YyUUu?mwto{N)Xx+|bl>JRYkKn|`)odrytmV{Oj$Si7*R zqIaan@?u$M@@NnC3wf-fJdf3lzujXzme238rssRCi3fYE3cS-Z=Mdn){C*QA@2!}# zcOT}lHWb4DaF4a<2!!G4g{egz>!zbT)|#Uc?-;}@MjqomR{n9w1AWFkbYqR|iO^5Q zOYxoHvD&}jvHH;U6ixD2GfwtcOHc7w^CyGOQ$1G0X&!6c=^kqf<~ChtfX1_cXR61l zoaV7^J=b$GdL&B5;4nV{I=-T-bQLU-4LZ6&|Y@fBgZJ<9v@*RSBFI zfbI(s?;?-YhR&dCCTP4EajSs)63~S|-`6}==`7GwjeIWiSgWzEWy@^v3`3LtD?L`p z9MCWqVOJy1YrxleD95!PYwvX)t9U;6bpz;GfOIz^zng&TX5{^Kl<5}m=2nz@A>#jk z?0pGfWL1^+>jbn_Py|$5MxPFijU-KNsU!_5**YD1Nl2xeuxO~|B`G_pidB{F1Obsn zTg7ceMaNMbw|2t?kaood6_-)R4aPx59kulrbw(VS8I}LL%Q^4eSMOD-I!P}ifppG$ z=idA7J@?#m&pr3ta|W<(2*RHYlz7+L+8ECl|{qSic@o{Ca%%4X6`-*S-mLz5(UF8GZW}^ua$O?OWGazx^kC z=k0iZBhtPD-}qB@-G_F(4|RP%%KZRn^g;B`hd_^;K&ua=a-Y{^Mi^2LJPH8fyH=GH|zMlDV=m3Io2Ak5&5Q|RAn?{-RMk#}8w!@4|Y)5w`p zaXdfeP@$+pkN&2{lyoSs3&Gx@1}W!}!0>nJDUEr;5uzt)!uX$;Y+RLsnlD+Q-qwx^3Zw^dXQr*o#9 zblI^p&SZLb9?j7-zX_N@?Dn zDdy2BB?qq^^rdKfrc~VJ6sT0{m9oqjn9`!Oo_5zrzAm>x{*O9rFEXLVi?isLe8Jyi zs-W6wtG+ARH|)G{)+txO2Ru-UH zFiaraoPv~24SosZjI$Qf)951AT^R@R!*-@;Aa9t(J!xxmidjD zcp!P0KCwu=LlVR!Ph^!oid~|SSWWt*HuZpi`Y{fN(zzfW5?teUs$z--`n}#xBpy#k zB5k6!@mQRgT~?m@@It3l^i~lZE_vO@=4W6iX)bTYkRv8PL&D(kR^a`uk>kK^Uc1SF zalwFzKnA3`cZ^3IQQ4?b^GKwnD?9B7dK#4#LvIm7GGPo!B~^GpwJkg(lje}r(uhmY zBNn~u4#^l%q*IK@Sm=l(dc+e^bSL^U8Bu&E9`MuBHI9jCVhWS*P%3WsKvl(*J>`^` z=VDrJHB6(4*?i6cL->2QCbjBdWG$jefQ3^l#sVyEP%9EjEmyv0BT+efMB{A+2eovk zD;2CH#vS|I;=HVbpj1+@e!HfWzrl(jY7WjQRWQy1wyh?ACo|E6>cKWSMiq?y%;YCB zPQjij$7j+x%*~Di?S0SUIsS<4&4qbCnH+DI^f4#}T6LFZ(U)7X=qThypn)%*=S?|w z$T&SrE`)PB$%R};ROw0?;vn_6rF+MwO=T}Khy$&#Pyr2zgQz>)g4I3NXPgct29l9BQ-1b9$n7fHU0Wg@89^I} zOLr1%SY{q3{t1(ma-xj{2_oX3HYXzGP=^yS<)k~4*y~5T2S;tpJT|NtwpON3uM$bg z#qp6b*y_-O&1pn)5zVY?Jkxk?429p z_VDa<21YWka(mEb0d#9joGKounM;f|v=8bRVtVP- zff`ZJbpzL5EdbZd*mt8_| zSCM6ht+%0lxj-A+JCdDAr#;f%)}G+@a!(S^%0-Yp(wC~52^vWCNONi`JEg^Krn;K#|R6}G=sHqUv?tIU_3fXNVxwx@=)6(Cyt#7ES*N)pGJBGUl ztEBM~ODQrZ9Eo#0b`I3+P9{Jt2P7Y0MJ2YKgl-r>qoAb{^PFK6MYXaVuXJUosc zkJw^R);(1z&X7V|CBYi*;Gni1#%>K)c1iXn+M;?LWUxMDpHqPGEi3hXuhsdG?O_}W z)plX}@Omijvo&o_Pp9ovwphYKD1hl3w4u<eX!*xQFpU}*B~*aVw7-}^D8+MZ<9&XPV`s<~iYxbEy9;n$h+hJ!>blF$wkRrKfDFNM3O z&m0kIm2taUD@Y+C53U^5dV;y-P(O{#RV!?ERWuq}aYQ1S*AZ8~lu2{xDrf{R^Ym0P zXcQQJ!)(EAd=ylzC0JxjyPWLd1^iz!Z4oJpuv#((am&EAp{|}0yL)R_&lcu=@(t3y zJ#781DSYd9R|sQfcQN2PZJ3UdQpbq~IJ8i!lG<-HmcXv7=ci?0`?)*B_CcRoD5d1i zkT|z<2sRu^tA~ZoC(aIbJAvn#L}ygZHIQJQ=0;iuW}Jz%J=EXY8Hq`?-Y_;D{Z8zX z>1+ECCv%D>(P-AR4Qwq=P9) zsV%CU`#2kjdMi>Gz~7m#Qg9?(_@~9vT}R zO}Rb=v<@Mprzk4Gx8`07pBI;2+DTUvttFIRE89jv^y)~M3o;+Ql!`ObXQ$3MI+Yxf zH*R~Og?oN#w)ZgEXclk9A|=uA%w&bXUKQBe?5kGuD-uW|1&H8|jM) z@uTKE*_y?xl(ns=tRUAvyKxp*r*<8G>*b^>c@+ucBSn+MVW3F^@`-4&7_)jcpR`r$ zL|LH{b(OMd#HWzEn37B224|-Z@x-;DDYbgNzL5E?hT!q@OWc3X1hTpYZI)SND_ajS z!NEBf9XxUTw221LMyk@OO#?d>*QmKnn{yVoiVu@7z9qbx)oPwI&_dWl#)W87haZhz zUvxw|OdHp>uHK%mkqhnArk%!kQk3bMnwf+}D7B1J*7ER7y|WVW4B2YqQS(qF^u@XH ze97saN?+=DZDI%KVAPOtwEn3`3P0Ff>Y1<2nJJueTpfq^rlLB2fxFh4AD>E>Cy8++ z&jifWrm@1*O6oa>q%FHVAj}P&HgU8&S;M|d{>6zz)bRR8-|G5@oX68PtOmPUw3ez` z&(x{a2hQRurh4X(fl0JSb-lVgw>jQGo9(V#dIq5Zs=Bb@@FiLps;>5`my#8fc4_iK z1C-L-t____OE=!PB*9R{>*4^Grjv}}1wX2Zd;tgeQo?wiN>^q}1sSx+jj5m~mV@9U zmvl-PP-AHi&&5|8dc7PIYWb#S(inF-=#6T)J4VjW=j|Sh_A;DO&10*^mK9sSGdO6i zH*Q5d2nqp$7zTh50z^nFnlpp>gd1DGAml6y>*V1(U_=2LLx?C6A~!&j9n$k!2oMid zm_gR}4ipe%YYE)OOc`2pQ>}h-9sImeLq%o%9g2pcThuYnE^J36v7o)rrSbrvRV?p8 zviE`%pR(rzPq@2tUM8oa$VA&rhn1G?BB~bxm)XOJN>`l97j{V(?bPfHP9rL>hQLAM zYgH~jg(kEK%)5@-dyaG(=H!T5{}du^VLMBl8!(6S@~FXwonyl_9imwRa!N|Q zsOhEDvi*WBgLc=z@TRTu49e0F$S3pk{HI2wj#9?bj7BuvNfbCQql9Uh?@j`S-JQ;9 zaVablQH+j#Aj>h&BrQy*cv9tC=#pnSf;dXd1~OzwMjWCP{EsQX4Gkrx z12r#n@U)nJVsd}^1Nu4tL%dJ@R3(Wp=`7x0w;=VS%% zAo_vf1=uo_z(#QiaUR7K5w!Iu=f;L&spwhLzm}+4XsXtFs3%_##h@~KHG~=hoyG_0 zM)a&S1oZn*zLYLtoj8ZkLn_jiPueYk=0j7JsWsNKde9wB1^CxUddz@x+-^4=NJ53J z=L|+pA05(f(qc2smW&P>P&Av&8~J-XfH78j(~4HyH!1 z;nV4+7NR67jgw^@XaO`@z^#;N}LN*z&W$kM3`@EbqefVKgmM#g`ON~(pxGoktOcE!6G_`|^5M4;^H$86@U6PSA?A_4~Ng0=DaXx^xM-~qS#aeS> zTvo07tGC|jRC#&6p)mrb&e#~h7)ki#$a1!p28uZ;*JCp^mV{M11WU3{OEk(R%#pH6 zBiEk9G|JLBAEm#n(#WL|)E9l?M#bSJ4X@?AbfG&A!qx4LChKZ9PAOEkTUt^M#){xSDpo}SpA{igq}Dfg#9}dN zCqbl0>R$P`<-D%#-CcI?@Zk17yKA_otGCZScklukylL^BT;Ehex>RWALRvODe-KYc zV>D~(aj$rqB74|FxIII(b1Alp0;WN4wL=YjG{1Aqji~Q@h_BA)C5F2;iAu}ZzzB!E zxFx&KAPQ25vB?8VF=kBzpI$?879NYz>>p~zqjocI#$v`wO30r~+8)f5^SM0k#n5g? zZr?#&-iC{EmYYw5m4F7kY^VUg3Cvwh1n7jdcbuzehm%9zfxR&862Y{SyN3rO&>D(8 zf0#8W&m0holFi4Y-!S}6O7`aYTq*654{E6K@xXemhe4B_W{Nr%U8X9zl+lx2I#B!x zb0);vVz{qsD@_bT!-E@^G3_=wt+`z=U5VpA+`Ztuiphp*M>_BMM%$giEA@lF@t}m{xd98bC%L(x9_qZm+2w zSFhY8l@_;WMdPMTuj)wmtD3KNuFMI`FNfO}lEV)%I+<=uq3RFIVe+}F*8kYus)5ik zeAS+~!GX3X#Dx%Yf1*{Nh;rBa3#^>$*mq(RmZ8NvvpGM*pQ zb9ZrSR>o+oc3(U6^UaZ>>rot&sN;)cGK_6193n5|=E=uGdM@i@FNdCBhu37m z23>IFQB*lY26_E8?3Qu_E!OKK7mqVcg>qj9K9a_aLwuwn$KVJ>ae^*~l0F&aZO|~S z8ek~pG+9$`rq#rPXQEw(GW`eToE#K@%HuysJQc~BvC@e~LvTircd2C^-#uCesiYI_ zL0L`x)_21Qri_Cg8(4#*&}S?RdWkIC!k3D$Xn&<8H*c*x=v{jWzS~4G7gDQtc zI0f+10{1ZUc*DUJkJ=PrUP^RCYBAA@8gH2pKI-hOW}}7)bJ&G;O_3DDMpfg?rH|w# z<{{8W`as!ThTt}o$wm639?rp5dpFy)L-SaR`o>yW=}0AY=b=^sw5)E>9bR*h-`~F` zd5)BM4f03oj5(g#6^hwIG*aq)#GbeDh23;OTUjulqVBQ&EBfLuc&P@C?PoY)-h4r)jhVPH?@p7>1kWunz%wZ!Igm=|2Ib5p{N3yWGAPKnfz3~ zGH;J2TjL!&tC*r;UCCsMnnUFhBeB%bSD)- zp5QbHws zcdw7+C!CTD(SS=7#G$B=a1AWPXufB5Q&B5~h(gba<1PB6i}X^H!7PGzZpaGRuzi;% zb1I-7`z}ZJS>P}o(JR-f*S@AJZlq;oPre|}wjlD86j@6-^{MHe+O>>?2~Zbnhkqct zP<+B;kMO)#vA#j0-~~ytnmPRizO?j}~EZcIGpswA_|s z-`Mrt+hp*QrR1QRy20U9quJ)o``8&@?3kTS0UN+R7h)lJ49iKw(z-TB@x(;7Y}$sR zI6|C&cav+g1Gh8Lrs5vpDgkqDAMG0)<=sZL_)NA2tUViUX#;xVq2Ps3Z+cgcj<&1Y zsS^p`{kEg|ba7kWKO3>qL$eSRh6Wc{nj2z%qrNG7%T1 z#d5f|NrUDnEXkB5!@cuU*=IYt^A$uV!u3k=h=@ADq6Ku4D~`sw$sBRZ%R>kbL$nFd z1Qib@L_8LcD!473wFgu7Xp3jf5n<;%x>ieZQp+lRBq5>^ZQpeHN4_Weq&D?{e}tY4 zHzjf7m>ly#%oM~OHO+lI#VpjD#OrX$l{!Z}rsDv2C|f(#^+E?RtaMdt2+zjvP^y|O zeO31hGY=zD-9zJw_T+QUuA<$wCDM^$vK|Vnz@eBF{eFHfVTdktuRXXLiGs616E`CgMxb?n)x109)V=?VJ5>*rt z?Jkxk;4~8VZOtyHUPu$Uxe5~wl7d(@sZ-k)E&MI3+yt?iK|U!)q-|DoCEH;Lo7)O(3TVHR$3-^{ay} z%YWAp53Tw|HD_^mRNaY;muU-#<{JE>^ha@@uZpdY>+v9Trg24H4l{bJSs7MoJB*7RJyYrTr8U__wOx~UM(VH-@Yo8xQrlZ))&Tn>JBrX=Ri#QB|HL-LkP=~D( z=Eh_uR=p^z3fTguC$%!xMfjYQaITAYCN%`U!g5-llZhwY^CF(;@Gccy{VCT0?HfN? zC+qH-;JIa6kKI$5oSmASU7nqN8dafzt~dcZEG%G3x$)`e@!+iT8(u z)5mjn1o6)by*nbDMp^e>gjE`8Z&v>}TfJXnDqR`J3Bipu_{hD3WR;J6eALkyRp;X( z<3_-<78PTBuyASG9_g#{pna&DtXTJra}0LLI$|zUJf!F|+%<6Sj>RkV2eXHM^=I-KEb}wmKoo1sp{kORlW=U15&OlgB#Q~>Bc1w;DwCd2ZdB( z;VqiyZJWHPJ~aUV^PG?!jx%5jRh5UE5K-P2Dvfi>7^Xk>tUf!*k%q z;{!x%JC9y2xuqplEX>OY4eEe6!n{l8d*hVCL-_6%Z)f`TbI&?2gjT%gCBt47OI6y$ zil7|Pt<6!s3muNW3`~#QmQ+Oq-PxHhRdC6s+#kfg*W&cjp!xKOJgcBjQIjtjLZ^&PTAg`pUwnb8-_!ae2OE=-eehh@>2w>Py*U@9aC0yHX7F<@$`-iX9+s_ z%ce*e*Wr)0ur0Ex%^rSOf;QJyytyd>t-r$WYgbqEuc+N>&s@-<8p?gWLfTFJ9c{0{ zD|0h|}FZ_qQERfU?(x>|LLDe5OE51Q0 z8FEQU-m}YjCaYRy)$w;+nMr4Z7mNz+x?;0HluI;!04P_pp!t#L^w5i&#lp7syb%~E ztC~)koYJMEZEV(3V`-!~?Krkv!wOH}daiwM{E+y;uf(aJ1M08z$42TOq~I)YfY-ZI zSj%8Q^#oD%-mt75|0Cl?$;Fj-*%IRFesEV6La@pPs?nz7nlKktM=q&aVd4UNuU9}! zC*UHW8_{`XJ+h^dh2;7I9`%sxI!0(7* zDItkNm%g-<%LIa2klyAV0zhCOd0Pz>D6PTx)i=aZ5X5oY5_H^Fw?uk3ps_d`&>6I# zuF;ODh&UqKu|otF@eLwwh3KFjgqSyNoJ&E^FcJUUHWcf-Ra8q#jT8~ zR@dZlpDzg9N95PtGBg_)CuUeoD_V63T1DG~h~-%?SFL6A=xAB#XRq~oCYy|@bxgt) z(t<=SqnYBIEzYNlwQb!Ln}-uqr? z1bXamF%`EIM51UMie4A?4G+q*?L!GVnN+n))3E7@M7w`)u~yuKBf#fFuW46fO}dLe z+!Qi9hd`4gqx^9u$*xPW30G1aPNt3Kn`}o+8swON$i}@4F*x-I^AE6E!syVb1O8y8 znn=VyM5Bnlek7EC>}4QY{el~c&tg?4y=P_!ZZ@?9hXN&9`S=OTVr7T)@skm=l!Z2w za*BH!)ZPW=A~FC*#b#buU+Ve=#8g#titf6@UB9Cyj;gQUtLiPO3fqyU>q7Bg7u)Ur zFt04XWP;>jtgKWriy#23^wxqWoi0?ImffHsaW-3)mFb@*ibK& zF_lc8jR&zN3ptnI4(NKLSW~}}kApVY(CJ;4eOO<%UiihM3W-ydczu0V}rEoBrMn6#rRNYO9tFu&Zl7FGS484@H7+=}IAv zQkYX3uk#vQ7VBw`t8OrYa@X^8m!xDa$n2W{$-wWF|F3$ikZwb{yhS-16 zW)-zic*jhKd7ay55{VoZ#pOGp^a~?f{{Xg z#cIq5K9DivMIgCs+&5~LWM}IrS)QN-P}}OSrZn~3>H2mpIp~)O|w#ZH^R9JaV3MH!4XZ&Sf1HR z*-(Oo4b3wR%*mXEPkBl8By7E}qJmkhY)C1p=k-SE<2xU!nYL$Y+3Gj#*Ph6?c0WMNZD7~klK59wS^ z?sGfi8MWVy!$v|VwQSDkN=4k!k(IY@O*<=C@uM+Caor*vN$JnTww2BKict90!ybL+ zP|xXhS0O!BoUpeQbJB+Io2fOYC_(FbD5(L$vr7GDG|s{kkveV^G84JB)odqPfS>V5 zo3uTc6e_YfPN zTr>}8A?Y#!g~QbIE>u;+xzX*$Ux7Q<-a$Dd6woyZk}#0Cor44AWu_!lR64XNPCAJ93a-0E#u6> zhQoAWMLm`fVu0WSWr3cD?DtelBX#8f(@gI~9oaNHB(rASd`8#FhS99AYpdNg+|$+D zC(g!f*clI4kQ|(*K}Vl>HuNMX8o?x0lr+WJnJ7I|-=SfTfg z+9R{2Owo3a@Iq0N)9G?p$&MfkkbiEb`?*}+S+VzXk@~`XMB|I@<_f0K@{cFdHO&=V z1EY%y@U7sMbpDn*I6}#zHJs+7!R^)2`&P&pW7|<&O=Qr6l^(BmwHgRyCeGUmqY!T0 za!=uUuHsVXPF-ETO0_jr*@b;O{P$RK-H*U~xM<*#tp#VD6Ya6&xcD1SC*y$R4A~;g z3i;f|Y_YI-O{f7AUH$4o$Uw~;ytY8{KGTLvm&NeJWghY`@nU{@CY_bR5v4gUez2>` z2Iz4pOqNo6iiZ2h<6M~bf+HnUkIjJswm!PDxaYknG=+iIc9FndzbQX4SrOOA3M;?8 zH9cRPtw;?M6cb*!q&)~a)b!u=pYmtzM(%DcRBv#ysyA+pHu~}0p4J`lWHi3bZnb-H zY&lyQD9p@O*brp&F4q1_s`zWZRr?#H%Qe1O@`c>1&GyQCzYx99d2-c2@{9hqoGY&R z8F8|cGH@K3&4y>EGgFSZzg0*GgJuoeS&ots;jYCqX||MFXId4Cur1EBZ<5b0 zyOj3)ss-hO!MbNa2OQ&Qd4#%l?t(@MHylQcG0_Ann2eMmo9 zrH`EFnLatqKMCcE5O#-T*j;}Q@ugSwcykoJ5cNpX(L=8`@12{g^isYpQIg}dj_2{W zsohJjUa4I!fr<4f5#*!+@HnJ9H}!hT!&e5KR{2WvRhyPuRdSsftZ%MTaL+D zi|B3X0@ePYuO)l}dfU^sxv6|qB@PQ%LJvt6q8ak8> zCMkmO;Rha=U?2Fq@O`R18%8z^Z`itFILLRfK@FL<`TfVw)yj%2O{Pt`@g+M};f8N& z?KOLSd&2G=s>;a0x-!#A8e_ytVkO=?%Zx>Hl1ndjAa7xMt?WGu+8>NLYC{=;p`0G>Ikn&ez^Fhi|+--0RL%o{(Y87A%X2FFGP|*}iJN7#BuO zDGCnF?akEI2ILH9S-cJ0rAJ3y^jQ8;LXB%+FORbv{7$)FZgeEn230kG$Z?Po+7&M0 zvQuY>Q}2u4I;lM~Q3DS%k0kWD2wDf3bB{@rW%uABnjBs}iDFw#=qpfKeDYGoN#(Gq z=3x=Tdvj@Jr`BT3a{~<@LSpTX$*gV3!P;I;>FXa`@eW0^>NzHqX7>8jrh%PuX>E|M z;SC5HXG+I&H;0$fw(ffAaNHcJr6MAXka z^W#(L@}%6;mItm)$*s3&^ukkxM;G?G+A&O6ijqUQrh>TA-ml{N*4ZA9BrSsLJ!(yI zx1FMJ=`$woILT*muC3zilEcJ%RLi$*X&NNe<`Ffifg@?0g|&7m7Z=)dr1+wI|5So( z1fu@s;&{bYr&mRIa;#96d2w>YO|aC@emW&%F}X+EvTc=4A{eBfP8^Gz^;sXCLr)xi|g z@2DRApKL8Ezt8Wejvxe5jC=0WWaEo}+;wy+8pXoKouJX~n7w{SYUR*K+rx9}C}Sj@ zgQvClkz6F~;YHm2iX$tY$*n=-x5+Gq$@`Fonv>VHEVLFvvvvG5M^c7$mhF9`BkHOs zQ!n#rESfe;a7|Q_ER3~v72SV)XK$z4Tj&1Uo`<4U$QA9>o_qx!cGWlYEX~69h}+r- z>uIc4d^CfyqI}AT=b2{irA&3xEmSiXLRLl>jMIHaRi{3Uv4PzjF>+XUZQOOr@7=nv z)mDnqfK#L{&4{n~ulB}k@zRWLv056=3O1Q&ZTN6dDU7pdzJUZ)92Qry#FZh%G6H%` z7wtl#&2V)Ue#}7%-@%%hg3pu_$<$C~##&|+ zI|q6Px_sWPnz0(3h{y(~*1~=poTiRXf2o5w=D}RQ{t~n`z~;G{=1bP`5^abuC4Q6{ zTns%asam#Quw@Wuw}<7ap2hia5^atEF>Wr>LylfD-{?D{q1ow)Pt#^_DrZZxWze{K zXezukuf>x({<)sdKpDj^gF7zhQfDSi9Yzi(akrohlkB}U*FE5rfuvOvSO?EvdcN|V zJk|rrwAR$K5HJUl-y9XZ4*<~;7W#na`6_zES13L7Ts=Mx>589tRPQyCJb~R>o~SXo zBUr;dxDZpOhI1GkUKX8QbhGj!F{|NR0^Dizc&=H`Fv8pO* z6rzlI_D20Y6pgO(klZ`gHU~d_Fb#)|u|p|?(mIMvO-EevFVza3e~3X^$}x9PQi$|< zKYgOBG6=VcxqIwY^r<0(R@5A(_n7_k2^nAZ`tGS&r&26dCe^u_6-6s8i`pWIY$Dp$ z*%ohuI|6R%zs$|Fcl}36k;+IDrJ$sc#em>%{wkosL?X=bUB*~*ynN2%W)iiSFwN-hvFdwbbD3nHe zURxb&)ng6Qn~D(?Q+pIlqw~^*?lgsJhRbkDSVD!mElteOmFN=RgWD8VHdxnStM+|) zk6i6r)U=NH_N!ni_Fn%fH>m6yubQ`vxDJ5g}Ti8B5X zSDm)8M;4vT_nQmr@EGAxgvv-PY{bbbsLzLHn5{R};pcU}!!vDjMFwsaVx{C+b2zA-kDj==LqOs7aVokohYr2@P@ z3NqZ^iXjpEG{j?wekgw=o4fJo6)z2U4V=4UB`&6EtYwoJUE(Lvrp6k@Cs6cBr8BtY zR+z6?3Q(X19$^ix6pxls=IUiG4{6^al9`%DPHA^~>aftKVXq;IghCTepgo57Vrsh$ zxqc5k#x#ABad{g;%SxvY?dK7F;t_RAgvmeW=cjVnbPf6ZP#s_-gXpZ9(!}IOmC{Lu z9k?-0v%=RZ8xZ z1{_N8*Kb@+e_zUJjD9=u(P{3H7j(y0N3b4 z?~8aiP2kk0POD}bX+I2{igp+=q!46p3?0wWIGsHW5UweF9uCbVRQt7-n zD9hKjN0p17S7<#H{7g80SDk()M6XD8+=waNqUkjxu2i)*6-!yit`SIDI<-o#*9IqZ za_9>7eO2s7%3R~a&F4h!8ExM9$#Clm3%Si>%%zi#{YPVr=>)fX8L2?V1zt+F@*hIb zK5^Ow&L@%TH?V|Bq#*xbjwcAK0#U2l2;(1v(3WXdR`Q5wg>VmI3YHcpc9*V~aZKMw z!-jGA*`=CaGKyd1%#VL~Ty=IvjH4?-9McICPD6vL25s~}JNU6gUQ1kpdko4un6$A@ zh7SyJbMx~_v}0V_Fu)`xpKR^1iDg98Jf8qsoN`n@sSaW{H++_NNmZYuCR$}9%4XQn z?w3DKDW9G?6Bin1is@4B%x%TlvU8?476itu@WCb1Zi1K!FnOwgKUZ=N7&s(`t0T<3pr7KYT zrZv=+vDq>@oeM#)}X?@tiz2~Xj+%z z(HFErV{LMwJq;g?5=Xm?@wJD})cIuQ&U~pdiz}*E?4(S3OcFoB3>`_Rn2Ug<^lDKi za-rgN7w7CYF)4>Dd4|)0IJHNM2eFWl!8w8r|1L)hWtkYdffI{VfPaDI4v7X8Jfcft zT&=5Ok&NUhUOS9TmS)S9>2w)duN|}V1v_f@jtJ7onfIV=h7GJ1>evOPyD|0Z%1@q} zt1G!$Sjex2=o4+LMIUwFQz1Q7oUjusmPWC-q7jcRgNG!IMlfI|z)(W5I2RsK&>j z7DO!MYK}ozXD9+gxLuWL)}ca+1@qVNY{A}c_m=Xz9bSyC90v2t^GIi-v|5?liA1+d zPOSl=%3Vq*2TDH}DNZ|%@>38oncba4!CT70=s%{t1i{-(v9f@#LasyavA1W{_e|n?V1$-FQ^)-`7SO@_ojiuw&Z(@ULD7G!4Vzx~RoQ}|!|_Ca5L?I1 z!{}B6T+@FKR1ZOUVVCO)vBE9VW_if0aIO`ccb4k3Su%aJ-j8QRA3++Ab|1`<2e-#` zq>_br#_wOG*ar3$4^5v$mXn0tY< z;N6y;!>!$eqpSxmk!Ag`cgI3;>-=_4NF~LiqawhyDLD=4^AI-;6Teo`hsN+KeZ;Vd z5PhPZ>TWf>^6-z?xRO2w^)QmLPBZBj z-U+mxCDsvi;-m(xR>z)aryX?CKW!b!SaQ4_m-EHr@uUbW-`1YQZgLA>aZ`_+LTDZe zmWTy6c_T>SRAo_&P*5-x?ArA#sNn+Cxa)?`W2|<(tD2FpgJ_j#PezluWLtYA35l*~ zMO&Wh;kQvL&!pjKmlKQk(h|f@KZs#ihoM6+amW_y-<~+=NUfw#l3a&VtJ+_SD?bHA zFL7BxJ-l_W%2XpBiObAi3+?6T{X3!;PRT8TUWjaWaGPIIt&p<|r>UT;D8aOZ#()w_ zje1Ui5`Sra;u31|7sLn*X>yqzaB9Gn^NF@dR*14#Bw^YgrAGpd$<)@?WLsOZwR_7_ zFJcU#wVb|r0sA3xsU5P2p)nY3kI8%S5{bCfJ!9IJvt=}&E^f;!=jj?6D4KL|+!XUW zp4H?gH5V*~oAl0!5p0dEPPMs-)-&Xr=R`I2$TxTt#{F$YTmMm;Bc*IQ=Ll|+k+LW- zCJQU2nakC<2%AaEaiz!0owX>&Ei4WB1i0_7M11IY6Q>`Q-P z-|*nj)*UH(DB-oaEN%-!&sCWGMe9SRci%`koTpVRE15{f;|XX#(RgRF4gV#RiFiAn z6R?EDlZmQ(cB=2UYH*C0lrdZ~eOG`e`BIY^Kuf7)X*sJMG+E3BZ>d7K`XxtKAy+Eq zb1hafine#gqo71I-UbRF+TWNTB+I~^C%@A zLSbGNGmDTK_(#q$YK(Nmv969M)%viWwc)|K3~2QuWUycbC8i}}^?DYEzQF?amt%*E z2qIZRx(c+57&F0RB#}!blbv2$14rSP)|-}XoAP$woVd=)$$1qxy&176rNopN_0T}K zae+41nr`!hDG}T^u-$4!?6%vpN4PZ2Rl<%JzbwiE6$4pQT4NpUGE9@*YVQ!zt3A@* z)=sxQNP5#hEu#a4nb`_)n!Ub%>!$NhchB*hpU1swd&-_AwyR~DdY)eTyW@`z@NY zgEo3kpXeg~67O`$b+erk9lOFvWb%)SBH<+w(`eIFeqyq+N+Xi5ULp}6^`;9ju;Z}p z3S%N;oaq?vLG(gn}r+{x(@VBJ< z)qGd|rAgEQdcMd)3SeT&`b1<`^NIXME?lBDr#%u6sZLPV&_sJW+N&m#^pLia(yVgj|0 zZVv)v*@7Tx8H|q7aT+ljRE*h7j7AF+Cy0dk2J=NZKY_DfD9-zG7A@AV(bz6QSA^_^ zB2Y@ta45bX_cZAX*W~pc?=TJ zS5$EZ#1Z7i$BcSUiJ=6_d$b~#-E`ja?2H&Ks=rJJCOMDyQb)C|lJSM?>LGTlZDO5BZ%YX)gP$P-}NH;F?R_13M^f88B zdJ2R_v_DD0Ea2+8v(_bu<5mM)Qklf3RX+%N>fxeljQ%Ky^LK{6h%|fBGug>BI34Pl zP6DMaI|*qcd0!1VbOK2ZjOlc?GBw{K=65>_roxm6Rt6_w(ii?BxV4+cSHQs|9x1i7De>7*jC$j?*tRKMi%WvF5E@S|E0 z(5e{(s=46%E-|C!b87S{hL#dv3`40|TRts#=Z>vgy0+V-2iK#+?Z&J$W$ltPxYFV* zsc|UHq5%EGozr(p9f&lmF>5ns;q6v0=Hxz6UCfn^wHvt`$wPCL(mc82CEp6M#p6+p zWHsaATV>R{1U(^be2wbn&P`$Eijgc1O3HrLU5EaVBS>_8b}BCY?o(Ny!{EsXbbgs^AS&a}Q138jI99U?-tTC{0voB$G&+hn6%6jQ2fh4Z7-D zW0>=3${J&=Yj%TPVS0$GO?h*cF`;9zqg7?Ew(8c=`&Maq5!CfE{AZ)?q?woTj|EVF+IU-4URta*E4G}&p>=H(YB_Sv zNZu0tHIMwNUFO^BR74Y{!J4UUOX;vtt>5~3um~^KdeKj7l$QXZ1BYBg1I z#=*gpqUKUv6x=1KAXXHDTU4FRw-zvFD!0ypW`3-ybFbBnQSR#9mi4h6Pu*7h&u=|; z@7JxzV!0hbU8kp|o@$9zWIVRfc2zSm&x&=tP9bz4sH`JG6%r1-@tDdOoX?XYPgR}Gx;efP0)_{Z3=o2))9MPH^{51 z?3o@Y_h3rbYuLVmm|JpI@1E&RQ?uns0jPJlC$iM-U1FiC8wpemxDIQwPh?Hs)Z6B<0XW<-Z8SNwPWG55VR`gI;FRx_|>0P3anCKl>)02Sf#)!1y&dZ z;v3={M2v7~l=k`kTkSslZp#39C|tKWL; z?O*BbOO068Pkqln^F811d;XK}`RBgp|L{Hkm+$!$)aeBLHsN;&zrw%j%7k+HYCcTEc#33Td?^IU|(wpYr-ze*o9K7 zd0L~5VUMy4^iOHqTNTe})4yYnY)!#-nsdZ{?!kU*#2Utas<84+OWT65el5Pviz~~m zQ&rpbcp2{R?y@s^1R|WN?sJ_6K?-**lqL_^fTo9*p|+DP>#bk5tasw~{rLSTe)r?| zcKlMG1(v~EW~KBV^po)U6ml{!t*-MPz3`@T$K?L>AZ)P#byVYlm+LTW;*!i-={)t& zb3+wwTWT5___F;o-mu=*! zE*l#U1!2+ErBt?+5d9!GN{93=m6|YR5kqQQN!sUAYMThAeWn5J_Rvn| zbRM^p!j>Ae_vqTW@wFZ~rOHpZI|e~**R<6i(win~hqONXwD9Q|gOm|_{zA?O8KET8 z7;MhU-(v$LlYlos-VDPII0nmT9w{A}cN}?3kP1Rhi67`_UdtbI_e_2ce!AMl#D_7c4QDLDLlaYEs`TfP7EU9{o{1^dk3HI(3om*Rgr?$nUcg#M8}`C@ha|#` zsJ`6WV?KMbZ9^+`Dv>5N2}|f!%z9#6oAehmo0lGPJmqGmr{{?Z)%4U{Wv23#E9q#Y zAcE;iv%^3+CC5?U=tu~rYq(or3}SUjlXqF8QrN;95V{Yx!`yO)1V_Qp32jm(&+iuL zQPDB{9h=5(c)kp83T&FvyK&()mzfVr%nlNP62}4&q7+4oG0icGR|^`<9c5dUWDz^mq7&;Xih9#uq_@1j zRDDHxn8RP3wVu6{g#LIs^uYCyzQWr|NNd|V1HV!E{%k>{sZF$<$nE$i(rB^1w4BPkJmD=ZxvMoE3;IdXr;E~A2C`j-`P z-CK2wD6g<@=*s)ORlIJ)mPiNB3DL;3^jg9U=#mMF3GVoYpOZ|d7E3~>VI_+az$ZvJ zA{aErG^YHS&}8A2G+V&dS#hEu{FQBqOksXf<)P|5 zdIo0CW@a(D>Xxp2aC{bx#3T%NH$gZek*Jd@V?00MI!A{WA*DNfO@!PRr6AiZwNS7Q zP4(n;qFrj>l7u^ICO{qNWAHzLV~5`JYSDA5E)tZ0gu^NWNtHLV>yjcpIJn)t+WVxA zc9WwD>MNW`;0vMKtyRK>8cvO&_M%TjS9>XHb!o?Pv`n}%!OsYOXIQrvDwc>CgyirX zM<sff{kiWUhtptXt4`2kER;@TvQp*c(IGy zU>SNg68#93aSD!P(%nri)N@$*m&653a4tgIgi}3g4{fpJ&|oS%ekU5ibjpL~niJMo zuf*>^;P=h=y%E1R;rG4xy%oQo#_!kgdpCZ6g5Q6|?-%j=OZ=jgjrR7U%cy01R5JI3+P)m;8*RzVdT5cQf|y%6cY)VUrrtA&m66aPq)WTv=dy+K z3i!6%X7>Dr>#07+Af%4+#6e2SQCh1US4tBzUX}He=6(ItCr$nmUD09t4S z*FmRI0*E}GkOqV5vMqhilh8`4l!OYmPkyi0E{=*_7I9<|}I-SnjYUilp0AAIn|$S;2$d>EeHp9dd&wDD|R z`8V;E2VdN;(_Cp8_y-?6-gveiJXSv=yoLDrdb5fD9N{hX^9SGa|E|^P`+Ise+UxVl zj%2Iw%bIJ=p%2GfOU~|Si`_j7monikEO#DT&rc@AT2c7HpKiBrh;6{0&B^)$Yc3tO z)?BuB&6AHi=9s-}EbA$FFMf}~?|PA@>(OhkZR$S$*xZ+pLgCKFYq3|jv)O}h9&Q#X zMBa<>dlhiE8Tgwe-UjY6{B}OvvYz@d091bO)y>V1f7qA4sLQw!sPm7vtQX-gr)kbVPi~k_w@5Sq@9&K50;d1d6w+$BB`bprg_Trmf%=vBLpZyqd-pP}{ zX^ipb0DmL!`|+2*-+ap&kwDb%61*RUqv30e{IBHvR|5Yl;KvPohVeH7zYS;p#*Okb zT>j_q{^pa!&K7=%hE3;i{(FJ{Gw{za@;{aHi%s7rJ`R0g;Ge{J8~FCeBaOHG9kO`I zALjr+1iaWybHA?=$o2#OKH%eCe9_H+CGhtEk1llc54iXnf&Vq|(jk!BSK#)24)}|n zV8KJzlmB^c{(FJH4EVGc-=q?V`dQ%39|3=vfuG~@ZQw7!2KjFd`~itS74Oagz7NFt zpJVYr_3H-@-*@a6yHqtKohFg)IZv~!|7Vo*EB?-2;7_+L>skZ<62|WX{wCnJ8F)n~ z(T+QT|3BbgVc=iN`40epEr|3E1OHEqUyCt)+A}Oz%ke|)c!5OA`mYCm1o$>D{)H}n zGw?45{%kK^kx{iD_%8t;#z%XB|1t2kH~+ka&C8NV0!w*ud1;JYMV z=otHe|0(b#@Aw;dS@TPex%$}VOw$*;zTEW{m0Ia0cO!l3Y|A=el=mO}y$66l>)Dod zzk&Y)<4<{nWu5sP%X%5)Cd-TFt68_{0RH1$=o2IV5a%BS{*m4A_44AUCEBv_ZVvdf zfPcLg58bEf6>8d8kN0mynr|XaueVS8UfO*1G0mN8M2l5%Qoi1av?ul=PN}!Nl1d=P z&jH{!*TAoRq-9+J{0-jxP1kdK)&u`|bk0=<{tAhQShY3-e*^H(Xu<=@U!luA5q;yS z=M2()vfr{E<1J^4ThG@5|5f0(dht!0xgH+@{&AZv>-h%$LdJg^_%iSr1OI%+{{i^# z10OVxigujvD70Y!vcOAo(T;tfxT>b4cL&ma_gu?*lJ`41RRTfpQQ+?b{xUDV$<-_7 zfX{CcXT|YD^lHj-J#PU1+ramD@k%X~-`@}XNg&coz4)f9IRD+izZv+~7UAB!H*ZHf4g3gye-!wOfWOedD*}n~=YYQz_@MDF@HYVe zzrer8$p6n={(j(Z926&+@Wb@m#rV5{f6NfpCtiMRUeELO1Hhj(Y+08Z`R6(RDaS*n z2R`fNgXXa{B7vx12k=kE;2$^2&v5ypz`tatWeJ|*`duQ6m;E;f{JVkwhEe{VT>cHf zzYxTQNOkjj)-C&ie;@GIdGSqqx&C(p--gb6w}F2L;~xP2hrr)q;6KOsQyvXn3!S&Y zsNb`=ejUJn<09y6M*bgi{!!rHe{s0JI0yVsYT$1G{^aL{>!bUD@2-Kr8~7RE!}Qe$ zfPZ%l{3#GnKLq}n-u9{Csm4F>YaoPzspSY#-7;0YdF;qdz*hKkfuRm4yy|jOTmJ*B&D}MAYX1@b^I2`~WcXW7BuIzt*0B zvvHF(^grOU`S9_)8TiitA0`hbfq&c!!q?e*fxiLxTaEgClL z{q6wpo2SC_uYD}$THrrxeBY!01ApDLWj)uR|5;4`&A@-XfVe#d{&>bu0)J02{QG-> z&&;3?jPKv%wjcPDUl=a0?*#shz=H&y{+;0b2Y_Ew3LnpFPlUcx4)5Rfz`wi(elzet z2R>{*n*{#cO87c{FYuoRK5V|&2mIsFxnbqs3H;^2hvh#2{9V9*#*o*aV0pdvBZaZe*t`0{r3U?+{?oG`%d6* zsewNL{OOm6=U;m=2$U`qr(Y<;vI_#eC^IKPcDHv|9ZtDsYP`@jEX z&CP$e=1X7EGI$DUl2=>S+YKK4N9MunfdBrrmh}N|9h=_EWB7x>UkQcpW<$n*m}UGo zfRDe@vfkvaL-XsI2Y(Cv*RI1l+bI9vxcuWDkM;Yjfb`~X`isQdc-v=u!$GslwAC$*^*>nTf^A_Ou z0slxZev?GYzWyHY9|Jy27Typ1-(4SWGd)?@3xQwbZA0^4xqb=YGjGIv=>5LOCOiWC zmw^8-BmZw@Ker%H1^Cw*6*@bCB5x%oZEiUgwk z&A`9$z2WPHN#K7EJVd0Yerf=U{Ck1V@53D4?7=sGi`U!xfIs_#(1{KFG~@3C{zD&z zAG^`Mw{!ar06+9m>{S@wALjP0eInWq{E0^XM|1x5!0-Q3o(1^y~8 zzDcc*Mf)a!Kj&u4TIa>5U7pCeV;UUyB+Gi#e%O$__}y+DTY&GYf!_-Ji-8~Y=5KP>gj2xZ z1$>(q@3A3Y2mEoLP-oGYhqt=l{~+*B0Um0ShlgAn;x~Z54)}At_{-eFz)u2yzBhkUiogF2;BN>1Szi3O+rHld|7+lH@Zvo-p5xHSmwXy_Zi5Fu zD|t}1AOG~+9xV4xMVVWHe-H2<_KqRQspj{Xwv!6d?f5+S-Kd8e4B|W2jG(z+d|X$N~eejB6tQ_wdhu1COcB!zXHOydJOa2mY!rqAlKfD!W>T->zo=9c1|( zpouqa^JiHuoCEyJz6{;g_?DWCY`nV!_ayG!bpO6ZpZeV($0iH!1t5uqo1%BFefSX@7~dSZ;afqZmctPkt(7<<~?U z8ZTZMFKoO@0DlYcCp^}Jhb(GteynVisLv?U-0|;7=jA0udd7 z&!BM&)A(J$@B0a4Bg$pDpiDh7{~f^J1$@63-_*nW@*luI^dz|Ku%S@cn&jBt1kKlSp$dI&TOtx1mW1Hyf|^0{?yB-{Hjz zK6$e%-#>^nyMGZZA4D170DeF4zx0>!V^zkfc>f2ac^eWyMRV&R`=#j`GAWC6r`U)& z`zzmkqtd;F(usDRgLL0Px@Q39b}4hK1(bCO{<$Cc9{^^&XxBI0c3p!sUpo+P>wFjR z$NxIq7IO#ii5mF-0REyH_+y?9c~Ap?D)8^Cf$s(W+coex;QtK#77IUYtL&HjDfGc> zfbaf|Wlec?8`1|aHf=#@iggRp-*lf(mjF#K))s2fFLxu&caa9H?|xI6$>o@N0Qmo` zfj*Z4*1Rn9@Qr<}45YhBDAnS zHvs>B;KSBi`+*->v&Qd=tX<8GyPxb)t)4&Jm>Nd(e1s(Gx;9*X1=`ZB= z)vnw=8)=4`*I4Ix(|GjVi-CVF@Eg5&&wAoA;J*g^ubVyJX#NGS>D~(b%@1D_x`*;< z;O_#yZLK$dbgdwQ=;M2UKMuxGz}N(R;n~=w77z1JVt8zt!Zf-}eFk+{dj6 z9S?T`p86dL902|!z+YnEFXpzch0=Bcj9(uz@b6>%df-0;{LC>(Kyz606x*IQ z1K;}OHG%u#Kv|Rc=Ow^5Kf;rLv)s%6(^?_~P@>;DG)dx0-`@lCFO+9kk0@tJEv z?FLr@|FjzT8-ZU3{3E^PtL25H)#rde6Zkv5ZE3!P<>0-*{~1Qf4c`1}8nSHh4iogc z)7MyE^!95%czFLYl7~fqoQgCDTGyC*Wz)}?H+q5pCN>IxDas?>@ZfX6-*RSfe>?+O zeu=uDY`qIm7SO|_ubqOf!Lx$C$IwX_ZR*{2hQ7|w6Cg_z_7aAk`*3=jc~6%9DF-CSN_7;Xd#n9&fsq(%ANag(Km5>Qr~zdL!aPu|IN@}89L@fD)~_ioygD=8L}CA zCPNz-YGdeZhI$yv08+J@0Cb;hQGwsRh@qD<^m>Ng&Co9x`aMH`2J|~w-e39M!%w2G zoxsp3fKT>Gi z3EBuq)xN;*<`}w)q1OXa1&T;=vfRsm!VOHE&=qPlAmt{^j{MCCS!lV*manE6}AFMjfyt`QuE9nSn>WS^S+6p zZ!mNL7XFH+X+SE+tN7g;0I3@6<98ncbiXX`HJFqYm;5tBA7JRFzbEWH3_TjEt{Qo5 z3=J`~7mylJw*XQy;tLFYo1q^w^gn>qhkRHF#{#D7Jd?rEn08-e|^#r{EkVrST}*E95w3<-@+ z<#;zBmE$Lj-40zzeQgIr7Xnf_<^ic3PdkIsoyO1^fK<8&AeFAb*h?9D7egOm=vxeJ zgGox&V1%Iy0I8Cn4@i~#IzXz=-@@YCel(?`7zNjQs+? z`zk}AqvzxzHzKLn)m{(;~9nW4Whc1=5#d=?-zQZC?kH}Sh$8Tuq3Rr0s_-CYdb z!`Pn!QgwcE2bJ6jNWFVCzk35iZvmuA{s_OjjiFC7_Va*LDZgasDV_9kScGUp|>;iMTWk~(3*|(wY3Z#4@iCOL_n&%0YJMj>psl7h|`S&QnT}C z0Vxfj?<~r(jiF(Np2tug(4XWiUf_3ShUOXi1|Zd!cL7pg`x(Ex50KIYPCT2wI{`@L zC@@q8q+0ZHe)n32-oV(m08;J!9%KKD-wi&SO5VxPMSxVvFXVS~3|-FHs{pBzZ)fa} z_+8I)sN{1Q8U&CLoa0P%lO@^8G1cqZvvz=l$!ym8vKFNJ@&cu?pNnvFIx7; z{{i~5gud2Awfa|vegH_->fZsW@{aE&=(!B#87eZg7m(_i4>9x;#;)rj?6Vn~XXrYH z_A~TXK&l4Ky#zgup)Cvz_gU8S)(GCs19||^$<`h~YMy={AXUmo8TvRwUts8)fE34m zm*4%Eq5By6BSR0{g!7j2YmWk?zVRf6Y=-(7I`Z7b`W$4cgJ$x(WXa%IWDZx-DAXW0kobG1Eev+ZvIo;1VUH3LBZ-Alg zfK++YfK*NIVC>f!`ZlNgKBxP;?Nr{W44n>0mA3(qDsPstmofAbPWMtyx1XVV82S}M zClAusp3IO9NPR8I@1D(2H)DqYsk(fUv7cw?%bf1(obI$C`dTYPF+l2T7xKF_L*tBn z3BTLR(5o2xMt=7}hHhqPKd1W)AXVq)^QbOQW@sBj6+r(h$Ka*>?ka{}#n4+B+A&P! zUCdA#kZRjFAobnvF!tXV`Z1@wpWpo-LkK3UOL-C?#k)^u=rqPYm)~t-XbWQlh3G4v#cp3cyEhR$Rt$SbsPL&FSRz|bWOO)yjeq-gpXes>2$ zUj?Mb(OsPG#0x0L84L{oQvEx`&<;RazHquXGW2nVz640|-|qmaQvSry{{m8_oNysw zpTN*l04eO#0jYLe%+MsK+t1ML4BY`p<^3VQ`zb@eWb9w~UGqg$gSCKE-oFE+zIzcv z6P)ff3|;hm%9~+m0+1@@a(;IWLoa9S+xgvl82SKXKLSYA;C{xQI7aVIW#~+XHZs)5 z&=5nT3|+#|BttU{%`tQ(Lwgx|BSZHCQX~Ga{O*yLQ2n0G&~<5|(8m~hQijrPXD9_o zX~-AwyDUS~4DDg)9~gQQAeHx@_}zOM`Y1!6V(3c@eT$*rF!Xyss=Pn(y9XJ1M3!oQ z5<`E-&@&l|GISP0eGKhn=*13|cO64-X6QW(-OSME82T56e#p?T7`mUKHRJS+$1!v| zL(gXDT!x;{P>G?JGV~UPZer*Q4E=zi-!SwyhEANIx}3&PoS}0V+Q!g@4CNS_W$2|0 zy@{cBF!TY2Ze{4pfRse~14Dmi=r4fO_+2weHQmb4d4T>8bIQq9p5GPt-Ano1EBW19 z0jaNjim`tKq&V!@Jbj~;p`C!#Om{gTmG>HkUJgjr@6~{mjJS)jKW6CXobCXpJM#rp zUXr1+0IBlM<9DMBJ&&;&K4o{hVEtTU-(_~E~?8~K&l2O08-zW zU~GY*GN*eZr@N1__cQcAobGR&E;B`6%QI8}q`vz)KgiV(fo2^jC(OW~jV%fK-ml04YAbnxVa%?yH<`!wV^08$%lbsrp?2 zNR{^y#@@!zr#ao{Io*#L`{WXp{0xSk2}qSZ$nSPCbP;2B^SjF#x{9&?#P8n4(EAvB z6ChRRW6M;70fvSc+5t$_2Be4e`V}375c^_0IBjG4M>%jW9%-5 zW;op}r~3h8f5gzwINh%}U1XNN*3Qt`fYf)p0IBc3iLq~E=$)KyAE*0I#y-H%UpZaV zZYpnnj=p;nL$@;YNkFOww*yi&_|`n-SbHf!k74L!Kq|)*0jV65j4d)$;dHOycdujU zjg0*uzq^^C{fzw#AoY#EFm~OGs8;V~=q8442Bhk@ACSuXAY&hP8RdNxAeHU}Kq}n@ zjJ<>*hts`)(|wb%-)HEDobD%_uIF<4+PMr30#e@{0i?dWpRulpibhHl_=|HSFmTuJ4v zW$1W7s=N~csq)4cdL={eXXslDo%|9i@5v0=fK+*B@w;w@`WZXK@5ULLW~jvJ{*m9^ z%+S99QZ;>mp|@TIkJUB8;`&vF{+ppwug2Lpi9HLDlHTV4QWl4E0jcr^8M=tm?dEq^ z@Vl1+nwI6gma%VQ>{|h;lHbGF4={8ar~3}S`{Dm*?`^>AniBr)lQtzKl^`WF2*LzK zT18N#np0^fA=;#hRvSs$WaLY7LQ6_b+L2?Y^r0wfrjepXhN9CcinKay5ENw+TB?dv zVNbUC|hNh9y z883tJ#xe9_(xr?ymGMd$TE);>kSgCz44q4wPr3`F%J%?BmG2RTwvbjZ-fG5M&(IFi zN2DDfb${q-c`=_1mlq-ms5QZ?xY(p=Jf(%qy#k(QC3Bt1)diPTPdhx7sIGg1%fJ5s+}b-V0O zN+2CUI-YbYDV;QmG>$ZZG?`RPsvuoQnnMbc?jYSyT1xs0X(j1JQXA<_(tD(DNc%au z4Tg};1zjW847Y*QEPprYK~S{}T}Ag1s7AV|Mm;A^28E=X4pK994X9SSdeF6!<}-8! z=sM|s0L_$i;Cx+zGePR!=G7n-TF1~kLF(>I7igAD`x8Tda~sowRA?PY)$LA@O1qq{ z7j(VM<+R)JO%q9TKq~DYK`QNbkgD4bkUAR-SfJhKpgNg0^*`|2Mv}@%w}DjJw?QiB z{qNB3DA0{EMHcCHhOQ-jK>C;zcc;!Jk(3O&N#=JV-D#wAK;m~r_6dxm`yEJ?AVgOO zQf+lJU6@Y%qKj&mmq@RW-XwL9J|ulg`hqlIq0TRsbTG*Q-7L%eBuI^o*Xce6sge%A zOZQAI==UyM}HST@&4-bZ^pi z()~oY&mz5#lR&CXPotXwQe$lkLqB2YyZ7qe?{}ZhfS3n#is2xYVm#gD zAl3HGbWehQl>M>rk2>vxAmx4lsa#6`q}!l|bQ4I;bqnbhgH)MUk#;aNuteuFkaRHV z1kxp>t4KAZdq`~{wYRrHs?1qUdLNgNt{~NbRO{Xja!VQsZPxAv(zc~Kzu-eUG=~%> z-AQ_b^bgX(59_o?kY$DexREnjbTV&deAoqxW z41W#+E+H@;q(24t122$?{J_}Mu*$z-x z=9lpo?Lr{s-Uq1`I^%I&=I24m9rA>B&7?ugbuRaTZk0K&0jV+cI%x~3oAd)|zbAEy z!$_&5Gf82P+Q%y()f(S{9J$|wr*zw&N*V`hl%dyvRH>Gbwt!T-9Pl*0*)QWg2vY79 zkQy7$uh9Gb8l>J!EB&i(`xPLSVhc#6xMHQ=+cc0GO|wC_$$iWRsj;yRr21$F>43j! zcPdDgc`Dsp(xaqT81D^`+FLj1cDc9RAhoxIRl3zKA~k>($aweAJxppLtsuQXY9qZz z+5!3xncoj|vCruJ9z;3~r0RAy>3op7gO&-pL*`Pz&?eBG(yalh7T?a$ounR+%H=1} zLYd;YXZ7BOl7@j)yfL7=WV~{QhDfs*?-tPAGTt*F@r!!<1Uf;gEW1IfM*W}D6a!NG zI0UpvrZ|tGLDD$Jn*_R7#(R3T&iU}?^%%blbe{|jfz-&p1*G=d4!U24Zln7Sv{&|hOE=M zoI{!hS|(F02R$k&@$dM(1xXV@YR+*$D(7cGDn%FQF&S?cNVRF=dL8dVkcw9eYLW5o z2C07g81xtEek2{bLAzn3Owu&cY|?Vj<1&|5NZUz2kq&Ir@lGaduWeoSPj@SZHd)vX# zLq62*NYL{#zXDPS^n!GMV7#Y5D(AIy8$d70ct3ztneYEd)5D}TkSf7OP-~Pp8+-~< zSG|X93k23kcNVDzv{t%$kZQH3K`%+Sp43a)_hTKp0JKiVdy@1K={0KklmgWi%Uz67cK&iop`Cnnv+AeFWf zv`M-KkXjWy3VKJnNxga`R)XG@?n#hJ`wVFf=||8%WW0mE(fdsWsT7xxW{}EB_k&d0 z7LY1)7ejZG628^>-2_teOCzX5?)Nc}O8YTrjdU0OTi-FP0Ch??7o_4X0lg>PO1jrT z?@Jf6OQ%f)ZI7;up14+M7wY zfz&?kBR$5@r|I4x4ftN?G6XEB?s@;=iduKY9EjMr0E0FXQboy=+Fj`%H_2Heg{Y9w;iNfcW{(; zLqW=2NV*bKAXD5%dH|$ySw**ww4I@Q=+5n@bD0AASmswv_Ymm`(#xc`NP9>F`|JD; zAmx#&NjHPa<=&d;UL$P-70S@hKxLA?Wazh~e$hJK5ugGY?>M@XL24goGIS&nH zL%${c1af2x9X%k*JyI?LZI|w9&?l1WK&tH*fmEBWpnHR^leC@GZy%jD0i@CnC5<8F zFy5tflSzdPEvKs{&0=UhT?6TMhTco}N76$KeS&T!T`S!Nx;N=M=(f@Ap!=Hcd%Ea- zbsOvtQf)ezE{X1Vx|8Y7q&tr;i|%5&%jl-j{f_P$x*Oi`xx|zbiH)P4b*Kg45ZRdq`Qi4Hr*dcx0CK?yp?q6`{|rZKq}`- zQV68x@%41Ck=|nHf&1%RMuAi=S)?4$PShwN@F%*5Nslpf8%T}zs92p#3~3N(r_804 zu8LI4&}Zq^kk&Kwz(G3aMA8u;m2)v&8R;5^K27&5=|zTq0aB$;J0Qw^LOC6zTH{XA zQ=~UZUy}yL=@iF-RDKibX3{ODTMbfIcQ2FPC4EflA^k`i9Iy9rBS@8W9;uOZC+R*? z6KNUg3DQc^^Q3j8S4nS?I!RkepOOAa+6{6?$$^^ENT-tuL8?ZLpnu7ca~DG&AicuS zj}O-CgMX3^OwjunMjB5l0jYh|(cMh?GpUvFHq(7W+IO(dWe7;s?F71xtn zN!vi>at8TzLx+>jX1og+FPov4kS=4q0>-eDQfAiC;gsuE9rjHlOUCLBk4VcenhvE?kl?8bp40u zTn2&E@sU7xBwZTmY|{Cp9MVM6RMHGkg`9_~>FyylgH%1fCmo%n%W?)O8>HgRpsOR@ z!O*|Z1&`1vvPqYK)H?$4wr82UL#wZ_0BbuRIw!622(HFPscvl+UU?q$;J3_a{9 zopUnjIFOq&-AvMKhQ3C(iPXu^m}Fi0bdYMb^GTT?wU4{$9w0r)&`;>PNnbMbsH62h zP9znPt_P|8K1}y_x^~i=AXS!xV|0okq-2l^y$Dnw$Iw-zdr41#)ZRMjcG7)A8hEUZ zcQC08q;j55cNa*V{hkG>b7)+OPJ1e7iY&`W(pb_&QX#2|bPGuB?J?2|q@$11p_@Vf zl;_`XKx$=lHIJ!S!@^kXDg;K`NIKztJhqAzcVkWhn=#T3$z2N4kg93{v}j zfo?tB>mYRw=wRp;(kG1f1>^mjp}R@Zsd^u=AeG-CAXU;Kq+=QHB*r_Pp=XmWV7zgR zm&ee{NCk{n%6K&lok^O*cnyqq2Se{6Eg?NhdW!TMX&q@JNVV?wbp21zHQyhkX3<0F z3PCExJ#=g6+DNZ~)NvGlqE2xrDG8)P3+PHn|cm&N+c}7)a%OHC;97 zI)=VY_a5m(hNcYFIiEyI1MQT@M;YA%q@|=s8Sft;HHP*-S?Bi~kaD$jcY)N={UGTH z(rVJnq<2aEPSH6JBpm=!B|R9V_I3^_#CTn#f024YD(!b5mG8a0w?#moPcH zghSe;G|~uCI%y;+gOo|iB4v|uNqMA6q{*adq#{xYsf<)b3Xx`#>PT})b4d-PM$!V( zLee7AV$u@QQqnR~3u!rN1!)y&HK~=fj?_kKCv7BcB6W~9leUt!le$RVq#jZ)X%}fX zDbP=kh-gv_DV7vZN+2bYl1Ry<6jCZ_C@GCJf|O1Ye?v(f6&a*VQWhzjluODZO(IPu zO(PYNN=Rj-DpH6vlT=5VLz+u!AT^Q}kQR~_krtDdkd~5`ky=R0Nh?UJNUKS$q;;e= zQafoQX%ne~w3)P(w4KyN>L&G&dP%!TyGeomx~HQ_F{D^hJSl;cNJ=6llTt{jq@koV z(g;#IX(TCwlu61WWs`DAd8A3C$)stdB2o!S{5>}{?yE>4(o9kvX%1;Fse#l;T0mMz zT0~k*T0&Y%T1ILiEhnuYts<=^wUXA6+DPrBjigPa4$@}QR?>D-7pa@nL+T~%BJCyx zqIHYoPvW|5A47^I#gh_9iKHY_GAV_WN*YQ^BaI-XlSYyifm()ONBrPBCM_W?B`qVhkd~8HkXDgalUhmZNNuEc z(niuIQU_@>X)9?vsf*N2>LK-#c9C|I0t57@izda8VoC9&1X3a?iIhxAA*GUrlF~>c zNa>`JqzqCfDT|a%$|dEICXptSrjd$BC8RP^6)8lTNvb2wAdt!6 zq!>~xDV~%-N+czbl1V9~RMJpV8fgS6oivh^LCPd$k+Mm-q&(6j(qz&!QW2?yR7RRZ zT0mMtT25*uZ6s|a^^gMl>UNGNC6m%flb_RfQ>KxMNF}5)QWYsgnn|i7%^`KY6XpJ$ zp9Sygy)7gyA}uB@AuS~>Bejs0lQzAtbM7E*CT%5cCv}mQ?$BwMky=R0Nh?UJNUKS$ zq;;e=QafoQX%ne~w3(EQYj$y;Dd{)Iw?} zb(3N-bGiAEvPos6Mp6r@ozzVdGn|_rNz5wBiTOZLBdLYdPUPY9zIg+DYA{ z*aLMgLrK}BGEyU{h15>!CdD4a{7BiPGEyU{h15>!CdD4i{7BiPGEyU{h15>!CdDQ& zKTXOw2IV0+C@q{ zRHsNMO(M-CEhDv)x=FE#I+vlOY*HDik<>zJCv}rz4`Y6$Y*HDik<>!kNa`WQAFlID zBju8+NDD~INgGK$r1&AskCaQQA}t^-Cv7D4km8e=A1RkKleCDmiqt{cMM^nB=a)$; zA~ld&NaAk@s*$sclz60e>7>b|29o$|f+}qrsf!eIlnzZLWs%BAjilwIjig>uQnJo3 zlT<`%AT1-ck-A7RN9$ZtNm-;4QUhrfX)|dzDd`xU-$>GAQXOeAX*FpxX*Vh9SmsBX zOsXR-CaorIChaCAr7%CzWKtbzF=;hvGif&|={V*`noO!AEheodZ6@s|B^|Hx%OFi7 z%^@uzwUV}y0>9C@B$F~oMWjYj3#pydO^Qv``3)sylgdboNUKO4q+O(x6Lfx=q$1K> z(o)ho(sokxi8_~5QWmL%bjtM7vf_aH@25S1z>KKs8D-P2JEhQddV^_F{udQU4)l-G z*4(1w1E@wo#OWu4&d0wu_V=1RnA7+5nktwHSTRLX-3IfzVICIwU=NS{841>$=z@<1FN8)@5BhKE!s51Wq(`lH)(2@B#=SJe31TzZ5A!5#gIU93tBZF>voDX0=HH>%~vi4+eoc*H%fzngF=5Ux!!<+(h(W%}z zqhVe$%w(AKG;f@lFn=-39WciX^Tv4`<{rcR9VT|TH_m%7Hyh?(FuA9B<3tY#1g4Mh znk1Mdr+dvXn3ZRE%@~-w&-9urV6IK~n(JVq&+?i(VHO!i+-=xmm<=!&kMySc0Orhd zz2+;Jlg{&+eKD^*HOgy_g4yQ+uQ?OuOv8wKq^}s}5|{%ry{W`~&rHMI0CT--Fevcf zZ7>G~RVrngU>3TjpNz8tX61$6oL__ayJ5tg&;zr)alV47G|WKE`fnQMD3~M1dQ*ur z!yDtgCI@DRVJ5>A|JEC)9H!kcb7A7Ly>ae=xyvw5!=&VRcn?Fz4%1@rJ^uelB8eZwq; ziJ#()^E}LXhWQ6fnPI+yX);Xwekh?~Qel2H%ovzcuJrC}D$Kctxd!IotGsc-Fc%kk z&Al)kGrZ;rn8!=JW-ZLrQm^TRdB!kb!yNcKZ=8K`H*29`4u=_gwKvXCm^Tb_9!zGL zH_jz6uNbBXrlH&$XEw}+3a_~brlZnpo`AU$i?YZV+W-@Pjn{00xx+BKV16{r0kN3t zYP_kAhM8xW5ilPbCJSav$eU^s%qqi#U=FJF#+eH<%P@Drylt32!z`HTP4yzo=d--# z9hl7Py=Es&_y(^TFbKb(V3?y|&Z+apISXdFVe(*(o9&HL1#_QaZi9)t(HrN_Fmnyl z2J@X^K7*;a$(w551F$+Z%!x3Q=6K_r4Kvp;<6u@BrU2%xo4u)OVOn2_3PcC=YWWVB z{eJI_^B0)m^~$Joinyow<~*-?6{hYFUL)>yp6Yl_56t>TWz?A{Ar8M6Hs5Q~g}KdZ zE`oXbcCRUc`R+fw<_4IUJH6&kn5Bk!3MLcJ&muJycT)2V^8rkeVR~RfhUpiNb~eml zn1zN(g;{Etb6{2&<|3GNhPe`E4$iWoZB#p73$w|Ha|_JlZoO2T2Vf3csOqlFUty*g z=I=09-tCRE31*F9#NFSg@Aby{38vsr-c~*IKpcaHIUVMhCEhrf!93XHHFIFP40Aus z9gle9JO{JWHL4bGz!Wc2ag_N0CcVX*>RXscpYWOk4#Kt7lU{Qo%!7u>hFS5HH_mjJ zXASdvn2}F=<2(XWV3?O+7W~y4=L4A2S9;BNFoXZ*H3-EglQ5U8@y2-(W~E`?hPipI zH_oRpUm50Gm>Xa6#@TN$j+Av?a{^5LdapSj<~76o7UsSU-Z+zCX0&l{Kp8dDz6Z1PL$CP(=550aIRrOOwtC~70aNgi z*Nle=Zu6Q-m`1}mFgI`a#(5a#O~b5#ss6+pXA8^2R`3tXk2<8pLyae-wVLpV}|DWDeKf;_~n8OakJZ6~lV5S>pD$MnUnFDj1VV1yr zX_yybZu*yZ?;pT~d%Wh~Fn|BbYvK>beH+81!DM~yjgtd&gJDWwwiu>f#Od{>`V&m& zH(v8R%z$sb<~^7phWQ5OD#IiW!7tPqW(3T?43iCW(7(Mom%}vd@|xRVLf?7KvoOtu z`2yxg!^9<_7TlK2g4bLD(`}fmVa^%sjZ+76rD5)bX)(;hFtLYtQ#}LojB8ZAHo%-P zM8#3&J($^s`4VPMiZ@R5k+`2=m_uO_@NL(~71@a}*SSWuMkdUy_*QGA?w7+f8>R|o z@Nc|v>S2Z$<{p@%4f7<-Nv=_~SPS!Ys<%8HBGn0A^A*f?eE%;}=GdcfeTr}EMa=Oq z%kd38Wljkd&kSKLEB=eZ|NWy5PKyehGf)cmpHqqoLIp01vhPcQj$|ZP_)(3x8GeEp37}vCCa1P@Dewb_@vAX*NB+PT<0_MedZybdDdq-eC8XUiAxsyRsX5IpOCCS z>++oIGlf1g+h^|ana6#m-Df`cnZVHj{-;WKn9mIJnV`=U`;6l=5BkhnpZVBl#FJkA zpDN*yWAta;hNt?>7@wKsGuQgeLZA7Y&#d>EPM;CaK=gn8Bph@yGf%vzu6@R=`tCgwQ1%*j4;n$L{! znJavz(r0e*nI%5+H=lXKXL@~R|KokN@R_rHX1veT_{=M~`8c0B z+h;EFnX7zerqA5&GmrSp8lUO(nXi53z>{QJU%1#l>ze0TrjPpscL2(37($ zVPVxQ+tgIKh1NOyNaseM%!dv>PEQ(iDrS5(EBUS7(oD|1avWwow^ zGN@O1<+W}_WIk1u*D)Iv2eqhR5m{#4%x;{j>e7mkn^4BNuCT^xLt%{82%**0YB=Tk z>#q--Qd}~1dUZj0abW7TH5G1#Y6UyCW@15EY0>D)3b9bfW_sz2fC?I2QdwD3JmvyJ zjxR>{)RegKM}gvjBx5Sc1qrfE45E&`Ti=-1((R*NVC!&^UF8j0Itw@7ratkgS!~GN~`t;I@qMU-N zDs%vzR;o@7mKB$yoySyGkE@(j6Dk!|6!Bz_Gjdfybxkop$$E{gKuvyIJj+|L(Io}C z)nxF5!s^O0^h6{CGXty3%OONUmO;0moi37xmYW8j zCtzwUWGWShohzG3m(oq+X(V?)mKlwa8!A>(<)qAnP(ejeL3NQgB(oU9vT~MJO^^o} z`hoR8DIiot+xp7DPi?3Rus;o40L2fQv-`#U$ z?BrILmKRjdVu{?r;C_}fpruM?)sz+%luanTKGK|Sba^tY2w^6{i@dS`Xlges(%~3S zuJaAGNOWINB$YV`k%X-gsTLJSgltL{N`4w&fK`iXr{a*uNF~m96Kl(^F3{65&xeK; zyO*)X7uVF5g}h@``3b)B{CJGI((2-(u@yC#2n&n3B#0DW2N_EOw;yud4#+INwzRO= zolOctV&$TCrK+T+S~VIc)K*U~C`6aIHN%Ng1&paItkvU94q~OP6Q7%j>~K4Wv4t4j z(~Xm^ik?$2v$WhwGDa-tu96ERHGJ&c%mHMFW)_qe%;=*Qqsy@56RnDKh`)~RSo61v zGMUBG3(#?@(0U1lNjM@@yvS#7AG@b573hsPp#*F8B3Uw}F@9C7y@%wLhV*g6*rI(^ z1{i5710Ix&M8i0dqmz;LqO#FT`dq@eqiU*(3q#|@sN&9jo#&26RVW!6*#!$?_NbBM z;;Mqe(h!D@u-vs_-O=T3UL0qbc#FMC4>hktE4y8&@^^=aih?TuoPoJ`&BCnjO)HNI zuV8J|rGr&suVhSP)Uk4XTi;yATznzS30-c^gA5U!u$Le?9QP8YuaS6NVf2b@lD(vK zJ83VWx^sNN)_C%Ts}AsvA2UiWR`S7X(U0!5d1*musPE6>{9jq?Ue=)DLc#K?&@36( zoi3(|RnpYV;KZ>P*R)tQl~ooLWtU!6T~J*r zRtwW{w)T81l+mzW%`3R7OoS_uRa{n8T&;(e9Qb;kE-F^@%9!fP^8CCp>4Svg+>0l= zCA#>k-=UP5cyxyg%yPMimUW029Nfhrb#BGvURYgPr6vk@g{T*{DkF4kjXLSpOp;Yc zM~jn@jun_%B+t?+wjRG3>DqgZEQja~o!ICu_DP?inZ+SgO9$bYslZ3fZ{7|!<7AfB z;LOrTG~L(AhMl2@Jf}Q0#E`3NjOt@9jk@`z z$~vbO_wuY(ax?EMD7&)o>b`t_1@4mQkQsW(G$AxguB`Ou;7r#P%G-rw)w)v6(e8?? zI5eiVtPIVFt2woU;uA)xdv9ezNkNsk-jcU<#BC4BqiSYV z6k_IAf=OV+4Yg1nu5;b%(t<*HLBh|~#bw0>xV@&suak`+u0=8;$Mr>69A3+1lN>AK zi)WP9pg~k!Mwb=T7{_>iMfJ}|7+WK*V=HS)#nct75NFOJ+HS*RrecV7|N7Y^z^Y8md>+q zw{vj&QQT$cMZFQnTAmwW);iq?(`!Pt1M8souH21O-etNGu(!3n5y@E88zJlr4tOJ2 z6;dV_H|zTdQ_WDim(Yo&HKiEIeWuh6(RaRCcoc*C1XfBtLRs3E8xSTh_aRB<) z^}0DwSTzUx4^tHM7lXtdL96|cqrPFT?ra%_K`7=~9l=VfrZ2VAK7;K0<3`r*4A*CJ z*2T(Jc>AuYk*R2(Uy2}(vc285vNQV?_o$2{-Wi=YtGr7eJyXmm4&|24EG|>4cYWop z&f=bcz|?Zzle^JgwPO2jJiG_LyDV3~~Sb{}9 zaorwKZvT7I>6%`cEmxX&_fS5?yD-~$kcTn^Wehy+G;2=XSG^Hv)SI7my`}KiTWYi3 zQknIZiuI0sV!b2EsJGN^y}`H~sVXaQ?*(0`D=J^Zl$k5Vq2ce{iznn1*I>bA7Fb)e z%-VVegIDQx(azsAI)wE$1gmaXqxL$)Z2DkQVGDpb;Eh#oI} zKR1`TxHmZ6hoxfuURqv-e`;nHmCg_kd)4P`-p`mdDr1DUXm`)J7ZxG< zBID+Om}x32isT9|r=aF)xnNXD5Q-bc?hS;o71Jv(^#o!+m}G0qinH)&u&nsfNT%MY zAvhBOEJI|W5Gj{lf~pJniz-8<)A6uEUJ7Rn6Sq@j-Q{^xte-JvYH&+AvNtgf3qpk@ zZh)s8xy8j-(+*G5S>@o~ap?uKLdAKN;=YV{;G8j>&8HO>+d5u`T+Yg3pwig|IBSV# z`x(qpO>L1~vA*cRiKW${+JZ8iTP}^%Ij=ImqEtM&_3U^89-SAL=N5Q@In9{BdFBbSoV9G*B37KKFaQGdGVpj#VQ6XYRlcJ03%7P zI%+UV*l%hqWRA8*jw;0Hf~uNGqh#V5CRCg`I#Oy+-tI!L##1CusLD?47&kH0fI+ub z%qX@>CPrgqAfVFTy^UAbP*6WtIgv$VFCq(hyNK8Sk;G_@y@p*88HX_9C^w>@gz`D6AyG6XSyOQeEX5l-xDj0qD#X)5 zbw4VSPW8`TgM;$IdT)udiwmyZd)DqK8GC`=Y2#upb=7r4)BJZVujv5Xe41w?8Fsc&ug zL)>XoTp~n9GK%27MK!ayuvVN5{0VWEtMb$yCr!7KSoL|2QPI@63s+n1DUo}uYtNY+ zry1Oe5-%9ZXAMRbIDz6;v}Yu`Gn2Z_FYa$d`aQF{V1_)5$KYqOyhUPwHLipoQ(944 zQxe%Timz%K=}!@DRAC{O7$RfO6e@<0yk~`Jj%PG|f|Yl7lM~SQXoX`&Nq7TW|=yFF*i(NQ(L9lC z{99c%qwJK*Qv@^~)BRP54S!WDSM_6+5wEeQ9 z_LVOskE!SvxTU|q=%`cVC7XIzS^V2EASy643g4i75C7o5lmo=u(P`7X-=32J1CV-O z6-R!?KN*2(t=@0Y37a#A_%~`Q3?7>^CDn z{K&$5c!DT ztH?1;LdQ7 z0|6)4>kJa{oGHC)KJFLwY8boI<$9~WJ0{$}KG+*2_j6XTx9(-}7sn8J_scJ#PW9c1 zZvLS|)$ZM0Zx|r*6#p%7Bc|)R$KAdFx=B`&k6R124P#@6&1HKFfzGzh!fl{DYT!W zxuQ8lJ$6ojKq+?KwjtPq&w-t%$!a+HJ!`i0i`wX*h}|qqw=RrqPMQAT`e2W4oSwRu zWDVFdBExyDadU^`;6Rg#kH~A!#%4hf``ZFv(>G&?Z;Kj9#8)Q_afU52ZE=w;uCzs^ zEpD=f=rLor57^?*w)mSZUbIEKE#9|<7{$hJ@m+RP;7j19IKUQ(wm8}r`17b{9>Z;M zo-ML$A%1hyDCt$UsIWzyEyV9_8hPAfi>0=B$`&u$0>6-CX8Nuzw%ek|7UHKkje;G7 z$;}YQ+v0p%h#%cFk`&qE8bj=i(i2Bw6FOZUM;~H~!=}!N2obi$B3mr8#WS{e#TFmf z;wxK--|aN2bdW8QZ86Li=NrOb>ChO|@3%%Ih^e+HvqhaD{Q1VsyJt7Qggq?7hkszqiHRwh({a%gEz7TfAnAt+x2W z5PcOmh{Fb*^`j9HVn3{PjJ+RjixgXk9}hK>jI_mATTHe^l`Ur5V!kczv&BQUc*+)Q zZSjsRKC;EXY_ZQi-rDxnw5K8lTJmrsBE)c8WY|LdsV1W(e`gEvLuN*d+ikJb7UFkF zjU?-A@wP2KwuShWQX>zsx;8|TEzYn-mMyNZMU^eY&yyN^xziSp*y69YXtTw8w)mGV z#BY}xyB&n}pdpU7#p$*fYl}i#RNCTtTZmsVHFkTCEtcA1xh+=PqRkeYY$1O1)Yxse zEq2)=8dp9>k^^mVq%BUeMY=75wis`VskSJy#Z9)j!xj(O;%~NSv&DP1*lCL&ZE?VU zRs$v5Vwf#P+ak{v(`|8`EyVA$8vSygEm~~xye;0a#a3H|HCLl3;>TPKA%4p>BK&)fn|n9Tc-Yw{BO=5{w)oN(QG>jBBgy`@IK&pm z+G3 z+aembe~j85Xp19lG1L}k+ak*r6KzpqiyLgQz!neNVx=uM*y10y_{*A@@i;ze6* zw8aiv{9udtgRP<;V~D=y>L_&;H{6JbIWo%@(`->@i@CN~WQ!JCthGg_EqZLRA8tV# z-E+JxetEt(&pUlJi+gc9(#|{I79m^QZHpDQSZ|BBZ1KJ=x@_^CEuwL|+h~>qTO`|J zxGltQ;~IHPvxWE_TqDK;TQnP@ucj4$c^(7oNh2b}8@AYH3-NdNjJ-!4Vu?Yv5I>!3 zBstX&+9Jmm(`*s4#VxkD-xiPC zVy!LSvBeHsd~1v7M5}TK+Tti%47J7Cwis)R%WP3%iMXfDvw#99>xX%`k*kZLI{71aJ$NQEM2}k?qw&;f+ z{59Gr$q;?ydnvLRVMKz+w#5~;xYibP4bjJr4o1Fr{8A)wC;LGo62x=1c-t0V7-BCw zA27t*Hhn}AJ3qvT1aYD*#@J$_A^iEq&2`U%6-GqleX}j@u*Ji+_?s=>vc*4bF%ZwI zjWKbYEiSOdG+WHJh4?LHBhzPWA^wJ^5kvebPeUZ)w}cIGqAfBE(O1)oXKHB4|6NO) zE%~2bOZ(e8Bo5$Hg7#5P;(w#6ZM7H;h5 zG+X4_qTCRD6h+Jm|5ui9E$ZRg|7X|t@|5&{;c`mebZaoW1zm8zEtcD2y)8D|Lj1^g zWO(@dI&SXss!s;ug_}r3?ENrX47G*$>1`v)I9pt9i*j4k+u{yeG~42NL-bXpWIS3# z4K^7OA-Zhwqb&|hwyJczEzY*Z#kMH4#Y|f?+M>x8f3?Lcw)nsnU)y5eqpi9m*&@vr z;-|Qc9=*aA*Vy6~TRdQk6}EWQ7Tav`Z(Hntj8(8?Ta2*9SX*3ai)vfkVv7fC@w6>o zw#7DE?6JlFu8GVs_RDLcBaXFte}pZ5Ym2LF@yqL~`2KR%@XZOnDZn?c_zv(U`&jf% z627C=cX0ZSc;Ars4QStC<2yKg^P6uv^UaaI$;vl37237+%{;z|#y5NU4qxBF>6-$4 z2e@w<@g2{;!`F9!`({Ajgy)+QeG{HO zz&K0%!xmo{!kUP4{* zYa(6!Ya;#Omm-Oau?LJu5G!o)vLW_T>Mg$}QtvNBiko|ElpN{eFB%vJ%}`rhV2dkk zag8k+ZP8+j7j3c07TvapO0`OQge}grh4|CyM&+)yh4_O7MvNy7;qL;ziTQUUB6{;5 zw%B2d?`(0v3D(|^vc)i4WZL2~L-bYP_I|Rb%Z!L9aJ?-S+2V0qth2>tTkN#O_qG^# zqE+cbY$5(8g3&4BPa+s1*A~-kQEiI`Tij!dhi&m!TdcFi+qU@F7UHib7)9@Yk|hqc zMY=66wMC^ZZnZ_TE!Nm#lPx~CMZcj|Ne{P0nk}+yag{CVY_ZT5PuXIlAv`0zE5Ciu z9(=jO{U*wd{pC3CM)a=q*Y@mb##u~UZwF3>_>D&l5#kV!7$L*}kH`_C7rE;^3WfOC zBW4QmmPafRVvR?v5MsGUye`C_JmMoEZu5w5g_!LT`<((&<`F4ET;UO!LX7i>Vj<4* zh}lAq#Ge(MqM330YZd@IBW9ub=ck?0Xe3$d?9oFT-wuSBY! zBg7{jQ6j`9kEj#kC6BmYh^IVar4UUX@rn=&JYu^LH+e+#Fo+6|I8}%#9x+ykY>y}q z;vA2t6XHaVXcXcwk7yAh#v@vV`1i|^>i7zq8}L1~-=H*3 zkZJMVGkKWfyJgMMC|n<(>vu)f?u+nwt+TM3E_}Sv{YKh=RiZv_dJ*8pyXhC>A;NaV z|FseO{o08Ae{IC*Uy9hztaHD;)mg`L^V@5@{$_st_m-cI=jQh_@ys^-#fZ8M`-&*X zW&N)HHzl~#@5ZB>#Bjj(KW{vA!vN9E{qg^X0YVD$oQYI0oEt1DI>r31mdrPDx;hra z-FGlVf};`K^_Sgy_F(lOM){>1hzoJBx>n4VF1{MUYcQ9)_E4PFT%7Sbv1t=A{vG0z z?-8GWpEzjCo;_X8F7KJPBucIfM6o{F%7~|YL~M-U!x8*Cf`hg(?&T5u^T)LNe?mMi zf&~%$D1xVa%DA6IaQJ7mO%W{ZqFvZceBxikoe})BhxWxUiJcMrI)a0~VuY~~ER5jn z2tM{T<6hFcXOA8i1Lbg=*BUaW7CEQhJUb=|ubkAzZWz#t;Wr2W?>rbXAmn~ZWKaDZ`%s15_Uzc*}BhwWPEnw!}+aFZge<*os%0A&Tn&aW5fCF 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 Date: Fri, 11 May 2018 18:14:42 +0200 Subject: [PATCH 28/53] Updated raylib_icon resource --- games/Makefile | 2 +- games/drturtle/Makefile | 2 +- games/just_do/Makefile | 2 +- games/koala_seasons/Makefile | 2 +- games/light_my_ritual/Makefile | 2 +- games/skully_escape/Makefile | 2 +- games/transmission/Makefile | 2 +- games/wave_collector/Makefile | 2 +- projects/Notepad++/npes_saved.txt | Bin 11872 -> 11884 bytes 9 files changed, 8 insertions(+), 8 deletions(-) diff --git a/games/Makefile b/games/Makefile index c299e0657..b00f4382b 100644 --- a/games/Makefile +++ b/games/Makefile @@ -160,7 +160,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) ifeq ($(PLATFORM_OS),WINDOWS) # resources file contains windows exe icon # -Wl,--subsystem,windows hides the console window - CFLAGS += $(RAYLIB_PATH)/src/resources -Wl,--subsystem,windows + CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) CFLAGS += -no-pie -D_DEFAULT_SOURCE diff --git a/games/drturtle/Makefile b/games/drturtle/Makefile index 9a2486fea..bbc71eb92 100644 --- a/games/drturtle/Makefile +++ b/games/drturtle/Makefile @@ -160,7 +160,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) ifeq ($(PLATFORM_OS),WINDOWS) # resources file contains windows exe icon # -Wl,--subsystem,windows hides the console window - CFLAGS += $(RAYLIB_PATH)/src/resources -Wl,--subsystem,windows + CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) CFLAGS += -no-pie -D_DEFAULT_SOURCE diff --git a/games/just_do/Makefile b/games/just_do/Makefile index 3f764abc7..0237f4f9f 100644 --- a/games/just_do/Makefile +++ b/games/just_do/Makefile @@ -160,7 +160,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) ifeq ($(PLATFORM_OS),WINDOWS) # resources file contains windows exe icon # -Wl,--subsystem,windows hides the console window - CFLAGS += $(RAYLIB_PATH)/src/resources -Wl,--subsystem,windows + CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) CFLAGS += -no-pie -D_DEFAULT_SOURCE diff --git a/games/koala_seasons/Makefile b/games/koala_seasons/Makefile index 3f1e4561b..25e6dcbe5 100644 --- a/games/koala_seasons/Makefile +++ b/games/koala_seasons/Makefile @@ -160,7 +160,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) ifeq ($(PLATFORM_OS),WINDOWS) # resources file contains windows exe icon # -Wl,--subsystem,windows hides the console window - CFLAGS += $(RAYLIB_PATH)/src/resources -Wl,--subsystem,windows + CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) CFLAGS += -no-pie -D_DEFAULT_SOURCE diff --git a/games/light_my_ritual/Makefile b/games/light_my_ritual/Makefile index 43738ac02..f6fd4533a 100644 --- a/games/light_my_ritual/Makefile +++ b/games/light_my_ritual/Makefile @@ -160,7 +160,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) ifeq ($(PLATFORM_OS),WINDOWS) # resources file contains windows exe icon # -Wl,--subsystem,windows hides the console window - CFLAGS += $(RAYLIB_PATH)/src/resources -Wl,--subsystem,windows + CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) CFLAGS += -no-pie -D_DEFAULT_SOURCE diff --git a/games/skully_escape/Makefile b/games/skully_escape/Makefile index 2191114b4..98d4696a0 100644 --- a/games/skully_escape/Makefile +++ b/games/skully_escape/Makefile @@ -160,7 +160,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) ifeq ($(PLATFORM_OS),WINDOWS) # resources file contains windows exe icon # -Wl,--subsystem,windows hides the console window - CFLAGS += $(RAYLIB_PATH)/src/resources -Wl,--subsystem,windows + CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) CFLAGS += -no-pie -D_DEFAULT_SOURCE diff --git a/games/transmission/Makefile b/games/transmission/Makefile index 60ab1d0a8..4e998f0f4 100644 --- a/games/transmission/Makefile +++ b/games/transmission/Makefile @@ -160,7 +160,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) ifeq ($(PLATFORM_OS),WINDOWS) # resources file contains windows exe icon # -Wl,--subsystem,windows hides the console window - CFLAGS += $(RAYLIB_PATH)/src/resources -Wl,--subsystem,windows + CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) CFLAGS += -no-pie -D_DEFAULT_SOURCE diff --git a/games/wave_collector/Makefile b/games/wave_collector/Makefile index 035ce1010..78b2bbe53 100644 --- a/games/wave_collector/Makefile +++ b/games/wave_collector/Makefile @@ -160,7 +160,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) ifeq ($(PLATFORM_OS),WINDOWS) # resources file contains windows exe icon # -Wl,--subsystem,windows hides the console window - CFLAGS += $(RAYLIB_PATH)/src/resources -Wl,--subsystem,windows + CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) CFLAGS += -no-pie -D_DEFAULT_SOURCE diff --git a/projects/Notepad++/npes_saved.txt b/projects/Notepad++/npes_saved.txt index ecc5c524bfb909141e7dd742fa5c6f5da164a585..89cca10cce3e14565fb619ab430ac88f76c5efec 100644 GIT binary patch delta 44 ycmaD5^Co6P4clZV7MaOc_(jBH7>XDY87dia7%~}>7~+9sGDAK?-sbIWE7bu^?+tVS delta 40 scmaD8^B`tJ4cp`-9ihqh_{D@{7>XED8HyS58A^eyWDtAvVYZd(04PTd761SM From 245704df723343fd274f77589164c6e9984aef8b Mon Sep 17 00:00:00 2001 From: Ray Date: Fri, 11 May 2018 18:14:51 +0200 Subject: [PATCH 29/53] Reviewed examples --- examples/core/core_3d_camera_free.c | 1 + examples/core/core_3d_mode.c | 1 + examples/core/core_3d_picking.c | 1 + examples/core/core_input_keys.c | 8 ++++---- examples/models/models_mesh_picking.c | 1 + examples/models/models_obj_loading.c | 10 +++++----- 6 files changed, 13 insertions(+), 9 deletions(-) diff --git a/examples/core/core_3d_camera_free.c b/examples/core/core_3d_camera_free.c index 81f04c139..9131ddf87 100644 --- a/examples/core/core_3d_camera_free.c +++ b/examples/core/core_3d_camera_free.c @@ -26,6 +26,7 @@ int main() camera.target = (Vector3){ 0.0f, 0.0f, 0.0f }; // Camera looking at point camera.up = (Vector3){ 0.0f, 1.0f, 0.0f }; // Camera up vector (rotation towards target) camera.fovy = 45.0f; // Camera field-of-view Y + camera.type = CAMERA_PERSPECTIVE; // Camera mode type Vector3 cubePosition = { 0.0f, 0.0f, 0.0f }; diff --git a/examples/core/core_3d_mode.c b/examples/core/core_3d_mode.c index 705bcb7a4..39c0752ab 100644 --- a/examples/core/core_3d_mode.c +++ b/examples/core/core_3d_mode.c @@ -26,6 +26,7 @@ int main() camera.target = (Vector3){ 0.0f, 0.0f, 0.0f }; // Camera looking at point camera.up = (Vector3){ 0.0f, 1.0f, 0.0f }; // Camera up vector (rotation towards target) camera.fovy = 45.0f; // Camera field-of-view Y + camera.type = CAMERA_PERSPECTIVE; // Camera mode type Vector3 cubePosition = { 0.0f, 0.0f, 0.0f }; diff --git a/examples/core/core_3d_picking.c b/examples/core/core_3d_picking.c index cd390d917..1c63e2a7f 100644 --- a/examples/core/core_3d_picking.c +++ b/examples/core/core_3d_picking.c @@ -26,6 +26,7 @@ int main() camera.target = (Vector3){ 0.0f, 0.0f, 0.0f }; // Camera looking at point camera.up = (Vector3){ 0.0f, 1.0f, 0.0f }; // Camera up vector (rotation towards target) camera.fovy = 45.0f; // Camera field-of-view Y + camera.type = CAMERA_PERSPECTIVE; // Camera mode type Vector3 cubePosition = { 0.0f, 1.0f, 0.0f }; Vector3 cubeSize = { 2.0f, 2.0f, 2.0f }; diff --git a/examples/core/core_input_keys.c b/examples/core/core_input_keys.c index b2305246e..69384fd9e 100644 --- a/examples/core/core_input_keys.c +++ b/examples/core/core_input_keys.c @@ -30,10 +30,10 @@ int main() { // Update //---------------------------------------------------------------------------------- - if (IsKeyDown(KEY_RIGHT)) ballPosition.x += 0.8f; - if (IsKeyDown(KEY_LEFT)) ballPosition.x -= 0.8f; - if (IsKeyDown(KEY_UP)) ballPosition.y -= 0.8f; - if (IsKeyDown(KEY_DOWN)) ballPosition.y += 0.8f; + if (IsKeyDown(KEY_RIGHT)) ballPosition.x += 2.0f; + if (IsKeyDown(KEY_LEFT)) ballPosition.x -= 2.0f; + if (IsKeyDown(KEY_UP)) ballPosition.y -= 2.0f; + if (IsKeyDown(KEY_DOWN)) ballPosition.y += 2.0f; //---------------------------------------------------------------------------------- // Draw diff --git a/examples/models/models_mesh_picking.c b/examples/models/models_mesh_picking.c index 17b8812d6..56b9397a7 100644 --- a/examples/models/models_mesh_picking.c +++ b/examples/models/models_mesh_picking.c @@ -30,6 +30,7 @@ int main() camera.target = (Vector3){ 0.0f, 2.3f, 0.0f }; // Camera looking at point camera.up = (Vector3){ 0.0f, 1.6f, 0.0f }; // Camera up vector (rotation towards target) camera.fovy = 45.0f; // Camera field-of-view Y + camera.type = CAMERA_PERSPECTIVE; // Camera mode type Ray ray; // Picking ray diff --git a/examples/models/models_obj_loading.c b/examples/models/models_obj_loading.c index 4e9b29864..45eb3e98e 100644 --- a/examples/models/models_obj_loading.c +++ b/examples/models/models_obj_loading.c @@ -22,11 +22,11 @@ int main() // Define the camera to look into our 3d world Camera camera = { 0 }; - camera.position = (Vector3){ 3.0f, 3.0f, 3.0f }; - camera.target = (Vector3){ 0.0f, 1.5f, 0.0f }; - camera.up = (Vector3){ 0.0f, 1.0f, 0.0f }; - camera.fovy = 45.0f; - camera.type = CAMERA_PERSPECTIVE; + camera.position = (Vector3){ 3.0f, 3.0f, 3.0f }; // Camera position + camera.target = (Vector3){ 0.0f, 1.5f, 0.0f }; // Camera looking at point + camera.up = (Vector3){ 0.0f, 1.0f, 0.0f }; // Camera up vector (rotation towards target) + camera.fovy = 45.0f; // Camera field-of-view Y + camera.type = CAMERA_PERSPECTIVE; // Camera mode type Model dwarf = LoadModel("resources/model/dwarf.obj"); // Load OBJ model Texture2D texture = LoadTexture("resources/model/dwarf_diffuse.png"); // Load model texture From 2d6fb5c628068757387525e190c3afdbe33ae9c6 Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Fri, 11 May 2018 23:43:00 +0200 Subject: [PATCH 30/53] Revert "CMake: Build glfw separately with CMake" This reverts commit 0adb4b67de6dfe3f7a0a557130dffc3b8f4d6a43, because it failed tests for Alien::raylib: http://www.cpantesters.org/distro/A/Alien-raylib.html --- .travis.yml | 26 +++++++++++------------ src/CMakeLists.txt | 36 +++++++++++++++----------------- utils.cmake | 51 +++++++++++++++++++++++++++++++++------------- 3 files changed, 66 insertions(+), 47 deletions(-) mode change 100755 => 100644 src/CMakeLists.txt mode change 100755 => 100644 utils.cmake diff --git a/.travis.yml b/.travis.yml index 2d9a774f3..e5097e75d 100644 --- a/.travis.yml +++ b/.travis.yml @@ -18,18 +18,19 @@ matrix: - os: linux env: ARCH=amd64 GLFW=SYSTEM sudo: required - - os: linux - env: USE_WAYLAND=ON ARCH=amd64 - sudo: required - addons: - apt: - packages: - - libwayland-dev - - libxkbcommon-dev - - libegl1-mesa-dev - os: osx env: ARCH=universal +# - os: linux +# env: USE_WAYLAND=ON ARCH=amd64 +# sudo: required +# addons: +# apt: +# packages: +# - libwayland-dev +# - libxkbcommon-dev +# - libegl1-mesa-dev + before_script: before_install: @@ -37,12 +38,11 @@ before_install: sudo apt-get install -y gcc-multilib libasound2-dev:$ARCH libxcursor-dev:$ARCH libxinerama-dev:$ARCH mesa-common-dev:$ARCH - libx11-dev:$ARCH libxrandr-dev:$ARCH libxrandr2:$ARCH libxi-dev:$ARCH + libx11-dev:$ARCH libxrandr-dev:$ARCH libxi-dev:$ARCH libgl1-mesa-dev:$ARCH libglu1-mesa-dev:$ARCH; - if [ "$ARCH" == "i386" ]; then - export CMAKE_ARCH_ARGS='-DCMAKE_C_FLAGS=-m32 -DCMAKE_SYSTEM_LIBRARY_PATH=/usr/lib/i386-linux-gnu'; - fi; export RAYLIB_PACKAGE_SUFFIX="-Linux-$ARCH"; + if [ "$ARCH" == "i386" ]; then export CFLAGS="-m32"; fi; + if [ "$ARCH" == "amd64" ]; then export CFLAGS="-m64"; fi; if [ "$GLFW" == "SYSTEM" ]; then wget 'http://ftp.de.debian.org/debian/pool/main/g/glfw3/libglfw3_3.2.1-1_amd64.deb'; wget 'http://ftp.de.debian.org/debian/pool/main/g/glfw3/libglfw3-dev_3.2.1-1_amd64.deb'; diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt old mode 100755 new mode 100644 index e6501dc50..0e3411ee9 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -10,28 +10,16 @@ include("CMakeOptions.txt") configure_file(config.h.in ${CMAKE_BINARY_DIR}/cmake/config.h) include_directories(${CMAKE_BINARY_DIR}) -if(MACOS_FATLIB) - if (CMAKE_OSX_ARCHITECTURES) - message(FATAL_ERROR "User supplied -DCMAKE_OSX_ARCHITECTURES overrides -DMACOS_FATLIB=ON") - else() - SET(CMAKE_OSX_ARCHITECTURES "x86_64;i386") - endif() -endif() - -if(NOT glfw3_FOUND) - set(GLFW_BUILD_DOCS OFF CACHE BOOL "" FORCE) - set(GLFW_BUILD_TESTS OFF CACHE BOOL "" FORCE) - set(GLFW_BUILD_EXAMPLES OFF CACHE BOOL "" FORCE) - set(GLFW_USE_WAYLAND ${USE_WAYLAND} CACHE BOOL "" FORCE) - - add_subdirectory(external/glfw) -endif() - include("../utils.cmake") # Get the sources together file(GLOB raylib_sources *.c) -list(REMOVE_ITEM raylib_sources ${CMAKE_CURRENT_SOURCE_DIR}/rglfw.c) + +if(glfw3_FOUND) + list(REMOVE_ITEM raylib_sources ${CMAKE_CURRENT_SOURCE_DIR}/rglfw.c) +else() + include_directories(external/glfw/include) +endif() if(USE_AUDIO) file(GLOB stb_vorbis external/stb_vorbis.c) @@ -63,6 +51,7 @@ if(${PLATFORM} MATCHES "Desktop") # See: https://github.com/raysan5/raylib/issues/341 if(APPLE) set(GRAPHICS "GRAPHICS_API_OPENGL_33") + set_source_files_properties(rglfw.c PROPERTIES COMPILE_FLAGS "-x objective-c") link_libraries("${LIBS_PRIVATE}") elseif(WIN32) add_definitions(-D_CRT_SECURE_NO_WARNINGS) @@ -87,6 +76,14 @@ elseif(${PLATFORM} MATCHES "Raspberry Pi") set(GRAPHICS "GRAPHICS_API_OPENGL_ES2") endif() +if(MACOS_FATLIB) + if (CMAKE_OSX_ARCHITECTURES) + message(FATAL_ERROR "User supplied -DCMAKE_OSX_ARCHITECTURES overrides -DMACOS_FATLIB=ON") + else() + SET(CMAKE_OSX_ARCHITECTURES "x86_64;i386") + endif() +endif() + # Which platform? if(${PLATFORM} MATCHES "PLATFORM_DESKTOP") @@ -103,7 +100,7 @@ if(${PLATFORM} MATCHES "PLATFORM_DESKTOP") set(CMAKE_INSTALL_RPATH_USE_LINK_PATH TRUE) set(CMAKE_MACOSX_RPATH ON) - target_link_libraries(${RAYLIB}_shared ${LIBS_PRIVATE} glfw) + target_link_libraries(${RAYLIB}_shared ${LIBS_PRIVATE}) if (UNIX AND ${FILESYSTEM_LACKS_SYMLINKS}) MESSAGE(WARNING "Can't version UNIX shared library on file system without symlink support") else() @@ -140,7 +137,6 @@ if(${PLATFORM} MATCHES "PLATFORM_DESKTOP") ) set(PKG_CONFIG_LIBS_PRIVATE ${__PKG_CONFIG_LIBS_PRIVATE}) - target_link_libraries(${RAYLIB} glfw) if (WITH_PIC) set_property(TARGET ${RAYLIB} PROPERTY POSITION_INDEPENDENT_CODE ON) diff --git a/utils.cmake b/utils.cmake old mode 100755 new mode 100644 index 27f74e682..71e34e016 --- a/utils.cmake +++ b/utils.cmake @@ -17,24 +17,47 @@ if(APPLE) elseif(WIN32) # no pkg-config --static on Windows yet... else() + if(USE_WAYLAND) + set(_GLFW_WAYLAND 1) + else() + set(_GLFW_X11 1) + endif() + find_library(pthread NAMES pthread) find_package(OpenGL QUIET) if ("${OPENGL_LIBRARIES}" STREQUAL "") - set(OPENGL_LIBRARIES "GL") - endif() - - include_directories(${OPENGL_INCLUDE_DIR}) - - if ("${CMAKE_SYSTEM_NAME}" MATCHES "(Net|Open)BSD") - find_library(OSS_LIBRARY ossaudio) - endif() - - set(LIBS_PRIVATE m pthread ${OPENGL_LIBRARIES} ${OSS_LIBRARY}) - # TODO: maybe read those out of glfw's cmake config? - if(USE_WAYLAND) - set(LIBS_PRIVATE ${LIBS_PRIVATE} wayland-client wayland-cursor wayland-egl) + if(NOT USE_WAYLAND) + # CFLAGS=-m32 cmake on Linux fails for some reason, so fallback to hardcoding + set(LIBS_PRIVATE m pthread GL X11 Xrandr Xinerama Xi Xxf86vm Xcursor) + else() + # CFLAGS=-m32 cmake on Linux fails for some reason, so fallback to hardcoding + set(LIBS_PRIVATE m pthread GL wayland-client wayland-cursor wayland-egl) + endif() else() - set(LIBS_PRIVATE ${LIBS_PRIVATE} X11 Xrandr Xinerama Xi Xxf86vm Xcursor) + if(NOT USE_WAYLAND) + find_package(X11 REQUIRED X11) + find_library(XRANDR_LIBRARY Xrandr) + find_library(XI_LIBRARY Xi) + find_library(XINERAMA_LIBRARY Xinerama) + find_library(XXF86VM_LIBRARY Xxf86vm) + find_library(XCURSOR_LIBRARY Xcursor) + else() + find_library(WAYLAND_CLIENT_LIBRARY wayland-client) + find_library(WAYLAND_CURSOR_LIBRARY wayland-cursor) + find_library(WAYLAND_EGL_LIBRARY wayland-egl) + endif() + + include_directories(${OPENGL_INCLUDE_DIR}) + + if ("${CMAKE_SYSTEM_NAME}" MATCHES "(Net|Open)BSD") + find_library(OSS_LIBRARY ossaudio) + endif() + + if(NOT USE_WAYLAND) + set(LIBS_PRIVATE m ${pthread} ${OPENGL_LIBRARIES} ${X11_LIBRARIES} ${XRANDR_LIBRARY} ${XINERAMA_LIBRARY} ${XI_LIBRARY} ${XXF86VM_LIBRARY} ${XCURSOR_LIBRARY} ${OSS_LIBRARY}) + else() + set(LIBS_PRIVATE m ${pthread} ${OPENGL_LIBRARIES} ${WAYLAND_CLIENT_LIBRARY} ${WAYLAND_CURSOR_LIBRARY} ${WAYLAND_EGL_LIBRARY} ${OSS_LIBRARY}) + endif() endif() endif() From c1b9104d54814b4084e0d7b113918a6d014e807e Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Sat, 12 May 2018 11:41:12 +0200 Subject: [PATCH 31/53] Makefile: Remove unnecessary -no-pie for older GCC support Currently, if: * GCC doesn't supports -no-pie: Build error * GCC supports -no-pie * GCC is not configured with --enable-default-pie: No-op * GCC is configured with --enable-default-pie: Slightly worse performance because we still generate -fpie code (-pie affects linker, -fpie affects compiler) So instead of probing for existence of -fno-pie -no-pie, remove it altogether. Fixes #540: Build breakage on Debian 8 with gcc 4.9. --- examples/Makefile | 2 +- games/Makefile | 2 +- games/drturtle/Makefile | 2 +- games/just_do/Makefile | 2 +- games/koala_seasons/Makefile | 2 +- games/light_my_ritual/Makefile | 2 +- games/skully_escape/Makefile | 2 +- games/transmission/Makefile | 2 +- games/wave_collector/Makefile | 2 +- templates/advance_game/Makefile | 2 +- templates/simple_game/Makefile | 2 +- templates/standard_game/Makefile | 2 +- 12 files changed, 12 insertions(+), 12 deletions(-) diff --git a/examples/Makefile b/examples/Makefile index d283e8077..64cec3d17 100644 --- a/examples/Makefile +++ b/examples/Makefile @@ -215,7 +215,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) #CC = clang endif ifeq ($(RAYLIB_LIBTYPE),STATIC) - CFLAGS += -no-pie -D_DEFAULT_SOURCE + CFLAGS += -D_DEFAULT_SOURCE endif ifeq ($(RAYLIB_LIBTYPE),SHARED) # Explicitly enable runtime link to libraylib.so diff --git a/games/Makefile b/games/Makefile index b00f4382b..c14ff36c7 100644 --- a/games/Makefile +++ b/games/Makefile @@ -163,7 +163,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) - CFLAGS += -no-pie -D_DEFAULT_SOURCE + CFLAGS += -D_DEFAULT_SOURCE endif endif ifeq ($(PLATFORM),PLATFORM_RPI) diff --git a/games/drturtle/Makefile b/games/drturtle/Makefile index bbc71eb92..242d0c5c1 100644 --- a/games/drturtle/Makefile +++ b/games/drturtle/Makefile @@ -163,7 +163,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) - CFLAGS += -no-pie -D_DEFAULT_SOURCE + CFLAGS += -D_DEFAULT_SOURCE endif endif ifeq ($(PLATFORM),PLATFORM_RPI) diff --git a/games/just_do/Makefile b/games/just_do/Makefile index 0237f4f9f..d5481e51e 100644 --- a/games/just_do/Makefile +++ b/games/just_do/Makefile @@ -163,7 +163,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) - CFLAGS += -no-pie -D_DEFAULT_SOURCE + CFLAGS += -D_DEFAULT_SOURCE endif endif ifeq ($(PLATFORM),PLATFORM_RPI) diff --git a/games/koala_seasons/Makefile b/games/koala_seasons/Makefile index 25e6dcbe5..3dd299fd9 100644 --- a/games/koala_seasons/Makefile +++ b/games/koala_seasons/Makefile @@ -163,7 +163,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) - CFLAGS += -no-pie -D_DEFAULT_SOURCE + CFLAGS += -D_DEFAULT_SOURCE endif endif ifeq ($(PLATFORM),PLATFORM_RPI) diff --git a/games/light_my_ritual/Makefile b/games/light_my_ritual/Makefile index f6fd4533a..cdd961293 100644 --- a/games/light_my_ritual/Makefile +++ b/games/light_my_ritual/Makefile @@ -163,7 +163,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) - CFLAGS += -no-pie -D_DEFAULT_SOURCE + CFLAGS += -D_DEFAULT_SOURCE endif endif ifeq ($(PLATFORM),PLATFORM_RPI) diff --git a/games/skully_escape/Makefile b/games/skully_escape/Makefile index 98d4696a0..74521e7b8 100644 --- a/games/skully_escape/Makefile +++ b/games/skully_escape/Makefile @@ -163,7 +163,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) - CFLAGS += -no-pie -D_DEFAULT_SOURCE + CFLAGS += -D_DEFAULT_SOURCE endif endif ifeq ($(PLATFORM),PLATFORM_RPI) diff --git a/games/transmission/Makefile b/games/transmission/Makefile index 4e998f0f4..2ba9afd9c 100644 --- a/games/transmission/Makefile +++ b/games/transmission/Makefile @@ -163,7 +163,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) - CFLAGS += -no-pie -D_DEFAULT_SOURCE + CFLAGS += -D_DEFAULT_SOURCE endif endif ifeq ($(PLATFORM),PLATFORM_RPI) diff --git a/games/wave_collector/Makefile b/games/wave_collector/Makefile index 78b2bbe53..9f03e62e0 100644 --- a/games/wave_collector/Makefile +++ b/games/wave_collector/Makefile @@ -163,7 +163,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) - CFLAGS += -no-pie -D_DEFAULT_SOURCE + CFLAGS += -D_DEFAULT_SOURCE endif endif ifeq ($(PLATFORM),PLATFORM_RPI) diff --git a/templates/advance_game/Makefile b/templates/advance_game/Makefile index 181f9dfbf..61a59bc2a 100644 --- a/templates/advance_game/Makefile +++ b/templates/advance_game/Makefile @@ -163,7 +163,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) - CFLAGS += -no-pie -D_DEFAULT_SOURCE + CFLAGS += -D_DEFAULT_SOURCE endif endif ifeq ($(PLATFORM),PLATFORM_RPI) diff --git a/templates/simple_game/Makefile b/templates/simple_game/Makefile index 4cd435ea4..1b5126706 100644 --- a/templates/simple_game/Makefile +++ b/templates/simple_game/Makefile @@ -163,7 +163,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) - CFLAGS += -no-pie -D_DEFAULT_SOURCE + CFLAGS += -D_DEFAULT_SOURCE endif endif ifeq ($(PLATFORM),PLATFORM_RPI) diff --git a/templates/standard_game/Makefile b/templates/standard_game/Makefile index e18703b25..7046233ca 100644 --- a/templates/standard_game/Makefile +++ b/templates/standard_game/Makefile @@ -163,7 +163,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) CFLAGS += $(RAYLIB_PATH)/src/raylib_icon -Wl,--subsystem,windows endif ifeq ($(PLATFORM_OS),LINUX) - CFLAGS += -no-pie -D_DEFAULT_SOURCE + CFLAGS += -D_DEFAULT_SOURCE endif endif ifeq ($(PLATFORM),PLATFORM_RPI) From 0f1aaa474a0d81ccb8c7fd74d856cd42e48cb3b0 Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Sat, 12 May 2018 15:39:13 +0200 Subject: [PATCH 32/53] CMake: (Properly) build glfw separately with CMake This reverts commit 2d6fb5c628068757387525e190c3afdbe33ae9c6, and adds a fix for Alien::raylib's test failures. The tests failed because the resulting static library didn't reexport GLFW symbols. As a fix, we now have GLFW create a CMake "object library" target that we can link with both the static and shared raylib. This is arguably ugly... Proper fix would probably be a GLFW upstream object library target. Closes #536. --- .travis.yml | 27 ++++++++------- src/CMakeLists.txt | 40 ++++++++++++++-------- src/external/glfw/src/CMakeLists.txt | 16 +++++---- utils.cmake | 51 ++++++++-------------------- 4 files changed, 63 insertions(+), 71 deletions(-) mode change 100644 => 100755 src/CMakeLists.txt mode change 100644 => 100755 utils.cmake diff --git a/.travis.yml b/.travis.yml index e5097e75d..3cfce867c 100644 --- a/.travis.yml +++ b/.travis.yml @@ -18,19 +18,18 @@ matrix: - os: linux env: ARCH=amd64 GLFW=SYSTEM sudo: required + - os: linux + env: USE_WAYLAND=ON ARCH=amd64 + sudo: required + addons: + apt: + packages: + - libwayland-dev + - libxkbcommon-dev + - libegl1-mesa-dev - os: osx env: ARCH=universal -# - os: linux -# env: USE_WAYLAND=ON ARCH=amd64 -# sudo: required -# addons: -# apt: -# packages: -# - libwayland-dev -# - libxkbcommon-dev -# - libegl1-mesa-dev - before_script: before_install: @@ -38,11 +37,12 @@ before_install: sudo apt-get install -y gcc-multilib libasound2-dev:$ARCH libxcursor-dev:$ARCH libxinerama-dev:$ARCH mesa-common-dev:$ARCH - libx11-dev:$ARCH libxrandr-dev:$ARCH libxi-dev:$ARCH + libx11-dev:$ARCH libxrandr-dev:$ARCH libxrandr2:$ARCH libxi-dev:$ARCH libgl1-mesa-dev:$ARCH libglu1-mesa-dev:$ARCH; + if [ "$ARCH" == "i386" ]; then + export CMAKE_ARCH_ARGS='-DCMAKE_C_FLAGS=-m32 -DCMAKE_SYSTEM_LIBRARY_PATH=/usr/lib/i386-linux-gnu'; + fi; export RAYLIB_PACKAGE_SUFFIX="-Linux-$ARCH"; - if [ "$ARCH" == "i386" ]; then export CFLAGS="-m32"; fi; - if [ "$ARCH" == "amd64" ]; then export CFLAGS="-m64"; fi; if [ "$GLFW" == "SYSTEM" ]; then wget 'http://ftp.de.debian.org/debian/pool/main/g/glfw3/libglfw3_3.2.1-1_amd64.deb'; wget 'http://ftp.de.debian.org/debian/pool/main/g/glfw3/libglfw3-dev_3.2.1-1_amd64.deb'; @@ -71,6 +71,7 @@ script: - if [ "$GLFW" != "SYSTEM" ]; then make package; fi; - sudo make install - pkg-config --static --libs raylib + - nm -g release/libraylib.a | grep glfwGetProcAddress || (echo "libraylib.a doesn't contain GLFW symbols! Aborting..." && false) deploy: provider: releases diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt old mode 100644 new mode 100755 index 0e3411ee9..675e060c7 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -10,17 +10,37 @@ include("CMakeOptions.txt") configure_file(config.h.in ${CMAKE_BINARY_DIR}/cmake/config.h) include_directories(${CMAKE_BINARY_DIR}) -include("../utils.cmake") +if(MACOS_FATLIB) + if (CMAKE_OSX_ARCHITECTURES) + message(FATAL_ERROR "User supplied -DCMAKE_OSX_ARCHITECTURES overrides -DMACOS_FATLIB=ON") + else() + SET(CMAKE_OSX_ARCHITECTURES "x86_64;i386") + endif() +endif() # Get the sources together file(GLOB raylib_sources *.c) +list(REMOVE_ITEM raylib_sources ${CMAKE_CURRENT_SOURCE_DIR}/rglfw.c) -if(glfw3_FOUND) - list(REMOVE_ITEM raylib_sources ${CMAKE_CURRENT_SOURCE_DIR}/rglfw.c) -else() +if(NOT glfw3_FOUND) + set(GLFW_BUILD_DOCS OFF CACHE BOOL "" FORCE) + set(GLFW_BUILD_TESTS OFF CACHE BOOL "" FORCE) + set(GLFW_BUILD_EXAMPLES OFF CACHE BOOL "" FORCE) + set(GLFW_INSTALL OFF CACHE BOOL "" FORCE) + set(BUILD_SHARED_LIBS OFF CACHE BOOL " " FORCE) + set(GLFW_USE_WAYLAND ${USE_WAYLAND} CACHE BOOL "" FORCE) + if (USE_PIC OR SHARED) + set(CMAKE_POSITION_INDEPENDENT_CODE ON) + endif() + + add_subdirectory(external/glfw) include_directories(external/glfw/include) + + list(APPEND raylib_sources $) endif() +include("../utils.cmake") + if(USE_AUDIO) file(GLOB stb_vorbis external/stb_vorbis.c) file(GLOB mini_al external/mini_al.c ${stb_vorbis}) @@ -51,7 +71,6 @@ if(${PLATFORM} MATCHES "Desktop") # See: https://github.com/raysan5/raylib/issues/341 if(APPLE) set(GRAPHICS "GRAPHICS_API_OPENGL_33") - set_source_files_properties(rglfw.c PROPERTIES COMPILE_FLAGS "-x objective-c") link_libraries("${LIBS_PRIVATE}") elseif(WIN32) add_definitions(-D_CRT_SECURE_NO_WARNINGS) @@ -76,14 +95,6 @@ elseif(${PLATFORM} MATCHES "Raspberry Pi") set(GRAPHICS "GRAPHICS_API_OPENGL_ES2") endif() -if(MACOS_FATLIB) - if (CMAKE_OSX_ARCHITECTURES) - message(FATAL_ERROR "User supplied -DCMAKE_OSX_ARCHITECTURES overrides -DMACOS_FATLIB=ON") - else() - SET(CMAKE_OSX_ARCHITECTURES "x86_64;i386") - endif() -endif() - # Which platform? if(${PLATFORM} MATCHES "PLATFORM_DESKTOP") @@ -100,7 +111,7 @@ if(${PLATFORM} MATCHES "PLATFORM_DESKTOP") set(CMAKE_INSTALL_RPATH_USE_LINK_PATH TRUE) set(CMAKE_MACOSX_RPATH ON) - target_link_libraries(${RAYLIB}_shared ${LIBS_PRIVATE}) + target_link_libraries(${RAYLIB}_shared ${LIBS_PRIVATE} glfw ${GLFW_LIBRARIES}) if (UNIX AND ${FILESYSTEM_LACKS_SYMLINKS}) MESSAGE(WARNING "Can't version UNIX shared library on file system without symlink support") else() @@ -137,6 +148,7 @@ if(${PLATFORM} MATCHES "PLATFORM_DESKTOP") ) set(PKG_CONFIG_LIBS_PRIVATE ${__PKG_CONFIG_LIBS_PRIVATE}) + target_link_libraries(${RAYLIB} glfw ${GLFW_LIBRARIES}) if (WITH_PIC) set_property(TARGET ${RAYLIB} PROPERTY POSITION_INDEPENDENT_CODE ON) diff --git a/src/external/glfw/src/CMakeLists.txt b/src/external/glfw/src/CMakeLists.txt index 22ce68f1b..6d3e33a50 100644 --- a/src/external/glfw/src/CMakeLists.txt +++ b/src/external/glfw/src/CMakeLists.txt @@ -92,7 +92,9 @@ if (${CMAKE_C_COMPILER_ID} STREQUAL GNU OR ${CMAKE_C_COMPILER_ID} STREQUAL Clang COMPILE_FLAGS -Wdeclaration-after-statement) endif() -add_library(glfw ${glfw_SOURCES} ${glfw_HEADERS}) +add_library(glfw_objlib OBJECT ${glfw_SOURCES} ${glfw_HEADERS}) +add_library(glfw $) + set_target_properties(glfw PROPERTIES OUTPUT_NAME ${GLFW_LIB_NAME} VERSION ${GLFW_VERSION} @@ -100,11 +102,11 @@ set_target_properties(glfw PROPERTIES POSITION_INDEPENDENT_CODE ON FOLDER "GLFW3") -target_compile_definitions(glfw PRIVATE _GLFW_USE_CONFIG_H) -target_include_directories(glfw PUBLIC +target_compile_definitions(glfw_objlib PRIVATE _GLFW_USE_CONFIG_H) +target_include_directories(glfw_objlib PUBLIC "$" "$/include>") -target_include_directories(glfw PRIVATE +target_include_directories(glfw_objlib PRIVATE "${GLFW_SOURCE_DIR}/src" "${GLFW_BINARY_DIR}/src" ${glfw_INCLUDE_DIRS}) @@ -113,11 +115,11 @@ target_include_directories(glfw PRIVATE # the inclusion of stddef.h (by glfw3.h), which is itself included before # win32_platform.h. We define them here until a saner solution can be found # NOTE: MinGW-w64 and Visual C++ do /not/ need this hack. -target_compile_definitions(glfw PRIVATE +target_compile_definitions(glfw_objlib PRIVATE "$<$:UNICODE;WINVER=0x0501>") # Enable a reasonable set of warnings (no, -Wextra is not reasonable) -target_compile_options(glfw PRIVATE +target_compile_options(glfw_objlib PRIVATE "$<$:-Wall>" "$<$:-Wall>") @@ -135,7 +137,7 @@ if (BUILD_SHARED_LIBS) endif() elseif (APPLE) # Add -fno-common to work around a bug in Apple's GCC - target_compile_options(glfw PRIVATE "-fno-common") + target_compile_options(glfw_objlib PRIVATE "-fno-common") set_target_properties(glfw PROPERTIES INSTALL_NAME_DIR "lib${LIB_SUFFIX}") diff --git a/utils.cmake b/utils.cmake old mode 100644 new mode 100755 index 71e34e016..27f74e682 --- a/utils.cmake +++ b/utils.cmake @@ -17,47 +17,24 @@ if(APPLE) elseif(WIN32) # no pkg-config --static on Windows yet... else() - if(USE_WAYLAND) - set(_GLFW_WAYLAND 1) - else() - set(_GLFW_X11 1) - endif() - find_library(pthread NAMES pthread) find_package(OpenGL QUIET) if ("${OPENGL_LIBRARIES}" STREQUAL "") - if(NOT USE_WAYLAND) - # CFLAGS=-m32 cmake on Linux fails for some reason, so fallback to hardcoding - set(LIBS_PRIVATE m pthread GL X11 Xrandr Xinerama Xi Xxf86vm Xcursor) - else() - # CFLAGS=-m32 cmake on Linux fails for some reason, so fallback to hardcoding - set(LIBS_PRIVATE m pthread GL wayland-client wayland-cursor wayland-egl) - endif() + set(OPENGL_LIBRARIES "GL") + endif() + + include_directories(${OPENGL_INCLUDE_DIR}) + + if ("${CMAKE_SYSTEM_NAME}" MATCHES "(Net|Open)BSD") + find_library(OSS_LIBRARY ossaudio) + endif() + + set(LIBS_PRIVATE m pthread ${OPENGL_LIBRARIES} ${OSS_LIBRARY}) + # TODO: maybe read those out of glfw's cmake config? + if(USE_WAYLAND) + set(LIBS_PRIVATE ${LIBS_PRIVATE} wayland-client wayland-cursor wayland-egl) else() - if(NOT USE_WAYLAND) - find_package(X11 REQUIRED X11) - find_library(XRANDR_LIBRARY Xrandr) - find_library(XI_LIBRARY Xi) - find_library(XINERAMA_LIBRARY Xinerama) - find_library(XXF86VM_LIBRARY Xxf86vm) - find_library(XCURSOR_LIBRARY Xcursor) - else() - find_library(WAYLAND_CLIENT_LIBRARY wayland-client) - find_library(WAYLAND_CURSOR_LIBRARY wayland-cursor) - find_library(WAYLAND_EGL_LIBRARY wayland-egl) - endif() - - include_directories(${OPENGL_INCLUDE_DIR}) - - if ("${CMAKE_SYSTEM_NAME}" MATCHES "(Net|Open)BSD") - find_library(OSS_LIBRARY ossaudio) - endif() - - if(NOT USE_WAYLAND) - set(LIBS_PRIVATE m ${pthread} ${OPENGL_LIBRARIES} ${X11_LIBRARIES} ${XRANDR_LIBRARY} ${XINERAMA_LIBRARY} ${XI_LIBRARY} ${XXF86VM_LIBRARY} ${XCURSOR_LIBRARY} ${OSS_LIBRARY}) - else() - set(LIBS_PRIVATE m ${pthread} ${OPENGL_LIBRARIES} ${WAYLAND_CLIENT_LIBRARY} ${WAYLAND_CURSOR_LIBRARY} ${WAYLAND_EGL_LIBRARY} ${OSS_LIBRARY}) - endif() + set(LIBS_PRIVATE ${LIBS_PRIVATE} X11 Xrandr Xinerama Xi Xxf86vm Xcursor) endif() endif() From eed170f85217b38bd0ff8091325dcaf06fd61608 Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Sat, 12 May 2018 18:51:26 +0200 Subject: [PATCH 33/53] CMake: Fix typo... s/USE_PIC/WITH_PIC/ --- src/CMakeLists.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 675e060c7..e8379ab0b 100755 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -29,7 +29,7 @@ if(NOT glfw3_FOUND) set(GLFW_INSTALL OFF CACHE BOOL "" FORCE) set(BUILD_SHARED_LIBS OFF CACHE BOOL " " FORCE) set(GLFW_USE_WAYLAND ${USE_WAYLAND} CACHE BOOL "" FORCE) - if (USE_PIC OR SHARED) + if (WITH_PIC OR SHARED) set(CMAKE_POSITION_INDEPENDENT_CODE ON) endif() From bb43755a9df89fab3018c5684d9a38ae5b52397b Mon Sep 17 00:00:00 2001 From: Ray Date: Sat, 12 May 2018 23:33:03 +0200 Subject: [PATCH 34/53] Corrected issue on LoadASTC() --- src/textures.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/textures.c b/src/textures.c index cb566c5e8..7344e74b9 100644 --- a/src/textures.c +++ b/src/textures.c @@ -2674,7 +2674,7 @@ static Image LoadASTC(const char *fileName) fread(image.data, dataSize, 1, astcFile); if (bpp == 8) image.format = COMPRESSED_ASTC_4x4_RGBA; - else if (bpp == 2) image.format = COMPRESSED_ASTC_4x4_RGBA; + else if (bpp == 2) image.format = COMPRESSED_ASTC_8x8_RGBA; } else TraceLog(LOG_WARNING, "[%s] ASTC block size configuration not supported", fileName); } From 542eb6f250d1338d92020be5b6edb9bbe64785f0 Mon Sep 17 00:00:00 2001 From: Ray Date: Mon, 14 May 2018 00:33:15 +0200 Subject: [PATCH 35/53] Restore removed projects --- .gitignore | 24 +-- .../raylib.App.UWP/raylib.App.UWP.vcxproj | 145 +++++++++++++ projects/VS2015.UWP/raylib.UWP.sln | 50 +++++ projects/VS2015.UWP/raylib/raylib.vcxproj | 186 ++++++++++++++++ .../VS2015/examples/core_basic_window.vcxproj | 182 ++++++++++++++++ .../examples/core_basic_window_cpp.vcxproj | 180 ++++++++++++++++ projects/VS2015/raylib.sln | 54 +++++ projects/VS2015/raylib/raylib.vcxproj | 198 ++++++++++++++++++ .../VS2017/examples/core_basic_window.vcxproj | 182 ++++++++++++++++ .../examples/core_basic_window_cpp.vcxproj | 180 ++++++++++++++++ projects/VS2017/raylib.sln | 57 +++++ projects/VS2017/raylib/raylib.vcxproj | 197 +++++++++++++++++ 12 files changed, 1619 insertions(+), 16 deletions(-) create mode 100644 projects/VS2015.UWP/raylib.App.UWP/raylib.App.UWP.vcxproj create mode 100644 projects/VS2015.UWP/raylib.UWP.sln create mode 100644 projects/VS2015.UWP/raylib/raylib.vcxproj create mode 100644 projects/VS2015/examples/core_basic_window.vcxproj create mode 100644 projects/VS2015/examples/core_basic_window_cpp.vcxproj create mode 100644 projects/VS2015/raylib.sln create mode 100644 projects/VS2015/raylib/raylib.vcxproj create mode 100644 projects/VS2017/examples/core_basic_window.vcxproj create mode 100644 projects/VS2017/examples/core_basic_window_cpp.vcxproj create mode 100644 projects/VS2017/raylib.sln create mode 100644 projects/VS2017/raylib/raylib.vcxproj diff --git a/.gitignore b/.gitignore index 6caeaeada..124b125bc 100644 --- a/.gitignore +++ b/.gitignore @@ -13,9 +13,10 @@ Thumbs.db # *.obj --> Can be confused with 3d model! *.pdb *.aps -*.vcproj.*.user -*.vcxproj* -*.sln +*.user +# *.vcproj +# *.vcxproj* +# *.sln *.vspscc *_i.c *.i @@ -41,6 +42,8 @@ _ReSharper*/ [Tt]est[Rr]esult* ipch/ *.opensdf +*.db +*.opendb # Ignore compiled binaries *.o @@ -83,19 +86,8 @@ xcuserdata/ DerivedData/ # Visual Studio project -project/vs2015/*.db -project/vs2015/*.opendb -project/vs2015.UWP/packages -project/vs2015.UWP/*.db -!project/vs2015/raylib.sln -!project/vs2015/raylib/*.vcxproj -!project/vs2015/examples/*.vcxproj -!project/vs2017/raylib.sln -!project/vs2017/raylib/*.vcxproj -!project/vs2017/examples/*.vcxproj -!project/vs2015.UWP/raylib/*.vcxproj -!project/vs2015.UWP/*.sln -!project/vs2015.UWP/raylib.App.UWP/*.vcxproj +project/VS2015.UWP/packages +project/VS2017/packages # Web examples docs/examples/web/*.html diff --git a/projects/VS2015.UWP/raylib.App.UWP/raylib.App.UWP.vcxproj b/projects/VS2015.UWP/raylib.App.UWP/raylib.App.UWP.vcxproj new file mode 100644 index 000000000..6af9db604 --- /dev/null +++ b/projects/VS2015.UWP/raylib.App.UWP/raylib.App.UWP.vcxproj @@ -0,0 +1,145 @@ + + + + + Debug + Win32 + + + Release + Win32 + + + Debug + x64 + + + Release + x64 + + + Debug + ARM + + + Release + ARM + + + + {b842558c-c034-4e4b-9457-a286f26e83cc} + raylibUWP + en-US + 14.0 + true + Windows Store + 10.0.14393.0 + 10.0.14393.0 + 10.0 + raylib.App.UWP + + + + Application + true + v140 + + + Application + false + true + v140 + + + + + + + + raylib.App.UWP.TemporaryKey.pfx + + + C:\Users\Sam\Documents\GitHub\raylib\release\include;$(IncludePath) + C:\Users\Sam\Documents\GitHub\raylib\project\vs2015.UWP\raylib\Debug;$(LibraryPath) + + + + mincore.lib;raylib.lib;%(AdditionalDependencies) + %(AdditionalLibraryDirectories);$(VCInstallDir)\lib\store\arm;$(VCInstallDir)\lib\arm + + + + + mincore.lib;raylib.lib;%(AdditionalDependencies) + $(SolutionDir)raylib\Debug;%(AdditionalLibraryDirectories); $(VCInstallDir)\lib\store; $(VCInstallDir)\lib + + + + + mincore.lib;raylib.lib;%(AdditionalDependencies) + C:\Users\Sam\Documents\GitHub\raylib\project\vs2015.UWP\x64\Debug;C:\Users\Alumno\Downloads\angle\UWP_OpenGLES2\raylib;%(AdditionalLibraryDirectories);$(VCInstallDir)\lib\store\amd64;$(VCInstallDir)\lib\amd64 + + + + + pch.h + $(IntDir)pch.pch + $(SolutionDir)..\..\src;$(ProjectDir);$(IntermediateOutputPath);%(AdditionalIncludeDirectories) + /bigobj %(AdditionalOptions) + 4453;28204 + _DEBUG;%(PreprocessorDefinitions) + + + true + + + + + pch.h + $(IntDir)pch.pch + $(SolutionDir)..\..\src;$(ProjectDir);$(IntermediateOutputPath);%(AdditionalIncludeDirectories) + /bigobj %(AdditionalOptions) + 4453;28204 + NDEBUG;%(PreprocessorDefinitions) + Default + false + + + /NODEFAULTLIB %(AdditionalOptions) + + + + + + + + + + + + + + + + + Create + + + + + Designer + + + + + + + + + + + This project references NuGet package(s) that are missing on this computer. Use NuGet Package Restore to download them. For more information, see http://go.microsoft.com/fwlink/?LinkID=322105. The missing file is {0}. + + + + \ No newline at end of file diff --git a/projects/VS2015.UWP/raylib.UWP.sln b/projects/VS2015.UWP/raylib.UWP.sln new file mode 100644 index 000000000..b2f95ca2a --- /dev/null +++ b/projects/VS2015.UWP/raylib.UWP.sln @@ -0,0 +1,50 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio 14 +VisualStudioVersion = 14.0.25420.1 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "raylib.App.UWP", "raylib.App.UWP\raylib.App.UWP.vcxproj", "{B842558C-C034-4E4B-9457-A286F26E83CC}" +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "raylib", "raylib\raylib.vcxproj", "{E89D61AC-55DE-4482-AFD4-DF7242EBC859}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|ARM = Debug|ARM + Debug|x64 = Debug|x64 + Debug|x86 = Debug|x86 + Release|ARM = Release|ARM + Release|x64 = Release|x64 + Release|x86 = Release|x86 + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|ARM.ActiveCfg = Debug|ARM + {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|ARM.Build.0 = Debug|ARM + {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|ARM.Deploy.0 = Debug|ARM + {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|x64.ActiveCfg = Debug|x64 + {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|x64.Build.0 = Debug|x64 + {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|x64.Deploy.0 = Debug|x64 + {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|x86.ActiveCfg = Debug|Win32 + {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|x86.Build.0 = Debug|Win32 + {B842558C-C034-4E4B-9457-A286F26E83CC}.Debug|x86.Deploy.0 = Debug|Win32 + {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|ARM.ActiveCfg = Release|ARM + {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|ARM.Build.0 = Release|ARM + {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|ARM.Deploy.0 = Release|ARM + {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|x64.ActiveCfg = Release|x64 + {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|x64.Build.0 = Release|x64 + {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|x64.Deploy.0 = Release|x64 + {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|x86.ActiveCfg = Release|Win32 + {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|x86.Build.0 = Release|Win32 + {B842558C-C034-4E4B-9457-A286F26E83CC}.Release|x86.Deploy.0 = Release|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|ARM.ActiveCfg = Debug|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|x64.ActiveCfg = Debug|x64 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|x86.ActiveCfg = Debug|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|x86.Build.0 = Debug|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|ARM.ActiveCfg = Release|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|x64.ActiveCfg = Release|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|x86.ActiveCfg = Release|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|x86.Build.0 = Release|Win32 + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection +EndGlobal diff --git a/projects/VS2015.UWP/raylib/raylib.vcxproj b/projects/VS2015.UWP/raylib/raylib.vcxproj new file mode 100644 index 000000000..c1fbca500 --- /dev/null +++ b/projects/VS2015.UWP/raylib/raylib.vcxproj @@ -0,0 +1,186 @@ + + + + + Debug + Win32 + + + Debug + x64 + + + Release + Win32 + + + Release + x64 + + + + {E89D61AC-55DE-4482-AFD4-DF7242EBC859} + Win32Proj + raylib + 10.0.16299.0 + + + + StaticLibrary + true + v140 + Unicode + + + StaticLibrary + true + v140 + Unicode + + + StaticLibrary + false + v140 + true + Unicode + + + StaticLibrary + false + v140 + true + Unicode + + + + + + + + + + + + + + + + + + + + + $(SolutionDir)$(ProjectName)\$(Configuration)\ + + + + $(SolutionDir)$(ProjectName)\$(Configuration)\ + $(SolutionDir)$(ProjectName)\$(Configuration)\temp + + + + + + Level3 + Disabled + WIN32;_DEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_ES2;PLATFORM_UWP + CompileAsC + $(SolutionDir)..\..\release\include;$(SolutionDir)..\..\src\external\ANGLE + + + Windows + + + %(AdditionalLibraryDirectories) + + + + + + + Level3 + Disabled + WIN32;_DEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_ES2;PLATFORM_UWP + CompileAsC + $(SolutionDir)..\..\release\include;$(SolutionDir)..\..\src\external\include\ANGLE + + + Windows + + + %(AdditionalLibraryDirectories) + + + + + Level3 + + + MaxSpeed + true + true + WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_ES2;PLATFORM_UWP + $(SolutionDir)..\..\src\external\ANGLE;$(SolutionDir)..\..\release\include + CompileAsC + + + Windows + true + true + + + + + Level3 + + + MaxSpeed + true + true + WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_ES2;PLATFORM_UWP + $(SolutionDir)..\..\src\external\include\ANGLE;$(SolutionDir)..\..\release\include + CompileAsC + + + Windows + true + true + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/projects/VS2015/examples/core_basic_window.vcxproj b/projects/VS2015/examples/core_basic_window.vcxproj new file mode 100644 index 000000000..a5b484954 --- /dev/null +++ b/projects/VS2015/examples/core_basic_window.vcxproj @@ -0,0 +1,182 @@ + + + + + Debug_DLL + Win32 + + + Debug + Win32 + + + Release_DLL + Win32 + + + Release + Win32 + + + + {0981CA98-E4A5-4DF1-987F-A41D09131EFC} + Win32Proj + core_basic_window + 8.1 + core_basic_window + + + + Application + true + v140 + Unicode + + + Application + true + v140 + Unicode + + + Application + false + v140 + true + Unicode + + + Application + false + v140 + true + Unicode + + + + + + + + + + + + + + + + + + + + + true + $(ProjectDir)$(ProjectName)\$(Configuration)\ + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + true + $(ProjectDir)$(ProjectName)\$(Configuration)\ + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + false + $(ProjectDir)$(ProjectName)\$(Configuration)\ + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + false + $(ProjectDir)$(ProjectName)\$(Configuration)\ + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + + + + Level3 + Disabled + WIN32;_DEBUG;_CONSOLE;PLATFORM_DESKTOP;%(PreprocessorDefinitions) + CompileAsC + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + + + Console + true + $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) + kernel32.lib;user32.lib;gdi32.lib;opengl32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + + + + + + + Level3 + Disabled + WIN32;_DEBUG;_CONSOLE;PLATFORM_DESKTOP;%(PreprocessorDefinitions) + CompileAsC + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + + + Console + true + $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) + kernel32.lib;user32.lib;gdi32.lib;opengl32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + + + + + Level3 + + + MaxSpeed + true + true + WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions);PLATFORM_DESKTOP + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + CompileAsC + true + + + Console + true + true + true + kernel32.lib;user32.lib;gdi32.lib;opengl32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) + + + + + Level3 + + + MaxSpeed + true + true + WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions);PLATFORM_DESKTOP + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + CompileAsC + true + + + Console + true + true + true + kernel32.lib;user32.lib;gdi32.lib;opengl32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) + + + + + + + + {e89d61ac-55de-4482-afd4-df7242ebc859} + + + + + + \ No newline at end of file diff --git a/projects/VS2015/examples/core_basic_window_cpp.vcxproj b/projects/VS2015/examples/core_basic_window_cpp.vcxproj new file mode 100644 index 000000000..90379fe5f --- /dev/null +++ b/projects/VS2015/examples/core_basic_window_cpp.vcxproj @@ -0,0 +1,180 @@ + + + + + Debug_DLL + Win32 + + + Debug + Win32 + + + Release_DLL + Win32 + + + Release + Win32 + + + + {B655E850-3322-42F7-941D-6AC18FD66CA1} + Win32Proj + raylib_example_cpp + 8.1 + core_basic_window_cpp + + + + Application + true + v140 + Unicode + + + Application + true + v140 + Unicode + + + Application + false + v140 + true + Unicode + + + Application + false + v140 + true + Unicode + + + + + + + + + + + + + + + + + + + + + true + $(ProjectDir)$(ProjectName)\$(Configuration) + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + true + $(ProjectDir)$(ProjectName)\$(Configuration) + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + false + $(ProjectDir)$(ProjectName)\$(Configuration) + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + false + $(ProjectDir)$(ProjectName)\$(Configuration) + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + + + + Level3 + Disabled + WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + CompileAsCpp + + + Console + true + kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) + + + + + + + Level3 + Disabled + WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + CompileAsCpp + + + Console + true + kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) + + + + + Level3 + + + MaxSpeed + true + true + WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) + CompileAsCpp + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + + + Console + true + true + true + $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) + kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + + + + + Level3 + + + MaxSpeed + true + true + WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) + CompileAsCpp + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + + + Console + true + true + true + $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) + kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + + + + + {e89d61ac-55de-4482-afd4-df7242ebc859} + + + + + + + + + \ No newline at end of file diff --git a/projects/VS2015/raylib.sln b/projects/VS2015/raylib.sln new file mode 100644 index 000000000..2ea3c9c24 --- /dev/null +++ b/projects/VS2015/raylib.sln @@ -0,0 +1,54 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio 14 +VisualStudioVersion = 14.0.25420.1 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "core_basic_window", "examples\core_basic_window.vcxproj", "{0981CA98-E4A5-4DF1-987F-A41D09131EFC}" +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "raylib", "raylib\raylib.vcxproj", "{E89D61AC-55DE-4482-AFD4-DF7242EBC859}" +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "core_basic_window_cpp", "examples\core_basic_window_cpp.vcxproj", "{B655E850-3322-42F7-941D-6AC18FD66CA1}" +EndProject +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "examples", "examples", "{8716DC0F-4FDE-4F57-8E25-5F78DFB80FE1}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug_DLL|x86 = Debug_DLL|x86 + Debug|x86 = Debug|x86 + Release_DLL|x86 = Release_DLL|x86 + Release|x86 = Release|x86 + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug_DLL|x86.ActiveCfg = Debug_DLL|Win32 + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug_DLL|x86.Build.0 = Debug_DLL|Win32 + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug|x86.ActiveCfg = Debug|Win32 + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug|x86.Build.0 = Debug|Win32 + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release_DLL|x86.ActiveCfg = Release_DLL|Win32 + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release_DLL|x86.Build.0 = Release_DLL|Win32 + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release|x86.ActiveCfg = Release|Win32 + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release|x86.Build.0 = Release|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug_DLL|x86.ActiveCfg = Debug_DLL|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug_DLL|x86.Build.0 = Debug_DLL|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|x86.ActiveCfg = Debug|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|x86.Build.0 = Debug|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release_DLL|x86.ActiveCfg = Release_DLL|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release_DLL|x86.Build.0 = Release_DLL|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|x86.ActiveCfg = Release|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|x86.Build.0 = Release|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug_DLL|x86.ActiveCfg = Debug_DLL|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug_DLL|x86.Build.0 = Debug_DLL|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug|x86.ActiveCfg = Debug|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug|x86.Build.0 = Debug|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release_DLL|x86.ActiveCfg = Release_DLL|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release_DLL|x86.Build.0 = Release_DLL|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release|x86.ActiveCfg = Release|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release|x86.Build.0 = Release|Win32 + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(NestedProjects) = preSolution + {0981CA98-E4A5-4DF1-987F-A41D09131EFC} = {8716DC0F-4FDE-4F57-8E25-5F78DFB80FE1} + {B655E850-3322-42F7-941D-6AC18FD66CA1} = {8716DC0F-4FDE-4F57-8E25-5F78DFB80FE1} + EndGlobalSection +EndGlobal diff --git a/projects/VS2015/raylib/raylib.vcxproj b/projects/VS2015/raylib/raylib.vcxproj new file mode 100644 index 000000000..97ce13e6d --- /dev/null +++ b/projects/VS2015/raylib/raylib.vcxproj @@ -0,0 +1,198 @@ + + + + + Debug_DLL + Win32 + + + Debug + Win32 + + + Release_DLL + Win32 + + + Release + Win32 + + + + {E89D61AC-55DE-4482-AFD4-DF7242EBC859} + Win32Proj + raylib + 8.1 + + + + StaticLibrary + true + v140 + Unicode + + + DynamicLibrary + true + v140 + Unicode + + + StaticLibrary + false + v140 + true + Unicode + + + DynamicLibrary + false + v140 + true + Unicode + + + + + + + + + + + + + + + + + + + + + $(SolutionDir)$(ProjectName)\$(Configuration)\ + + + $(SolutionDir)$(ProjectName)\$(Configuration)\ + + + $(SolutionDir)$(ProjectName)\$(Configuration)\ + $(SolutionDir)$(ProjectName)\$(Configuration)\temp + + + $(SolutionDir)$(ProjectName)\$(Configuration)\ + $(SolutionDir)$(ProjectName)\$(Configuration)\temp + + + + + + Level3 + Disabled + WIN32;_DEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP + CompileAsC + $(SolutionDir)..\..\src\external\glfw\include;$(SolutionDir)..\..\release\include + MultiThreadedDebug + + + Windows + + + %(AdditionalLibraryDirectories) + + + + + + + Level3 + Disabled + WIN32;_DEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP;BUILD_LIBTYPE_SHARED + CompileAsC + $(SolutionDir)..\..\src\external\glfw\include;$(SolutionDir)..\..\release\include + MultiThreadedDebug + + + Windows + + + %(AdditionalLibraryDirectories) + + + + + Level3 + + + MaxSpeed + true + true + WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP + $(SolutionDir)..\..\src\external\glfw\include;$(SolutionDir)..\..\release\include + CompileAsC + MultiThreaded + + + Windows + true + true + + + + + Level3 + + + MaxSpeed + true + true + WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP;BUILD_LIBTYPE_SHARED + $(SolutionDir)..\..\src\external\glfw\include;$(SolutionDir)..\..\release\include + CompileAsC + MultiThreaded + + + Windows + true + true + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/projects/VS2017/examples/core_basic_window.vcxproj b/projects/VS2017/examples/core_basic_window.vcxproj new file mode 100644 index 000000000..7b4d4a8cd --- /dev/null +++ b/projects/VS2017/examples/core_basic_window.vcxproj @@ -0,0 +1,182 @@ + + + + + Debug_DLL + Win32 + + + Debug + Win32 + + + Release_DLL + Win32 + + + Release + Win32 + + + + {0981CA98-E4A5-4DF1-987F-A41D09131EFC} + Win32Proj + core_basic_window + 10.0.14393.0 + core_basic_window + + + + Application + true + v141 + Unicode + + + Application + true + v141 + Unicode + + + Application + false + v141 + true + Unicode + + + Application + false + v141 + true + Unicode + + + + + + + + + + + + + + + + + + + + + true + $(ProjectDir)$(ProjectName)\$(Configuration)\ + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + true + $(ProjectDir)$(ProjectName)\$(Configuration)\ + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + false + $(ProjectDir)$(ProjectName)\$(Configuration)\ + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + false + $(ProjectDir)$(ProjectName)\$(Configuration)\ + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + + + + Level3 + Disabled + WIN32;_DEBUG;_CONSOLE;PLATFORM_DESKTOP;%(PreprocessorDefinitions) + CompileAsC + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + + + Console + true + %(AdditionalLibraryDirectories) + kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + + + + + + + Level3 + Disabled + WIN32;_DEBUG;_CONSOLE;PLATFORM_DESKTOP;%(PreprocessorDefinitions) + CompileAsC + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + + + Console + true + %(AdditionalLibraryDirectories) + kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + + + + + Level3 + + + MaxSpeed + true + true + WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions);PLATFORM_DESKTOP + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + CompileAsC + true + + + Console + true + true + true + kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + %(AdditionalLibraryDirectories) + + + + + Level3 + + + MaxSpeed + true + true + WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions);PLATFORM_DESKTOP + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + CompileAsC + true + + + Console + true + true + true + kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + %(AdditionalLibraryDirectories) + + + + + + + + {e89d61ac-55de-4482-afd4-df7242ebc859} + + + + + + \ No newline at end of file diff --git a/projects/VS2017/examples/core_basic_window_cpp.vcxproj b/projects/VS2017/examples/core_basic_window_cpp.vcxproj new file mode 100644 index 000000000..a015690cd --- /dev/null +++ b/projects/VS2017/examples/core_basic_window_cpp.vcxproj @@ -0,0 +1,180 @@ + + + + + Debug_DLL + Win32 + + + Debug + Win32 + + + Release_DLL + Win32 + + + Release + Win32 + + + + {B655E850-3322-42F7-941D-6AC18FD66CA1} + Win32Proj + raylib_example_cpp + 10.0.14393.0 + core_basic_window_cpp + + + + Application + true + v141 + Unicode + + + Application + true + v141 + Unicode + + + Application + false + v141 + true + Unicode + + + Application + false + v141 + true + Unicode + + + + + + + + + + + + + + + + + + + + + true + $(ProjectDir)$(ProjectName)\$(Configuration) + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + true + $(ProjectDir)$(ProjectName)\$(Configuration) + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + false + $(ProjectDir)$(ProjectName)\$(Configuration) + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + false + $(ProjectDir)$(ProjectName)\$(Configuration) + $(ProjectDir)$(ProjectName)\$(Configuration)\temp + + + + + + Level3 + Disabled + WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + CompileAsCpp + + + Console + true + kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) + + + + + + + Level3 + Disabled + WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + CompileAsCpp + + + Console + true + kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) + + + + + Level3 + + + MaxSpeed + true + true + WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) + CompileAsCpp + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + + + Console + true + true + true + $(SolutionDir)..\..\release\libs\win32\msvc;%(AdditionalLibraryDirectories) + kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + + + + + Level3 + + + MaxSpeed + true + true + WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) + CompileAsCpp + $(SolutionDir)..\..\release\include;%(AdditionalIncludeDirectories) + + + Console + true + true + true + %(AdditionalLibraryDirectories) + kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies) + + + + + {e89d61ac-55de-4482-afd4-df7242ebc859} + + + + + + + + + \ No newline at end of file diff --git a/projects/VS2017/raylib.sln b/projects/VS2017/raylib.sln new file mode 100644 index 000000000..77378c847 --- /dev/null +++ b/projects/VS2017/raylib.sln @@ -0,0 +1,57 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio 15 +VisualStudioVersion = 15.0.27130.2024 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "core_basic_window", "examples\core_basic_window.vcxproj", "{0981CA98-E4A5-4DF1-987F-A41D09131EFC}" +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "raylib", "raylib\raylib.vcxproj", "{E89D61AC-55DE-4482-AFD4-DF7242EBC859}" +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "core_basic_window_cpp", "examples\core_basic_window_cpp.vcxproj", "{B655E850-3322-42F7-941D-6AC18FD66CA1}" +EndProject +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "examples", "examples", "{8716DC0F-4FDE-4F57-8E25-5F78DFB80FE1}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug_DLL|x86 = Debug_DLL|x86 + Debug|x86 = Debug|x86 + Release_DLL|x86 = Release_DLL|x86 + Release|x86 = Release|x86 + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug_DLL|x86.ActiveCfg = Debug_DLL|Win32 + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug_DLL|x86.Build.0 = Debug_DLL|Win32 + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug|x86.ActiveCfg = Debug|Win32 + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Debug|x86.Build.0 = Debug|Win32 + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release_DLL|x86.ActiveCfg = Release_DLL|Win32 + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release_DLL|x86.Build.0 = Release_DLL|Win32 + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release|x86.ActiveCfg = Release|Win32 + {0981CA98-E4A5-4DF1-987F-A41D09131EFC}.Release|x86.Build.0 = Release|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug_DLL|x86.ActiveCfg = Debug_DLL|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug_DLL|x86.Build.0 = Debug_DLL|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|x86.ActiveCfg = Debug|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Debug|x86.Build.0 = Debug|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release_DLL|x86.ActiveCfg = Release_DLL|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release_DLL|x86.Build.0 = Release_DLL|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|x86.ActiveCfg = Release|Win32 + {E89D61AC-55DE-4482-AFD4-DF7242EBC859}.Release|x86.Build.0 = Release|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug_DLL|x86.ActiveCfg = Debug_DLL|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug_DLL|x86.Build.0 = Debug_DLL|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug|x86.ActiveCfg = Debug|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Debug|x86.Build.0 = Debug|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release_DLL|x86.ActiveCfg = Release_DLL|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release_DLL|x86.Build.0 = Release_DLL|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release|x86.ActiveCfg = Release|Win32 + {B655E850-3322-42F7-941D-6AC18FD66CA1}.Release|x86.Build.0 = Release|Win32 + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(NestedProjects) = preSolution + {0981CA98-E4A5-4DF1-987F-A41D09131EFC} = {8716DC0F-4FDE-4F57-8E25-5F78DFB80FE1} + {B655E850-3322-42F7-941D-6AC18FD66CA1} = {8716DC0F-4FDE-4F57-8E25-5F78DFB80FE1} + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {E926C768-6307-4423-A1EC-57E95B1FAB29} + EndGlobalSection +EndGlobal diff --git a/projects/VS2017/raylib/raylib.vcxproj b/projects/VS2017/raylib/raylib.vcxproj new file mode 100644 index 000000000..582067933 --- /dev/null +++ b/projects/VS2017/raylib/raylib.vcxproj @@ -0,0 +1,197 @@ + + + + + Debug_DLL + Win32 + + + Debug + Win32 + + + Release_DLL + Win32 + + + Release + Win32 + + + + {E89D61AC-55DE-4482-AFD4-DF7242EBC859} + Win32Proj + raylib + 10.0.14393.0 + + + + StaticLibrary + true + v141 + Unicode + + + DynamicLibrary + true + v141 + Unicode + + + StaticLibrary + false + v141 + true + Unicode + + + DynamicLibrary + false + v141 + true + Unicode + + + + + + + + + + + + + + + + + + + + + $(SolutionDir)$(ProjectName)\$(Configuration)\ + + + $(SolutionDir)$(ProjectName)\$(Configuration)\ + + + $(SolutionDir)$(ProjectName)\$(Configuration)\ + $(SolutionDir)$(ProjectName)\$(Configuration)\temp + + + $(SolutionDir)$(ProjectName)\$(Configuration)\ + $(SolutionDir)$(ProjectName)\$(Configuration)\temp + + + + + + Level3 + Disabled + WIN32;_DEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP + CompileAsC + $(SolutionDir)..\..\release\include;$(SolutionDir)..\..\src\external\glfw\include + + + Windows + + + %(AdditionalLibraryDirectories) + + + + + + + Level3 + Disabled + WIN32;_DEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP;BUILD_LIBTYPE_SHARED + CompileAsC + $(SolutionDir)..\..\release\include;$(SolutionDir)..\..\src\external\glfw\include + MultiThreadedDebug + + + Windows + + + %(AdditionalLibraryDirectories) + + + + + Level3 + + + MaxSpeed + true + true + WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP + $(SolutionDir)..\..\release\include;$(SolutionDir)..\..\src\external\glfw\include + CompileAsC + + + Windows + true + true + + + + + Level3 + + + MaxSpeed + true + true + WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions);GRAPHICS_API_OPENGL_33;PLATFORM_DESKTOP;BUILD_LIBTYPE_SHARED + $(SolutionDir)..\..\release\include;$(SolutionDir)..\..\src\external\glfw\include + CompileAsC + MultiThreaded + + + Windows + true + true + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file From 1d3e4ef437bc7e8e0bdd9607370f0cce85e9f150 Mon Sep 17 00:00:00 2001 From: Ray Date: Thu, 17 May 2018 00:04:12 +0200 Subject: [PATCH 36/53] Corrected issue on file extension check --- src/core.c | 1 + 1 file changed, 1 insertion(+) diff --git a/src/core.c b/src/core.c index ece76138d..cae9a1c88 100644 --- a/src/core.c +++ b/src/core.c @@ -1310,6 +1310,7 @@ bool IsFileExtension(const char *fileName, const char *ext) } } } + else result = false; #else if (strcmp(fileExt, ext) == 0) result = true; #endif From 2aae62cea28f8b09b85133bb325f075c001f7f56 Mon Sep 17 00:00:00 2001 From: Ray Date: Thu, 17 May 2018 00:04:36 +0200 Subject: [PATCH 37/53] Header tweak and comments --- src/models.c | 5 ++--- src/text.c | 5 ++--- src/textures.c | 4 ++-- 3 files changed, 6 insertions(+), 8 deletions(-) diff --git a/src/models.c b/src/models.c index 387917473..afeee0fc2 100644 --- a/src/models.c +++ b/src/models.c @@ -36,9 +36,8 @@ * **********************************************************************************************/ -#include "config.h" - -#include "raylib.h" +#include "config.h" // Defines module configuration flags +#include "raylib.h" // Declares module functions #include "utils.h" // Required for: fopen() Android mapping diff --git a/src/text.c b/src/text.c index aa22c3082..553159002 100644 --- a/src/text.c +++ b/src/text.c @@ -36,9 +36,8 @@ * **********************************************************************************************/ -#include "config.h" - -#include "raylib.h" +#include "config.h" // Defines module configuration flags +#include "raylib.h" // Declares module functions #include // Required for: malloc(), free() #include // Required for: strlen() diff --git a/src/textures.c b/src/textures.c index 7344e74b9..46867aaba 100644 --- a/src/textures.c +++ b/src/textures.c @@ -52,9 +52,9 @@ * 3. This notice may not be removed or altered from any source distribution. * **********************************************************************************************/ -#include "config.h" -#include "raylib.h" +#include "config.h" // Defines module configuration flags +#include "raylib.h" // Declares module functions #include // Required for: malloc(), free() #include // Required for: strcmp(), strrchr(), strncmp() From 88c2337225e04cc8e9d412155e97df1ffedf1bae Mon Sep 17 00:00:00 2001 From: Ray Date: Thu, 17 May 2018 00:04:58 +0200 Subject: [PATCH 38/53] Preliminary support for MP3 fileformat -WIP- --- src/audio.c | 41 ++++++++++++++++++++++++++++++++++++++--- 1 file changed, 38 insertions(+), 3 deletions(-) diff --git a/src/audio.c b/src/audio.c index 1d42e52b4..4e18df26f 100644 --- a/src/audio.c +++ b/src/audio.c @@ -73,8 +73,6 @@ * **********************************************************************************************/ -#include "config.h" - #if !defined(USE_OPENAL_BACKEND) #define USE_MINI_AL 1 // Set to 1 to use mini_al; 0 to use OpenAL. #endif @@ -83,7 +81,8 @@ #include "audio.h" #include // Required for: va_list, va_start(), vfprintf(), va_end() #else - #include "raylib.h" + #include "config.h" // Defines module configuration flags + #include "raylib.h" // Declares module functions #include "utils.h" // Required for: fopen() Android mapping #endif @@ -164,6 +163,7 @@ typedef enum { MUSIC_AUDIO_OGG = 0, MUSIC_AUDIO_FLAC, + MUSIC_AUDIO_MP3, MUSIC_MODULE_XM, MUSIC_MODULE_MOD } MusicContextType; @@ -177,6 +177,9 @@ typedef struct MusicData { #if defined(SUPPORT_FILEFORMAT_FLAC) drflac *ctxFlac; // FLAC audio context #endif +#if defined(SUPPORT_FILEFORMAT_MP3) + drmp3 ctxMp3; // MP3 audio context +#endif #if defined(SUPPORT_FILEFORMAT_XM) jar_xm_context_t *ctxXm; // XM chiptune context #endif @@ -1368,6 +1371,27 @@ Music LoadMusicStream(const char *fileName) } } #endif +#if defined(SUPPORT_FILEFORMAT_MP3) + else if (IsFileExtension(fileName, ".mp3")) + { + drmp3_init_file(&music->ctxMp3, fileName, NULL) + + if (music->ctxMp3 == NULL) TraceLog(LOG_WARNING, "[%s] MP3 audio file could not be opened", fileName); + else + { + music->stream = InitAudioStream(music->ctxMp3.sampleRate, 16, music->ctxMp3.channels); + //music->totalSamples = (unsigned int)music->ctxMp3.totalSampleCount/music->ctxMp3.channels; //TODO! + music->samplesLeft = music->totalSamples; + music->ctxType = MUSIC_AUDIO_MP3; + music->loopCount = -1; // Infinite loop by default + + TraceLog(LOG_DEBUG, "[%s] MP3 total samples: %i", fileName, music->totalSamples); + TraceLog(LOG_DEBUG, "[%s] MP3 sample rate: %i", fileName, music->ctxMp3.sampleRate); + //TraceLog(LOG_DEBUG, "[%s] MP3 bits per sample: %i", fileName, music->ctxMp3.bitsPerSample); + TraceLog(LOG_DEBUG, "[%s] MP3 channels: %i", fileName, music->ctxMp3.channels); + } + } +#endif #if defined(SUPPORT_FILEFORMAT_XM) else if (IsFileExtension(fileName, ".xm")) { @@ -1423,6 +1447,9 @@ void UnloadMusicStream(Music music) #if defined(SUPPORT_FILEFORMAT_FLAC) else if (music->ctxType == MUSIC_AUDIO_FLAC) drflac_free(music->ctxFlac); #endif +#if defined(SUPPORT_FILEFORMAT_MP3) + else if (music->ctxType == MUSIC_AUDIO_MP3) drmp3_uninit(&music->ctxMp3); +#endif #if defined(SUPPORT_FILEFORMAT_XM) else if (music->ctxType == MUSIC_MODULE_XM) jar_xm_free_context(music->ctxXm); #endif @@ -1564,6 +1591,14 @@ void UpdateMusicStream(Music music) } break; #endif + #if defined(SUPPORT_FILEFORMAT_MP3) + case MUSIC_AUDIO_MP3: + { + // NOTE: Returns the number of samples to process + unsigned int numSamplesMp3 = (unsigned int)drmp3_read_f32(music->ctxMp3, samplesCount*music->stream.channels, (short *)pcm); + + } break; + #endif #if defined(SUPPORT_FILEFORMAT_XM) case MUSIC_MODULE_XM: jar_xm_generate_samples_16bit(music->ctxXm, pcm, samplesCount); break; #endif From 0b05169aa74e7c298f44e214f2cf5aeed82f11cb Mon Sep 17 00:00:00 2001 From: Ray Date: Thu, 17 May 2018 00:58:58 +0200 Subject: [PATCH 39/53] Some warnings review --- src/core.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/src/core.c b/src/core.c index cae9a1c88..5cd9bfd43 100644 --- a/src/core.c +++ b/src/core.c @@ -1026,7 +1026,7 @@ Ray GetMouseRay(Vector2 mousePosition, Camera camera) // Calculate view matrix from camera look at Matrix matView = MatrixLookAt(camera.position, camera.target, camera.up); - Matrix matProj; + Matrix matProj = MatrixIdentity(); if (camera.type == CAMERA_PERSPECTIVE) { @@ -1038,6 +1038,7 @@ Ray GetMouseRay(Vector2 mousePosition, Camera camera) float aspect = (float)screenWidth/(float)screenHeight; double top = camera.fovy/2.0; double right = top*aspect; + // Calculate projection matrix from orthographic matProj = MatrixOrtho(-right, right, -top, top, 0.01, 1000.0); } @@ -1067,18 +1068,19 @@ Ray GetMouseRay(Vector2 mousePosition, Camera camera) Vector2 GetWorldToScreen(Vector3 position, Camera camera) { // Calculate projection matrix (from perspective instead of frustum - Matrix matProj; + Matrix matProj = MatrixIdentity(); - if(camera.type == CAMERA_PERSPECTIVE) + if (camera.type == CAMERA_PERSPECTIVE) { // Calculate projection matrix from perspective matProj = MatrixPerspective(camera.fovy*DEG2RAD, ((double)GetScreenWidth()/(double)GetScreenHeight()), 0.01, 1000.0); } - else if(camera.type == CAMERA_ORTHOGRAPHIC) + else if (camera.type == CAMERA_ORTHOGRAPHIC) { float aspect = (float)screenWidth/(float)screenHeight; double top = camera.fovy/2.0; double right = top*aspect; + // Calculate projection matrix from orthographic matProj = MatrixOrtho(-right, right, -top, top, 0.01, 1000.0); } From fb4265f64659a50a5a86f9f283e7468b7998c60f Mon Sep 17 00:00:00 2001 From: Ray Date: Thu, 17 May 2018 00:59:53 +0200 Subject: [PATCH 40/53] Reviewed Android pipeline Now defaults to Clang, ARM64 and API 21 --- release/libs/android/arm64-v8a/libraylib.a | Bin 0 -> 981332 bytes src/Makefile | 17 ++++++++--------- 2 files changed, 8 insertions(+), 9 deletions(-) create mode 100644 release/libs/android/arm64-v8a/libraylib.a diff --git a/release/libs/android/arm64-v8a/libraylib.a b/release/libs/android/arm64-v8a/libraylib.a new file mode 100644 index 0000000000000000000000000000000000000000..0e252902c40542aba10907fe2c9c23960155707f GIT binary patch literal 981332 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 U-}M)|m*4SN8jtGtO*!TNFNvbC`2YX_ literal 0 HcmV?d00001 diff --git a/src/Makefile b/src/Makefile index 67d7c8c28..582daf49c 100644 --- a/src/Makefile +++ b/src/Makefile @@ -163,10 +163,10 @@ endif ifeq ($(PLATFORM),PLATFORM_ANDROID) # Android required path variables ANDROID_NDK = C:/android-ndk - ANDROID_TOOLCHAIN = C:/android_toolchain_arm_api16 + ANDROID_TOOLCHAIN = C:/android_toolchain_arm64_api21 # Android architecture: ARM or ARM64 - ANDROID_ARCH ?= ARM + ANDROID_ARCH ?= ARM64 endif # RAYLIB_RELEASE_PATH points to provided binaries or your immediate build of raylib. @@ -251,12 +251,11 @@ ifeq ($(PLATFORM),PLATFORM_WEB) endif ifeq ($(PLATFORM),PLATFORM_ANDROID) # Android toolchain (must be provided for desired architecture and compiler) - # NOTE: gcc compiler is being deprecated in Android NDK r16 ifeq ($(ANDROID_ARCH),ARM) - CC = $(ANDROID_TOOLCHAIN)/bin/arm-linux-androideabi-gcc + CC = $(ANDROID_TOOLCHAIN)/bin/arm-linux-androideabi-clang endif ifeq ($(ANDROID_ARCH),ARM64) - CC = $(ANDROID_TOOLCHAIN)/bin/aarch64-linux-android-gcc + CC = $(ANDROID_TOOLCHAIN)/bin/aarch64-linux-android-clang endif endif @@ -316,15 +315,15 @@ ifeq ($(PLATFORM),PLATFORM_WEB) CFLAGS += -s USE_GLFW=3 -s ASSERTIONS=1 --profiling endif ifeq ($(PLATFORM),PLATFORM_ANDROID) - # Compiler flags for arquitecture - CFLAGS += -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 + # Compiler flags for arquitecture (only ARM, not ARM64) + #CFLAGS += -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 # Compilation functions attributes options - CFLAGS += -ffunction-sections -funwind-tables -fstack-protector-strong -fPIC + CFLAGS += -ffunction-sections -funwind-tables -fstack-protector-strong -fPIE -fPIC # Compiler options for the linker # -Werror=format-security CFLAGS += -Wa,--noexecstack -Wformat -no-canonical-prefixes # Preprocessor macro definitions - CFLAGS += -DANDROID -DPLATFORM_ANDROID -D__ANDROID_API__=16 + CFLAGS += -DANDROID -DPLATFORM_ANDROID -D__ANDROID_API__=21 endif # Define required compilation flags for raylib SHARED lib From 5cfbb53f6c837bef2ebfafd778b08840f2e33704 Mon Sep 17 00:00:00 2001 From: Michael Vetter Date: Fri, 18 May 2018 16:04:18 +0200 Subject: [PATCH 41/53] Increase API version Please do this whenever necessary. And adapt it before releasing a new RC. The RC should already have the correct one. --- src/CMakeLists.txt | 2 +- src/Makefile | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index e8379ab0b..458b96064 100755 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -3,7 +3,7 @@ project(raylib) include(GNUInstallDirs) set(PROJECT_VERSION 2.0.0) -set(API_VERSION 1) +set(API_VERSION 2) set(RAYLIB raylib) # Name of the generated library include("CMakeOptions.txt") diff --git a/src/Makefile b/src/Makefile index 582daf49c..d327c2d13 100644 --- a/src/Makefile +++ b/src/Makefile @@ -43,7 +43,7 @@ # Define required raylib variables RAYLIB_VERSION = 2.0.0 -RAYLIB_API_VERSION = 1 +RAYLIB_API_VERSION = 2 # See below for alternatives. RAYLIB_PATH = .. From 25d5e907ececc3930924835336a072e9ab0593ec Mon Sep 17 00:00:00 2001 From: raysan5 Date: Sun, 20 May 2018 00:37:16 +0200 Subject: [PATCH 42/53] Some code review (mainly comments) --- src/text.c | 23 +++++++++++------------ 1 file changed, 11 insertions(+), 12 deletions(-) diff --git a/src/text.c b/src/text.c index 553159002..b553f0dee 100644 --- a/src/text.c +++ b/src/text.c @@ -763,22 +763,23 @@ static Font LoadBMFont(const char *fileName) { Image imCopy = ImageCopy(imFont); - for (int i = 0; i < imCopy.width*imCopy.height; i++) ((unsigned char *)imCopy.data)[i] = 0xff; // WHITE pixel + for (int i = 0; i < imCopy.width*imCopy.height; i++) ((unsigned char *)imCopy.data)[i] = 0xff; ImageAlphaMask(&imCopy, imFont); font.texture = LoadTextureFromImage(imCopy); UnloadImage(imCopy); } else font.texture = LoadTextureFromImage(imFont); + + UnloadImage(imFont); + free(texPath); + + // Fill font characters info data font.baseSize = fontSize; font.charsCount = charsCount; font.chars = (CharInfo *)malloc(charsCount*sizeof(CharInfo)); - UnloadImage(imFont); - - free(texPath); - int charId, charX, charY, charWidth, charHeight, charOffsetX, charOffsetY, charAdvanceX; for (int i = 0; i < charsCount; i++) @@ -870,7 +871,7 @@ static Font LoadTTF(const char *fileName, int fontSize, int charsCount, int *fon for (int i = 0, k = 0; i < textureSize*textureSize; i++, k += 2) { - dataGrayAlpha[k] = 255; + dataGrayAlpha[k] = 0xff; dataGrayAlpha[k + 1] = dataBitmap[i]; } @@ -883,13 +884,11 @@ static Font LoadTTF(const char *fileName, int fontSize, int charsCount, int *fon image.mipmaps = 1; image.format = UNCOMPRESSED_GRAY_ALPHA; image.data = dataGrayAlpha; + font.texture = LoadTextureFromImage(image); // Load image into texture + UnloadImage(image); // Unloads image data (dataGrayAlpha) - font.texture = LoadTextureFromImage(image); - - //SavePNG("generated_ttf_image.png", (unsigned char *)image.data, image.width, image.height, 2); - - UnloadImage(image); // Unloads dataGrayAlpha - + + // Fill font characters info data font.baseSize = fontSize; font.charsCount = charsCount; font.chars = (CharInfo *)malloc(font.charsCount*sizeof(CharInfo)); From 24adca4ad054196a144eca8629e090ee10e413c5 Mon Sep 17 00:00:00 2001 From: raysan5 Date: Sun, 20 May 2018 00:39:56 +0200 Subject: [PATCH 43/53] Manual mipmap generation review On OpenGL 1.1 only is supported for 32bit RGBA textures --- src/rlgl.c | 60 +++++++++++++++++++++++++++++------------------------- 1 file changed, 32 insertions(+), 28 deletions(-) diff --git a/src/rlgl.c b/src/rlgl.c index 93a0b0f84..e69694e90 100644 --- a/src/rlgl.c +++ b/src/rlgl.c @@ -1448,7 +1448,7 @@ unsigned int rlLoadTexture(void *data, int width, int height, int format, int mi else glCompressedTexImage2D(GL_TEXTURE_2D, i, glInternalFormat, mipWidth, mipHeight, 0, mipSize, (unsigned char *)data + mipOffset); #endif - #if defined(GRAPHICS_API_OPENGL_33) + #if defined(GRAPHICS_API_OPENGL_21) || defined(GRAPHICS_API_OPENGL_33) if (format == UNCOMPRESSED_GRAYSCALE) { GLint swizzleMask[] = { GL_RED, GL_RED, GL_RED, GL_ONE }; @@ -1648,37 +1648,40 @@ void rlGenerateMipmaps(Texture2D *texture) if ((texIsPOT) || (texNPOTSupported)) { #if defined(GRAPHICS_API_OPENGL_11) - // Compute required mipmaps - void *data = rlReadTexturePixels(*texture); - - // NOTE: data size is reallocated to fit mipmaps data - // NOTE: CPU mipmap generation only supports RGBA 32bit data - int mipmapCount = GenerateMipmaps(data, texture->width, texture->height); - - int size = texture->width*texture->height*4; // RGBA 32bit only - int offset = size; - - int mipWidth = texture->width/2; - int mipHeight = texture->height/2; - - // Load the mipmaps - for (int level = 1; level < mipmapCount; level++) + // WARNING: Manual mipmap generation only works for RGBA 32bit textures! + if (texture->format == UNCOMPRESSED_R8G8B8A8) { - glTexImage2D(GL_TEXTURE_2D, level, GL_RGBA8, mipWidth, mipHeight, 0, GL_RGBA, GL_UNSIGNED_BYTE, (unsigned char *)data + offset); + // Retrieve texture data from VRAM + void *data = rlReadTexturePixels(*texture); + + // NOTE: data size is reallocated to fit mipmaps data + // NOTE: CPU mipmap generation only supports RGBA 32bit data + int mipmapCount = GenerateMipmaps(data, texture->width, texture->height); - size = mipWidth*mipHeight*4; - offset += size; + int size = texture->width*texture->height*4; + int offset = size; - mipWidth /= 2; - mipHeight /= 2; + int mipWidth = texture->width/2; + int mipHeight = texture->height/2; + + // Load the mipmaps + for (int level = 1; level < mipmapCount; level++) + { + glTexImage2D(GL_TEXTURE_2D, level, GL_RGBA8, mipWidth, mipHeight, 0, GL_RGBA, GL_UNSIGNED_BYTE, (unsigned char *)data + offset); + + size = mipWidth*mipHeight*4; + offset += size; + + mipWidth /= 2; + mipHeight /= 2; + } + + texture->mipmaps = mipmapCount + 1; + free(data); // Once mipmaps have been generated and data has been uploaded to GPU VRAM, we can discard RAM data + + TraceLog(LOG_WARNING, "[TEX ID %i] Mipmaps [%i] generated manually on CPU side", texture->id, texture->mipmaps); } - - TraceLog(LOG_WARNING, "[TEX ID %i] Mipmaps generated manually on CPU side", texture->id); - - // NOTE: Once mipmaps have been generated and data has been uploaded to GPU VRAM, we can discard RAM data - free(data); - - texture->mipmaps = mipmapCount + 1; + else TraceLog(LOG_WARNING, "[TEX ID %i] Mipmaps could not be generated for texture format", texture->id); #endif #if defined(GRAPHICS_API_OPENGL_33) || defined(GRAPHICS_API_OPENGL_ES2) @@ -4058,6 +4061,7 @@ static void GetGlFormats(int format, int *glInternalFormat, int *glFormat, int * #if defined(GRAPHICS_API_OPENGL_11) // Mipmaps data is generated after image data +// NOTE: Only works with RGBA (4 bytes) data! static int GenerateMipmaps(unsigned char *data, int baseWidth, int baseHeight) { int mipmapCount = 1; // Required mipmap levels count (including base level) From 3b70b66a089ed48b99305ce058a4bbde4a0bc3b4 Mon Sep 17 00:00:00 2001 From: raysan5 Date: Sun, 20 May 2018 00:41:12 +0200 Subject: [PATCH 44/53] Love OpenGL gotchas... make my life more enjoyable! --- src/rlgl.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/rlgl.c b/src/rlgl.c index e69694e90..f83a9f6b4 100644 --- a/src/rlgl.c +++ b/src/rlgl.c @@ -1456,7 +1456,11 @@ unsigned int rlLoadTexture(void *data, int width, int height, int format, int mi } else if (format == UNCOMPRESSED_GRAY_ALPHA) { + #if defined(GRAPHICS_API_OPENGL_21) + GLint swizzleMask[] = { GL_RED, GL_RED, GL_RED, GL_ALPHA }; + #elif defined(GRAPHICS_API_OPENGL_33) GLint swizzleMask[] = { GL_RED, GL_RED, GL_RED, GL_GREEN }; + #endif glTexParameteriv(GL_TEXTURE_2D, GL_TEXTURE_SWIZZLE_RGBA, swizzleMask); } #endif From ca690688149e90b8fc92713d31b17330f9ea8b43 Mon Sep 17 00:00:00 2001 From: raysan5 Date: Sun, 20 May 2018 01:55:46 +0200 Subject: [PATCH 45/53] Added function: rlCheckBufferLimit() --- src/rlgl.c | 54 +++++++++++++++++++++++++++++++++------------------- src/rlgl.h | 1 + src/shapes.c | 16 +++++++++++++++- 3 files changed, 50 insertions(+), 21 deletions(-) diff --git a/src/rlgl.c b/src/rlgl.c index f83a9f6b4..8912a3940 100644 --- a/src/rlgl.c +++ b/src/rlgl.c @@ -85,18 +85,18 @@ #define WINGDIAPI __declspec(dllimport) #endif - #include // OpenGL 1.1 library + #include // OpenGL 1.1 library #endif #endif #if defined(GRAPHICS_API_OPENGL_21) - #define GRAPHICS_API_OPENGL_33 + #define GRAPHICS_API_OPENGL_33 // OpenGL 2.1 uses mostly OpenGL 3.3 Core functionality #endif #if defined(GRAPHICS_API_OPENGL_33) #if defined(__APPLE__) - #include // OpenGL 3 library for OSX - #include + #include // OpenGL 3 library for OSX + #include // OpenGL 3 extensions library for OSX #else #define GLAD_IMPLEMENTATION #if defined(RLGL_STANDALONE) @@ -108,17 +108,17 @@ #endif #if defined(GRAPHICS_API_OPENGL_ES2) - #include // EGL library - #include // OpenGL ES 2.0 library - #include // OpenGL ES 2.0 extensions library + #include // EGL library + #include // OpenGL ES 2.0 library + #include // OpenGL ES 2.0 extensions library #endif #if defined(RLGL_STANDALONE) - #include // Required for: va_list, va_start(), vfprintf(), va_end() [Used only on TraceLog()] + #include // Required for: va_list, va_start(), vfprintf(), va_end() [Used only on TraceLog()] #endif #if !defined(GRAPHICS_API_OPENGL_11) && defined(SUPPORT_DISTORTION_SHADER) - #include "shader_distortion.h" // Distortion shader to be embedded + #include "shader_distortion.h" // Distortion shader to be embedded #endif @@ -307,17 +307,17 @@ static bool vrStereoRender = false; // VR stereo rendering enabled/disabled // Extension supported flag: Anisotropic filtering static bool texAnisotropicFilterSupported = false; // Anisotropic texture filtering support -static float maxAnisotropicLevel = 0.0f; // Maximum anisotropy level supported (minimum is 2.0f) +static float maxAnisotropicLevel = 0.0f; // Maximum anisotropy level supported (minimum is 2.0f) // Extension supported flag: Clamp mirror wrap mode -static bool texClampMirrorSupported = false; // Clamp mirror wrap mode supported +static bool texClampMirrorSupported = false; // Clamp mirror wrap mode supported #if defined(GRAPHICS_API_OPENGL_ES2) // NOTE: VAO functionality is exposed through extensions (OES) static PFNGLGENVERTEXARRAYSOESPROC glGenVertexArrays; static PFNGLBINDVERTEXARRAYOESPROC glBindVertexArray; static PFNGLDELETEVERTEXARRAYSOESPROC glDeleteVertexArrays; -//static PFNGLISVERTEXARRAYOESPROC glIsVertexArray; // NOTE: Fails in WebGL, omitted +//static PFNGLISVERTEXARRAYOESPROC glIsVertexArray; // NOTE: Fails in WebGL, omitted #endif static bool debugMarkerSupported = false; @@ -658,13 +658,11 @@ void rlEnd(void) // Correct increment formula would be: depthInc = (zfar - znear)/pow(2, bits) currentDepth += (1.0f/20000.0f); - // TODO: Verify internal buffers limits - // NOTE: Before launching draw, verify no matrix are left in the stack! - // NOTE: Probably a lines/triangles margin should be left, rlEnd could be called - // after an undetermined number of triangles buffered (check shapes::DrawPoly()) + // Verify internal buffers limits + // NOTE: This check is combined with usage of rlCheckBufferLimit() if ((lines.vCounter/2 >= MAX_LINES_BATCH - 2) || - (triangles.vCounter/3 >= MAX_TRIANGLES_BATCH - 16) || - (quads.vCounter/4 >= MAX_QUADS_BATCH - 2)) rlglDraw(); + (triangles.vCounter/3 >= MAX_TRIANGLES_BATCH - 3) || + (quads.vCounter/4 >= MAX_QUADS_BATCH - 4)) rlglDraw(); } // Define one vertex (position) @@ -1313,6 +1311,22 @@ int rlGetVersion(void) #endif } +// Check internal buffer overflow for a given number of vertex +bool rlCheckBufferLimit(int type, int vCount) +{ + bool overflow = false; +#if defined(GRAPHICS_API_OPENGL_33) || defined(GRAPHICS_API_OPENGL_ES2) + switch (type) + { + case RL_LINES: overflow = ((lines.vCounter + vCount)/2 >= MAX_LINES_BATCH); break; + case RL_TRIANGLES: overflow = ((triangles.vCounter + vCount)/3 >= MAX_TRIANGLES_BATCH); break; + case RL_QUADS: overflow = ((quads.vCounter + vCount)/4 >= MAX_QUADS_BATCH); break; + default: break; + } +#endif + return overflow; +} + // Set debug marker void rlSetDebugMarker(const char *text) { @@ -1325,7 +1339,7 @@ void rlSetDebugMarker(const char *text) // NOTE: External loader function could be passed as a pointer void rlLoadExtensions(void *loader) { -#if defined(GRAPHICS_API_OPENGL_21) || defined(GRAPHICS_API_OPENGL_33) +#if defined(GRAPHICS_API_OPENGL_33) // NOTE: glad is generated and contains only required OpenGL 3.3 Core extensions (and lower versions) #if !defined(__APPLE__) if (!gladLoadGLLoader((GLADloadproc)loader)) TraceLog(LOG_WARNING, "GLAD: Cannot load OpenGL extensions"); @@ -1448,7 +1462,7 @@ unsigned int rlLoadTexture(void *data, int width, int height, int format, int mi else glCompressedTexImage2D(GL_TEXTURE_2D, i, glInternalFormat, mipWidth, mipHeight, 0, mipSize, (unsigned char *)data + mipOffset); #endif - #if defined(GRAPHICS_API_OPENGL_21) || defined(GRAPHICS_API_OPENGL_33) + #if defined(GRAPHICS_API_OPENGL_33) if (format == UNCOMPRESSED_GRAYSCALE) { GLint swizzleMask[] = { GL_RED, GL_RED, GL_RED, GL_ONE }; diff --git a/src/rlgl.h b/src/rlgl.h index c071acac2..18eff3809 100644 --- a/src/rlgl.h +++ b/src/rlgl.h @@ -424,6 +424,7 @@ void rlglClose(void); // De-inititialize rlgl (buffers void rlglDraw(void); // Update and Draw default buffers (lines, triangles, quads) int rlGetVersion(void); // Returns current OpenGL version +bool rlCheckBufferLimit(int type, int vCount); // Check internal buffer overflow for a given number of vertex void rlSetDebugMarker(const char *text); // Set debug marker for analysis void rlLoadExtensions(void *loader); // Load OpenGL extensions Vector3 rlUnproject(Vector3 source, Matrix proj, Matrix view); // Get world coordinates from screen coordinates diff --git a/src/shapes.c b/src/shapes.c index 361fb9c7a..dc547e0d2 100644 --- a/src/shapes.c +++ b/src/shapes.c @@ -173,6 +173,8 @@ void DrawCircle(int centerX, int centerY, float radius, Color color) // NOTE: Gradient goes from center (color1) to border (color2) void DrawCircleGradient(int centerX, int centerY, float radius, Color color1, Color color2) { + if (rlCheckBufferLimit(RL_TRIANGLES, 3*36)) rlglDraw(); + rlBegin(RL_TRIANGLES); for (int i = 0; i < 360; i += 10) { @@ -189,8 +191,10 @@ void DrawCircleGradient(int centerX, int centerY, float radius, Color color1, Co // Draw a color-filled circle (Vector version) // NOTE: On OpenGL 3.3 and ES2 we use QUADS to avoid drawing order issues (view rlglDraw) void DrawCircleV(Vector2 center, float radius, Color color) -{ +{ #if defined(SUPPORT_QUADS_DRAW_MODE) + if (rlCheckBufferLimit(RL_QUADS, 4*(36/2))) rlglDraw(); + rlEnableTexture(GetTextureDefault().id); // Default white texture rlBegin(RL_QUADS); @@ -207,6 +211,8 @@ void DrawCircleV(Vector2 center, float radius, Color color) rlDisableTexture(); #else + if (rlCheckBufferLimit(RL_TRIANGLES, 3*(36/2))) rlglDraw(); + rlBegin(RL_TRIANGLES); for (int i = 0; i < 360; i += 10) { @@ -223,6 +229,8 @@ void DrawCircleV(Vector2 center, float radius, Color color) // Draw circle outline void DrawCircleLines(int centerX, int centerY, float radius, Color color) { + if (rlCheckBufferLimit(RL_LINES, 2*36)) rlglDraw(); + rlBegin(RL_LINES); rlColor4ub(color.r, color.g, color.b, color.a); @@ -504,6 +512,8 @@ void DrawTriangleLines(Vector2 v1, Vector2 v2, Vector2 v3, Color color) void DrawPoly(Vector2 center, int sides, float radius, float rotation, Color color) { if (sides < 3) sides = 3; + + if (rlCheckBufferLimit(RL_QUADS, 4*(360/sides))) rlglDraw(); rlPushMatrix(); rlTranslatef(center.x, center.y, 0.0); @@ -544,6 +554,8 @@ void DrawPolyEx(Vector2 *points, int pointsCount, Color color) { if (pointsCount >= 3) { + if (rlCheckBufferLimit(RL_QUADS, pointsCount)) rlglDraw(); + #if defined(SUPPORT_QUADS_DRAW_MODE) rlEnableTexture(GetTextureDefault().id); // Default white texture @@ -579,6 +591,8 @@ void DrawPolyExLines(Vector2 *points, int pointsCount, Color color) { if (pointsCount >= 2) { + if (rlCheckBufferLimit(RL_LINES, pointsCount)) rlglDraw(); + rlBegin(RL_LINES); rlColor4ub(color.r, color.g, color.b, color.a); From 8e0cd51afb50bcc7b96fc0530c74dc7210b0138d Mon Sep 17 00:00:00 2001 From: raysan5 Date: Sun, 20 May 2018 18:49:58 +0200 Subject: [PATCH 46/53] Support shared library building on Android --- release/libs/android/arm64-v8a/libraylib.a | Bin 981332 -> 982394 bytes release/libs/android/arm64-v8a/libraylib.so | Bin 0 -> 553384 bytes src/Makefile | 5 ++++- 3 files changed, 4 insertions(+), 1 deletion(-) create mode 100644 release/libs/android/arm64-v8a/libraylib.so diff --git a/release/libs/android/arm64-v8a/libraylib.a b/release/libs/android/arm64-v8a/libraylib.a index 0e252902c40542aba10907fe2c9c23960155707f..76656402d262042dd212ef9426593f4338e41af3 100644 GIT binary patch delta 39287 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 LK6`D_g5UpNbK(~X diff --git a/release/libs/android/arm64-v8a/libraylib.so b/release/libs/android/arm64-v8a/libraylib.so new file mode 100644 index 0000000000000000000000000000000000000000..04e53f03955f50bee410481391f091c00ab3e582 GIT binary patch literal 553384 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

@!|O|y}p0`l;-E>KQrf7^B*br z{rpvP{yu-&3+Lv4P-#hhEq`F@uYNQ#^>^8^sdlG5b+>O;YG%44HD&4I)E_;Un|l3i z`KjOiQEBSbD{50CBN|eF|I;0*=Wf3{b=95sr)s}`BsFICk5V_k`BZB9kA9YVFuTJ~*_SI>n zQ}WVk-!D!(`%-DzZw^O{G{^k!UEyecE6H(H{2a&NhPjTg4^kada?>3(uVgtsS-jBk&>Kq}&lat4%-39w zvp>AXF*4^{j^>D)9Hp=3J5JtP;~2NF)G=v#h2#4%)sBYIn;jFz-{N>~M4e-f zZJXon8QUF47ktNYJg?F5{B3tQHa)h>k@V{K9PQ`tc5Iq@kHcJeuVc-l_d7mld(e@2 z`NNLZ%10bikM4CmF#2(aR`rDA_BVd)m~v&aIIbV^Uyd0K&p0Mt_;1J1o1b&c zzu4kvxcx;(`|$s9tb5{+!=853arwKybY$Lg%uze(RmYIyuRD&`A9uW!@}{Hzx!*hP zeeP{X;jMpklrR2^qjl^_N8u;$IZ9uD-*MolryV!k`;nud{$t0>m7hAwyyqPE7N2*F zTl=-cRCdXc{BzCO|0=Wd$rBdmrM!Ml^C$hCzusyT{NaVm zoI8(9ac1v~cfNjYf^+WVY0kzk5}o(Ia)tAOeKVbD>85wsXP5S2;hucagJx_Y!B=?q$@s!g>6`RnD=Gxtyz? z%5^rrc&+ov*H$~6&HvjHmmZ zn0ZaVrsM(rTvz@w?DunbhFzJuI_wrlLReF}DeUK&4-7bx9W&s2i=OL0e%Vd^H?ADo z{|VP?{eE)IUHx{i{#L(l-7qO);J53-#}|HK{o~rL)@w>fTlZA_e8Ar7(gC+_o-|3$ zmr8kK@p@5Slq(p$%J!!haeZTYN%dxJx@c_%=jr8)FQ5`1RCI4gcq-bJah=T@s6ABm z#IKyvEuGS|3R1g4s|QKMrpj`ZfhxJ)QCua8kN$q3fgw8bA*wq8MHIiNrgxR(t9sE@ zlTvLJUQS^3Je9>9ffb`m641B`iYzav=GdO51nX<{mM{c1MlLO@hZ3eUVJp#UD2W?OO1 zvSpf{LVfas7?m&4G!czAb=RRwAu7-uEu*x;<3^34s>HS)RU^@sLUhl6jE&9Bsi$B- zaH^p3<#to47ckPLu6q1qrpBmB%R*0{u`jGvC%3BCa>K)L_HGHdhf!4RF|Pd-$OR%! zd+C6j2o|AdM`1gW^iUQw^wt6wJyhaEoAF&{g^&&#zg9g~I z&WN@sw`W3?8hfVFuTn7?OO*NwBE0l=PnhpfGTF-?n}^o3c_A+w+mm3yh#0l6IYi4DvVtAk&mKjSWr<>C9{ZM zWZUIsrM0%1a|m$L54E>V91+V!hhSA{y-i*7#AsD$wrN3i=uq*v(XK1wq84{mxR=ng zIbf+@rI(3XTv^6Q>b1xaOOxVVlf4Tkdow3{GvxMKPI*mbq1-$2PmzBy1GU zkGs;AK$JHxPZm%vI~3({y|Egt7P+~Zmr~%Zj@RRjdvZEaw)OU7=TLt-IjZuwf|*C* zWo4{TX=$J*b(WNIGtIxoR@YV(YX#^o!vipr)+#?UQ{CLq&{?eZqV8l{jIO7O5|12# zXw~KAwo5AklQm&XeCy^@EG*C$k17!=9W|mib%8OKt4wv9B3TaEZ?q__Q zk*F`63R2n{ZzXGl=whmdc*|H}(SlpGjGK?ut`#{p_Zm^iSe%`atA`7OZ7J3hNbgi4 z)oe+1qlC-n<%e&q`9ur$09ENiQ=b0g3I>f;?0@(*7^@-UlwOt4#R6kePOpVoM`dY_XlD zq)t+rkYtjOWI`qhNk~ExnoKHMDkK?Fu!M|Z+LB7!X{9TzQE7{c7L|5s#flbJRJ53| zii$3~vMa0Xik7XoqM}8`Ep15W_kGU2cjnG8K)UPu`MvMwvy&XY_de%2=RD`{{dexU z&gz?UD^A?Oc5SU33}S^ht-`<{Z*HEv>keL9l~a&v%`6zbfH_>>QKEWo$6 zXl(A6|+c9Nf3nw|UKK>4YVxD$7bv-Ep)`N+I%kpq^>%=65+`#OmP3TfLN> zc2kiv(un-Lr7dp-auQS}Q{klB-w`ZNn7xE!76-Mz%Al2_290}pxmudIjoGZC2F#7_}sC!Lyy$zI9b2bw=5-g7iXpU#5vQeyJ{B1{XmpJu2 z7;#ZUEMFj1#arY-X}(5FX0ESl%8L>nB}=GhV&q^c6?)1TJyq?VDk{&f&43gx@<1RBgJ(P;IBq%RVFI%>9 zUX|OjZ(n9wAQxfs&Pamvw9tQk@D(_7T&ub<{* z#qOxaZ*3QPn>YfOZ1dDVn+wKWy~5$AXcd^ldfvUZkU65Lc`v$6>^w1Zof|sbtjFyA2nd)RHXh#QEEGP4XVdRMQ? z)~d3l&);kK+iYiSH`i4SeGb7iULPZtlh9&nfE?A}Wr~6lk#nP6Y z>SW9qZFNIRxVKos0Wx^H#M(@xiJVT@2&`Hx&cUi8L~6~HRpDqEM2qX=5S>m)Jr+>4x71ai=l=Q4(o(Vnli zVokAj^4YRWFR9_z*RA14iWRk4DUy8m5R5oC=mxfRXDJGU3*3{&0kSHbrBii}%; z3@&l&tXUtkiJsD!t4Ksa6HOOuH?TUEdVCkXXB_WixhEX&H8X!|8HTxSjH=9Kq+V}I zH{L*t&|;fKsxJ1`azQNrrPr?VRdQ9ba=v!F;*Pu2DTKZPK;+H~&s#Muw0_N+udt?J zDCbMN9^8_~Jkm<$ls4X@GidC~9Mj_am{0qlPVfB}!h@j;;dGoEm;He5mx;d(*J$k5 z*XeQzXNGkVR$L#l4xGeWNE}7TYS;?SJt{;R14j@NQMsY~wr#VhyW|J2xO@pmk- zr`mR;Y7>9ky4pc_o4)UKzWUO89Ld^)$+`DkH+dh^Qk;^0$VmPT zb0uSE3$>>mj=ZszX^S3Cey}jVg?-oPZkH=V98kXz@;)#hHn=Aw|=3d6z!pH z=U#mImGhU`?GJA|XUo^Vx9zDySDM#hU;6O27Dt=*+|KBJL#ji2e9u!QW3Oz-|MdO! zPKWl;!Kb{gq-~BzG9UKVdD%buly`aZHpeaOKNMnr+qs^VliR1RpMLoMbJ{|+2CmHA zk)NdhMt{jR&89i?x2kYV3bL{9ajI#oYLd{zeJ{T9@XLE|Is5YYvoCMD#is4pn)a}3 z&+g}3k3Q{m++v&9v32s(u06YCf8?@TY^nIy8UEU$$C6d}m3#jAxv}$SN8W#(YKS(6 zm*gByl_r1ct|;Yibl;R4Y)^`6omy`#w+oyi%GUh7!?n=5T2mu;I&eke03&6YOy zP1`@)LtWqb^`ecBXc?D#T*(UyZ6VFun;gp1mee`NlC?q%@rIH$r(OF$Ir_#4r9!^eJA3RiaN_$NiEo4QbzQ$(I?(b=NO^JbBxVwxsKCVHM^r$=i}s zmuXAVdT7oU?qB#6&H9BG7A(FZkKXq1wuKLRovEo;COK^S{sYFo?V<1M`Vao-*MGk9 z%B0nwr}>NiQ@XylOW!{&-Gum@EiyZtpG;um7jP=f{>PQ<_`s4RE!nX>If?m&wQ07x zyd=$OtFwh1TOQKtRR3FWzx1+2*VDFCe|z+x?BDy;%L_iUN45^C{XN$?lIzsg5|K{s z#lP;T@|S(vy-&H4YgK$7x?jw_>{~BW`Rb?2QRdLi_jA~tlzN@E-4nqX^;I*pgA26ITt)e$&20VN5@vxozr+ogy>yHJ9yT zqnQ`6+sva$(=VRZaPfYU4{I5iXyq+(TkbosLz#VvWZ%_&~Gf3B=OA_BC@1l!a$LU z%+-NYvQVh9OigB5y1K%-v+$6nY)~^k)RYF9H^J1=V?m}as#PoXnYUr&v*h+AmKaQR(WuftLr|@$TV$~*@%TZ_z|+@*j@FeKUdlk`d&(3D zQY8+Vu2cgco+3rTtEE6gjE=w{6k|J_Hbj!6+%j5P{6c5b+Dr&F&= zRg;Dt8=ZyBNoC>-4>k;5aXZd3bwE8`=UI+W zmL;iiXY0SnO?e}llIpTDHLJ&rR-bpk{cqPv9+w@xIafs?Gx8)JV$_qhSa9t4aW&aO zJz$W#^O2~S9mf|3!~~x8sEK3dKF`L~yfIYu34vyIh*u(uiN?6GT@{I?Dl+fPOv*@A zOi^aU#bLxyAu*`Q3Ke8Vb&Qzukl@vKRs>48A5hBIVc;I~;U5O;$dkik!I~BF=vIFe z!xIypW2;s)!zZR$onkTt6X%>2&s9a5v%8|v(&ZzoJ&pT z^YcQ3zWg6^_{vU8)0SsVC8tY*Cj(|TW$a>|T9u%hnJEd%h@s2P_ALX^tQM$8YUXSq zQkEx;E|(axd>P|``J_%_X8f%*qSo^$Y3cJbEE7yrXN=@F#=^)Xt1`x&)6&aNmmEDA zl$CjzVT4f6r=G={NN<*vmt?Z@@gqm8UCiA*vP{j-T9Iv;vmy2|FWk>0gkzNz@&bx7 zF>0OaP(~FbGAhz3jRH|vrk$3D%%@jr5sQ_TT8*01QX?c6id0YyvzTktC{iOCVpBYs zoGd$f2xC*1bCSpJw=42|=dWMr<@+Q2zQKEpvTn$ag(Lm_!{vHxpBZE8pulYcO}wPjB$BHVNy@XxT*c04}U~Gj{&$ ziXWWAZ5e#~>*2t4x*N}kZksY;>a~gGR-HuK9wS_uB@I*0ny$$5&}qk6UM}FIu7ov! z17+159HTqTj%3a0ee(%epQzQYp56gq1vNewJH%u-6#ECI~Y zr+gMk`SMish~C=EDv#f+25>&?ByV>x$->Z) zzq$}b{x8xht4}k`o^Y1Qmu5CHpS`RmK=qU{fu+hXA4Dj_|VMwEQNYEq#}5|c7yq$ zH5JE!ZF~4~hWcvGDd*iZ)TE0&PDTIIUK?bGnW# zbFR)_mE$~k{9C5n5@>!W9Rcn_K)g4Uwtmdn)G@2Ewsd)2`-gGQ` zG#_(MZK;~CSh-aGb5#_#u}ClPYThA}H~x5W_e8K#m&yB))I3FEydGCpBa^dzrr4N1 zuHK$i#_7j5OXp-(nrbXAi%c~Hj@SuA3=^C)GZl`*0w2R+SIw+7H)W{V&f7{eeQ(w=$2sLMI6Q{Um6;i1nSoFR^6Sw*DArKQVnd(WcVs~71u@oJk9RDYY6 zriz*JWf)ogy_zdr{cB~Bn-Kav1HDt}w;81QiJ6wB$Sw_1Bu49uLRT~PEkQ(IU54u! zO>k)}7nACvRIKT|%+U1}%wD3Lc+u#c+$C6Ft*aLp7xm^~CF{`dJrWt0wY?0Z#?Y

CcJ;7PGrnKF>5(( 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 Date: Sun, 20 May 2018 19:13:10 +0200 Subject: [PATCH 47/53] Removed 32bit arm Android library From 2019 64bit support will be mandatory to publish an Android app. Google plans to require that new apps target Oreo (API level 26) in August of 2018. --- release/libs/android/armeabi-v7a/libraylib.a | Bin 883994 -> 0 bytes release/libs/android/armeabi-v7a/libraylib.so | Bin 477808 -> 0 bytes src/Makefile | 15 ++--------- templates/advance_game/Makefile.Android | 24 ++++++++--------- templates/simple_game/Makefile.Android | 22 +++++++-------- templates/standard_game/Makefile.Android | 25 +++++++++--------- 6 files changed, 38 insertions(+), 48 deletions(-) delete mode 100644 release/libs/android/armeabi-v7a/libraylib.a delete mode 100644 release/libs/android/armeabi-v7a/libraylib.so diff --git a/release/libs/android/armeabi-v7a/libraylib.a b/release/libs/android/armeabi-v7a/libraylib.a deleted file mode 100644 index 1e6a008868bfc9f0d2ca887b032c30db2c312040..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 883994 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

U{JI#;#2r4^1%JFF$~DN^QIghOI3+ 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

=onv}g9`}5hF98@@5A3G&~F9Z4f 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 dPH?`!MGX)jXwV4ZMN6B6WJ6Y$Y}{;kE3JW` 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

sEj$_+fqzcc*86p=yU?>yXJI>f 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

f1 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 diff --git a/src/Makefile b/src/Makefile index ae0265c94..f8219044d 100644 --- a/src/Makefile +++ b/src/Makefile @@ -165,7 +165,8 @@ ifeq ($(PLATFORM),PLATFORM_ANDROID) ANDROID_NDK = C:/android-ndk ANDROID_TOOLCHAIN = C:/android_toolchain_arm64_api21 - # Android architecture: ARM or ARM64 + # Android architecture: ARM64 + # Starting at 2019 using ARM64 is mandatory for published apps ANDROID_ARCH ?= ARM64 endif @@ -195,9 +196,6 @@ ifeq ($(PLATFORM),PLATFORM_WEB) RAYLIB_RELEASE_PATH = $(RAYLIB_PATH)/release/libs/html5 endif ifeq ($(PLATFORM),PLATFORM_ANDROID) - ifeq ($(ANDROID_ARCH),ARM) - RAYLIB_RELEASE_PATH = $(RAYLIB_PATH)/release/libs/android/armeabi-v7a - endif ifeq ($(ANDROID_ARCH),ARM64) RAYLIB_RELEASE_PATH = $(RAYLIB_PATH)/release/libs/android/arm64-v8a endif @@ -251,9 +249,6 @@ ifeq ($(PLATFORM),PLATFORM_WEB) endif ifeq ($(PLATFORM),PLATFORM_ANDROID) # Android toolchain (must be provided for desired architecture and compiler) - ifeq ($(ANDROID_ARCH),ARM) - CC = $(ANDROID_TOOLCHAIN)/bin/arm-linux-androideabi-clang - endif ifeq ($(ANDROID_ARCH),ARM64) CC = $(ANDROID_TOOLCHAIN)/bin/aarch64-linux-android-clang endif @@ -272,9 +267,6 @@ endif # Android archiver (also depends on desired architecture) ifeq ($(PLATFORM),PLATFORM_ANDROID) - ifeq ($(ANDROID_ARCH),ARM) - AR = $(ANDROID_TOOLCHAIN)/bin/arm-linux-androideabi-ar - endif ifeq ($(ANDROID_ARCH),ARM64) AR = $(ANDROID_TOOLCHAIN)/bin/aarch64-linux-android-ar endif @@ -430,9 +422,6 @@ all: raylib # NOTE: Android toolchain could already be provided generate_android_toolchain: ifeq ($(PLATFORM),PLATFORM_ANDROID) - ifeq ($(ANDROID_ARCH),ARM) - $(ANDROID_NDK)/build/tools/make-standalone-toolchain.sh --platform=android-9 --toolchain=arm-linux-androideabi-4.9 --use-llvm --install-dir=$(ANDROID_TOOLCHAIN) - endif ifeq ($(ANDROID_ARCH),ARM64) $(ANDROID_NDK)/build/tools/make-standalone-toolchain.sh --platform=android-21 --toolchain=aarch64-linux-androideabi-4.9 --use-llvm --install-dir=$(ANDROID_TOOLCHAIN) endif diff --git a/templates/advance_game/Makefile.Android b/templates/advance_game/Makefile.Android index f082ab230..af23f4a38 100644 --- a/templates/advance_game/Makefile.Android +++ b/templates/advance_game/Makefile.Android @@ -29,7 +29,7 @@ RAYLIB_PATH ?= ..\.. # NOTE: JAVA_HOME must be set to JDK ANDROID_HOME = C:/android-sdk ANDROID_NDK = C:/android-ndk -ANDROID_TOOLCHAIN = C:/android_toolchain_arm_api16 +ANDROID_TOOLCHAIN = C:/android_toolchain_arm64_api21 ANDROID_BUILD_TOOLS = $(ANDROID_HOME)/build-tools/26.0.2 ANDROID_PLATFORM_TOOLS = $(ANDROID_HOME)/platform-tools JAVA_HOME = C:/PROGRA~1/Java/jdk1.8.0_144 @@ -61,21 +61,21 @@ APP_KEYSTORE_PASS ?= raylib # Library type used for raylib: STATIC (.a) or SHARED (.so/.dll) RAYLIB_LIBTYPE ?= STATIC -RAYLIB_LIB_PATH = $(RAYLIB_PATH)\release\libs\android\armeabi-v7a +RAYLIB_LIB_PATH = $(RAYLIB_PATH)\release\libs\android\arm64-v8a # Shared libs must be added to APK if required # NOTE: Generated NativeLoader.java automatically load those libraries ifeq ($(RAYLIB_LIBTYPE),SHARED) - PROJECT_SHARED_LIBS = lib/armeabi-v7a/libraylib.so + PROJECT_SHARED_LIBS = lib/arm64-v8a/libraylib.so endif # Compiler and archiver # NOTE: GCC is being deprectated in Android NDK r16 -CC = $(ANDROID_TOOLCHAIN)/bin/arm-linux-androideabi-gcc -AR = $(ANDROID_TOOLCHAIN)/bin/arm-linux-androideabi-ar +CC = $(ANDROID_TOOLCHAIN)/bin/aarch64-linux-android-clang +AR = $(ANDROID_TOOLCHAIN)/bin/aarch64-linux-android-ar # Compiler flags for arquitecture -CFLAGS = -std=c99 -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 +CFLAGS = -std=c99 -march=arm64-v8a # Compilation functions attributes options CFLAGS += -ffunction-sections -funwind-tables -fstack-protector-strong -fPIC # Compiler options for the linker @@ -92,7 +92,7 @@ LDFLAGS += -Wl,--build-id -Wl,--no-undefined -Wl,-z,noexecstack -Wl,-z,relro -Wl # Force linking of library module to define symbol LDFLAGS += -u ANativeActivity_onCreate # Library paths containing required libs -LDFLAGS += -L. -L$(PROJECT_BUILD_PATH)/obj -L$(PROJECT_BUILD_PATH)/lib/armeabi-v7a +LDFLAGS += -L. -L$(PROJECT_BUILD_PATH)/obj -L$(PROJECT_BUILD_PATH)/lib/arm64-v8a # Define any libraries to link into executable # if you want to link libraries (libname.so or libname.a), use the -lname @@ -127,7 +127,7 @@ create_temp_project_dirs: if not exist $(PROJECT_BUILD_PATH)\src\com\$(APP_COMPANY_NAME) mkdir $(PROJECT_BUILD_PATH)\src\com\$(APP_COMPANY_NAME) if not exist $(PROJECT_BUILD_PATH)\src\com\$(APP_COMPANY_NAME)\$(APP_PRODUCT_NAME) mkdir $(PROJECT_BUILD_PATH)\src\com\$(APP_COMPANY_NAME)\$(APP_PRODUCT_NAME) if not exist $(PROJECT_BUILD_PATH)\lib mkdir $(PROJECT_BUILD_PATH)\lib - if not exist $(PROJECT_BUILD_PATH)\lib\armeabi-v7a mkdir $(PROJECT_BUILD_PATH)\lib\armeabi-v7a + if not exist $(PROJECT_BUILD_PATH)\lib\arm64-v8a mkdir $(PROJECT_BUILD_PATH)\lib\arm64-v8a if not exist $(PROJECT_BUILD_PATH)\bin mkdir $(PROJECT_BUILD_PATH)\bin if not exist $(PROJECT_BUILD_PATH)\res mkdir $(PROJECT_BUILD_PATH)\res if not exist $(PROJECT_BUILD_PATH)\res\drawable-ldpi mkdir $(PROJECT_BUILD_PATH)\res\drawable-ldpi @@ -147,10 +147,10 @@ endef # NOTE: If using shared libs they are loaded by generated NativeLoader.java copy_project_required_libs: ifeq ($(RAYLIB_LIBTYPE),SHARED) - copy /Y $(RAYLIB_LIB_PATH)\libraylib.so $(PROJECT_BUILD_PATH)\lib\armeabi-v7a\libraylib.so + copy /Y $(RAYLIB_LIB_PATH)\libraylib.so $(PROJECT_BUILD_PATH)\lib\arm64-v8a\libraylib.so endif ifeq ($(RAYLIB_LIBTYPE),STATIC) - copy /Y $(RAYLIB_LIB_PATH)\libraylib.a $(PROJECT_BUILD_PATH)\lib\armeabi-v7a\libraylib.a + copy /Y $(RAYLIB_LIB_PATH)\libraylib.a $(PROJECT_BUILD_PATH)\lib\arm64-v8a\libraylib.a endif # Copy project required resources: strings.xml, icon.png, assets @@ -219,7 +219,7 @@ compile_native_app_glue: # Compile project code into a shared library: lib/lib$(PROJECT_LIBRARY_NAME).so compile_project_code: $(OBJS) - $(CC) -o $(PROJECT_BUILD_PATH)/lib/armeabi-v7a/lib$(PROJECT_LIBRARY_NAME).so $(OBJS) -shared $(INCLUDE_PATHS) $(LDFLAGS) $(LDLIBS) + $(CC) -o $(PROJECT_BUILD_PATH)/lib/arm64-v8a/lib$(PROJECT_LIBRARY_NAME).so $(OBJS) -shared $(INCLUDE_PATHS) $(LDFLAGS) $(LDLIBS) # Compile all .c files required into object (.o) files # NOTE: Those files will be linked into a shared library @@ -240,7 +240,7 @@ compile_project_class_dex: # NOTE: Use -A resources to define additional directory in which to find raw asset files create_project_apk_package: $(ANDROID_BUILD_TOOLS)/aapt package -f -M $(PROJECT_BUILD_PATH)/AndroidManifest.xml -S $(PROJECT_BUILD_PATH)/res -A $(PROJECT_BUILD_PATH)/assets -I $(ANDROID_HOME)/platforms/android-16/android.jar -F $(PROJECT_BUILD_PATH)/bin/$(PROJECT_NAME).unsigned.apk $(PROJECT_BUILD_PATH)/bin - cd $(PROJECT_BUILD_PATH) && $(ANDROID_BUILD_TOOLS)/aapt add bin/$(PROJECT_NAME).unsigned.apk lib/armeabi-v7a/lib$(PROJECT_LIBRARY_NAME).so $(PROJECT_SHARED_LIBS) + cd $(PROJECT_BUILD_PATH) && $(ANDROID_BUILD_TOOLS)/aapt add bin/$(PROJECT_NAME).unsigned.apk lib/arm64-v8a/lib$(PROJECT_LIBRARY_NAME).so $(PROJECT_SHARED_LIBS) # Create signed APK package using generated Key: bin/$(PROJECT_NAME).signed.apk sign_project_apk_package: diff --git a/templates/simple_game/Makefile.Android b/templates/simple_game/Makefile.Android index f082ab230..e45293fd2 100644 --- a/templates/simple_game/Makefile.Android +++ b/templates/simple_game/Makefile.Android @@ -29,7 +29,7 @@ RAYLIB_PATH ?= ..\.. # NOTE: JAVA_HOME must be set to JDK ANDROID_HOME = C:/android-sdk ANDROID_NDK = C:/android-ndk -ANDROID_TOOLCHAIN = C:/android_toolchain_arm_api16 +ANDROID_TOOLCHAIN = C:/android_toolchain_arm64_api21 ANDROID_BUILD_TOOLS = $(ANDROID_HOME)/build-tools/26.0.2 ANDROID_PLATFORM_TOOLS = $(ANDROID_HOME)/platform-tools JAVA_HOME = C:/PROGRA~1/Java/jdk1.8.0_144 @@ -61,21 +61,21 @@ APP_KEYSTORE_PASS ?= raylib # Library type used for raylib: STATIC (.a) or SHARED (.so/.dll) RAYLIB_LIBTYPE ?= STATIC -RAYLIB_LIB_PATH = $(RAYLIB_PATH)\release\libs\android\armeabi-v7a +RAYLIB_LIB_PATH = $(RAYLIB_PATH)\release\libs\android\arm64-v8a # Shared libs must be added to APK if required # NOTE: Generated NativeLoader.java automatically load those libraries ifeq ($(RAYLIB_LIBTYPE),SHARED) - PROJECT_SHARED_LIBS = lib/armeabi-v7a/libraylib.so + PROJECT_SHARED_LIBS = lib/arm64-v8a/libraylib.so endif # Compiler and archiver # NOTE: GCC is being deprectated in Android NDK r16 -CC = $(ANDROID_TOOLCHAIN)/bin/arm-linux-androideabi-gcc -AR = $(ANDROID_TOOLCHAIN)/bin/arm-linux-androideabi-ar +CC = $(ANDROID_TOOLCHAIN)/bin/aarch64-linux-android-clang +AR = $(ANDROID_TOOLCHAIN)/bin/aarch64-linux-android-ar # Compiler flags for arquitecture -CFLAGS = -std=c99 -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 +CFLAGS = -std=c99 -march=arm64-v8a # Compilation functions attributes options CFLAGS += -ffunction-sections -funwind-tables -fstack-protector-strong -fPIC # Compiler options for the linker @@ -127,7 +127,7 @@ create_temp_project_dirs: if not exist $(PROJECT_BUILD_PATH)\src\com\$(APP_COMPANY_NAME) mkdir $(PROJECT_BUILD_PATH)\src\com\$(APP_COMPANY_NAME) if not exist $(PROJECT_BUILD_PATH)\src\com\$(APP_COMPANY_NAME)\$(APP_PRODUCT_NAME) mkdir $(PROJECT_BUILD_PATH)\src\com\$(APP_COMPANY_NAME)\$(APP_PRODUCT_NAME) if not exist $(PROJECT_BUILD_PATH)\lib mkdir $(PROJECT_BUILD_PATH)\lib - if not exist $(PROJECT_BUILD_PATH)\lib\armeabi-v7a mkdir $(PROJECT_BUILD_PATH)\lib\armeabi-v7a + if not exist $(PROJECT_BUILD_PATH)\lib\arm64-v8a mkdir $(PROJECT_BUILD_PATH)\lib\arm64-v8a if not exist $(PROJECT_BUILD_PATH)\bin mkdir $(PROJECT_BUILD_PATH)\bin if not exist $(PROJECT_BUILD_PATH)\res mkdir $(PROJECT_BUILD_PATH)\res if not exist $(PROJECT_BUILD_PATH)\res\drawable-ldpi mkdir $(PROJECT_BUILD_PATH)\res\drawable-ldpi @@ -147,10 +147,10 @@ endef # NOTE: If using shared libs they are loaded by generated NativeLoader.java copy_project_required_libs: ifeq ($(RAYLIB_LIBTYPE),SHARED) - copy /Y $(RAYLIB_LIB_PATH)\libraylib.so $(PROJECT_BUILD_PATH)\lib\armeabi-v7a\libraylib.so + copy /Y $(RAYLIB_LIB_PATH)\libraylib.so $(PROJECT_BUILD_PATH)\lib\arm64-v8a\libraylib.so endif ifeq ($(RAYLIB_LIBTYPE),STATIC) - copy /Y $(RAYLIB_LIB_PATH)\libraylib.a $(PROJECT_BUILD_PATH)\lib\armeabi-v7a\libraylib.a + copy /Y $(RAYLIB_LIB_PATH)\libraylib.a $(PROJECT_BUILD_PATH)\lib\arm64-v8a\libraylib.a endif # Copy project required resources: strings.xml, icon.png, assets @@ -219,7 +219,7 @@ compile_native_app_glue: # Compile project code into a shared library: lib/lib$(PROJECT_LIBRARY_NAME).so compile_project_code: $(OBJS) - $(CC) -o $(PROJECT_BUILD_PATH)/lib/armeabi-v7a/lib$(PROJECT_LIBRARY_NAME).so $(OBJS) -shared $(INCLUDE_PATHS) $(LDFLAGS) $(LDLIBS) + $(CC) -o $(PROJECT_BUILD_PATH)/lib/arm64-v8a/lib$(PROJECT_LIBRARY_NAME).so $(OBJS) -shared $(INCLUDE_PATHS) $(LDFLAGS) $(LDLIBS) # Compile all .c files required into object (.o) files # NOTE: Those files will be linked into a shared library @@ -240,7 +240,7 @@ compile_project_class_dex: # NOTE: Use -A resources to define additional directory in which to find raw asset files create_project_apk_package: $(ANDROID_BUILD_TOOLS)/aapt package -f -M $(PROJECT_BUILD_PATH)/AndroidManifest.xml -S $(PROJECT_BUILD_PATH)/res -A $(PROJECT_BUILD_PATH)/assets -I $(ANDROID_HOME)/platforms/android-16/android.jar -F $(PROJECT_BUILD_PATH)/bin/$(PROJECT_NAME).unsigned.apk $(PROJECT_BUILD_PATH)/bin - cd $(PROJECT_BUILD_PATH) && $(ANDROID_BUILD_TOOLS)/aapt add bin/$(PROJECT_NAME).unsigned.apk lib/armeabi-v7a/lib$(PROJECT_LIBRARY_NAME).so $(PROJECT_SHARED_LIBS) + cd $(PROJECT_BUILD_PATH) && $(ANDROID_BUILD_TOOLS)/aapt add bin/$(PROJECT_NAME).unsigned.apk lib/arm64-v8a/lib$(PROJECT_LIBRARY_NAME).so $(PROJECT_SHARED_LIBS) # Create signed APK package using generated Key: bin/$(PROJECT_NAME).signed.apk sign_project_apk_package: diff --git a/templates/standard_game/Makefile.Android b/templates/standard_game/Makefile.Android index f082ab230..d9503a40a 100644 --- a/templates/standard_game/Makefile.Android +++ b/templates/standard_game/Makefile.Android @@ -29,7 +29,7 @@ RAYLIB_PATH ?= ..\.. # NOTE: JAVA_HOME must be set to JDK ANDROID_HOME = C:/android-sdk ANDROID_NDK = C:/android-ndk -ANDROID_TOOLCHAIN = C:/android_toolchain_arm_api16 +ANDROID_TOOLCHAIN = C:/android_toolchain_arm64_api21 ANDROID_BUILD_TOOLS = $(ANDROID_HOME)/build-tools/26.0.2 ANDROID_PLATFORM_TOOLS = $(ANDROID_HOME)/platform-tools JAVA_HOME = C:/PROGRA~1/Java/jdk1.8.0_144 @@ -61,21 +61,22 @@ APP_KEYSTORE_PASS ?= raylib # Library type used for raylib: STATIC (.a) or SHARED (.so/.dll) RAYLIB_LIBTYPE ?= STATIC -RAYLIB_LIB_PATH = $(RAYLIB_PATH)\release\libs\android\armeabi-v7a +RAYLIB_LIB_PATH = $(RAYLIB_PATH)\release\libs\android\arm64-v8a # Shared libs must be added to APK if required # NOTE: Generated NativeLoader.java automatically load those libraries ifeq ($(RAYLIB_LIBTYPE),SHARED) - PROJECT_SHARED_LIBS = lib/armeabi-v7a/libraylib.so + PROJECT_SHARED_LIBS = lib/arm64-v8a/libraylib.so endif # Compiler and archiver # NOTE: GCC is being deprectated in Android NDK r16 -CC = $(ANDROID_TOOLCHAIN)/bin/arm-linux-androideabi-gcc -AR = $(ANDROID_TOOLCHAIN)/bin/arm-linux-androideabi-ar +CC = $(ANDROID_TOOLCHAIN)/bin/aarch64-linux-android-clang +AR = $(ANDROID_TOOLCHAIN)/bin/aarch64-linux-android-ar # Compiler flags for arquitecture -CFLAGS = -std=c99 -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 +#CFLAGS = -std=c99 -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 --> Old 32bit +CFLAGS = -std=c99 -march=arm64-v8a # Compilation functions attributes options CFLAGS += -ffunction-sections -funwind-tables -fstack-protector-strong -fPIC # Compiler options for the linker @@ -92,7 +93,7 @@ LDFLAGS += -Wl,--build-id -Wl,--no-undefined -Wl,-z,noexecstack -Wl,-z,relro -Wl # Force linking of library module to define symbol LDFLAGS += -u ANativeActivity_onCreate # Library paths containing required libs -LDFLAGS += -L. -L$(PROJECT_BUILD_PATH)/obj -L$(PROJECT_BUILD_PATH)/lib/armeabi-v7a +LDFLAGS += -L. -L$(PROJECT_BUILD_PATH)/obj -L$(PROJECT_BUILD_PATH)/lib/arm64-v8a # Define any libraries to link into executable # if you want to link libraries (libname.so or libname.a), use the -lname @@ -127,7 +128,7 @@ create_temp_project_dirs: if not exist $(PROJECT_BUILD_PATH)\src\com\$(APP_COMPANY_NAME) mkdir $(PROJECT_BUILD_PATH)\src\com\$(APP_COMPANY_NAME) if not exist $(PROJECT_BUILD_PATH)\src\com\$(APP_COMPANY_NAME)\$(APP_PRODUCT_NAME) mkdir $(PROJECT_BUILD_PATH)\src\com\$(APP_COMPANY_NAME)\$(APP_PRODUCT_NAME) if not exist $(PROJECT_BUILD_PATH)\lib mkdir $(PROJECT_BUILD_PATH)\lib - if not exist $(PROJECT_BUILD_PATH)\lib\armeabi-v7a mkdir $(PROJECT_BUILD_PATH)\lib\armeabi-v7a + if not exist $(PROJECT_BUILD_PATH)\lib\arm64-v8a mkdir $(PROJECT_BUILD_PATH)\lib\arm64-v8a if not exist $(PROJECT_BUILD_PATH)\bin mkdir $(PROJECT_BUILD_PATH)\bin if not exist $(PROJECT_BUILD_PATH)\res mkdir $(PROJECT_BUILD_PATH)\res if not exist $(PROJECT_BUILD_PATH)\res\drawable-ldpi mkdir $(PROJECT_BUILD_PATH)\res\drawable-ldpi @@ -147,10 +148,10 @@ endef # NOTE: If using shared libs they are loaded by generated NativeLoader.java copy_project_required_libs: ifeq ($(RAYLIB_LIBTYPE),SHARED) - copy /Y $(RAYLIB_LIB_PATH)\libraylib.so $(PROJECT_BUILD_PATH)\lib\armeabi-v7a\libraylib.so + copy /Y $(RAYLIB_LIB_PATH)\libraylib.so $(PROJECT_BUILD_PATH)\lib\arm64-v8a\libraylib.so endif ifeq ($(RAYLIB_LIBTYPE),STATIC) - copy /Y $(RAYLIB_LIB_PATH)\libraylib.a $(PROJECT_BUILD_PATH)\lib\armeabi-v7a\libraylib.a + copy /Y $(RAYLIB_LIB_PATH)\libraylib.a $(PROJECT_BUILD_PATH)\lib\arm64-v8a\libraylib.a endif # Copy project required resources: strings.xml, icon.png, assets @@ -219,7 +220,7 @@ compile_native_app_glue: # Compile project code into a shared library: lib/lib$(PROJECT_LIBRARY_NAME).so compile_project_code: $(OBJS) - $(CC) -o $(PROJECT_BUILD_PATH)/lib/armeabi-v7a/lib$(PROJECT_LIBRARY_NAME).so $(OBJS) -shared $(INCLUDE_PATHS) $(LDFLAGS) $(LDLIBS) + $(CC) -o $(PROJECT_BUILD_PATH)/lib/arm64-v8a/lib$(PROJECT_LIBRARY_NAME).so $(OBJS) -shared $(INCLUDE_PATHS) $(LDFLAGS) $(LDLIBS) # Compile all .c files required into object (.o) files # NOTE: Those files will be linked into a shared library @@ -240,7 +241,7 @@ compile_project_class_dex: # NOTE: Use -A resources to define additional directory in which to find raw asset files create_project_apk_package: $(ANDROID_BUILD_TOOLS)/aapt package -f -M $(PROJECT_BUILD_PATH)/AndroidManifest.xml -S $(PROJECT_BUILD_PATH)/res -A $(PROJECT_BUILD_PATH)/assets -I $(ANDROID_HOME)/platforms/android-16/android.jar -F $(PROJECT_BUILD_PATH)/bin/$(PROJECT_NAME).unsigned.apk $(PROJECT_BUILD_PATH)/bin - cd $(PROJECT_BUILD_PATH) && $(ANDROID_BUILD_TOOLS)/aapt add bin/$(PROJECT_NAME).unsigned.apk lib/armeabi-v7a/lib$(PROJECT_LIBRARY_NAME).so $(PROJECT_SHARED_LIBS) + cd $(PROJECT_BUILD_PATH) && $(ANDROID_BUILD_TOOLS)/aapt add bin/$(PROJECT_NAME).unsigned.apk lib/arm64-v8a/lib$(PROJECT_LIBRARY_NAME).so $(PROJECT_SHARED_LIBS) # Create signed APK package using generated Key: bin/$(PROJECT_NAME).signed.apk sign_project_apk_package: From 20ddc6a2bb4cbd39c460d8fa5d1f7175095bba2f Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Sun, 20 May 2018 19:47:19 +0200 Subject: [PATCH 48/53] Move utils.cmake to separate cmake/ directory --- utils.cmake => cmake/utils.cmake | 0 examples/CMakeLists.txt | 2 +- games/CMakeLists.txt | 2 +- games/drturtle/CMakeLists.txt | 2 +- games/just_do/CMakeLists.txt | 2 +- games/koala_seasons/CMakeLists.txt | 2 +- games/light_my_ritual/CMakeLists.txt | 2 +- games/skully_escape/CMakeLists.txt | 2 +- games/wave_collector/CMakeLists.txt | 2 +- src/CMakeLists.txt | 2 +- 10 files changed, 9 insertions(+), 9 deletions(-) rename utils.cmake => cmake/utils.cmake (100%) diff --git a/utils.cmake b/cmake/utils.cmake similarity index 100% rename from utils.cmake rename to cmake/utils.cmake diff --git a/examples/CMakeLists.txt b/examples/CMakeLists.txt index 1f05d529e..ae882444a 100644 --- a/examples/CMakeLists.txt +++ b/examples/CMakeLists.txt @@ -1,7 +1,7 @@ # Setup the project and settings project(examples) -include("../utils.cmake") +include("../cmake/utils.cmake") # Make sure raylib has been built # TODO `build` directory should maybe be something else... diff --git a/games/CMakeLists.txt b/games/CMakeLists.txt index 278d1330d..35c991394 100644 --- a/games/CMakeLists.txt +++ b/games/CMakeLists.txt @@ -1,7 +1,7 @@ # Setup the project and settings project(games) -include("../utils.cmake") +include("../cmake/utils.cmake") # Make sure raylib has been built # TODO `build` directory should maybe be something else... diff --git a/games/drturtle/CMakeLists.txt b/games/drturtle/CMakeLists.txt index 59813fb3a..bdd919708 100644 --- a/games/drturtle/CMakeLists.txt +++ b/games/drturtle/CMakeLists.txt @@ -1,7 +1,7 @@ # Setup the project and settings project(drturtle) -include("../../utils.cmake") +include("../../cmake/utils.cmake") # Make sure raylib has been built diff --git a/games/just_do/CMakeLists.txt b/games/just_do/CMakeLists.txt index 116440086..4c5e1ee46 100644 --- a/games/just_do/CMakeLists.txt +++ b/games/just_do/CMakeLists.txt @@ -1,7 +1,7 @@ # Setup the project and settings project(just_do) -include("../../utils.cmake") +include("../../cmake/utils.cmake") # Make sure raylib has been built diff --git a/games/koala_seasons/CMakeLists.txt b/games/koala_seasons/CMakeLists.txt index 16069a7e9..f79ab9112 100644 --- a/games/koala_seasons/CMakeLists.txt +++ b/games/koala_seasons/CMakeLists.txt @@ -1,7 +1,7 @@ # Setup the project and settings project(koala_seasons) -include("../../utils.cmake") +include("../../cmake/utils.cmake") # Make sure raylib has been built diff --git a/games/light_my_ritual/CMakeLists.txt b/games/light_my_ritual/CMakeLists.txt index 1e2cafe18..11d2e4f4e 100644 --- a/games/light_my_ritual/CMakeLists.txt +++ b/games/light_my_ritual/CMakeLists.txt @@ -1,7 +1,7 @@ # Setup the project and settings project(light_my_ritual) -include("../../utils.cmake") +include("../../cmake/utils.cmake") # Make sure raylib has been built diff --git a/games/skully_escape/CMakeLists.txt b/games/skully_escape/CMakeLists.txt index d14f52d9e..337e1db56 100644 --- a/games/skully_escape/CMakeLists.txt +++ b/games/skully_escape/CMakeLists.txt @@ -1,7 +1,7 @@ # Setup the project and settings project(skully_escape) -include("../../utils.cmake") +include("../../cmake/utils.cmake") # Make sure raylib has been built diff --git a/games/wave_collector/CMakeLists.txt b/games/wave_collector/CMakeLists.txt index c16bd4263..ca6c37b82 100644 --- a/games/wave_collector/CMakeLists.txt +++ b/games/wave_collector/CMakeLists.txt @@ -1,7 +1,7 @@ # Setup the project and settings project(wave_collector) -include("../../utils.cmake") +include("../../cmake/utils.cmake") # Make sure raylib has been built diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 458b96064..4b32de107 100755 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -39,7 +39,7 @@ if(NOT glfw3_FOUND) list(APPEND raylib_sources $) endif() -include("../utils.cmake") +include("../cmake/utils.cmake") if(USE_AUDIO) file(GLOB stb_vorbis external/stb_vorbis.c) From ae26e083b4471f1404e4f25eee71e4f71e9b13f0 Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Sun, 20 May 2018 19:59:18 +0200 Subject: [PATCH 49/53] CMake: Add default build type if none specified Release, unless we are in a Git repo, then it's Debug. --- cmake/BuildType.cmake | 43 +++++++++++++++++++++++++++++++++++++++++++ src/CMakeLists.txt | 4 +++- 2 files changed, 46 insertions(+), 1 deletion(-) create mode 100644 cmake/BuildType.cmake diff --git a/cmake/BuildType.cmake b/cmake/BuildType.cmake new file mode 100644 index 000000000..80ccdee2c --- /dev/null +++ b/cmake/BuildType.cmake @@ -0,0 +1,43 @@ +# Set a default build type if none was specified +set(default_build_type "Release") +if(EXISTS "${CMAKE_SOURCE_DIR}/.git") + set(default_build_type "Debug") +endif() + +if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES) + message(STATUS "Setting build type to '${default_build_type}' as none was specified.") + set(CMAKE_BUILD_TYPE "${default_build_type}" CACHE + STRING "Choose the type of build." FORCE) + # Set the possible values of build type for cmake-gui + set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS "Debug" "Release" + "MinSizeRel" "RelWithDebInfo") +endif() + +# Taken from the https://github.com/OpenChemistry/tomviz project +# Copyright (c) 2014-2017, Kitware, Inc. +# All rights reserved. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions are met: +# +# 1. Redistributions of source code must retain the above copyright notice, this +# list of conditions and the following disclaimer. +# +# 2. Redistributions in binary form must reproduce the above copyright notice, +# this list of conditions and the following disclaimer in the documentation +# and/or other materials provided with the distribution. +# +# 3. Neither the name of the copyright holder nor the names of its contributors +# may be used to endorse or promote products derived from this software +# without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND +# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE +# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR +# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR +# TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF +# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 4b32de107..f6f867e29 100755 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -1,12 +1,14 @@ # Setup the project and settings project(raylib) include(GNUInstallDirs) +set(CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/../cmake") set(PROJECT_VERSION 2.0.0) set(API_VERSION 2) set(RAYLIB raylib) # Name of the generated library include("CMakeOptions.txt") +include(BuildType) configure_file(config.h.in ${CMAKE_BINARY_DIR}/cmake/config.h) include_directories(${CMAKE_BINARY_DIR}) @@ -39,7 +41,7 @@ if(NOT glfw3_FOUND) list(APPEND raylib_sources $) endif() -include("../cmake/utils.cmake") +include(utils) if(USE_AUDIO) file(GLOB stb_vorbis external/stb_vorbis.c) From ff55af14f98fc70895ccdbbb4dccdccd68dec9dd Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Sun, 20 May 2018 20:08:43 +0200 Subject: [PATCH 50/53] CMake: Move reusable code to new cmake/ directory --- CMakeLists.txt | 45 ++++++----------------- cmake/AddIfFlagCompiles.cmake | 12 ++++++ cmake/CheckFileSystemSymlinkSupport.cmake | 13 +++++++ src/CMakeLists.txt | 2 +- 4 files changed, 38 insertions(+), 34 deletions(-) create mode 100644 cmake/AddIfFlagCompiles.cmake create mode 100644 cmake/CheckFileSystemSymlinkSupport.cmake diff --git a/CMakeLists.txt b/CMakeLists.txt index 38d98c355..34411b463 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,4 +1,5 @@ cmake_minimum_required(VERSION 3.0) +set(CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/cmake) # Config options option(BUILD_EXAMPLES "Build the examples." ON) @@ -15,47 +16,25 @@ else() set (CMAKE_C_STANDARD 99) endif() -include(CheckCCompilerFlag) -function(add_if_flag_works flag) - CHECK_C_COMPILER_FLAG("${flag}" COMPILER_HAS_THOSE_TOGGLES) - set(outcome "Failed") - if(COMPILER_HAS_THOSE_TOGGLES) - foreach(var ${ARGN}) - set(${var} "${flag} ${${var}}" PARENT_SCOPE) - endforeach() - set(outcome "works") - endif() - message(STATUS "Testing if ${flag} can be used -- ${outcome}") -endfunction() - -add_if_flag_works(-Werror=pointer-arith CMAKE_C_FLAGS) -add_if_flag_works(-Werror=implicit-function-declaration CMAKE_C_FLAGS) +include(AddIfFlagCompiles) +add_if_flag_compiles(-Werror=pointer-arith CMAKE_C_FLAGS) +add_if_flag_compiles(-Werror=implicit-function-declaration CMAKE_C_FLAGS) # src/external/jar_xm.h does shady stuff -add_if_flag_works(-fno-strict-aliasing CMAKE_C_FLAGS) +add_if_flag_compiles(-fno-strict-aliasing CMAKE_C_FLAGS) -message(STATUS "Testing if file system supports symlinks") -execute_process( - COMMAND ${CMAKE_COMMAND} -E create_symlink CMakeLists.txt "${CMAKE_CURRENT_BINARY_DIR}/TestingIfSymlinkWorks" - WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} - RESULT_VARIABLE FILESYSTEM_LACKS_SYMLINKS -) -If (FILESYSTEM_LACKS_SYMLINKS) - message(STATUS "Testing if file system supports symlinks -- unsupported") -else() - message(STATUS "Testing if file system supports symlinks -- supported") -endif() +include(CheckFileSystemSymlinkSupport) if (ENABLE_ASAN) - add_if_flag_works(-fno-omit-frame-pointer CMAKE_C_FLAGS CMAKE_LINKER_FLAGS) - add_if_flag_works(-fsanitize=address CMAKE_C_FLAGS CMAKE_LINKER_FLAGS) + add_if_flag_compiles(-fno-omit-frame-pointer CMAKE_C_FLAGS CMAKE_LINKER_FLAGS) + add_if_flag_compiles(-fsanitize=address CMAKE_C_FLAGS CMAKE_LINKER_FLAGS) endif() if (ENABLE_UBSAN) - add_if_flag_works(-fno-omit-frame-pointer CMAKE_C_FLAGS CMAKE_LINKER_FLAGS) - add_if_flag_works(-fsanitize=undefined CMAKE_C_FLAGS CMAKE_LINKER_FLAGS) + add_if_flag_compiles(-fno-omit-frame-pointer CMAKE_C_FLAGS CMAKE_LINKER_FLAGS) + add_if_flag_compiles(-fsanitize=undefined CMAKE_C_FLAGS CMAKE_LINKER_FLAGS) endif() if (ENABLE_MSAN) - add_if_flag_works(-fno-omit-frame-pointer CMAKE_C_FLAGS CMAKE_LINKER_FLAGS) - add_if_flag_works(-fsanitize=memory CMAKE_C_FLAGS CMAKE_LINKER_FLAGS) + add_if_flag_compiles(-fno-omit-frame-pointer CMAKE_C_FLAGS CMAKE_LINKER_FLAGS) + add_if_flag_compiles(-fsanitize=memory CMAKE_C_FLAGS CMAKE_LINKER_FLAGS) endif() if (ENABLE_MSAN AND ENABLE_ASAN) diff --git a/cmake/AddIfFlagCompiles.cmake b/cmake/AddIfFlagCompiles.cmake new file mode 100644 index 000000000..403607b57 --- /dev/null +++ b/cmake/AddIfFlagCompiles.cmake @@ -0,0 +1,12 @@ +include(CheckCCompilerFlag) +function(add_if_flag_compiles flag) + CHECK_C_COMPILER_FLAG("${flag}" COMPILER_HAS_THOSE_TOGGLES) + set(outcome "Failed") + if(COMPILER_HAS_THOSE_TOGGLES) + foreach(var ${ARGN}) + set(${var} "${flag} ${${var}}" PARENT_SCOPE) + endforeach() + set(outcome "compiles") + endif() + message(STATUS "Testing if ${flag} can be used -- ${outcome}") +endfunction() diff --git a/cmake/CheckFileSystemSymlinkSupport.cmake b/cmake/CheckFileSystemSymlinkSupport.cmake new file mode 100644 index 000000000..798840efb --- /dev/null +++ b/cmake/CheckFileSystemSymlinkSupport.cmake @@ -0,0 +1,13 @@ +# Populates a ${FILESYSTEM_LACKS_SYMLINKS} variable +message(STATUS "Testing if file system supports symlinks") +execute_process( + COMMAND ${CMAKE_COMMAND} -E create_symlink CMakeLists.txt "${CMAKE_CURRENT_BINARY_DIR}/TestingIfSymlinkWorks" + WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} + RESULT_VARIABLE FILESYSTEM_LACKS_SYMLINKS +) +If (FILESYSTEM_LACKS_SYMLINKS) + message(STATUS "Testing if file system supports symlinks -- unsupported") +else() + message(STATUS "Testing if file system supports symlinks -- supported") +endif() + diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index f6f867e29..1f7689c82 100755 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -1,7 +1,7 @@ # Setup the project and settings project(raylib) include(GNUInstallDirs) -set(CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/../cmake") +list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/../cmake") set(PROJECT_VERSION 2.0.0) set(API_VERSION 2) From ad8509732ca2a235c1735fae739577a59e17cf1c Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Sun, 20 May 2018 23:03:04 +0200 Subject: [PATCH 51/53] CMake: Fix (Add?) Android support Not sure if this ever worked, but now it at least compiles. --- .travis.yml | 43 +++++++++++++++++++++++++++++-------------- cmake/utils.cmake | 15 ++++++++++----- src/CMakeLists.txt | 32 +++++++++++++++++++++++++------- src/utils.c | 6 ++++++ 4 files changed, 70 insertions(+), 26 deletions(-) diff --git a/.travis.yml b/.travis.yml index 3cfce867c..309940154 100644 --- a/.travis.yml +++ b/.travis.yml @@ -29,24 +29,39 @@ matrix: - libegl1-mesa-dev - os: osx env: ARCH=universal + - os: linux + env: ARCH=arm64-android + sudo: required before_script: before_install: + - export PLATFORM=Desktop - if [ "$TRAVIS_OS_NAME" == "linux" ]; then - sudo apt-get install -y gcc-multilib - libasound2-dev:$ARCH - libxcursor-dev:$ARCH libxinerama-dev:$ARCH mesa-common-dev:$ARCH - libx11-dev:$ARCH libxrandr-dev:$ARCH libxrandr2:$ARCH libxi-dev:$ARCH - libgl1-mesa-dev:$ARCH libglu1-mesa-dev:$ARCH; - if [ "$ARCH" == "i386" ]; then - export CMAKE_ARCH_ARGS='-DCMAKE_C_FLAGS=-m32 -DCMAKE_SYSTEM_LIBRARY_PATH=/usr/lib/i386-linux-gnu'; - fi; - export RAYLIB_PACKAGE_SUFFIX="-Linux-$ARCH"; - if [ "$GLFW" == "SYSTEM" ]; then - wget 'http://ftp.de.debian.org/debian/pool/main/g/glfw3/libglfw3_3.2.1-1_amd64.deb'; - wget 'http://ftp.de.debian.org/debian/pool/main/g/glfw3/libglfw3-dev_3.2.1-1_amd64.deb'; - sudo dpkg -i libglfw3_3.2.1-1_amd64.deb libglfw3-dev_3.2.1-1_amd64.deb; + if [[ "$ARCH" == *-android ]]; then + export RAYLIB_PACKAGE_SUFFIX="-Android-arm64"; + wget https://dl.google.com/android/repository/android-ndk-r17-linux-x86_64.zip; + unzip -qq android-ndk*.zip; + android-ndk*/build/tools/make_standalone_toolchain.py --arch arm64 --api 21 --install-dir /tmp/android-toolchain; + export PATH=/tmp/android-toolchain/bin:$PATH; + export PLATFORM=Android; + export CC=aarch64-linux-android-clang; + export CXX=aarch64-linux-android-clang++; + else + sudo apt-get install -y gcc-multilib + libasound2-dev:$ARCH + libxcursor-dev:$ARCH libxinerama-dev:$ARCH mesa-common-dev:$ARCH + libx11-dev:$ARCH libxrandr-dev:$ARCH libxrandr2:$ARCH libxi-dev:$ARCH + libgl1-mesa-dev:$ARCH libglu1-mesa-dev:$ARCH; + if [ "$ARCH" == "i386" ]; then + export CMAKE_ARCH_ARGS='-DCMAKE_C_FLAGS=-m32 -DCMAKE_SYSTEM_LIBRARY_PATH=/usr/lib/i386-linux-gnu'; + fi; + export RAYLIB_PACKAGE_SUFFIX="-Linux-$ARCH"; + if [ "$GLFW" == "SYSTEM" ]; then + wget 'http://ftp.de.debian.org/debian/pool/main/g/glfw3/libglfw3_3.2.1-1_amd64.deb'; + wget 'http://ftp.de.debian.org/debian/pool/main/g/glfw3/libglfw3-dev_3.2.1-1_amd64.deb'; + sudo dpkg -i libglfw3_3.2.1-1_amd64.deb libglfw3-dev_3.2.1-1_amd64.deb; + fi; fi; fi - if [ "$TRAVIS_OS_NAME" == "osx" ]; then @@ -66,7 +81,7 @@ script: git checkout 1.12 && ./autogen.sh --prefix=/usr && make && sudo make install; popd; fi - - cmake $CMAKE_ARCH_ARGS -DMACOS_FATLIB=ON -DSTATIC=ON -DSHARED=ON -DBUILD_EXAMPLES=ON -DBUILD_GAMES=ON -DUSE_EXTERNAL_GLFW=IF_POSSIBLE -DUSE_WAYLAND=${USE_WAYLAND} .. + - cmake $CMAKE_ARCH_ARGS -DMACOS_FATLIB=ON -DSTATIC=ON -DSHARED=ON -DBUILD_EXAMPLES=ON -DBUILD_GAMES=ON -DUSE_EXTERNAL_GLFW=IF_POSSIBLE -DUSE_WAYLAND=${USE_WAYLAND} -DPLATFORM=${PLATFORM} .. - make VERBOSE=1 - if [ "$GLFW" != "SYSTEM" ]; then make package; fi; - sudo make install diff --git a/cmake/utils.cmake b/cmake/utils.cmake index 27f74e682..a3e60fb5a 100755 --- a/cmake/utils.cmake +++ b/cmake/utils.cmake @@ -16,6 +16,9 @@ if(APPLE) ${IOKIT_LIBRARY} ${COREFOUNDATION_LIBRARY} ${COREVIDEO_LIBRARY}) elseif(WIN32) # no pkg-config --static on Windows yet... +elseif(${PLATFORM} MATCHES "Android") + find_library(OPENGL_LIBRARY OpenGL) + set(LIBS_PRIVATE m log android EGL GLESv2 OpenSLES atomic c) else() find_library(pthread NAMES pthread) find_package(OpenGL QUIET) @@ -38,13 +41,15 @@ else() endif() endif() -if(USE_EXTERNAL_GLFW STREQUAL "ON") +if(${PLATFORM} MATCHES "Desktop") + if(USE_EXTERNAL_GLFW STREQUAL "ON") find_package(glfw3 3.2.1 REQUIRED) -elseif(USE_EXTERNAL_GLFW STREQUAL "IF_POSSIBLE") + elseif(USE_EXTERNAL_GLFW STREQUAL "IF_POSSIBLE") find_package(glfw3 3.2.1 QUIET) -endif() -if (glfw3_FOUND) - set(LIBS_PRIVATE ${LIBS_PRIVATE} glfw) + endif() + if (glfw3_FOUND) + set(LIBS_PRIVATE ${LIBS_PRIVATE} glfw) + endif() endif() if(CMAKE_SYSTEM_NAME STREQUAL Linux) diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 1f7689c82..41b417a02 100755 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -11,6 +11,7 @@ include("CMakeOptions.txt") include(BuildType) configure_file(config.h.in ${CMAKE_BINARY_DIR}/cmake/config.h) include_directories(${CMAKE_BINARY_DIR}) +include_directories(SYSTEM .) if(MACOS_FATLIB) if (CMAKE_OSX_ARCHITECTURES) @@ -24,7 +25,7 @@ endif() file(GLOB raylib_sources *.c) list(REMOVE_ITEM raylib_sources ${CMAKE_CURRENT_SOURCE_DIR}/rglfw.c) -if(NOT glfw3_FOUND) +if(NOT glfw3_FOUND AND "${PLATFORM}" MATCHES "Desktop") set(GLFW_BUILD_DOCS OFF CACHE BOOL "" FORCE) set(GLFW_BUILD_TESTS OFF CACHE BOOL "" FORCE) set(GLFW_BUILD_EXAMPLES OFF CACHE BOOL "" FORCE) @@ -53,6 +54,8 @@ else() set(sources ${raylib_sources}) endif() +include(AddIfFlagCompiles) + ### Config options ### # Translate the config options to what raylib wants if(${PLATFORM} MATCHES "Desktop") @@ -92,14 +95,27 @@ elseif(${PLATFORM} MATCHES "Web") elseif(${PLATFORM} MATCHES "Android") set(PLATFORM "PLATFORM_ANDROID") set(GRAPHICS "GRAPHICS_API_OPENGL_ES2") + add_if_flag_compiles(-ffunction-sections CMAKE_C_FLAGS) + add_if_flag_compiles(-funwind-tables CMAKE_C_FLAGS) + add_if_flag_compiles(-fstack-protector-strong CMAKE_C_FLAGS) + set(CMAKE_POSITION_INDEPENDENT_CODE ON) + add_if_flag_compiles(-Wa,--noexecstack CMAKE_C_FLAGS) + add_if_flag_compiles(-no-canonical-prefixes CMAKE_C_FLAGS) + add_definitions(-DANDROID -D__ANDROID_API__=21) + include_directories(external/android/native_app_glue ) + set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--exclude-libs,libatomic.a -Wl,--build-id -Wl,-z,noexecstack -Wl,-z,relro -Wl,-z,now -Wl,--warn-shared-textrel -Wl,--fatal-warnings -uANativeActivity_onCreate") + elseif(${PLATFORM} MATCHES "Raspberry Pi") set(PLATFORM "PLATFORM_RPI") set(GRAPHICS "GRAPHICS_API_OPENGL_ES2") endif() # Which platform? -if(${PLATFORM} MATCHES "PLATFORM_DESKTOP") +if(${PLATFORM} MATCHES "PLATFORM_WEB") + # For the web. + add_executable(${RAYLIB} ${sources}) +else() if(${SHARED}) add_library(${RAYLIB}_shared SHARED ${sources}) @@ -113,7 +129,10 @@ if(${PLATFORM} MATCHES "PLATFORM_DESKTOP") set(CMAKE_INSTALL_RPATH_USE_LINK_PATH TRUE) set(CMAKE_MACOSX_RPATH ON) - target_link_libraries(${RAYLIB}_shared ${LIBS_PRIVATE} glfw ${GLFW_LIBRARIES}) + target_link_libraries(${RAYLIB}_shared ${LIBS_PRIVATE}) + if (${PLATFORM} MATCHES "Desktop") + target_link_libraries(${RAYLIB}_shared glfw ${GLFW_LIBRARIES}) + endif() if (UNIX AND ${FILESYSTEM_LACKS_SYMLINKS}) MESSAGE(WARNING "Can't version UNIX shared library on file system without symlink support") else() @@ -150,7 +169,9 @@ if(${PLATFORM} MATCHES "PLATFORM_DESKTOP") ) set(PKG_CONFIG_LIBS_PRIVATE ${__PKG_CONFIG_LIBS_PRIVATE}) - target_link_libraries(${RAYLIB} glfw ${GLFW_LIBRARIES}) + if (${PLATFORM} MATCHES "Desktop") + target_link_libraries(${RAYLIB} glfw ${GLFW_LIBRARIES}) + endif() if (WITH_PIC) set_property(TARGET ${RAYLIB} PROPERTY POSITION_INDEPENDENT_CODE ON) @@ -171,9 +192,6 @@ if(${PLATFORM} MATCHES "PLATFORM_DESKTOP") file(COPY "physac.h" DESTINATION ".") file(COPY "raymath.h" DESTINATION ".") file(COPY "audio.h" DESTINATION ".") -elseif(${PLATFORM} MATCHES "PLATFORM_WEB") - # For the web. - add_executable(${RAYLIB} ${sources}) endif() # Print the flags for the user diff --git a/src/utils.c b/src/utils.c index 9d9d8b553..cd75e6954 100644 --- a/src/utils.c +++ b/src/utils.c @@ -57,6 +57,12 @@ #include // Required for: va_list, va_start(), vfprintf(), va_end() #include // Required for: strlen(), strrchr(), strcmp() +/* This should be in , but Travis doesn't find it... */ +FILE *funopen(const void *cookie, int (*readfn)(void *, char *, int), + int (*writefn)(void *, const char *, int), + fpos_t (*seekfn)(void *, fpos_t, int), int (*closefn)(void *)); + + #if defined(PLATFORM_DESKTOP) || defined(PLATFORM_RPI) #define STB_IMAGE_WRITE_IMPLEMENTATION #include "external/stb_image_write.h" // Required for: stbi_write_bmp(), stbi_write_png() From bd2300fed34b458e4a419a486019afccf2ab39b1 Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Mon, 21 May 2018 00:58:49 +0200 Subject: [PATCH 52/53] CMake+Android: Skip tests with SetCameraMode src/core.c does explicitly skip including on Android and tests fail. Therefore skip these failing tests. Closes #507. --- .travis.yml | 4 +++- examples/CMakeLists.txt | 23 +++++++++++++++++++++++ 2 files changed, 26 insertions(+), 1 deletion(-) diff --git a/.travis.yml b/.travis.yml index 309940154..82f73e8de 100644 --- a/.travis.yml +++ b/.travis.yml @@ -86,7 +86,9 @@ script: - if [ "$GLFW" != "SYSTEM" ]; then make package; fi; - sudo make install - pkg-config --static --libs raylib - - nm -g release/libraylib.a | grep glfwGetProcAddress || (echo "libraylib.a doesn't contain GLFW symbols! Aborting..." && false) + - if [[ "$ARCH" != *-android ]]; then + nm -g release/libraylib.a | grep glfwGetProcAddress || (echo "libraylib.a doesn't contain GLFW symbols! Aborting..." && false); + fi deploy: provider: releases diff --git a/examples/CMakeLists.txt b/examples/CMakeLists.txt index ae882444a..fd65a74b6 100644 --- a/examples/CMakeLists.txt +++ b/examples/CMakeLists.txt @@ -40,6 +40,29 @@ if(NOT HAVE_OCULUS_CAPI) endif() list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/others/standard_lighting.c) +if(${PLATFORM} MATCHES "Android") + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/others/rlgl_standalone.c) + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/core/core_3d_picking.c) + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/core/core_vr_simulator.c) + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/core/core_3d_camera_free.c) + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/core/core_3d_camera_first_person.c) + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/core/core_world_screen.c) + + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/models/models_mesh_picking.c) + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/models/models_material_pbr.c) + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/models/models_cubicmap.c) + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/models/models_skybox.c) + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/models/models_mesh_picking.c) + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/models/models_mesh_generation.c) + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/models/models_heightmap.c) + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/models/models_billboard.c) + + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/shaders/shaders_custom_uniform.c) + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/shaders/shaders_model_shader.c) + list(REMOVE_ITEM example_sources ${CMAKE_CURRENT_SOURCE_DIR}/shaders/shaders_postprocessing.c) + +endif() + # Do each example foreach(example_source ${example_sources}) From e025e62445913bf1ec9cf075eaaf1dc7374da83c Mon Sep 17 00:00:00 2001 From: Ahmad Fatoum Date: Thu, 12 Apr 2018 19:31:53 +0200 Subject: [PATCH 53/53] cmake: Fix PLATFORM_WEB build Did this ever work? Surely, doesn't look like it... --- .travis.yml | 36 +++++---- cmake/emscripten.cmake | 15 ++++ cmake/utils.cmake | 12 ++- src/CMakeLists.txt | 165 +++++++++++++++++++---------------------- src/CMakeOptions.txt | 29 ++++++-- src/audio.c | 1 + src/config.h.in | 2 + src/textures.c | 1 + src/utils.c | 10 +-- 9 files changed, 150 insertions(+), 121 deletions(-) create mode 100644 cmake/emscripten.cmake diff --git a/.travis.yml b/.travis.yml index 82f73e8de..2fd73c18b 100644 --- a/.travis.yml +++ b/.travis.yml @@ -5,7 +5,8 @@ git: depth: 3 # TODO we could use a 32 bit Docker container for running true 32-bit tests -# services: - docker +services: + - docker matrix: include: @@ -16,10 +17,10 @@ matrix: env: ARCH=amd64 sudo: required - os: linux - env: ARCH=amd64 GLFW=SYSTEM + env: ARCH=amd64 GLFW=SYSTEM RELEASE=NO sudo: required - os: linux - env: USE_WAYLAND=ON ARCH=amd64 + env: USE_WAYLAND=ON ARCH=amd64 RELEASE=NO sudo: required addons: apt: @@ -30,13 +31,15 @@ matrix: - os: osx env: ARCH=universal - os: linux - env: ARCH=arm64-android + env: ARCH=arm64-android RELEASE=NO + sudo: required + - os: linux + env: ARCH=html5 RELEASE=NO sudo: required before_script: before_install: - - export PLATFORM=Desktop - if [ "$TRAVIS_OS_NAME" == "linux" ]; then if [[ "$ARCH" == *-android ]]; then export RAYLIB_PACKAGE_SUFFIX="-Android-arm64"; @@ -44,9 +47,14 @@ before_install: unzip -qq android-ndk*.zip; android-ndk*/build/tools/make_standalone_toolchain.py --arch arm64 --api 21 --install-dir /tmp/android-toolchain; export PATH=/tmp/android-toolchain/bin:$PATH; - export PLATFORM=Android; + export CMAKE_ARCH_ARGS='-DPLATFORM=Android'; export CC=aarch64-linux-android-clang; export CXX=aarch64-linux-android-clang++; + elif [ "$ARCH" == "html5" ]; then + export RAYLIB_PACKAGE_SUFFIX="-html5"; + docker run --privileged=true -dit --name emscripten -v $(pwd):/src trzeci/emscripten:sdk-incoming-64bit bash; + export CMAKE_ARCH_ARGS='-DPLATFORM=Web -DCMAKE_TOOLCHAIN_FILE=../cmake/emscripten.cmake'; + export RUNNER='docker exec -it emscripten cmake -E chdir build'; else sudo apt-get install -y gcc-multilib libasound2-dev:$ARCH @@ -68,10 +76,10 @@ before_install: export RAYLIB_PACKAGE_SUFFIX="-macOS"; if [ "$GLFW" == "SYSTEM" ]; then brew update; brew install glfw; fi; fi - - "$CC --version" + - mkdir build + - $RUNNER $CC --version script: - - mkdir build - cd build - if test -n "${USE_WAYLAND}"; then wget https://mirrors.kernel.org/ubuntu/pool/universe/e/extra-cmake-modules/extra-cmake-modules_5.38.0a-0ubuntu1_amd64.deb; @@ -81,12 +89,12 @@ script: git checkout 1.12 && ./autogen.sh --prefix=/usr && make && sudo make install; popd; fi - - cmake $CMAKE_ARCH_ARGS -DMACOS_FATLIB=ON -DSTATIC=ON -DSHARED=ON -DBUILD_EXAMPLES=ON -DBUILD_GAMES=ON -DUSE_EXTERNAL_GLFW=IF_POSSIBLE -DUSE_WAYLAND=${USE_WAYLAND} -DPLATFORM=${PLATFORM} .. - - make VERBOSE=1 - - if [ "$GLFW" != "SYSTEM" ]; then make package; fi; - - sudo make install - - pkg-config --static --libs raylib - - if [[ "$ARCH" != *-android ]]; then + - $RUNNER cmake $CMAKE_ARCH_ARGS -DMACOS_FATLIB=ON -DSTATIC=ON -DSHARED=ON -DBUILD_EXAMPLES=ON -DBUILD_GAMES=ON -DUSE_EXTERNAL_GLFW=IF_POSSIBLE -DUSE_WAYLAND=${USE_WAYLAND} .. + - $RUNNER make VERBOSE=1 + - if [ "$RELEASE" != "NO" ]; then $RUNNER make package; fi; + - sudo $RUNNER make install + - if [[ "$ARCH" != *-android && "$ARCH" != html5 ]]; then + pkg-config --static --libs raylib; nm -g release/libraylib.a | grep glfwGetProcAddress || (echo "libraylib.a doesn't contain GLFW symbols! Aborting..." && false); fi diff --git a/cmake/emscripten.cmake b/cmake/emscripten.cmake new file mode 100644 index 000000000..621ae7875 --- /dev/null +++ b/cmake/emscripten.cmake @@ -0,0 +1,15 @@ +SET(CMAKE_SYSTEM_NAME Linux) + +SET(CMAKE_C_COMPILER emcc) +SET(CMAKE_CXX_COMPILER em++) +if(NOT DEFINED CMAKE_AR) + find_program(CMAKE_AR NAMES emar) +endif() +if(NOT DEFINED CMAKE_RANLIB) + find_program(CMAKE_RANLIB NAMES emranlib) +endif() + +set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) +set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) +set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE BOTH) +set(CMAKE_FIND_ROOT_PATH_MODE_PACKAGE ONLY) diff --git a/cmake/utils.cmake b/cmake/utils.cmake index a3e60fb5a..fc75ef4fd 100755 --- a/cmake/utils.cmake +++ b/cmake/utils.cmake @@ -5,7 +5,11 @@ add_definitions("-DRAYLIB_CMAKE=1") # Linking for OS X -framework options # Will do nothing on other OSes -if(APPLE) +if(${PLATFORM} MATCHES "Android") + find_library(OPENGL_LIBRARY OpenGL) + set(LIBS_PRIVATE m log android EGL GLESv2 OpenSLES atomic c) +elseif(${PLATFORM} MATCHES "Web") +elseif(APPLE) find_library(OPENGL_LIBRARY OpenGL) find_library(COCOA_LIBRARY Cocoa) find_library(IOKIT_LIBRARY IOKit) @@ -16,9 +20,6 @@ if(APPLE) ${IOKIT_LIBRARY} ${COREFOUNDATION_LIBRARY} ${COREVIDEO_LIBRARY}) elseif(WIN32) # no pkg-config --static on Windows yet... -elseif(${PLATFORM} MATCHES "Android") - find_library(OPENGL_LIBRARY OpenGL) - set(LIBS_PRIVATE m log android EGL GLESv2 OpenSLES atomic c) else() find_library(pthread NAMES pthread) find_package(OpenGL QUIET) @@ -87,6 +88,9 @@ function(link_libraries_to_executable executable) # Link raylib if (TARGET raylib_shared) target_link_libraries(${executable} raylib_shared) + elseif(${PLATFORM} MATCHES "Web") + target_link_libraries(${executable} ${__PKG_CONFIG_LIBS_PRIVATE}) + target_link_libraries(${executable} raylib) else() target_link_libraries(${executable} raylib ${__PKG_CONFIG_LIBS_PRIVATE}) endif() diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 41b417a02..7e94d97db 100755 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -1,5 +1,5 @@ # Setup the project and settings -project(raylib) +project(raylib C) include(GNUInstallDirs) list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/../cmake") @@ -13,14 +13,6 @@ configure_file(config.h.in ${CMAKE_BINARY_DIR}/cmake/config.h) include_directories(${CMAKE_BINARY_DIR}) include_directories(SYSTEM .) -if(MACOS_FATLIB) - if (CMAKE_OSX_ARCHITECTURES) - message(FATAL_ERROR "User supplied -DCMAKE_OSX_ARCHITECTURES overrides -DMACOS_FATLIB=ON") - else() - SET(CMAKE_OSX_ARCHITECTURES "x86_64;i386") - endif() -endif() - # Get the sources together file(GLOB raylib_sources *.c) list(REMOVE_ITEM raylib_sources ${CMAKE_CURRENT_SOURCE_DIR}/rglfw.c) @@ -72,9 +64,9 @@ if(${PLATFORM} MATCHES "Desktop") set(GRAPHICS "GRAPHICS_API_OPENGL_ES2") endif() - # Need to force OpenGL 3.3 on OS X - # See: https://github.com/raysan5/raylib/issues/341 if(APPLE) + # Need to force OpenGL 3.3 on OS X + # See: https://github.com/raysan5/raylib/issues/341 set(GRAPHICS "GRAPHICS_API_OPENGL_33") link_libraries("${LIBS_PRIVATE}") elseif(WIN32) @@ -85,12 +77,9 @@ elseif(${PLATFORM} MATCHES "Web") set(PLATFORM "PLATFORM_WEB") set(GRAPHICS "GRAPHICS_API_OPENGL_ES2") - # Need to use `emcc` - set(CMAKE_C_COMPILER "emcc") - set(CMAKE_CXX_COMPILER "em++") + set(CMAKE_C_FLAGS "-s USE_GLFW=3 -s ASSERTIONS=1 --profiling") # Change the name of the output library - set(RAYLIB "libraylib.bc") elseif(${PLATFORM} MATCHES "Android") set(PLATFORM "PLATFORM_ANDROID") @@ -110,89 +99,87 @@ elseif(${PLATFORM} MATCHES "Raspberry Pi") set(GRAPHICS "GRAPHICS_API_OPENGL_ES2") endif() -# Which platform? -if(${PLATFORM} MATCHES "PLATFORM_WEB") - # For the web. - add_executable(${RAYLIB} ${sources}) +if(${SHARED}) + add_library(${RAYLIB}_shared SHARED ${sources}) -else() - if(${SHARED}) - add_library(${RAYLIB}_shared SHARED ${sources}) + target_compile_definitions(${RAYLIB}_shared + PUBLIC ${PLATFORM} + PUBLIC ${GRAPHICS} + ) - target_compile_definitions(${RAYLIB}_shared - PUBLIC ${PLATFORM} - PUBLIC ${GRAPHICS} - ) + set_property(TARGET ${RAYLIB}_shared PROPERTY POSITION_INDEPENDENT_CODE ON) + set(CMAKE_INSTALL_RPATH "${CMAKE_INSTALL_LIBDIR}") + set(CMAKE_INSTALL_RPATH_USE_LINK_PATH TRUE) + set(CMAKE_MACOSX_RPATH ON) - set_property(TARGET ${RAYLIB}_shared PROPERTY POSITION_INDEPENDENT_CODE ON) - set(CMAKE_INSTALL_RPATH "${CMAKE_INSTALL_LIBDIR}") - set(CMAKE_INSTALL_RPATH_USE_LINK_PATH TRUE) - set(CMAKE_MACOSX_RPATH ON) - - target_link_libraries(${RAYLIB}_shared ${LIBS_PRIVATE}) - if (${PLATFORM} MATCHES "Desktop") - target_link_libraries(${RAYLIB}_shared glfw ${GLFW_LIBRARIES}) - endif() - if (UNIX AND ${FILESYSTEM_LACKS_SYMLINKS}) - MESSAGE(WARNING "Can't version UNIX shared library on file system without symlink support") - else() - set_target_properties(${RAYLIB}_shared PROPERTIES - VERSION ${PROJECT_VERSION} - SOVERSION ${API_VERSION} - ) - endif() - set_target_properties(${RAYLIB}_shared PROPERTIES - PUBLIC_HEADER "raylib.h" - ) - if(WIN32) - install( - TARGETS ${RAYLIB}_shared - RUNTIME DESTINATION lib - PUBLIC_HEADER DESTINATION include + target_link_libraries(${RAYLIB}_shared ${LIBS_PRIVATE}) + if (${PLATFORM} MATCHES "Desktop") + target_link_libraries(${RAYLIB}_shared glfw ${GLFW_LIBRARIES}) + endif() + if (UNIX AND ${FILESYSTEM_LACKS_SYMLINKS}) + MESSAGE(WARNING "Can't version UNIX shared library on file system without symlink support") + else() + set_target_properties(${RAYLIB}_shared PROPERTIES + VERSION ${PROJECT_VERSION} + SOVERSION ${API_VERSION} ) - else() # Keep lib*.(a|dll) name, but avoid *.lib files overwriting each other on Windows - set_target_properties(${RAYLIB}_shared PROPERTIES OUTPUT_NAME ${RAYLIB}) - install( - TARGETS ${RAYLIB}_shared - LIBRARY DESTINATION "${CMAKE_INSTALL_LIBDIR}" - PUBLIC_HEADER DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}" - ) - endif() - endif(${SHARED}) - - if(${STATIC}) - add_library(${RAYLIB} STATIC ${sources}) - - target_compile_definitions(${RAYLIB} - PUBLIC ${PLATFORM} - PUBLIC ${GRAPHICS} + endif() + set_target_properties(${RAYLIB}_shared PROPERTIES + PUBLIC_HEADER "raylib.h" + ) + if(WIN32) + install( + TARGETS ${RAYLIB}_shared + RUNTIME DESTINATION lib + PUBLIC_HEADER DESTINATION include ) - - set(PKG_CONFIG_LIBS_PRIVATE ${__PKG_CONFIG_LIBS_PRIVATE}) - if (${PLATFORM} MATCHES "Desktop") - target_link_libraries(${RAYLIB} glfw ${GLFW_LIBRARIES}) - endif() - - if (WITH_PIC) - set_property(TARGET ${RAYLIB} PROPERTY POSITION_INDEPENDENT_CODE ON) - endif() - set_target_properties(${RAYLIB} PROPERTIES PUBLIC_HEADER "raylib.h") - install(TARGETS ${RAYLIB} - ARCHIVE DESTINATION "${CMAKE_INSTALL_LIBDIR}" + else() # Keep lib*.(a|dll) name, but avoid *.lib files overwriting each other on Windows + set_target_properties(${RAYLIB}_shared PROPERTIES OUTPUT_NAME ${RAYLIB}) + install( + TARGETS ${RAYLIB}_shared + LIBRARY DESTINATION "${CMAKE_INSTALL_LIBDIR}" PUBLIC_HEADER DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}" ) - endif(${STATIC}) + endif() +endif(${SHARED}) - configure_file(../raylib.pc.in raylib.pc @ONLY) - install(FILES ${CMAKE_BINARY_DIR}/release/raylib.pc DESTINATION "${CMAKE_INSTALL_LIBDIR}/pkgconfig") +if(${STATIC}) + if(${PLATFORM} MATCHES "PLATFORM_WEB") + set(CMAKE_STATIC_LIBRARY_SUFFIX ".bc") + endif() + + add_library(${RAYLIB} STATIC ${sources}) + + set(PKG_CONFIG_LIBS_PRIVATE ${__PKG_CONFIG_LIBS_PRIVATE}) + if (${PLATFORM} MATCHES "Desktop") + target_link_libraries(${RAYLIB} glfw ${GLFW_LIBRARIES}) + endif() + + if (WITH_PIC) + set_property(TARGET ${RAYLIB} PROPERTY POSITION_INDEPENDENT_CODE ON) + endif() + set_target_properties(${RAYLIB} PROPERTIES PUBLIC_HEADER "raylib.h") + install(TARGETS ${RAYLIB} + ARCHIVE DESTINATION "${CMAKE_INSTALL_LIBDIR}" + PUBLIC_HEADER DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}" + ) +endif(${STATIC}) + +configure_file(../raylib.pc.in raylib.pc @ONLY) +install(FILES ${CMAKE_BINARY_DIR}/release/raylib.pc DESTINATION "${CMAKE_INSTALL_LIBDIR}/pkgconfig") + +# Copy the header files to the build directory +file(COPY "raylib.h" DESTINATION ".") +file(COPY "rlgl.h" DESTINATION ".") +file(COPY "physac.h" DESTINATION ".") +file(COPY "raymath.h" DESTINATION ".") +file(COPY "audio.h" DESTINATION ".") + +target_compile_definitions(${RAYLIB} + PUBLIC ${PLATFORM} + PUBLIC ${GRAPHICS} +) - # Copy the header files to the build directory - file(COPY "raylib.h" DESTINATION ".") - file(COPY "rlgl.h" DESTINATION ".") - file(COPY "physac.h" DESTINATION ".") - file(COPY "raymath.h" DESTINATION ".") - file(COPY "audio.h" DESTINATION ".") -endif() # Print the flags for the user message(STATUS "Compiling with the flags:") diff --git a/src/CMakeOptions.txt b/src/CMakeOptions.txt index 00fc79043..4ed1a375d 100644 --- a/src/CMakeOptions.txt +++ b/src/CMakeOptions.txt @@ -1,13 +1,24 @@ ### Config options ### include(CMakeDependentOption) +set(PLATFORM "Desktop" CACHE STRING "Platform to build for.") +set_property(CACHE PLATFORM PROPERTY STRINGS "Desktop" "Web" "Android" "Raspberry Pi") + +set(OPENGL_VERSION "3.3" CACHE STRING "OpenGL Version to build raylib with") +set_property(CACHE OPENGL_VERSION PROPERTY STRINGS "3.3" "2.1" "1.1" "ES 2.0") + # Shared library is always PIC. Static library should be PIC too if linked into a shared library option(WITH_PIC "Compile static library as position-independent code" OFF) option(SHARED "Build raylib as a dynamic library" OFF) option(STATIC "Build raylib as a static library" ON) option(MACOS_FATLIB "Build fat library for both i386 and x86_64 on macOS" ON) option(USE_AUDIO "Build raylib with audio module" ON) -cmake_dependent_option(USE_OPENAL_BACKEND "Link raylib with openAL instead of mini-al" OFF "USE_AUDIO" OFF) +if(${PLATFORM} MATCHES "Web") + cmake_dependent_option(USE_OPENAL_BACKEND "Link raylib with openAL instead of mini-al" ON "USE_AUDIO" OFF) +else() + cmake_dependent_option(USE_OPENAL_BACKEND "Link raylib with openAL instead of mini-al" OFF "USE_AUDIO" OFF) +endif() + set(USE_EXTERNAL_GLFW OFF CACHE STRING "Link raylib against system GLFW instead of embedded one") set_property(CACHE USE_EXTERNAL_GLFW PROPERTY STRINGS ON OFF IF_POSSIBLE) if(UNIX AND NOT APPLE) @@ -15,12 +26,6 @@ if(UNIX AND NOT APPLE) endif() -set(PLATFORM "Desktop" CACHE STRING "Platform to build for.") -set_property(CACHE PLATFORM PROPERTY STRINGS "Desktop" "Web" "Android" "Raspberry Pi") - -set(OPENGL_VERSION "3.3" CACHE STRING "OpenGL Version to build raylib with") -set_property(CACHE OPENGL_VERSION PROPERTY STRINGS "3.3" "2.1" "1.1" "ES 2.0") - # core.c option(SUPPORT_BUSY_WAIT_LOOP "Use busy wait loop for timing sync instead of a high-resolution timer" ON) option(SUPPORT_CAMERA_SYSTEM "Provide camera module (camera.h) with multiple predefined cameras: free, 1st/3rd person, orbital" ON) @@ -88,4 +93,14 @@ if(DEFINED STATIC_RAYLIB) message(DEPRECATION "-DSTATIC_RAYLIB is deprecated. Please use -DSTATIC instead.") endif() +if(${PLATFORM} MATCHES "Desktop" AND APPLE) + if(MACOS_FATLIB) + if (CMAKE_OSX_ARCHITECTURES) + message(FATAL_ERROR "User supplied -DCMAKE_OSX_ARCHITECTURES overrides -DMACOS_FATLIB=ON") + else() + set(CMAKE_OSX_ARCHITECTURES "x86_64;i386") + endif() + endif() +endif() + # vim: ft=cmake diff --git a/src/audio.c b/src/audio.c index 4e18df26f..53f5814f7 100644 --- a/src/audio.c +++ b/src/audio.c @@ -73,6 +73,7 @@ * **********************************************************************************************/ +#include "config.h" #if !defined(USE_OPENAL_BACKEND) #define USE_MINI_AL 1 // Set to 1 to use mini_al; 0 to use OpenAL. #endif diff --git a/src/config.h.in b/src/config.h.in index 651024c19..d767560b7 100644 --- a/src/config.h.in +++ b/src/config.h.in @@ -1,5 +1,7 @@ /* config.h.in */ +#cmakedefine USE_OPENAL_BACKEND 1 + // core.c /* Camera module is included (camera.h) and multiple predefined cameras are available: free, 1st/3rd person, orbital */ #cmakedefine SUPPORT_CAMERA_SYSTEM 1 diff --git a/src/textures.c b/src/textures.c index 46867aaba..3a1934b97 100644 --- a/src/textures.c +++ b/src/textures.c @@ -568,6 +568,7 @@ void ExportImage(const char *fileName, Image image) // NOTE: Getting Color array as RGBA unsigned char values unsigned char *imgData = (unsigned char *)GetImageData(image); SavePNG(fileName, imgData, image.width, image.height, 4); + // FIXME ^ this fails on PLATFORM_WEB, what should we do? free(imgData); } diff --git a/src/utils.c b/src/utils.c index cd75e6954..74780680d 100644 --- a/src/utils.c +++ b/src/utils.c @@ -143,31 +143,27 @@ void TraceLog(int msgType, const char *text, ...) va_end(args); if (msgType == LOG_ERROR) exit(1); // If LOG_ERROR message, exit program - + #endif // SUPPORT_TRACELOG } -#if defined(SUPPORT_SAVE_BMP) // Creates a BMP image file from an array of pixel data void SaveBMP(const char *fileName, unsigned char *imgData, int width, int height, int compSize) { -#if defined(PLATFORM_DESKTOP) || defined(PLATFORM_RPI) +#if defined(SUPPORT_SAVE_BMP) && (defined(PLATFORM_DESKTOP) || defined(PLATFORM_RPI)) stbi_write_bmp(fileName, width, height, compSize, imgData); TraceLog(LOG_INFO, "BMP Image saved: %s", fileName); #endif } -#endif -#if defined(SUPPORT_SAVE_PNG) // Creates a PNG image file from an array of pixel data void SavePNG(const char *fileName, unsigned char *imgData, int width, int height, int compSize) { -#if defined(PLATFORM_DESKTOP) || defined(PLATFORM_RPI) +#if defined(SUPPORT_SAVE_PNG) && (defined(PLATFORM_DESKTOP) || defined(PLATFORM_RPI)) stbi_write_png(fileName, width, height, compSize, imgData, width*compSize); TraceLog(LOG_INFO, "PNG Image saved: %s", fileName); #endif } -#endif // Keep track of memory allocated // NOTE: mallocType defines the type of data allocated

>mNTNMJJ+SYR_IM9f=RUkir3%{9 zY5vFG(ipt5DQ#hj{%EP9|I1`tAXToBDlgJK>{--@v}?6B{cWnPY_utBHK40!#lWH0 z1`YcdSRQ<~2i-Yd8_2WMch&?>;7pS-M>O1@2pkNdK>?{IPxbhdYZdlkIz55)hWWz* z8{+|cSVk37t+GRN+z=g|z!5W(tStk5DtU@Zj*j{oCPzo7Hk9Qdn}A>q6vQQf(AfC^ zwbfhm7Zw5eO8_}DwZUM^7hoJ9Z=$9eO|AWHRT2?S)?VS1^;HZBh9@({5Z%O3hSpR2p=3LtA@++^H#jP z>X(T6<=9Mrq{wMQY8!HHU`~J`=Zfg65g!;eVl}4Vri6$O&#+TM;voPXQn*rV15LpD z90E3o@8@MNYjLDj&EApwMdnsmh(H=G}}L=-1%0buY$yKp_5~ z1jA;9;YXnVM^@vNkdOEaEEcx(Nph`1E;y*4P37*FqU;}`xPyr$flFSFzvO#GC`|^+ z6x~EvpvBkc>q^pG(!B5i6%l;|h$wA=hO_v1Uob|OT~Xto3*fljr_JAl4bN~kml8O7 z9$p@0QxBoj*}WV&r20~mF`Vm$GR4?g5-RKv_Z@-imd@0(7X7Rj1?FMoqjPoN2ZvZM zCI@hPx5lkjs%X&f7B^7LZpLG2$U(XD?CqECCbbbz~o^NM^Epwo*r1vYw;)qu; zynQa(afk7Nqo9D&{xWg6PFs5+#EGX1I*WSaap>^ER4A~8lPFB`>W**Wv?(N7b_E>b za7%-al}n)pctf4}I%xlr>W%2Tn>L-Po2!gYobJhBW66u1^xKUHRA zxu2QHnHU1lXE}?@4LFg|*0(dyGBG=qSzi<4*cyOLgLkaY-~E@!4kEZja1wC1UQ~{6 zx^oQY>xHZeS#dBvQdJ0~#+0%fd7J`j#s$U*sLJ?L4L>a2!r_LAcJb?W@%|hg`sbFyA{4<=s31#&{KBegfX^oCW+v<^ zUk|j?3yC^ZJR)I=GTcM)y1?B%SUM`F(wwQ}pqg?JzZsS;{H3UeAA_qE4_9TchU20{ zwknk^!fc9%5FZMYC$k@!bIpdVPnN*rE`EGGob^KC6;of#|FH-#AWJR23Ixa=?WoY^ z)utgXZYV*G+j|@*$1pM!wcFRI+U#AldYK3o?{Z{*3hz#-L)sqINS!%pq{q=nk6Xb< zABAdq(S8dy>>zV?+SE39^zi{>TC5>vjje|+3O;W?u14-%+ECJ1Yk`%5-wnULSRVc$U9NTHTUGhwcTaCh1n zro3psiOkG2Lr}zHD-rIrC0qV;8=Ky=8fRc4B+_;OcIFoQt>82EThUB8)DPTk?vyw4 z{*9~N^d+_v2WAew9udzGUpupGSr~{S4)OD)sP#{D+P$PfmzMi3!ejHoxUIo(qf0GA zspzZuFCgLqbmN=Rr!ij6?jvmDvXh;FuJ7HL>rZf6HWa35#D;g$j4$5g}oVswzp@BFy$-$IC$2fd@2MA0FsR z19)H{9L9qhm>uHl;z1f#!r(KC9HwEksSnCGC3S|ehB~7gwz(*TjA(%tp@j5AGeFSz z*>PZ=wPdL56`gH&j0aUyCSW}ZER|m}9w0e(5-do?BqHm}qu!vuL+D34aU~&MH*EUi zSY=DjArCnxS|1D-WqbB7sR~5Z(HiAs$fb&+gQCpDip@lkp5t|}4qF>nMVkh!1`J^k z8&x+9VGth04h&&Mbg9;bDZ|z+IfQKx9~PO23(It<}$^d?J3Ce!p2iZ^e^7 zD)gg0ugehmji|j3roKddT}5qW6ee)rh-RR#gUw$@A?g*qrQuo)e1`zXIBj`Ve$%Zi z#f5I+SO}I+i2TjK0u8=m2ef|)6c}boChPpZyv#U$M(!169QT4w8Tb^j9O1sGiGB7p zR@PNg|E&GUeC${0)_NC8t*s z8*Du68qDqY`_R!u0s%tU1Bcl=CS(9Bzt z+u7&nhlb+8KqPaKPvd@yxVZ#s4u(a$YJDEMrQj{^aSaSa0Lr}+D7 z>&GOlAhz=b=waie?JbHa8Z)cvV7?VEg88I4=m7xDHU0w8lTM%LlcVAN|qnsf(z-=Qo1e+-#dK5b1Y!x!bwpdL${>t_l z7%0QUCw2&zInn&v3@nxdI4ldM#FF8=(`P4^Z1bg!pu_`8^v0GA6!2O|J{K-{6qQnm z#O?jjru|khHW}7V{z93?JRmyn;>o3T9;QXyfd|uRcvA=GRBD1HGpkBCUml{jAKn1i zJ5w0KR-9VY4N+Cx!C0J%Wz;H3tq{k}*u1dVkT-(7>r3Q?b%&(|*|)Y;Z?-^T+U=Bp zc51*52s%4p+|k)#`qcH1%#BUQ{lVC7Hjy|50Ky5a0r{}Vc$Lb_d9O)08wvSUFkp^z zW5)H>{Jm-B-LIVOdpS{8i8jH?QUxC1Qy33ySPZ!vDl^2sgQgy&j1jwo$2hT!)v;RxzaVE{@jBfdNp^nuW`D(!%#zP7_nzdY#_h(Xy4Jk zyq~`cBHi>`h{12!)$QZyRmc15N7Ji*o2VO=#i6)teB>GIh3}C({`9_&8BU#Hi`4OJCz zRE6QFVn1@kjQ(HbpqSC^gk6#gzWAkEv=W%Bw-R>#3w=4mFmLY$_@<`eyWySMFoovs zMr;QUA?Bw*v|%zK5TN(XhI`G~{5ZURyv-!9zYI0N4YE#emkr6fx9h%7>i!fo08G0R z*FilcYFEbVIuf<_#xd!sX~0AUW;nWqY~=)TFDKSZWc6Wi{nHrhPBfmEwD$s0Im;kIKArm3^V3A`bnv%i`M?Gf;DLJaz*D$?esAmDLeY zQl416K$Tsi%3fs3zN;5tF#^Y9bD1SJQ^E@*JX^vw_{|-Jld<4IBy~y2KoEra~&haad8U-ZE_mEx!n4v(iZ9m-{>ta2yAs}0(U(!d?H&>P8 zKSs_Fi66oC;@r#PRTOIIt}&=GQW4}fs3h;3uH4Ts_cu%Dequ~+=5&|6j=AdqCiH(? zSzmWcwn6wN9Qp^xBmOr)0QUuqRl?7+vk(1UZlc0xJ@hGs?>zIa`E!=S5C2pX4(2$h zi)nj8q4vp1i9tfcm+C;X9&SD~80c?r%{8Be+Xr(S@GBktv2UY|6)9VFoZ;_AybI|Q zKzi`evmjPztQn}x=)^`y3o7N;RnKECsz3`|!Sa^-r3Ama!SIUoOZW}re+d5r`0pkC zW<|PRRTSGbg%&ld1pyPBB2GcryP>6+={=*;p8ni_KyJ6@K91Y@x8~;H7o40Jd~CDB z$!ifO?3n0~=VI2GGwLT`OGWzc@f(&NQeah~r+icq$L$T#)I@UWu?H|dsU^V)+g4PxAZX6Ych7fdt+mXMla74hf4L@mFMkpZnR z`61m+JMbY6<#5t;h}8z^|G{RxnYHV|%!<9$5b_^*M+dKm z{gV|(aj^L{QPqwHsP7ZM>E9z3TK~MpTck3D-U5D~sz*@z#|oX@Ctb84cR!|o6HC^> zct+?c%@v}hie*}gFayBNKrdBAeGtb|M7A%cY`4Kt7H!H{jk7q4)-+)9R+)^+peyG& zU}!mKYJLDlVsz%%2v$0S$p0dWRkC=b`)c~R>FC~YYVaXW4W2VgKgHkv`fcf_7>`|| zQ_P+oek~klZ;}hS=^}2ncO;jL`nqQArPAEau^aQ>?HsqcWnnu9ZA{+KG*cUR@FG#W zI9|6UQF}wYt|d`Z8@IRS&r3)};`WwAjMhWkZb^vsfW)NO1c|zBux>GD+=2(z(p&IA zjkk))i?Q<}uWsv_eb{?q%C+`E&f^Bij-)YOG3m*LF=!L=N*V%fb z7d|vKIy$|fGWQys?9tJxVDk^b=IH1}!RBwkKFhtt=%(x>L+Z0ADlNuFy1pYF>jo9+ z`h)3Mj|AG%v0e!rNXPmlurD1OkiedFEF*zl5!8ybeL!@u-G&F|ItTFxNK$#)?!b$Y z+V5ZkSsG9oldo6uNv1vSO#57!{uG&V6^eE^Mbx1DYrK!4J!NP|B^2$bgrXglP_*wi zw4*kIQi;9kSk_c)NCLakv0+`m*oXvr()NCkG)_(J6w->S`eQU++U`-AR5k5gcmsP> zP3^rZle?-9BU5e`+6v87ZmJr3w^c(iRn?O=T&d~|4YN8aG#)0g_AdOi zR*^F?`OS=9O=T?D?pp2wuH2_6noZfMrk0nY*8lSjigxTt*Y{E??Srhz0sidc&mR2L z?<~}DKO^_@hqbNWk+yfHUrXCN@NJW^{k@{0wy#`&Bsa=uv5E7`+Pr?E;j zYrp)uo49`#KNN}8m-@c^9A?EhbE1&-5o9gA9eP35E{N$>g$d(sQ}(hAdQb1w7@uKM z#OvTF=}Yev6{PjwR#{er6Cn%IFhnc>4yA}`6wQVzkp3?&fG=Ktl-&E4BK)VRz)QZAfo}5yGM!4a&uWS}aZ0b$F@m#8z0= zLM;)iDX}3sf$k&wOR!;VnoLn)HV$CZ8ZuzO4aLi3pO}+0=p==igzaHYQpQQDU=ntP zIZ0V3sgg->#iNvA9U1LdYWzcR62Qd3*0{#=$h9#nJ_0`hFHI-EWH!YW4a&Xx=uo2m1=-L4I5C=!sez{=tx5$=~Ih>t_*PBe( zK$l-5h0w`r2tpxrjABOZD(GC3$85~wv9Ur9Zp?j$n`{rqyReWi2vqJqRkwfX(1fB) zxZJ{KduWvlO%)fS=zfLIzhH>`n^Xv=cFX7rSOq*Q3W@CFkVt(ht(J-0wy)L2UZm;+ zk^(f97-o=?XH&c~K+aL(1nyaAFSPdRMBVX(J*xIe3^^u^FO{r?M@nz6`v|hbn+EB? ze4G1hhZLqf4%IShtweF_?eYAFJUGsEa2$cg*pYvqItaNTE~4xa4XM9YAJ~OUX)^tx zoSrjWL*ee&BXG09)#+aR`xd0l#b!FUTu5GE2K0NbaKIfd(kkYoQWRfsyu#5TKaXKH zT;OUZ2&`W0;8i%$1QV$;!lNMXKU&4X!{~X>{5f?5bK7yR>90RFhRRCW#0NCrQ_{OcC zF3>`Q)e0ykj7~X7)2%cIX*+o11iA&5Df;nCM}L;1AfL{jNH20!^&CaVD=Fz%ToYpU z zrij&mRl|tccv&T{Rpzx?UaQUPOe@%oFX%vV%v4c1eDMe78IaiMqu3kPPrGSQmN7zD z;O0`t(fYolcHdF6Sl{$IG~Vm7l#xlV%Jjn;TJ<`%?|}&R1rYEl4Et|`nQmlZBEw?I zX(Ov5GLR3thPYocaqPqP?P z0Xp~sSWe2#drtr4ksi!c;M~7?)Pt>Mi5F z6a5(&g+_*Dl;-MngHl;Ijx~fflUtDFe8Nz!MaC)&ZrJ$Kcnj3j`D?@YedzwlZ4pd* z@`1KH00EnWjvg5ZM{rLC&iRX~V~4>Y#WjDU>aJoxhE5n(iUD^8iGnb<1)-p1Ej;U3 z`31KHl7(xWz8>k3MioFQGRReTzgZENI*}4uG$XVQhuJ-J?`64aCwk*+h6`vqHoGk6 za>bN|1N>hx7)gZ!vg#a2TgP%}j%2A5$%GMs*svy=zVa)J#(2D8V0raH3nO^>9PNs$)QY*=Bsbna)7{!Wz3 zpvgx-RX+q(B9G;~iMUmX+kpM)Y##s98Oa3p5t)P)Vw41APuZv6nX6l{0 z79nn2D8iu2s4->Ca}{2xPzN;X`@E?C%R!xo3?A(>8N-^UHGgPg3RE5jB&lrlqWW(K z)h-d|k~ALeTLTktY?4rU-&ctCelObJ7_|8t3@PLpYqbW`mLgP!%KPNDo(H_BCc{r5 z@`IHZgUhMtjV8vRSo29>cdjXdS(g?e3TbMxPMlU@-$?Ry~b^I z#ppD5@{_mb{aeupqCqwd?M0QTC}3a0C6oJe&Ym$^pbs@A)BBzSYdlL7kmVt zNW?0FNPLXf3`&|mUB5-tUo-c?+0Byt@FhS8SEjv1UN`@Z(6A-lv>B$*W-)~}rdMt3 zZ(WaZF}-SYV!H&4S8$7GjOH5@q-?QrjnPN3os30}i&Hj;^Cm)`@j31|lTLyh`vAD| z9|h*zpU8^RY34NQgt=|zz680cO29lYXhd_dzFRa_H(R1h;-JMc5sk?Ec zr|t4K&N9PMKiCxP~kTiMFX=i491`&4C_1(qiO^ZZ2$VKL_^m~(VpDY|5U)t zJ*2_v2bsG|jC3)2(ZIv1fsbHBV0#a#*B{~42nCALLb1mcJLJSZ%B)b<VdA zMv{H$dPsLOyX27Tt+-3lD=Pici%IgPG2#`XaW??ByMkiO zZB%R=)Da=PWBQ@r5z2DS0#Qus5Nl*eVlW&64PwwB-E_)!V-psi8IcI&LCcN^L>JqG z3{43`h4WbdKtIK?4xaZ~hi=<1znV~cgv`n42~fJeO;@h|KpIORSlGbikk$ZKAX8pG z)6+>NryM3jQ;pSi-dvhJf}Ew+@7JWk-*+9HekF?7Z*XF}Fm$IE#K8wz=-=jY=m0dw zzUTrNFSyRxN#g_SN{W@53}NHDAY->Ix1J$4R+5YwAp>f1C#8^N z7>OhqXV{W|P=bt8w&cHaDfDke_`wZD#yTNGabx8flkrVpOxs>=oRW+$AyfX!;%uiB zfDa>E6bJ9n!!RlbTXxDR>M%V9@NnSBdF&SKLNK=L7RX+wxsgkJ-<|eBR2`A~)kDsQ z(j9^2{F)6IWD&xBJ|0gqtFZuiy_IDcv{r@*Fsiy}8w_(2ccg!o1=pPu|J)N0GHfB@ zL$(m@qR>6X-~Rf6^iz!A)HJ|_Y;Gi%0A*b+id3GuVJ`R$@wyLOFt!CJ!?`0GwVP)T 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°`R__*A#jjablG%&@FKjn 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

>mNTNMJJ+SYR_IM9f=RUkir3%{9 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 z zrij&mRl|tccv&T{Rpzx?UaQUPOe@%oFX%vV%v4c1eDMe78IaiMqu3kPPrGSQmN7zD z;O0`t(fYolcHdF6Sl{$IG~Vm7l#xlV%Jjn;TJ<`%?|}&R1rYEl4Et|`nQmlZBEw?I zX(Ov5GLR3thPYocaqPqP?P z0Xp~sSWe2#drtr4ksi!c;M~7?)Pt>Mi5F z6a5(&g+_*Dl;-MngHl;Ijx~fflUtDFe8Nz!MaC)&ZrJ$Kcnj3j`D?@YedzwlZ4pd* z@`1KH00EnWjvg5ZM{rLC&iRX~V~4>Y#WjDU>aJoxhE5n(iUD^8iGnb<1)-p1Ej;U3 z`31KHl7(xWz8>k3MioFQGRReTzgZENI*}4uG$XVQhuJ-J?`64aCwk*+h6`vqHoGk6 za>bN|1N>hx7)gZ!vg#a2TgP%}j%2A5$%GMs*svy=zVa)J#(2D8V0raH3nO^>9PNs$)QY*=Bsbna)7{!Wz3 zpvgx-RX+q(B9G;~iMUmX+kpM)Y##s98Oa3p5t)P)Vw41APuZv6nX6l{0 z79nn2D8iu2s4->Ca}{2xPzN;X`@E?C%R!xo3?A(>8N-^UHGgPg3RE5jB&lrlqWW(K z)h-d|k~ALeTLTktY?4rU-&ctCelObJ7_|8t3@PLpYqbW`mLgP!%KPNDo(H_BCc{r5 z@`IHZgUhMtjV8vRSo29>cdjXdS(g?e3TbMxPMlU@-$?Ry~b^I z#ppD5@{_mb{aeupqCqwd?M0QTC}3a0C6oJe&Ym$^pbs@A)BBzSYdlL7kmVt zNW?0FNPLXf3`&|mUB5-tUo-c?+0Byt@FhS8SEjv1UN`@Z(6A-lv>B$*W-)~}rdMt3 zZ(WaZF}-SYV!H&4S8$7GjOH5@q-?QrjnPN3os30}i&Hj;^Cm)`@j31|lTLyh`vAD| z9|h*zpU8^RY34NQgt=|zz680cO29lYXhd_dzFRa_H(R1h;-JMc5sk?Ec zr|t4K&N9PMKiCxP~kTiMFX=i491`&4C_1(qiO^ZZ2$VKL_^m~(VpDY|5U)t zJ*2_v2bsG|jC3)2(ZIv1fsbHBV0#a#*B{~42nCALLb1mcJLJSZ%B)b<VdA zMv{H$dPsLOyX27Tt+-3lD=Pici%IgPG2#`XaW??ByMkiO zZB%R=)Da=PWBQ@r5z2DS0#Qus5Nl*eVlW&64PwwB-E_)!V-psi8IcI&LCcN^L>JqG z3{43`h4WbdKtIK?4xaZ~hi=<1znV~cgv`n42~fJeO;@h|KpIORSlGbikk$ZKAX8pG z)6+>NryM3jQ;pSi-dvhJf}Ew+@7JWk-*+9HekF?7Z*XF}Fm$IE#K8wz=-=jY=m0dw zzUTrNFSyRxN#g_SN{W@53}NHDAY->Ix1J$4R+5YwAp>f1C#8^N z7>OhqXV{W|P=bt8w&cHaDfDke_`wZD#yTNGabx8flkrVpOxs>=oRW+$AyfX!;%uiB zfDa>E6bJ9n!!RlbTXxDR>M%V9@NnSBdF&SKLNK=L7RX+wxsgkJ-<|eBR2`A~)kDsQ z(j9^2{F)6IWD&xBJ|0gqtFZuiy_IDcv{r@*Fsiy}8w_(2ccg!o1=pPu|J)N0GHfB@ zL$(m@qR>6X-~Rf6^iz!A)HJ|_Y;Gi%0A*b+id3GuVJ`R$@wyLOFt!CJ!?`0GwVP)T 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°`R__*A#jjablG%&@FKjn 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