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

Side by Side Diff: chrome/browser/extensions/api/messaging/native_process_launcher_posix.cc

Issue 12386018: Revert 185189. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 7 years, 9 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 (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "chrome/browser/extensions/api/messaging/native_process_launcher.h" 5 #include "chrome/browser/extensions/api/messaging/native_process_launcher.h"
6 6
7 #include "base/command_line.h" 7 #include "base/command_line.h"
8 #include "base/file_util.h" 8 #include "base/file_util.h"
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "base/posix/eintr_wrapper.h" 10 #include "base/posix/eintr_wrapper.h"
11 #include "base/process_util.h" 11 #include "base/process_util.h"
12 #include "chrome/browser/extensions/api/messaging/native_messaging_host_manifest .h"
13 12
14 namespace extensions { 13 namespace extensions {
15 14
16 namespace {
17
18 const char kNativeMessagingDirectory[] =
19 #if defined(OS_MAXOSX)
20 "/Library/Chrome/NativeMessagingHosts";
21 #else
22 "/etc/opt/chrome/native-messaging-hosts";
23 #endif
24
25 } // namespace
26
27 // static
28 scoped_ptr<NativeMessagingHostManifest>
29 NativeProcessLauncher::FindAndLoadManifest(
30 const std::string& native_host_name,
31 std::string* error_message) {
32 base::FilePath manifest_path =
33 base::FilePath(kNativeMessagingDirectory).Append(
34 native_host_name + ".json");
35 return NativeMessagingHostManifest::Load(manifest_path, error_message);
36 }
37
38 // static 15 // static
39 bool NativeProcessLauncher::LaunchNativeProcess( 16 bool NativeProcessLauncher::LaunchNativeProcess(
40 const base::FilePath& path, 17 const base::FilePath& path,
41 base::PlatformFile* read_file, 18 base::PlatformFile* read_file,
42 base::PlatformFile* write_file) { 19 base::PlatformFile* write_file) {
43 base::FileHandleMappingVector fd_map; 20 base::FileHandleMappingVector fd_map;
44 21
45 int read_pipe_fds[2] = {0}; 22 int read_pipe_fds[2] = {0};
46 if (HANDLE_EINTR(pipe(read_pipe_fds)) != 0) { 23 if (HANDLE_EINTR(pipe(read_pipe_fds)) != 0) {
47 LOG(ERROR) << "Bad read pipe"; 24 LOG(ERROR) << "Bad read pipe";
(...skipping 25 matching lines...) Expand all
73 write_pipe_read_fd.reset(); 50 write_pipe_read_fd.reset();
74 read_pipe_write_fd.reset(); 51 read_pipe_write_fd.reset();
75 52
76 *read_file = *read_pipe_read_fd.release(); 53 *read_file = *read_pipe_read_fd.release();
77 *write_file = *write_pipe_write_fd.release(); 54 *write_file = *write_pipe_write_fd.release();
78 55
79 return true; 56 return true;
80 } 57 }
81 58
82 } // namespace extensions 59 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698