You've already forked godot
mirror of
https://github.com/godotengine/godot.git
synced 2025-11-04 12:00:25 +00:00
Make FileAccess and DirAccess classes reference counted.
This commit is contained in:
@@ -30,73 +30,69 @@
|
||||
|
||||
#include "zip_io.h"
|
||||
|
||||
void *zipio_open(void *data, const char *p_fname, int mode) {
|
||||
FileAccess *&f = *(FileAccess **)data;
|
||||
void *zipio_open(voidpf opaque, const char *p_fname, int mode) {
|
||||
ZipIOData *zd = (ZipIOData *)opaque;
|
||||
|
||||
String fname;
|
||||
fname.parse_utf8(p_fname);
|
||||
|
||||
if (mode & ZLIB_FILEFUNC_MODE_WRITE) {
|
||||
f = FileAccess::open(fname, FileAccess::WRITE);
|
||||
zd->f = FileAccess::open(fname, FileAccess::WRITE);
|
||||
} else {
|
||||
f = FileAccess::open(fname, FileAccess::READ);
|
||||
zd->f = FileAccess::open(fname, FileAccess::READ);
|
||||
}
|
||||
|
||||
if (!f) {
|
||||
if (zd->f.is_null()) {
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
return data;
|
||||
return opaque;
|
||||
}
|
||||
|
||||
uLong zipio_read(void *data, void *fdata, void *buf, uLong size) {
|
||||
FileAccess *f = *(FileAccess **)data;
|
||||
return f->get_buffer((uint8_t *)buf, size);
|
||||
uLong zipio_read(voidpf opaque, voidpf stream, void *buf, uLong size) {
|
||||
ZipIOData *zd = (ZipIOData *)opaque;
|
||||
return zd->f->get_buffer((uint8_t *)buf, size);
|
||||
}
|
||||
|
||||
uLong zipio_write(voidpf opaque, voidpf stream, const void *buf, uLong size) {
|
||||
FileAccess *f = *(FileAccess **)opaque;
|
||||
f->store_buffer((uint8_t *)buf, size);
|
||||
ZipIOData *zd = (ZipIOData *)opaque;
|
||||
zd->f->store_buffer((uint8_t *)buf, size);
|
||||
return size;
|
||||
}
|
||||
|
||||
long zipio_tell(voidpf opaque, voidpf stream) {
|
||||
FileAccess *f = *(FileAccess **)opaque;
|
||||
return f->get_position();
|
||||
ZipIOData *zd = (ZipIOData *)opaque;
|
||||
return zd->f->get_position();
|
||||
}
|
||||
|
||||
long zipio_seek(voidpf opaque, voidpf stream, uLong offset, int origin) {
|
||||
FileAccess *f = *(FileAccess **)opaque;
|
||||
ZipIOData *zd = (ZipIOData *)opaque;
|
||||
|
||||
uint64_t pos = offset;
|
||||
switch (origin) {
|
||||
case ZLIB_FILEFUNC_SEEK_CUR:
|
||||
pos = f->get_position() + offset;
|
||||
pos = zd->f->get_position() + offset;
|
||||
break;
|
||||
case ZLIB_FILEFUNC_SEEK_END:
|
||||
pos = f->get_length() + offset;
|
||||
pos = zd->f->get_length() + offset;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
f->seek(pos);
|
||||
zd->f->seek(pos);
|
||||
return 0;
|
||||
}
|
||||
|
||||
int zipio_close(voidpf opaque, voidpf stream) {
|
||||
FileAccess *&f = *(FileAccess **)opaque;
|
||||
if (f) {
|
||||
f->close();
|
||||
memdelete(f);
|
||||
f = nullptr;
|
||||
}
|
||||
ZipIOData *zd = (ZipIOData *)opaque;
|
||||
memdelete(zd);
|
||||
return 0;
|
||||
}
|
||||
|
||||
int zipio_testerror(voidpf opaque, voidpf stream) {
|
||||
FileAccess *f = *(FileAccess **)opaque;
|
||||
return (f && f->get_error() != OK) ? 1 : 0;
|
||||
ZipIOData *zd = (ZipIOData *)opaque;
|
||||
return (zd->f.is_valid() && zd->f->get_error() != OK) ? 1 : 0;
|
||||
}
|
||||
|
||||
voidpf zipio_alloc(voidpf opaque, uInt items, uInt size) {
|
||||
@@ -109,9 +105,9 @@ void zipio_free(voidpf opaque, voidpf address) {
|
||||
memfree(address);
|
||||
}
|
||||
|
||||
zlib_filefunc_def zipio_create_io_from_file(FileAccess **p_file) {
|
||||
zlib_filefunc_def zipio_create_io() {
|
||||
zlib_filefunc_def io;
|
||||
io.opaque = p_file;
|
||||
io.opaque = (void *)memnew(ZipIOData);
|
||||
io.zopen_file = zipio_open;
|
||||
io.zread_file = zipio_read;
|
||||
io.zwrite_file = zipio_write;
|
||||
|
||||
Reference in New Issue
Block a user