| // Copyright (c) 2010 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef CHROME_COMMON_CHROME_PATHS_INTERNAL_H_ |
| #define CHROME_COMMON_CHROME_PATHS_INTERNAL_H_ |
| #pragma once |
| |
| #include "build/build_config.h" |
| |
| class FilePath; |
| |
| namespace chrome { |
| |
| // Get the path to the user's data directory, regardless of whether |
| // DIR_USER_DATA has been overridden by a command-line option. |
| bool GetDefaultUserDataDirectory(FilePath* result); |
| |
| // This returns the base directory in which Chrome Frame stores user profiles. |
| // Note that this cannot be wrapped in a preprocessor define since |
| // CF and Google Chrome want to share the same binaries. |
| bool GetChromeFrameUserDataDirectory(FilePath* result); |
| |
| // Get the path to the user's cache directory. This is normally the |
| // same as the profile directory, but on Linux it can also be |
| // $XDG_CACHE_HOME and on Mac it can be under ~/Library/Caches. |
| // Note that the Chrome cache directories are actually subdirectories |
| // of this directory, with names like "Cache" and "Media Cache". |
| // This will always fill in |result| with a directory, sometimes |
| // just |profile_dir|. |
| void GetUserCacheDirectory(const FilePath& profile_dir, FilePath* result); |
| |
| // Get the path to the user's documents directory. |
| bool GetUserDocumentsDirectory(FilePath* result); |
| |
| #if defined (OS_WIN) |
| // Gets the path to a safe default download directory for a user. |
| bool GetUserDownloadsDirectorySafe(FilePath* result); |
| #endif |
| |
| // Get the path to the user's downloads directory. |
| bool GetUserDownloadsDirectory(FilePath* result); |
| |
| // The path to the user's desktop. |
| bool GetUserDesktop(FilePath* result); |
| |
| #if defined(OS_MACOSX) |
| // The "versioned directory" is a directory in the browser .app bundle. It |
| // contains the bulk of the application, except for the things that the system |
| // requires be located at spepcific locations. The versioned directory is |
| // in the .app at Contents/Versions/w.x.y.z. |
| FilePath GetVersionedDirectory(); |
| |
| // This overrides the directory returned by |GetVersionedDirectory()|, to be |
| // used when |GetVersionedDirectory()| can't automatically determine the proper |
| // location. This is the case when the browser didn't load itself but by, e.g., |
| // the app mode loader. This should be called before |ChromeMain()|. This takes |
| // ownership of the object |path| and the caller must not delete it. |
| void SetOverrideVersionedDirectory(const FilePath* path); |
| |
| // Most of the application is further contained within the framework. The |
| // framework bundle is located within the versioned directory at a specific |
| // path. The only components in the versioned directory not included in the |
| // framework are things that also depend on the framework, such as the helper |
| // app bundle. |
| FilePath GetFrameworkBundlePath(); |
| |
| // Get the local library directory. |
| bool GetLocalLibraryDirectory(FilePath* result); |
| |
| #endif // OS_MACOSX |
| |
| } // namespace chrome |
| |
| #endif // CHROME_COMMON_CHROME_PATHS_INTERNAL_H_ |