set_message_queue_paramT_set_message_queue_paramSetMessageQueueParamSetMessageQueueParamset_message_queue_param (Operator)

Name

set_message_queue_paramT_set_message_queue_paramSetMessageQueueParamSetMessageQueueParamset_message_queue_param — Set message queue parameters or invoke commands on the queue.

Signature

set_message_queue_param( : : QueueHandle, GenParamName, GenParamValue : )

Herror T_set_message_queue_param(const Htuple QueueHandle, const Htuple GenParamName, const Htuple GenParamValue)

void SetMessageQueueParam(const HTuple& QueueHandle, const HTuple& GenParamName, const HTuple& GenParamValue)

void HMessageQueue::SetMessageQueueParam(const HTuple& GenParamName, const HTuple& GenParamValue) const

void HMessageQueue::SetMessageQueueParam(const HString& GenParamName, const HTuple& GenParamValue) const

void HMessageQueue::SetMessageQueueParam(const char* GenParamName, const HTuple& GenParamValue) const

void HMessageQueue::SetMessageQueueParam(const wchar_t* GenParamName, const HTuple& GenParamValue) const   ( Windows only)

static void HOperatorSet.SetMessageQueueParam(HTuple queueHandle, HTuple genParamName, HTuple genParamValue)

void HMessageQueue.SetMessageQueueParam(HTuple genParamName, HTuple genParamValue)

void HMessageQueue.SetMessageQueueParam(string genParamName, HTuple genParamValue)

def set_message_queue_param(queue_handle: HHandle, gen_param_name: MaybeSequence[str], gen_param_value: MaybeSequence[Union[int, float, str]]) -> None

Description

set_message_queue_paramset_message_queue_paramSetMessageQueueParamSetMessageQueueParamset_message_queue_param sets message queue parameters or invokes action commands on the queue.

Multiple parameters and action commands can be passed through a single set_message_queue_paramset_message_queue_paramSetMessageQueueParamSetMessageQueueParamset_message_queue_param call, passing multiple parameter names in a tuple GenParamNameGenParamNameGenParamNamegenParamNamegen_param_name and corresponding values in GenParamValueGenParamValueGenParamValuegenParamValuegen_param_value. There must be always the same number of names and values and the values must be in the same order as the names. The parameters and action commands are applied in the same order passed in GenParamNameGenParamNameGenParamNamegenParamNamegen_param_name. It is important to understand that in particular in case of the action commands, it might not be possible to revert the effect of previous action commands if a later command fails, the caller therefore might need to be careful when setting multiple commands in a single call.

Currently supported parameter names are:

'abort_dequeuing'"abort_dequeuing""abort_dequeuing""abort_dequeuing""abort_dequeuing":
'abort_enqueuing'"abort_enqueuing""abort_enqueuing""abort_enqueuing""abort_enqueuing":

Aborts any dequeue_messagedequeue_messageDequeueMessageDequeueMessagedequeue_message or enqueue_messageenqueue_messageEnqueueMessageEnqueueMessageenqueue_message operator waiting in any thread for data to be delivered. Any currently waiting call will unblock and return H_ERR_MQCNCL. Any dequeue_messagedequeue_messageDequeueMessageDequeueMessagedequeue_message or enqueue_messageenqueue_messageEnqueueMessageEnqueueMessageenqueue_message call invoked in the future will return H_ERR_MQCNCL immediately regardless of the queue status.

This command is typically needed for cleanup when any threads using the message queue and possibly blocked in dequeue_messagedequeue_messageDequeueMessageDequeueMessagedequeue_message or enqueue_messageenqueue_messageEnqueueMessageEnqueueMessageenqueue_message must be released, because it is not allowed to destroy the queue (clear_message_queueclear_message_queueClearMessageQueueClearMessageQueueclear_message_queue) while any operators might still use it. It might be necessary to wait for the completion of those threads after invoking the 'abort_dequeuing'"abort_dequeuing""abort_dequeuing""abort_dequeuing""abort_dequeuing" and 'abort_enqueuing'"abort_enqueuing""abort_enqueuing""abort_enqueuing""abort_enqueuing" command to be sure any operators using the queue are completed.

The message data currently stored in the message queue is not affected by the command. The effect of canceling any further dequeue_messagedequeue_messageDequeueMessageDequeueMessagedequeue_message or enqueue_messageenqueue_messageEnqueueMessageEnqueueMessageenqueue_message calls can be reset again using the 'restore_queue'"restore_queue""restore_queue""restore_queue""restore_queue" command.

The parameter value must be integer 1.

'restore_queue'"restore_queue""restore_queue""restore_queue""restore_queue":

Clears the effect of a previous 'abort_dequeuing'"abort_dequeuing""abort_dequeuing""abort_dequeuing""abort_dequeuing" and 'abort_enqueuing'"abort_enqueuing""abort_enqueuing""abort_enqueuing""abort_enqueuing" command. This means the next call to dequeue_messagedequeue_messageDequeueMessageDequeueMessagedequeue_message will again attempt to deliver message data, and the next call to enqueue_messageenqueue_messageEnqueueMessageEnqueueMessageenqueue_message will be able to enqueue new messages.

The parameter value must be integer 1.

'flush_queue'"flush_queue""flush_queue""flush_queue""flush_queue":

Flushes the queue. All currently enqueued messages are removed from the queue and all associated resources, in particular the tuple or object data stored in the messages, are released.

The parameter value must be integer 1.

'max_message_num'"max_message_num""max_message_num""max_message_num""max_message_num":

Sets the maximum number of messages that can be stored in the queue. The setting 'wait_on_full'"wait_on_full""wait_on_full""wait_on_full""wait_on_full" can be used to change the behavior of an enqueue_messageenqueue_messageEnqueueMessageEnqueueMessageenqueue_message operator call that would result in the queue containing more messages after the operation than the defined maximum. In such a case, if 'wait_on_full'"wait_on_full""wait_on_full""wait_on_full""wait_on_full" is set to 'false'"false""false""false""false", enqueue_messageenqueue_messageEnqueueMessageEnqueueMessageenqueue_message would fail with code H_ERR_MQOVL. If 'wait_on_full'"wait_on_full""wait_on_full""wait_on_full""wait_on_full" is set to 'true'"true""true""true""true", enqueue_messageenqueue_messageEnqueueMessageEnqueueMessageenqueue_message would wait until enough space becomes available in the queue.

Setting the 'max_message_num'"max_message_num""max_message_num""max_message_num""max_message_num" parameter has no effect on the messages already present in the queue. No messages that are already in the queue can be removed by this operation.

The parameter value can be a positive integer or -1 if the queue size should be unlimited. The string value 'infinite'"infinite""infinite""infinite""infinite" is accepted as well. The queue size is unlimited by default.

Suggested values: -1, 'infinite'"infinite""infinite""infinite""infinite", 10, 20

Default: -1

'wait_on_full'"wait_on_full""wait_on_full""wait_on_full""wait_on_full":

If 'max_message_num'"max_message_num""max_message_num""max_message_num""max_message_num" is set for the queue, this parameter can be used to configure the behavior of enqueue_messageenqueue_messageEnqueueMessageEnqueueMessageenqueue_message when the queue is full.

If this parameter is set to 'false'"false""false""false""false" (default), then enqueue_messageenqueue_messageEnqueueMessageEnqueueMessageenqueue_message returns the value H_ERR_MQOVL when the queue is full.

If this parameter is set to 'true'"true""true""true""true", then enqueue_messageenqueue_messageEnqueueMessageEnqueueMessageenqueue_message waits when the queue is full until space becomes available again. This can happen through a call to dequeue_messagedequeue_messageDequeueMessageDequeueMessagedequeue_message, by increasing the value of 'max_message_num'"max_message_num""max_message_num""max_message_num""max_message_num", or by manually clearing the queue using 'flush_queue'"flush_queue""flush_queue""flush_queue""flush_queue".

If a call to enqueue_messageenqueue_messageEnqueueMessageEnqueueMessageenqueue_message attempts to place more messages in the queue than allowed by 'max_message_num'"max_message_num""max_message_num""max_message_num""max_message_num", then enqueue_messageenqueue_messageEnqueueMessageEnqueueMessageenqueue_message returns an error regardless of the setting of 'wait_on_full'"wait_on_full""wait_on_full""wait_on_full""wait_on_full".

Pending calls to enqueue_messageenqueue_messageEnqueueMessageEnqueueMessageenqueue_message can also be aborted using 'abort_enqueuing'"abort_enqueuing""abort_enqueuing""abort_enqueuing""abort_enqueuing".

List of values: 'false'"false""false""false""false", 'true'"true""true""true""true"

Default: 'false'"false""false""false""false"

Execution Information

Parameters

QueueHandleQueueHandleQueueHandlequeueHandlequeue_handle (input_control)  message_queue HMessageQueue, HTupleHHandleHTupleHtuple (handle) (IntPtr) (HHandle) (handle)

Message queue handle.

Number of elements: QueueHandle == 1

Restriction: QueueHandle != 0

GenParamNameGenParamNameGenParamNamegenParamNamegen_param_name (input_control)  string(-array) HTupleMaybeSequence[str]HTupleHtuple (string) (string) (HString) (char*)

Names of the queue parameters or action commands.

Number of elements: GenParamName == GenParamValue

Default: 'max_message_num' "max_message_num" "max_message_num" "max_message_num" "max_message_num"

List of values: 'abort_dequeuing'"abort_dequeuing""abort_dequeuing""abort_dequeuing""abort_dequeuing", 'abort_enqueuing'"abort_enqueuing""abort_enqueuing""abort_enqueuing""abort_enqueuing", 'flush_queue'"flush_queue""flush_queue""flush_queue""flush_queue", 'max_message_num'"max_message_num""max_message_num""max_message_num""max_message_num", 'restore_queue'"restore_queue""restore_queue""restore_queue""restore_queue", 'wait_on_full'"wait_on_full""wait_on_full""wait_on_full""wait_on_full"

GenParamValueGenParamValueGenParamValuegenParamValuegen_param_value (input_control)  tuple(-array) HTupleMaybeSequence[Union[int, float, str]]HTupleHtuple (string / integer / real) (string / int / long / double) (HString / Hlong / double) (char* / Hlong / double)

Values of the queue parameters or action commands.

Number of elements: GenParamName == GenParamValue

Default: 1

Suggested values: 1, -1, 'true'"true""true""true""true", 'false'"false""false""false""false"

Example (HDevelop)

* abort waiting dequeue_message operators
set_message_queue_param (Queue, 'abort_dequeuing', 1)
* abort waiting enqueue_message operators (if 'wait_on_full' is set)
set_message_queue_param (Queue, 'abort_enqueuing', 1)
*
* ... wait for the operators to abort
*
* Restore normal queue operations
set_message_queue_param (Queue, 'restore_queue', 1)

Result

If all the operator parameters and their values are valid, set_message_queue_paramset_message_queue_paramSetMessageQueueParamSetMessageQueueParamset_message_queue_param returns 2 ( H_MSG_TRUE) . Otherwise an exception is raised.

Possible Predecessors

create_message_queuecreate_message_queueCreateMessageQueueCreateMessageQueuecreate_message_queue

Possible Successors

clear_message_queueclear_message_queueClearMessageQueueClearMessageQueueclear_message_queue

See also

create_message_queuecreate_message_queueCreateMessageQueueCreateMessageQueuecreate_message_queue, clear_message_queueclear_message_queueClearMessageQueueClearMessageQueueclear_message_queue, enqueue_messageenqueue_messageEnqueueMessageEnqueueMessageenqueue_message, dequeue_messagedequeue_messageDequeueMessageDequeueMessagedequeue_message, get_message_queue_paramget_message_queue_paramGetMessageQueueParamGetMessageQueueParamget_message_queue_param, create_messagecreate_messageCreateMessageCreateMessagecreate_message, clear_messageclear_messageClearMessageClearMessageclear_message, set_message_tupleset_message_tupleSetMessageTupleSetMessageTupleset_message_tuple, get_message_tupleget_message_tupleGetMessageTupleGetMessageTupleget_message_tuple, set_message_objset_message_objSetMessageObjSetMessageObjset_message_obj, get_message_objget_message_objGetMessageObjGetMessageObjget_message_obj

Module

Foundation