commit - 3f148bc66e13559704e12d07a8c05612be797de2
commit + 339c298e66d94d2a92f3b1af99c60e0e4172b1e7
blob - fd98027aca25f70b7500f2f6e60ae73cc02d6033
blob + 08d2a404aeb438f0119da97f048a5a3735aa51c1
--- lib/worktree.c
+++ lib/worktree.c
ie->size == (sb->st_size & 0xffffffff));
}
-/* Report file status and initialize sb->st_mode. */
static const struct got_error *
get_file_status(unsigned char *status, struct stat *sb,
struct got_fileindex_entry *ie, const char *abspath,
const struct got_error *err = NULL;
struct got_object_id id;
size_t hdrlen;
- int fd;
FILE *f = NULL;
uint8_t fbuf[8192];
struct got_blob_object *blob = NULL;
*status = GOT_STATUS_NO_CHANGE;
- fd = open(abspath, O_RDONLY | O_NOFOLLOW);
- if (fd == -1) {
+ if (lstat(abspath, sb) == -1) {
if (errno == ENOENT) {
if (ie) {
if (got_fileindex_entry_has_file_on_disk(ie))
sb->st_mode = GOT_DEFAULT_FILE_MODE;
return NULL;
}
- return got_error_from_errno2("open", abspath);
+ return got_error_from_errno2("lstat", abspath);
}
- if (ie == NULL) {
- sb->st_mode = GOT_DEFAULT_FILE_MODE;
- goto done;
+ if (!S_ISREG(sb->st_mode)) {
+ *status = GOT_STATUS_OBSTRUCTED;
+ return NULL;
}
- if (fstat(fd, sb) == -1) {
- err = got_error_from_errno2("fstat", abspath);
- goto done;
- }
+ if (ie == NULL)
+ return NULL;
if (!got_fileindex_entry_has_file_on_disk(ie)) {
- if (S_ISREG(sb->st_mode))
- *status = GOT_STATUS_DELETE;
- else
- *status = GOT_STATUS_OBSTRUCTED;
- goto done;
+ *status = GOT_STATUS_DELETE;
+ return NULL;
} else if (!got_fileindex_entry_has_blob(ie)) {
- if (S_ISREG(sb->st_mode))
- *status = GOT_STATUS_ADD;
- else
- *status = GOT_STATUS_OBSTRUCTED;
- goto done;
- } else if (!S_ISREG(sb->st_mode)) {
- *status = GOT_STATUS_OBSTRUCTED;
- goto done;
+ *status = GOT_STATUS_ADD;
+ return NULL;
}
if (!stat_info_differs(ie, sb))
- goto done;
+ return NULL;
memcpy(id.sha1, ie->blob_sha1, sizeof(id.sha1));
err = got_object_open_as_blob(&blob, repo, &id, sizeof(fbuf));
if (err)
- goto done;
+ return err;
- f = fdopen(fd, "r");
+ f = fopen(abspath, "r");
if (f == NULL) {
- err = got_error_from_errno2("fdopen", abspath);
+ err = got_error_from_errno2("fopen", abspath);
goto done;
}
- fd = -1;
hdrlen = got_object_blob_get_hdrlen(blob);
for (;;) {
const uint8_t *bbuf = got_object_blob_get_read_buf(blob);
done:
if (blob)
got_object_blob_close(blob);
- if (fd != -1 && close(fd) == -1 && err == NULL)
- err = got_error_from_errno2("close", abspath);
if (f)
fclose(f);
return err;