| /*============================================================================ |
| CMake - Cross Platform Makefile Generator |
| Copyright 2000-2009 Kitware, Inc., Insight Software Consortium |
| |
| Distributed under the OSI-approved BSD License (the "License"); |
| see accompanying file Copyright.txt for details. |
| |
| This software is distributed WITHOUT ANY WARRANTY; without even the |
| implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
| See the License for more information. |
| ============================================================================*/ |
| #ifndef cmListFileCache_h |
| #define cmListFileCache_h |
| |
| #include "cmStandardIncludes.h" |
| |
| #include "cmState.h" |
| |
| /** \class cmListFileCache |
| * \brief A class to cache list file contents. |
| * |
| * cmListFileCache is a class used to cache the contents of parsed |
| * cmake list files. |
| */ |
| |
| class cmMakefile; |
| |
| struct cmCommandContext |
| { |
| std::string Name; |
| long Line; |
| cmCommandContext() |
| : Name() |
| , Line(0) |
| { |
| } |
| }; |
| |
| struct cmListFileArgument |
| { |
| enum Delimiter |
| { |
| Unquoted, |
| Quoted, |
| Bracket |
| }; |
| cmListFileArgument() |
| : Value() |
| , Delim(Unquoted) |
| , Line(0) |
| { |
| } |
| cmListFileArgument(const cmListFileArgument& r) |
| : Value(r.Value) |
| , Delim(r.Delim) |
| , Line(r.Line) |
| { |
| } |
| cmListFileArgument(const std::string& v, Delimiter d, long line) |
| : Value(v) |
| , Delim(d) |
| , Line(line) |
| { |
| } |
| bool operator==(const cmListFileArgument& r) const |
| { |
| return (this->Value == r.Value) && (this->Delim == r.Delim); |
| } |
| bool operator!=(const cmListFileArgument& r) const { return !(*this == r); } |
| std::string Value; |
| Delimiter Delim; |
| long Line; |
| }; |
| |
| class cmListFileContext |
| { |
| public: |
| std::string Name; |
| std::string FilePath; |
| long Line; |
| cmListFileContext() |
| : Name() |
| , FilePath() |
| , Line(0) |
| { |
| } |
| |
| static cmListFileContext FromCommandContext(cmCommandContext const& lfcc, |
| std::string const& fileName) |
| { |
| cmListFileContext lfc; |
| lfc.FilePath = fileName; |
| lfc.Line = lfcc.Line; |
| lfc.Name = lfcc.Name; |
| return lfc; |
| } |
| }; |
| |
| std::ostream& operator<<(std::ostream&, cmListFileContext const&); |
| bool operator<(const cmListFileContext& lhs, const cmListFileContext& rhs); |
| bool operator==(cmListFileContext const& lhs, cmListFileContext const& rhs); |
| bool operator!=(cmListFileContext const& lhs, cmListFileContext const& rhs); |
| |
| struct cmListFileFunction : public cmCommandContext |
| { |
| std::vector<cmListFileArgument> Arguments; |
| }; |
| |
| // Represent a backtrace (call stack). Provide value semantics |
| // but use efficient reference-counting underneath to avoid copies. |
| class cmListFileBacktrace |
| { |
| public: |
| // Default-constructed backtrace may not be used until after |
| // set via assignment from a backtrace constructed with a |
| // valid snapshot. |
| cmListFileBacktrace(); |
| |
| // Construct an empty backtrace whose bottom sits in the directory |
| // indicated by the given valid snapshot. |
| cmListFileBacktrace(cmState::Snapshot snapshot); |
| |
| // Backtraces may be copied and assigned as values. |
| cmListFileBacktrace(cmListFileBacktrace const& r); |
| cmListFileBacktrace& operator=(cmListFileBacktrace const& r); |
| ~cmListFileBacktrace(); |
| |
| // Get a backtrace with the given file scope added to the top. |
| // May not be called until after construction with a valid snapshot. |
| cmListFileBacktrace Push(std::string const& file) const; |
| |
| // Get a backtrace with the given call context added to the top. |
| // May not be called until after construction with a valid snapshot. |
| cmListFileBacktrace Push(cmListFileContext const& lfc) const; |
| |
| // Get a backtrace with the top level removed. |
| // May not be called until after a matching Push. |
| cmListFileBacktrace Pop() const; |
| |
| // Get the context at the top of the backtrace. |
| // Returns an empty context if the backtrace is empty. |
| cmListFileContext const& Top() const; |
| |
| // Print the top of the backtrace. |
| void PrintTitle(std::ostream& out) const; |
| |
| // Print the call stack below the top of the backtrace. |
| void PrintCallStack(std::ostream& out) const; |
| |
| private: |
| struct Entry; |
| cmState::Snapshot Bottom; |
| Entry* Cur; |
| cmListFileBacktrace(cmState::Snapshot bottom, Entry* up, |
| cmListFileContext const& lfc); |
| cmListFileBacktrace(cmState::Snapshot bottom, Entry* cur); |
| }; |
| |
| struct cmListFile |
| { |
| bool ParseFile(const char* path, bool topLevel, cmMakefile* mf); |
| |
| std::vector<cmListFileFunction> Functions; |
| }; |
| |
| #endif |