[pacman-dev] [PATCH 1/2] add libarchive compatability object

Dan McGee dpmcgee at gmail.com
Mon Jan 28 22:42:40 EST 2013


On Mon, Jan 28, 2013 at 7:23 PM, Dave Reisner <dreisner at archlinux.org> wrote:
> This allows us to support both libarchive 2.8.x as well as 3.x without
> deprecation warnings on compile.
>
> Signed-off-by: Dave Reisner <dreisner at archlinux.org>
> ---
> Decided to just do this since libarchive 3.x has been a little scary from a
> stability standpoint. Compile tested on both 3.1.1 and 3.0.4.

Apparently patches don't sit more than two hours before being pulled
and pushed to master now. :) Reviewing anyway.

It is silly to do one-liners in a C file where they can't be inlined;
I would have done everything in the .h file itself and then the
compiler could work its magic to remove these redirections completely.

-Dan

>  lib/libalpm/Makefile.am         |  1 +
>  lib/libalpm/libarchive-compat.c | 65 +++++++++++++++++++++++++++++++++++++++++
>  lib/libalpm/libarchive-compat.h | 33 +++++++++++++++++++++
>  3 files changed, 99 insertions(+)
>  create mode 100644 lib/libalpm/libarchive-compat.c
>  create mode 100644 lib/libalpm/libarchive-compat.h
>
> diff --git a/lib/libalpm/Makefile.am b/lib/libalpm/Makefile.am
> index 5cf66b9..55fec9c 100644
> --- a/lib/libalpm/Makefile.am
> +++ b/lib/libalpm/Makefile.am
> @@ -44,6 +44,7 @@ libalpm_la_SOURCES = \
>         graph.h graph.c \
>         group.h group.c \
>         handle.h handle.c \
> +       libarchive-compat.h libarchive-compat.c \
>         log.h log.c \
>         package.h package.c \
>         pkghash.h pkghash.c \
> diff --git a/lib/libalpm/libarchive-compat.c b/lib/libalpm/libarchive-compat.c
> new file mode 100644
> index 0000000..56af2e1
> --- /dev/null
> +++ b/lib/libalpm/libarchive-compat.c
> @@ -0,0 +1,65 @@
> +/*
> + * libarchive-compat.c
> + *
> + *  Copyright (c) 2013 Pacman Development Team <pacman-dev at archlinux.org>
> + *
> + *  This program is free software; you can redistribute it and/or modify
> + *  it under the terms of the GNU General Public License as published by
> + *  the Free Software Foundation; either version 2 of the License, or
> + *  (at your option) any later version.
> + *
> + *  This program is distributed in the hope that it will be useful,
> + *  but WITHOUT ANY WARRANTY; without even the implied warranty of
> + *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
> + *  GNU General Public License for more details.
> + *
> + *  You should have received a copy of the GNU General Public License
> + *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
> + */
> +
> +#include <stdint.h>
> +
> +#include "libarchive-compat.h"
> +
> +int _alpm_archive_read_free(struct archive *archive) {
> +#if ARCHIVE_VERSION_NUMBER >= 3000000
> +       return archive_read_free(archive);
> +#else
> +       return archive_read_finish(archive);
> +#endif
> +}
> +
> +int64_t _alpm_archive_compressed_ftell(struct archive *archive) {
> +#if ARCHIVE_VERSION_NUMBER >= 3000000
> +       return archive_filter_bytes(archive, -1);
> +#else
> +       return archive_position_compressed(archive);
> +#endif
> +}
> +
> +int _alpm_archive_read_open_file(struct archive *archive,
> +               const char *filename, size_t block_size) {
> +#if ARCHIVE_VERSION_NUMBER >= 3000000
> +       return archive_read_open_filename(archive, filename, block_size);
> +#else
> +       return archive_read_open_file(archive, filename, block_size);
> +#endif
> +}
> +
> +int _alpm_archive_filter_code(struct archive *archive) {
> +#if ARCHIVE_VERSION_NUMBER >= 3000000
> +       return archive_filter_code(archive, 0);
> +#else
> +       return archive_compression(archive);
> +#endif
> +}
> +
> +int _alpm_archive_read_support_filter_all(struct archive *archive) {
> +#if ARCHIVE_VERSION_NUMBER >= 3000000
> +       return archive_read_support_filter_all(archive);
> +#else
> +       return archive_read_support_compression_all(archive);
> +#endif
> +}
> +
> +/* vim: set ts=2 sw=2 noet: */
> diff --git a/lib/libalpm/libarchive-compat.h b/lib/libalpm/libarchive-compat.h
> new file mode 100644
> index 0000000..a1b379e
> --- /dev/null
> +++ b/lib/libalpm/libarchive-compat.h
> @@ -0,0 +1,33 @@
> +/*
> + * libarchive-compat.h
> + *
> + *  Copyright (c) 2013 Pacman Development Team <pacman-dev at archlinux.org>
> + *
> + *  This program is free software; you can redistribute it and/or modify
> + *  it under the terms of the GNU General Public License as published by
> + *  the Free Software Foundation; either version 2 of the License, or
> + *  (at your option) any later version.
> + *
> + *  This program is distributed in the hope that it will be useful,
> + *  but WITHOUT ANY WARRANTY; without even the implied warranty of
> + *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
> + *  GNU General Public License for more details.
> + *
> + *  You should have received a copy of the GNU General Public License
> + *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
> + */
> +#ifndef _LIBARCHIVE_H
> +#define _LIBARCHIVE_H
> +
> +#include <archive.h>
> +
> +int _alpm_archive_read_free(struct archive *archive);
> +int64_t _alpm_archive_compressed_ftell(struct archive *archive);
> +int _alpm_archive_read_open_file(struct archive *archive,
> +               const char *filename, size_t block_size);
> +int _alpm_archive_filter_code(struct archive *archive);
> +int _alpm_archive_read_support_filter_all(struct archive *archive);
> +
> +#endif /* _LIBARCHIVE_H */
> +
> +/* vim: set ts=2 sw=2 noet: */
> --
> 1.8.1.1
>
>


More information about the pacman-dev mailing list