question

Upvotes
Accepted
95 7 12 25

EMA C++ - Print DataDictionary containing entries with negative ids

Hi all,

using the Refinitiv EMA C++ library (3.6.1.L2), I'm seeing a weird behavior.

The application is a consumer, downloading the DataDictionary from the network.

The dictionary contains custom entries, which are using negative IDs.

The consumer downloads and decodes the dictionary without issues: I can inspect and access the custom entries using e.g.

const DictionaryEntry& getEntry(const refinitiv::ema::access::EmaString& fieldName) const;

However, when I print the whole dictionary object (e.g. to save the content to a file, just for troubleshooting), the dictionary lists only the entries with non-negative IDs.

Note: the header of the output actually shows a correct summary, but the following detailed list of entries is partial.

Data Dictionary Dump: MinFid=-23627 MaxFid=32766 NumEntries 20955

Is this expected? How can I get the entire list of entries?

Thanks

Best Regards,

Paolo

Ps: the code is similar to the following:

DataDictionary _dataDictionary;
...
switch (msg.getPayload().getDataType())
{
case DataType::SeriesEnum:
{
if (msg.getName() == "RWFFld")
{
_dataDictionary.decodeFieldDictionary(msg.getPayload().getSeries(), DICTIONARY_NORMAL);
_fldDictComplete |= complete;
}
else if (msg.getName() == "RWFEnum")
{
_dataDictionary.decodeEnumTypeDictionary(msg.getPayload().getSeries(), DICTIONARY_NORMAL);
_enumTypeComplete |= complete;
}

if (_fldDictComplete && _enumTypeComplete)
{
ofstream fidDbDumpFile;
fidDbDumpFile.open(dictDumpFileName);
fidDbDumpFile << _dataDictionary << endl;
fidDbDumpFile.close();
}
break;
}
}
ema-apic++consumerelektron-data-dictionaryFID
icon clock
10 |1500

Up to 2 attachments (including images) can be used with a maximum of 512.0 KiB each and 1.0 MiB total.

1 Answer

· Write an Answer
Upvotes
Accepted
32.2k 40 11 20

Hello @Paolo Parlapiano ,

From my testing, the dictionary that is read from file is valid, and includes both positive and negative range of the fids defined as reflected in:

Data Dictionary Dump: MinFid=-1000 MaxFid=32766 NumEntries 15596

The reason it does not print the negative range, please see open source DataDictionaryImpl on GitHub:

const refinitiv::ema::access::EmaString&  DataDictionaryImpl::toString() const
{
_stringToString.append("Field Dictionary:\n");

RsslDictionaryEntry* rsslDictionaryEntry = 0;
DictionaryEntrydictionaryEntry;

for (Int32 index = 0; index <= _pRsslDataDictionary->maxFid; index++)
{
rsslDictionaryEntry = *(_pRsslDataDictionary->entriesArray + index);

if (rsslDictionaryEntry)
{
dictionaryEntry._pImpl->rsslDictionaryEntry(rsslDictionaryEntry);
_stringToString.append("  Fid=").append(dictionaryEntry.getFid()).append(" '").append(dictionaryEntry.getAcronym()).
append("' '").append(dictionaryEntry.getDDEAcronym()).
append("' Type=").append(dictionaryEntry.getFieldType()).
append(" RippleTo=").append(dictionaryEntry.getRippleToField()).append(" Len=").append(dictionaryEntry.getLength()).
append(" EnumLen=").append(dictionaryEntry.getEnumLength()).
append(" RwfType=").append(dictionaryEntry.getRwfType()).append(" RwfLen=").append(dictionaryEntry.getRwfLength()).append("\n");
}
}

By default, the printing of the dictionaries (fids) does not start with minFid but starts with 0.

If you are populating negative range- you may wish to print from minFid, and if you are building RTSDK from source, you could modify at this point, rebuild and should see the negative fids included in the dictionary output.

Hope that this information helps.


icon clock
10 |1500

Up to 2 attachments (including images) can be used with a maximum of 512.0 KiB each and 1.0 MiB total.

Hello @Paolo Parlapiano ,

Your question was also submitted to RTSDK dev team on GitHub as:

https://github.com/Refinitiv/Real-Time-SDK/issues/225

to be reviewed by RTSDK dev team

Thank you @zoya faberov,

this clarifies the experienced behavior.

Best Regards,

Paolo

Write an Answer

Hint: Notify or tag a user in this post by typing @username.

Up to 2 attachments (including images) can be used with a maximum of 512.0 KiB each and 1.0 MiB total.