aboutsummaryrefslogtreecommitdiff
path: root/src/archive_api.h
diff options
context:
space:
mode:
authorMax Kellermann <max@duempel.org>2009-12-15 17:36:21 +0100
committerMax Kellermann <max@duempel.org>2009-12-15 19:02:24 +0100
commitaef6609f4f9464ae9f33febcd3967d8df50c220b (patch)
treea4cde62419cc43bb3dc84868ce5f9a89532d06ca /src/archive_api.h
parent6b728e4756523f5d00eff865bb8a2e9f929a9433 (diff)
archive_api.h: moved struct archive_plugin to archive_plugin.h
Diffstat (limited to 'src/archive_api.h')
-rw-r--r--src/archive_api.h60
1 files changed, 1 insertions, 59 deletions
diff --git a/src/archive_api.h b/src/archive_api.h
index dbd050bf..20a4f927 100644
--- a/src/archive_api.h
+++ b/src/archive_api.h
@@ -27,69 +27,11 @@
*/
#include "archive_internal.h"
+#include "archive_plugin.h"
#include "input_stream.h"
#include <stdbool.h>
-struct archive_file;
-
-struct archive_plugin {
- const char *name;
-
- /**
- * optional, set this to NULL if the archive plugin doesn't
- * have/need one this must false if there is an error and
- * true otherwise
- */
- bool (*init)(void);
-
- /**
- * optional, set this to NULL if the archive plugin doesn't
- * have/need one
- */
- void (*finish)(void);
-
- /**
- * tryes to open archive file and associates handle with archive
- * returns pointer to handle used is all operations with this archive
- * or NULL when opening fails
- */
- struct archive_file *(*open)(char * pathname);
-
- /**
- * reset routine will move current read index in archive to default
- * position and then the filenames from archives can be read
- * via scan_next routine
- */
- void (*scan_reset)(struct archive_file *);
-
- /**
- * the read method will return corresponding files from archive
- * (as pathnames) and move read index to next file. When there is no
- * next file it return NULL.
- */
- char *(*scan_next)(struct archive_file *);
-
- /**
- * Opens an input_stream of a file within the archive.
- *
- * @param path the path within the archive
- */
- bool (*open_stream)(struct archive_file *, struct input_stream *is,
- const char *path);
-
- /**
- * closes archive file.
- */
- void (*close)(struct archive_file *);
-
- /**
- * suffixes handled by this plugin.
- * last element in these arrays must always be a NULL
- */
- const char *const*suffixes;
-};
-
bool archive_lookup(char *pathname, char **archive, char **inpath, char **suffix);
#endif