mirror of
https://github.com/boostorg/fiber.git
synced 2026-02-21 15:02:29 +00:00
55 lines
1.7 KiB
C++
55 lines
1.7 KiB
C++
/*
|
|
* Boost.Extension / hello world example main
|
|
*
|
|
* (C) Copyright Jeremy Pack 2008
|
|
* 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)
|
|
*
|
|
* See http://www.boost.org/ for latest version.
|
|
*/
|
|
|
|
#include <iostream>
|
|
|
|
#include <boost/extension/shared_library.hpp>
|
|
#include <boost/function.hpp>
|
|
|
|
int main() {
|
|
using namespace boost::extensions;
|
|
|
|
// In the Jamfile, shared libraries are set to have the same
|
|
// prefix and extension, even on different operating systems.
|
|
// This is for convenience in writing cross-platform code, but
|
|
// is not required. All shared libraries are set to start with
|
|
// "lib" and end with "extension".
|
|
std::string library_path = "libtutorial_1.extension";
|
|
|
|
// Create shared_library object with the relative or absolute
|
|
// path to the shared library.
|
|
shared_library lib(library_path);
|
|
|
|
// Attempt to open the shared library.
|
|
if (!lib.open()) {
|
|
std::cerr << "Library failed to open: " << library_path << std::endl;
|
|
return 1;
|
|
}
|
|
|
|
// Retrieve a function from the library, and store it in a Boost.Function
|
|
// object. It is also possible to use function pointers, but the syntax
|
|
// for Boost.Function is easier to understand. This retrieves a function
|
|
// called "boost_extension_hello_world" with a void return type and a single
|
|
// parameter of type int.
|
|
boost::function<void (int)>
|
|
f(lib.get<void, int>("boost_extension_hello_world"));
|
|
|
|
// Check that the function was found.
|
|
if (!f) {
|
|
std::cerr << "Function not found!" << std::endl;
|
|
return 1;
|
|
}
|
|
|
|
// Call the function from the shared library with
|
|
// an integer parameter.
|
|
f(4);
|
|
}
|