* Routines used to keep and match include and exclude
* filename/pathname patterns.
*
+ * Note, this file is used for the old style include and
+ * excludes, so is deprecated. The new style code is
+ * found in find.c
+ *
* Kern E. Sibbald, December MMI
*
*/
/*
- Copyright (C) 2001, 2002 Kern Sibbald and John Walker
+ Copyright (C) 2001-2004 Kern Sibbald and John Walker
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
#define FNM_LEADING_DIR 0
#endif
-#undef bmalloc
-#define bmalloc(x) sm_malloc(__FILE__, __LINE__, x)
-
-#ifdef HAVE_CYGWIN
-static int win32_client = 1;
+/* Fold case in fnmatch() on Win32 */
+#ifdef WIN32
+static const int fnmode = FNM_CASEFOLD;
#else
-static int win32_client = 0;
+static const int fnmode = 0;
#endif
+
+#undef bmalloc
+#define bmalloc(x) sm_malloc(__FILE__, __LINE__, x)
+
+extern const int win32_client;
/*
* Initialize structures for filename matching
/*
* Add a filename to list of included files
*/
-void add_fname_to_include_list(FF_PKT *ff, int prefixed, char *fname)
+void add_fname_to_include_list(FF_PKT *ff, int prefixed, const char *fname)
{
int len, j;
struct s_included_file *inc;
char *p;
+ const char *rp;
len = strlen(fname);
- inc =(struct s_included_file *) bmalloc(sizeof(struct s_included_file) + len + 1);
- inc->next = ff->included_files_list;
+ inc =(struct s_included_file *)bmalloc(sizeof(struct s_included_file) + len + 1);
inc->options = 0;
inc->VerifyOpts[0] = 'V';
inc->VerifyOpts[1] = ':';
/* prefixed = preceded with options */
if (prefixed) {
- for (p=fname; *p && *p != ' '; p++) {
- switch (*p) {
- case 'a': /* alway replace */
- case '0': /* no option */
- break;
- case 'w':
- inc->options |= OPT_replace_if_newer;
- break;
- case 'n':
- inc->options |= OPT_never_replace;
- break;
- case 'M': /* MD5 */
- inc->options |= OPT_compute_MD5;
- break;
- case 'Z': /* gzip compression */
- inc->options |= OPT_GZIP_compression;
- inc->level = *++p - '0';
- Dmsg1(200, "Compression level=%d\n", inc->level);
- break;
- case 'h': /* no recursion */
- inc->options |= OPT_no_recursion;
- break;
- case 'f':
- inc->options |= OPT_multifs;
- break;
- case 's':
- inc->options |= OPT_sparse;
- break;
- case 'V': /* verify options */
- /* Copy Verify Options */
- for (j=0; *p && *p != ':'; p++) {
- inc->VerifyOpts[j] = *p;
- if (j < (int)sizeof(inc->VerifyOpts) - 1) {
- j++;
- }
+ for (rp=fname; *rp && *rp != ' '; rp++) {
+ switch (*rp) {
+ case 'a': /* alway replace */
+ case '0': /* no option */
+ break;
+ case 'f':
+ inc->options |= FO_MULTIFS;
+ break;
+ case 'h': /* no recursion */
+ inc->options |= FO_NO_RECURSION;
+ break;
+ case 'M': /* MD5 */
+ inc->options |= FO_MD5;
+ break;
+ case 'n':
+ inc->options |= FO_NOREPLACE;
+ break;
+ case 'p': /* use portable data format */
+ inc->options |= FO_PORTABLE;
+ break;
+ case 'r': /* read fifo */
+ inc->options |= FO_READFIFO;
+ break;
+ case 'S':
+ inc->options |= FO_SHA1;
+ break;
+ case 's':
+ inc->options |= FO_SPARSE;
+ break;
+ case 'm':
+ inc->options |= FO_MTIMEONLY;
+ break;
+ case 'k':
+ inc->options |= FO_KEEPATIME;
+ break;
+ case 'V': /* verify options */
+ /* Copy Verify Options */
+ for (j=0; *rp && *rp != ':'; rp++) {
+ inc->VerifyOpts[j] = *rp;
+ if (j < (int)sizeof(inc->VerifyOpts) - 1) {
+ j++;
}
- inc->VerifyOpts[j] = 0;
- break;
- default:
- Emsg1(M_ERROR, 0, "Unknown include/exclude option: %c\n", *p);
- break;
+ }
+ inc->VerifyOpts[j] = 0;
+ break;
+ case 'w':
+ inc->options |= FO_IF_NEWER;
+ break;
+ case 'A':
+ inc->options |= FO_ACL;
+ break;
+ case 'Z': /* gzip compression */
+ inc->options |= FO_GZIP;
+ inc->level = *++rp - '0';
+ Dmsg1(200, "Compression level=%d\n", inc->level);
+ break;
+ default:
+ Emsg1(M_ERROR, 0, "Unknown include/exclude option: %c\n", *rp);
+ break;
}
}
/* Skip past space(s) */
- for ( ; *p == ' '; p++)
+ for ( ; *rp == ' '; rp++)
{}
} else {
- p = fname;
+ rp = fname;
}
- strcpy(inc->fname, p);
+ strcpy(inc->fname, rp);
+ p = inc->fname;
len = strlen(p);
/* Zap trailing slashes. */
p += len - 1;
break;
}
}
- ff->included_files_list = inc;
+#if defined(HAVE_CYGWIN) || defined(HAVE_WIN32)
+ /* Convert any \'s into /'s */
+ for (p=inc->fname; *p; p++) {
+ if (*p == '\\') {
+ *p = '/';
+ }
+ }
+#endif
+ inc->next = NULL;
+ /* Chain this one on the end of the list */
+ if (!ff->included_files_list) {
+ /* First one, so set head */
+ ff->included_files_list = inc;
+ } else {
+ struct s_included_file *next;
+ /* Walk to end of list */
+ for (next=ff->included_files_list; next->next; next=next->next)
+ { }
+ next->next = inc;
+ }
Dmsg1(50, "add_fname_to_include fname=%s\n", inc->fname);
}
* We add an exclude name to either the exclude path
* list or the exclude filename list.
*/
-void add_fname_to_exclude_list(FF_PKT *ff, char *fname)
+void add_fname_to_exclude_list(FF_PKT *ff, const char *fname)
{
int len;
struct s_excluded_file *exc, **list;
Dmsg1(20, "Add name to exclude: %s\n", fname);
+#if defined(HAVE_CYGWIN) || defined(HAVE_WIN32)
+ if (strchr(fname, '/') || strchr(fname, '\\')) {
+#else
if (strchr(fname, '/')) {
+#endif
list = &ff->excluded_paths_list;
} else {
list = &ff->excluded_files_list;
exc->next = *list;
exc->len = len;
strcpy(exc->fname, fname);
+#if defined(HAVE_CYGWIN) || defined(HAVE_WIN32)
+ /* Convert any \'s into /'s */
+ for (char *p=exc->fname; *p; p++) {
+ if (*p == '\\') {
+ *p = '/';
+ }
+ }
+#endif
*list = exc;
}
} else {
inc = ainc->next;
}
+ /*
+ * copy inc_options for this file into the ff packet
+ */
if (inc) {
ff->flags = inc->options;
- if (inc->options & OPT_compute_MD5) {
- ff->compute_MD5 = 1;
- } else {
- ff->compute_MD5 = 0;
- }
- if (inc->options & OPT_GZIP_compression) {
- ff->GZIP_compression = 1;
- ff->GZIP_level = inc->level;
- } else {
- ff->GZIP_compression = 0;
- }
- if (inc->options & OPT_no_recursion) {
- ff->no_recursion = 1;
- } else {
- ff->no_recursion = 0;
- }
- if (inc->options & OPT_multifs) {
- ff->one_file_system = 0;
- } else {
- ff->one_file_system = 1;
- }
+ ff->GZIP_level = inc->level;
}
return inc;
}
* file is included possibly with wild-cards.
*/
-int file_is_included(FF_PKT *ff, char *file)
+int file_is_included(FF_PKT *ff, const char *file)
{
struct s_included_file *inc = ff->included_files_list;
int len;
for ( ; inc; inc=inc->next ) {
if (inc->pattern) {
- if (fnmatch(inc->fname, file, FNM_LEADING_DIR) == 0) {
+ if (fnmatch(inc->fname, file, fnmode|FNM_LEADING_DIR) == 0) {
return 1;
}
continue;
* Determine if the file is excluded or not.
*/
static int
-file_in_excluded_list(struct s_excluded_file *exc, char *file)
+file_in_excluded_list(struct s_excluded_file *exc, const char *file)
{
if (exc == NULL) {
Dmsg0(900, "exc is NULL\n");
}
for ( ; exc; exc=exc->next ) {
- if (fnmatch(exc->fname, file, FNM_PATHNAME) == 0) {
+ if (fnmatch(exc->fname, file, fnmode|FNM_PATHNAME) == 0) {
Dmsg2(900, "Match exc pat=%s: file=%s:\n", exc->fname, file);
return 1;
}
* of an excluded directory.
*/
-int file_is_excluded(FF_PKT *ff, char *file)
+int file_is_excluded(FF_PKT *ff, const char *file)
{
- char *p;
+ const char *p;
+ /*
+ * ***NB*** this removes the drive from the exclude
+ * rule. Why?????
+ */
if (win32_client && file[1] == ':') {
file += 2;
}
/* Match from the beginning of a component only */
if ((p == file || (*p != '/' && *(p-1) == '/'))
&& file_in_excluded_list(ff->excluded_files_list, p)) {
- return 1;
+ return 1;
}
}
return 0;