ECC-1699: Dump

This commit is contained in:
Shahram Najm 2023-12-05 13:02:27 +00:00
parent 3cb61d994f
commit 161a048488
11 changed files with 63 additions and 37 deletions

View File

@ -1134,3 +1134,11 @@ int codes_bufr_key_is_coordinate(const grib_handle* h, const char* key, int* err
*err = GRIB_SUCCESS; *err = GRIB_SUCCESS;
return ((acc->flags & GRIB_ACCESSOR_FLAG_BUFR_COORD) != 0); return ((acc->flags & GRIB_ACCESSOR_FLAG_BUFR_COORD) != 0);
} }
int codes_bufr_key_exclude_from_dump(const char* key)
{
if (strstr(key, "percentConfidence->percentConfidence->percentConfidence->percentConfidence->percentConfidence")) {
return 1;
}
return 0;
}

View File

@ -1382,6 +1382,7 @@ int codes_bufr_extract_headers_malloc(grib_context* c, const char* filename, cod
int codes_bufr_header_get_string(codes_bufr_header* bh, const char* key, char* val, size_t* len); int codes_bufr_header_get_string(codes_bufr_header* bh, const char* key, char* val, size_t* len);
int codes_bufr_key_is_header(const grib_handle* h, const char* key, int* err); int codes_bufr_key_is_header(const grib_handle* h, const char* key, int* err);
int codes_bufr_key_is_coordinate(const grib_handle* h, const char* key, int* err); int codes_bufr_key_is_coordinate(const grib_handle* h, const char* key, int* err);
int codes_bufr_key_exclude_from_dump(const char* key);
/* string_util.cc*/ /* string_util.cc*/
int strcmp_nocase(const char* s1, const char* s2); int strcmp_nocase(const char* s1, const char* s2);

View File

@ -326,6 +326,7 @@ static void dump_long(grib_dumper* d, grib_accessor* a, const char* comment)
} }
else { else {
r = compute_bufr_key_rank(h, self->keys, a->name); r = compute_bufr_key_rank(h, self->keys, a->name);
if (!codes_bufr_key_exclude_from_dump(a->name)) {
if (!grib_is_missing_long(a, value)) { if (!grib_is_missing_long(a, value)) {
if (r != 0) if (r != 0)
fprintf(self->dumper.out, " CODES_CHECK(codes_get_long(h, \"#%d#%s\", &iVal), 0);\n", r, a->name); fprintf(self->dumper.out, " CODES_CHECK(codes_get_long(h, \"#%d#%s\", &iVal), 0);\n", r, a->name);
@ -333,6 +334,7 @@ static void dump_long(grib_dumper* d, grib_accessor* a, const char* comment)
fprintf(self->dumper.out, " CODES_CHECK(codes_get_long(h, \"%s\", &iVal), 0);\n", a->name); fprintf(self->dumper.out, " CODES_CHECK(codes_get_long(h, \"%s\", &iVal), 0);\n", a->name);
} }
} }
}
if (self->isLeaf == 0) { if (self->isLeaf == 0) {
char* prefix; char* prefix;
@ -388,10 +390,12 @@ static void dump_long_attribute(grib_dumper* d, grib_accessor* a, const char* pr
} }
else { else {
/* int r=compute_bufr_key_rank(h,self->keys,a->name); */ /* int r=compute_bufr_key_rank(h,self->keys,a->name); */
if (!codes_bufr_key_exclude_from_dump(prefix)) {
if (!grib_is_missing_long(a, value)) { if (!grib_is_missing_long(a, value)) {
fprintf(self->dumper.out, " CODES_CHECK(codes_get_long(h, \"%s->%s\", &iVal), 0);\n", prefix, a->name); fprintf(self->dumper.out, " CODES_CHECK(codes_get_long(h, \"%s->%s\", &iVal), 0);\n", prefix, a->name);
} }
} }
}
if (self->isLeaf == 0) { if (self->isLeaf == 0) {
char* prefix1; char* prefix1;

View File

@ -322,8 +322,9 @@ static void dump_long_attribute(grib_dumper* d, grib_accessor* a, const char* pr
return; return;
self->empty = 0; self->empty = 0;
if (!codes_bufr_key_exclude_from_dump(prefix)) {
fprintf(self->dumper.out, "print \"%s->%s = [%s->%s]\";\n", prefix, a->name, prefix, a->name); fprintf(self->dumper.out, "print \"%s->%s = [%s->%s]\";\n", prefix, a->name, prefix, a->name);
}
if (self->isLeaf == 0) { if (self->isLeaf == 0) {
char* prefix1 = (char*)grib_context_malloc_clear(c, sizeof(char) * (strlen(a->name) + strlen(prefix) + 5)); char* prefix1 = (char*)grib_context_malloc_clear(c, sizeof(char) * (strlen(a->name) + strlen(prefix) + 5));
snprintf(prefix1, 1024, "%s->%s", prefix, a->name); snprintf(prefix1, 1024, "%s->%s", prefix, a->name);

View File

@ -347,10 +347,12 @@ static void dump_long_attribute(grib_dumper* d, grib_accessor* a, const char* pr
fprintf(self->dumper.out, " call codes_get(ibufr, '%s->%s', iValues)\n", prefix, a->name); fprintf(self->dumper.out, " call codes_get(ibufr, '%s->%s', iValues)\n", prefix, a->name);
} }
else { else {
if (!codes_bufr_key_exclude_from_dump(prefix)) {
if (!grib_is_missing_long(a, value)) { if (!grib_is_missing_long(a, value)) {
fprintf(self->dumper.out, " call codes_get(ibufr, '%s->%s', iVal)\n", prefix, a->name); fprintf(self->dumper.out, " call codes_get(ibufr, '%s->%s', iVal)\n", prefix, a->name);
} }
} }
}
if (self->isLeaf == 0) { if (self->isLeaf == 0) {
char* prefix1; char* prefix1;

View File

@ -359,10 +359,12 @@ static void dump_long_attribute(grib_dumper* d, grib_accessor* a, const char* pr
fprintf(self->dumper.out, " iVals = codes_get_array(ibufr, '%s->%s')\n", prefix, a->name); fprintf(self->dumper.out, " iVals = codes_get_array(ibufr, '%s->%s')\n", prefix, a->name);
} }
else { else {
if (!codes_bufr_key_exclude_from_dump(prefix)) {
if (!grib_is_missing_long(a, value)) { if (!grib_is_missing_long(a, value)) {
fprintf(self->dumper.out, " iVal = codes_get(ibufr, '%s->%s')\n", prefix, a->name); fprintf(self->dumper.out, " iVal = codes_get(ibufr, '%s->%s')\n", prefix, a->name);
} }
} }
}
if (self->isLeaf == 0) { if (self->isLeaf == 0) {
char* prefix1; char* prefix1;

View File

@ -524,11 +524,13 @@ static void dump_long_attribute(grib_dumper* d, grib_accessor* a, const char* pr
fprintf(self->dumper.out, " CODES_CHECK(codes_set_long_array(h, \"%s->%s\", ivalues, size), 0);\n", prefix, a->name); fprintf(self->dumper.out, " CODES_CHECK(codes_set_long_array(h, \"%s->%s\", ivalues, size), 0);\n", prefix, a->name);
} }
else { else {
if (!codes_bufr_key_exclude_from_dump(prefix)) {
char* sval = lval_to_string(c, value); char* sval = lval_to_string(c, value);
fprintf(self->dumper.out, " CODES_CHECK(codes_set_long(h, \"%s->%s\", ", prefix, a->name); fprintf(self->dumper.out, " CODES_CHECK(codes_set_long(h, \"%s->%s\", ", prefix, a->name);
fprintf(self->dumper.out, "%s), 0);\n", sval); fprintf(self->dumper.out, "%s), 0);\n", sval);
grib_context_free(c, sval); grib_context_free(c, sval);
} }
}
if (self->isLeaf == 0) { if (self->isLeaf == 0) {
const size_t prefix1MaxLen = strlen(a->name) + strlen(prefix) + 5; const size_t prefix1MaxLen = strlen(a->name) + strlen(prefix) + 5;

View File

@ -451,11 +451,13 @@ static void dump_long_attribute(grib_dumper* d, grib_accessor* a, const char* pr
} }
else { else {
/* int r=compute_bufr_key_rank(h,self->keys,a->name); */ /* int r=compute_bufr_key_rank(h,self->keys,a->name); */
if (!codes_bufr_key_exclude_from_dump(prefix)) {
if (!grib_is_missing_long(a, value)) { if (!grib_is_missing_long(a, value)) {
fprintf(self->dumper.out, "set %s->%s = ", prefix, a->name); fprintf(self->dumper.out, "set %s->%s = ", prefix, a->name);
fprintf(self->dumper.out, "%ld ;\n", value); fprintf(self->dumper.out, "%ld ;\n", value);
} }
} }
}
if (self->isLeaf == 0) { if (self->isLeaf == 0) {
char* prefix1; char* prefix1;

View File

@ -573,11 +573,13 @@ static void dump_long_attribute(grib_dumper* d, grib_accessor* a, const char* pr
fprintf(self->dumper.out, " call codes_set(ibufr,'%s->%s' &\n,ivalues)\n", pref, a->name); fprintf(self->dumper.out, " call codes_set(ibufr,'%s->%s' &\n,ivalues)\n", pref, a->name);
} }
else { else {
if (!codes_bufr_key_exclude_from_dump(prefix)) {
char* sval = lval_to_string(c, value); char* sval = lval_to_string(c, value);
fprintf(self->dumper.out, " call codes_set(ibufr,'%s->%s'&\n,", pref, a->name); fprintf(self->dumper.out, " call codes_set(ibufr,'%s->%s'&\n,", pref, a->name);
fprintf(self->dumper.out, "%s)\n", sval); fprintf(self->dumper.out, "%s)\n", sval);
grib_context_free(c, sval); grib_context_free(c, sval);
} }
}
if (self->isLeaf == 0) { if (self->isLeaf == 0) {
char* prefix1; char* prefix1;

View File

@ -519,11 +519,13 @@ static void dump_long_attribute(grib_dumper* d, grib_accessor* a, const char* pr
fprintf(self->dumper.out, " codes_set_array(ibufr, '%s->%s', ivalues)\n", prefix, a->name); fprintf(self->dumper.out, " codes_set_array(ibufr, '%s->%s', ivalues)\n", prefix, a->name);
} }
else { else {
if (!codes_bufr_key_exclude_from_dump(prefix)) {
char* sval = lval_to_string(c, value); char* sval = lval_to_string(c, value);
fprintf(self->dumper.out, " codes_set(ibufr, '%s->%s', ", prefix, a->name); fprintf(self->dumper.out, " codes_set(ibufr, '%s->%s', ", prefix, a->name);
fprintf(self->dumper.out, "%s)\n", sval); fprintf(self->dumper.out, "%s)\n", sval);
grib_context_free(c, sval); grib_context_free(c, sval);
} }
}
if (self->isLeaf == 0) { if (self->isLeaf == 0) {
char* prefix1; char* prefix1;

View File

@ -466,6 +466,7 @@ static void dump_long_attribute(grib_dumper* d, grib_accessor* a, const char* pr
} }
else { else {
/* int r=compute_bufr_key_rank(h,self->keys,a->name); */ /* int r=compute_bufr_key_rank(h,self->keys,a->name); */
if (!codes_bufr_key_exclude_from_dump(prefix)) {
if (!grib_is_missing_long(a, value)) { if (!grib_is_missing_long(a, value)) {
fprintf(self->dumper.out, "%s->%s = ", prefix, a->name); fprintf(self->dumper.out, "%s->%s = ", prefix, a->name);
fprintf(self->dumper.out, "%ld\n", value); fprintf(self->dumper.out, "%ld\n", value);
@ -474,11 +475,10 @@ static void dump_long_attribute(grib_dumper* d, grib_accessor* a, const char* pr
fprintf(self->dumper.out, "%s->%s = MISSING\n", prefix, a->name); fprintf(self->dumper.out, "%s->%s = MISSING\n", prefix, a->name);
} }
} }
}
if (self->isLeaf == 0) { if (self->isLeaf == 0) {
char* prefix1; char* prefix1 = (char*)grib_context_malloc_clear(c, sizeof(char) * (strlen(a->name) + strlen(prefix) + 5));
prefix1 = (char*)grib_context_malloc_clear(c, sizeof(char) * (strlen(a->name) + strlen(prefix) + 5));
snprintf(prefix1, 1024, "%s->%s", prefix, a->name); snprintf(prefix1, 1024, "%s->%s", prefix, a->name);
dump_attributes(d, a, prefix1); dump_attributes(d, a, prefix1);