#include <quote.h>
#include <safe-read.h>
#include <timespec.h>
+#define obstack_chunk_alloc xmalloc
+#define obstack_chunk_free free
+#include <obstack.h>
/* Log base 2 of common values. */
#define LG_8 3
/* Patterns that match file names to be excluded. */
GLOBAL struct exclude *excluded;
-/* Specified file containing names to work on. */
-GLOBAL const char *files_from_option;
+/* Exclude directories containing a cache directory tag. */
+GLOBAL bool exclude_caches_option;
/* Specified value to be put into tar file in place of stat () results, or
just -1 if such an override should not take place. */
GLOBAL dev_t root_device;
+/* Unquote filenames */
+GLOBAL bool unquote_option;
\f
/* Declarations for each module. */
void print_header (struct tar_stat_info *, off_t);
void read_and (void (*) (void));
enum read_header read_header (bool);
+enum read_header tar_checksum (union block *header, bool silent);
void skip_file (off_t);
void skip_member (void);
{
ORDINARY_REMOVE_OPTION,
RECURSIVE_REMOVE_OPTION,
- WANT_DIRECTORY_REMOVE_OPTION
+
+ /* FIXME: The following value is never used. It seems to be intended
+ as a placeholder for a hypothetical option that should instruct tar
+ to recursively remove subdirectories in purge_directory(),
+ as opposed to the functionality of --recursive-unlink
+ (RECURSIVE_REMOVE_OPTION value), which removes them in
+ prepare_to_extract() phase. However, with the addition of more
+ meta-info to the incremental dumps, this should become unnecessary */
+ WANT_DIRECTORY_REMOVE_OPTION
};
int remove_any_file (const char *, enum remove_option);
bool maybe_backup_file (const char *, int);
void seek_warn (char const *);
void seek_warn_details (char const *, off_t);
void seek_diag_details (char const *, off_t);
+void stat_fatal (char const *);
void stat_error (char const *);
void stat_warn (char const *);
void stat_diag (char const *name);
void name_init (void);
void name_term (void);
char *name_next (int);
-void name_close (void);
void name_gather (void);
struct name *addname (char const *, int);
int name_match (const char *);