Blame doc/man/archive_read_extract.3

Packit 08bd4c
.TH ARCHIVE_READ_EXTRACT 3 "February 2, 2012" ""
Packit 08bd4c
.SH NAME
Packit 08bd4c
.ad l
Packit 08bd4c
\fB\%archive_read_extract\fP,
Packit 08bd4c
\fB\%archive_read_extract2\fP,
Packit 08bd4c
\fB\%archive_read_extract_set_progress_callback\fP
Packit 08bd4c
\- functions for reading streaming archives
Packit 08bd4c
.SH LIBRARY
Packit 08bd4c
.ad l
Packit 08bd4c
Streaming Archive Library (libarchive, -larchive)
Packit 08bd4c
.SH SYNOPSIS
Packit 08bd4c
.ad l
Packit 08bd4c
\fB#include <archive.h>\fP
Packit 08bd4c
.br
Packit 08bd4c
\fIint\fP
Packit 08bd4c
.br
Packit 08bd4c
\fB\%archive_read_extract\fP(\fI\%struct\ archive\ *\fP, \fI\%struct\ archive_entry\ *\fP, \fI\%int\ flags\fP);
Packit 08bd4c
.br
Packit 08bd4c
\fIint\fP
Packit 08bd4c
.br
Packit 08bd4c
\fB\%archive_read_extract2\fP(\fI\%struct\ archive\ *src\fP, \fI\%struct\ archive_entry\ *\fP, \fI\%struct\ archive\ *dest\fP);
Packit 08bd4c
.br
Packit 08bd4c
\fIvoid\fP
Packit 08bd4c
.br
Packit 08bd4c
\fB\%archive_read_extract_set_progress_callback\fP(\fI\%struct\ archive\ *\fP, \fI\%void\ (*func)(void\ *)\fP, \fI\%void\ *user_data\fP);
Packit 08bd4c
.SH DESCRIPTION
Packit 08bd4c
.ad l
Packit 08bd4c
.RS 5
Packit 08bd4c
.TP
Packit 08bd4c
\fB\%archive_read_extract\fP(), \fB\%archive_read_extract_set_skip_file\fP()
Packit 08bd4c
A convenience function that wraps the corresponding
Packit 08bd4c
\fBarchive_write_disk\fP(3)
Packit 08bd4c
interfaces.
Packit 08bd4c
The first call to
Packit 08bd4c
\fB\%archive_read_extract\fP()
Packit 08bd4c
creates a restore object using
Packit 08bd4c
\fBarchive_write_disk_new\fP(3)
Packit 08bd4c
and
Packit 08bd4c
\fBarchive_write_disk_set_standard_lookup\fP(3),
Packit 08bd4c
then transparently invokes
Packit 08bd4c
\fBarchive_write_disk_set_options\fP(3),
Packit 08bd4c
\fBarchive_write_header\fP(3),
Packit 08bd4c
\fBarchive_write_data\fP(3),
Packit 08bd4c
and
Packit 08bd4c
\fBarchive_write_finish_entry\fP(3)
Packit 08bd4c
to create the entry on disk and copy data into it.
Packit 08bd4c
The
Packit 08bd4c
\fIflags\fP
Packit 08bd4c
argument is passed unmodified to
Packit 08bd4c
\fBarchive_write_disk_set_options\fP(3).
Packit 08bd4c
.TP
Packit 08bd4c
\fB\%archive_read_extract2\fP()
Packit 08bd4c
This is another version of
Packit 08bd4c
\fB\%archive_read_extract\fP()
Packit 08bd4c
that allows you to provide your own restore object.
Packit 08bd4c
In particular, this allows you to override the standard lookup functions
Packit 08bd4c
using
Packit 08bd4c
\fBarchive_write_disk_set_group_lookup\fP(3),
Packit 08bd4c
and
Packit 08bd4c
\fBarchive_write_disk_set_user_lookup\fP(3).
Packit 08bd4c
Note that
Packit 08bd4c
\fB\%archive_read_extract2\fP()
Packit 08bd4c
does not accept a
Packit 08bd4c
\fIflags\fP
Packit 08bd4c
argument; you should use
Packit 08bd4c
\fB\%archive_write_disk_set_options\fP()
Packit 08bd4c
to set the restore options yourself.
Packit 08bd4c
.TP
Packit 08bd4c
\fB\%archive_read_extract_set_progress_callback\fP()
Packit 08bd4c
Sets a pointer to a user-defined callback that can be used
Packit 08bd4c
for updating progress displays during extraction.
Packit 08bd4c
The progress function will be invoked during the extraction of large
Packit 08bd4c
regular files.
Packit 08bd4c
The progress function will be invoked with the pointer provided to this call.
Packit 08bd4c
Generally, the data pointed to should include a reference to the archive
Packit 08bd4c
object and the archive_entry object so that various statistics
Packit 08bd4c
can be retrieved for the progress display.
Packit 08bd4c
.RE
Packit 08bd4c
.SH RETURN VALUES
Packit 08bd4c
.ad l
Packit 08bd4c
Most functions return zero on success, non-zero on error.
Packit 08bd4c
The possible return codes include:
Packit 08bd4c
\fBARCHIVE_OK\fP
Packit 08bd4c
(the operation succeeded),
Packit 08bd4c
\fBARCHIVE_WARN\fP
Packit 08bd4c
(the operation succeeded but a non-critical error was encountered),
Packit 08bd4c
\fBARCHIVE_EOF\fP
Packit 08bd4c
(end-of-archive was encountered),
Packit 08bd4c
\fBARCHIVE_RETRY\fP
Packit 08bd4c
(the operation failed but can be retried),
Packit 08bd4c
and
Packit 08bd4c
\fBARCHIVE_FATAL\fP
Packit 08bd4c
(there was a fatal error; the archive should be closed immediately).
Packit 08bd4c
.SH ERRORS
Packit 08bd4c
.ad l
Packit 08bd4c
Detailed error codes and textual descriptions are available from the
Packit 08bd4c
\fB\%archive_errno\fP()
Packit 08bd4c
and
Packit 08bd4c
\fB\%archive_error_string\fP()
Packit 08bd4c
functions.
Packit 08bd4c
.SH SEE ALSO
Packit 08bd4c
.ad l
Packit 08bd4c
\fBtar\fP(1),
Packit 08bd4c
\fBlibarchive\fP(3),
Packit 08bd4c
\fBarchive_read\fP(3),
Packit 08bd4c
\fBarchive_read_data\fP(3),
Packit 08bd4c
\fBarchive_read_filter\fP(3),
Packit 08bd4c
\fBarchive_read_format\fP(3),
Packit 08bd4c
\fBarchive_read_open\fP(3),
Packit 08bd4c
\fBarchive_read_set_options\fP(3),
Packit 08bd4c
\fBarchive_util\fP(3),
Packit 08bd4c
\fBtar\fP(5)