2005-03-14 20:51:43 -05:00
|
|
|
/*
|
|
|
|
* alpm.h
|
2007-11-16 21:18:45 -05:00
|
|
|
*
|
2008-06-01 22:47:31 -04:00
|
|
|
* Copyright (c) 2002-2008 by Judd Vinet <jvinet@zeroflux.org>
|
2006-10-15 15:31:03 -04:00
|
|
|
* 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>
|
2007-11-16 21:18:45 -05:00
|
|
|
*
|
2005-03-14 20:51:43 -05:00
|
|
|
* 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
|
2007-12-10 23:55:22 -05:00
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2005-03-14 20:51:43 -05:00
|
|
|
*/
|
|
|
|
#ifndef _ALPM_H
|
|
|
|
#define _ALPM_H
|
|
|
|
|
2005-12-28 05:38:12 -05:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2008-06-01 22:47:31 -04:00
|
|
|
#include <sys/types.h> /* for off_t */
|
2006-11-20 04:10:23 -05:00
|
|
|
#include <time.h> /* for time_t */
|
2007-06-07 20:55:13 -04:00
|
|
|
#include <stdarg.h> /* for va_list */
|
2006-11-20 04:10:23 -05:00
|
|
|
|
2007-10-14 18:29:32 -04:00
|
|
|
#include <alpm_list.h>
|
|
|
|
|
2007-08-26 22:42:17 -04:00
|
|
|
#define DEPRECATED __attribute__((deprecated))
|
|
|
|
|
2005-03-14 20:51:43 -05:00
|
|
|
/*
|
|
|
|
* Arch Linux Package Management library
|
|
|
|
*/
|
|
|
|
|
2007-11-16 21:18:45 -05:00
|
|
|
/*
|
2006-11-20 04:10:23 -05:00
|
|
|
* Structures
|
2005-03-14 20:51:43 -05:00
|
|
|
*/
|
|
|
|
|
2006-11-20 04:10:23 -05:00
|
|
|
typedef struct __pmdb_t pmdb_t;
|
|
|
|
typedef struct __pmpkg_t pmpkg_t;
|
2007-10-19 13:17:51 -04:00
|
|
|
typedef struct __pmdelta_t pmdelta_t;
|
2006-11-20 04:10:23 -05:00
|
|
|
typedef struct __pmgrp_t pmgrp_t;
|
|
|
|
typedef struct __pmtrans_t pmtrans_t;
|
|
|
|
typedef struct __pmsyncpkg_t pmsyncpkg_t;
|
|
|
|
typedef struct __pmdepend_t pmdepend_t;
|
|
|
|
typedef struct __pmdepmissing_t pmdepmissing_t;
|
2007-11-18 08:25:43 -05:00
|
|
|
typedef struct __pmconflict_t pmconflict_t;
|
2007-11-18 04:29:55 -05:00
|
|
|
typedef struct __pmfileconflict_t pmfileconflict_t;
|
2005-03-14 20:51:43 -05:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Library
|
|
|
|
*/
|
|
|
|
|
2007-07-06 12:11:55 -04:00
|
|
|
int alpm_initialize(void);
|
2005-11-07 07:57:33 -05:00
|
|
|
int alpm_release(void);
|
2008-02-29 15:52:57 -05:00
|
|
|
const char *alpm_version(void);
|
2005-03-14 20:51:43 -05:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Logging facilities
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Levels */
|
2007-01-23 22:02:53 -05:00
|
|
|
typedef enum _pmloglevel_t {
|
2007-01-31 01:10:21 -05:00
|
|
|
PM_LOG_ERROR = 0x01,
|
|
|
|
PM_LOG_WARNING = 0x02,
|
|
|
|
PM_LOG_DEBUG = 0x04,
|
2007-06-07 22:20:40 -04:00
|
|
|
PM_LOG_FUNCTION = 0x08
|
2007-01-23 22:02:53 -05:00
|
|
|
} pmloglevel_t;
|
2005-03-14 20:51:43 -05:00
|
|
|
|
2007-06-07 20:55:13 -04:00
|
|
|
typedef void (*alpm_cb_log)(pmloglevel_t, char *, va_list);
|
2005-03-14 20:51:43 -05:00
|
|
|
int alpm_logaction(char *fmt, ...);
|
|
|
|
|
2006-11-20 04:10:23 -05:00
|
|
|
/*
|
|
|
|
* Downloading
|
|
|
|
*/
|
|
|
|
|
2008-06-01 22:47:31 -04:00
|
|
|
typedef void (*alpm_cb_download)(const char *filename,
|
|
|
|
off_t xfered, off_t total);
|
2008-06-02 00:10:30 -04:00
|
|
|
typedef void (*alpm_cb_totaldl)(off_t total);
|
2006-11-20 04:10:23 -05:00
|
|
|
|
2005-03-14 20:51:43 -05:00
|
|
|
/*
|
|
|
|
* Options
|
|
|
|
*/
|
|
|
|
|
2006-11-20 04:10:23 -05:00
|
|
|
alpm_cb_log alpm_option_get_logcb();
|
|
|
|
void alpm_option_set_logcb(alpm_cb_log cb);
|
|
|
|
|
|
|
|
alpm_cb_download alpm_option_get_dlcb();
|
|
|
|
void alpm_option_set_dlcb(alpm_cb_download cb);
|
|
|
|
|
2008-06-02 00:10:30 -04:00
|
|
|
alpm_cb_totaldl alpm_option_get_totaldlcb();
|
|
|
|
void alpm_option_set_totaldlcb(alpm_cb_totaldl cb);
|
|
|
|
|
2006-11-20 04:10:23 -05:00
|
|
|
const char *alpm_option_get_root();
|
2007-08-21 21:28:05 -04:00
|
|
|
int alpm_option_set_root(const char *root);
|
2006-11-20 04:10:23 -05:00
|
|
|
|
|
|
|
const char *alpm_option_get_dbpath();
|
2007-08-21 21:28:05 -04:00
|
|
|
int alpm_option_set_dbpath(const char *dbpath);
|
2006-11-20 04:10:23 -05:00
|
|
|
|
2007-06-04 14:50:16 -04:00
|
|
|
alpm_list_t *alpm_option_get_cachedirs();
|
2007-08-21 21:28:05 -04:00
|
|
|
int alpm_option_add_cachedir(const char *cachedir);
|
2007-06-04 14:50:16 -04:00
|
|
|
void alpm_option_set_cachedirs(alpm_list_t *cachedirs);
|
2007-12-22 06:28:08 -05:00
|
|
|
int alpm_option_remove_cachedir(const char *cachedir);
|
2006-11-20 04:10:23 -05:00
|
|
|
|
|
|
|
const char *alpm_option_get_logfile();
|
2007-08-21 21:28:05 -04:00
|
|
|
int alpm_option_set_logfile(const char *logfile);
|
2006-11-20 04:10:23 -05:00
|
|
|
|
2007-05-31 02:51:28 -04:00
|
|
|
const char *alpm_option_get_lockfile();
|
2007-06-27 23:25:04 -04:00
|
|
|
/* no set_lockfile, path is determined from dbpath */
|
2007-05-31 02:51:28 -04:00
|
|
|
|
2007-01-23 22:02:53 -05:00
|
|
|
unsigned short alpm_option_get_usesyslog();
|
|
|
|
void alpm_option_set_usesyslog(unsigned short usesyslog);
|
2006-11-20 04:10:23 -05:00
|
|
|
|
2007-01-19 04:28:44 -05:00
|
|
|
alpm_list_t *alpm_option_get_noupgrades();
|
2007-06-05 17:34:33 -04:00
|
|
|
void alpm_option_add_noupgrade(const char *pkg);
|
2007-01-19 04:28:44 -05:00
|
|
|
void alpm_option_set_noupgrades(alpm_list_t *noupgrade);
|
2007-12-22 06:28:08 -05:00
|
|
|
int alpm_option_remove_noupgrade(const char *pkg);
|
2006-11-20 04:10:23 -05:00
|
|
|
|
2007-01-19 04:28:44 -05:00
|
|
|
alpm_list_t *alpm_option_get_noextracts();
|
2007-06-05 17:34:33 -04:00
|
|
|
void alpm_option_add_noextract(const char *pkg);
|
2007-01-19 04:28:44 -05:00
|
|
|
void alpm_option_set_noextracts(alpm_list_t *noextract);
|
2007-12-22 06:28:08 -05:00
|
|
|
int alpm_option_remove_noextract(const char *pkg);
|
2006-11-20 04:10:23 -05:00
|
|
|
|
2007-01-19 04:28:44 -05:00
|
|
|
alpm_list_t *alpm_option_get_ignorepkgs();
|
2007-06-05 17:34:33 -04:00
|
|
|
void alpm_option_add_ignorepkg(const char *pkg);
|
2007-01-19 04:28:44 -05:00
|
|
|
void alpm_option_set_ignorepkgs(alpm_list_t *ignorepkgs);
|
2007-12-22 06:28:08 -05:00
|
|
|
int alpm_option_remove_ignorepkg(const char *pkg);
|
2006-11-20 04:10:23 -05:00
|
|
|
|
2007-01-19 04:28:44 -05:00
|
|
|
alpm_list_t *alpm_option_get_holdpkgs();
|
2007-06-05 17:34:33 -04:00
|
|
|
void alpm_option_add_holdpkg(const char *pkg);
|
2007-01-19 04:28:44 -05:00
|
|
|
void alpm_option_set_holdpkgs(alpm_list_t *holdpkgs);
|
2007-12-22 06:28:08 -05:00
|
|
|
int alpm_option_remove_holdpkg(const char *pkg);
|
2006-11-20 04:10:23 -05:00
|
|
|
|
2007-11-09 20:13:28 -05:00
|
|
|
alpm_list_t *alpm_option_get_ignoregrps();
|
|
|
|
void alpm_option_add_ignoregrp(const char *grp);
|
|
|
|
void alpm_option_set_ignoregrps(alpm_list_t *ignoregrps);
|
2007-12-22 06:28:08 -05:00
|
|
|
int alpm_option_remove_ignoregrp(const char *grp);
|
2007-11-09 20:13:28 -05:00
|
|
|
|
2006-11-20 04:10:23 -05:00
|
|
|
const char *alpm_option_get_xfercommand();
|
|
|
|
void alpm_option_set_xfercommand(const char *cmd);
|
2005-03-14 20:51:43 -05:00
|
|
|
|
2006-11-20 04:10:23 -05:00
|
|
|
unsigned short alpm_option_get_nopassiveftp();
|
|
|
|
void alpm_option_set_nopassiveftp(unsigned short nopasv);
|
2007-10-19 13:17:53 -04:00
|
|
|
void alpm_option_set_usedelta(unsigned short usedelta);
|
2006-11-20 04:10:23 -05:00
|
|
|
|
2007-01-19 04:28:44 -05:00
|
|
|
pmdb_t *alpm_option_get_localdb();
|
|
|
|
alpm_list_t *alpm_option_get_syncdbs();
|
|
|
|
|
2005-03-14 20:51:43 -05:00
|
|
|
/*
|
|
|
|
* Databases
|
|
|
|
*/
|
|
|
|
|
2007-08-26 22:42:17 -04:00
|
|
|
/* Preferred interfaces db_register_local and db_register_sync */
|
|
|
|
pmdb_t *alpm_db_register_local(void);
|
|
|
|
pmdb_t *alpm_db_register_sync(const char *treename);
|
2006-11-20 04:10:23 -05:00
|
|
|
int alpm_db_unregister(pmdb_t *db);
|
2007-08-21 21:28:05 -04:00
|
|
|
int alpm_db_unregister_all(void);
|
2006-10-15 15:31:03 -04:00
|
|
|
|
2007-06-05 17:34:33 -04:00
|
|
|
const char *alpm_db_get_name(const pmdb_t *db);
|
|
|
|
const char *alpm_db_get_url(const pmdb_t *db);
|
2005-03-14 20:51:43 -05:00
|
|
|
|
2006-11-20 04:10:23 -05:00
|
|
|
int alpm_db_setserver(pmdb_t *db, const char *url);
|
2005-04-02 18:20:00 -05:00
|
|
|
|
2006-11-20 04:10:23 -05:00
|
|
|
int alpm_db_update(int level, pmdb_t *db);
|
2005-03-16 14:31:20 -05:00
|
|
|
|
2007-02-26 03:38:48 -05:00
|
|
|
pmpkg_t *alpm_db_get_pkg(pmdb_t *db, const char *name);
|
2007-01-19 04:28:44 -05:00
|
|
|
alpm_list_t *alpm_db_getpkgcache(pmdb_t *db);
|
2005-03-14 20:51:43 -05:00
|
|
|
|
2007-02-26 03:38:48 -05:00
|
|
|
pmgrp_t *alpm_db_readgrp(pmdb_t *db, const char *name);
|
2007-01-19 04:28:44 -05:00
|
|
|
alpm_list_t *alpm_db_getgrpcache(pmdb_t *db);
|
2007-06-05 17:34:33 -04:00
|
|
|
alpm_list_t *alpm_db_search(pmdb_t *db, const alpm_list_t* needles);
|
2005-03-14 20:51:43 -05:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Packages
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Info parameters */
|
|
|
|
|
|
|
|
/* reasons -- ie, why the package was installed */
|
2007-01-23 22:02:53 -05:00
|
|
|
typedef enum _pmpkgreason_t {
|
|
|
|
PM_PKG_REASON_EXPLICIT = 0, /* explicitly requested by the user */
|
|
|
|
PM_PKG_REASON_DEPEND = 1 /* installed as a dependency for another package */
|
|
|
|
} pmpkgreason_t;
|
2005-03-14 20:51:43 -05:00
|
|
|
|
2007-09-28 00:39:37 -04:00
|
|
|
int alpm_pkg_load(const char *filename, unsigned short full, pmpkg_t **pkg);
|
2006-11-20 04:10:23 -05:00
|
|
|
int alpm_pkg_free(pmpkg_t *pkg);
|
|
|
|
int alpm_pkg_checkmd5sum(pmpkg_t *pkg);
|
2007-06-05 17:34:33 -04:00
|
|
|
char *alpm_fetch_pkgurl(const char *url);
|
2008-05-14 01:37:51 -04:00
|
|
|
int alpm_pkg_vercmp(const char *a, const char *b);
|
2007-08-25 19:07:02 -04:00
|
|
|
alpm_list_t *alpm_pkg_compute_requiredby(pmpkg_t *pkg);
|
2005-03-14 20:51:43 -05:00
|
|
|
|
2006-11-22 04:03:41 -05:00
|
|
|
const char *alpm_pkg_get_filename(pmpkg_t *pkg);
|
2006-11-20 04:10:23 -05:00
|
|
|
const char *alpm_pkg_get_name(pmpkg_t *pkg);
|
|
|
|
const char *alpm_pkg_get_version(pmpkg_t *pkg);
|
|
|
|
const char *alpm_pkg_get_desc(pmpkg_t *pkg);
|
|
|
|
const char *alpm_pkg_get_url(pmpkg_t *pkg);
|
2007-09-19 01:21:56 -04:00
|
|
|
time_t alpm_pkg_get_builddate(pmpkg_t *pkg);
|
|
|
|
time_t alpm_pkg_get_installdate(pmpkg_t *pkg);
|
2006-11-20 04:10:23 -05:00
|
|
|
const char *alpm_pkg_get_packager(pmpkg_t *pkg);
|
|
|
|
const char *alpm_pkg_get_md5sum(pmpkg_t *pkg);
|
|
|
|
const char *alpm_pkg_get_arch(pmpkg_t *pkg);
|
2008-06-01 22:47:31 -04:00
|
|
|
off_t alpm_pkg_get_size(pmpkg_t *pkg);
|
|
|
|
off_t alpm_pkg_get_isize(pmpkg_t *pkg);
|
2007-01-23 22:02:53 -05:00
|
|
|
pmpkgreason_t alpm_pkg_get_reason(pmpkg_t *pkg);
|
2007-01-19 04:28:44 -05:00
|
|
|
alpm_list_t *alpm_pkg_get_licenses(pmpkg_t *pkg);
|
|
|
|
alpm_list_t *alpm_pkg_get_groups(pmpkg_t *pkg);
|
|
|
|
alpm_list_t *alpm_pkg_get_depends(pmpkg_t *pkg);
|
2007-09-26 00:02:30 -04:00
|
|
|
alpm_list_t *alpm_pkg_get_optdepends(pmpkg_t *pkg);
|
2007-01-19 04:28:44 -05:00
|
|
|
alpm_list_t *alpm_pkg_get_conflicts(pmpkg_t *pkg);
|
|
|
|
alpm_list_t *alpm_pkg_get_provides(pmpkg_t *pkg);
|
2007-10-19 13:17:51 -04:00
|
|
|
alpm_list_t *alpm_pkg_get_deltas(pmpkg_t *pkg);
|
2007-01-19 04:28:44 -05:00
|
|
|
alpm_list_t *alpm_pkg_get_replaces(pmpkg_t *pkg);
|
|
|
|
alpm_list_t *alpm_pkg_get_files(pmpkg_t *pkg);
|
|
|
|
alpm_list_t *alpm_pkg_get_backup(pmpkg_t *pkg);
|
2007-12-09 00:42:04 -05:00
|
|
|
void *alpm_pkg_changelog_open(pmpkg_t *pkg);
|
|
|
|
size_t alpm_pkg_changelog_read(void *ptr, size_t size,
|
|
|
|
const pmpkg_t *pkg, const void *fp);
|
|
|
|
/*int alpm_pkg_changelog_feof(const pmpkg_t *pkg, void *fp);*/
|
|
|
|
int alpm_pkg_changelog_close(const pmpkg_t *pkg, void *fp);
|
2007-01-23 22:02:53 -05:00
|
|
|
unsigned short alpm_pkg_has_scriptlet(pmpkg_t *pkg);
|
2006-11-20 04:10:23 -05:00
|
|
|
|
2008-06-01 22:47:31 -04:00
|
|
|
off_t alpm_pkg_download_size(pmpkg_t *newpkg);
|
2007-10-19 13:17:54 -04:00
|
|
|
|
2007-10-19 13:17:51 -04:00
|
|
|
/*
|
|
|
|
* Deltas
|
|
|
|
*/
|
|
|
|
|
2007-10-29 02:28:13 -04:00
|
|
|
const char *alpm_delta_get_from(pmdelta_t *delta);
|
2008-02-15 21:17:57 -05:00
|
|
|
const char *alpm_delta_get_from_md5sum(pmdelta_t *delta);
|
2007-10-29 02:28:13 -04:00
|
|
|
const char *alpm_delta_get_to(pmdelta_t *delta);
|
2008-02-15 21:17:57 -05:00
|
|
|
const char *alpm_delta_get_to_md5sum(pmdelta_t *delta);
|
2007-10-29 02:28:13 -04:00
|
|
|
const char *alpm_delta_get_filename(pmdelta_t *delta);
|
|
|
|
const char *alpm_delta_get_md5sum(pmdelta_t *delta);
|
2008-06-01 22:47:31 -04:00
|
|
|
off_t alpm_delta_get_size(pmdelta_t *delta);
|
2007-10-19 13:17:51 -04:00
|
|
|
|
2005-03-14 20:51:43 -05:00
|
|
|
/*
|
|
|
|
* Groups
|
|
|
|
*/
|
2007-06-05 17:34:33 -04:00
|
|
|
const char *alpm_grp_get_name(const pmgrp_t *grp);
|
2008-01-12 02:13:52 -05:00
|
|
|
alpm_list_t *alpm_grp_get_pkgs(const pmgrp_t *grp);
|
2005-03-14 20:51:43 -05:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Sync
|
|
|
|
*/
|
|
|
|
|
2007-06-05 17:34:33 -04:00
|
|
|
pmpkg_t *alpm_sync_get_pkg(const pmsyncpkg_t *sync);
|
2008-01-27 06:24:50 -05:00
|
|
|
alpm_list_t *alpm_sync_get_removes(const pmsyncpkg_t *sync);
|
2008-01-27 19:44:23 -05:00
|
|
|
pmpkg_t *alpm_sync_newversion(pmpkg_t *pkg, alpm_list_t *dbs_sync);
|
2007-08-24 18:10:40 -04:00
|
|
|
int alpm_sync_sysupgrade(pmdb_t *db_local,
|
|
|
|
alpm_list_t *dbs_sync, alpm_list_t **syncpkgs);
|
2005-03-14 20:51:43 -05:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Transactions
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Types */
|
2007-01-23 22:02:53 -05:00
|
|
|
typedef enum _pmtranstype_t {
|
2008-03-16 17:36:31 -04:00
|
|
|
PM_TRANS_TYPE_UPGRADE = 1,
|
2005-03-14 20:51:43 -05:00
|
|
|
PM_TRANS_TYPE_REMOVE,
|
2007-07-14 09:34:39 -04:00
|
|
|
PM_TRANS_TYPE_REMOVEUPGRADE,
|
2005-03-14 20:51:43 -05:00
|
|
|
PM_TRANS_TYPE_SYNC
|
2007-01-23 22:02:53 -05:00
|
|
|
} pmtranstype_t;
|
2005-03-14 20:51:43 -05:00
|
|
|
|
|
|
|
/* Flags */
|
2007-01-23 22:02:53 -05:00
|
|
|
typedef enum _pmtransflag_t {
|
|
|
|
PM_TRANS_FLAG_NODEPS = 0x01,
|
|
|
|
PM_TRANS_FLAG_FORCE = 0x02,
|
|
|
|
PM_TRANS_FLAG_NOSAVE = 0x04,
|
2007-11-21 12:25:50 -05:00
|
|
|
/* 0x08 flag can go here */
|
2007-01-23 22:02:53 -05:00
|
|
|
PM_TRANS_FLAG_CASCADE = 0x10,
|
|
|
|
PM_TRANS_FLAG_RECURSE = 0x20,
|
|
|
|
PM_TRANS_FLAG_DBONLY = 0x40,
|
2008-03-15 16:10:54 -04:00
|
|
|
/* 0x80 flag can go here */
|
2007-01-23 22:02:53 -05:00
|
|
|
PM_TRANS_FLAG_ALLDEPS = 0x100,
|
|
|
|
PM_TRANS_FLAG_DOWNLOADONLY = 0x200,
|
|
|
|
PM_TRANS_FLAG_NOSCRIPTLET = 0x400,
|
|
|
|
PM_TRANS_FLAG_NOCONFLICTS = 0x800,
|
2007-11-22 15:01:45 -05:00
|
|
|
PM_TRANS_FLAG_PRINTURIS = 0x1000,
|
2008-01-13 16:15:10 -05:00
|
|
|
PM_TRANS_FLAG_NEEDED = 0x2000,
|
2007-11-18 12:45:46 -05:00
|
|
|
PM_TRANS_FLAG_ALLEXPLICIT = 0x4000,
|
2008-03-03 16:09:21 -05:00
|
|
|
PM_TRANS_FLAG_UNNEEDED = 0x8000,
|
|
|
|
PM_TRANS_FLAG_RECURSEALL = 0x10000
|
2007-01-23 22:02:53 -05:00
|
|
|
} pmtransflag_t;
|
2005-03-14 20:51:43 -05:00
|
|
|
|
2008-04-27 06:54:38 -04:00
|
|
|
/**
|
|
|
|
* @addtogroup alpm_trans
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* @brief Transaction events.
|
|
|
|
* NULL parameters are passed to in all events unless specified otherwise.
|
|
|
|
*/
|
2007-01-23 22:02:53 -05:00
|
|
|
typedef enum _pmtransevt_t {
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Dependencies will be computed for a package. */
|
2005-04-02 15:28:01 -05:00
|
|
|
PM_TRANS_EVT_CHECKDEPS_START = 1,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Dependencies were computed for a package. */
|
2005-04-02 15:28:01 -05:00
|
|
|
PM_TRANS_EVT_CHECKDEPS_DONE,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** File conflicts will be computed for a package. */
|
2005-04-02 15:28:01 -05:00
|
|
|
PM_TRANS_EVT_FILECONFLICTS_START,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** File conflicts were computed for a package. */
|
2005-04-02 15:28:01 -05:00
|
|
|
PM_TRANS_EVT_FILECONFLICTS_DONE,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Dependencies will be resolved for target package. */
|
2005-04-02 15:28:01 -05:00
|
|
|
PM_TRANS_EVT_RESOLVEDEPS_START,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Dependencies were resolved for target package. */
|
2005-04-02 15:28:01 -05:00
|
|
|
PM_TRANS_EVT_RESOLVEDEPS_DONE,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Inter-conflicts will be checked for target package. */
|
2005-04-13 15:59:04 -04:00
|
|
|
PM_TRANS_EVT_INTERCONFLICTS_START,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Inter-conflicts were checked for target package. */
|
2005-04-13 15:59:04 -04:00
|
|
|
PM_TRANS_EVT_INTERCONFLICTS_DONE,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Package will be installed.
|
|
|
|
* A pointer to the target package is passed to the callback.
|
|
|
|
*/
|
2005-03-15 13:41:02 -05:00
|
|
|
PM_TRANS_EVT_ADD_START,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Package was installed.
|
|
|
|
* A pointer to the new package is passed to the callback.
|
|
|
|
*/
|
2005-03-15 13:41:02 -05:00
|
|
|
PM_TRANS_EVT_ADD_DONE,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Package will be removed.
|
|
|
|
* A pointer to the target package is passed to the callback.
|
|
|
|
*/
|
2005-03-15 13:41:02 -05:00
|
|
|
PM_TRANS_EVT_REMOVE_START,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Package was removed.
|
|
|
|
* A pointer to the removed package is passed to the callback.
|
|
|
|
*/
|
2005-03-15 13:41:02 -05:00
|
|
|
PM_TRANS_EVT_REMOVE_DONE,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Package will be upgraded.
|
|
|
|
* A pointer to the upgraded package is passed to the callback.
|
|
|
|
*/
|
2005-03-15 13:41:02 -05:00
|
|
|
PM_TRANS_EVT_UPGRADE_START,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Package was upgraded.
|
|
|
|
* A pointer to the new package, and a pointer to the old package is passed
|
|
|
|
* to the callback, respectively.
|
|
|
|
*/
|
2006-10-15 15:31:03 -04:00
|
|
|
PM_TRANS_EVT_UPGRADE_DONE,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Target package's integrity will be checked. */
|
2006-10-15 15:31:03 -04:00
|
|
|
PM_TRANS_EVT_INTEGRITY_START,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Target package's integrity was checked. */
|
2006-10-15 15:31:03 -04:00
|
|
|
PM_TRANS_EVT_INTEGRITY_DONE,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Target deltas's integrity will be checked. */
|
2007-10-19 13:17:53 -04:00
|
|
|
PM_TRANS_EVT_DELTA_INTEGRITY_START,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Target delta's integrity was checked. */
|
2007-10-19 13:17:53 -04:00
|
|
|
PM_TRANS_EVT_DELTA_INTEGRITY_DONE,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Deltas will be applied to packages. */
|
2007-10-19 13:17:53 -04:00
|
|
|
PM_TRANS_EVT_DELTA_PATCHES_START,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Deltas were applied to packages. */
|
2007-10-19 13:17:53 -04:00
|
|
|
PM_TRANS_EVT_DELTA_PATCHES_DONE,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Delta patch will be applied to target package.
|
|
|
|
* The filename of the package and the filename of the patch is passed to the
|
|
|
|
* callback.
|
|
|
|
*/
|
2007-10-19 13:17:53 -04:00
|
|
|
PM_TRANS_EVT_DELTA_PATCH_START,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Delta patch was applied to target package. */
|
2007-10-19 13:17:53 -04:00
|
|
|
PM_TRANS_EVT_DELTA_PATCH_DONE,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Delta patch failed to apply to target package. */
|
2007-10-19 13:17:53 -04:00
|
|
|
PM_TRANS_EVT_DELTA_PATCH_FAILED,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Scriptlet has printed information.
|
|
|
|
* A line of text is passed to the callback.
|
|
|
|
*/
|
2007-11-04 10:47:21 -05:00
|
|
|
PM_TRANS_EVT_SCRIPTLET_INFO,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Print URI.
|
|
|
|
* The database's URI and the package's filename are passed to the callback.
|
|
|
|
*/
|
2006-10-15 15:31:03 -04:00
|
|
|
PM_TRANS_EVT_PRINTURI,
|
2008-04-27 06:54:38 -04:00
|
|
|
/** Files will be downloaded from a repository.
|
|
|
|
* The repository's tree name is passed to the callback.
|
|
|
|
*/
|
2006-10-15 15:31:03 -04:00
|
|
|
PM_TRANS_EVT_RETRIEVE_START,
|
2007-01-23 22:02:53 -05:00
|
|
|
} pmtransevt_t;
|
2008-04-27 06:54:38 -04:00
|
|
|
/*@}*/
|
2005-03-14 20:51:43 -05:00
|
|
|
|
2005-10-09 02:09:57 -04:00
|
|
|
/* Transaction Conversations (ie, questions) */
|
2007-01-23 22:02:53 -05:00
|
|
|
typedef enum _pmtransconv_t {
|
2006-10-15 15:31:03 -04:00
|
|
|
PM_TRANS_CONV_INSTALL_IGNOREPKG = 0x01,
|
|
|
|
PM_TRANS_CONV_REPLACE_PKG = 0x02,
|
|
|
|
PM_TRANS_CONV_CONFLICT_PKG = 0x04,
|
|
|
|
PM_TRANS_CONV_CORRUPTED_PKG = 0x08,
|
|
|
|
PM_TRANS_CONV_LOCAL_NEWER = 0x10,
|
2007-11-22 15:01:45 -05:00
|
|
|
/* 0x20 flag can go here */
|
2006-10-15 15:31:03 -04:00
|
|
|
PM_TRANS_CONV_REMOVE_HOLDPKG = 0x40
|
2007-01-23 22:02:53 -05:00
|
|
|
} pmtransconv_t;
|
2006-10-15 15:31:03 -04:00
|
|
|
|
|
|
|
/* Transaction Progress */
|
2007-01-23 22:02:53 -05:00
|
|
|
typedef enum _pmtransprog_t {
|
2006-10-15 15:31:03 -04:00
|
|
|
PM_TRANS_PROGRESS_ADD_START,
|
|
|
|
PM_TRANS_PROGRESS_UPGRADE_START,
|
2006-10-15 19:54:43 -04:00
|
|
|
PM_TRANS_PROGRESS_REMOVE_START,
|
|
|
|
PM_TRANS_PROGRESS_CONFLICTS_START
|
2007-01-23 22:02:53 -05:00
|
|
|
} pmtransprog_t;
|
2005-10-09 02:09:57 -04:00
|
|
|
|
|
|
|
/* Transaction Event callback */
|
2007-01-23 22:02:53 -05:00
|
|
|
typedef void (*alpm_trans_cb_event)(pmtransevt_t, void *, void *);
|
2005-05-04 15:55:23 -04:00
|
|
|
|
2005-10-09 02:09:57 -04:00
|
|
|
/* Transaction Conversation callback */
|
2007-01-23 22:02:53 -05:00
|
|
|
typedef void (*alpm_trans_cb_conv)(pmtransconv_t, void *, void *,
|
|
|
|
void *, int *);
|
2005-03-14 20:51:43 -05:00
|
|
|
|
2006-10-15 15:31:03 -04:00
|
|
|
/* Transaction Progress callback */
|
2007-03-03 03:13:59 -05:00
|
|
|
typedef void (*alpm_trans_cb_progress)(pmtransprog_t, const char *, int, int, int);
|
2006-10-15 15:31:03 -04:00
|
|
|
|
2007-01-23 22:02:53 -05:00
|
|
|
pmtranstype_t alpm_trans_get_type();
|
2006-11-22 04:03:41 -05:00
|
|
|
unsigned int alpm_trans_get_flags();
|
2007-02-26 03:38:48 -05:00
|
|
|
alpm_list_t * alpm_trans_get_pkgs();
|
2007-03-05 20:21:41 -05:00
|
|
|
int alpm_trans_init(pmtranstype_t type, pmtransflag_t flags,
|
2007-01-23 22:02:53 -05:00
|
|
|
alpm_trans_cb_event cb_event, alpm_trans_cb_conv conv,
|
|
|
|
alpm_trans_cb_progress cb_progress);
|
2005-11-07 07:57:33 -05:00
|
|
|
int alpm_trans_sysupgrade(void);
|
2005-03-14 20:51:43 -05:00
|
|
|
int alpm_trans_addtarget(char *target);
|
2007-01-19 04:28:44 -05:00
|
|
|
int alpm_trans_prepare(alpm_list_t **data);
|
|
|
|
int alpm_trans_commit(alpm_list_t **data);
|
2007-09-07 18:36:38 -04:00
|
|
|
int alpm_trans_interrupt(void);
|
2005-11-07 07:57:33 -05:00
|
|
|
int alpm_trans_release(void);
|
2005-03-14 20:51:43 -05:00
|
|
|
|
2005-03-29 15:31:03 -05:00
|
|
|
/*
|
2006-02-05 04:27:26 -05:00
|
|
|
* Dependencies and conflicts
|
2005-03-29 15:31:03 -05:00
|
|
|
*/
|
|
|
|
|
2007-01-23 22:02:53 -05:00
|
|
|
typedef enum _pmdepmod_t {
|
2005-03-29 15:31:03 -05:00
|
|
|
PM_DEP_MOD_ANY = 1,
|
|
|
|
PM_DEP_MOD_EQ,
|
|
|
|
PM_DEP_MOD_GE,
|
2007-12-18 08:24:44 -05:00
|
|
|
PM_DEP_MOD_LE,
|
|
|
|
PM_DEP_MOD_GT,
|
|
|
|
PM_DEP_MOD_LT
|
2007-01-23 22:02:53 -05:00
|
|
|
} pmdepmod_t;
|
|
|
|
|
2007-03-07 02:45:30 -05:00
|
|
|
int alpm_depcmp(pmpkg_t *pkg, pmdepend_t *dep);
|
2007-08-12 16:26:54 -04:00
|
|
|
alpm_list_t *alpm_checkdeps(pmdb_t *db, int reversedeps,
|
|
|
|
alpm_list_t *remove, alpm_list_t *upgrade);
|
2008-01-21 19:28:05 -05:00
|
|
|
alpm_list_t *alpm_deptest(pmdb_t *db, alpm_list_t *targets);
|
Cleanup usages of alpm_list_find and alpm_list_remove.
* remove obsolete and unused *_cmp helper functions like deppkg_cmp and
_alpm_grp_cmp
* new alpm_list_remove_str function, used 6 times in handle.c
* remove _alpm_prov_cmp / _alpm_db_whatprovides and replace them by
a more general alpm_find_pkg_satisfiers with a cleaner implementation.
before: alpm_db_whatprovides(db, targ)
after: alpm_find_pkg_satisfiers(alpm_db_getpkgcache(db), targ)
* remove satisfycmp and replace alpm_list_find + satisfycmp usage by
_alpm_find_dep_satisfiers.
before : alpm_list_find(_alpm_db_get_pkgcache(db), dep, satisfycmp)
after : _alpm_find_dep_satisfiers(_alpm_db_get_pkgcache(db), dep)
* remove _alpm_pkgname_pkg_cmp, which was used with alpm_list_remove, and
use _alpm_pkg_find + alpm_list_remove with _alpm_pkg_cmp instead.
This commit actually get rids of all complicated and asymmetric _cmp
functions. I first thought these functions were worth it, be caused it
allowed us to reuse list_find and list_remove. But this was at the detriment
of the clarity and also the ease of use of these functions, dangerous
because of their asymmetricity.
Signed-off-by: Chantry Xavier <shiningxc@gmail.com>
Signed-off-by: Dan McGee <dan@archlinux.org>
2008-05-10 12:47:42 -04:00
|
|
|
alpm_list_t *alpm_find_pkg_satisfiers(alpm_list_t *pkgs, const char *pkgname);
|
2007-03-07 02:45:30 -05:00
|
|
|
|
2007-11-12 23:48:15 -05:00
|
|
|
const char *alpm_miss_get_target(const pmdepmissing_t *miss);
|
2007-07-16 08:08:48 -04:00
|
|
|
pmdepend_t *alpm_miss_get_dep(pmdepmissing_t *miss);
|
2007-11-18 12:45:46 -05:00
|
|
|
const char *alpm_miss_get_causingpkg(const pmdepmissing_t *miss);
|
2007-07-16 08:08:48 -04:00
|
|
|
|
2007-12-09 08:49:34 -05:00
|
|
|
alpm_list_t *alpm_checkdbconflicts(pmdb_t *db_local);
|
|
|
|
|
2007-11-18 08:25:43 -05:00
|
|
|
const char *alpm_conflict_get_package1(pmconflict_t *conflict);
|
|
|
|
const char *alpm_conflict_get_package2(pmconflict_t *conflict);
|
|
|
|
|
2007-11-12 23:48:15 -05:00
|
|
|
pmdepmod_t alpm_dep_get_mod(const pmdepend_t *dep);
|
|
|
|
const char *alpm_dep_get_name(const pmdepend_t *dep);
|
|
|
|
const char *alpm_dep_get_version(const pmdepend_t *dep);
|
|
|
|
char *alpm_dep_get_string(const pmdepend_t *dep);
|
2005-03-29 15:31:03 -05:00
|
|
|
|
2006-02-05 04:27:26 -05:00
|
|
|
/*
|
|
|
|
* File conflicts
|
|
|
|
*/
|
|
|
|
|
2007-11-18 04:29:55 -05:00
|
|
|
typedef enum _pmfileconflicttype_t {
|
|
|
|
PM_FILECONFLICT_TARGET = 1,
|
|
|
|
PM_FILECONFLICT_FILESYSTEM
|
|
|
|
} pmfileconflicttype_t;
|
2006-02-05 04:27:26 -05:00
|
|
|
|
2007-11-18 04:29:55 -05:00
|
|
|
const char *alpm_fileconflict_get_target(pmfileconflict_t *conflict);
|
|
|
|
pmfileconflicttype_t alpm_fileconflict_get_type(pmfileconflict_t *conflict);
|
|
|
|
const char *alpm_fileconflict_get_file(pmfileconflict_t *conflict);
|
|
|
|
const char *alpm_fileconflict_get_ctarget(pmfileconflict_t *conflict);
|
2006-02-05 04:27:26 -05:00
|
|
|
|
2005-03-14 20:51:43 -05:00
|
|
|
/*
|
2006-01-02 11:20:01 -05:00
|
|
|
* Helpers
|
2005-03-14 20:51:43 -05:00
|
|
|
*/
|
|
|
|
|
2007-06-05 17:34:33 -04:00
|
|
|
/* checksums */
|
2007-08-20 12:55:38 -04:00
|
|
|
char *alpm_get_md5sum(const char *name);
|
2005-03-14 20:51:43 -05:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Errors
|
|
|
|
*/
|
2007-01-23 22:02:53 -05:00
|
|
|
enum _pmerrno_t {
|
2006-10-21 17:30:43 -04:00
|
|
|
PM_ERR_MEMORY = 1,
|
2005-03-14 20:51:43 -05:00
|
|
|
PM_ERR_SYSTEM,
|
|
|
|
PM_ERR_BADPERMS,
|
|
|
|
PM_ERR_NOT_A_FILE,
|
2007-08-21 21:28:05 -04:00
|
|
|
PM_ERR_NOT_A_DIR,
|
2005-03-14 20:51:43 -05:00
|
|
|
PM_ERR_WRONG_ARGS,
|
|
|
|
/* Interface */
|
|
|
|
PM_ERR_HANDLE_NULL,
|
|
|
|
PM_ERR_HANDLE_NOT_NULL,
|
|
|
|
PM_ERR_HANDLE_LOCK,
|
|
|
|
/* Databases */
|
|
|
|
PM_ERR_DB_OPEN,
|
|
|
|
PM_ERR_DB_CREATE,
|
|
|
|
PM_ERR_DB_NULL,
|
|
|
|
PM_ERR_DB_NOT_NULL,
|
2005-10-08 19:40:49 -04:00
|
|
|
PM_ERR_DB_NOT_FOUND,
|
2005-03-14 20:51:43 -05:00
|
|
|
PM_ERR_DB_WRITE,
|
2006-02-07 17:01:50 -05:00
|
|
|
PM_ERR_DB_REMOVE,
|
2006-10-15 15:31:03 -04:00
|
|
|
/* Servers */
|
2007-02-09 05:10:49 -05:00
|
|
|
PM_ERR_SERVER_BAD_URL,
|
2005-03-14 20:51:43 -05:00
|
|
|
/* Transactions */
|
|
|
|
PM_ERR_TRANS_NOT_NULL,
|
|
|
|
PM_ERR_TRANS_NULL,
|
|
|
|
PM_ERR_TRANS_DUP_TARGET,
|
|
|
|
PM_ERR_TRANS_NOT_INITIALIZED,
|
|
|
|
PM_ERR_TRANS_NOT_PREPARED,
|
|
|
|
PM_ERR_TRANS_ABORT,
|
2006-02-07 17:01:50 -05:00
|
|
|
PM_ERR_TRANS_TYPE,
|
2006-10-15 15:31:03 -04:00
|
|
|
PM_ERR_TRANS_COMMITING,
|
2007-02-09 05:10:49 -05:00
|
|
|
PM_ERR_TRANS_DOWNLOADING,
|
2005-03-14 20:51:43 -05:00
|
|
|
/* Packages */
|
|
|
|
PM_ERR_PKG_NOT_FOUND,
|
|
|
|
PM_ERR_PKG_INVALID,
|
|
|
|
PM_ERR_PKG_OPEN,
|
|
|
|
PM_ERR_PKG_LOAD,
|
|
|
|
PM_ERR_PKG_CANT_FRESH,
|
2007-02-08 03:09:34 -05:00
|
|
|
PM_ERR_PKG_CANT_REMOVE,
|
2005-04-17 06:01:22 -04:00
|
|
|
PM_ERR_PKG_INVALID_NAME,
|
2006-10-31 01:39:59 -05:00
|
|
|
PM_ERR_PKG_REPO_NOT_FOUND,
|
2007-10-19 13:17:53 -04:00
|
|
|
/* Deltas */
|
2008-02-26 18:50:17 -05:00
|
|
|
PM_ERR_DLT_INVALID,
|
2007-10-19 13:17:53 -04:00
|
|
|
PM_ERR_DLT_PATCHFAILED,
|
2005-03-14 20:51:43 -05:00
|
|
|
/* Groups */
|
|
|
|
PM_ERR_GRP_NOT_FOUND,
|
|
|
|
/* Dependencies */
|
|
|
|
PM_ERR_UNSATISFIED_DEPS,
|
|
|
|
PM_ERR_CONFLICTING_DEPS,
|
|
|
|
PM_ERR_FILE_CONFLICTS,
|
|
|
|
/* Misc */
|
|
|
|
PM_ERR_USER_ABORT,
|
2006-09-28 16:51:33 -04:00
|
|
|
PM_ERR_INTERNAL_ERROR,
|
2006-10-15 15:31:03 -04:00
|
|
|
PM_ERR_DB_SYNC,
|
|
|
|
PM_ERR_RETRIEVE,
|
|
|
|
PM_ERR_PKG_HOLD,
|
|
|
|
PM_ERR_INVALID_REGEX,
|
2008-04-06 21:09:27 -04:00
|
|
|
/* External library errors */
|
|
|
|
PM_ERR_LIBARCHIVE,
|
2008-04-06 22:00:11 -04:00
|
|
|
PM_ERR_LIBDOWNLOAD,
|
|
|
|
PM_ERR_EXTERNAL_DOWNLOAD
|
2006-12-22 14:38:55 -05:00
|
|
|
};
|
|
|
|
|
2007-01-23 22:02:53 -05:00
|
|
|
extern enum _pmerrno_t pm_errno;
|
2005-03-14 20:51:43 -05:00
|
|
|
|
2007-06-05 17:34:33 -04:00
|
|
|
const char *alpm_strerror(int err);
|
2007-09-08 12:41:45 -04:00
|
|
|
const char *alpm_strerrorlast(void);
|
2005-03-14 20:51:43 -05:00
|
|
|
|
2006-01-07 04:42:48 -05:00
|
|
|
#ifdef __cplusplus
|
2005-12-28 05:38:12 -05:00
|
|
|
}
|
|
|
|
#endif
|
2005-03-14 20:51:43 -05:00
|
|
|
#endif /* _ALPM_H */
|
|
|
|
|
|
|
|
/* vim: set ts=2 sw=2 noet: */
|