blob: 3cea49ea3481cc6e8039f11159b4b6c8994c8c54 [file] [log] [blame]
// 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_