2005-03-14 20:51:43 -05:00
|
|
|
/*
|
|
|
|
* add.c
|
|
|
|
*
|
2006-01-02 14:55:35 -05:00
|
|
|
* Copyright (c) 2002-2006 by Judd Vinet <jvinet@zeroflux.org>
|
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
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
|
|
|
|
* USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
2006-05-14 22:19:57 -04:00
|
|
|
#include <libintl.h>
|
2005-03-14 20:51:43 -05:00
|
|
|
|
|
|
|
#include <alpm.h>
|
2007-01-19 04:28:44 -05:00
|
|
|
#include <alpm_list.h>
|
2005-03-14 20:51:43 -05:00
|
|
|
/* pacman */
|
2005-03-19 04:00:40 -05:00
|
|
|
#include "log.h"
|
2006-11-14 02:58:42 -05:00
|
|
|
#include "downloadprog.h"
|
2005-03-19 04:00:40 -05:00
|
|
|
#include "trans.h"
|
2005-10-29 03:17:43 -04:00
|
|
|
#include "add.h"
|
2005-10-28 08:20:40 -04:00
|
|
|
#include "conf.h"
|
2006-05-14 22:19:57 -04:00
|
|
|
#include "util.h"
|
2005-03-14 20:51:43 -05:00
|
|
|
|
2005-10-29 03:00:56 -04:00
|
|
|
extern config_t *config;
|
2005-03-14 20:51:43 -05:00
|
|
|
|
2007-01-19 04:28:44 -05:00
|
|
|
int pacman_add(alpm_list_t *targets)
|
2005-03-14 20:51:43 -05:00
|
|
|
{
|
2007-01-30 23:42:39 -05:00
|
|
|
alpm_list_t *i = targets, *data = NULL;
|
2006-01-26 15:46:48 -05:00
|
|
|
int retval = 0;
|
2005-03-14 20:51:43 -05:00
|
|
|
|
|
|
|
if(targets == NULL) {
|
|
|
|
return(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Check for URL targets and process them
|
|
|
|
*/
|
2007-01-19 04:28:44 -05:00
|
|
|
while(i) {
|
2005-03-14 20:51:43 -05:00
|
|
|
if(strstr(i->data, "://")) {
|
2006-10-15 15:34:52 -04:00
|
|
|
char *str = alpm_fetch_pkgurl(i->data);
|
2005-03-14 20:51:43 -05:00
|
|
|
if(str == NULL) {
|
|
|
|
return(1);
|
|
|
|
} else {
|
|
|
|
free(i->data);
|
|
|
|
i->data = str;
|
|
|
|
}
|
|
|
|
}
|
2007-01-19 04:28:44 -05:00
|
|
|
i = i->next;
|
2005-03-14 20:51:43 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Step 1: create a new transaction
|
|
|
|
*/
|
2005-10-28 08:20:40 -04:00
|
|
|
if(alpm_trans_init((config->upgrade == 0) ? PM_TRANS_TYPE_ADD : PM_TRANS_TYPE_UPGRADE,
|
2006-10-15 15:34:52 -04:00
|
|
|
config->flags, cb_trans_evt, cb_trans_conv, cb_trans_progress) == -1) {
|
2005-03-14 20:51:43 -05:00
|
|
|
ERR(NL, "%s\n", alpm_strerror(pm_errno));
|
2006-01-26 15:46:48 -05:00
|
|
|
if(pm_errno == PM_ERR_HANDLE_LOCK) {
|
2006-05-14 22:19:57 -04:00
|
|
|
MSG(NL, _(" if you're sure a package manager is not already running,\n"
|
2007-01-31 01:10:21 -05:00
|
|
|
" you can remove %s%s\n"), alpm_option_get_root(), PM_LOCK);
|
2006-01-26 15:46:48 -05:00
|
|
|
}
|
2005-03-14 20:51:43 -05:00
|
|
|
return(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* and add targets to it */
|
2006-05-14 22:19:57 -04:00
|
|
|
MSG(NL, _("loading package data... "));
|
2005-03-14 20:51:43 -05:00
|
|
|
for(i = targets; i; i = i->next) {
|
|
|
|
if(alpm_trans_addtarget(i->data) == -1) {
|
2007-02-01 01:35:30 -05:00
|
|
|
MSG(NL, "\n");
|
2007-02-03 22:24:32 -05:00
|
|
|
ERR(NL, _("failed to add target '%s' (%s)"), (char *)i->data, alpm_strerror(pm_errno));
|
2006-01-26 15:46:48 -05:00
|
|
|
retval = 1;
|
|
|
|
goto cleanup;
|
2005-03-14 20:51:43 -05:00
|
|
|
}
|
|
|
|
}
|
2007-02-01 01:35:30 -05:00
|
|
|
MSG(CL, _("done.\n"));
|
2005-03-14 20:51:43 -05:00
|
|
|
|
|
|
|
/* Step 2: "compute" the transaction based on targets and flags
|
|
|
|
*/
|
|
|
|
if(alpm_trans_prepare(&data) == -1) {
|
2006-10-15 15:34:52 -04:00
|
|
|
long long *pkgsize, *freespace;
|
2005-03-14 20:51:43 -05:00
|
|
|
|
2006-05-14 22:19:57 -04:00
|
|
|
ERR(NL, _("failed to prepare transaction (%s)\n"), alpm_strerror(pm_errno));
|
2005-03-14 20:51:43 -05:00
|
|
|
switch(pm_errno) {
|
|
|
|
case PM_ERR_UNSATISFIED_DEPS:
|
2007-01-19 04:28:44 -05:00
|
|
|
for(i = data; i; i = alpm_list_next(i)) {
|
2006-11-20 04:10:23 -05:00
|
|
|
pmdepmissing_t *miss = alpm_list_getdata(i);
|
2007-02-28 23:51:33 -05:00
|
|
|
|
|
|
|
/* TODO indicate if the error was a virtual package or not:
|
|
|
|
* :: %s: requires %s, provided by %s
|
|
|
|
*/
|
2006-11-22 04:03:41 -05:00
|
|
|
MSG(NL, _(":: %s: requires %s"), alpm_dep_get_target(miss),
|
|
|
|
alpm_dep_get_name(miss));
|
|
|
|
switch(alpm_dep_get_mod(miss)) {
|
2007-01-23 22:02:53 -05:00
|
|
|
case PM_DEP_MOD_ANY:
|
|
|
|
break;
|
|
|
|
case PM_DEP_MOD_EQ:
|
|
|
|
MSG(CL, "=%s", alpm_dep_get_version(miss));
|
|
|
|
break;
|
|
|
|
case PM_DEP_MOD_GE:
|
|
|
|
MSG(CL, ">=%s", alpm_dep_get_version(miss));
|
|
|
|
break;
|
|
|
|
case PM_DEP_MOD_LE:
|
|
|
|
MSG(CL, "<=%s", alpm_dep_get_version(miss));
|
|
|
|
break;
|
2005-03-14 20:51:43 -05:00
|
|
|
}
|
|
|
|
MSG(CL, "\n");
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case PM_ERR_CONFLICTING_DEPS:
|
2007-01-19 04:28:44 -05:00
|
|
|
for(i = data; i; i = alpm_list_next(i)) {
|
2006-11-20 04:10:23 -05:00
|
|
|
pmdepmissing_t *miss = alpm_list_getdata(i);
|
2006-05-14 22:19:57 -04:00
|
|
|
MSG(NL, _(":: %s: conflicts with %s"),
|
2006-11-22 04:03:41 -05:00
|
|
|
alpm_dep_get_target(miss), alpm_dep_get_name(miss));
|
2005-03-14 20:51:43 -05:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case PM_ERR_FILE_CONFLICTS:
|
2007-01-19 04:28:44 -05:00
|
|
|
for(i = data; i; i = alpm_list_next(i)) {
|
2006-11-20 04:10:23 -05:00
|
|
|
pmconflict_t *conflict = alpm_list_getdata(i);
|
2006-11-22 04:03:41 -05:00
|
|
|
switch(alpm_conflict_get_type(conflict)) {
|
2006-02-05 04:34:49 -05:00
|
|
|
case PM_CONFLICT_TYPE_TARGET:
|
2007-02-23 02:50:35 -05:00
|
|
|
MSG(NL, _("%s exists in both '%s' and '%s'\n"),
|
2006-11-22 04:03:41 -05:00
|
|
|
alpm_conflict_get_file(conflict),
|
|
|
|
alpm_conflict_get_target(conflict),
|
|
|
|
alpm_conflict_get_ctarget(conflict));
|
2006-02-05 04:34:49 -05:00
|
|
|
break;
|
|
|
|
case PM_CONFLICT_TYPE_FILE:
|
2007-02-23 02:50:35 -05:00
|
|
|
MSG(NL, _("%s: %s exists in filesystem\n"),
|
2006-11-22 04:03:41 -05:00
|
|
|
alpm_conflict_get_target(conflict),
|
|
|
|
alpm_conflict_get_file(conflict));
|
2006-02-05 04:34:49 -05:00
|
|
|
break;
|
|
|
|
}
|
2005-03-14 20:51:43 -05:00
|
|
|
}
|
2006-05-14 22:19:57 -04:00
|
|
|
MSG(NL, _("\nerrors occurred, no packages were upgraded.\n"));
|
2005-03-14 20:51:43 -05:00
|
|
|
break;
|
2007-01-19 04:28:44 -05:00
|
|
|
/* TODO This is gross... we should not return these values in the same list we
|
|
|
|
* would get conflicts and such with... it's just silly
|
|
|
|
*/
|
2006-10-15 15:34:52 -04:00
|
|
|
case PM_ERR_DISK_FULL:
|
2007-01-19 04:28:44 -05:00
|
|
|
i = data;
|
2006-10-15 15:34:52 -04:00
|
|
|
pkgsize = alpm_list_getdata(i);
|
|
|
|
i = alpm_list_next(i);
|
|
|
|
freespace = alpm_list_getdata(i);
|
|
|
|
MSG(NL, _(":: %.1f MB required, have %.1f MB"),
|
2007-01-19 04:28:44 -05:00
|
|
|
(double)(*pkgsize / (1024.0*1024.0)), (double)(*freespace / (1024.0*1024.0)));
|
2006-10-15 15:34:52 -04:00
|
|
|
break;
|
2005-03-14 20:51:43 -05:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
2006-10-15 15:34:52 -04:00
|
|
|
retval=1;
|
2006-01-26 15:46:48 -05:00
|
|
|
goto cleanup;
|
2005-03-14 20:51:43 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Step 3: actually perform the installation
|
|
|
|
*/
|
2006-01-07 13:42:44 -05:00
|
|
|
if(alpm_trans_commit(NULL) == -1) {
|
2006-05-14 22:19:57 -04:00
|
|
|
ERR(NL, _("failed to commit transaction (%s)\n"), alpm_strerror(pm_errno));
|
2006-10-15 15:34:52 -04:00
|
|
|
retval=1;
|
2006-01-26 15:46:48 -05:00
|
|
|
goto cleanup;
|
2005-03-14 20:51:43 -05:00
|
|
|
}
|
|
|
|
|
2006-01-26 15:46:48 -05:00
|
|
|
cleanup:
|
2006-11-21 22:51:06 -05:00
|
|
|
if(data) {
|
2007-01-24 03:51:50 -05:00
|
|
|
alpm_list_free(data);
|
2006-11-21 22:51:06 -05:00
|
|
|
}
|
2006-01-13 16:16:49 -05:00
|
|
|
if(alpm_trans_release() == -1) {
|
2006-05-14 22:19:57 -04:00
|
|
|
ERR(NL, _("failed to release transaction (%s)\n"), alpm_strerror(pm_errno));
|
2006-10-15 15:34:52 -04:00
|
|
|
retval=1;
|
2006-01-13 16:16:49 -05:00
|
|
|
}
|
2006-01-26 15:46:48 -05:00
|
|
|
|
|
|
|
return(retval);
|
2005-03-14 20:51:43 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/* vim: set ts=2 sw=2 noet: */
|