pikapython/package/PikaStdLib/PikaStdData_List.c

117 lines
3.3 KiB
C
Raw Normal View History

#include "PikaStdData_List.h"
2021-12-28 01:21:47 +08:00
#include "BaseObj.h"
2021-12-13 22:14:59 +08:00
#include "PikaObj.h"
#include "PikaStdData_Tuple.h"
#include "dataStrs.h"
2021-12-13 21:32:45 +08:00
void PikaStdData_List_append(PikaObj* self, Arg* arg) {
2023-06-18 00:03:16 +08:00
objList_append(self, arg);
2021-12-13 21:32:45 +08:00
}
void PikaStdData_List_set(PikaObj* self, int i, Arg* arg) {
2023-06-18 00:03:16 +08:00
return objList_set(self, i, arg);
2021-12-13 21:32:45 +08:00
}
2021-12-28 01:21:47 +08:00
void PikaStdData_List___setitem__(PikaObj* self, Arg* __key, Arg* __val) {
PikaStdData_List_set(self, obj_getInt(self, "__key"),
obj_getArg(self, "__val"));
2022-01-30 17:37:21 +08:00
}
2022-03-25 21:18:54 +08:00
void PikaStdData_List___init__(PikaObj* self) {
2023-06-18 00:03:16 +08:00
objList_init(self);
}
char* builtins_str(PikaObj* self, Arg* arg);
2023-06-18 00:03:16 +08:00
typedef struct {
Arg* buf;
int count;
} ListToStrContext;
2023-06-18 00:03:16 +08:00
int32_t listToStrEachHandle(PikaObj* self,
int itemIndex,
Arg* itemEach,
void* context) {
ListToStrContext* ctx = (ListToStrContext*)context;
char* item_str = builtins_str(self, itemEach);
if (ctx->count != 0) {
ctx->buf = arg_strAppend(ctx->buf, ", ");
}
if (arg_getType(itemEach) == ARG_TYPE_STRING) {
ctx->buf = arg_strAppend(ctx->buf, "'");
}
ctx->buf = arg_strAppend(ctx->buf, item_str);
if (arg_getType(itemEach) == ARG_TYPE_STRING) {
ctx->buf = arg_strAppend(ctx->buf, "'");
}
2023-06-18 00:03:16 +08:00
ctx->count++;
return 0;
}
char* PikaStdData_List___str__(PikaObj* self) {
ListToStrContext context;
context.buf = arg_newStr("[");
context.count = 0;
objList_forEach(self, listToStrEachHandle, &context);
context.buf = arg_strAppend(context.buf, "]");
obj_setStr(self, "_buf", arg_getStr(context.buf));
arg_deinit(context.buf);
return obj_getStr(self, "_buf");
}
2022-08-16 12:21:11 +08:00
void PikaStdData_List_reverse(PikaObj* self) {
PikaList* list = obj_getPtr(self, "list");
2022-11-19 19:11:34 +08:00
pikaList_reverse(list);
2022-08-16 12:21:11 +08:00
}
2022-08-16 17:40:11 +08:00
PikaObj* PikaStdData_List___add__(PikaObj* self, PikaObj* others) {
PikaObj* res = newNormalObj(New_PikaStdData_List);
PikaStdData_List___init__(res);
PikaList* list_res = obj_getPtr(res, "list");
PikaList* list1 = obj_getPtr(self, "list");
PikaList* list2 = obj_getPtr(others, "list");
2022-11-19 19:11:34 +08:00
for (size_t i = 0; i < pikaList_getSize(list1); i++) {
Arg* arg = pikaList_getArg(list1, i);
pikaList_append(list_res, arg);
2022-08-16 17:40:11 +08:00
}
2022-11-19 19:11:34 +08:00
for (size_t i = 0; i < pikaList_getSize(list2); i++) {
Arg* arg = pikaList_getArg(list2, i);
pikaList_append(list_res, arg);
2022-08-16 17:40:11 +08:00
}
return res;
}
2023-04-23 20:55:20 +08:00
void PikaStdData_List_insert(PikaObj* self, int i, Arg* arg) {
PikaList* list = obj_getPtr(self, "list");
2022-11-19 19:11:34 +08:00
if (PIKA_RES_OK != pikaList_insert(list, i, arg)) {
obj_setErrorCode(self, 1);
obj_setSysOut(self, "Error: index exceeded lengh of list.");
}
}
2023-04-23 20:55:20 +08:00
Arg* PikaStdData_List_pop(PikaObj* self, PikaTuple* index) {
int i = 0;
PikaList* list = obj_getPtr(self, "list");
2023-04-23 20:55:20 +08:00
if (pikaTuple_getSize(index) == 1) {
if (pikaTuple_getType(index, 0) == ARG_TYPE_INT) {
i = pikaTuple_getInt(index, 0);
} else {
obj_setErrorCode(self, 1);
obj_setSysOut(self, "Error: index must be int.");
return NULL;
}
return pikaList_pop_withIndex(list, i);
} else {
return pikaList_pop(list);
}
}
2023-04-23 20:55:20 +08:00
void PikaStdData_List_remove(PikaObj* self, Arg* val) {
PikaList* list = obj_getPtr(self, "list");
2022-11-19 19:11:34 +08:00
pikaList_remove(list, val);
}