add.c and remove.c cleanup

Unification and cleanup of the add.c and remove.c code. It looks remarkably
similar, so this may be a candidate for functionalization at a later time.

Signed-off-by: Dan McGee <dan@archlinux.org>
This commit is contained in:
Dan McGee 2007-04-25 04:08:49 -04:00
parent 7760f5fe60
commit c03277f83d
3 changed files with 74 additions and 42 deletions

View File

@ -710,7 +710,7 @@ int SYMEXPORT alpm_trans_addtarget(char *target)
} }
/** Prepare a transaction. /** Prepare a transaction.
* @param data the address of a PM_LIST where detailed description * @param data the address of an alpm_list where detailed description
* of an error can be dumped (ie. list of conflicting files) * of an error can be dumped (ie. list of conflicting files)
* @return 0 on success, -1 on error (pm_errno is set accordingly) * @return 0 on success, -1 on error (pm_errno is set accordingly)
*/ */
@ -729,7 +729,7 @@ int SYMEXPORT alpm_trans_prepare(alpm_list_t **data)
} }
/** Commit a transaction. /** Commit a transaction.
* @param data the address of a PM_LIST where detailed description * @param data the address of an alpm_list where detailed description
* of an error can be dumped (ie. list of conflicting files) * of an error can be dumped (ie. list of conflicting files)
* @return 0 on success, -1 on error (pm_errno is set accordingly) * @return 0 on success, -1 on error (pm_errno is set accordingly)
*/ */

View File

@ -37,6 +37,13 @@
extern config_t *config; extern config_t *config;
/**
* @brief Upgrade a specified list of packages.
*
* @param targets a list of packages (as strings) to upgrade
*
* @return 0 on success, 1 on failure
*/
int pacman_upgrade(alpm_list_t *targets) int pacman_upgrade(alpm_list_t *targets)
{ {
/* this is basically just a remove-then-add process. pacman_add() will */ /* this is basically just a remove-then-add process. pacman_add() will */
@ -45,9 +52,17 @@ int pacman_upgrade(alpm_list_t *targets)
return(pacman_add(targets)); return(pacman_add(targets));
} }
/**
* @brief Add a specified list of packages which cannot already be installed.
*
* @param targets a list of packages (as strings) to add
*
* @return 0 on success, 1 on failure
*/
int pacman_add(alpm_list_t *targets) int pacman_add(alpm_list_t *targets)
{ {
alpm_list_t *i = targets, *data = NULL; alpm_list_t *i, *data = NULL;
pmtranstype_t transtype = PM_TRANS_TYPE_ADD;
int retval = 0; int retval = 0;
if(targets == NULL) { if(targets == NULL) {
@ -56,7 +71,7 @@ int pacman_add(alpm_list_t *targets)
/* Check for URL targets and process them /* Check for URL targets and process them
*/ */
while(i) { for(i = targets; i; i = alpm_list_next(i)) {
if(strstr(i->data, "://")) { if(strstr(i->data, "://")) {
char *str = alpm_fetch_pkgurl(i->data); char *str = alpm_fetch_pkgurl(i->data);
if(str == NULL) { if(str == NULL) {
@ -66,13 +81,17 @@ int pacman_add(alpm_list_t *targets)
i->data = str; i->data = str;
} }
} }
i = i->next;
} }
/* Step 1: create a new transaction /* Step 1: create a new transaction */
*/ if(config->upgrade == 1) {
if(alpm_trans_init((config->upgrade == 0) ? PM_TRANS_TYPE_ADD : PM_TRANS_TYPE_UPGRADE, /* if upgrade flag was set, change this to an upgrade transaction */
config->flags, cb_trans_evt, cb_trans_conv, cb_trans_progress) == -1) { transtype = PM_TRANS_TYPE_UPGRADE;
}
if(alpm_trans_init(transtype, config->flags, cb_trans_evt,
cb_trans_conv, cb_trans_progress) == -1) {
/* TODO: error messages should be in the front end, not the back */
ERR(NL, "%s\n", alpm_strerror(pm_errno)); ERR(NL, "%s\n", alpm_strerror(pm_errno));
if(pm_errno == PM_ERR_HANDLE_LOCK) { if(pm_errno == PM_ERR_HANDLE_LOCK) {
MSG(NL, _(" if you're sure a package manager is not already running,\n" MSG(NL, _(" if you're sure a package manager is not already running,\n"
@ -81,20 +100,23 @@ int pacman_add(alpm_list_t *targets)
return(1); return(1);
} }
/* and add targets to it */ /* add targets to the created transaction */
MSG(NL, _("loading package data... ")); MSG(NL, _("loading package data... "));
for(i = targets; i; i = i->next) { for(i = targets; i; i = alpm_list_next(i)) {
if(alpm_trans_addtarget(i->data) == -1) { char *targ = alpm_list_getdata(i);
if(alpm_trans_addtarget(targ) == -1) {
/* TODO: glad this output is hacky */
MSG(NL, "\n"); MSG(NL, "\n");
ERR(NL, _("failed to add target '%s' (%s)"), (char *)i->data, alpm_strerror(pm_errno)); ERR(NL, _("failed to add target '%s' (%s)"), targ,
alpm_strerror(pm_errno));
retval = 1; retval = 1;
goto cleanup; goto cleanup;
} }
} }
MSG(CL, _("done.\n")); MSG(CL, _("done.\n"));
/* Step 2: "compute" the transaction based on targets and flags /* Step 2: "compute" the transaction based on targets and flags */
*/ /* TODO: No, compute nothing. This is stupid. */
if(alpm_trans_prepare(&data) == -1) { if(alpm_trans_prepare(&data) == -1) {
long long *pkgsize, *freespace; long long *pkgsize, *freespace;
@ -124,14 +146,14 @@ int pacman_add(alpm_list_t *targets)
} }
MSG(CL, "\n"); MSG(CL, "\n");
} }
break; break;
case PM_ERR_CONFLICTING_DEPS: case PM_ERR_CONFLICTING_DEPS:
for(i = data; i; i = alpm_list_next(i)) { for(i = data; i; i = alpm_list_next(i)) {
pmdepmissing_t *miss = alpm_list_getdata(i); pmdepmissing_t *miss = alpm_list_getdata(i);
MSG(NL, _(":: %s: conflicts with %s"), MSG(NL, _(":: %s: conflicts with %s"),
alpm_dep_get_target(miss), alpm_dep_get_name(miss)); alpm_dep_get_target(miss), alpm_dep_get_name(miss));
} }
break; break;
case PM_ERR_FILE_CONFLICTS: case PM_ERR_FILE_CONFLICTS:
for(i = data; i; i = alpm_list_next(i)) { for(i = data; i; i = alpm_list_next(i)) {
pmconflict_t *conflict = alpm_list_getdata(i); pmconflict_t *conflict = alpm_list_getdata(i);
@ -150,9 +172,9 @@ int pacman_add(alpm_list_t *targets)
} }
} }
MSG(NL, _("\nerrors occurred, no packages were upgraded.\n")); MSG(NL, _("\nerrors occurred, no packages were upgraded.\n"));
break; break;
/* TODO This is gross... we should not return these values in the same list we /* TODO This is gross... we should not return these values in the same
* would get conflicts and such with... it's just silly * list we would get conflicts and such with... it's just silly
*/ */
case PM_ERR_DISK_FULL: case PM_ERR_DISK_FULL:
i = data; i = data;
@ -160,17 +182,17 @@ int pacman_add(alpm_list_t *targets)
i = alpm_list_next(i); i = alpm_list_next(i);
freespace = alpm_list_getdata(i); freespace = alpm_list_getdata(i);
MSG(NL, _(":: %.1f MB required, have %.1f MB"), MSG(NL, _(":: %.1f MB required, have %.1f MB"),
(double)(*pkgsize / (1024.0*1024.0)), (double)(*freespace / (1024.0*1024.0))); (double)(*pkgsize / (1024.0*1024.0)),
break; (double)(*freespace / (1024.0*1024.0)));
break;
default: default:
break; break;
} }
retval=1; retval=1;
goto cleanup; goto cleanup;
} }
/* Step 3: actually perform the installation /* Step 3: perform the installation */
*/
if(alpm_trans_commit(NULL) == -1) { if(alpm_trans_commit(NULL) == -1) {
ERR(NL, _("failed to commit transaction (%s)\n"), alpm_strerror(pm_errno)); ERR(NL, _("failed to commit transaction (%s)\n"), alpm_strerror(pm_errno));
retval=1; retval=1;

View File

@ -39,9 +39,16 @@ extern config_t *config;
extern pmdb_t *db_local; extern pmdb_t *db_local;
/**
* @brief Remove a specified list of packages.
*
* @param targets a list of packages (as strings) to remove from the system
*
* @return 0 on success, 1 on failure
*/
int pacman_remove(alpm_list_t *targets) int pacman_remove(alpm_list_t *targets)
{ {
alpm_list_t *data = NULL, *i, *j, *finaltargs = NULL; alpm_list_t *i, *j, *data = NULL, *finaltargs = NULL;
int retval = 0; int retval = 0;
if(targets == NULL) { if(targets == NULL) {
@ -73,9 +80,9 @@ int pacman_remove(alpm_list_t *targets)
} }
} }
/* Step 1: create a new transaction /* Step 1: create a new transaction */
*/ if(alpm_trans_init(PM_TRANS_TYPE_REMOVE, config->flags,
if(alpm_trans_init(PM_TRANS_TYPE_REMOVE, config->flags, cb_trans_evt, cb_trans_conv, cb_trans_progress) == -1) { cb_trans_evt, cb_trans_conv, cb_trans_progress) == -1) {
ERR(NL, _("failed to init transaction (%s)\n"), alpm_strerror(pm_errno)); ERR(NL, _("failed to init transaction (%s)\n"), alpm_strerror(pm_errno));
if(pm_errno == PM_ERR_HANDLE_LOCK) { if(pm_errno == PM_ERR_HANDLE_LOCK) {
MSG(NL, _(" if you're sure a package manager is not already running,\n" MSG(NL, _(" if you're sure a package manager is not already running,\n"
@ -84,18 +91,22 @@ int pacman_remove(alpm_list_t *targets)
FREELIST(finaltargs); FREELIST(finaltargs);
return(1); return(1);
} }
/* and add targets to it */
/* add targets to the created transaction */
MSG(NL, _("loading package data... "));
for(i = finaltargs; i; i = alpm_list_next(i)) { for(i = finaltargs; i; i = alpm_list_next(i)) {
char *targ = alpm_list_getdata(i); char *targ = alpm_list_getdata(i);
if(alpm_trans_addtarget(targ) == -1) { if(alpm_trans_addtarget(targ) == -1) {
ERR(NL, _("failed to add target '%s' (%s)\n"), targ, alpm_strerror(pm_errno)); /* TODO: glad this output is hacky */
MSG(NL, "\n");
ERR(NL, _("failed to add target '%s' (%s)\n"), targ,
alpm_strerror(pm_errno));
retval = 1; retval = 1;
goto cleanup; goto cleanup;
} }
} }
/* Step 2: prepare the transaction based on its type, targets and flags /* Step 2: prepare the transaction based on its type, targets and flags */
*/
if(alpm_trans_prepare(&data) == -1) { if(alpm_trans_prepare(&data) == -1) {
ERR(NL, _("failed to prepare transaction (%s)\n"), alpm_strerror(pm_errno)); ERR(NL, _("failed to prepare transaction (%s)\n"), alpm_strerror(pm_errno));
switch(pm_errno) { switch(pm_errno) {
@ -106,19 +117,20 @@ int pacman_remove(alpm_list_t *targets)
alpm_dep_get_name(miss)); alpm_dep_get_name(miss));
} }
alpm_list_free(data); alpm_list_free(data);
break; break;
default: default:
break; break;
} }
retval = 1; retval = 1;
goto cleanup; goto cleanup;
} }
/* Warn user in case of dangerous operation /* Warn user in case of dangerous operation */
*/ if(config->flags & PM_TRANS_FLAG_RECURSE ||
if(config->flags & PM_TRANS_FLAG_RECURSE || config->flags & PM_TRANS_FLAG_CASCADE) { config->flags & PM_TRANS_FLAG_CASCADE) {
/* list transaction targets */ /* list transaction targets */
alpm_list_t *lst = NULL; alpm_list_t *lst = NULL;
/* create a new list of package names only */
for(i = alpm_trans_get_pkgs(); i; i = alpm_list_next(i)) { for(i = alpm_trans_get_pkgs(); i; i = alpm_list_next(i)) {
pmpkg_t *pkg = alpm_list_getdata(i); pmpkg_t *pkg = alpm_list_getdata(i);
lst = alpm_list_add(lst, strdup(alpm_pkg_get_name(pkg))); lst = alpm_list_add(lst, strdup(alpm_pkg_get_name(pkg)));
@ -134,16 +146,14 @@ int pacman_remove(alpm_list_t *targets)
MSG(NL, "\n"); MSG(NL, "\n");
} }
/* Step 3: actually perform the removal /* Step 3: actually perform the removal */
*/
if(alpm_trans_commit(NULL) == -1) { if(alpm_trans_commit(NULL) == -1) {
ERR(NL, _("failed to commit transaction (%s)\n"), alpm_strerror(pm_errno)); ERR(NL, _("failed to commit transaction (%s)\n"), alpm_strerror(pm_errno));
retval = 1; retval = 1;
goto cleanup; goto cleanup;
} }
/* Step 4: release transaction resources /* Step 4: release transaction resources */
*/
cleanup: cleanup:
FREELIST(finaltargs); FREELIST(finaltargs);
if(alpm_trans_release() == -1) { if(alpm_trans_release() == -1) {