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

Side by Side Diff: mojo/runner/native_application_support.cc

Issue 1107233002: Move runner stuff into a runner namespace. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: . Created 5 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
« no previous file with comments | « mojo/runner/native_application_support.h ('k') | mojo/runner/native_runner_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 "mojo/runner/native_application_support.h" 5 #include "mojo/runner/native_application_support.h"
6 6
7 #include "base/command_line.h" 7 #include "base/command_line.h"
8 #include "base/files/file_path.h" 8 #include "base/files/file_path.h"
9 #include "base/files/file_util.h" 9 #include "base/files/file_util.h"
10 #include "base/logging.h" 10 #include "base/logging.h"
11 #include "mojo/public/platform/native/gles2_impl_chromium_miscellaneous_thunks.h " 11 #include "mojo/public/platform/native/gles2_impl_chromium_miscellaneous_thunks.h "
12 #include "mojo/public/platform/native/gles2_impl_chromium_sub_image_thunks.h" 12 #include "mojo/public/platform/native/gles2_impl_chromium_sub_image_thunks.h"
13 #include "mojo/public/platform/native/gles2_impl_chromium_sync_point_thunks.h" 13 #include "mojo/public/platform/native/gles2_impl_chromium_sync_point_thunks.h"
14 #include "mojo/public/platform/native/gles2_impl_chromium_texture_mailbox_thunks .h" 14 #include "mojo/public/platform/native/gles2_impl_chromium_texture_mailbox_thunks .h"
15 #include "mojo/public/platform/native/gles2_impl_occlusion_query_ext_thunks.h" 15 #include "mojo/public/platform/native/gles2_impl_occlusion_query_ext_thunks.h"
16 #include "mojo/public/platform/native/gles2_impl_thunks.h" 16 #include "mojo/public/platform/native/gles2_impl_thunks.h"
17 #include "mojo/public/platform/native/gles2_thunks.h" 17 #include "mojo/public/platform/native/gles2_thunks.h"
18 #include "mojo/public/platform/native/system_thunks.h" 18 #include "mojo/public/platform/native/system_thunks.h"
19 19
20 namespace mojo { 20 namespace mojo {
21 namespace shell { 21 namespace runner {
22 22
23 namespace { 23 namespace {
24 24
25 template <typename Thunks> 25 template <typename Thunks>
26 bool SetThunks(Thunks (*make_thunks)(), 26 bool SetThunks(Thunks (*make_thunks)(),
27 const char* function_name, 27 const char* function_name,
28 base::NativeLibrary library) { 28 base::NativeLibrary library) {
29 typedef size_t (*SetThunksFn)(const Thunks* thunks); 29 typedef size_t (*SetThunksFn)(const Thunks* thunks);
30 SetThunksFn set_thunks = reinterpret_cast<SetThunksFn>( 30 SetThunksFn set_thunks = reinterpret_cast<SetThunksFn>(
31 base::GetFunctionPointerFromNativeLibrary(library, function_name)); 31 base::GetFunctionPointerFromNativeLibrary(library, function_name));
32 if (!set_thunks) 32 if (!set_thunks)
33 return false; 33 return false;
34 Thunks thunks = make_thunks(); 34 Thunks thunks = make_thunks();
35 size_t expected_size = set_thunks(&thunks); 35 size_t expected_size = set_thunks(&thunks);
36 if (expected_size > sizeof(Thunks)) { 36 if (expected_size > sizeof(Thunks)) {
37 LOG(ERROR) << "Invalid app library: expected " << function_name 37 LOG(ERROR) << "Invalid app library: expected " << function_name
38 << " to return thunks of size: " << expected_size; 38 << " to return thunks of size: " << expected_size;
39 return false; 39 return false;
40 } 40 }
41 return true; 41 return true;
42 } 42 }
43 43
44 } // namespace 44 } // namespace
45 45
46 base::NativeLibrary LoadNativeApplication(const base::FilePath& app_path, 46 base::NativeLibrary LoadNativeApplication(
47 NativeApplicationCleanup cleanup) { 47 const base::FilePath& app_path,
48 shell::NativeApplicationCleanup cleanup) {
48 DVLOG(2) << "Loading Mojo app in process from library: " << app_path.value(); 49 DVLOG(2) << "Loading Mojo app in process from library: " << app_path.value();
49 50
50 base::NativeLibraryLoadError error; 51 base::NativeLibraryLoadError error;
51 base::NativeLibrary app_library = base::LoadNativeLibrary(app_path, &error); 52 base::NativeLibrary app_library = base::LoadNativeLibrary(app_path, &error);
52 if (cleanup == NativeApplicationCleanup::DELETE) 53 if (cleanup == shell::NativeApplicationCleanup::DELETE)
53 DeleteFile(app_path, false); 54 DeleteFile(app_path, false);
54 LOG_IF(ERROR, !app_library) 55 LOG_IF(ERROR, !app_library)
55 << "Failed to load app library (error: " << error.ToString() << ")"; 56 << "Failed to load app library (error: " << error.ToString() << ")";
56 return app_library; 57 return app_library;
57 } 58 }
58 59
59 bool RunNativeApplication(base::NativeLibrary app_library, 60 bool RunNativeApplication(base::NativeLibrary app_library,
60 InterfaceRequest<Application> application_request) { 61 InterfaceRequest<Application> application_request) {
61 // Tolerate |app_library| being null, to make life easier for callers. 62 // Tolerate |app_library| being null, to make life easier for callers.
62 if (!app_library) 63 if (!app_library)
(...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after
134 } 135 }
135 // |MojoMain()| takes ownership of the service handle. 136 // |MojoMain()| takes ownership of the service handle.
136 MojoHandle handle = application_request.PassMessagePipe().release().value(); 137 MojoHandle handle = application_request.PassMessagePipe().release().value();
137 MojoResult result = main_function(handle); 138 MojoResult result = main_function(handle);
138 if (result != MOJO_RESULT_OK) { 139 if (result != MOJO_RESULT_OK) {
139 LOG(ERROR) << "MojoMain returned error (result: " << result << ")"; 140 LOG(ERROR) << "MojoMain returned error (result: " << result << ")";
140 } 141 }
141 return true; 142 return true;
142 } 143 }
143 144
144 } // namespace shell 145 } // namespace runner
145 } // namespace mojo 146 } // namespace mojo
OLDNEW
« no previous file with comments | « mojo/runner/native_application_support.h ('k') | mojo/runner/native_runner_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698