瀏覽代碼

cmGlobalVisualStudioGenerator: Consolidate solution generation methods

Brad King 1 月之前
父節點
當前提交
6a77c80834
共有 2 個文件被更改,包括 11 次插入18 次删除
  1. 9 13
      Source/cmGlobalVisualStudioGenerator.cxx
  2. 2 5
      Source/cmGlobalVisualStudioGenerator.h

+ 9 - 13
Source/cmGlobalVisualStudioGenerator.cxx

@@ -39,7 +39,7 @@
 #include "cmake.h"
 
 namespace {
-std::string GetSLNFile(cmLocalGenerator* root)
+std::string GetSLNFile(cmLocalGenerator const* root)
 {
   return cmStrCat(root->GetCurrentBinaryDirectory(), '/',
                   root->GetProjectName(), ".sln");
@@ -1099,7 +1099,7 @@ void cmGlobalVisualStudioGenerator::Generate()
 
   // Now write out the VS Solution files.
   for (auto& it : this->ProjectMap) {
-    this->OutputSLNFile(it.second[0], it.second);
+    this->GenerateSolution(it.second[0], it.second);
   }
 
   // If any solution or project files changed during the generation,
@@ -1131,8 +1131,9 @@ void cmGlobalVisualStudioGenerator::Generate()
   }
 }
 
-void cmGlobalVisualStudioGenerator::OutputSLNFile(
-  cmLocalGenerator* root, std::vector<cmLocalGenerator*>& generators)
+void cmGlobalVisualStudioGenerator::GenerateSolution(
+  cmLocalGenerator const* root,
+  std::vector<cmLocalGenerator*> const& generators)
 {
   if (generators.empty()) {
     return;
@@ -1149,16 +1150,11 @@ void cmGlobalVisualStudioGenerator::OutputSLNFile(
   if (!fout) {
     return;
   }
-  this->WriteSLNFile(fout, root, projectTargets);
-  if (fout.Close()) {
-    this->FileReplacedDuringGenerate(fname);
-  }
-}
 
-void cmGlobalVisualStudioGenerator::WriteSLNFile(
-  std::ostream& fout, cmLocalGenerator* root,
-  TargetDependSet const& projectTargets) const
-{
   cm::VS::Solution const solution = this->CreateSolution(root, projectTargets);
   WriteSln(fout, solution);
+
+  if (fout.Close()) {
+    this->FileReplacedDuringGenerate(fname);
+  }
 }

+ 2 - 5
Source/cmGlobalVisualStudioGenerator.h

@@ -198,11 +198,8 @@ protected:
 
   void Generate() override;
 
-  void OutputSLNFile(cmLocalGenerator* root,
-                     std::vector<cmLocalGenerator*>& generators);
-
-  void WriteSLNFile(std::ostream& fout, cmLocalGenerator* root,
-                    TargetDependSet const& projectTargets) const;
+  void GenerateSolution(cmLocalGenerator const* root,
+                        std::vector<cmLocalGenerator*> const& generators);
 
 private:
   virtual std::string GetVSMakeProgram() = 0;