mirror of
https://github.com/moparisthebest/pacman
synced 2025-01-10 13:28:12 -05:00
libalpm/util: two stat() related cleanups
First, use fstat() in preference to stat() since we already have an open file handle. This also removes the need to check for a symlink as that is not possible when a file is opened. Next, use archive_entry_mode() rather than archive_entry_stat() as we only use the mode portion of the stat struct and the call is much cheaper. Also delay it until it is necessary. Signed-off-by: Dan McGee <dan@archlinux.org>
This commit is contained in:
parent
a708e7d28e
commit
d5f0395dc1
@ -160,12 +160,10 @@ int _alpm_copyfile(const char *src, const char *dest)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* chmod dest to permissions of src, as long as it is not a symlink */
|
/* chmod dest to permissions of src */
|
||||||
struct stat statbuf;
|
struct stat statbuf;
|
||||||
if(!stat(src, &statbuf)) {
|
if(!fstat(fileno(in), &statbuf)) {
|
||||||
if(! S_ISLNK(statbuf.st_mode)) {
|
|
||||||
fchmod(fileno(out), statbuf.st_mode);
|
fchmod(fileno(out), statbuf.st_mode);
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
/* stat was unsuccessful */
|
/* stat was unsuccessful */
|
||||||
ret = 1;
|
ret = 1;
|
||||||
@ -313,18 +311,11 @@ int _alpm_unpack(alpm_handle_t *handle, const char *archive, const char *prefix,
|
|||||||
}
|
}
|
||||||
|
|
||||||
while(archive_read_next_header(_archive, &entry) == ARCHIVE_OK) {
|
while(archive_read_next_header(_archive, &entry) == ARCHIVE_OK) {
|
||||||
const struct stat *st;
|
const char *entryname;
|
||||||
const char *entryname; /* the name of the file in the archive */
|
mode_t mode;
|
||||||
|
|
||||||
st = archive_entry_stat(entry);
|
|
||||||
entryname = archive_entry_pathname(entry);
|
entryname = archive_entry_pathname(entry);
|
||||||
|
|
||||||
if(S_ISREG(st->st_mode)) {
|
|
||||||
archive_entry_set_perm(entry, 0644);
|
|
||||||
} else if(S_ISDIR(st->st_mode)) {
|
|
||||||
archive_entry_set_perm(entry, 0755);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* If specific files were requested, skip entries that don't match. */
|
/* If specific files were requested, skip entries that don't match. */
|
||||||
if(list) {
|
if(list) {
|
||||||
char *entry_prefix = strdup(entryname);
|
char *entry_prefix = strdup(entryname);
|
||||||
@ -345,6 +336,13 @@ int _alpm_unpack(alpm_handle_t *handle, const char *archive, const char *prefix,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mode = archive_entry_mode(entry);
|
||||||
|
if(S_ISREG(mode)) {
|
||||||
|
archive_entry_set_perm(entry, 0644);
|
||||||
|
} else if(S_ISDIR(mode)) {
|
||||||
|
archive_entry_set_perm(entry, 0755);
|
||||||
|
}
|
||||||
|
|
||||||
/* Extract the archive entry. */
|
/* Extract the archive entry. */
|
||||||
int readret = archive_read_extract(_archive, entry, 0);
|
int readret = archive_read_extract(_archive, entry, 0);
|
||||||
if(readret == ARCHIVE_WARN) {
|
if(readret == ARCHIVE_WARN) {
|
||||||
@ -555,6 +553,7 @@ int _alpm_run_chroot(alpm_handle_t *handle, const char *path, char *const argv[]
|
|||||||
}
|
}
|
||||||
umask(0022);
|
umask(0022);
|
||||||
execv(path, argv);
|
execv(path, argv);
|
||||||
|
/* execv only returns if there was an error */
|
||||||
fprintf(stderr, _("call to execv failed (%s)\n"), strerror(errno));
|
fprintf(stderr, _("call to execv failed (%s)\n"), strerror(errno));
|
||||||
exit(1);
|
exit(1);
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user