1 /* opkg_install.c - the opkg package management system
5 Copyright (C) 2001 University of Southern California
7 This program is free software; you can redistribute it and/or
8 modify it under the terms of the GNU General Public License as
9 published by the Free Software Foundation; either version 2, or (at
10 your option) any later version.
12 This program is distributed in the hope that it will be useful, but
13 WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 General Public License for more details.
24 typedef void (*sighandler_t)(int);
28 #include "pkg_extract.h"
30 #include "opkg_install.h"
31 #include "opkg_configure.h"
32 #include "opkg_download.h"
33 #include "opkg_remove.h"
35 #include "opkg_utils.h"
36 #include "opkg_message.h"
37 #include "opkg_state.h"
38 #include "opkg_defines.h"
40 #include "sprintf_alloc.h"
41 #include "file_util.h"
46 int satisfy_dependencies_for(opkg_conf_t *conf, pkg_t *pkg);
47 static int verify_pkg_installable(opkg_conf_t *conf, pkg_t *pkg);
48 static int unpack_pkg_control_files(opkg_conf_t *conf, pkg_t *pkg);
50 static int prerm_upgrade_old_pkg(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg);
51 static int prerm_upgrade_old_pkg_unwind(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg);
52 static int prerm_deconfigure_conflictors(opkg_conf_t *conf, pkg_t *pkg, pkg_vec_t *conflictors);
53 static int prerm_deconfigure_conflictors_unwind(opkg_conf_t *conf, pkg_t *pkg, pkg_vec_t *conflictors);
54 static int preinst_configure(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg);
55 static int preinst_configure_unwind(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg);
56 static int check_data_file_clashes(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg);
57 static int check_data_file_clashes_change(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg);
58 static int check_data_file_clashes_unwind(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg);
59 static int backup_modified_conffiles(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg);
60 static int backup_modified_conffiles_unwind(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg);
61 static int postrm_upgrade_old_pkg(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg);
62 static int postrm_upgrade_old_pkg_unwind(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg);
64 static int remove_obsolesced_files(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg);
65 static int install_maintainer_scripts(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg);
66 static int remove_disappeared(opkg_conf_t *conf, pkg_t *pkg);
67 static int install_data_files(opkg_conf_t *conf, pkg_t *pkg);
68 static int resolve_conffiles(opkg_conf_t *conf, pkg_t *pkg);
70 static int cleanup_temporary_files(opkg_conf_t *conf, pkg_t *pkg);
72 static int user_prefers_old_conffile(const char *file, const char *backup);
74 static char *backup_filename_alloc(const char *file_name);
75 static int backup_make_backup(opkg_conf_t *conf, const char *file_name);
76 static int backup_exists_for(const char *file_name);
77 static int backup_remove(const char *file_name);
80 int opkg_install_from_file(opkg_conf_t *conf, const char *filename)
84 char *old_version, *new_version;
91 err = pkg_init_from_file(pkg, filename);
96 if (!pkg->architecture) {
97 opkg_message(conf, OPKG_ERROR, "Package %s has no Architecture defined.\n", pkg->name);
101 /* XXX: CLEANUP: hash_insert_pkg has a nasty side effect of possibly
102 freeing the pkg that we pass in. It might be nice to clean this up
104 pkg = hash_insert_pkg(&conf->pkg_hash, pkg, 1,conf);
105 old = pkg_hash_fetch_installed_by_name(&conf->pkg_hash, pkg->name);
107 pkg->local_filename = strdup(filename);
110 old_version = pkg_version_str_alloc(old);
111 new_version = pkg_version_str_alloc(pkg);
113 cmp = pkg_compare_versions(old, pkg);
114 if ( (conf->force_downgrade==1) && (cmp > 0) ){ /* We've been asked to allow downgrade and version is precedent */
115 cmp = -1 ; /* then we force opkg to downgrade */
116 /* We need to use a value < 0 because in the 0 case we are asking to */
117 /* reinstall, and some check could fail asking the "force-reinstall" option */
120 opkg_message(conf, OPKG_NOTICE,
121 "Not downgrading package %s on %s from %s to %s.\n",
122 old->name, old->dest->name, old_version, new_version);
123 pkg->state_want = SW_DEINSTALL;
124 pkg->state_flag |= SF_OBSOLETE;
134 opkg_message(conf, OPKG_DEBUG2,"Function: %s calling opkg_install_pkg \n",__FUNCTION__);
135 return opkg_install_pkg(conf, pkg,0);
138 opkg_error_t opkg_install_by_name(opkg_conf_t *conf, const char *pkg_name)
142 char *old_version, *new_version;
144 opkg_message(conf, OPKG_DEBUG2, " Getting old from pkg_hash_fetch \n" );
145 old = pkg_hash_fetch_installed_by_name(&conf->pkg_hash, pkg_name);
147 opkg_message(conf, OPKG_DEBUG2, " Old versions from pkg_hash_fetch %s \n", old->version );
149 opkg_message(conf, OPKG_DEBUG2, " Getting new from pkg_hash_fetch \n" );
150 new = pkg_hash_fetch_best_installation_candidate_by_name(conf, pkg_name, &err);
152 opkg_message(conf, OPKG_DEBUG2, " New versions from pkg_hash_fetch %s \n", new->version );
154 /* Pigi Basically here is broken the version stuff.
155 What's happening is that nothing provide the version to differents
156 functions, so the returned struct is always the latest.
157 That's why the install by name don't work.
159 opkg_message(conf, OPKG_DEBUG2, " Versions from pkg_hash_fetch in %s ", __FUNCTION__ );
162 opkg_message(conf, OPKG_DEBUG2, " old %s ", old->version );
164 opkg_message(conf, OPKG_DEBUG2, " new %s ", new->version );
165 opkg_message(conf, OPKG_DEBUG2, " \n");
171 return OPKG_PKG_HAS_NO_CANDIDATE;
174 new->state_flag |= SF_USER;
176 old_version = pkg_version_str_alloc(old);
177 new_version = pkg_version_str_alloc(new);
179 cmp = pkg_compare_versions(old, new);
180 if ( (conf->force_downgrade==1) && (cmp > 0) ){ /* We've been asked to allow downgrade and version is precedent */
181 opkg_message(conf, OPKG_DEBUG, " Forcing downgrade \n");
182 cmp = -1 ; /* then we force opkg to downgrade */
183 /* We need to use a value < 0 because in the 0 case we are asking to */
184 /* reinstall, and some check could fail asking the "force-reinstall" option */
186 opkg_message(conf, OPKG_DEBUG,
187 "Comparing visible versions of pkg %s:"
188 "\n\t%s is installed "
189 "\n\t%s is available "
190 "\n\t%d was comparison result\n",
191 pkg_name, old_version, new_version, cmp);
192 if (cmp == 0 && !conf->force_reinstall) {
193 opkg_message(conf, OPKG_NOTICE,
194 "Package %s (%s) installed in %s is up to date.\n",
195 old->name, old_version, old->dest->name);
199 } else if (cmp > 0) {
200 opkg_message(conf, OPKG_NOTICE,
201 "Not downgrading package %s on %s from %s to %s.\n",
202 old->name, old->dest->name, old_version, new_version);
206 } else if (cmp < 0) {
207 new->dest = old->dest;
208 old->state_want = SW_DEINSTALL; /* Here probably the problem for bug 1277 */
212 /* XXX: CLEANUP: The error code of opkg_install_by_name is really
213 supposed to be an opkg_error_t, but opkg_install_pkg could
214 return any kind of integer, (might be errno from a syscall,
215 etc.). This is a real mess and will need to be cleaned up if
216 anyone ever wants to make a nice libopkg. */
218 opkg_message(conf, OPKG_DEBUG2,"Function: %s calling opkg_install_pkg \n",__FUNCTION__);
219 return opkg_install_pkg(conf, new,0);
222 opkg_error_t opkg_install_multi_by_name(opkg_conf_t *conf, const char *pkg_name)
224 abstract_pkg_vec_t *providers = pkg_hash_fetch_all_installation_candidates (&conf->pkg_hash, pkg_name);
227 abstract_pkg_t *ppkg ;
229 if (providers == NULL)
230 return OPKG_PKG_HAS_NO_CANDIDATE;
232 for (i = 0; i < providers->len; i++) {
233 ppkg = abstract_pkg_vec_get(providers, i);
234 opkg_message(conf, OPKG_DEBUG2,"Function: %s calling opkg_install_by_name %d \n",__FUNCTION__, i);
235 err = opkg_install_by_name(conf, ppkg->name);
238 /* XXX Maybe ppkg should be freed ? */
244 * Walk dependence graph starting with pkg, collect packages to be
245 * installed into pkgs_needed, in dependence order.
247 int pkg_mark_dependencies_for_installation(opkg_conf_t *conf, pkg_t *pkg, pkg_vec_t *pkgs_needed)
250 pkg_vec_t *depends = pkg_vec_alloc();
251 char **unresolved = NULL;
254 ndepends = pkg_hash_fetch_unsatisfied_dependencies(conf,
259 opkg_message(conf, OPKG_ERROR,
260 "%s: Cannot satisfy the following dependencies for %s:\n\t",
261 conf->force_depends ? "Warning" : "ERROR", pkg->name);
262 while (*unresolved) {
263 opkg_message(conf, OPKG_ERROR, " %s", *unresolved);
266 opkg_message(conf, OPKG_ERROR, "\n");
267 if (! conf->force_depends) {
268 opkg_message(conf, OPKG_INFO,
269 "This could mean that your package list is out of date or that the packages\n"
270 "mentioned above do not yet exist (try 'opkg update'). To proceed in spite\n"
271 "of this problem try again with the '-force-depends' option.\n");
272 pkg_vec_free(depends);
273 return OPKG_PKG_DEPS_UNSATISFIED;
278 pkg_vec_free(depends);
282 for (i = 0; i < depends->len; i++) {
283 pkg_t *dep = depends->pkgs[i];
284 /* The package was uninstalled when we started, but another
285 dep earlier in this loop may have depended on it and pulled
286 it in, so check first. */
287 if ((dep->state_status != SS_INSTALLED)
288 && (dep->state_status != SS_UNPACKED)
289 && (dep->state_want != SW_INSTALL)) {
291 /* Mark packages as to-be-installed */
292 dep->state_want = SW_INSTALL;
294 /* Dependencies should be installed the same place as pkg */
295 if (dep->dest == NULL) {
296 dep->dest = pkg->dest;
299 err = pkg_mark_dependencies_for_installation(conf, dep, pkgs_needed);
301 pkg_vec_free(depends);
307 pkg_vec_insert(pkgs_needed, pkg);
309 pkg_vec_free(depends);
314 int name_mark_dependencies_for_installation(opkg_conf_t *conf, const char *pkg_name, pkg_vec_t *pkgs_needed)
318 char *old_version, *new_version;
320 old = pkg_hash_fetch_installed_by_name(&conf->pkg_hash, pkg_name);
322 new = pkg_hash_fetch_best_installation_candidate_by_name(conf, pkg_name);
324 return OPKG_PKG_HAS_NO_CANDIDATE;
327 old_version = pkg_version_str_alloc(old);
328 new_version = pkg_version_str_alloc(new);
330 cmp = pkg_compare_versions(old, new);
331 if ( (conf->force_downgrade==1) && (cmp > 0) ){ /* We've been asked to allow downgrade and version is precedent */
332 opkg_message(conf, OPKG_DEBUG, " Forcing downgrade ");
333 cmp = -1 ; /* then we force opkg to downgrade */
334 /* We need to use a value < 0 because in the 0 case we are asking to */
335 /* reinstall, and some check could fail asking the "force-reinstall" option */
337 opkg_message(conf, OPKG_DEBUG,
338 "comparing visible versions of pkg %s:"
339 "\n\t%s is installed "
340 "\n\t%s is available "
341 "\n\t%d was comparison result\n",
342 pkg_name, old_version, new_version, cmp);
343 if (cmp == 0 && !conf->force_reinstall) {
344 opkg_message(conf, OPKG_NOTICE,
345 "Package %s (%s) installed in %s is up to date.\n",
346 old->name, old_version, old->dest->name);
350 } else if (cmp > 0) {
351 opkg_message(conf, OPKG_NOTICE,
352 "Not downgrading package %s on %s from %s to %s.\n",
353 old->name, old->dest->name, old_version, new_version);
357 } else if (cmp < 0) {
358 new->dest = old->dest;
359 old->state_want = SW_DEINSTALL;
360 old->state_flag |= SF_OBSOLETE;
363 return pkg_mark_dependencies_for_installation(conf, new, pkgs_needed);
368 int satisfy_dependencies_for(opkg_conf_t *conf, pkg_t *pkg)
371 pkg_vec_t *depends = pkg_vec_alloc();
373 char **unresolved = NULL;
376 ndepends = pkg_hash_fetch_unsatisfied_dependencies(conf,
381 opkg_message(conf, OPKG_ERROR,
382 "%s: Cannot satisfy the following dependencies for %s:\n\t",
383 conf->force_depends ? "Warning" : "ERROR", pkg->name);
384 while (*unresolved) {
385 opkg_message(conf, OPKG_ERROR, " %s", *unresolved);
388 opkg_message(conf, OPKG_ERROR, "\n");
389 if (! conf->force_depends) {
390 opkg_message(conf, OPKG_INFO,
391 "This could mean that your package list is out of date or that the packages\n"
392 "mentioned above do not yet exist (try 'opkg update'). To proceed in spite\n"
393 "of this problem try again with the '-force-depends' option.\n");
394 pkg_vec_free(depends);
395 return OPKG_PKG_DEPS_UNSATISFIED;
400 pkg_vec_free(depends);
404 /* Mark packages as to-be-installed */
405 for (i=0; i < depends->len; i++) {
406 /* Dependencies should be installed the same place as pkg */
407 if (depends->pkgs[i]->dest == NULL) {
408 depends->pkgs[i]->dest = pkg->dest;
410 depends->pkgs[i]->state_want = SW_INSTALL;
413 for (i = 0; i < depends->len; i++) {
414 dep = depends->pkgs[i];
415 /* The package was uninstalled when we started, but another
416 dep earlier in this loop may have depended on it and pulled
417 it in, so check first. */
418 if ((dep->state_status != SS_INSTALLED)
419 && (dep->state_status != SS_UNPACKED)) {
420 opkg_message(conf, OPKG_DEBUG2,"Function: %s calling opkg_install_pkg \n",__FUNCTION__);
421 err = opkg_install_pkg(conf, dep,0);
422 /* mark this package as having been automatically installed to
423 * satisfy a dependancy */
424 dep->auto_installed = 1;
426 pkg_vec_free(depends);
432 pkg_vec_free(depends);
438 /* check all packages have their dependences satisfied, e.g., in case an upgraded package split */
439 int opkg_satisfy_all_dependences(opkg_conf_t *conf)
441 if (conf->nodeps == 0) {
443 pkg_vec_t *installed = pkg_vec_alloc();
444 pkg_hash_fetch_all_installed(&conf->pkg_hash, installed);
445 for (i = 0; i < installed->len; i++) {
446 pkg_t *pkg = installed->pkgs[i];
447 satisfy_dependencies_for(conf, pkg);
449 pkg_vec_free(installed);
456 static int check_conflicts_for(opkg_conf_t *conf, pkg_t *pkg)
459 pkg_vec_t *conflicts = NULL;
462 if (conf->force_depends) {
470 if (!conf->force_depends)
471 conflicts = (pkg_vec_t *)pkg_hash_fetch_conflicts(&conf->pkg_hash, pkg);
474 opkg_message(conf, level,
475 "%s: The following packages conflict with %s:\n\t", prefix, pkg->name);
477 while (i < conflicts->len)
478 opkg_message(conf, level, " %s", conflicts->pkgs[i++]->name);
479 opkg_message(conf, level, "\n");
480 pkg_vec_free(conflicts);
481 return OPKG_PKG_DEPS_UNSATISFIED;
486 static int update_file_ownership(opkg_conf_t *conf, pkg_t *new_pkg, pkg_t *old_pkg)
488 str_list_t *new_list = pkg_get_installed_files(new_pkg);
489 str_list_elt_t *iter;
491 for (iter = new_list->head; iter; iter = iter->next) {
492 char *new_file = iter->data;
493 pkg_t *owner = file_hash_get_file_owner(conf, new_file);
495 opkg_message(conf, OPKG_ERROR, "Null new_file for new_pkg=%s\n", new_pkg->name);
496 if (!owner || (owner == old_pkg))
497 file_hash_set_file_owner(conf, new_file, new_pkg);
500 str_list_t *old_list = pkg_get_installed_files(old_pkg);
501 for (iter = old_list->head; iter; iter = iter->next) {
502 char *old_file = iter->data;
503 pkg_t *owner = file_hash_get_file_owner(conf, old_file);
504 if (owner == old_pkg) {
506 hash_table_insert(&conf->obs_file_hash, old_file, old_pkg);
513 static int verify_pkg_installable(opkg_conf_t *conf, pkg_t *pkg)
515 /* XXX: FEATURE: Anything else needed here? Maybe a check on free space? */
517 /* sma 6.20.02: yup; here's the first bit */
519 * XXX: BUG easy for cworth
520 * 1) please point the call below to the correct current root destination
521 * 2) we need to resolve how to check the required space for a pending pkg,
522 * my diddling with the .ipk file size below isn't going to cut it.
523 * 3) return a proper error code instead of 1
525 int comp_size, blocks_available;
527 if (!conf->force_space && pkg->installed_size != NULL) {
528 blocks_available = get_available_blocks(conf->default_dest->root_dir);
530 comp_size = strtoul(pkg->installed_size, NULL, 0);
531 /* round up a blocks count without doing fancy-but-slow casting jazz */
532 comp_size = (int)((comp_size + 1023) / 1024);
534 if (comp_size >= blocks_available) {
535 opkg_message(conf, OPKG_ERROR,
536 "Only have %d available blocks on filesystem %s, pkg %s needs %d\n",
537 blocks_available, conf->default_dest->root_dir, pkg->name, comp_size);
544 static int unpack_pkg_control_files(opkg_conf_t *conf, pkg_t *pkg)
547 char *conffiles_file_name;
549 FILE *conffiles_file;
551 sprintf_alloc(&pkg->tmp_unpack_dir, "%s/%s-XXXXXX", conf->tmp_dir, pkg->name);
553 pkg->tmp_unpack_dir = mkdtemp(pkg->tmp_unpack_dir);
554 if (pkg->tmp_unpack_dir == NULL) {
555 opkg_message(conf, OPKG_ERROR,
556 "%s: Failed to create temporary directory '%s': %s\n",
557 __FUNCTION__, pkg->tmp_unpack_dir, strerror(errno));
561 err = pkg_extract_control_files_to_dir(pkg, pkg->tmp_unpack_dir);
566 /* XXX: CLEANUP: There might be a cleaner place to read in the
567 conffiles. Seems like I should be able to get everything to go
568 through pkg_init_from_file. If so, maybe it would make sense to
569 move all of unpack_pkg_control_files to that function. */
571 /* Don't need to re-read conffiles if we already have it */
572 if (pkg->conffiles.head) {
576 sprintf_alloc(&conffiles_file_name, "%s/conffiles", pkg->tmp_unpack_dir);
577 if (! file_exists(conffiles_file_name)) {
578 free(conffiles_file_name);
582 conffiles_file = fopen(conffiles_file_name, "r");
583 if (conffiles_file == NULL) {
584 fprintf(stderr, "%s: failed to open %s: %s\n",
585 __FUNCTION__, conffiles_file_name, strerror(errno));
586 free(conffiles_file_name);
589 free(conffiles_file_name);
593 char *cf_name_in_dest;
595 cf_name = file_read_line_alloc(conffiles_file);
596 if (cf_name == NULL) {
600 if (cf_name[0] == '\0') {
604 /* Prepend dest->root_dir to conffile name.
605 Take pains to avoid multiple slashes. */
606 root_dir = pkg->dest->root_dir;
607 if (conf->offline_root)
608 /* skip the offline_root prefix */
609 root_dir = pkg->dest->root_dir + strlen(conf->offline_root);
610 sprintf_alloc(&cf_name_in_dest, "%s%s", root_dir,
611 cf_name[0] == '/' ? (cf_name + 1) : cf_name);
613 /* Can't get an md5sum now, (file isn't extracted yet).
614 We'll wait until resolve_conffiles */
615 conffile_list_append(&pkg->conffiles, cf_name_in_dest, NULL);
618 free(cf_name_in_dest);
621 fclose(conffiles_file);
626 /* returns number of installed replacees */
627 int pkg_get_installed_replacees(opkg_conf_t *conf, pkg_t *pkg, pkg_vec_t *installed_replacees)
629 abstract_pkg_t **replaces = pkg->replaces;
630 int replaces_count = pkg->replaces_count;
632 for (i = 0; i < replaces_count; i++) {
633 abstract_pkg_t *ab_pkg = replaces[i];
634 pkg_vec_t *pkg_vec = ab_pkg->pkgs;
636 for (j = 0; j < pkg_vec->len; j++) {
637 pkg_t *replacee = pkg_vec->pkgs[j];
638 if (!pkg_conflicts(pkg, replacee))
640 if (replacee->state_status == SS_INSTALLED) {
641 pkg_vec_insert(installed_replacees, replacee);
646 return installed_replacees->len;
649 int pkg_remove_installed_replacees(opkg_conf_t *conf, pkg_vec_t *replacees)
652 int replaces_count = replacees->len;
653 for (i = 0; i < replaces_count; i++) {
654 pkg_t *replacee = replacees->pkgs[i];
656 replacee->state_flag |= SF_REPLACE; /* flag it so remove won't complain */
657 err = opkg_remove_pkg(conf, replacee,0);
664 /* to unwind the removal: make sure they are installed */
665 int pkg_remove_installed_replacees_unwind(opkg_conf_t *conf, pkg_vec_t *replacees)
668 int replaces_count = replacees->len;
669 for (i = 0; i < replaces_count; i++) {
670 pkg_t *replacee = replacees->pkgs[i];
671 if (replacee->state_status != SS_INSTALLED) {
672 opkg_message(conf, OPKG_DEBUG2,"Function: %s calling opkg_install_pkg \n",__FUNCTION__);
673 err = opkg_install_pkg(conf, replacee,0);
681 int caught_sigint = 0;
682 static void opkg_install_pkg_sigint_handler(int sig)
687 /* compares versions of pkg and old_pkg, returns 0 if OK to proceed with installation of pkg, 1 otherwise */
688 static int opkg_install_check_downgrade(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg, int message)
691 char message_out[15];
692 char *old_version = pkg_version_str_alloc(old_pkg);
693 char *new_version = pkg_version_str_alloc(pkg);
694 int cmp = pkg_compare_versions(old_pkg, pkg);
697 memset(message_out,'\x0',15);
698 strncpy (message_out,"Upgrading ",strlen("Upgrading "));
699 if ( (conf->force_downgrade==1) && (cmp > 0) ){ /* We've been asked to allow downgrade and version is precedent */
700 cmp = -1 ; /* then we force opkg to downgrade */
701 strncpy (message_out,"Downgrading ",strlen("Downgrading ")); /* We need to use a value < 0 because in the 0 case we are asking to */
702 /* reinstall, and some check could fail asking the "force-reinstall" option */
706 opkg_message(conf, OPKG_NOTICE,
707 "Not downgrading package %s on %s from %s to %s.\n",
708 old_pkg->name, old_pkg->dest->name, old_version, new_version);
710 } else if (cmp < 0) {
711 opkg_message(conf, OPKG_NOTICE,
712 "%s%s on %s from %s to %s...\n",
713 message_out, pkg->name, old_pkg->dest->name, old_version, new_version);
714 pkg->dest = old_pkg->dest;
716 } else /* cmp == 0 */ {
717 if (conf->force_reinstall) {
718 opkg_message(conf, OPKG_NOTICE,
719 "Reinstalling %s (%s) on %s...\n",
720 pkg->name, new_version, old_pkg->dest->name);
721 pkg->dest = old_pkg->dest;
724 opkg_message(conf, OPKG_NOTICE,
725 "Not installing %s (%s) on %s -- already installed.\n",
726 pkg->name, new_version, old_pkg->dest->name);
734 char message_out[15] ;
735 memset(message_out,'\x0',15);
737 strncpy( message_out,"Upgrading ",strlen("Upgrading ") );
739 strncpy( message_out,"Installing ",strlen("Installing ") );
740 char *version = pkg_version_str_alloc(pkg);
742 opkg_message(conf, OPKG_NOTICE,
743 "%s%s (%s) to %s...\n", message_out,
744 pkg->name, version, pkg->dest->name);
750 /* and now the meat... */
751 int opkg_install_pkg(opkg_conf_t *conf, pkg_t *pkg, int from_upgrade)
755 pkg_t *old_pkg = NULL;
756 pkg_vec_t *replacees;
757 abstract_pkg_t *ab_pkg = NULL;
763 message = 1; /* Coming from an upgrade, and should change the output message */
766 opkg_message(conf, OPKG_ERROR,
767 "INTERNAL ERROR: null pkg passed to opkg_install_pkg\n");
768 return OPKG_INSTALL_ERR_INTERNAL;
771 opkg_message(conf, OPKG_DEBUG2, "Function: %s calling pkg_arch_supported %s \n", __FUNCTION__, __FUNCTION__);
773 if (!pkg_arch_supported(conf, pkg)) {
774 opkg_message(conf, OPKG_ERROR, "INTERNAL ERROR: architecture %s for pkg %s is unsupported.\n",
775 pkg->architecture, pkg->name);
776 return OPKG_INSTALL_ERR_INTERNAL;
778 if (pkg->state_status == SS_INSTALLED && conf->force_reinstall == 0 && conf->nodeps == 0) {
779 err = satisfy_dependencies_for(conf, pkg);
780 if (err) { return OPKG_INSTALL_ERR_DEPENDENCIES; }
782 opkg_message(conf, OPKG_NOTICE,
783 "Package %s is already installed in %s.\n",
784 pkg->name, pkg->dest->name);
788 if (pkg->dest == NULL) {
789 pkg->dest = conf->default_dest;
792 old_pkg = pkg_hash_fetch_installed_by_name(&conf->pkg_hash, pkg->name);
794 err = opkg_install_check_downgrade(conf, pkg, old_pkg, message);
795 if (err) { return OPKG_INSTALL_ERR_NO_DOWNGRADE; }
797 pkg->state_want = SW_INSTALL;
799 old_pkg->state_want = SW_DEINSTALL; /* needed for check_data_file_clashes of dependences */
803 /* Abhaya: conflicts check */
804 err = check_conflicts_for(conf, pkg);
805 if (err) { return OPKG_INSTALL_ERR_CONFLICTS; }
807 /* this setup is to remove the upgrade scenario in the end when
808 installing pkg A, A deps B & B deps on A. So both B and A are
809 installed. Then A's installation is started resulting in an
810 uncecessary upgrade */
811 if (pkg->state_status == SS_INSTALLED
812 && conf->force_reinstall == 0) return 0;
814 err = verify_pkg_installable(conf, pkg);
815 if (err) { return OPKG_INSTALL_ERR_NO_SPACE; }
817 if (pkg->local_filename == NULL) {
818 err = opkg_download_pkg(conf, pkg, conf->tmp_dir);
820 opkg_message(conf, OPKG_ERROR,
821 "Failed to download %s. Perhaps you need to run 'opkg update'?\n",
823 return OPKG_INSTALL_ERR_DOWNLOAD;
827 /* check that the repository is valid */
829 char *list_file_name, *sig_file_name, *lists_dir;
831 sprintf_alloc (&lists_dir, "%s",
832 (conf->restrict_to_default_dest)
833 ? conf->default_dest->lists_dir
835 sprintf_alloc (&list_file_name, "%s/%s", lists_dir, pkg->src->name);
836 sprintf_alloc (&sig_file_name, "%s/%s.sig", lists_dir, pkg->src->name);
838 if (file_exists (sig_file_name))
840 if (opkg_verify_file (conf, list_file_name, sig_file_name))
841 return OPKG_INSTALL_ERR_SIGNATURE;
845 free (list_file_name);
846 free (sig_file_name);
849 /* Check for md5 values */
852 file_md5 = file_md5sum_alloc(pkg->local_filename);
853 if (strcmp(file_md5, pkg->md5sum))
855 opkg_message(conf, OPKG_ERROR,
856 "Package %s md5sum mismatch. Either the opkg or the package index are corrupt. Try 'opkg update'.\n",
859 return OPKG_INSTALL_ERR_MD5;
864 if (pkg->tmp_unpack_dir == NULL) {
865 unpack_pkg_control_files(conf, pkg);
868 /* We should update the filelist here, so that upgrades of packages that split will not fail. -Jamey 27-MAR-03 */
869 /* Pigi: check if it will pass from here when replacing. It seems to fail */
870 /* That's rather strange that files don't change owner. Investigate !!!!!!*/
871 err = update_file_ownership(conf, pkg, old_pkg);
872 if (err) { return OPKG_ERR_UNKNOWN; }
874 if (conf->nodeps == 0) {
875 err = satisfy_dependencies_for(conf, pkg);
876 if (err) { return OPKG_INSTALL_ERR_DEPENDENCIES; }
879 replacees = pkg_vec_alloc();
880 pkg_get_installed_replacees(conf, pkg, replacees);
882 sprintf_alloc (&pkgid, "%s;%s;%s;", pkg->name, pkg->version, pkg->architecture);
883 opkg_set_current_state (conf, OPKG_STATE_INSTALLING_PKG, pkgid);
886 /* this next section we do with SIGINT blocked to prevent inconsistency between opkg database and filesystem */
888 sigset_t newset, oldset;
889 sighandler_t old_handler = NULL;
893 old_handler = signal(SIGINT, opkg_install_pkg_sigint_handler);
895 sigemptyset(&newset);
896 sigaddset(&newset, SIGINT);
897 sigprocmask(SIG_BLOCK, &newset, &oldset);
900 opkg_state_changed++;
901 pkg->state_flag |= SF_FILELIST_CHANGED;
903 /* XXX: BUG: we really should treat replacement more like an upgrade
904 * Instead, we're going to remove the replacees
906 err = pkg_remove_installed_replacees(conf, replacees);
907 if (err) goto UNWIND_REMOVE_INSTALLED_REPLACEES;
909 err = prerm_upgrade_old_pkg(conf, pkg, old_pkg);
910 if (err) goto UNWIND_PRERM_UPGRADE_OLD_PKG;
912 err = prerm_deconfigure_conflictors(conf, pkg, replacees);
913 if (err) goto UNWIND_PRERM_DECONFIGURE_CONFLICTORS;
915 err = preinst_configure(conf, pkg, old_pkg);
916 if (err) goto UNWIND_PREINST_CONFIGURE;
918 err = backup_modified_conffiles(conf, pkg, old_pkg);
919 if (err) goto UNWIND_BACKUP_MODIFIED_CONFFILES;
921 err = check_data_file_clashes(conf, pkg, old_pkg);
922 if (err) goto UNWIND_CHECK_DATA_FILE_CLASHES;
924 err = postrm_upgrade_old_pkg(conf, pkg, old_pkg);
925 if (err) goto UNWIND_POSTRM_UPGRADE_OLD_PKG;
927 if (conf->noaction) return 0;
929 /* point of no return: no unwinding after this */
930 if (old_pkg && !conf->force_reinstall) {
931 old_pkg->state_want = SW_DEINSTALL;
933 if (old_pkg->state_flag & SF_NOPRUNE) {
934 opkg_message(conf, OPKG_INFO,
935 " not removing obsolesced files because package marked noprune\n");
937 opkg_message(conf, OPKG_INFO,
938 " removing obsolesced files\n");
939 remove_obsolesced_files(conf, pkg, old_pkg);
941 /* removing files from old package, to avoid ghost files */
942 remove_data_files_and_list(conf, old_pkg);
943 /* Pigi : It should be better to remove also maintainer and postrem scripts here, just in case*/
944 remove_maintainer_scripts_except_postrm(conf, old_pkg);
945 remove_postrm(conf, old_pkg);
951 opkg_message(conf, OPKG_INFO,
952 " installing maintainer scripts\n");
953 install_maintainer_scripts(conf, pkg, old_pkg);
955 /* the following just returns 0 */
956 remove_disappeared(conf, pkg);
958 opkg_message(conf, OPKG_INFO,
959 " installing data files\n");
960 install_data_files(conf, pkg);
962 /* read comments from function for detail but I will execute this here as all other tests are ok.*/
963 err = check_data_file_clashes_change(conf, pkg, old_pkg);
965 opkg_message(conf, OPKG_INFO,
966 " resolving conf files\n");
967 resolve_conffiles(conf, pkg);
969 pkg->state_status = SS_UNPACKED;
970 old_state_flag = pkg->state_flag;
971 pkg->state_flag &= ~SF_PREFER;
972 opkg_message(conf, OPKG_DEBUG, " pkg=%s old_state_flag=%x state_flag=%x\n", pkg->name, old_state_flag, pkg->state_flag);
974 if (old_pkg && !conf->force_reinstall) {
975 old_pkg->state_status = SS_NOT_INSTALLED;
978 time(&pkg->installed_time);
980 opkg_message(conf, OPKG_INFO,
981 " cleanup temp files\n");
982 cleanup_temporary_files(conf, pkg);
984 ab_pkg = pkg->parent;
986 ab_pkg->state_status = pkg->state_status;
988 opkg_message(conf, OPKG_INFO, "Done.\n");
991 signal(SIGINT, old_handler);
993 sigprocmask(SIG_UNBLOCK, &newset, &oldset);
994 pkg_vec_free (replacees);
998 UNWIND_POSTRM_UPGRADE_OLD_PKG:
999 postrm_upgrade_old_pkg_unwind(conf, pkg, old_pkg);
1000 UNWIND_CHECK_DATA_FILE_CLASHES:
1001 check_data_file_clashes_unwind(conf, pkg, old_pkg);
1002 UNWIND_BACKUP_MODIFIED_CONFFILES:
1003 backup_modified_conffiles_unwind(conf, pkg, old_pkg);
1004 UNWIND_PREINST_CONFIGURE:
1005 preinst_configure_unwind(conf, pkg, old_pkg);
1006 UNWIND_PRERM_DECONFIGURE_CONFLICTORS:
1007 prerm_deconfigure_conflictors_unwind(conf, pkg, replacees);
1008 UNWIND_PRERM_UPGRADE_OLD_PKG:
1009 prerm_upgrade_old_pkg_unwind(conf, pkg, old_pkg);
1010 UNWIND_REMOVE_INSTALLED_REPLACEES:
1011 pkg_remove_installed_replacees_unwind(conf, replacees);
1013 opkg_message(conf, OPKG_INFO,
1014 " cleanup temp files\n");
1015 cleanup_temporary_files(conf, pkg);
1017 opkg_message(conf, OPKG_INFO,
1020 signal(SIGINT, old_handler);
1022 sigprocmask(SIG_UNBLOCK, &newset, &oldset);
1024 pkg_vec_free (replacees);
1025 return OPKG_ERR_UNKNOWN;
1027 opkg_set_current_state (conf, OPKG_STATE_NONE, NULL);
1030 static int prerm_upgrade_old_pkg(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg)
1032 /* DPKG_INCOMPATIBILITY:
1033 dpkg does some things here that we don't do yet. Do we care?
1035 1. If a version of the package is already installed, call
1036 old-prerm upgrade new-version
1037 2. If the script runs but exits with a non-zero exit status
1038 new-prerm failed-upgrade old-version
1039 Error unwind, for both the above cases:
1040 old-postinst abort-upgrade new-version
1045 static int prerm_upgrade_old_pkg_unwind(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg)
1047 /* DPKG_INCOMPATIBILITY:
1048 dpkg does some things here that we don't do yet. Do we care?
1049 (See prerm_upgrade_old_package for details)
1054 static int prerm_deconfigure_conflictors(opkg_conf_t *conf, pkg_t *pkg, pkg_vec_t *conflictors)
1056 /* DPKG_INCOMPATIBILITY:
1057 dpkg does some things here that we don't do yet. Do we care?
1058 2. If a 'conflicting' package is being removed at the same time:
1059 1. If any packages depended on that conflicting package and
1060 --auto-deconfigure is specified, call, for each such package:
1061 deconfigured's-prerm deconfigure \
1062 in-favour package-being-installed version \
1063 removing conflicting-package version
1065 deconfigured's-postinst abort-deconfigure \
1066 in-favour package-being-installed-but-failed version \
1067 removing conflicting-package version
1069 The deconfigured packages are marked as requiring
1070 configuration, so that if --install is used they will be
1071 configured again if possible.
1072 2. To prepare for removal of the conflicting package, call:
1073 conflictor's-prerm remove in-favour package new-version
1075 conflictor's-postinst abort-remove in-favour package new-version
1080 static int prerm_deconfigure_conflictors_unwind(opkg_conf_t *conf, pkg_t *pkg, pkg_vec_t *conflictors)
1082 /* DPKG_INCOMPATIBILITY: dpkg does some things here that we don't
1083 do yet. Do we care? (See prerm_deconfigure_conflictors for
1088 static int preinst_configure(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg)
1094 char *old_version = pkg_version_str_alloc(old_pkg);
1095 sprintf_alloc(&preinst_args, "upgrade %s", old_version);
1097 } else if (pkg->state_status == SS_CONFIG_FILES) {
1098 char *pkg_version = pkg_version_str_alloc(pkg);
1099 sprintf_alloc(&preinst_args, "install %s", pkg_version);
1102 preinst_args = strdup("install");
1105 err = pkg_run_script(conf, pkg, "preinst", preinst_args);
1107 opkg_message(conf, OPKG_ERROR,
1108 "Aborting installation of %s\n", pkg->name);
1117 static int preinst_configure_unwind(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg)
1119 /* DPKG_INCOMPATIBILITY:
1120 dpkg does the following error unwind, should we?
1121 pkg->postrm abort-upgrade old-version
1122 OR pkg->postrm abort-install old-version
1123 OR pkg->postrm abort-install
1128 static int backup_modified_conffiles(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg)
1131 conffile_list_elt_t *iter;
1134 if (conf->noaction) return 0;
1136 /* Backup all modified conffiles */
1138 for (iter = old_pkg->conffiles.head; iter; iter = iter->next) {
1142 cf_name = root_filename_alloc(conf, cf->name);
1144 /* Don't worry if the conffile is just plain gone */
1145 if (file_exists(cf_name) && conffile_has_been_modified(conf, cf)) {
1146 err = backup_make_backup(conf, cf_name);
1155 /* Backup all conffiles that were not conffiles in old_pkg */
1156 for (iter = pkg->conffiles.head; iter; iter = iter->next) {
1159 cf_name = root_filename_alloc(conf, cf->name);
1160 /* Ignore if this was a conffile in old_pkg as well */
1161 if (pkg_get_conffile(old_pkg, cf->name)) {
1165 if (file_exists(cf_name) && (! backup_exists_for(cf_name))) {
1166 err = backup_make_backup(conf, cf_name);
1177 static int backup_modified_conffiles_unwind(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg)
1179 conffile_list_elt_t *iter;
1182 for (iter = old_pkg->conffiles.head; iter; iter = iter->next) {
1183 backup_remove(iter->data->name);
1187 for (iter = pkg->conffiles.head; iter; iter = iter->next) {
1188 backup_remove(iter->data->name);
1195 static int check_data_file_clashes(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg)
1197 /* DPKG_INCOMPATIBILITY:
1198 opkg takes a slightly different approach than dpkg at this
1199 point. dpkg installs each file in the new package while
1200 creating a backup for any file that is replaced, (so that it
1201 can unwind if necessary). To avoid complexity and redundant
1202 storage, opkg doesn't do any installation until later, (at the
1203 point at which dpkg removes the backups.
1205 But, we do have to check for data file clashes, since after
1206 installing a package with a file clash, removing either of the
1207 packages involved in the clash has the potential to break the
1210 str_list_t *files_list;
1211 str_list_elt_t *iter;
1215 files_list = pkg_get_installed_files(pkg);
1216 for (iter = files_list->head; iter; iter = iter->next) {
1217 char *root_filename;
1218 char *filename = iter->data;
1219 root_filename = root_filename_alloc(conf, filename);
1220 if (file_exists(root_filename) && (! file_is_dir(root_filename))) {
1223 /* Pre-existing conffiles are OK */
1224 /* @@@@ should have way to check that it is a conffile -Jamey */
1225 if (backup_exists_for(root_filename)) {
1229 /* Pre-existing files are OK if force-overwrite was asserted. */
1230 if (conf->force_overwrite) {
1231 /* but we need to change who owns this file */
1232 file_hash_set_file_owner(conf, filename, pkg);
1236 owner = file_hash_get_file_owner(conf, filename);
1238 /* Pre-existing files are OK if owned by the pkg being upgraded. */
1239 if (owner && old_pkg) {
1240 if (strcmp(owner->name, old_pkg->name) == 0) {
1245 /* Pre-existing files are OK if owned by a package replaced by new pkg. */
1247 opkg_message(conf, OPKG_DEBUG2, "Checking for replaces for %s in package %s\n", filename, owner->name);
1248 if (pkg_replaces(pkg, owner)) {
1251 /* If the file that would be installed is owned by the same package, ( as per a reinstall or similar )
1252 then it's ok to overwrite. */
1253 if (strcmp(owner->name,pkg->name)==0){
1254 opkg_message(conf, OPKG_INFO, "Replacing pre-existing file %s owned by package %s\n", filename, owner->name);
1259 /* Pre-existing files are OK if they are obsolete */
1260 obs = hash_table_get(&conf->obs_file_hash, filename);
1262 opkg_message(conf, OPKG_INFO, "Pre-exiting file %s is obsolete. obs_pkg=%s\n", filename, obs->name);
1266 /* We have found a clash. */
1267 opkg_message(conf, OPKG_ERROR,
1268 "Package %s wants to install file %s\n"
1269 "\tBut that file is already provided by package ",
1270 pkg->name, filename);
1272 opkg_message(conf, OPKG_ERROR,
1273 "%s\n", owner->name);
1275 opkg_message(conf, OPKG_ERROR,
1276 "<no package>\nPlease move this file out of the way and try again.\n");
1280 free(root_filename);
1282 pkg_free_installed_files(pkg);
1287 static int check_data_file_clashes_change(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg)
1289 /* Basically that's the worst hack I could do to be able to change ownership of
1290 file list, but, being that we have no way to unwind the mods, due to structure
1291 of hash table, probably is the quickest hack too, whishing it would not slow-up thing too much.
1292 What we do here is change the ownership of file in hash if a replace ( or similar events
1294 Only the action that are needed to change name should be considered.
1295 @@@ To change after 1.0 release.
1297 str_list_t *files_list;
1298 str_list_elt_t *iter;
1302 files_list = pkg_get_installed_files(pkg);
1303 for (iter = files_list->head; iter; iter = iter->next) {
1304 char *root_filename;
1305 char *filename = iter->data;
1306 root_filename = root_filename_alloc(conf, filename);
1307 if (file_exists(root_filename) && (! file_is_dir(root_filename))) {
1310 if (conf->force_overwrite) {
1311 /* but we need to change who owns this file */
1312 file_hash_set_file_owner(conf, filename, pkg);
1316 owner = file_hash_get_file_owner(conf, filename);
1318 /* Pre-existing files are OK if owned by a package replaced by new pkg. */
1320 if (pkg_replaces(pkg, owner)) {
1321 /* It's now time to change the owner of that file.
1322 It has been "replaced" from the new "Replaces", then I need to inform lists file about that. */
1323 opkg_message(conf, OPKG_INFO, "Replacing pre-existing file %s owned by package %s\n", filename, owner->name);
1324 file_hash_set_file_owner(conf, filename, pkg);
1330 free(root_filename);
1332 pkg_free_installed_files(pkg);
1337 static int check_data_file_clashes_unwind(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg)
1339 /* Nothing to do since check_data_file_clashes doesn't change state */
1343 static int postrm_upgrade_old_pkg(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg)
1345 /* DPKG_INCOMPATIBILITY: dpkg does the following here, should we?
1346 1. If the package is being upgraded, call
1347 old-postrm upgrade new-version
1348 2. If this fails, attempt:
1349 new-postrm failed-upgrade old-version
1350 Error unwind, for both cases:
1351 old-preinst abort-upgrade new-version */
1355 static int postrm_upgrade_old_pkg_unwind(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg)
1357 /* DPKG_INCOMPATIBILITY:
1358 dpkg does some things here that we don't do yet. Do we care?
1359 (See postrm_upgrade_old_pkg for details)
1364 static int remove_obsolesced_files(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg)
1367 str_list_t *old_files;
1369 str_list_t *new_files;
1372 if (old_pkg == NULL) {
1376 old_files = pkg_get_installed_files(old_pkg);
1377 new_files = pkg_get_installed_files(pkg);
1379 for (of = old_files->head; of; of = of->next) {
1383 for (nf = new_files->head; nf; nf = nf->next) {
1385 if (strcmp(old, new) == 0) {
1389 if (file_is_dir(old)) {
1392 owner = file_hash_get_file_owner(conf, old);
1393 if (owner != old_pkg) {
1394 /* in case obsolete file no longer belongs to old_pkg */
1398 /* old file is obsolete */
1399 opkg_message(conf, OPKG_INFO,
1400 " removing obsolete file %s\n", old);
1401 if (!conf->noaction) {
1404 opkg_message(conf, OPKG_ERROR, " Warning: remove %s failed: %s\n", old,
1413 pkg_free_installed_files(old_pkg);
1414 pkg_free_installed_files(pkg);
1419 static int remove_obsolete_maintainer_scripts(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg)
1427 opkg_message(conf, OPKG_ERROR, "%s: no dest for package %s\n", __FUNCTION__, pkg->name);
1430 sprintf_alloc(&globpattern, "%s/%s.*", pkg->dest->info_dir, pkg->name);
1431 err = glob(globpattern, 0, NULL, &globbuf);
1436 /* XXXX this should perhaps only remove the ones that are not overwritten in new package. Jamey 11/11/2003 */
1437 for (i = 0; i < globbuf.gl_pathc; i++) {
1438 opkg_message(conf, OPKG_DEBUG, "Removing control file %s from old_pkg %s\n",
1439 globbuf.gl_pathv[i], old_pkg->name);
1440 if (!conf->noaction)
1441 unlink(globbuf.gl_pathv[i]);
1448 static int install_maintainer_scripts(opkg_conf_t *conf, pkg_t *pkg, pkg_t *old_pkg)
1454 remove_obsolete_maintainer_scripts(conf, pkg, old_pkg);
1455 sprintf_alloc(&prefix, "%s.", pkg->name);
1456 ret = pkg_extract_control_files_to_dir_with_prefix(pkg,
1457 pkg->dest->info_dir,
1463 static int remove_disappeared(opkg_conf_t *conf, pkg_t *pkg)
1465 /* DPKG_INCOMPATIBILITY:
1466 This is a fairly sophisticated dpkg operation. Shall we
1469 /* Any packages all of whose files have been overwritten during the
1470 installation, and which aren't required for dependencies, are
1471 considered to have been removed. For each such package
1472 1. disappearer's-postrm disappear overwriter overwriter-version
1473 2. The package's maintainer scripts are removed
1474 3. It is noted in the status database as being in a sane state,
1475 namely not installed (any conffiles it may have are ignored,
1476 rather than being removed by dpkg). Note that disappearing
1477 packages do not have their prerm called, because dpkg doesn't
1478 know in advance that the package is going to vanish.
1483 static int install_data_files(opkg_conf_t *conf, pkg_t *pkg)
1487 /* opkg takes a slightly different approach to data file backups
1488 than dpkg. Rather than removing backups at this point, we
1489 actually do the data file installation now. See comments in
1490 check_data_file_clashes() for more details. */
1492 opkg_message(conf, OPKG_INFO,
1493 " extracting data files to %s\n", pkg->dest->root_dir);
1494 err = pkg_extract_data_files_to_dir(pkg, pkg->dest->root_dir);
1499 /* XXX: BUG or FEATURE : We are actually loosing the Essential flag,
1500 so we can't save ourself from removing important packages
1501 At this point we (should) have extracted the .control file, so it
1502 would be a good idea to reload the data in it, and set the Essential
1503 state in *pkg. From now on the Essential is back in status file and
1504 we can protect again.
1505 We should operate this way:
1506 fopen the file ( pkg->dest->root_dir/pkg->name.control )
1507 check for "Essential" in it
1508 set the value in pkg->essential.
1509 This new routine could be useful also for every other flag
1511 set_flags_from_control(conf, pkg) ;
1513 opkg_message(conf, OPKG_DEBUG, " Calling pkg_write_filelist from %s\n", __FUNCTION__);
1514 err = pkg_write_filelist(conf, pkg);
1518 /* XXX: FEATURE: opkg should identify any files which existed
1519 before installation and which were overwritten, (see
1520 check_data_file_clashes()). What it must do is remove any such
1521 files from the filelist of the old package which provided the
1522 file. Otherwise, if the old package were removed at some point
1523 it would break the new package. Removing the new package will
1524 also break the old one, but this cannot be helped since the old
1525 package's file has already been deleted. This is the importance
1526 of check_data_file_clashes(), and only allowing opkg to install
1527 a clashing package with a user force. */
1532 static int resolve_conffiles(opkg_conf_t *conf, pkg_t *pkg)
1534 conffile_list_elt_t *iter;
1541 if (conf->noaction) return 0;
1543 for (iter = pkg->conffiles.head; iter; iter = iter->next) {
1544 char *root_filename;
1546 root_filename = root_filename_alloc(conf, cf->name);
1548 /* Might need to initialize the md5sum for each conffile */
1549 if (cf->value == NULL) {
1550 cf->value = file_md5sum_alloc(root_filename);
1553 if (!file_exists(root_filename)) {
1554 free(root_filename);
1558 cf_backup = backup_filename_alloc(root_filename);
1561 if (file_exists(cf_backup)) {
1562 /* Let's compute md5 to test if files are changed */
1563 md5sum = file_md5sum_alloc(cf_backup);
1564 if (strcmp( cf->value,md5sum) != 0 ) {
1565 if (conf->force_defaults
1566 || user_prefers_old_conffile(cf->name, cf_backup) ) {
1567 rename(cf_backup, root_filename);
1575 free(root_filename);
1581 static int user_prefers_old_conffile(const char *file_name, const char *backup)
1584 const char *short_file_name;
1586 short_file_name = strrchr(file_name, '/');
1587 if (short_file_name) {
1590 short_file_name = file_name;
1594 response = get_user_response(" Configuration file '%s'\n"
1595 " ==> File on system created by you or by a script.\n"
1596 " ==> File also in package provided by package maintainer.\n"
1597 " What would you like to do about it ? Your options are:\n"
1598 " Y or I : install the package maintainer's version\n"
1599 " N or O : keep your currently-installed version\n"
1600 " D : show the differences between the versions (if diff is installed)\n"
1601 " The default action is to keep your current version.\n"
1602 " *** %s (Y/I/N/O/D) [default=N] ? ", file_name, short_file_name);
1603 if (strcmp(response, "y") == 0
1604 || strcmp(response, "i") == 0
1605 || strcmp(response, "yes") == 0) {
1610 if (strcmp(response, "d") == 0) {
1614 /* XXX: BUG rewrite to use exec or busybox's internal diff */
1615 sprintf_alloc(&cmd, "diff -u %s %s", backup, file_name);
1618 printf(" [Press ENTER to continue]\n");
1619 response = file_read_line_alloc(stdin);
1629 /* XXX: CLEANUP: I'd like to move all of the code for
1630 creating/cleaning pkg->tmp_unpack_dir directly into pkg.c. (Then,
1631 it would make sense to cleanup pkg->tmp_unpack_dir directly from
1632 pkg_deinit for example). */
1633 static int cleanup_temporary_files(opkg_conf_t *conf, pkg_t *pkg)
1636 struct dirent *dirent;
1639 #ifdef OPKG_DEBUG_NO_TMP_CLEANUP
1641 opkg_message(conf, OPKG_DEBUG,
1642 "%s: Not cleaning up %s since opkg compiled with OPKG_DEBUG_NO_TMP_CLEANUP\n",
1643 __FUNCTION__, pkg->tmp_unpack_dir);
1647 if (pkg->tmp_unpack_dir && file_is_dir(pkg->tmp_unpack_dir)) {
1648 tmp_dir = opendir(pkg->tmp_unpack_dir);
1651 dirent = readdir(tmp_dir);
1652 if (dirent == NULL) {
1655 sprintf_alloc(&tmp_file, "%s/%s",
1656 pkg->tmp_unpack_dir, dirent->d_name);
1657 if (! file_is_dir(tmp_file)) {
1663 rmdir(pkg->tmp_unpack_dir);
1664 free(pkg->tmp_unpack_dir);
1665 pkg->tmp_unpack_dir = NULL;
1669 opkg_message(conf, OPKG_INFO, "cleanup_temporary_files: pkg=%s local_filename=%s tmp_dir=%s\n",
1670 pkg->name, pkg->local_filename, conf->tmp_dir);
1671 if (pkg->local_filename && strncmp(pkg->local_filename, conf->tmp_dir, strlen(conf->tmp_dir)) == 0) {
1672 unlink(pkg->local_filename);
1673 free(pkg->local_filename);
1674 pkg->local_filename = NULL;
1680 static char *backup_filename_alloc(const char *file_name)
1684 sprintf_alloc(&backup, "%s%s", file_name, OPKG_BACKUP_SUFFIX);
1689 int backup_make_backup(opkg_conf_t *conf, const char *file_name)
1694 backup = backup_filename_alloc(file_name);
1695 err = file_copy(file_name, backup);
1697 opkg_message(conf, OPKG_ERROR,
1698 "%s: Failed to copy %s to %s\n",
1699 __FUNCTION__, file_name, backup);
1707 static int backup_exists_for(const char *file_name)
1712 backup = backup_filename_alloc(file_name);
1714 ret = file_exists(backup);
1721 static int backup_remove(const char *file_name)
1725 backup = backup_filename_alloc(file_name);