2 Copyright (C) 1998-99 Paul Barton-Davis
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
26 #include <sys/types.h>
29 #include <glibmm/miscutils.h>
31 #include "pbd/error.h"
32 #include "pbd/pathscanner.h"
33 #include "pbd/stl_delete.h"
39 PathScanner::operator() (const string &dirpath, const string ®exp,
40 bool match_fullpath, bool return_fullpath,
41 long limit, bool recurse)
47 if ((err = regcomp (&compiled_pattern, regexp.c_str(),
48 REG_EXTENDED|REG_NOSUB))) {
50 regerror (err, &compiled_pattern,
53 error << "Cannot compile soundfile regexp for use ("
61 return run_scan (dirpath, &PathScanner::regexp_filter,
62 (bool (*)(const string &, void *)) 0,
70 PathScanner::run_scan (const string &dirpath,
71 bool (PathScanner::*memberfilter)(const string &),
72 bool (*filter)(const string &, void *),
74 bool match_fullpath, bool return_fullpath,
78 return run_scan_internal ((vector<string*>*) 0, dirpath, memberfilter, filter, arg, match_fullpath, return_fullpath, limit, recurse);
82 PathScanner::run_scan_internal (vector<string *> *result,
83 const string &dirpath,
84 bool (PathScanner::*memberfilter)(const string &),
85 bool (*filter)(const string &, void *),
87 bool match_fullpath, bool return_fullpath,
93 char *pathcopy = strdup (dirpath.c_str());
100 if ((thisdir = strtok (pathcopy, ":")) == 0 ||
101 strlen (thisdir) == 0) {
107 result = new vector<string *>;
112 if ((dir = opendir (thisdir)) == 0) {
116 while ((finfo = readdir (dir)) != 0) {
118 if ((finfo->d_name[0] == '.' && finfo->d_name[1] == '\0') ||
119 (finfo->d_name[0] == '.' && finfo->d_name[1] == '.' && finfo->d_name[2] == '\0')) {
123 fullpath = Glib::build_filename (thisdir, finfo->d_name);
126 if (stat (fullpath.c_str(), &statbuf) < 0) {
130 if (statbuf.st_mode & S_IFDIR && recurse) {
131 run_scan_internal (result, fullpath, memberfilter, filter, arg, match_fullpath, return_fullpath, limit, recurse);
134 if (match_fullpath) {
135 search_str = fullpath;
137 search_str = finfo->d_name;
140 /* handle either type of function ptr */
143 if (!(this->*memberfilter)(search_str)) {
147 if (!filter(search_str, arg)) {
152 if (return_fullpath) {
153 newstr = new string (fullpath);
155 newstr = new string (finfo->d_name);
158 result->push_back (newstr);
164 } while ((limit < 0 || (nfound < limit)) && (thisdir = strtok (0, ":")));
171 PathScanner::find_first (const string &dirpath,
172 const string ®exp,
174 bool return_fullpath)
176 vector<string *> *res;
181 if ((err = regcomp (&compiled_pattern, regexp.c_str(),
182 REG_EXTENDED|REG_NOSUB))) {
184 regerror (err, &compiled_pattern,
187 error << "Cannot compile soundfile regexp for use (" << msg << ")" << endmsg;
193 res = run_scan (dirpath,
194 &PathScanner::regexp_filter,
195 (bool (*)(const string &, void *)) 0,
201 if (res->size() == 0) {
212 PathScanner::find_first (const string &dirpath,
213 bool (*filter)(const string &, void *),
216 bool return_fullpath)
218 vector<string *> *res;
221 res = run_scan (dirpath,
222 (bool (PathScanner::*)(const string &)) 0,
228 if (res->size() == 0) {