summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2001-04-16 16:31:56 (GMT)
committerBrad King <brad.king@kitware.com>2001-04-16 16:31:56 (GMT)
commitf63e4a144c20ed04828e9a13e24f4d878a876576 (patch)
tree2ebb793ccdd198706a696867a579f5de59a1ec00
parente963dcaa8f37fac0fc450dfa1707266469f57998 (diff)
downloadCMake-f63e4a144c20ed04828e9a13e24f4d878a876576.zip
CMake-f63e4a144c20ed04828e9a13e24f4d878a876576.tar.gz
CMake-f63e4a144c20ed04828e9a13e24f4d878a876576.tar.bz2
ENH: Changed m_Indices to an stl set and renamed it to m_IndexSet. Using a set results in a significant performance increase and reduction in memory usage.
-rw-r--r--Source/cmMakeDepend.cxx31
-rw-r--r--Source/cmMakeDepend.h11
2 files changed, 11 insertions, 31 deletions
diff --git a/Source/cmMakeDepend.cxx b/Source/cmMakeDepend.cxx
index fafcedc..fef088e 100644
--- a/Source/cmMakeDepend.cxx
+++ b/Source/cmMakeDepend.cxx
@@ -98,14 +98,12 @@ void cmMakeDepend::DoDepends()
i != m_DependInformation.end(); ++i)
{
cmDependInformation* info = *i;
- // Remove duplicate depends
- info->RemoveDuplicateIndices();
// find the class
if(info->m_ClassFileIndex != 0)
{
cmClassFile& cfile = *(info->m_ClassFileIndex);
- for( std::vector<int>::iterator indx = info->m_Indices.begin();
- indx != info->m_Indices.end(); ++indx)
+ for( cmDependInformation::IndexSet::const_iterator indx = info->m_IndexSet.begin();
+ indx != info->m_IndexSet.end(); ++indx)
{
cfile.m_Depends.push_back(m_DependInformation[*indx]->m_FullPath);
}
@@ -164,7 +162,7 @@ void cmMakeDepend::Depend(cmDependInformation* info)
// Found dependency information. We are done.
return;
- }
+ }
}
// Couldn't find any dependency information.
@@ -244,7 +242,7 @@ void cmMakeDepend::AddDependency(cmDependInformation* info, const char* file)
int index = this->FindInformation(file);
// add the index to the depends of the current
// depend info object
- info->m_Indices.push_back(index);
+ info->m_IndexSet.insert(index);
// Get the depend information object for the include file
cmDependInformation* dependInfo = m_DependInformation[index];
// if the depends are not known for an include file, then compute them
@@ -286,28 +284,13 @@ int cmMakeDepend::FindInformation(const char* fname)
return m_DependInformation.size()-1;
}
-// remove duplicate indices from the depend information
-void cmDependInformation::RemoveDuplicateIndices()
-{
- // sort the array
- std::sort(m_Indices.begin(), m_Indices.end(), std::less<int>());
- // remove duplicates
- std::vector<int>::iterator new_end =
- std::unique(m_Indices.begin(), m_Indices.end());
- m_Indices.erase(new_end, m_Indices.end());
-}
-// add the depend information from info to the m_Indices varible of this class.
+// add the depend information from info to the m_IndexSet varible of this class.
void cmDependInformation::MergeInfo(cmDependInformation* info)
{
- if(this == info)
- {
- return;
- }
- std::vector<int>::iterator i = info->m_Indices.begin();
- for(; i!= info->m_Indices.end(); ++i)
+ if(this != info)
{
- m_Indices.push_back(*i);
+ m_IndexSet.insert(info->m_IndexSet.begin(), info->m_IndexSet.end());
}
}
diff --git a/Source/cmMakeDepend.h b/Source/cmMakeDepend.h
index 731150f..cb5a9d7 100644
--- a/Source/cmMakeDepend.h
+++ b/Source/cmMakeDepend.h
@@ -39,10 +39,12 @@ struct cmDependInformation
}
/**
- * A list of indices into the m_DependInformation array of cmMakeDepend.
+ * A set of indices into the m_DependInformation array of cmMakeDepend.
* The index represents the files that this file depends on.
+ * This must be a "set" to keep indices unique.
*/
- std::vector<int> m_Indices;
+ typedef std::set<int> IndexSet;
+ IndexSet m_IndexSet;
/**
* Full path to this file.
@@ -70,11 +72,6 @@ struct cmDependInformation
* This method adds the dependencies of another file to this one.
*/
void MergeInfo(cmDependInformation*);
-
- /**
- * This method removes duplicate depends from the index list.
- */
- void RemoveDuplicateIndices();
};