summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/glsl/pp/sl_pp_extension.c28
1 files changed, 20 insertions, 8 deletions
diff --git a/src/glsl/pp/sl_pp_extension.c b/src/glsl/pp/sl_pp_extension.c
index 677fb8a0e6..1f00d94eba 100644
--- a/src/glsl/pp/sl_pp_extension.c
+++ b/src/glsl/pp/sl_pp_extension.c
@@ -137,8 +137,11 @@ sl_pp_process_extension(struct sl_pp_context *context,
return -1;
}
out.token = SL_PP_EXTENSION_REQUIRE;
- assert(extension);
- extension->enabled = 1;
+
+ if (extension_name != context->dict.all) {
+ assert(extension);
+ extension->enabled = 1;
+ }
} else if (behavior == context->dict.enable) {
if (out.data.extension == -1) {
/* Warning: the extension cannot be enabled. */
@@ -149,24 +152,33 @@ sl_pp_process_extension(struct sl_pp_context *context,
return -1;
}
out.token = SL_PP_EXTENSION_ENABLE;
- assert(extension);
- extension->enabled = 1;
+
+ if (extension_name != context->dict.all) {
+ assert(extension);
+ extension->enabled = 1;
+ }
} else if (behavior == context->dict.warn) {
if (out.data.extension == -1) {
/* Warning: the extension is not supported. */
return 0;
}
out.token = SL_PP_EXTENSION_WARN;
- assert(extension);
- extension->enabled = 1;
+
+ if (extension_name != context->dict.all) {
+ assert(extension);
+ extension->enabled = 1;
+ }
} else if (behavior == context->dict.disable) {
if (out.data.extension == -1) {
/* Warning: the extension is not supported. */
return 0;
}
out.token = SL_PP_EXTENSION_DISABLE;
- assert(extension);
- extension->enabled = 0;
+
+ if (extension_name != context->dict.all) {
+ assert(extension);
+ extension->enabled = 0;
+ }
} else {
strcpy(context->error_msg, "unrecognised behavior name");
return -1;