aboutsummaryrefslogtreecommitdiffstats
path: root/deps/sol2/examples/require_dll_example
diff options
context:
space:
mode:
Diffstat (limited to 'deps/sol2/examples/require_dll_example')
-rw-r--r--deps/sol2/examples/require_dll_example/CMakeLists.txt145
-rw-r--r--deps/sol2/examples/require_dll_example/include/my_object/my_object.hpp28
-rw-r--r--deps/sol2/examples/require_dll_example/include/my_object/my_object_api.hpp27
-rw-r--r--deps/sol2/examples/require_dll_example/source/my_object.cpp27
-rw-r--r--deps/sol2/examples/require_dll_example/source/require_from_dll.cpp33
5 files changed, 260 insertions, 0 deletions
diff --git a/deps/sol2/examples/require_dll_example/CMakeLists.txt b/deps/sol2/examples/require_dll_example/CMakeLists.txt
new file mode 100644
index 0000000..a2aea84
--- /dev/null
+++ b/deps/sol2/examples/require_dll_example/CMakeLists.txt
@@ -0,0 +1,145 @@
+# # # # sol3
+# The MIT License (MIT)
+#
+# Copyright (c) 2013-2019 Rapptz, ThePhD, and contributors
+#
+# Permission is hereby granted, free of charge, to any person obtaining a copy of
+# this software and associated documentation files (the "Software"), to deal in
+# the Software without restriction, including without limitation the rights to
+# use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
+# the Software, and to permit persons to whom the Software is furnished to do so,
+# subject to the following conditions:
+#
+# The above copyright notice and this permission notice shall be included in all
+# copies or substantial portions of the Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
+# FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
+# COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
+# IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
+# CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+
+# # # sol3 Examples - require_from_dll
+
+# # Reusable function to call for single target
+# # Also hides variables from directory/global scope
+function(make_require_from_dll_example target_lib example_lib_name_suffix)
+ # define sources
+ set(my_object_sources source/my_object.cpp)
+ set(require_from_dll_sources source/require_from_dll.cpp)
+
+ # define names
+ set(example_lib_name my_object)
+ set(example_name require_from_dll)
+ set(example_lib_name "${example_lib_name}${example_lib_name_suffix}")
+ set(example_name "${example_name}${example_lib_name_suffix}")
+
+ # add library target my_object for the require_from_dll program
+ add_library(${example_lib_name} SHARED ${my_object_sources})
+ set_target_properties(${example_lib_name} PROPERTIES
+ PREFIX "")
+
+ target_include_directories(${example_lib_name}
+ PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/include")
+ target_compile_definitions(${example_lib_name}
+ PUBLIC MY_OBJECT_DLL
+ PRIVATE MY_OBJECT_BUILD)
+ target_link_libraries(${example_lib_name}
+ PUBLIC ${target_lib} ${LUA_LIBRARIES} sol2::assert)
+ target_include_directories(${example_lib_name}
+ PUBLIC "${LUA_INCLUDE_DIRS}")
+
+ if (MSVC)
+ target_compile_options(${example_lib_name}
+ PRIVATE /std:c++latest /EHsc "$<$<CONFIG:Debug>:/MDd>"
+ "$<$<CONFIG:Release>:/MD>"
+ "$<$<CONFIG:RelWithDebInfo>:/MD>"
+ "$<$<CONFIG:MinSizeRel>:/MD>")
+ target_compile_definitions(${example_lib_name}
+ PRIVATE UNICODE _UNICODE
+ _CRT_SECURE_NO_WARNINGS _CRT_SECURE_NO_DEPRECATE)
+ else()
+ target_compile_options(${example_lib_name}
+ PRIVATE -std=c++1z
+ -Wno-unknown-warning -Wno-unknown-warning-option
+ -Wall -Wextra -Wpedantic -pedantic -pedantic-errors
+ -Wno-noexcept-type)
+
+ if (CMAKE_CXX_COMPILER_ID MATCHES "Clang")
+ # For another day, when C++ is not so crap
+ # and we have time to audit the entire lib
+ # for all uses of `detail::swallow`...
+ #target_compile_options(${test_target_name}
+ # PRIVATE -Wcomma)
+ endif()
+
+
+ if (IS_X86)
+ target_compile_options(${example_lib_name} BEFORE PRIVATE -m32)
+ endif()
+ endif()
+
+ if(CMAKE_DL_LIBS)
+ target_link_libraries(${example_lib_name} PUBLIC ${CMAKE_DL_LIBS})
+ endif()
+
+ # add executable target that represents require_from_dll program
+ add_executable(${example_name} ${require_from_dll_sources})
+ target_link_libraries(${example_name}
+ PRIVATE my_object ${LUA_LIBRARIES} ${target_lib})
+ target_include_directories(${example_name}
+ PRIVATE ${LUA_INCLUDE_DIRS})
+
+ if (MSVC)
+ target_compile_options(${example_name}
+ PRIVATE /std:c++latest /EHsc "$<$<CONFIG:Debug>:/MDd>"
+ "$<$<CONFIG:Release>:/MD>"
+ "$<$<CONFIG:RelWithDebInfo>:/MD>"
+ "$<$<CONFIG:MinSizeRel>:/MD>")
+ target_compile_definitions(${example_name}
+ PRIVATE UNICODE _UNICODE
+ _CRT_SECURE_NO_WARNINGS _CRT_SECURE_NO_DEPRECATE)
+ else()
+ target_compile_options(${example_name}
+ PRIVATE -std=c++1z
+ -Wno-unknown-warning -Wno-unknown-warning-option
+ -Wall -Wextra -Wpedantic -pedantic -pedantic-errors
+ -Wno-noexcept-type)
+
+ if (CMAKE_CXX_COMPILER_ID MATCHES "Clang")
+ # For another day, when C++ is not so crap
+ # and we have time to audit the entire lib
+ # for all uses of `detail::swallow`...
+ #target_compile_options(${test_target_name}
+ # PRIVATE -Wcomma)
+ endif()
+ endif()
+
+ if(CMAKE_DL_LIBS)
+ target_link_libraries(${example_name} PRIVATE ${CMAKE_DL_LIBS})
+ endif()
+
+ if (SOL2_TESTS_DYNAMIC_LOADING_EXAMPLES)
+ get_target_property(example_working_dir ${example_name} RUNTIME_OUTPUT_DIRECTORY)
+ add_test(NAME ${example_name} COMMAND ${example_name} WORKING_DIRECTORY "${example_working_dir}")
+ endif()
+endfunction()
+
+list(GET LUA_LIBRARIES 0 lua_lib_target)
+get_target_property(lua_lib_type ${lua_lib_target} TYPE)
+if (lua_lib_type MATCHES "STATIC")
+ # avoid multiply defined references due to linking in the same static library
+ # twice over, and get "multiple definition" errors during linking
+ return()
+endif()
+
+if (SOL2_DYNAMIC_LOADING_EXAMPLES)
+ make_require_from_dll_example(sol2::sol2 "")
+endif()
+if (SOL2_DYNAMIC_LOADING_EXAMPLES_SINGLE)
+ make_require_from_dll_example(sol2::sol2_single ".single")
+endif()
+if (SOL2_DYNAMIC_LOADING_EXAMPLES_SINGLE_GENERATED)
+ make_require_from_dll_example(sol2::sol2_single_generated ".single.generated")
+endif()
diff --git a/deps/sol2/examples/require_dll_example/include/my_object/my_object.hpp b/deps/sol2/examples/require_dll_example/include/my_object/my_object.hpp
new file mode 100644
index 0000000..f8ec5e5
--- /dev/null
+++ b/deps/sol2/examples/require_dll_example/include/my_object/my_object.hpp
@@ -0,0 +1,28 @@
+#pragma once
+
+#include <my_object/my_object_api.hpp>
+
+// forward declare as a C struct
+// so a pointer to lua_State can be part of a signature
+extern "C" {
+ struct lua_State;
+}
+// you can replace the above if you're fine with including
+// <sol.hpp> earlier than absolutely necessary
+
+namespace my_object {
+
+ struct test {
+ int value;
+
+ test() = default;
+ test(int val) : value(val) {}
+ };
+
+} // namespace my_object
+
+// this function needs to be exported from your
+// dll. "extern 'C'" should do the trick, but
+// we're including platform-specific stuff here to help
+// see my_object_api.hpp for details
+extern "C" MY_OBJECT_API int luaopen_my_object(lua_State* L);
diff --git a/deps/sol2/examples/require_dll_example/include/my_object/my_object_api.hpp b/deps/sol2/examples/require_dll_example/include/my_object/my_object_api.hpp
new file mode 100644
index 0000000..6af5f42
--- /dev/null
+++ b/deps/sol2/examples/require_dll_example/include/my_object/my_object_api.hpp
@@ -0,0 +1,27 @@
+#pragma once
+
+namespace my_object {
+
+#if defined _MSC_VER
+ #define MY_OBJECT_VC
+#elif defined __GNUC__
+ #define MY_OBJECT_GCC
+#elif defined __clang__
+ #define MY_OBJECT_CLANG
+#endif
+
+#if defined MY_OBJECT_VC
+ #if defined MY_OBJECT_DLL
+ #if defined MY_OBJECT_BUILD
+ #define MY_OBJECT_API __declspec(dllexport)
+ #else
+ #define MY_OBJECT_API __declspec(dllexport)
+ #endif // MY_OBJECT_BUILD - Building the Library vs. Using the Library
+ #else
+ #define MY_OBJECT_API
+ #endif // Building a DLL vs. Static Library
+#else // g++ / clang++
+ #define MY_OBJECT_API __attribute__ ((visibility ("default")))
+#endif // MY_OBJECT_BUILD
+
+} // namespace my_object
diff --git a/deps/sol2/examples/require_dll_example/source/my_object.cpp b/deps/sol2/examples/require_dll_example/source/my_object.cpp
new file mode 100644
index 0000000..d966c2b
--- /dev/null
+++ b/deps/sol2/examples/require_dll_example/source/my_object.cpp
@@ -0,0 +1,27 @@
+#include <my_object/my_object.hpp>
+
+#define SOL_ALL_SAFETIES_ON 1
+#include <sol/sol.hpp>
+
+namespace my_object {
+
+ sol::table open_my_object(sol::this_state L) {
+ sol::state_view lua(L);
+ sol::table module = lua.create_table();
+ module.new_usertype<test>("test",
+ sol::constructors<test(), test(int)>(),
+ "value", &test::value);
+
+ return module;
+ }
+
+} // namespace my_object
+
+extern "C" int luaopen_my_object(lua_State* L) {
+ // pass the lua_State,
+ // the index to start grabbing arguments from,
+ // and the function itself
+ // optionally, you can pass extra arguments to the function if that's necessary,
+ // but that's advanced usage and is generally reserved for internals only
+ return sol::stack::call_lua(L, 1, my_object::open_my_object );
+}
diff --git a/deps/sol2/examples/require_dll_example/source/require_from_dll.cpp b/deps/sol2/examples/require_dll_example/source/require_from_dll.cpp
new file mode 100644
index 0000000..874d187
--- /dev/null
+++ b/deps/sol2/examples/require_dll_example/source/require_from_dll.cpp
@@ -0,0 +1,33 @@
+#define SOL_ALL_SAFETIES_ON 1
+#include <sol/sol.hpp>
+
+#include <my_object/my_object.hpp>
+#include <assert.hpp>
+
+#include <iostream>
+
+int main(int, char*[]) {
+ std::cout << "=== require from DLL ===" << std::endl;
+
+ sol::state lua;
+ lua.open_libraries(sol::lib::package, sol::lib::base);
+
+ const auto& code = R"(
+mo = require("my_object")
+
+obj = mo.test.new(24)
+print(obj.value))";
+ auto script_result = lua.safe_script(code, &sol::script_pass_on_error);
+ if (script_result.valid()) {
+ std::cout << "The DLL was require'd from successfully!" << std::endl;
+ }
+ else {
+ sol::error err = script_result;
+ std::cout << "Something bad happened: " << err.what() << std::endl;
+ }
+ c_assert(script_result.valid());
+ my_object::test& obj = lua["obj"];
+ c_assert(obj.value == 24);
+
+ return 0;
+} \ No newline at end of file