diff options
author | Brad King <brad.king@kitware.com> | 2008-07-21 14:07:56 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2008-07-21 14:07:56 (GMT) |
commit | ff63bb1b4441e8ef2eb2eb3cfa65cc5125e0b462 (patch) | |
tree | 95dee76c0fc82860fc85c89c44ea48502389ea6c /Source | |
parent | dbb89f47aa2bcffe023fc1f2e23cb5466c331b17 (diff) | |
download | CMake-ff63bb1b4441e8ef2eb2eb3cfa65cc5125e0b462.zip CMake-ff63bb1b4441e8ef2eb2eb3cfa65cc5125e0b462.tar.gz CMake-ff63bb1b4441e8ef2eb2eb3cfa65cc5125e0b462.tar.bz2 |
ENH: Support full-path libs w/out extension in VS IDE.
- This case worked accidentally in CMake 2.4, though not in Makefiles.
- Some projects build only with the VS IDE on windows and have this
mistake.
- Support them when 2.4 compatibility is enabled by adding the extension.
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmComputeLinkInformation.cxx | 41 |
1 files changed, 40 insertions, 1 deletions
diff --git a/Source/cmComputeLinkInformation.cxx b/Source/cmComputeLinkInformation.cxx index b133e35..87157a7 100644 --- a/Source/cmComputeLinkInformation.cxx +++ b/Source/cmComputeLinkInformation.cxx @@ -1078,8 +1078,47 @@ void cmComputeLinkInformation::AddFullItem(std::string const& item) this->Items.push_back(Item(this->LibLinkFileFlag, false)); } + // Full path libraries should have an extension. CMake 2.4 would + // add the extension after splitting the file off of the directory. + // Some existing projects depended on this to build correctly + // because they left off the extension of an otherwise full-path + // library. This worked with CMake 2.4 but only for VS IDE builds + // because the file-level dependency added to the Makefile would not + // be found. Nevertheless, some projects have this mistake but work + // because they build only with the VS IDE. We need to support them + // here by adding the missing extension. + std::string final_item = item; + if(strstr(this->GlobalGenerator->GetName(), "Visual Studio") && + this->Makefile->NeedBackwardsCompatibility(2,4) && + !cmSystemTools::ComparePath( + cmSystemTools::GetFilenameLastExtension(item).c_str(), + this->LibLinkSuffix.c_str())) + { + // Issue the warning at most once. + std::string wid = "VSIDE-LINK-EXT-"; + wid += item; + if(!this->Target->GetPropertyAsBool(wid.c_str())) + { + this->Target->SetProperty(wid.c_str(), "1"); + cmOStringStream w; + w << "Target \"" << this->Target->GetName() << "\" links to " + << "full-path item\n" + << " " << item << "\n" + << "which does not have the proper link extension \"" + << this->LibLinkSuffix << "\". " + << "CMake is adding the missing extension because compatibility " + << "with CMake 2.4 is currently enabled and this case worked " + << "accidentally in that version. " + << "The link extension should be added by the project developer."; + this->Makefile->IssueMessage(cmake::AUTHOR_WARNING, w.str()); + } + + // Add the missing extension. + final_item += this->LibLinkSuffix; + } + // Now add the full path to the library. - this->Items.push_back(Item(item, true)); + this->Items.push_back(Item(final_item, true)); } //---------------------------------------------------------------------------- |