2022-06-14 03:20:17 +00:00
|
|
|
#include "PikaStdLib_SysObj.h"
|
2022-07-15 02:06:23 +00:00
|
|
|
#include "PikaStdData_FILEIO.h"
|
2021-12-27 21:57:08 +08:00
|
|
|
#include "PikaStdLib_RangeObj.h"
|
2022-01-09 23:37:24 +08:00
|
|
|
#include "PikaStdLib_StringObj.h"
|
2022-06-14 03:20:17 +00:00
|
|
|
#include "PikaVM.h"
|
2021-10-01 00:21:50 +08:00
|
|
|
#include "dataStrs.h"
|
|
|
|
|
|
|
|
void PikaStdLib_SysObj_remove(PikaObj* self, char* argPath) {
|
|
|
|
obj_setErrorCode(self, 0);
|
|
|
|
int32_t res = obj_removeArg(self, argPath);
|
|
|
|
if (1 == res) {
|
|
|
|
obj_setSysOut(self, "[error] del: object no found.");
|
|
|
|
obj_setErrorCode(self, 1);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (2 == res) {
|
|
|
|
obj_setSysOut(self, "[error] del: arg not match.");
|
|
|
|
obj_setErrorCode(self, 2);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-30 16:10:08 +08:00
|
|
|
Arg* PikaStdLib_SysObj_type(PikaObj* self, Arg* arg) {
|
2021-10-01 00:21:50 +08:00
|
|
|
if (NULL == arg) {
|
|
|
|
obj_setSysOut(self, "[error] type: arg no found.");
|
|
|
|
obj_setErrorCode(self, 1);
|
2022-07-20 10:32:01 +08:00
|
|
|
return arg_newNull();
|
2021-10-01 00:21:50 +08:00
|
|
|
}
|
2021-11-15 09:35:48 +08:00
|
|
|
ArgType type = arg_getType(arg);
|
2022-03-02 10:34:33 +08:00
|
|
|
if (ARG_TYPE_INT == type) {
|
2023-01-23 14:19:19 +08:00
|
|
|
return arg_copy(obj_getMethodArg(self, "int"));
|
2021-11-15 09:35:48 +08:00
|
|
|
}
|
2022-03-02 10:34:33 +08:00
|
|
|
if (ARG_TYPE_FLOAT == type) {
|
2023-01-23 14:19:19 +08:00
|
|
|
return arg_copy(obj_getMethodArg(self, "float"));
|
2021-11-15 09:35:48 +08:00
|
|
|
}
|
2022-03-02 10:34:33 +08:00
|
|
|
if (ARG_TYPE_STRING == type) {
|
2023-01-23 14:19:19 +08:00
|
|
|
return arg_copy(obj_getMethodArg(self, "str"));
|
2021-11-15 09:35:48 +08:00
|
|
|
}
|
2023-02-18 16:35:03 +08:00
|
|
|
if (ARG_TYPE_BOOL == type) {
|
|
|
|
return arg_copy(obj_getMethodArg(self, "bool"));
|
|
|
|
}
|
2022-06-30 16:10:08 +08:00
|
|
|
if (argType_isObject(type)) {
|
|
|
|
PikaObj* obj = arg_getPtr(arg);
|
|
|
|
NewFun clsptr = obj_getClass(obj);
|
|
|
|
PikaObj* New_PikaStdData_List(Args * args);
|
2023-01-24 00:20:43 +08:00
|
|
|
/* list */
|
2022-06-30 16:10:08 +08:00
|
|
|
if (clsptr == New_PikaStdData_List) {
|
2023-01-23 23:59:15 +08:00
|
|
|
return arg_copy(obj_getMethodArg(self, "list"));
|
2022-06-30 16:10:08 +08:00
|
|
|
}
|
|
|
|
/* dict */
|
|
|
|
PikaObj* New_PikaStdData_Dict(Args * args);
|
|
|
|
if (clsptr == New_PikaStdData_Dict) {
|
2023-01-23 23:59:15 +08:00
|
|
|
return arg_copy(obj_getMethodArg(self, "dict"));
|
2022-06-30 16:10:08 +08:00
|
|
|
}
|
2023-01-24 00:20:43 +08:00
|
|
|
/* tuple */
|
|
|
|
PikaObj* New_PikaStdData_Tuple(Args * args);
|
|
|
|
if (clsptr == New_PikaStdData_Tuple) {
|
|
|
|
return arg_copy(obj_getMethodArg(self, "tuple"));
|
|
|
|
}
|
2023-03-01 22:03:51 +08:00
|
|
|
#if PIKA_TYPE_FULL_FEATURE_ENABLE
|
|
|
|
Arg* aMethod = obj_getArg(obj, "__class__");
|
|
|
|
if (NULL != aMethod) {
|
|
|
|
return arg_copy(aMethod);
|
|
|
|
}
|
|
|
|
#endif
|
2022-07-20 10:32:01 +08:00
|
|
|
return arg_newStr("<class 'object'>");
|
2021-11-15 09:35:48 +08:00
|
|
|
}
|
2022-04-28 00:42:06 +08:00
|
|
|
if (ARG_TYPE_OBJECT_META == type) {
|
2022-07-20 10:32:01 +08:00
|
|
|
return arg_newStr("<class 'meta object'>");
|
2021-11-15 09:35:48 +08:00
|
|
|
}
|
2022-04-28 16:04:14 +08:00
|
|
|
if (ARG_TYPE_BYTES == type) {
|
2022-07-20 10:32:01 +08:00
|
|
|
return arg_newStr("<class 'bytes'>");
|
2022-04-28 16:04:14 +08:00
|
|
|
}
|
2022-04-28 00:29:32 +08:00
|
|
|
if (ARG_TYPE_METHOD_OBJECT == type) {
|
2022-07-20 10:32:01 +08:00
|
|
|
return arg_newStr("<class 'method'>");
|
2022-04-27 23:38:00 +08:00
|
|
|
}
|
2022-04-28 00:29:32 +08:00
|
|
|
if (ARG_TYPE_METHOD_STATIC == type) {
|
2022-07-20 10:32:01 +08:00
|
|
|
return arg_newStr("<class 'function'>");
|
2021-11-15 09:35:48 +08:00
|
|
|
}
|
2022-07-06 15:13:23 +08:00
|
|
|
if (ARG_TYPE_NONE == type) {
|
2022-07-20 10:32:01 +08:00
|
|
|
return arg_newStr("<class 'NoneType'>");
|
2022-07-06 15:13:23 +08:00
|
|
|
}
|
2023-03-01 22:03:51 +08:00
|
|
|
return arg_newStr("<class 'buitin_function_or_method'>");
|
2021-10-01 00:21:50 +08:00
|
|
|
}
|
2021-11-20 09:28:21 +08:00
|
|
|
|
2022-09-28 11:23:39 +08:00
|
|
|
pika_float PikaStdLib_SysObj_float(PikaObj* self, Arg* arg) {
|
2021-11-20 09:28:21 +08:00
|
|
|
ArgType type = arg_getType(arg);
|
2022-03-02 10:34:33 +08:00
|
|
|
if (ARG_TYPE_INT == type) {
|
2023-04-19 22:24:10 +08:00
|
|
|
return (pika_float)arg_getInt(arg);
|
2021-11-20 09:28:21 +08:00
|
|
|
}
|
2022-03-02 10:34:33 +08:00
|
|
|
if (ARG_TYPE_FLOAT == type) {
|
2023-04-19 22:24:10 +08:00
|
|
|
return (pika_float)arg_getFloat(arg);
|
2021-11-20 09:28:21 +08:00
|
|
|
}
|
2022-11-08 22:07:06 +08:00
|
|
|
if (ARG_TYPE_STRING == type) {
|
|
|
|
return strtod(arg_getStr(arg), NULL);
|
|
|
|
}
|
2023-02-18 16:35:03 +08:00
|
|
|
if (ARG_TYPE_BOOL == type) {
|
2023-04-19 22:24:10 +08:00
|
|
|
return (pika_float)arg_getBool(arg);
|
2023-02-18 16:35:03 +08:00
|
|
|
}
|
2022-10-24 10:14:12 +08:00
|
|
|
obj_setSysOut(self, "[error] convert to pika_float type failed.");
|
2021-11-20 09:28:21 +08:00
|
|
|
obj_setErrorCode(self, 1);
|
2023-02-18 16:35:03 +08:00
|
|
|
return _PIKA_FLOAT_ERR;
|
2021-11-20 09:28:21 +08:00
|
|
|
}
|
|
|
|
|
2023-03-17 14:28:10 +08:00
|
|
|
PIKA_RES _transeInt(Arg* arg, int base, int64_t* res) {
|
2021-11-20 09:28:21 +08:00
|
|
|
ArgType type = arg_getType(arg);
|
2022-03-02 10:34:33 +08:00
|
|
|
if (ARG_TYPE_INT == type) {
|
2023-03-17 14:28:10 +08:00
|
|
|
*res = arg_getInt(arg);
|
2023-02-18 16:35:03 +08:00
|
|
|
return PIKA_RES_OK;
|
|
|
|
}
|
|
|
|
if (ARG_TYPE_BOOL == type) {
|
|
|
|
*res = (int)arg_getBool(arg);
|
|
|
|
return PIKA_RES_OK;
|
2021-11-20 09:28:21 +08:00
|
|
|
}
|
2022-03-02 10:34:33 +08:00
|
|
|
if (ARG_TYPE_FLOAT == type) {
|
2023-02-18 16:35:03 +08:00
|
|
|
*res = (int)arg_getFloat(arg);
|
|
|
|
return PIKA_RES_OK;
|
2021-11-20 09:28:21 +08:00
|
|
|
}
|
2022-04-09 01:15:21 +08:00
|
|
|
if (ARG_TYPE_STRING == type) {
|
2023-03-17 14:28:10 +08:00
|
|
|
*res = strtoll(arg_getStr(arg), NULL, base);
|
2023-02-18 16:35:03 +08:00
|
|
|
return PIKA_RES_OK;
|
2022-04-09 01:15:21 +08:00
|
|
|
}
|
2022-05-27 10:29:57 +08:00
|
|
|
if (ARG_TYPE_BYTES == type) {
|
|
|
|
size_t size = arg_getBytesSize(arg);
|
|
|
|
if (size != 1) {
|
2023-02-18 16:35:03 +08:00
|
|
|
return PIKA_RES_ERR_INVALID_PARAM;
|
2022-05-27 10:29:57 +08:00
|
|
|
}
|
|
|
|
uint8_t val = *arg_getBytes(arg);
|
2023-02-18 16:35:03 +08:00
|
|
|
*res = val;
|
|
|
|
return PIKA_RES_OK;
|
|
|
|
}
|
|
|
|
return PIKA_RES_ERR_INVALID_PARAM;
|
|
|
|
}
|
|
|
|
|
2023-03-17 14:28:10 +08:00
|
|
|
int PikaStdLib_SysObj_int(PikaObj* self, Arg* arg, PikaTuple* base) {
|
|
|
|
int64_t res = 0;
|
|
|
|
int iBase = 10;
|
|
|
|
if (pikaTuple_getSize(base) > 0) {
|
|
|
|
if (arg_getType(arg) != ARG_TYPE_STRING &&
|
|
|
|
arg_getType(arg) != ARG_TYPE_BYTES) {
|
|
|
|
obj_setSysOut(self,
|
|
|
|
"TypeError: int() can't convert non-string with "
|
|
|
|
"explicit base");
|
|
|
|
obj_setErrorCode(self, 1);
|
|
|
|
return _PIKA_INT_ERR;
|
|
|
|
}
|
|
|
|
iBase = (int)pikaTuple_getInt(base, 0);
|
|
|
|
}
|
|
|
|
if (_transeInt(arg, iBase, &res) == PIKA_RES_OK) {
|
2023-02-18 16:35:03 +08:00
|
|
|
return res;
|
2022-05-27 10:29:57 +08:00
|
|
|
}
|
2023-02-18 16:35:03 +08:00
|
|
|
obj_setSysOut(self, "ValueError: invalid literal for int()");
|
2021-11-20 09:28:21 +08:00
|
|
|
obj_setErrorCode(self, 1);
|
2023-02-18 16:35:03 +08:00
|
|
|
return _PIKA_INT_ERR;
|
2021-12-24 22:44:56 +08:00
|
|
|
}
|
|
|
|
|
2023-02-18 16:35:03 +08:00
|
|
|
PIKA_BOOL PikaStdLib_SysObj_bool(PikaObj* self, Arg* arg) {
|
2023-03-17 14:28:10 +08:00
|
|
|
int64_t res = 0;
|
|
|
|
if (_transeInt(arg, 10, &res) == PIKA_RES_OK) {
|
2023-02-18 16:35:03 +08:00
|
|
|
return res ? PIKA_TRUE : PIKA_FALSE;
|
|
|
|
}
|
|
|
|
obj_setSysOut(self, "ValueError: invalid literal for bool()");
|
|
|
|
obj_setErrorCode(self, 1);
|
|
|
|
return _PIKA_BOOL_ERR;
|
2023-01-23 14:19:19 +08:00
|
|
|
}
|
|
|
|
|
2022-01-09 00:12:38 +08:00
|
|
|
char* PikaStdLib_SysObj_str(PikaObj* self, Arg* arg) {
|
2023-01-26 15:58:58 +08:00
|
|
|
// if (arg_getType(arg) == ARG_TYPE_BYTES) {
|
|
|
|
// return obj_cacheStr(self, (char*)arg_getBytes(arg));
|
|
|
|
// }
|
2023-01-23 23:53:21 +08:00
|
|
|
Arg* arg_str = arg_toStrArg(arg);
|
|
|
|
if (NULL == arg_str) {
|
|
|
|
obj_setSysOut(self, "Error: convert to str type failed.");
|
|
|
|
obj_setErrorCode(self, 1);
|
|
|
|
return NULL;
|
2022-05-25 13:57:02 +08:00
|
|
|
}
|
2023-01-23 23:53:21 +08:00
|
|
|
char* str = obj_cacheStr(self, arg_getStr(arg_str));
|
|
|
|
arg_deinit(arg_str);
|
|
|
|
return str;
|
2022-01-09 00:12:38 +08:00
|
|
|
}
|
|
|
|
|
2021-12-27 21:57:08 +08:00
|
|
|
Arg* PikaStdLib_SysObj_iter(PikaObj* self, Arg* arg) {
|
2022-09-19 09:53:27 +08:00
|
|
|
/* object */
|
2023-03-06 14:39:04 +08:00
|
|
|
PIKA_BOOL bIsTemp = PIKA_FALSE;
|
|
|
|
PikaObj* oArg = _arg_to_obj(arg, &bIsTemp);
|
|
|
|
NewFun _clsptr = (NewFun)oArg->constructor;
|
2022-09-19 09:53:27 +08:00
|
|
|
if (_clsptr == New_PikaStdLib_RangeObj) {
|
|
|
|
/* found RangeObj, return directly */
|
2021-12-27 23:54:31 +08:00
|
|
|
return arg_copy(arg);
|
2021-12-27 23:17:21 +08:00
|
|
|
}
|
2023-03-06 14:39:04 +08:00
|
|
|
/* clang-format off */
|
|
|
|
PIKA_PYTHON(
|
|
|
|
@res_iter = __iter__()
|
|
|
|
)
|
|
|
|
/* clang-format on */
|
2022-09-19 09:53:27 +08:00
|
|
|
const uint8_t bytes[] = {
|
2022-11-08 22:07:06 +08:00
|
|
|
0x08, 0x00, 0x00, 0x00, /* instruct array size */
|
2022-09-19 09:53:27 +08:00
|
|
|
0x00, 0x82, 0x01, 0x00, 0x00, 0x04, 0x0a, 0x00, /* instruct array */
|
2023-03-06 14:39:04 +08:00
|
|
|
0x14, 0x00, 0x00, 0x00, /* const pool size */
|
|
|
|
0x00, 0x5f, 0x5f, 0x69, 0x74, 0x65, 0x72, 0x5f, 0x5f, 0x00, 0x40,
|
|
|
|
0x72, 0x65, 0x73, 0x5f, 0x69, 0x74, 0x65, 0x72, 0x00, /* const pool */
|
2022-09-19 09:53:27 +08:00
|
|
|
};
|
2023-03-08 22:28:19 +08:00
|
|
|
Arg* res = pikaVM_runByteCodeReturn(oArg, (uint8_t*)bytes, "@res_iter");
|
2023-03-06 14:39:04 +08:00
|
|
|
if (bIsTemp) {
|
|
|
|
obj_refcntDec(oArg);
|
2021-12-27 23:17:21 +08:00
|
|
|
}
|
2022-09-19 09:53:27 +08:00
|
|
|
return res;
|
2021-12-24 22:44:56 +08:00
|
|
|
}
|
2021-12-28 00:49:13 +08:00
|
|
|
|
2022-09-12 20:01:30 +08:00
|
|
|
Arg* PikaStdLib_SysObj_range(PikaObj* self, PikaTuple* ax) {
|
2021-12-27 23:27:19 +08:00
|
|
|
/* set template arg to create rangeObj */
|
2023-03-10 21:39:04 +08:00
|
|
|
Arg* aRangeObj = arg_newDirectObj(New_PikaStdLib_RangeObj);
|
|
|
|
PikaObj* oRangeObj = arg_getPtr(aRangeObj);
|
|
|
|
RangeData tRangeData = {0};
|
2022-11-19 19:11:34 +08:00
|
|
|
if (pikaTuple_getSize(ax) == 1) {
|
2022-09-12 20:01:30 +08:00
|
|
|
int start = 0;
|
2022-11-19 19:11:34 +08:00
|
|
|
int end = arg_getInt(pikaTuple_getArg(ax, 0));
|
2023-03-10 21:39:04 +08:00
|
|
|
tRangeData.start = start;
|
|
|
|
tRangeData.end = end;
|
|
|
|
tRangeData.step = 1;
|
2022-11-19 19:11:34 +08:00
|
|
|
} else if (pikaTuple_getSize(ax) == 2) {
|
|
|
|
int start = arg_getInt(pikaTuple_getArg(ax, 0));
|
|
|
|
int end = arg_getInt(pikaTuple_getArg(ax, 1));
|
2023-03-10 21:39:04 +08:00
|
|
|
tRangeData.start = start;
|
|
|
|
tRangeData.end = end;
|
|
|
|
tRangeData.step = 1;
|
2022-11-19 19:11:34 +08:00
|
|
|
} else if (pikaTuple_getSize(ax) == 3) {
|
|
|
|
int start = arg_getInt(pikaTuple_getArg(ax, 0));
|
|
|
|
int end = arg_getInt(pikaTuple_getArg(ax, 1));
|
|
|
|
int step = arg_getInt(pikaTuple_getArg(ax, 2));
|
2023-03-10 21:39:04 +08:00
|
|
|
tRangeData.start = start;
|
|
|
|
tRangeData.end = end;
|
|
|
|
tRangeData.step = step;
|
2022-09-12 20:01:30 +08:00
|
|
|
}
|
2023-03-10 21:39:04 +08:00
|
|
|
tRangeData.i = tRangeData.start;
|
|
|
|
obj_setStruct(oRangeObj, "_", tRangeData);
|
|
|
|
return aRangeObj;
|
2021-12-27 21:57:08 +08:00
|
|
|
}
|
2022-01-13 21:56:44 +08:00
|
|
|
|
2022-07-30 18:26:58 +08:00
|
|
|
Arg* PikaStdLib_SysObj___getitem__(PikaObj* self, Arg* obj, Arg* key) {
|
2023-03-11 13:14:54 +08:00
|
|
|
return _vm_get(NULL, self, key, obj);
|
2022-01-13 21:56:44 +08:00
|
|
|
}
|
2022-01-13 23:31:06 +08:00
|
|
|
|
2022-07-29 23:40:16 +08:00
|
|
|
Arg* PikaStdLib_SysObj___setitem__(PikaObj* self,
|
|
|
|
Arg* obj,
|
2022-07-30 18:26:58 +08:00
|
|
|
Arg* key,
|
2022-07-29 23:40:16 +08:00
|
|
|
Arg* val) {
|
2022-01-13 21:56:44 +08:00
|
|
|
ArgType obj_type = arg_getType(obj);
|
2022-03-02 10:34:33 +08:00
|
|
|
if (ARG_TYPE_STRING == obj_type) {
|
2022-01-18 21:55:08 +08:00
|
|
|
int index = arg_getInt(key);
|
|
|
|
char* str_val = arg_getStr(val);
|
|
|
|
char* str_pyload = arg_getStr(obj);
|
|
|
|
str_pyload[index] = str_val[0];
|
2022-07-20 10:32:01 +08:00
|
|
|
return arg_newStr(str_pyload);
|
2022-01-18 21:55:08 +08:00
|
|
|
}
|
2022-05-21 19:23:34 +08:00
|
|
|
if (ARG_TYPE_BYTES == obj_type) {
|
|
|
|
int index = arg_getInt(key);
|
2022-06-24 16:08:27 +08:00
|
|
|
uint8_t byte_val = 0;
|
|
|
|
if (ARG_TYPE_BYTES == arg_getType(val)) {
|
|
|
|
uint8_t* bytes_val = arg_getBytes(val);
|
|
|
|
byte_val = bytes_val[0];
|
|
|
|
}
|
|
|
|
if (ARG_TYPE_INT == arg_getType(val)) {
|
|
|
|
byte_val = arg_getInt(val);
|
|
|
|
}
|
2022-05-21 19:23:34 +08:00
|
|
|
uint8_t* bytes_pyload = arg_getBytes(obj);
|
|
|
|
size_t bytes_len = arg_getBytesSize(obj);
|
2022-06-24 16:08:27 +08:00
|
|
|
bytes_pyload[index] = byte_val;
|
2022-07-20 10:32:01 +08:00
|
|
|
return arg_newBytes(bytes_pyload, bytes_len);
|
2022-05-21 19:23:34 +08:00
|
|
|
}
|
2022-06-01 14:39:59 +08:00
|
|
|
if (argType_isObject(obj_type)) {
|
2022-01-13 21:56:44 +08:00
|
|
|
PikaObj* arg_obj = arg_getPtr(obj);
|
|
|
|
obj_setArg(arg_obj, "__key", key);
|
|
|
|
obj_setArg(arg_obj, "__val", val);
|
2022-07-29 23:40:16 +08:00
|
|
|
/* clang-format off */
|
|
|
|
PIKA_PYTHON(
|
|
|
|
__setitem__(__key, __val)
|
|
|
|
)
|
|
|
|
/* clang-format on */
|
2022-03-18 23:00:51 +08:00
|
|
|
const uint8_t bytes[] = {
|
2022-11-08 22:07:06 +08:00
|
|
|
0x0c, 0x00, 0x00, 0x00, /* instruct array size */
|
2022-03-18 23:00:51 +08:00
|
|
|
0x10, 0x81, 0x01, 0x00, 0x10, 0x01, 0x07, 0x00, 0x00, 0x02, 0x0d,
|
|
|
|
0x00,
|
|
|
|
/* instruct array */
|
2022-11-08 22:07:06 +08:00
|
|
|
0x19, 0x00, 0x00, 0x00, /* const pool size */
|
2022-03-18 23:00:51 +08:00
|
|
|
0x00, 0x5f, 0x5f, 0x6b, 0x65, 0x79, 0x00, 0x5f, 0x5f, 0x76, 0x61,
|
2022-07-29 23:40:16 +08:00
|
|
|
0x6c, 0x00, 0x5f, 0x5f, 0x73, 0x65, 0x74, 0x69, 0x74, 0x65, 0x6d,
|
|
|
|
0x5f, 0x5f, 0x00,
|
|
|
|
/* const pool */
|
2022-03-18 23:00:51 +08:00
|
|
|
};
|
|
|
|
pikaVM_runByteCode(arg_obj, (uint8_t*)bytes);
|
2022-07-20 10:32:01 +08:00
|
|
|
return arg_newRef(arg_obj);
|
2022-01-13 21:56:44 +08:00
|
|
|
}
|
2022-06-24 16:08:27 +08:00
|
|
|
return NULL;
|
2022-01-13 21:56:44 +08:00
|
|
|
}
|
2022-04-09 01:15:21 +08:00
|
|
|
|
|
|
|
int PikaStdLib_SysObj_len(PikaObj* self, Arg* arg) {
|
|
|
|
if (ARG_TYPE_STRING == arg_getType(arg)) {
|
|
|
|
return strGetSize(arg_getStr(arg));
|
|
|
|
}
|
2022-06-10 10:55:48 +08:00
|
|
|
if (ARG_TYPE_BYTES == arg_getType(arg)) {
|
|
|
|
return arg_getBytesSize(arg);
|
|
|
|
}
|
2022-06-24 18:18:06 +08:00
|
|
|
|
2023-03-01 21:23:33 +08:00
|
|
|
if (arg_isObject(arg)) {
|
2022-06-24 18:18:06 +08:00
|
|
|
PikaObj* arg_obj = arg_getPtr(arg);
|
|
|
|
Arg* method_arg = obj_getMethodArg(arg_obj, "__len__");
|
|
|
|
if (NULL != method_arg) {
|
|
|
|
arg_deinit(method_arg);
|
2023-03-06 14:39:04 +08:00
|
|
|
obj_removeArg(arg_obj, "@res_len");
|
2022-06-24 18:18:06 +08:00
|
|
|
/* clang-format off */
|
2023-03-06 14:39:04 +08:00
|
|
|
PIKA_PYTHON(
|
|
|
|
@res_len = __len__()
|
|
|
|
)
|
2022-06-24 18:18:06 +08:00
|
|
|
/* clang-format on */
|
|
|
|
const uint8_t bytes[] = {
|
2022-11-08 22:07:06 +08:00
|
|
|
0x08, 0x00, 0x00, 0x00, /* instruct array size */
|
2022-06-24 18:18:06 +08:00
|
|
|
0x00, 0x82, 0x01, 0x00, 0x00, 0x04, 0x09, 0x00, /* instruct
|
|
|
|
array */
|
2023-03-06 14:39:04 +08:00
|
|
|
0x12, 0x00, 0x00, 0x00, /* const pool size */
|
|
|
|
0x00, 0x5f, 0x5f, 0x6c, 0x65, 0x6e, 0x5f, 0x5f, 0x00, 0x40,
|
|
|
|
0x72, 0x65, 0x73, 0x5f, 0x6c, 0x65, 0x6e, 0x00, /* const pool */
|
2022-06-24 18:18:06 +08:00
|
|
|
};
|
|
|
|
pikaVM_runByteCode(arg_obj, (uint8_t*)bytes);
|
2023-03-06 14:39:04 +08:00
|
|
|
return obj_getInt(arg_obj, "@res_len");
|
2022-06-24 18:18:06 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-04-09 01:15:21 +08:00
|
|
|
obj_setErrorCode(self, 1);
|
|
|
|
__platform_printf("[Error] len: arg type not support\r\n");
|
|
|
|
return -1;
|
|
|
|
}
|
2022-04-13 12:03:10 +08:00
|
|
|
|
2022-09-19 09:53:27 +08:00
|
|
|
Arg* PikaStdLib_SysObj_list(PikaObj* self, PikaTuple* val) {
|
2022-07-14 08:36:02 +00:00
|
|
|
#if PIKA_BUILTIN_STRUCT_ENABLE
|
2022-11-19 19:11:34 +08:00
|
|
|
if (1 == pikaTuple_getSize(val)) {
|
|
|
|
Arg* in = pikaTuple_getArg(val, 0);
|
2022-09-19 09:53:27 +08:00
|
|
|
obj_setArg(self, "__list", in);
|
|
|
|
/* clang-format off */
|
|
|
|
PIKA_PYTHON(
|
2023-03-06 14:39:04 +08:00
|
|
|
@res_list = []
|
2022-09-19 09:53:27 +08:00
|
|
|
for __item in __list:
|
2023-03-06 14:39:04 +08:00
|
|
|
@res_list.append(__item)
|
2022-09-19 09:53:27 +08:00
|
|
|
del __item
|
|
|
|
del __list
|
2023-03-06 14:39:04 +08:00
|
|
|
|
2022-09-19 09:53:27 +08:00
|
|
|
)
|
|
|
|
/* clang-format on */
|
|
|
|
const uint8_t bytes[] = {
|
2022-11-08 22:07:06 +08:00
|
|
|
0x3c, 0x00, 0x00, 0x00, /* instruct array size */
|
2023-03-06 14:39:04 +08:00
|
|
|
0x00, 0x95, 0x00, 0x00, 0x00, 0x04, 0x01, 0x00, 0x10, 0x81, 0x0b,
|
|
|
|
0x00, 0x00, 0x02, 0x12, 0x00, 0x00, 0x04, 0x17, 0x00, 0x00, 0x82,
|
|
|
|
0x1b, 0x00, 0x00, 0x04, 0x28, 0x00, 0x00, 0x0d, 0x28, 0x00, 0x00,
|
|
|
|
0x07, 0x2f, 0x00, 0x11, 0x81, 0x28, 0x00, 0x01, 0x02, 0x31, 0x00,
|
|
|
|
0x00, 0x86, 0x42, 0x00, 0x00, 0x8c, 0x17, 0x00, 0x00, 0x8c, 0x28,
|
|
|
|
0x00, 0x00, 0x8c, 0x0b, 0x00,
|
2022-09-19 09:53:27 +08:00
|
|
|
/* instruct array */
|
2023-03-06 14:39:04 +08:00
|
|
|
0x45, 0x00, 0x00, 0x00, /* const pool size */
|
|
|
|
0x00, 0x40, 0x72, 0x65, 0x73, 0x5f, 0x6c, 0x69, 0x73, 0x74, 0x00,
|
|
|
|
0x5f, 0x5f, 0x6c, 0x69, 0x73, 0x74, 0x00, 0x69, 0x74, 0x65, 0x72,
|
|
|
|
0x00, 0x24, 0x6c, 0x30, 0x00, 0x24, 0x6c, 0x30, 0x2e, 0x5f, 0x5f,
|
|
|
|
0x6e, 0x65, 0x78, 0x74, 0x5f, 0x5f, 0x00, 0x5f, 0x5f, 0x69, 0x74,
|
|
|
|
0x65, 0x6d, 0x00, 0x32, 0x00, 0x40, 0x72, 0x65, 0x73, 0x5f, 0x6c,
|
|
|
|
0x69, 0x73, 0x74, 0x2e, 0x61, 0x70, 0x70, 0x65, 0x6e, 0x64, 0x00,
|
|
|
|
0x2d, 0x31, 0x00, /* const pool */
|
2022-09-19 09:53:27 +08:00
|
|
|
};
|
2023-03-08 22:28:19 +08:00
|
|
|
return pikaVM_runByteCodeReturn(self, (uint8_t*)bytes, "@res_list");
|
2022-09-19 09:53:27 +08:00
|
|
|
}
|
2022-04-25 15:01:58 +08:00
|
|
|
PikaObj* New_PikaStdData_List(Args * args);
|
2022-06-24 03:30:56 +00:00
|
|
|
return arg_newDirectObj(New_PikaStdData_List);
|
2022-07-01 23:40:29 +08:00
|
|
|
#else
|
2022-04-14 15:58:24 +08:00
|
|
|
obj_setErrorCode(self, 1);
|
2022-04-14 16:12:18 +08:00
|
|
|
__platform_printf("[Error] built-in list is not enabled.\r\n");
|
2022-09-19 09:53:27 +08:00
|
|
|
return arg_newNull();
|
2023-01-29 12:11:43 +08:00
|
|
|
#endif
|
2022-04-14 16:12:18 +08:00
|
|
|
}
|
|
|
|
|
2022-09-28 10:55:36 +08:00
|
|
|
Arg* PikaStdLib_SysObj_dict(PikaObj* self, PikaTuple* val) {
|
2022-07-14 08:36:02 +00:00
|
|
|
#if PIKA_BUILTIN_STRUCT_ENABLE
|
2022-04-25 15:01:58 +08:00
|
|
|
PikaObj* New_PikaStdData_Dict(Args * args);
|
2022-06-24 03:30:56 +00:00
|
|
|
return arg_newDirectObj(New_PikaStdData_Dict);
|
2022-07-01 23:40:29 +08:00
|
|
|
#else
|
2022-04-14 16:12:18 +08:00
|
|
|
obj_setErrorCode(self, 1);
|
|
|
|
__platform_printf("[Error] built-in dist is not enabled.\r\n");
|
2022-07-20 10:32:01 +08:00
|
|
|
return arg_newNull();
|
2022-07-01 23:40:29 +08:00
|
|
|
#endif
|
2022-04-13 12:03:10 +08:00
|
|
|
}
|
2022-05-25 15:42:25 +08:00
|
|
|
|
2023-01-24 00:20:43 +08:00
|
|
|
Arg* PikaStdLib_SysObj_tuple(PikaObj* self, Arg* val) {
|
|
|
|
#if PIKA_BUILTIN_STRUCT_ENABLE
|
|
|
|
obj_setErrorCode(self, 1);
|
|
|
|
__platform_printf("Error: tuple() is not supported.\r\n");
|
|
|
|
return arg_newNull();
|
|
|
|
#else
|
|
|
|
obj_setErrorCode(self, 1);
|
|
|
|
__platform_printf("[Error] built-in tuple is not enabled.\r\n");
|
|
|
|
return arg_newNull();
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2022-05-25 15:53:39 +08:00
|
|
|
char* PikaStdLib_SysObj_hex(PikaObj* self, int val) {
|
2022-05-25 15:42:25 +08:00
|
|
|
char buff[PIKA_SPRINTF_BUFF_SIZE] = {0};
|
2022-07-15 10:47:24 +08:00
|
|
|
if (val >= 0) {
|
2022-05-25 15:42:25 +08:00
|
|
|
__platform_sprintf(buff, "0x%02x", val);
|
2022-05-25 15:53:39 +08:00
|
|
|
} else {
|
2022-05-25 15:42:25 +08:00
|
|
|
__platform_sprintf(buff, "-0x%02x", -val);
|
|
|
|
}
|
|
|
|
/* load the string from stack to heap */
|
|
|
|
obj_setStr(self, "__buf", buff);
|
|
|
|
return obj_getStr(self, "__buf");
|
|
|
|
}
|
2022-05-25 15:53:39 +08:00
|
|
|
|
|
|
|
int PikaStdLib_SysObj_ord(PikaObj* self, char* val) {
|
|
|
|
return (int)val[0];
|
|
|
|
}
|
|
|
|
|
|
|
|
char* PikaStdLib_SysObj_chr(PikaObj* self, int val) {
|
|
|
|
char buff[PIKA_SPRINTF_BUFF_SIZE] = {0};
|
|
|
|
char to_str[] = "0";
|
|
|
|
to_str[0] = val;
|
|
|
|
__platform_sprintf(buff, "%s", to_str);
|
|
|
|
/* load the string from stack to heap */
|
|
|
|
obj_setStr(self, "__buf", buff);
|
|
|
|
return obj_getStr(self, "__buf");
|
|
|
|
}
|
2022-05-26 15:46:34 +08:00
|
|
|
|
|
|
|
Arg* PikaStdLib_SysObj_bytes(PikaObj* self, Arg* val) {
|
|
|
|
ArgType type = arg_getType(val);
|
|
|
|
if (ARG_TYPE_INT == type) {
|
|
|
|
int size = arg_getInt(val);
|
|
|
|
/* src is NULL so the bytes are all '\0' */
|
2022-07-20 10:32:01 +08:00
|
|
|
Arg* bytes = arg_newBytes(NULL, size);
|
2022-05-26 15:46:34 +08:00
|
|
|
return bytes;
|
|
|
|
}
|
|
|
|
if (ARG_TYPE_BYTES == type) {
|
|
|
|
return arg_copy(val);
|
|
|
|
}
|
|
|
|
if (ARG_TYPE_STRING == type) {
|
|
|
|
int size = strGetSize(arg_getStr(val));
|
2022-07-20 10:32:01 +08:00
|
|
|
Arg* bytes = arg_newBytes((uint8_t*)arg_getStr(val), size);
|
2022-05-26 15:46:34 +08:00
|
|
|
return bytes;
|
|
|
|
}
|
2022-09-19 10:01:16 +08:00
|
|
|
#if !PIKA_NANO_ENABLE
|
|
|
|
if (argType_isObject(type)) {
|
|
|
|
PikaObj* obj = arg_getPtr(val);
|
|
|
|
PikaObj* New_PikaStdData_List(Args * args);
|
|
|
|
PikaObj* New_PikaStdData_Tuple(Args * args);
|
|
|
|
if (obj->constructor == New_PikaStdData_List ||
|
|
|
|
obj->constructor == New_PikaStdData_Tuple) {
|
|
|
|
PikaList* list = obj_getPtr(obj, "list");
|
2022-11-19 19:11:34 +08:00
|
|
|
Arg* bytes = arg_newBytes(NULL, pikaList_getSize(list));
|
2022-09-19 10:01:16 +08:00
|
|
|
uint8_t* bytes_raw = arg_getBytes(bytes);
|
2022-11-19 19:11:34 +08:00
|
|
|
for (size_t i = 0; i < pikaList_getSize(list); i++) {
|
|
|
|
bytes_raw[i] = (uint8_t)pikaList_getInt(list, i);
|
2022-09-19 10:01:16 +08:00
|
|
|
}
|
|
|
|
return bytes;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
2022-05-26 15:46:34 +08:00
|
|
|
obj_setErrorCode(self, 1);
|
|
|
|
__platform_printf("Error: input arg type not supported.\r\n");
|
2022-07-20 10:32:01 +08:00
|
|
|
return arg_newNull();
|
2022-05-26 15:46:34 +08:00
|
|
|
}
|
2022-05-26 17:03:58 +08:00
|
|
|
|
2022-09-02 00:13:01 +08:00
|
|
|
void PikaStdLib_SysObj_print(PikaObj* self, PikaTuple* val, PikaDict* ops) {
|
2022-11-19 19:11:34 +08:00
|
|
|
int arg_size = pikaTuple_getSize(val);
|
|
|
|
char* end = pikaDict_getStr(ops, "end");
|
2022-11-17 12:48:10 +08:00
|
|
|
if (NULL == end) {
|
|
|
|
/* default */
|
|
|
|
end = "\r\n";
|
|
|
|
}
|
|
|
|
if (arg_size == 1) {
|
2023-01-23 23:53:21 +08:00
|
|
|
arg_print(pikaTuple_getArg(val, 0), PIKA_FALSE, end);
|
2022-11-17 12:48:10 +08:00
|
|
|
return;
|
|
|
|
}
|
2022-11-17 12:30:37 +08:00
|
|
|
Arg* print_out_arg = NULL;
|
2022-06-11 14:56:51 +00:00
|
|
|
PIKA_BOOL is_get_print = PIKA_FALSE;
|
|
|
|
for (int i = 0; i < arg_size; i++) {
|
2022-11-19 19:11:34 +08:00
|
|
|
Arg* arg = pikaTuple_getArg(val, i);
|
2023-01-23 23:53:21 +08:00
|
|
|
Arg* item_arg_str = arg_toStrArg(arg);
|
|
|
|
if (NULL != item_arg_str) {
|
2022-06-11 14:56:51 +00:00
|
|
|
is_get_print = PIKA_TRUE;
|
2022-11-17 12:30:37 +08:00
|
|
|
if (NULL == print_out_arg) {
|
|
|
|
print_out_arg = arg_newStr("");
|
|
|
|
}
|
2023-01-23 23:53:21 +08:00
|
|
|
print_out_arg =
|
|
|
|
arg_strAppend(print_out_arg, arg_getStr(item_arg_str));
|
2022-06-11 14:56:51 +00:00
|
|
|
if (i < arg_size - 1) {
|
|
|
|
print_out_arg = arg_strAppend(print_out_arg, " ");
|
|
|
|
}
|
2023-01-23 23:53:21 +08:00
|
|
|
arg_deinit(item_arg_str);
|
2022-06-11 14:56:51 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (PIKA_TRUE == is_get_print) {
|
2022-11-17 12:48:10 +08:00
|
|
|
__platform_printf("%s%s", arg_getStr(print_out_arg), end);
|
2022-11-17 12:30:37 +08:00
|
|
|
}
|
|
|
|
if (NULL != print_out_arg) {
|
|
|
|
arg_deinit(print_out_arg);
|
2022-06-11 14:56:51 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-14 03:20:17 +00:00
|
|
|
char* PikaStdLib_SysObj_cformat(PikaObj* self, char* fmt, PikaTuple* var) {
|
2022-07-11 06:42:12 +00:00
|
|
|
#if PIKA_SYNTAX_FORMAT_ENABLE
|
2022-06-14 03:20:17 +00:00
|
|
|
Args buffs = {0};
|
|
|
|
pikaMemMaxReset();
|
|
|
|
char* res = strsFormatList(&buffs, fmt, &var->super);
|
|
|
|
obj_setStr(self, "_buf", res);
|
|
|
|
res = obj_getStr(self, "_buf");
|
|
|
|
strsDeinit(&buffs);
|
|
|
|
return res;
|
2022-07-06 15:13:23 +08:00
|
|
|
#else
|
2022-07-01 23:10:51 +08:00
|
|
|
obj_setErrorCode(self, 1);
|
2022-07-11 03:14:14 +00:00
|
|
|
__platform_printf("[Error] PIKA_SYNTAX_FORMAT_ENABLE is not enabled.\r\n");
|
2022-07-01 23:10:51 +08:00
|
|
|
return NULL;
|
2022-07-06 15:13:23 +08:00
|
|
|
#endif
|
2022-06-14 03:20:17 +00:00
|
|
|
}
|
2022-06-14 12:06:56 +08:00
|
|
|
|
|
|
|
int PikaStdLib_SysObj_id(PikaObj* self, Arg* obj) {
|
|
|
|
uintptr_t ptr = 0;
|
2023-03-01 21:23:33 +08:00
|
|
|
if (arg_isObject(obj)) {
|
2022-06-14 12:06:56 +08:00
|
|
|
ptr = (uintptr_t)arg_getPtr(obj);
|
|
|
|
} else {
|
|
|
|
ptr = (uintptr_t)obj;
|
|
|
|
}
|
|
|
|
return ptr & (0x7FFFFFFF);
|
|
|
|
}
|
2022-07-15 02:06:23 +00:00
|
|
|
|
2022-07-30 18:26:58 +08:00
|
|
|
PikaObj* PikaStdLib_SysObj_open(PikaObj* self, char* path, char* mode) {
|
2022-07-15 02:06:23 +00:00
|
|
|
#if PIKA_FILEIO_ENABLE
|
|
|
|
PikaObj* file = newNormalObj(New_PikaStdData_FILEIO);
|
2022-08-06 17:59:32 +08:00
|
|
|
if (0 != PikaStdData_FILEIO_init(file, path, mode)) {
|
|
|
|
obj_setErrorCode(self, 1);
|
|
|
|
__platform_printf("[Error] open: can not open file.\r\n");
|
|
|
|
obj_deinit(file);
|
|
|
|
return NULL;
|
|
|
|
}
|
2022-07-15 02:06:23 +00:00
|
|
|
return file;
|
|
|
|
#else
|
|
|
|
obj_setErrorCode(self, 1);
|
|
|
|
__platform_printf("[Error] PIKA_FILEIO_ENABLE is not enabled.\r\n");
|
|
|
|
return NULL;
|
|
|
|
#endif
|
|
|
|
}
|
2022-08-10 11:49:54 +08:00
|
|
|
|
|
|
|
/* __dir_each */
|
2023-03-09 13:56:17 +08:00
|
|
|
int32_t __dir_each(Arg* argEach, void* context) {
|
|
|
|
PikaObj* list = args_getPtr((Args*)context, "list");
|
2022-08-10 11:49:54 +08:00
|
|
|
if (argType_isCallable(arg_getType(argEach))) {
|
2023-01-22 23:25:20 +08:00
|
|
|
char name_buff[PIKA_LINE_BUFF_SIZE] = {0};
|
2022-08-10 11:49:54 +08:00
|
|
|
char* method_name =
|
|
|
|
methodArg_getName(argEach, name_buff, sizeof(name_buff));
|
|
|
|
Arg* arg_str = arg_newStr(method_name);
|
|
|
|
__vm_List_append(list, arg_str);
|
|
|
|
arg_deinit(arg_str);
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2023-01-22 23:16:38 +08:00
|
|
|
PikaObj* PikaStdLib_SysObj_dir(PikaObj* self, Arg* arg) {
|
2023-03-01 21:23:33 +08:00
|
|
|
if (!arg_isObject(arg)) {
|
2023-01-22 23:16:38 +08:00
|
|
|
obj_setErrorCode(self, 1);
|
2023-01-22 23:25:20 +08:00
|
|
|
__platform_printf("[Error] dir: not support type.\r\n");
|
2023-01-22 23:16:38 +08:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
PikaObj* obj = arg_getPtr(arg);
|
2022-08-10 11:49:54 +08:00
|
|
|
PikaObj* New_PikaStdData_List(Args * args);
|
|
|
|
PikaObj* list = newNormalObj(New_PikaStdData_List);
|
|
|
|
__vm_List___init__(list);
|
|
|
|
Args* context = New_args(NULL);
|
|
|
|
args_setPtr(context, "list", list);
|
|
|
|
args_foreach(obj->list, __dir_each, context);
|
|
|
|
args_deinit(context);
|
|
|
|
return list;
|
|
|
|
}
|
2022-08-10 12:07:32 +08:00
|
|
|
|
|
|
|
void PikaStdLib_SysObj_exec(PikaObj* self, char* code) {
|
|
|
|
#if PIKA_EXEC_ENABLE
|
|
|
|
obj_run(self, code);
|
|
|
|
#else
|
|
|
|
obj_setErrorCode(self, 1);
|
|
|
|
__platform_printf("[Error] PIKA_EXEC_ENABLE is not enabled.\r\n");
|
|
|
|
#endif
|
|
|
|
}
|
2022-08-11 17:21:01 +08:00
|
|
|
|
|
|
|
Arg* PikaStdLib_SysObj_getattr(PikaObj* self, PikaObj* obj, char* name) {
|
|
|
|
Arg* res = NULL;
|
|
|
|
if (NULL == obj) {
|
|
|
|
obj_setErrorCode(self, 1);
|
|
|
|
__platform_printf("[Error] getattr: can not get attr of NULL.\r\n");
|
|
|
|
return NULL;
|
|
|
|
}
|
2022-09-26 11:03:14 +08:00
|
|
|
Arg* arg = obj_getArg(obj, name);
|
|
|
|
if (NULL == arg) {
|
|
|
|
arg = obj_getMethodArg(obj, name);
|
|
|
|
}
|
|
|
|
if (NULL != arg) {
|
|
|
|
res = arg_copy(arg);
|
2023-03-01 19:28:16 +08:00
|
|
|
methodArg_setHostObj(res, obj);
|
2022-09-26 11:03:14 +08:00
|
|
|
}
|
2023-03-01 19:28:16 +08:00
|
|
|
return res;
|
2022-08-11 17:21:01 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void PikaStdLib_SysObj_setattr(PikaObj* self,
|
|
|
|
PikaObj* obj,
|
|
|
|
char* name,
|
|
|
|
Arg* val) {
|
|
|
|
if (NULL == obj) {
|
|
|
|
obj_setErrorCode(self, 1);
|
|
|
|
__platform_printf("[Error] setattr: obj is null.\r\n");
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
obj_setArg(obj, name, val);
|
|
|
|
exit:
|
|
|
|
return;
|
|
|
|
}
|
2022-09-14 13:46:19 +08:00
|
|
|
|
2022-09-19 09:53:27 +08:00
|
|
|
void PikaStdLib_SysObj_exit(PikaObj* self) {
|
2022-09-14 13:46:19 +08:00
|
|
|
pks_vm_exit();
|
|
|
|
}
|
2022-09-26 10:14:01 +08:00
|
|
|
|
|
|
|
int PikaStdLib_SysObj_hasattr(PikaObj* self, PikaObj* obj, char* name) {
|
|
|
|
if (NULL == obj) {
|
|
|
|
obj_setErrorCode(self, 1);
|
|
|
|
__platform_printf("[Error] hasattr: obj is null.\r\n");
|
|
|
|
return 0;
|
|
|
|
}
|
2022-09-26 11:03:14 +08:00
|
|
|
if (obj_isArgExist(obj, name)) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
Arg* method = obj_getMethodArg(obj, name);
|
|
|
|
if (NULL != method) {
|
|
|
|
arg_deinit(method);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
return 0;
|
2022-09-26 10:14:01 +08:00
|
|
|
}
|
2022-10-01 14:03:57 +08:00
|
|
|
|
|
|
|
Arg* PikaStdLib_SysObj_eval(PikaObj* self, char* code) {
|
|
|
|
Args buffs = {0};
|
|
|
|
char* cmd = strsAppend(&buffs, "@res = ", code);
|
|
|
|
obj_run(self, cmd);
|
|
|
|
Arg* res = arg_copy(obj_getArg(self, "@res"));
|
|
|
|
strsDeinit(&buffs);
|
|
|
|
obj_removeArg(self, "@res");
|
|
|
|
return res;
|
|
|
|
}
|
2022-10-09 19:46:05 +08:00
|
|
|
|
2022-11-08 12:37:33 +08:00
|
|
|
static enum shellCTRL __obj_shellLineHandler_input(PikaObj* self,
|
2022-11-08 22:07:06 +08:00
|
|
|
char* input_line,
|
|
|
|
struct ShellConfig* cfg) {
|
2022-10-09 19:46:05 +08:00
|
|
|
cfg->context = arg_newStr(input_line);
|
2022-11-08 12:37:33 +08:00
|
|
|
return SHELL_CTRL_EXIT;
|
2022-10-09 19:46:05 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
char* PikaStdLib_SysObj_input(PikaObj* self, PikaTuple* info) {
|
2022-10-21 17:14:06 +08:00
|
|
|
struct ShellConfig cfg = {
|
|
|
|
.prefix = "",
|
|
|
|
.context = NULL,
|
|
|
|
.handler = __obj_shellLineHandler_input,
|
2022-10-25 14:32:43 +08:00
|
|
|
.fn_getchar = __platform_getchar,
|
2022-10-21 17:14:06 +08:00
|
|
|
};
|
2022-11-19 19:11:34 +08:00
|
|
|
if (pikaTuple_getSize(info) > 0) {
|
|
|
|
__platform_printf("%s", pikaTuple_getStr(info, 0));
|
2022-10-09 19:46:05 +08:00
|
|
|
}
|
2022-10-25 11:52:42 +08:00
|
|
|
_temp__do_pikaScriptShell(self, &cfg);
|
2022-10-09 19:46:05 +08:00
|
|
|
char* res = obj_cacheStr(self, arg_getStr(cfg.context));
|
|
|
|
arg_deinit(cfg.context);
|
|
|
|
return res;
|
|
|
|
}
|
2022-11-30 00:39:01 +08:00
|
|
|
|
|
|
|
extern volatile PikaObj* __pikaMain;
|
|
|
|
void PikaStdLib_SysObj_help(PikaObj* self, char* name) {
|
|
|
|
if (strEqu(name, "modules")) {
|
|
|
|
obj_printModules((PikaObj*)__pikaMain);
|
|
|
|
}
|
|
|
|
}
|
2023-01-19 17:44:22 +08:00
|
|
|
|
2023-01-22 23:16:38 +08:00
|
|
|
void PikaStdLib_SysObj_reboot(PikaObj* self) {
|
2023-01-19 17:44:22 +08:00
|
|
|
pika_platform_reboot();
|
|
|
|
}
|
2023-02-26 17:48:19 +08:00
|
|
|
|
|
|
|
void PikaStdLib_SysObj_clear(PikaObj* self) {
|
|
|
|
pika_platform_clear();
|
|
|
|
}
|
2023-03-09 13:56:17 +08:00
|
|
|
|
2023-03-10 21:39:04 +08:00
|
|
|
void PikaStdLib_SysObj_gcdump(PikaObj* self) {
|
2023-03-09 13:56:17 +08:00
|
|
|
pikaGC_markDump();
|
|
|
|
}
|