2005-10-18 22:08:55 +04:00
|
|
|
/*=========================================================================
|
|
|
|
|
|
|
|
Program: KWSys - Kitware System Library
|
|
|
|
Module: $RCSfile$
|
|
|
|
|
|
|
|
Copyright (c) Kitware, Inc., Insight Consortium. All rights reserved.
|
|
|
|
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
|
|
|
|
|
|
|
|
This software is distributed WITHOUT ANY WARRANTY; without even
|
|
|
|
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
|
|
PURPOSE. See the above copyright notices for more information.
|
|
|
|
|
|
|
|
=========================================================================*/
|
|
|
|
#ifndef @KWSYS_NAMESPACE@_Glob_hxx
|
|
|
|
#define @KWSYS_NAMESPACE@_Glob_hxx
|
|
|
|
|
|
|
|
#include <@KWSYS_NAMESPACE@/stl/string>
|
|
|
|
#include <@KWSYS_NAMESPACE@/stl/vector>
|
|
|
|
|
|
|
|
#include <@KWSYS_NAMESPACE@/Configure.h>
|
|
|
|
|
|
|
|
namespace @KWSYS_NAMESPACE@
|
|
|
|
{
|
|
|
|
|
|
|
|
class GlobInternals;
|
|
|
|
|
|
|
|
/** \class Glob
|
|
|
|
* \brief Portable globbing searches.
|
|
|
|
*
|
|
|
|
* Globbing expressions are much simpler than regular
|
|
|
|
* expressions. This class will search for files using
|
|
|
|
* globbing expressions.
|
|
|
|
*
|
|
|
|
* Finds all files that match a given globbing expression.
|
|
|
|
*/
|
|
|
|
class @KWSYS_NAMESPACE@_EXPORT Glob
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Glob();
|
|
|
|
~Glob();
|
|
|
|
|
|
|
|
//! Find all files that match the pattern.
|
2005-10-19 18:47:19 +04:00
|
|
|
bool FindFiles(const kwsys_stl::string& inexpr);
|
2005-10-18 22:08:55 +04:00
|
|
|
|
|
|
|
//! Return the list of files that matched.
|
2005-10-19 18:47:19 +04:00
|
|
|
kwsys_stl::vector<kwsys_stl::string>& GetFiles();
|
2005-10-18 22:08:55 +04:00
|
|
|
|
|
|
|
//! Set recurse to true to match subdirectories.
|
|
|
|
void RecurseOn() { this->SetRecurse(true); }
|
|
|
|
void RecurseOff() { this->SetRecurse(false); }
|
|
|
|
void SetRecurse(bool i) { m_Recurse = i; }
|
|
|
|
bool GetRecurse() { return m_Recurse; }
|
|
|
|
|
|
|
|
protected:
|
|
|
|
//! Process directory
|
2005-10-19 18:47:19 +04:00
|
|
|
void ProcessDirectory(kwsys_stl::string::size_type start,
|
|
|
|
const kwsys_stl::string& dir, bool dir_only);
|
2005-10-18 22:08:55 +04:00
|
|
|
|
|
|
|
//! Process last directory, but only when recurse flags is on. That is
|
|
|
|
// effectively like saying: /path/to/file/**/file
|
2005-10-19 18:47:19 +04:00
|
|
|
void RecurseDirectory(kwsys_stl::string::size_type start,
|
|
|
|
const kwsys_stl::string& dir, bool dir_only);
|
2005-10-18 22:08:55 +04:00
|
|
|
|
|
|
|
//! Escape all non-alphanumeric characters in pattern.
|
|
|
|
void Escape(int ch, char* buffer);
|
|
|
|
|
|
|
|
//!
|
|
|
|
// Translate a shell PATTERN to a regular expression.
|
|
|
|
// There is no way to quote meta-characters.
|
2005-10-19 18:47:19 +04:00
|
|
|
kwsys_stl::string ConvertExpression(const kwsys_stl::string& expr);
|
2005-10-18 22:08:55 +04:00
|
|
|
|
|
|
|
//! Add regular expression
|
|
|
|
void AddExpression(const char* expr);
|
|
|
|
|
|
|
|
GlobInternals* m_Internals;
|
|
|
|
bool m_Recurse;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace @KWSYS_NAMESPACE@
|
|
|
|
|
|
|
|
#endif
|