mirror of
https://github.com/Gator96100/ProxSpace.git
synced 2024-12-12 06:51:25 -08:00
2906 lines
94 KiB
C
2906 lines
94 KiB
C
/*
|
|
* alpm.h
|
|
*
|
|
* Copyright (c) 2006-2021 Pacman Development Team <pacman-dev@archlinux.org>
|
|
* Copyright (c) 2002-2006 by Judd Vinet <jvinet@zeroflux.org>
|
|
* Copyright (c) 2005 by Aurelien Foret <orelien@chez.com>
|
|
* Copyright (c) 2005 by Christian Hamar <krics@linuxforum.hu>
|
|
* Copyright (c) 2005, 2006 by Miklos Vajna <vmiklos@frugalware.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/>.
|
|
*/
|
|
|
|
|
|
/** @mainpage alpm
|
|
*
|
|
* libalpm is a package management library, primarily used by pacman.
|
|
*/
|
|
|
|
#ifndef ALPM_H
|
|
#define ALPM_H
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include <stdint.h> /* int64_t */
|
|
#include <sys/types.h> /* off_t */
|
|
#include <stdarg.h> /* va_list */
|
|
|
|
/* libarchive */
|
|
#include <archive.h>
|
|
#include <archive_entry.h>
|
|
|
|
#include <alpm_list.h>
|
|
|
|
/** @addtogroup libalpm The libalpm Public API
|
|
*
|
|
*
|
|
*
|
|
* libalpm is a package management library, primarily used by pacman.
|
|
* For ease of access, the libalpm manual has been split up into several sections.
|
|
*
|
|
* @section see_also See Also
|
|
* \b libalpm_list(3),
|
|
* \b libalpm_cb(3),
|
|
* \b libalpm_databases(3),
|
|
* \b libalpm_depends(3),
|
|
* \b libalpm_errors(3),
|
|
* \b libalpm_files(3),
|
|
* \b libalpm_groups(3),
|
|
* \b libalpm_handle(3),
|
|
* \b libalpm_log(3),
|
|
* \b libalpm_misc(3),
|
|
* \b libalpm_options(3),
|
|
* \b libalpm_packages(3),
|
|
* \b libalpm_sig(3),
|
|
* \b libalpm_trans(3)
|
|
* @{
|
|
*/
|
|
|
|
/*
|
|
* Opaque Structures
|
|
*/
|
|
|
|
/** The libalpm context handle.
|
|
*
|
|
* This struct represents an instance of libalpm.
|
|
* @ingroup libalpm_handle
|
|
*/
|
|
typedef struct __alpm_handle_t alpm_handle_t;
|
|
|
|
/** A database.
|
|
*
|
|
* A database is a container that stores metadata about packages.
|
|
*
|
|
* A database can be located on the local filesystem or on a remote server.
|
|
*
|
|
* To use a database, it must first be registered via \link alpm_register_syncdb \endlink.
|
|
* If the database is already present in dbpath then it will be usable. Otherwise,
|
|
* the database needs to be downloaded using \link alpm_db_update \endlink. Even if the
|
|
* source of the database is the local filesystem.
|
|
*
|
|
* After this, the database can be used to query packages and groups. Any packages or groups
|
|
* from the database will continue to be owned by the database and do not need to be freed by
|
|
* the user. They will be freed when the database is unregistered.
|
|
*
|
|
* Databases are automatically unregistered when the \link alpm_handle_t \endlink is released.
|
|
* @ingroup libalpm_databases
|
|
*/
|
|
typedef struct __alpm_db_t alpm_db_t;
|
|
|
|
|
|
/** A package.
|
|
*
|
|
* A package can be loaded from disk via \link alpm_pkg_load \endlink or retrieved from a database.
|
|
* Packages from databases are automatically freed when the database is unregistered. Packages loaded
|
|
* from a file must be freed manually.
|
|
*
|
|
* Packages can then be queried for metadata or added to a \link alpm_trans_t transaction \endlink
|
|
* to be added or removed from the system.
|
|
* @ingroup libalpm_packages
|
|
*/
|
|
typedef struct __alpm_pkg_t alpm_pkg_t;
|
|
|
|
/** Transaction structure used internally by libalpm
|
|
* @ingroup libalpm_trans
|
|
* */
|
|
typedef struct __alpm_trans_t alpm_trans_t;
|
|
|
|
|
|
/** The time type used by libalpm. Represents a unix time stamp
|
|
* @ingroup libalpm_misc */
|
|
typedef int64_t alpm_time_t;
|
|
|
|
/** @addtogroup libalpm_files Files
|
|
* @brief Functions for package files
|
|
* @{
|
|
*/
|
|
|
|
/** File in a package */
|
|
typedef struct _alpm_file_t {
|
|
/** Name of the file */
|
|
char *name;
|
|
/** Size of the file */
|
|
off_t size;
|
|
/** The file's permissions */
|
|
mode_t mode;
|
|
} alpm_file_t;
|
|
|
|
/** Package filelist container */
|
|
typedef struct _alpm_filelist_t {
|
|
/** Amount of files in the array */
|
|
size_t count;
|
|
/** An array of files */
|
|
alpm_file_t *files;
|
|
} alpm_filelist_t;
|
|
|
|
/** Local package or package file backup entry */
|
|
typedef struct _alpm_backup_t {
|
|
/** Name of the file (without .pacsave extension) */
|
|
char *name;
|
|
/** Hash of the filename (used internally) */
|
|
char *hash;
|
|
} alpm_backup_t;
|
|
|
|
/** Determines whether a package filelist contains a given path.
|
|
* The provided path should be relative to the install root with no leading
|
|
* slashes, e.g. "etc/localtime". When searching for directories, the path must
|
|
* have a trailing slash.
|
|
* @param filelist a pointer to a package filelist
|
|
* @param path the path to search for in the package
|
|
* @return a pointer to the matching file or NULL if not found
|
|
*/
|
|
alpm_file_t *alpm_filelist_contains(alpm_filelist_t *filelist, const char *path);
|
|
|
|
/* End of libalpm_files */
|
|
/** @} */
|
|
|
|
|
|
/** @addtogroup libalpm_groups Groups
|
|
* @brief Functions for package groups
|
|
* @{
|
|
*/
|
|
|
|
/** Package group */
|
|
typedef struct _alpm_group_t {
|
|
/** group name */
|
|
char *name;
|
|
/** list of alpm_pkg_t packages */
|
|
alpm_list_t *packages;
|
|
} alpm_group_t;
|
|
|
|
/** Find group members across a list of databases.
|
|
* If a member exists in several databases, only the first database is used.
|
|
* IgnorePkg is also handled.
|
|
* @param dbs the list of alpm_db_t *
|
|
* @param name the name of the group
|
|
* @return the list of alpm_pkg_t * (caller is responsible for alpm_list_free)
|
|
*/
|
|
alpm_list_t *alpm_find_group_pkgs(alpm_list_t *dbs, const char *name);
|
|
|
|
/* End of libalpm_groups */
|
|
/** @} */
|
|
|
|
|
|
/** @addtogroup libalpm_errors Error Codes
|
|
* Error codes returned by libalpm.
|
|
* @{
|
|
*/
|
|
|
|
/** libalpm's error type */
|
|
typedef enum _alpm_errno_t {
|
|
/** No error */
|
|
ALPM_ERR_OK = 0,
|
|
/** Failed to allocate memory */
|
|
ALPM_ERR_MEMORY,
|
|
/** A system error occurred */
|
|
ALPM_ERR_SYSTEM,
|
|
/** Permmision denied */
|
|
ALPM_ERR_BADPERMS,
|
|
/** Should be a file */
|
|
ALPM_ERR_NOT_A_FILE,
|
|
/** Should be a directory */
|
|
ALPM_ERR_NOT_A_DIR,
|
|
/** Function was called with invalid arguments */
|
|
ALPM_ERR_WRONG_ARGS,
|
|
/** Insufficient disk space */
|
|
ALPM_ERR_DISK_SPACE,
|
|
/* Interface */
|
|
/** Handle should be null */
|
|
ALPM_ERR_HANDLE_NULL,
|
|
/** Handle should not be null */
|
|
ALPM_ERR_HANDLE_NOT_NULL,
|
|
/** Failed to acquire lock */
|
|
ALPM_ERR_HANDLE_LOCK,
|
|
/* Databases */
|
|
/** Failed to open database */
|
|
ALPM_ERR_DB_OPEN,
|
|
/** Failed to create database */
|
|
ALPM_ERR_DB_CREATE,
|
|
/** Database should not be null */
|
|
ALPM_ERR_DB_NULL,
|
|
/** Database should be null */
|
|
ALPM_ERR_DB_NOT_NULL,
|
|
/** The database could not be found */
|
|
ALPM_ERR_DB_NOT_FOUND,
|
|
/** Database is invalid */
|
|
ALPM_ERR_DB_INVALID,
|
|
/** Database has an invalid signature */
|
|
ALPM_ERR_DB_INVALID_SIG,
|
|
/** The localdb is in a newer/older format than libalpm expects */
|
|
ALPM_ERR_DB_VERSION,
|
|
/** Failed to write to the database */
|
|
ALPM_ERR_DB_WRITE,
|
|
/** Failed to remove entry from database */
|
|
ALPM_ERR_DB_REMOVE,
|
|
/* Servers */
|
|
/** Server URL is in an invalid format */
|
|
ALPM_ERR_SERVER_BAD_URL,
|
|
/** The database has no configured servers */
|
|
ALPM_ERR_SERVER_NONE,
|
|
/* Transactions */
|
|
/** A transaction is already initialized */
|
|
ALPM_ERR_TRANS_NOT_NULL,
|
|
/** A transaction has not been initialized */
|
|
ALPM_ERR_TRANS_NULL,
|
|
/** Duplicate target in transaction */
|
|
ALPM_ERR_TRANS_DUP_TARGET,
|
|
/** Duplicate filename in transaction */
|
|
ALPM_ERR_TRANS_DUP_FILENAME,
|
|
/** A transaction has not been initialized */
|
|
ALPM_ERR_TRANS_NOT_INITIALIZED,
|
|
/** Transaction has not been prepared */
|
|
ALPM_ERR_TRANS_NOT_PREPARED,
|
|
/** Transaction was aborted */
|
|
ALPM_ERR_TRANS_ABORT,
|
|
/** Failed to interrupt transaction */
|
|
ALPM_ERR_TRANS_TYPE,
|
|
/** Tried to commit transaction without locking the database */
|
|
ALPM_ERR_TRANS_NOT_LOCKED,
|
|
/** A hook failed to run */
|
|
ALPM_ERR_TRANS_HOOK_FAILED,
|
|
/* Packages */
|
|
/** Package not found */
|
|
ALPM_ERR_PKG_NOT_FOUND,
|
|
/** Package is in ignorepkg */
|
|
ALPM_ERR_PKG_IGNORED,
|
|
/** Package is invalid */
|
|
ALPM_ERR_PKG_INVALID,
|
|
/** Package has an invalid checksum */
|
|
ALPM_ERR_PKG_INVALID_CHECKSUM,
|
|
/** Package has an invalid signature */
|
|
ALPM_ERR_PKG_INVALID_SIG,
|
|
/** Package does not have a signature */
|
|
ALPM_ERR_PKG_MISSING_SIG,
|
|
/** Cannot open the package file */
|
|
ALPM_ERR_PKG_OPEN,
|
|
/** Failed to remove package files */
|
|
ALPM_ERR_PKG_CANT_REMOVE,
|
|
/** Package has an invalid name */
|
|
ALPM_ERR_PKG_INVALID_NAME,
|
|
/** Package has an invalid architecture */
|
|
ALPM_ERR_PKG_INVALID_ARCH,
|
|
/* Signatures */
|
|
/** Signatures are missing */
|
|
ALPM_ERR_SIG_MISSING,
|
|
/** Signatures are invalid */
|
|
ALPM_ERR_SIG_INVALID,
|
|
/* Dependencies */
|
|
/** Dependencies could not be satisfied */
|
|
ALPM_ERR_UNSATISFIED_DEPS,
|
|
/** Conflicting dependencies */
|
|
ALPM_ERR_CONFLICTING_DEPS,
|
|
/** Files conflict */
|
|
ALPM_ERR_FILE_CONFLICTS,
|
|
/* Misc */
|
|
/** Download failed */
|
|
ALPM_ERR_RETRIEVE,
|
|
/** Invalid Regex */
|
|
ALPM_ERR_INVALID_REGEX,
|
|
/* External library errors */
|
|
/** Error in libarchive */
|
|
ALPM_ERR_LIBARCHIVE,
|
|
/** Error in libcurl */
|
|
ALPM_ERR_LIBCURL,
|
|
/** Error in external download program */
|
|
ALPM_ERR_EXTERNAL_DOWNLOAD,
|
|
/** Error in gpgme */
|
|
ALPM_ERR_GPGME,
|
|
/** Missing compile-time features */
|
|
ALPM_ERR_MISSING_CAPABILITY_SIGNATURES
|
|
} alpm_errno_t;
|
|
|
|
/** Returns the current error code from the handle.
|
|
* @param handle the context handle
|
|
* @return the current error code of the handle
|
|
*/
|
|
alpm_errno_t alpm_errno(alpm_handle_t *handle);
|
|
|
|
/** Returns the string corresponding to an error number.
|
|
* @param err the error code to get the string for
|
|
* @return the string relating to the given error code
|
|
*/
|
|
const char *alpm_strerror(alpm_errno_t err);
|
|
|
|
/* End of libalpm_errors */
|
|
/** @} */
|
|
|
|
|
|
/** \addtogroup libalpm_handle Handle
|
|
* @brief Functions to initialize and release libalpm
|
|
* @{
|
|
*/
|
|
|
|
/** Initializes the library.
|
|
* Creates handle, connects to database and creates lockfile.
|
|
* This must be called before any other functions are called.
|
|
* @param root the root path for all filesystem operations
|
|
* @param dbpath the absolute path to the libalpm database
|
|
* @param err an optional variable to hold any error return codes
|
|
* @return a context handle on success, NULL on error, err will be set if provided
|
|
*/
|
|
alpm_handle_t *alpm_initialize(const char *root, const char *dbpath,
|
|
alpm_errno_t *err);
|
|
|
|
/** Release the library.
|
|
* Disconnects from the database, removes handle and lockfile
|
|
* This should be the last alpm call you make.
|
|
* After this returns, handle should be considered invalid and cannot be reused
|
|
* in any way.
|
|
* @param handle the context handle
|
|
* @return 0 on success, -1 on error
|
|
*/
|
|
int alpm_release(alpm_handle_t *handle);
|
|
|
|
/* End of libalpm_handle */
|
|
/** @} */
|
|
|
|
|
|
/** @addtogroup libalpm_sig Signature checking
|
|
* @brief Functions to check signatures
|
|
* @{
|
|
*/
|
|
|
|
/** PGP signature verification options */
|
|
typedef enum _alpm_siglevel_t {
|
|
/** Packages require a signature */
|
|
ALPM_SIG_PACKAGE = (1 << 0),
|
|
/** Packages do not require a signature,
|
|
* but check packages that do have signatures */
|
|
ALPM_SIG_PACKAGE_OPTIONAL = (1 << 1),
|
|
/* Allow packages with signatures that are marginal trust */
|
|
ALPM_SIG_PACKAGE_MARGINAL_OK = (1 << 2),
|
|
/** Allow packages with signatures that are unknown trust */
|
|
ALPM_SIG_PACKAGE_UNKNOWN_OK = (1 << 3),
|
|
|
|
/** Databases require a signature */
|
|
ALPM_SIG_DATABASE = (1 << 10),
|
|
/** Databases do not require a signature,
|
|
* but check databases that do have signatures */
|
|
ALPM_SIG_DATABASE_OPTIONAL = (1 << 11),
|
|
/** Allow databases with signatures that are marginal trust */
|
|
ALPM_SIG_DATABASE_MARGINAL_OK = (1 << 12),
|
|
/** Allow databases with signatures that are unknown trust */
|
|
ALPM_SIG_DATABASE_UNKNOWN_OK = (1 << 13),
|
|
|
|
/** The Default siglevel */
|
|
ALPM_SIG_USE_DEFAULT = (1 << 30)
|
|
} alpm_siglevel_t;
|
|
|
|
/** PGP signature verification status return codes */
|
|
typedef enum _alpm_sigstatus_t {
|
|
/** Signature is valid */
|
|
ALPM_SIGSTATUS_VALID,
|
|
/** The key has expired */
|
|
ALPM_SIGSTATUS_KEY_EXPIRED,
|
|
/** The signature has expired */
|
|
ALPM_SIGSTATUS_SIG_EXPIRED,
|
|
/** The key is not in the keyring */
|
|
ALPM_SIGSTATUS_KEY_UNKNOWN,
|
|
/** The key has been disabled */
|
|
ALPM_SIGSTATUS_KEY_DISABLED,
|
|
/** The signature is invalid */
|
|
ALPM_SIGSTATUS_INVALID
|
|
} alpm_sigstatus_t;
|
|
|
|
|
|
/** The trust level of a PGP key */
|
|
typedef enum _alpm_sigvalidity_t {
|
|
/** The signature is fully trusted */
|
|
ALPM_SIGVALIDITY_FULL,
|
|
/** The signature is marginally trusted */
|
|
ALPM_SIGVALIDITY_MARGINAL,
|
|
/** The signature is never trusted */
|
|
ALPM_SIGVALIDITY_NEVER,
|
|
/** The signature has unknown trust */
|
|
ALPM_SIGVALIDITY_UNKNOWN
|
|
} alpm_sigvalidity_t;
|
|
|
|
/** A PGP key */
|
|
typedef struct _alpm_pgpkey_t {
|
|
/** The actual key data */
|
|
void *data;
|
|
/** The key's fingerprint */
|
|
char *fingerprint;
|
|
/** UID of the key */
|
|
char *uid;
|
|
/** Name of the key's owner */
|
|
char *name;
|
|
/** Email of the key's owner */
|
|
char *email;
|
|
/** When the key was created */
|
|
alpm_time_t created;
|
|
/** When the key expires */
|
|
alpm_time_t expires;
|
|
/** The length of the key */
|
|
unsigned int length;
|
|
/** has the key been revoked */
|
|
unsigned int revoked;
|
|
/** A character representing the encryption algorithm used by the public key
|
|
*
|
|
* ? = unknown
|
|
* R = RSA
|
|
* D = DSA
|
|
* E = EDDSA
|
|
*/
|
|
char pubkey_algo;
|
|
} alpm_pgpkey_t;
|
|
|
|
/**
|
|
* Signature result. Contains the key, status, and validity of a given
|
|
* signature.
|
|
*/
|
|
typedef struct _alpm_sigresult_t {
|
|
/** The key of the signature */
|
|
alpm_pgpkey_t key;
|
|
/** The status of the signature */
|
|
alpm_sigstatus_t status;
|
|
/** The validity of the signature */
|
|
alpm_sigvalidity_t validity;
|
|
} alpm_sigresult_t;
|
|
|
|
/**
|
|
* Signature list. Contains the number of signatures found and a pointer to an
|
|
* array of results. The array is of size count.
|
|
*/
|
|
typedef struct _alpm_siglist_t {
|
|
/** The amount of results in the array */
|
|
size_t count;
|
|
/** An array of sigresults */
|
|
alpm_sigresult_t *results;
|
|
} alpm_siglist_t;
|
|
|
|
/**
|
|
* Check the PGP signature for the given package file.
|
|
* @param pkg the package to check
|
|
* @param siglist a pointer to storage for signature results
|
|
* @return a int value : 0 (valid), 1 (invalid), -1 (an error occurred)
|
|
*/
|
|
int alpm_pkg_check_pgp_signature(alpm_pkg_t *pkg, alpm_siglist_t *siglist);
|
|
|
|
/**
|
|
* Check the PGP signature for the given database.
|
|
* @param db the database to check
|
|
* @param siglist a pointer to storage for signature results
|
|
* @return a int value : 0 (valid), 1 (invalid), -1 (an error occurred)
|
|
*/
|
|
int alpm_db_check_pgp_signature(alpm_db_t *db, alpm_siglist_t *siglist);
|
|
|
|
/**
|
|
* Clean up and free a signature result list.
|
|
* Note that this does not free the siglist object itself in case that
|
|
* was allocated on the stack; this is the responsibility of the caller.
|
|
* @param siglist a pointer to storage for signature results
|
|
* @return 0 on success, -1 on error
|
|
*/
|
|
int alpm_siglist_cleanup(alpm_siglist_t *siglist);
|
|
|
|
/**
|
|
* Decode a loaded signature in base64 form.
|
|
* @param base64_data the signature to attempt to decode
|
|
* @param data the decoded data; must be freed by the caller
|
|
* @param data_len the length of the returned data
|
|
* @return 0 on success, -1 on failure to properly decode
|
|
*/
|
|
int alpm_decode_signature(const char *base64_data,
|
|
unsigned char **data, size_t *data_len);
|
|
|
|
/**
|
|
* Extract the Issuer Key ID from a signature
|
|
* @param handle the context handle
|
|
* @param identifier the identifier of the key.
|
|
* This may be the name of the package or the path to the package.
|
|
* @param sig PGP signature
|
|
* @param len length of signature
|
|
* @param keys a pointer to storage for key IDs
|
|
* @return 0 on success, -1 on error
|
|
*/
|
|
int alpm_extract_keyid(alpm_handle_t *handle, const char *identifier,
|
|
const unsigned char *sig, const size_t len, alpm_list_t **keys);
|
|
|
|
/* End of libalpm_sig */
|
|
/** @} */
|
|
|
|
|
|
/** @addtogroup libalpm_depends Dependency
|
|
* @brief Functions dealing with libalpm's dependency and conflict
|
|
* information.
|
|
* @{
|
|
*/
|
|
|
|
/** Types of version constraints in dependency specs. */
|
|
typedef enum _alpm_depmod_t {
|
|
/** No version constraint */
|
|
ALPM_DEP_MOD_ANY = 1,
|
|
/** Test version equality (package=x.y.z) */
|
|
ALPM_DEP_MOD_EQ,
|
|
/** Test for at least a version (package>=x.y.z) */
|
|
ALPM_DEP_MOD_GE,
|
|
/** Test for at most a version (package<=x.y.z) */
|
|
ALPM_DEP_MOD_LE,
|
|
/** Test for greater than some version (package>x.y.z) */
|
|
ALPM_DEP_MOD_GT,
|
|
/** Test for less than some version (package<x.y.z) */
|
|
ALPM_DEP_MOD_LT
|
|
} alpm_depmod_t;
|
|
|
|
/**
|
|
* File conflict type.
|
|
* Whether the conflict results from a file existing on the filesystem, or with
|
|
* another target in the transaction.
|
|
*/
|
|
typedef enum _alpm_fileconflicttype_t {
|
|
/** The conflict results with a another target in the transaction */
|
|
ALPM_FILECONFLICT_TARGET = 1,
|
|
/** The conflict results from a file existing on the filesystem */
|
|
ALPM_FILECONFLICT_FILESYSTEM
|
|
} alpm_fileconflicttype_t;
|
|
|
|
/** The basic dependency type.
|
|
*
|
|
* This type is used throughout libalpm, not just for dependencies
|
|
* but also conflicts and providers. */
|
|
typedef struct _alpm_depend_t {
|
|
/** Name of the provider to satisfy this dependency */
|
|
char *name;
|
|
/** Version of the provider to match against (optional) */
|
|
char *version;
|
|
/** A description of why this dependency is needed (optional) */
|
|
char *desc;
|
|
/** A hash of name (used internally to speed up conflict checks) */
|
|
unsigned long name_hash;
|
|
/** How the version should match against the provider */
|
|
alpm_depmod_t mod;
|
|
} alpm_depend_t;
|
|
|
|
/** Missing dependency. */
|
|
typedef struct _alpm_depmissing_t {
|
|
/** Name of the package that has the dependency */
|
|
char *target;
|
|
/** The dependency that was wanted */
|
|
alpm_depend_t *depend;
|
|
/** If the depmissing was caused by a conflict, the name of the package
|
|
* that would be installed, causing the satisfying package to be removed */
|
|
char *causingpkg;
|
|
} alpm_depmissing_t;
|
|
|
|
/** A conflict that has occurred between two packages. */
|
|
typedef struct _alpm_conflict_t {
|
|
/** Hash of the first package name
|
|
* (used internally to speed up conflict checks) */
|
|
unsigned long package1_hash;
|
|
/** Hash of the second package name
|
|
* (used internally to speed up conflict checks) */
|
|
unsigned long package2_hash;
|
|
/** Name of the first package */
|
|
char *package1;
|
|
/** Name of the second package */
|
|
char *package2;
|
|
/** The conflict */
|
|
alpm_depend_t *reason;
|
|
} alpm_conflict_t;
|
|
|
|
/** File conflict.
|
|
*
|
|
* A conflict that has happened due to a two packages containing the same file,
|
|
* or a package contains a file that is already on the filesystem and not owned
|
|
* by that package. */
|
|
typedef struct _alpm_fileconflict_t {
|
|
/** The name of the package that caused the conflict */
|
|
char *target;
|
|
/** The type of conflict */
|
|
alpm_fileconflicttype_t type;
|
|
/** The name of the file that the package conflicts with */
|
|
char *file;
|
|
/** The name of the package that also owns the file if there is one*/
|
|
char *ctarget;
|
|
} alpm_fileconflict_t;
|
|
|
|
/** Checks dependencies and returns missing ones in a list.
|
|
* Dependencies can include versions with depmod operators.
|
|
* @param handle the context handle
|
|
* @param pkglist the list of local packages
|
|
* @param remove an alpm_list_t* of packages to be removed
|
|
* @param upgrade an alpm_list_t* of packages to be upgraded (remove-then-upgrade)
|
|
* @param reversedeps handles the backward dependencies
|
|
* @return an alpm_list_t* of alpm_depmissing_t pointers.
|
|
*/
|
|
alpm_list_t *alpm_checkdeps(alpm_handle_t *handle, alpm_list_t *pkglist,
|
|
alpm_list_t *remove, alpm_list_t *upgrade, int reversedeps);
|
|
|
|
/** Find a package satisfying a specified dependency.
|
|
* The dependency can include versions with depmod operators.
|
|
* @param pkgs an alpm_list_t* of alpm_pkg_t where the satisfyer will be searched
|
|
* @param depstring package or provision name, versioned or not
|
|
* @return a alpm_pkg_t* satisfying depstring
|
|
*/
|
|
alpm_pkg_t *alpm_find_satisfier(alpm_list_t *pkgs, const char *depstring);
|
|
|
|
/** Find a package satisfying a specified dependency.
|
|
* First look for a literal, going through each db one by one. Then look for
|
|
* providers. The first satisfyer that belongs to an installed package is
|
|
* returned. If no providers belong to an installed package then an
|
|
* alpm_question_select_provider_t is created to select the provider.
|
|
* The dependency can include versions with depmod operators.
|
|
*
|
|
* @param handle the context handle
|
|
* @param dbs an alpm_list_t* of alpm_db_t where the satisfyer will be searched
|
|
* @param depstring package or provision name, versioned or not
|
|
* @return a alpm_pkg_t* satisfying depstring
|
|
*/
|
|
alpm_pkg_t *alpm_find_dbs_satisfier(alpm_handle_t *handle,
|
|
alpm_list_t *dbs, const char *depstring);
|
|
|
|
/** Check the package conflicts in a database
|
|
*
|
|
* @param handle the context handle
|
|
* @param pkglist the list of packages to check
|
|
*
|
|
* @return an alpm_list_t of alpm_conflict_t
|
|
*/
|
|
alpm_list_t *alpm_checkconflicts(alpm_handle_t *handle, alpm_list_t *pkglist);
|
|
|
|
/** Returns a newly allocated string representing the dependency information.
|
|
* @param dep a dependency info structure
|
|
* @return a formatted string, e.g. "glibc>=2.12"
|
|
*/
|
|
char *alpm_dep_compute_string(const alpm_depend_t *dep);
|
|
|
|
/** Return a newly allocated dependency information parsed from a string
|
|
*\link alpm_dep_free should be used to free the dependency \endlink
|
|
* @param depstring a formatted string, e.g. "glibc=2.12"
|
|
* @return a dependency info structure
|
|
*/
|
|
alpm_depend_t *alpm_dep_from_string(const char *depstring);
|
|
|
|
/** Free a dependency info structure
|
|
* @param dep struct to free
|
|
*/
|
|
void alpm_dep_free(alpm_depend_t *dep);
|
|
|
|
/** Free a fileconflict and its members.
|
|
* @param conflict the fileconflict to free
|
|
*/
|
|
void alpm_fileconflict_free(alpm_fileconflict_t *conflict);
|
|
|
|
/** Free a depmissing and its members
|
|
* @param miss the depmissing to free
|
|
* */
|
|
void alpm_depmissing_free(alpm_depmissing_t *miss);
|
|
|
|
/**
|
|
* Free a conflict and its members.
|
|
* @param conflict the conflict to free
|
|
*/
|
|
void alpm_conflict_free(alpm_conflict_t *conflict);
|
|
|
|
|
|
/* End of libalpm_depends */
|
|
/** @} */
|
|
|
|
|
|
/** \addtogroup libalpm_cb Callbacks
|
|
* @brief Functions and structures for libalpm's callbacks
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* Type of events.
|
|
*/
|
|
typedef enum _alpm_event_type_t {
|
|
/** Dependencies will be computed for a package. */
|
|
ALPM_EVENT_CHECKDEPS_START = 1,
|
|
/** Dependencies were computed for a package. */
|
|
ALPM_EVENT_CHECKDEPS_DONE,
|
|
/** File conflicts will be computed for a package. */
|
|
ALPM_EVENT_FILECONFLICTS_START,
|
|
/** File conflicts were computed for a package. */
|
|
ALPM_EVENT_FILECONFLICTS_DONE,
|
|
/** Dependencies will be resolved for target package. */
|
|
ALPM_EVENT_RESOLVEDEPS_START,
|
|
/** Dependencies were resolved for target package. */
|
|
ALPM_EVENT_RESOLVEDEPS_DONE,
|
|
/** Inter-conflicts will be checked for target package. */
|
|
ALPM_EVENT_INTERCONFLICTS_START,
|
|
/** Inter-conflicts were checked for target package. */
|
|
ALPM_EVENT_INTERCONFLICTS_DONE,
|
|
/** Processing the package transaction is starting. */
|
|
ALPM_EVENT_TRANSACTION_START,
|
|
/** Processing the package transaction is finished. */
|
|
ALPM_EVENT_TRANSACTION_DONE,
|
|
/** Package will be installed/upgraded/downgraded/re-installed/removed; See
|
|
* alpm_event_package_operation_t for arguments. */
|
|
ALPM_EVENT_PACKAGE_OPERATION_START,
|
|
/** Package was installed/upgraded/downgraded/re-installed/removed; See
|
|
* alpm_event_package_operation_t for arguments. */
|
|
ALPM_EVENT_PACKAGE_OPERATION_DONE,
|
|
/** Target package's integrity will be checked. */
|
|
ALPM_EVENT_INTEGRITY_START,
|
|
/** Target package's integrity was checked. */
|
|
ALPM_EVENT_INTEGRITY_DONE,
|
|
/** Target package will be loaded. */
|
|
ALPM_EVENT_LOAD_START,
|
|
/** Target package is finished loading. */
|
|
ALPM_EVENT_LOAD_DONE,
|
|
/** Scriptlet has printed information; See alpm_event_scriptlet_info_t for
|
|
* arguments. */
|
|
ALPM_EVENT_SCRIPTLET_INFO,
|
|
/** Database files will be downloaded from a repository. */
|
|
ALPM_EVENT_DB_RETRIEVE_START,
|
|
/** Database files were downloaded from a repository. */
|
|
ALPM_EVENT_DB_RETRIEVE_DONE,
|
|
/** Not all database files were successfully downloaded from a repository. */
|
|
ALPM_EVENT_DB_RETRIEVE_FAILED,
|
|
/** Package files will be downloaded from a repository. */
|
|
ALPM_EVENT_PKG_RETRIEVE_START,
|
|
/** Package files were downloaded from a repository. */
|
|
ALPM_EVENT_PKG_RETRIEVE_DONE,
|
|
/** Not all package files were successfully downloaded from a repository. */
|
|
ALPM_EVENT_PKG_RETRIEVE_FAILED,
|
|
/** Disk space usage will be computed for a package. */
|
|
ALPM_EVENT_DISKSPACE_START,
|
|
/** Disk space usage was computed for a package. */
|
|
ALPM_EVENT_DISKSPACE_DONE,
|
|
/** An optdepend for another package is being removed; See
|
|
* alpm_event_optdep_removal_t for arguments. */
|
|
ALPM_EVENT_OPTDEP_REMOVAL,
|
|
/** A configured repository database is missing; See
|
|
* alpm_event_database_missing_t for arguments. */
|
|
ALPM_EVENT_DATABASE_MISSING,
|
|
/** Checking keys used to create signatures are in keyring. */
|
|
ALPM_EVENT_KEYRING_START,
|
|
/** Keyring checking is finished. */
|
|
ALPM_EVENT_KEYRING_DONE,
|
|
/** Downloading missing keys into keyring. */
|
|
ALPM_EVENT_KEY_DOWNLOAD_START,
|
|
/** Key downloading is finished. */
|
|
ALPM_EVENT_KEY_DOWNLOAD_DONE,
|
|
/** A .pacnew file was created; See alpm_event_pacnew_created_t for arguments. */
|
|
ALPM_EVENT_PACNEW_CREATED,
|
|
/** A .pacsave file was created; See alpm_event_pacsave_created_t for
|
|
* arguments. */
|
|
ALPM_EVENT_PACSAVE_CREATED,
|
|
/** Processing hooks will be started. */
|
|
ALPM_EVENT_HOOK_START,
|
|
/** Processing hooks is finished. */
|
|
ALPM_EVENT_HOOK_DONE,
|
|
/** A hook is starting */
|
|
ALPM_EVENT_HOOK_RUN_START,
|
|
/** A hook has finished running. */
|
|
ALPM_EVENT_HOOK_RUN_DONE
|
|
} alpm_event_type_t;
|
|
|
|
/** An event that may represent any event. */
|
|
typedef struct _alpm_event_any_t {
|
|
/** Type of event */
|
|
alpm_event_type_t type;
|
|
} alpm_event_any_t;
|
|
|
|
/** An enum over the kind of package operations. */
|
|
typedef enum _alpm_package_operation_t {
|
|
/** Package (to be) installed. (No oldpkg) */
|
|
ALPM_PACKAGE_INSTALL = 1,
|
|
/** Package (to be) upgraded */
|
|
ALPM_PACKAGE_UPGRADE,
|
|
/** Package (to be) re-installed */
|
|
ALPM_PACKAGE_REINSTALL,
|
|
/** Package (to be) downgraded */
|
|
ALPM_PACKAGE_DOWNGRADE,
|
|
/** Package (to be) removed (No newpkg) */
|
|
ALPM_PACKAGE_REMOVE
|
|
} alpm_package_operation_t;
|
|
|
|
/** A package operation event occurred. */
|
|
typedef struct _alpm_event_package_operation_t {
|
|
/** Type of event */
|
|
alpm_event_type_t type;
|
|
/** Type of operation */
|
|
alpm_package_operation_t operation;
|
|
/** Old package */
|
|
alpm_pkg_t *oldpkg;
|
|
/** New package */
|
|
alpm_pkg_t *newpkg;
|
|
} alpm_event_package_operation_t;
|
|
|
|
/** An optional dependency was removed. */
|
|
typedef struct _alpm_event_optdep_removal_t {
|
|
/** Type of event */
|
|
alpm_event_type_t type;
|
|
/** Package with the optdep */
|
|
alpm_pkg_t *pkg;
|
|
/** Optdep being removed */
|
|
alpm_depend_t *optdep;
|
|
} alpm_event_optdep_removal_t;
|
|
|
|
/** A scriptlet was ran. */
|
|
typedef struct _alpm_event_scriptlet_info_t {
|
|
/** Type of event */
|
|
alpm_event_type_t type;
|
|
/** Line of scriptlet output */
|
|
const char *line;
|
|
} alpm_event_scriptlet_info_t;
|
|
|
|
|
|
/** A database is missing.
|
|
*
|
|
* The database is registered but has not been downloaded
|
|
*/
|
|
typedef struct _alpm_event_database_missing_t {
|
|
/** Type of event */
|
|
alpm_event_type_t type;
|
|
/** Name of the database */
|
|
const char *dbname;
|
|
} alpm_event_database_missing_t;
|
|
|
|
/** A package was downloaded. */
|
|
typedef struct _alpm_event_pkgdownload_t {
|
|
/** Type of event */
|
|
alpm_event_type_t type;
|
|
/** Name of the file */
|
|
const char *file;
|
|
} alpm_event_pkgdownload_t;
|
|
|
|
/** A pacnew file was created. */
|
|
typedef struct _alpm_event_pacnew_created_t {
|
|
/** Type of event */
|
|
alpm_event_type_t type;
|
|
/** Whether the creation was result of a NoUpgrade or not */
|
|
int from_noupgrade;
|
|
/** Old package */
|
|
alpm_pkg_t *oldpkg;
|
|
/** New Package */
|
|
alpm_pkg_t *newpkg;
|
|
/** Filename of the file without the .pacnew suffix */
|
|
const char *file;
|
|
} alpm_event_pacnew_created_t;
|
|
|
|
/** A pacsave file was created. */
|
|
typedef struct _alpm_event_pacsave_created_t {
|
|
/** Type of event */
|
|
alpm_event_type_t type;
|
|
/** Old package */
|
|
alpm_pkg_t *oldpkg;
|
|
/** Filename of the file without the .pacsave suffix */
|
|
const char *file;
|
|
} alpm_event_pacsave_created_t;
|
|
|
|
/** Kind of hook. */
|
|
typedef enum _alpm_hook_when_t {
|
|
/* Pre transaction hook */
|
|
ALPM_HOOK_PRE_TRANSACTION = 1,
|
|
/* Post transaction hook */
|
|
ALPM_HOOK_POST_TRANSACTION
|
|
} alpm_hook_when_t;
|
|
|
|
/** pre/post transaction hooks are to be ran. */
|
|
typedef struct _alpm_event_hook_t {
|
|
/** Type of event*/
|
|
alpm_event_type_t type;
|
|
/** Type of hook */
|
|
alpm_hook_when_t when;
|
|
} alpm_event_hook_t;
|
|
|
|
/** A pre/post transaction hook was ran. */
|
|
typedef struct _alpm_event_hook_run_t {
|
|
/** Type of event */
|
|
alpm_event_type_t type;
|
|
/** Name of hook */
|
|
const char *name;
|
|
/** Description of hook to be outputted */
|
|
const char *desc;
|
|
/** position of hook being run */
|
|
size_t position;
|
|
/** total hooks being run */
|
|
size_t total;
|
|
} alpm_event_hook_run_t;
|
|
|
|
/** Packages downloading about to start. */
|
|
typedef struct _alpm_event_pkg_retrieve_t {
|
|
/** Type of event */
|
|
alpm_event_type_t type;
|
|
/** Number of packages to download */
|
|
size_t num;
|
|
/** Total size of packages to download */
|
|
off_t total_size;
|
|
} alpm_event_pkg_retrieve_t;
|
|
|
|
/** Events.
|
|
* This is a union passed to the callback that allows the frontend to know
|
|
* which type of event was triggered (via type). It is then possible to
|
|
* typecast the pointer to the right structure, or use the union field, in order
|
|
* to access event-specific data. */
|
|
typedef union _alpm_event_t {
|
|
/** Type of event it's always safe to access this. */
|
|
alpm_event_type_t type;
|
|
/** The any event type. It's always safe to access this. */
|
|
alpm_event_any_t any;
|
|
/** Package operation */
|
|
alpm_event_package_operation_t package_operation;
|
|
/** An optdept was remove */
|
|
alpm_event_optdep_removal_t optdep_removal;
|
|
/** A scriptlet was ran */
|
|
alpm_event_scriptlet_info_t scriptlet_info;
|
|
/** A database is missing */
|
|
alpm_event_database_missing_t database_missing;
|
|
/** A package was downloaded */
|
|
alpm_event_pkgdownload_t pkgdownload;
|
|
/** A pacnew file was created */
|
|
alpm_event_pacnew_created_t pacnew_created;
|
|
/** A pacsave file was created */
|
|
alpm_event_pacsave_created_t pacsave_created;
|
|
/** Pre/post transaction hooks are being ran */
|
|
alpm_event_hook_t hook;
|
|
/** A hook was ran */
|
|
alpm_event_hook_run_t hook_run;
|
|
/** Download packages */
|
|
alpm_event_pkg_retrieve_t pkg_retrieve;
|
|
} alpm_event_t;
|
|
|
|
/** Event callback.
|
|
*
|
|
* Called when an event occurs
|
|
* @param ctx user-provided context
|
|
* @param event the event that occurred */
|
|
typedef void (*alpm_cb_event)(void *ctx, alpm_event_t *);
|
|
|
|
/**
|
|
* Type of question.
|
|
* Unlike the events or progress enumerations, this enum has bitmask values
|
|
* so a frontend can use a bitmask map to supply preselected answers to the
|
|
* different types of questions.
|
|
*/
|
|
typedef enum _alpm_question_type_t {
|
|
/** Should target in ignorepkg be installed anyway? */
|
|
ALPM_QUESTION_INSTALL_IGNOREPKG = (1 << 0),
|
|
/** Should a package be replaced? */
|
|
ALPM_QUESTION_REPLACE_PKG = (1 << 1),
|
|
/** Should a conflicting package be removed? */
|
|
ALPM_QUESTION_CONFLICT_PKG = (1 << 2),
|
|
/** Should a corrupted package be deleted? */
|
|
ALPM_QUESTION_CORRUPTED_PKG = (1 << 3),
|
|
/** Should unresolvable targets be removed from the transaction? */
|
|
ALPM_QUESTION_REMOVE_PKGS = (1 << 4),
|
|
/** Provider selection */
|
|
ALPM_QUESTION_SELECT_PROVIDER = (1 << 5),
|
|
/** Should a key be imported? */
|
|
ALPM_QUESTION_IMPORT_KEY = (1 << 6)
|
|
} alpm_question_type_t;
|
|
|
|
/** A question that can represent any other question. */
|
|
typedef struct _alpm_question_any_t {
|
|
/** Type of question */
|
|
alpm_question_type_t type;
|
|
/** Answer */
|
|
int answer;
|
|
} alpm_question_any_t;
|
|
|
|
/** Should target in ignorepkg be installed anyway? */
|
|
typedef struct _alpm_question_install_ignorepkg_t {
|
|
/** Type of question */
|
|
alpm_question_type_t type;
|
|
/** Answer: whether or not to install pkg anyway */
|
|
int install;
|
|
/** The ignored package that we are deciding whether to install */
|
|
alpm_pkg_t *pkg;
|
|
} alpm_question_install_ignorepkg_t;
|
|
|
|
/** Should a package be replaced? */
|
|
typedef struct _alpm_question_replace_t {
|
|
/** Type of question */
|
|
alpm_question_type_t type;
|
|
/** Answer: whether or not to replace oldpkg with newpkg */
|
|
int replace;
|
|
/** Package to be replaced */
|
|
alpm_pkg_t *oldpkg;
|
|
/** Package to replace with.*/
|
|
alpm_pkg_t *newpkg;
|
|
/** DB of newpkg */
|
|
alpm_db_t *newdb;
|
|
} alpm_question_replace_t;
|
|
|
|
/** Should a conflicting package be removed? */
|
|
typedef struct _alpm_question_conflict_t {
|
|
/** Type of question */
|
|
alpm_question_type_t type;
|
|
/** Answer: whether or not to remove conflict->package2 */
|
|
int remove;
|
|
/** Conflict info */
|
|
alpm_conflict_t *conflict;
|
|
} alpm_question_conflict_t;
|
|
|
|
/** Should a corrupted package be deleted? */
|
|
typedef struct _alpm_question_corrupted_t {
|
|
/** Type of question */
|
|
alpm_question_type_t type;
|
|
/** Answer: whether or not to remove filepath */
|
|
int remove;
|
|
/** File to remove */
|
|
const char *filepath;
|
|
/** Error code indicating the reason for package invalidity */
|
|
alpm_errno_t reason;
|
|
} alpm_question_corrupted_t;
|
|
|
|
/** Should unresolvable targets be removed from the transaction? */
|
|
typedef struct _alpm_question_remove_pkgs_t {
|
|
/** Type of question */
|
|
alpm_question_type_t type;
|
|
/** Answer: whether or not to skip packages */
|
|
int skip;
|
|
/** List of alpm_pkg_t* with unresolved dependencies */
|
|
alpm_list_t *packages;
|
|
} alpm_question_remove_pkgs_t;
|
|
|
|
/** Provider selection */
|
|
typedef struct _alpm_question_select_provider_t {
|
|
/** Type of question */
|
|
alpm_question_type_t type;
|
|
/** Answer: which provider to use (index from providers) */
|
|
int use_index;
|
|
/** List of alpm_pkg_t* as possible providers */
|
|
alpm_list_t *providers;
|
|
/** What providers provide for */
|
|
alpm_depend_t *depend;
|
|
} alpm_question_select_provider_t;
|
|
|
|
/** Should a key be imported? */
|
|
typedef struct _alpm_question_import_key_t {
|
|
/** Type of question */
|
|
alpm_question_type_t type;
|
|
/** Answer: whether or not to import key */
|
|
int import;
|
|
/** The key to import */
|
|
alpm_pgpkey_t *key;
|
|
} alpm_question_import_key_t;
|
|
|
|
/**
|
|
* Questions.
|
|
* This is an union passed to the callback that allows the frontend to know
|
|
* which type of question was triggered (via type). It is then possible to
|
|
* typecast the pointer to the right structure, or use the union field, in order
|
|
* to access question-specific data. */
|
|
typedef union _alpm_question_t {
|
|
/** The type of question. It's always safe to access this. */
|
|
alpm_question_type_t type;
|
|
/** A question that can represent any question.
|
|
* It's always safe to access this. */
|
|
alpm_question_any_t any;
|
|
/** Should target in ignorepkg be installed anyway? */
|
|
alpm_question_install_ignorepkg_t install_ignorepkg;
|
|
/** Should a package be replaced? */
|
|
alpm_question_replace_t replace;
|
|
/** Should a conflicting package be removed? */
|
|
alpm_question_conflict_t conflict;
|
|
/** Should a corrupted package be deleted? */
|
|
alpm_question_corrupted_t corrupted;
|
|
/** Should unresolvable targets be removed from the transaction? */
|
|
alpm_question_remove_pkgs_t remove_pkgs;
|
|
/** Provider selection */
|
|
alpm_question_select_provider_t select_provider;
|
|
/** Should a key be imported? */
|
|
alpm_question_import_key_t import_key;
|
|
} alpm_question_t;
|
|
|
|
/** Question callback.
|
|
*
|
|
* This callback allows user to give input and decide what to do during certain events
|
|
* @param ctx user-provided context
|
|
* @param question the question being asked.
|
|
*/
|
|
typedef void (*alpm_cb_question)(void *ctx, alpm_question_t *);
|
|
|
|
/** An enum over different kinds of progress alerts. */
|
|
typedef enum _alpm_progress_t {
|
|
/** Package install */
|
|
ALPM_PROGRESS_ADD_START,
|
|
/** Package upgrade */
|
|
ALPM_PROGRESS_UPGRADE_START,
|
|
/** Package downgrade */
|
|
ALPM_PROGRESS_DOWNGRADE_START,
|
|
/** Package reinstall */
|
|
ALPM_PROGRESS_REINSTALL_START,
|
|
/** Package removal */
|
|
ALPM_PROGRESS_REMOVE_START,
|
|
/** Conflict checking */
|
|
ALPM_PROGRESS_CONFLICTS_START,
|
|
/** Diskspace checking */
|
|
ALPM_PROGRESS_DISKSPACE_START,
|
|
/** Package Integrity checking */
|
|
ALPM_PROGRESS_INTEGRITY_START,
|
|
/** Loading packages from disk */
|
|
ALPM_PROGRESS_LOAD_START,
|
|
/** Checking signatures of packages */
|
|
ALPM_PROGRESS_KEYRING_START
|
|
} alpm_progress_t;
|
|
|
|
/** Progress callback
|
|
*
|
|
* Alert the front end about the progress of certain events.
|
|
* Allows the implementation of loading bars for events that
|
|
* make take a while to complete.
|
|
* @param ctx user-provided context
|
|
* @param progress the kind of event that is progressing
|
|
* @param pkg for package operations, the name of the package being operated on
|
|
* @param percent the percent completion of the action
|
|
* @param howmany the total amount of items in the action
|
|
* @param current the current amount of items completed
|
|
*/
|
|
/** Progress callback */
|
|
typedef void (*alpm_cb_progress)(void *ctx, alpm_progress_t progress, const char *pkg,
|
|
int percent, size_t howmany, size_t current);
|
|
|
|
/*
|
|
* Downloading
|
|
*/
|
|
|
|
/** File download events.
|
|
* These events are reported by ALPM via download callback.
|
|
*/
|
|
typedef enum _alpm_download_event_type_t {
|
|
/** A download was started */
|
|
ALPM_DOWNLOAD_INIT,
|
|
/** A download made progress */
|
|
ALPM_DOWNLOAD_PROGRESS,
|
|
/** Download will be retried */
|
|
ALPM_DOWNLOAD_RETRY,
|
|
/** A download completed */
|
|
ALPM_DOWNLOAD_COMPLETED
|
|
} alpm_download_event_type_t;
|
|
|
|
/** Context struct for when a download starts. */
|
|
typedef struct _alpm_download_event_init_t {
|
|
/** whether this file is optional and thus the errors could be ignored */
|
|
int optional;
|
|
} alpm_download_event_init_t;
|
|
|
|
/** Context struct for when a download progresses. */
|
|
typedef struct _alpm_download_event_progress_t {
|
|
/** Amount of data downloaded */
|
|
off_t downloaded;
|
|
/** Total amount need to be downloaded */
|
|
off_t total;
|
|
} alpm_download_event_progress_t;
|
|
|
|
/** Context struct for when a download retries. */
|
|
typedef struct _alpm_download_event_retry_t {
|
|
/** If the download will resume or start over */
|
|
int resume;
|
|
} alpm_download_event_retry_t;
|
|
|
|
/** Context struct for when a download completes. */
|
|
typedef struct _alpm_download_event_completed_t {
|
|
/** Total bytes in file */
|
|
off_t total;
|
|
/** download result code:
|
|
* 0 - download completed successfully
|
|
* 1 - the file is up-to-date
|
|
* -1 - error
|
|
*/
|
|
int result;
|
|
} alpm_download_event_completed_t;
|
|
|
|
/** Type of download progress callbacks.
|
|
* @param ctx user-provided context
|
|
* @param filename the name of the file being downloaded
|
|
* @param event the event type
|
|
* @param data the event data of type alpm_download_event_*_t
|
|
*/
|
|
typedef void (*alpm_cb_download)(void *ctx, const char *filename,
|
|
alpm_download_event_type_t event, void *data);
|
|
|
|
|
|
/** A callback for downloading files
|
|
* @param ctx user-provided context
|
|
* @param url the URL of the file to be downloaded
|
|
* @param localpath the directory to which the file should be downloaded
|
|
* @param force whether to force an update, even if the file is the same
|
|
* @return 0 on success, 1 if the file exists and is identical, -1 on
|
|
* error.
|
|
*/
|
|
typedef int (*alpm_cb_fetch)(void *ctx, const char *url, const char *localpath,
|
|
int force);
|
|
|
|
/* End of libalpm_cb */
|
|
/** @} */
|
|
|
|
|
|
/** @addtogroup libalpm_databases Database
|
|
* @brief Functions to query and manipulate the database of libalpm.
|
|
* @{
|
|
*/
|
|
|
|
/** Get the database of locally installed packages.
|
|
* The returned pointer points to an internal structure
|
|
* of libalpm which should only be manipulated through
|
|
* libalpm functions.
|
|
* @return a reference to the local database
|
|
*/
|
|
alpm_db_t *alpm_get_localdb(alpm_handle_t *handle);
|
|
|
|
/** Get the list of sync databases.
|
|
* Returns a list of alpm_db_t structures, one for each registered
|
|
* sync database.
|
|
*
|
|
* @param handle the context handle
|
|
* @return a reference to an internal list of alpm_db_t structures
|
|
*/
|
|
alpm_list_t *alpm_get_syncdbs(alpm_handle_t *handle);
|
|
|
|
/** Register a sync database of packages.
|
|
* Databases can not be registered when there is an active transaction.
|
|
*
|
|
* @param handle the context handle
|
|
* @param treename the name of the sync repository
|
|
* @param level what level of signature checking to perform on the
|
|
* database; note that this must be a '.sig' file type verification
|
|
* @return an alpm_db_t* on success (the value), NULL on error
|
|
*/
|
|
alpm_db_t *alpm_register_syncdb(alpm_handle_t *handle, const char *treename,
|
|
int level);
|
|
|
|
/** Unregister all package databases.
|
|
* Databases can not be unregistered while there is an active transaction.
|
|
*
|
|
* @param handle the context handle
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_unregister_all_syncdbs(alpm_handle_t *handle);
|
|
|
|
/** Unregister a package database.
|
|
* Databases can not be unregistered when there is an active transaction.
|
|
*
|
|
* @param db pointer to the package database to unregister
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_db_unregister(alpm_db_t *db);
|
|
|
|
/** Get the name of a package database.
|
|
* @param db pointer to the package database
|
|
* @return the name of the package database, NULL on error
|
|
*/
|
|
const char *alpm_db_get_name(const alpm_db_t *db);
|
|
|
|
/** Get the signature verification level for a database.
|
|
* Will return the default verification level if this database is set up
|
|
* with ALPM_SIG_USE_DEFAULT.
|
|
* @param db pointer to the package database
|
|
* @return the signature verification level
|
|
*/
|
|
int alpm_db_get_siglevel(alpm_db_t *db);
|
|
|
|
/** Check the validity of a database.
|
|
* This is most useful for sync databases and verifying signature status.
|
|
* If invalid, the handle error code will be set accordingly.
|
|
* @param db pointer to the package database
|
|
* @return 0 if valid, -1 if invalid (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_db_get_valid(alpm_db_t *db);
|
|
|
|
/** @name Server accessors
|
|
* @{
|
|
*/
|
|
|
|
/** Get the list of servers assigned to this db.
|
|
* @param db pointer to the database to get the servers from
|
|
* @return a char* list of servers
|
|
*/
|
|
alpm_list_t *alpm_db_get_servers(const alpm_db_t *db);
|
|
|
|
/** Sets the list of servers for the database to use.
|
|
* @param db the database to set the servers. The list will be duped and
|
|
* the original will still need to be freed by the caller.
|
|
* @param servers a char* list of servers.
|
|
*/
|
|
int alpm_db_set_servers(alpm_db_t *db, alpm_list_t *servers);
|
|
|
|
/** Add a download server to a database.
|
|
* @param db database pointer
|
|
* @param url url of the server
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_db_add_server(alpm_db_t *db, const char *url);
|
|
|
|
/** Remove a download server from a database.
|
|
* @param db database pointer
|
|
* @param url url of the server
|
|
* @return 0 on success, 1 on server not present,
|
|
* -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_db_remove_server(alpm_db_t *db, const char *url);
|
|
|
|
/* End of server accessors */
|
|
/** @} */
|
|
|
|
/** Update package databases.
|
|
*
|
|
* An update of the package databases in the list \a dbs will be attempted.
|
|
* Unless \a force is true, the update will only be performed if the remote
|
|
* databases were modified since the last update.
|
|
*
|
|
* This operation requires a database lock, and will return an applicable error
|
|
* if the lock could not be obtained.
|
|
*
|
|
* Example:
|
|
* @code
|
|
* alpm_list_t *dbs = alpm_get_syncdbs(config->handle);
|
|
* ret = alpm_db_update(config->handle, dbs, force);
|
|
* if(ret < 0) {
|
|
* pm_printf(ALPM_LOG_ERROR, _("failed to synchronize all databases (%s)\n"),
|
|
* alpm_strerror(alpm_errno(config->handle)));
|
|
* }
|
|
* @endcode
|
|
*
|
|
* @note After a successful update, the \link alpm_db_get_pkgcache()
|
|
* package cache \endlink will be invalidated
|
|
* @param handle the context handle
|
|
* @param dbs list of package databases to update
|
|
* @param force if true, then forces the update, otherwise update only in case
|
|
* the databases aren't up to date
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly),
|
|
* 1 if all databases are up to to date
|
|
*/
|
|
int alpm_db_update(alpm_handle_t *handle, alpm_list_t *dbs, int force);
|
|
|
|
/** Get a package entry from a package database.
|
|
* Looking up a package is O(1) and will be significantly faster than
|
|
* iterating over the pkgcahe.
|
|
* @param db pointer to the package database to get the package from
|
|
* @param name of the package
|
|
* @return the package entry on success, NULL on error
|
|
*/
|
|
alpm_pkg_t *alpm_db_get_pkg(alpm_db_t *db, const char *name);
|
|
|
|
/** Get the package cache of a package database.
|
|
* This is a list of all packages the db contains.
|
|
* @param db pointer to the package database to get the package from
|
|
* @return the list of packages on success, NULL on error
|
|
*/
|
|
alpm_list_t *alpm_db_get_pkgcache(alpm_db_t *db);
|
|
|
|
/** Get a group entry from a package database.
|
|
* Looking up a group is O(1) and will be significantly faster than
|
|
* iterating over the groupcahe.
|
|
* @param db pointer to the package database to get the group from
|
|
* @param name of the group
|
|
* @return the groups entry on success, NULL on error
|
|
*/
|
|
alpm_group_t *alpm_db_get_group(alpm_db_t *db, const char *name);
|
|
|
|
/** Get the group cache of a package database.
|
|
* @param db pointer to the package database to get the group from
|
|
* @return the list of groups on success, NULL on error
|
|
*/
|
|
alpm_list_t *alpm_db_get_groupcache(alpm_db_t *db);
|
|
|
|
/** Searches a database with regular expressions.
|
|
* @param db pointer to the package database to search in
|
|
* @param needles a list of regular expressions to search for
|
|
* @param ret pointer to list for storing packages matching all
|
|
* regular expressions - must point to an empty (NULL) alpm_list_t *.
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_db_search(alpm_db_t *db, const alpm_list_t *needles,
|
|
alpm_list_t **ret);
|
|
|
|
/** The usage level of a database. */
|
|
typedef enum _alpm_db_usage_t {
|
|
/** Enable refreshes for this database */
|
|
ALPM_DB_USAGE_SYNC = 1,
|
|
/** Enable search for this database */
|
|
ALPM_DB_USAGE_SEARCH = (1 << 1),
|
|
/** Enable installing packages from this database */
|
|
ALPM_DB_USAGE_INSTALL = (1 << 2),
|
|
/** Enable sysupgrades with this database */
|
|
ALPM_DB_USAGE_UPGRADE = (1 << 3),
|
|
/** Enable all usage levels */
|
|
ALPM_DB_USAGE_ALL = (1 << 4) - 1,
|
|
} alpm_db_usage_t;
|
|
|
|
/** @name Usage accessors
|
|
* @{
|
|
*/
|
|
|
|
/** Sets the usage of a database.
|
|
* @param db pointer to the package database to set the status for
|
|
* @param usage a bitmask of alpm_db_usage_t values
|
|
* @return 0 on success, or -1 on error
|
|
*/
|
|
int alpm_db_set_usage(alpm_db_t *db, int usage);
|
|
|
|
/** Gets the usage of a database.
|
|
* @param db pointer to the package database to get the status of
|
|
* @param usage pointer to an alpm_db_usage_t to store db's status
|
|
* @return 0 on success, or -1 on error
|
|
*/
|
|
int alpm_db_get_usage(alpm_db_t *db, int *usage);
|
|
|
|
/* End of usage accessors */
|
|
/** @} */
|
|
|
|
|
|
/* End of libalpm_databases */
|
|
/** @} */
|
|
|
|
|
|
/** \addtogroup libalpm_log Logging Functions
|
|
* @brief Functions to log using libalpm
|
|
* @{
|
|
*/
|
|
|
|
/** Logging Levels */
|
|
typedef enum _alpm_loglevel_t {
|
|
/** Error */
|
|
ALPM_LOG_ERROR = 1,
|
|
/** Warning */
|
|
ALPM_LOG_WARNING = (1 << 1),
|
|
/** Debug */
|
|
ALPM_LOG_DEBUG = (1 << 2),
|
|
/** Function */
|
|
ALPM_LOG_FUNCTION = (1 << 3)
|
|
} alpm_loglevel_t;
|
|
|
|
|
|
/** The callback type for logging.
|
|
*
|
|
* libalpm will call this function whenever something is to be logged.
|
|
* many libalpm will produce log output. Additionally any calls to \link alpm_logaction
|
|
* \endlink will also call this callback.
|
|
* @param ctx user-provided context
|
|
* @param level the currently set loglevel
|
|
* @param fmt the printf like format string
|
|
* @param args printf like arguments
|
|
*/
|
|
typedef void (*alpm_cb_log)(void *ctx, alpm_loglevel_t level, const char *fmt, va_list args);
|
|
|
|
/** A printf-like function for logging.
|
|
* @param handle the context handle
|
|
* @param prefix caller-specific prefix for the log
|
|
* @param fmt output format
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_logaction(alpm_handle_t *handle, const char *prefix,
|
|
const char *fmt, ...) __attribute__((format(printf, 3, 4)));
|
|
|
|
/* End of libalpm_log */
|
|
/** @} */
|
|
|
|
|
|
/** @addtogroup libalpm_options Options
|
|
* Libalpm option getters and setters
|
|
* @{
|
|
*/
|
|
|
|
/** @name Accessors for callbacks
|
|
* @{
|
|
*/
|
|
|
|
/** Returns the callback used for logging.
|
|
* @param handle the context handle
|
|
* @return the currently set log callback
|
|
*/
|
|
alpm_cb_log alpm_option_get_logcb(alpm_handle_t *handle);
|
|
|
|
/** Returns the callback used for logging.
|
|
* @param handle the context handle
|
|
* @return the currently set log callback context
|
|
*/
|
|
void *alpm_option_get_logcb_ctx(alpm_handle_t *handle);
|
|
|
|
/** Sets the callback used for logging.
|
|
* @param handle the context handle
|
|
* @param cb the cb to use
|
|
* @param ctx user-provided context to pass to cb
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_logcb(alpm_handle_t *handle, alpm_cb_log cb, void *ctx);
|
|
|
|
/** Returns the callback used to report download progress.
|
|
* @param handle the context handle
|
|
* @return the currently set download callback
|
|
*/
|
|
alpm_cb_download alpm_option_get_dlcb(alpm_handle_t *handle);
|
|
|
|
/** Returns the callback used to report download progress.
|
|
* @param handle the context handle
|
|
* @return the currently set download callback context
|
|
*/
|
|
void *alpm_option_get_dlcb_ctx(alpm_handle_t *handle);
|
|
|
|
/** Sets the callback used to report download progress.
|
|
* @param handle the context handle
|
|
* @param cb the cb to use
|
|
* @param ctx user-provided context to pass to cb
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_dlcb(alpm_handle_t *handle, alpm_cb_download cb, void *ctx);
|
|
|
|
/** Returns the downloading callback.
|
|
* @param handle the context handle
|
|
* @return the currently set fetch callback
|
|
*/
|
|
alpm_cb_fetch alpm_option_get_fetchcb(alpm_handle_t *handle);
|
|
|
|
/** Returns the downloading callback.
|
|
* @param handle the context handle
|
|
* @return the currently set fetch callback context
|
|
*/
|
|
void *alpm_option_get_fetchcb_ctx(alpm_handle_t *handle);
|
|
|
|
/** Sets the downloading callback.
|
|
* @param handle the context handle
|
|
* @param cb the cb to use
|
|
* @param ctx user-provided context to pass to cb
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_fetchcb(alpm_handle_t *handle, alpm_cb_fetch cb, void *ctx);
|
|
|
|
/** Returns the callback used for events.
|
|
* @param handle the context handle
|
|
* @return the currently set event callback
|
|
*/
|
|
alpm_cb_event alpm_option_get_eventcb(alpm_handle_t *handle);
|
|
|
|
/** Returns the callback used for events.
|
|
* @param handle the context handle
|
|
* @return the currently set event callback context
|
|
*/
|
|
void *alpm_option_get_eventcb_ctx(alpm_handle_t *handle);
|
|
|
|
/** Sets the callback used for events.
|
|
* @param handle the context handle
|
|
* @param cb the cb to use
|
|
* @param ctx user-provided context to pass to cb
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_eventcb(alpm_handle_t *handle, alpm_cb_event cb, void *ctx);
|
|
|
|
/** Returns the callback used for questions.
|
|
* @param handle the context handle
|
|
* @return the currently set question callback
|
|
*/
|
|
alpm_cb_question alpm_option_get_questioncb(alpm_handle_t *handle);
|
|
|
|
/** Returns the callback used for questions.
|
|
* @param handle the context handle
|
|
* @return the currently set question callback context
|
|
*/
|
|
void *alpm_option_get_questioncb_ctx(alpm_handle_t *handle);
|
|
|
|
/** Sets the callback used for questions.
|
|
* @param handle the context handle
|
|
* @param cb the cb to use
|
|
* @param ctx user-provided context to pass to cb
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_questioncb(alpm_handle_t *handle, alpm_cb_question cb, void *ctx);
|
|
|
|
/**Returns the callback used for operation progress.
|
|
* @param handle the context handle
|
|
* @return the currently set progress callback
|
|
*/
|
|
alpm_cb_progress alpm_option_get_progresscb(alpm_handle_t *handle);
|
|
|
|
/**Returns the callback used for operation progress.
|
|
* @param handle the context handle
|
|
* @return the currently set progress callback context
|
|
*/
|
|
void *alpm_option_get_progresscb_ctx(alpm_handle_t *handle);
|
|
|
|
/** Sets the callback used for operation progress.
|
|
* @param handle the context handle
|
|
* @param cb the cb to use
|
|
* @param ctx user-provided context to pass to cb
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_progresscb(alpm_handle_t *handle, alpm_cb_progress cb, void *ctx);
|
|
/* End of callback accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors to the root directory
|
|
*
|
|
* The root directory is the prefix to which libalpm installs packages to.
|
|
* Hooks and scriptlets will also be run in a chroot to ensure they behave correctly
|
|
* in alternative roots.
|
|
* @{
|
|
*/
|
|
|
|
/** Returns the root path. Read-only.
|
|
* @param handle the context handle
|
|
*/
|
|
const char *alpm_option_get_root(alpm_handle_t *handle);
|
|
/* End of root accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors to the database path
|
|
*
|
|
* The dbpath is where libalpm stores the local db and
|
|
* downloads sync databases.
|
|
* @{
|
|
*/
|
|
|
|
/** Returns the path to the database directory. Read-only.
|
|
* @param handle the context handle
|
|
*/
|
|
const char *alpm_option_get_dbpath(alpm_handle_t *handle);
|
|
/* End of dbpath accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors to the lockfile
|
|
*
|
|
* The lockfile is used to ensure two instances of libalpm can not write
|
|
* to the database at the same time. The lock file is created when
|
|
* committing a transaction and released when the transaction completes.
|
|
* Or when calling \link alpm_unlock \endlink.
|
|
* @{
|
|
*/
|
|
|
|
/** Get the name of the database lock file. Read-only.
|
|
* This is the name that the lockfile would have. It does not
|
|
* matter if the lockfile actually exists on disk.
|
|
* @param handle the context handle
|
|
*/
|
|
const char *alpm_option_get_lockfile(alpm_handle_t *handle);
|
|
/* End of lockfile accessors */
|
|
/** @} */
|
|
|
|
/** @name Accessors to the list of package cache directories.
|
|
*
|
|
* This is where libalpm will store downloaded packages.
|
|
* @{
|
|
*/
|
|
|
|
/** Gets the currently configured cachedirs,
|
|
* @param handle the context handle
|
|
* @return a char* list of cache directories
|
|
*/
|
|
alpm_list_t *alpm_option_get_cachedirs(alpm_handle_t *handle);
|
|
|
|
/** Sets the cachedirs.
|
|
* @param handle the context handle
|
|
* @param cachedirs a char* list of cachdirs. The list will be duped and
|
|
* the original will still need to be freed by the caller.
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_cachedirs(alpm_handle_t *handle, alpm_list_t *cachedirs);
|
|
|
|
/** Append a cachedir to the configured cachedirs.
|
|
* @param handle the context handle
|
|
* @param cachedir the cachedir to add
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_add_cachedir(alpm_handle_t *handle, const char *cachedir);
|
|
|
|
/** Remove a cachedir from the configured cachedirs.
|
|
* @param handle the context handle
|
|
* @param cachedir the cachedir to remove
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_remove_cachedir(alpm_handle_t *handle, const char *cachedir);
|
|
/* End of cachedir accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors to the list of package hook directories.
|
|
*
|
|
* libalpm will search these directories for hooks to run. A hook in
|
|
* a later directory will override previous hooks if they have the same name.
|
|
* @{
|
|
*/
|
|
|
|
/** Gets the currently configured hookdirs,
|
|
* @param handle the context handle
|
|
* @return a char* list of hook directories
|
|
*/
|
|
alpm_list_t *alpm_option_get_hookdirs(alpm_handle_t *handle);
|
|
|
|
/** Sets the hookdirs.
|
|
* @param handle the context handle
|
|
* @param hookdirs a char* list of hookdirs. The list will be duped and
|
|
* the original will still need to be freed by the caller.
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_hookdirs(alpm_handle_t *handle, alpm_list_t *hookdirs);
|
|
|
|
/** Append a hookdir to the configured hookdirs.
|
|
* @param handle the context handle
|
|
* @param hookdir the hookdir to add
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_add_hookdir(alpm_handle_t *handle, const char *hookdir);
|
|
|
|
/** Remove a hookdir from the configured hookdirs.
|
|
* @param handle the context handle
|
|
* @param hookdir the hookdir to remove
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_remove_hookdir(alpm_handle_t *handle, const char *hookdir);
|
|
/* End of hookdir accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors to the list of overwritable files.
|
|
*
|
|
* Normally libalpm will refuse to install a package that owns files that
|
|
* are already on disk and not owned by that package.
|
|
*
|
|
* If a conflicting file matches a glob in the overwrite_files list, then no
|
|
* conflict will be raised and libalpm will simply overwrite the file.
|
|
* @{
|
|
*/
|
|
|
|
/** Gets the currently configured overwritable files,
|
|
* @param handle the context handle
|
|
* @return a char* list of overwritable file globs
|
|
*/
|
|
alpm_list_t *alpm_option_get_overwrite_files(alpm_handle_t *handle);
|
|
|
|
/** Sets the overwritable files.
|
|
* @param handle the context handle
|
|
* @param globs a char* list of overwritable file globs. The list will be duped and
|
|
* the original will still need to be freed by the caller.
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_overwrite_files(alpm_handle_t *handle, alpm_list_t *globs);
|
|
|
|
/** Append an overwritable file to the configured overwritable files.
|
|
* @param handle the context handle
|
|
* @param glob the file glob to add
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_add_overwrite_file(alpm_handle_t *handle, const char *glob);
|
|
|
|
/** Remove a file glob from the configured overwritable files globs.
|
|
* @note The overwritable file list contains a list of globs. The glob to
|
|
* remove must exactly match the entry to remove. There is no glob expansion.
|
|
* @param handle the context handle
|
|
* @param glob the file glob to remove
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_remove_overwrite_file(alpm_handle_t *handle, const char *glob);
|
|
/* End of overwrite accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors to the log file
|
|
*
|
|
* This controls where libalpm will save log output to.
|
|
* @{
|
|
*/
|
|
|
|
/** Gets the filepath to the currently set logfile.
|
|
* @param handle the context handle
|
|
* @return the path to the logfile
|
|
*/
|
|
const char *alpm_option_get_logfile(alpm_handle_t *handle);
|
|
|
|
/** Sets the logfile path.
|
|
* @param handle the context handle
|
|
* @param logfile path to the new location of the logfile
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_logfile(alpm_handle_t *handle, const char *logfile);
|
|
/* End of logfile accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors to the GPG directory
|
|
*
|
|
* This controls where libalpm will store GnuPG's files.
|
|
* @{
|
|
*/
|
|
|
|
/** Returns the path to libalpm's GnuPG home directory.
|
|
* @param handle the context handle
|
|
* @return the path to libalpms's GnuPG home directory
|
|
*/
|
|
const char *alpm_option_get_gpgdir(alpm_handle_t *handle);
|
|
|
|
/** Sets the path to libalpm's GnuPG home directory.
|
|
* @param handle the context handle
|
|
* @param gpgdir the gpgdir to set
|
|
*/
|
|
int alpm_option_set_gpgdir(alpm_handle_t *handle, const char *gpgdir);
|
|
/* End of gpdir accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors for use syslog
|
|
*
|
|
* This controls whether libalpm will also use the syslog. Even if this option
|
|
* is enabled, libalpm will still try to log to its log file.
|
|
* @{
|
|
*/
|
|
|
|
/** Returns whether to use syslog (0 is FALSE, TRUE otherwise).
|
|
* @param handle the context handle
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_get_usesyslog(alpm_handle_t *handle);
|
|
|
|
/** Sets whether to use syslog (0 is FALSE, TRUE otherwise).
|
|
* @param handle the context handle
|
|
* @param usesyslog whether to use the syslog (0 is FALSE, TRUE otherwise)
|
|
*/
|
|
int alpm_option_set_usesyslog(alpm_handle_t *handle, int usesyslog);
|
|
/* End of usesyslog accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors to the list of no-upgrade files.
|
|
* These functions modify the list of files which should
|
|
* not be updated by package installation.
|
|
* @{
|
|
*/
|
|
|
|
/** Get the list of no-upgrade files
|
|
* @param handle the context handle
|
|
* @return the char* list of no-upgrade files
|
|
*/
|
|
alpm_list_t *alpm_option_get_noupgrades(alpm_handle_t *handle);
|
|
|
|
/** Add a file to the no-upgrade list
|
|
* @param handle the context handle
|
|
* @param path the path to add
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_add_noupgrade(alpm_handle_t *handle, const char *path);
|
|
|
|
/** Sets the list of no-upgrade files
|
|
* @param handle the context handle
|
|
* @param noupgrade a char* list of file to not upgrade.
|
|
* The list will be duped and the original will still need to be freed by the caller.
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_noupgrades(alpm_handle_t *handle, alpm_list_t *noupgrade);
|
|
|
|
/** Remove an entry from the no-upgrade list
|
|
* @param handle the context handle
|
|
* @param path the path to remove
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_remove_noupgrade(alpm_handle_t *handle, const char *path);
|
|
|
|
/** Test if a path matches any of the globs in the no-upgrade list
|
|
* @param handle the context handle
|
|
* @param path the path to test
|
|
* @return 0 is the path matches a glob, negative if there is no match and
|
|
* positive is the match was inverted
|
|
*/
|
|
int alpm_option_match_noupgrade(alpm_handle_t *handle, const char *path);
|
|
/* End of noupgrade accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors to the list of no-extract files.
|
|
* These functions modify the list of filenames which should
|
|
* be skipped packages which should
|
|
* not be upgraded by a sysupgrade operation.
|
|
* @{
|
|
*/
|
|
|
|
/** Get the list of no-extract files
|
|
* @param handle the context handle
|
|
* @return the char* list of no-extract files
|
|
*/
|
|
alpm_list_t *alpm_option_get_noextracts(alpm_handle_t *handle);
|
|
|
|
/** Add a file to the no-extract list
|
|
* @param handle the context handle
|
|
* @param path the path to add
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_add_noextract(alpm_handle_t *handle, const char *path);
|
|
|
|
/** Sets the list of no-extract files
|
|
* @param handle the context handle
|
|
* @param noextract a char* list of file to not extract.
|
|
* The list will be duped and the original will still need to be freed by the caller.
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_noextracts(alpm_handle_t *handle, alpm_list_t *noextract);
|
|
|
|
/** Remove an entry from the no-extract list
|
|
* @param handle the context handle
|
|
* @param path the path to remove
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_remove_noextract(alpm_handle_t *handle, const char *path);
|
|
|
|
/** Test if a path matches any of the globs in the no-extract list
|
|
* @param handle the context handle
|
|
* @param path the path to test
|
|
* @return 0 is the path matches a glob, negative if there is no match and
|
|
* positive is the match was inverted
|
|
*/
|
|
int alpm_option_match_noextract(alpm_handle_t *handle, const char *path);
|
|
/* End of noextract accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors to the list of ignored packages.
|
|
* These functions modify the list of packages that
|
|
* should be ignored by a sysupgrade.
|
|
*
|
|
* Entries in this list may be globs and only match the package's
|
|
* name. Providers are not taken into account.
|
|
* @{
|
|
*/
|
|
|
|
/** Get the list of ignored packages
|
|
* @param handle the context handle
|
|
* @return the char* list of ignored packages
|
|
*/
|
|
alpm_list_t *alpm_option_get_ignorepkgs(alpm_handle_t *handle);
|
|
|
|
/** Add a file to the ignored package list
|
|
* @param handle the context handle
|
|
* @param pkg the package to add
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_add_ignorepkg(alpm_handle_t *handle, const char *pkg);
|
|
|
|
/** Sets the list of packages to ignore
|
|
* @param handle the context handle
|
|
* @param ignorepkgs a char* list of packages to ignore
|
|
* The list will be duped and the original will still need to be freed by the caller.
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_ignorepkgs(alpm_handle_t *handle, alpm_list_t *ignorepkgs);
|
|
|
|
/** Remove an entry from the ignorepkg list
|
|
* @param handle the context handle
|
|
* @param pkg the package to remove
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_remove_ignorepkg(alpm_handle_t *handle, const char *pkg);
|
|
/* End of ignorepkg accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors to the list of ignored groups.
|
|
* These functions modify the list of groups whose packages
|
|
* should be ignored by a sysupgrade.
|
|
*
|
|
* Entries in this list may be globs.
|
|
* @{
|
|
*/
|
|
|
|
/** Get the list of ignored groups
|
|
* @param handle the context handle
|
|
* @return the char* list of ignored groups
|
|
*/
|
|
alpm_list_t *alpm_option_get_ignoregroups(alpm_handle_t *handle);
|
|
|
|
/** Add a file to the ignored group list
|
|
* @param handle the context handle
|
|
* @param grp the group to add
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_add_ignoregroup(alpm_handle_t *handle, const char *grp);
|
|
|
|
/** Sets the list of groups to ignore
|
|
* @param handle the context handle
|
|
* @param ignoregrps a char* list of groups to ignore
|
|
* The list will be duped and the original will still need to be freed by the caller.
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_ignoregroups(alpm_handle_t *handle, alpm_list_t *ignoregrps);
|
|
|
|
/** Remove an entry from the ignoregroup list
|
|
* @param handle the context handle
|
|
* @param grp the group to remove
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_remove_ignoregroup(alpm_handle_t *handle, const char *grp);
|
|
/* End of ignoregroup accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors to the list of ignored dependencies.
|
|
* These functions modify the list of dependencies that
|
|
* should be ignored by a sysupgrade.
|
|
*
|
|
* This is effectively a list of virtual providers that
|
|
* packages can use to satisfy their dependencies.
|
|
* @{
|
|
*/
|
|
|
|
/** Gets the list of dependencies that are assumed to be met
|
|
* @param handle the context handle
|
|
* @return a list of alpm_depend_t*
|
|
*/
|
|
alpm_list_t *alpm_option_get_assumeinstalled(alpm_handle_t *handle);
|
|
|
|
/** Add a depend to the assumed installed list
|
|
* @param handle the context handle
|
|
* @param dep the dependency to add
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_add_assumeinstalled(alpm_handle_t *handle, const alpm_depend_t *dep);
|
|
|
|
/** Sets the list of dependencies that are assumed to be met
|
|
* @param handle the context handle
|
|
* @param deps a list of *alpm_depend_t
|
|
* The list will be duped and the original will still need to be freed by the caller.
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_assumeinstalled(alpm_handle_t *handle, alpm_list_t *deps);
|
|
|
|
/** Remove an entry from the assume installed list
|
|
* @param handle the context handle
|
|
* @param dep the dep to remove
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_remove_assumeinstalled(alpm_handle_t *handle, const alpm_depend_t *dep);
|
|
/* End of assunmeinstalled accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors to the list of allowed architectures.
|
|
* libalpm will only install packages that match one of the configured
|
|
* architectures. The architectures do not need to match the physical
|
|
architecture. They can just be treated as a label.
|
|
* @{
|
|
*/
|
|
|
|
/** Returns the allowed package architecture.
|
|
* @param handle the context handle
|
|
* @return the configured package architectures
|
|
*/
|
|
alpm_list_t *alpm_option_get_architectures(alpm_handle_t *handle);
|
|
|
|
/** Adds an allowed package architecture.
|
|
* @param handle the context handle
|
|
* @param arch the architecture to set
|
|
*/
|
|
int alpm_option_add_architecture(alpm_handle_t *handle, const char *arch);
|
|
|
|
/** Sets the allowed package architecture.
|
|
* @param handle the context handle
|
|
* @param arches the architecture to set
|
|
*/
|
|
int alpm_option_set_architectures(alpm_handle_t *handle, alpm_list_t *arches);
|
|
|
|
/** Removes an allowed package architecture.
|
|
* @param handle the context handle
|
|
* @param arch the architecture to remove
|
|
*/
|
|
int alpm_option_remove_architecture(alpm_handle_t *handle, const char *arch);
|
|
|
|
/* End of arch accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors for check space.
|
|
*
|
|
* This controls whether libalpm will check if there is sufficient before
|
|
* installing packages.
|
|
* @{
|
|
*/
|
|
|
|
/** Get whether or not checking for free space before installing packages is enabled.
|
|
* @param handle the context handle
|
|
* @return 0 if disabled, 1 if enabled
|
|
*/
|
|
int alpm_option_get_checkspace(alpm_handle_t *handle);
|
|
|
|
/** Enable/disable checking free space before installing packages.
|
|
* @param handle the context handle
|
|
* @param checkspace 0 for disabled, 1 for enabled
|
|
*/
|
|
int alpm_option_set_checkspace(alpm_handle_t *handle, int checkspace);
|
|
/* End of checkspace accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors for the database extension
|
|
*
|
|
* This controls the extension used for sync databases. libalpm will use this
|
|
* extension to both lookup remote databses and as the name used when opening
|
|
* reading them.
|
|
*
|
|
* This is useful for file databases. Seems as files can increase the size of
|
|
* a database by quite a lot, a server could hold a database without files under
|
|
* one extension, and another with files under another extension.
|
|
*
|
|
* Which one is downloaded and used then depends on this setting.
|
|
* @{
|
|
*/
|
|
|
|
/** Gets the configured database extension.
|
|
* @param handle the context handle
|
|
* @return the configured database extension
|
|
*/
|
|
const char *alpm_option_get_dbext(alpm_handle_t *handle);
|
|
|
|
/** Sets the database extension.
|
|
* @param handle the context handle
|
|
* @param dbext the database extension to use
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_dbext(alpm_handle_t *handle, const char *dbext);
|
|
/* End of dbext accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors for the signature levels
|
|
* @{
|
|
*/
|
|
|
|
/** Get the default siglevel.
|
|
* @param handle the context handle
|
|
* @return a \link alpm_siglevel_t \endlink bitfield of the siglevel
|
|
*/
|
|
int alpm_option_get_default_siglevel(alpm_handle_t *handle);
|
|
|
|
/** Set the default siglevel.
|
|
* @param handle the context handle
|
|
* @param level a \link alpm_siglevel_t \endlink bitfield of the level to set
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_default_siglevel(alpm_handle_t *handle, int level);
|
|
|
|
/** Get the configured local file siglevel.
|
|
* @param handle the context handle
|
|
* @return a \link alpm_siglevel_t \endlink bitfield of the siglevel
|
|
*/
|
|
int alpm_option_get_local_file_siglevel(alpm_handle_t *handle);
|
|
|
|
/** Set the local file siglevel.
|
|
* @param handle the context handle
|
|
* @param level a \link alpm_siglevel_t \endlink bitfield of the level to set
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_local_file_siglevel(alpm_handle_t *handle, int level);
|
|
|
|
/** Get the configured remote file siglevel.
|
|
* @param handle the context handle
|
|
* @return a \link alpm_siglevel_t \endlink bitfield of the siglevel
|
|
*/
|
|
int alpm_option_get_remote_file_siglevel(alpm_handle_t *handle);
|
|
|
|
/** Set the remote file siglevel.
|
|
* @param handle the context handle
|
|
* @param level a \link alpm_siglevel_t \endlink bitfield of the level to set
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_remote_file_siglevel(alpm_handle_t *handle, int level);
|
|
/* End of signature accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors for download timeout
|
|
*
|
|
* By default, libalpm will timeout if a download has been transferring
|
|
* less than 1 byte for 10 seconds.
|
|
* @{
|
|
*/
|
|
|
|
/** Enables/disables the download timeout.
|
|
* @param handle the context handle
|
|
* @param disable_dl_timeout 0 for enabled, 1 for disabled
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_option_set_disable_dl_timeout(alpm_handle_t *handle, unsigned short disable_dl_timeout);
|
|
/* End of disable_dl_timeout accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Accessors for parallel downloads
|
|
* \link alpm_db_update \endlink, \link alpm_fetch_pkgurl \endlink and
|
|
* \link alpm_trans_commit \endlink can all download packages in parallel.
|
|
* This setting configures how many packages can be downloaded in parallel,
|
|
*
|
|
* By default this value is set to 1, meaning packages are downloading
|
|
* sequentially.
|
|
*
|
|
* @{
|
|
*/
|
|
|
|
/** Gets the number of parallel streams to download database and package files.
|
|
* @param handle the context handle
|
|
* @return the number of parallel streams to download database and package files
|
|
*/
|
|
int alpm_option_get_parallel_downloads(alpm_handle_t *handle);
|
|
|
|
/** Sets number of parallel streams to download database and package files.
|
|
* @param handle the context handle
|
|
* @param num_streams number of parallel download streams
|
|
* @return 0 on success, -1 on error
|
|
*/
|
|
int alpm_option_set_parallel_downloads(alpm_handle_t *handle, unsigned int num_streams);
|
|
/* End of parallel_downloads accessors */
|
|
/** @} */
|
|
|
|
|
|
/* End of libalpm_options */
|
|
/** @} */
|
|
|
|
|
|
/** @addtogroup libalpm_packages Package Functions
|
|
* Functions to manipulate libalpm packages
|
|
* @{
|
|
*/
|
|
|
|
/** Package install reasons. */
|
|
typedef enum _alpm_pkgreason_t {
|
|
/** Explicitly requested by the user. */
|
|
ALPM_PKG_REASON_EXPLICIT = 0,
|
|
/** Installed as a dependency for another package. */
|
|
ALPM_PKG_REASON_DEPEND = 1
|
|
} alpm_pkgreason_t;
|
|
|
|
/** Location a package object was loaded from. */
|
|
typedef enum _alpm_pkgfrom_t {
|
|
/** Loaded from a file via \link alpm_pkg_load \endlink */
|
|
ALPM_PKG_FROM_FILE = 1,
|
|
/** From the local database */
|
|
ALPM_PKG_FROM_LOCALDB,
|
|
/** From a sync database */
|
|
ALPM_PKG_FROM_SYNCDB
|
|
} alpm_pkgfrom_t;
|
|
|
|
|
|
/** Method used to validate a package. */
|
|
typedef enum _alpm_pkgvalidation_t {
|
|
/** The package's validation type is unknown */
|
|
ALPM_PKG_VALIDATION_UNKNOWN = 0,
|
|
/** The package does not have any validation */
|
|
ALPM_PKG_VALIDATION_NONE = (1 << 0),
|
|
/** The package is validated with md5 */
|
|
ALPM_PKG_VALIDATION_MD5SUM = (1 << 1),
|
|
/** The package is validated with sha256 */
|
|
ALPM_PKG_VALIDATION_SHA256SUM = (1 << 2),
|
|
/** The package is validated with a PGP signature */
|
|
ALPM_PKG_VALIDATION_SIGNATURE = (1 << 3)
|
|
} alpm_pkgvalidation_t;
|
|
|
|
/** Create a package from a file.
|
|
* If full is false, the archive is read only until all necessary
|
|
* metadata is found. If it is true, the entire archive is read, which
|
|
* serves as a verification of integrity and the filelist can be created.
|
|
* The allocated structure should be freed using alpm_pkg_free().
|
|
* @param handle the context handle
|
|
* @param filename location of the package tarball
|
|
* @param full whether to stop the load after metadata is read or continue
|
|
* through the full archive
|
|
* @param level what level of package signature checking to perform on the
|
|
* package; note that this must be a '.sig' file type verification
|
|
* @param pkg address of the package pointer
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_pkg_load(alpm_handle_t *handle, const char *filename, int full,
|
|
int level, alpm_pkg_t **pkg);
|
|
|
|
/** Fetch a list of remote packages.
|
|
* @param handle the context handle
|
|
* @param urls list of package URLs to download
|
|
* @param fetched list of filepaths to the fetched packages, each item
|
|
* corresponds to one in `urls` list. This is an output parameter,
|
|
* the caller should provide a pointer to an empty list
|
|
* (*fetched === NULL) and the callee fills the list with data.
|
|
* @return 0 on success or -1 on failure
|
|
*/
|
|
int alpm_fetch_pkgurl(alpm_handle_t *handle, const alpm_list_t *urls,
|
|
alpm_list_t **fetched);
|
|
|
|
/** Find a package in a list by name.
|
|
* @param haystack a list of alpm_pkg_t
|
|
* @param needle the package name
|
|
* @return a pointer to the package if found or NULL
|
|
*/
|
|
alpm_pkg_t *alpm_pkg_find(alpm_list_t *haystack, const char *needle);
|
|
|
|
/** Free a package.
|
|
* Only packages loaded with \link alpm_pkg_load \endlink can be freed.
|
|
* Packages from databases will be freed by libalpm when they are unregistered.
|
|
* @param pkg package pointer to free
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_pkg_free(alpm_pkg_t *pkg);
|
|
|
|
/** Check the integrity (with md5) of a package from the sync cache.
|
|
* @param pkg package pointer
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_pkg_checkmd5sum(alpm_pkg_t *pkg);
|
|
|
|
/** Compare two version strings and determine which one is 'newer'.
|
|
* Returns a value comparable to the way strcmp works. Returns 1
|
|
* if a is newer than b, 0 if a and b are the same version, or -1
|
|
* if b is newer than a.
|
|
*
|
|
* Different epoch values for version strings will override any further
|
|
* comparison. If no epoch is provided, 0 is assumed.
|
|
*
|
|
* Keep in mind that the pkgrel is only compared if it is available
|
|
* on both versions handed to this function. For example, comparing
|
|
* 1.5-1 and 1.5 will yield 0; comparing 1.5-1 and 1.5-2 will yield
|
|
* -1 as expected. This is mainly for supporting versioned dependencies
|
|
* that do not include the pkgrel.
|
|
*/
|
|
int alpm_pkg_vercmp(const char *a, const char *b);
|
|
|
|
/** Computes the list of packages requiring a given package.
|
|
* The return value of this function is a newly allocated
|
|
* list of package names (char*), it should be freed by the caller.
|
|
* @param pkg a package
|
|
* @return the list of packages requiring pkg
|
|
*/
|
|
alpm_list_t *alpm_pkg_compute_requiredby(alpm_pkg_t *pkg);
|
|
|
|
/** Computes the list of packages optionally requiring a given package.
|
|
* The return value of this function is a newly allocated
|
|
* list of package names (char*), it should be freed by the caller.
|
|
* @param pkg a package
|
|
* @return the list of packages optionally requiring pkg
|
|
*/
|
|
alpm_list_t *alpm_pkg_compute_optionalfor(alpm_pkg_t *pkg);
|
|
|
|
/** Test if a package should be ignored.
|
|
* Checks if the package is ignored via IgnorePkg, or if the package is
|
|
* in a group ignored via IgnoreGroup.
|
|
* @param handle the context handle
|
|
* @param pkg the package to test
|
|
* @return 1 if the package should be ignored, 0 otherwise
|
|
*/
|
|
int alpm_pkg_should_ignore(alpm_handle_t *handle, alpm_pkg_t *pkg);
|
|
|
|
/** @name Package Property Accessors
|
|
* Any pointer returned by these functions points to internal structures
|
|
* allocated by libalpm. They should not be freed nor modified in any
|
|
* way.
|
|
*
|
|
* For loaded packages, they will be freed when \link alpm_pkg_free \endlink is called.
|
|
* For database packages, they will be freed when the database is unregistered.
|
|
* @{
|
|
*/
|
|
|
|
/** Gets the name of the file from which the package was loaded.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal string
|
|
*/
|
|
const char *alpm_pkg_get_filename(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the package base name.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal string
|
|
*/
|
|
const char *alpm_pkg_get_base(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the package name.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal string
|
|
*/
|
|
const char *alpm_pkg_get_name(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the package version as a string.
|
|
* This includes all available epoch, version, and pkgrel components. Use
|
|
* alpm_pkg_vercmp() to compare version strings if necessary.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal string
|
|
*/
|
|
const char *alpm_pkg_get_version(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the origin of the package.
|
|
* @return an alpm_pkgfrom_t constant, -1 on error
|
|
*/
|
|
alpm_pkgfrom_t alpm_pkg_get_origin(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the package description.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal string
|
|
*/
|
|
const char *alpm_pkg_get_desc(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the package URL.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal string
|
|
*/
|
|
const char *alpm_pkg_get_url(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the build timestamp of the package.
|
|
* @param pkg a pointer to package
|
|
* @return the timestamp of the build time
|
|
*/
|
|
alpm_time_t alpm_pkg_get_builddate(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the install timestamp of the package.
|
|
* @param pkg a pointer to package
|
|
* @return the timestamp of the install time
|
|
*/
|
|
alpm_time_t alpm_pkg_get_installdate(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the packager's name.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal string
|
|
*/
|
|
const char *alpm_pkg_get_packager(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the package's MD5 checksum as a string.
|
|
* The returned string is a sequence of 32 lowercase hexadecimal digits.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal string
|
|
*/
|
|
const char *alpm_pkg_get_md5sum(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the package's SHA256 checksum as a string.
|
|
* The returned string is a sequence of 64 lowercase hexadecimal digits.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal string
|
|
*/
|
|
const char *alpm_pkg_get_sha256sum(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the architecture for which the package was built.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal string
|
|
*/
|
|
const char *alpm_pkg_get_arch(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the size of the package. This is only available for sync database
|
|
* packages and package files, not those loaded from the local database.
|
|
* @param pkg a pointer to package
|
|
* @return the size of the package in bytes.
|
|
*/
|
|
off_t alpm_pkg_get_size(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the installed size of the package.
|
|
* @param pkg a pointer to package
|
|
* @return the total size of files installed by the package.
|
|
*/
|
|
off_t alpm_pkg_get_isize(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the package installation reason.
|
|
* @param pkg a pointer to package
|
|
* @return an enum member giving the install reason.
|
|
*/
|
|
alpm_pkgreason_t alpm_pkg_get_reason(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the list of package licenses.
|
|
* @param pkg a pointer to package
|
|
* @return a pointer to an internal list of strings.
|
|
*/
|
|
alpm_list_t *alpm_pkg_get_licenses(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the list of package groups.
|
|
* @param pkg a pointer to package
|
|
* @return a pointer to an internal list of strings.
|
|
*/
|
|
alpm_list_t *alpm_pkg_get_groups(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the list of package dependencies as alpm_depend_t.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal list of alpm_depend_t structures.
|
|
*/
|
|
alpm_list_t *alpm_pkg_get_depends(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the list of package optional dependencies.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal list of alpm_depend_t structures.
|
|
*/
|
|
alpm_list_t *alpm_pkg_get_optdepends(alpm_pkg_t *pkg);
|
|
|
|
/** Returns a list of package check dependencies
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal list of alpm_depend_t structures.
|
|
*/
|
|
alpm_list_t *alpm_pkg_get_checkdepends(alpm_pkg_t *pkg);
|
|
|
|
/** Returns a list of package make dependencies
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal list of alpm_depend_t structures.
|
|
*/
|
|
alpm_list_t *alpm_pkg_get_makedepends(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the list of packages conflicting with pkg.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal list of alpm_depend_t structures.
|
|
*/
|
|
alpm_list_t *alpm_pkg_get_conflicts(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the list of packages provided by pkg.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal list of alpm_depend_t structures.
|
|
*/
|
|
alpm_list_t *alpm_pkg_get_provides(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the list of packages to be replaced by pkg.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal list of alpm_depend_t structures.
|
|
*/
|
|
alpm_list_t *alpm_pkg_get_replaces(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the list of files installed by pkg.
|
|
* The filenames are relative to the install root,
|
|
* and do not include leading slashes.
|
|
* @param pkg a pointer to package
|
|
* @return a pointer to a filelist object containing a count and an array of
|
|
* package file objects
|
|
*/
|
|
alpm_filelist_t *alpm_pkg_get_files(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the list of files backed up when installing pkg.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to a list of alpm_backup_t objects
|
|
*/
|
|
alpm_list_t *alpm_pkg_get_backup(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the database containing pkg.
|
|
* Returns a pointer to the alpm_db_t structure the package is
|
|
* originating from, or NULL if the package was loaded from a file.
|
|
* @param pkg a pointer to package
|
|
* @return a pointer to the DB containing pkg, or NULL.
|
|
*/
|
|
alpm_db_t *alpm_pkg_get_db(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the base64 encoded package signature.
|
|
* @param pkg a pointer to package
|
|
* @return a reference to an internal string
|
|
*/
|
|
const char *alpm_pkg_get_base64_sig(alpm_pkg_t *pkg);
|
|
|
|
/** Extracts package signature either from embedded package signature
|
|
* or if it is absent then reads data from detached signature file.
|
|
* @param pkg a pointer to package.
|
|
* @param sig output parameter for signature data. Callee function allocates
|
|
* a buffer needed for the signature data. Caller is responsible for
|
|
* freeing this buffer.
|
|
* @param sig_len output parameter for the signature data length.
|
|
* @return 0 on success, negative number on error.
|
|
*/
|
|
int alpm_pkg_get_sig(alpm_pkg_t *pkg, unsigned char **sig, size_t *sig_len);
|
|
|
|
/** Returns the method used to validate a package during install.
|
|
* @param pkg a pointer to package
|
|
* @return an enum member giving the validation method
|
|
*/
|
|
int alpm_pkg_get_validation(alpm_pkg_t *pkg);
|
|
|
|
/** Returns whether the package has an install scriptlet.
|
|
* @return 0 if FALSE, TRUE otherwise
|
|
*/
|
|
int alpm_pkg_has_scriptlet(alpm_pkg_t *pkg);
|
|
|
|
/** Returns the size of the files that will be downloaded to install a
|
|
* package.
|
|
* @param newpkg the new package to upgrade to
|
|
* @return the size of the download
|
|
*/
|
|
off_t alpm_pkg_download_size(alpm_pkg_t *newpkg);
|
|
|
|
/** Set install reason for a package in the local database.
|
|
* The provided package object must be from the local database or this method
|
|
* will fail. The write to the local database is performed immediately.
|
|
* @param pkg the package to update
|
|
* @param reason the new install reason
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_pkg_set_reason(alpm_pkg_t *pkg, alpm_pkgreason_t reason);
|
|
|
|
|
|
/* End of libalpm_pkg_t accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Changelog functions
|
|
* Functions for reading the changelog
|
|
* @{
|
|
*/
|
|
|
|
/** Open a package changelog for reading.
|
|
* Similar to fopen in functionality, except that the returned 'file
|
|
* stream' could really be from an archive as well as from the database.
|
|
* @param pkg the package to read the changelog of (either file or db)
|
|
* @return a 'file stream' to the package changelog
|
|
*/
|
|
void *alpm_pkg_changelog_open(alpm_pkg_t *pkg);
|
|
|
|
/** Read data from an open changelog 'file stream'.
|
|
* Similar to fread in functionality, this function takes a buffer and
|
|
* amount of data to read. If an error occurs pm_errno will be set.
|
|
* @param ptr a buffer to fill with raw changelog data
|
|
* @param size the size of the buffer
|
|
* @param pkg the package that the changelog is being read from
|
|
* @param fp a 'file stream' to the package changelog
|
|
* @return the number of characters read, or 0 if there is no more data or an
|
|
* error occurred.
|
|
*/
|
|
size_t alpm_pkg_changelog_read(void *ptr, size_t size,
|
|
const alpm_pkg_t *pkg, void *fp);
|
|
|
|
/** Close a package changelog for reading.
|
|
* @param pkg the package to close the changelog of (either file or db)
|
|
* @param fp the 'file stream' to the package changelog to close
|
|
* @return 0 on success, -1 on error
|
|
*/
|
|
int alpm_pkg_changelog_close(const alpm_pkg_t *pkg, void *fp);
|
|
|
|
/* End of changelog accessors */
|
|
/** @} */
|
|
|
|
|
|
/** @name Mtree functions
|
|
* Functions for reading the mtree
|
|
* @{
|
|
*/
|
|
|
|
/** Open a package mtree file for reading.
|
|
* @param pkg the local package to read the mtree of
|
|
* @return an archive structure for the package mtree file
|
|
*/
|
|
struct archive *alpm_pkg_mtree_open(alpm_pkg_t *pkg);
|
|
|
|
/** 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 on success, 1 if end of archive is reached, -1 otherwise.
|
|
*/
|
|
int alpm_pkg_mtree_next(const alpm_pkg_t *pkg, struct archive *archive,
|
|
struct archive_entry **entry);
|
|
|
|
/** Close a package mtree file.
|
|
* @param pkg the local package to close the mtree of
|
|
* @param archive the archive to close
|
|
*/
|
|
int alpm_pkg_mtree_close(const alpm_pkg_t *pkg, struct archive *archive);
|
|
|
|
/* End of mtree accessors */
|
|
/** @} */
|
|
|
|
|
|
/* End of libalpm_packages */
|
|
/** @} */
|
|
|
|
/** @addtogroup libalpm_trans Transaction
|
|
* @brief Functions to manipulate libalpm transactions
|
|
*
|
|
* Transactions are the way to add/remove packages to/from the system.
|
|
* Only one transaction can exist at a time.
|
|
*
|
|
* The basic workflow of a transaction is to:
|
|
*
|
|
* - Initialize with \link alpm_trans_init \endlink
|
|
* - Choose which packages to add with \link alpm_add_pkg \endlink and \link alpm_remove_pkg \endlink
|
|
* - Prepare the transaction with \link alpm_trans_prepare \endlink
|
|
* - Commit the transaction with \link alpm_trans_commit \endlink
|
|
* - Release the transaction with \link alpm_trans_release \endlink
|
|
*
|
|
* A transaction can be released at any time. A transaction does not have to be committed.
|
|
* @{
|
|
*/
|
|
|
|
/** Transaction flags */
|
|
typedef enum _alpm_transflag_t {
|
|
/** Ignore dependency checks. */
|
|
ALPM_TRANS_FLAG_NODEPS = 1,
|
|
/* (1 << 1) flag can go here */
|
|
/** Delete files even if they are tagged as backup. */
|
|
ALPM_TRANS_FLAG_NOSAVE = (1 << 2),
|
|
/** Ignore version numbers when checking dependencies. */
|
|
ALPM_TRANS_FLAG_NODEPVERSION = (1 << 3),
|
|
/** Remove also any packages depending on a package being removed. */
|
|
ALPM_TRANS_FLAG_CASCADE = (1 << 4),
|
|
/** Remove packages and their unneeded deps (not explicitly installed). */
|
|
ALPM_TRANS_FLAG_RECURSE = (1 << 5),
|
|
/** Modify database but do not commit changes to the filesystem. */
|
|
ALPM_TRANS_FLAG_DBONLY = (1 << 6),
|
|
/* (1 << 7) flag can go here */
|
|
/** Use ALPM_PKG_REASON_DEPEND when installing packages. */
|
|
ALPM_TRANS_FLAG_ALLDEPS = (1 << 8),
|
|
/** Only download packages and do not actually install. */
|
|
ALPM_TRANS_FLAG_DOWNLOADONLY = (1 << 9),
|
|
/** Do not execute install scriptlets after installing. */
|
|
ALPM_TRANS_FLAG_NOSCRIPTLET = (1 << 10),
|
|
/** Ignore dependency conflicts. */
|
|
ALPM_TRANS_FLAG_NOCONFLICTS = (1 << 11),
|
|
/* (1 << 12) flag can go here */
|
|
/** Do not install a package if it is already installed and up to date. */
|
|
ALPM_TRANS_FLAG_NEEDED = (1 << 13),
|
|
/** Use ALPM_PKG_REASON_EXPLICIT when installing packages. */
|
|
ALPM_TRANS_FLAG_ALLEXPLICIT = (1 << 14),
|
|
/** Do not remove a package if it is needed by another one. */
|
|
ALPM_TRANS_FLAG_UNNEEDED = (1 << 15),
|
|
/** Remove also explicitly installed unneeded deps (use with ALPM_TRANS_FLAG_RECURSE). */
|
|
ALPM_TRANS_FLAG_RECURSEALL = (1 << 16),
|
|
/** Do not lock the database during the operation. */
|
|
ALPM_TRANS_FLAG_NOLOCK = (1 << 17)
|
|
} alpm_transflag_t;
|
|
|
|
/** Returns the bitfield of flags for the current transaction.
|
|
* @param handle the context handle
|
|
* @return the bitfield of transaction flags
|
|
*/
|
|
int alpm_trans_get_flags(alpm_handle_t *handle);
|
|
|
|
/** Returns a list of packages added by the transaction.
|
|
* @param handle the context handle
|
|
* @return a list of alpm_pkg_t structures
|
|
*/
|
|
alpm_list_t *alpm_trans_get_add(alpm_handle_t *handle);
|
|
|
|
/** Returns the list of packages removed by the transaction.
|
|
* @param handle the context handle
|
|
* @return a list of alpm_pkg_t structures
|
|
*/
|
|
alpm_list_t *alpm_trans_get_remove(alpm_handle_t *handle);
|
|
|
|
/** Initialize the transaction.
|
|
* @param handle the context handle
|
|
* @param flags flags of the transaction (like nodeps, etc; see alpm_transflag_t)
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_trans_init(alpm_handle_t *handle, int flags);
|
|
|
|
/** Prepare a transaction.
|
|
* @param handle the context handle
|
|
* @param data the address of an alpm_list where a list
|
|
* of alpm_depmissing_t objects is dumped (conflicting packages)
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_trans_prepare(alpm_handle_t *handle, alpm_list_t **data);
|
|
|
|
/** Commit a transaction.
|
|
* @param handle the context handle
|
|
* @param data the address of an alpm_list where detailed description
|
|
* of an error can be dumped (i.e. list of conflicting files)
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_trans_commit(alpm_handle_t *handle, alpm_list_t **data);
|
|
|
|
/** Interrupt a transaction.
|
|
* @param handle the context handle
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_trans_interrupt(alpm_handle_t *handle);
|
|
|
|
/** Release a transaction.
|
|
* @param handle the context handle
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_trans_release(alpm_handle_t *handle);
|
|
|
|
/** @name Add/Remove packages
|
|
* These functions remove/add packages to the transactions
|
|
* @{
|
|
* */
|
|
|
|
/** Search for packages to upgrade and add them to the transaction.
|
|
* @param handle the context handle
|
|
* @param enable_downgrade allow downgrading of packages if the remote version is lower
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_sync_sysupgrade(alpm_handle_t *handle, int enable_downgrade);
|
|
#ifdef __MSYS__
|
|
int alpm_sync_sysupgrade_core(alpm_handle_t *handle, int enable_downgrade);
|
|
|
|
/** Informs whether a package is a core package.
|
|
* @param pkg the package to check
|
|
* @return non-zero if this is a core package, zero otherwise
|
|
*/
|
|
int alpm_pkg_is_core_package(const alpm_pkg_t *pkg);
|
|
#endif
|
|
|
|
/** Add a package to the transaction.
|
|
* If the package was loaded by alpm_pkg_load(), it will be freed upon
|
|
* \link alpm_trans_release \endlink invocation.
|
|
* @param handle the context handle
|
|
* @param pkg the package to add
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_add_pkg(alpm_handle_t *handle, alpm_pkg_t *pkg);
|
|
|
|
/** Add a package removal to the transaction.
|
|
* @param handle the context handle
|
|
* @param pkg the package to uninstall
|
|
* @return 0 on success, -1 on error (pm_errno is set accordingly)
|
|
*/
|
|
int alpm_remove_pkg(alpm_handle_t *handle, alpm_pkg_t *pkg);
|
|
|
|
/* End of add/remove packages */
|
|
/** @} */
|
|
|
|
|
|
/* End of libalpm_trans */
|
|
/** @} */
|
|
|
|
|
|
/** \addtogroup libalpm_misc Miscellaneous Functions
|
|
* @brief Various libalpm functions
|
|
* @{
|
|
*/
|
|
|
|
/** Check for new version of pkg in syncdbs.
|
|
*
|
|
* If the same package appears multiple dbs only the first will be checked
|
|
*
|
|
* This only checks the syncdb for a newer version. It does not access the network at all.
|
|
* See \link alpm_db_update \endlink to update a database.
|
|
*/
|
|
alpm_pkg_t *alpm_sync_get_new_version(alpm_pkg_t *pkg, alpm_list_t *dbs_sync);
|
|
|
|
/** Get the md5 sum of file.
|
|
* @param filename name of the file
|
|
* @return the checksum on success, NULL on error
|
|
*/
|
|
char *alpm_compute_md5sum(const char *filename);
|
|
|
|
/** Get the sha256 sum of file.
|
|
* @param filename name of the file
|
|
* @return the checksum on success, NULL on error
|
|
*/
|
|
char *alpm_compute_sha256sum(const char *filename);
|
|
|
|
/** Remove the database lock file
|
|
* @param handle the context handle
|
|
* @return 0 on success, -1 on error
|
|
*
|
|
* @note Safe to call from inside signal handlers.
|
|
*/
|
|
int alpm_unlock(alpm_handle_t *handle);
|
|
|
|
/** Enum of possible compile time features */
|
|
enum alpm_caps {
|
|
/** localization */
|
|
ALPM_CAPABILITY_NLS = (1 << 0),
|
|
/** Ability to download */
|
|
ALPM_CAPABILITY_DOWNLOADER = (1 << 1),
|
|
/** Signature checking */
|
|
ALPM_CAPABILITY_SIGNATURES = (1 << 2)
|
|
};
|
|
|
|
/** Get the version of library.
|
|
* @return the library version, e.g. "6.0.4"
|
|
* */
|
|
const char *alpm_version(void);
|
|
|
|
/** Get the capabilities of the library.
|
|
* @return a bitmask of the capabilities
|
|
* */
|
|
int alpm_capabilities(void);
|
|
|
|
/* End of libalpm_misc */
|
|
/** @} */
|
|
|
|
/* End of libalpm_api */
|
|
/** @} */
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
#endif /* ALPM_H */
|