summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
Diffstat (limited to 'Source')
-rw-r--r--Source/cmake.cxx38
-rw-r--r--Source/cmake.h5
2 files changed, 33 insertions, 10 deletions
diff --git a/Source/cmake.cxx b/Source/cmake.cxx
index 0a58904..5f933a1 100644
--- a/Source/cmake.cxx
+++ b/Source/cmake.cxx
@@ -3890,25 +3890,40 @@ int cmake::VisualStudioLink(std::vector<std::string>& args, int type)
expandedArgs.push_back(*i);
}
}
- // figure out if this is an incremental link or not and run the correct
- // link function.
+ bool hasIncremental = false;
+ bool hasManifest = true;
for(std::vector<std::string>::iterator i = expandedArgs.begin();
i != expandedArgs.end(); ++i)
{
if(cmSystemTools::Strucmp(i->c_str(), "/INCREMENTAL:YES") == 0)
{
- if(verbose)
- {
- std::cout << "Visual Studio Incremental Link\n";
- }
- return cmake::VisualStudioLinkIncremental(expandedArgs, type, verbose);
+ hasIncremental = true;
+ }
+ if(cmSystemTools::Strucmp(i->c_str(), "/MANIFEST:NO") == 0)
+ {
+ hasManifest = false;
+ }
+ }
+ if(hasIncremental && hasManifest)
+ {
+ if(verbose)
+ {
+ std::cout << "Visual Studio Incremental Link with embeded manifests\n";
}
+ return cmake::VisualStudioLinkIncremental(expandedArgs, type, verbose);
}
if(verbose)
{
- std::cout << "Visual Studio Non-Incremental Link\n";
+ if(!hasIncremental)
+ {
+ std::cout << "Visual Studio Non-Incremental Link\n";
+ }
+ else
+ {
+ std::cout << "Visual Studio Incremental Link without manifests\n";
+ }
}
- return cmake::VisualStudioLinkNonIncremental(expandedArgs, type, verbose);
+ return cmake::VisualStudioLinkNonIncremental(expandedArgs, type, hasManifest, verbose);
}
int cmake::ParseVisualStudioLinkCommand(std::vector<std::string>& args,
@@ -4113,6 +4128,7 @@ int cmake::VisualStudioLinkIncremental(std::vector<std::string>& args,
int cmake::VisualStudioLinkNonIncremental(std::vector<std::string>& args,
int type,
+ bool hasManifest,
bool verbose)
{
std::vector<cmStdString> linkCommand;
@@ -4126,6 +4142,10 @@ int cmake::VisualStudioLinkNonIncremental(std::vector<std::string>& args,
{
return -1;
}
+ if(!hasManifest)
+ {
+ return 0;
+ }
std::vector<cmStdString> mtCommand;
mtCommand.push_back(cmSystemTools::FindProgram("mt.exe"));
mtCommand.push_back("/nologo");
diff --git a/Source/cmake.h b/Source/cmake.h
index 8dd5ad1..1c4351a 100644
--- a/Source/cmake.h
+++ b/Source/cmake.h
@@ -416,6 +416,7 @@ protected:
bool verbose);
static int VisualStudioLinkNonIncremental(std::vector<std::string>& args,
int type,
+ bool hasManifest,
bool verbose);
static int ParseVisualStudioLinkCommand(std::vector<std::string>& args,
std::vector<cmStdString>& command,
@@ -428,7 +429,9 @@ protected:
///! Find the full path to one of the cmake programs like ctest, cpack, etc.
std::string FindCMakeProgram(const char* name) const;
-private:
+private:
+ cmake(const cmake&); // Not implemented.
+ void operator=(const cmake&); // Not implemented.
ProgressCallbackType ProgressCallback;
void* ProgressCallbackClientData;
bool Verbose;