grib_util_set_spec: Refactoring

This commit is contained in:
Shahram Najm 2021-02-15 19:05:36 +00:00
parent b158c067ac
commit 46bda29a22
1 changed files with 51 additions and 48 deletions

View File

@ -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;
} }