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

Side by Side Diff: mojo/examples/compositor_app/compositor_app.cc

Issue 298653010: Change Shell / ShellClient to ServiceProvider (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Support content Mojo stuff Created 6 years, 7 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include <stdio.h> 5 #include <stdio.h>
6 #include <string> 6 #include <string>
7 7
8 #include "base/macros.h" 8 #include "base/macros.h"
9 #include "base/message_loop/message_loop.h" 9 #include "base/message_loop/message_loop.h"
10 #include "mojo/examples/compositor_app/compositor_host.h" 10 #include "mojo/examples/compositor_app/compositor_host.h"
11 #include "mojo/geometry/geometry_type_converters.h" 11 #include "mojo/geometry/geometry_type_converters.h"
12 #include "mojo/public/cpp/application/application.h"
12 #include "mojo/public/cpp/bindings/allocation_scope.h" 13 #include "mojo/public/cpp/bindings/allocation_scope.h"
13 #include "mojo/public/cpp/gles2/gles2.h" 14 #include "mojo/public/cpp/gles2/gles2.h"
14 #include "mojo/public/cpp/shell/application.h"
15 #include "mojo/public/cpp/system/core.h" 15 #include "mojo/public/cpp/system/core.h"
16 #include "mojo/public/interfaces/shell/shell.mojom.h" 16 #include "mojo/public/interfaces/service_provider/service_provider.mojom.h"
17 #include "mojo/services/native_viewport/native_viewport.mojom.h" 17 #include "mojo/services/native_viewport/native_viewport.mojom.h"
18 #include "ui/gfx/rect.h" 18 #include "ui/gfx/rect.h"
19 19
20 #if defined(WIN32) 20 #if defined(WIN32)
21 #if !defined(CDECL) 21 #if !defined(CDECL)
22 #define CDECL __cdecl 22 #define CDECL __cdecl
23 #endif 23 #endif
24 #define SAMPLE_APP_EXPORT __declspec(dllexport) 24 #define SAMPLE_APP_EXPORT __declspec(dllexport)
25 #else 25 #else
26 #define CDECL 26 #define CDECL
27 #define SAMPLE_APP_EXPORT __attribute__((visibility("default"))) 27 #define SAMPLE_APP_EXPORT __attribute__((visibility("default")))
28 #endif 28 #endif
29 29
30 namespace mojo { 30 namespace mojo {
31 namespace examples { 31 namespace examples {
32 32
33 class SampleApp : public Application, public NativeViewportClient { 33 class SampleApp : public Application, public NativeViewportClient {
34 public: 34 public:
35 explicit SampleApp(MojoHandle shell_handle) : Application(shell_handle) { 35 explicit SampleApp(MojoHandle service_provider_handle)
36 : Application(service_provider_handle) {
36 AllocationScope scope; 37 AllocationScope scope;
37 38
38 ConnectTo("mojo:mojo_native_viewport_service", &viewport_); 39 ConnectTo("mojo:mojo_native_viewport_service", &viewport_);
39 viewport_.set_client(this); 40 viewport_.set_client(this);
40 41
41 viewport_->Create(gfx::Rect(10, 10, 800, 600)); 42 viewport_->Create(gfx::Rect(10, 10, 800, 600));
42 viewport_->Show(); 43 viewport_->Show();
43 44
44 MessagePipe gles2_pipe; 45 MessagePipe gles2_pipe;
45 viewport_->CreateGLES2Context(gles2_pipe.handle0.Pass()); 46 viewport_->CreateGLES2Context(gles2_pipe.handle0.Pass());
(...skipping 18 matching lines...) Expand all
64 65
65 private: 66 private:
66 NativeViewportPtr viewport_; 67 NativeViewportPtr viewport_;
67 scoped_ptr<CompositorHost> host_; 68 scoped_ptr<CompositorHost> host_;
68 }; 69 };
69 70
70 } // namespace examples 71 } // namespace examples
71 } // namespace mojo 72 } // namespace mojo
72 73
73 extern "C" SAMPLE_APP_EXPORT MojoResult CDECL MojoMain( 74 extern "C" SAMPLE_APP_EXPORT MojoResult CDECL MojoMain(
74 MojoHandle shell_handle) { 75 MojoHandle service_provider_handle) {
75 base::MessageLoop loop; 76 base::MessageLoop loop;
76 mojo::GLES2Initializer gles2; 77 mojo::GLES2Initializer gles2;
77 78
78 mojo::examples::SampleApp app(shell_handle); 79 mojo::examples::SampleApp app(service_provider_handle);
79 loop.Run(); 80 loop.Run();
80 return MOJO_RESULT_OK; 81 return MOJO_RESULT_OK;
81 } 82 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698