add nocanon option

This commit is contained in:
dockes 2009-11-10 17:37:56 +00:00
parent 66d9896d81
commit d91d471b7d
2 changed files with 39 additions and 20 deletions

View File

@ -39,7 +39,7 @@ using namespace std;
#endif /* NO_NAMESPACES */
class FsTreeWalker::Internal {
Options options;
int options;
stringstream reason;
list<string> skippedNames;
list<string> skippedPaths;
@ -53,7 +53,7 @@ class FsTreeWalker::Internal {
friend class FsTreeWalker;
};
FsTreeWalker::FsTreeWalker(Options opts)
FsTreeWalker::FsTreeWalker(int opts)
{
data = new Internal;
if (data) {
@ -112,7 +112,7 @@ bool FsTreeWalker::inSkippedNames(const string& name)
bool FsTreeWalker::addSkippedPath(const string& ipath)
{
string path = path_canon(ipath);
string path = (data->options & FtwNoCanon) ? ipath : path_canon(ipath);
if (find(data->skippedPaths.begin(),
data->skippedPaths.end(), path) == data->skippedPaths.end())
data->skippedPaths.push_back(path);
@ -123,7 +123,8 @@ bool FsTreeWalker::setSkippedPaths(const list<string> &paths)
data->skippedPaths = paths;
for (list<string>::iterator it = data->skippedPaths.begin();
it != data->skippedPaths.end(); it++)
*it = path_canon(*it);
if (!(data->options & FtwNoCanon))
*it = path_canon(*it);
data->skippedPaths.sort();
data->skippedPaths.unique();
return true;
@ -142,7 +143,7 @@ bool FsTreeWalker::inSkippedPaths(const string& path)
FsTreeWalker::Status FsTreeWalker::walk(const string& _top,
FsTreeWalkerCB& cb)
{
string top = path_canon(_top);
string top = (data->options & FtwNoCanon) ? _top : path_canon(_top);
struct stat st;
int statret;
@ -225,9 +226,12 @@ FsTreeWalker::Status FsTreeWalker::iwalk(const string &top,
}
if (status & (FtwStop|FtwError))
goto out;
if ((status = cb.processone(top, &st, FtwDirReturn))
& (FtwStop|FtwError))
goto out;
// No DirReturn call when not recursing
if (!(data->options & FtwNoRecurse))
if ((status = cb.processone(top, &st, FtwDirReturn))
& (FtwStop|FtwError))
goto out;
} else if (S_ISREG(st.st_mode)) {
if ((status = cb.processone(fn, &st, FtwRegular)) &
(FtwStop|FtwError)) {
@ -256,14 +260,24 @@ FsTreeWalker::Status FsTreeWalker::iwalk(const string &top,
using namespace std;
static int op_flags;
#define OPT_MOINS 0x1
#define OPT_p 0x2
#define OPT_P 0x4
#define OPT_r 0x8
#define OPT_c 0x10
class myCB : public FsTreeWalkerCB {
public:
FsTreeWalker::Status processone(const string &path,
const struct stat *st,
FsTreeWalker::CbFlag flg)
const struct stat *st,
FsTreeWalker::CbFlag flg)
{
if (flg == FsTreeWalker::FtwDirEnter) {
cout << "[Entering " << path << "]" << endl;
if (op_flags & OPT_r)
cout << path << endl;
else
cout << "[Entering " << path << "]" << endl;
} else if (flg == FsTreeWalker::FtwDirReturn) {
cout << "[Returning to " << path << "]" << endl;
} else if (flg == FsTreeWalker::FtwRegular) {
@ -276,7 +290,9 @@ class myCB : public FsTreeWalkerCB {
static const char *thisprog;
static char usage [] =
"trfstreewalk [-p pattern] [-P ignpath] topdir\n\n"
"trfstreewalk [-p pattern] [-P ignpath] [-r] [-c] topdir\n"
" -r : norecurse\n"
" -c : no path canonification\n"
;
static void
Usage(void)
@ -285,11 +301,6 @@ Usage(void)
exit(1);
}
static int op_flags;
#define OPT_MOINS 0x1
#define OPT_p 0x2
#define OPT_P 0x4
int main(int argc, const char **argv)
{
list<string> patterns;
@ -304,6 +315,8 @@ int main(int argc, const char **argv)
Usage();
while (**argv)
switch (*(*argv)++) {
case 'r': op_flags |= OPT_r; break;
case 'c': op_flags |= OPT_c; break;
case 'p': op_flags |= OPT_p; if (argc < 2) Usage();
patterns.push_back(*(++argv));
argc--;
@ -321,7 +334,12 @@ int main(int argc, const char **argv)
Usage();
string topdir = *argv++;argc--;
FsTreeWalker walker;
int opt = 0;
if (op_flags & OPT_r)
opt |= FsTreeWalker::FtwNoRecurse;
if (op_flags & OPT_c)
opt |= FsTreeWalker::FtwNoCanon;
FsTreeWalker walker(opt);
walker.setSkippedNames(patterns);
walker.setSkippedPaths(paths);
myCB cb;

View File

@ -45,9 +45,10 @@ class FsTreeWalker {
enum CbFlag {FtwRegular, FtwDirEnter, FtwDirReturn};
enum Status {FtwOk=0, FtwError=1, FtwStop=2,
FtwStatAll = FtwError|FtwStop};
enum Options {FtwOptNone = 0, FtwNoRecurse = 1, FtwFollow = 2};
enum Options {FtwOptNone = 0, FtwNoRecurse = 1, FtwFollow = 2,
FtwNoCanon = 4};
FsTreeWalker(Options opts = FtwOptNone);
FsTreeWalker(int opts = FtwOptNone);
~FsTreeWalker();
void setOpts(Options opts);