From 453bb26ef553fb1ab426f6e2b7920dfc73610a19 Mon Sep 17 00:00:00 2001
From: John Kessenich <cepheus@frii.com>
Date: Fri, 12 Jun 2015 05:01:25 +0000
Subject: [PATCH] glslang AEP: The extension scheme, extension-enabled
 stage-existence testing, and compute-shader interface.  Still needs in/out
 blocks, unsized arrays, etc. before real testing can be done.

git-svn-id: https://cvs.khronos.org/svn/repos/ogl/trunk/ecosystem/public/sdk/tools/glslang@31479 e7fa87d3-cd2b-0410-9028-fcbf551c1848
---
 Test/310.geom                              | 143 ++++++++++
 Test/baseResults/310.geom.out              | 299 +++++++++++++++++++++
 Test/baseResults/mains1.frag.out           |   2 +-
 Test/testlist                              |   1 +
 glslang/MachineIndependent/Initialize.cpp  |  76 ++++--
 glslang/MachineIndependent/ParseHelper.cpp |  27 +-
 glslang/MachineIndependent/ParseHelper.h   |   1 +
 glslang/MachineIndependent/ShaderLang.cpp  |  26 +-
 glslang/MachineIndependent/Versions.cpp    |  66 ++++-
 glslang/MachineIndependent/Versions.h      |  18 ++
 10 files changed, 627 insertions(+), 32 deletions(-)
 create mode 100644 Test/310.geom
 create mode 100644 Test/baseResults/310.geom.out

diff --git a/Test/310.geom b/Test/310.geom
new file mode 100644
index 000000000..075d59a58
--- /dev/null
+++ b/Test/310.geom
@@ -0,0 +1,143 @@
+#version 310 es
+
+#extension GL_EXT_geometry_shader : enable
+
+precision mediump float;
+
+in fromVertex {
+    in vec3 color;
+} fromV[];
+
+out toFragment {
+    out vec3 color;
+} toF;
+
+out fromVertex {  // okay to reuse a block name for another block name
+    vec3 color;
+};
+
+out fooB {
+    vec2 color;
+} fromVertex;     // ERROR, cannot reuse block name as block instance
+
+int fromVertex;   // ERROR, cannot reuse a block name for something else
+
+out fooC {
+    vec2 color;
+} fooC;           // ERROR, cannot have same name for block and instance name
+
+void main()
+{
+    EmitVertex();
+    EndPrimitive();
+    EmitStreamVertex(1);    // ERROR
+    EndStreamPrimitive(0);  // ERROR
+
+    color = fromV[0].color;
+    gl_ClipDistance[3] = gl_in[1].gl_ClipDistance[2];
+    gl_Position = gl_in[0].gl_Position;
+    gl_PointSize = gl_in[3].gl_PointSize;
+    gl_PrimitiveID = gl_PrimitiveIDIn;
+    gl_Layer = 2;
+}
+
+out vec4 ov0;  // stream should be 0
+layout(stream = 4) out vec4 ov4;
+out vec4 o1v0;  // stream should be 0
+
+layout(stream = 3) uniform;        // ERROR
+layout(stream = 3) in;             // ERROR
+layout(stream = 3) uniform int ua; // ERROR
+layout(stream = 3) uniform ubb { int ua; } ibb; // ERROR
+
+layout(line_strip, points, triangle_strip, stream = 3, points, triangle_strip) out;  // just means "stream = 3, triangle_strip"
+layout(stream = 3, triangle_strip) out;
+out vec4 ov3;  // stream should be 3
+
+layout(stream = 6) out ooutb { vec4 a; } ouuaa6;
+
+layout(stream = 6) out ooutb2 {
+    layout(stream = 6) vec4 a;
+} ouua6;
+
+layout(stream = 7) out ooutb3 {
+    layout(stream = 6) vec4 a;  // ERROR
+} ouua7;
+
+out vec4 ov2s3;  // stream should be 3
+
+layout(max_vertices = 200) out;
+layout(max_vertices = 300) out;   // ERROR, too big
+void foo(layout(max_vertices = 4) int a)  // ERROR
+{
+    ouuaa6.a = vec4(1.0);
+}
+
+layout(line_strip, points, triangle_strip, stream = 3, points) out;  // ERROR, changing output primitive
+layout(line_strip, points, stream = 3) out; // ERROR, changing output primitive
+layout(triangle_strip) in; // ERROR, not an input primitive
+layout(triangle_strip) uniform; // ERROR
+layout(triangle_strip) out vec4 badv4;  // ERROR, not on a variable
+layout(triangle_strip) in vec4 bad2v4[];  // ERROR, not on a variable or input
+layout(invocations = 3) out outbn { int a; }; // 2 ERROR, not on a block, not until 4.0
+out outbn2 {
+    layout(invocations = 3)  int a; // 2 ERRORs, not on a block member, not until 4.0
+    layout(max_vertices = 3) int b; // ERROR, not on a block member
+    layout(triangle_strip)   int c; // ERROR, not on a block member
+} outbi;
+
+layout(lines) out;  // ERROR, not on output
+layout(lines_adjacency) in;
+layout(triangles) in;             // ERROR, can't change it
+layout(triangles_adjacency) in;   // ERROR, can't change it
+layout(invocations = 4) in;       // ERROR, not until 4.0
+
+in inbn {
+    layout(stream = 2) int a;     // ERROR, stream on input
+} inbi[];
+
+in sameName {
+    int a15;
+} insn[];
+
+out sameName {
+    float f15;
+};
+
+uniform sameName {
+    bool b15;
+};
+
+float summ = gl_MaxVertexAttribs +
+             gl_MaxVertexUniformComponents +
+             gl_MaxVaryingFloats +
+             gl_MaxVaryingComponents +
+             gl_MaxVertexOutputComponents  +
+             gl_MaxGeometryInputComponents  +
+             gl_MaxGeometryOutputComponents  +
+             gl_MaxFragmentInputComponents  +
+             gl_MaxVertexTextureImageUnits +
+             gl_MaxCombinedTextureImageUnits +
+             gl_MaxTextureImageUnits +
+             gl_MaxFragmentUniformComponents +
+             gl_MaxDrawBuffers +
+             gl_MaxClipDistances  +
+             gl_MaxGeometryTextureImageUnits +
+             gl_MaxGeometryOutputVertices +
+             gl_MaxGeometryTotalOutputComponents  +
+             gl_MaxGeometryUniformComponents  +
+             gl_MaxGeometryVaryingComponents;
+
+void fooe1()
+{
+    gl_ViewportIndex = gl_MaxViewports - 1;
+}
+
+#extension GL_ARB_viewport_array : enable
+
+void fooe2()
+{
+    gl_ViewportIndex = gl_MaxViewports - 1;
+}
+
+out int gl_ViewportIndex;
diff --git a/Test/baseResults/310.geom.out b/Test/baseResults/310.geom.out
new file mode 100644
index 000000000..3eba0674e
--- /dev/null
+++ b/Test/baseResults/310.geom.out
@@ -0,0 +1,299 @@
+310.geom
+Warning, version 310 is not yet complete; most version-specific features are present, but some are missing.
+WARNING: 0:3: '#extension' : extension is only partially supported: GL_EXT_geometry_shader
+ERROR: 0:7: '' : array size required 
+ERROR: 0:7: 'input block' : not supported with this profile: es
+ERROR: 0:11: 'output block' : not supported with this profile: es
+ERROR: 0:15: 'output block' : not supported with this profile: es
+ERROR: 0:19: 'output block' : not supported with this profile: es
+ERROR: 0:19: 'fromVertex' : block instance name redefinition 
+ERROR: 0:23: 'fromVertex' : redefinition 
+ERROR: 0:25: 'output block' : not supported with this profile: es
+ERROR: 0:25: 'fooC' : block instance name redefinition 
+ERROR: 0:31: 'EmitVertex' : no matching overloaded function found 
+ERROR: 0:32: 'EndPrimitive' : no matching overloaded function found 
+ERROR: 0:33: 'EmitStreamVertex' : no matching overloaded function found 
+ERROR: 0:34: 'EndStreamPrimitive' : no matching overloaded function found 
+ERROR: 0:37: 'gl_ClipDistance' : undeclared identifier 
+ERROR: 0:37: 'gl_ClipDistance' :  left of '[' is not of type array, matrix, or vector  
+ERROR: 0:37: 'gl_in' : undeclared identifier 
+ERROR: 0:37: 'gl_in' :  left of '[' is not of type array, matrix, or vector  
+ERROR: 0:37: 'scalar swizzle' : not supported with this profile: es
+ERROR: 0:37: 'gl_ClipDistance' : illegal vector field selection 
+ERROR: 0:37: 'expression' :  left of '[' is not of type array, matrix, or vector  
+ERROR: 0:37: 'assign' :  l-value required (can't modify a const)
+ERROR: 0:38: 'gl_Position' : undeclared identifier 
+ERROR: 0:38: 'gl_in' :  left of '[' is not of type array, matrix, or vector  
+ERROR: 0:38: 'scalar swizzle' : not supported with this profile: es
+ERROR: 0:38: 'gl_Position' : illegal vector field selection 
+ERROR: 0:39: 'gl_PointSize' : undeclared identifier 
+ERROR: 0:39: 'gl_in' :  left of '[' is not of type array, matrix, or vector  
+ERROR: 0:39: 'scalar swizzle' : not supported with this profile: es
+ERROR: 0:39: 'gl_PointSize' : illegal vector field selection 
+ERROR: 0:40: 'gl_PrimitiveID' : undeclared identifier 
+ERROR: 0:40: 'gl_PrimitiveIDIn' : undeclared identifier 
+ERROR: 0:41: 'gl_Layer' : undeclared identifier 
+ERROR: 0:41: 'assign' :  cannot convert from 'const int' to 'temp float'
+ERROR: 0:48: 'stream' : can only be used on an output 
+ERROR: 0:49: 'stream' : can only be used on an output 
+ERROR: 0:50: 'stream' : can only be used on an output 
+ERROR: 0:51: 'stream' : can only be used on an output 
+ERROR: 0:51: 'stream' : can only be used on an output 
+ERROR: 0:57: 'output block' : not supported with this profile: es
+ERROR: 0:59: 'output block' : not supported with this profile: es
+ERROR: 0:63: 'output block' : not supported with this profile: es
+ERROR: 0:64: 'stream' : member cannot contradict block 
+ERROR: 0:70: 'max_vertices' : too large, must be less than gl_MaxGeometryOutputVertices 
+ERROR: 0:70: 'max_vertices' : cannot change previously set layout value 
+ERROR: 0:71: 'max_vertices' : can only apply to a standalone qualifier 
+ERROR: 0:76: 'points' : cannot change previously set output primitive 
+ERROR: 0:77: 'points' : cannot change previously set output primitive 
+ERROR: 0:78: 'triangle_strip' : cannot apply to input 
+ERROR: 0:79: 'triangle_strip' : cannot apply to: uniform
+ERROR: 0:80: 'triangle_strip' : can only apply to a standalone qualifier 
+ERROR: 0:81: 'triangle_strip' : can only apply to a standalone qualifier 
+ERROR: 0:81: '' : array size required 
+ERROR: 0:82: 'invocations' : can only apply to a standalone qualifier 
+ERROR: 0:82: 'output block' : not supported with this profile: es
+ERROR: 0:84: 'invocations' : can only apply to a standalone qualifier 
+ERROR: 0:85: 'max_vertices' : can only apply to a standalone qualifier 
+ERROR: 0:86: 'triangle_strip' : can only apply to a standalone qualifier 
+ERROR: 0:83: 'output block' : not supported with this profile: es
+ERROR: 0:89: 'lines' : cannot apply to 'out' 
+ERROR: 0:91: 'triangles' : cannot change previously set input primitive 
+ERROR: 0:92: 'triangles_adjacency' : cannot change previously set input primitive 
+ERROR: 0:95: '' : array size required 
+ERROR: 0:95: 'input block' : not supported with this profile: es
+ERROR: 0:96: 'stream' : member cannot contradict block 
+ERROR: 0:96: 'stream' : can only be used on an output 
+ERROR: 0:99: '' : array size required 
+ERROR: 0:99: 'input block' : not supported with this profile: es
+ERROR: 0:103: 'output block' : not supported with this profile: es
+ERROR: 0:112: 'gl_MaxVertexUniformComponents' : undeclared identifier 
+ERROR: 0:111: '+' :  wrong operand types: no operation '+' exists that takes a left-hand operand of type 'const mediump int' and a right operand of type 'temp float' (or there is no acceptable conversion)
+ERROR: 0:113: 'gl_MaxVaryingFloats' : undeclared identifier 
+ERROR: 0:112: '+' :  wrong operand types: no operation '+' exists that takes a left-hand operand of type 'const mediump int' and a right operand of type 'temp float' (or there is no acceptable conversion)
+ERROR: 0:114: 'gl_MaxVaryingComponents' : undeclared identifier 
+ERROR: 0:113: '+' :  wrong operand types: no operation '+' exists that takes a left-hand operand of type 'const mediump int' and a right operand of type 'temp float' (or there is no acceptable conversion)
+ERROR: 0:115: 'gl_MaxVertexOutputComponents' : undeclared identifier 
+ERROR: 0:114: '+' :  wrong operand types: no operation '+' exists that takes a left-hand operand of type 'const mediump int' and a right operand of type 'temp float' (or there is no acceptable conversion)
+ERROR: 0:118: 'gl_MaxFragmentInputComponents' : undeclared identifier 
+ERROR: 0:117: '+' :  wrong operand types: no operation '+' exists that takes a left-hand operand of type 'const mediump int' and a right operand of type 'temp float' (or there is no acceptable conversion)
+ERROR: 0:122: 'gl_MaxFragmentUniformComponents' : undeclared identifier 
+ERROR: 0:121: '+' :  wrong operand types: no operation '+' exists that takes a left-hand operand of type 'const mediump int' and a right operand of type 'temp float' (or there is no acceptable conversion)
+ERROR: 0:124: 'gl_MaxClipDistances' : undeclared identifier 
+ERROR: 0:123: '+' :  wrong operand types: no operation '+' exists that takes a left-hand operand of type 'const mediump int' and a right operand of type 'temp float' (or there is no acceptable conversion)
+ERROR: 0:129: 'gl_MaxGeometryVaryingComponents' : undeclared identifier 
+ERROR: 0:128: '+' :  wrong operand types: no operation '+' exists that takes a left-hand operand of type 'const mediump int' and a right operand of type 'temp float' (or there is no acceptable conversion)
+ERROR: 0:111: '=' :  cannot convert from 'const mediump int' to 'global mediump float'
+ERROR: 0:133: 'gl_ViewportIndex' : undeclared identifier 
+ERROR: 0:133: 'gl_MaxViewports' : undeclared identifier 
+ERROR: 0:133: '-' :  wrong operand types: no operation '-' exists that takes a left-hand operand of type 'temp float' and a right operand of type 'const int' (or there is no acceptable conversion)
+ERROR: 0:140: 'gl_ViewportIndex' : undeclared identifier 
+ERROR: 0:140: 'gl_MaxViewports' : undeclared identifier 
+ERROR: 0:140: '-' :  wrong operand types: no operation '-' exists that takes a left-hand operand of type 'temp float' and a right operand of type 'const int' (or there is no acceptable conversion)
+ERROR: 91 compilation errors.  No code generated.
+
+
+Shader version: 310
+Requested GL_ARB_viewport_array
+Requested GL_EXT_geometry_shader
+invocations = 4
+max_vertices = 200
+input primitive = lines_adjacency
+output primitive = triangle_strip
+ERROR: node is still EOpNull!
+0:29  Function Definition: main( (global void)
+0:29    Function Parameters: 
+0:31    Sequence
+0:31      Constant:
+0:31        0.000000
+0:32      Constant:
+0:32        0.000000
+0:33      Constant:
+0:33        0.000000
+0:34      Constant:
+0:34        0.000000
+0:36      move second child to first child (temp mediump 3-component vector of float)
+0:36        color: direct index for structure (layout(stream=0 ) out mediump 3-component vector of float)
+0:36          'anon@0' (layout(stream=0 ) out block{layout(stream=0 ) out mediump 3-component vector of float color})
+0:36          Constant:
+0:36            0 (const uint)
+0:36        color: direct index for structure (in mediump 3-component vector of float)
+0:36          direct index (temp block{in mediump 3-component vector of float color})
+0:36            'fromV' (in 4-element array of block{in mediump 3-component vector of float color})
+0:36            Constant:
+0:36              0 (const int)
+0:36          Constant:
+0:36            0 (const int)
+0:37      move second child to first child (temp float)
+0:37        Constant:
+0:37          0.000000
+0:37        Constant:
+0:37          0.000000
+0:38      move second child to first child (temp float)
+0:38        'gl_Position' (temp float)
+0:38        Constant:
+0:38          0.000000
+0:39      move second child to first child (temp float)
+0:39        'gl_PointSize' (temp float)
+0:39        Constant:
+0:39          0.000000
+0:40      move second child to first child (temp float)
+0:40        'gl_PrimitiveID' (temp float)
+0:40        'gl_PrimitiveIDIn' (temp float)
+0:41      'gl_Layer' (temp float)
+0:71  Function Definition: foo(i1; (global void)
+0:71    Function Parameters: 
+0:71      'a' (in highp int)
+0:73    Sequence
+0:73      move second child to first child (temp mediump 4-component vector of float)
+0:73        a: direct index for structure (layout(stream=6 ) out mediump 4-component vector of float)
+0:73          'ouuaa6' (layout(stream=6 ) out block{layout(stream=6 ) out mediump 4-component vector of float a})
+0:73          Constant:
+0:73            0 (const int)
+0:73        Constant:
+0:73          1.000000
+0:73          1.000000
+0:73          1.000000
+0:73          1.000000
+0:131  Function Definition: fooe1( (global void)
+0:131    Function Parameters: 
+0:133    Sequence
+0:133      move second child to first child (temp float)
+0:133        'gl_ViewportIndex' (temp float)
+0:133        'gl_MaxViewports' (temp float)
+0:138  Function Definition: fooe2( (global void)
+0:138    Function Parameters: 
+0:140    Sequence
+0:140      move second child to first child (temp float)
+0:140        'gl_ViewportIndex' (temp float)
+0:140        'gl_MaxViewports' (temp float)
+0:?   Linker Objects
+0:?     'fromV' (in 4-element array of block{in mediump 3-component vector of float color})
+0:?     'toF' (layout(stream=0 ) out block{layout(stream=0 ) out mediump 3-component vector of float color})
+0:?     'anon@0' (layout(stream=0 ) out block{layout(stream=0 ) out mediump 3-component vector of float color})
+0:?     'ov0' (layout(stream=0 ) out mediump 4-component vector of float)
+0:?     'ov4' (layout(stream=4 ) out mediump 4-component vector of float)
+0:?     'o1v0' (layout(stream=0 ) out mediump 4-component vector of float)
+0:?     'ua' (layout(stream=3 ) uniform highp int)
+0:?     'ibb' (layout(stream=3 column_major shared ) uniform block{layout(stream=3 column_major shared ) uniform highp int ua})
+0:?     'ov3' (layout(stream=3 ) out mediump 4-component vector of float)
+0:?     'ouuaa6' (layout(stream=6 ) out block{layout(stream=6 ) out mediump 4-component vector of float a})
+0:?     'ouua6' (layout(stream=6 ) out block{layout(stream=6 ) out mediump 4-component vector of float a})
+0:?     'ouua7' (layout(stream=7 ) out block{layout(stream=6 ) out mediump 4-component vector of float a})
+0:?     'ov2s3' (layout(stream=3 ) out mediump 4-component vector of float)
+0:?     'badv4' (layout(stream=3 ) out mediump 4-component vector of float)
+0:?     'bad2v4' (in implicitly-sized array of mediump 4-component vector of float)
+0:?     'anon@1' (layout(stream=3 ) out block{layout(stream=3 ) out highp int a})
+0:?     'outbi' (layout(stream=3 ) out block{layout(stream=3 ) out highp int a, layout(stream=3 ) out highp int b, layout(stream=3 ) out highp int c})
+0:?     'inbi' (in 4-element array of block{layout(stream=2 ) in highp int a})
+0:?     'insn' (in 4-element array of block{in highp int a15})
+0:?     'anon@2' (layout(stream=3 ) out block{layout(stream=3 ) out mediump float f15})
+0:?     'anon@3' (layout(column_major shared ) uniform block{layout(column_major shared ) uniform bool b15})
+0:?     'summ' (global mediump float)
+0:?     'gl_ViewportIndex' (layout(stream=3 ) out highp int)
+
+
+Linked geometry stage:
+
+
+Shader version: 310
+Requested GL_ARB_viewport_array
+Requested GL_EXT_geometry_shader
+invocations = 4
+max_vertices = 200
+input primitive = lines_adjacency
+output primitive = triangle_strip
+ERROR: node is still EOpNull!
+0:29  Function Definition: main( (global void)
+0:29    Function Parameters: 
+0:31    Sequence
+0:31      Constant:
+0:31        0.000000
+0:32      Constant:
+0:32        0.000000
+0:33      Constant:
+0:33        0.000000
+0:34      Constant:
+0:34        0.000000
+0:36      move second child to first child (temp mediump 3-component vector of float)
+0:36        color: direct index for structure (layout(stream=0 ) out mediump 3-component vector of float)
+0:36          'anon@0' (layout(stream=0 ) out block{layout(stream=0 ) out mediump 3-component vector of float color})
+0:36          Constant:
+0:36            0 (const uint)
+0:36        color: direct index for structure (in mediump 3-component vector of float)
+0:36          direct index (temp block{in mediump 3-component vector of float color})
+0:36            'fromV' (in 4-element array of block{in mediump 3-component vector of float color})
+0:36            Constant:
+0:36              0 (const int)
+0:36          Constant:
+0:36            0 (const int)
+0:37      move second child to first child (temp float)
+0:37        Constant:
+0:37          0.000000
+0:37        Constant:
+0:37          0.000000
+0:38      move second child to first child (temp float)
+0:38        'gl_Position' (temp float)
+0:38        Constant:
+0:38          0.000000
+0:39      move second child to first child (temp float)
+0:39        'gl_PointSize' (temp float)
+0:39        Constant:
+0:39          0.000000
+0:40      move second child to first child (temp float)
+0:40        'gl_PrimitiveID' (temp float)
+0:40        'gl_PrimitiveIDIn' (temp float)
+0:41      'gl_Layer' (temp float)
+0:71  Function Definition: foo(i1; (global void)
+0:71    Function Parameters: 
+0:71      'a' (in highp int)
+0:73    Sequence
+0:73      move second child to first child (temp mediump 4-component vector of float)
+0:73        a: direct index for structure (layout(stream=6 ) out mediump 4-component vector of float)
+0:73          'ouuaa6' (layout(stream=6 ) out block{layout(stream=6 ) out mediump 4-component vector of float a})
+0:73          Constant:
+0:73            0 (const int)
+0:73        Constant:
+0:73          1.000000
+0:73          1.000000
+0:73          1.000000
+0:73          1.000000
+0:131  Function Definition: fooe1( (global void)
+0:131    Function Parameters: 
+0:133    Sequence
+0:133      move second child to first child (temp float)
+0:133        'gl_ViewportIndex' (temp float)
+0:133        'gl_MaxViewports' (temp float)
+0:138  Function Definition: fooe2( (global void)
+0:138    Function Parameters: 
+0:140    Sequence
+0:140      move second child to first child (temp float)
+0:140        'gl_ViewportIndex' (temp float)
+0:140        'gl_MaxViewports' (temp float)
+0:?   Linker Objects
+0:?     'fromV' (in 4-element array of block{in mediump 3-component vector of float color})
+0:?     'toF' (layout(stream=0 ) out block{layout(stream=0 ) out mediump 3-component vector of float color})
+0:?     'anon@0' (layout(stream=0 ) out block{layout(stream=0 ) out mediump 3-component vector of float color})
+0:?     'ov0' (layout(stream=0 ) out mediump 4-component vector of float)
+0:?     'ov4' (layout(stream=4 ) out mediump 4-component vector of float)
+0:?     'o1v0' (layout(stream=0 ) out mediump 4-component vector of float)
+0:?     'ua' (layout(stream=3 ) uniform highp int)
+0:?     'ibb' (layout(stream=3 column_major shared ) uniform block{layout(stream=3 column_major shared ) uniform highp int ua})
+0:?     'ov3' (layout(stream=3 ) out mediump 4-component vector of float)
+0:?     'ouuaa6' (layout(stream=6 ) out block{layout(stream=6 ) out mediump 4-component vector of float a})
+0:?     'ouua6' (layout(stream=6 ) out block{layout(stream=6 ) out mediump 4-component vector of float a})
+0:?     'ouua7' (layout(stream=7 ) out block{layout(stream=6 ) out mediump 4-component vector of float a})
+0:?     'ov2s3' (layout(stream=3 ) out mediump 4-component vector of float)
+0:?     'badv4' (layout(stream=3 ) out mediump 4-component vector of float)
+0:?     'bad2v4' (in 1-element array of mediump 4-component vector of float)
+0:?     'anon@1' (layout(stream=3 ) out block{layout(stream=3 ) out highp int a})
+0:?     'outbi' (layout(stream=3 ) out block{layout(stream=3 ) out highp int a, layout(stream=3 ) out highp int b, layout(stream=3 ) out highp int c})
+0:?     'inbi' (in 4-element array of block{layout(stream=2 ) in highp int a})
+0:?     'insn' (in 4-element array of block{in highp int a15})
+0:?     'anon@2' (layout(stream=3 ) out block{layout(stream=3 ) out mediump float f15})
+0:?     'anon@3' (layout(column_major shared ) uniform block{layout(column_major shared ) uniform bool b15})
+0:?     'summ' (global mediump float)
+0:?     'gl_ViewportIndex' (layout(stream=3 ) out highp int)
+
diff --git a/Test/baseResults/mains1.frag.out b/Test/baseResults/mains1.frag.out
index efda6bd05..baf15df3f 100644
--- a/Test/baseResults/mains1.frag.out
+++ b/Test/baseResults/mains1.frag.out
@@ -15,7 +15,7 @@ Shader version: 110
 0:?   Linker Objects
 
 noMain1.geom
-ERROR: #version: geometry shaders require non-es profile and version 150 or above
+ERROR: #version: geometry shaders require es profile with version 310 or non-es profile with version 150 or above
 ERROR: 1 compilation errors.  No code generated.
 
 
diff --git a/Test/testlist b/Test/testlist
index 85b5ba30f..5c06ce1e0 100644
--- a/Test/testlist
+++ b/Test/testlist
@@ -38,6 +38,7 @@ comment.frag
 300block.frag
 310.comp
 310.vert
+310.geom
 310.frag
 310implicitSizeArrayError.vert
 310AofA.vert
diff --git a/glslang/MachineIndependent/Initialize.cpp b/glslang/MachineIndependent/Initialize.cpp
index e666d7f77..ab5d185dd 100644
--- a/glslang/MachineIndependent/Initialize.cpp
+++ b/glslang/MachineIndependent/Initialize.cpp
@@ -989,7 +989,7 @@ void TBuiltIns::initialize(int version, EProfile profile)
             "vec4 texture3DLod(sampler3D, vec3, float);"         // GL_ARB_shader_texture_lod  // OES_texture_3D, but caught by keyword check
             "vec4 texture3DProjLod(sampler3D, vec4, float);"     // GL_ARB_shader_texture_lod  // OES_texture_3D, but caught by keyword check
             "vec4 textureCubeLod(samplerCube, vec3, float);"     // GL_ARB_shader_texture_lod
-            
+
             "\n");
     }
     if ( profile == ECompatibilityProfile ||
@@ -1026,14 +1026,15 @@ void TBuiltIns::initialize(int version, EProfile profile)
             "\n");
     }
 
-    if (profile != EEsProfile && version >= 150) {
+    if ((profile != EEsProfile && version >= 150) ||
+        (profile == EEsProfile && version >= 310)) {
         //============================================================================
         //
         // Prototypes for built-in functions seen by geometry shaders only.
         //
         //============================================================================
 
-        if (version >= 400) {
+        if (profile != EEsProfile && version >= 400) {
             stageBuiltins[EShLangGeometry].append(
                 "void EmitStreamVertex(int);"
                 "void EndStreamPrimitive(int);"
@@ -1093,7 +1094,7 @@ void TBuiltIns::initialize(int version, EProfile profile)
             "vec4 texture3D(sampler3D, vec3, float);"        // OES_texture_3D
             "vec4 texture3DProj(sampler3D, vec4, float);"    // OES_texture_3D
             "vec4 textureCube(samplerCube, vec3, float);"
-            
+
             "\n");
     }
     if (profile != EEsProfile && version > 100) {
@@ -1105,7 +1106,7 @@ void TBuiltIns::initialize(int version, EProfile profile)
             "vec4 shadow2D(sampler2DShadow, vec3, float);"
             "vec4 shadow1DProj(sampler1DShadow, vec4, float);"
             "vec4 shadow2DProj(sampler2DShadow, vec4, float);"
-            
+
             "\n");
     }
     if (profile == EEsProfile) {
@@ -1114,7 +1115,7 @@ void TBuiltIns::initialize(int version, EProfile profile)
             "vec4 texture2DProjLodEXT(sampler2D, vec3, float);"  // GL_EXT_shader_texture_lod
             "vec4 texture2DProjLodEXT(sampler2D, vec4, float);"  // GL_EXT_shader_texture_lod
             "vec4 textureCubeLodEXT(samplerCube, vec3, float);"  // GL_EXT_shader_texture_lod
-            
+
             "\n");
     }
 
@@ -1128,12 +1129,12 @@ void TBuiltIns::initialize(int version, EProfile profile)
         "vec2  dFdy(vec2  p);"
         "vec3  dFdy(vec3  p);"
         "vec4  dFdy(vec4  p);"
-                 
+
         "float fwidth(float p);"
         "vec2  fwidth(vec2  p);"
         "vec3  fwidth(vec3  p);"
         "vec4  fwidth(vec4  p);"
-            
+
         "\n");
 
     // GL_ARB_derivative_control
@@ -1143,17 +1144,17 @@ void TBuiltIns::initialize(int version, EProfile profile)
             "vec2  dFdxFine(vec2  p);"
             "vec3  dFdxFine(vec3  p);"
             "vec4  dFdxFine(vec4  p);"
-                 
+
             "float dFdyFine(float p);"
             "vec2  dFdyFine(vec2  p);"
             "vec3  dFdyFine(vec3  p);"
             "vec4  dFdyFine(vec4  p);"
-                 
+
             "float fwidthFine(float p);"
             "vec2  fwidthFine(vec2  p);"
             "vec3  fwidthFine(vec3  p);"
             "vec4  fwidthFine(vec4  p);"
-            
+
             "\n");
 
         stageBuiltins[EShLangFragment].append(
@@ -1161,7 +1162,7 @@ void TBuiltIns::initialize(int version, EProfile profile)
             "vec2  dFdxCoarse(vec2  p);"
             "vec3  dFdxCoarse(vec3  p);"
             "vec4  dFdxCoarse(vec4  p);"
-                 
+
             "float dFdyCoarse(float p);"
             "vec2  dFdyCoarse(vec2  p);"
             "vec3  dFdyCoarse(vec3  p);"
@@ -1505,7 +1506,7 @@ void TBuiltIns::initialize(int version, EProfile profile)
                 "float gl_PointSize;"
                 "float gl_ClipDistance[];"
                 "\n");
-        if (version >= 400 && profile == ECompatibilityProfile)
+        if (profile == ECompatibilityProfile && version >= 400)
             stageBuiltins[EShLangGeometry].append(
                 "vec4 gl_ClipVertex;"
                 "vec4 gl_FrontColor;"
@@ -1525,23 +1526,43 @@ void TBuiltIns::initialize(int version, EProfile profile)
             "out int gl_PrimitiveID;"
             "out int gl_Layer;");
 
-        if (version < 400 && profile == ECompatibilityProfile)
+        if (profile == ECompatibilityProfile && version < 400)
             stageBuiltins[EShLangGeometry].append(
             "out vec4 gl_ClipVertex;"
             );
 
-        if (version >= 400 && profile != EEsProfile)
+        if (version >= 400)
             stageBuiltins[EShLangGeometry].append(
             "in int gl_InvocationID;"
             );
         // GL_ARB_viewport_array
-        if (version >= 150 && profile != EEsProfile)
+        if (version >= 150)
             stageBuiltins[EShLangGeometry].append(
             "out int gl_ViewportIndex;"
             );
         stageBuiltins[EShLangGeometry].append("\n");
+    } else if (profile == EEsProfile && version >= 310) {
+        stageBuiltins[EShLangGeometry].append(
+            "in gl_PerVertex {"
+                "highp vec4 gl_Position;"
+                "highp float gl_PointSize;"
+            "} gl_in[];"
+            "\n"
+            "in highp int gl_PrimitiveIDIn;"
+            "in highp int gl_InvocationID;"
+            "\n"
+            "out gl_PerVertex {"
+                "vec4 gl_Position;"
+                "float gl_PointSize;"
+            "};"
+            "\n"
+            "out int gl_PrimitiveID;"
+            "out int gl_Layer;"
+            "\n"
+            );
     }
 
+
     //============================================================================
     //
     // Define the interface to the tessellation control shader.
@@ -2275,6 +2296,29 @@ void TBuiltIns::initialize(const TBuiltInResource &resources, int version, EProf
             snprintf(builtInConstant, maxSize, "const mediump int  gl_MaxProgramTexelOffset = %d;", resources.maxProgramTexelOffset);
             s.append(builtInConstant);
         }
+
+        // geometry
+        if (version >= 310) {
+            snprintf(builtInConstant, maxSize, "const int gl_MaxGeometryInputComponents = %d;", resources.maxGeometryInputComponents);
+            s.append(builtInConstant);
+            snprintf(builtInConstant, maxSize, "const int gl_MaxGeometryOutputComponents = %d;", resources.maxGeometryOutputComponents);
+            s.append(builtInConstant);
+            snprintf(builtInConstant, maxSize, "const int gl_MaxGeometryImageUniforms = %d;", resources.maxGeometryImageUniforms);
+            s.append(builtInConstant);
+            snprintf(builtInConstant, maxSize, "const int gl_MaxGeometryTextureImageUnits = %d;", resources.maxGeometryTextureImageUnits);
+            s.append(builtInConstant);
+            snprintf(builtInConstant, maxSize, "const int gl_MaxGeometryOutputVertices = %d;", resources.maxGeometryOutputVertices);
+            s.append(builtInConstant);
+            snprintf(builtInConstant, maxSize, "const int gl_MaxGeometryTotalOutputComponents = %d;", resources.maxGeometryTotalOutputComponents);
+            s.append(builtInConstant);
+            snprintf(builtInConstant, maxSize, "const int gl_MaxGeometryUniformComponents = %d;", resources.maxGeometryUniformComponents);
+            s.append(builtInConstant);
+            snprintf(builtInConstant, maxSize, "const int gl_MaxGeometryAtomicCounters = %d;", resources.maxGeometryAtomicCounters);
+            s.append(builtInConstant);
+            snprintf(builtInConstant, maxSize, "const int gl_MaxGeometryAtomicCounterBuffers = %d;", resources.maxGeometryAtomicCounterBuffers);
+            s.append(builtInConstant);
+        }
+
     } else {
         // non-ES profile
 
diff --git a/glslang/MachineIndependent/ParseHelper.cpp b/glslang/MachineIndependent/ParseHelper.cpp
index 6a311de30..44239aa08 100644
--- a/glslang/MachineIndependent/ParseHelper.cpp
+++ b/glslang/MachineIndependent/ParseHelper.cpp
@@ -157,7 +157,8 @@ bool TParseContext::parseShaderStrings(TPpContext& ppContext, TInputScanner& inp
     currentScanner = &input;
     ppContext.setInput(input, versionWillBeError);
     yyparse(this);
-    finalErrorCheck();
+    if (! parsingBuiltins)
+        finalErrorCheck();
 
     return numErrors == 0;
 }
@@ -3105,6 +3106,30 @@ void TParseContext::finalErrorCheck()
     // Check on array indexes for ES 2.0 (version 100) limitations.
     for (size_t i = 0; i < needsIndexLimitationChecking.size(); ++i)
         constantIndexExpressionCheck(needsIndexLimitationChecking[i]);
+
+    // Check for stages that are enabled by extension.
+    // Can't do this at the beginning, it is chicken and egg to add a stage by extension.
+    // Specific stage-specific features were correctly tested for already, this is just 
+    // about the stage itself.
+    switch (language) {
+    case EShLangGeometry:
+        if (profile == EEsProfile && version == 310)
+            requireExtensions(getCurrentLoc(), 1, &GL_EXT_geometry_shader, "geometry shaders");
+        break;
+    case EShLangTessControl:
+    case EShLangTessEvaluation:
+        if (profile == EEsProfile && version == 310)
+            requireExtensions(getCurrentLoc(), 1, &GL_EXT_tessellation_shader, "tessellation shaders");
+        else if (profile != EEsProfile && version < 400)
+            requireExtensions(getCurrentLoc(), 1, &GL_ARB_tessellation_shader, "tessellation shaders");
+        break;
+    case EShLangCompute:
+        if (profile != EEsProfile && version < 430)
+            requireExtensions(getCurrentLoc(), 1, &GL_ARB_compute_shader, "tessellation shaders");
+        break;
+    default:
+        break;
+    }
 }
 
 //
diff --git a/glslang/MachineIndependent/ParseHelper.h b/glslang/MachineIndependent/ParseHelper.h
index 90b22df03..c2bb6daab 100644
--- a/glslang/MachineIndependent/ParseHelper.h
+++ b/glslang/MachineIndependent/ParseHelper.h
@@ -224,6 +224,7 @@ protected:
     TIntermNode* executeInitializer(TSourceLoc, TIntermTyped* initializer, TVariable* variable);
     TIntermTyped* convertInitializerList(TSourceLoc, const TType&, TIntermTyped* initializer);
     TOperator mapTypeToConstructorOp(const TType&) const;
+    void updateExtensionBehavior(const char* const extension, TExtensionBehavior);
     void finalErrorCheck();
 
 public:
diff --git a/glslang/MachineIndependent/ShaderLang.cpp b/glslang/MachineIndependent/ShaderLang.cpp
index bc773d63f..bb2cadb9b 100644
--- a/glslang/MachineIndependent/ShaderLang.cpp
+++ b/glslang/MachineIndependent/ShaderLang.cpp
@@ -347,28 +347,32 @@ bool DeduceVersionProfile(TInfoSink& infoSink, EShLanguage stage, bool versionNo
     // Correct for stage type...
     switch (stage) {
     case EShLangGeometry:
-        if (version < 150 || (profile != ECoreProfile && profile != ECompatibilityProfile)) {
+        if ((profile == EEsProfile && version < 310) ||
+            (profile != EEsProfile && version < 150)) {
             correct = false;
-            infoSink.info.message(EPrefixError, "#version: geometry shaders require non-es profile and version 150 or above");
-            version = 150;
-            profile = ECoreProfile;
+            infoSink.info.message(EPrefixError, "#version: geometry shaders require es profile with version 310 or non-es profile with version 150 or above");
+            version = (profile == EEsProfile) ? 310 : 150;
+            if (profile == EEsProfile || profile == ENoProfile)
+                profile = ECoreProfile;
         }
         break;
     case EShLangTessControl:
     case EShLangTessEvaluation:
-        if (version < 150 || (profile != ECoreProfile && profile != ECompatibilityProfile)) {
+        if ((profile == EEsProfile && version < 310) ||
+            (profile != EEsProfile && version < 150)) {
             correct = false;
-            infoSink.info.message(EPrefixError, "#version: tessellation shaders require non-es profile and version 150 or above");
-            version = 150;
-            profile = ECoreProfile;
+            infoSink.info.message(EPrefixError, "#version: tessellation shaders require es profile with version 310 or non-es profile with version 150 or above");
+            version = (profile == EEsProfile) ? 310 : 400; // 150 supports the extension, correction is to 400 which does not
+            if (profile == EEsProfile || profile == ENoProfile)
+                profile = ECoreProfile;
         }
         break;
     case EShLangCompute:
         if ((profile == EEsProfile && version < 310) ||
-            (profile != EEsProfile && version < 430)) {
+            (profile != EEsProfile && version < 420)) {
             correct = false;
-            infoSink.info.message(EPrefixError, "#version: compute shaders require es profile with version 310 or above, or non-es profile with version 430 or above");
-            version = profile == EEsProfile ? 310 : 430;
+            infoSink.info.message(EPrefixError, "#version: compute shaders require es profile with version 310 or above, or non-es profile with version 420 or above");
+            version = profile == EEsProfile ? 310 : 430; // 420 supports the extension, correction is to 430 which does not
             profile = ECoreProfile;
         }
         break;
diff --git a/glslang/MachineIndependent/Versions.cpp b/glslang/MachineIndependent/Versions.cpp
index b4c7e692d..619727909 100644
--- a/glslang/MachineIndependent/Versions.cpp
+++ b/glslang/MachineIndependent/Versions.cpp
@@ -161,6 +161,7 @@ void TParseContext::initializeExtensionBehavior()
     extensionBehavior[GL_ARB_texture_gather]               = EBhDisable;
     extensionBehavior[GL_ARB_gpu_shader5]                  = EBhDisablePartial;
     extensionBehavior[GL_ARB_separate_shader_objects]      = EBhDisable;
+    extensionBehavior[GL_ARB_compute_shader]               = EBhDisablePartial;
     extensionBehavior[GL_ARB_tessellation_shader]          = EBhDisable;
     extensionBehavior[GL_ARB_enhanced_layouts]             = EBhDisable;
     extensionBehavior[GL_ARB_texture_cube_map_array]       = EBhDisable;
@@ -172,6 +173,23 @@ void TParseContext::initializeExtensionBehavior()
     extensionBehavior[GL_ARB_shader_texture_image_samples] = EBhDisable;
     extensionBehavior[GL_ARB_viewport_array]               = EBhDisable;
 //    extensionBehavior[GL_ARB_cull_distance]                = EBhDisable;    // present for 4.5, but need extension control over block members
+
+    // AEP
+    extensionBehavior[GL_ANDROID_extension_pack_es31a]             = EBhDisablePartial;
+    extensionBehavior[GL_KHR_blend_equation_advanced]              = EBhDisablePartial;
+    extensionBehavior[GL_OES_sample_variables]                     = EBhDisablePartial;
+    extensionBehavior[GL_OES_shader_image_atomic]                  = EBhDisablePartial;
+    extensionBehavior[GL_OES_shader_multisample_interpolation]     = EBhDisablePartial;
+    extensionBehavior[GL_OES_texture_storage_multisample_2d_array] = EBhDisablePartial;
+    extensionBehavior[GL_EXT_geometry_shader]                      = EBhDisablePartial;
+    extensionBehavior[GL_EXT_geometry_point_size]                  = EBhDisablePartial;
+    extensionBehavior[GL_EXT_gpu_shader5]                          = EBhDisablePartial;
+    extensionBehavior[GL_EXT_primitive_bounding_box]               = EBhDisablePartial;
+    extensionBehavior[GL_EXT_shader_io_blocks]                     = EBhDisablePartial;
+    extensionBehavior[GL_EXT_tessellation_shader]                  = EBhDisablePartial;
+    extensionBehavior[GL_EXT_tessellation_point_size]              = EBhDisablePartial;
+    extensionBehavior[GL_EXT_texture_buffer]                       = EBhDisablePartial;
+    extensionBehavior[GL_EXT_texture_cube_map_array]               = EBhDisablePartial;
 }
 
 // Get code that is not part of a shared symbol table, is specific to this shader,
@@ -187,6 +205,23 @@ const char* TParseContext::getPreamble()
             "#define GL_EXT_frag_depth 1\n"
             "#define GL_OES_EGL_image_external 1\n"
             "#define GL_EXT_shader_texture_lod 1\n"
+
+            // AEP
+            "#define GL_ANDROID_extension_pack_es31a 1\n"
+            "#define GL_KHR_blend_equation_advanced 1\n"
+            "#define GL_OES_sample_variables 1\n"
+            "#define GL_OES_shader_image_atomic 1\n"
+            "#define GL_OES_shader_multisample_interpolation 1\n"
+            "#define GL_OES_texture_storage_multisample_2d_array 1\n"
+            "#define GL_EXT_geometry_shader 1\n"
+            "#define GL_EXT_geometry_point_size 1\n"
+            "#define GL_EXT_gpu_shader5 1\n"
+            "#define GL_EXT_primitive_bounding_box 1\n"
+            "#define GL_EXT_shader_io_blocks 1\n"
+            "#define GL_EXT_tessellation_shader 1\n"
+            "#define GL_EXT_tessellation_point_size 1\n"
+            "#define GL_EXT_texture_buffer 1\n"
+            "#define GL_EXT_texture_cube_map_array 1\n"
             ;
     } else {
         return
@@ -196,6 +231,7 @@ const char* TParseContext::getPreamble()
             "#define GL_ARB_texture_gather 1\n"
             "#define GL_ARB_gpu_shader5 1\n"
             "#define GL_ARB_separate_shader_objects 1\n"
+            "#define GL_ARB_compute_shader 1\n"
             "#define GL_ARB_tessellation_shader 1\n"
             "#define GL_ARB_enhanced_layouts 1\n"
             "#define GL_ARB_texture_cube_map_array 1\n"
@@ -434,12 +470,36 @@ void TParseContext::updateExtensionBehavior(const char* extension, const char* b
         behavior = EBhDisable;
     else if (! strcmp("warn", behaviorString))
         behavior = EBhWarn;
-    else
-        error(getCurrentLoc(), "behavior not supported", "#extension", behaviorString);
+    else {
+        error(getCurrentLoc(), "behavior not supported:", "#extension", behaviorString);
+        return;
+    }
 
+    // update the requested extension
+    updateExtensionBehavior(extension, behavior);
+
+    // see if need to propagate to everything in AEP
+    if (strcmp(extension, "GL_ANDROID_extension_pack_es31a") == 0) {
+        updateExtensionBehavior("GL_KHR_blend_equation_advanced", behaviorString);
+        updateExtensionBehavior("GL_OES_sample_variables", behaviorString);
+        updateExtensionBehavior("GL_OES_shader_image_atomic", behaviorString);
+        updateExtensionBehavior("GL_OES_shader_multisample_interpolation", behaviorString);
+        updateExtensionBehavior("GL_OES_texture_storage_multisample_2d_array", behaviorString);
+        updateExtensionBehavior("GL_EXT_geometry_shader", behaviorString);
+        updateExtensionBehavior("GL_EXT_gpu_shader5", behaviorString);
+        updateExtensionBehavior("GL_EXT_primitive_bounding_box", behaviorString);
+        updateExtensionBehavior("GL_EXT_shader_io_blocks", behaviorString);
+        updateExtensionBehavior("GL_EXT_tessellation_shader", behaviorString);
+        updateExtensionBehavior("GL_EXT_texture_buffer", behaviorString);
+        updateExtensionBehavior("GL_EXT_texture_cube_map_array", behaviorString);
+    }
+}
+
+void TParseContext::updateExtensionBehavior(const char* extension, TExtensionBehavior behavior)
+{
     // Update the current behavior
     TMap<TString, TExtensionBehavior>::iterator iter;
-    if (! strcmp(extension, "all")) {
+    if (strcmp(extension, "all") == 0) {
         // special case for the 'all' extension; apply it to every extension present
         if (behavior == EBhRequire || behavior == EBhEnable) {
             error(getCurrentLoc(), "extension 'all' cannot have 'require' or 'enable' behavior", "#extension", "");
diff --git a/glslang/MachineIndependent/Versions.h b/glslang/MachineIndependent/Versions.h
index 6d0e63bd4..fddcd120c 100644
--- a/glslang/MachineIndependent/Versions.h
+++ b/glslang/MachineIndependent/Versions.h
@@ -85,6 +85,7 @@ const char* const GL_ARB_shading_language_420pack     = "GL_ARB_shading_language
 const char* const GL_ARB_texture_gather               = "GL_ARB_texture_gather";
 const char* const GL_ARB_gpu_shader5                  = "GL_ARB_gpu_shader5";
 const char* const GL_ARB_separate_shader_objects      = "GL_ARB_separate_shader_objects";
+const char* const GL_ARB_compute_shader               = "GL_ARB_compute_shader";
 const char* const GL_ARB_tessellation_shader          = "GL_ARB_tessellation_shader";
 const char* const GL_ARB_enhanced_layouts             = "GL_ARB_enhanced_layouts";
 const char* const GL_ARB_texture_cube_map_array       = "GL_ARB_texture_cube_map_array";
@@ -97,6 +98,23 @@ const char* const GL_ARB_shader_texture_image_samples = "GL_ARB_shader_texture_i
 const char* const GL_ARB_viewport_array               = "GL_ARB_viewport_array";
 //const char* const GL_ARB_cull_distance            = "GL_ARB_cull_distance";  // present for 4.5, but need extension control over block members
 
+// AEP
+const char* const GL_ANDROID_extension_pack_es31a             = "GL_ANDROID_extension_pack_es31a";
+const char* const GL_KHR_blend_equation_advanced              = "GL_KHR_blend_equation_advanced";
+const char* const GL_OES_sample_variables                     = "GL_OES_sample_variables";
+const char* const GL_OES_shader_image_atomic                  = "GL_OES_shader_image_atomic";
+const char* const GL_OES_shader_multisample_interpolation     = "GL_OES_shader_multisample_interpolation";
+const char* const GL_OES_texture_storage_multisample_2d_array = "GL_OES_texture_storage_multisample_2d_array";
+const char* const GL_EXT_geometry_shader                      = "GL_EXT_geometry_shader";
+const char* const GL_EXT_geometry_point_size                  = "GL_EXT_geometry_point_size";
+const char* const GL_EXT_gpu_shader5                          = "GL_EXT_gpu_shader5";
+const char* const GL_EXT_primitive_bounding_box               = "GL_EXT_primitive_bounding_box";
+const char* const GL_EXT_shader_io_blocks                     = "GL_EXT_shader_io_blocks";
+const char* const GL_EXT_tessellation_shader                  = "GL_EXT_tessellation_shader";
+const char* const GL_EXT_tessellation_point_size              = "GL_EXT_tessellation_point_size";
+const char* const GL_EXT_texture_buffer                       = "GL_EXT_texture_buffer";
+const char* const GL_EXT_texture_cube_map_array               = "GL_EXT_texture_cube_map_array";
+
 } // end namespace glslang
 
 #endif // _VERSIONS_INCLUDED_
-- 
GitLab