From 309191052cf83bc5535ff66e9ece04cda18d5fe5 Mon Sep 17 00:00:00 2001 From: Florian Schweiger Date: Mon, 7 Feb 2022 13:07:40 +0100 Subject: VS: Set Visual Studio versions read out from solution file --- Source/cmVisualStudioSlnData.h | 17 +++++++++++++++++ Source/cmVisualStudioSlnParser.cxx | 9 +++++++-- 2 files changed, 24 insertions(+), 2 deletions(-) diff --git a/Source/cmVisualStudioSlnData.h b/Source/cmVisualStudioSlnData.h index b217bd8..19e58f5 100644 --- a/Source/cmVisualStudioSlnData.h +++ b/Source/cmVisualStudioSlnData.h @@ -31,6 +31,22 @@ private: class cmSlnData { public: + std::string GetVisualStudioVersion() const { return visualStudioVersion; } + void SetVisualStudioVersion(const std::string& version) + { + visualStudioVersion = version; + } + + std::string GetMinimumVisualStudioVersion() const + { + return minimumVisualStudioVersion; + } + + void SetMinimumVisualStudioVersion(const std::string& version) + { + minimumVisualStudioVersion = version; + } + const cmSlnProjectEntry* GetProjectByGUID( const std::string& projectGUID) const; @@ -44,6 +60,7 @@ public: const std::string& projectRelativePath); private: + std::string visualStudioVersion, minimumVisualStudioVersion; using ProjectStorage = std::map; ProjectStorage ProjectsByGUID; using ProjectStringIndex = std::map; diff --git a/Source/cmVisualStudioSlnParser.cxx b/Source/cmVisualStudioSlnParser.cxx index d900a95..8138f4c 100644 --- a/Source/cmVisualStudioSlnParser.cxx +++ b/Source/cmVisualStudioSlnParser.cxx @@ -219,9 +219,14 @@ bool cmVisualStudioSlnParser::State::Process( this->Stack.push(FileStateProject); } else this->IgnoreUntilTag("EndProject"); - } else if (line.GetTag().compare("Global") == 0) + } else if (line.GetTag().compare("Global") == 0) { + this->Stack.push(FileStateGlobal); - else { + } else if (line.GetTag().compare("VisualStudioVersion") == 0) { + output.SetVisualStudioVersion(line.GetValue(0)); + } else if (line.GetTag().compare("MinimumVisualStudioVersion") == 0) { + output.SetMinimumVisualStudioVersion(line.GetValue(0)); + } else { result.SetError(ResultErrorInputStructure, this->GetCurrentLine()); return false; } -- cgit v0.12