summaryrefslogtreecommitdiffstats
path: root/chrome/common/chrome_paths_mac.mm
diff options
context:
space:
mode:
authormark@chromium.org <mark@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-14 22:01:26 +0000
committermark@chromium.org <mark@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-14 22:01:26 +0000
commit1405220aad5d0885a3f583e95d9a96e76455b1c7 (patch)
tree86dcdcc3d656a236a958bbf93f7851cdbd3c59c3 /chrome/common/chrome_paths_mac.mm
parent6b82c608d606fc848c3b0849204968e9e649ef86 (diff)
downloadchromium_src-1405220aad5d0885a3f583e95d9a96e76455b1c7.zip
chromium_src-1405220aad5d0885a3f583e95d9a96e76455b1c7.tar.gz
chromium_src-1405220aad5d0885a3f583e95d9a96e76455b1c7.tar.bz2
Eliminate char/wchar_t conversions, probably-unsafe statics, and disk access
when determining the framework and helper app paths on the Mac. BUG=24833 TEST=app still works, tests still pass Review URL: http://codereview.chromium.org/267102 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@29034 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/common/chrome_paths_mac.mm')
-rw-r--r--chrome/common/chrome_paths_mac.mm38
1 files changed, 11 insertions, 27 deletions
diff --git a/chrome/common/chrome_paths_mac.mm b/chrome/common/chrome_paths_mac.mm
index beb22f2..b4f28a0 100644
--- a/chrome/common/chrome_paths_mac.mm
+++ b/chrome/common/chrome_paths_mac.mm
@@ -67,34 +67,18 @@ bool GetUserDesktop(FilePath* result) {
}
FilePath GetVersionedDirectory() {
- static FilePath path;
+ // Start out with the path to the running .app.
+ NSBundle* app_bundle = [NSBundle mainBundle];
+ FilePath path = FilePath([[app_bundle bundlePath] fileSystemRepresentation]);
- if (path.empty()) {
- // Start out with the path to the running .app.
- NSBundle* app_bundle = [NSBundle mainBundle];
- path = FilePath([[app_bundle bundlePath] fileSystemRepresentation]);
-
- if (mac_util::IsBackgroundOnlyProcess()) {
- // path identifies the helper .app in the browser .app's versioned
- // directory. Go up one level to get to the browser .app's versioned
- // directory.
- path = path.DirName();
- } else {
- // path identifies the browser .app. Go into its versioned directory.
- // TODO(mark): Here, |version| comes from the outer .app bundle's
- // Info.plist. In the event of an incomplete update, it may be possible
- // for this value to be incorrect. Consider the case where the updater
- // is able to update one, but not both, of the executable and the
- // Info.plist. The executable may load one version of the framework,
- // and the Info.plist may refer to another version. Ideally, the
- // version would be available in a compile-time constant, or there would
- // be a better way to detect the loaded framework version at runtime.
- NSString* version =
- [app_bundle objectForInfoDictionaryKey:@"CFBundleShortVersionString"];
- path = path.Append("Contents").
- Append("Versions").
- Append([version fileSystemRepresentation]);
- }
+ if (mac_util::IsBackgroundOnlyProcess()) {
+ // path identifies the helper .app in the browser .app's versioned
+ // directory. Go up one level to get to the browser .app's versioned
+ // directory.
+ path = path.DirName();
+ } else {
+ // path identifies the browser .app. Go into its versioned directory.
+ path = path.Append("Contents").Append("Versions").Append(kChromeVersion);
}
return path;