- extfs_read() and extfs_write() return -1 on error and don't clear errno

- parent CNIDs of FSItems are exchanged in fs_rename() and fs_cat_move()
This commit is contained in:
cebix 1999-12-22 16:16:18 +00:00
parent b27458fb2d
commit 92be3b6781
5 changed files with 55 additions and 48 deletions

View File

@ -343,24 +343,22 @@ void close_rfork(const char *path, int fd)
/* /*
* Read "length" bytes from file to "buffer", * Read "length" bytes from file to "buffer",
* returns number of bytes read (or 0) * returns number of bytes read (or -1 on error)
*/ */
size_t extfs_read(int fd, void *buffer, size_t length) ssize_t extfs_read(int fd, void *buffer, size_t length)
{ {
errno = 0;
return read(fd, buffer, length); return read(fd, buffer, length);
} }
/* /*
* Write "length" bytes from "buffer" to file, * Write "length" bytes from "buffer" to file,
* returns number of bytes written (or 0) * returns number of bytes written (or -1 on error)
*/ */
size_t extfs_write(int fd, void *buffer, size_t length) ssize_t extfs_write(int fd, void *buffer, size_t length)
{ {
errno = 0;
return write(fd, buffer, length); return write(fd, buffer, length);
} }

View File

@ -369,7 +369,7 @@ void close_rfork(const char *path, int fd)
/* /*
* Read "length" bytes from file to "buffer", * Read "length" bytes from file to "buffer",
* returns number of bytes read (or 0) * returns number of bytes read (or -1 on error)
*/ */
static inline ssize_t sread(int fd, void *buf, size_t count) static inline ssize_t sread(int fd, void *buf, size_t count)
@ -379,42 +379,38 @@ static inline ssize_t sread(int fd, void *buf, size_t count)
return res; return res;
} }
size_t extfs_read(int fd, void *buffer, size_t length) ssize_t extfs_read(int fd, void *buffer, size_t length)
{ {
errno = 0;
// Buffer in kernel space? // Buffer in kernel space?
size_t actual = 0;
if ((uint32)buffer < 0x80000000) { if ((uint32)buffer < 0x80000000) {
// Yes, transfer via buffer // Yes, transfer via buffer
ssize_t actual = 0;
while (length) { while (length) {
size_t transfer_size = (length > TMP_BUF_SIZE) ? TMP_BUF_SIZE : length; size_t transfer_size = (length > TMP_BUF_SIZE) ? TMP_BUF_SIZE : length;
ssize_t res = sread(fd, tmp_buf, transfer_size); ssize_t res = sread(fd, tmp_buf, transfer_size);
if (res >= 0) { if (res < 0)
memcpy(buffer, tmp_buf, res); return res;
buffer = (void *)((uint8 *)buffer + res); memcpy(buffer, tmp_buf, res);
length -= res; buffer = (void *)((uint8 *)buffer + res);
actual += res; length -= res;
} actual += res;
if (res != transfer_size) if (res != transfer_size)
return actual; return actual;
} }
return actual;
} else { } else {
// No, transfer directly // No, transfer directly
actual = sread(fd, buffer, length); return sread(fd, buffer, length);
if (actual < 0)
actual = 0;
} }
return actual;
} }
/* /*
* Write "length" bytes from "buffer" to file, * Write "length" bytes from "buffer" to file,
* returns number of bytes written (or 0) * returns number of bytes written (or -1 on error)
*/ */
static inline ssize_t swrite(int fd, void *buf, size_t count) static inline ssize_t swrite(int fd, void *buf, size_t count)
@ -424,36 +420,32 @@ static inline ssize_t swrite(int fd, void *buf, size_t count)
return res; return res;
} }
size_t extfs_write(int fd, void *buffer, size_t length) ssize_t extfs_write(int fd, void *buffer, size_t length)
{ {
errno = 0;
// Buffer in kernel space? // Buffer in kernel space?
size_t actual = 0;
if ((uint32)buffer < 0x80000000) { if ((uint32)buffer < 0x80000000) {
// Yes, transfer via buffer // Yes, transfer via buffer
ssize_t actual = 0;
while (length) { while (length) {
size_t transfer_size = (length > TMP_BUF_SIZE) ? TMP_BUF_SIZE : length; size_t transfer_size = (length > TMP_BUF_SIZE) ? TMP_BUF_SIZE : length;
memcpy(tmp_buf, buffer, transfer_size); memcpy(tmp_buf, buffer, transfer_size);
ssize_t res = swrite(fd, tmp_buf, transfer_size); ssize_t res = swrite(fd, tmp_buf, transfer_size);
if (res >= 0) { if (res < 0)
buffer = (void *)((uint8 *)buffer + res); return res;
length -= res; buffer = (void *)((uint8 *)buffer + res);
actual += res; length -= res;
} actual += res;
if (res != transfer_size) if (res != transfer_size)
return actual; return actual;
} }
return actual;
} else { } else {
// No, transfer directly // No, transfer directly
actual = swrite(fd, buffer, length); return swrite(fd, buffer, length);
if (actual < 0)
actual = 0;
} }
return actual;
} }

View File

@ -348,24 +348,22 @@ void close_rfork(const char *path, int fd)
/* /*
* Read "length" bytes from file to "buffer", * Read "length" bytes from file to "buffer",
* returns number of bytes read (or 0) * returns number of bytes read (or -1 on error)
*/ */
size_t extfs_read(int fd, void *buffer, size_t length) ssize_t extfs_read(int fd, void *buffer, size_t length)
{ {
errno = 0;
return read(fd, buffer, length); return read(fd, buffer, length);
} }
/* /*
* Write "length" bytes from "buffer" to file, * Write "length" bytes from "buffer" to file,
* returns number of bytes written (or 0) * returns number of bytes written (or -1 on error)
*/ */
size_t extfs_write(int fd, void *buffer, size_t length) ssize_t extfs_write(int fd, void *buffer, size_t length)
{ {
errno = 0;
return write(fd, buffer, length); return write(fd, buffer, length);
} }

View File

@ -222,6 +222,23 @@ static void get_path_for_fsitem(FSItem *p)
} }
/*
* Exchange parent CNIDs in all FSItems
*/
static void swap_parent_ids(uint32 parent1, uint32 parent2)
{
FSItem *p = first_fs_item;
while (p) {
if (p->parent_id == parent1)
p->parent_id = parent2;
else if (p->parent_id == parent2)
p->parent_id = parent1;
p = p->next;
}
}
/* /*
* String handling functions * String handling functions
*/ */
@ -1778,15 +1795,15 @@ static int16 fs_read(uint32 pb)
} }
// Read // Read
size_t actual = extfs_read(fd, Mac2HostAddr(ReadMacInt32(pb + ioBuffer)), ReadMacInt32(pb + ioReqCount)); ssize_t actual = extfs_read(fd, Mac2HostAddr(ReadMacInt32(pb + ioBuffer)), ReadMacInt32(pb + ioReqCount));
int16 read_err = errno2oserr(); int16 read_err = errno2oserr();
D(bug(" actual %d\n", actual)); D(bug(" actual %d\n", actual));
WriteMacInt32(pb + ioActCount, actual); WriteMacInt32(pb + ioActCount, actual >= 0 ? actual : 0);
uint32 pos = lseek(fd, 0, SEEK_CUR); uint32 pos = lseek(fd, 0, SEEK_CUR);
WriteMacInt32(fcb + fcbCrPs, pos); WriteMacInt32(fcb + fcbCrPs, pos);
WriteMacInt32(pb + ioPosOffset, pos); WriteMacInt32(pb + ioPosOffset, pos);
if (actual != ReadMacInt32(pb + ioReqCount)) if (actual != ReadMacInt32(pb + ioReqCount))
return read_err ? read_err : eofErr; return actual < 0 ? read_err : eofErr;
else else
return noErr; return noErr;
} }
@ -1827,10 +1844,10 @@ static int16 fs_write(uint32 pb)
} }
// Write // Write
size_t actual = extfs_write(fd, Mac2HostAddr(ReadMacInt32(pb + ioBuffer)), ReadMacInt32(pb + ioReqCount)); ssize_t actual = extfs_write(fd, Mac2HostAddr(ReadMacInt32(pb + ioBuffer)), ReadMacInt32(pb + ioReqCount));
int16 write_err = errno2oserr(); int16 write_err = errno2oserr();
D(bug(" actual %d\n", actual)); D(bug(" actual %d\n", actual));
WriteMacInt32(pb + ioActCount, actual); WriteMacInt32(pb + ioActCount, actual >= 0 ? actual : 0);
uint32 pos = lseek(fd, 0, SEEK_CUR); uint32 pos = lseek(fd, 0, SEEK_CUR);
WriteMacInt32(fcb + fcbCrPs, pos); WriteMacInt32(fcb + fcbCrPs, pos);
WriteMacInt32(pb + ioPosOffset, pos); WriteMacInt32(pb + ioPosOffset, pos);
@ -1940,6 +1957,7 @@ static int16 fs_rename(uint32 pb, uint32 dirID)
return errno2oserr(); return errno2oserr();
else { else {
// The ID of the old file/dir has to stay the same, so we swap the IDs of the FSItems // The ID of the old file/dir has to stay the same, so we swap the IDs of the FSItems
swap_parent_ids(fs_item->id, new_item->id);
uint32 t = fs_item->id; uint32 t = fs_item->id;
fs_item->id = new_item->id; fs_item->id = new_item->id;
new_item->id = t; new_item->id = t;
@ -1985,6 +2003,7 @@ static int16 fs_cat_move(uint32 pb)
// The ID of the old file/dir has to stay the same, so we swap the IDs of the FSItems // The ID of the old file/dir has to stay the same, so we swap the IDs of the FSItems
FSItem *new_item = find_fsitem(fs_item->name, new_dir_item); FSItem *new_item = find_fsitem(fs_item->name, new_dir_item);
if (new_item) { if (new_item) {
swap_parent_ids(fs_item->id, new_item->id);
uint32 t = fs_item->id; uint32 t = fs_item->id;
fs_item->id = new_item->id; fs_item->id = new_item->id;
new_item->id = t; new_item->id = t;

View File

@ -40,8 +40,8 @@ extern void set_finder_flags(const char *path, uint16 flags);
extern uint32 get_rfork_size(const char *path); extern uint32 get_rfork_size(const char *path);
extern int open_rfork(const char *path, int flag); extern int open_rfork(const char *path, int flag);
extern void close_rfork(const char *path, int fd); extern void close_rfork(const char *path, int fd);
extern size_t extfs_read(int fd, void *buffer, size_t length); extern ssize_t extfs_read(int fd, void *buffer, size_t length);
extern size_t extfs_write(int fd, void *buffer, size_t length); extern ssize_t extfs_write(int fd, void *buffer, size_t length);
extern bool extfs_remove(const char *path); extern bool extfs_remove(const char *path);
extern bool extfs_rename(const char *old_path, const char *new_path); extern bool extfs_rename(const char *old_path, const char *new_path);