Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(9)

Unified Diff: app/gfx/gl/gl_implementation.cc

Issue 6325005: Relanding r71472.... Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Created 9 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « app/gfx/gl/gl_implementation.h ('k') | app/gfx/gl/gl_implementation_linux.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: app/gfx/gl/gl_implementation.cc
===================================================================
--- app/gfx/gl/gl_implementation.cc (revision 71474)
+++ app/gfx/gl/gl_implementation.cc (working copy)
@@ -21,6 +21,16 @@
namespace {
+const struct {
+ const char* name;
+ GLImplementation implementation;
+} kGLImplementationNamePairs[] = {
+ { kGLImplementationDesktopName, kGLImplementationDesktopGL },
+ { kGLImplementationOSMesaName, kGLImplementationOSMesaGL },
+ { kGLImplementationEGLName, kGLImplementationEGLGLES2 },
+ { kGLImplementationMockName, kGLImplementationMockGL }
+};
+
typedef std::vector<base::NativeLibrary> LibraryArray;
GLImplementation g_gl_implementation = kGLImplementationNone;
@@ -40,24 +50,23 @@
}
GLImplementation GetNamedGLImplementation(const std::string& name) {
- static const struct {
- const char* name;
- GLImplementation implemention;
- } name_pairs[] = {
- { kGLImplementationDesktopName, kGLImplementationDesktopGL },
- { kGLImplementationOSMesaName, kGLImplementationOSMesaGL },
- { kGLImplementationEGLName, kGLImplementationEGLGLES2 },
- { kGLImplementationMockName, kGLImplementationMockGL }
- };
-
- for (size_t i = 0; i < ARRAYSIZE_UNSAFE(name_pairs); ++i) {
- if (name == name_pairs[i].name)
- return name_pairs[i].implemention;
+ for (size_t i = 0; i < ARRAYSIZE_UNSAFE(kGLImplementationNamePairs); ++i) {
+ if (name == kGLImplementationNamePairs[i].name)
+ return kGLImplementationNamePairs[i].implementation;
}
return kGLImplementationNone;
}
+const char* GetGLImplementationName(GLImplementation implementation) {
+ for (size_t i = 0; i < ARRAYSIZE_UNSAFE(kGLImplementationNamePairs); ++i) {
+ if (implementation == kGLImplementationNamePairs[i].implementation)
+ return kGLImplementationNamePairs[i].name;
+ }
+
+ return "unknown";
+}
+
bool InitializeBestGLBindings(
const GLImplementation* allowed_implementations_begin,
const GLImplementation* allowed_implementations_end) {
@@ -69,23 +78,29 @@
if (std::find(allowed_implementations_begin,
allowed_implementations_end,
requested_implementation) == allowed_implementations_end) {
- LOG(ERROR) << "Requested GL implementation is not allowed.";
+ LOG(ERROR) << "Requested GL implementation is not available.";
return false;
}
- if (InitializeGLBindings(requested_implementation))
- return true;
+ InitializeGLBindings(requested_implementation);
} else {
for (const GLImplementation* p = allowed_implementations_begin;
p < allowed_implementations_end;
++p) {
if (InitializeGLBindings(*p))
- return true;
+ break;
}
}
- LOG(ERROR) << "Could not initialize GL.";
- return false;
+ if (GetGLImplementation() == kGLImplementationNone) {
+ LOG(ERROR) << "Could not initialize GL.";
+ return false;
+ } else {
+ LOG(INFO) << "Using "
+ << GetGLImplementationName(GetGLImplementation())
+ << " GL implementation.";
+ return true;
+ }
}
void SetGLImplementation(GLImplementation implementation) {
« no previous file with comments | « app/gfx/gl/gl_implementation.h ('k') | app/gfx/gl/gl_implementation_linux.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698