2023-07-24 12:14:40 +00:00
|
|
|
/*
|
|
|
|
* (C) Copyright 2005- ECMWF.
|
|
|
|
*
|
|
|
|
* This software is licensed under the terms of the Apache Licence Version 2.0
|
|
|
|
* which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
|
|
|
|
*
|
|
|
|
* In applying this licence, ECMWF does not waive the privileges and immunities granted to it by
|
|
|
|
* virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "grib_api_internal.h"
|
|
|
|
|
|
|
|
int main(int argc, char* argv[])
|
|
|
|
{
|
|
|
|
FILE* f1 = NULL;
|
|
|
|
FILE* f2 = NULL;
|
|
|
|
grib_handle* h1 = NULL;
|
|
|
|
grib_handle* h2 = NULL;
|
|
|
|
int err = 0;
|
2023-12-17 16:39:18 +00:00
|
|
|
size_t num_diffs = 0, i = 0;
|
|
|
|
char** list_provided_keys = NULL;
|
2023-07-24 12:14:40 +00:00
|
|
|
|
|
|
|
f1 = fopen(argv[1], "rb");
|
|
|
|
f2 = fopen(argv[2], "rb");
|
|
|
|
Assert(f1 && f2);
|
|
|
|
|
2023-12-17 16:39:18 +00:00
|
|
|
if (argc == 4) {
|
|
|
|
// List of keys is also given on the command line
|
|
|
|
char* input = argv[3];
|
|
|
|
list_provided_keys = string_split(input, ",");
|
|
|
|
}
|
|
|
|
|
2023-07-24 12:14:40 +00:00
|
|
|
while ((h1 = grib_handle_new_from_file(0, f1, &err)) != NULL && (h2 = grib_handle_new_from_file(0, f2, &err)) != NULL) {
|
|
|
|
grib_keys_iterator* kiter = NULL;
|
|
|
|
|
2023-07-24 13:26:04 +00:00
|
|
|
// Use namespace of NULL to get ALL keys
|
|
|
|
// Set flags to 0 to not filter any keys
|
2023-07-24 12:14:40 +00:00
|
|
|
//kiter = grib_keys_iterator_new(h1, /*flags=*/0, /*namespace=*/NULL);
|
|
|
|
kiter = grib_keys_iterator_new(h1, /*flags=*/GRIB_KEYS_ITERATOR_SKIP_COMPUTED, /*namespace=*/NULL);
|
|
|
|
Assert(kiter);
|
|
|
|
|
|
|
|
while (grib_keys_iterator_next(kiter)) {
|
|
|
|
const char* name = grib_keys_iterator_get_name(kiter);
|
|
|
|
Assert(name);
|
|
|
|
err = codes_compare_key(h1, h2, name, 0);
|
|
|
|
if (err) {
|
2023-07-24 13:26:04 +00:00
|
|
|
fprintf(stderr, "key: %s (%s)\n", name, grib_get_error_message(err));
|
2023-12-17 16:39:18 +00:00
|
|
|
++num_diffs;
|
2023-07-24 12:14:40 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-10-16 16:40:25 +00:00
|
|
|
// Some specific keys
|
|
|
|
codes_compare_key(h1, h2, "md5Headers", 0); // md5
|
|
|
|
codes_compare_key(h1, h2, "computeStatistics", 0); // statistics
|
|
|
|
codes_compare_key(h1, h2, "paramId", 0); // concept
|
|
|
|
codes_compare_key(h1, h2, "identifier", 0); // ascii
|
|
|
|
|
2023-12-17 16:39:18 +00:00
|
|
|
if (list_provided_keys) {
|
|
|
|
for (i = 0; list_provided_keys[i] != NULL; ++i) {
|
|
|
|
const char* pkey = list_provided_keys[i];
|
2023-12-17 17:08:48 +00:00
|
|
|
//printf("Comparing provided key %s ...\n", list_provided_keys[i]);
|
2023-12-17 16:39:18 +00:00
|
|
|
err = codes_compare_key(h1, h2, pkey, 0);
|
|
|
|
if (err) {
|
|
|
|
fprintf(stderr, "key: %s (%s)\n", pkey, grib_get_error_message(err));
|
|
|
|
++num_diffs;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-07-24 12:14:40 +00:00
|
|
|
grib_keys_iterator_delete(kiter);
|
|
|
|
grib_handle_delete(h1);
|
|
|
|
grib_handle_delete(h2);
|
|
|
|
}
|
2023-12-17 16:39:18 +00:00
|
|
|
|
2023-07-24 12:14:40 +00:00
|
|
|
fclose(f1);
|
|
|
|
fclose(f2);
|
2023-12-17 16:39:18 +00:00
|
|
|
|
|
|
|
if (list_provided_keys) {
|
|
|
|
for (i = 0; list_provided_keys[i] != NULL; ++i) free(list_provided_keys[i]);
|
|
|
|
free(list_provided_keys);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (num_diffs > 0) {
|
|
|
|
fprintf(stderr, "\nComparison failed: %zu differences\n", num_diffs);
|
2023-07-24 15:10:55 +00:00
|
|
|
return 1;
|
2023-07-24 12:14:40 +00:00
|
|
|
}
|
2023-07-24 15:10:55 +00:00
|
|
|
return 0;
|
2023-07-24 12:14:40 +00:00
|
|
|
}
|