Skip to content
Snippets Groups Projects
Commit 971809c5 authored by Ben Boeckel's avatar Ben Boeckel
Browse files

DynamicLoader: test the SearchBesideLibrary flag

parent 40d9e482
No related branches found
No related tags found
1 merge request!135Dynamic loader flags
...@@ -1099,6 +1099,20 @@ IF(KWSYS_STANDALONE OR CMake_SOURCE_DIR) ...@@ -1099,6 +1099,20 @@ IF(KWSYS_STANDALONE OR CMake_SOURCE_DIR)
ADD_LIBRARY(${KWSYS_NAMESPACE}TestDynload MODULE testDynload.c) ADD_LIBRARY(${KWSYS_NAMESPACE}TestDynload MODULE testDynload.c)
SET_PROPERTY(TARGET ${KWSYS_NAMESPACE}TestDynload PROPERTY LABELS ${KWSYS_LABELS_LIB}) SET_PROPERTY(TARGET ${KWSYS_NAMESPACE}TestDynload PROPERTY LABELS ${KWSYS_LABELS_LIB})
ADD_DEPENDENCIES(${KWSYS_NAMESPACE}TestDynload ${KWSYS_TARGET_INTERFACE}) ADD_DEPENDENCIES(${KWSYS_NAMESPACE}TestDynload ${KWSYS_TARGET_INTERFACE})
if (WIN32)
# Windows tests supported flags.
add_library(${KWSYS_NAMESPACE}TestDynloadImpl SHARED testDynloadImpl.c)
set_property(TARGET ${KWSYS_NAMESPACE}TestDynloadImpl PROPERTY LABELS ${KWSYS_LABELS_LIB})
set_property(TARGET ${KWSYS_NAMESPACE}TestDynloadImpl PROPERTY DEFINE_SYMBOL BUILDING_TestDynloadImpl)
set_property(TARGET ${KWSYS_NAMESPACE}TestDynloadImpl PROPERTY RUNTIME_OUTPUT_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/dynloaddir")
add_dependencies(${KWSYS_NAMESPACE}TestDynloadImpl ${KWSYS_TARGET_INTERFACE})
add_library(${KWSYS_NAMESPACE}TestDynloadUse MODULE testDynloadUse.c)
set_property(TARGET ${KWSYS_NAMESPACE}TestDynloadUse PROPERTY LABELS ${KWSYS_LABELS_LIB})
set_property(TARGET ${KWSYS_NAMESPACE}TestDynloadUse PROPERTY LIBRARY_OUTPUT_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/dynloaddir")
add_dependencies(${KWSYS_NAMESPACE}TestDynloadUse ${KWSYS_TARGET_INTERFACE})
target_link_libraries(${KWSYS_NAMESPACE}TestDynloadUse PRIVATE ${KWSYS_NAMESPACE}TestDynloadImpl)
endif ()
ENDIF() ENDIF()
CREATE_TEST_SOURCELIST( CREATE_TEST_SOURCELIST(
KWSYS_CXX_TEST_SRCS ${KWSYS_NAMESPACE}TestsCxx.cxx KWSYS_CXX_TEST_SRCS ${KWSYS_NAMESPACE}TestsCxx.cxx
......
...@@ -21,11 +21,15 @@ ...@@ -21,11 +21,15 @@
// left on disk. // left on disk.
#include <testSystemTools.h> #include <testSystemTools.h>
static std::string GetLibName(const char* lname) static std::string GetLibName(const char* lname, const char* subdir = NULL)
{ {
// Construct proper name of lib // Construct proper name of lib
std::string slname; std::string slname;
slname = EXECUTABLE_OUTPUT_PATH; slname = EXECUTABLE_OUTPUT_PATH;
if (subdir) {
slname += "/";
slname += subdir;
}
#ifdef CMAKE_INTDIR #ifdef CMAKE_INTDIR
slname += "/"; slname += "/";
slname += CMAKE_INTDIR; slname += CMAKE_INTDIR;
...@@ -45,26 +49,29 @@ static std::string GetLibName(const char* lname) ...@@ -45,26 +49,29 @@ static std::string GetLibName(const char* lname)
* r3: should CloseLibrary succeed ? * r3: should CloseLibrary succeed ?
*/ */
static int TestDynamicLoader(const char* libname, const char* symbol, int r1, static int TestDynamicLoader(const char* libname, const char* symbol, int r1,
int r2, int r3) int r2, int r3, int flags = 0)
{ {
std::cerr << "Testing: " << libname << std::endl; std::cerr << "Testing: " << libname << std::endl;
kwsys::DynamicLoader::LibraryHandle l = kwsys::DynamicLoader::LibraryHandle l =
kwsys::DynamicLoader::OpenLibrary(libname); kwsys::DynamicLoader::OpenLibrary(libname, flags);
// If result is incompatible with expectation just fails (xor): // If result is incompatible with expectation just fails (xor):
if ((r1 && !l) || (!r1 && l)) { if ((r1 && !l) || (!r1 && l)) {
std::cerr << kwsys::DynamicLoader::LastError() << std::endl; std::cerr << "OpenLibrary: " << kwsys::DynamicLoader::LastError()
<< std::endl;
return 1; return 1;
} }
kwsys::DynamicLoader::SymbolPointer f = kwsys::DynamicLoader::SymbolPointer f =
kwsys::DynamicLoader::GetSymbolAddress(l, symbol); kwsys::DynamicLoader::GetSymbolAddress(l, symbol);
if ((r2 && !f) || (!r2 && f)) { if ((r2 && !f) || (!r2 && f)) {
std::cerr << kwsys::DynamicLoader::LastError() << std::endl; std::cerr << "GetSymbolAddress: " << kwsys::DynamicLoader::LastError()
<< std::endl;
return 1; return 1;
} }
#ifndef __APPLE__ #ifndef __APPLE__
int s = kwsys::DynamicLoader::CloseLibrary(l); int s = kwsys::DynamicLoader::CloseLibrary(l);
if ((r3 && !s) || (!r3 && s)) { if ((r3 && !s) || (!r3 && s)) {
std::cerr << kwsys::DynamicLoader::LastError() << std::endl; std::cerr << "CloseLibrary: " << kwsys::DynamicLoader::LastError()
<< std::endl;
return 1; return 1;
} }
#else #else
...@@ -113,5 +120,14 @@ int testDynamicLoader(int argc, char* argv[]) ...@@ -113,5 +120,14 @@ int testDynamicLoader(int argc, char* argv[])
res += TestDynamicLoader(libname.c_str(), "TestDynamicLoaderData", 1, 1, 1); res += TestDynamicLoader(libname.c_str(), "TestDynamicLoaderData", 1, 1, 1);
res += TestDynamicLoader(libname.c_str(), "_TestDynamicLoaderData", 1, 0, 1); res += TestDynamicLoader(libname.c_str(), "_TestDynamicLoaderData", 1, 0, 1);
#ifdef _WIN32
libname = GetLibName(KWSYS_NAMESPACE_STRING "TestDynloadUse", "dynloaddir");
res += TestDynamicLoader(libname.c_str(), "dummy", 0, 0, 0);
res += TestDynamicLoader(libname.c_str(), "TestLoad", 1, 1, 1,
kwsys::DynamicLoader::SearchBesideLibrary);
res += TestDynamicLoader(libname.c_str(), "_TestLoad", 1, 0, 1,
kwsys::DynamicLoader::SearchBesideLibrary);
#endif
return res; return res;
} }
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
file Copyright.txt or https://cmake.org/licensing#kwsys for details. */
#include "testDynloadImpl.h"
int TestDynamicLoaderImplData = 0;
void TestDynamicLoaderImplSymbolPointer()
{
}
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
file Copyright.txt or https://cmake.org/licensing#kwsys for details. */
#ifdef _WIN32
# ifdef BUILDING_TestDynloadImpl
# define DLIMPL_EXPORT __declspec(dllexport)
# else
# define DLIMPL_EXPORT __declspec(dllimport)
# endif
#else
# define DLIMPL_EXPORT
#endif
DLIMPL_EXPORT int TestDynamicLoaderImplData;
DLIMPL_EXPORT void TestDynamicLoaderImplSymbolPointer();
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
file Copyright.txt or https://cmake.org/licensing#kwsys for details. */
#include "testDynloadImpl.h"
#ifdef _WIN32
# define DL_EXPORT __declspec(dllexport)
#else
# define DL_EXPORT
#endif
DL_EXPORT int TestLoad()
{
TestDynamicLoaderImplSymbolPointer();
return TestDynamicLoaderImplData;
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment