-/*
- * Test program for find files
- *
- * Kern Sibbald, MM
- *
- */
/*
Bacula® - The Network Backup Solution
- Copyright (C) 2000-2006 Free Software Foundation Europe e.V.
+ Copyright (C) 2000-2008 Free Software Foundation Europe e.V.
The main author of Bacula is Kern Sibbald, with contributions from
many others, a complete list can be found in the file AUTHORS.
This program is Free Software; you can redistribute it and/or
- modify it under the terms of version two of the GNU General Public
- License as published by the Free Software Foundation plus additions
- that are listed in the file LICENSE.
+ modify it under the terms of version three of the GNU Affero General Public
+ License as published by the Free Software Foundation and included
+ in the file LICENSE.
This program is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
- You should have received a copy of the GNU General Public License
+ You should have received a copy of the GNU Affero General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301, USA.
- Bacula® is a registered trademark of John Walker.
+ Bacula® is a registered trademark of Kern Sibbald.
The licensor of Bacula is the Free Software Foundation Europe
(FSFE), Fiduciary Program, Sumatrastrasse 25, 8006 Zürich,
Switzerland, email:ftf@fsfeurope.org.
*/
+/*
+ * Test program for find files
+ *
+ * Kern Sibbald, MM
+ *
+ */
#include "bacula.h"
#include "dird/dird.h"
#include "findlib/find.h"
-
+#include "lib/mntent_cache.h"
+#include "ch.h"
#if defined(HAVE_WIN32)
#define isatty(fd) (fd==0)
/* Dummy functions */
int generate_daemon_event(JCR *jcr, const char *event) { return 1; }
int generate_job_event(JCR *jcr, const char *event) { return 1; }
+void generate_plugin_event(JCR *jcr, bEventType eventType, void *value) { }
+extern bool parse_dir_config(CONFIG *config, const char *configfile, int exit_code);
/* Global variables */
static int num_files = 0;
static int trunc_fname = 0;
static int trunc_path = 0;
static int attrs = 0;
+static CONFIG *config;
static JCR *jcr;
-static int print_file(FF_PKT *ff, void *pkt, bool);
+static int print_file(JCR *jcr, FF_PKT *ff, bool);
static void count_files(FF_PKT *ff);
static bool copy_fileset(FF_PKT *ff, JCR *jcr);
static void set_options(findFOPTS *fo, const char *opts);
"\n"
"Usage: testfind [-d debug_level] [-] [pattern1 ...]\n"
" -a print extended attributes (Win32 debug)\n"
-" -dnn set debug level to nn\n"
+" -d <nn> set debug level to <nn>\n"
+" -dt print timestamp in debug output\n"
" -c specify config file containing FileSet resources\n"
" -f specify which FileSet to use\n"
" -? print this message.\n"
main (int argc, char *const *argv)
{
FF_PKT *ff;
- char *configfile = "bacula-dir.conf";
- char *fileset_name = "Windows-Full-Set";
+ const char *configfile = "bacula-dir.conf";
+ const char *fileset_name = "Windows-Full-Set";
int ch, hard_links;
OSDependentInit();
setlocale(LC_ALL, "");
bindtextdomain("bacula", LOCALEDIR);
textdomain("bacula");
+ lmgr_init_thread();
while ((ch = getopt(argc, argv, "ac:d:f:?")) != -1) {
switch (ch) {
break;
case 'd': /* set debug level */
+ if (*optarg == 't') {
+ dbg_timestamp = true;
+ } else {
debug_level = atoi(optarg);
if (debug_level <= 0) {
debug_level = 1;
}
+ }
break;
case 'f': /* exclude patterns */
argc -= optind;
argv += optind;
- parse_config(configfile);
+ config = new_config_parser();
+ parse_dir_config(config, configfile, M_ERROR_TERM);
MSGS *msg;
find_files(jcr, ff, print_file, NULL);
free_jcr(jcr);
- free_config_resources();
+ if (config) {
+ config->free_resources();
+ free(config);
+ config = NULL;
+ }
+
term_last_jobs_list();
/* Clean up fileset */
fo->wildbase.destroy();
fo->fstype.destroy();
fo->drivetype.destroy();
- if (fo->reader) {
- free(fo->reader);
- }
- if (fo->writer) {
- free(fo->writer);
- }
}
incexe->opts_list.destroy();
incexe->name_list.destroy();
num_files, max_file_len, max_path_len,
trunc_fname, trunc_path, hard_links);
+ flush_mntent_cache();
+
term_msg();
close_memory_pool();
+ lmgr_cleanup_main();
sm_dump(false);
exit(0);
}
-static int print_file(FF_PKT *ff, void *pkt, bool top_level)
+static int print_file(JCR *jcr, FF_PKT *ff, bool top_level)
{
switch (ff->type) {
set_options(current_opts, fo->opts);
for (k=0; k<fo->regex.size(); k++) {
- // bnet_fsend(fd, "R %s\n", fo->regex.get(k));
+ // fd->fsend("R %s\n", fo->regex.get(k));
current_opts->regex.append(bstrdup((const char *)fo->regex.get(k)));
}
for (k=0; k<fo->regexdir.size(); k++) {
- // bnet_fsend(fd, "RD %s\n", fo->regexdir.get(k));
+ // fd->fsend("RD %s\n", fo->regexdir.get(k));
current_opts->regexdir.append(bstrdup((const char *)fo->regexdir.get(k)));
}
for (k=0; k<fo->regexfile.size(); k++) {
- // bnet_fsend(fd, "RF %s\n", fo->regexfile.get(k));
+ // fd->fsend("RF %s\n", fo->regexfile.get(k));
current_opts->regexfile.append(bstrdup((const char *)fo->regexfile.get(k)));
}
for (k=0; k<fo->wild.size(); k++) {
for (k=0; k<fo->drivetype.size(); k++) {
current_opts->drivetype.append(bstrdup((const char *)fo->drivetype.get(k)));
}
- if (fo->reader) {
- current_opts->reader = bstrdup(fo->reader);
- }
- if (fo->writer) {
- current_opts->writer = bstrdup(fo->writer);
- }
}
for (j=0; j<ie->name_list.size(); j++) {
case 'W':
fo->flags |= FO_ENHANCEDWILD;
break;
- case 'Z': /* gzip compression */
- fo->flags |= FO_GZIP;
- fo->GZIP_level = *++p - '0';
- Dmsg1(200, "Compression level=%d\n", fo->GZIP_level);
+ case 'Z': /* compression */
+ p++; /* skip Z */
+ if (*p >= '0' && *p <= '9') {
+ fo->flags |= FO_COMPRESS;
+ fo->Compress_algo = COMPRESS_GZIP;
+ fo->Compress_level = *p - '0';
+ }
+ else if (*p == 'o') {
+ fo->flags |= FO_COMPRESS;
+ fo->Compress_algo = COMPRESS_LZO1X;
+ fo->Compress_level = 1; /* not used with LZO */
+ }
+ Dmsg2(200, "Compression alg=%d level=%d\n", fo->Compress_algo, fo->Compress_level);
+ break;
+ case 'X':
+ fo->flags |= FO_XATTR;
break;
default:
Emsg1(M_ERROR, 0, _("Unknown include/exclude option: %c\n"), *p);