mirror of
https://github.com/reactos/CMake.git
synced 2024-12-14 07:09:22 +00:00
0ac18d40c8
Modern editors provide plenty of ways to visually separate functions. Drop the explicit comments that previously served this purpose. Use the following command to automate the change: $ git ls-files -z -- \ "*.c" "*.cc" "*.cpp" "*.cxx" "*.h" "*.hh" "*.hpp" "*.hxx" | egrep -z -v "^Source/cmCommandArgumentLexer\." | egrep -z -v "^Source/cmCommandArgumentParser(\.y|\.cxx|Tokens\.h)" | egrep -z -v "^Source/cmDependsJavaLexer\." | egrep -z -v "^Source/cmDependsJavaParser(\.y|\.cxx|Tokens\.h)" | egrep -z -v "^Source/cmExprLexer\." | egrep -z -v "^Source/cmExprParser(\.y|\.cxx|Tokens\.h)" | egrep -z -v "^Source/cmFortranLexer\." | egrep -z -v "^Source/cmFortranParser(\.y|\.cxx|Tokens\.h)" | egrep -z -v "^Source/cmListFileLexer\." | egrep -z -v "^Source/cm_sha2" | egrep -z -v "^Source/(kwsys|CursesDialog/form)/" | egrep -z -v "^Utilities/(KW|cm).*/" | xargs -0 sed -i '/^\(\/\/---*\|\/\*---*\*\/\)$/ {d;}' This avoids modifying third-party sources and generated sources.
192 lines
4.3 KiB
C++
192 lines
4.3 KiB
C++
/*============================================================================
|
|
CMake - Cross Platform Makefile Generator
|
|
Copyright 2000-2009 Kitware, Inc., Insight Software Consortium
|
|
|
|
Distributed under the OSI-approved BSD License (the "License");
|
|
see accompanying file Copyright.txt for details.
|
|
|
|
This software is distributed WITHOUT ANY WARRANTY; without even the
|
|
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
See the License for more information.
|
|
============================================================================*/
|
|
#include "cmSourceGroup.h"
|
|
|
|
class cmSourceGroupInternals
|
|
{
|
|
public:
|
|
std::vector<cmSourceGroup> GroupChildren;
|
|
};
|
|
|
|
cmSourceGroup::cmSourceGroup(const char* name, const char* regex,
|
|
const char* parentName): Name(name)
|
|
{
|
|
this->Internal = new cmSourceGroupInternals;
|
|
this->SetGroupRegex(regex);
|
|
if(parentName)
|
|
{
|
|
this->FullName = parentName;
|
|
this->FullName += "\\";
|
|
}
|
|
this->FullName += this->Name;
|
|
}
|
|
|
|
cmSourceGroup::~cmSourceGroup()
|
|
{
|
|
delete this->Internal;
|
|
}
|
|
|
|
cmSourceGroup::cmSourceGroup(cmSourceGroup const& r)
|
|
{
|
|
this->Name = r.Name;
|
|
this->FullName = r.FullName;
|
|
this->GroupRegex = r.GroupRegex;
|
|
this->GroupFiles = r.GroupFiles;
|
|
this->SourceFiles = r.SourceFiles;
|
|
this->Internal = new cmSourceGroupInternals(*r.Internal);
|
|
}
|
|
|
|
cmSourceGroup& cmSourceGroup::operator=(cmSourceGroup const& r)
|
|
{
|
|
this->Name = r.Name;
|
|
this->GroupRegex = r.GroupRegex;
|
|
this->GroupFiles = r.GroupFiles;
|
|
this->SourceFiles = r.SourceFiles;
|
|
*(this->Internal) = *(r.Internal);
|
|
return *this;
|
|
}
|
|
|
|
void cmSourceGroup::SetGroupRegex(const char* regex)
|
|
{
|
|
if(regex)
|
|
{
|
|
this->GroupRegex.compile(regex);
|
|
}
|
|
else
|
|
{
|
|
this->GroupRegex.compile("^$");
|
|
}
|
|
}
|
|
|
|
void cmSourceGroup::AddGroupFile(const std::string& name)
|
|
{
|
|
this->GroupFiles.insert(name);
|
|
}
|
|
|
|
const char* cmSourceGroup::GetName() const
|
|
{
|
|
return this->Name.c_str();
|
|
}
|
|
|
|
const char* cmSourceGroup::GetFullName() const
|
|
{
|
|
return this->FullName.c_str();
|
|
}
|
|
|
|
bool cmSourceGroup::MatchesRegex(const char* name)
|
|
{
|
|
return this->GroupRegex.find(name);
|
|
}
|
|
|
|
bool cmSourceGroup::MatchesFiles(const char* name)
|
|
{
|
|
std::set<std::string>::const_iterator i = this->GroupFiles.find(name);
|
|
if(i != this->GroupFiles.end())
|
|
{
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
void cmSourceGroup::AssignSource(const cmSourceFile* sf)
|
|
{
|
|
this->SourceFiles.push_back(sf);
|
|
}
|
|
|
|
const std::vector<const cmSourceFile*>& cmSourceGroup::GetSourceFiles() const
|
|
{
|
|
return this->SourceFiles;
|
|
}
|
|
|
|
void cmSourceGroup::AddChild(cmSourceGroup child)
|
|
{
|
|
this->Internal->GroupChildren.push_back(child);
|
|
}
|
|
|
|
cmSourceGroup *cmSourceGroup::LookupChild(const char* name) const
|
|
{
|
|
// initializing iterators
|
|
std::vector<cmSourceGroup>::const_iterator iter =
|
|
this->Internal->GroupChildren.begin();
|
|
const std::vector<cmSourceGroup>::const_iterator end =
|
|
this->Internal->GroupChildren.end();
|
|
|
|
// st
|
|
for(;iter!=end; ++iter)
|
|
{
|
|
std::string sgName = iter->GetName();
|
|
|
|
// look if descenened is the one were looking for
|
|
if(sgName == name)
|
|
{
|
|
return const_cast<cmSourceGroup*>(&(*iter)); // if it so return it
|
|
}
|
|
}
|
|
|
|
// if no child with this name was found return NULL
|
|
return NULL;
|
|
}
|
|
|
|
cmSourceGroup *cmSourceGroup::MatchChildrenFiles(const char *name)
|
|
{
|
|
// initializing iterators
|
|
std::vector<cmSourceGroup>::iterator iter =
|
|
this->Internal->GroupChildren.begin();
|
|
std::vector<cmSourceGroup>::iterator end =
|
|
this->Internal->GroupChildren.end();
|
|
|
|
if(this->MatchesFiles(name))
|
|
{
|
|
return this;
|
|
}
|
|
for(;iter!=end;++iter)
|
|
{
|
|
cmSourceGroup *result = iter->MatchChildrenFiles(name);
|
|
if(result)
|
|
{
|
|
return result;
|
|
}
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
|
|
cmSourceGroup *cmSourceGroup::MatchChildrenRegex(const char *name)
|
|
{
|
|
// initializing iterators
|
|
std::vector<cmSourceGroup>::iterator iter =
|
|
this->Internal->GroupChildren.begin();
|
|
std::vector<cmSourceGroup>::iterator end =
|
|
this->Internal->GroupChildren.end();
|
|
|
|
for(;iter!=end; ++iter)
|
|
{
|
|
cmSourceGroup *result = iter->MatchChildrenRegex(name);
|
|
if(result)
|
|
{
|
|
return result;
|
|
}
|
|
}
|
|
if(this->MatchesRegex(name))
|
|
{
|
|
return this;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
std::vector<cmSourceGroup> const&
|
|
cmSourceGroup::GetGroupChildren() const
|
|
{
|
|
return this->Internal->GroupChildren;
|
|
}
|