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