diff options
author | bauerb@chromium.org <bauerb@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-07-30 10:17:07 +0000 |
---|---|---|
committer | bauerb@chromium.org <bauerb@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-07-30 10:17:07 +0000 |
commit | 96ea63d0d101ebbdbb08f79a80f3fa38bfb27ced (patch) | |
tree | f33c8f6fa3ae9fbba0178ba0cbf4f291fd3ec11e /tools/gn/source_file.h | |
parent | fb68e6c9f20785ccd0024f14b09c200060931953 (diff) | |
download | chromium_src-96ea63d0d101ebbdbb08f79a80f3fa38bfb27ced.zip chromium_src-96ea63d0d101ebbdbb08f79a80f3fa38bfb27ced.tar.gz chromium_src-96ea63d0d101ebbdbb08f79a80f3fa38bfb27ced.tar.bz2 |
Revert 214325 "Revert 214254 "Add initial prototype for the GN m..."
The issue was already fixed :)
> Revert 214254 "Add initial prototype for the GN meta-buildsystem."
>
> It broke the check_licenses step on Android (see http://build.chromium.org/p/chromium.linux/builders/Android%20Builder%20%28dbg%29/builds/39904/steps/check_licenses/logs/stdio):
>
> @@@BUILD_STEP check_licenses@@@
> > /b/build/slave/Android_Builder__dbg_/build/src/android_webview/tools/webview_licenses.py scan
> Got LicenseError "missing README.chromium or licenses.py SPECIAL_CASES entry" while scanning tools/gn/secondary/base/third_party/dynamic_annotations
> Got LicenseError "missing README.chromium or licenses.py SPECIAL_CASES entry" while scanning tools/gn/secondary/third_party/modp_b64
> < /b/build/slave/Android_Builder__dbg_/build/src/android_webview/tools/webview_licenses.py scan
> ERROR: process exited with code 2
> @@@STEP_FAILURE@@@
>
>
> > Add initial prototype for the GN meta-buildsystem.
> >
> > This is currently not hooked into the build. To build, add a reference to the
> > gn.gyp file to build/all.gyp
> >
> > R=darin@chromium.org, scottmg@chromium.org
> >
> > Review URL: https://codereview.chromium.org/21114002
>
> TBR=brettw@chromium.org
>
> Review URL: https://codereview.chromium.org/21084010
TBR=bauerb@chromium.org
Review URL: https://codereview.chromium.org/21204003
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@214333 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'tools/gn/source_file.h')
-rw-r--r-- | tools/gn/source_file.h | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/tools/gn/source_file.h b/tools/gn/source_file.h new file mode 100644 index 0000000..d883bc0 --- /dev/null +++ b/tools/gn/source_file.h @@ -0,0 +1,97 @@ +// Copyright (c) 2013 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 TOOLS_GN_SOURCE_FILE_H_ +#define TOOLS_GN_SOURCE_FILE_H_ + +#include <string> + +#include "base/containers/hash_tables.h" +#include "base/files/file_path.h" +#include "base/logging.h" +#include "base/strings/string_piece.h" + +class SourceDir; + +// Represents a file within the source tree. Always begins in a slash, never +// ends in one. +class SourceFile { + public: + SourceFile(); + + // Takes a known absolute source file. Always begins in a slash. + explicit SourceFile(const base::StringPiece& p); + + ~SourceFile(); + + bool is_null() const { return value_.empty(); } + const std::string& value() const { return value_; } + + // Returns everythign after the last slash. + std::string GetName() const; + SourceDir GetDir() const; + + // Resolves this source file relative to some given source root. Returns + // an empty file path on error. + base::FilePath Resolve(const base::FilePath& source_root) const; + + // Returns true if this file starts with a "//" which indicates a path + // from the source root. + bool is_source_absolute() const { + return value_.size() >= 2 && value_[0] == '/' && value_[1] == '/'; + } + + // Returns true if this file starts with a single slash which indicates a + // system-absolute path. + bool is_system_absolute() const { + return !is_source_absolute(); + } + + // Returns a source-absolute path starting with only one slash at the + // beginning (normally source-absolute paths start with two slashes to mark + // them as such). This is normally used when concatenating names together. + // + // This function asserts that the file is actually source-absolute. The + // return value points into our buffer. + base::StringPiece SourceAbsoluteWithOneSlash() const { + CHECK(is_source_absolute()); + return base::StringPiece(&value_[1], value_.size() - 1); + } + + bool operator==(const SourceFile& other) const { + return value_ == other.value_; + } + bool operator!=(const SourceFile& other) const { + return !operator==(other); + } + bool operator<(const SourceFile& other) const { + return value_ < other.value_; + } + + private: + friend class SourceDir; + + std::string value_; + + // Copy & assign supported. +}; + +namespace BASE_HASH_NAMESPACE { + +#if defined(COMPILER_GCC) +template<> struct hash<SourceFile> { + std::size_t operator()(const SourceFile& v) const { + hash<std::string> h; + return h(v.value()); + } +}; +#elif defined(COMPILER_MSVC) +inline size_t hash_value(const SourceFile& v) { + return hash_value(v.value()); +} +#endif // COMPILER... + +} // namespace BASE_HASH_NAMESPACE + +#endif // TOOLS_GN_SOURCE_FILE_H_ |