Stop emitting the "#version missing" warning, and hook up the existing "suppress warnings" to a command-line option (-w).
git-svn-id: https://cvs.khronos.org/svn/repos/ogl/trunk/ecosystem/public/sdk/tools/glslang@23952 e7fa87d3-cd2b-0410-9028-fcbf551c1848
diff --git a/StandAlone/StandAlone.cpp b/StandAlone/StandAlone.cpp
index a3c1faf..ae0465c 100644
--- a/StandAlone/StandAlone.cpp
+++ b/StandAlone/StandAlone.cpp
@@ -62,6 +62,7 @@
EOptionMultiThreaded = 0x040,
EOptionDumpConfig = 0x080,
EOptionDumpReflection = 0x100,
+ EOptionSuppressWarnings = 0x200,
};
//
@@ -91,7 +92,7 @@
ShBindingTable FixedAttributeTable = { 3, FixedAttributeBindings };
EShLanguage FindLanguage(const std::string& name);
-bool CompileFile(const char *fileName, ShHandle, int options);
+bool CompileFile(const char *fileName, ShHandle);
void usage();
void FreeFileData(char** data);
char** ReadFileData(const char* fileName);
@@ -478,9 +479,12 @@
break;
case 't':
#ifdef _WIN32
- Options |= EOptionMultiThreaded;
+ Options |= EOptionMultiThreaded;
#endif
break;
+ case 'w':
+ Options |= EOptionSuppressWarnings;
+ break;
default:
return false;
}
@@ -496,6 +500,16 @@
return true;
}
+void SetMessageOptions(EShMessages& messages)
+{
+ if (Options & EOptionRelaxedErrors)
+ messages = (EShMessages)(messages | EShMsgRelaxedErrors);
+ if (Options & EOptionIntermediate)
+ messages = (EShMessages)(messages | EShMsgAST);
+ if (Options & EOptionSuppressWarnings)
+ messages = (EShMessages)(messages | EShMsgSuppressWarnings);
+}
+
// Thread entry point, for non-linking asynchronous mode.
unsigned int
#ifdef _WIN32
@@ -509,7 +523,7 @@
if (compiler == 0)
return false;
- CompileFile(workItem->name.c_str(), compiler, Options);
+ CompileFile(workItem->name.c_str(), compiler);
if (! (Options & EOptionSuppressInfolog))
workItem->results = ShGetInfoLog(compiler);
@@ -532,10 +546,7 @@
std::list<glslang::TShader*> shaders;
EShMessages messages = EShMsgDefault;
- if (Options & EOptionRelaxedErrors)
- messages = (EShMessages)(messages | EShMsgRelaxedErrors);
- if (Options & EOptionIntermediate)
- messages = (EShMessages)(messages | EShMsgAST);
+ SetMessageOptions(messages);
//
// Per-shader processing...
@@ -713,7 +724,7 @@
// Read a file's data into a string, and compile it using the old interface ShCompile,
// for non-linkable results.
//
-bool CompileFile(const char *fileName, ShHandle compiler, int Options)
+bool CompileFile(const char *fileName, ShHandle compiler)
{
int ret;
char** shaderStrings = ReadFileData(fileName);
@@ -732,10 +743,7 @@
return false;
EShMessages messages = EShMsgDefault;
- if (Options & EOptionRelaxedErrors)
- messages = (EShMessages)(messages | EShMsgRelaxedErrors);
- if (Options & EOptionIntermediate)
- messages = (EShMessages)(messages | EShMsgAST);
+ SetMessageOptions(messages);
for (int i = 0; i < ((Options & EOptionMemoryLeakMode) ? 100 : 1); ++i) {
for (int j = 0; j < ((Options & EOptionMemoryLeakMode) ? 100 : 1); ++j) {
@@ -777,13 +785,14 @@
"To get other information, use one of the following options:\n"
"-c: configuration dump; use to create default configuration file (redirect to a .conf file)\n"
"-i: intermediate tree (glslang AST) is printed out\n"
- "-d: delay exit\n"
"-l: link validation of all input files\n"
"-m: memory leak mode\n"
"-q: dump reflection query database\n"
"-r: relaxed semantic error-checking mode\n"
"-s: silent mode\n"
- "-t: multi-threaded mode\n");
+ "-t: multi-threaded mode\n"
+ "-w: suppress warnings (except as required by #extension : warn)\n"
+ );
}
#ifndef _WIN32