xref: /freebsd/contrib/libarchive/libarchive/archive_entry.3 (revision cdf63a700c77204252e3c2e38d7106965559f3c6)
1caf54c4fSMartin Matuska.\" Copyright (c) 2003-2007 Tim Kientzle
26c95142eSMartin Matuska.\" Copyright (c) 2010 Joerg Sonnenberger
3caf54c4fSMartin Matuska.\" All rights reserved.
4caf54c4fSMartin Matuska.\"
5caf54c4fSMartin Matuska.\" Redistribution and use in source and binary forms, with or without
6caf54c4fSMartin Matuska.\" modification, are permitted provided that the following conditions
7caf54c4fSMartin Matuska.\" are met:
8caf54c4fSMartin Matuska.\" 1. Redistributions of source code must retain the above copyright
9caf54c4fSMartin Matuska.\"    notice, this list of conditions and the following disclaimer.
10caf54c4fSMartin Matuska.\" 2. Redistributions in binary form must reproduce the above copyright
11caf54c4fSMartin Matuska.\"    notice, this list of conditions and the following disclaimer in the
12caf54c4fSMartin Matuska.\"    documentation and/or other materials provided with the distribution.
13caf54c4fSMartin Matuska.\"
14caf54c4fSMartin Matuska.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15caf54c4fSMartin Matuska.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16caf54c4fSMartin Matuska.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17caf54c4fSMartin Matuska.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18caf54c4fSMartin Matuska.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19caf54c4fSMartin Matuska.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20caf54c4fSMartin Matuska.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21caf54c4fSMartin Matuska.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22caf54c4fSMartin Matuska.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23caf54c4fSMartin Matuska.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24caf54c4fSMartin Matuska.\" SUCH DAMAGE.
25caf54c4fSMartin Matuska.\"
266c22d9efSMartin Matuska.\" $FreeBSD$
27caf54c4fSMartin Matuska.\"
28fd082e96SMartin Matuska.Dd Feburary 2, 2012
29e2f3482bSMartin Matuska.Dt ARCHIVE_ENTRY 3
30caf54c4fSMartin Matuska.Os
31caf54c4fSMartin Matuska.Sh NAME
32caf54c4fSMartin Matuska.Nm archive_entry_clear ,
33caf54c4fSMartin Matuska.Nm archive_entry_clone ,
34caf54c4fSMartin Matuska.Nm archive_entry_free ,
35caf54c4fSMartin Matuska.Nm archive_entry_new ,
366c95142eSMartin Matuska.Nd functions for managing archive entry descriptions
37fd082e96SMartin Matuska.Sh LIBRARY
38fd082e96SMartin MatuskaStreaming Archive Library (libarchive, -larchive)
39caf54c4fSMartin Matuska.Sh SYNOPSIS
40caf54c4fSMartin Matuska.In archive_entry.h
41caf54c4fSMartin Matuska.Ft "struct archive_entry *"
42caf54c4fSMartin Matuska.Fn archive_entry_clear "struct archive_entry *"
43caf54c4fSMartin Matuska.Ft struct archive_entry *
44caf54c4fSMartin Matuska.Fn archive_entry_clone "struct archive_entry *"
45caf54c4fSMartin Matuska.Ft void
46caf54c4fSMartin Matuska.Fn archive_entry_free "struct archive_entry *"
47caf54c4fSMartin Matuska.Ft struct archive_entry *
48caf54c4fSMartin Matuska.Fn archive_entry_new "void"
49caf54c4fSMartin Matuska.Sh DESCRIPTION
50caf54c4fSMartin MatuskaThese functions create and manipulate data objects that
51caf54c4fSMartin Matuskarepresent entries within an archive.
52caf54c4fSMartin MatuskaYou can think of a
53caf54c4fSMartin Matuska.Tn struct archive_entry
54caf54c4fSMartin Matuskaas a heavy-duty version of
55caf54c4fSMartin Matuska.Tn struct stat :
56caf54c4fSMartin Matuskait includes everything from
57caf54c4fSMartin Matuska.Tn struct stat
58caf54c4fSMartin Matuskaplus associated pathname, textual group and user names, etc.
59caf54c4fSMartin MatuskaThese objects are used by
60caf54c4fSMartin Matuska.Xr libarchive 3
61caf54c4fSMartin Matuskato represent the metadata associated with a particular
62caf54c4fSMartin Matuskaentry in an archive.
63caf54c4fSMartin Matuska.Ss Create and Destroy
64caf54c4fSMartin MatuskaThere are functions to allocate, destroy, clear, and copy
65caf54c4fSMartin Matuska.Va archive_entry
66caf54c4fSMartin Matuskaobjects:
67caf54c4fSMartin Matuska.Bl -tag -compact -width indent
68caf54c4fSMartin Matuska.It Fn archive_entry_clear
69caf54c4fSMartin MatuskaErases the object, resetting all internal fields to the
70caf54c4fSMartin Matuskasame state as a newly-created object.
71caf54c4fSMartin MatuskaThis is provided to allow you to quickly recycle objects
72caf54c4fSMartin Matuskawithout thrashing the heap.
73caf54c4fSMartin Matuska.It Fn archive_entry_clone
74caf54c4fSMartin MatuskaA deep copy operation; all text fields are duplicated.
75caf54c4fSMartin Matuska.It Fn archive_entry_free
76caf54c4fSMartin MatuskaReleases the
77caf54c4fSMartin Matuska.Tn struct archive_entry
78caf54c4fSMartin Matuskaobject.
79caf54c4fSMartin Matuska.It Fn archive_entry_new
80caf54c4fSMartin MatuskaAllocate and return a blank
81caf54c4fSMartin Matuska.Tn struct archive_entry
82caf54c4fSMartin Matuskaobject.
83caf54c4fSMartin Matuska.El
846c95142eSMartin Matuska.Ss Function groups
856c95142eSMartin MatuskaDue to high number of functions, the accessor functions can be found in
866c95142eSMartin Matuskaman pages grouped by the purpose.
876c95142eSMartin Matuska.Bl -tag -width ".Xr archive_entry_perms 3"
886c95142eSMartin Matuska.It Xr archive_entry_acl 3
896c95142eSMartin MatuskaAccess Control List manipulation
906c95142eSMartin Matuska.It Xr archive_entry_paths 3
916c95142eSMartin MatuskaPath name manipulation
926c95142eSMartin Matuska.It Xr archive_entry_perms 3
936c95142eSMartin MatuskaUser, group and mode manipulation
946c95142eSMartin Matuska.It Xr archive_entry_stat 3
956c95142eSMartin MatuskaFunctions not in the other groups and copying to/from
966c95142eSMartin Matuska.Vt struct stat .
976c95142eSMartin Matuska.It Xr archive_entry_time 3
986c95142eSMartin MatuskaTime field manipulation
996c95142eSMartin Matuska.El
1006c95142eSMartin Matuska.Pp
1016c95142eSMartin MatuskaMost of the functions set or read entries in an object.
102caf54c4fSMartin MatuskaSuch functions have one of the following forms:
103caf54c4fSMartin Matuska.Bl -tag -compact -width indent
104caf54c4fSMartin Matuska.It Fn archive_entry_set_XXXX
105caf54c4fSMartin MatuskaStores the provided data in the object.
106caf54c4fSMartin MatuskaIn particular, for strings, the pointer is stored,
107caf54c4fSMartin Matuskanot the referenced string.
108caf54c4fSMartin Matuska.It Fn archive_entry_copy_XXXX
109caf54c4fSMartin MatuskaAs above, except that the referenced data is copied
110caf54c4fSMartin Matuskainto the object.
111caf54c4fSMartin Matuska.It Fn archive_entry_XXXX
112caf54c4fSMartin MatuskaReturns the specified data.
113caf54c4fSMartin MatuskaIn the case of strings, a const-qualified pointer to
114caf54c4fSMartin Matuskathe string is returned.
115caf54c4fSMartin Matuska.El
116caf54c4fSMartin MatuskaString data can be set or accessed as wide character strings
117caf54c4fSMartin Matuskaor normal
118caf54c4fSMartin Matuska.Va char
119caf54c4fSMartin Matuskastrings.
120caf54c4fSMartin MatuskaThe functions that use wide character strings are suffixed with
121caf54c4fSMartin Matuska.Cm _w .
122caf54c4fSMartin MatuskaNote that these are different representations of the same data:
123caf54c4fSMartin MatuskaFor example, if you store a narrow string and read the corresponding
124caf54c4fSMartin Matuskawide string, the object will transparently convert formats
125caf54c4fSMartin Matuskausing the current locale.
126caf54c4fSMartin MatuskaSimilarly, if you store a wide string and then store a
127caf54c4fSMartin Matuskanarrow string for the same data, the previously-set wide string will
128caf54c4fSMartin Matuskabe discarded in favor of the new data.
129caf54c4fSMartin Matuska.Pp
130caf54c4fSMartin Matuska.\" .Sh EXAMPLE
131caf54c4fSMartin Matuska.\" .Sh RETURN VALUES
132caf54c4fSMartin Matuska.\" .Sh ERRORS
133caf54c4fSMartin Matuska.Sh SEE ALSO
1346c95142eSMartin Matuska.Xr archive_entry_acl 3 ,
1356c95142eSMartin Matuska.Xr archive_entry_paths 3 ,
1366c95142eSMartin Matuska.Xr archive_entry_perms 3 ,
1376c95142eSMartin Matuska.Xr archive_entry_time 3
138*cdf63a70SMartin Matuska.Xr libarchive 3 ,
139caf54c4fSMartin Matuska.Sh HISTORY
140caf54c4fSMartin MatuskaThe
141caf54c4fSMartin Matuska.Nm libarchive
142caf54c4fSMartin Matuskalibrary first appeared in
143caf54c4fSMartin Matuska.Fx 5.3 .
144caf54c4fSMartin Matuska.Sh AUTHORS
145caf54c4fSMartin Matuska.An -nosplit
146caf54c4fSMartin MatuskaThe
147caf54c4fSMartin Matuska.Nm libarchive
148caf54c4fSMartin Matuskalibrary was written by
149caf54c4fSMartin Matuska.An Tim Kientzle Aq kientzle@acm.org .
150caf54c4fSMartin Matuska.\" .Sh BUGS
151