mirror of
https://github.com/glfw/glfw.git
synced 2024-11-26 14:24:35 +00:00
Replaced guessing with dirent and regex.
This commit is contained in:
parent
e70ced5e05
commit
4cb569b5b3
@ -648,7 +648,8 @@ int _glfwPlatformInit(void)
|
|||||||
|
|
||||||
_glfwLibrary.X11.cursor = createNULLCursor();
|
_glfwLibrary.X11.cursor = createNULLCursor();
|
||||||
|
|
||||||
_glfwInitJoysticks();
|
if (!_glfwInitJoysticks())
|
||||||
|
return GL_FALSE;
|
||||||
|
|
||||||
// Start the timer
|
// Start the timer
|
||||||
_glfwInitTimer();
|
_glfwInitTimer();
|
||||||
|
@ -37,7 +37,8 @@
|
|||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
#include <regex.h>
|
||||||
|
#include <dirent.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#endif // _GLFW_USE_LINUX_JOYSTICKS
|
#endif // _GLFW_USE_LINUX_JOYSTICKS
|
||||||
@ -171,30 +172,52 @@ static void pollJoystickEvents(void)
|
|||||||
// Initialize joystick interface
|
// Initialize joystick interface
|
||||||
//========================================================================
|
//========================================================================
|
||||||
|
|
||||||
void _glfwInitJoysticks(void)
|
int _glfwInitJoysticks(void)
|
||||||
{
|
{
|
||||||
#ifdef _GLFW_USE_LINUX_JOYSTICKS
|
#ifdef _GLFW_USE_LINUX_JOYSTICKS
|
||||||
int i, j, joy = 0;
|
int i, joy = 0;
|
||||||
char path[20];
|
regex_t regex;
|
||||||
const char* bases[] =
|
DIR* dir;
|
||||||
|
const char* directories[] =
|
||||||
{
|
{
|
||||||
"/dev/input/js",
|
"/dev/input",
|
||||||
"/dev/js"
|
"/dev"
|
||||||
};
|
};
|
||||||
|
|
||||||
for (i = 0; i < sizeof(bases) / sizeof(bases[0]); i++)
|
if (regcomp(®ex, "^js[0-9]\\+$", 0) != 0)
|
||||||
{
|
{
|
||||||
for (j = 0; j < 50; j++)
|
_glfwSetError(GLFW_PLATFORM_ERROR, "X11: Failed to compile regex");
|
||||||
{
|
return GL_FALSE;
|
||||||
if (joy > GLFW_JOYSTICK_LAST)
|
}
|
||||||
break;
|
|
||||||
|
|
||||||
sprintf(path, "%s%i", bases[i], j);
|
for (i = 0; i < sizeof(directories) / sizeof(directories[0]); i++)
|
||||||
|
{
|
||||||
|
struct dirent* entry;
|
||||||
|
|
||||||
|
dir = opendir(directories[i]);
|
||||||
|
if (!dir)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
while ((entry = readdir(dir)))
|
||||||
|
{
|
||||||
|
char path[20];
|
||||||
|
regmatch_t match;
|
||||||
|
|
||||||
|
if (regexec(®ex, entry->d_name, 1, &match, 0) != 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
snprintf(path, sizeof(path), "%s/%s", directories[i], entry->d_name);
|
||||||
if (openJoystickDevice(joy, path))
|
if (openJoystickDevice(joy, path))
|
||||||
joy++;
|
joy++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
closedir(dir);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
regfree(®ex);
|
||||||
#endif // _GLFW_USE_LINUX_JOYSTICKS
|
#endif // _GLFW_USE_LINUX_JOYSTICKS
|
||||||
|
|
||||||
|
return GL_TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -305,7 +305,7 @@ void _glfwSetVideoMode(int* width, int* height, int* rate);
|
|||||||
void _glfwRestoreVideoMode(void);
|
void _glfwRestoreVideoMode(void);
|
||||||
|
|
||||||
// Joystick input
|
// Joystick input
|
||||||
void _glfwInitJoysticks(void);
|
int _glfwInitJoysticks(void);
|
||||||
void _glfwTerminateJoysticks(void);
|
void _glfwTerminateJoysticks(void);
|
||||||
|
|
||||||
// Unicode support
|
// Unicode support
|
||||||
|
Loading…
Reference in New Issue
Block a user