aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorGravatar wm4 <wm4@nowhere>2015-03-25 12:40:45 +0100
committerGravatar wm4 <wm4@nowhere>2015-03-25 12:40:45 +0100
commit45ff6cef629e257b74029f6a7e6f67dee09c6098 (patch)
tree68c17553c60924188dedfa95c64d369bd9de504d
parent6d9f15a8ab8a80d13a04c4fae5ce3f251aa20275 (diff)
vo_opengl: minor simplification
We don't need alternative function names in the GL loader anymore.
-rw-r--r--video/out/gl_common.c29
1 files changed, 12 insertions, 17 deletions
diff --git a/video/out/gl_common.c b/video/out/gl_common.c
index dbf5dbd277..1470227b5c 100644
--- a/video/out/gl_common.c
+++ b/video/out/gl_common.c
@@ -89,12 +89,12 @@ static bool check_ext(GL *gl, const char *name)
#define FN_OFFS(name) offsetof(GL, name)
-#define DEF_FN(name) {FN_OFFS(name), {"gl" # name}}
-#define DEF_FN_NAMES(name, ...) {FN_OFFS(name), {__VA_ARGS__}}
+#define DEF_FN(name) {FN_OFFS(name), "gl" # name}
+#define DEF_FN_NAME(name, str) {FN_OFFS(name), str}
struct gl_function {
ptrdiff_t offset;
- char *funcnames[7];
+ char *name;
};
struct gl_functions {
@@ -255,22 +255,22 @@ static const struct gl_functions gl_functions[] = {
{
.extension = "GLX_SGI_swap_control",
.functions = (const struct gl_function[]) {
- DEF_FN_NAMES(SwapInterval, "glXSwapIntervalSGI"),
+ DEF_FN_NAME(SwapInterval, "glXSwapIntervalSGI"),
{0},
},
},
{
.extension = "WGL_EXT_swap_control",
.functions = (const struct gl_function[]) {
- DEF_FN_NAMES(SwapInterval, "wglSwapIntervalEXT"),
+ DEF_FN_NAME(SwapInterval, "wglSwapIntervalEXT"),
{0},
},
},
{
.extension = "GLX_SGI_video_sync",
.functions = (const struct gl_function[]) {
- DEF_FN_NAMES(GetVideoSync, "glXGetVideoSyncSGI"),
- DEF_FN_NAMES(WaitVideoSync, "glXWaitVideoSyncSGI"),
+ DEF_FN_NAME(GetVideoSync, "glXGetVideoSyncSGI"),
+ DEF_FN_NAME(WaitVideoSync, "glXWaitVideoSyncSGI"),
{0},
},
},
@@ -313,7 +313,7 @@ static const struct gl_functions gl_functions[] = {
#undef FN_OFFS
#undef DEF_FN_HARD
#undef DEF_FN
-#undef DEF_FN_NAMES
+#undef DEF_FN_NAME
// Fill the GL struct with function pointers and extensions from the current
@@ -437,18 +437,13 @@ void mpgl_load_functions2(GL *gl, void *(*get_fn)(void *ctx, const char *n),
bool all_loaded = true;
const struct gl_function *fnlist = section->functions;
- for (int i = 0; fnlist && fnlist[i].funcnames[0]; i++) {
+ for (int i = 0; fnlist && fnlist[i].name; i++) {
const struct gl_function *fn = &fnlist[i];
- void *ptr = NULL;
- for (int x = 0; fn->funcnames[x]; x++) {
- ptr = get_fn(fn_ctx, fn->funcnames[x]);
- if (ptr)
- break;
- }
+ void *ptr = get_fn(fn_ctx, fn->name);
if (!ptr) {
all_loaded = false;
mp_warn(log, "Required function '%s' not "
- "found for %s OpenGL %d.%d.\n", fn->funcnames[0],
+ "found for %s OpenGL %d.%d.\n", fn->name,
section->extension ? section->extension : "builtin",
MPGL_VER_GET_MAJOR(ver_core),
MPGL_VER_GET_MINOR(ver_core));
@@ -464,7 +459,7 @@ void mpgl_load_functions2(GL *gl, void *(*get_fn)(void *ctx, const char *n),
if (all_loaded) {
gl->mpgl_caps |= section->provides;
- for (int i = 0; fnlist && fnlist[i].funcnames[0]; i++) {
+ for (int i = 0; fnlist && fnlist[i].name; i++) {
const struct gl_function *fn = &fnlist[i];
void **funcptr = (void**)(((char*)gl) + fn->offset);
if (loaded[i])