diff --git a/StandAlone.vcproj b/StandAlone.vcproj deleted file mode 100644 index 411a83c818156ac30c9c7570f4057c1fb359ffa7..0000000000000000000000000000000000000000 --- a/StandAlone.vcproj +++ /dev/null @@ -1,145 +0,0 @@ -<?xml version="1.0" encoding = "Windows-1252"?> -<VisualStudioProject - ProjectType="Visual C++" - Version="7.00" - Name="Tests - StandAlone" - ProjectGUID="{660D0A05-69A9-4F09-9664-02FBEB08FAE2}"> - <Platforms> - <Platform - Name="Win32"/> - </Platforms> - <Configurations> - <Configuration - Name="UserM_Debug|Win32" - OutputDirectory="UserM_Debug" - IntermediateDirectory="UserM_Debug" - ConfigurationType="1" - UseOfMFC="0" - ATLMinimizesCRunTimeLibraryUsage="FALSE" - CharacterSet="2"> - <Tool - Name="VCCLCompilerTool" - Optimization="0" - AdditionalIncludeDirectories="glslang" - PreprocessorDefinitions="WIN32,_DEBUG,_CONSOLE,GENERIC_COMPILER" - BasicRuntimeChecks="3" - RuntimeLibrary="5" - UsePrecompiledHeader="0" - PrecompiledHeaderFile="" - AssemblerListingLocation="UserM_Debug/" - ObjectFile="UserM_Debug/" - ProgramDataBaseFileName="UserM_Debug/Standalone" - WarningLevel="3" - SuppressStartupBanner="TRUE" - DebugInformationFormat="3" - CallingConvention="1"/> - <Tool - Name="VCCustomBuildTool"/> - <Tool - Name="VCLinkerTool" - AdditionalOptions="/MACHINE:I386" - AdditionalDependencies="odbc32.lib odbccp32.lib psapi.lib Standalone\glslang.lib" - OutputFile="UserM_Debug/StandAlone.exe" - LinkIncremental="2" - SuppressStartupBanner="TRUE" - IgnoreDefaultLibraryNames="" - GenerateDebugInformation="TRUE" - ProgramDatabaseFile="UserM_Debug/StandAlone.pdb" - SubSystem="1"/> - <Tool - Name="VCMIDLTool" - TypeLibraryName="UserM_Debug/StandAlone.tlb"/> - <Tool - Name="VCPostBuildEventTool" - Description="move exe" - CommandLine="xcopy /y UserM_Debug\StandAlone.exe Standalone"/> - <Tool - Name="VCPreBuildEventTool"/> - <Tool - Name="VCPreLinkEventTool"/> - <Tool - Name="VCResourceCompilerTool" - PreprocessorDefinitions="_DEBUG" - Culture="1033"/> - <Tool - Name="VCWebServiceProxyGeneratorTool"/> - <Tool - Name="VCWebDeploymentTool"/> - </Configuration> - <Configuration - Name="UserM_Release|Win32" - OutputDirectory="UserM_Release" - IntermediateDirectory="UserM_Release" - ConfigurationType="1" - UseOfMFC="0" - ATLMinimizesCRunTimeLibraryUsage="FALSE" - CharacterSet="2"> - <Tool - Name="VCCLCompilerTool" - Optimization="2" - InlineFunctionExpansion="1" - OmitFramePointers="TRUE" - AdditionalIncludeDirectories="glslang" - PreprocessorDefinitions="WIN32,NDEBUG,_CONSOLE,GENERIC_COMPILER" - StringPooling="TRUE" - BasicRuntimeChecks="0" - RuntimeLibrary="4" - BufferSecurityCheck="TRUE" - EnableFunctionLevelLinking="TRUE" - UsePrecompiledHeader="0" - PrecompiledHeaderFile="" - AssemblerListingLocation="UserM_Release/" - ObjectFile="UserM_Release/" - ProgramDataBaseFileName="UserM_Release/Standalone" - WarningLevel="3" - SuppressStartupBanner="TRUE" - DebugInformationFormat="3" - CallingConvention="1"/> - <Tool - Name="VCCustomBuildTool"/> - <Tool - Name="VCLinkerTool" - AdditionalOptions="/MACHINE:I386" - AdditionalDependencies="odbc32.lib odbccp32.lib psapi.lib Standalone\glslang.lib" - OutputFile="UserM_Release/StandAlone.exe" - LinkIncremental="1" - SuppressStartupBanner="TRUE" - IgnoreDefaultLibraryNames="" - GenerateDebugInformation="TRUE" - ProgramDatabaseFile="UserM_Release/StandAlone.pdb" - SubSystem="1" - OptimizeReferences="2" - EnableCOMDATFolding="2"/> - <Tool - Name="VCMIDLTool" - TypeLibraryName="UserM_Release/StandAlone.tlb"/> - <Tool - Name="VCPostBuildEventTool" - Description="move exe" - CommandLine="xcopy /y UserM_Release\StandAlone.exe Standalone"/> - <Tool - Name="VCPreBuildEventTool"/> - <Tool - Name="VCPreLinkEventTool"/> - <Tool - Name="VCResourceCompilerTool" - PreprocessorDefinitions="NDEBUG" - Culture="1033"/> - <Tool - Name="VCWebServiceProxyGeneratorTool"/> - <Tool - Name="VCWebDeploymentTool"/> - </Configuration> - </Configurations> - <Files> - <Filter - Name="Source Files" - Filter="cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"> - <File - RelativePath="Standalone\StandAlone.cpp"> - </File> - </Filter> - </Files> - <Globals> - </Globals> -</VisualStudioProject> diff --git a/StandAlone.vcxproj b/StandAlone.vcxproj new file mode 100644 index 0000000000000000000000000000000000000000..36eec5e6b8cd5c4d8e0a63c990d5f12debe7f157 --- /dev/null +++ b/StandAlone.vcxproj @@ -0,0 +1,151 @@ +<?xml version="1.0" encoding="utf-8"?> +<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> + <ItemGroup Label="ProjectConfigurations"> + <ProjectConfiguration Include="Debug|Win32"> + <Configuration>Debug</Configuration> + <Platform>Win32</Platform> + </ProjectConfiguration> + <ProjectConfiguration Include="Release|Win32"> + <Configuration>Release</Configuration> + <Platform>Win32</Platform> + </ProjectConfiguration> + </ItemGroup> + <PropertyGroup Label="Globals"> + <ProjectName>StandAlone</ProjectName> + <ProjectGuid>{660D0A05-69A9-4F09-9664-02FBEB08FAE2}</ProjectGuid> + </PropertyGroup> + <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> + <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> + <ConfigurationType>Application</ConfigurationType> + <UseOfMfc>false</UseOfMfc> + <CharacterSet>MultiByte</CharacterSet> + </PropertyGroup> + <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration"> + <ConfigurationType>Application</ConfigurationType> + <UseOfMfc>false</UseOfMfc> + <CharacterSet>MultiByte</CharacterSet> + </PropertyGroup> + <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" /> + <ImportGroup Label="ExtensionSettings"> + </ImportGroup> + <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="PropertySheets"> + <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> + </ImportGroup> + <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="PropertySheets"> + <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> + </ImportGroup> + <PropertyGroup Label="UserMacros" /> + <PropertyGroup> + <_ProjectFileVersion>10.0.30319.1</_ProjectFileVersion> + <OutDir Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">StandAlone\UserM_Debug\</OutDir> + <IntDir Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">StandAlone\UserM_Debug\</IntDir> + <LinkIncremental Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</LinkIncremental> + <OutDir Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">UserM_Release\</OutDir> + <IntDir Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">UserM_Release\</IntDir> + <LinkIncremental Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">false</LinkIncremental> + </PropertyGroup> + <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> + <ClCompile> + <Optimization>Disabled</Optimization> + <AdditionalIncludeDirectories>glslang;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> + <PreprocessorDefinitions>WIN32;_DEBUG;_CONSOLE;GENERIC_COMPILER;%(PreprocessorDefinitions)</PreprocessorDefinitions> + <BasicRuntimeChecks>EnableFastChecks</BasicRuntimeChecks> + <RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary> + <PrecompiledHeader> + </PrecompiledHeader> + <PrecompiledHeaderOutputFile> + </PrecompiledHeaderOutputFile> + <AssemblerListingLocation>$(IntDir)</AssemblerListingLocation> + <ObjectFileName>$(IntDir)</ObjectFileName> + <ProgramDataBaseFileName>$(IntDir)</ProgramDataBaseFileName> + <WarningLevel>Level3</WarningLevel> + <SuppressStartupBanner>true</SuppressStartupBanner> + <DebugInformationFormat>ProgramDatabase</DebugInformationFormat> + <CallingConvention>FastCall</CallingConvention> + </ClCompile> + <Link> + <AdditionalOptions>/MACHINE:I386 %(AdditionalOptions)</AdditionalOptions> + <AdditionalDependencies>odbc32.lib;odbccp32.lib;psapi.lib;UserM_Debug\generic\glslang.lib;%(AdditionalDependencies)</AdditionalDependencies> + <SuppressStartupBanner>true</SuppressStartupBanner> + <IgnoreSpecificDefaultLibraries>%(IgnoreSpecificDefaultLibraries)</IgnoreSpecificDefaultLibraries> + <GenerateDebugInformation>true</GenerateDebugInformation> + <ProgramDatabaseFile>UserM_Debug/StandAlone.pdb</ProgramDatabaseFile> + <SubSystem>Console</SubSystem> + </Link> + <Midl> + <TypeLibraryName>UserM_Debug/StandAlone.tlb</TypeLibraryName> + </Midl> + <PostBuildEvent> + <Message>move exe</Message> + <Command>xcopy /y StandAlone\UserM_Debug\StandAlone.exe Test</Command> + </PostBuildEvent> + <ResourceCompile> + <PreprocessorDefinitions>_DEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions> + <Culture>0x0409</Culture> + </ResourceCompile> + <PreLinkEvent> + <Command> + </Command> + </PreLinkEvent> + </ItemDefinitionGroup> + <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> + <ClCompile> + <Optimization>MaxSpeed</Optimization> + <InlineFunctionExpansion>OnlyExplicitInline</InlineFunctionExpansion> + <OmitFramePointers>true</OmitFramePointers> + <AdditionalIncludeDirectories>glslang;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> + <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;GENERIC_COMPILER;%(PreprocessorDefinitions)</PreprocessorDefinitions> + <StringPooling>true</StringPooling> + <BasicRuntimeChecks>Default</BasicRuntimeChecks> + <RuntimeLibrary>MultiThreaded</RuntimeLibrary> + <BufferSecurityCheck>true</BufferSecurityCheck> + <FunctionLevelLinking>true</FunctionLevelLinking> + <PrecompiledHeader> + </PrecompiledHeader> + <PrecompiledHeaderOutputFile> + </PrecompiledHeaderOutputFile> + <AssemblerListingLocation>UserM_Release/</AssemblerListingLocation> + <ObjectFileName>UserM_Release/</ObjectFileName> + <ProgramDataBaseFileName>UserM_Release/Standalone</ProgramDataBaseFileName> + <WarningLevel>Level3</WarningLevel> + <SuppressStartupBanner>true</SuppressStartupBanner> + <DebugInformationFormat>ProgramDatabase</DebugInformationFormat> + <CallingConvention>FastCall</CallingConvention> + </ClCompile> + <Link> + <AdditionalOptions>/MACHINE:I386 %(AdditionalOptions)</AdditionalOptions> + <AdditionalDependencies>odbc32.lib;odbccp32.lib;psapi.lib;Standalone\glslang.lib;%(AdditionalDependencies)</AdditionalDependencies> + <OutputFile>UserM_Release/StandAlone.exe</OutputFile> + <SuppressStartupBanner>true</SuppressStartupBanner> + <IgnoreSpecificDefaultLibraries>%(IgnoreSpecificDefaultLibraries)</IgnoreSpecificDefaultLibraries> + <GenerateDebugInformation>true</GenerateDebugInformation> + <ProgramDatabaseFile>UserM_Release/StandAlone.pdb</ProgramDatabaseFile> + <SubSystem>Console</SubSystem> + <OptimizeReferences>true</OptimizeReferences> + <EnableCOMDATFolding>true</EnableCOMDATFolding> + </Link> + <Midl> + <TypeLibraryName>UserM_Release/StandAlone.tlb</TypeLibraryName> + </Midl> + <PostBuildEvent> + <Message>move exe</Message> + <Command>xcopy /y StandAlone\UserM_Release\StandAlone.exe StandAlone</Command> + </PostBuildEvent> + <ResourceCompile> + <PreprocessorDefinitions>NDEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions> + <Culture>0x0409</Culture> + </ResourceCompile> + </ItemDefinitionGroup> + <ItemGroup> + <ClCompile Include="Standalone\StandAlone.cpp" /> + </ItemGroup> + <ItemGroup> + <ProjectReference Include="glslang.vcxproj"> + <Project>{3b146cc5-b2b8-4573-9d46-6139e2edfea3}</Project> + <ReferenceOutputAssembly>false</ReferenceOutputAssembly> + </ProjectReference> + </ItemGroup> + <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" /> + <ImportGroup Label="ExtensionTargets"> + </ImportGroup> +</Project> \ No newline at end of file diff --git a/StandAlone.vcxproj.filters b/StandAlone.vcxproj.filters new file mode 100644 index 0000000000000000000000000000000000000000..0685ca2f863b37dce84fc89b339f7a65ab799c50 --- /dev/null +++ b/StandAlone.vcxproj.filters @@ -0,0 +1,14 @@ +<?xml version="1.0" encoding="utf-8"?> +<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> + <ItemGroup> + <Filter Include="Source Files"> + <UniqueIdentifier>{fcd4a310-b19f-40bd-9324-e7d4e7d4dad1}</UniqueIdentifier> + <Extensions>cpp;c;cxx;rc;def;r;odl;idl;hpj;bat</Extensions> + </Filter> + </ItemGroup> + <ItemGroup> + <ClCompile Include="Standalone\StandAlone.cpp"> + <Filter>Source Files</Filter> + </ClCompile> + </ItemGroup> +</Project> \ No newline at end of file diff --git a/Test/run.bat b/Test/run.bat new file mode 100644 index 0000000000000000000000000000000000000000..2e4d5c178f43ea7be58c2a5b18c99c875b9f30a9 --- /dev/null +++ b/Test/run.bat @@ -0,0 +1,5 @@ +.\StandAlone.exe -i sample.vert > sample.vert.newout +diff sample.vert.out sample.vert.newout + +.\StandAlone.exe -i sample.frag > sample.frag.newout +diff sample.frag.out sample.frag.newout diff --git a/Test/runlist.bat b/Test/runlist.bat new file mode 100644 index 0000000000000000000000000000000000000000..8d68a4732a2353c10b5bd575575c3af44f5c5137 --- /dev/null +++ b/Test/runlist.bat @@ -0,0 +1 @@ +for /F "tokens=*" %%f in (testlist) do .\StandAlone.exe -i %%f diff --git a/StandAlone/sample.frag b/Test/sample.frag similarity index 95% rename from StandAlone/sample.frag rename to Test/sample.frag index 0d11cb2e4688b913683073ab9e68dc25703fbaf7..af3a6265be6fd66cd96778df1079b0215be066a9 100644 --- a/StandAlone/sample.frag +++ b/Test/sample.frag @@ -36,5 +36,5 @@ varying vec3 color; void main() { - gl_FragColor = vec4(color, 1.0); + gl_FragColor = vec4(color, 1.0f); } diff --git a/StandAlone/sample.frag.out b/Test/sample.frag.out similarity index 85% rename from StandAlone/sample.frag.out rename to Test/sample.frag.out index 5af223e4d04a31379c71795ee85203bc039c9442..ebc450cae958abe74202ba55f50317bd181ff126 100644 --- a/StandAlone/sample.frag.out +++ b/Test/sample.frag.out @@ -6,7 +6,7 @@ 0:39 move second child to first child (4-component vector of float) 0:39 'gl_FragColor' (FragColor 4-component vector of float) 0:39 Construct vec4 (4-component vector of float) -0:39 'color' (varying 3-component vector of float) +0:39 'color' (varying in 3-component vector of float) 0:39 1.000000 (const float) #### END COMPILER 0 INFO LOG #### diff --git a/StandAlone/sample.vert b/Test/sample.vert similarity index 100% rename from StandAlone/sample.vert rename to Test/sample.vert diff --git a/StandAlone/sample.vert.out b/Test/sample.vert.out similarity index 90% rename from StandAlone/sample.vert.out rename to Test/sample.vert.out index 2d50a82812dcd192ec8ae0f29860c4e2af492f67..ebb700d22b0e8478417433ceec65c01565d14b19 100644 --- a/StandAlone/sample.vert.out +++ b/Test/sample.vert.out @@ -4,7 +4,7 @@ 0:37 Function Parameters: 0:39 Sequence 0:39 move second child to first child (3-component vector of float) -0:39 'color' (varying 3-component vector of float) +0:39 'color' (varying out 3-component vector of float) 0:39 1.000000 (const float) 0:39 1.000000 (const float) 0:39 1.000000 (const float) diff --git a/Test/specExamples.frag b/Test/specExamples.frag new file mode 100644 index 0000000000000000000000000000000000000000..3da05f43789c82ada262ff79265484b4baab2b9e --- /dev/null +++ b/Test/specExamples.frag @@ -0,0 +1,237 @@ +#version 430 + +#extension GL_3DL_array_objects : enable + +int a = 0xffffffff; // 32 bits, a gets the value -1 +//int b = 0xffffffffU; // ERROR: can't convert uint to int +uint c = 0xffffffff; // 32 bits, c gets the value 0xFFFFFFFF +//uint d = 0xffffffffU; // 32 bits, d gets the value 0xFFFFFFFF +int e = -1; // the literal is “1”, then negation is performed, + // and the resulting non-literal 32-bit signed + // bit pattern of 0xFFFFFFFF is assigned, giving e + // the value of -1. +//uint f = -1u; // the literal is “1u”, then negation is performed, + // and the resulting non-literal 32-bit unsigned + // bit pattern of 0xFFFFFFFF is assigned, giving f + // the value of 0xFFFFFFFF. +int g = 3000000000; // a signed decimal literal taking 32 bits, + // setting the sign bit, g gets -1294967296 +int h = 0xA0000000; // okay, 32-bit signed hexadecimal +//int i = 5000000000; // ERROR: needs more than 32 bits +//int j = 0xFFFFFFFFF; // ERROR: needs more that 32 bits +int k = 0x80000000; // k gets -2147483648 == 0x80000000 +int l = 2147483648; // l gets -2147483648 (the literal set the sign bit) + +float fa, fb = 1.5; // single-precision floating-point +//double fc, fd = 2.0LF; // double-precision floating-point + +vec2 texcoord1, texcoord2; +vec3 position; +vec4 myRGBA; +ivec2 textureLookup; +bvec3 less; + +mat2 mat2D; +mat3 optMatrix; +mat4 view, projection; +mat4x4 view; // an alternate way of declaring a mat4 +mat3x2 m; // a matrix with 3 columns and 2 rows +dmat4 highPrecisionMVP; +dmat2x4 dm; + +struct light { + float intensity; + vec3 position; +} lightVar; + +struct S { float f; }; + +struct T { + //S; // Error: anonymous structures disallowed + //struct { ... }; // Error: embedded structures disallowed + S s; // Okay: nested structures with name are allowed +}; + +float frequencies[3]; +uniform vec4 lightPosition[4]; +light lights[]; +const int numLights = 2; +light lights[numLights]; + +in vec3 normal; +centroid in vec2 TexCoord; +invariant centroid in vec4 Color; +noperspective in float temperature; +flat in vec3 myColor; +noperspective centroid in vec2 myTexCoord; + +uniform vec4 lightPosition; +uniform vec3 color = vec3(0.7, 0.7, 0.2); // value assigned at link time + +in Material { + smooth in vec4 Color1; // legal, input inside in block + smooth vec4 Color2; // legal, 'in' inherited from 'in Material' + vec2 TexCoord; // legal, TexCoord is an input + uniform float Atten; // illegal, mismatched storage qualifier + +}; + +in Light { + vec4 LightPos; + vec3 LightColor; +}; +in ColoredTexture { + vec4 Color; + vec2 TexCoord; +} Material; // instance name +vec3 Color; // different Color than Material.Color + +in vec4 gl_FragCoord; // redeclaration that changes nothing is allowed + +// All the following are allowed redeclaration that change behavior +layout(origin_upper_left) in vec4 gl_FragCoord; +layout(pixel_center_integer) in vec4 gl_FragCoord; +layout(origin_upper_left, pixel_center_integer) in vec4 gl_FragCoord; + +layout(early_fragment_tests) in; + +// compute shader: +layout (local_size_x = 32, local_size_y = 32) in; +layout (local_size_x = 8) in; + +layout(location = 3) out vec4 color; +layout(location = 3, index = 1) out vec4 factor; +layout(location = 2) out vec4 colors[3]; + +layout (depth_greater) out float gl_FragDepth; + +// redeclaration that changes nothing is allowed +out float gl_FragDepth; + +// assume it may be modified in any way +layout (depth_any) out float gl_FragDepth; + +// assume it may be modified such that its value will only increase +layout (depth_greater) out float gl_FragDepth; + +// assume it may be modified such that its value will only decrease +layout (depth_less) out float gl_FragDepth; + +// assume it will not be modified +layout (depth_unchanged) out float gl_FragDepth; + +in vec4 gl_Color; // predeclared by the fragment language +flat in vec4 gl_Color; // redeclared by user to be flat + + +float[5] foo(float[5]) +{ + return float[5](3.4, 4.2, 5.0, 5.2, 1.1); +} + +precision highp float; +precision highp int; +precision mediump int; +precision highp float; + +void main() +{ + { + float a[5] = float[5](3.4, 4.2, 5.0, 5.2, 1.1); + } + { + float a[5] = float[](3.4, 4.2, 5.0, 5.2, 1.1); // same thing + } + { + vec4 a[3][2]; // size-3 array of size-2 array of vec4 + vec4[2] a1[3]; // size-3 array of size-2 array of vec4 + vec4[3][2] a2; // size-3 array of size-2 array of vec4 + vec4 b[2] = vec4[2](vec4(0.0), vec4(0.1)); + vec4[3][2] a3 = vec4[3][2](b, b, b); // constructor + void foo(vec4[3][2]); // prototype with unnamed parameter + vec4 a4[3][2] = {vec4[2](vec4(0.0), vec4(1.0)), + vec4[2](vec4(0.0), vec4(1.0)), + vec4[2](vec4(0.0), vec4(1.0)) }; + } + { + float a[5]; + { + float b[] = a; // b is explicitly size 5 + } + { + float b[5] = a; // means the same thing + } + { + float b[] = float[](1,2,3,4,5); // also explicitly sizes to 5 + } + a.length(); // returns 5 + } + { + vec4 a[3][2]; + a.length(); // this is 3 + a[x].length(); // this is 2 + } + // for an array b containing a member array a: + b[++x].a.length(); // b is never dereferenced, but “++x” is evaluated + + // for an array s of a shader storage object containing a member array a: + s[x].a.length(); // s is dereferenced; x needs to be a valid index + // + //All of the following declarations result in a compile-time error. + //float a[2] = { 3.4, 4.2, 5.0 }; // illegal + //vec2 b = { 1.0, 2.0, 3.0 }; // illegal + //mat3x3 c = { vec3(0.0), vec3(1.0), vec3(2.0), vec3(3.0) }; // illegal + //mat2x2 d = { 1.0, 0.0, 0.0, 1.0 }; // illegal, can't flatten nesting + //struct { + // float a; + // int b; + //} e = { 1.2, 2, 3 }; // illegal + + struct { + float a; + int b; + } e = { 1.2, 2 }; // legal, all types match + + struct { + float a; + int b; + } e = { 1, 3 }; // legal, first initializer is converted + + //All of the following declarations result in a compile-time error. + //int a = true; // illegal + //vec4 b[2] = { vec4(0.0), 1.0 }; // illegal + //mat4x2 c = { vec3(0.0), vec3(1.0) }; // illegal + + //struct S1 { + // vec4 a; + // vec4 b; + //}; + + //struct { + // float s; + // float t; + //} d[] = { S1(vec4(0.0), vec4(1.1)) }; // illegal + + { + float a[] = float[](3.4, 4.2, 5.0, 5.2, 1.1); + float b[] = { 3.4, 4.2, 5.0, 5.2, 1.1 }; + float c[] = a; // c is explicitly size 5 + float d[5] = b; // means the same thing + } + { + const vec3 zAxis = vec3 (0.0, 0.0, 1.0); + const float ceiling = a + b; // a and b not necessarily constants + } + { + in vec4 position; + in vec3 normal; + in vec2 texCoord[4]; + } + { + lowp float color; + out mediump vec2 P; + lowp ivec2 foo(lowp mat3); + highp mat4 m; + } + +} diff --git a/Test/specExamples.vert b/Test/specExamples.vert new file mode 100644 index 0000000000000000000000000000000000000000..555593079bcb5aef2f1e3fdb20654f9f5da10ae1 --- /dev/null +++ b/Test/specExamples.vert @@ -0,0 +1,196 @@ +#version 110 + +#extension GL_3DL_array_objects : enable + +out Vertex { + vec4 Position; // API transform/feedback will use “Vertex.Position” + vec2 Texture; +} Coords; // shader will use “Coords.Position” + +out Vertex2 { + vec4 Color; // API will use “Color” +}; + +uniform Transform { // API uses “Transform[2]” to refer to instance 2 + mat4 ModelViewMatrix; + mat4 ModelViewProjectionMatrix; + vec4 a[]; // array will get implicitly sized + float Deformation; +} transforms[4]; + +layout(location = 3) in vec4 normal; +layout(location = 6) in vec4 colors[3]; +layout(location = 9) in mat4 transforms[2]; + +layout(location = 3) struct S { + vec3 a; + mat2 b; + vec4 c[2]; +} s; + +layout(triangles, invocations = 6) in; + +layout(lines) in; // legal for Color2, input size is 2, matching Color2 + +layout(triangle_strip, max_vertices = 60) out; // order does not matter +layout(max_vertices = 60) out; // redeclaration okay +layout(triangle_strip) out; // redeclaration okay +//layout(points) out; // error, contradicts triangle_strip +//layout(max_vertices = 30) out; // error, contradicts 60 + +layout(stream = 1) out; + +layout(stream=1) out; // default is now stream 1 +out vec4 var1; // var1 gets default stream (1) +layout(stream=2) out Block1 { // "Block1" belongs to stream 2 + layout(stream=2) vec4 var2; // redundant block member stream decl + layout(stream=3) vec2 var3; // ILLEGAL (must match block stream) + vec3 var4; // belongs to stream 2 +}; +layout(stream=0) out; // default is now stream 0 +out vec4 var5; // var5 gets default stream (0) +out Block2 { // "Block2" gets default stream (0) + vec4 var6; +}; +layout(stream=3) out vec4 var7; // var7 belongs to stream 3 + +layout(shared, column_major) uniform; +layout(shared, column_major) buffer; + +layout(row_major, column_major) + +layout(shared, row_major) uniform; // default is now shared and row_major + +layout(std140) uniform Transform { // layout of this block is std140 + mat4 M1; // row_major + layout(column_major) mat4 M2; // column major + mat3 N1; // row_major +}; + +layout(column_major) uniform T3 { // shared and column_major + mat4 M3; // column_major + layout(row_major) mat4 m4; // row major + mat3 N2; // column_major +}; + +// in one compilation unit... +layout(binding=3) uniform sampler2D s; // s bound to unit 3 + +// in another compilation unit... +uniform sampler2D s; // okay, s still bound at 3 + +// in another compilation unit... +//layout(binding=4) uniform sampler2D s; // ERROR: contradictory bindings + +layout (binding = 2, offset = 4) uniform atomic_uint a; + +layout (binding = 2) uniform atomic_uint bar; + +layout (binding = 2, offset = 4) uniform atomic_uint; + +layout (binding = 2) uniform atomic_uint bar; // offset is 4 +layout (offset = 8) uniform atomic_uint bar; // error, no default binding + +layout (binding=3, offset=4) uniform atomic_uint a2; // offset = 4 +layout (binding=2) uniform atomic_uint b2; // offset = 0 +layout (binding=3) uniform atomic_uint c2; // offset = 8 +layout (binding=2) uniform atomic_uint d2; // offset = 4 + +//layout (offset=4) // error, must include binding +layout (binding=1, offset=0) a; // okay +layout (binding=2, offset=0) b; // okay +//layout (binding=1, offset=0) c; // error, offsets must not be shared +// // between a and c +//layout (binding=1, offset=2) d; // error, overlaps offset 0 of a + +flat in vec4 gl_FrontColor; // input to geometry shader, no “gl_in[]” +flat out vec4 gl_FrontColor; // output from geometry shader + +invariant gl_Position; // make existing gl_Position be invariant + +out vec3 Color; +invariant Color; // make existing Color be invariant + +invariant centroid out vec3 Color4; +precise out vec4 position; + +out vec3 Color5; +precise Color5; // make existing Color be precise +in vec4 a, b, c, d; +precise out vec4 v; + +coherent buffer Block { + readonly vec4 member1; + vec4 member2; +}; + +buffer Block { + coherent readonly vec4 member1; + coherent vec4 member2; +}; + +shared vec4 shv; + +vec4 funcA(restrict image2D a) { } + +vec4 funcB(image2D a) { } +layout(rgba32f) uniform image2D img1; +layout(rgba32f) coherent uniform image2D img2; + +float func(float e, float f, float g, float h) +{ + return (e*f) + (g*h); // no constraint on order or + // operator consistency +} + +float func2(float e, float f, float g, float h) +{ + precise float result = (e*f) + (g*h); // ensures same precision for + // the two multiplies + return result; +} + +float func3(float i, float j, precise out float k) +{ + k = i * i + j; // precise, due to <k> declaration +} + +void main() +{ + vec3 r = vec3(a * b); // precise, used to compute v.xyz + vec3 s = vec3(c * d); // precise, used to compute v.xyz + v.xyz = r + s; // precise + v.w = (a.w * b.w) + (c.w * d.w); // precise + v.x = func(a.x, b.x, c.x, d.x); // values computed in func() + // are NOT precise + v.x = func2(a.x, b.x, c.x, d.x); // precise! + func3(a.x * b.x, c.x * d.x, v.x); // precise! + + funcA(img1); // OK, adding "restrict" is allowed + funcB(img2); // illegal, stripping "coherent" is not + + { + struct light { + float intensity; + vec3 position; + }; + + light lightVar = light(3.0, vec3(1.0, 2.0, 3.0)); + } + { + const float c[3] = float[3](5.0, 7.2, 1.1); + const float d[3] = float[](5.0, 7.2, 1.1); + + float g; + float a[5] = float[5](g, 1, g, 2.3, g); + float b[3]; + + b = float[3](g, g + 1.0, g + 2.0); + } + { + vec4 b[2] = { vec4(1.0), vec4(1.0) }; + vec4[3][2](b, b, b); // constructor + vec4[][2](b, b, b); // constructor, valid, size deduced + vec4[3][](b, b, b); // compile-time error, invalid type constructed + } +} diff --git a/Test/versionsClean.frag b/Test/versionsClean.frag new file mode 100644 index 0000000000000000000000000000000000000000..187ffb6c4082502a556a989f2b8dc174e017928f --- /dev/null +++ b/Test/versionsClean.frag @@ -0,0 +1,45 @@ +// +//Copyright (C) 2012 LunarG, Inc. +//All rights reserved. +// +//Redistribution and use in source and binary forms, with or without +//modification, are permitted provided that the following conditions +//are met: +// +// Redistributions of source code must retain the above copyright +// notice, this list of conditions and the following disclaimer. +// +// Redistributions in binary form must reproduce the above +// copyright notice, this list of conditions and the following +// disclaimer in the documentation and/or other materials provided +// with the distribution. +// +// Neither the name of LunarG Inc. nor the names of its +// contributors may be used to endorse or promote products derived +// from this software without specific prior written permission. +// +//THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +//"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +//LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +//FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +//COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +//INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +//BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +//LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +//CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +//LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +//ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +//POSSIBILITY OF SUCH DAMAGE. +// +#version 300 es + +in vec3 color; +out vec4 foo; + +uniform sampler2DRect bar; + +void main() +{ + foo = vec4(color, 142.0f); + discard; +} diff --git a/Test/versionsClean.vert b/Test/versionsClean.vert new file mode 100644 index 0000000000000000000000000000000000000000..7c197857ac732b96d1a7edfa25c45cfbd1ce1689 --- /dev/null +++ b/Test/versionsClean.vert @@ -0,0 +1,43 @@ +// +//Copyright (C) 2012 LunarG, Inc. +//All rights reserved. +// +//Redistribution and use in source and binary forms, with or without +//modification, are permitted provided that the following conditions +//are met: +// +// Redistributions of source code must retain the above copyright +// notice, this list of conditions and the following disclaimer. +// +// Redistributions in binary form must reproduce the above +// copyright notice, this list of conditions and the following +// disclaimer in the documentation and/or other materials provided +// with the distribution. +// +// Neither the name of LunarG Inc. nor the names of its +// contributors may be used to endorse or promote products derived +// from this software without specific prior written permission. +// +//THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +//"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +//LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +//FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +//COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +//INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +//BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +//LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +//CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +//LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +//ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +//POSSIBILITY OF SUCH DAMAGE. +// +#version 420 compatibility + +attribute vec3 color; + +uniform sampler2DRect foo; + +void main() +{ + gl_Position = vec4(color, 142.0f); +} diff --git a/Test/versionsErrors.frag b/Test/versionsErrors.frag new file mode 100644 index 0000000000000000000000000000000000000000..021c7356bb0f05ef374029a6d80b853c36147796 --- /dev/null +++ b/Test/versionsErrors.frag @@ -0,0 +1,46 @@ +// +//Copyright (C) 2012 LunarG, Inc. +//All rights reserved. +// +//Redistribution and use in source and binary forms, with or without +//modification, are permitted provided that the following conditions +//are met: +// +// Redistributions of source code must retain the above copyright +// notice, this list of conditions and the following disclaimer. +// +// Redistributions in binary form must reproduce the above +// copyright notice, this list of conditions and the following +// disclaimer in the documentation and/or other materials provided +// with the distribution. +// +// Neither the name of LunarG Inc. nor the names of its +// contributors may be used to endorse or promote products derived +// from this software without specific prior written permission. +// +//THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +//"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +//LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +//FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +//COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +//INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +//BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +//LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +//CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +//LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +//ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +//POSSIBILITY OF SUCH DAMAGE. +// +#version 110 es + +#extension GL_ARB_texture_rectangle : disable + +attribute vec3 color; + +uniform sampler2DRect foo; + +void main() +{ + gl_FragColor = vec4(color, 142.0f); + discard; +} diff --git a/Test/versionsErrors.vert b/Test/versionsErrors.vert new file mode 100644 index 0000000000000000000000000000000000000000..8736f2e792d7d78c0329a69920c96cea043fdc19 --- /dev/null +++ b/Test/versionsErrors.vert @@ -0,0 +1,46 @@ +// +//Copyright (C) 2012 LunarG, Inc. +//All rights reserved. +// +//Redistribution and use in source and binary forms, with or without +//modification, are permitted provided that the following conditions +//are met: +// +// Redistributions of source code must retain the above copyright +// notice, this list of conditions and the following disclaimer. +// +// Redistributions in binary form must reproduce the above +// copyright notice, this list of conditions and the following +// disclaimer in the documentation and/or other materials provided +// with the distribution. +// +// Neither the name of LunarG Inc. nor the names of its +// contributors may be used to endorse or promote products derived +// from this software without specific prior written permission. +// +//THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +//"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +//LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +//FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +//COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +//INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +//BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +//LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +//CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +//LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +//ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +//POSSIBILITY OF SUCH DAMAGE. +// +#version 420 core + +#extension GL_ARB_texture_rectangle : enable + +attribute vec3 color; + +uniform sampler2DRect foo; + +void main() +{ + gl_Position = vec4(color, 142.0f); + discard; +} diff --git a/Todo.txt b/Todo.txt new file mode 100644 index 0000000000000000000000000000000000000000..8d003d695cf7f06f58101c02e9f1e31d2670271f --- /dev/null +++ b/Todo.txt @@ -0,0 +1,16 @@ +Minor "to do" items are identified in the source code with "TODO..." comments. + +Major items to do: + +* Use the new versioning infrastructure to identify all errors specific to + - profile + - extension + - version + - stage + +* Add semantics for all new grammar (1.2 through 4.3) + +* Replace the preprocessor with a better one. + +* Verify/fix thread safety of the parse context. + diff --git a/glslang.vcproj b/glslang.vcproj deleted file mode 100644 index a1fdc9a66a86a0f6fb2afecb11ce30d72db26cfe..0000000000000000000000000000000000000000 --- a/glslang.vcproj +++ /dev/null @@ -1,436 +0,0 @@ -<?xml version="1.0" encoding = "Windows-1252"?> -<VisualStudioProject - ProjectType="Visual C++" - Version="7.00" - Name="Targets - glslang (generic)" - ProjectGUID="{3B146CC5-B2B8-4573-9D46-6139E2EDFEA3}"> - <Platforms> - <Platform - Name="Win32"/> - </Platforms> - <Configurations> - <Configuration - Name="UserM_Debug|Win32" - OutputDirectory="UserM_Debug" - IntermediateDirectory="UserM_Debug" - ConfigurationType="2" - UseOfMFC="0" - ATLMinimizesCRunTimeLibraryUsage="FALSE" - CharacterSet="2"> - <Tool - Name="VCCLCompilerTool" - Optimization="0" - AdditionalIncludeDirectories="glslang;glslang\MachineIndependent;glslang\OSDependent\Windows;OGLCompilersDLL" - PreprocessorDefinitions="_DEBUG,WIN32,_CONSOLE,_USRDLL,TEST_EXPORTS,GENERIC_COMPILER" - MinimalRebuild="FALSE" - BasicRuntimeChecks="3" - RuntimeLibrary="3" - PrecompiledHeaderFile="" - AssemblerListingLocation="UserM_Debug/" - ObjectFile="UserM_Debug/" - ProgramDataBaseFileName="UserM_Debug/glslang" - BrowseInformation="0" - WarningLevel="3" - SuppressStartupBanner="TRUE" - DebugInformationFormat="3" - CallingConvention="1" - CompileAs="0"/> - <Tool - Name="VCCustomBuildTool"/> - <Tool - Name="VCLinkerTool" - AdditionalOptions="/MACHINE:I386" - AdditionalDependencies="odbc32.lib odbccp32.lib" - OutputFile="UserM_Debug/generic/glslang.dll" - LinkIncremental="2" - SuppressStartupBanner="TRUE" - IgnoreDefaultLibraryNames="libcmtd.lib;libcd.lib;libcmt.lib;libcmt.lib" - GenerateDebugInformation="TRUE" - ProgramDatabaseFile="UserM_Debug/glslang.pdb" - SubSystem="1" - ImportLibrary="UserM_Debug/generic/glslang.lib"/> - <Tool - Name="VCMIDLTool" - TypeLibraryName="UserM_Debug/generic/glslang.tlb"/> - <Tool - Name="VCPostBuildEventTool" - Description="copy dll" - CommandLine="xcopy /y UserM_Debug\generic\glslang.* standalone"/> - <Tool - Name="VCPreBuildEventTool"/> - <Tool - Name="VCPreLinkEventTool"/> - <Tool - Name="VCResourceCompilerTool" - PreprocessorDefinitions="_DEBUG" - Culture="2057"/> - <Tool - Name="VCWebServiceProxyGeneratorTool"/> - <Tool - Name="VCWebDeploymentTool"/> - </Configuration> - <Configuration - Name="UserM_Release|Win32" - OutputDirectory="UserM_Release" - IntermediateDirectory="UserM_Release" - ConfigurationType="2" - UseOfMFC="0" - ATLMinimizesCRunTimeLibraryUsage="FALSE" - CharacterSet="2"> - <Tool - Name="VCCLCompilerTool" - Optimization="2" - InlineFunctionExpansion="1" - OmitFramePointers="TRUE" - AdditionalIncludeDirectories="glslang;glslang\MachineIndependent;glslang\OSDependent\Windows;OGLCompilersDLL" - PreprocessorDefinitions="NDEBUG,WIN32,_CONSOLE,_USRDLL,TEST_EXPORTS,GENERIC_COMPILER" - StringPooling="TRUE" - MinimalRebuild="FALSE" - BasicRuntimeChecks="0" - RuntimeLibrary="2" - BufferSecurityCheck="TRUE" - EnableFunctionLevelLinking="TRUE" - PrecompiledHeaderFile="" - AssemblerListingLocation="UserM_Release/" - ObjectFile="UserM_Release/" - ProgramDataBaseFileName="UserM_Release/glslang" - BrowseInformation="0" - WarningLevel="3" - SuppressStartupBanner="TRUE" - DebugInformationFormat="3" - CallingConvention="1" - CompileAs="0"/> - <Tool - Name="VCCustomBuildTool"/> - <Tool - Name="VCLinkerTool" - AdditionalOptions="/MACHINE:I386" - AdditionalDependencies="odbc32.lib odbccp32.lib" - OutputFile="UserM_Release/generic/glslang.dll" - LinkIncremental="1" - SuppressStartupBanner="TRUE" - IgnoreDefaultLibraryNames="libcmtd.lib;libcd.lib;libcmt.lib;" - GenerateDebugInformation="TRUE" - ProgramDatabaseFile="UserM_Release/generic/glslang.pdb" - SubSystem="1" - OptimizeReferences="2" - EnableCOMDATFolding="2" - ImportLibrary="UserM_Release/generic/glslang.lib"/> - <Tool - Name="VCMIDLTool" - TypeLibraryName="UserM_Release/generic/glslang.tlb"/> - <Tool - Name="VCPostBuildEventTool" - Description="copy dll" - CommandLine="xcopy /y UserM_Release\generic\glslang.* standalone"/> - <Tool - Name="VCPreBuildEventTool"/> - <Tool - Name="VCPreLinkEventTool"/> - <Tool - Name="VCResourceCompilerTool" - PreprocessorDefinitions="NDEBUG" - Culture="2057"/> - <Tool - Name="VCWebServiceProxyGeneratorTool"/> - <Tool - Name="VCWebDeploymentTool"/> - </Configuration> - </Configurations> - <Files> - <Filter - Name="Machine Independent" - Filter="cpp;c;cxx;rc;def;r;odl;idl;hpj;bat;y;l"> - <File - RelativePath="glslang\MachineIndependent\InfoSink.cpp"> - </File> - <File - RelativePath="glslang\MachineIndependent\Initialize.cpp"> - </File> - <File - RelativePath="glslang\MachineIndependent\Initialize.h"> - </File> - <File - RelativePath="OGLCompilersDLL\InitializeDll.cpp"> - </File> - <File - RelativePath="glslang\MachineIndependent\IntermTraverse.cpp"> - </File> - <File - RelativePath="glslang\MachineIndependent\Intermediate.cpp"> - </File> - <File - RelativePath="glslang\MachineIndependent\MMap.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\ParseHelper.cpp"> - </File> - <File - RelativePath="glslang\MachineIndependent\ParseHelper.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\PoolAlloc.cpp"> - </File> - <File - RelativePath="glslang\MachineIndependent\QualifierAlive.cpp"> - </File> - <File - RelativePath="glslang\MachineIndependent\QualifierAlive.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\RemoveTree.cpp"> - </File> - <File - RelativePath="glslang\MachineIndependent\RemoveTree.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\ShaderLang.cpp"> - </File> - <File - RelativePath="glslang\MachineIndependent\SymbolTable.cpp"> - </File> - <File - RelativePath="glslang\MachineIndependent\glslang.l"> - <FileConfiguration - Name="UserM_Debug|Win32"> - <Tool - Name="VCCustomBuildTool" - Description="Executing flex on $(InputPath)" - CommandLine="$(InputDir)..\..\tools\flex.exe $(InputPath) -if EXIST $(InputDir)gen_glslang.cpp del $(InputDir)gen_glslang.cpp -move gen_glslang.cpp $(InputDir)gen_glslang.cpp -cd $(InputDir) -rename gen_glslang.cpp Gen_glslang.cpp -" - AdditionalDependencies="glslang_tab.h" - Outputs="$(InputDir)Gen_glslang.cpp"/> - </FileConfiguration> - <FileConfiguration - Name="UserM_Release|Win32"> - <Tool - Name="VCCustomBuildTool" - Description="Executing flex on $(InputPath)" - CommandLine="$(InputDir)..\..\tools\flex.exe $(InputPath) -if EXIST $(InputDir)gen_glslang.cpp del $(InputDir)gen_glslang.cpp -move gen_glslang.cpp $(InputDir)gen_glslang.cpp -" - AdditionalDependencies="glslang_tab.h" - Outputs="$(InputDir)Gen_glslang.cpp"/> - </FileConfiguration> - </File> - <File - RelativePath="glslang\MachineIndependent\glslang.y"> - <FileConfiguration - Name="UserM_Debug|Win32"> - <Tool - Name="VCCustomBuildTool" - Description="Executing Bison on $(InputPath)" - CommandLine="SET BISON_SIMPLE=$(InputDir)..\..\tools\bison.simple -SET BISON_HAIRY=$(InputDir)..\..\tools\bison.simple -cd $(InputDir) -$(InputDir)..\..\tools\bison.exe -d -t -v $(InputName).y -if EXIST $(InputDir)Gen_$(InputName)_tab.cpp del $(InputDir)Gen_$(InputName)_tab.cpp -rename $(InputDir)$(InputName)_tab.c Gen_$(InputName)_tab.cpp -" - Outputs="$(InputDir)Gen_$(InputName)_tab.cpp"/> - </FileConfiguration> - <FileConfiguration - Name="UserM_Release|Win32"> - <Tool - Name="VCCustomBuildTool" - Description="Executing Bison on $(InputPath)" - CommandLine="SET BISON_SIMPLE=$(InputDir)..\..\tools\bison.simple -SET BISON_HAIRY=$(InputDir)..\..\tools\bison.simple -cd $(InputDir) -$(InputDir)..\..\tools\bison.exe -d -t -v $(InputName).y -if EXIST $(InputDir)Gen_$(InputName)_tab.cpp del $(InputDir)Gen_$(InputName)_tab.cpp -rename $(InputDir)$(InputName)_tab.c Gen_$(InputName)_tab.cpp -" - Outputs="$(InputDir)Gen_$(InputName)_tab.cpp"/> - </FileConfiguration> - </File> - <File - RelativePath="glslang\MachineIndependent\intermOut.cpp"> - </File> - <File - RelativePath="glslang\MachineIndependent\localintermediate.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\parseConst.cpp"> - </File> - <Filter - Name="Generated Source" - Filter=""> - <File - RelativePath="glslang\MachineIndependent\Gen_glslang.cpp"> - </File> - <File - RelativePath="glslang\MachineIndependent\Gen_glslang_tab.cpp"> - </File> - <File - RelativePath="glslang\MachineIndependent\glslang_tab.h"> - </File> - </Filter> - <Filter - Name="CPP" - Filter=""> - <File - RelativePath="glslang\MachineIndependent\preprocessor\atom.c"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\atom.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\compile.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\cpp.c"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\cpp.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\cppstruct.c"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\memory.c"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\memory.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\parser.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\preprocess.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\scanner.c"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\scanner.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\slglobals.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\symbols.c"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\symbols.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\tokens.c"> - </File> - <File - RelativePath="glslang\MachineIndependent\preprocessor\tokens.h"> - </File> - </Filter> - </Filter> - <Filter - Name="Header Files"> - <File - RelativePath="glslang\Include\BaseTypes.h"> - </File> - <File - RelativePath="glslang\Include\Common.h"> - </File> - <File - RelativePath="glslang\Include\ConstantUnion.h"> - </File> - <File - RelativePath="glslang\Include\InfoSink.h"> - </File> - <File - RelativePath="OGLCompilersDLL\InitializeDll.h"> - </File> - <File - RelativePath="glslang\Include\InitializeGlobals.h"> - </File> - <File - RelativePath="glslang\Include\InitializeParseContext.h"> - </File> - <File - RelativePath="glslang\Include\PoolAlloc.h"> - </File> - <File - RelativePath="glslang\Include\ResourceLimits.h"> - </File> - <File - RelativePath="glslang\Include\ShHandle.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\SymbolTable.h"> - </File> - <File - RelativePath="glslang\Include\Types.h"> - </File> - <File - RelativePath="glslang\Include\intermediate.h"> - </File> - <File - RelativePath="glslang\MachineIndependent\unistd.h"> - </File> - </Filter> - <Filter - Name="Public" - Filter=""> - <File - RelativePath="glslang\Public\ShaderLang.h"> - </File> - </Filter> - <Filter - Name="Generic Code Gen" - Filter=""> - <File - RelativePath="glslang\GenericCodeGen\CodeGen.cpp"> - </File> - <File - RelativePath="glslang\GenericCodeGen\Link.cpp"> - </File> - </Filter> - <Filter - Name="OSDependent" - Filter=""> - <Filter - Name="Windows" - Filter=""> - <File - RelativePath="glslang\OSDependent\Windows\main.cpp"> - </File> - <File - RelativePath="glslang\OSDependent\Windows\osinclude.h"> - </File> - <File - RelativePath="glslang\OSDependent\Windows\ossource.cpp"> - </File> - </Filter> - <Filter - Name="Linux" - Filter=""> - <File - RelativePath="glslang\OSDependent\Linux\osinclude.h"> - </File> - <File - RelativePath="glslang\OSDependent\Linux\ossource.cpp"> - <FileConfiguration - Name="UserM_Debug|Win32" - ExcludedFromBuild="TRUE"> - <Tool - Name="VCCLCompilerTool" - ObjectFile="$(IntDir)/$(InputName)1.obj"/> - </FileConfiguration> - <FileConfiguration - Name="UserM_Release|Win32" - ExcludedFromBuild="TRUE"> - <Tool - Name="VCCLCompilerTool" - ObjectFile="$(IntDir)/$(InputName)1.obj"/> - </FileConfiguration> - </File> - </Filter> - </Filter> - </Files> - <Globals> - </Globals> -</VisualStudioProject> diff --git a/glslang.vcxproj b/glslang.vcxproj new file mode 100644 index 0000000000000000000000000000000000000000..555ddf1e34cc73ef272fd6cf351fc8e419848e6f --- /dev/null +++ b/glslang.vcxproj @@ -0,0 +1,250 @@ +<?xml version="1.0" encoding="utf-8"?> +<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> + <ItemGroup Label="ProjectConfigurations"> + <ProjectConfiguration Include="Debug|Win32"> + <Configuration>Debug</Configuration> + <Platform>Win32</Platform> + </ProjectConfiguration> + <ProjectConfiguration Include="Release|Win32"> + <Configuration>Release</Configuration> + <Platform>Win32</Platform> + </ProjectConfiguration> + </ItemGroup> + <PropertyGroup Label="Globals"> + <ProjectName>glslang</ProjectName> + <ProjectGuid>{3B146CC5-B2B8-4573-9D46-6139E2EDFEA3}</ProjectGuid> + </PropertyGroup> + <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> + <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> + <ConfigurationType>DynamicLibrary</ConfigurationType> + <UseOfMfc>false</UseOfMfc> + <CharacterSet>MultiByte</CharacterSet> + </PropertyGroup> + <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration"> + <ConfigurationType>DynamicLibrary</ConfigurationType> + <UseOfMfc>false</UseOfMfc> + <CharacterSet>MultiByte</CharacterSet> + </PropertyGroup> + <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" /> + <ImportGroup Label="ExtensionSettings"> + </ImportGroup> + <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="PropertySheets"> + <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> + </ImportGroup> + <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="PropertySheets"> + <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> + </ImportGroup> + <PropertyGroup Label="UserMacros" /> + <PropertyGroup> + <_ProjectFileVersion>10.0.30319.1</_ProjectFileVersion> + <OutDir Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">glslang\UserM_Debug\</OutDir> + <IntDir Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">glslang\UserM_Debug\</IntDir> + <LinkIncremental Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">false</LinkIncremental> + <OutDir Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">UserM_Release\</OutDir> + <IntDir Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">UserM_Release\</IntDir> + <LinkIncremental Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">false</LinkIncremental> + </PropertyGroup> + <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> + <ClCompile> + <Optimization>Disabled</Optimization> + <AdditionalIncludeDirectories>glslang;glslang\MachineIndependent;glslang\OSDependent\Windows;OGLCompilersDLL;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> + <PreprocessorDefinitions>_DEBUG;WIN32;_CONSOLE;_USRDLL;TEST_EXPORTS;GENERIC_COMPILER;%(PreprocessorDefinitions)</PreprocessorDefinitions> + <MinimalRebuild>false</MinimalRebuild> + <BasicRuntimeChecks>EnableFastChecks</BasicRuntimeChecks> + <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> + <PrecompiledHeaderOutputFile> + </PrecompiledHeaderOutputFile> + <AssemblerListingLocation>$(IntDir)</AssemblerListingLocation> + <ObjectFileName>$(IntDir)</ObjectFileName> + <ProgramDataBaseFileName>$(IntDir)</ProgramDataBaseFileName> + <BrowseInformation> + </BrowseInformation> + <WarningLevel>Level3</WarningLevel> + <SuppressStartupBanner>true</SuppressStartupBanner> + <DebugInformationFormat>ProgramDatabase</DebugInformationFormat> + <CallingConvention>FastCall</CallingConvention> + <CompileAs>Default</CompileAs> + </ClCompile> + <Link> + <AdditionalOptions>/MACHINE:I386 %(AdditionalOptions)</AdditionalOptions> + <AdditionalDependencies>odbc32.lib;odbccp32.lib;%(AdditionalDependencies)</AdditionalDependencies> + <SuppressStartupBanner>false</SuppressStartupBanner> + <IgnoreSpecificDefaultLibraries>libcmtd.lib;libcd.lib;libcmt.lib;libcmt.lib;%(IgnoreSpecificDefaultLibraries)</IgnoreSpecificDefaultLibraries> + <GenerateDebugInformation>true</GenerateDebugInformation> + <ProgramDatabaseFile>UserM_Debug/glslang.pdb</ProgramDatabaseFile> + <SubSystem>Console</SubSystem> + <ImportLibrary>UserM_Debug/generic/glslang.lib</ImportLibrary> + <OutputFile>$(IntDir)$(TargetName)$(TargetExt)</OutputFile> + </Link> + <Midl> + <TypeLibraryName>UserM_Debug/generic/glslang.tlb</TypeLibraryName> + </Midl> + <PostBuildEvent> + <Message>copy dll</Message> + <Command>del Test\$(TargetName)$(TargetExt) +xcopy /y $(IntDir)$(TargetName)$(TargetExt) Test</Command> + </PostBuildEvent> + <ResourceCompile> + <PreprocessorDefinitions>_DEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions> + <Culture>0x0809</Culture> + </ResourceCompile> + </ItemDefinitionGroup> + <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> + <ClCompile> + <Optimization>MaxSpeed</Optimization> + <InlineFunctionExpansion>OnlyExplicitInline</InlineFunctionExpansion> + <OmitFramePointers>true</OmitFramePointers> + <AdditionalIncludeDirectories>glslang;glslang\MachineIndependent;glslang\OSDependent\Windows;OGLCompilersDLL;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> + <PreprocessorDefinitions>NDEBUG;WIN32;_CONSOLE;_USRDLL;TEST_EXPORTS;GENERIC_COMPILER;%(PreprocessorDefinitions)</PreprocessorDefinitions> + <StringPooling>true</StringPooling> + <MinimalRebuild>false</MinimalRebuild> + <BasicRuntimeChecks>Default</BasicRuntimeChecks> + <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> + <BufferSecurityCheck>true</BufferSecurityCheck> + <FunctionLevelLinking>true</FunctionLevelLinking> + <PrecompiledHeaderOutputFile> + </PrecompiledHeaderOutputFile> + <AssemblerListingLocation>UserM_Release/</AssemblerListingLocation> + <ObjectFileName>UserM_Release/</ObjectFileName> + <ProgramDataBaseFileName>UserM_Release/glslang</ProgramDataBaseFileName> + <BrowseInformation> + </BrowseInformation> + <WarningLevel>Level3</WarningLevel> + <SuppressStartupBanner>true</SuppressStartupBanner> + <DebugInformationFormat>ProgramDatabase</DebugInformationFormat> + <CallingConvention>FastCall</CallingConvention> + <CompileAs>Default</CompileAs> + </ClCompile> + <Link> + <AdditionalOptions>/MACHINE:I386 %(AdditionalOptions)</AdditionalOptions> + <AdditionalDependencies>odbc32.lib;odbccp32.lib;%(AdditionalDependencies)</AdditionalDependencies> + <OutputFile>UserM_Release/generic/glslang.dll</OutputFile> + <SuppressStartupBanner>true</SuppressStartupBanner> + <IgnoreSpecificDefaultLibraries>libcmtd.lib;libcd.lib;libcmt.lib;%(IgnoreSpecificDefaultLibraries)</IgnoreSpecificDefaultLibraries> + <GenerateDebugInformation>true</GenerateDebugInformation> + <ProgramDatabaseFile>UserM_Release/generic/glslang.pdb</ProgramDatabaseFile> + <SubSystem>Console</SubSystem> + <OptimizeReferences>true</OptimizeReferences> + <EnableCOMDATFolding>true</EnableCOMDATFolding> + <ImportLibrary>UserM_Release/generic/glslang.lib</ImportLibrary> + </Link> + <Midl> + <TypeLibraryName>UserM_Release/generic/glslang.tlb</TypeLibraryName> + </Midl> + <PostBuildEvent> + <Message>copy dll</Message> + <Command>xcopy /y UserM_Release\generic\glslang.* StandAlone</Command> + </PostBuildEvent> + <ResourceCompile> + <PreprocessorDefinitions>NDEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions> + <Culture>0x0809</Culture> + </ResourceCompile> + </ItemDefinitionGroup> + <ItemGroup> + <ClCompile Include="glslang\MachineIndependent\gen_glslang.cpp" /> + <ClCompile Include="glslang\MachineIndependent\glslang_tab.cpp" /> + <ClCompile Include="glslang\MachineIndependent\InfoSink.cpp" /> + <ClCompile Include="glslang\MachineIndependent\Initialize.cpp" /> + <ClCompile Include="glslang\MachineIndependent\Versions.cpp" /> + <ClCompile Include="OGLCompilersDLL\InitializeDll.cpp" /> + <ClCompile Include="glslang\MachineIndependent\IntermTraverse.cpp" /> + <ClCompile Include="glslang\MachineIndependent\Intermediate.cpp" /> + <ClCompile Include="glslang\MachineIndependent\ParseHelper.cpp" /> + <ClCompile Include="glslang\MachineIndependent\PoolAlloc.cpp" /> + <ClCompile Include="glslang\MachineIndependent\QualifierAlive.cpp" /> + <ClCompile Include="glslang\MachineIndependent\RemoveTree.cpp" /> + <ClCompile Include="glslang\MachineIndependent\ShaderLang.cpp" /> + <ClCompile Include="glslang\MachineIndependent\SymbolTable.cpp" /> + <ClCompile Include="glslang\MachineIndependent\intermOut.cpp" /> + <ClCompile Include="glslang\MachineIndependent\parseConst.cpp" /> + <ClCompile Include="glslang\MachineIndependent\preprocessor\atom.c" /> + <ClCompile Include="glslang\MachineIndependent\preprocessor\cpp.c" /> + <ClCompile Include="glslang\MachineIndependent\preprocessor\cppstruct.c" /> + <ClCompile Include="glslang\MachineIndependent\preprocessor\memory.c" /> + <ClCompile Include="glslang\MachineIndependent\preprocessor\scanner.c" /> + <ClCompile Include="glslang\MachineIndependent\preprocessor\symbols.c" /> + <ClCompile Include="glslang\MachineIndependent\preprocessor\tokens.c" /> + <ClCompile Include="glslang\GenericCodeGen\CodeGen.cpp" /> + <ClCompile Include="glslang\GenericCodeGen\Link.cpp" /> + <ClCompile Include="glslang\OSDependent\Windows\main.cpp" /> + <ClCompile Include="glslang\OSDependent\Windows\ossource.cpp" /> + <ClCompile Include="glslang\OSDependent\Linux\ossource.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> + <ObjectFileName Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">$(IntDir)%(Filename)1.obj</ObjectFileName> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> + <ObjectFileName Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">$(IntDir)%(Filename)1.obj</ObjectFileName> + </ClCompile> + </ItemGroup> + <ItemGroup> + <ClInclude Include="glslang\MachineIndependent\glslang_tab.cpp.h" /> + <ClInclude Include="glslang\MachineIndependent\Initialize.h" /> + <ClInclude Include="glslang\MachineIndependent\MMap.h" /> + <ClInclude Include="glslang\MachineIndependent\ParseHelper.h" /> + <ClInclude Include="glslang\MachineIndependent\QualifierAlive.h" /> + <ClInclude Include="glslang\MachineIndependent\RemoveTree.h" /> + <ClInclude Include="glslang\MachineIndependent\localintermediate.h" /> + <ClInclude Include="glslang\MachineIndependent\preprocessor\atom.h" /> + <ClInclude Include="glslang\MachineIndependent\preprocessor\compile.h" /> + <ClInclude Include="glslang\MachineIndependent\preprocessor\cpp.h" /> + <ClInclude Include="glslang\MachineIndependent\preprocessor\memory.h" /> + <ClInclude Include="glslang\MachineIndependent\preprocessor\parser.h" /> + <ClInclude Include="glslang\MachineIndependent\preprocessor\preprocess.h" /> + <ClInclude Include="glslang\MachineIndependent\preprocessor\scanner.h" /> + <ClInclude Include="glslang\MachineIndependent\preprocessor\slglobals.h" /> + <ClInclude Include="glslang\MachineIndependent\preprocessor\symbols.h" /> + <ClInclude Include="glslang\MachineIndependent\preprocessor\tokens.h" /> + <ClInclude Include="glslang\Include\BaseTypes.h" /> + <ClInclude Include="glslang\Include\Common.h" /> + <ClInclude Include="glslang\Include\ConstantUnion.h" /> + <ClInclude Include="glslang\Include\InfoSink.h" /> + <ClInclude Include="glslang\MachineIndependent\Versions.h" /> + <ClInclude Include="OGLCompilersDLL\InitializeDll.h" /> + <ClInclude Include="glslang\Include\InitializeGlobals.h" /> + <ClInclude Include="glslang\Include\InitializeParseContext.h" /> + <ClInclude Include="glslang\Include\PoolAlloc.h" /> + <ClInclude Include="glslang\Include\ResourceLimits.h" /> + <ClInclude Include="glslang\Include\ShHandle.h" /> + <ClInclude Include="glslang\MachineIndependent\SymbolTable.h" /> + <ClInclude Include="glslang\Include\Types.h" /> + <ClInclude Include="glslang\Include\intermediate.h" /> + <ClInclude Include="glslang\MachineIndependent\unistd.h" /> + <ClInclude Include="glslang\Public\ShaderLang.h" /> + <ClInclude Include="glslang\OSDependent\Windows\osinclude.h" /> + <ClInclude Include="glslang\OSDependent\Linux\osinclude.h" /> + </ItemGroup> + <ItemGroup> + <CustomBuild Include="glslang\MachineIndependent\glslang.y"> + <FileType>Document</FileType> + <Message Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">Executing Bison on glslang.y</Message> + <Command Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">SET BISON_SIMPLE=%(RootDir)%(Directory)..\..\tools\bison.simple +SET BISON_HAIRY=%(RootDir)%(Directory)..\..\tools\bison.simple +cd %(RootDir)%(Directory) +%(RootDir)%(Directory)..\..\tools\bison.exe -d -t glslang.y -o glslang_tab.cpp +</Command> + <Outputs Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">%(RootDir)%(Directory)glslang_tab.cpp;%(RootDir)%(Directory)glslang_tab.cpp.h</Outputs> + <Message Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">Executing Bison on %(FullPath)</Message> + <Command Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">SET BISON_SIMPLE=%(RootDir)%(Directory)..\..\tools\bison.simple +SET BISON_HAIRY=%(RootDir)%(Directory)..\..\tools\bison.simple +cd %(RootDir)%(Directory) +%(RootDir)%(Directory)..\..\tools\bison.exe -d -t -v %(Filename).y +if EXIST %(RootDir)%(Directory)Gen_%(Filename)_tab.cpp del %(RootDir)%(Directory)Gen_%(Filename)_tab.cpp +rename %(RootDir)%(Directory)%(Filename)_tab.c Gen_%(Filename)_tab.cpp +</Command> + <Outputs Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">%(RootDir)%(Directory)Gen_%(Filename)_tab.cpp;%(Outputs)</Outputs> + </CustomBuild> + </ItemGroup> + <ItemGroup> + <CustomBuild Include="glslang\MachineIndependent\glslang.l"> + <FileType>Document</FileType> + <Command Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">cd %(RootDir)%(Directory) +%(RootDir)%(Directory)..\..\tools\flex.exe glslang.l +</Command> + <Message Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">Executing flex on glslang.l</Message> + <Outputs Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">%(RootDir)%(Directory)gen_glslang.cpp</Outputs> + <AdditionalInputs Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">%(RootDir)%(Directory)glslang_tab.cpp.h</AdditionalInputs> + </CustomBuild> + </ItemGroup> + <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" /> + <ImportGroup Label="ExtensionTargets"> + </ImportGroup> +</Project> \ No newline at end of file diff --git a/glslang.vcxproj.filters b/glslang.vcxproj.filters new file mode 100644 index 0000000000000000000000000000000000000000..00f33d8a8bc6e3d9350bbdc9bfdbe1e29429c13f --- /dev/null +++ b/glslang.vcxproj.filters @@ -0,0 +1,234 @@ +<?xml version="1.0" encoding="utf-8"?> +<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> + <ItemGroup> + <Filter Include="Machine Independent"> + <UniqueIdentifier>{593f06dd-7981-4cb7-91ba-eae633fa547e}</UniqueIdentifier> + <Extensions>cpp;c;cxx;rc;def;r;odl;idl;hpj;bat;y;l</Extensions> + </Filter> + <Filter Include="Machine Independent\Generated Source"> + <UniqueIdentifier>{564543b5-6302-49ab-9d24-bd6bef91274a}</UniqueIdentifier> + </Filter> + <Filter Include="Machine Independent\CPP"> + <UniqueIdentifier>{5d320e20-4d64-4db1-9d8c-e7fdc234be36}</UniqueIdentifier> + </Filter> + <Filter Include="Header Files"> + <UniqueIdentifier>{d4faa328-f693-4b77-9fcb-9629ca0d8ee8}</UniqueIdentifier> + </Filter> + <Filter Include="Public"> + <UniqueIdentifier>{c79e7f4d-1836-4b72-b201-46e72e4e4b6b}</UniqueIdentifier> + </Filter> + <Filter Include="Generic Code Gen"> + <UniqueIdentifier>{b56dd525-2a9c-4ae5-a6b4-d024e624c6b4}</UniqueIdentifier> + </Filter> + <Filter Include="OSDependent"> + <UniqueIdentifier>{d48b8f48-5784-4cb6-bead-7f98647a1c44}</UniqueIdentifier> + </Filter> + <Filter Include="OSDependent\Windows"> + <UniqueIdentifier>{092b92ee-743a-407d-ad9b-92af399715d6}</UniqueIdentifier> + </Filter> + <Filter Include="OSDependent\Linux"> + <UniqueIdentifier>{0c27903f-6ef2-4725-9d9c-70f50aeaa7a1}</UniqueIdentifier> + </Filter> + </ItemGroup> + <ItemGroup> + <ClCompile Include="glslang\MachineIndependent\InfoSink.cpp"> + <Filter>Machine Independent</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\Initialize.cpp"> + <Filter>Machine Independent</Filter> + </ClCompile> + <ClCompile Include="OGLCompilersDLL\InitializeDll.cpp"> + <Filter>Machine Independent</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\IntermTraverse.cpp"> + <Filter>Machine Independent</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\Intermediate.cpp"> + <Filter>Machine Independent</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\ParseHelper.cpp"> + <Filter>Machine Independent</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\PoolAlloc.cpp"> + <Filter>Machine Independent</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\QualifierAlive.cpp"> + <Filter>Machine Independent</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\RemoveTree.cpp"> + <Filter>Machine Independent</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\ShaderLang.cpp"> + <Filter>Machine Independent</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\SymbolTable.cpp"> + <Filter>Machine Independent</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\intermOut.cpp"> + <Filter>Machine Independent</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\parseConst.cpp"> + <Filter>Machine Independent</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\preprocessor\atom.c"> + <Filter>Machine Independent\CPP</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\preprocessor\cpp.c"> + <Filter>Machine Independent\CPP</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\preprocessor\cppstruct.c"> + <Filter>Machine Independent\CPP</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\preprocessor\memory.c"> + <Filter>Machine Independent\CPP</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\preprocessor\scanner.c"> + <Filter>Machine Independent\CPP</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\preprocessor\symbols.c"> + <Filter>Machine Independent\CPP</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\preprocessor\tokens.c"> + <Filter>Machine Independent\CPP</Filter> + </ClCompile> + <ClCompile Include="glslang\GenericCodeGen\CodeGen.cpp"> + <Filter>Generic Code Gen</Filter> + </ClCompile> + <ClCompile Include="glslang\GenericCodeGen\Link.cpp"> + <Filter>Generic Code Gen</Filter> + </ClCompile> + <ClCompile Include="glslang\OSDependent\Windows\main.cpp"> + <Filter>OSDependent\Windows</Filter> + </ClCompile> + <ClCompile Include="glslang\OSDependent\Windows\ossource.cpp"> + <Filter>OSDependent\Windows</Filter> + </ClCompile> + <ClCompile Include="glslang\OSDependent\Linux\ossource.cpp"> + <Filter>OSDependent\Linux</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\gen_glslang.cpp"> + <Filter>Machine Independent\Generated Source</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\glslang_tab.cpp"> + <Filter>Machine Independent\Generated Source</Filter> + </ClCompile> + <ClCompile Include="glslang\MachineIndependent\Versions.cpp"> + <Filter>Machine Independent</Filter> + </ClCompile> + </ItemGroup> + <ItemGroup> + <ClInclude Include="glslang\MachineIndependent\Initialize.h"> + <Filter>Machine Independent</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\MMap.h"> + <Filter>Machine Independent</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\ParseHelper.h"> + <Filter>Machine Independent</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\QualifierAlive.h"> + <Filter>Machine Independent</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\RemoveTree.h"> + <Filter>Machine Independent</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\localintermediate.h"> + <Filter>Machine Independent</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\preprocessor\atom.h"> + <Filter>Machine Independent\CPP</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\preprocessor\compile.h"> + <Filter>Machine Independent\CPP</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\preprocessor\cpp.h"> + <Filter>Machine Independent\CPP</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\preprocessor\memory.h"> + <Filter>Machine Independent\CPP</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\preprocessor\parser.h"> + <Filter>Machine Independent\CPP</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\preprocessor\preprocess.h"> + <Filter>Machine Independent\CPP</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\preprocessor\scanner.h"> + <Filter>Machine Independent\CPP</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\preprocessor\slglobals.h"> + <Filter>Machine Independent\CPP</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\preprocessor\symbols.h"> + <Filter>Machine Independent\CPP</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\preprocessor\tokens.h"> + <Filter>Machine Independent\CPP</Filter> + </ClInclude> + <ClInclude Include="glslang\Include\BaseTypes.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="glslang\Include\Common.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="glslang\Include\ConstantUnion.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="glslang\Include\InfoSink.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="OGLCompilersDLL\InitializeDll.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="glslang\Include\InitializeGlobals.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="glslang\Include\InitializeParseContext.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="glslang\Include\PoolAlloc.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="glslang\Include\ResourceLimits.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="glslang\Include\ShHandle.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\SymbolTable.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="glslang\Include\Types.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="glslang\Include\intermediate.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\unistd.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="glslang\Public\ShaderLang.h"> + <Filter>Public</Filter> + </ClInclude> + <ClInclude Include="glslang\OSDependent\Windows\osinclude.h"> + <Filter>OSDependent\Windows</Filter> + </ClInclude> + <ClInclude Include="glslang\OSDependent\Linux\osinclude.h"> + <Filter>OSDependent\Linux</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\glslang_tab.cpp.h"> + <Filter>Machine Independent\Generated Source</Filter> + </ClInclude> + <ClInclude Include="glslang\MachineIndependent\Versions.h"> + <Filter>Machine Independent</Filter> + </ClInclude> + </ItemGroup> + <ItemGroup> + <CustomBuild Include="glslang\MachineIndependent\glslang.y"> + <Filter>Machine Independent</Filter> + </CustomBuild> + <CustomBuild Include="glslang\MachineIndependent\glslang.l"> + <Filter>Machine Independent</Filter> + </CustomBuild> + </ItemGroup> +</Project> \ No newline at end of file diff --git a/glslang/MachineIndependent/ParseHelper.cpp b/glslang/MachineIndependent/ParseHelper.cpp index f2c77535cd987f381042cd765c24fab205c1f27e..05575a09eb4dae7e48c57c2f489e6db4195050ab 100644 --- a/glslang/MachineIndependent/ParseHelper.cpp +++ b/glslang/MachineIndependent/ParseHelper.cpp @@ -739,8 +739,8 @@ bool TParseContext::arrayQualifierErrorCheck(int line, TPublicType type) return true; } - if (type.qualifier == EvqConst && extensionErrorCheck(line, "GL_3DL_array_objects")) - return true; + if (type.qualifier == EvqConst) + profileRequires(line, ENoProfile, 120, "GL_3DL_array_objects", "const array"); return false; } @@ -948,20 +948,6 @@ bool TParseContext::paramErrorCheck(int line, TQualifier qualifier, TType* type) } } -bool TParseContext::extensionErrorCheck(int line, const char* extension) -{ - if (extensionBehavior[extension] == EBhWarn) { - infoSink.info.message(EPrefixWarning, ("extension " + TString(extension) + " is being used").c_str(), line); - return false; - } - if (extensionBehavior[extension] == EBhDisable) { - error(line, "extension", extension, "is disabled"); - return true; - } - - return false; -} - ///////////////////////////////////////////////////////////////////////////////// // // Non-Errors. @@ -1448,7 +1434,7 @@ void TParseContext::initializeExtensionBehavior() // example code: extensionBehavior["test"] = EBhDisable; // where "test" is the name of // supported extension // - extensionBehavior["GL_ARB_texture_rectangle"] = EBhRequire; + extensionBehavior["GL_ARB_texture_rectangle"] = EBhDisable; extensionBehavior["GL_3DL_array_objects"] = EBhDisable; } @@ -1457,7 +1443,7 @@ OS_TLSIndex GlobalParseContextIndex = OS_INVALID_TLS_INDEX; bool InitializeParseContextIndex() { if (GlobalParseContextIndex != OS_INVALID_TLS_INDEX) { - assert(0 && "InitializeParseContextIndex(): Parse Context already initalised"); + assert(0 && "InitializeParseContextIndex(): Parse Context already initialised"); return false; } @@ -1467,7 +1453,7 @@ bool InitializeParseContextIndex() GlobalParseContextIndex = OS_AllocTLSIndex(); if (GlobalParseContextIndex == OS_INVALID_TLS_INDEX) { - assert(0 && "InitializeParseContextIndex(): Parse Context already initalised"); + assert(0 && "InitializeParseContextIndex(): Parse Context already initialised"); return false; } @@ -1477,13 +1463,13 @@ bool InitializeParseContextIndex() bool InitializeGlobalParseContext() { if (GlobalParseContextIndex == OS_INVALID_TLS_INDEX) { - assert(0 && "InitializeGlobalParseContext(): Parse Context index not initalised"); + assert(0 && "InitializeGlobalParseContext(): Parse Context index not initialized"); return false; } TThreadParseContext *lpParseContext = static_cast<TThreadParseContext *>(OS_GetTLSValue(GlobalParseContextIndex)); if (lpParseContext != 0) { - assert(0 && "InitializeParseContextIndex(): Parse Context already initalised"); + assert(0 && "InitializeParseContextIndex(): Parse Context already initialized"); return false; } @@ -1513,7 +1499,7 @@ TParseContextPointer& GetGlobalParseContext() bool FreeParseContext() { if (GlobalParseContextIndex == OS_INVALID_TLS_INDEX) { - assert(0 && "FreeParseContext(): Parse Context index not initalised"); + assert(0 && "FreeParseContext(): Parse Context index not initialized"); return false; } @@ -1529,7 +1515,7 @@ bool FreeParseContextIndex() OS_TLSIndex tlsiIndex = GlobalParseContextIndex; if (GlobalParseContextIndex == OS_INVALID_TLS_INDEX) { - assert(0 && "FreeParseContextIndex(): Parse Context index not initalised"); + assert(0 && "FreeParseContextIndex(): Parse Context index not initialized"); return false; } diff --git a/glslang/MachineIndependent/ParseHelper.h b/glslang/MachineIndependent/ParseHelper.h index 704d3e47f0930c0e929fea33d26867d476f5dca7..3e1a125b156293a781b2e8f5059359d924472f53 100644 --- a/glslang/MachineIndependent/ParseHelper.h +++ b/glslang/MachineIndependent/ParseHelper.h @@ -2,6 +2,8 @@ //Copyright (C) 2002-2005 3Dlabs Inc. Ltd. //All rights reserved. // +//Copyright (C) 2012 LunarG, Inc. +// //Redistribution and use in source and binary forms, with or without //modification, are permitted provided that the following conditions //are met: @@ -34,6 +36,7 @@ #ifndef _PARSER_HELPER_INCLUDED_ #define _PARSER_HELPER_INCLUDED_ +#include "Versions.h" #include "../Include/ShHandle.h" #include "SymbolTable.h" #include "localintermediate.h" @@ -67,8 +70,9 @@ struct TParseContext { TParseContext(TSymbolTable& symt, TIntermediate& interm, EShLanguage L, TInfoSink& is) : intermediate(interm), symbolTable(symt), infoSink(is), language(L), treeRoot(0), recoveredFromError(false), numErrors(0), lexAfterType(false), loopNestingLevel(0), - switchNestingLevel(0), - inTypeParen(false), contextPragma(true, false) { } + switchNestingLevel(0), inTypeParen(false), + version(110), profile(ENoProfile), futureCompatibility(false), + contextPragma(true, false) { } TIntermediate& intermediate; // to hold and build a parse tree TSymbolTable& symbolTable; // symbol table that goes with the language currently being parsed TInfoSink& infoSink; @@ -82,7 +86,16 @@ struct TParseContext { bool inTypeParen; // true if in parentheses, looking only for an identifier const TType* currentFunctionType; // the return type of the function that's currently being parsed bool functionReturnsValue; // true if a non-void function has a return - TMap<TString, TBehavior> extensionBehavior; + + int version; // the declared version in the shader (110 by default) + EProfile profile; // the declared profile in the shader (core by default) + bool futureCompatibility; // true if requesting errors for future compatibility (false by default) + TMap<TString, TBehavior> extensionBehavior; // for each extension string, what it's current enablement is + + struct TPragma contextPragma; + TString HashErrMsg; + bool AfterEOF; + void initializeExtensionBehavior(); void C_DECL error(TSourceLoc, const char *szReason, const char *szToken, @@ -117,7 +130,6 @@ struct TParseContext { bool nonInitConstErrorCheck(int line, TString& identifier, TPublicType& type); bool nonInitErrorCheck(int line, TString& identifier, TPublicType& type); bool paramErrorCheck(int line, TQualifier qualifier, TType* type); - bool extensionErrorCheck(int line, const char*); const TFunction* findFunction(int line, TFunction* pfnCall, bool *builtIn = 0); bool executeInitializer(TSourceLoc line, TString& identifier, TPublicType& pType, TIntermTyped* initializer, TIntermNode*& intermNode, TVariable* variable = 0); @@ -131,9 +143,12 @@ struct TParseContext { TIntermTyped* addConstArrayNode(int index, TIntermTyped* node, TSourceLoc line); TIntermTyped* addConstStruct(TString& , TIntermTyped*, TSourceLoc); bool arraySetMaxSize(TIntermSymbol*, TType*, int, bool, TSourceLoc); - struct TPragma contextPragma; - TString HashErrMsg; - bool AfterEOF; + void requireProfile(int line, EProfileMask profileMask, const char *featureDesc); + void requireStage(int line, EShLanguageMask languageMask, const char *featureDesc); + void profileRequires(int line, EProfile callingProfile, int minVersion, int numExtensions, const char* extensions[], const char *featureDesc); + void profileRequires(int line, EProfile callingProfile, int minVersion, const char* extension, const char *featureDesc); + void checkDeprecated(int line, EProfile callingProfile, int depVersion, const char *featureDesc); + void requireNotRemoved(int line, EProfile callingProfile, int removedVersion, const char *featureDesc); }; int PaParseStrings(char* argv[], int strLen[], int argc, TParseContext&); diff --git a/glslang/MachineIndependent/ShaderLang.cpp b/glslang/MachineIndependent/ShaderLang.cpp index 5d932d18b40336f2236ccbdca4c193904dc9f666..f38f856fb5fcc5d6f43709ff3f416cbebc74be21 100644 --- a/glslang/MachineIndependent/ShaderLang.cpp +++ b/glslang/MachineIndependent/ShaderLang.cpp @@ -282,6 +282,8 @@ int ShCompile( GenerateBuiltInSymbolTable(resources, compiler->infoSink, &symbolTable, compiler->getLanguage()); + // TODO: this is happening *after* initialization, which already parsed some things... what parse context was that? + // what extensions did it have? TParseContext parseContext(symbolTable, intermediate, compiler->getLanguage(), compiler->infoSink); parseContext.initializeExtensionBehavior(); diff --git a/glslang/MachineIndependent/Versions.cpp b/glslang/MachineIndependent/Versions.cpp new file mode 100644 index 0000000000000000000000000000000000000000..c1341b705cc79a444a5d1292b43bd41a162308bc --- /dev/null +++ b/glslang/MachineIndependent/Versions.cpp @@ -0,0 +1,161 @@ +// +//Copyright (C) 2002-2005 3Dlabs Inc. Ltd. +//All rights reserved. +// +//Copyright (C) 2012 LunarG, Inc. +//All rights reserved. +// +//Redistribution and use in source and binary forms, with or without +//modification, are permitted provided that the following conditions +//are met: +// +// Redistributions of source code must retain the above copyright +// notice, this list of conditions and the following disclaimer. +// +// Redistributions in binary form must reproduce the above +// copyright notice, this list of conditions and the following +// disclaimer in the documentation and/or other materials provided +// with the distribution. +// +// Neither the name of 3Dlabs Inc. Ltd. nor the names of its +// contributors may be used to endorse or promote products derived +// from this software without specific prior written permission. +// +//THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +//"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +//LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +//FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +//COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +//INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +//BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +//LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +//CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +//LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +//ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +//POSSIBILITY OF SUCH DAMAGE. +// + +// +// Help manage multiple profiles, versions, extensions etc. +// +// These don't return error codes, as the presumption is parsing +// will always continue as if the feature were present, and there +// is no error recovery needed to enable that. +// + +#include "ParseHelper.h" + +char* StageName[EShLangCount] = { + "vertex", + "tessellation control", + "tessellation evaluation", + "geometry", + "fragment" +}; + +char* ProfileName[EProfileCount] = { + "none", + "core", + "compatibility", + "es" +}; + +// +// If only some profiles support a feature, use requireProfile() to specify +// which subset allows the feature. If the current profile is not present, +// give an error message. +// +void TParseContext::requireProfile(int line, EProfileMask profileMask, const char *featureDesc) +{ + if (((1 << profile) & profileMask) == 0) { + error(line, "not supported with this profile:", featureDesc, ProfileName[profile]); + recover(); + } +} + +// +// If only some stages support a feature, use requireStage() to specify +// which subset allows the feature. If the current stage is not present, +// give an error message. +// +void TParseContext::requireStage(int line, EShLanguageMask languageMask, const char *featureDesc) +{ + if (((1 << language) & languageMask) == 0) { + error(line, "not supported in this stage:", featureDesc, StageName[language]); + recover(); + } +} + +// +// Within a profile, if a feature requires a version level or extension, use +// ProfileRequires(). This only checks if the current profile matches +// the passed-in profile. +// + +// one that takes multiple extensions +void TParseContext::profileRequires(int line, EProfile callingProfile, int minVersion, int numExtensions, const char* extensions[], const char *featureDesc) +{ + if (profile == callingProfile) { + bool okay = false; + if (version >= minVersion) + okay = true; + for (int i = 0; i < numExtensions; ++i) { + TBehavior behavior = extensionBehavior[extensions[i]]; + switch (behavior) { + case EBhWarn: + infoSink.info.message(EPrefixWarning, ("extension " + TString(extensions[i]) + " is being used for " + featureDesc).c_str(), line); + // fall through + case EBhRequire: + case EBhEnable: + okay = true; + break; + } + } + + if (! okay) { + error(line, "not supported for this version or the enabled extensions", featureDesc, ""); + recover(); + } + } +} + +// one that takes a single extension +void TParseContext::profileRequires(int line, EProfile callingProfile, int minVersion, const char* extension, const char *featureDesc) +{ + profileRequires(line, callingProfile, minVersion, 1, &extension, featureDesc); +} + +// +// Within a profile, see if a feature is deprecated and error or warn based on whether +// a future compatibility context is being use. +// +void TParseContext::checkDeprecated(int line, EProfile callingProfile, int depVersion, const char *featureDesc) +{ + if (profile == callingProfile) { + if (version >= depVersion) { + if (futureCompatibility) { + error(line, "deprecated, may be removed in future release", featureDesc, ""); + recover(); + } else { + infoSink.info.message(EPrefixWarning, (TString(featureDesc) + " being used, but may be removed in future release").c_str(), line); + } + } + } +} + +// +// Within a profile, see if a feature has now been removed and if so, give an error. +// The version argument is the first version no longer having the feature. +// +void TParseContext::requireNotRemoved(int line, EProfile callingProfile, int removedVersion, const char *featureDesc) +{ + if (profile == callingProfile) { + if (version >= removedVersion) { + const int maxSize = 60; + char buf[maxSize]; + sprintf_s(buf, maxSize, "%s profile; removed in version %d", ProfileName[profile], removedVersion); + error(line, "no longer supported in", featureDesc, buf); + recover(); + } + } +} diff --git a/glslang/MachineIndependent/Versions.h b/glslang/MachineIndependent/Versions.h new file mode 100644 index 0000000000000000000000000000000000000000..11dde5b3a36ba42c6046453f05f3c1eda6e687d6 --- /dev/null +++ b/glslang/MachineIndependent/Versions.h @@ -0,0 +1,59 @@ +// +//Copyright (C) 2002-2005 3Dlabs Inc. Ltd. +//All rights reserved. +// +//Copyright (C) 2012 LunarG, Inc. +//All rights reserved. +// +//Redistribution and use in source and binary forms, with or without +//modification, are permitted provided that the following conditions +//are met: +// +// Redistributions of source code must retain the above copyright +// notice, this list of conditions and the following disclaimer. +// +// Redistributions in binary form must reproduce the above +// copyright notice, this list of conditions and the following +// disclaimer in the documentation and/or other materials provided +// with the distribution. +// +// Neither the name of 3Dlabs Inc. Ltd. nor the names of its +// contributors may be used to endorse or promote products derived +// from this software without specific prior written permission. +// +//THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +//"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +//LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +//FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +//COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +//INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +//BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +//LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +//CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +//LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +//ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +//POSSIBILITY OF SUCH DAMAGE. +// +#ifndef _VERSIONS_INCLUDED_ +#define _VERSIONS_INCLUDED_ + +// +// Help manage multiple profiles, versions, extensions etc. +// + +typedef enum { + ENoProfile, // only for desktop, before profiles showed up + ECoreProfile, + ECompatibilityProfile, + EEsProfile, + EProfileCount, +} EProfile; + +typedef enum { + ENoProfileMask = (1 << ENoProfile), + ECoreProfileMask = (1 << ECoreProfile), + ECompatibilityProfileMask = (1 << ECompatibilityProfile), + EEsProfileMask = (1 << EEsProfile) +} EProfileMask; + +#endif // _VERSIONS_INCLUDED_ diff --git a/glslang/MachineIndependent/glslang.l b/glslang/MachineIndependent/glslang.l index 771d22c35c791aa384a4cdeda7998bb1d6f74022..25ad975958e64d7549e94cd1363db83a5723fd16 100644 --- a/glslang/MachineIndependent/glslang.l +++ b/glslang/MachineIndependent/glslang.l @@ -3,6 +3,8 @@ //Copyright (C) 2002-2005 3Dlabs Inc. Ltd. //All rights reserved. // +//Copyright (C) 2012 LunarG, Inc. +// //Redistribution and use in source and binary forms, with or without //modification, are permitted provided that the following conditions //are met: @@ -568,7 +570,7 @@ void CPPShInfoLogMsg(const char *msg) void CPPErrorToInfoLog(char *msg) { - ((TParseContext *)cpp->pC)->error(yylineno,"syntax error", "",msg,""); + ((TParseContext *)cpp->pC)->error(yylineno, "CPP error:", "",msg,""); GlobalParseContext->recover(); } @@ -708,6 +710,48 @@ void ResetTString(void) ((TParseContext *)cpp->pC)->HashErrMsg = ""; } +void SetVersion(int version) +{ + ((TParseContext *)cpp->pC)->version = version; +} + +const int FirstProfileVersion = 150; + +// Important assumption: SetVersion() is called before SetProfile(), and is always called +// if there is a version, sending in a ENoProfile if there is no profile given. +void SetProfile(EProfile profile) +{ + int version = ((TParseContext *)cpp->pC)->version; + + if (profile == ENoProfile) { + if (version == 100 || version == 300) { + CPPErrorToInfoLog("versions 100 and 300 require specifying the es profile"); + ((TParseContext *)cpp->pC)->profile = ENoProfile; + } else if (version >= FirstProfileVersion) + ((TParseContext *)cpp->pC)->profile = ECoreProfile; + else + ((TParseContext *)cpp->pC)->profile = ENoProfile; + } else { + // a profile was provided... + if (version == 100 || version == 300) { + if (profile != EEsProfile) + CPPErrorToInfoLog("versions 100 and 300 only support the es profile"); + ((TParseContext *)cpp->pC)->profile = EEsProfile; + } else { + if (profile == EEsProfile) { + CPPErrorToInfoLog("only versions 100 and 300 support the es profile"); + if (version >= FirstProfileVersion) + ((TParseContext *)cpp->pC)->profile = ECoreProfile; + else + ((TParseContext *)cpp->pC)->profile = ENoProfile; + } else { + // typical desktop case... e.g., "#version 410 core" + ((TParseContext *)cpp->pC)->profile = profile; + } + } + } +} + TBehavior GetBehavior(const char* behavior) { if (!strcmp("require", behavior)) diff --git a/glslang/MachineIndependent/glslang.y b/glslang/MachineIndependent/glslang.y index e1f9fd6c97944cd27f158c9ec1caaab98bf7e641..4d004fc69196fa21aaee98c5933854760b1df6a9 100644 --- a/glslang/MachineIndependent/glslang.y +++ b/glslang/MachineIndependent/glslang.y @@ -2,6 +2,8 @@ //Copyright (C) 2002-2005 3Dlabs Inc. Ltd. //All rights reserved. // +//Copyright (C) 2012 LunarG, Inc. +// //Redistribution and use in source and binary forms, with or without //modification, are permitted provided that the following conditions //are met: @@ -70,20 +72,6 @@ Jutta Degener, 1995 extern void yyerror(char*); #endif -#define VERTEX_ONLY(S, L) { \ - if (parseContext.language != EShLangVertex) { \ - parseContext.error(L, " supported in vertex shaders only ", S, "", ""); \ - parseContext.recover(); \ - } \ -} - -#define FRAG_ONLY(S, L) { \ - if (parseContext.language != EShLangFragment) { \ - parseContext.error(L, " supported in fragment shaders only ", S, "", "");\ - parseContext.recover(); \ - } \ -} - %} %union { struct { @@ -384,12 +372,8 @@ postfix_expression // TODO: if next token is not "(", then this is an error if (*$3.string == "length") { - if (parseContext.extensionErrorCheck($3.line, "GL_3DL_array_objects")) { - parseContext.recover(); - $$ = $1; - } else { - $$ = parseContext.intermediate.addMethod($1, TType(EbtInt), $3.string, $2.line); - } + parseContext.profileRequires($3.line, ENoProfile, 120, "GL_3DL_array_objects", ".length"); + $$ = parseContext.intermediate.addMethod($1, TType(EbtInt), $3.string, $2.line); } else { parseContext.error($3.line, "only the length method is supported for array", $3.string->c_str(), ""); parseContext.recover(); @@ -695,10 +679,7 @@ function_identifier $$.intermNode = 0; if ($1.array) { - if (parseContext.extensionErrorCheck($1.line, "GL_3DL_array_objects")) { - parseContext.recover(); - $1.setArray(false); - } + parseContext.profileRequires($1.line, ENoProfile, 120, "GL_3DL_array_objects", "array"); } if ($1.userDef) { @@ -966,8 +947,8 @@ equality_expression constUnion *unionArray = new constUnion[1]; unionArray->setBConst(false); $$ = parseContext.intermediate.addConstantUnion(unionArray, TType(EbtBool, EvqConst), $2.line); - } else if (($1->isArray() || $3->isArray()) && parseContext.extensionErrorCheck($2.line, "GL_3DL_array_objects")) - parseContext.recover(); + } else if (($1->isArray() || $3->isArray())) + parseContext.profileRequires($2.line, ENoProfile, 120, "GL_3DL_array_objects", "=="); } | equality_expression NE_OP relational_expression { $$ = parseContext.intermediate.addBinaryMath(EOpNotEqual, $1, $3, $2.line, parseContext.symbolTable); @@ -977,8 +958,8 @@ equality_expression constUnion *unionArray = new constUnion[1]; unionArray->setBConst(false); $$ = parseContext.intermediate.addConstantUnion(unionArray, TType(EbtBool, EvqConst), $2.line); - } else if (($1->isArray() || $3->isArray()) && parseContext.extensionErrorCheck($2.line, "GL_3DL_array_objects")) - parseContext.recover(); + } else if (($1->isArray() || $3->isArray())) + parseContext.profileRequires($2.line, ENoProfile, 120, "GL_3DL_array_objects", "!="); } ; @@ -1088,8 +1069,8 @@ assignment_expression parseContext.assignError($2.line, "assign", $1->getCompleteString(), $3->getCompleteString()); parseContext.recover(); $$ = $1; - } else if (($1->isArray() || $3->isArray()) && parseContext.extensionErrorCheck($2.line, "GL_3DL_array_objects")) - parseContext.recover(); + } else if (($1->isArray() || $3->isArray())) + parseContext.profileRequires($2.line, ENoProfile, 120, "GL_3DL_array_objects", "="); } ; @@ -1394,22 +1375,20 @@ init_declarator_list parseContext.recover(); } - if (parseContext.extensionErrorCheck($$.line, "GL_3DL_array_objects")) + parseContext.profileRequires($5.line, ENoProfile, 120, "GL_3DL_array_objects", "initializer"); + + TIntermNode* intermNode; + if (!parseContext.executeInitializer($3.line, *$3.string, $1.type, $6, intermNode, variable)) { + // + // build the intermediate representation + // + if (intermNode) + $$.intermAggregate = parseContext.intermediate.growAggregate($1.intermNode, intermNode, $5.line); + else + $$.intermAggregate = $1.intermAggregate; + } else { parseContext.recover(); - else { - TIntermNode* intermNode; - if (!parseContext.executeInitializer($3.line, *$3.string, $1.type, $6, intermNode, variable)) { - // - // build the intermediate representation - // - if (intermNode) - $$.intermAggregate = parseContext.intermediate.growAggregate($1.intermNode, intermNode, $5.line); - else - $$.intermAggregate = $1.intermAggregate; - } else { - parseContext.recover(); - $$.intermAggregate = 0; - } + $$.intermAggregate = 0; } } | init_declarator_list COMMA IDENTIFIER EQUAL initializer { @@ -1492,22 +1471,20 @@ single_declaration parseContext.recover(); } - if (parseContext.extensionErrorCheck($$.line, "GL_3DL_array_objects")) - parseContext.recover(); - else { - TIntermNode* intermNode; - if (!parseContext.executeInitializer($2.line, *$2.string, $1, $5, intermNode, variable)) { - // - // Build intermediate representation - // - if (intermNode) - $$.intermAggregate = parseContext.intermediate.makeAggregate(intermNode, $4.line); - else - $$.intermAggregate = 0; - } else { - parseContext.recover(); + parseContext.profileRequires($4.line, ENoProfile, 120, "GL_3DL_array_objects", "initializer"); + + TIntermNode* intermNode; + if (!parseContext.executeInitializer($2.line, *$2.string, $1, $5, intermNode, variable)) { + // + // Build intermediate representation + // + if (intermNode) + $$.intermAggregate = parseContext.intermediate.makeAggregate(intermNode, $4.line); + else $$.intermAggregate = 0; - } + } else { + parseContext.recover(); + $$.intermAggregate = 0; } } | fully_specified_type IDENTIFIER EQUAL initializer { @@ -1538,17 +1515,13 @@ fully_specified_type $$ = $1; if ($1.array) { - if (parseContext.extensionErrorCheck($1.line, "GL_3DL_array_objects")) { - parseContext.recover(); - $1.setArray(false); - } + parseContext.profileRequires($1.line, ENoProfile, 120, "GL_3DL_array_objects", "array"); } } | type_qualifier type_specifier { - if ($2.array && parseContext.extensionErrorCheck($2.line, "GL_3DL_array_objects")) { - parseContext.recover(); - $2.setArray(false); - } + if ($2.array) + parseContext.profileRequires($1.line, ENoProfile, 120, "GL_3DL_array_objects", "array"); + if ($2.array && parseContext.arrayQualifierErrorCheck($2.line, $1)) { parseContext.recover(); $2.setArray(false); @@ -1661,12 +1634,15 @@ storage_qualifier $$.setBasic(EbtVoid, EvqConst, $1.line); } | ATTRIBUTE { - VERTEX_ONLY("attribute", $1.line); + //parseContext.requireProfile($1.line, (EProfileMask)(ENoProfileMask | ECompatibilityProfileMask), "attribute"); + parseContext.requireStage($1.line, EShLangVertexMask, "attribute"); + parseContext.requireNotRemoved($1.line, ECoreProfile, 420, "attribute"); if (parseContext.globalErrorCheck($1.line, parseContext.symbolTable.atGlobalLevel(), "attribute")) parseContext.recover(); $$.setBasic(EbtVoid, EvqAttribute, $1.line); } | VARYING { + parseContext.requireNotRemoved($1.line, ECoreProfile, 420, "varying"); if (parseContext.globalErrorCheck($1.line, parseContext.symbolTable.atGlobalLevel(), "varying")) parseContext.recover(); if (parseContext.language == EShLangVertex) @@ -2162,29 +2138,25 @@ type_specifier_nonarray $$.setBasic(EbtSampler2DShadow, qual, $1.line); } | SAMPLER2DRECT { - if (parseContext.extensionErrorCheck($1.line, "GL_ARB_texture_rectangle")) - parseContext.recover(); + parseContext.profileRequires($1.line, ENoProfile, 140, "GL_ARB_texture_rectangle", "rectangle texture"); TQualifier qual = parseContext.symbolTable.atGlobalLevel() ? EvqGlobal : EvqTemporary; $$.setBasic(EbtSamplerRect, qual, $1.line); } | SAMPLER2DRECTSHADOW { - if (parseContext.extensionErrorCheck($1.line, "GL_ARB_texture_rectangle")) - parseContext.recover(); + parseContext.profileRequires($1.line, ECoreProfile, 140, "GL_ARB_texture_rectangle", "rectangle texture"); TQualifier qual = parseContext.symbolTable.atGlobalLevel() ? EvqGlobal : EvqTemporary; $$.setBasic(EbtSamplerRectShadow, qual, $1.line); } | ISAMPLER2DRECT { - if (parseContext.extensionErrorCheck($1.line, "GL_ARB_texture_rectangle")) - parseContext.recover(); + parseContext.profileRequires($1.line, ECoreProfile, 140, "GL_ARB_texture_rectangle", "rectangle texture"); TQualifier qual = parseContext.symbolTable.atGlobalLevel() ? EvqGlobal : EvqTemporary; $$.setBasic(EbtSamplerRect, qual, $1.line); } | USAMPLER2DRECT { - if (parseContext.extensionErrorCheck($1.line, "GL_ARB_texture_rectangle")) - parseContext.recover(); + parseContext.profileRequires($1.line, ECoreProfile, 140, "GL_ARB_texture_rectangle", "rectangle texture"); TQualifier qual = parseContext.symbolTable.atGlobalLevel() ? EvqGlobal : EvqTemporary; $$.setBasic(EbtSamplerRect, qual, $1.line); @@ -2760,7 +2732,7 @@ jump_statement } } | DISCARD SEMICOLON { - FRAG_ONLY("discard", $1.line); + parseContext.requireStage($1.line, EShLangFragmentMask, "discard"); $$ = parseContext.intermediate.addBranch(EOpKill, $1.line); } ; diff --git a/glslang/MachineIndependent/preprocessor/compile.h b/glslang/MachineIndependent/preprocessor/compile.h index 140a2159171de9042c0bdc23755800715f6356e3..08a928089d4c91fa997c1d9e759d1288fc7e78d2 100644 --- a/glslang/MachineIndependent/preprocessor/compile.h +++ b/glslang/MachineIndependent/preprocessor/compile.h @@ -127,10 +127,6 @@ struct CPPStruct_Rec { int PaArgc; // count of strings in the array char** PaArgv; // our array of strings to parse unsigned int tokensBeforeEOF : 1; - - // Declared version of the shader - int version; - int profileAtom; }; #endif // !defined(__COMPILE_H) diff --git a/glslang/MachineIndependent/preprocessor/cpp.c b/glslang/MachineIndependent/preprocessor/cpp.c index 72837050ab0a25694b645503459633e958d2e8ee..83bb4b3af7237a8cc53bbb7b14c02884899a023c 100644 --- a/glslang/MachineIndependent/preprocessor/cpp.c +++ b/glslang/MachineIndependent/preprocessor/cpp.c @@ -685,18 +685,22 @@ static int CPPversion(yystypepp * yylvalpp) yylvalpp->sc_int=atoi(yylvalpp->symbol_name); - cpp->version = yylvalpp->sc_int; + SetVersion(yylvalpp->sc_int); token = cpp->currentInput->scan(cpp->currentInput, yylvalpp); - if (token == '\n'){ + if (token == '\n') { + SetProfile(ENoProfile); return token; } - else{ - cpp->profileAtom = yylvalpp->sc_ident; - if (cpp->profileAtom != coreAtom && - cpp->profileAtom != compatibilityAtom && - cpp->profileAtom != esAtom) + else { + if (yylvalpp->sc_ident == coreAtom) + SetProfile(ECoreProfile); + else if (yylvalpp->sc_ident == compatibilityAtom) + SetProfile(ECompatibilityProfile); + else if (yylvalpp->sc_ident == esAtom) + SetProfile(EEsProfile); + else CPPErrorToInfoLog("#version profile name"); token = cpp->currentInput->scan(cpp->currentInput, yylvalpp); diff --git a/glslang/MachineIndependent/preprocessor/cpp.h b/glslang/MachineIndependent/preprocessor/cpp.h index 10ecd123234c2da6aee046f7961b9d3b0f0c6214..f7195cda64fc82b9f273094f259f993e3f348bbb 100644 --- a/glslang/MachineIndependent/preprocessor/cpp.h +++ b/glslang/MachineIndependent/preprocessor/cpp.h @@ -83,6 +83,7 @@ NVIDIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. #include "parser.h" #include "tokens.h" +#include "Versions.h" int InitCPP(void); int FinalCPP(void); @@ -113,6 +114,8 @@ void SetStringNumber(int); // Set string number. int GetLineNumber(void); // Get the current String Number. int GetStringNumber(void); // Get the current String Number. const char* GetStrfromTStr(void); // Convert TString to String. +void SetVersion(int); +void SetProfile(EProfile); void updateExtensionBehavior(const char* extName, const char* behavior); int FreeCPP(void); diff --git a/glslang/MachineIndependent/preprocessor/cppstruct.c b/glslang/MachineIndependent/preprocessor/cppstruct.c index c924dc2402b2dfd42c764829e5d121b6e0f8006e..b1b15fa0b897dd0b5558df4431ead5dfe2c424f9 100644 --- a/glslang/MachineIndependent/preprocessor/cppstruct.c +++ b/glslang/MachineIndependent/preprocessor/cppstruct.c @@ -132,8 +132,6 @@ int ResetPreprocessor(void) cpp->elsedepth[cpp->elsetracker]=0; cpp->elsetracker=0; cpp->tokensBeforeEOF = 0; - cpp->version = 110; - cpp->profileAtom = 0; return 1; } diff --git a/glslang/Public/ShaderLang.h b/glslang/Public/ShaderLang.h index 96e35d424317ed118a6062931c5e4df7bb746c86..c4b69844a4fa03453098979e9d15018ec7ef8858 100644 --- a/glslang/Public/ShaderLang.h +++ b/glslang/Public/ShaderLang.h @@ -71,10 +71,23 @@ SH_IMPORT_EXPORT int __fastcall ShFinalize(); // typedef enum { EShLangVertex, + EShLangTessControl, + EShLangTessEvaluation, + EShLangGeometry, EShLangFragment, EShLangCount, } EShLanguage; +typedef enum { + EShLangVertexMask = (1 << EShLangVertex), + EShLangTessControlMask = (1 << EShLangTessControl), + EShLangTessEvaluationMask = (1 << EShLangTessEvaluation), + EShLangGeometryMask = (1 << EShLangGeometry), + EShLangFragmentMask = (1 << EShLangFragment), +} EShLanguageMask; + +extern char* StageName[EShLangCount]; + // // Types of output the linker will create. //