VirtualBox

source: vbox/trunk/src/VBox/Runtime/common/zip/tar.h

Last change on this file was 98325, checked in by vboxsync, 16 months ago

Runtime,Main: Remove the now unused and deprecated RTTar* API in favor of the VFS implementation, move the header declaring the tar headers to iprt/formats so the appliance code can access some required defines [build fix, needed to split up the tar format header]

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.4 KB
Line 
1/* $Id: tar.h 98325 2023-01-26 16:16:07Z vboxsync $ */
2/** @file
3 * IPRT - TAR Virtual Filesystem.
4 */
5
6/*
7 * Copyright (C) 2010-2023 Oracle and/or its affiliates.
8 *
9 * This file is part of VirtualBox base platform packages, as
10 * available from https://www.virtualbox.org.
11 *
12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License
14 * as published by the Free Software Foundation, in version 3 of the
15 * License.
16 *
17 * This program is distributed in the hope that it will be useful, but
18 * WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20 * General Public License for more details.
21 *
22 * You should have received a copy of the GNU General Public License
23 * along with this program; if not, see <https://www.gnu.org/licenses>.
24 *
25 * The contents of this file may alternatively be used under the terms
26 * of the Common Development and Distribution License Version 1.0
27 * (CDDL), a copy of it is provided in the "COPYING.CDDL" file included
28 * in the VirtualBox distribution, in which case the provisions of the
29 * CDDL are applicable instead of those of the GPL.
30 *
31 * You may elect to license modified versions of this file under the
32 * terms and conditions of either the GPL or the CDDL or both.
33 *
34 * SPDX-License-Identifier: GPL-3.0-only OR CDDL-1.0
35 */
36
37#ifndef IPRT_INCLUDED_SRC_common_zip_tar_h
38#define IPRT_INCLUDED_SRC_common_zip_tar_h
39#ifndef RT_WITHOUT_PRAGMA_ONCE
40# pragma once
41#endif
42
43#include <iprt/assert.h>
44#include <iprt/formats/tar.h>
45
46/**
47 * Tar header union.
48 */
49typedef union RTZIPTARHDR
50{
51 /** Byte view. */
52 char ab[512];
53 /** The standard header. */
54 RTZIPTARHDRANCIENT Ancient;
55 /** The standard header. */
56 RTZIPTARHDRPOSIX Posix;
57 /** The GNU header. */
58 RTZIPTARHDRGNU Gnu;
59 /** The bits common to both GNU and the standard header. */
60 RTZIPTARHDRCOMMON Common;
61 /** GNU sparse header. */
62 RTZIPTARHDRGNUSPARSE GnuSparse;
63} RTZIPTARHDR;
64AssertCompileSize(RTZIPTARHDR, 512);
65/** Pointer to a tar file header. */
66typedef RTZIPTARHDR *PRTZIPTARHDR;
67/** Pointer to a const tar file header. */
68typedef RTZIPTARHDR const *PCRTZIPTARHDR;
69
70
71/**
72 * Tar header type.
73 */
74typedef enum RTZIPTARTYPE
75{
76 /** Invalid type value. */
77 RTZIPTARTYPE_INVALID = 0,
78 /** Posix header. */
79 RTZIPTARTYPE_POSIX,
80 /** The old GNU header, has layout conflicting with posix. */
81 RTZIPTARTYPE_GNU,
82 /** Ancient tar header which does not use anything beyond the magic. */
83 RTZIPTARTYPE_ANCIENT,
84 /** End of the valid type values (this is not valid). */
85 RTZIPTARTYPE_END,
86 /** The usual type blow up. */
87 RTZIPTARTYPE_32BIT_HACK = 0x7fffffff
88} RTZIPTARTYPE;
89typedef RTZIPTARTYPE *PRTZIPTARTYPE;
90
91
92/**
93 * Calculates the TAR header checksums and detects if it's all zeros.
94 *
95 * @returns true if all zeros, false if not.
96 * @param pHdr The header to checksum.
97 * @param pi32Unsigned Where to store the checksum calculated using
98 * unsigned chars. This is the one POSIX specifies.
99 * @param pi32Signed Where to store the checksum calculated using
100 * signed chars.
101 *
102 * @remarks The reason why we calculate the checksum as both signed and unsigned
103 * has to do with various the char C type being signed on some hosts
104 * and unsigned on others.
105 */
106DECLINLINE(bool) rtZipTarCalcChkSum(PCRTZIPTARHDR pHdr, int32_t *pi32Unsigned, int32_t *pi32Signed)
107{
108 int32_t i32Unsigned = 0;
109 int32_t i32Signed = 0;
110
111 /*
112 * Sum up the entire header.
113 */
114 const char *pch = (const char *)pHdr;
115 const char *pchEnd = pch + sizeof(*pHdr);
116 do
117 {
118 i32Unsigned += *(unsigned char *)pch;
119 i32Signed += *(signed char *)pch;
120 } while (++pch != pchEnd);
121
122 /*
123 * Check if it's all zeros and replace the chksum field with spaces.
124 */
125 bool const fZeroHdr = i32Unsigned == 0;
126
127 pch = pHdr->Common.chksum;
128 pchEnd = pch + sizeof(pHdr->Common.chksum);
129 do
130 {
131 i32Unsigned -= *(unsigned char *)pch;
132 i32Signed -= *(signed char *)pch;
133 } while (++pch != pchEnd);
134
135 i32Unsigned += (unsigned char)' ' * sizeof(pHdr->Common.chksum);
136 i32Signed += (signed char)' ' * sizeof(pHdr->Common.chksum);
137
138 *pi32Unsigned = i32Unsigned;
139 if (pi32Signed)
140 *pi32Signed = i32Signed;
141 return fZeroHdr;
142}
143
144
145#endif /* !IPRT_INCLUDED_SRC_common_zip_tar_h */
146
Note: See TracBrowser for help on using the repository browser.

© 2023 Oracle
ContactPrivacy policyTerms of Use