mirror of
https://github.com/slsdetectorgroup/slsDetectorPackage.git
synced 2025-06-20 00:37:12 +02:00
fix to access to shared memory that doesnt exist (#638)
* fix to access to shared memory that doesnt exist * fix for freeing shm and then setting hostname from API * exception error message moved to private function * refactoring to avoid allocating intermediate string
This commit is contained in:
@ -33,7 +33,7 @@ namespace sls {
|
||||
template <typename T> class SharedMemory {
|
||||
static constexpr int NAME_MAX_LENGTH = 255;
|
||||
std::string name;
|
||||
T *shared_struct{};
|
||||
T *shared_struct{nullptr};
|
||||
|
||||
public:
|
||||
// moduleid of -1 creates a detector only shared memory
|
||||
@ -64,8 +64,18 @@ template <typename T> class SharedMemory {
|
||||
unmapSharedMemory();
|
||||
}
|
||||
|
||||
T *operator()() { return shared_struct; }
|
||||
const T *operator()() const { return shared_struct; }
|
||||
T *operator()() {
|
||||
if (shared_struct)
|
||||
return shared_struct;
|
||||
throw SharedMemoryError(getNoShmAccessMessage());
|
||||
}
|
||||
|
||||
const T *operator()() const {
|
||||
if (shared_struct)
|
||||
return shared_struct;
|
||||
throw SharedMemoryError(getNoShmAccessMessage());
|
||||
}
|
||||
|
||||
std::string getName() const { return name; }
|
||||
|
||||
bool exists() {
|
||||
@ -204,6 +214,11 @@ template <typename T> class SharedMemory {
|
||||
throw SharedMemoryError(msg);
|
||||
}
|
||||
}
|
||||
|
||||
const char* getNoShmAccessMessage() const {
|
||||
return ("No shared memory to access. Create it first with "
|
||||
"hostname or config command.");
|
||||
};
|
||||
};
|
||||
|
||||
} // namespace sls
|
||||
|
Reference in New Issue
Block a user