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

Side by Side Diff: chrome/browser/apps/app_shim/app_shim_host_mac.h

Issue 2295063002: Use ChannelMojo between app shims and the browser process. (Closed)
Patch Set: Created 4 years, 3 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 | « chrome/browser/apps/app_shim/DEPS ('k') | chrome/browser/apps/app_shim/app_shim_host_mac.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 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 #ifndef CHROME_BROWSER_APPS_APP_SHIM_APP_SHIM_HOST_MAC_H_ 5 #ifndef CHROME_BROWSER_APPS_APP_SHIM_APP_SHIM_HOST_MAC_H_
6 #define CHROME_BROWSER_APPS_APP_SHIM_APP_SHIM_HOST_MAC_H_ 6 #define CHROME_BROWSER_APPS_APP_SHIM_APP_SHIM_HOST_MAC_H_
7 7
8 #include <memory> 8 #include <memory>
9 #include <string> 9 #include <string>
10 #include <vector> 10 #include <vector>
11 11
12 #include "base/files/file_path.h" 12 #include "base/files/file_path.h"
13 #include "base/threading/non_thread_safe.h" 13 #include "base/threading/non_thread_safe.h"
14 #include "chrome/browser/apps/app_shim/app_shim_handler_mac.h" 14 #include "chrome/browser/apps/app_shim/app_shim_handler_mac.h"
15 #include "ipc/ipc_listener.h" 15 #include "ipc/ipc_listener.h"
16 #include "ipc/ipc_sender.h" 16 #include "ipc/ipc_sender.h"
17 #include "mojo/edk/embedder/scoped_platform_handle.h"
17 18
18 namespace IPC { 19 namespace IPC {
19 struct ChannelHandle;
20 class ChannelProxy; 20 class ChannelProxy;
21 class Message; 21 class Message;
22 } // namespace IPC 22 } // namespace IPC
23 23
24 // This is the counterpart to AppShimController in 24 // This is the counterpart to AppShimController in
25 // chrome/app/chrome_main_app_mode_mac.mm. The AppShimHost owns itself, and is 25 // chrome/app/chrome_main_app_mode_mac.mm. The AppShimHost owns itself, and is
26 // destroyed when the app it corresponds to is closed or when the channel 26 // destroyed when the app it corresponds to is closed or when the channel
27 // connected to the app shim is closed. 27 // connected to the app shim is closed.
28 class AppShimHost : public IPC::Listener, 28 class AppShimHost : public IPC::Listener,
29 public IPC::Sender, 29 public IPC::Sender,
30 public apps::AppShimHandler::Host, 30 public apps::AppShimHandler::Host,
31 public base::NonThreadSafe { 31 public base::NonThreadSafe {
32 public: 32 public:
33 AppShimHost(); 33 AppShimHost();
34 ~AppShimHost() override; 34 ~AppShimHost() override;
35 35
36 // Creates a new server-side IPC channel at |handle|, which should contain a 36 // Creates a new server-side IPC channel at |handle|, which should contain a
37 // file descriptor of a channel created by an UnixDomainSocketAcceptor, 37 // file descriptor of a channel created by an UnixDomainSocketAcceptor,
38 // and begins listening for messages on it. 38 // and begins listening for messages on it.
39 void ServeChannel(const IPC::ChannelHandle& handle); 39 void ServeChannel(mojo::edk::ScopedPlatformHandle handle);
40 40
41 protected: 41 protected:
42 // IPC::Listener implementation. 42 // IPC::Listener implementation.
43 bool OnMessageReceived(const IPC::Message& message) override; 43 bool OnMessageReceived(const IPC::Message& message) override;
44 void OnChannelError() override; 44 void OnChannelError() override;
45 45
46 // IPC::Sender implementation. 46 // IPC::Sender implementation.
47 bool Send(IPC::Message* message) override; 47 bool Send(IPC::Message* message) override;
48 48
49 private: 49 private:
(...skipping 27 matching lines...) Expand all
77 // Closes the channel and destroys the AppShimHost. 77 // Closes the channel and destroys the AppShimHost.
78 void Close(); 78 void Close();
79 79
80 std::unique_ptr<IPC::ChannelProxy> channel_; 80 std::unique_ptr<IPC::ChannelProxy> channel_;
81 std::string app_id_; 81 std::string app_id_;
82 base::FilePath profile_path_; 82 base::FilePath profile_path_;
83 bool initial_launch_finished_; 83 bool initial_launch_finished_;
84 }; 84 };
85 85
86 #endif // CHROME_BROWSER_APPS_APP_SHIM_APP_SHIM_HOST_MAC_H_ 86 #endif // CHROME_BROWSER_APPS_APP_SHIM_APP_SHIM_HOST_MAC_H_
OLDNEW
« no previous file with comments | « chrome/browser/apps/app_shim/DEPS ('k') | chrome/browser/apps/app_shim/app_shim_host_mac.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698