Bug 1325995 - Do our own GLSL char validity checks based on ESSL3 rules. - r=daoshengmu

MozReview-Commit-ID: 60mJqYFTQBA
This commit is contained in:
Jeff Gilbert 2016-12-29 18:48:04 -08:00
parent 43c4b02d0c
commit 2d5f771315
3 changed files with 92 additions and 40 deletions

View File

@ -166,7 +166,7 @@ WebGLShader::ShaderSource(const nsAString& source)
return;
}
if (!ValidateGLSLString(sourceWithoutComments, mContext, funcName))
if (!ValidateGLSLPreprocString(mContext, funcName, sourceWithoutComments))
return;
// We checked that the source stripped of comments is in the

View File

@ -5,33 +5,9 @@
#include "WebGLValidateStrings.h"
#include "nsString.h"
#include "WebGLContext.h"
namespace mozilla {
// The following code was taken from the WebKit WebGL implementation,
// which can be found here:
// http://trac.webkit.org/browser/trunk/Source/WebCore/html/canvas/WebGLRenderingContext.cpp?rev=93625#L121
// Note that some modifications were done to adapt it to Mozilla.
/****** BEGIN CODE TAKEN FROM WEBKIT ******/
bool IsValidGLSLCharacter(char16_t c)
{
// Printing characters are valid except " $ ` @ \ ' DEL.
if (c >= 32 && c <= 126 &&
c != '"' && c != '$' && c != '`' && c != '@' && c != '\\' && c != '\'')
{
return true;
}
// Horizontal tab, line feed, vertical tab, form feed, carriage return
// are also valid.
if (c >= 9 && c <= 13) {
return true;
}
return false;
}
/****** END CODE TAKEN FROM WEBKIT ******/
bool
TruncateComments(const nsAString& src, nsAString* const out)
@ -125,13 +101,84 @@ TruncateComments(const nsAString& src, nsAString* const out)
return true;
}
////////////////////////////////////////////////////////////////////////////////
static bool
IsValidGLSLChar(char16_t c)
{
if (('a' <= c && c <= 'z') ||
('A' <= c && c <= 'Z') ||
('0' <= c && c <= '9'))
{
return true;
}
switch (c) {
case ' ':
case '\t':
case '\v':
case '\f':
case '\r':
case '\n':
case '_':
case '.':
case '+':
case '-':
case '/':
case '*':
case '%':
case '<':
case '>':
case '[':
case ']':
case '(':
case ')':
case '{':
case '}':
case '^':
case '|':
case '&':
case '~':
case '=':
case '!':
case ':':
case ';':
case ',':
case '?':
return true;
default:
return false;
}
}
static bool
IsValidGLSLPreprocChar(char16_t c)
{
if (IsValidGLSLChar(c))
return true;
switch (c) {
case '\\':
case '#':
return true;
default:
return false;
}
}
////
bool
ValidateGLSLString(const nsAString& string, WebGLContext* webgl, const char* funcName)
ValidateGLSLPreprocString(WebGLContext* webgl, const char* funcName,
const nsAString& string)
{
for (size_t i = 0; i < string.Length(); ++i) {
if (!IsValidGLSLCharacter(string.CharAt(i))) {
webgl->ErrorInvalidValue("%s: String contains the illegal character '%d'",
funcName, string.CharAt(i));
const auto& cur = string[i];
if (!IsValidGLSLPreprocChar(cur)) {
webgl->ErrorInvalidValue("%s: String contains the illegal character 0x%x.",
funcName, cur);
return false;
}
}
@ -147,14 +194,20 @@ ValidateGLSLVariableName(const nsAString& name, WebGLContext* webgl, const char*
const uint32_t maxSize = webgl->IsWebGL2() ? 1024 : 256;
if (name.Length() > maxSize) {
webgl->ErrorInvalidValue("%s: Identifier is %d characters long, exceeds the"
" maximum allowed length of %d characters.",
webgl->ErrorInvalidValue("%s: Identifier is %u characters long, exceeds the"
" maximum allowed length of %u characters.",
funcName, name.Length(), maxSize);
return false;
}
if (!ValidateGLSLString(name, webgl, funcName))
return false;
for (size_t i = 0; i < name.Length(); ++i) {
const auto& cur = name[i];
if (!IsValidGLSLChar(cur)) {
webgl->ErrorInvalidValue("%s: String contains the illegal character 0x%x'.",
funcName, cur);
return false;
}
}
nsString prefix1 = NS_LITERAL_STRING("webgl_");
nsString prefix2 = NS_LITERAL_STRING("_webgl_");

View File

@ -28,7 +28,6 @@
#define WEBGL_VALIDATE_STRINGS_H_
#include "nsString.h"
#include "nsTArray.h"
namespace mozilla {
@ -36,12 +35,12 @@ class WebGLContext;
bool
TruncateComments(const nsAString& src, nsAString* const out);
bool ValidateGLSLString(const nsAString& string, WebGLContext* webgl,
const char* funcName);
bool ValidateGLSLVariableName(const nsAString& name, WebGLContext* webgl,
const char* funcName);
bool
ValidateGLSLPreprocString(WebGLContext* webgl, const char* funcName,
const nsAString& string);
bool
ValidateGLSLVariableName(const nsAString& name, WebGLContext* webgl,
const char* funcName);
} // namespace mozilla