eccodes/tests/codes_dump_action_tree.cc

48 lines
1.2 KiB
C++
Raw Permalink Normal View History

2023-08-12 12:39:44 +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.
*/
#undef NDEBUG
#include <assert.h>
#include "eccodes.h"
2024-09-01 15:42:00 +00:00
static ProductKind get_product_kind(const char* p)
{
if (strcmp(p, "GRIB") == 0) return PRODUCT_GRIB;
if (strcmp(p, "BUFR") == 0) return PRODUCT_BUFR;
if (strcmp(p, "METAR") == 0) return PRODUCT_METAR;
if (strcmp(p, "GTS") == 0) return PRODUCT_GTS;
return PRODUCT_ANY;
}
2023-08-12 12:39:44 +00:00
int main(int argc, char** argv)
{
int err = 0;
codes_context* c = codes_context_get_default();
2024-09-01 15:42:00 +00:00
assert(argc == 3);
const ProductKind mode = get_product_kind( argv[1] );
const char* filename = argv[2];
2023-08-12 12:39:44 +00:00
FILE* fp = fopen(filename, "rb");
assert(fp);
2024-09-01 15:42:00 +00:00
codes_handle* h = codes_handle_new_from_file(c, fp, mode, &err);
2023-08-12 12:39:44 +00:00
assert(h);
assert(!err);
codes_dump_action_tree(c, stdout);
codes_handle_delete(h);
fclose(fp);
return 0;
}