diff options
-rw-r--r-- | Source/cmLocalVisualStudio6Generator.cxx | 6 | ||||
-rw-r--r-- | Source/cmLocalVisualStudio7Generator.cxx | 6 | ||||
-rw-r--r-- | Source/cmMakefile.cxx | 82 | ||||
-rw-r--r-- | Source/cmTarget.cxx | 14 |
4 files changed, 69 insertions, 39 deletions
diff --git a/Source/cmLocalVisualStudio6Generator.cxx b/Source/cmLocalVisualStudio6Generator.cxx index 5aa9e47..055ac3a 100644 --- a/Source/cmLocalVisualStudio6Generator.cxx +++ b/Source/cmLocalVisualStudio6Generator.cxx @@ -281,7 +281,11 @@ void cmLocalVisualStudio6Generator::WriteDSPFile(std::ostream& fout, name += "."; name += outsf->GetSourceExtension(); } - srcFilesToProcess.push(name); + std::string temp = + cmSystemTools::GetFilenamePath(outsf->GetFullPath()); + temp += "/"; + temp += name; + srcFilesToProcess.push(temp); } // add its dependencies to the list to check unsigned int i; diff --git a/Source/cmLocalVisualStudio7Generator.cxx b/Source/cmLocalVisualStudio7Generator.cxx index 5e4b5cd..56b3e91 100644 --- a/Source/cmLocalVisualStudio7Generator.cxx +++ b/Source/cmLocalVisualStudio7Generator.cxx @@ -705,7 +705,11 @@ void cmLocalVisualStudio7Generator::WriteVCProjFile(std::ostream& fout, name += "."; name += outsf->GetSourceExtension(); } - srcFilesToProcess.push(name); + std::string temp = + cmSystemTools::GetFilenamePath(outsf->GetFullPath()); + temp += "/"; + temp += name; + srcFilesToProcess.push(temp); } // add its dependencies to the list to check unsigned int i; diff --git a/Source/cmMakefile.cxx b/Source/cmMakefile.cxx index a9db9a6..0aacb35 100644 --- a/Source/cmMakefile.cxx +++ b/Source/cmMakefile.cxx @@ -1625,7 +1625,25 @@ cmData* cmMakefile::LookupData(const char* name) const cmSourceFile* cmMakefile::GetSource(const char* sourceName) const { - std::string s = cmSystemTools::GetFilenameName(sourceName); + // if the source is provided with a full path use it, otherwise + // by default it is in the current source dir + std::string path = cmSystemTools::GetFilenamePath(sourceName); + std::string s = sourceName; + if (path.empty()) + { + s = this->GetCurrentDirectory(); + s += "/"; + s += cmSystemTools::GetFilenameName(sourceName); + path = this->GetCurrentDirectory(); + } + std::string sname = + cmSystemTools::GetFilenameWithoutLastExtension(s); + + /* unfortunately old CMakeList files sometimes use sources with providing + * their extensions. If this is the case then we must + */ + + // compute the extension std::string ext; ext = cmSystemTools::GetFilenameLastExtension(s); s = s.substr(0, s.length()-ext.length()); @@ -1633,15 +1651,15 @@ cmSourceFile* cmMakefile::GetSource(const char* sourceName) const { ext = ext.substr(1); } + for(std::vector<cmSourceFile*>::const_iterator i = m_SourceFiles.begin(); i != m_SourceFiles.end(); ++i) { - if ((*i)->GetSourceName() == s) + if (cmSystemTools::GetFilenamePath((*i)->GetFullPath()) == path && + (*i)->GetSourceName() == sname && + (ext.size() == 0 || (ext == (*i)->GetSourceExtension()))) { - if ((ext.size() == 0 || (ext == (*i)->GetSourceExtension()))) - { - return *i; - } + return *i; } } return 0; @@ -1650,58 +1668,48 @@ cmSourceFile* cmMakefile::GetSource(const char* sourceName) const cmSourceFile* cmMakefile::GetOrCreateSource(const char* sourceName, bool generated) { + // make it a full path first + std::string path = cmSystemTools::GetFilenamePath(sourceName); + std::string src = sourceName; + if (path.empty()) + { + src = this->GetCurrentDirectory(); + src += "/"; + src += cmSystemTools::GetFilenameName(sourceName); + } + // check to see if it exists - cmSourceFile* ret = this->GetSource(sourceName); + cmSourceFile* ret = this->GetSource(src.c_str()); if (ret) { return ret; } // we must create one - std::string newfile = sourceName; cmSourceFile file; - std::string path = cmSystemTools::GetFilenamePath(newfile); + path = cmSystemTools::GetFilenamePath(src); if(generated) { - std::string ext = cmSystemTools::GetFilenameLastExtension(newfile); - std::string name_no_ext = cmSystemTools::GetFilenameName(newfile.c_str()); + std::string ext = cmSystemTools::GetFilenameLastExtension(src); + std::string name_no_ext = cmSystemTools::GetFilenameName(src.c_str()); name_no_ext = name_no_ext.substr(0, name_no_ext.length()-ext.length()); if ( ext.length() && ext[0] == '.' ) { ext = ext.substr(1); } - if((path.size() && path[0] == '/') || - (path.size() > 1 && path[1] == ':')) - { - file.SetName(name_no_ext.c_str(), path.c_str(), ext.c_str(), false); - } - else - { - file.SetName(name_no_ext.c_str(), this->GetCurrentOutputDirectory(), - ext.c_str(), false); - } + file.SetName(name_no_ext.c_str(), path.c_str(), ext.c_str(), false); } else { - // if this is a full path then - if((path.size() && path[0] == '/') || - (path.size() > 1 && path[1] == ':')) - { - file.SetName(cmSystemTools::GetFilenameName(newfile.c_str()).c_str(), - path.c_str(), - this->GetSourceExtensions(), - this->GetHeaderExtensions()); - } - else - { - file.SetName(newfile.c_str(), this->GetCurrentDirectory(), - this->GetSourceExtensions(), - this->GetHeaderExtensions()); - } + file.SetName(cmSystemTools::GetFilenameName(src.c_str()).c_str(), + path.c_str(), + this->GetSourceExtensions(), + this->GetHeaderExtensions()); } // add the source file to the makefile this->AddSource(file); - ret = this->GetSource(sourceName); + src = file.GetFullPath(); + ret = this->GetSource(src.c_str()); if (!ret) { cmSystemTools::Error( diff --git a/Source/cmTarget.cxx b/Source/cmTarget.cxx index 9706ba8..4cb4bb8 100644 --- a/Source/cmTarget.cxx +++ b/Source/cmTarget.cxx @@ -54,12 +54,26 @@ void cmTarget::GenerateSourceFilesFromSourceLists( cmMakefile &mf) mf.ExpandVariablesInString(temps); // Next if one wasn't found then assume it is a single class + // check to see if it is an existing source file if (!done && mf.GetSource(temps.c_str())) { m_SourceFiles.push_back(mf.GetSource(temps.c_str())); done = 1; } + // check to see if it is an existing source file in the output directory + if (!done && cmSystemTools::GetFilenamePath(temps).empty()) + { + std::string testName = mf.GetCurrentOutputDirectory(); + testName += "/"; + testName += temps; + if (mf.GetSource(testName.c_str())) + { + m_SourceFiles.push_back(mf.GetSource(testName.c_str())); + done = 1; + } + } + // if it wasn't a source file listed with the makefile // see if it is a variable. This is for old CMake 1.2 compatability // where a source list would be passed into here, by making it |