41 lines
1.1 KiB
C
Raw Normal View History

2022-10-09 14:18:26 +08:00
#include "PikaMain.h"
#include "PikaParser.h"
#include "PikaStdLib_MemChecker.h"
#include "PikaVM.h"
#include "dataArgs.h"
#include "dataMemory.h"
#include "dataStrs.h"
#include "pikaScript.h"
#include <time.h>
2022-10-13 10:44:37 +08:00
void __platform_printf(char* format, ...) {
}
2022-10-09 14:18:26 +08:00
int main(void) {
PikaObj* pikaMain = newRootObj("pikaMain", New_PikaMain);
extern unsigned char pikaModules_py_a[];
obj_linkLibrary(pikaMain, pikaModules_py_a);
/* run */
__platform_printf("BEGIN\r\n");
/* clang-format off */
clock_t start = clock();
pikaVM_run(pikaMain,
2022-10-13 10:44:37 +08:00
"for i in range(500000):\n"
2022-10-09 14:18:26 +08:00
" print(i)"
);
clock_t end = clock();
/* deinit */
obj_deinit(pikaMain);
#if PIKA_ARG_CACHE_ENABLE
extern PikaMemInfo pikaMemInfo;
printf("[ Info]: alloc times: %d, cached times: %d (%0.2f%%)\r\n",
pikaMemInfo.alloc_times, pikaMemInfo.alloc_times_cache,
((float)pikaMemInfo.alloc_times_cache /
(float)pikaMemInfo.alloc_times) *
100.0);
#endif
printf("[ Info]: time elapsed: %lfs\r\n",
((double)end - (double)start) / (double)CLOCKS_PER_SEC);
return 0;
}