diff --git a/definitions/bufr/rdb_key.def b/definitions/bufr/rdb_key.def index 915fa96f5..e5eeaddd4 100644 --- a/definitions/bufr/rdb_key.def +++ b/definitions/bufr/rdb_key.def @@ -11,18 +11,22 @@ meta localMinute bits(keyData,27,6) : dump,long_type,no_copy; meta localSecond bits(keyData,33,6) : dump,long_type,no_copy; meta spare bits(keyData,39,1) : no_copy; # 40 bits = 5 bytes -alias mars.localYear=localYear; -alias mars.localMonth=localMonth; -alias mars.localDay=localDay; -alias mars.localHour=localHour; -alias mars.localMinute=localMinute; -alias mars.localSecond=localSecond; +alias rdb.localYear=localYear; +alias rdb.localMonth=localMonth; +alias rdb.localDay=localDay; +alias rdb.localHour=localHour; +alias rdb.localMinute=localMinute; +alias rdb.localSecond=localSecond; +meta localDate sprintf("%.4d%.2d%.2d",localYear,localMonth,localDay) : no_copy,read_only; +meta localTime sprintf("%.2d%.2d",localHour,localMinute) : no_copy,read_only; meta localDateTime julian_date(localYear,localMonth,localDay,localHour,localMinute,localSecond) : no_copy; +alias mars.date = localDate; +alias mars.time = localTime; # isSatellite and other stuff moved to section 3 -ascii[8] keyMore : hidden; -byte[9] keySat : hidden; +ascii[8] keyMore : hidden; +byte[9] keySat : hidden; # 16 bytes unsigned[2] messageLength; @@ -80,9 +84,10 @@ if (oldSubtype < 255 ) { alias ls.rdbType=rdbType; alias ls.rdbSubtype=rdbSubtype; -alias mars.rdbType=rdbType; -alias mars.rdbSubtype=rdbSubtype; +alias rdb.rdbType=rdbType; +alias rdb.rdbSubtype=rdbSubtype; + +alias mars.obstype = rdbSubtype; #Data assimilation loop for purpose of Continous DA unsigned[1] daLoop; - diff --git a/definitions/bufr/section.3.def b/definitions/bufr/section.3.def index 49ac2fa74..7bbe1c486 100644 --- a/definitions/bufr/section.3.def +++ b/definitions/bufr/section.3.def @@ -75,19 +75,15 @@ if (section2Present && bufrHeaderCentre==98 && section2Length==52) { oldSubtype==31) { meta ls.localNumberOfObservations bits(keySat,0,16) : dump,long_type,no_copy; meta ls.satelliteID bits(keySat,16,16) : dump,long_type,no_copy; - alias mars.satelliteID=satelliteID; } else { meta ls.localNumberOfObservations bits(keySat,0,8) : dump,long_type,no_copy; meta ls.satelliteID bits(keySat,8,16) : dump,long_type,no_copy; - alias mars.satelliteID=satelliteID; } } else { meta ls.localLatitude bits(keyData,72,25,-9000000,100000) : dump,no_copy; meta ls.localLongitude bits(keyData,40,26,-18000000,100000) : dump,no_copy; - alias ls.ident=keyMore : dump,string_type,no_copy; - - alias mars.localLatitude=localLatitude; - alias mars.localLongitude=localLongitude; + meta ident trim(keyMore,1,1): dump, no_copy; # remove whitespaces left and right + alias mars.ident = ident : string_type, no_copy; } } diff --git a/examples/F90/bufr_read_tropical_cyclone.f90 b/examples/F90/bufr_read_tropical_cyclone.f90 index a8c1ba0d5..b2b1ee512 100644 --- a/examples/F90/bufr_read_tropical_cyclone.f90 +++ b/examples/F90/bufr_read_tropical_cyclone.f90 @@ -11,7 +11,11 @@ ! ! Description: how to read data for a tropical cyclone BUFR message. ! - +! Please note that tropical cyclone tracks can be encoded in various ways in BUFR. +! Therefore the code below might not work directly for other types of messages +! than the one used in the example. It is advised to use bufr_dump to +! understand the structure of the messages. +! program bufr_read_tropical_cyclone use eccodes implicit none diff --git a/examples/python/bufr_expanded.py b/examples/python/bufr_expanded.py index 3b3df93ee..a012e6db6 100644 --- a/examples/python/bufr_expanded.py +++ b/examples/python/bufr_expanded.py @@ -12,7 +12,6 @@ # # Description: how to read values of different type of keys from BUFR messages. # -# from __future__ import absolute_import from __future__ import print_function diff --git a/examples/python/bufr_keys_iterator.py b/examples/python/bufr_keys_iterator.py index dbc48e6b3..f4a4eecfd 100644 --- a/examples/python/bufr_keys_iterator.py +++ b/examples/python/bufr_keys_iterator.py @@ -11,8 +11,8 @@ # Python implementation: bufr_keys_iterator # # Description: Example on how to use keys_iterator functions and the -# codes_bufr_keys_iterator structure to get all the available -# keys in a BUFR message. +# codes_bufr_keys_iterator structure to get all the available +# keys in a BUFR message. from __future__ import print_function diff --git a/examples/python/bufr_read_tropical_cyclone.py b/examples/python/bufr_read_tropical_cyclone.py index 7fe8aabcb..42031638d 100644 --- a/examples/python/bufr_read_tropical_cyclone.py +++ b/examples/python/bufr_read_tropical_cyclone.py @@ -10,6 +10,11 @@ # # Description: how to read data of the ECMWF EPS tropical cyclone tracks encoded in BUFR format. # +# Please note that tropical cyclone tracks can be encoded in various ways in BUFR. +# Therefore the code below might not work directly for other types of messages +# than the one used in the example. It is advised to use bufr_dump to +# understand the structure of the messages. +# from __future__ import print_function import traceback diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 51e478a82..ef91a859e 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -184,6 +184,7 @@ list( APPEND grib_api_srcs grib_accessor_class_spectral_truncation.c grib_accessor_class_time.c grib_accessor_class_transient.c + grib_accessor_class_trim.c grib_accessor_class_transient_darray.c grib_accessor_class_values.c grib_accessor_class_simple_packing_error.c diff --git a/src/Makefile.am b/src/Makefile.am index 5a67d7535..c483bf548 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -201,6 +201,7 @@ libeccodes_la_prototypes= \ grib_accessor_class_spectral_truncation.c \ grib_accessor_class_time.c \ grib_accessor_class_transient.c \ + grib_accessor_class_trim.c \ grib_accessor_class_values.c \ grib_accessor_class_simple_packing_error.c \ grib_accessor_class_data_simple_packing.c \ diff --git a/src/bufr_keys_iterator.c b/src/bufr_keys_iterator.c index 1d588b457..2dd2d492a 100644 --- a/src/bufr_keys_iterator.c +++ b/src/bufr_keys_iterator.c @@ -89,28 +89,12 @@ int codes_bufr_keys_iterator_rewind(bufr_keys_iterator* ki) return GRIB_SUCCESS; } -static int is_ident_key(const bufr_keys_iterator* kiter) -{ - if (kiter->current->sub_section) - return 0; - - if ((GRIB_ACCESSOR_FLAG_HIDDEN & kiter->current->flags) != 0 && - strcmp(kiter->current->name, "keyMore") == 0 && - grib_is_defined(kiter->handle, "ls.ident")) { - return 1; - } - return 0; -} - static int skip(bufr_keys_iterator* kiter) { if (kiter->current->sub_section) return 1; if (kiter->current->flags & kiter->accessor_flags_skip) { - /* The "ident" key deserves special treatment */ - if (is_ident_key(kiter)) - return 0; return 1; } @@ -233,12 +217,7 @@ char* codes_bufr_keys_iterator_get_name(const bufr_keys_iterator* ckiter) sprintf(ret, "#%d#%s", *r, kiter->current->name); } else { - if (is_ident_key(kiter)) { - strcpy(ret, "ident"); - } - else { - strcpy(ret, kiter->current->name); - } + strcpy(ret, kiter->current->name); } } diff --git a/src/bufr_util.c b/src/bufr_util.c index e44e264ca..58bf2dedc 100644 --- a/src/bufr_util.c +++ b/src/bufr_util.c @@ -204,6 +204,8 @@ static int bufr_decode_rdb_keys(const void* message, long offset_section2, codes return GRIB_SUCCESS; } +#define IDENT_LEN 9 /* 8 chars plus the final 0 terminator */ + /* The ECMWF BUFR local use section */ static int bufr_decode_extra_rdb_keys(const void* message, long offset_section2, codes_bufr_header* hdr) { @@ -261,8 +263,11 @@ static int bufr_decode_extra_rdb_keys(const void* message, long offset_section2, } } else { - size_t i = 0; - long lValue = 0; + size_t i = 0; + long lValue = 0; + char* pTemp = NULL; + char temp[IDENT_LEN] = {0,}; + start = 72; lValue = (long)grib_decode_unsigned_long(pKeyData, &start, 25); hdr->localLatitude = (lValue - 9000000.0) / 100000.0; @@ -270,11 +275,14 @@ static int bufr_decode_extra_rdb_keys(const void* message, long offset_section2, lValue = (long)grib_decode_unsigned_long(pKeyData, &start, 26); hdr->localLongitude = (lValue - 18000000.0) / 100000.0; - /* interpret keyMore as a string */ - for (i = 0; i < 8; ++i) { - hdr->ident[i] = *pKeyMore++; + /* interpret keyMore as a string. Copy to a temporary */ + for (i = 0; i < IDENT_LEN - 1; ++i) { + temp[i] = *pKeyMore++; } - hdr->ident[i] = '\0'; + temp[i] = '\0'; + pTemp = temp; + lrtrim(&pTemp, 1, 1); /* Trim left and right */ + strncpy(hdr->ident, pTemp, IDENT_LEN - 1); } return GRIB_SUCCESS; diff --git a/src/grib_accessor_class.h b/src/grib_accessor_class.h index 2d73fc61b..31292b4cb 100644 --- a/src/grib_accessor_class.h +++ b/src/grib_accessor_class.h @@ -208,6 +208,7 @@ extern grib_accessor_class* grib_accessor_class_to_integer; extern grib_accessor_class* grib_accessor_class_to_string; extern grib_accessor_class* grib_accessor_class_transient; extern grib_accessor_class* grib_accessor_class_transient_darray; +extern grib_accessor_class* grib_accessor_class_trim; extern grib_accessor_class* grib_accessor_class_uint16; extern grib_accessor_class* grib_accessor_class_uint16_little_endian; extern grib_accessor_class* grib_accessor_class_uint32; diff --git a/src/grib_accessor_class_trim.c b/src/grib_accessor_class_trim.c new file mode 100644 index 000000000..6f97593db --- /dev/null +++ b/src/grib_accessor_class_trim.c @@ -0,0 +1,200 @@ +/* + * (C) Copyright 2005- ECMWF. + * + * This software is licensed under the terms of the Apache Licence Version 2.0 + * which can be obtained at http://www.apache.org/licenses/LICENSE-2.0. + * + * In applying this licence, ECMWF does not waive the privileges and immunities granted to it by + * virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction. + */ + +#include "grib_api_internal.h" +/* + This is used by make_class.pl + + START_CLASS_DEF + CLASS = accessor + SUPER = grib_accessor_class_ascii + IMPLEMENTS = unpack_string;pack_string + IMPLEMENTS = init; string_length + MEMBERS= const char* input + MEMBERS= int trim_left + MEMBERS= int trim_right + END_CLASS_DEF + + */ + +/* START_CLASS_IMP */ + +/* + +Don't edit anything between START_CLASS_IMP and END_CLASS_IMP +Instead edit values between START_CLASS_DEF and END_CLASS_DEF +or edit "accessor.class" and rerun ./make_class.pl + +*/ + +static int pack_string(grib_accessor*, const char*, size_t* len); +static int unpack_string(grib_accessor*, char*, size_t* len); +static size_t string_length(grib_accessor*); +static void init(grib_accessor*, const long, grib_arguments*); +static void init_class(grib_accessor_class*); + +typedef struct grib_accessor_trim +{ + grib_accessor att; + /* Members defined in gen */ + /* Members defined in ascii */ + /* Members defined in trim */ + const char* input; + int trim_left; + int trim_right; +} grib_accessor_trim; + +extern grib_accessor_class* grib_accessor_class_ascii; + +static grib_accessor_class _grib_accessor_class_trim = { + &grib_accessor_class_ascii, /* super */ + "trim", /* name */ + sizeof(grib_accessor_trim), /* size */ + 0, /* inited */ + &init_class, /* init_class */ + &init, /* init */ + 0, /* post_init */ + 0, /* free mem */ + 0, /* describes himself */ + 0, /* get length of section */ + &string_length, /* get length of string */ + 0, /* get number of values */ + 0, /* get number of bytes */ + 0, /* get offset to bytes */ + 0, /* get native type */ + 0, /* get sub_section */ + 0, /* grib_pack procedures long */ + 0, /* grib_pack procedures long */ + 0, /* grib_pack procedures long */ + 0, /* grib_unpack procedures long */ + 0, /* grib_pack procedures double */ + 0, /* grib_unpack procedures double */ + &pack_string, /* grib_pack procedures string */ + &unpack_string, /* grib_unpack procedures string */ + 0, /* grib_pack array procedures string */ + 0, /* grib_unpack array procedures string */ + 0, /* grib_pack procedures bytes */ + 0, /* grib_unpack procedures bytes */ + 0, /* pack_expression */ + 0, /* notify_change */ + 0, /* update_size */ + 0, /* preferred_size */ + 0, /* resize */ + 0, /* nearest_smaller_value */ + 0, /* next accessor */ + 0, /* compare vs. another accessor */ + 0, /* unpack only ith value */ + 0, /* unpack a subarray */ + 0, /* clear */ + 0, /* clone accessor */ +}; + + +grib_accessor_class* grib_accessor_class_trim = &_grib_accessor_class_trim; + + +static void init_class(grib_accessor_class* c) +{ + c->dump = (*(c->super))->dump; + c->next_offset = (*(c->super))->next_offset; + c->value_count = (*(c->super))->value_count; + c->byte_count = (*(c->super))->byte_count; + c->byte_offset = (*(c->super))->byte_offset; + c->get_native_type = (*(c->super))->get_native_type; + c->sub_section = (*(c->super))->sub_section; + c->pack_missing = (*(c->super))->pack_missing; + c->is_missing = (*(c->super))->is_missing; + c->pack_long = (*(c->super))->pack_long; + c->unpack_long = (*(c->super))->unpack_long; + c->pack_double = (*(c->super))->pack_double; + c->unpack_double = (*(c->super))->unpack_double; + c->pack_string_array = (*(c->super))->pack_string_array; + c->unpack_string_array = (*(c->super))->unpack_string_array; + c->pack_bytes = (*(c->super))->pack_bytes; + c->unpack_bytes = (*(c->super))->unpack_bytes; + c->pack_expression = (*(c->super))->pack_expression; + c->notify_change = (*(c->super))->notify_change; + c->update_size = (*(c->super))->update_size; + c->preferred_size = (*(c->super))->preferred_size; + c->resize = (*(c->super))->resize; + c->nearest_smaller_value = (*(c->super))->nearest_smaller_value; + c->next = (*(c->super))->next; + c->compare = (*(c->super))->compare; + c->unpack_double_element = (*(c->super))->unpack_double_element; + c->unpack_double_subarray = (*(c->super))->unpack_double_subarray; + c->clear = (*(c->super))->clear; + c->make_clone = (*(c->super))->make_clone; +} + +/* END_CLASS_IMP */ + +static void init(grib_accessor* a, const long l, grib_arguments* arg) +{ + int n = 0; + grib_accessor_trim* self = (grib_accessor_trim*)a; + grib_handle* h = grib_handle_of_accessor(a); + + self->input = grib_arguments_get_name(h, arg, n++); + self->trim_left = grib_arguments_get_long(h, arg, n++); + self->trim_right= grib_arguments_get_long(h, arg, n++); + DebugAssert(self->trim_left == 0 || self->trim_left == 1); + DebugAssert(self->trim_right == 0 || self->trim_right == 1); +} + +static int unpack_string(grib_accessor* a, char* val, size_t* len) +{ + grib_accessor_trim* self = (grib_accessor_trim*)a; + + int err = 0; + grib_handle* h = grib_handle_of_accessor(a); + char input[256] = {0,}; + size_t size = sizeof(input) / sizeof(*input); + char* pInput = input; + + err = grib_get_string(h, self->input, input, &size); + if (err) return err; + + lrtrim(&pInput, self->trim_left, self->trim_right); + sprintf(val, "%s", pInput); + size = strlen(val); + *len = size + 1; + return GRIB_SUCCESS; +} + +static int pack_string(grib_accessor* a, const char* val, size_t* len) +{ + char input[256] = {0,}; + + size_t inputLen = 256; + char buf[256] = {0,}; + char* pBuf = NULL; + int err; + grib_handle* h = grib_handle_of_accessor(a); + grib_accessor_trim* self = (grib_accessor_trim*)a; + grib_accessor* inputAccesstor = grib_find_accessor(h, self->input); + if (!inputAccesstor) { + grib_context_log(a->context, GRIB_LOG_ERROR, "Accessor for %s not found", self->input); + return GRIB_NOT_FOUND; + } + + if ((err = grib_get_string(h, self->input, input, &inputLen)) != GRIB_SUCCESS) + return err; + + sprintf(buf, "%s", val); + pBuf = buf; + lrtrim(&pBuf, self->trim_left, self->trim_right); + + return grib_pack_string(inputAccesstor, pBuf, len); +} + +static size_t string_length(grib_accessor* a) +{ + return 1024; +} diff --git a/src/grib_accessor_classes_hash.c b/src/grib_accessor_classes_hash.c index 7daa566f9..306873272 100644 --- a/src/grib_accessor_classes_hash.c +++ b/src/grib_accessor_classes_hash.c @@ -37,12 +37,12 @@ error "gperf generated tables don't work with this execution character set. Plea #line 6 "accessor_class_list.gperf" struct accessor_class_hash { char *name; grib_accessor_class **cclass;}; -#define TOTAL_KEYWORDS 226 +#define TOTAL_KEYWORDS 227 #define MIN_WORD_LENGTH 1 #define MAX_WORD_LENGTH 44 #define MIN_HASH_VALUE 1 -#define MAX_HASH_VALUE 552 -/* maximum key range = 552, duplicates = 0 */ +#define MAX_HASH_VALUE 618 +/* maximum key range = 618, duplicates = 0 */ #ifdef __GNUC__ @@ -56,32 +56,32 @@ grib_accessor_classes_get_id (const char *str, unsigned int len) { static const unsigned short asso_values[] = { - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 0, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 10, 44, - 14, 0, 24, 553, 28, 553, 0, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 0, 553, 0, 158, 74, - 0, 0, 119, 29, 145, 1, 7, 14, 146, 207, - 13, 63, 20, 553, 87, 1, 53, 103, 160, 9, - 7, 30, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553, 553, 553, 553, 553, - 553, 553, 553, 553, 553, 553 + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 0, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 0, 60, + 18, 14, 21, 619, 23, 619, 4, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 0, 619, 0, 134, 189, + 0, 3, 187, 28, 45, 1, 17, 0, 165, 217, + 14, 64, 55, 619, 109, 3, 2, 98, 201, 3, + 1, 60, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619, 619, 619, 619, 619, + 619, 619, 619, 619, 619, 619 }; register int hval = len; @@ -117,559 +117,589 @@ static const struct accessor_class_hash classes[] = {""}, #line 9 "accessor_class_list.gperf" {" "}, - {""}, {""}, {""}, {""}, + {""}, {""}, {""}, {""}, {""}, +#line 211 "accessor_class_list.gperf" + {"time", &grib_accessor_class_time}, #line 199 "accessor_class_list.gperf" {"size", &grib_accessor_class_size}, #line 14 "accessor_class_list.gperf" {"ascii", &grib_accessor_class_ascii}, + {""}, +#line 212 "accessor_class_list.gperf" + {"times", &grib_accessor_class_times}, + {""}, #line 196 "accessor_class_list.gperf" {"signed", &grib_accessor_class_signed}, - {""}, {""}, {""}, {""}, {""}, -#line 197 "accessor_class_list.gperf" - {"signed_bits", &grib_accessor_class_signed_bits}, - {""}, + {""}, {""}, #line 75 "accessor_class_list.gperf" {"data_raw_packing", &grib_accessor_class_data_raw_packing}, {""}, +#line 205 "accessor_class_list.gperf" + {"statistics", &grib_accessor_class_statistics}, #line 142 "accessor_class_list.gperf" {"int8", &grib_accessor_class_int8}, {""}, +#line 197 "accessor_class_list.gperf" + {"signed_bits", &grib_accessor_class_signed_bits}, + {""}, #line 80 "accessor_class_list.gperf" {"data_simple_packing", &grib_accessor_class_data_simple_packing}, #line 76 "accessor_class_list.gperf" {"data_secondary_bitmap", &grib_accessor_class_data_secondary_bitmap}, -#line 190 "accessor_class_list.gperf" - {"section", &grib_accessor_class_section}, -#line 176 "accessor_class_list.gperf" - {"pad", &grib_accessor_class_pad}, -#line 202 "accessor_class_list.gperf" - {"spd", &grib_accessor_class_spd}, + {""}, #line 82 "accessor_class_list.gperf" {"dictionary", &grib_accessor_class_dictionary}, - {""}, {""}, {""}, +#line 206 "accessor_class_list.gperf" + {"statistics_spectral", &grib_accessor_class_statistics_spectral}, +#line 190 "accessor_class_list.gperf" + {"section", &grib_accessor_class_section}, +#line 164 "accessor_class_list.gperf" + {"nearest", &grib_accessor_class_nearest}, #line 74 "accessor_class_list.gperf" {"data_png_packing", &grib_accessor_class_data_png_packing}, + {""}, {""}, +#line 208 "accessor_class_list.gperf" + {"step_in_units", &grib_accessor_class_step_in_units}, +#line 126 "accessor_class_list.gperf" + {"gen", &grib_accessor_class_gen}, + {""}, #line 192 "accessor_class_list.gperf" {"section_padding", &grib_accessor_class_section_padding}, #line 193 "accessor_class_list.gperf" {"section_pointer", &grib_accessor_class_section_pointer}, -#line 126 "accessor_class_list.gperf" - {"gen", &grib_accessor_class_gen}, #line 138 "accessor_class_list.gperf" {"int32", &grib_accessor_class_int32}, - {""}, #line 66 "accessor_class_list.gperf" {"data_g22order_packing", &grib_accessor_class_data_g22order_packing}, -#line 83 "accessor_class_list.gperf" - {"dirty", &grib_accessor_class_dirty}, -#line 50 "accessor_class_list.gperf" - {"data_apply_bitmap", &grib_accessor_class_data_apply_bitmap}, -#line 70 "accessor_class_list.gperf" - {"data_g2shsimple_packing", &grib_accessor_class_data_g2shsimple_packing}, {""}, -#line 88 "accessor_class_list.gperf" - {"expanded_descriptors", &grib_accessor_class_expanded_descriptors}, -#line 189 "accessor_class_list.gperf" - {"second_order_bits_per_value", &grib_accessor_class_second_order_bits_per_value}, -#line 191 "accessor_class_list.gperf" - {"section_length", &grib_accessor_class_section_length}, #line 140 "accessor_class_list.gperf" {"int64", &grib_accessor_class_int64}, -#line 53 "accessor_class_list.gperf" - {"data_apply_gdsnotpresent", &grib_accessor_class_data_apply_gdsnotpresent}, -#line 124 "accessor_class_list.gperf" - {"gds_is_present", &grib_accessor_class_gds_is_present}, -#line 51 "accessor_class_list.gperf" - {"data_apply_boustrophedonic", &grib_accessor_class_data_apply_boustrophedonic}, +#line 70 "accessor_class_list.gperf" + {"data_g2shsimple_packing", &grib_accessor_class_data_g2shsimple_packing}, #line 136 "accessor_class_list.gperf" {"int16", &grib_accessor_class_int16}, +#line 88 "accessor_class_list.gperf" + {"expanded_descriptors", &grib_accessor_class_expanded_descriptors}, + {""}, +#line 124 "accessor_class_list.gperf" + {"gds_is_present", &grib_accessor_class_gds_is_present}, + {""}, {""}, +#line 191 "accessor_class_list.gperf" + {"section_length", &grib_accessor_class_section_length}, +#line 189 "accessor_class_list.gperf" + {"second_order_bits_per_value", &grib_accessor_class_second_order_bits_per_value}, #line 127 "accessor_class_list.gperf" {"getenv", &grib_accessor_class_getenv}, -#line 121 "accessor_class_list.gperf" - {"g2step", &grib_accessor_class_g2step}, +#line 235 "accessor_class_list.gperf" + {"when", &grib_accessor_class_when}, #line 117 "accessor_class_list.gperf" {"g2grid", &grib_accessor_class_g2grid}, +#line 115 "accessor_class_list.gperf" + {"g2date", &grib_accessor_class_g2date}, +#line 121 "accessor_class_list.gperf" + {"g2step", &grib_accessor_class_g2step}, +#line 113 "accessor_class_list.gperf" + {"g2bitmap", &grib_accessor_class_g2bitmap}, + {""}, +#line 176 "accessor_class_list.gperf" + {"pad", &grib_accessor_class_pad}, +#line 116 "accessor_class_list.gperf" + {"g2end_step", &grib_accessor_class_g2end_step}, + {""}, +#line 202 "accessor_class_list.gperf" + {"spd", &grib_accessor_class_spd}, + {""}, {""}, {""}, +#line 120 "accessor_class_list.gperf" + {"g2lon", &grib_accessor_class_g2lon}, +#line 83 "accessor_class_list.gperf" + {"dirty", &grib_accessor_class_dirty}, + {""}, {""}, +#line 125 "accessor_class_list.gperf" + {"gds_not_present_bitmap", &grib_accessor_class_gds_not_present_bitmap}, + {""}, {""}, +#line 50 "accessor_class_list.gperf" + {"data_apply_bitmap", &grib_accessor_class_data_apply_bitmap}, + {""}, {""}, +#line 143 "accessor_class_list.gperf" + {"iterator", &grib_accessor_class_iterator}, #line 73 "accessor_class_list.gperf" {"data_jpeg2000_packing", &grib_accessor_class_data_jpeg2000_packing}, {""}, +#line 215 "accessor_class_list.gperf" + {"to_string", &grib_accessor_class_to_string}, +#line 53 "accessor_class_list.gperf" + {"data_apply_gdsnotpresent", &grib_accessor_class_data_apply_gdsnotpresent}, + {""}, +#line 51 "accessor_class_list.gperf" + {"data_apply_boustrophedonic", &grib_accessor_class_data_apply_boustrophedonic}, + {""}, +#line 56 "accessor_class_list.gperf" + {"data_constant_field", &grib_accessor_class_data_constant_field}, +#line 64 "accessor_class_list.gperf" + {"data_g1shsimple_packing", &grib_accessor_class_data_g1shsimple_packing}, +#line 130 "accessor_class_list.gperf" + {"gts_header", &grib_accessor_class_gts_header}, + {""}, +#line 55 "accessor_class_list.gperf" + {"data_complex_packing", &grib_accessor_class_data_complex_packing}, #line 52 "accessor_class_list.gperf" {"data_apply_boustrophedonic_bitmap", &grib_accessor_class_data_apply_boustrophedonic_bitmap}, -#line 116 "accessor_class_list.gperf" - {"g2end_step", &grib_accessor_class_g2end_step}, +#line 122 "accessor_class_list.gperf" + {"g2step_range", &grib_accessor_class_g2step_range}, + {""}, +#line 177 "accessor_class_list.gperf" + {"padding", &grib_accessor_class_padding}, + {""}, +#line 214 "accessor_class_list.gperf" + {"to_integer", &grib_accessor_class_to_integer}, #line 71 "accessor_class_list.gperf" {"data_g2simple_packing", &grib_accessor_class_data_g2simple_packing}, #line 68 "accessor_class_list.gperf" {"data_g2complex_packing", &grib_accessor_class_data_g2complex_packing}, -#line 177 "accessor_class_list.gperf" - {"padding", &grib_accessor_class_padding}, -#line 211 "accessor_class_list.gperf" - {"time", &grib_accessor_class_time}, - {""}, -#line 212 "accessor_class_list.gperf" - {"times", &grib_accessor_class_times}, -#line 120 "accessor_class_list.gperf" - {"g2lon", &grib_accessor_class_g2lon}, - {""}, {""}, {""}, {""}, {""}, {""}, -#line 64 "accessor_class_list.gperf" - {"data_g1shsimple_packing", &grib_accessor_class_data_g1shsimple_packing}, -#line 111 "accessor_class_list.gperf" - {"g2_eps", &grib_accessor_class_g2_eps}, - {""}, {""}, {""}, -#line 164 "accessor_class_list.gperf" - {"nearest", &grib_accessor_class_nearest}, -#line 72 "accessor_class_list.gperf" - {"data_g2simple_packing_with_preprocessing", &grib_accessor_class_data_g2simple_packing_with_preprocessing}, - {""}, {""}, {""}, {""}, +#line 97 "accessor_class_list.gperf" + {"g1date", &grib_accessor_class_g1date}, #line 95 "accessor_class_list.gperf" {"g1area", &grib_accessor_class_g1area}, -#line 187 "accessor_class_list.gperf" - {"scale", &grib_accessor_class_scale}, -#line 208 "accessor_class_list.gperf" - {"step_in_units", &grib_accessor_class_step_in_units}, -#line 56 "accessor_class_list.gperf" - {"data_constant_field", &grib_accessor_class_data_constant_field}, -#line 55 "accessor_class_list.gperf" - {"data_complex_packing", &grib_accessor_class_data_complex_packing}, -#line 122 "accessor_class_list.gperf" - {"g2step_range", &grib_accessor_class_g2step_range}, -#line 65 "accessor_class_list.gperf" - {"data_g1simple_packing", &grib_accessor_class_data_g1simple_packing}, -#line 58 "accessor_class_list.gperf" - {"data_g1complex_packing", &grib_accessor_class_data_g1complex_packing}, - {""}, -#line 178 "accessor_class_list.gperf" - {"padto", &grib_accessor_class_padto}, - {""}, -#line 183 "accessor_class_list.gperf" - {"raw", &grib_accessor_class_raw}, -#line 93 "accessor_class_list.gperf" - {"g1_message_length", &grib_accessor_class_g1_message_length}, -#line 54 "accessor_class_list.gperf" - {"data_ccsds_packing", &grib_accessor_class_data_ccsds_packing}, - {""}, -#line 15 "accessor_class_list.gperf" - {"assert", &grib_accessor_class_assert}, - {""}, {""}, {""}, {""}, -#line 105 "accessor_class_list.gperf" - {"g1p1p2", &grib_accessor_class_g1p1p2}, +#line 96 "accessor_class_list.gperf" + {"g1bitmap", &grib_accessor_class_g1bitmap}, + {""}, {""}, {""}, {""}, {""}, +#line 209 "accessor_class_list.gperf" + {"sum", &grib_accessor_class_sum}, #line 69 "accessor_class_list.gperf" {"data_g2secondary_bitmap", &grib_accessor_class_data_g2secondary_bitmap}, #line 67 "accessor_class_list.gperf" {"data_g2bifourier_packing", &grib_accessor_class_data_g2bifourier_packing}, -#line 115 "accessor_class_list.gperf" - {"g2date", &grib_accessor_class_g2date}, - {""}, -#line 113 "accessor_class_list.gperf" - {"g2bitmap", &grib_accessor_class_g2bitmap}, -#line 165 "accessor_class_list.gperf" - {"non_alpha", &grib_accessor_class_non_alpha}, -#line 184 "accessor_class_list.gperf" - {"rdbtime_guess_date", &grib_accessor_class_rdbtime_guess_date}, -#line 209 "accessor_class_list.gperf" - {"sum", &grib_accessor_class_sum}, - {""}, -#line 224 "accessor_class_list.gperf" +#line 111 "accessor_class_list.gperf" + {"g2_eps", &grib_accessor_class_g2_eps}, +#line 225 "accessor_class_list.gperf" {"uint8", &grib_accessor_class_uint8}, -#line 220 "accessor_class_list.gperf" - {"uint32", &grib_accessor_class_uint32}, - {""}, {""}, {""}, -#line 107 "accessor_class_list.gperf" - {"g1step_range", &grib_accessor_class_g1step_range}, -#line 194 "accessor_class_list.gperf" - {"select_step_template", &grib_accessor_class_select_step_template}, -#line 109 "accessor_class_list.gperf" - {"g2_aerosol", &grib_accessor_class_g2_aerosol}, -#line 125 "accessor_class_list.gperf" - {"gds_not_present_bitmap", &grib_accessor_class_gds_not_present_bitmap}, -#line 205 "accessor_class_list.gperf" - {"statistics", &grib_accessor_class_statistics}, + {""}, {""}, +#line 93 "accessor_class_list.gperf" + {"g1_message_length", &grib_accessor_class_g1_message_length}, +#line 183 "accessor_class_list.gperf" + {"raw", &grib_accessor_class_raw}, +#line 72 "accessor_class_list.gperf" + {"data_g2simple_packing_with_preprocessing", &grib_accessor_class_data_g2simple_packing_with_preprocessing}, #line 57 "accessor_class_list.gperf" {"data_dummy_field", &grib_accessor_class_data_dummy_field}, +#line 218 "accessor_class_list.gperf" + {"trim", &grib_accessor_class_trim}, +#line 78 "accessor_class_list.gperf" + {"data_sh_unpacked", &grib_accessor_class_data_sh_unpacked}, + {""}, +#line 15 "accessor_class_list.gperf" + {"assert", &grib_accessor_class_assert}, +#line 221 "accessor_class_list.gperf" + {"uint32", &grib_accessor_class_uint32}, +#line 118 "accessor_class_list.gperf" + {"g2latlon", &grib_accessor_class_g2latlon}, +#line 79 "accessor_class_list.gperf" + {"data_shsimple_packing", &grib_accessor_class_data_shsimple_packing}, +#line 207 "accessor_class_list.gperf" + {"step_human_readable", &grib_accessor_class_step_human_readable}, +#line 109 "accessor_class_list.gperf" + {"g2_aerosol", &grib_accessor_class_g2_aerosol}, +#line 178 "accessor_class_list.gperf" + {"padto", &grib_accessor_class_padto}, #line 145 "accessor_class_list.gperf" {"julian_day", &grib_accessor_class_julian_day}, -#line 144 "accessor_class_list.gperf" - {"julian_date", &grib_accessor_class_julian_date}, -#line 13 "accessor_class_list.gperf" - {"array", &grib_accessor_class_array}, - {""}, {""}, -#line 143 "accessor_class_list.gperf" - {"iterator", &grib_accessor_class_iterator}, - {""}, -#line 206 "accessor_class_list.gperf" - {"statistics_spectral", &grib_accessor_class_statistics_spectral}, -#line 12 "accessor_class_list.gperf" - {"apply_operators", &grib_accessor_class_apply_operators}, - {""}, -#line 63 "accessor_class_list.gperf" - {"data_g1secondary_bitmap", &grib_accessor_class_data_g1secondary_bitmap}, - {""}, -#line 97 "accessor_class_list.gperf" - {"g1date", &grib_accessor_class_g1date}, - {""}, -#line 96 "accessor_class_list.gperf" - {"g1bitmap", &grib_accessor_class_g1bitmap}, -#line 123 "accessor_class_list.gperf" - {"gaussian_grid_name", &grib_accessor_class_gaussian_grid_name}, - {""}, {""}, -#line 222 "accessor_class_list.gperf" - {"uint64", &grib_accessor_class_uint64}, -#line 214 "accessor_class_list.gperf" - {"to_integer", &grib_accessor_class_to_integer}, - {""}, -#line 129 "accessor_class_list.gperf" - {"group", &grib_accessor_class_group}, -#line 61 "accessor_class_list.gperf" - {"data_g1second_order_general_packing", &grib_accessor_class_data_g1second_order_general_packing}, - {""}, {""}, -#line 62 "accessor_class_list.gperf" - {"data_g1second_order_row_by_row_packing", &grib_accessor_class_data_g1second_order_row_by_row_packing}, - {""}, {""}, {""}, -#line 59 "accessor_class_list.gperf" - {"data_g1second_order_constant_width_packing", &grib_accessor_class_data_g1second_order_constant_width_packing}, #line 216 "accessor_class_list.gperf" {"transient", &grib_accessor_class_transient}, -#line 60 "accessor_class_list.gperf" - {"data_g1second_order_general_extended_packing", &grib_accessor_class_data_g1second_order_general_extended_packing}, -#line 167 "accessor_class_list.gperf" - {"number_of_points", &grib_accessor_class_number_of_points}, -#line 227 "accessor_class_list.gperf" - {"unsigned", &grib_accessor_class_unsigned}, -#line 218 "accessor_class_list.gperf" - {"uint16", &grib_accessor_class_uint16}, -#line 186 "accessor_class_list.gperf" - {"round", &grib_accessor_class_round}, -#line 148 "accessor_class_list.gperf" - {"laplacian", &grib_accessor_class_laplacian}, + {""}, +#line 223 "accessor_class_list.gperf" + {"uint64", &grib_accessor_class_uint64}, +#line 144 "accessor_class_list.gperf" + {"julian_date", &grib_accessor_class_julian_date}, + {""}, +#line 107 "accessor_class_list.gperf" + {"g1step_range", &grib_accessor_class_g1step_range}, +#line 94 "accessor_class_list.gperf" + {"g1_section4_length", &grib_accessor_class_g1_section4_length}, #line 217 "accessor_class_list.gperf" {"transient_darray", &grib_accessor_class_transient_darray}, -#line 234 "accessor_class_list.gperf" - {"when", &grib_accessor_class_when}, -#line 228 "accessor_class_list.gperf" - {"unsigned_bits", &grib_accessor_class_unsigned_bits}, -#line 204 "accessor_class_list.gperf" - {"sprintf", &grib_accessor_class_sprintf}, -#line 168 "accessor_class_list.gperf" - {"number_of_points_gaussian", &grib_accessor_class_number_of_points_gaussian}, +#line 184 "accessor_class_list.gperf" + {"rdbtime_guess_date", &grib_accessor_class_rdbtime_guess_date}, +#line 222 "accessor_class_list.gperf" + {"uint32_little_endian", &grib_accessor_class_uint32_little_endian}, +#line 65 "accessor_class_list.gperf" + {"data_g1simple_packing", &grib_accessor_class_data_g1simple_packing}, +#line 58 "accessor_class_list.gperf" + {"data_g1complex_packing", &grib_accessor_class_data_g1complex_packing}, #line 16 "accessor_class_list.gperf" {"bit", &grib_accessor_class_bit}, #line 18 "accessor_class_list.gperf" {"bits", &grib_accessor_class_bits}, -#line 146 "accessor_class_list.gperf" - {"ksec1expver", &grib_accessor_class_ksec1expver}, + {""}, #line 17 "accessor_class_list.gperf" {"bitmap", &grib_accessor_class_bitmap}, -#line 231 "accessor_class_list.gperf" - {"values", &grib_accessor_class_values}, -#line 118 "accessor_class_list.gperf" - {"g2latlon", &grib_accessor_class_g2latlon}, -#line 94 "accessor_class_list.gperf" - {"g1_section4_length", &grib_accessor_class_g1_section4_length}, -#line 48 "accessor_class_list.gperf" - {"data_2order_packing", &grib_accessor_class_data_2order_packing}, +#line 165 "accessor_class_list.gperf" + {"non_alpha", &grib_accessor_class_non_alpha}, {""}, -#line 225 "accessor_class_list.gperf" - {"unexpanded_descriptors", &grib_accessor_class_unexpanded_descriptors}, +#line 224 "accessor_class_list.gperf" + {"uint64_little_endian", &grib_accessor_class_uint64_little_endian}, + {""}, {""}, +#line 63 "accessor_class_list.gperf" + {"data_g1secondary_bitmap", &grib_accessor_class_data_g1secondary_bitmap}, {""}, +#line 105 "accessor_class_list.gperf" + {"g1p1p2", &grib_accessor_class_g1p1p2}, + {""}, +#line 228 "accessor_class_list.gperf" + {"unsigned", &grib_accessor_class_unsigned}, #line 19 "accessor_class_list.gperf" {"bits_per_value", &grib_accessor_class_bits_per_value}, -#line 99 "accessor_class_list.gperf" - {"g1end_of_interval_monthly", &grib_accessor_class_g1end_of_interval_monthly}, -#line 49 "accessor_class_list.gperf" - {"data_2order_packing_count", &grib_accessor_class_data_2order_packing_count}, -#line 207 "accessor_class_list.gperf" - {"step_human_readable", &grib_accessor_class_step_human_readable}, -#line 221 "accessor_class_list.gperf" - {"uint32_little_endian", &grib_accessor_class_uint32_little_endian}, + {""}, {""}, {""}, {""}, +#line 229 "accessor_class_list.gperf" + {"unsigned_bits", &grib_accessor_class_unsigned_bits}, +#line 123 "accessor_class_list.gperf" + {"gaussian_grid_name", &grib_accessor_class_gaussian_grid_name}, +#line 61 "accessor_class_list.gperf" + {"data_g1second_order_general_packing", &grib_accessor_class_data_g1second_order_general_packing}, +#line 102 "accessor_class_list.gperf" + {"g1monthlydate", &grib_accessor_class_g1monthlydate}, {""}, -#line 215 "accessor_class_list.gperf" - {"to_string", &grib_accessor_class_to_string}, -#line 203 "accessor_class_list.gperf" - {"spectral_truncation", &grib_accessor_class_spectral_truncation}, -#line 78 "accessor_class_list.gperf" - {"data_sh_unpacked", &grib_accessor_class_data_sh_unpacked}, -#line 198 "accessor_class_list.gperf" - {"simple_packing_error", &grib_accessor_class_simple_packing_error}, - {""}, {""}, {""}, -#line 79 "accessor_class_list.gperf" - {"data_shsimple_packing", &grib_accessor_class_data_shsimple_packing}, - {""}, {""}, -#line 89 "accessor_class_list.gperf" - {"forward", &grib_accessor_class_forward}, -#line 100 "accessor_class_list.gperf" - {"g1fcperiod", &grib_accessor_class_g1fcperiod}, -#line 128 "accessor_class_list.gperf" - {"global_gaussian", &grib_accessor_class_global_gaussian}, -#line 134 "accessor_class_list.gperf" - {"ieeefloat", &grib_accessor_class_ieeefloat}, -#line 173 "accessor_class_list.gperf" - {"offset_file", &grib_accessor_class_offset_file}, -#line 36 "accessor_class_list.gperf" - {"bytes", &grib_accessor_class_bytes}, +#line 62 "accessor_class_list.gperf" + {"data_g1second_order_row_by_row_packing", &grib_accessor_class_data_g1second_order_row_by_row_packing}, {""}, -#line 195 "accessor_class_list.gperf" - {"sexagesimal2decimal", &grib_accessor_class_sexagesimal2decimal}, -#line 43 "accessor_class_list.gperf" - {"concept", &grib_accessor_class_concept}, -#line 92 "accessor_class_list.gperf" - {"g1_increment", &grib_accessor_class_g1_increment}, +#line 131 "accessor_class_list.gperf" + {"hash_array", &grib_accessor_class_hash_array}, +#line 219 "accessor_class_list.gperf" + {"uint16", &grib_accessor_class_uint16}, +#line 59 "accessor_class_list.gperf" + {"data_g1second_order_constant_width_packing", &grib_accessor_class_data_g1second_order_constant_width_packing}, + {""}, +#line 60 "accessor_class_list.gperf" + {"data_g1second_order_general_extended_packing", &grib_accessor_class_data_g1second_order_general_extended_packing}, + {""}, {""}, {""}, {""}, #line 114 "accessor_class_list.gperf" {"g2bitmap_present", &grib_accessor_class_g2bitmap_present}, -#line 182 "accessor_class_list.gperf" - {"proj_string", &grib_accessor_class_proj_string}, - {""}, -#line 210 "accessor_class_list.gperf" - {"suppressed", &grib_accessor_class_suppressed}, - {""}, {""}, -#line 223 "accessor_class_list.gperf" - {"uint64_little_endian", &grib_accessor_class_uint64_little_endian}, -#line 86 "accessor_class_list.gperf" - {"element", &grib_accessor_class_element}, -#line 181 "accessor_class_list.gperf" - {"position", &grib_accessor_class_position}, +#line 13 "accessor_class_list.gperf" + {"array", &grib_accessor_class_array}, +#line 148 "accessor_class_list.gperf" + {"laplacian", &grib_accessor_class_laplacian}, #line 149 "accessor_class_list.gperf" {"latitudes", &grib_accessor_class_latitudes}, {""}, -#line 160 "accessor_class_list.gperf" - {"md5", &grib_accessor_class_md5}, -#line 44 "accessor_class_list.gperf" - {"constant", &grib_accessor_class_constant}, -#line 166 "accessor_class_list.gperf" - {"number_of_coded_values", &grib_accessor_class_number_of_coded_values}, -#line 154 "accessor_class_list.gperf" - {"long", &grib_accessor_class_long}, -#line 161 "accessor_class_list.gperf" - {"message", &grib_accessor_class_message}, -#line 85 "accessor_class_list.gperf" - {"double", &grib_accessor_class_double}, +#line 186 "accessor_class_list.gperf" + {"round", &grib_accessor_class_round}, {""}, -#line 158 "accessor_class_list.gperf" - {"mars_param", &grib_accessor_class_mars_param}, -#line 112 "accessor_class_list.gperf" - {"g2_mars_labeling", &grib_accessor_class_g2_mars_labeling}, -#line 180 "accessor_class_list.gperf" - {"padtomultiple", &grib_accessor_class_padtomultiple}, - {""}, -#line 219 "accessor_class_list.gperf" +#line 86 "accessor_class_list.gperf" + {"element", &grib_accessor_class_element}, +#line 220 "accessor_class_list.gperf" {"uint16_little_endian", &grib_accessor_class_uint16_little_endian}, {""}, {""}, +#line 146 "accessor_class_list.gperf" + {"ksec1expver", &grib_accessor_class_ksec1expver}, + {""}, +#line 167 "accessor_class_list.gperf" + {"number_of_points", &grib_accessor_class_number_of_points}, + {""}, +#line 203 "accessor_class_list.gperf" + {"spectral_truncation", &grib_accessor_class_spectral_truncation}, +#line 198 "accessor_class_list.gperf" + {"simple_packing_error", &grib_accessor_class_simple_packing_error}, + {""}, +#line 99 "accessor_class_list.gperf" + {"g1end_of_interval_monthly", &grib_accessor_class_g1end_of_interval_monthly}, +#line 48 "accessor_class_list.gperf" + {"data_2order_packing", &grib_accessor_class_data_2order_packing}, +#line 181 "accessor_class_list.gperf" + {"position", &grib_accessor_class_position}, +#line 12 "accessor_class_list.gperf" + {"apply_operators", &grib_accessor_class_apply_operators}, +#line 168 "accessor_class_list.gperf" + {"number_of_points_gaussian", &grib_accessor_class_number_of_points_gaussian}, + {""}, +#line 129 "accessor_class_list.gperf" + {"group", &grib_accessor_class_group}, +#line 49 "accessor_class_list.gperf" + {"data_2order_packing_count", &grib_accessor_class_data_2order_packing_count}, +#line 112 "accessor_class_list.gperf" + {"g2_mars_labeling", &grib_accessor_class_g2_mars_labeling}, +#line 187 "accessor_class_list.gperf" + {"scale", &grib_accessor_class_scale}, #line 21 "accessor_class_list.gperf" {"box", &grib_accessor_class_box}, +#line 36 "accessor_class_list.gperf" + {"bytes", &grib_accessor_class_bytes}, +#line 226 "accessor_class_list.gperf" + {"unexpanded_descriptors", &grib_accessor_class_unexpanded_descriptors}, {""}, -#line 229 "accessor_class_list.gperf" - {"validity_date", &grib_accessor_class_validity_date}, -#line 230 "accessor_class_list.gperf" - {"validity_time", &grib_accessor_class_validity_time}, - {""}, -#line 233 "accessor_class_list.gperf" - {"vector", &grib_accessor_class_vector}, +#line 182 "accessor_class_list.gperf" + {"proj_string", &grib_accessor_class_proj_string}, {""}, +#line 54 "accessor_class_list.gperf" + {"data_ccsds_packing", &grib_accessor_class_data_ccsds_packing}, #line 84 "accessor_class_list.gperf" {"divdouble", &grib_accessor_class_divdouble}, {""}, +#line 232 "accessor_class_list.gperf" + {"values", &grib_accessor_class_values}, +#line 128 "accessor_class_list.gperf" + {"global_gaussian", &grib_accessor_class_global_gaussian}, + {""}, {""}, {""}, {""}, +#line 230 "accessor_class_list.gperf" + {"validity_date", &grib_accessor_class_validity_date}, +#line 231 "accessor_class_list.gperf" + {"validity_time", &grib_accessor_class_validity_time}, + {""}, {""}, +#line 160 "accessor_class_list.gperf" + {"md5", &grib_accessor_class_md5}, +#line 195 "accessor_class_list.gperf" + {"sexagesimal2decimal", &grib_accessor_class_sexagesimal2decimal}, + {""}, +#line 210 "accessor_class_list.gperf" + {"suppressed", &grib_accessor_class_suppressed}, + {""}, {""}, {""}, +#line 158 "accessor_class_list.gperf" + {"mars_param", &grib_accessor_class_mars_param}, +#line 159 "accessor_class_list.gperf" + {"mars_step", &grib_accessor_class_mars_step}, + {""}, +#line 161 "accessor_class_list.gperf" + {"message", &grib_accessor_class_message}, +#line 132 "accessor_class_list.gperf" + {"headers_only", &grib_accessor_class_headers_only}, + {""}, +#line 154 "accessor_class_list.gperf" + {"long", &grib_accessor_class_long}, + {""}, +#line 85 "accessor_class_list.gperf" + {"double", &grib_accessor_class_double}, + {""}, +#line 92 "accessor_class_list.gperf" + {"g1_increment", &grib_accessor_class_g1_increment}, +#line 200 "accessor_class_list.gperf" + {"smart_table", &grib_accessor_class_smart_table}, + {""}, {""}, +#line 24 "accessor_class_list.gperf" + {"bufr_data", &grib_accessor_class_bufr_data}, +#line 22 "accessor_class_list.gperf" + {"budgdate", &grib_accessor_class_budgdate}, + {""}, {""}, +#line 201 "accessor_class_list.gperf" + {"smart_table_column", &grib_accessor_class_smart_table_column}, + {""}, +#line 25 "accessor_class_list.gperf" + {"bufr_data_array", &grib_accessor_class_bufr_data_array}, #line 77 "accessor_class_list.gperf" {"data_sh_packed", &grib_accessor_class_data_sh_packed}, - {""}, {""}, -#line 135 "accessor_class_list.gperf" - {"ifs_param", &grib_accessor_class_ifs_param}, -#line 130 "accessor_class_list.gperf" - {"gts_header", &grib_accessor_class_gts_header}, + {""}, {""}, {""}, +#line 26 "accessor_class_list.gperf" + {"bufr_data_element", &grib_accessor_class_bufr_data_element}, {""}, -#line 162 "accessor_class_list.gperf" - {"message_copy", &grib_accessor_class_message_copy}, - {""}, {""}, -#line 131 "accessor_class_list.gperf" - {"hash_array", &grib_accessor_class_hash_array}, - {""}, -#line 102 "accessor_class_list.gperf" - {"g1monthlydate", &grib_accessor_class_g1monthlydate}, #line 163 "accessor_class_list.gperf" {"missing", &grib_accessor_class_missing}, {""}, -#line 188 "accessor_class_list.gperf" - {"scale_values", &grib_accessor_class_scale_values}, - {""}, {""}, {""}, {""}, -#line 179 "accessor_class_list.gperf" - {"padtoeven", &grib_accessor_class_padtoeven}, - {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, - {""}, {""}, -#line 39 "accessor_class_list.gperf" - {"codeflag", &grib_accessor_class_codeflag}, - {""}, -#line 91 "accessor_class_list.gperf" - {"g1_half_byte_codeflag", &grib_accessor_class_g1_half_byte_codeflag}, - {""}, {""}, -#line 159 "accessor_class_list.gperf" - {"mars_step", &grib_accessor_class_mars_step}, -#line 24 "accessor_class_list.gperf" - {"bufr_data", &grib_accessor_class_bufr_data}, - {""}, {""}, {""}, {""}, {""}, -#line 25 "accessor_class_list.gperf" - {"bufr_data_array", &grib_accessor_class_bufr_data_array}, - {""}, -#line 26 "accessor_class_list.gperf" - {"bufr_data_element", &grib_accessor_class_bufr_data_element}, -#line 152 "accessor_class_list.gperf" - {"library_version", &grib_accessor_class_library_version}, - {""}, {""}, #line 33 "accessor_class_list.gperf" {"bufr_simple_thinning", &grib_accessor_class_bufr_simple_thinning}, - {""}, {""}, {""}, -#line 37 "accessor_class_list.gperf" - {"change_scanning_direction", &grib_accessor_class_change_scanning_direction}, {""}, +#line 89 "accessor_class_list.gperf" + {"forward", &grib_accessor_class_forward}, #line 35 "accessor_class_list.gperf" {"bufrdc_expanded_descriptors", &grib_accessor_class_bufrdc_expanded_descriptors}, + {""}, {""}, +#line 100 "accessor_class_list.gperf" + {"g1fcperiod", &grib_accessor_class_g1fcperiod}, #line 32 "accessor_class_list.gperf" {"bufr_has_delayed_replication", &grib_accessor_class_bufr_has_delayed_replication}, - {""}, {""}, -#line 169 "accessor_class_list.gperf" - {"number_of_values", &grib_accessor_class_number_of_values}, - {""}, {""}, -#line 226 "accessor_class_list.gperf" - {"unpack_bufr_values", &grib_accessor_class_unpack_bufr_values}, +#line 134 "accessor_class_list.gperf" + {"ieeefloat", &grib_accessor_class_ieeefloat}, +#line 43 "accessor_class_list.gperf" + {"concept", &grib_accessor_class_concept}, +#line 204 "accessor_class_list.gperf" + {"sprintf", &grib_accessor_class_sprintf}, {""}, -#line 147 "accessor_class_list.gperf" - {"label", &grib_accessor_class_label}, -#line 174 "accessor_class_list.gperf" - {"offset_values", &grib_accessor_class_offset_values}, -#line 175 "accessor_class_list.gperf" - {"pack_bufr_values", &grib_accessor_class_pack_bufr_values}, +#line 173 "accessor_class_list.gperf" + {"offset_file", &grib_accessor_class_offset_file}, {""}, -#line 171 "accessor_class_list.gperf" - {"octahedral_gaussian", &grib_accessor_class_octahedral_gaussian}, - {""}, {""}, -#line 132 "accessor_class_list.gperf" - {"headers_only", &grib_accessor_class_headers_only}, - {""}, {""}, -#line 155 "accessor_class_list.gperf" - {"long_vector", &grib_accessor_class_long_vector}, -#line 20 "accessor_class_list.gperf" - {"blob", &grib_accessor_class_blob}, -#line 170 "accessor_class_list.gperf" - {"number_of_values_data_raw_packing", &grib_accessor_class_number_of_values_data_raw_packing}, -#line 90 "accessor_class_list.gperf" - {"from_scale_factor_scaled_value", &grib_accessor_class_from_scale_factor_scaled_value}, - {""}, -#line 150 "accessor_class_list.gperf" - {"latlon_increment", &grib_accessor_class_latlon_increment}, -#line 133 "accessor_class_list.gperf" - {"ibmfloat", &grib_accessor_class_ibmfloat}, -#line 232 "accessor_class_list.gperf" - {"variable", &grib_accessor_class_variable}, - {""}, {""}, {""}, -#line 157 "accessor_class_list.gperf" - {"lookup", &grib_accessor_class_lookup}, -#line 45 "accessor_class_list.gperf" - {"count_file", &grib_accessor_class_count_file}, - {""}, {""}, -#line 22 "accessor_class_list.gperf" - {"budgdate", &grib_accessor_class_budgdate}, -#line 156 "accessor_class_list.gperf" - {"longitudes", &grib_accessor_class_longitudes}, -#line 87 "accessor_class_list.gperf" - {"evaluate", &grib_accessor_class_evaluate}, -#line 200 "accessor_class_list.gperf" - {"smart_table", &grib_accessor_class_smart_table}, - {""}, {""}, {""}, {""}, {""}, {""}, -#line 201 "accessor_class_list.gperf" - {"smart_table_column", &grib_accessor_class_smart_table_column}, -#line 98 "accessor_class_list.gperf" - {"g1day_of_the_year_date", &grib_accessor_class_g1day_of_the_year_date}, -#line 11 "accessor_class_list.gperf" - {"abstract_vector", &grib_accessor_class_abstract_vector}, - {""}, {""}, {""}, {""}, -#line 139 "accessor_class_list.gperf" - {"int32_little_endian", &grib_accessor_class_int32_little_endian}, - {""}, {""}, {""}, -#line 38 "accessor_class_list.gperf" - {"check_internal_version", &grib_accessor_class_check_internal_version}, +#line 194 "accessor_class_list.gperf" + {"select_step_template", &grib_accessor_class_select_step_template}, {""}, {""}, #line 213 "accessor_class_list.gperf" {"to_double", &grib_accessor_class_to_double}, +#line 234 "accessor_class_list.gperf" + {"vector", &grib_accessor_class_vector}, + {""}, {""}, +#line 44 "accessor_class_list.gperf" + {"constant", &grib_accessor_class_constant}, + {""}, +#line 98 "accessor_class_list.gperf" + {"g1day_of_the_year_date", &grib_accessor_class_g1day_of_the_year_date}, +#line 34 "accessor_class_list.gperf" + {"bufr_string_values", &grib_accessor_class_bufr_string_values}, + {""}, {""}, {""}, {""}, +#line 180 "accessor_class_list.gperf" + {"padtomultiple", &grib_accessor_class_padtomultiple}, + {""}, {""}, {""}, {""}, +#line 162 "accessor_class_list.gperf" + {"message_copy", &grib_accessor_class_message_copy}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, +#line 91 "accessor_class_list.gperf" + {"g1_half_byte_codeflag", &grib_accessor_class_g1_half_byte_codeflag}, + {""}, {""}, +#line 37 "accessor_class_list.gperf" + {"change_scanning_direction", &grib_accessor_class_change_scanning_direction}, + {""}, +#line 20 "accessor_class_list.gperf" + {"blob", &grib_accessor_class_blob}, + {""}, {""}, {""}, {""}, +#line 133 "accessor_class_list.gperf" + {"ibmfloat", &grib_accessor_class_ibmfloat}, + {""}, {""}, {""}, +#line 87 "accessor_class_list.gperf" + {"evaluate", &grib_accessor_class_evaluate}, + {""}, {""}, {""}, {""}, +#line 171 "accessor_class_list.gperf" + {"octahedral_gaussian", &grib_accessor_class_octahedral_gaussian}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, +#line 166 "accessor_class_list.gperf" + {"number_of_coded_values", &grib_accessor_class_number_of_coded_values}, + {""}, {""}, +#line 179 "accessor_class_list.gperf" + {"padtoeven", &grib_accessor_class_padtoeven}, + {""}, {""}, +#line 169 "accessor_class_list.gperf" + {"number_of_values", &grib_accessor_class_number_of_values}, +#line 157 "accessor_class_list.gperf" + {"lookup", &grib_accessor_class_lookup}, + {""}, +#line 147 "accessor_class_list.gperf" + {"label", &grib_accessor_class_label}, + {""}, {""}, +#line 156 "accessor_class_list.gperf" + {"longitudes", &grib_accessor_class_longitudes}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, +#line 170 "accessor_class_list.gperf" + {"number_of_values_data_raw_packing", &grib_accessor_class_number_of_values_data_raw_packing}, +#line 152 "accessor_class_list.gperf" + {"library_version", &grib_accessor_class_library_version}, +#line 31 "accessor_class_list.gperf" + {"bufr_group", &grib_accessor_class_bufr_group}, +#line 155 "accessor_class_list.gperf" + {"long_vector", &grib_accessor_class_long_vector}, + {""}, +#line 150 "accessor_class_list.gperf" + {"latlon_increment", &grib_accessor_class_latlon_increment}, + {""}, {""}, {""}, {""}, {""}, {""}, +#line 135 "accessor_class_list.gperf" + {"ifs_param", &grib_accessor_class_ifs_param}, + {""}, {""}, {""}, +#line 174 "accessor_class_list.gperf" + {"offset_values", &grib_accessor_class_offset_values}, +#line 38 "accessor_class_list.gperf" + {"check_internal_version", &grib_accessor_class_check_internal_version}, + {""}, {""}, {""}, +#line 175 "accessor_class_list.gperf" + {"pack_bufr_values", &grib_accessor_class_pack_bufr_values}, + {""}, {""}, {""}, +#line 233 "accessor_class_list.gperf" + {"variable", &grib_accessor_class_variable}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, +#line 139 "accessor_class_list.gperf" + {"int32_little_endian", &grib_accessor_class_int32_little_endian}, {""}, {""}, #line 141 "accessor_class_list.gperf" {"int64_little_endian", &grib_accessor_class_int64_little_endian}, -#line 108 "accessor_class_list.gperf" - {"g1verificationdate", &grib_accessor_class_g1verificationdate}, - {""}, {""}, + {""}, #line 137 "accessor_class_list.gperf" {"int16_little_endian", &grib_accessor_class_int16_little_endian}, - {""}, {""}, -#line 119 "accessor_class_list.gperf" - {"g2level", &grib_accessor_class_g2level}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, #line 40 "accessor_class_list.gperf" {"codetable", &grib_accessor_class_codetable}, -#line 31 "accessor_class_list.gperf" - {"bufr_group", &grib_accessor_class_bufr_group}, - {""}, {""}, -#line 34 "accessor_class_list.gperf" - {"bufr_string_values", &grib_accessor_class_bufr_string_values}, -#line 30 "accessor_class_list.gperf" - {"bufr_extract_subsets", &grib_accessor_class_bufr_extract_subsets}, - {""}, {""}, {""}, {""}, -#line 28 "accessor_class_list.gperf" - {"bufr_extract_area_subsets", &grib_accessor_class_bufr_extract_area_subsets}, -#line 185 "accessor_class_list.gperf" - {"reference_value_error", &grib_accessor_class_reference_value_error}, - {""}, + {""}, {""}, {""}, {""}, {""}, +#line 108 "accessor_class_list.gperf" + {"g1verificationdate", &grib_accessor_class_g1verificationdate}, #line 81 "accessor_class_list.gperf" {"decimal_precision", &grib_accessor_class_decimal_precision}, -#line 29 "accessor_class_list.gperf" - {"bufr_extract_datetime_subsets", &grib_accessor_class_bufr_extract_datetime_subsets}, - {""}, {""}, -#line 106 "accessor_class_list.gperf" - {"g1param", &grib_accessor_class_g1param}, - {""}, {""}, {""}, {""}, {""}, {""}, -#line 151 "accessor_class_list.gperf" - {"latlonvalues", &grib_accessor_class_latlonvalues}, -#line 172 "accessor_class_list.gperf" - {"octect_number", &grib_accessor_class_octect_number}, - {""}, -#line 153 "accessor_class_list.gperf" - {"local_definition", &grib_accessor_class_local_definition}, - {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, - {""}, {""}, {""}, {""}, {""}, {""}, -#line 47 "accessor_class_list.gperf" - {"count_total", &grib_accessor_class_count_total}, - {""}, -#line 10 "accessor_class_list.gperf" - {"abstract_long_vector", &grib_accessor_class_abstract_long_vector}, - {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, -#line 46 "accessor_class_list.gperf" - {"count_missing", &grib_accessor_class_count_missing}, - {""}, {""}, {""}, {""}, #line 41 "accessor_class_list.gperf" {"codetable_title", &grib_accessor_class_codetable_title}, - {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, {""}, {""}, {""}, +#line 188 "accessor_class_list.gperf" + {"scale_values", &grib_accessor_class_scale_values}, + {""}, {""}, #line 23 "accessor_class_list.gperf" {"bufr_clear_tables", &grib_accessor_class_bufr_clear_tables}, + {""}, {""}, {""}, {""}, +#line 119 "accessor_class_list.gperf" + {"g2level", &grib_accessor_class_g2level}, + {""}, +#line 106 "accessor_class_list.gperf" + {"g1param", &grib_accessor_class_g1param}, + {""}, {""}, +#line 153 "accessor_class_list.gperf" + {"local_definition", &grib_accessor_class_local_definition}, + {""}, {""}, {""}, +#line 227 "accessor_class_list.gperf" + {"unpack_bufr_values", &grib_accessor_class_unpack_bufr_values}, + {""}, +#line 27 "accessor_class_list.gperf" + {"bufr_elements_table", &grib_accessor_class_bufr_elements_table}, + {""}, {""}, +#line 47 "accessor_class_list.gperf" + {"count_total", &grib_accessor_class_count_total}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, +#line 30 "accessor_class_list.gperf" + {"bufr_extract_subsets", &grib_accessor_class_bufr_extract_subsets}, + {""}, {""}, +#line 151 "accessor_class_list.gperf" + {"latlonvalues", &grib_accessor_class_latlonvalues}, + {""}, +#line 28 "accessor_class_list.gperf" + {"bufr_extract_area_subsets", &grib_accessor_class_bufr_extract_area_subsets}, +#line 39 "accessor_class_list.gperf" + {"codeflag", &grib_accessor_class_codeflag}, + {""}, +#line 11 "accessor_class_list.gperf" + {"abstract_vector", &grib_accessor_class_abstract_vector}, +#line 29 "accessor_class_list.gperf" + {"bufr_extract_datetime_subsets", &grib_accessor_class_bufr_extract_datetime_subsets}, +#line 45 "accessor_class_list.gperf" + {"count_file", &grib_accessor_class_count_file}, + {""}, {""}, {""}, {""}, +#line 185 "accessor_class_list.gperf" + {"reference_value_error", &grib_accessor_class_reference_value_error}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, +#line 110 "accessor_class_list.gperf" + {"g2_chemical", &grib_accessor_class_g2_chemical}, + {""}, +#line 46 "accessor_class_list.gperf" + {"count_missing", &grib_accessor_class_count_missing}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, {""}, {""}, {""}, {""}, {""}, +#line 42 "accessor_class_list.gperf" + {"codetable_units", &grib_accessor_class_codetable_units}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, {""}, {""}, +#line 90 "accessor_class_list.gperf" + {"from_scale_factor_scaled_value", &grib_accessor_class_from_scale_factor_scaled_value}, +#line 10 "accessor_class_list.gperf" + {"abstract_long_vector", &grib_accessor_class_abstract_long_vector}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, {""}, {""}, #line 104 "accessor_class_list.gperf" {"g1number_of_coded_values_sh_simple", &grib_accessor_class_g1number_of_coded_values_sh_simple}, #line 103 "accessor_class_list.gperf" {"g1number_of_coded_values_sh_complex", &grib_accessor_class_g1number_of_coded_values_sh_complex}, - {""}, {""}, {""}, {""}, -#line 27 "accessor_class_list.gperf" - {"bufr_elements_table", &grib_accessor_class_bufr_elements_table}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, - {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, {""}, {""}, {""}, +#line 172 "accessor_class_list.gperf" + {"octect_number", &grib_accessor_class_octect_number}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, + {""}, #line 101 "accessor_class_list.gperf" - {"g1forecastmonth", &grib_accessor_class_g1forecastmonth}, - {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, -#line 42 "accessor_class_list.gperf" - {"codetable_units", &grib_accessor_class_codetable_units}, - {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, - {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, - {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, - {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, - {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, - {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, - {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, - {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, - {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, - {""}, {""}, {""}, {""}, -#line 110 "accessor_class_list.gperf" - {"g2_chemical", &grib_accessor_class_g2_chemical} + {"g1forecastmonth", &grib_accessor_class_g1forecastmonth} }; static const struct accessor_class_hash * diff --git a/src/grib_accessor_factory.h b/src/grib_accessor_factory.h index 95b3ef49e..e53058a17 100644 --- a/src/grib_accessor_factory.h +++ b/src/grib_accessor_factory.h @@ -207,6 +207,7 @@ { "to_string", &grib_accessor_class_to_string, }, { "transient", &grib_accessor_class_transient, }, { "transient_darray", &grib_accessor_class_transient_darray, }, +{ "trim", &grib_accessor_class_trim, }, { "uint16", &grib_accessor_class_uint16, }, { "uint16_little_endian", &grib_accessor_class_uint16_little_endian, }, { "uint32", &grib_accessor_class_uint32, }, diff --git a/src/grib_accessor_factory_hash_list b/src/grib_accessor_factory_hash_list index be806bdad..80aee104d 100644 --- a/src/grib_accessor_factory_hash_list +++ b/src/grib_accessor_factory_hash_list @@ -208,6 +208,7 @@ to_integer, &grib_accessor_class_to_integer to_string, &grib_accessor_class_to_string transient, &grib_accessor_class_transient transient_darray, &grib_accessor_class_transient_darray +trim, &grib_accessor_class_trim uint16, &grib_accessor_class_uint16 uint16_little_endian, &grib_accessor_class_uint16_little_endian uint32, &grib_accessor_class_uint32 diff --git a/src/grib_api_prototypes.h b/src/grib_api_prototypes.h index 362345ec6..12ce195ee 100644 --- a/src/grib_api_prototypes.h +++ b/src/grib_api_prototypes.h @@ -1494,6 +1494,7 @@ int codes_bufr_header_get_string(codes_bufr_header* bh, const char* key, char* v /* string_util.c */ int strcmp_nocase(const char* s1, const char* s2); void rtrim(char* s); +void lrtrim(char** x, int do_left, int do_right); const char* extract_filename(const char* filepath); char** string_split(char* inputString, const char* delimiter); int string_to_long(const char* input, long* output); diff --git a/src/grib_bits_any_endian.c b/src/grib_bits_any_endian.c index c614d0a80..1591fd5d1 100644 --- a/src/grib_bits_any_endian.c +++ b/src/grib_bits_any_endian.c @@ -420,7 +420,7 @@ int grib_encode_size_tb(unsigned char* p, size_t val, long* bitp, long nb) #if OMP_PACKING #include "grib_bits_any_endian_omp.c" #elif VECTOR -#include "grib_bits_any_endian_vector.c" /* Experimental */ +#include "grib_bits_any_endian_vector.c" #else #include "grib_bits_any_endian_simple.c" #endif diff --git a/src/grib_bits_any_endian_vector.c b/src/grib_bits_any_endian_vector.c index f8e29af79..c712d98b3 100644 --- a/src/grib_bits_any_endian_vector.c +++ b/src/grib_bits_any_endian_vector.c @@ -10,16 +10,14 @@ /*************************************************************************** * Enrico Fucile - 19.06.2007 * - * EXPERIMENTAL CODE - NOT FULLY TESTED * + * Johannes Schick, Deutscher Wetterdienst - 24.06.2020 * ***************************************************************************/ - int grib_decode_long_array(const unsigned char* p, long* bitp, long bitsPerValue, size_t n_vals, long* val) { long i = 0; unsigned long lvalue = 0; - /* SUP-3196: Thanks to Daniel Tameling */ if (bitsPerValue % 8 || (*bitp & 7)) { int j = 0; for (i = 0; i < n_vals; i++) { @@ -55,6 +53,7 @@ int grib_decode_long_array(const unsigned char* p, long* bitp, long bitsPerValue return 0; } + int grib_decode_double_array(const unsigned char* p, long* bitp, long bitsPerValue, double reference_value, double s, double d, size_t n_vals, double* val) @@ -96,14 +95,12 @@ int grib_decode_double_array(const unsigned char* p, long* bitp, long bitsPerVal return 0; } -int grib_decode_double_array_complex(const unsigned char* p, long* bitp, long nbits, double reference_value, - double s, double* d, size_t size, double* val) +int grib_decode_double_array_complex(const unsigned char* p, long* bitp, long nbits, double reference_value, double s, double* d, size_t size, double* val) { return GRIB_NOT_IMPLEMENTED; } -int grib_encode_double_array(size_t n_vals, const double* val, long bits_per_value, double reference_value, - double d, double divisor, unsigned char* p, long* off) +int grib_encode_double_array(size_t n_vals, const double* val, long bits_per_value, double reference_value, double d, double divisor, unsigned char* p, long* off) { size_t i = 0; unsigned long unsigned_val = 0; @@ -115,15 +112,47 @@ int grib_encode_double_array(size_t n_vals, const double* val, long bits_per_val } } else { - for (i = 0; i < n_vals; i++) { - int blen = 0; - blen = bits_per_value; - unsigned_val = (unsigned long)((((val[i] * d) - reference_value) * divisor) + 0.5); - while (blen >= 8) { - blen -= 8; - *encoded = (unsigned_val >> blen); - encoded++; - *off += 8; + if (bits_per_value == 16 && !((uint64_t)p & 3)) { + uint32_t* encoded4byte = (uint32_t*)p; + uint32_t tmp; + unsigned long unsigned_val2 = 0; + for (i = 0; i < n_vals - 1; i += 2) { + unsigned_val = (unsigned long)((((val[i] * d) - reference_value) * divisor) + 0.5); + unsigned_val2 = (unsigned long)((((val[i + 1] * d) - reference_value) * divisor) + 0.5); + tmp = (unsigned_val2 & 0xff); + tmp = (tmp << 8) + (unsigned_val2 >> 8 & 0xff); + tmp = (tmp << 8) + (unsigned_val & 0xff); + tmp = (tmp << 8) + ((unsigned_val >> 8) & 0xff); + *encoded4byte = tmp; + encoded4byte++; + *off += 32; + } + /* remainder */ + if (n_vals % 2) { + int blen = 0; + i = n_vals - 1; + encoded = (unsigned char*)encoded4byte; + blen = bits_per_value; + unsigned_val = (unsigned long)((((val[i] * d) - reference_value) * divisor) + 0.5); + while (blen >= 8) { + blen -= 8; + *encoded = (unsigned_val >> blen); + encoded++; + *off += 8; + } + } + } + else { + for (i = 0; i < n_vals; i++) { + int blen = 0; + blen = bits_per_value; + unsigned_val = (unsigned long)((((val[i] * d) - reference_value) * divisor) + 0.5); + while (blen >= 8) { + blen -= 8; + *encoded = (unsigned_val >> blen); + encoded++; + *off += 8; + } } } } diff --git a/src/grib_dumper_class_bufr_decode_C.c b/src/grib_dumper_class_bufr_decode_C.c index b9c6954a8..b95dd4341 100644 --- a/src/grib_dumper_class_bufr_decode_C.c +++ b/src/grib_dumper_class_bufr_decode_C.c @@ -547,12 +547,13 @@ static void dump_string_array(grib_dumper* d, grib_accessor* a, const char* comm (void)err; /* TODO */ } +#define MAX_STRING_SIZE 4096 static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) { grib_dumper_bufr_decode_C* self = (grib_dumper_bufr_decode_C*)d; - char* value = NULL; + char value[MAX_STRING_SIZE] = {0,}; /* See ECC-710 */ + size_t size = MAX_STRING_SIZE; char* p = NULL; - size_t size = 0; grib_context* c = a->context; int r = 0, err = 0; grib_handle* h = grib_handle_of_accessor(a); @@ -560,23 +561,12 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) if ((a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0 || (a->flags & GRIB_ACCESSOR_FLAG_READ_ONLY) != 0) return; - _grib_get_string_length(a, &size); - if (size == 0) - return; - - value = (char*)grib_context_malloc_clear(c, size); - if (!value) { - grib_context_log(c, GRIB_LOG_FATAL, "unable to allocate %d bytes", (int)size); - return; - } - self->empty = 0; err = grib_unpack_string(a, value, &size); p = value; r = compute_bufr_key_rank(h, self->keys, a->name); if (grib_is_missing_string(a, (unsigned char*)value, size)) { - grib_context_free(c, value); return; } @@ -613,7 +603,6 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) depth -= 2; } - grib_context_free(c, value); (void)err; /* TODO */ } diff --git a/src/grib_dumper_class_bufr_decode_filter.c b/src/grib_dumper_class_bufr_decode_filter.c index 4841a13e2..1434efc23 100644 --- a/src/grib_dumper_class_bufr_decode_filter.c +++ b/src/grib_dumper_class_bufr_decode_filter.c @@ -460,31 +460,21 @@ static void dump_string_array(grib_dumper* d, grib_accessor* a, const char* comm (void)err; /* TODO */ } +#define MAX_STRING_SIZE 4096 static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) { grib_dumper_bufr_decode_filter* self = (grib_dumper_bufr_decode_filter*)d; - char* value = NULL; - char* p = NULL; - size_t size = 0; - grib_context* c = a->context; + char value[MAX_STRING_SIZE] = {0,}; /* See ECC-710 */ + size_t size = MAX_STRING_SIZE; + char* p = NULL; + grib_context* c = a->context; int r =0, err = 0; grib_handle* h = grib_handle_of_accessor(a); if ((a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0 || (a->flags & GRIB_ACCESSOR_FLAG_READ_ONLY) != 0) return; - _grib_get_string_length(a, &size); - if (size == 0) - return; - - value = (char*)grib_context_malloc_clear(c, size); - if (!value) { - grib_context_log(c, GRIB_LOG_FATAL, "unable to allocate %d bytes", (int)size); - return; - } - - else - self->begin = 0; + self->begin = 0; self->empty = 0; @@ -492,7 +482,6 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) p = value; r = compute_bufr_key_rank(h, self->keys, a->name); if (grib_is_missing_string(a, (unsigned char*)value, size)) { - grib_context_free(c, value); return; } @@ -528,7 +517,6 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) depth -= 2; } - grib_context_free(c, value); (void)err; /* TODO */ } diff --git a/src/grib_dumper_class_bufr_decode_fortran.c b/src/grib_dumper_class_bufr_decode_fortran.c index 8b9d1e10a..0089d35b2 100644 --- a/src/grib_dumper_class_bufr_decode_fortran.c +++ b/src/grib_dumper_class_bufr_decode_fortran.c @@ -489,36 +489,26 @@ static void dump_string_array(grib_dumper* d, grib_accessor* a, const char* comm (void)err; /* TODO */ } +#define MAX_STRING_SIZE 4096 static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) { grib_dumper_bufr_decode_fortran* self = (grib_dumper_bufr_decode_fortran*)d; - char* value = NULL; - char* p = NULL; - size_t size = 0; - grib_context* c = a->context; + char value[MAX_STRING_SIZE] = {0,}; /* See ECC-710 */ + size_t size = MAX_STRING_SIZE; + char* p = NULL; + grib_context* c = a->context; int r = 0, err = 0; grib_handle* h = grib_handle_of_accessor(a); if ((a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0 || (a->flags & GRIB_ACCESSOR_FLAG_READ_ONLY) != 0) return; - _grib_get_string_length(a, &size); - if (size == 0) - return; - - value = (char*)grib_context_malloc_clear(c, size); - if (!value) { - grib_context_log(c, GRIB_LOG_FATAL, "unable to allocate %d bytes", (int)size); - return; - } - self->empty = 0; err = grib_unpack_string(a, value, &size); p = value; r = compute_bufr_key_rank(h, self->keys, a->name); if (grib_is_missing_string(a, (unsigned char*)value, size)) { - grib_context_free(c, value); return; } @@ -556,7 +546,6 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) depth -= 2; } - grib_context_free(c, value); (void)err; /* TODO */ } diff --git a/src/grib_dumper_class_bufr_decode_python.c b/src/grib_dumper_class_bufr_decode_python.c index 2d2dc7a0f..18dc5846c 100644 --- a/src/grib_dumper_class_bufr_decode_python.c +++ b/src/grib_dumper_class_bufr_decode_python.c @@ -502,12 +502,13 @@ static void dump_string_array(grib_dumper* d, grib_accessor* a, const char* comm (void)err; /* TODO */ } +#define MAX_STRING_SIZE 4096 static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) { grib_dumper_bufr_decode_python* self = (grib_dumper_bufr_decode_python*)d; - char* value = NULL; + char value[MAX_STRING_SIZE] = {0,}; /* See ECC-710 */ char* p = NULL; - size_t size = 0; + size_t size = MAX_STRING_SIZE; grib_context* c = a->context; int r = 0, err = 0; grib_handle* h = grib_handle_of_accessor(a); @@ -515,23 +516,12 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) if ((a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0 || (a->flags & GRIB_ACCESSOR_FLAG_READ_ONLY) != 0) return; - _grib_get_string_length(a, &size); - if (size == 0) - return; - - value = (char*)grib_context_malloc_clear(c, size); - if (!value) { - grib_context_log(c, GRIB_LOG_FATAL, "unable to allocate %d bytes", (int)size); - return; - } - self->empty = 0; err = grib_unpack_string(a, value, &size); p = value; r = compute_bufr_key_rank(h, self->keys, a->name); if (grib_is_missing_string(a, (unsigned char*)value, size)) { - grib_context_free(c, value); return; } @@ -567,7 +557,6 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) depth -= 2; } - grib_context_free(c, value); (void)err; /* TODO */ } diff --git a/src/grib_dumper_class_bufr_encode_C.c b/src/grib_dumper_class_bufr_encode_C.c index 9426f2534..f82cc960c 100644 --- a/src/grib_dumper_class_bufr_encode_C.c +++ b/src/grib_dumper_class_bufr_encode_C.c @@ -694,18 +694,8 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) if (size == 0) return; - if ((a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0 || (a->flags & GRIB_ACCESSOR_FLAG_READ_ONLY) != 0) { - /* ECC-356: Solution for the special local section key 'keyMore' and its alias 'ident' */ - int skip = 1; - if ((a->flags & GRIB_ACCESSOR_FLAG_HIDDEN) != 0) { - if (strcmp(a->name, "keyMore") == 0 && grib_is_defined(h, "ls.ident")) { - skip = 0; - acc_name = "ident"; - } - } - if (skip) - return; - } + if ((a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0 || (a->flags & GRIB_ACCESSOR_FLAG_READ_ONLY) != 0) + return; value = (char*)grib_context_malloc_clear(c, size); if (!value) { diff --git a/src/grib_dumper_class_bufr_encode_fortran.c b/src/grib_dumper_class_bufr_encode_fortran.c index 94dba94c8..1f17ead15 100644 --- a/src/grib_dumper_class_bufr_encode_fortran.c +++ b/src/grib_dumper_class_bufr_encode_fortran.c @@ -748,18 +748,8 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) if (size == 0) return; - if ((a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0 || (a->flags & GRIB_ACCESSOR_FLAG_READ_ONLY) != 0) { - /* ECC-356: Solution for the special local section key 'keyMore' and its alias 'ident' */ - int skip = 1; - if ((a->flags & GRIB_ACCESSOR_FLAG_HIDDEN) != 0) { - if (strcmp(a->name, "keyMore") == 0 && grib_is_defined(h, "ls.ident")) { - skip = 0; - acc_name = "ident"; - } - } - if (skip) - return; - } + if ((a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0 || (a->flags & GRIB_ACCESSOR_FLAG_READ_ONLY) != 0) + return; value = (char*)grib_context_malloc_clear(c, size); if (!value) { diff --git a/src/grib_dumper_class_bufr_encode_python.c b/src/grib_dumper_class_bufr_encode_python.c index 107f77a17..9abf28a85 100644 --- a/src/grib_dumper_class_bufr_encode_python.c +++ b/src/grib_dumper_class_bufr_encode_python.c @@ -691,18 +691,8 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) if (size == 0) return; - if ((a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0 || (a->flags & GRIB_ACCESSOR_FLAG_READ_ONLY) != 0) { - /* ECC-356: Solution for the special local section key 'keyMore' and its alias 'ident' */ - int skip = 1; - if ((a->flags & GRIB_ACCESSOR_FLAG_HIDDEN) != 0) { - if (strcmp(acc_name, "keyMore") == 0 && grib_is_defined(h, "ls.ident")) { - skip = 0; - acc_name = "ident"; - } - } - if (skip) - return; - } + if ((a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0 || (a->flags & GRIB_ACCESSOR_FLAG_READ_ONLY) != 0) + return; value = (char*)grib_context_malloc_clear(c, size); if (!value) { diff --git a/src/grib_dumper_class_bufr_simple.c b/src/grib_dumper_class_bufr_simple.c index 22e313a38..6ae765c69 100644 --- a/src/grib_dumper_class_bufr_simple.c +++ b/src/grib_dumper_class_bufr_simple.c @@ -628,12 +628,13 @@ static void dump_string_array(grib_dumper* d, grib_accessor* a, const char* comm (void)err; /* TODO */ } +#define MAX_STRING_SIZE 4096 static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) { grib_dumper_bufr_simple* self = (grib_dumper_bufr_simple*)d; - char* value = NULL; + char value[MAX_STRING_SIZE] = {0,}; /* See ECC-710 */ char* p = NULL; - size_t size = 0; + size_t size = MAX_STRING_SIZE; grib_context* c = a->context; int r = 0; int is_missing = 0; @@ -641,32 +642,14 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) grib_handle* h = grib_handle_of_accessor(a); const char* acc_name = a->name; - _grib_get_string_length(a, &size); - if (size == 0) - return; - if ((a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0 || (a->flags & GRIB_ACCESSOR_FLAG_READ_ONLY) != 0) { - /* ECC-356: Solution for the special local section key 'keyMore' and its alias 'ident' */ - int skip = 1; - if ((a->flags & GRIB_ACCESSOR_FLAG_HIDDEN) != 0) { - if (strcmp(a->name, "keyMore") == 0 && grib_is_defined(h, "ls.ident")) { - skip = 0; - acc_name = "ident"; - } - } - if (skip) - return; - } - - value = (char*)grib_context_malloc_clear(c, size); - if (!value) { - grib_context_log(c, GRIB_LOG_FATAL, "unable to allocate %d bytes", (int)size); return; } self->empty = 0; err = grib_unpack_string(a, value, &size); + Assert(size < MAX_STRING_SIZE); p = value; r = compute_bufr_key_rank(h, self->keys, acc_name); if (grib_is_missing_string(a, (unsigned char*)value, size)) { @@ -707,7 +690,6 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) grib_context_free(c, prefix); } - grib_context_free(c, value); (void)err; /* TODO */ } diff --git a/src/grib_dumper_class_json.c b/src/grib_dumper_class_json.c index 5d2f525eb..8a526005c 100644 --- a/src/grib_dumper_class_json.c +++ b/src/grib_dumper_class_json.c @@ -450,24 +450,14 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment) { grib_dumper_json* self = (grib_dumper_json*)d; char value[MAX_STRING_SIZE] = {0,}; /* See ECC-710 */ + size_t size = MAX_STRING_SIZE; char* p = NULL; - size_t size = MAX_STRING_SIZE; int is_missing = 0; int err = 0; const char* acc_name = a->name; if ((a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0) { - /* ECC-356: Solution for the special local section key 'keyMore' and its alias 'ident' */ - int skip = 1; - if ((a->flags & GRIB_ACCESSOR_FLAG_HIDDEN) != 0) { - grib_handle* h = grib_handle_of_accessor(a); - if (strcmp(a->name, "keyMore") == 0 && grib_is_defined(h, "ls.ident")) { - skip = 0; - acc_name = "ident"; - } - } - if (skip) - return; + return; } /* ECC-710: It is MUCH slower determining the string length here diff --git a/src/string_util.c b/src/string_util.c index 448f4c5cc..fb1ffb00b 100644 --- a/src/string_util.c +++ b/src/string_util.c @@ -38,6 +38,26 @@ void rtrim(char* s) s[len] = '\0'; } +void lrtrim(char** x, int do_left, int do_right) +{ + DebugAssert(do_left || do_right); + if (do_left) { + while (isspace(**x) && **x != '\0') + (*x)++; + } + if (**x == '\0') + return; + if (do_right) { + char* p = (*x) + strlen(*x) - 1; + while (isspace(*p)) { + *p = '\0'; + p--; + } + if (isspace(*p)) + *p = '\0'; + } +} + /* Return the component after final slash */ /* "/tmp/x" -> "x" */ /* "/tmp/" -> "" */ diff --git a/tests/bufr_dump_encode_fortran.sh b/tests/bufr_dump_encode_fortran.sh index c6feba219..996e1fe56 100755 --- a/tests/bufr_dump_encode_fortran.sh +++ b/tests/bufr_dump_encode_fortran.sh @@ -25,7 +25,7 @@ mkdir -p $tempDir bufr_files=`cat ${data_dir}/bufr/bufr_data_files.txt` # If FORTRAN is enabled, then the pkgconfig should be one level above the test dir -PKGCONFIG_FILE=../../eccodes_f90.pc +PKGCONFIG_FILE=../../lib/pkgconfig/eccodes_f90.pc CACHE_FILE=../../CMakeCache.txt COMPILE_AND_RUN=0 @@ -69,16 +69,14 @@ do # valgrind --error-exitcode=1 ./$tempExe ./$tempExe - # ECC-356: have to blacklist 'ident' because of the spaces - ${tools_dir}/bufr_compare -b ident ${data_dir}/bufr/$file $tempBufr + ${tools_dir}/bufr_compare ${data_dir}/bufr/$file $tempBufr TEMP_OUT1=${label}.$file.dump.out TEMP_OUT2=${label}.$tempBufr.dump.out ${tools_dir}/bufr_dump -p ${data_dir}/bufr/$file > $TEMP_OUT1 ${tools_dir}/bufr_dump -p $tempBufr > $TEMP_OUT2 - # Using the '-w' (--ignore-all-space option) for diff because of the 'ident' key - # See ECC-356 - diff -w $TEMP_OUT1 $TEMP_OUT2 + + diff $TEMP_OUT1 $TEMP_OUT2 rm -f $TEMP_OUT1 $TEMP_OUT2 fi diff --git a/tests/bufr_filter.sh b/tests/bufr_filter.sh index 3a37adfd9..3ac55d058 100755 --- a/tests/bufr_filter.sh +++ b/tests/bufr_filter.sh @@ -636,6 +636,7 @@ EOF #Clean up rm -f ${dSplit}/* +rmdir ${dSplit} rm -f $fLog $fRules rm -f $fBufrTmp @@ -877,7 +878,7 @@ diff ${fOut}.log.ref ${fOut}.log ${tools_dir}/bufr_compare ${fOut} ${fOut}.ref rm -f ${fOut}.log -rm -f $fLog $fRules ${fOut} +rm -f $fLog $fRules ${fOut} ${fOut}.log.ref #----------------------------------------------------------- # Test: add section 2 #----------------------------------------------------------- @@ -909,7 +910,7 @@ EOF fi rm -f ${fOut}.log -rm -f $fLog $fRules ${fOut} +rm -f $fLog $fRules ${fOut} ${fOut}.log.ref #----------------------------------------------------------- # Test: extract subsets uncompressed data diff --git a/tests/bufr_filter_extract_area.sh b/tests/bufr_filter_extract_area.sh index 426cc65c9..ace3f85a0 100755 --- a/tests/bufr_filter_extract_area.sh +++ b/tests/bufr_filter_extract_area.sh @@ -136,6 +136,7 @@ fieldOfViewNumber=7 8 9 10 11 12 13 8 9 10 11 12 11 12 EOF diff $outputRef $outputFilt +rm -f $outputBufr # Uncompressed message # --------------------- diff --git a/tests/bufr_get.sh b/tests/bufr_get.sh index f91d5bcdb..26633d503 100755 --- a/tests/bufr_get.sh +++ b/tests/bufr_get.sh @@ -10,22 +10,23 @@ . ./include.sh -#Enter data dir +# Enter data dir cd ${data_dir}/bufr -#Define a common label for all the tmp files +# Define a common label for all the tmp files label="bufr_get_test" -#Create log file +# Create log file fLog=${label}".log" rm -f $fLog touch $fLog -#Define tmp file +# Define tmp file fTmp=${label}".tmp.txt" -rm -f $fTmp +tempRef=${label}".tmp.ref.txt" +rm -f $fTmp $tempRef -#Define another tmp file to store the test results +# Define another tmp file to store the test results res_get=${label}".get.test" rm -f $res_get @@ -41,14 +42,14 @@ id=`${tools_dir}/bufr_get -p edition,identifier aaen_55.bufr` #------------------------------------------- f="aaen_55.bufr" -#The reference is the same as for ls +# The reference is the same as for ls ref_get=$f".ls.ref" echo "Test: -p switch" >> $fLog echo "file: $f" >> $fLog ${tools_dir}/bufr_get -p totalLength,bufrHeaderCentre,bufrHeaderSubCentre,masterTableNumber,masterTablesVersionNumber,localTablesVersionNumber,numberOfSubsets,localNumberOfObservations $f > $fTmp -#Write the values into a file and compare with ref +# Write the values into a file and compare with ref cat $fTmp | awk '{split($0,a," "); for (i=1; i<=8; i++) print a[i]}' > $res_get diff $ref_get $res_get @@ -68,17 +69,30 @@ result=`${tools_dir}/bufr_get -s unpack=1 -p satelliteIdentifier wavb_134.bufr` # ECC-315: BUFR keys in the MARS namespace #------------------------------------------- result=`${tools_dir}/bufr_get -m aaen_55.bufr` -[ "$result" = "2 55 2012 11 2 0 0 8 209" ] +[ "$result" = "55 20121102 0000" ] result=`${tools_dir}/bufr_get -m syno_1.bufr` -[ "$result" = "1 1 2012 10 30 0 0 0 7.45 151.83" ] +[ "$result" = "1 20121030 0000 91334" ] +${tools_dir}/bufr_ls -j -m syno_1.bufr > $fTmp +cat > $tempRef <$REDIRECT 2> $REDIRECT fi + rm -f ${file}.json done diff --git a/tests/bufr_set.sh b/tests/bufr_set.sh index 79f62ef62..4a57db70b 100755 --- a/tests/bufr_set.sh +++ b/tests/bufr_set.sh @@ -170,6 +170,11 @@ ${tools_dir}/bufr_set -s keyMore=ABCD $f $fBufrTmp result=`${tools_dir}/bufr_get -p keyMore,ident $fBufrTmp` [ "$result" = "ABCD ABCD" ] +${tools_dir}/bufr_set -s ident=' AB CD ' $f $fBufrTmp +result=`${tools_dir}/bufr_get -p ident $fBufrTmp` +[ "$result" = "AB CD" ] + + # ${tools_dir}/bufr_compare $f $fBufrTmp #Clean up diff --git a/tests/unit_tests.c b/tests/unit_tests.c index 31eb6a5b3..ad22d722d 100644 --- a/tests/unit_tests.c +++ b/tests/unit_tests.c @@ -1485,9 +1485,41 @@ static void test_concept_condition_strings() grib_handle_delete(h); } +void test_trimming() +{ + char a[] = " Standing "; + char b[] = " Weeping "; + char c[] = " Silhouette "; + char d[] = " The Forest Of October "; + char e[] = "\t\n Apostle In Triumph \r "; + char* pA = a; + char* pB = b; + char* pC = c; + char* pD = d; + char* pE = e; + + lrtrim(&pA, 0, 1); /*right only*/ + assert( strcmp(pA, " Standing")==0 ); + + lrtrim(&pB, 1, 0); /*left only*/ + assert( strcmp(pB, "Weeping ")==0 ); + + lrtrim(&pC, 1, 1); /*both ends*/ + assert( strcmp(pC, "Silhouette")==0 ); + + lrtrim(&pD, 1, 1); /*make sure other spaces are not removed*/ + assert( strcmp(pD, "The Forest Of October")==0 ); + + lrtrim(&pE, 1, 1); /* Other chars */ + assert( strcmp(pE, "Apostle In Triumph")==0 ); +} + int main(int argc, char** argv) { /*printf("Doing unit tests. ecCodes version = %ld\n", grib_get_api_version());*/ + + test_trimming(); + test_get_git_sha1(); test_concept_condition_strings(); diff --git a/tools/bufr_compare.c b/tools/bufr_compare.c index 2d023cb2b..0babb11cd 100644 --- a/tools/bufr_compare.c +++ b/tools/bufr_compare.c @@ -1319,16 +1319,6 @@ static int compare_all_dump_keys(grib_handle* handle1, grib_handle* handle2, gri grib_keys_iterator_delete(iter); - /* ECC-356: Handling special case of 'ident' key */ - name = "ls.ident"; - if (!blacklisted("ident") && grib_is_defined(handle1, name) && grib_is_defined(handle2, name)) { - if (compare_values(options, handle1, handle2, "ident", GRIB_TYPE_STRING)) { - (*pErr)++; - write_messages(handle1, handle2); - ret = 1; - } - } - return ret; } diff --git a/windows/msvc/grib_api_lib/grib_api_lib.vcxproj b/windows/msvc/grib_api_lib/grib_api_lib.vcxproj index cb60baef7..b4a3525e3 100755 --- a/windows/msvc/grib_api_lib/grib_api_lib.vcxproj +++ b/windows/msvc/grib_api_lib/grib_api_lib.vcxproj @@ -408,6 +408,7 @@ +