feat add lua
All checks were successful
linux-mips64-gcc / linux-gcc-mips64el (Debug) (push) Successful in 1m53s
linux-x64-gcc / linux-gcc (Debug) (push) Successful in 1m46s
linux-mips64-gcc / linux-gcc-mips64el (Release) (push) Successful in 2m13s
linux-x64-gcc / linux-gcc (Release) (push) Successful in 1m49s
All checks were successful
linux-mips64-gcc / linux-gcc-mips64el (Debug) (push) Successful in 1m53s
linux-x64-gcc / linux-gcc (Debug) (push) Successful in 1m46s
linux-mips64-gcc / linux-gcc-mips64el (Release) (push) Successful in 2m13s
linux-x64-gcc / linux-gcc (Release) (push) Successful in 1m49s
This commit is contained in:
parent
17619b443b
commit
3c43c4ff58
7
3party/minilua/CMakeLists.txt
Normal file
7
3party/minilua/CMakeLists.txt
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
cmake_minimum_required(VERSION 3.10)
|
||||||
|
project(
|
||||||
|
minilua
|
||||||
|
VERSION 5.4.6
|
||||||
|
LANGUAGES C CXX)
|
||||||
|
add_library(minilua STATIC src/minilua.c)
|
||||||
|
target_include_directories(minilua PUBLIC src)
|
2
3party/minilua/src/minilua.c
Normal file
2
3party/minilua/src/minilua.c
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
#define LUA_IMPL
|
||||||
|
#include "minilua.h"
|
29240
3party/minilua/src/minilua.h
Normal file
29240
3party/minilua/src/minilua.h
Normal file
File diff suppressed because it is too large
Load Diff
@ -24,6 +24,7 @@ target_include_directories(benchmark_main PUBLIC src/)
|
|||||||
|
|
||||||
add_library(sled STATIC "")
|
add_library(sled STATIC "")
|
||||||
|
|
||||||
|
add_subdirectory(3party/minilua EXCLUDE_FROM_ALL)
|
||||||
add_subdirectory(3party/gperftools EXCLUDE_FROM_ALL)
|
add_subdirectory(3party/gperftools EXCLUDE_FROM_ALL)
|
||||||
add_subdirectory(3party/asyncplusplus EXCLUDE_FROM_ALL)
|
add_subdirectory(3party/asyncplusplus EXCLUDE_FROM_ALL)
|
||||||
# add_subdirectory(3party/cppuprofile EXCLUDE_FROM_ALL)
|
# add_subdirectory(3party/cppuprofile EXCLUDE_FROM_ALL)
|
||||||
@ -88,19 +89,18 @@ target_sources(
|
|||||||
src/sled/uri.cc)
|
src/sled/uri.cc)
|
||||||
# set(BUILD_RTTR_DYNAMIC OFF) set(BUILD_UNIT_TESTS OFF)
|
# set(BUILD_RTTR_DYNAMIC OFF) set(BUILD_UNIT_TESTS OFF)
|
||||||
# set(BUILD_WITH_STATIC_RUNTIME_LIBS ON) set(BUILD_WITH_DOCUMENTATION OFF)
|
# set(BUILD_WITH_STATIC_RUNTIME_LIBS ON) set(BUILD_WITH_DOCUMENTATION OFF)
|
||||||
# add_subdirectory(3party/rttr EXCLUDE_FROM_ALL)
|
# add_subdirectory(3party/rttr EXCLUDE_FROM_ALL) include(CheckCCompilerFlag)
|
||||||
include(CheckCCompilerFlag)
|
# check_c_compiler_flag("-Wl,--whole-archive" SUPPORT_COMPILE_WHOLE_ARCHIVE)
|
||||||
check_c_compiler_flag("-Wl,--whole-archive" SUPPORT_COMPILE_WHOLE_ARCHIVE)
|
# if(SUPPORT_COMPILE_WHOLE_ARCHIVE) set(WHOLE_ARCHIVE_WRAPPER_START
|
||||||
if(SUPPORT_COMPILE_WHOLE_ARCHIVE)
|
# "-Wl,--whole-archive") set(WHOLE_ARCHIVE_WRAPPER_END "-Wl,--no-whole-archive")
|
||||||
set(WHOLE_ARCHIVE_WRAPPER_START "-Wl,--whole-archive")
|
# endif()
|
||||||
set(WHOLE_ARCHIVE_WRAPPER_END "-Wl,--no-whole-archive")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
target_link_libraries(
|
target_link_libraries(
|
||||||
sled
|
sled
|
||||||
PUBLIC dl rpc_core fmt marl Async++
|
PUBLIC rpc_core fmt marl Async++ minilua
|
||||||
# protobuf::libprotobuf ${WHOLE_ARCHIVE_WRAPPER_START}
|
PRIVATE dl
|
||||||
# tcmalloc_and_profiler_static
|
# protobuf::libprotobuf ${WHOLE_ARCHIVE_WRAPPER_START}
|
||||||
|
# tcmalloc_and_profiler_static
|
||||||
# ${WHOLE_ARCHIVE_WRAPPER_END}
|
# ${WHOLE_ARCHIVE_WRAPPER_END}
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -148,7 +148,7 @@ function(sled_add_test)
|
|||||||
sled/testing/test.h)
|
sled/testing/test.h)
|
||||||
endif()
|
endif()
|
||||||
target_include_directories(${SLED_TEST_NAME} PRIVATE ${SLED_TEST_INC_DIRS})
|
target_include_directories(${SLED_TEST_NAME} PRIVATE ${SLED_TEST_INC_DIRS})
|
||||||
target_link_libraries(${SLED_TEST_NAME} PRIVATE ${SLED_TEST_LIBS})
|
target_link_libraries(${SLED_TEST_NAME} PRIVATE ${SLED_TEST_LIBS} sled)
|
||||||
add_test(NAME ${SLED_TEST_NAME} COMMAND ${SLED_TEST_NAME})
|
add_test(NAME ${SLED_TEST_NAME} COMMAND ${SLED_TEST_NAME})
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
@ -178,11 +178,11 @@ if(SLED_BUILD_TESTS)
|
|||||||
src/sled/rx_test.cc
|
src/sled/rx_test.cc
|
||||||
src/sled/uri_test.cc
|
src/sled/uri_test.cc
|
||||||
LIBS
|
LIBS
|
||||||
sled
|
|
||||||
test_main)
|
test_main)
|
||||||
|
|
||||||
sled_add_test(NAME sled_symbolize_test SRCS
|
sled_add_test(NAME sled_symbolize_test SRCS
|
||||||
src/sled/debugging/symbolize_test.cc LIBS sled)
|
src/sled/debugging/symbolize_test.cc)
|
||||||
|
sled_add_test(NAME sled_lua_test SRCS tests/lua_test.cc LIBS test_main)
|
||||||
endif(SLED_BUILD_TESTS)
|
endif(SLED_BUILD_TESTS)
|
||||||
|
|
||||||
if(SLED_BUILD_FUZZ)
|
if(SLED_BUILD_FUZZ)
|
||||||
|
73
tests/lua_test.cc
Normal file
73
tests/lua_test.cc
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
#include <minilua.h>
|
||||||
|
#include <sled/random.h>
|
||||||
|
|
||||||
|
TEST_SUITE("lua")
|
||||||
|
{
|
||||||
|
TEST_CASE("Base Test")
|
||||||
|
{
|
||||||
|
lua_State *state = luaL_newstate();
|
||||||
|
CHECK(state != nullptr);
|
||||||
|
luaL_openlibs(state);
|
||||||
|
REQUIRE_EQ(lua_gettop(state), 0);
|
||||||
|
|
||||||
|
SUBCASE("add")
|
||||||
|
{
|
||||||
|
REQUIRE_EQ(LUA_OK, luaL_loadstring(state, "function add(a, b) return a+b end"));
|
||||||
|
// load script
|
||||||
|
REQUIRE_EQ(lua_pcall(state, 0, 0, 0), LUA_OK);
|
||||||
|
// push function
|
||||||
|
|
||||||
|
sled::Random rand(-1);
|
||||||
|
for (int i = 0; i < 100; i++) {
|
||||||
|
int a = rand.Rand(0, 100);
|
||||||
|
int b = rand.Rand(0, 100);
|
||||||
|
|
||||||
|
CHECK_EQ(LUA_TFUNCTION, lua_getglobal(state, "add"));
|
||||||
|
CHECK(lua_isfunction(state, -1));
|
||||||
|
|
||||||
|
REQUIRE_EQ(lua_gettop(state), 1);
|
||||||
|
lua_pushnumber(state, a);
|
||||||
|
lua_pushnumber(state, b);
|
||||||
|
CHECK_EQ(lua_gettop(state), 3);
|
||||||
|
|
||||||
|
CHECK_MESSAGE(lua_pcall(state, 2, 1, 0) == LUA_OK, "call add(a,b) error: ", lua_tostring(state, -1));
|
||||||
|
CHECK(lua_isnumber(state, -1));
|
||||||
|
CHECK_EQ(lua_tonumber(state, -1), a + b);
|
||||||
|
lua_pop(state, 1);
|
||||||
|
CHECK_EQ(lua_gettop(state), 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
SUBCASE("dump all function")
|
||||||
|
{
|
||||||
|
const char *dump_func
|
||||||
|
= " local seen={}\n"
|
||||||
|
"\n"
|
||||||
|
" function dump(t,i)\n"
|
||||||
|
" seen[t]=true\n"
|
||||||
|
" local s={}\n"
|
||||||
|
" local n=0\n"
|
||||||
|
" for k in pairs(t) do\n"
|
||||||
|
" n=n+1\n"
|
||||||
|
" s[n]=k\n"
|
||||||
|
" end\n"
|
||||||
|
" table.sort(s)\n"
|
||||||
|
" for k,v in ipairs(s) do\n"
|
||||||
|
" -- print(i,v)\n"
|
||||||
|
" v=t[v]\n"
|
||||||
|
" if type(v)==\"table\" and not seen[v] then\n"
|
||||||
|
" dump(v,i..\"\\t\")\n"
|
||||||
|
" end\n"
|
||||||
|
" end\n"
|
||||||
|
" end\n"
|
||||||
|
"\n"
|
||||||
|
"dump(_G,\"\")";
|
||||||
|
|
||||||
|
REQUIRE_EQ(LUA_OK, luaL_loadstring(state, dump_func));
|
||||||
|
CHECK_EQ(lua_gettop(state), 1);
|
||||||
|
CHECK_EQ(LUA_TFUNCTION, lua_type(state, -1));
|
||||||
|
REQUIRE_EQ(LUA_OK, lua_pcall(state, 0, 0, 0));
|
||||||
|
}
|
||||||
|
lua_close(state);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user