xref: /freebsd/usr.bin/ar/ar.h (revision 995dc984471c92c03daad19a1d35af46c086ef3e)
1 /*-
2  * Copyright (c) 2007 Kai Wang
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  *    in this position and unchanged.
11  * 2. Redistributions in binary form must reproduce the above copyright
12  *    notice, this list of conditions and the following disclaimer in the
13  *    documentation and/or other materials provided with the distribution.
14  *
15  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) ``AS IS'' AND ANY EXPRESS OR
16  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
17  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
18  * IN NO EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY DIRECT, INDIRECT,
19  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
20  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
21  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
22  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
24  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25  *
26  * $FreeBSD$
27  */
28 
29 /*
30  * ar(1) options.
31  */
32 #define AR_A	0x0001		/* position-after */
33 #define AR_B	0x0002		/* position-before */
34 #define AR_C	0x0004		/* creating new archive */
35 #define AR_CC	0x0008		/* do not overwrite when extracting */
36 #define AR_J	0x0010		/* bzip2 compression */
37 #define AR_O	0x0020		/* preserve original mtime when extracting */
38 #define AR_S	0x0040		/* write archive symbol table */
39 #define AR_SS	0x0080		/* do not write archive symbol table */
40 #define AR_TR	0x0100		/* only keep first 15 chars for member name */
41 #define AR_U	0x0200		/* only extract or update newer members.*/
42 #define AR_V	0x0400		/* verbose mode */
43 #define AR_Z	0x0800		/* gzip compression */
44 
45 #define DEF_BLKSZ 10240		/* default block size */
46 
47 /*
48  * Convenient wrapper for general libarchive error handling.
49  */
50 #define	AC(CALL) do {					\
51 	if ((CALL))					\
52 		bsdar_errc(bsdar, EX_SOFTWARE, 0, "%s",	\
53 		    archive_error_string(a));		\
54 } while (0)
55 
56 /*
57  * In-memory representation of archive member(object).
58  */
59 struct ar_obj {
60 	char		 *name;		/* member name */
61 	void		 *maddr;	/* mmap start address */
62 	uid_t		  uid;		/* user id */
63 	gid_t		  gid;		/* group id */
64 	mode_t		  md;		/* octal file permissions */
65 	size_t		  size;		/* member size */
66 	time_t		  mtime;	/* modification time */
67 	int		  fd;		/* file descriptor */
68 	dev_t		  dev;		/* inode's device */
69 	ino_t		  ino;		/* inode's number */
70 
71 	TAILQ_ENTRY(ar_obj) objs;
72 };
73 
74 /*
75  * Structure encapsulates the "global" data for "ar" program.
76  */
77 struct bsdar {
78 	const char	 *filename;	/* archive name. */
79 	const char	 *posarg;	/* position arg for modifiers -a, -b. */
80 	char		  mode;		/* program mode */
81 	char		  compression;	/* compression mode */
82 	int		  options;	/* command line options */
83 
84 	const char	 *progname;	/* program name */
85 	int		  argc;
86 	char		**argv;
87 
88 	/*
89 	 * Fields for the archive string table.
90 	 */
91 	char		 *as;		/* buffer for archive string table. */
92 	size_t		  as_sz;	/* current size of as table. */
93 	size_t		  as_cap;	/* capacity of as table buffer. */
94 
95 	/*
96 	 * Fields for the archive symbol table.
97 	 */
98 	uint32_t	  s_cnt;	/* current number of symbols. */
99 	uint32_t	 *s_so;		/* symbol offset table. */
100 	size_t		  s_so_cap;	/* capacity of so table buffer. */
101 	char		 *s_sn;		/* symbol name table */
102 	size_t		  s_sn_cap;	/* capacity of sn table buffer. */
103 	size_t		  s_sn_sz;	/* current size of sn table. */
104 	/* Current member's offset (relative to the end of pseudo members.) */
105 	off_t		  rela_off;
106 
107 	TAILQ_HEAD(, ar_obj) v_obj;	/* object(member) list */
108 };
109 
110 void	bsdar_errc(struct bsdar *, int _eval, int _code,
111 	    const char *fmt, ...);
112 void	bsdar_warnc(struct bsdar *, int _code, const char *fmt, ...);
113 void	ar_mode_d(struct bsdar *bsdar);
114 void	ar_mode_m(struct bsdar *bsdar);
115 void	ar_mode_p(struct bsdar *bsdar);
116 void	ar_mode_r(struct bsdar *bsdar);
117 void	ar_mode_s(struct bsdar *bsdar);
118 void	ar_mode_t(struct bsdar *bsdar);
119 void	ar_mode_x(struct bsdar *bsdar);
120