From acf33ba191156c65682166f31a01e5d184b482ed Mon Sep 17 00:00:00 2001 From: Brad King Date: Tue, 11 Apr 2006 11:40:24 -0400 Subject: BUG: Do not add non-per-config subdirectory name of cmake target libraries as full path libs. --- Source/cmLocalGenerator.cxx | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/Source/cmLocalGenerator.cxx b/Source/cmLocalGenerator.cxx index bd4b9b0..a8b038e 100644 --- a/Source/cmLocalGenerator.cxx +++ b/Source/cmLocalGenerator.cxx @@ -1399,6 +1399,8 @@ cmLocalGenerator::ComputeLinkInformation(cmTarget& target, linkItem += "/"; linkItem += tgt->GetFullName(config); linkLibraries.push_back(linkItem); + + // For full path, use the true location. if(fullPathLibs) { fullPathLibs->push_back(tgt->GetFullPath(config)); @@ -1408,6 +1410,14 @@ cmLocalGenerator::ComputeLinkInformation(cmTarget& target, { // This is not a CMake target. Use the name given. linkLibraries.push_back(lib); + + // Add to the list of full paths if this library is one. + if(fullPathLibs && + cmSystemTools::FileIsFullPath(lib.c_str()) && + !cmSystemTools::FileIsDirectory(lib.c_str())) + { + fullPathLibs->push_back(lib); + } } } } @@ -1450,10 +1460,6 @@ cmLocalGenerator::ComputeLinkInformation(cmTarget& target, orderLibs.DetermineLibraryPathOrder(); std::vector orderedLibs; orderLibs.GetLinkerInformation(outDirs, orderedLibs); - if(fullPathLibs) - { - orderLibs.GetFullPathLibraries(*fullPathLibs); - } // Make sure libraries are linked with the proper syntax. std::string libLinkFlag = -- cgit v0.12