MQDH (Distribution header) on IBM i
The MQDH structure describes the additional data that is present in a message when that message is a distribution-list message stored on a transmission queue.
Overview
Purpose: A distribution-list message is a message that is sent to multiple destination queues. The additional data consists of the MQDH structure followed by an array of MQOR records and an array of MQPMR records.
This structure is for use by specialized applications that put messages directly on transmission queues, or which remove messages from transmission queues (for example: message channel agents).
This structure should not be used by normal applications which simply want to put messages to distribution lists. Those applications should use the MQOD structure to define the destinations in the distribution list, and the MQPMO structure to specify message properties or receive information about the messages sent to the individual destinations.
Character set and encoding: Data in MQDH must be in the character set given by the CodedCharSetId queue manager attribute and encoding of the local queue manager given by ENNAT for the C programming language.
The character set and encoding of the MQDH must be set into the MDCSI and MDENC fields in:- The MQMD (if the MQDH structure is at the start of the message data), or
- The header structure that precedes the MQDH structure (all other cases).
- MQXQH structure
- MQDH structure plus arrays of MQOR and MQPMR records
- Application message data
Depending on the destinations, more than one such message might be generated by the queue manager, and placed on different transmission queues. In this case, the MQDH structures in those messages identify different subsets of the destinations defined by the distribution list opened by the application.
An application that puts a distribution-list message directly on a transmission queue must conform to the sequence described previously, and must ensure that the MQDH structure is correct. If the MQDH structure is not valid, the queue manager may choose to fail the MQPUT or MQPUT1 call with reason code RC2135.
Messages can be stored on a queue in distribution-list form only if the queue is defined as being able to support distribution list messages (see the DistLists queue attribute described in Attributes for queues ). If an application puts a distribution-list message directly on a queue that does not support distribution lists, the queue manager splits the distribution list message into individual messages, and places those on the queue instead.
Fields
The MQDH structure contains the following fields; the fields are described in alphabetical order:
- DHCNT (10-digit signed integer)
-
Number of MQOR records present.
This defines the number of destinations. A distribution list must always contain at least one destination, so DHCNT must always be greater than zero.
The initial value of this field is 0.
- DHCSI (10-digit signed integer)
-
Character set identifier of data that follows the MQOR and MQPMR records.
This specifies the character set identifier of the data that follows the arrays of MQOR and MQPMR records; it does not apply to character data in the MQDH structure itself.
On the MQPUT or MQPUT1 call, the application must set this field to the value appropriate to the data. The following special value can be used:- CSINHT
- Inherit character-set identifier of this structure.
Character data in the data following this structure is in the same character set as this structure.
The queue manager changes this value in the structure sent in the message to the actual character-set identifier of the structure. Provided no error occurs, the value CSINHT is not returned by the MQGET call.
CSINHT cannot be used if the value of the MDPAT field in MQMD is ATBRKR.
The initial value of this field is CSUNDF.
- DHENC (10-digit signed integer)
-
Numeric encoding of data that follows the MQOR and MQPMR records.
This specifies the numeric encoding of the data that follows the arrays of MQOR and MQPMR records; it does not apply to numeric data in the MQDH structure itself.
On the MQPUT or MQPUT1 call, the application must set this field to the value appropriate to the data.
The initial value of this field is 0.
- DHFLG (10-digit signed integer)
-
General flags.
The following flag can be specified:- DHFNEW
- Generate new message identifiers.
This flag indicates that a new message identifier is to be generated for each destination in the distribution list. This can be set only when there are no put-message records present, or when the records are present but they do not contain the PRMID field.
Use this flag defers generation of the message identifiers until the last possible moment, namely the moment when the distribution-list message is finally split into individual messages. This minimizes the amount of control information that must flow with the distribution-list message.
When an application puts a message to a distribution list, the queue manager sets DHFNEW in the MQDH it generates when both of the following statements are true:- There are no put-message records provided by the application, or the records provided do not contain the PRMID field.
- The MDMID field in MQMD is MINONE, or the PMOPT field in MQPMO includes PMNMID
If no flags are needed, the following can be specified:
- DHFNON
- No flags.
This constant indicates that no flags have been specified. DHFNON is defined to aid program documentation. It is not intended that this constant is used with any other, but as its value is zero, such use cannot be detected.
The initial value of this field is DHFNON.
- DHFMT (8-byte character string)
-
Format name of data that follows the MQOR and MQPMR records.
This specifies the format name of the data that follows the arrays of MQOD and MQPMR records (whichever occurs last).
On the MQPUT or MQPUT1 call, the application must set this field to the value appropriate to the data. The rules for coding this field are the same as those for the MDFMT field in MQMD.
The initial value of this field is FMNONE.
- DHLEN (10-digit signed integer)
-
Length of MQDH structure plus following MQOR and MQPMR records.
This is the number of bytes from the start of the MQDH structure to the start of the message data following the arrays of MQOR and MQPMR records. The data occurs in the following sequence:- MQDH structure
- Array of MQOR records
- Array of MQPMR records
- Message data
The arrays of MQOR and MQPMR records are addressed by offsets contained within the MQDH structure. If these offsets result in unused bytes between one or more of the MQDH structure, the arrays of records, and the message data, those unused bytes must be included in the value of DHLEN, but the content of those bytes is not preserved by the queue manager. It is valid for the array of MQPMR records to precede the array of MQOR records.
The initial value of this field is 0.
- DHORO (10-digit signed integer)
-
Offset of first MQOR record from start of MQDH.
This field gives the offset in bytes of the first record in the array of MQOR object records containing the names of the destination queues. There are DHCNT records in this array. These records (plus any bytes skipped between the first object record and the previous field) are included in the length given by the DHLEN field.
A distribution list must always contain at least one destination, so DHORO must always be greater than zero.
The initial value of this field is 0.
- DHPRF (10-digit signed integer)
-
Flags indicating which MQPMR fields are present.
Zero or more of the following flags can be specified:- PFMID
- Message-identifier field is present.
- PFCID
- Correlation-identifier field is present.
- PFGID
- Group-identifier field is present.
- PFFB
- Feedback field is present.
- PFACC
- Accounting-token field is present.
If no MQPMR fields are present, the following can be specified:
- PFNONE
- No put-message record fields are present.
PFNONE is defined to aid program documentation. It is not intended that this constant be used with any other, but as its value is zero, such use cannot be detected.
The initial value of this field is PFNONE.
- DHPRO (10-digit signed integer)
-
Offset of first MQPMR record from start of MQDH.
This field gives the offset in bytes of the first record in the array of MQPMR put message records containing the message properties. If present, there are DHCNT records in this array. These records (plus any bytes skipped between the first put message record and the previous field) are included in the length given by the DHLEN field.
Put message records are optional; if no records are provided, DHPRO is zero, and DHPRF has the value PFNONE.
The initial value of this field is 0.
- DHSID (4-byte character string)
-
Structure identifier.
The value must be:- DHSIDV
- Identifier for distribution header structure.
The initial value of this field is DHSIDV.
- DHVER (10-digit signed integer)
-
Structure version number.
The value must be:- DHVER1
- Version number for distribution header structure.
The following constant specifies the version number of the current version:
- DHVERC
- Current version of distribution header structure.
The initial value of this field is DHVER1.
Initial values
Field name | Name of constant | Value of constant |
---|---|---|
DHSID | DHSIDV | 'DH¬¬' |
DHVER | DHVER1 | 1 |
DHLEN | None | 0 |
DHENC | None | 0 |
DHCSI | CSUNDF | 0 |
DHFMT | FMNONE | Blanks |
DHFLG | DHFNON | 0 |
DHPRF | PFNONE | 0 |
DHCNT | None | 0 |
DHORO | None | 0 |
DHPRO | None | 0 |
- The symbol ¬ represents a single blank character.
RPG declaration
D*..1....:....2....:....3....:....4....:....5....:....6....:....7.. D* MQDH Structure D* D* Structure identifier D DHSID 1 4 INZ('DH ') D* Structure version number D DHVER 5 8I 0 INZ(1) D* Length of MQDH structure plusfollowing MQOR and MQPMR records D DHLEN 9 12I 0 INZ(0) D* Numeric encoding of data that followsthe MQOR and MQPMR records D DHENC 13 16I 0 INZ(0) D* Character set identifier of data thatfollows the MQOR and MQPMR D* records D DHCSI 17 20I 0 INZ(0) D* Format name of data that follows theMQOR and MQPMR records D DHFMT 21 28 INZ(' ') D* General flags D DHFLG 29 32I 0 INZ(0) D* Flags indicating which MQPMR fieldsare present D DHPRF 33 36I 0 INZ(0) D* Number of MQOR records present D DHCNT 37 40I 0 INZ(0) D* Offset of first MQOR record from startof MQDH D DHORO 41 44I 0 INZ(0) D* Offset of first MQPMR record fromstart of MQDH D DHPRO 45 48I 0 INZ(0)