mirror of https://github.com/ecmwf/eccodes.git
Default native step type is string. It's long if unit is not shown.
This commit is contained in:
parent
afc918b3f0
commit
b8830c337b
|
@ -744,14 +744,15 @@ static int pack_string(grib_accessor* a, const char* val, size_t* len)
|
||||||
|
|
||||||
static int get_native_type(grib_accessor* a)
|
static int get_native_type(grib_accessor* a)
|
||||||
{
|
{
|
||||||
// TODO: Still experimental.
|
|
||||||
// Change the type to depend on the stepUnits for backward compatibility
|
|
||||||
|
|
||||||
grib_handle* h = grib_handle_of_accessor(a);
|
grib_handle* h = grib_handle_of_accessor(a);
|
||||||
long step_units = 0;
|
int show_hours = a->context->show_hour_stepunit;
|
||||||
if (grib_get_long_internal(h, "stepUnits", &step_units) == GRIB_SUCCESS) {
|
|
||||||
if (step_units == 1) {
|
if (!show_hours) {
|
||||||
return GRIB_TYPE_LONG;
|
long step_units = 0;
|
||||||
|
if (grib_get_long_internal(h, "stepUnits", &step_units) == GRIB_SUCCESS) {
|
||||||
|
if (eccodes::Unit{step_units} == eccodes::Unit::Value::HOUR) {
|
||||||
|
return GRIB_TYPE_LONG;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -349,16 +349,16 @@ static int unpack_string(grib_accessor* a, char* val, size_t* len)
|
||||||
|
|
||||||
static int get_native_type(grib_accessor* a)
|
static int get_native_type(grib_accessor* a)
|
||||||
{
|
{
|
||||||
// TODO: Still experimental.
|
|
||||||
// Change the type to depend on the stepUnits for backward compatibility
|
|
||||||
|
|
||||||
grib_handle* h = grib_handle_of_accessor(a);
|
grib_handle* h = grib_handle_of_accessor(a);
|
||||||
long step_units = 0;
|
int show_hours = a->context->show_hour_stepunit;
|
||||||
if (grib_get_long_internal(h, "stepUnits", &step_units) == GRIB_SUCCESS) {
|
|
||||||
if (step_units == 1) {
|
if (!show_hours) {
|
||||||
return GRIB_TYPE_LONG;
|
long step_units = 0;
|
||||||
|
if (grib_get_long_internal(h, "stepUnits", &step_units) == GRIB_SUCCESS) {
|
||||||
|
if (eccodes::Unit{step_units} == eccodes::Unit::Value::HOUR) {
|
||||||
|
return GRIB_TYPE_LONG;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return GRIB_TYPE_STRING;
|
return GRIB_TYPE_STRING;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue