joystickcallback : Add unit tests. Fix signature.

This commit is contained in:
Philippe Groarke 2019-09-22 14:56:22 -04:00
parent 8b2b1d7eda
commit 21d4e379ac
3 changed files with 108 additions and 3 deletions

View File

@ -5201,7 +5201,7 @@ GLFWAPI GLFWjoystickfun glfwSetJoystickCallback(GLFWjoystickfun callback);
* *
* @ingroup input * @ingroup input
*/ */
GLFWAPI GLFWjoystickwindowfun glfwSetJoystickCallback(GLFWwindow* window, GLFWjoystickwindowfun callback); GLFWAPI GLFWjoystickwindowfun glfwSetWindowJoystickCallback(GLFWwindow* window, GLFWjoystickwindowfun callback);
/*! @brief Adds the specified SDL_GameControllerDB gamepad mappings. /*! @brief Adds the specified SDL_GameControllerDB gamepad mappings.
* *

View File

@ -1124,7 +1124,7 @@ GLFWAPI GLFWjoystickfun glfwSetJoystickCallback(GLFWjoystickfun cbfun)
return cbfun; return cbfun;
} }
GLFWAPI GLFWjoystickwindowfun glfwSetJoystickCallback(GLFWwindow* handle, GLFWjoystickwindowfun cbfun) GLFWAPI GLFWjoystickwindowfun glfwSetWindowJoystickCallback(GLFWwindow* handle, GLFWjoystickwindowfun cbfun)
{ {
_GLFWwindow* window = (_GLFWwindow*) handle; _GLFWwindow* window = (_GLFWwindow*) handle;
assert(window != NULL); assert(window != NULL);

View File

@ -45,6 +45,7 @@
#define NK_GLFW_GL2_IMPLEMENTATION #define NK_GLFW_GL2_IMPLEMENTATION
#include <nuklear_glfw_gl2.h> #include <nuklear_glfw_gl2.h>
#include <assert.h>
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <stdlib.h> #include <stdlib.h>
@ -53,9 +54,27 @@
#define strdup(x) _strdup(x) #define strdup(x) _strdup(x)
#endif #endif
#ifdef NDEBUG
#define TEST_ASSERT(expr) if(!(expr)) { \
fprintf(stderr, "TEST FAILURE : " #expr "\n %s : line %d\n", __FILE__, __LINE__); \
glfwTerminate(); \
exit(EXIT_FAILURE); \
}
#else
#define TEST_ASSERT(expr) assert(expr)
#endif // !NDEBUG
static GLFWwindow* window; static GLFWwindow* window;
static int joysticks[GLFW_JOYSTICK_LAST + 1]; static int joysticks[GLFW_JOYSTICK_LAST + 1];
static int joystick_count = 0; static int joystick_count = 0;
static int window_joysticks[GLFW_JOYSTICK_LAST + 1];
static int window_joystick_count = 0;
#define OTHER_WINDOWS_COUNT 4
static GLFWwindow* other_windows[OTHER_WINDOWS_COUNT];
static int num_window_callbacks = 0;
static int num_other_window_callbacks = 0;
static void error_callback(int error, const char* description) static void error_callback(int error, const char* description)
{ {
@ -64,6 +83,9 @@ static void error_callback(int error, const char* description)
static void joystick_callback(int jid, int event) static void joystick_callback(int jid, int event)
{ {
// Check the window callbacks are working ok.
TEST_ASSERT(num_window_callbacks * OTHER_WINDOWS_COUNT == num_other_window_callbacks);
if (event == GLFW_CONNECTED) if (event == GLFW_CONNECTED)
joysticks[joystick_count++] = jid; joysticks[joystick_count++] = jid;
else if (event == GLFW_DISCONNECTED) else if (event == GLFW_DISCONNECTED)
@ -86,6 +108,41 @@ static void joystick_callback(int jid, int event)
glfwRequestWindowAttention(window); glfwRequestWindowAttention(window);
} }
// We are guaranteed the window callback executes after the global one.
static void joystick_window_callback(GLFWwindow* w, int jid, int event)
{
TEST_ASSERT(w != NULL && w == window);
if (event == GLFW_CONNECTED)
window_joysticks[window_joystick_count++] = jid;
else if (event == GLFW_DISCONNECTED)
{
int i;
for (i = 0; i < window_joystick_count; i++)
{
if (window_joysticks[i] == jid)
break;
}
for (i = i + 1; i < window_joystick_count; i++)
window_joysticks[i - 1] = window_joysticks[i];
window_joystick_count--;
}
if (!glfwGetWindowAttrib(w, GLFW_FOCUSED))
glfwRequestWindowAttention(w);
TEST_ASSERT(joystick_count == window_joystick_count);
for (int i = 0; i < window_joystick_count; ++i) {
TEST_ASSERT(window_joysticks[i] == joysticks[i]);
}
++num_window_callbacks;
}
static void drop_callback(GLFWwindow* window, int count, const char* paths[]) static void drop_callback(GLFWwindow* window, int count, const char* paths[])
{ {
int i; int i;
@ -168,6 +225,35 @@ static void hat_widget(struct nk_context* nk, unsigned char state)
} }
} }
static void other_joystick_window_callback(GLFWwindow* w, int jid, int event) {
TEST_ASSERT(w != NULL && w != window);
int window_ptr_found = GLFW_FALSE;
for (int i = 0; i < OTHER_WINDOWS_COUNT; ++i) {
if (other_windows[i] == w) {
window_ptr_found = GLFW_TRUE;
break;
}
}
TEST_ASSERT(window_ptr_found == GLFW_TRUE);
int jid_found = GLFW_FALSE;
for (int i = 0; i < joystick_count; ++i) {
if (joysticks[i] == jid) {
jid_found = GLFW_TRUE;
break;
}
}
if (event == GLFW_CONNECTED) {
TEST_ASSERT(jid_found == GLFW_TRUE);
}
else {
TEST_ASSERT(jid_found == GLFW_FALSE);
}
++num_other_window_callbacks;
}
int main(void) int main(void)
{ {
int jid, hat_buttons = GLFW_FALSE; int jid, hat_buttons = GLFW_FALSE;
@ -175,12 +261,24 @@ int main(void)
struct nk_font_atlas* atlas; struct nk_font_atlas* atlas;
memset(joysticks, 0, sizeof(joysticks)); memset(joysticks, 0, sizeof(joysticks));
memset(window_joysticks, 0, sizeof(window_joysticks));
memset(other_windows, 0, sizeof(other_windows));
glfwSetErrorCallback(error_callback); glfwSetErrorCallback(error_callback);
if (!glfwInit()) if (!glfwInit())
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
for (int i = 0; i < OTHER_WINDOWS_COUNT; ++i) {
other_windows[i] = glfwCreateWindow(800, 600, "other window", NULL, NULL);
if (other_windows[i] == NULL) {
glfwTerminate();
exit(EXIT_FAILURE);
}
glfwSetWindowJoystickCallback(other_windows[i], other_joystick_window_callback);
}
glfwWindowHint(GLFW_SCALE_TO_MONITOR, GLFW_TRUE); glfwWindowHint(GLFW_SCALE_TO_MONITOR, GLFW_TRUE);
window = glfwCreateWindow(800, 600, "Joystick Test", NULL, NULL); window = glfwCreateWindow(800, 600, "Joystick Test", NULL, NULL);
@ -194,17 +292,24 @@ int main(void)
gladLoadGL(glfwGetProcAddress); gladLoadGL(glfwGetProcAddress);
glfwSwapInterval(1); glfwSwapInterval(1);
// Make Nuklear window the main focus
if (!glfwGetWindowAttrib(window, GLFW_FOCUSED))
glfwRequestWindowAttention(window);
nk = nk_glfw3_init(window, NK_GLFW3_INSTALL_CALLBACKS); nk = nk_glfw3_init(window, NK_GLFW3_INSTALL_CALLBACKS);
nk_glfw3_font_stash_begin(&atlas); nk_glfw3_font_stash_begin(&atlas);
nk_glfw3_font_stash_end(); nk_glfw3_font_stash_end();
for (jid = GLFW_JOYSTICK_1; jid <= GLFW_JOYSTICK_LAST; jid++) for (jid = GLFW_JOYSTICK_1; jid <= GLFW_JOYSTICK_LAST; jid++)
{ {
if (glfwJoystickPresent(jid)) if (glfwJoystickPresent(jid)) {
joysticks[joystick_count++] = jid; joysticks[joystick_count++] = jid;
window_joysticks[window_joystick_count++] = jid;
}
} }
glfwSetJoystickCallback(joystick_callback); glfwSetJoystickCallback(joystick_callback);
glfwSetWindowJoystickCallback(window, joystick_window_callback);
glfwSetDropCallback(window, drop_callback); glfwSetDropCallback(window, drop_callback);
while (!glfwWindowShouldClose(window)) while (!glfwWindowShouldClose(window))