mirror of
https://github.com/pocketpy/pocketpy
synced 2025-10-20 11:30:18 +00:00
up
This commit is contained in:
parent
5c1128d4ab
commit
2012e47507
@ -28,6 +28,8 @@ for n in [4,3,2,1]:
|
|||||||
c_args = ['VM*'] + [mapping[i] for i in p_args]
|
c_args = ['VM*'] + [mapping[i] for i in p_args]
|
||||||
c_ret = mapping[p_ret]
|
c_ret = mapping[p_ret]
|
||||||
name = f'__f_{p_ret}__{"_".join(p_args)}'
|
name = f'__f_{p_ret}__{"_".join(p_args)}'
|
||||||
|
# if c_ret == 'const char*':
|
||||||
|
# c_ret = 'char*'
|
||||||
s = f'typedef {c_ret} (*{name})({", ".join(c_args)});'
|
s = f'typedef {c_ret} (*{name})({", ".join(c_args)});'
|
||||||
s += '\n'
|
s += '\n'
|
||||||
|
|
||||||
|
@ -270,42 +270,6 @@ class dict:
|
|||||||
a.append(k.__json__()+': '+v.__json__())
|
a.append(k.__json__()+': '+v.__json__())
|
||||||
return '{'+ ', '.join(a) + '}'
|
return '{'+ ', '.join(a) + '}'
|
||||||
|
|
||||||
import ffi
|
|
||||||
|
|
||||||
def input():
|
|
||||||
return ffi.input()
|
|
||||||
|
|
||||||
class FileIO:
|
|
||||||
def __init__(self, path, mode):
|
|
||||||
assert type(path) is str
|
|
||||||
assert type(mode) is str
|
|
||||||
assert mode in ['r', 'w', 'rt', 'wt']
|
|
||||||
self.path = path
|
|
||||||
self.mode = mode
|
|
||||||
self.fp = ffi.fopen(path, mode)
|
|
||||||
|
|
||||||
def read(self):
|
|
||||||
assert self.mode in ['r', 'rt']
|
|
||||||
return ffi.fread(self.fp)
|
|
||||||
|
|
||||||
def write(self, s):
|
|
||||||
assert self.mode in ['w', 'wt']
|
|
||||||
assert type(s) is str
|
|
||||||
ffi.fwrite(self.fp, s)
|
|
||||||
|
|
||||||
def close(self):
|
|
||||||
ffi.fclose(self.fp)
|
|
||||||
|
|
||||||
def __enter__(self):
|
|
||||||
pass
|
|
||||||
|
|
||||||
def __exit__(self):
|
|
||||||
self.close()
|
|
||||||
|
|
||||||
def open(path, mode='r'):
|
|
||||||
return FileIO(path, mode)
|
|
||||||
|
|
||||||
|
|
||||||
class set:
|
class set:
|
||||||
def __init__(self, iterable=None):
|
def __init__(self, iterable=None):
|
||||||
iterable = iterable or []
|
iterable = iterable or []
|
||||||
|
28
src/main.cpp
28
src/main.cpp
@ -3,31 +3,28 @@
|
|||||||
|
|
||||||
#include "pocketpy.h"
|
#include "pocketpy.h"
|
||||||
|
|
||||||
#define PK_DEBUG_TIME
|
|
||||||
|
|
||||||
struct Timer{
|
struct Timer{
|
||||||
const char* title;
|
const char* title;
|
||||||
Timer(const char* title) : title(title) {}
|
Timer(const char* title) : title(title) {}
|
||||||
void run(std::function<void()> f){
|
void run(std::function<void()> f){
|
||||||
#ifdef PK_DEBUG_TIME
|
|
||||||
auto start = std::chrono::high_resolution_clock::now();
|
auto start = std::chrono::high_resolution_clock::now();
|
||||||
f();
|
f();
|
||||||
auto end = std::chrono::high_resolution_clock::now();
|
auto end = std::chrono::high_resolution_clock::now();
|
||||||
double elapsed = std::chrono::duration_cast<std::chrono::microseconds>(end - start).count() / 1000000.0;
|
double elapsed = std::chrono::duration_cast<std::chrono::microseconds>(end - start).count() / 1000000.0;
|
||||||
std::cout << title << ": " << elapsed << " s" << std::endl;
|
std::cout << title << ": " << elapsed << " s" << std::endl;
|
||||||
#else
|
|
||||||
f();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef __NO_MAIN
|
#ifndef __NO_MAIN
|
||||||
|
|
||||||
int main(int argc, char** argv){
|
int main(int argc, char** argv){
|
||||||
if(argc == 1){
|
|
||||||
VM* vm = pkpy_new_vm(true);
|
VM* vm = pkpy_new_vm(true);
|
||||||
|
pkpy_vm_bind__f_str__(vm, "builtins", "input", [](VM* vm){
|
||||||
|
static std::string line;
|
||||||
|
std::getline(std::cin, line);
|
||||||
|
return line.c_str();
|
||||||
|
});
|
||||||
|
if(argc == 1){
|
||||||
REPL repl(vm);
|
REPL repl(vm);
|
||||||
int result = -1;
|
int result = -1;
|
||||||
while(true){
|
while(true){
|
||||||
@ -36,6 +33,7 @@ int main(int argc, char** argv){
|
|||||||
std::getline(std::cin, line);
|
std::getline(std::cin, line);
|
||||||
result = pkpy_repl_input(&repl, line.c_str());
|
result = pkpy_repl_input(&repl, line.c_str());
|
||||||
}
|
}
|
||||||
|
pkpy_delete(vm);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -49,13 +47,17 @@ int main(int argc, char** argv){
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
std::string src((std::istreambuf_iterator<char>(file)), std::istreambuf_iterator<char>());
|
std::string src((std::istreambuf_iterator<char>(file)), std::istreambuf_iterator<char>());
|
||||||
|
PyVarOrNull ret = nullptr;
|
||||||
|
|
||||||
VM* vm = pkpy_new_vm(true);
|
if(filename[0] != '_'){
|
||||||
Timer("Running time").run([=]{
|
Timer("Running time").run([&]{
|
||||||
vm->exec(src.c_str(), filename, EXEC_MODE);
|
ret = vm->exec(src.c_str(), filename, EXEC_MODE);
|
||||||
});
|
});
|
||||||
|
}else{
|
||||||
|
ret = vm->exec(src.c_str(), filename, EXEC_MODE);
|
||||||
|
}
|
||||||
pkpy_delete(vm);
|
pkpy_delete(vm);
|
||||||
return 0;
|
return ret != nullptr ? 0 : 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
__HELP:
|
__HELP:
|
||||||
|
@ -766,9 +766,6 @@ extern "C" {
|
|||||||
__add_module_re(vm);
|
__add_module_re(vm);
|
||||||
__add_module_dis(vm);
|
__add_module_dis(vm);
|
||||||
|
|
||||||
|
|
||||||
vm->new_module("ffi");
|
|
||||||
|
|
||||||
// add builtins | no exception handler | must succeed
|
// add builtins | no exception handler | must succeed
|
||||||
_Code code = vm->compile(__BUILTINS_CODE, "<builtins>", EXEC_MODE);
|
_Code code = vm->compile(__BUILTINS_CODE, "<builtins>", EXEC_MODE);
|
||||||
vm->_exec(code, vm->builtins, pkpy::make_shared<PyVarDict>());
|
vm->_exec(code, vm->builtins, pkpy::make_shared<PyVarDict>());
|
||||||
|
Loading…
x
Reference in New Issue
Block a user