mirror of https://github.com/ecmwf/eccodes.git
grib_util_set_spec: Refactoring
This commit is contained in:
parent
b158c067ac
commit
46bda29a22
|
@ -11,6 +11,7 @@
|
||||||
#include "grib_api_internal.h"
|
#include "grib_api_internal.h"
|
||||||
#include <float.h>
|
#include <float.h>
|
||||||
|
|
||||||
|
#define STR_EQUAL(s1, s2) (strcmp((s1), (s2)) == 0)
|
||||||
|
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
|
@ -888,8 +889,8 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
size_t count = 0;
|
size_t count = 0;
|
||||||
int i;
|
int i;
|
||||||
long editionNumber;
|
long editionNumber;
|
||||||
grib_handle* outh = NULL;
|
grib_handle* h_out = NULL;
|
||||||
grib_handle* tmp = NULL;
|
grib_handle* h_sample = NULL;
|
||||||
const char* grid_type = NULL;
|
const char* grid_type = NULL;
|
||||||
char name[1024];
|
char name[1024];
|
||||||
char input_grid_type[100];
|
char input_grid_type[100];
|
||||||
|
@ -1090,7 +1091,7 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
}
|
}
|
||||||
|
|
||||||
return h;
|
return h;
|
||||||
}
|
} /* flags & GRIB_UTIL_SET_SPEC_FLAGS_ONLY_PACKING */
|
||||||
|
|
||||||
grid_type = get_grid_type_name(spec->grid_type);
|
grid_type = get_grid_type_name(spec->grid_type);
|
||||||
if (grid_type == NULL) {
|
if (grid_type == NULL) {
|
||||||
|
@ -1143,9 +1144,9 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* TODO: recycle tmp handle */
|
/* TODO: recycle h_sample handle */
|
||||||
tmp = grib_handle_new_from_samples(NULL, name);
|
h_sample = grib_handle_new_from_samples(NULL, name);
|
||||||
if (!tmp) {
|
if (!h_sample) {
|
||||||
*err = GRIB_INVALID_FILE;
|
*err = GRIB_INVALID_FILE;
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -1447,6 +1448,8 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* ECC-1201: case of IEEE input ?? */
|
||||||
|
|
||||||
switch (packing_spec->accuracy) {
|
switch (packing_spec->accuracy) {
|
||||||
case GRIB_UTIL_ACCURACY_SAME_BITS_PER_VALUES_AS_INPUT: {
|
case GRIB_UTIL_ACCURACY_SAME_BITS_PER_VALUES_AS_INPUT: {
|
||||||
long bitsPerValue = 0;
|
long bitsPerValue = 0;
|
||||||
|
@ -1470,7 +1473,7 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
|
|
||||||
default:
|
default:
|
||||||
fprintf(stderr, "invalid packing_spec->accuracy = %ld\n", (long)packing_spec->accuracy);
|
fprintf(stderr, "invalid packing_spec->accuracy = %ld\n", (long)packing_spec->accuracy);
|
||||||
grib_handle_delete(tmp);
|
grib_handle_delete(h_sample);
|
||||||
*err = GRIB_INTERNAL_ERROR;
|
*err = GRIB_INTERNAL_ERROR;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
break;
|
break;
|
||||||
|
@ -1498,13 +1501,13 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* grib_write_message(h,"input.grib","w"); */
|
/* grib_write_message(h,"input.grib","w"); */
|
||||||
/* grib_write_message(tmp,"geo.grib","w"); */
|
/* grib_write_message(h_sample,"geo.grib","w"); */
|
||||||
/* copy product and local sections from h to tmp handle and store in outh */
|
/* copy product and local sections from h to h_sample handle and store in h_out */
|
||||||
if ((outh = grib_util_sections_copy(h, tmp, GRIB_SECTION_PRODUCT | GRIB_SECTION_LOCAL, err)) == NULL) {
|
if ((h_out = grib_util_sections_copy(h, h_sample, GRIB_SECTION_PRODUCT | GRIB_SECTION_LOCAL, err)) == NULL) {
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
grib_handle_delete(tmp);
|
grib_handle_delete(h_sample);
|
||||||
Assert(*err == 0);
|
Assert(*err == 0);
|
||||||
|
|
||||||
/* Set "pl" array if provided (For reduced Gaussian grids) */
|
/* Set "pl" array if provided (For reduced Gaussian grids) */
|
||||||
|
@ -1520,7 +1523,7 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (spec->pl_size != 0 && (spec->grid_type == GRIB_UTIL_GRID_SPEC_REDUCED_GG || spec->grid_type == GRIB_UTIL_GRID_SPEC_REDUCED_ROTATED_GG)) {
|
if (spec->pl_size != 0 && (spec->grid_type == GRIB_UTIL_GRID_SPEC_REDUCED_GG || spec->grid_type == GRIB_UTIL_GRID_SPEC_REDUCED_ROTATED_GG)) {
|
||||||
*err = grib_set_long_array(outh, "pl", spec->pl, spec->pl_size);
|
*err = grib_set_long_array(h_out, "pl", spec->pl, spec->pl_size);
|
||||||
if (*err) {
|
if (*err) {
|
||||||
fprintf(stderr, "SET_GRID_DATA_DESCRIPTION: Cannot set pl %s\n", grib_get_error_message(*err));
|
fprintf(stderr, "SET_GRID_DATA_DESCRIPTION: Cannot set pl %s\n", grib_get_error_message(*err));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
@ -1544,23 +1547,23 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
|
|
||||||
/* Apply adjustments to bounding box if needed */
|
/* Apply adjustments to bounding box if needed */
|
||||||
if (expandBoundingBox) {
|
if (expandBoundingBox) {
|
||||||
if ((*err = expand_bounding_box(outh, values, count)) != 0) {
|
if ((*err = expand_bounding_box(h_out, values, count)) != 0) {
|
||||||
fprintf(stderr, "SET_GRID_DATA_DESCRIPTION: Cannot expand bounding box: %s\n", grib_get_error_message(*err));
|
fprintf(stderr, "SET_GRID_DATA_DESCRIPTION: Cannot expand bounding box: %s\n", grib_get_error_message(*err));
|
||||||
if (h->context->write_on_fail)
|
if (h->context->write_on_fail)
|
||||||
grib_write_message(outh, "error.grib", "w");
|
grib_write_message(h_out, "error.grib", "w");
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (convertEditionEarlier && packing_spec->editionNumber > 1) {
|
if (convertEditionEarlier && packing_spec->editionNumber > 1) {
|
||||||
*err = grib_set_long(outh, "edition", packing_spec->editionNumber);
|
*err = grib_set_long(h_out, "edition", packing_spec->editionNumber);
|
||||||
if (*err) {
|
if (*err) {
|
||||||
fprintf(stderr, "SET_GRID_DATA_DESCRIPTION: Cannot convert to edition %ld.\n", packing_spec->editionNumber);
|
fprintf(stderr, "SET_GRID_DATA_DESCRIPTION: Cannot convert to edition %ld.\n", packing_spec->editionNumber);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((*err = grib_set_values(outh, values, count)) != 0) {
|
if ((*err = grib_set_values(h_out, values, count)) != 0) {
|
||||||
fprintf(stderr, "SET_GRID_DATA_DESCRIPTION: Cannot set key values: %s\n", grib_get_error_message(*err));
|
fprintf(stderr, "SET_GRID_DATA_DESCRIPTION: Cannot set key values: %s\n", grib_get_error_message(*err));
|
||||||
|
|
||||||
for (i = 0; i < count; i++)
|
for (i = 0; i < count; i++)
|
||||||
|
@ -1569,7 +1572,7 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((*err = grib_set_double_array(outh, "values", data_values, data_values_count)) != 0) {
|
if ((*err = grib_set_double_array(h_out, "values", data_values, data_values_count)) != 0) {
|
||||||
FILE* ferror;
|
FILE* ferror;
|
||||||
size_t ii, lcount;
|
size_t ii, lcount;
|
||||||
grib_context* c = grib_context_get_default();
|
grib_context* c = grib_context_get_default();
|
||||||
|
@ -1589,66 +1592,66 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
fprintf(ferror, "%g }", data_values[data_values_count - 1]);
|
fprintf(ferror, "%g }", data_values[data_values_count - 1]);
|
||||||
fclose(ferror);
|
fclose(ferror);
|
||||||
if (c->write_on_fail)
|
if (c->write_on_fail)
|
||||||
grib_write_message(outh, "error.grib", "w");
|
grib_write_message(h_out, "error.grib", "w");
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* grib_write_message(outh,"h.grib","w"); */
|
/* grib_write_message(h_out,"h.grib","w"); */
|
||||||
/* if the field is empty GRIBEX is packing as simple*/
|
/* if the field is empty GRIBEX is packing as simple*/
|
||||||
/* if (!strcmp(input_packing_type,"grid_simple_matrix")) {
|
/* if (!strcmp(input_packing_type,"grid_simple_matrix")) {
|
||||||
long numberOfValues;
|
long numberOfValues;
|
||||||
grib_get_long(outh,"numberOfValues",&numberOfValues);
|
grib_get_long(h_out,"numberOfValues",&numberOfValues);
|
||||||
if (numberOfValues==0) {
|
if (numberOfValues==0) {
|
||||||
slen=11;
|
slen=11;
|
||||||
grib_set_string(outh,"packingType","grid_simple",&slen);
|
grib_set_string(h_out,"packingType","grid_simple",&slen);
|
||||||
}
|
}
|
||||||
} */
|
} */
|
||||||
|
|
||||||
if (grib1_high_resolution_fix) {
|
if (grib1_high_resolution_fix) {
|
||||||
/* GRIB-863: must set increments to MISSING */
|
/* GRIB-863: must set increments to MISSING */
|
||||||
/* increments are not coded in message but computed */
|
/* increments are not coded in message but computed */
|
||||||
if ((*err = grib_set_missing(outh, "iDirectionIncrement")) != 0) {
|
if ((*err = grib_set_missing(h_out, "iDirectionIncrement")) != 0) {
|
||||||
fprintf(stderr, "GRIB_UTIL_SET_SPEC: Cannot set Di to missing: %s\n", grib_get_error_message(*err));
|
fprintf(stderr, "GRIB_UTIL_SET_SPEC: Cannot set Di to missing: %s\n", grib_get_error_message(*err));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
if ((*err = grib_set_missing(outh, "jDirectionIncrement")) != 0) {
|
if ((*err = grib_set_missing(h_out, "jDirectionIncrement")) != 0) {
|
||||||
fprintf(stderr, "GRIB_UTIL_SET_SPEC: Cannot set Dj to missing: %s\n", grib_get_error_message(*err));
|
fprintf(stderr, "GRIB_UTIL_SET_SPEC: Cannot set Dj to missing: %s\n", grib_get_error_message(*err));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*grib_dump_content(outh, stdout,"debug", ~0, NULL);*/
|
/*grib_dump_content(h_out, stdout,"debug", ~0, NULL);*/
|
||||||
|
|
||||||
/* convert to second_order if not constant field. (Also see ECC-326) */
|
/* convert to second_order if not constant field. (Also see ECC-326) */
|
||||||
if (setSecondOrder) {
|
if (setSecondOrder) {
|
||||||
int constant = 0;
|
int constant = 0;
|
||||||
double missingValue = 0;
|
double missingValue = 0;
|
||||||
grib_get_double(outh, "missingValue", &missingValue);
|
grib_get_double(h_out, "missingValue", &missingValue);
|
||||||
constant = is_constant_field(missingValue, data_values, data_values_count);
|
constant = is_constant_field(missingValue, data_values, data_values_count);
|
||||||
|
|
||||||
if (!constant) {
|
if (!constant) {
|
||||||
if (editionNumber == 1) {
|
if (editionNumber == 1) {
|
||||||
long numberOfGroups = 0;
|
long numberOfGroups = 0;
|
||||||
grib_handle* htmp = grib_handle_clone(outh);
|
grib_handle* htmp = grib_handle_clone(h_out);
|
||||||
|
|
||||||
slen = 17;
|
slen = 17;
|
||||||
grib_set_string(htmp, "packingType", "grid_second_order", &slen);
|
grib_set_string(htmp, "packingType", "grid_second_order", &slen);
|
||||||
grib_get_long(htmp, "numberOfGroups", &numberOfGroups);
|
grib_get_long(htmp, "numberOfGroups", &numberOfGroups);
|
||||||
/* GRIBEX is not able to decode overflown numberOfGroups with SPD */
|
/* GRIBEX is not able to decode overflown numberOfGroups with SPD */
|
||||||
if (numberOfGroups > 65534 && outh->context->no_spd) {
|
if (numberOfGroups > 65534 && h_out->context->no_spd) {
|
||||||
slen = 24;
|
slen = 24;
|
||||||
grib_set_string(outh, "packingType", "grid_second_order_no_SPD", &slen);
|
grib_set_string(h_out, "packingType", "grid_second_order_no_SPD", &slen);
|
||||||
grib_handle_delete(htmp);
|
grib_handle_delete(htmp);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
grib_handle_delete(outh);
|
grib_handle_delete(h_out);
|
||||||
outh = htmp;
|
h_out = htmp;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
slen = 17;
|
slen = 17;
|
||||||
grib_set_string(outh, "packingType", "grid_second_order", &slen);
|
grib_set_string(h_out, "packingType", "grid_second_order", &slen);
|
||||||
*err = grib_set_double_array(outh, "values", data_values, data_values_count);
|
*err = grib_set_double_array(h_out, "values", data_values, data_values_count);
|
||||||
if (*err != GRIB_SUCCESS) {
|
if (*err != GRIB_SUCCESS) {
|
||||||
fprintf(stderr, "GRIB_UTIL_SET_SPEC: setting data values failed! %s\n", grib_get_error_message(*err));
|
fprintf(stderr, "GRIB_UTIL_SET_SPEC: setting data values failed! %s\n", grib_get_error_message(*err));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
@ -1656,21 +1659,21 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if (outh->context->gribex_mode_on) {
|
if (h_out->context->gribex_mode_on) {
|
||||||
outh->context->gribex_mode_on = 0;
|
h_out->context->gribex_mode_on = 0;
|
||||||
grib_set_double_array(outh, "values", data_values, data_values_count);
|
grib_set_double_array(h_out, "values", data_values, data_values_count);
|
||||||
outh->context->gribex_mode_on = 1;
|
h_out->context->gribex_mode_on = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (packing_spec->editionNumber && packing_spec->editionNumber != editionNumber) {
|
if (packing_spec->editionNumber && packing_spec->editionNumber != editionNumber) {
|
||||||
*err = grib_set_long(outh, "edition", packing_spec->editionNumber);
|
*err = grib_set_long(h_out, "edition", packing_spec->editionNumber);
|
||||||
if (*err != GRIB_SUCCESS) {
|
if (*err != GRIB_SUCCESS) {
|
||||||
fprintf(stderr, "GRIB_UTIL_SET_SPEC: Failed to change edition to %ld: %s\n",
|
fprintf(stderr, "GRIB_UTIL_SET_SPEC: Failed to change edition to %ld: %s\n",
|
||||||
packing_spec->editionNumber, grib_get_error_message(*err));
|
packing_spec->editionNumber, grib_get_error_message(*err));
|
||||||
if (h->context->write_on_fail)
|
if (h->context->write_on_fail)
|
||||||
grib_write_message(outh, "error.grib", "w");
|
grib_write_message(h_out, "error.grib", "w");
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1679,7 +1682,7 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
/* ECC-353 */
|
/* ECC-353 */
|
||||||
/* JPEG packing is not available in GRIB edition 1 and has to be done AFTER we set data values */
|
/* JPEG packing is not available in GRIB edition 1 and has to be done AFTER we set data values */
|
||||||
if (setJpegPacking == 1) {
|
if (setJpegPacking == 1) {
|
||||||
*err = grib_set_string(outh, "packingType", "grid_jpeg", &slen);
|
*err = grib_set_string(h_out, "packingType", "grid_jpeg", &slen);
|
||||||
if (*err != GRIB_SUCCESS) {
|
if (*err != GRIB_SUCCESS) {
|
||||||
fprintf(stderr, "GRIB_UTIL_SET_SPEC: Failed to change packingType to JPEG: %s\n",
|
fprintf(stderr, "GRIB_UTIL_SET_SPEC: Failed to change packingType to JPEG: %s\n",
|
||||||
grib_get_error_message(*err));
|
grib_get_error_message(*err));
|
||||||
|
@ -1687,7 +1690,7 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (setCcsdsPacking == 1) {
|
if (setCcsdsPacking == 1) {
|
||||||
*err = grib_set_string(outh, "packingType", "grid_ccsds", &slen);
|
*err = grib_set_string(h_out, "packingType", "grid_ccsds", &slen);
|
||||||
if (*err != GRIB_SUCCESS) {
|
if (*err != GRIB_SUCCESS) {
|
||||||
fprintf(stderr, "GRIB_UTIL_SET_SPEC: Failed to change packingType to CCSDS: %s\n",
|
fprintf(stderr, "GRIB_UTIL_SET_SPEC: Failed to change packingType to CCSDS: %s\n",
|
||||||
grib_get_error_message(*err));
|
grib_get_error_message(*err));
|
||||||
|
@ -1697,7 +1700,7 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (packing_spec->deleteLocalDefinition) {
|
if (packing_spec->deleteLocalDefinition) {
|
||||||
grib_set_long(outh, "deleteLocalDefinition", 1);
|
grib_set_long(h_out, "deleteLocalDefinition", 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ECC-445 */
|
/* ECC-445 */
|
||||||
|
@ -1705,16 +1708,16 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
Assert(!global_grid); /* ECC-576: "global" should not be set */
|
Assert(!global_grid); /* ECC-576: "global" should not be set */
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((*err = check_geometry(outh, spec, data_values_count, global_grid)) != GRIB_SUCCESS) {
|
if ((*err = check_geometry(h_out, spec, data_values_count, global_grid)) != GRIB_SUCCESS) {
|
||||||
fprintf(stderr, "GRIB_UTIL_SET_SPEC: Geometry check failed! %s\n", grib_get_error_message(*err));
|
fprintf(stderr, "GRIB_UTIL_SET_SPEC: Geometry check failed! %s\n", grib_get_error_message(*err));
|
||||||
if (h->context->write_on_fail)
|
if (h->context->write_on_fail)
|
||||||
grib_write_message(outh, "error.grib", "w");
|
grib_write_message(h_out, "error.grib", "w");
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Disable check: need to re-examine GRIB-864 */
|
/* Disable check: need to re-examine GRIB-864 */
|
||||||
#if 0
|
#if 0
|
||||||
if ( (*err = check_handle_against_spec(outh, editionNumber, spec, global_grid)) != GRIB_SUCCESS)
|
if ( (*err = check_handle_against_spec(h_out, editionNumber, spec, global_grid)) != GRIB_SUCCESS)
|
||||||
{
|
{
|
||||||
|
|
||||||
grib_context* c=grib_context_get_default();
|
grib_context* c=grib_context_get_default();
|
||||||
|
@ -1723,18 +1726,18 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
||||||
fprintf(stderr,"Note: in GRIB edition 1 latitude and longitude values cannot be represented with sub-millidegree precision.\n");
|
fprintf(stderr,"Note: in GRIB edition 1 latitude and longitude values cannot be represented with sub-millidegree precision.\n");
|
||||||
}
|
}
|
||||||
if (c->write_on_fail)
|
if (c->write_on_fail)
|
||||||
grib_write_message(outh,"error.grib","w");
|
grib_write_message(h_out,"error.grib","w");
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (h->context->debug == -1)
|
if (h->context->debug == -1)
|
||||||
fprintf(stderr, "ECCODES DEBUG: grib_util_set_spec end\n");
|
fprintf(stderr, "ECCODES DEBUG: grib_util_set_spec end\n");
|
||||||
|
|
||||||
return outh;
|
return h_out;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
if (outh)
|
if (h_out)
|
||||||
grib_handle_delete(outh);
|
grib_handle_delete(h_out);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue