Simple GLSL compilation checker (uses display driver)
(c) 2013-2015 Christoph Kubisch: pixeljetstream@luxinia.de http://glslc.luxinia.de
- Basic commandline compiler for GLSL
- Creates an invisible dummy window and evokes the GL driver for compiling.
- Can dump pseudo assembly files for NVIDIA
- Basic #include handling independent of GL_ARB_shading_language_include support
- Best used with GLSL editing capabilites of the https://github.com/pkulchenko/ZeroBraneStudio/ IDE
- Install the zbstudio-graphicscodepack
- Set the GLSLC_BIN_PATH environment variable to where your glslc.exe is located (excluding the exe name). Alternatively add "path.glslcbin = [[path to glslc.exe]] " to your "cfg/user.lua" file. Upon restart of zbstudio, you should now see the GLSL top menu.
- 'Compile from .ext' derives the shader profile type from the filename, for example a ".v" within the filename causes the file to be compiled as vertex shader. The tool tests in following order: ".v",".f",".g",".t * c",".t * e",".c".
- 'Link multiple .ext' will try to compile and link multiple shader files that only differ in their file extension.
glslc -o output.txt -profile vertex myvertex.vs
glslc -glslversion "430 core" -o output.txt -DFOO -vertex myvertex.vs -fragment myfrag.fs
glslc -glslversion "430 core" -o output.txt -DFOO -SD_VERTEX_ -vertex myprogram.glsl -SD_FRAGMENT_ -fragment myprogram.glsl
glslc [options] filename
-profilename
or
-profile profilename
Profilename can be: vertex, fragment, geometry, tessevaluation, tesscontrol, compute and must be specified prior each file name.
-glslversion "string"
Prepends "#version string\n" prior macros and shader and puts // in front of #version find in shaderfile.
-separable
Will mark the program separable (default is false) prior attaching and linking, if GL_ARB_separate_shader_objects is supported.
-o outputfilename
NVIDIA drivers can output pseudo assembly file based on NV_program
-P preprocessfilename
stores the pre-processed file for the next specified shader
-E
Pre-processes files only, no GL context creation. Outputs to stdout unless -P was specified.
-DMACRO[=VALUE]
Prepends '#define MACRO VALUE' to all shaders. If VALUE is not specified it defaults to 1.
-SDMACRO[=VALUE]
Prepends '#define MACRO VALUE' to next shader. If VALUE is not specified it defaults to 1. All shader defines are cleared with each shader file.
Currently Windows and Linux are supported. For Visual Studio 2008 a solution exists in /buildvc9. The project is just the src/glsl.cpp compiled as console application.
Thanks to Alan Chambers for Linux support.