mirror of
https://github.com/pocketpy/pocketpy
synced 2025-10-20 11:30:18 +00:00
refactor io
This commit is contained in:
parent
d81a1c5415
commit
eaf231fd9d
@ -7,26 +7,3 @@ namespace pkpy{
|
||||
void add_module_os(VM* vm);
|
||||
void add_module_io(VM* vm);
|
||||
}
|
||||
|
||||
#if PK_ENABLE_OS
|
||||
|
||||
#include <filesystem>
|
||||
#include <cstdio>
|
||||
|
||||
namespace pkpy{
|
||||
|
||||
struct FileIO {
|
||||
PY_CLASS(FileIO, io, FileIO)
|
||||
|
||||
Str file;
|
||||
Str mode;
|
||||
FILE* fp;
|
||||
|
||||
bool is_text() const { return mode != "rb" && mode != "wb" && mode != "ab"; }
|
||||
FileIO(VM* vm, std::string file, std::string mode);
|
||||
void close();
|
||||
static void _register(VM* vm, PyObject* mod, PyObject* type);
|
||||
};
|
||||
|
||||
} // namespace pkpy
|
||||
#endif
|
43
src/io.cpp
43
src/io.cpp
@ -1,8 +1,27 @@
|
||||
#include "pocketpy/io.h"
|
||||
|
||||
#if PK_ENABLE_OS
|
||||
#include <filesystem>
|
||||
#include <cstdio>
|
||||
#endif
|
||||
|
||||
namespace pkpy{
|
||||
|
||||
#if PK_ENABLE_OS
|
||||
|
||||
struct FileIO {
|
||||
PY_CLASS(FileIO, io, FileIO)
|
||||
|
||||
Str file;
|
||||
Str mode;
|
||||
FILE* fp;
|
||||
|
||||
bool is_text() const { return mode != "rb" && mode != "wb" && mode != "ab"; }
|
||||
FileIO(VM* vm, std::string file, std::string mode);
|
||||
void close();
|
||||
static void _register(VM* vm, PyObject* mod, PyObject* type);
|
||||
};
|
||||
|
||||
static FILE* io_fopen(const char* name, const char* mode){
|
||||
#if _MSC_VER
|
||||
FILE* fp;
|
||||
@ -21,11 +40,8 @@ static size_t io_fread(void* buffer, size_t size, size_t count, FILE* fp){
|
||||
return fread(buffer, size, count, fp);
|
||||
#endif
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
unsigned char* _default_import_handler(const char* name_p, int name_size, int* out_size){
|
||||
#if PK_ENABLE_OS
|
||||
std::string name(name_p, name_size);
|
||||
bool exists = std::filesystem::exists(std::filesystem::path(name));
|
||||
if(!exists) return nullptr;
|
||||
@ -36,16 +52,12 @@ unsigned char* _default_import_handler(const char* name_p, int name_size, int* o
|
||||
unsigned char* buffer = new unsigned char[buffer_size];
|
||||
fseek(fp, 0, SEEK_SET);
|
||||
size_t sz = io_fread(buffer, 1, buffer_size, fp);
|
||||
(void)sz; // suppress warning
|
||||
fclose(fp);
|
||||
*out_size = buffer_size;
|
||||
return buffer;
|
||||
#else
|
||||
return nullptr;
|
||||
#endif
|
||||
};
|
||||
|
||||
|
||||
#if PK_ENABLE_OS
|
||||
void FileIO::_register(VM* vm, PyObject* mod, PyObject* type){
|
||||
vm->bind_constructor<3>(type, [](VM* vm, ArgsView args){
|
||||
Type cls = PK_OBJ_GET(Type, args[0]);
|
||||
@ -106,10 +118,7 @@ unsigned char* _default_import_handler(const char* name_p, int name_size, int* o
|
||||
fp = nullptr;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
void add_module_io(VM* vm){
|
||||
#if PK_ENABLE_OS
|
||||
PyObject* mod = vm->new_module("io");
|
||||
FileIO::register_class(vm, mod);
|
||||
vm->bind(vm->builtins, "open(path, mode='r')", [](VM* vm, ArgsView args){
|
||||
@ -117,11 +126,9 @@ void add_module_io(VM* vm){
|
||||
PK_LOCAL_STATIC StrName m_FileIO("FileIO");
|
||||
return vm->call(vm->_modules[m_io]->attr(m_FileIO), args[0], args[1]);
|
||||
});
|
||||
#endif
|
||||
}
|
||||
|
||||
void add_module_os(VM* vm){
|
||||
#if PK_ENABLE_OS
|
||||
PyObject* mod = vm->new_module("os");
|
||||
PyObject* path_obj = vm->heap.gcnew<DummyInstance>(vm->tp_object);
|
||||
mod->attr().set("path", path_obj);
|
||||
@ -192,7 +199,15 @@ void add_module_os(VM* vm){
|
||||
std::filesystem::path path(CAST(Str&, args[0]).sv());
|
||||
return VAR(path.filename().string());
|
||||
});
|
||||
#endif
|
||||
}
|
||||
#else
|
||||
|
||||
void add_module_io(VM* vm){}
|
||||
void add_module_os(VM* vm){}
|
||||
unsigned char* _default_import_handler(const char* name_p, int name_size, int* out_size){
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
} // namespace pkpy
|
Loading…
x
Reference in New Issue
Block a user