| // Copyright 2012 The Chromium Authors |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef BASE_BASE_PATHS_H_ |
| #define BASE_BASE_PATHS_H_ |
| |
| // This file declares path keys for the base module. These can be used with |
| // the PathService to access various special directories and files. |
| |
| #include "build/build_config.h" |
| |
| #if defined(STARBOARD) |
| #include "base/base_paths_starboard.h" |
| #else |
| #if BUILDFLAG(IS_WIN) |
| #include "base/base_paths_win.h" |
| #elif BUILDFLAG(IS_APPLE) |
| #include "base/base_paths_mac.h" |
| #elif BUILDFLAG(IS_ANDROID) |
| #include "base/base_paths_android.h" |
| #endif |
| |
| #if BUILDFLAG(IS_POSIX) |
| #include "base/base_paths_posix.h" |
| #endif |
| #endif |
| |
| namespace base { |
| |
| enum BasePathKey { |
| PATH_START = 0, |
| |
| // The following refer to the current application. |
| FILE_EXE, // Path and filename of the current executable. |
| #if !BUILDFLAG(IS_FUCHSIA) |
| // Prefer keys (e.g., DIR_ASSETS) that are specific to the use case as the |
| // module location may not work as expected on some platforms. For this |
| // reason, this key is not defined on Fuchsia. See crbug.com/1263691 for |
| // details. |
| FILE_MODULE, // Path and filename of the module containing the code for |
| // the PathService (which could differ from FILE_EXE if the |
| // PathService were compiled into a shared object, for |
| // example). |
| #endif |
| DIR_EXE, // Directory containing FILE_EXE. |
| #if !BUILDFLAG(IS_FUCHSIA) |
| // Prefer keys (e.g., DIR_ASSETS) that are specific to the use case as the |
| // module location may not work as expected on some platforms. For this |
| // reason, this key is not defined on Fuchsia. See crbug.com/1263691 for |
| // details. |
| DIR_MODULE, // Directory containing FILE_MODULE. |
| #endif |
| DIR_ASSETS, // Directory that contains application assets. |
| |
| // The following refer to system and system user directories. |
| DIR_TEMP, // Temporary directory for the system and/or user. |
| DIR_HOME, // User's root home directory. On Windows this will look |
| // like "C:\Users\<user>" which isn't necessarily a great |
| // place to put files. |
| DIR_USER_DESKTOP, // The current user's Desktop. |
| |
| // The following refer to the applications current environment. |
| DIR_CURRENT, // Current directory. |
| |
| // The following are only for use in tests. |
| // On some platforms, such as Android and Fuchsia, tests do not have access to |
| // the build file system so the necessary files are bundled with the test |
| // binary. On such platforms, these will return an appropriate path inside the |
| // bundle. |
| DIR_SRC_TEST_DATA_ROOT, // The root of files in the source tree that are |
| // made available to tests. Useful for tests that use |
| // resources that exist in the source tree. |
| DIR_SOURCE_ROOT = DIR_SRC_TEST_DATA_ROOT, // Legacy name still widely used. |
| // TODO(crbug.com/1264897): Replace |
| // all instances and remove alias. |
| DIR_GEN_TEST_DATA_ROOT, // The root of files created by the build that are |
| // made available to tests. On platforms that do |
| // not bundle test files, this is usually the |
| // directory containing the test binary. |
| DIR_TEST_DATA, // Directory containing test data for //base tests. |
| // Only for use in base_unittests. Equivalent to |
| // DIR_SRC_TEST_DATA_ROOT + "/base/test/data". |
| |
| PATH_END |
| }; |
| |
| } // namespace base |
| |
| #endif // BASE_BASE_PATHS_H_ |