mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-24 21:58:06 +00:00
Bug 1236787 - Check internalformat to pass getInternalformatParameter in gl-object-get-calls.html (2.0); r=jgilbert
MozReview-Commit-ID: ALsgs1MSmtj --HG-- extra : transplant_source : %1E9%97%B8%B8%D6%08I%7DH%97eI%CE%EA3D%EFI%F9
This commit is contained in:
parent
5298dd04a9
commit
d4556d9101
@ -18,6 +18,8 @@ WebGL2Context::GetInternalformatParameter(JSContext* cx, GLenum target,
|
||||
ErrorResult& out_rv)
|
||||
{
|
||||
const char funcName[] = "getInternalfomratParameter";
|
||||
retval.setObjectOrNull(nullptr);
|
||||
|
||||
if (IsContextLost())
|
||||
return;
|
||||
|
||||
@ -27,9 +29,32 @@ WebGL2Context::GetInternalformatParameter(JSContext* cx, GLenum target,
|
||||
return;
|
||||
}
|
||||
|
||||
// GL_INVALID_ENUM is generated if internalformat is not color-, depth-, or
|
||||
// stencil-renderable.
|
||||
// TODO: When format table queries lands.
|
||||
// GLES 3.0.4 $4.4.4 p212:
|
||||
// "An internal format is color-renderable if it is one of the formats from table 3.13
|
||||
// noted as color-renderable or if it is unsized format RGBA or RGB."
|
||||
|
||||
GLenum sizedFormat;
|
||||
switch (internalformat) {
|
||||
case LOCAL_GL_RGB:
|
||||
sizedFormat = LOCAL_GL_RGB8;
|
||||
break;
|
||||
case LOCAL_GL_RGBA:
|
||||
sizedFormat = LOCAL_GL_RGBA8;
|
||||
break;
|
||||
default:
|
||||
sizedFormat = internalformat;
|
||||
break;
|
||||
}
|
||||
|
||||
// In RenderbufferStorage, we allow DEPTH_STENCIL. Therefore, it is accepted for
|
||||
// internalformat as well. Please ignore the conformance test fail for DEPTH_STENCIL.
|
||||
|
||||
const auto usage = mFormatUsage->GetRBUsage(sizedFormat);
|
||||
if (!usage) {
|
||||
ErrorInvalidEnum("%s: `internalformat` must be color-, depth-, or stencil-renderable, was: 0x%04x.",
|
||||
funcName, internalformat);
|
||||
return;
|
||||
}
|
||||
|
||||
if (pname != LOCAL_GL_SAMPLES) {
|
||||
ErrorInvalidEnumInfo("%s: `pname` must be SAMPLES, was 0x%04x.", funcName, pname);
|
||||
|
Loading…
x
Reference in New Issue
Block a user