1caf54c4fSMartin Matuska /*- 2*bd66c1b4SMartin Matuska * SPDX-License-Identifier: BSD-2-Clause 3*bd66c1b4SMartin Matuska * 4caf54c4fSMartin Matuska * Copyright (c) 2003-2007 Tim Kientzle 5caf54c4fSMartin Matuska * All rights reserved. 6caf54c4fSMartin Matuska */ 7caf54c4fSMartin Matuska 8f9762417SMartin Matuska #ifndef BSDTAR_H_INCLUDED 9f9762417SMartin Matuska #define BSDTAR_H_INCLUDED 10f9762417SMartin Matuska 11caf54c4fSMartin Matuska #include "bsdtar_platform.h" 12caf54c4fSMartin Matuska #include <stdio.h> 13caf54c4fSMartin Matuska 14caf54c4fSMartin Matuska #define DEFAULT_BYTES_PER_BLOCK (20*512) 15acc60b03SMartin Matuska #define ENV_READER_OPTIONS "TAR_READER_OPTIONS" 16acc60b03SMartin Matuska #define ENV_WRITER_OPTIONS "TAR_WRITER_OPTIONS" 17acc60b03SMartin Matuska #define IGNORE_WRONG_MODULE_NAME "__ignore_wrong_module_name__," 18caf54c4fSMartin Matuska 19acc60b03SMartin Matuska struct creation_set; 20caf54c4fSMartin Matuska /* 21caf54c4fSMartin Matuska * The internal state for the "bsdtar" program. 22caf54c4fSMartin Matuska * 23caf54c4fSMartin Matuska * Keeping all of the state in a structure like this simplifies memory 24caf54c4fSMartin Matuska * leak testing (at exit, anything left on the heap is suspect). A 25caf54c4fSMartin Matuska * pointer to this structure is passed to most bsdtar internal 26caf54c4fSMartin Matuska * functions. 27caf54c4fSMartin Matuska */ 28caf54c4fSMartin Matuska struct bsdtar { 29caf54c4fSMartin Matuska /* Options */ 30caf54c4fSMartin Matuska const char *filename; /* -f filename */ 31caf54c4fSMartin Matuska char *pending_chdir; /* -C dir */ 32caf54c4fSMartin Matuska const char *names_from_file; /* -T file */ 33caf54c4fSMartin Matuska int bytes_per_block; /* -b block_size */ 346c95142eSMartin Matuska int bytes_in_last_block; /* See -b handling. */ 35caf54c4fSMartin Matuska int verbose; /* -v */ 3664287048SMartin Matuska unsigned int flags; /* Bitfield of boolean options */ 37caf54c4fSMartin Matuska int extract_flags; /* Flags for extract operation */ 38fd082e96SMartin Matuska int readdisk_flags; /* Flags for read disk operation */ 39caf54c4fSMartin Matuska int strip_components; /* Remove this many leading dirs */ 40caf54c4fSMartin Matuska int gid; /* --gid */ 41caf54c4fSMartin Matuska const char *gname; /* --gname */ 42caf54c4fSMartin Matuska int uid; /* --uid */ 43caf54c4fSMartin Matuska const char *uname; /* --uname */ 44cdf63a70SMartin Matuska const char *passphrase; /* --passphrase */ 45caf54c4fSMartin Matuska char mode; /* Program mode: 'c', 't', 'r', 'u', 'x' */ 46caf54c4fSMartin Matuska char symlink_mode; /* H or L, per BSD conventions */ 47caf54c4fSMartin Matuska const char *option_options; /* --options */ 48caf54c4fSMartin Matuska char day_first; /* show day before month in -tv output */ 49acc60b03SMartin Matuska struct creation_set *cset; 506c95142eSMartin Matuska 516c95142eSMartin Matuska /* Option parser state */ 526c95142eSMartin Matuska int getopt_state; 536c95142eSMartin Matuska char *getopt_word; 54caf54c4fSMartin Matuska 55caf54c4fSMartin Matuska /* If >= 0, then close this when done. */ 56caf54c4fSMartin Matuska int fd; 57caf54c4fSMartin Matuska 58caf54c4fSMartin Matuska /* Miscellaneous state information */ 59caf54c4fSMartin Matuska int argc; 60caf54c4fSMartin Matuska char **argv; 616c95142eSMartin Matuska const char *argument; 62caf54c4fSMartin Matuska size_t gs_width; /* For 'list_item' in read.c */ 63caf54c4fSMartin Matuska size_t u_width; /* for 'list_item' in read.c */ 64caf54c4fSMartin Matuska uid_t user_uid; /* UID running this program */ 65caf54c4fSMartin Matuska int return_value; /* Value returned by main() */ 66caf54c4fSMartin Matuska char warned_lead_slash; /* Already displayed warning */ 67caf54c4fSMartin Matuska char next_line_is_dir; /* Used for -C parsing in -cT */ 68caf54c4fSMartin Matuska 69caf54c4fSMartin Matuska /* 70caf54c4fSMartin Matuska * Data for various subsystems. Full definitions are located in 71caf54c4fSMartin Matuska * the file where they are used. 72caf54c4fSMartin Matuska */ 73caf54c4fSMartin Matuska struct archive *diskreader; /* for write.c */ 74caf54c4fSMartin Matuska struct archive_entry_linkresolver *resolver; /* for write.c */ 75caf54c4fSMartin Matuska struct archive_dir *archive_dir; /* for write.c */ 76caf54c4fSMartin Matuska struct name_cache *gname_cache; /* for write.c */ 77caf54c4fSMartin Matuska char *buff; /* for write.c */ 786c95142eSMartin Matuska size_t buff_size; /* for write.c */ 79fd082e96SMartin Matuska int first_fs; /* for write.c */ 80fd082e96SMartin Matuska struct archive *matching; /* for matching.c */ 81caf54c4fSMartin Matuska struct security *security; /* for read.c */ 82caf54c4fSMartin Matuska struct name_cache *uname_cache; /* for write.c */ 83caf54c4fSMartin Matuska struct siginfo_data *siginfo; /* for siginfo.c */ 84caf54c4fSMartin Matuska struct substitution *substitution; /* for subst.c */ 85cdf63a70SMartin Matuska char *ppbuff; /* for util.c */ 86caf54c4fSMartin Matuska }; 87caf54c4fSMartin Matuska 8864287048SMartin Matuska /* Options for flags bitfield */ 8964287048SMartin Matuska #define OPTFLAG_AUTO_COMPRESS (0x00000001) /* -a */ 9064287048SMartin Matuska #define OPTFLAG_ABSOLUTE_PATHS (0x00000002) /* -P */ 9164287048SMartin Matuska #define OPTFLAG_CHROOT (0x00000004) /* --chroot */ 9264287048SMartin Matuska #define OPTFLAG_FAST_READ (0x00000008) /* --fast-read */ 9364287048SMartin Matuska #define OPTFLAG_IGNORE_ZEROS (0x00000010) /* --ignore-zeros */ 9464287048SMartin Matuska #define OPTFLAG_INTERACTIVE (0x00000020) /* -w */ 9564287048SMartin Matuska #define OPTFLAG_NO_OWNER (0x00000040) /* -o */ 9664287048SMartin Matuska #define OPTFLAG_NO_SUBDIRS (0x00000080) /* -n */ 9764287048SMartin Matuska #define OPTFLAG_NULL (0x00000100) /* --null */ 9864287048SMartin Matuska #define OPTFLAG_NUMERIC_OWNER (0x00000200) /* --numeric-owner */ 9964287048SMartin Matuska #define OPTFLAG_O (0x00000400) /* -o */ 10064287048SMartin Matuska #define OPTFLAG_STDOUT (0x00000800) /* -O */ 10164287048SMartin Matuska #define OPTFLAG_TOTALS (0x00001000) /* --totals */ 10264287048SMartin Matuska #define OPTFLAG_UNLINK_FIRST (0x00002000) /* -U */ 10364287048SMartin Matuska #define OPTFLAG_WARN_LINKS (0x00004000) /* --check-links */ 10464287048SMartin Matuska #define OPTFLAG_NO_XATTRS (0x00008000) /* --no-xattrs */ 10564287048SMartin Matuska #define OPTFLAG_XATTRS (0x00010000) /* --xattrs */ 10664287048SMartin Matuska #define OPTFLAG_NO_ACLS (0x00020000) /* --no-acls */ 10764287048SMartin Matuska #define OPTFLAG_ACLS (0x00040000) /* --acls */ 10864287048SMartin Matuska #define OPTFLAG_NO_FFLAGS (0x00080000) /* --no-fflags */ 10964287048SMartin Matuska #define OPTFLAG_FFLAGS (0x00100000) /* --fflags */ 11064287048SMartin Matuska #define OPTFLAG_NO_MAC_METADATA (0x00200000) /* --no-mac-metadata */ 11164287048SMartin Matuska #define OPTFLAG_MAC_METADATA (0x00400000) /* --mac-metadata */ 112833a452eSMartin Matuska #define OPTFLAG_NO_READ_SPARSE (0x00800000) /* --no-read-sparse */ 113833a452eSMartin Matuska #define OPTFLAG_READ_SPARSE (0x01000000) /* --read-sparse */ 11464287048SMartin Matuska 115caf54c4fSMartin Matuska /* Fake short equivalents for long options that otherwise lack them. */ 116caf54c4fSMartin Matuska enum { 11764287048SMartin Matuska OPTION_ACLS = 1, 11864287048SMartin Matuska OPTION_B64ENCODE, 119acc60b03SMartin Matuska OPTION_CHECK_LINKS, 120caf54c4fSMartin Matuska OPTION_CHROOT, 121cdf63a70SMartin Matuska OPTION_CLEAR_NOCHANGE_FFLAGS, 122caf54c4fSMartin Matuska OPTION_EXCLUDE, 12352c2bb75SMartin Matuska OPTION_EXCLUDE_VCS, 12464287048SMartin Matuska OPTION_FFLAGS, 125caf54c4fSMartin Matuska OPTION_FORMAT, 126caf54c4fSMartin Matuska OPTION_GID, 127caf54c4fSMartin Matuska OPTION_GNAME, 128b9128a37SMartin Matuska OPTION_GROUP, 129acc60b03SMartin Matuska OPTION_GRZIP, 130caf54c4fSMartin Matuska OPTION_HELP, 131acc60b03SMartin Matuska OPTION_HFS_COMPRESSION, 132cdf63a70SMartin Matuska OPTION_IGNORE_ZEROS, 133caf54c4fSMartin Matuska OPTION_INCLUDE, 134caf54c4fSMartin Matuska OPTION_KEEP_NEWER_FILES, 135acc60b03SMartin Matuska OPTION_LRZIP, 136cdf63a70SMartin Matuska OPTION_LZ4, 1376c95142eSMartin Matuska OPTION_LZIP, 138caf54c4fSMartin Matuska OPTION_LZMA, 139acc60b03SMartin Matuska OPTION_LZOP, 14064287048SMartin Matuska OPTION_MAC_METADATA, 141caf54c4fSMartin Matuska OPTION_NEWER_CTIME, 142caf54c4fSMartin Matuska OPTION_NEWER_CTIME_THAN, 143caf54c4fSMartin Matuska OPTION_NEWER_MTIME, 144caf54c4fSMartin Matuska OPTION_NEWER_MTIME_THAN, 145caf54c4fSMartin Matuska OPTION_NODUMP, 146acc60b03SMartin Matuska OPTION_NOPRESERVE_HFS_COMPRESSION, 14764287048SMartin Matuska OPTION_NO_ACLS, 14864287048SMartin Matuska OPTION_NO_FFLAGS, 14964287048SMartin Matuska OPTION_NO_MAC_METADATA, 150833a452eSMartin Matuska OPTION_NO_READ_SPARSE, 151f9762417SMartin Matuska OPTION_NO_SAFE_WRITES, 152caf54c4fSMartin Matuska OPTION_NO_SAME_OWNER, 153caf54c4fSMartin Matuska OPTION_NO_SAME_PERMISSIONS, 15464287048SMartin Matuska OPTION_NO_XATTRS, 155caf54c4fSMartin Matuska OPTION_NULL, 156caf54c4fSMartin Matuska OPTION_NUMERIC_OWNER, 157acc60b03SMartin Matuska OPTION_OLDER_CTIME, 158acc60b03SMartin Matuska OPTION_OLDER_CTIME_THAN, 159acc60b03SMartin Matuska OPTION_OLDER_MTIME, 160acc60b03SMartin Matuska OPTION_OLDER_MTIME_THAN, 161caf54c4fSMartin Matuska OPTION_ONE_FILE_SYSTEM, 162caf54c4fSMartin Matuska OPTION_OPTIONS, 163b9128a37SMartin Matuska OPTION_OWNER, 164cdf63a70SMartin Matuska OPTION_PASSPHRASE, 165caf54c4fSMartin Matuska OPTION_POSIX, 166833a452eSMartin Matuska OPTION_READ_SPARSE, 167f9762417SMartin Matuska OPTION_SAFE_WRITES, 168caf54c4fSMartin Matuska OPTION_SAME_OWNER, 169caf54c4fSMartin Matuska OPTION_STRIP_COMPONENTS, 170caf54c4fSMartin Matuska OPTION_TOTALS, 171caf54c4fSMartin Matuska OPTION_UID, 172caf54c4fSMartin Matuska OPTION_UNAME, 173caf54c4fSMartin Matuska OPTION_USE_COMPRESS_PROGRAM, 174acc60b03SMartin Matuska OPTION_UUENCODE, 17564287048SMartin Matuska OPTION_VERSION, 1765c831a5bSMartin Matuska OPTION_XATTRS, 1775c831a5bSMartin Matuska OPTION_ZSTD, 178caf54c4fSMartin Matuska }; 179caf54c4fSMartin Matuska 180caf54c4fSMartin Matuska int bsdtar_getopt(struct bsdtar *); 181caf54c4fSMartin Matuska void do_chdir(struct bsdtar *); 182caf54c4fSMartin Matuska int edit_pathname(struct bsdtar *, struct archive_entry *); 183caf54c4fSMartin Matuska int need_report(void); 184caf54c4fSMartin Matuska int pathcmp(const char *a, const char *b); 18564287048SMartin Matuska void safe_fprintf(FILE *, const char *fmt, ...) __LA_PRINTF(2, 3); 186caf54c4fSMartin Matuska void set_chdir(struct bsdtar *, const char *newdir); 187caf54c4fSMartin Matuska const char *tar_i64toa(int64_t); 188caf54c4fSMartin Matuska void tar_mode_c(struct bsdtar *bsdtar); 189caf54c4fSMartin Matuska void tar_mode_r(struct bsdtar *bsdtar); 190caf54c4fSMartin Matuska void tar_mode_t(struct bsdtar *bsdtar); 191caf54c4fSMartin Matuska void tar_mode_u(struct bsdtar *bsdtar); 192caf54c4fSMartin Matuska void tar_mode_x(struct bsdtar *bsdtar); 193b9128a37SMartin Matuska __LA_NORETURN void usage(void); 19464287048SMartin Matuska int yes(const char *fmt, ...) __LA_PRINTF(1, 2); 195caf54c4fSMartin Matuska 196b9128a37SMartin Matuska #if defined(HAVE_REGEX_H) || defined(HAVE_PCREPOSIX_H) || defined(HAVE_PCRE2POSIX_H) 197caf54c4fSMartin Matuska void add_substitution(struct bsdtar *, const char *); 1986c95142eSMartin Matuska int apply_substitution(struct bsdtar *, const char *, char **, int, int); 199caf54c4fSMartin Matuska void cleanup_substitution(struct bsdtar *); 200caf54c4fSMartin Matuska #endif 201acc60b03SMartin Matuska 202acc60b03SMartin Matuska void cset_add_filter(struct creation_set *, const char *); 203acc60b03SMartin Matuska void cset_add_filter_program(struct creation_set *, const char *); 204acc60b03SMartin Matuska int cset_auto_compress(struct creation_set *, const char *); 205acc60b03SMartin Matuska void cset_free(struct creation_set *); 206acc60b03SMartin Matuska const char * cset_get_format(struct creation_set *); 207acc60b03SMartin Matuska struct creation_set *cset_new(void); 208acc60b03SMartin Matuska int cset_read_support_filter_program(struct creation_set *, 209acc60b03SMartin Matuska struct archive *); 210acc60b03SMartin Matuska void cset_set_format(struct creation_set *, const char *); 211acc60b03SMartin Matuska int cset_write_add_filters(struct creation_set *, 212acc60b03SMartin Matuska struct archive *, const void **); 213acc60b03SMartin Matuska 214cdf63a70SMartin Matuska const char * passphrase_callback(struct archive *, void *); 215cdf63a70SMartin Matuska void passphrase_free(char *); 216cdf63a70SMartin Matuska void list_item_verbose(struct bsdtar *, FILE *, 217cdf63a70SMartin Matuska struct archive_entry *); 218f9762417SMartin Matuska 219f9762417SMartin Matuska #endif 220