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-19 13:16:50 +08:00
|
|
|
#ifndef __platform_printf
|
2022-10-13 10:44:37 +08:00
|
|
|
void __platform_printf(char* format, ...) {
|
|
|
|
}
|
2022-10-19 13:16:50 +08:00
|
|
|
#endif
|
2022-10-13 10:44:37 +08:00
|
|
|
|
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
|
2023-03-06 14:39:04 +08:00
|
|
|
extern PikaMemInfo g_PikaMemInfo;
|
2022-10-09 14:18:26 +08:00
|
|
|
printf("[ Info]: alloc times: %d, cached times: %d (%0.2f%%)\r\n",
|
2023-03-06 14:39:04 +08:00
|
|
|
g_PikaMemInfo.alloc_times, g_PikaMemInfo.alloc_times_cache,
|
|
|
|
((float)g_PikaMemInfo.alloc_times_cache /
|
|
|
|
(float)g_PikaMemInfo.alloc_times) *
|
2022-10-09 14:18:26 +08:00
|
|
|
100.0);
|
|
|
|
#endif
|
|
|
|
printf("[ Info]: time elapsed: %lfs\r\n",
|
|
|
|
((double)end - (double)start) / (double)CLOCKS_PER_SEC);
|
|
|
|
return 0;
|
|
|
|
}
|