ECC-1621: Valgrind error: grib_compare -H

This commit is contained in:
Shahram Najm 2023-07-13 11:39:39 +00:00
parent cf6a64afad
commit bc216cdc41
2 changed files with 14 additions and 0 deletions

View File

@ -25,6 +25,7 @@ ${tools_dir}/grib_compare $infile $outfile
status=$? status=$?
set -e set -e
[ $status -eq 1 ] [ $status -eq 1 ]
${tools_dir}/grib_compare -b referenceValue $infile $outfile
${tools_dir}/grib_compare -H $infile $outfile ${tools_dir}/grib_compare -H $infile $outfile

View File

@ -1155,6 +1155,19 @@ static int compare_handles(grib_handle* h1, grib_handle* h2, grib_runtime_option
} }
if (headerMode) { if (headerMode) {
// An alternative implementation:
// Instead of forming two partial handles (only meta-data) and comparing
// the keys in those, we can instead get all the keys in the original handles
// and check their offset and only process those which are before the "endOfHeadersMarker"
// i.e., only compare keys that come before the bitmap/data sections
//
// GRIB_CHECK_NOLINE(grib_get_offset(h1, "endOfHeadersMarker", &endOfHeadersOffset), 0);
// create iterator
// foreach key in iter
// GRIB_CHECK_NOLINE(grib_get_offset(h1, name, &keyOffset), 0);
// if (keyOffset < endOfHeadersOffset) {
// compare_values...
//
const void *msg1 = NULL, *msg2 = NULL; const void *msg1 = NULL, *msg2 = NULL;
size_t size1 = 0, size2 = 0; size_t size1 = 0, size2 = 0;
grib_handle *h11, *h22; grib_handle *h11, *h22;