C++ YASMIN (Yet Another State MachINe)
Loading...
Searching...
No Matches
yasmin::blackboard::Blackboard Class Reference

A thread-safe storage for key-value pairs of varying types. More...

#include <blackboard.hpp>

Collaboration diagram for yasmin::blackboard::Blackboard:

Public Member Functions

 Blackboard ()
 Default constructor for Blackboard.
 
 Blackboard (const Blackboard &other)
 Copy constructor for Blackboard.
 
 ~Blackboard ()
 Destructor for Blackboard.
 
template<class T>
get (const std::string &key)
 Retrieve a value from the blackboard.
 
template<class T>
void set (std::string name, T value)
 Set a value in the blackboard.
 
void remove (const std::string &key)
 Remove a value from the blackboard.
 
bool contains (const std::string &key)
 Check if a key exists in the blackboard.
 
int size ()
 Get the number of key-value pairs in the blackboard.
 
std::string to_string ()
 Convert the contents of the blackboard to a string.
 
void set_remapping (const std::map< std::string, std::string > &remapping)
 Set the remapping of the blackboard.
 
const std::map< std::string, std::string > & get_remapping ()
 Get the remapping of the blackboard.
 

Private Member Functions

const std::string & remap (const std::string &key)
 Internal method that acquires the maped key. In the case the key is not remaped, retruns the arg key.
 

Private Attributes

std::recursive_mutex mutex
 Mutex for thread safety.
 
std::map< std::string, BlackboardValueInterface * > values
 Storage for key-value pairs.
 
std::map< std::string, std::string > remapping
 Storage for key-value pairs.
 

Detailed Description

A thread-safe storage for key-value pairs of varying types.

The Blackboard class allows storing, retrieving, and managing values associated with string keys in a thread-safe manner using a recursive mutex. Values are stored as pointers to BlackboardValueInterface instances.

Constructor & Destructor Documentation

◆ Blackboard() [1/2]

Blackboard::Blackboard ( )

Default constructor for Blackboard.

◆ Blackboard() [2/2]

Blackboard::Blackboard ( const Blackboard & other)

Copy constructor for Blackboard.

Parameters
otherThe instance to copy from.

◆ ~Blackboard()

Blackboard::~Blackboard ( )

Destructor for Blackboard.

Member Function Documentation

◆ contains()

bool Blackboard::contains ( const std::string & key)

Check if a key exists in the blackboard.

Parameters
keyThe key to check.
Returns
True if the key exists, false otherwise.

◆ get()

template<class T>
T yasmin::blackboard::Blackboard::get ( const std::string & key)
inline

Retrieve a value from the blackboard.

Template Parameters
TThe type of the value to retrieve.
Parameters
nameThe key associated with the value.
Returns
The value associated with the specified key.
Exceptions
std::runtime_errorif the key does not exist.

◆ get_remapping()

const std::map< std::string, std::string > & Blackboard::get_remapping ( )

Get the remapping of the blackboard.

Returns
The remapping of the blackboard.

◆ remap()

const std::string & Blackboard::remap ( const std::string & key)
private

Internal method that acquires the maped key. In the case the key is not remaped, retruns the arg key.

Parameters
otherThe instance to copy from.

◆ remove()

void Blackboard::remove ( const std::string & key)

Remove a value from the blackboard.

Parameters
keyThe key associated with the value to remove.

◆ set()

template<class T>
void yasmin::blackboard::Blackboard::set ( std::string name,
T value )
inline

Set a value in the blackboard.

Template Parameters
TThe type of the value to store.
Parameters
nameThe key to associate with the value.
valueThe value to store.

◆ set_remapping()

void Blackboard::set_remapping ( const std::map< std::string, std::string > & remapping)

Set the remapping of the blackboard.

Parameters
remappingThe remapping to set.

◆ size()

int Blackboard::size ( )

Get the number of key-value pairs in the blackboard.

Returns
The size of the blackboard.

◆ to_string()

std::string Blackboard::to_string ( )

Convert the contents of the blackboard to a string.

Returns
A string representation of the blackboard.

Member Data Documentation

◆ mutex

std::recursive_mutex yasmin::blackboard::Blackboard::mutex
private

Mutex for thread safety.

◆ remapping

std::map<std::string, std::string> yasmin::blackboard::Blackboard::remapping
private

Storage for key-value pairs.

◆ values

std::map<std::string, BlackboardValueInterface *> yasmin::blackboard::Blackboard::values
private

Storage for key-value pairs.


The documentation for this class was generated from the following files: