1
0
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:
Dan McGee 2011-10-26 14:55:50 -05:00
parent a708e7d28e
commit d5f0395dc1

View File

@ -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 {