Logo Search packages:      
Sourcecode: grads version File versions  Download package

gabufr.h

/*  Copyright (C) 1988-2010 by Brian Doty and the 
    Institute of Global Environment and Society (IGES).  
    See file COPYRIGHT for more information.   */

#ifndef GABUFR_H
#define GABUFR_H

#define GABUFR_X_BITS 6
#define GABUFR_Y_BITS 8

#define GABUFR_TBL_SIZE   ((1 << GABUFR_X_BITS) * (1 << GABUFR_Y_BITS))

#define GABUFR_NUM_TYPE 0
#define GABUFR_STR_TYPE 1

#define GABUFR_DEF 0
#define GABUFR_UNDEF 1

#include "gatypes.h"

00021 typedef struct {
  gaint scale;
  gaint offset;
  gaint width;
  gaint datatype; /* flag to indicate numerical or string data */
  char *description;
} gabufr_varinf;

00029 typedef struct gabufr_val_struct {
  struct gabufr_val_struct * next;
  gaint x;      /* BUFR ID (F,X,Y) */
  gaint y;      /* BUFR ID (F,X,Y) */
  gaint z;      /* replication offset (vert. level), if present, or -1 */
  char undef;   /* set to GABUFR_UNDEF if packed data was all ones */
  gadouble val; /* data value when datatype is NUM, or DBL_MIN otherwise */
  char *sval;   /* data value when datatype is STR, or NULL otherwise*/
} gabufr_val;

00039 typedef struct {
  gaint bufr_edition;
  gaint master_tbl_num;
  gaint master_tbl_version;
  gaint local_tbl_version;
} gabufr_tbl_inf;

00046 typedef struct gabufr_msg_struct {
  struct gabufr_msg_struct * next;
  gaint year;            /* base time for entire message */
  gaint month;
  gaint day;
  gaint hour;
  gaint min;
  gaint subcnt;          /* number of subsets */
  gabufr_val ** subs;    /* array of linked lists, with size nsub; 
                      one linked list per subset in message */
  gaint fileindex;       /* index of message in file, just for reference */
  gaint is_new_tbl;      /* if 0, message contains data, otherwise it's a
                        replacement BUFR table */
  /* remainder for use during parsing */
  unsigned char *section0;
  unsigned char *section1;
  unsigned char *section3;
  unsigned char *section4;
  unsigned char *end;
  gabufr_tbl_inf tbl_inf;
} gabufr_msg;

00068 typedef struct {
  gabufr_msg * msgs; /* linked list of decoded messages 
                  (some may be missing if parsing failed */
  gaint msgcnt;      /* number of messages in file */
  /* remainder for use during parsing */
  void * buf; 
  gaint len;
} gabufr_dset;


/***** external interface ******/

/* Open a BUFR datafile and parse into a gabufr_dset structure */
gabufr_dset * gabufr_open(const char * path);

/* Open a BUFR datafile and print descriptors. The only data
 * that are parsed are any replacement tables. */
gabufr_dset * gabufr_scan(const char * path);

/* Release all memory associated with a parsed dset structure */
void gabufr_close(gabufr_dset * dset);

/* Free BUFR tables */
void gabufr_reset_tbls();

/* Set directory where BUFR tables can be found */
void gabufr_set_tbl_base_path(const char * path);

/***** internals *****/

#define GABUFR_OK 0
#define GABUFR_ERR 1

gaint gabufr_valid_varid(gaint f, gaint x, gaint y);

00103 typedef struct gabufr_varid_struct {
  struct gabufr_varid_struct * next;
  gaint f;
  gaint x;
  gaint y;
} gabufr_varid;

/* Read tables into memory */
gaint gabufr_read_tbls(gabufr_tbl_inf * tbl_inf);

/* Return a Table B entry */
gabufr_varinf * gabufr_get_varinf(gaint x, gaint y);

/* Return a Table D entry */
gabufr_varid * gabufr_get_seq(gaint x, gaint y);

/* Free storage used by parsing results */
void gabufr_free(gabufr_dset * bufrdata);

/* Extract BUFR table updates from a decoded NCEP BUFR message */
void gabufr_update_ncep_tbl(gabufr_dset * file, gabufr_msg * msg);

/* Check if table has been loaded */
gaint gabufr_have_tbl(gabufr_tbl_inf * tbl_inf);

/* Free a list of varids */
void gabufr_free_varids(gabufr_varid * list);

/* Free BUFR tables */
void gabufr_reset_tbls();

/* Free all varinfo data */
void gabufr_reinit();

#endif /* GABUFR_H */

Generated by  Doxygen 1.6.0   Back to index