libwreport  3.29
Public Member Functions | Static Public Member Functions | Data Fields
wreport::BufrBulletin Class Reference

BUFR bulletin implementation. More...

#include <bulletin.h>

Inheritance diagram for wreport::BufrBulletin:
wreport::Bulletin

Public Member Functions

void clear ()
 Reset the bulletin.
 
const char * encoding_name () const override throw ()
 Type of source/target encoding.
 
void load_tables () override
 Load a new set of tables to use for encoding this message.
 
std::string encode () const override
 Encode the message.
 
void print_details (FILE *out) const override
 Print format-specific details.
 
unsigned diff_details (const Bulletin &msg) const override
 Diff format-specific details.
 
- Public Member Functions inherited from wreport::Bulletin
Subsetobtain_subset (unsigned subsection)
 Get a Subset from the message. More...
 
const Subsetsubset (unsigned subsection) const
 Get a Subset from the message. More...
 
void print (FILE *out) const
 Dump the contents of this bulletin.
 
void print_structured (FILE *out) const
 Dump the contents of this bulletin, in a more structured way.
 
void print_datadesc (FILE *out, unsigned indent=0) const
 Pretty-print the data descriptor section. More...
 
virtual unsigned diff (const Bulletin &msg) const
 Compute the differences between two bulletins. More...
 

Static Public Member Functions

static bool read (FILE *in, std::string &buf, const char *fname=0, off_t *offset=0)
 Read an encoded BUFR message from a stream. More...
 
static void write (const std::string &buf, FILE *out, const char *fname=0)
 Write an encoded BUFR message to a stream. More...
 
static std::unique_ptr< BufrBulletincreate ()
 To prevent breaking ABI if new members are added to bulletins, direct construction is discouraged in favour of an allocator function.
 
static std::unique_ptr< BufrBulletindecode_header (const std::string &raw, const char *fname="(memory)", size_t offset=0)
 Parse only the header of an encoded BUFR message. More...
 
static std::unique_ptr< BufrBulletindecode_header (const std::string &raw, const BufrCodecOptions &opts, const char *fname="(memory)", size_t offset=0)
 Parse only the header of an encoded BUFR message. More...
 
static std::unique_ptr< BufrBulletindecode (const std::string &raw, const char *fname="(memory)", size_t offset=0)
 Parse an encoded BUFR message. More...
 
static std::unique_ptr< BufrBulletindecode_verbose (const std::string &raw, FILE *out, const char *fname="(memory)", size_t offset=0)
 Parse an encoded BUFR message, printing decoding information. More...
 
static std::unique_ptr< BufrBulletindecode (const std::string &raw, const BufrCodecOptions &opts, const char *fname="(memory)", size_t offset=0)
 Parse an encoded BUFR message. More...
 

Data Fields

uint8_t edition_number = 4
 BUFR edition number.
 
uint8_t master_table_version_number = 19
 Version number of BUFR master table used. More...
 
uint8_t master_table_version_number_local = 0
 Version number of local table used to augment the master table. More...
 
bool compression
 Whether the message is compressed.
 
std::string optional_section
 Raw optional section of the message. More...
 
unsigned section_end [6] = { 0, 0, 0, 0, 0, 0 }
 Offsets of the end of BUFR sections. More...
 
- Data Fields inherited from wreport::Bulletin
std::string fname
 Input file name (optional). More...
 
off_t offset = 0
 File offset of the start of the message. More...
 
uint8_t master_table_number = 0
 BUFR Master table number. More...
 
uint8_t data_category = 0xff
 Data category (BUFR or CREX Table A)
 
uint8_t data_subcategory = 0xff
 International data sub-category (see Common Code table C-13)
 
uint8_t data_subcategory_local = 0xff
 Local data sub-category, defined locally by automatic data-processing (ADP) centres. More...
 
uint16_t originating_centre = 0xffff
 Identification of originating/generating centre (see Common Code table C-11)
 
uint16_t originating_subcentre = 0xffff
 Identification of originating/generating sub-centre (allocated by originating/generating centre - see Common Code table C-12)
 
uint8_t update_sequence_number = 0
 Update sequence number (zero for original messages and for messages containing only delayed reports; incremented for the other updates)
 
uint16_t rep_year = 0
 Reference year in bulletin header.
 
uint8_t rep_month = 0
 Reference month in bulletin header.
 
uint8_t rep_day = 0
 Reference day in bulletin header.
 
uint8_t rep_hour = 0
 Reference hour in bulletin header.
 
uint8_t rep_minute = 0
 Reference minute in bulletin header.
 
uint8_t rep_second = 0
 Reference second in bulletin header.
 
Tables tables
 Varcode and opcode tables used for encoding or decoding.
 
std::vector< Varcodedatadesc
 Parsed data descriptor section.
 
std::vector< Subsetsubsets
 Decoded variables.
 

Detailed Description

BUFR bulletin implementation.

Member Function Documentation

◆ decode() [1/2]

static std::unique_ptr<BufrBulletin> wreport::BufrBulletin::decode ( const std::string &  raw,
const BufrCodecOptions opts,
const char *  fname = "(memory)",
size_t  offset = 0 
)
static

Parse an encoded BUFR message.

Parameters
bufThe buffer to decode
optsOptions used to customise encoding or decoding.
fnameThe file name to use for error messages
offsetThe offset inside the file of the start of the bulletin, used for error messages
Returns
The new bulletin with the decoded message

◆ decode() [2/2]

static std::unique_ptr<BufrBulletin> wreport::BufrBulletin::decode ( const std::string &  raw,
const char *  fname = "(memory)",
size_t  offset = 0 
)
static

Parse an encoded BUFR message.

Parameters
bufThe buffer to decode
fnameThe file name to use for error messages
offsetThe offset inside the file of the start of the bulletin, used for error messages
Returns
The new bulletin with the decoded message

◆ decode_header() [1/2]

static std::unique_ptr<BufrBulletin> wreport::BufrBulletin::decode_header ( const std::string &  raw,
const BufrCodecOptions opts,
const char *  fname = "(memory)",
size_t  offset = 0 
)
static

Parse only the header of an encoded BUFR message.

Parameters
bufThe buffer to decode
optsOptions used to customise encoding or decoding.
fnameThe file name to use for error messages
offsetThe offset inside the file of the start of the bulletin, used for error messages
Returns
The new bulletin with the decoded message

◆ decode_header() [2/2]

static std::unique_ptr<BufrBulletin> wreport::BufrBulletin::decode_header ( const std::string &  raw,
const char *  fname = "(memory)",
size_t  offset = 0 
)
static

Parse only the header of an encoded BUFR message.

Parameters
bufThe buffer to decode
fnameThe file name to use for error messages
offsetThe offset inside the file of the start of the bulletin, used for error messages
Returns
The new bulletin with the decoded message

◆ decode_verbose()

static std::unique_ptr<BufrBulletin> wreport::BufrBulletin::decode_verbose ( const std::string &  raw,
FILE *  out,
const char *  fname = "(memory)",
size_t  offset = 0 
)
static

Parse an encoded BUFR message, printing decoding information.

Parameters
bufThe buffer to decode
outWhere the decoder information should be printed
fnameThe file name to use for error messages
offsetThe offset inside the file of the start of the bulletin, used for error messages
Returns
The new bulletin with the decoded message

◆ read()

static bool wreport::BufrBulletin::read ( FILE *  in,
std::string &  buf,
const char *  fname = 0,
off_t *  offset = 0 
)
static

Read an encoded BUFR message from a stream.

Parameters
inThe stream to read from
bufThe buffer where the data will be written
fnameFile name to use in error messages
Return values
offsetThe offset in the file of the beginning of the BUFR data
Returns
true if a message was found, false on EOF

◆ write()

static void wreport::BufrBulletin::write ( const std::string &  buf,
FILE *  out,
const char *  fname = 0 
)
static

Write an encoded BUFR message to a stream.

Parameters
bufThe buffer with the data to write
outThe stream to write to
fnameFile name to use in error messages

Field Documentation

◆ master_table_version_number

uint8_t wreport::BufrBulletin::master_table_version_number = 19

Version number of BUFR master table used.

See WMO Manual on Codes, Binary codes, FM94-XIV BUFR, Section 1 Identification section, note 5, or FB95-XIV CREX, Specification of sections, note 3, for a list.

◆ master_table_version_number_local

uint8_t wreport::BufrBulletin::master_table_version_number_local = 0

Version number of local table used to augment the master table.

Local tables shall define those parts of the master table which are reserved for local use, thus version numbers of local tables may be changed at will by the originating centre. If no local table is used, the version number of the local table shall be encoded as 0.

◆ optional_section

std::string wreport::BufrBulletin::optional_section

Raw optional section of the message.

It is empty if the message does not contain an optional section.

◆ section_end

unsigned wreport::BufrBulletin::section_end[6] = { 0, 0, 0, 0, 0, 0 }

Offsets of the end of BUFR sections.

This is only filled in during decoding.


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