Extensions: Auto-add linked extensions
parent
65a6fadd1d
commit
5733300de6
|
|
@ -116,6 +116,14 @@ if(LIBICSNEO_BUILD_EXAMPLES)
|
||||||
add_subdirectory(examples)
|
add_subdirectory(examples)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# Extensions
|
||||||
|
set(LIBICSNEO_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR})
|
||||||
|
foreach(EXT_PATH ${LIBICSNEO_EXTENSION_DIRS})
|
||||||
|
get_filename_component(EXT_DIR ${EXT_PATH} NAME)
|
||||||
|
message("Adding extension " ${EXT_DIR})
|
||||||
|
add_subdirectory(${EXT_PATH} ${CMAKE_CURRENT_BINARY_DIR}/${EXT_DIR})
|
||||||
|
endforeach()
|
||||||
|
|
||||||
set(SRC_FILES
|
set(SRC_FILES
|
||||||
communication/message/flexray/control/flexraycontrolmessage.cpp
|
communication/message/flexray/control/flexraycontrolmessage.cpp
|
||||||
communication/message/neomessage.cpp
|
communication/message/neomessage.cpp
|
||||||
|
|
@ -165,6 +173,18 @@ endif()
|
||||||
|
|
||||||
configure_file(api/icsneocpp/buildinfo.h.template ${CMAKE_CURRENT_BINARY_DIR}/generated/buildinfo.h)
|
configure_file(api/icsneocpp/buildinfo.h.template ${CMAKE_CURRENT_BINARY_DIR}/generated/buildinfo.h)
|
||||||
configure_file(api/icsneoc/version.rc.template ${CMAKE_CURRENT_BINARY_DIR}/generated/icsneoc/version.rc)
|
configure_file(api/icsneoc/version.rc.template ${CMAKE_CURRENT_BINARY_DIR}/generated/icsneoc/version.rc)
|
||||||
|
|
||||||
|
foreach(EXTINC ${LIBICSNEO_EXTENSION_INCLUDES})
|
||||||
|
message("Including " ${EXTINC})
|
||||||
|
list(APPEND LIBICSNEO_EXT_CODE_INCS_LIST "#include \"${EXTINC}\"")
|
||||||
|
endforeach()
|
||||||
|
list(JOIN LIBICSNEO_EXT_CODE_INCS_LIST "\n" LIBICSNEO_EXT_CODE_INCS)
|
||||||
|
foreach(EXTCLASS ${LIBICSNEO_EXTENSION_CLASSES})
|
||||||
|
list(APPEND LIBICSNEO_EXT_CODE_LIST "device->addExtension(std::make_shared<${EXTCLASS}>(*device))\;")
|
||||||
|
endforeach()
|
||||||
|
list(JOIN LIBICSNEO_EXT_CODE_LIST "\n\t" LIBICSNEO_EXT_CODE)
|
||||||
|
configure_file(include/icsneo/device/extensions/builtin.h.template ${CMAKE_CURRENT_BINARY_DIR}/generated/extensions/builtin.h)
|
||||||
|
|
||||||
include_directories(BEFORE ${CMAKE_CURRENT_BINARY_DIR})
|
include_directories(BEFORE ${CMAKE_CURRENT_BINARY_DIR})
|
||||||
|
|
||||||
add_library(icsneocpp
|
add_library(icsneocpp
|
||||||
|
|
@ -174,15 +194,19 @@ add_library(icsneocpp
|
||||||
api/icsneocpp/version.cpp
|
api/icsneocpp/version.cpp
|
||||||
${SRC_FILES}
|
${SRC_FILES}
|
||||||
)
|
)
|
||||||
|
message("Include paths " ${LIBICSNEO_EXTENSION_INCLUDE_PATHS})
|
||||||
target_include_directories(icsneocpp
|
target_include_directories(icsneocpp
|
||||||
PUBLIC
|
PUBLIC
|
||||||
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
|
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
|
||||||
$<INSTALL_INTERFACE:>
|
$<INSTALL_INTERFACE:>
|
||||||
PRIVATE
|
PRIVATE
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/include
|
${CMAKE_CURRENT_SOURCE_DIR}/include
|
||||||
|
${LIBICSNEO_EXTENSION_INCLUDE_PATHS}
|
||||||
)
|
)
|
||||||
set_property(TARGET icsneocpp PROPERTY POSITION_INDEPENDENT_CODE ON)
|
set_property(TARGET icsneocpp PROPERTY POSITION_INDEPENDENT_CODE ON)
|
||||||
target_compile_features(icsneocpp PUBLIC cxx_auto_type cxx_constexpr cxx_lambdas cxx_nullptr cxx_range_for cxx_rvalue_references cxx_sizeof_member cxx_strong_enums)
|
target_compile_features(icsneocpp PUBLIC cxx_auto_type cxx_constexpr cxx_lambdas cxx_nullptr cxx_range_for cxx_rvalue_references cxx_sizeof_member cxx_strong_enums)
|
||||||
|
message("Loaded extensions: " ${LIBICSNEO_EXTENSION_TARGETS})
|
||||||
|
target_link_libraries(icsneocpp PUBLIC ${LIBICSNEO_EXTENSION_TARGETS})
|
||||||
|
|
||||||
# libftdi
|
# libftdi
|
||||||
if(NOT WIN32)
|
if(NOT WIN32)
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,6 @@
|
||||||
#include "icsneo/device/devicefinder.h"
|
#include "icsneo/device/devicefinder.h"
|
||||||
#include "icsneo/platform/devices.h"
|
#include "icsneo/platform/devices.h"
|
||||||
|
#include "generated/extensions/builtin.h"
|
||||||
|
|
||||||
using namespace icsneo;
|
using namespace icsneo;
|
||||||
|
|
||||||
|
|
@ -245,6 +246,10 @@ std::vector<std::shared_ptr<Device>> DeviceFinder::FindAll() {
|
||||||
foundDevices.insert(foundDevices.end(), std::make_move_iterator(results.begin()), std::make_move_iterator(results.end()));
|
foundDevices.insert(foundDevices.end(), std::make_move_iterator(results.begin()), std::make_move_iterator(results.end()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for(auto& device : foundDevices) {
|
||||||
|
AddBuiltInExtensionsTo(device);
|
||||||
|
}
|
||||||
|
|
||||||
return foundDevices;
|
return foundDevices;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -157,6 +157,8 @@ public:
|
||||||
|
|
||||||
virtual std::vector<std::shared_ptr<FlexRay::Controller>> getFlexRayControllers() const { return {}; }
|
virtual std::vector<std::shared_ptr<FlexRay::Controller>> getFlexRayControllers() const { return {}; }
|
||||||
|
|
||||||
|
void addExtension(std::shared_ptr<DeviceExtension>&& extension);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* For use by extensions only.
|
* For use by extensions only.
|
||||||
*/
|
*/
|
||||||
|
|
@ -248,7 +250,6 @@ protected:
|
||||||
virtual void setupSupportedTXNetworks(std::vector<Network>&) {}
|
virtual void setupSupportedTXNetworks(std::vector<Network>&) {}
|
||||||
|
|
||||||
virtual void setupExtensions() {}
|
virtual void setupExtensions() {}
|
||||||
void addExtension(std::shared_ptr<DeviceExtension>&& extension);
|
|
||||||
|
|
||||||
// Hook for devices such as FIRE which need to inject traffic before RequestSerialNumber
|
// Hook for devices such as FIRE which need to inject traffic before RequestSerialNumber
|
||||||
// Return false to bail
|
// Return false to bail
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,16 @@
|
||||||
|
#ifndef __ICSNEO_DEVICE_EXTENSIONS_BUILTIN_H_
|
||||||
|
#define __ICSNEO_DEVICE_EXTENSIONS_BUILTIN_H_
|
||||||
|
|
||||||
|
@LIBICSNEO_EXT_CODE_INCS@
|
||||||
|
#include "icsneo/device/device.h"
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
|
namespace icsneo {
|
||||||
|
|
||||||
|
static void AddBuiltInExtensionsTo([[maybe_unused]] const std::shared_ptr<icsneo::Device>& device) {
|
||||||
|
@LIBICSNEO_EXT_CODE@
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
Loading…
Reference in New Issue