xref: /aosp_15_r20/bionic/libc/include/tar.h (revision 8d67ca893c1523eb926b9080dbe4e2ffd2a27ba1)
1*8d67ca89SAndroid Build Coastguard Worker /*
2*8d67ca89SAndroid Build Coastguard Worker  * Copyright (C) 2016 The Android Open Source Project
3*8d67ca89SAndroid Build Coastguard Worker  * All rights reserved.
4*8d67ca89SAndroid Build Coastguard Worker  *
5*8d67ca89SAndroid Build Coastguard Worker  * Redistribution and use in source and binary forms, with or without
6*8d67ca89SAndroid Build Coastguard Worker  * modification, are permitted provided that the following conditions
7*8d67ca89SAndroid Build Coastguard Worker  * are met:
8*8d67ca89SAndroid Build Coastguard Worker  *  * Redistributions of source code must retain the above copyright
9*8d67ca89SAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer.
10*8d67ca89SAndroid Build Coastguard Worker  *  * Redistributions in binary form must reproduce the above copyright
11*8d67ca89SAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer in
12*8d67ca89SAndroid Build Coastguard Worker  *    the documentation and/or other materials provided with the
13*8d67ca89SAndroid Build Coastguard Worker  *    distribution.
14*8d67ca89SAndroid Build Coastguard Worker  *
15*8d67ca89SAndroid Build Coastguard Worker  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16*8d67ca89SAndroid Build Coastguard Worker  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17*8d67ca89SAndroid Build Coastguard Worker  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18*8d67ca89SAndroid Build Coastguard Worker  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19*8d67ca89SAndroid Build Coastguard Worker  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20*8d67ca89SAndroid Build Coastguard Worker  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21*8d67ca89SAndroid Build Coastguard Worker  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22*8d67ca89SAndroid Build Coastguard Worker  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23*8d67ca89SAndroid Build Coastguard Worker  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24*8d67ca89SAndroid Build Coastguard Worker  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25*8d67ca89SAndroid Build Coastguard Worker  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26*8d67ca89SAndroid Build Coastguard Worker  * SUCH DAMAGE.
27*8d67ca89SAndroid Build Coastguard Worker  */
28*8d67ca89SAndroid Build Coastguard Worker 
29*8d67ca89SAndroid Build Coastguard Worker #pragma once
30*8d67ca89SAndroid Build Coastguard Worker 
31*8d67ca89SAndroid Build Coastguard Worker /**
32*8d67ca89SAndroid Build Coastguard Worker  * @file tar.h
33*8d67ca89SAndroid Build Coastguard Worker  * @brief Constants for reading/writing `.tar` files.
34*8d67ca89SAndroid Build Coastguard Worker  */
35*8d67ca89SAndroid Build Coastguard Worker 
36*8d67ca89SAndroid Build Coastguard Worker #include <sys/cdefs.h>
37*8d67ca89SAndroid Build Coastguard Worker 
38*8d67ca89SAndroid Build Coastguard Worker /** `.tar` file magic. (Includes the NUL.) */
39*8d67ca89SAndroid Build Coastguard Worker #define TMAGIC "ustar"
40*8d67ca89SAndroid Build Coastguard Worker /** `.tar` file magic length in bytes. */
41*8d67ca89SAndroid Build Coastguard Worker #define TMAGLEN 6
42*8d67ca89SAndroid Build Coastguard Worker /** `.tar` file version. (Does not include the NUL.) */
43*8d67ca89SAndroid Build Coastguard Worker #define TVERSION "00"
44*8d67ca89SAndroid Build Coastguard Worker /** `.tar` file version length in bytes. */
45*8d67ca89SAndroid Build Coastguard Worker #define TVERSLEN 2
46*8d67ca89SAndroid Build Coastguard Worker 
47*8d67ca89SAndroid Build Coastguard Worker /** Regular file type flag. */
48*8d67ca89SAndroid Build Coastguard Worker #define REGTYPE '0'
49*8d67ca89SAndroid Build Coastguard Worker /** Alternate regular file type flag. */
50*8d67ca89SAndroid Build Coastguard Worker #define AREGTYPE '\0'
51*8d67ca89SAndroid Build Coastguard Worker /** Link type flag. */
52*8d67ca89SAndroid Build Coastguard Worker #define LNKTYPE '1'
53*8d67ca89SAndroid Build Coastguard Worker /** Symbolic link type flag. */
54*8d67ca89SAndroid Build Coastguard Worker #define SYMTYPE '2'
55*8d67ca89SAndroid Build Coastguard Worker /** Character special file type flag. */
56*8d67ca89SAndroid Build Coastguard Worker #define CHRTYPE '3'
57*8d67ca89SAndroid Build Coastguard Worker /** Block special file type flag. */
58*8d67ca89SAndroid Build Coastguard Worker #define BLKTYPE '4'
59*8d67ca89SAndroid Build Coastguard Worker /** Directory type flag. */
60*8d67ca89SAndroid Build Coastguard Worker #define DIRTYPE '5'
61*8d67ca89SAndroid Build Coastguard Worker /** FIFO special file type flag. */
62*8d67ca89SAndroid Build Coastguard Worker #define FIFOTYPE '6'
63*8d67ca89SAndroid Build Coastguard Worker /** Reserved type flag. */
64*8d67ca89SAndroid Build Coastguard Worker #define CONTTYPE '7'
65*8d67ca89SAndroid Build Coastguard Worker 
66*8d67ca89SAndroid Build Coastguard Worker /** Set-UID mode field bit. */
67*8d67ca89SAndroid Build Coastguard Worker #define TSUID 04000
68*8d67ca89SAndroid Build Coastguard Worker /** Set-GID mode field bit. */
69*8d67ca89SAndroid Build Coastguard Worker #define TSGID 02000
70*8d67ca89SAndroid Build Coastguard Worker /** Directory restricted deletion mode field bit. */
71*8d67ca89SAndroid Build Coastguard Worker #define TSVTX 01000
72*8d67ca89SAndroid Build Coastguard Worker /** Readable by user mode field bit. */
73*8d67ca89SAndroid Build Coastguard Worker #define TUREAD 00400
74*8d67ca89SAndroid Build Coastguard Worker /** Writable by user mode field bit. */
75*8d67ca89SAndroid Build Coastguard Worker #define TUWRITE 00200
76*8d67ca89SAndroid Build Coastguard Worker /** Executable by user mode field bit. */
77*8d67ca89SAndroid Build Coastguard Worker #define TUEXEC 00100
78*8d67ca89SAndroid Build Coastguard Worker /** Readable by group mode field bit. */
79*8d67ca89SAndroid Build Coastguard Worker #define TGREAD 00040
80*8d67ca89SAndroid Build Coastguard Worker /** Writable by group mode field bit. */
81*8d67ca89SAndroid Build Coastguard Worker #define TGWRITE 00020
82*8d67ca89SAndroid Build Coastguard Worker /** Executable by group mode field bit. */
83*8d67ca89SAndroid Build Coastguard Worker #define TGEXEC 00010
84*8d67ca89SAndroid Build Coastguard Worker /** Readable by other mode field bit. */
85*8d67ca89SAndroid Build Coastguard Worker #define TOREAD 00004
86*8d67ca89SAndroid Build Coastguard Worker /** Writable by other mode field bit. */
87*8d67ca89SAndroid Build Coastguard Worker #define TOWRITE 00002
88*8d67ca89SAndroid Build Coastguard Worker /** Executable by other mode field bit. */
89*8d67ca89SAndroid Build Coastguard Worker #define TOEXEC 00001
90