2019-05-22 07:17:31 +08:00
|
|
|
#define SOL_ALL_SAFETIES_ON 1
|
2018-09-28 13:27:38 +08:00
|
|
|
#include <sol/sol.hpp>
|
2018-03-11 11:00:08 +08:00
|
|
|
|
|
|
|
|
2018-03-11 09:45:01 +08:00
|
|
|
#include <unordered_set>
|
|
|
|
#include <iostream>
|
|
|
|
|
|
|
|
int main() {
|
|
|
|
struct hasher {
|
2021-03-06 23:14:48 +08:00
|
|
|
typedef std::pair<std::string, std::string>
|
|
|
|
argument_type;
|
2018-03-11 09:45:01 +08:00
|
|
|
typedef std::size_t result_type;
|
|
|
|
|
|
|
|
result_type operator()(const argument_type& p) const {
|
|
|
|
return std::hash<std::string>()(p.first);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-03-06 23:14:48 +08:00
|
|
|
using my_set = std::unordered_set<
|
|
|
|
std::pair<std::string, std::string>,
|
|
|
|
hasher>;
|
2018-03-11 09:45:01 +08:00
|
|
|
|
2021-03-06 23:14:48 +08:00
|
|
|
std::cout << "=== containers with std::pair<> ==="
|
|
|
|
<< std::endl;
|
2018-03-11 09:45:01 +08:00
|
|
|
|
|
|
|
sol::state lua;
|
|
|
|
lua.open_libraries(sol::lib::base);
|
|
|
|
|
2021-03-06 23:14:48 +08:00
|
|
|
lua.set_function("f", []() {
|
|
|
|
return my_set { { "key1", "value1" },
|
|
|
|
{ "key2", "value2" },
|
|
|
|
{ "key3", "value3" } };
|
|
|
|
});
|
2018-03-11 09:45:01 +08:00
|
|
|
|
|
|
|
lua.safe_script("v = f()");
|
|
|
|
lua.safe_script("print('v:', v)");
|
2018-03-11 11:00:08 +08:00
|
|
|
lua.safe_script("print('#v:', #v)");
|
2018-03-11 09:45:01 +08:00
|
|
|
// note that using my_obj:pairs() is a
|
2021-03-06 23:14:48 +08:00
|
|
|
// way around pairs(my_obj) not working in Lua 5.1/LuaJIT:
|
|
|
|
// try it!
|
|
|
|
lua.safe_script(
|
|
|
|
"for k,v1,v2 in v:pairs() do print(k, v1, v2) end");
|
2018-03-11 09:45:01 +08:00
|
|
|
|
|
|
|
std::cout << std::endl;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|