mirror of
https://github.com/moparisthebest/pacman
synced 2025-01-11 05:48:09 -05:00
_alpm_filelist_resolve: use original filenames where possible
If a filename isn't resolved, the original can be used instead of strdup()ing it. Signed-off-by: Andrew Gregory <andrew.gregory.8@gmail.com> Signed-off-by: Allan McRae <allan@archlinux.org>
This commit is contained in:
parent
80bc89c147
commit
28d404f16a
lib/libalpm
@ -57,13 +57,13 @@ size_t _alpm_filelist_resolve_link(
|
|||||||
causal_dir = files->files[i].name;
|
causal_dir = files->files[i].name;
|
||||||
causal_dir_len = strlen(causal_dir);
|
causal_dir_len = strlen(causal_dir);
|
||||||
if(realpath(path, filename_r) == NULL) {
|
if(realpath(path, filename_r) == NULL) {
|
||||||
STRDUP(files->resolved_path[i], causal_dir, goto error);
|
files->resolved_path[i] = causal_dir;
|
||||||
FREE(filename_r);
|
FREE(filename_r);
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
causal_dir_r_len = strlen(filename_r + root_len) + 1;
|
causal_dir_r_len = strlen(filename_r + root_len) + 1;
|
||||||
if(causal_dir_r_len >= PATH_MAX) {
|
if(causal_dir_r_len >= PATH_MAX) {
|
||||||
STRDUP(files->resolved_path[i], causal_dir, goto error);
|
files->resolved_path[i] = causal_dir;
|
||||||
FREE(filename_r);
|
FREE(filename_r);
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
@ -91,23 +91,25 @@ size_t _alpm_filelist_resolve_link(
|
|||||||
filename_r_len = filename_len + causal_dir_r_len - causal_dir_len;
|
filename_r_len = filename_len + causal_dir_r_len - causal_dir_len;
|
||||||
if(filename_r_len >= PATH_MAX) {
|
if(filename_r_len >= PATH_MAX) {
|
||||||
/* resolved path is too long */
|
/* resolved path is too long */
|
||||||
STRDUP(files->resolved_path[i], filename, goto error);
|
files->resolved_path[i] = filename;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
strcpy(filename_r + causal_dir_r_len, filename + causal_dir_len);
|
strcpy(filename_r + causal_dir_r_len, filename + causal_dir_len);
|
||||||
} else {
|
|
||||||
filename_r = filename;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* deal with files and paths too long to resolve*/
|
/* deal with files and paths too long to resolve*/
|
||||||
if(filename[filename_len - 1] != '/' || root_len + filename_r_len >= PATH_MAX) {
|
if(filename[filename_len - 1] != '/' || root_len + filename_r_len >= PATH_MAX) {
|
||||||
|
if(resolving) {
|
||||||
STRDUP(files->resolved_path[i], filename_r, goto error);
|
STRDUP(files->resolved_path[i], filename_r, goto error);
|
||||||
|
} else {
|
||||||
|
files->resolved_path[i] = filename;
|
||||||
|
}
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* construct absolute path and stat() */
|
/* construct absolute path and stat() */
|
||||||
strcpy(path + root_len, filename_r);
|
strcpy(path + root_len, resolving ? filename_r : filename);
|
||||||
exists = !_alpm_lstat(path, &sbuf);
|
exists = !_alpm_lstat(path, &sbuf);
|
||||||
|
|
||||||
/* deal with symlinks */
|
/* deal with symlinks */
|
||||||
@ -117,7 +119,11 @@ size_t _alpm_filelist_resolve_link(
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* deal with normal directories */
|
/* deal with normal directories */
|
||||||
|
if(resolving) {
|
||||||
STRDUP(files->resolved_path[i], filename_r, goto error);
|
STRDUP(files->resolved_path[i], filename_r, goto error);
|
||||||
|
} else {
|
||||||
|
files->resolved_path[i] = filename;
|
||||||
|
}
|
||||||
|
|
||||||
/* deal with children of non-existent directories to reduce lstat() calls */
|
/* deal with children of non-existent directories to reduce lstat() calls */
|
||||||
if (!exists) {
|
if (!exists) {
|
||||||
@ -136,25 +142,24 @@ size_t _alpm_filelist_resolve_link(
|
|||||||
strcpy(filename_r + causal_dir_r_len, f + causal_dir_len);
|
strcpy(filename_r + causal_dir_r_len, f + causal_dir_len);
|
||||||
STRDUP(files->resolved_path[i], filename_r, goto error);
|
STRDUP(files->resolved_path[i], filename_r, goto error);
|
||||||
} else {
|
} else {
|
||||||
STRDUP(files->resolved_path[i], f, goto error);
|
files->resolved_path[i] = f;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
i--;
|
i--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(resolving) {
|
|
||||||
FREE(filename_r);
|
FREE(filename_r);
|
||||||
}
|
|
||||||
|
|
||||||
return i-1;
|
return i-1;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
if(resolving) {
|
|
||||||
FREE(filename_r);
|
FREE(filename_r);
|
||||||
|
/* out of memory, set remaining files to their original names */
|
||||||
|
for(; i < files->count; (i)++) {
|
||||||
|
files->resolved_path[i] = files->files[i].name;
|
||||||
}
|
}
|
||||||
/* out of memory, not much point in going on */
|
return i-1;
|
||||||
return files->count;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -591,17 +591,24 @@ void _alpm_pkg_free(alpm_pkg_t *pkg)
|
|||||||
free_deplist(pkg->replaces);
|
free_deplist(pkg->replaces);
|
||||||
FREELIST(pkg->groups);
|
FREELIST(pkg->groups);
|
||||||
if(pkg->files.count) {
|
if(pkg->files.count) {
|
||||||
size_t i;
|
size_t i, j, k;
|
||||||
for(i = 0; i < pkg->files.count; i++) {
|
|
||||||
FREE(pkg->files.files[i].name);
|
|
||||||
}
|
|
||||||
free(pkg->files.files);
|
|
||||||
if(pkg->files.resolved_path) {
|
if(pkg->files.resolved_path) {
|
||||||
for(i = 0; i < pkg->files.count; i++) {
|
for(i = 0, j = 0; i < pkg->files.count; i++) {
|
||||||
|
for(k = j; k <= pkg->files.count; k++) {
|
||||||
|
if(pkg->files.resolved_path[i] == pkg->files.files[k].name) {
|
||||||
|
pkg->files.files[k].name = NULL;
|
||||||
|
j = k + 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
free(pkg->files.resolved_path[i]);
|
free(pkg->files.resolved_path[i]);
|
||||||
}
|
}
|
||||||
free(pkg->files.resolved_path);
|
free(pkg->files.resolved_path);
|
||||||
}
|
}
|
||||||
|
for(j = 0; j < pkg->files.count; j++) {
|
||||||
|
FREE(pkg->files.files[j].name);
|
||||||
|
}
|
||||||
|
free(pkg->files.files);
|
||||||
}
|
}
|
||||||
alpm_list_free_inner(pkg->backup, (alpm_list_fn_free)_alpm_backup_free);
|
alpm_list_free_inner(pkg->backup, (alpm_list_fn_free)_alpm_backup_free);
|
||||||
alpm_list_free(pkg->backup);
|
alpm_list_free(pkg->backup);
|
||||||
|
Loading…
Reference in New Issue
Block a user