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

Side by Side Diff: chrome/common/chrome_paths_mac.mm

Issue 267102: Better code to determine the framework and helper app paths (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 11 years, 2 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) 2006-2008 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2006-2008 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/common/chrome_paths_internal.h" 5 #include "chrome/common/chrome_paths_internal.h"
6 6
7 #import <Cocoa/Cocoa.h> 7 #import <Cocoa/Cocoa.h>
8 8
9 #include "base/base_paths.h" 9 #include "base/base_paths.h"
10 #include "base/logging.h" 10 #include "base/logging.h"
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after
60 NSUserDomainMask, 60 NSUserDomainMask,
61 YES); 61 YES);
62 if ([docArray count] && result) { 62 if ([docArray count] && result) {
63 *result = FilePath([[docArray objectAtIndex:0] fileSystemRepresentation]); 63 *result = FilePath([[docArray objectAtIndex:0] fileSystemRepresentation]);
64 success = true; 64 success = true;
65 } 65 }
66 return success; 66 return success;
67 } 67 }
68 68
69 FilePath GetVersionedDirectory() { 69 FilePath GetVersionedDirectory() {
70 static FilePath path; 70 // Start out with the path to the running .app.
71 NSBundle* app_bundle = [NSBundle mainBundle];
TVL 2009/10/14 21:09:15 since the concern in here was threading, http://de
Mark Mentovai 2009/10/14 21:26:46 TVL wrote:
72 FilePath path = FilePath([[app_bundle bundlePath] fileSystemRepresentation]);
71 73
72 if (path.empty()) { 74 if (mac_util::IsBackgroundOnlyProcess()) {
73 // Start out with the path to the running .app. 75 // path identifies the helper .app in the browser .app's versioned
74 NSBundle* app_bundle = [NSBundle mainBundle]; 76 // directory. Go up one level to get to the browser .app's versioned
75 path = FilePath([[app_bundle bundlePath] fileSystemRepresentation]); 77 // directory.
76 78 path = path.DirName();
77 if (mac_util::IsBackgroundOnlyProcess()) { 79 } else {
78 // path identifies the helper .app in the browser .app's versioned 80 // path identifies the browser .app. Go into its versioned directory.
79 // directory. Go up one level to get to the browser .app's versioned 81 path = path.Append("Contents").Append("Versions").Append(kChromeVersion);
80 // directory.
81 path = path.DirName();
82 } else {
83 // path identifies the browser .app. Go into its versioned directory.
84 // TODO(mark): Here, |version| comes from the outer .app bundle's
85 // Info.plist. In the event of an incomplete update, it may be possible
86 // for this value to be incorrect. Consider the case where the updater
87 // is able to update one, but not both, of the executable and the
88 // Info.plist. The executable may load one version of the framework,
89 // and the Info.plist may refer to another version. Ideally, the
90 // version would be available in a compile-time constant, or there would
91 // be a better way to detect the loaded framework version at runtime.
92 NSString* version =
93 [app_bundle objectForInfoDictionaryKey:@"CFBundleShortVersionString"];
94 path = path.Append("Contents").
95 Append("Versions").
96 Append([version fileSystemRepresentation]);
97 }
98 } 82 }
99 83
100 return path; 84 return path;
101 } 85 }
102 86
103 FilePath GetFrameworkBundlePath() { 87 FilePath GetFrameworkBundlePath() {
104 // It's tempting to use +[NSBundle bundleWithIdentifier:], but it's really 88 // It's tempting to use +[NSBundle bundleWithIdentifier:], but it's really
105 // slow (about 30ms on 10.5 and 10.6), despite Apple's documentation stating 89 // slow (about 30ms on 10.5 and 10.6), despite Apple's documentation stating
106 // that it may be more efficient than +bundleForClass:. +bundleForClass: 90 // that it may be more efficient than +bundleForClass:. +bundleForClass:
107 // itself takes 1-2ms. Getting an NSBundle from a path, on the other hand, 91 // itself takes 1-2ms. Getting an NSBundle from a path, on the other hand,
108 // essentially takes no time at all, at least when the bundle has already 92 // essentially takes no time at all, at least when the bundle has already
109 // been loaded as it will have been in this case. The FilePath operations 93 // been loaded as it will have been in this case. The FilePath operations
110 // needed to compute the framework's path are also effectively free, so that 94 // needed to compute the framework's path are also effectively free, so that
111 // is the approach that is used here. 95 // is the approach that is used here.
112 96
113 // The framework bundle is at a known path and name from the browser .app's 97 // The framework bundle is at a known path and name from the browser .app's
114 // versioned directory. 98 // versioned directory.
115 return GetVersionedDirectory().Append(kFrameworkName); 99 return GetVersionedDirectory().Append(kFrameworkName);
116 } 100 }
117 101
118 } // namespace chrome 102 } // namespace chrome
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698