PLCnext API Documentation 25.9.0.13
Public Types | Public Member Functions | List of all members
Arp::System::Commons::Ipc::MessageQueue Class Reference

Message queues allow processes to exchange data in form of messages More...

#include <MessageQueue.hpp>

Public Types

enum class  OpenMode { CreateNew = 0 , Open , OpenOrCreate }
 Supported opening modes for message queues. More...
 
enum class  Access { ReadOnly , WriteOnly , ReadWrite }
 Supported access modes for message queues. More...
 

Public Member Functions

 MessageQueue (const String &name, bool blocking=false)
 Tries to open an already existing message queue. More...
 
 MessageQueue (const String &name, OpenMode openMode, Access permission=Access::ReadWrite, bool blocking=false)
 Tries to construct a new message queue based on assigned parameters. More...
 
 MessageQueue (const String &name, OpenMode openMode, Access permission, bool blocking, long maxmsg, long msgsize)
 Tries to construct a new message queue based on assigned parameters. More...
 
 ~MessageQueue (void)
 Destructs this instance and closes the message queue. More...
 
bool IsBlocking () const
 Checks if this message queue was created in blocking mode. More...
 
long GetMessageCount () const
 Queries the current amount of message stored in the message queue. More...
 
long GetMaxMessageCount () const
 Queries the maximal amount of messages that can be stored inside the message queue. More...
 
long GetMaxMessageSize () const
 Queries the maximal supported byte-size of a message. More...
 
void Send (const char *pMsg, size_t len, unsigned int prio, Milliseconds timeoutMs=Milliseconds(0))
 Sends a message to the queue. More...
 
size_t Receive (char *pBuffer, size_t len, unsigned int &prio, Milliseconds timeoutMs=Milliseconds(0))
 Receives a message from the queue. More...
 
void Close ()
 Closes the message queue.
 
void Unlink ()
 Deletes the message queue. More...
 

Detailed Description

Message queues allow processes to exchange data in form of messages

Message queues are identified by names of the form /somename, that is, each name must begin with a slash otherwise an exception will be thrown during invocation of the constructor. On linux os the message queues are based on POSIX message queues and therefore are subject to the same restrictions. For example, on some systems the maximum amount of messages in a queue is set to 10. For more information see POSIX message queue.

Member Enumeration Documentation

◆ Access

Supported access modes for message queues.

Enumerator
ReadOnly 

Object owner has only permission for read access.

WriteOnly 

Object owner has only permission for write access.

ReadWrite 

Object owner can reas and write to message queue.

◆ OpenMode

Supported opening modes for message queues.

Enumerator
CreateNew 

A new queue should be created. If one already exists an exception will be thrown.

Open 

An already existing queue should be opened. An exception will be thrown if the message could does not exists yet.

OpenOrCreate 

An already existing queue should be opened. If no one exists yet, a new one will be created.

Constructor & Destructor Documentation

◆ MessageQueue() [1/3]

Arp::System::Commons::Ipc::MessageQueue::MessageQueue ( const String name,
bool  blocking = false 
)

Tries to open an already existing message queue.

Parameters
nameName of message queue to be opened. Must be of the form /somename.
blockingFlag indicating if queue should be opened in blocking mode.
Exceptions
Arp::System::Commons::InvalidOperationExceptionif message queues are not supported.
Arp::Exceptionwith additional error message if the queue could not be created by the operating system.

◆ MessageQueue() [2/3]

Arp::System::Commons::Ipc::MessageQueue::MessageQueue ( const String name,
OpenMode  openMode,
Access  permission = Access::ReadWrite,
bool  blocking = false 
)

Tries to construct a new message queue based on assigned parameters.

Parameters
nameName of message queue to be opened. Must be of the form /somename.
openModeOpening mode for message queue.
permissionDetermines access permissions for object owner.
blockingFlag indicating if queue should be opened in blocking mode.
Exceptions
Arp::System::Commons::InvalidOperationExceptionif message queues are not supported.
Arp::Exceptionwith additional error message if the queue could not be created by the operating system.

◆ MessageQueue() [3/3]

Arp::System::Commons::Ipc::MessageQueue::MessageQueue ( const String name,
OpenMode  openMode,
Access  permission,
bool  blocking,
long  maxmsg,
long  msgsize 
)

Tries to construct a new message queue based on assigned parameters.

Parameters
nameName of message queue to be opened. Must be of the form /somename.
openModeOpening mode for message queue.
permissionDetermines access permissions for object owner.
blockingFlag indicating if queue should be opened in blocking mode.
maxmsgAmount of messages that can be stored by the message queue internally. On linux os this value is restricted by the current setting for POSIX message queues. See POSIX message queue for more information.
msgsizeMaximal amount of bytes of a single message.
Exceptions
Arp::System::Commons::InvalidOperationExceptionif message queues are not supported.
Arp::Exceptionwith additional error message if the queue could not be created by the operating system.

◆ ~MessageQueue()

Arp::System::Commons::Ipc::MessageQueue::~MessageQueue ( void  )

Destructs this instance and closes the message queue.

The message queue is not deleted until Unlink is called. That is, a new object instance for the same message queue will reopen the previously created queue.

Member Function Documentation

◆ GetMaxMessageCount()

long Arp::System::Commons::Ipc::MessageQueue::GetMaxMessageCount ( ) const

Queries the maximal amount of messages that can be stored inside the message queue.

Exceptions
Arp::Exceptionwith additional error information.
Returns
Maximal amount of messages that can be stored inside the message queue.

◆ GetMaxMessageSize()

long Arp::System::Commons::Ipc::MessageQueue::GetMaxMessageSize ( ) const

Queries the maximal supported byte-size of a message.

Exceptions
Arp::Exceptionwith additional error information.
Returns
Maximal supported byte-size of a message.

◆ GetMessageCount()

long Arp::System::Commons::Ipc::MessageQueue::GetMessageCount ( ) const

Queries the current amount of message stored in the message queue.

Exceptions
Arp::Exceptionwith additional error information.
Returns
Current amount of message stored in the message queue.

◆ IsBlocking()

bool Arp::System::Commons::Ipc::MessageQueue::IsBlocking ( ) const

Checks if this message queue was created in blocking mode.

Returns
True if message queue was created in blocking mode, otherwise false is returned.

◆ Receive()

size_t Arp::System::Commons::Ipc::MessageQueue::Receive ( char *  pBuffer,
size_t  len,
unsigned int &  prio,
Milliseconds  timeoutMs = Milliseconds(0) 
)

Receives a message from the queue.

Parameters
pBufferPointer to pre-allocate buffer where message can be stored.
lenCapacaity of buffer in bytes.
prioContainer variable storing the priority of the received message.
timeoutMsTimeout for call in milliseconds. If set to zero the call blocks until a message can be read from the queue.
Exceptions
Arp::Exceptionwith additional error information.
Returns
Amount of bytes read from message queue. A timeout or an empty non-blocking queue is signaled by a return value of 0.

◆ Send()

void Arp::System::Commons::Ipc::MessageQueue::Send ( const char *  pMsg,
size_t  len,
unsigned int  prio,
Milliseconds  timeoutMs = Milliseconds(0) 
)

Sends a message to the queue.

Parameters
pMsgPointer to message to be send to queue.
lenByte-length of message.
prioPriority of message.
timeoutMsTimeout for send call in milliseconds. If set to zero the call blocks until the message can be send.
Exceptions
Arp::Exceptionwith additional error information.

◆ Unlink()

void Arp::System::Commons::Ipc::MessageQueue::Unlink ( )

Deletes the message queue.

The name of the message queue will be deleted immediately from the file system. The queue itself remains until every reference to the queue is closed.

Exceptions
Arp::Exceptionwith additional error information.

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