fwupd/libfwupdplugin/fu-archive.h

59 lines
1.4 KiB
C

/*
* Copyright (C) 2018 Richard Hughes <richard@hughsie.com>
*
* SPDX-License-Identifier: LGPL-2.1+
*/
#pragma once
#include <glib-object.h>
#define FU_TYPE_ARCHIVE (fu_archive_get_type ())
G_DECLARE_FINAL_TYPE (FuArchive, fu_archive, FU, ARCHIVE, GObject)
/**
* FuArchiveFlags:
* @FU_ARCHIVE_FLAG_NONE: No flags set
* @FU_ARCHIVE_FLAG_IGNORE_PATH: Ignore any path component
*
* The flags to use when loading the archive.
**/
typedef enum {
FU_ARCHIVE_FLAG_NONE = 0,
FU_ARCHIVE_FLAG_IGNORE_PATH = 1 << 0,
/*< private >*/
FU_ARCHIVE_FLAG_LAST
} FuArchiveFlags;
/**
* FuArchiveIterateFunc:
* @self: a #FuArchive
* @filename: a filename
* @bytes: the blob referenced by @filename
* @user_data: user data
* @error: a #GError or NULL
*
* The archive iteration callback.
*/
typedef gboolean (*FuArchiveIterateFunc) (FuArchive *self,
const gchar *filename,
GBytes *bytes,
gpointer user_data,
GError **error)
G_GNUC_WARN_UNUSED_RESULT;
FuArchive *fu_archive_new (GBytes *data,
FuArchiveFlags flags,
GError **error)
G_GNUC_WARN_UNUSED_RESULT;
GBytes *fu_archive_lookup_by_fn (FuArchive *self,
const gchar *fn,
GError **error)
G_GNUC_WARN_UNUSED_RESULT;
gboolean fu_archive_iterate (FuArchive *self,
FuArchiveIterateFunc callback,
gpointer user_data,
GError **error)
G_GNUC_WARN_UNUSED_RESULT;