diff options
author | Bill Hoffman <bill.hoffman@kitware.com> | 2009-07-11 04:05:20 (GMT) |
---|---|---|
committer | Bill Hoffman <bill.hoffman@kitware.com> | 2009-07-11 04:05:20 (GMT) |
commit | 28b1912aa3eba8427cc3d0a4954f7366fcb338b9 (patch) | |
tree | 180a95ccff9004c9e0997c7004ae1a96bb8a5c35 | |
parent | 2e22b70aa2c76ab5c980a566b72d043be0deb670 (diff) | |
download | CMake-28b1912aa3eba8427cc3d0a4954f7366fcb338b9.zip CMake-28b1912aa3eba8427cc3d0a4954f7366fcb338b9.tar.gz CMake-28b1912aa3eba8427cc3d0a4954f7366fcb338b9.tar.bz2 |
ENH: add group support and fix borland error
-rw-r--r-- | Source/cmLocalGenerator.h | 8 | ||||
-rw-r--r-- | Source/cmMakefile.cxx | 2 | ||||
-rw-r--r-- | Source/cmSourceGroup.cxx | 16 | ||||
-rw-r--r-- | Source/cmSourceGroup.h | 10 | ||||
-rw-r--r-- | Source/cmVisualStudio10TargetGenerator.cxx | 170 | ||||
-rw-r--r-- | Source/cmVisualStudio10TargetGenerator.h | 4 | ||||
-rw-r--r-- | Tests/SourceGroups/CMakeLists.txt | 2 | ||||
-rw-r--r-- | Tests/SourceGroups/README.txt | 1 |
8 files changed, 164 insertions, 49 deletions
diff --git a/Source/cmLocalGenerator.h b/Source/cmLocalGenerator.h index 6ef2c43..94cf510 100644 --- a/Source/cmLocalGenerator.h +++ b/Source/cmLocalGenerator.h @@ -302,6 +302,10 @@ public: /** Construct a comment for a custom command. */ std::string ConstructComment(const cmCustomCommand& cc, const char* default_comment = ""); + // Compute object file names. + std::string GetObjectFileNameWithoutTarget(const cmSourceFile& source, + std::string const& dir_max, + bool* hasSourceExtension = 0); protected: /** Fill out these strings for the given target. Libraries to link, @@ -346,10 +350,6 @@ protected: std::ostream& os, const char* config, std::vector<std::string> const& configurationTypes); - // Compute object file names. - std::string GetObjectFileNameWithoutTarget(const cmSourceFile& source, - std::string const& dir_max, - bool* hasSourceExtension = 0); std::string& CreateSafeUniqueObjectFileName(const char* sin, std::string const& dir_max); diff --git a/Source/cmMakefile.cxx b/Source/cmMakefile.cxx index f2486c5..3451c4d 100644 --- a/Source/cmMakefile.cxx +++ b/Source/cmMakefile.cxx @@ -1958,7 +1958,7 @@ void cmMakefile::AddSourceGroup(const std::vector<std::string>& name, // build the whole source group path for(++i; i<=lastElement; ++i) { - sg->AddChild(cmSourceGroup(name[i].c_str(), 0)); + sg->AddChild(cmSourceGroup(name[i].c_str(), 0, sg->GetFullName())); sg = sg->lookupChild(name[i].c_str()); } diff --git a/Source/cmSourceGroup.cxx b/Source/cmSourceGroup.cxx index d64ba3e..d4fd306 100644 --- a/Source/cmSourceGroup.cxx +++ b/Source/cmSourceGroup.cxx @@ -23,10 +23,17 @@ public: }; //---------------------------------------------------------------------------- -cmSourceGroup::cmSourceGroup(const char* name, const char* regex): Name(name) +cmSourceGroup::cmSourceGroup(const char* name, const char* regex, + const char* parentName): Name(name) { this->Internal = new cmSourceGroupInternals; this->SetGroupRegex(regex); + if(parentName) + { + this->FullName = parentName; + this->FullName += "\\"; + } + this->FullName += this->Name; } //---------------------------------------------------------------------------- @@ -39,6 +46,7 @@ cmSourceGroup::~cmSourceGroup() cmSourceGroup::cmSourceGroup(cmSourceGroup const& r) { this->Name = r.Name; + this->FullName = r.FullName; this->GroupRegex = r.GroupRegex; this->GroupFiles = r.GroupFiles; this->SourceFiles = r.SourceFiles; @@ -80,6 +88,12 @@ const char* cmSourceGroup::GetName() const { return this->Name.c_str(); } + +//---------------------------------------------------------------------------- +const char* cmSourceGroup::GetFullName() const +{ + return this->FullName.c_str(); +} //---------------------------------------------------------------------------- bool cmSourceGroup::MatchesRegex(const char* name) diff --git a/Source/cmSourceGroup.h b/Source/cmSourceGroup.h index 1e64bc1..83778e1 100644 --- a/Source/cmSourceGroup.h +++ b/Source/cmSourceGroup.h @@ -37,7 +37,8 @@ class cmSourceGroupInternals; class cmSourceGroup { public: - cmSourceGroup(const char* name, const char* regex); + cmSourceGroup(const char* name, const char* regex, + const char* parentName=0); cmSourceGroup(cmSourceGroup const& r); ~cmSourceGroup(); cmSourceGroup& operator=(cmSourceGroup const&); @@ -66,6 +67,11 @@ public: * Get the name of this group. */ const char* GetName() const; + + /** + * Get the full path name for group. + */ + const char* GetFullName() const; /** * Check if the given name matches this group's regex. @@ -107,6 +113,8 @@ private: * The name of the source group. */ std::string Name; + // Full path to group + std::string FullName; /** * The regular expression matching the files in the group. diff --git a/Source/cmVisualStudio10TargetGenerator.cxx b/Source/cmVisualStudio10TargetGenerator.cxx index 5da4e94..289510f 100644 --- a/Source/cmVisualStudio10TargetGenerator.cxx +++ b/Source/cmVisualStudio10TargetGenerator.cxx @@ -331,35 +331,137 @@ void cmVisualStudio10TargetGenerator::ConvertToWindowsSlash(std::string& s) } } void cmVisualStudio10TargetGenerator::WriteGroups() -{ - // This should create a target.vcxproj.filters file - // something like this: +{ + // collect up group information + std::vector<cmSourceGroup> sourceGroups = + this->Makefile->GetSourceGroups(); + std::vector<cmSourceFile*> classes = this->Target->GetSourceFiles(); + + std::set<cmSourceGroup*> groupsUsed; + std::vector<cmSourceFile*> clCompile; + std::vector<cmSourceFile*> customBuild; + std::vector<cmSourceFile*> none; -/* - <?xml version="1.0" encoding="utf-8"?> -<Project ToolsVersion="4.0" -xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> - <ItemGroup> - <CustomBuild Include="..\CMakeLists.txt" /> - </ItemGroup> - <ItemGroup> - <Filter Include="Source Files"> - <UniqueIdentifier>{05072589-c7be-439a-8fd7-5db6ee5008a9} - </UniqueIdentifier> - </Filter> - </ItemGroup> - <ItemGroup> - <ClCompile Include="..\foo.c"> - <Filter>Source Files</Filter> - </ClCompile> - <ClCompile Include="..\testCCompiler.c"> - <Filter>Source Files</Filter> - </ClCompile> - </ItemGroup> -</Project> -*/ + for(std::vector<cmSourceFile*>::const_iterator s = classes.begin(); + s != classes.end(); s++) + { + cmSourceFile* sf = *s; + std::string const& source = sf->GetFullPath(); + cmSourceGroup& sourceGroup = + this->Makefile->FindSourceGroup(source.c_str(), sourceGroups); + groupsUsed.insert(&sourceGroup); + const char* lang = sf->GetLanguage(); + if(!lang) + { + lang = "None"; + } + if(lang[0] == 'C') + { + clCompile.push_back(sf); + } + else if(sf->GetCustomCommand()) + { + customBuild.push_back(sf); + } + else + { + none.push_back(sf); + } + } + // Write out group file + std::string path = this->Makefile->GetStartOutputDirectory(); + path += "/"; + path += this->Target->GetName(); + path += ".vcxproj.filters"; + cmGeneratedFileStream fout(path.c_str()); + char magic[] = {0xEF,0xBB, 0xBF}; + fout.write(magic, 3); + cmGeneratedFileStream* save = this->BuildFileStream; + this->BuildFileStream = & fout; + this->WriteString("<?xml version=\"1.0\" encoding=\"utf-8\"?>\n" + "<Project " + "ToolsVersion=\"4.0\" " + "xmlns=\"http://schemas.microsoft.com/" + "developer/msbuild/2003\">\n", + 0); + this->WriteGroupSources("ClCompile", clCompile, sourceGroups); + this->WriteGroupSources("CustomBuild", customBuild, sourceGroups); + + this->WriteString("<ItemGroup>\n", 1); + for(std::set<cmSourceGroup*>::iterator g = groupsUsed.begin(); + g != groupsUsed.end(); ++g) + { + cmSourceGroup* sg = *g; + const char* name = sg->GetFullName(); + if(strlen(name) != 0) + { + this->WriteString("<Filter Include=\"", 2); + (*this->BuildFileStream) << name << "\">\n"; + std::string guidName = "SG_Filter_"; + guidName += name; + this->GlobalGenerator->CreateGUID(guidName.c_str()); + this->WriteString("<UniqueIdentifier>", 3); + std::string guid + = this->GlobalGenerator->GetGUID(guidName.c_str()); + (*this->BuildFileStream) + << "{" + << guid << "}" + << "</UniqueIdentifier>\n"; + this->WriteString("</Filter>\n", 2); + } + } + this->WriteString("</ItemGroup>\n", 1); + this->WriteGroupSources("None", none, sourceGroups); + this->WriteString("</Project>\n", 0); + // restore stream pointer + this->BuildFileStream = save; } +void +cmVisualStudio10TargetGenerator:: +WriteGroupSources(const char* name, + std::vector<cmSourceFile*> const& sources, + std::vector<cmSourceGroup>& sourceGroups) +{ + this->WriteString("<ItemGroup>\n", 1); + for(std::vector<cmSourceFile*>::const_iterator s = sources.begin(); + s != sources.end(); ++s) + { + cmSourceFile* sf = *s; + std::string const& source = sf->GetFullPath(); + cmSourceGroup& sourceGroup = + this->Makefile->FindSourceGroup(source.c_str(), sourceGroups); + const char* filter = sourceGroup.GetFullName(); + this->WriteString("<", 2); + std::string path = source; + // custom command source are done with relative paths + // so that the custom command display in the GUI + // the source groups have to EXACTLY match the string + // used in the .vcxproj file + if(sf->GetCustomCommand()) + { + path = cmSystemTools::RelativePath( + this->Makefile->GetCurrentOutputDirectory(), + source.c_str()); + } + this->ConvertToWindowsSlash(path); + (*this->BuildFileStream) << name << " Include=\"" + << path; + if(strlen(filter)) + { + (*this->BuildFileStream) << "\">\n"; + this->WriteString("<Filter>", 3); + (*this->BuildFileStream) << filter << "</Filter>\n"; + this->WriteString("</", 2); + (*this->BuildFileStream) << name << ">\n"; + } + else + { + (*this->BuildFileStream) << "\" />\n"; + } + } + this->WriteString("</ItemGroup>\n", 1); +} void cmVisualStudio10TargetGenerator::WriteObjSources() { @@ -412,6 +514,7 @@ void cmVisualStudio10TargetGenerator::WriteCLSources() if(lang && (strcmp(lang, "C") == 0 || strcmp(lang, "CXX") ==0)) { std::string sourceFile = (*source)->GetFullPath(); + this->ConvertToWindowsSlash(sourceFile); // output the source file this->WriteString("<ClCompile Include=\"", 2); (*this->BuildFileStream ) << sourceFile << "\""; @@ -1025,21 +1128,6 @@ WriteMidlOptions(std::string const& /*config*/, { this->WriteString("<Midl>\n", 2); this->OutputIncludes(includes); - // Need this stuff, but there is an midl.xml file... - // should we look for .idl language?, and flags? - /* - <MkTypLibCompatible>false</MkTypLibCompatible> - <TargetEnvironment>Win32</TargetEnvironment> - <GenerateStublessProxies>true</GenerateStublessProxies> - <TypeLibraryName>%(FileName).tlb</TypeLibraryName> - <OutputDirectory>$(IntDir)\</OutputDirectory> - <HeaderFileName>%(FileName).h</HeaderFileName> - <DllDataFileName> - </DllDataFileName> - <InterfaceIdentifierFileName>%(FileName)_i.c - </InterfaceIdentifierFileName> - <ProxyFileName>%(FileName)_p.c</ProxyFileName> - */ this->WriteString("</Midl>\n", 2); } diff --git a/Source/cmVisualStudio10TargetGenerator.h b/Source/cmVisualStudio10TargetGenerator.h index 7564a86..81e15f8 100644 --- a/Source/cmVisualStudio10TargetGenerator.h +++ b/Source/cmVisualStudio10TargetGenerator.h @@ -26,6 +26,7 @@ class cmSourceFile; class cmCustomCommand; class cmLocalVisualStudio7Generator; class cmComputeLinkInformation; +#include "cmSourceGroup.h" class cmVisualStudio10TargetGenerator { @@ -74,6 +75,9 @@ private: void WriteEvent(const char* name, std::vector<cmCustomCommand> & commands, std::string const& configName); void ComputeObjectNames(); + void WriteGroupSources(const char* name, + std::vector<cmSourceFile*> const& sources, + std::vector<cmSourceGroup>& ); private: std::string ModuleDefinitionFile; std::string PathToVcxproj; diff --git a/Tests/SourceGroups/CMakeLists.txt b/Tests/SourceGroups/CMakeLists.txt index b665115..e57e019 100644 --- a/Tests/SourceGroups/CMakeLists.txt +++ b/Tests/SourceGroups/CMakeLists.txt @@ -31,5 +31,5 @@ source_group(Base\\Sub1\\Base FILES bar.c) source_group(EmptyGroup) -add_executable(SourceGroups main.c bar.c foo.c sub1/foo.c sub1/foobar.c baz.c) +add_executable(SourceGroups main.c bar.c foo.c sub1/foo.c sub1/foobar.c baz.c README.txt) diff --git a/Tests/SourceGroups/README.txt b/Tests/SourceGroups/README.txt new file mode 100644 index 0000000..1a4baf5 --- /dev/null +++ b/Tests/SourceGroups/README.txt @@ -0,0 +1 @@ + |