diff options
Diffstat (limited to 'lib/libalpm')
| -rw-r--r-- | lib/libalpm/add.c | 13 | ||||
| -rw-r--r-- | lib/libalpm/alpm.h | 19 | ||||
| -rw-r--r-- | lib/libalpm/conflict.c | 6 | ||||
| -rw-r--r-- | lib/libalpm/db.c | 4 | ||||
| -rw-r--r-- | lib/libalpm/deps.c | 12 | ||||
| -rw-r--r-- | lib/libalpm/dload.c | 47 | ||||
| -rw-r--r-- | lib/libalpm/error.c | 6 | ||||
| -rw-r--r-- | lib/libalpm/handle.c | 9 | ||||
| -rw-r--r-- | lib/libalpm/package.c | 9 | ||||
| -rw-r--r-- | lib/libalpm/remove.c | 6 | ||||
| -rw-r--r-- | lib/libalpm/sync.c | 101 | ||||
| -rw-r--r-- | lib/libalpm/sync.h | 3 | ||||
| -rw-r--r-- | lib/libalpm/trans.c | 22 | ||||
| -rw-r--r-- | lib/libalpm/trans.h | 1 | 
14 files changed, 101 insertions, 157 deletions
| diff --git a/lib/libalpm/add.c b/lib/libalpm/add.c index eef7aab1..50405895 100644 --- a/lib/libalpm/add.c +++ b/lib/libalpm/add.c @@ -114,7 +114,7 @@ int _alpm_add_prepare(pmtrans_t *trans, pmdb_t *db, alpm_list_t **data)  		/* look for unsatisfied dependencies */  		_alpm_log(PM_LOG_DEBUG, "looking for unsatisfied dependencies\n"); -		lp = alpm_checkdeps(db, 1, NULL, trans->packages); +		lp = alpm_checkdeps(_alpm_db_get_pkgcache(db), 1, NULL, trans->packages);  		if(lp != NULL) {  			if(data) {  				*data = lp; @@ -650,17 +650,18 @@ static int commit_single_pkg(pmpkg_t *newpkg, int pkg_current, int pkg_count,  	if(local) {  		is_upgrade = 1; -		EVENT(trans, PM_TRANS_EVT_UPGRADE_START, newpkg, NULL); -		_alpm_log(PM_LOG_DEBUG, "upgrading package %s-%s\n", -				newpkg->name, newpkg->version); -  		/* we'll need to save some record for backup checks later */  		oldpkg = _alpm_pkg_dup(local);  		/* make sure all infos are loaded because the database entry  		 * will be removed soon */  		_alpm_db_read(oldpkg->origin_data.db, oldpkg, INFRQ_ALL); + +		EVENT(trans, PM_TRANS_EVT_UPGRADE_START, newpkg, oldpkg); +		_alpm_log(PM_LOG_DEBUG, "upgrading package %s-%s\n", +				newpkg->name, newpkg->version); +  		/* copy over the install reason */ -		newpkg->reason = alpm_pkg_get_reason(local); +		newpkg->reason = alpm_pkg_get_reason(oldpkg);  		/* pre_upgrade scriptlet */  		if(alpm_pkg_has_scriptlet(newpkg) && !(trans->flags & PM_TRANS_FLAG_NOSCRIPTLET)) { diff --git a/lib/libalpm/alpm.h b/lib/libalpm/alpm.h index 16b48a0a..eda35d30 100644 --- a/lib/libalpm/alpm.h +++ b/lib/libalpm/alpm.h @@ -170,10 +170,10 @@ int alpm_db_setserver(pmdb_t *db, const char *url);  int alpm_db_update(int level, pmdb_t *db);  pmpkg_t *alpm_db_get_pkg(pmdb_t *db, const char *name); -alpm_list_t *alpm_db_getpkgcache(pmdb_t *db); +alpm_list_t *alpm_db_get_pkgcache(pmdb_t *db);  pmgrp_t *alpm_db_readgrp(pmdb_t *db, const char *name); -alpm_list_t *alpm_db_getgrpcache(pmdb_t *db); +alpm_list_t *alpm_db_get_grpcache(pmdb_t *db);  alpm_list_t *alpm_db_search(pmdb_t *db, const alpm_list_t* needles);  /* @@ -218,6 +218,7 @@ alpm_list_t *alpm_pkg_get_deltas(pmpkg_t *pkg);  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); +pmdb_t *alpm_pkg_get_db(pmpkg_t *pkg);  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); @@ -253,8 +254,6 @@ alpm_list_t *alpm_grp_get_pkgs(const pmgrp_t *grp);  pmpkg_t *alpm_sync_get_pkg(const pmsyncpkg_t *sync);  alpm_list_t *alpm_sync_get_removes(const pmsyncpkg_t *sync);  pmpkg_t *alpm_sync_newversion(pmpkg_t *pkg, alpm_list_t *dbs_sync); -int alpm_sync_sysupgrade(pmdb_t *db_local, -		alpm_list_t *dbs_sync, alpm_list_t **syncpkgs);  /*   * Transactions @@ -282,7 +281,7 @@ typedef enum _pmtransflag_t {  	PM_TRANS_FLAG_DOWNLOADONLY = 0x200,  	PM_TRANS_FLAG_NOSCRIPTLET = 0x400,  	PM_TRANS_FLAG_NOCONFLICTS = 0x800, -	PM_TRANS_FLAG_PRINTURIS = 0x1000, +	/* 0x1000 flag can go here */  	PM_TRANS_FLAG_NEEDED = 0x2000,  	PM_TRANS_FLAG_ALLEXPLICIT = 0x4000,  	PM_TRANS_FLAG_UNNEEDED = 0x8000, @@ -364,10 +363,6 @@ typedef enum _pmtransevt_t {  	 * A line of text is passed to the callback.  	 */  	PM_TRANS_EVT_SCRIPTLET_INFO, -	/** Print URI. -	 * The database's URI and the package's filename are passed to the callback. -	 */ -	PM_TRANS_EVT_PRINTURI,  	/** Files will be downloaded from a repository.  	 * The repository's tree name is passed to the callback.  	 */ @@ -431,7 +426,7 @@ typedef enum _pmdepmod_t {  } pmdepmod_t;  int alpm_depcmp(pmpkg_t *pkg, pmdepend_t *dep); -alpm_list_t *alpm_checkdeps(pmdb_t *db, int reversedeps, +alpm_list_t *alpm_checkdeps(alpm_list_t *pkglist, int reversedeps,  		alpm_list_t *remove, alpm_list_t *upgrade);  alpm_list_t *alpm_deptest(pmdb_t *db, alpm_list_t *targets); @@ -439,7 +434,7 @@ const char *alpm_miss_get_target(const pmdepmissing_t *miss);  pmdepend_t *alpm_miss_get_dep(pmdepmissing_t *miss);  const char *alpm_miss_get_causingpkg(const pmdepmissing_t *miss); -alpm_list_t *alpm_checkdbconflicts(pmdb_t *db_local); +alpm_list_t *alpm_checkconflicts(alpm_list_t *pkglist);  const char *alpm_conflict_get_package1(pmconflict_t *conflict);  const char *alpm_conflict_get_package2(pmconflict_t *conflict); @@ -531,7 +526,7 @@ enum _pmerrno_t {  	PM_ERR_INVALID_REGEX,  	/* External library errors */  	PM_ERR_LIBARCHIVE, -	PM_ERR_LIBDOWNLOAD, +	PM_ERR_LIBFETCH,  	PM_ERR_EXTERNAL_DOWNLOAD  }; diff --git a/lib/libalpm/conflict.c b/lib/libalpm/conflict.c index a044fc60..499e55a4 100644 --- a/lib/libalpm/conflict.c +++ b/lib/libalpm/conflict.c @@ -218,11 +218,11 @@ alpm_list_t *_alpm_outerconflicts(pmdb_t *db, alpm_list_t *packages)  /** Check the package conflicts in a database   * - * @param db_local the database to check + * @param pkglist the list of packages to check   * @return an alpm_list_t of pmconflict_t   */ -alpm_list_t SYMEXPORT *alpm_checkdbconflicts(pmdb_t *db_local) { -	return(_alpm_innerconflicts(_alpm_db_get_pkgcache(db_local))); +alpm_list_t SYMEXPORT *alpm_checkconflicts(alpm_list_t *pkglist) { +	return(_alpm_innerconflicts(pkglist));  }  /* Returns a alpm_list_t* of file conflicts. diff --git a/lib/libalpm/db.c b/lib/libalpm/db.c index 5632ffac..9b91ce47 100644 --- a/lib/libalpm/db.c +++ b/lib/libalpm/db.c @@ -263,7 +263,7 @@ pmpkg_t SYMEXPORT *alpm_db_get_pkg(pmdb_t *db, const char *name)   * @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 SYMEXPORT *alpm_db_getpkgcache(pmdb_t *db) +alpm_list_t SYMEXPORT *alpm_db_get_pkgcache(pmdb_t *db)  {  	ALPM_LOG_FUNC; @@ -295,7 +295,7 @@ pmgrp_t SYMEXPORT *alpm_db_readgrp(pmdb_t *db, const char *name)   * @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 SYMEXPORT *alpm_db_getgrpcache(pmdb_t *db) +alpm_list_t SYMEXPORT *alpm_db_get_grpcache(pmdb_t *db)  {  	ALPM_LOG_FUNC; diff --git a/lib/libalpm/deps.c b/lib/libalpm/deps.c index c667daa2..96c971a2 100644 --- a/lib/libalpm/deps.c +++ b/lib/libalpm/deps.c @@ -229,13 +229,13 @@ alpm_list_t SYMEXPORT *alpm_deptest(pmdb_t *db, alpm_list_t *targets)  /** Checks dependencies and returns missing ones in a list.   * Dependencies can include versions with depmod operators. - * @param db pointer to the local package database + * @param pkglist the list of local packages   * @param reversedeps handles the backward dependencies   * @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)   * @return an alpm_list_t* of pmpkg_t* of missing_t pointers.   */ -alpm_list_t SYMEXPORT *alpm_checkdeps(pmdb_t *db, int reversedeps, +alpm_list_t SYMEXPORT *alpm_checkdeps(alpm_list_t *pkglist, int reversedeps,  		alpm_list_t *remove, alpm_list_t *upgrade)  {  	alpm_list_t *i, *j; @@ -245,12 +245,8 @@ alpm_list_t SYMEXPORT *alpm_checkdeps(pmdb_t *db, int reversedeps,  	ALPM_LOG_FUNC; -	if(db == NULL) { -		return(NULL); -	} -  	targets = alpm_list_join(alpm_list_copy(remove), alpm_list_copy(upgrade)); -	for(i = _alpm_db_get_pkgcache(db); i; i = i->next) { +	for(i = pkglist; i; i = i->next) {  		void *pkg = i->data;  		if(alpm_list_find(targets, pkg, _alpm_pkg_cmp)) {  			modified = alpm_list_add(modified, pkg); @@ -572,7 +568,7 @@ int _alpm_resolvedeps(pmdb_t *local, alpm_list_t *dbs_sync, alpm_list_t *list,  	for(i = list; i; i = i->next) {  		pmpkg_t *tpkg = i->data;  		targ = alpm_list_add(NULL, tpkg); -		deps = alpm_checkdeps(local, 0, remove, targ); +		deps = alpm_checkdeps(_alpm_db_get_pkgcache(local), 0, remove, targ);  		alpm_list_free(targ);  		for(j = deps; j; j = j->next) {  			pmdepmissing_t *miss = j->data; diff --git a/lib/libalpm/dload.c b/lib/libalpm/dload.c index 9b082943..9934f30a 100644 --- a/lib/libalpm/dload.c +++ b/lib/libalpm/dload.c @@ -24,6 +24,7 @@  #include <errno.h>  #include <string.h>  #include <unistd.h> +#include <signal.h>  #include <limits.h>  /* the following two are needed on BSD for libfetch */  #if defined(HAVE_SYS_SYSLIMITS_H) @@ -35,14 +36,14 @@  #if defined(HAVE_LIBDOWNLOAD)  #include <download.h> +#define fetchFreeURL downloadFreeURL +#define fetchLastErrCode downloadLastErrCode +#define fetchLastErrString downloadLastErrString +#define fetchParseURL downloadParseURL +#define fetchTimeout downloadTimeout +#define fetchXGet downloadXGet  #elif defined(HAVE_LIBFETCH)  #include <fetch.h> -#define downloadFreeURL fetchFreeURL -#define downloadLastErrCode fetchLastErrCode -#define downloadLastErrString fetchLastErrString -#define downloadParseURL fetchParseURL -#define downloadTimeout fetchTimeout -#define downloadXGet fetchXGet  #endif  /* libalpm */ @@ -86,7 +87,7 @@ static char *get_tempfile(const char *path, const char *filename) {  static struct url *url_for_string(const char *url)  {  	struct url *ret = NULL; -	ret = downloadParseURL(url); +	ret = fetchParseURL(url);  	if(!ret) {  		_alpm_log(PM_LOG_ERROR, _("url '%s' is invalid\n"), url);  		RET_ERR(PM_ERR_SERVER_BAD_URL, NULL); @@ -114,6 +115,7 @@ static int download_internal(const char *url, const char *localpath,  	int chk_resume = 0, ret = 0;  	size_t dl_thisfile = 0, nread = 0;  	char *tempfile, *destfile, *filename; +	struct sigaction new_action, old_action;  	struct url *fileurl = url_for_string(url);  	char buffer[PM_DLBUF_LEN]; @@ -142,23 +144,29 @@ static int download_internal(const char *url, const char *localpath,  		dl_thisfile = 0;  	} -	/* libdownload does not reset the error code, reset it in -	 * the case of previous errors */ -	downloadLastErrCode = 0; +	/* libfetch does not reset the error code */ +	fetchLastErrCode = 0;  	/* 10s timeout - TODO make a config option */ -	downloadTimeout = 10000; +	fetchTimeout = 10000; -	dlf = downloadXGet(fileurl, &ust, (handle->nopassiveftp ? "" : "p")); +	/* ignore any SIGPIPE signals- these may occur if our FTP socket dies or +	 * something along those lines. Store the old signal handler first. */ +	new_action.sa_handler = SIG_IGN; +	sigemptyset(&new_action.sa_mask); +	sigaction(SIGPIPE, NULL, &old_action); +	sigaction(SIGPIPE, &new_action, NULL); -	if(downloadLastErrCode != 0 || dlf == NULL) { +	dlf = fetchXGet(fileurl, &ust, (handle->nopassiveftp ? "" : "p")); + +	if(fetchLastErrCode != 0 || dlf == NULL) {  		const char *host = _("disk");  		if(strcmp(SCHEME_FILE, fileurl->scheme) != 0) {  			host = fileurl->host;  		} -		pm_errno = PM_ERR_LIBDOWNLOAD; +		pm_errno = PM_ERR_LIBFETCH;  		_alpm_log(PM_LOG_ERROR, _("failed retrieving file '%s' from %s : %s\n"), -				filename, host, downloadLastErrString); +				filename, host, fetchLastErrString);  		ret = -1;  		goto cleanup;  	} else { @@ -203,9 +211,9 @@ static int download_internal(const char *url, const char *localpath,  	while((nread = fread(buffer, 1, PM_DLBUF_LEN, dlf)) > 0) {  		size_t nwritten = 0;  		if(ferror(dlf)) { -			pm_errno = PM_ERR_LIBDOWNLOAD; +			pm_errno = PM_ERR_LIBFETCH;  			_alpm_log(PM_LOG_ERROR, _("error downloading '%s': %s\n"), -					filename, downloadLastErrString); +					filename, fetchLastErrString);  			ret = -1;  			goto cleanup;  		} @@ -237,6 +245,9 @@ static int download_internal(const char *url, const char *localpath,  	ret = 0;  cleanup: +	/* restore any existing SIGPIPE signal handler */ +	sigaction(SIGPIPE, &old_action, NULL); +  	FREE(tempfile);  	FREE(destfile);  	if(localf != NULL) { @@ -245,7 +256,7 @@ cleanup:  	if(dlf != NULL) {  		fclose(dlf);  	} -	downloadFreeURL(fileurl); +	fetchFreeURL(fileurl);  	return(ret);  }  #endif diff --git a/lib/libalpm/error.c b/lib/libalpm/error.c index 05caf8ec..80a4fb1a 100644 --- a/lib/libalpm/error.c +++ b/lib/libalpm/error.c @@ -32,9 +32,9 @@  #if defined(HAVE_LIBDOWNLOAD)  #include <download.h> /* downloadLastErrString */ +#define fetchLastErrString downloadLastErrString  #elif defined(HAVE_LIBFETCH)  #include <fetch.h> /* fetchLastErrString */ -#define downloadLastErrString fetchLastErrString  #endif  /* libalpm */ @@ -154,9 +154,9 @@ const char SYMEXPORT *alpm_strerror(int err)  			 * requires the archive struct, so we can't. Just use a generic  			 * error string instead. */  			return _("libarchive error"); -		case PM_ERR_LIBDOWNLOAD: +		case PM_ERR_LIBFETCH:  #if defined(INTERNAL_DOWNLOAD) -			return downloadLastErrString; +			return fetchLastErrString;  #else  			/* obviously shouldn't get here... */  			return _("download library error"); diff --git a/lib/libalpm/handle.c b/lib/libalpm/handle.c index af1cc78b..7dc01223 100644 --- a/lib/libalpm/handle.c +++ b/lib/libalpm/handle.c @@ -48,16 +48,7 @@ pmhandle_t *_alpm_handle_new()  	ALPM_LOG_FUNC;  	CALLOC(handle, 1, sizeof(pmhandle_t), RET_ERR(PM_ERR_MEMORY, NULL)); -  	handle->lckfd = -1; -	handle->logstream = NULL; - -	handle->root = NULL; -	handle->dbpath = NULL; -	handle->cachedirs = NULL; -	handle->lockfile = NULL; -	handle->logfile = NULL; -	handle->usedelta = 0;  	return(handle);  } diff --git a/lib/libalpm/package.c b/lib/libalpm/package.c index a9f4b43d..ee0ff6f5 100644 --- a/lib/libalpm/package.c +++ b/lib/libalpm/package.c @@ -422,6 +422,15 @@ alpm_list_t SYMEXPORT *alpm_pkg_get_backup(pmpkg_t *pkg)  	return pkg->backup;  } +pmdb_t SYMEXPORT *alpm_pkg_get_db(pmpkg_t *pkg) +{ +	/* Sanity checks */ +	ASSERT(pkg != NULL, return(NULL)); +	ASSERT(pkg->origin == PKG_FROM_CACHE, return(NULL)); + +	return(pkg->origin_data.db); +} +  /**   * Open a package changelog for reading. Similar to fopen in functionality,   * except that the returned 'file stream' could really be from an archive diff --git a/lib/libalpm/remove.c b/lib/libalpm/remove.c index 864fafaf..f0734902 100644 --- a/lib/libalpm/remove.c +++ b/lib/libalpm/remove.c @@ -104,7 +104,7 @@ static void remove_prepare_cascade(pmtrans_t *trans, pmdb_t *db,  		}  		alpm_list_free_inner(lp, (alpm_list_fn_free)_alpm_depmiss_free);  		alpm_list_free(lp); -		lp = alpm_checkdeps(db, 1, trans->packages, NULL); +		lp = alpm_checkdeps(_alpm_db_get_pkgcache(db), 1, trans->packages, NULL);  	}  } @@ -134,7 +134,7 @@ static void remove_prepare_keep_needed(pmtrans_t *trans, pmdb_t *db,  		}  		alpm_list_free_inner(lp, (alpm_list_fn_free)_alpm_depmiss_free);  		alpm_list_free(lp); -		lp = alpm_checkdeps(db, 1, trans->packages, NULL); +		lp = alpm_checkdeps(_alpm_db_get_pkgcache(db), 1, trans->packages, NULL);  	}  } @@ -161,7 +161,7 @@ int _alpm_remove_prepare(pmtrans_t *trans, pmdb_t *db, alpm_list_t **data)  		EVENT(trans, PM_TRANS_EVT_CHECKDEPS_START, NULL, NULL);  		_alpm_log(PM_LOG_DEBUG, "looking for unsatisfied dependencies\n"); -		lp = alpm_checkdeps(db, 1, trans->packages, NULL); +		lp = alpm_checkdeps(_alpm_db_get_pkgcache(db), 1, trans->packages, NULL);  		if(lp != NULL) {  			if(trans->flags & PM_TRANS_FLAG_CASCADE) { diff --git a/lib/libalpm/sync.c b/lib/libalpm/sync.c index 4a705b57..b458874d 100644 --- a/lib/libalpm/sync.c +++ b/lib/libalpm/sync.c @@ -77,17 +77,12 @@ void _alpm_sync_free(pmsyncpkg_t *sync)  /* Find recommended replacements for packages during a sync.   */ -static int find_replacements(pmtrans_t *trans, pmdb_t *db_local, -		alpm_list_t *dbs_sync, alpm_list_t **syncpkgs) +static int find_replacements(pmtrans_t *trans, pmdb_t *db_local, alpm_list_t *dbs_sync)  {  	alpm_list_t *i, *j, *k; /* wow */  	ALPM_LOG_FUNC; -	if(syncpkgs == NULL) { -		return(-1); -	} -  	/* check for "recommended" package replacements */  	_alpm_log(PM_LOG_DEBUG, "checking for package replacements\n");  	for(i = dbs_sync; i; i = i->next) { @@ -113,13 +108,10 @@ static int find_replacements(pmtrans_t *trans, pmdb_t *db_local,  										alpm_pkg_get_name(lpkg), alpm_pkg_get_version(lpkg),  										alpm_pkg_get_name(spkg), alpm_pkg_get_version(spkg));  				} else { -					/* get confirmation for the replacement */ -					if(trans) { -						int doreplace = 0; -						QUESTION(trans, PM_TRANS_CONV_REPLACE_PKG, lpkg, spkg, db->treename, &doreplace); -						if(!doreplace) { -							continue; -						} +					int doreplace = 0; +					QUESTION(trans, PM_TRANS_CONV_REPLACE_PKG, lpkg, spkg, db->treename, &doreplace); +					if(!doreplace) { +						continue;  					}  					/* if confirmed, add this to the 'final' list, designating 'lpkg' as @@ -129,7 +121,7 @@ static int find_replacements(pmtrans_t *trans, pmdb_t *db_local,  					/* check if spkg->name is already in the packages list. */  					/* TODO: same package name doesn't mean same package */ -					sync = _alpm_sync_find(*syncpkgs, alpm_pkg_get_name(spkg)); +					sync = _alpm_sync_find(trans->packages, alpm_pkg_get_name(spkg));  					if(sync) {  						/* found it -- just append to the removes list */  						sync->removes = alpm_list_add(sync->removes, lpkg); @@ -143,15 +135,12 @@ static int find_replacements(pmtrans_t *trans, pmdb_t *db_local,  						sync = _alpm_sync_new(alpm_pkg_get_reason(lpkg), spkg, NULL);  						if(sync == NULL) {  							pm_errno = PM_ERR_MEMORY; -							alpm_list_free_inner(*syncpkgs, (alpm_list_fn_free)_alpm_sync_free); -							alpm_list_free(*syncpkgs); -							*syncpkgs = NULL;  							return(-1);  						}  						sync->removes = alpm_list_add(NULL, lpkg);  						_alpm_log(PM_LOG_DEBUG, "adding package %s-%s to the transaction targets\n",  									alpm_pkg_get_name(spkg), alpm_pkg_get_version(spkg)); -						*syncpkgs = alpm_list_add(*syncpkgs, sync); +						trans->packages = alpm_list_add(trans->packages, sync);  					}  					_alpm_log(PM_LOG_DEBUG, "%s-%s elected for removal (to be replaced by %s-%s)\n",  							alpm_pkg_get_name(lpkg), alpm_pkg_get_version(lpkg), @@ -199,33 +188,19 @@ pmpkg_t SYMEXPORT *alpm_sync_newversion(pmpkg_t *pkg, alpm_list_t *dbs_sync)  	return(NULL);  } -/** Get a list of upgradable packages on the current system - * Adds out of date packages to *list. - * @arg list pointer to a list of pmsyncpkg_t. - */ -int SYMEXPORT alpm_sync_sysupgrade(pmdb_t *db_local, -		alpm_list_t *dbs_sync, alpm_list_t **syncpkgs) -{ -	return(_alpm_sync_sysupgrade(NULL, db_local, dbs_sync, syncpkgs)); -} - -int _alpm_sync_sysupgrade(pmtrans_t *trans, -		pmdb_t *db_local, alpm_list_t *dbs_sync, alpm_list_t **syncpkgs) +int _alpm_sync_sysupgrade(pmtrans_t *trans, pmdb_t *db_local, alpm_list_t *dbs_sync)  {  	alpm_list_t *i, *j, *replaced = NULL;  	ALPM_LOG_FUNC; -	if(syncpkgs == NULL) { -		return(-1); -	}  	/* check for "recommended" package replacements */ -	if(find_replacements(trans, db_local, dbs_sync, syncpkgs)) { +	if(find_replacements(trans, db_local, dbs_sync)) {  		return(-1);  	}  	/* compute the to-be-replaced packages for efficiency */ -	for(i = *syncpkgs; i; i = i->next) { +	for(i = trans->packages; i; i = i->next) {  		pmsyncpkg_t *sync = i->data;  		for(j = sync->removes; j; j = j->next) {  			replaced = alpm_list_add(replaced, j->data); @@ -255,22 +230,19 @@ int _alpm_sync_sysupgrade(pmtrans_t *trans,  			}  			/* add the upgrade package to our pmsyncpkg_t list */ -			if(_alpm_sync_find(*syncpkgs, alpm_pkg_get_name(spkg))) { +			if(_alpm_sync_find(trans->packages, alpm_pkg_get_name(spkg))) {  				/* avoid duplicated targets */  				continue;  			}  			/* we can set any reason here, it will be overridden by add_commit */  			pmsyncpkg_t *sync = _alpm_sync_new(PM_PKG_REASON_EXPLICIT, spkg, NULL);  			if(sync == NULL) { -				alpm_list_free_inner(*syncpkgs, (alpm_list_fn_free)_alpm_sync_free); -				alpm_list_free(*syncpkgs); -				*syncpkgs = NULL;  				alpm_list_free(replaced);  				return(-1);  			}  			_alpm_log(PM_LOG_DEBUG, "adding package %s-%s to the transaction targets\n",  							alpm_pkg_get_name(spkg), alpm_pkg_get_version(spkg)); -			*syncpkgs = alpm_list_add(*syncpkgs, sync); +			trans->packages = alpm_list_add(trans->packages, sync);  		}  	} @@ -497,8 +469,7 @@ int _alpm_sync_prepare(pmtrans_t *trans, pmdb_t *db_local, alpm_list_t *dbs_sync  		EVENT(trans, PM_TRANS_EVT_RESOLVEDEPS_DONE, NULL, NULL);  	} -	/* We don't care about conflicts if we're just printing uris */ -	if(!(trans->flags & (PM_TRANS_FLAG_NOCONFLICTS | PM_TRANS_FLAG_PRINTURIS))) { +	if(!(trans->flags & PM_TRANS_FLAG_NOCONFLICTS)) {  		/* check for inter-conflicts and whatnot */  		EVENT(trans, PM_TRANS_EVT_INTERCONFLICTS_START, NULL, NULL); @@ -631,7 +602,7 @@ int _alpm_sync_prepare(pmtrans_t *trans, pmdb_t *db_local, alpm_list_t *dbs_sync  		}  		_alpm_log(PM_LOG_DEBUG, "checking dependencies\n"); -		deps = alpm_checkdeps(db_local, 1, remove, list); +		deps = alpm_checkdeps(_alpm_db_get_pkgcache(db_local), 1, remove, list);  		if(deps) {  			pm_errno = PM_ERR_UNSATISFIED_DEPS;  			ret = -1; @@ -838,32 +809,27 @@ int _alpm_sync_commit(pmtrans_t *trans, pmdb_t *db_local, alpm_list_t **data)  				fname = alpm_pkg_get_filename(spkg);  				ASSERT(fname != NULL, RET_ERR(PM_ERR_PKG_INVALID_NAME, -1)); -				if(trans->flags & PM_TRANS_FLAG_PRINTURIS) { -					EVENT(trans, PM_TRANS_EVT_PRINTURI, (char *)alpm_db_get_url(current), -							(char *)fname); -				} else { -					if(spkg->download_size != 0) { -						alpm_list_t *delta_path = spkg->delta_path; -						if(delta_path) { -							alpm_list_t *dlts = NULL; - -							for(dlts = delta_path; dlts; dlts = dlts->next) { -								pmdelta_t *d = dlts->data; - -								if(d->download_size != 0) { -									/* add the delta filename to the download list if -									 * it's not in the cache */ -									files = alpm_list_add(files, strdup(d->delta)); -								} - -								/* keep a list of the delta files for md5sums */ -								deltas = alpm_list_add(deltas, d); +				if(spkg->download_size != 0) { +					alpm_list_t *delta_path = spkg->delta_path; +					if(delta_path) { +						alpm_list_t *dlts = NULL; + +						for(dlts = delta_path; dlts; dlts = dlts->next) { +							pmdelta_t *d = dlts->data; + +							if(d->download_size != 0) { +								/* add the delta filename to the download list if +								 * it's not in the cache */ +								files = alpm_list_add(files, strdup(d->delta));  							} -						} else { -							/* not using deltas, so add the file to the download list */ -							files = alpm_list_add(files, strdup(fname)); +							/* keep a list of the delta files for md5sums */ +							deltas = alpm_list_add(deltas, d);  						} + +					} else { +						/* not using deltas, so add the file to the download list */ +						files = alpm_list_add(files, strdup(fname));  					}  				}  			} @@ -880,9 +846,6 @@ int _alpm_sync_commit(pmtrans_t *trans, pmdb_t *db_local, alpm_list_t **data)  			FREELIST(files);  		}  	} -	if(trans->flags & PM_TRANS_FLAG_PRINTURIS) { -		return(0); -	}  	/* clear out value to let callback know we are done */  	if(handle->totaldlcb) { diff --git a/lib/libalpm/sync.h b/lib/libalpm/sync.h index b71f0ef2..b6a4bbff 100644 --- a/lib/libalpm/sync.h +++ b/lib/libalpm/sync.h @@ -33,8 +33,7 @@ struct __pmsyncpkg_t {  pmsyncpkg_t *_alpm_sync_new(pmpkgreason_t newreason, pmpkg_t *spkg, alpm_list_t *removes);  void _alpm_sync_free(pmsyncpkg_t *data); -int _alpm_sync_sysupgrade(pmtrans_t *trans, -		pmdb_t *db_local, alpm_list_t *dbs_sync, alpm_list_t **syncpkgs); +int _alpm_sync_sysupgrade(pmtrans_t *trans, pmdb_t *db_local, alpm_list_t *dbs_sync);  int _alpm_sync_addtarget(pmtrans_t *trans, pmdb_t *db_local, alpm_list_t *dbs_sync, char *name);  int _alpm_sync_prepare(pmtrans_t *trans, pmdb_t *db_local, alpm_list_t *dbs_sync, alpm_list_t **data); diff --git a/lib/libalpm/trans.c b/lib/libalpm/trans.c index acad84e8..4b831193 100644 --- a/lib/libalpm/trans.c +++ b/lib/libalpm/trans.c @@ -100,7 +100,7 @@ int SYMEXPORT alpm_trans_sysupgrade()  	ASSERT(trans->state == STATE_INITIALIZED, RET_ERR(PM_ERR_TRANS_NOT_INITIALIZED, -1));  	ASSERT(trans->type == PM_TRANS_TYPE_SYNC, RET_ERR(PM_ERR_TRANS_TYPE, -1)); -	return(_alpm_trans_sysupgrade(trans)); +	return(_alpm_sync_sysupgrade(trans, handle->db_local, handle->dbs_sync));  }  /** Add a target to the transaction. @@ -226,15 +226,6 @@ pmtrans_t *_alpm_trans_new()  	ALPM_LOG_FUNC;  	CALLOC(trans, 1, sizeof(pmtrans_t), RET_ERR(PM_ERR_MEMORY, NULL)); - -	trans->packages = NULL; -	trans->skip_add = NULL; -	trans->skip_remove = NULL; -	trans->type = 0; -	trans->flags = 0; -	trans->cb_event = NULL; -	trans->cb_conv = NULL; -	trans->cb_progress = NULL;  	trans->state = STATE_IDLE;  	return(trans); @@ -280,17 +271,6 @@ int _alpm_trans_init(pmtrans_t *trans, pmtranstype_t type, pmtransflag_t flags,  	return(0);  } -int _alpm_trans_sysupgrade(pmtrans_t *trans) -{ -	ALPM_LOG_FUNC; - -	/* Sanity checks */ -	ASSERT(trans != NULL, RET_ERR(PM_ERR_TRANS_NULL, -1)); - -	return(_alpm_sync_sysupgrade(trans, handle->db_local, handle->dbs_sync, -				&(trans->packages))); -} -  /** Add a target to the transaction.   * @param trans the current transaction   * @param target the name of the target to add diff --git a/lib/libalpm/trans.h b/lib/libalpm/trans.h index d74c3e90..48996573 100644 --- a/lib/libalpm/trans.h +++ b/lib/libalpm/trans.h @@ -71,7 +71,6 @@ void _alpm_trans_free(pmtrans_t *trans);  int _alpm_trans_init(pmtrans_t *trans, pmtranstype_t type, pmtransflag_t flags,                       alpm_trans_cb_event event, alpm_trans_cb_conv conv,                       alpm_trans_cb_progress progress); -int _alpm_trans_sysupgrade(pmtrans_t *trans);  int _alpm_trans_addtarget(pmtrans_t *trans, char *target);  int _alpm_trans_prepare(pmtrans_t *trans, alpm_list_t **data);  int _alpm_trans_commit(pmtrans_t *trans, alpm_list_t **data); | 
