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

Side by Side Diff: shell/android/background_application_loader.h

Issue 930243006: Simplify the ApplicationLoader interface in preparation for changes. (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: ptal Created 5 years, 10 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 | « shell/android/android_handler_loader.cc ('k') | shell/android/background_application_loader.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 #ifndef SHELL_ANDROID_BACKGROUND_APPLICATION_LOADER_H_ 5 #ifndef SHELL_ANDROID_BACKGROUND_APPLICATION_LOADER_H_
6 #define SHELL_ANDROID_BACKGROUND_APPLICATION_LOADER_H_ 6 #define SHELL_ANDROID_BACKGROUND_APPLICATION_LOADER_H_
7 7
8 #include "base/macros.h" 8 #include "base/macros.h"
9 #include "base/memory/scoped_ptr.h" 9 #include "base/memory/scoped_ptr.h"
10 #include "base/message_loop/message_loop.h" 10 #include "base/message_loop/message_loop.h"
11 #include "base/synchronization/waitable_event.h" 11 #include "base/synchronization/waitable_event.h"
12 #include "base/threading/simple_thread.h" 12 #include "base/threading/simple_thread.h"
13 #include "shell/application_manager/application_loader.h" 13 #include "shell/application_manager/application_loader.h"
14 14
15 namespace mojo { 15 namespace mojo {
16 16
17 class MOJO_APPLICATION_MANAGER_EXPORT BackgroundApplicationLoader 17 class MOJO_APPLICATION_MANAGER_EXPORT BackgroundApplicationLoader
18 : public ApplicationLoader, 18 : public ApplicationLoader,
19 public base::DelegateSimpleThread::Delegate { 19 public base::DelegateSimpleThread::Delegate {
20 public: 20 public:
21 BackgroundApplicationLoader(scoped_ptr<ApplicationLoader> real_loader, 21 BackgroundApplicationLoader(scoped_ptr<ApplicationLoader> real_loader,
22 const std::string& thread_name, 22 const std::string& thread_name,
23 base::MessageLoop::Type message_loop_type); 23 base::MessageLoop::Type message_loop_type);
24 ~BackgroundApplicationLoader() override; 24 ~BackgroundApplicationLoader() override;
25 25
26 // ApplicationLoader overrides: 26 // ApplicationLoader overrides:
27 void Load(ApplicationManager* manager, 27 void Load(const GURL& url,
28 const GURL& url, 28 InterfaceRequest<Application> application_request) override;
29 InterfaceRequest<Application> application_request,
30 LoadCallback callback) override;
31 void OnApplicationError(ApplicationManager* manager, 29 void OnApplicationError(ApplicationManager* manager,
32 const GURL& url) override; 30 const GURL& url) override;
33 31
34 private: 32 private:
35 // |base::DelegateSimpleThread::Delegate| method: 33 // |base::DelegateSimpleThread::Delegate| method:
36 void Run() override; 34 void Run() override;
37 35
38 // These functions are exected on the background thread. They call through 36 // These functions are exected on the background thread. They call through
39 // to |background_loader_| to do the actual loading. 37 // to |background_loader_| to do the actual loading.
40 // TODO: having this code take a |manager| is fragile (as ApplicationManager
41 // isn't thread safe).
42 void LoadOnBackgroundThread( 38 void LoadOnBackgroundThread(
43 ApplicationManager* manager,
44 const GURL& url, 39 const GURL& url,
45 InterfaceRequest<Application> application_request); 40 InterfaceRequest<Application> application_request);
46 void OnApplicationErrorOnBackgroundThread(ApplicationManager* manager, 41 void OnApplicationErrorOnBackgroundThread(ApplicationManager* manager,
47 const GURL& url); 42 const GURL& url);
48 bool quit_on_shutdown_; 43 bool quit_on_shutdown_;
49 scoped_ptr<ApplicationLoader> loader_; 44 scoped_ptr<ApplicationLoader> loader_;
50 45
51 const base::MessageLoop::Type message_loop_type_; 46 const base::MessageLoop::Type message_loop_type_;
52 const std::string thread_name_; 47 const std::string thread_name_;
53 48
54 // Created on |thread_| during construction of |this|. Protected against 49 // Created on |thread_| during construction of |this|. Protected against
55 // uninitialized use by |message_loop_created_|, and protected against 50 // uninitialized use by |message_loop_created_|, and protected against
56 // use-after-free by holding a reference to the thread-safe object. Note 51 // use-after-free by holding a reference to the thread-safe object. Note
57 // that holding a reference won't hold |thread_| from exiting. 52 // that holding a reference won't hold |thread_| from exiting.
58 scoped_refptr<base::TaskRunner> task_runner_; 53 scoped_refptr<base::TaskRunner> task_runner_;
59 base::WaitableEvent message_loop_created_; 54 base::WaitableEvent message_loop_created_;
60 55
61 // Lives on |thread_|. 56 // Lives on |thread_|.
62 base::Closure quit_closure_; 57 base::Closure quit_closure_;
63 58
64 scoped_ptr<base::DelegateSimpleThread> thread_; 59 scoped_ptr<base::DelegateSimpleThread> thread_;
65 60
66 DISALLOW_COPY_AND_ASSIGN(BackgroundApplicationLoader); 61 DISALLOW_COPY_AND_ASSIGN(BackgroundApplicationLoader);
67 }; 62 };
68 63
69 } // namespace mojo 64 } // namespace mojo
70 65
71 #endif // SHELL_ANDROID_BACKGROUND_APPLICATION_LOADER_H_ 66 #endif // SHELL_ANDROID_BACKGROUND_APPLICATION_LOADER_H_
OLDNEW
« no previous file with comments | « shell/android/android_handler_loader.cc ('k') | shell/android/background_application_loader.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698