2009-11-28 10:13:21 +05:30
|
|
|
/*-
|
2013-03-09 18:00:56 +05:30
|
|
|
* Copyright (c) 2009-2013 Juan Romero Pardines.
|
2009-11-28 10:13:21 +05:30
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <errno.h>
|
2010-05-18 11:16:27 +05:30
|
|
|
#include <unistd.h>
|
2009-11-28 10:13:21 +05:30
|
|
|
|
2010-11-13 07:48:58 +05:30
|
|
|
#include "xbps_api_impl.h"
|
2009-11-28 10:13:21 +05:30
|
|
|
|
2013-03-09 18:00:56 +05:30
|
|
|
static prop_array_t
|
|
|
|
merge_filelist(prop_dictionary_t d)
|
|
|
|
{
|
|
|
|
prop_array_t a, result;
|
|
|
|
prop_dictionary_t filed;
|
|
|
|
size_t i;
|
|
|
|
|
|
|
|
result = prop_array_create();
|
|
|
|
assert(result);
|
|
|
|
|
|
|
|
if ((a = prop_dictionary_get(d, "files"))) {
|
|
|
|
for (i = 0; i < prop_array_count(a); i++) {
|
|
|
|
filed = prop_array_get(a, i);
|
|
|
|
prop_array_add(result, filed);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ((a = prop_dictionary_get(d, "links"))) {
|
|
|
|
for (i = 0; i < prop_array_count(a); i++) {
|
|
|
|
filed = prop_array_get(a, i);
|
|
|
|
prop_array_add(result, filed);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ((a = prop_dictionary_get(d, "conf_files"))) {
|
|
|
|
for (i = 0; i < prop_array_count(a); i++) {
|
|
|
|
filed = prop_array_get(a, i);
|
|
|
|
prop_array_add(result, filed);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ((a = prop_dictionary_get(d, "dirs"))) {
|
|
|
|
for (i = 0; i < prop_array_count(a); i++) {
|
|
|
|
filed = prop_array_get(a, i);
|
|
|
|
prop_array_add(result, filed);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2012-10-24 11:15:00 +05:30
|
|
|
prop_array_t
|
|
|
|
xbps_find_pkg_obsoletes(struct xbps_handle *xhp,
|
|
|
|
prop_dictionary_t instd,
|
|
|
|
prop_dictionary_t newd)
|
2009-11-28 10:13:21 +05:30
|
|
|
{
|
2013-03-09 18:00:56 +05:30
|
|
|
prop_array_t instfiles, newfiles, obsoletes;
|
2010-11-19 18:10:13 +05:30
|
|
|
prop_object_t obj, obj2;
|
|
|
|
prop_string_t oldstr, newstr;
|
2012-10-24 11:15:00 +05:30
|
|
|
size_t i, x;
|
2012-07-14 15:41:55 +05:30
|
|
|
const char *oldhash;
|
2010-11-19 18:10:13 +05:30
|
|
|
char *file;
|
2011-02-21 22:12:47 +05:30
|
|
|
int rv = 0;
|
2013-03-09 18:00:56 +05:30
|
|
|
bool found;
|
2012-10-24 11:15:00 +05:30
|
|
|
|
|
|
|
assert(prop_object_type(instd) == PROP_TYPE_DICTIONARY);
|
2011-10-19 20:23:38 +05:30
|
|
|
assert(prop_object_type(newd) == PROP_TYPE_DICTIONARY);
|
2011-01-25 08:44:33 +05:30
|
|
|
|
2012-10-24 11:15:00 +05:30
|
|
|
obsoletes = prop_array_create();
|
|
|
|
assert(obsoletes);
|
|
|
|
|
2013-03-09 18:00:56 +05:30
|
|
|
instfiles = merge_filelist(instd);
|
|
|
|
if (prop_array_count(instfiles) == 0) {
|
|
|
|
/* nothing to check if current pkg does not own any file */
|
|
|
|
prop_object_release(instfiles);
|
|
|
|
return obsoletes;
|
|
|
|
}
|
|
|
|
newfiles = merge_filelist(newd);
|
2012-09-30 12:27:57 +05:30
|
|
|
|
2009-11-28 10:13:21 +05:30
|
|
|
/*
|
2012-10-24 11:15:00 +05:30
|
|
|
* Iterate over files list from installed package.
|
2009-11-28 10:13:21 +05:30
|
|
|
*/
|
2013-03-09 18:00:56 +05:30
|
|
|
for (i = 0; i < prop_array_count(instfiles); i++) {
|
2009-11-28 10:13:21 +05:30
|
|
|
found = false;
|
2013-03-09 18:00:56 +05:30
|
|
|
obj = prop_array_get(instfiles, i);
|
2013-03-14 02:38:13 +05:30
|
|
|
if (prop_object_type(obj) != PROP_TYPE_DICTIONARY) {
|
|
|
|
/* ignore unexistent files */
|
|
|
|
continue;
|
|
|
|
}
|
2009-11-28 10:13:21 +05:30
|
|
|
oldstr = prop_dictionary_get(obj, "file");
|
2012-11-30 11:41:51 +05:30
|
|
|
if (oldstr == NULL)
|
|
|
|
continue;
|
2012-10-24 11:15:00 +05:30
|
|
|
|
2010-05-18 11:16:27 +05:30
|
|
|
file = xbps_xasprintf(".%s",
|
|
|
|
prop_string_cstring_nocopy(oldstr));
|
2012-10-24 11:15:00 +05:30
|
|
|
|
2013-03-09 18:00:56 +05:30
|
|
|
oldhash = NULL;
|
|
|
|
prop_dictionary_get_cstring_nocopy(obj,
|
|
|
|
"sha256", &oldhash);
|
|
|
|
if (oldhash) {
|
2011-06-01 13:07:32 +05:30
|
|
|
rv = xbps_file_hash_check(file, oldhash);
|
2010-05-18 11:16:27 +05:30
|
|
|
if (rv == ENOENT || rv == ERANGE) {
|
|
|
|
/*
|
|
|
|
* Skip unexistent and files that do not
|
|
|
|
* match the hash.
|
|
|
|
*/
|
|
|
|
free(file);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
}
|
2013-03-09 18:00:56 +05:30
|
|
|
/*
|
|
|
|
* Check if current file is available in new pkg filelist.
|
|
|
|
*/
|
|
|
|
for (x = 0; x < prop_array_count(newfiles); x++) {
|
|
|
|
obj2 = prop_array_get(newfiles, x);
|
|
|
|
newstr = prop_dictionary_get(obj2, "file");
|
|
|
|
assert(newstr);
|
|
|
|
/*
|
|
|
|
* Skip files with same path.
|
|
|
|
*/
|
|
|
|
if (prop_string_equals(oldstr, newstr)) {
|
|
|
|
found = true;
|
|
|
|
break;
|
2009-11-28 10:13:21 +05:30
|
|
|
}
|
|
|
|
}
|
2010-05-18 11:16:27 +05:30
|
|
|
if (found) {
|
|
|
|
free(file);
|
2009-11-28 10:13:21 +05:30
|
|
|
continue;
|
2010-05-18 11:16:27 +05:30
|
|
|
}
|
2012-07-11 02:52:25 +05:30
|
|
|
/*
|
2012-10-24 11:15:00 +05:30
|
|
|
* Do not add required symlinks for the
|
2012-07-11 02:52:25 +05:30
|
|
|
* system transition to /usr.
|
|
|
|
*/
|
|
|
|
if ((strcmp(file, "./bin") == 0) ||
|
2012-07-14 15:41:55 +05:30
|
|
|
(strcmp(file, "./bin/") == 0) ||
|
2012-07-11 02:52:25 +05:30
|
|
|
(strcmp(file, "./sbin") == 0) ||
|
2012-07-14 15:41:55 +05:30
|
|
|
(strcmp(file, "./sbin/") == 0) ||
|
2012-07-11 02:52:25 +05:30
|
|
|
(strcmp(file, "./lib") == 0) ||
|
2012-07-14 15:41:55 +05:30
|
|
|
(strcmp(file, "./lib/") == 0) ||
|
|
|
|
(strcmp(file, "./lib64/") == 0) ||
|
2012-07-11 02:52:25 +05:30
|
|
|
(strcmp(file, "./lib64") == 0)) {
|
|
|
|
free(file);
|
|
|
|
continue;
|
|
|
|
}
|
2009-11-28 10:13:21 +05:30
|
|
|
/*
|
2012-10-24 11:15:00 +05:30
|
|
|
* Obsolete found, add onto the array.
|
2009-11-28 10:13:21 +05:30
|
|
|
*/
|
2013-03-09 18:00:56 +05:30
|
|
|
xbps_dbg_printf(xhp, "found obsolete: %s\n", file);
|
2012-10-24 11:15:00 +05:30
|
|
|
prop_array_add_cstring(obsoletes, file);
|
2010-12-25 07:07:25 +05:30
|
|
|
free(file);
|
2009-11-28 10:13:21 +05:30
|
|
|
}
|
2013-03-09 18:00:56 +05:30
|
|
|
prop_object_release(instfiles);
|
|
|
|
prop_object_release(newfiles);
|
2009-11-28 10:13:21 +05:30
|
|
|
|
2012-10-24 11:15:00 +05:30
|
|
|
return obsoletes;
|
2010-05-18 11:16:27 +05:30
|
|
|
}
|