summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2006-01-05 22:16:22 (GMT)
committerBrad King <brad.king@kitware.com>2006-01-05 22:16:22 (GMT)
commit8dc1de6efd4d4edd010be56ddb57c22d8c0b5294 (patch)
treeb91a4d0fd03b0bae12ac6272927a61a919bf158e
parentbdbb7f84bc85c27aa49133f060e3407aa3990eea (diff)
downloadCMake-8dc1de6efd4d4edd010be56ddb57c22d8c0b5294.zip
CMake-8dc1de6efd4d4edd010be56ddb57c22d8c0b5294.tar.gz
CMake-8dc1de6efd4d4edd010be56ddb57c22d8c0b5294.tar.bz2
BUG: Fix for scanning generated headers included with double-quotes. Also fixed double-quote include support to not use the special quoted location when a full path is given on the include line.
-rw-r--r--Source/cmDependsC.cxx37
-rw-r--r--Source/cmDependsC.h3
2 files changed, 35 insertions, 5 deletions
diff --git a/Source/cmDependsC.cxx b/Source/cmDependsC.cxx
index 29254e6..9a9c164 100644
--- a/Source/cmDependsC.cxx
+++ b/Source/cmDependsC.cxx
@@ -318,10 +318,12 @@ void cmDependsC::Scan(std::istream& is, const char* directory, const cmStdString
// Get the file being included.
UnscannedEntry entry;
entry.FileName = m_IncludeRegexLine.match(1);
- if(m_IncludeRegexLine.match(2) == "\"")
+ if(m_IncludeRegexLine.match(2) == "\"" &&
+ !cmSystemTools::FileIsFullPath(entry.FileName.c_str()))
{
- // This was a double-quoted include. We must check for the
- // file in the directory containing the file we are scanning.
+ // This was a double-quoted include with a relative path. We
+ // must check for the file in the directory containing the
+ // file we are scanning.
entry.QuotedLocation = directory;
entry.QuotedLocation += "/";
entry.QuotedLocation += entry.FileName;
@@ -352,7 +354,32 @@ bool cmDependsC::FileExistsOrIsGenerated(const std::string& fname,
std::set<cmStdString>& scanned,
std::set<cmStdString>& dependencies)
{
- // Check first for a generated file.
+ // Check for a generated file.
+ if(this->FileIsGenerated(fname, scanned, dependencies))
+ {
+ return true;
+ }
+ else if(cmSystemTools::FileIsFullPath(fname.c_str()))
+ {
+ // The generated file may have been listed with a relative path.
+ std::string dir = cmSystemTools::CollapseFullPath(m_Directory.c_str());
+ std::string rname =
+ cmSystemTools::RelativePath(dir.c_str(), fname.c_str());
+ if(this->FileIsGenerated(rname, scanned, dependencies))
+ {
+ return true;
+ }
+ }
+
+ // Check for an existing file.
+ return cmSystemTools::FileExists(fname.c_str());
+}
+
+//----------------------------------------------------------------------------
+bool cmDependsC::FileIsGenerated(const std::string& fname,
+ std::set<cmStdString>& scanned,
+ std::set<cmStdString>& dependencies)
+{
if(m_GeneratedFiles &&
std::set<cmStdString>::const_iterator(m_GeneratedFiles->find(fname)) !=
m_GeneratedFiles->end())
@@ -369,6 +396,6 @@ bool cmDependsC::FileExistsOrIsGenerated(const std::string& fname,
}
else
{
- return cmSystemTools::FileExists(fname.c_str());
+ return false;
}
}
diff --git a/Source/cmDependsC.h b/Source/cmDependsC.h
index 687131d..f7167e8 100644
--- a/Source/cmDependsC.h
+++ b/Source/cmDependsC.h
@@ -53,6 +53,9 @@ protected:
bool FileExistsOrIsGenerated(const std::string& fname,
std::set<cmStdString>& scanned,
std::set<cmStdString>& dependencies);
+ bool FileIsGenerated(const std::string& fname,
+ std::set<cmStdString>& scanned,
+ std::set<cmStdString>& dependencies);
// The include file search path.
std::vector<std::string> const* m_IncludePath;