diff options
author | Brian Paul <brianp@vmware.com> | 2010-02-16 10:42:05 -0700 |
---|---|---|
committer | Brian Paul <brianp@vmware.com> | 2010-02-16 10:43:36 -0700 |
commit | de5928a61549a6ca66e6b9ff6e50b305f653888c (patch) | |
tree | 7eec9b42a9420533b632cd2f39dc5fdafbcb0011 /src/glsl/pp/sl_pp_extension.c | |
parent | f7aea808a4724a9e50bf3afa5a1bf547d0da5d65 (diff) |
sl/pp: re-do extension testing code
The #extension directive should not effect which extension preprocessor
symbols are defined/undefined; only whether/how the compiler accepts
language features defined by the extension.
Diffstat (limited to 'src/glsl/pp/sl_pp_extension.c')
-rw-r--r-- | src/glsl/pp/sl_pp_extension.c | 28 |
1 files changed, 23 insertions, 5 deletions
diff --git a/src/glsl/pp/sl_pp_extension.c b/src/glsl/pp/sl_pp_extension.c index 1f00d94eba..0816e815a4 100644 --- a/src/glsl/pp/sl_pp_extension.c +++ b/src/glsl/pp/sl_pp_extension.c @@ -53,7 +53,7 @@ sl_pp_context_add_extension(struct sl_pp_context *context, return -1; } - ext.enabled = 0; + ext.state = SL_PP_EXTENSION_STATE_DISABLED; context->extensions[context->num_extensions++] = ext; @@ -62,6 +62,24 @@ sl_pp_context_add_extension(struct sl_pp_context *context, return 0; } + +enum sl_pp_extension_state +sl_pp_get_extension_state(const struct sl_pp_context *context, + int extension_name) +{ + unsigned i; + + for (i = 0; i < context->num_extensions; i++) { + if (extension_name == context->extensions[i].name) { + return context->extensions[i].state; + } + } + + assert(0 && "unknown extension"); + return SL_PP_EXTENSION_STATE_DISABLED; +} + + /** * Process a "#extension name: behavior" directive. */ @@ -140,7 +158,7 @@ sl_pp_process_extension(struct sl_pp_context *context, if (extension_name != context->dict.all) { assert(extension); - extension->enabled = 1; + extension->state = SL_PP_EXTENSION_STATE_REQUIRE; } } else if (behavior == context->dict.enable) { if (out.data.extension == -1) { @@ -155,7 +173,7 @@ sl_pp_process_extension(struct sl_pp_context *context, if (extension_name != context->dict.all) { assert(extension); - extension->enabled = 1; + extension->state = SL_PP_EXTENSION_STATE_ENABLED; } } else if (behavior == context->dict.warn) { if (out.data.extension == -1) { @@ -166,7 +184,7 @@ sl_pp_process_extension(struct sl_pp_context *context, if (extension_name != context->dict.all) { assert(extension); - extension->enabled = 1; + extension->state = SL_PP_EXTENSION_STATE_WARN; } } else if (behavior == context->dict.disable) { if (out.data.extension == -1) { @@ -177,7 +195,7 @@ sl_pp_process_extension(struct sl_pp_context *context, if (extension_name != context->dict.all) { assert(extension); - extension->enabled = 0; + extension->state = SL_PP_EXTENSION_STATE_DISABLED; } } else { strcpy(context->error_msg, "unrecognised behavior name"); |