boost/libs/dll/test/cpp_import_class_test.cpp
2018-01-12 21:47:58 +01:00

116 lines
3.4 KiB
C++

// Copyright 2016 Klemens Morgenstern
//
// Distributed under the Boost Software License, Version 1.0.
// (See accompanying file LICENSE_1_0.txt
// or copy at http://www.boost.org/LICENSE_1_0.txt)
// For more information, see http://www.boost.org
#include <boost/predef.h>
#if (__cplusplus >= 201402L) || (BOOST_COMP_MSVC >= BOOST_VERSION_NUMBER(14,0,0))
#include "../example/b2_workarounds.hpp"
#include <iostream>
using namespace std;
#include <boost/dll/smart_library.hpp>
#include <boost/dll/import_mangled.hpp>
#include <boost/dll/import_class.hpp>
#include <boost/core/lightweight_test.hpp>
#include <boost/filesystem.hpp>
#include <boost/variant.hpp>
#include <boost/function.hpp>
#define L cout << __LINE__ << endl;
int main(int argc, char* argv[])
{
using namespace boost::dll;
using namespace boost::dll::experimental;
boost::filesystem::path pt = b2_workarounds::first_lib_from_argv(argc, argv);
BOOST_TEST(!pt.empty());
std::cout << "Library: " << pt << std::endl;
smart_library sm(pt);
auto static_val = import_mangled<int>(sm, "some_space::some_class::value");
std::cout << "--------------------- Entry Points ------------------------\n" << std::endl;
for (auto &s : sm.symbol_storage().get_storage())
std::cout << s.demangled << std::endl;
std::cout << "-----------------------------------------------------------\n\n" << std::endl;
auto sp_variable = import_mangled<double>(sm, "some_space::variable");
auto unscoped_var = import_mangled<int>(sm, "unscoped_var");
std::size_t type_size = *import_mangled<std::size_t>(sm, "some_space::size_of_some_class");
{
#if defined(BOOST_MSVC) || defined(BOOST_MSVC_FULL_VER)
class override_class{};
auto cl = import_class<override_class, int>(sm, "some_space::some_class", type_size, 42);
#else
auto cl = import_class<class override_class, int>(sm, "some_space::some_class", type_size, 42);
#endif
BOOST_TEST(!cl.is_copy_assignable());
BOOST_TEST(!cl.is_copy_constructible());
BOOST_TEST( cl.is_move_assignable());
BOOST_TEST( cl.is_move_constructible());
BOOST_TEST(*static_val == 42);
auto i = cl.call<const override_class, int()>("get")();
BOOST_TEST(i == 456);
cl.call<void(int)>("set")(42);
i = 0;
i = cl.call<const override_class, int()>("get")();
BOOST_TEST(i == 42);
auto func = import_mangled<
override_class, double(double, double), int(int, int),
volatile override_class, int(int, int),
const volatile override_class, double(double, double)>(sm, "func");
BOOST_TEST((cl->*func)(3.,2.) == 6.);
BOOST_TEST((cl->*func)(1 ,2 ) == 3 );
auto fun2 = cl.import<double(double, double), int(int, int)>("func");
BOOST_TEST((cl->*fun2)(3.,2.) == 6.);
BOOST_TEST((cl->*fun2)(5 ,2 ) == 7 );
//test if it binds.
boost::function<int(override_class* const, int, int)> mem_fn_obj = func;
const std::type_info & ti = cl.get_type_info();
std::string imp_name = boost::core::demangle(ti.name());
#if defined(BOOST_MSVC) || defined(BOOST_MSVC_FULL_VER)
std::string exp_name = "struct some_space::some_class";
#else
std::string exp_name = "some_space::some_class";
#endif
BOOST_TEST(imp_name == exp_name);
}
BOOST_TEST(*static_val == 0);
return boost::report_errors();
}
#else
int main() {return 0;}
#endif