From f6a818e76d09633c37057703ba1796ecd5678317 Mon Sep 17 00:00:00 2001 From: Nanley Chery Date: Wed, 2 Sep 2015 11:53:16 -0700 Subject: [PATCH] mesa/extensions: Create _mesa_extension_supported() Create a function which determines if an extension is supported in the current context. v2: Use common variable names (Emil) Insert new line between variables and return statement (Chad) Rename api_set variable to api_bit (Chad) Signed-off-by: Nanley Chery Reviewed-by: Chad Versace --- src/mesa/main/extensions.c | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/src/mesa/main/extensions.c b/src/mesa/main/extensions.c index 4fd7487e7e2..83c492130f2 100644 --- a/src/mesa/main/extensions.c +++ b/src/mesa/main/extensions.c @@ -425,6 +425,24 @@ _mesa_init_extensions(struct gl_extensions *extensions) typedef unsigned short extension_index; +/** + * Given an extension enum, return whether or not the extension is supported + * dependent on the following factors: + * There's driver support and the OpenGL/ES version is at least that + * specified in the extension_table. + */ +static inline bool +_mesa_extension_supported(const struct gl_context *ctx, extension_index i) +{ + const bool *base = (bool *) &ctx->Extensions; + const struct extension *ext = extension_table + i; + const uint8_t api_bit = 1 << ctx->API; + + return (ext->api_set & api_bit) && + (ctx->Version >= ext->version[ctx->API]) && + base[ext->offset]; +} + /** * Compare two entries of the extensions table. Sorts first by year, * then by name. -- 2.30.2