diff options
author | Allan McRae <allan@archlinux.org> | 2012-05-01 10:12:13 +0200 |
---|---|---|
committer | Allan McRae <allan@archlinux.org> | 2012-12-14 04:45:12 +0100 |
commit | 0445c68d9b7738553dd1a5088110b8b0a1e1f7f9 (patch) | |
tree | dc71ae968d3a65b87f496635d2f19f162ccdd179 /lib/libalpm/be_local.c | |
parent | da3a0333de34b37d073e1d27e9a07a7fa80025ee (diff) | |
download | pacman-0445c68d9b7738553dd1a5088110b8b0a1e1f7f9.tar.gz pacman-0445c68d9b7738553dd1a5088110b8b0a1e1f7f9.tar.xz |
Add internal functions for reading mtree file from local db
Signed-off-by: Allan McRae <allan@archlinux.org>
Diffstat (limited to 'lib/libalpm/be_local.c')
-rw-r--r-- | lib/libalpm/be_local.c | 77 |
1 files changed, 77 insertions, 0 deletions
diff --git a/lib/libalpm/be_local.c b/lib/libalpm/be_local.c index f0e4a80f..57092455 100644 --- a/lib/libalpm/be_local.c +++ b/lib/libalpm/be_local.c @@ -28,6 +28,10 @@ #include <dirent.h> #include <limits.h> /* PATH_MAX */ +/* libarchive */ +#include <archive.h> +#include <archive_entry.h> + /* libalpm */ #include "db.h" #include "alpm_list.h" @@ -211,6 +215,75 @@ static int _cache_changelog_close(const alpm_pkg_t UNUSED *pkg, void *fp) return fclose((FILE *)fp); } +/** + * Open a package mtree file for reading. + * @param pkg the local package to read the changelog of + * @return a archive structure for the package mtree file + */ +static struct archive *_cache_mtree_open(alpm_pkg_t *pkg) +{ + int r; + struct archive *mtree; + + pkg->handle->pm_errno = 0; + + alpm_db_t *db = alpm_pkg_get_db(pkg); + char *mtfile = _alpm_local_db_pkgpath(db, pkg, "mtree"); + + if(access(mtfile, F_OK) != 0) { + /* there is no mtree file for this package */ + goto error; + } + + if((mtree = archive_read_new()) == NULL) { + pkg->handle->pm_errno = ALPM_ERR_LIBARCHIVE; + goto error; + } + + archive_read_support_filter_gzip(mtree); + archive_read_support_format_mtree(mtree); + + if((r = archive_read_open_file(mtree, mtfile, ALPM_BUFFER_SIZE))) { + _alpm_log(pkg->handle, ALPM_LOG_ERROR, _("error while reading file %s: %s\n"), + mtfile, archive_error_string(mtree)); + pkg->handle->pm_errno = ALPM_ERR_LIBARCHIVE; + archive_read_finish(mtree); + goto error; + } + + free(mtfile); + return mtree; + +error: + free(mtfile); + return NULL; +} + +/** + * Read next entry from a package mtree file. + * @param pkg the package that the mtree file is being read from + * @param archive the archive structure reading from the mtree file + * @param entry an archive_entry to store the entry header information + * @return 0 if end of archive is reached, non-zero otherwise. + */ +static int _cache_mtree_next(const alpm_pkg_t UNUSED *pkg, + struct archive *mtree, struct archive_entry **entry) +{ + return archive_read_next_header(mtree, entry); +} + +/** + * Close a package mtree file for reading. + * @param pkg the package that the mtree file was read from + * @param mtree the archive structure use for reading from the mtree file + * @return whether closing the package changelog stream was successful + */ +static int _cache_mtree_close(const alpm_pkg_t UNUSED *pkg, + struct archive *mtree) +{ + return archive_read_finish(mtree); +} + static int _cache_force_load(alpm_pkg_t *pkg) { return local_db_read(pkg, INFRQ_ALL); @@ -246,6 +319,10 @@ static struct pkg_operations local_pkg_ops = { .changelog_read = _cache_changelog_read, .changelog_close = _cache_changelog_close, + .mtree_open = _cache_mtree_open, + .mtree_next = _cache_mtree_next, + .mtree_close = _cache_mtree_close, + .force_load = _cache_force_load, }; |