Closed
Bug 1097411
Opened 10 years ago
Closed 10 years ago
Extend error reporting for GL enums.
Categories
(Core :: Graphics: CanvasWebGL, defect)
Core
Graphics: CanvasWebGL
Tracking
()
RESOLVED
FIXED
mozilla36
People
(Reporter: u480271, Assigned: u480271)
References
Details
Attachments
(1 file, 1 obsolete file)
13.54 KB,
patch
|
jgilbert
:
review+
|
Details | Diff | Splinter Review |
No description provided.
Comment 2•10 years ago
|
||
Comment on attachment 8524361 [details] [diff] [review] Extend error reporting Review of attachment 8524361 [details] [diff] [review]: ----------------------------------------------------------------- ::: dom/canvas/WebGLContextUtils.cpp @@ +505,5 @@ > void > WebGLContext::ErrorInvalidEnumInfo(const char *info, GLenum enumvalue) > { > + const char* name = EnumName(enumvalue); > + if (!name || name[0] == '[') We should really have two functions: Infallible `const char* EnumName(GLenum val)` Fallible `bool EnumName(GLenum val, const char* const out_name)` In theory, the fallible version could just return null, but I think it's more clear which is fallible this way. Use the fallible version here. @@ +508,5 @@ > + const char* name = EnumName(enumvalue); > + if (!name || name[0] == '[') > + return ErrorInvalidEnum("%s: invalid enum value 0x%04x", info, enumvalue); > + > + return ErrorInvalidEnum("%s: invalid enum value %s", info, name); So here's the problem with this. It assumes (GLenum val)->(const char* name) is one-to-one. This isn't universally true, though. The proper construction here for all GLenums is map<GLenum val, set<const char*> names>. Maybe the question is whether this matters. Restrict `GLenum val` to >= 0x10 and we should be one-to-one again.
Attachment #8524361 -
Flags: review?(jgilbert) → review+
Yeah, I know it's not one-to-one, but how do you select the result you want? An option to the function call, I suppose.
Updated with fallible and non-fallible versions of EnumName.
Attachment #8526465 -
Flags: review?(jgilbert)
Attachment #8524361 -
Attachment is obsolete: true
Updated•10 years ago
|
Attachment #8526465 -
Flags: review?(jgilbert) → review+
(In reply to Dan Glastonbury :djg :kamidphish from comment #6) > https://tbpl.mozilla.org/?tree=Try&rev=5db03e87ca06 *sigh* Programming is hard.
Comment 10•10 years ago
|
||
https://hg.mozilla.org/mozilla-central/rev/5fdc1acbc53f
Status: NEW → RESOLVED
Closed: 10 years ago
Resolution: --- → FIXED
Target Milestone: --- → mozilla36
You need to log in
before you can comment on or make changes to this bug.
Description
•