/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying file Copyright.txt or https://cmake.org/licensing for details. */ #ifndef cmSourceFile_h #define cmSourceFile_h #include "cmConfigure.h" // IWYU pragma: keep #include "cmPropertyMap.h" #include "cmSourceFileLocation.h" #include "cmSourceFileLocationKind.h" #include #include class cmCustomCommand; class cmMakefile; /** \class cmSourceFile * \brief Represent a class loaded from a makefile. * * cmSourceFile is represents a class loaded from * a makefile. */ class cmSourceFile { public: /** * Construct with the makefile storing the source and the initial * name referencing it. */ cmSourceFile( cmMakefile* mf, const std::string& name, cmSourceFileLocationKind kind = cmSourceFileLocationKind::Ambiguous); ~cmSourceFile(); cmSourceFile(const cmSourceFile&) = delete; cmSourceFile& operator=(const cmSourceFile&) = delete; /** * Get the list of the custom commands for this source file */ cmCustomCommand* GetCustomCommand(); cmCustomCommand const* GetCustomCommand() const; void SetCustomCommand(cmCustomCommand* cc); ///! Set/Get a property of this source file void SetProperty(const std::string& prop, const char* value); void AppendProperty(const std::string& prop, const char* value, bool asString = false); ///! Might return a nullptr if the property is not set or invalid const char* GetProperty(const std::string& prop) const; ///! Always returns a valid pointer const char* GetSafeProperty(const std::string& prop) const; bool GetPropertyAsBool(const std::string& prop) const; /** Implement getting a property when called from a CMake language command like get_property or get_source_file_property. */ const char* GetPropertyForUser(const std::string& prop); ///! Checks is the GENERATED property is set and true /// @return Equivalent to GetPropertyAsBool("GENERATED") bool GetIsGenerated() const { return this->IsGenerated; } /** * The full path to the file. The non-const version of this method * may attempt to locate the file on disk and finalize its location. * The const version of this method may return an empty string if * the non-const version has not yet been called (yes this is a * horrible interface, but is necessary for backwards * compatibility). */ std::string const& GetFullPath(std::string* error = nullptr); std::string const& GetFullPath() const; /** * Get the information currently known about the source file * location without attempting to locate the file as GetFullPath * would. See cmSourceFileLocation documentation. */ cmSourceFileLocation const& GetLocation() const; /** * Get the file extension of this source file. */ std::string const& GetExtension() const; /** * Get the language of the compiler to use for this source file. */ std::string GetLanguage(); std::string GetLanguage() const; /** * Return the vector that holds the list of dependencies */ const std::vector& GetDepends() const { return this->Depends; } void AddDepend(const std::string& d) { this->Depends.push_back(d); } // Get the properties cmPropertyMap& GetProperties() { return this->Properties; } const cmPropertyMap& GetProperties() const { return this->Properties; } /** * Check whether the given source file location could refer to this * source. */ bool Matches(cmSourceFileLocation const&); void SetObjectLibrary(std::string const& objlib); std::string GetObjectLibrary() const; private: cmSourceFileLocation Location; cmPropertyMap Properties; cmCustomCommand* CustomCommand = nullptr; std::string Extension; std::string Language; std::string FullPath; std::string ObjectLibrary; std::vector Depends; bool FindFullPathFailed = false; bool IsGenerated = false; bool FindFullPath(std::string* error); void CheckExtension(); void CheckLanguage(std::string const& ext); static const std::string propLANGUAGE; static const std::string propLOCATION; static const std::string propGENERATED; }; // TODO: Factor out into platform information modules. #define CM_HEADER_REGEX "\\.(h|hh|h\\+\\+|hm|hpp|hxx|in|txx|inl)$" #define CM_SOURCE_REGEX \ "\\.(C|M|c|c\\+\\+|cc|cpp|cxx|cu|f|f90|for|fpp|ftn|m|mm|rc|def|r|odl|idl|" \ "hpj" \ "|bat)$" #define CM_RESOURCE_REGEX "\\.(pdf|plist|png|jpeg|jpg|storyboard|xcassets)$" #endif