xref: /freebsd/contrib/libarchive/tar/bsdtar.h (revision bc96366c864c07ef352edb92017357917c75b36c)
1 /*-
2  * Copyright (c) 2003-2007 Tim Kientzle
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer in the
12  *    documentation and/or other materials provided with the distribution.
13  *
14  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) ``AS IS'' AND ANY EXPRESS OR
15  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
16  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
17  * IN NO EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY DIRECT, INDIRECT,
18  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
19  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
20  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
21  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
23  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24  *
25  * $FreeBSD$
26  */
27 
28 #include "bsdtar_platform.h"
29 #include <stdio.h>
30 
31 #define	DEFAULT_BYTES_PER_BLOCK	(20*512)
32 #define ENV_READER_OPTIONS	"TAR_READER_OPTIONS"
33 #define ENV_WRITER_OPTIONS	"TAR_WRITER_OPTIONS"
34 #define IGNORE_WRONG_MODULE_NAME "__ignore_wrong_module_name__,"
35 
36 struct creation_set;
37 /*
38  * The internal state for the "bsdtar" program.
39  *
40  * Keeping all of the state in a structure like this simplifies memory
41  * leak testing (at exit, anything left on the heap is suspect).  A
42  * pointer to this structure is passed to most bsdtar internal
43  * functions.
44  */
45 struct bsdtar {
46 	/* Options */
47 	const char	 *filename; /* -f filename */
48 	char		 *pending_chdir; /* -C dir */
49 	const char	 *names_from_file; /* -T file */
50 	int		  bytes_per_block; /* -b block_size */
51 	int		  bytes_in_last_block; /* See -b handling. */
52 	int		  verbose;   /* -v */
53 	int		  extract_flags; /* Flags for extract operation */
54 	int		  readdisk_flags; /* Flags for read disk operation */
55 	int		  strip_components; /* Remove this many leading dirs */
56 	int		  gid;  /* --gid */
57 	const char	 *gname; /* --gname */
58 	int		  uid;  /* --uid */
59 	const char	 *uname; /* --uname */
60 	char		  mode; /* Program mode: 'c', 't', 'r', 'u', 'x' */
61 	char		  symlink_mode; /* H or L, per BSD conventions */
62 	char		  option_absolute_paths; /* -P */
63 	char		  option_chroot; /* --chroot */
64 	char		  option_fast_read; /* --fast-read */
65 	const char	 *option_options; /* --options */
66 	char		  option_interactive; /* -w */
67 	char		  option_no_owner; /* -o */
68 	char		  option_no_subdirs; /* -n */
69 	char		  option_numeric_owner; /* --numeric-owner */
70 	char		  option_null; /* --null */
71 	char		  option_stdout; /* -O */
72 	char		  option_totals; /* --totals */
73 	char		  option_unlink_first; /* -U */
74 	char		  option_warn_links; /* --check-links */
75 	char		  day_first; /* show day before month in -tv output */
76 	struct creation_set *cset;
77 
78 	/* Option parser state */
79 	int		  getopt_state;
80 	char		 *getopt_word;
81 
82 	/* If >= 0, then close this when done. */
83 	int		  fd;
84 
85 	/* Miscellaneous state information */
86 	int		  argc;
87 	char		**argv;
88 	const char	 *argument;
89 	size_t		  gs_width; /* For 'list_item' in read.c */
90 	size_t		  u_width; /* for 'list_item' in read.c */
91 	uid_t		  user_uid; /* UID running this program */
92 	int		  return_value; /* Value returned by main() */
93 	char		  warned_lead_slash; /* Already displayed warning */
94 	char		  next_line_is_dir; /* Used for -C parsing in -cT */
95 
96 	/*
97 	 * Data for various subsystems.  Full definitions are located in
98 	 * the file where they are used.
99 	 */
100 	struct archive		*diskreader;	/* for write.c */
101 	struct archive_entry_linkresolver *resolver; /* for write.c */
102 	struct archive_dir	*archive_dir;	/* for write.c */
103 	struct name_cache	*gname_cache;	/* for write.c */
104 	char			*buff;		/* for write.c */
105 	size_t			 buff_size;	/* for write.c */
106 	int			 first_fs;	/* for write.c */
107 	struct archive		*matching;	/* for matching.c */
108 	struct security		*security;	/* for read.c */
109 	struct name_cache	*uname_cache;	/* for write.c */
110 	struct siginfo_data	*siginfo;	/* for siginfo.c */
111 	struct substitution	*substitution;	/* for subst.c */
112 };
113 
114 /* Fake short equivalents for long options that otherwise lack them. */
115 enum {
116 	OPTION_B64ENCODE = 1,
117 	OPTION_CHECK_LINKS,
118 	OPTION_CHROOT,
119 	OPTION_DISABLE_COPYFILE,
120 	OPTION_EXCLUDE,
121 	OPTION_FORMAT,
122 	OPTION_GID,
123 	OPTION_GNAME,
124 	OPTION_GRZIP,
125 	OPTION_HELP,
126 	OPTION_HFS_COMPRESSION,
127 	OPTION_INCLUDE,
128 	OPTION_KEEP_NEWER_FILES,
129 	OPTION_LRZIP,
130 	OPTION_LZIP,
131 	OPTION_LZMA,
132 	OPTION_LZOP,
133 	OPTION_NEWER_CTIME,
134 	OPTION_NEWER_CTIME_THAN,
135 	OPTION_NEWER_MTIME,
136 	OPTION_NEWER_MTIME_THAN,
137 	OPTION_NODUMP,
138 	OPTION_NOPRESERVE_HFS_COMPRESSION,
139 	OPTION_NO_SAME_OWNER,
140 	OPTION_NO_SAME_PERMISSIONS,
141 	OPTION_NULL,
142 	OPTION_NUMERIC_OWNER,
143 	OPTION_OLDER_CTIME,
144 	OPTION_OLDER_CTIME_THAN,
145 	OPTION_OLDER_MTIME,
146 	OPTION_OLDER_MTIME_THAN,
147 	OPTION_ONE_FILE_SYSTEM,
148 	OPTION_OPTIONS,
149 	OPTION_POSIX,
150 	OPTION_SAME_OWNER,
151 	OPTION_STRIP_COMPONENTS,
152 	OPTION_TOTALS,
153 	OPTION_UID,
154 	OPTION_UNAME,
155 	OPTION_USE_COMPRESS_PROGRAM,
156 	OPTION_UUENCODE,
157 	OPTION_VERSION
158 };
159 
160 int	bsdtar_getopt(struct bsdtar *);
161 void	do_chdir(struct bsdtar *);
162 int	edit_pathname(struct bsdtar *, struct archive_entry *);
163 int	need_report(void);
164 int	pathcmp(const char *a, const char *b);
165 void	safe_fprintf(FILE *, const char *fmt, ...);
166 void	set_chdir(struct bsdtar *, const char *newdir);
167 const char *tar_i64toa(int64_t);
168 void	tar_mode_c(struct bsdtar *bsdtar);
169 void	tar_mode_r(struct bsdtar *bsdtar);
170 void	tar_mode_t(struct bsdtar *bsdtar);
171 void	tar_mode_u(struct bsdtar *bsdtar);
172 void	tar_mode_x(struct bsdtar *bsdtar);
173 void	usage(void);
174 int	yes(const char *fmt, ...);
175 
176 #if defined(HAVE_REGEX_H) || defined(HAVE_PCREPOSIX_H)
177 void	add_substitution(struct bsdtar *, const char *);
178 int	apply_substitution(struct bsdtar *, const char *, char **, int, int);
179 void	cleanup_substitution(struct bsdtar *);
180 #endif
181 
182 void		cset_add_filter(struct creation_set *, const char *);
183 void		cset_add_filter_program(struct creation_set *, const char *);
184 int		cset_auto_compress(struct creation_set *, const char *);
185 void		cset_free(struct creation_set *);
186 const char *	cset_get_format(struct creation_set *);
187 struct creation_set *cset_new(void);
188 int		cset_read_support_filter_program(struct creation_set *,
189 		    struct archive *);
190 void		cset_set_format(struct creation_set *, const char *);
191 int		cset_write_add_filters(struct creation_set *,
192 		    struct archive *, const void **);
193 
194