| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- /*============================================================================
- CMake - Cross Platform Makefile Generator
- Copyright 2000-2012 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 cmGeneratorTarget_h
- #define cmGeneratorTarget_h
- #include "cmStandardIncludes.h"
- class cmCustomCommand;
- class cmGlobalGenerator;
- class cmLocalGenerator;
- class cmMakefile;
- class cmSourceFile;
- class cmTarget;
- class cmGeneratorTarget
- {
- public:
- cmGeneratorTarget(cmTarget*);
- int GetType() const;
- const char *GetName() const;
- const char *GetProperty(const std::string& prop) const;
- bool GetPropertyAsBool(const std::string& prop) const;
- void GetSourceFiles(std::vector<cmSourceFile*>& files) const;
- void GetObjectSources(std::vector<cmSourceFile*> &) const;
- const std::string& GetObjectName(cmSourceFile const* file);
- void AddObject(cmSourceFile *sf, std::string const&name);
- bool HasExplicitObjectName(cmSourceFile const* file) const;
- void AddExplicitObjectName(cmSourceFile* sf);
- void GetResxSources(std::vector<cmSourceFile*>&) const;
- void GetIDLSources(std::vector<cmSourceFile*>&) const;
- void GetExternalObjects(std::vector<cmSourceFile*>&) const;
- void GetHeaderSources(std::vector<cmSourceFile*>&) const;
- void GetExtraSources(std::vector<cmSourceFile*>&) const;
- void GetCustomCommands(std::vector<cmSourceFile*>&) const;
- void GetExpectedResxHeaders(std::set<std::string>&) const;
- cmTarget* Target;
- cmMakefile* Makefile;
- cmLocalGenerator* LocalGenerator;
- cmGlobalGenerator const* GlobalGenerator;
- std::string GetModuleDefinitionFile() const;
- /** Full path with trailing slash to the top-level directory
- holding object files for this target. Includes the build
- time config name placeholder if needed for the generator. */
- std::string ObjectDirectory;
- void UseObjectLibraries(std::vector<std::string>& objs) const;
- void GetAppleArchs(const char* config,
- std::vector<std::string>& archVec) const;
- ///! Return the rule variable used to create this type of target,
- // need to add CMAKE_(LANG) for full name.
- const char* GetCreateRuleVariable() const;
- /** Get the include directories for this target. */
- std::vector<std::string> GetIncludeDirectories(const char *config) const;
- bool IsSystemIncludeDirectory(const char *dir, const char *config) const;
- /** Add the target output files to the global generator manifest. */
- void GenerateTargetManifest(const char* config) const;
- /**
- * Trace through the source files in this target and add al source files
- * that they depend on, used by all generators
- */
- void TraceDependencies();
- void LookupObjectLibraries();
- /** Get sources that must be built before the given source. */
- std::vector<cmSourceFile*> const* GetSourceDepends(cmSourceFile* sf) const;
- /**
- * Flags for a given source file as used in this target. Typically assigned
- * via SET_TARGET_PROPERTIES when the property is a list of source files.
- */
- enum SourceFileType
- {
- SourceFileTypeNormal,
- SourceFileTypePrivateHeader, // is in "PRIVATE_HEADER" target property
- SourceFileTypePublicHeader, // is in "PUBLIC_HEADER" target property
- SourceFileTypeResource, // is in "RESOURCE" target property *or*
- // has MACOSX_PACKAGE_LOCATION=="Resources"
- SourceFileTypeMacContent // has MACOSX_PACKAGE_LOCATION!="Resources"
- };
- struct SourceFileFlags
- {
- SourceFileFlags(): Type(SourceFileTypeNormal), MacFolder(0) {}
- SourceFileFlags(SourceFileFlags const& r):
- Type(r.Type), MacFolder(r.MacFolder) {}
- SourceFileType Type;
- const char* MacFolder; // location inside Mac content folders
- };
- struct SourceFileFlags
- GetTargetSourceFileFlags(const cmSourceFile* sf) const;
- struct ResxData {
- mutable std::set<std::string> ExpectedResxHeaders;
- mutable std::vector<cmSourceFile*> ResxSources;
- };
- private:
- friend class cmTargetTraceDependencies;
- struct SourceEntry { std::vector<cmSourceFile*> Depends; };
- typedef std::map<cmSourceFile*, SourceEntry> SourceEntriesType;
- SourceEntriesType SourceEntries;
- std::map<cmSourceFile const*, std::string> Objects;
- std::set<cmSourceFile const*> ExplicitObjectName;
- mutable std::vector<cmSourceFile*> ObjectSources;
- std::vector<cmTarget*> ObjectLibraries;
- mutable std::map<std::string, std::vector<std::string> > SystemIncludesCache;
- void ConstructSourceFileFlags() const;
- mutable bool SourceFileFlagsConstructed;
- mutable std::map<cmSourceFile const*, SourceFileFlags> SourceFlagsMap;
- cmGeneratorTarget(cmGeneratorTarget const&);
- void operator=(cmGeneratorTarget const&);
- };
- struct cmStrictTargetComparison {
- bool operator()(cmTarget const* t1, cmTarget const* t2) const;
- };
- typedef std::map<cmTarget const*,
- cmGeneratorTarget*,
- cmStrictTargetComparison> cmGeneratorTargetsType;
- #endif
|