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

Unified Diff: ui/gl/gl_context_ozone.cc

Issue 17932004: Support ozone=1 compositor_unittests with OSMesa (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: include order version Created 7 years, 6 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 | « ui/gl/gl.gyp ('k') | ui/gl/gl_image_ozone.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ui/gl/gl_context_ozone.cc
diff --git a/ui/gl/gl_context_ozone.cc b/ui/gl/gl_context_ozone.cc
index aeb91953df78b50bdf34af22cb8ced2d5494d8f1..776e114e3dae62c3b034b3bc0e5f52e6374c2003 100644
--- a/ui/gl/gl_context_ozone.cc
+++ b/ui/gl/gl_context_ozone.cc
@@ -9,6 +9,7 @@
#include "base/sys_info.h"
#include "ui/gl/gl_bindings.h"
#include "ui/gl/gl_context_egl.h"
+#include "ui/gl/gl_context_osmesa.h"
#include "ui/gl/gl_context_stub.h"
#include "ui/gl/gl_implementation.h"
#include "ui/gl/gl_surface.h"
@@ -20,20 +21,26 @@ scoped_refptr<GLContext> GLContext::CreateGLContext(
GLShareGroup* share_group,
GLSurface* compatible_surface,
GpuPreference gpu_preference) {
- if (GetGLImplementation() == kGLImplementationMockGL)
- return scoped_refptr<GLContext>(new GLContextStub());
- scoped_refptr<GLContext> context;
- if (!compatible_surface->GetHandle()) {
- DLOG(ERROR) << "Surface has no associated handle.\n";
- return NULL;
+ switch (GetGLImplementation()) {
+ case kGLImplementationMockGL:
+ return scoped_refptr<GLContext>(new GLContextStub());
+ case kGLImplementationOSMesaGL: {
+ scoped_refptr<GLContext> context(new GLContextOSMesa(share_group));
+ if (!context->Initialize(compatible_surface, gpu_preference))
+ return NULL;
+ return context;
+ }
+ case kGLImplementationEGLGLES2: {
+ scoped_refptr<GLContext> context(new GLContextEGL(share_group));
+ if (!context->Initialize(compatible_surface, gpu_preference))
+ return NULL;
+ return context;
+ }
+ default:
+ NOTREACHED();
+ return NULL;
}
-
- context = new GLContextEGL(share_group);
-
- if (!context->Initialize(compatible_surface, gpu_preference))
- return NULL;
- return context;
}
} // namespace gfx
« no previous file with comments | « ui/gl/gl.gyp ('k') | ui/gl/gl_image_ozone.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698