Files
salmanoff/smocore/include/stimBuffApis/stimBuffApiLib.h
T

91 lines
2.2 KiB
C++
Raw Normal View History

#ifndef SENSE_API_PROVIDER_DESC_H
#define SENSE_API_PROVIDER_DESC_H
#include <string>
#include <memory>
#include <atomic>
#include <vector>
#include <dlfcn.h>
#include <functional>
#include <user/senseApiDesc.h>
#include <qutex.h>
2025-07-22 06:48:04 -04:00
namespace smo {
2025-10-01 18:47:42 -04:00
namespace stim_buff {
2025-10-01 18:47:42 -04:00
class StimBuffApiLib
{
2025-01-12 09:44:08 -04:00
private:
2025-10-01 18:47:42 -04:00
friend class StimBuffApiManager;
2025-09-30 01:15:02 -04:00
struct DlCloser
{
void operator()(void* handle) const
{
if (handle) {
dlclose(handle);
}
}
};
2025-01-12 09:44:08 -04:00
public:
2025-10-01 18:47:42 -04:00
StimBuffApiLib(
2025-09-30 01:15:02 -04:00
const std::string& path, void *_dlopen_handle,
2025-10-01 18:47:42 -04:00
SMO_GET_STIM_BUFF_API_DESC_FN_TYPEDEF *descFn)
: libraryPath(path), qutex("StimBuffApiLib-" + path),
isBeingDestroyed(false),
dlopen_handle(_dlopen_handle, DlCloser()),
2025-10-01 18:47:42 -04:00
SMO_GET_STIM_BUFF_API_DESC_FN_NAME(descFn)
2025-09-30 01:15:02 -04:00
{}
2025-10-01 18:47:42 -04:00
void setStimBuffApiDesc(const StimBuffApiDesc &desc)
2025-09-30 01:15:02 -04:00
{
2025-10-01 18:47:42 -04:00
if (!StimBuffApiDesc::sanityCheck(desc))
2025-09-30 01:15:02 -04:00
{
throw std::runtime_error(
2025-10-01 18:47:42 -04:00
std::string(__func__) + ": Sanity check failed for stim buff API "
2025-09-30 01:15:02 -04:00
"descriptor in library '" + libraryPath + "'");
}
2025-10-01 18:47:42 -04:00
stimBuffApiDesc = desc;
2025-09-30 01:15:02 -04:00
}
public:
2025-09-30 01:15:02 -04:00
std::string libraryPath;
Qutex qutex;
std::atomic<bool> isBeingDestroyed;
2025-09-30 01:15:02 -04:00
std::unique_ptr<void, DlCloser> dlopen_handle;
/* UNIMPLEMENTED: API-specific cmdline options. These affect this specific
2025-10-01 18:47:42 -04:00
* stim buff api lib's behaviour globally.
2025-09-30 01:15:02 -04:00
*/
std::vector<std::string> options;
2025-09-30 01:15:02 -04:00
/**
2025-10-01 18:47:42 -04:00
* @brief Each stim buff API library must provide a function returning a
* StimBuffApiDesc. This struct specifies which API the library uses to
* connect Salmanoff to its supported stim buff provider.
2025-09-30 01:15:02 -04:00
*
* This getter function should be visible to dlsym() so that Salmanoff can
* find it in the lib after loading it, and call it.
*/
2025-10-01 18:47:42 -04:00
std::function<SMO_GET_STIM_BUFF_API_DESC_FN_TYPEDEF>
SMO_GET_STIM_BUFF_API_DESC_FN_NAME;
2025-09-30 01:15:02 -04:00
/**
2025-10-01 18:47:42 -04:00
* @brief Salmanoff will call the `SMO_GET_STIM_BUFF_API_DESC_FN_NAME` getter
2025-09-30 01:15:02 -04:00
* function and use the data it provides in order to fill out this
* descriptor.
*/
2025-10-01 18:47:42 -04:00
StimBuffApiDesc stimBuffApiDesc;
2025-09-30 01:15:02 -04:00
std::string stringify() const {
std::string result = "Library Path: " + libraryPath + "\n";
2025-10-01 18:47:42 -04:00
result += "Stim Buff API Descriptor: " + stimBuffApiDesc.stringify() + "\n";
2025-09-30 01:15:02 -04:00
return result;
}
};
2025-10-01 18:47:42 -04:00
} // namespace stim_buff
2025-07-22 06:48:04 -04:00
} // namespace smo
#endif // SENSE_API_PROVIDER_DESC_H