eccodes/examples/C/bufr_copy_data.c

113 lines
4.1 KiB
C
Raw Permalink Normal View History

2016-10-18 16:59:04 +00:00
/*
2020-01-28 14:32:34 +00:00
* (C) Copyright 2005- ECMWF.
2016-10-18 16:59:04 +00:00
*
* 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.
*/
/*
* C Implementation: bufr_copy_data
*
* Description: How to copy all the values in the data section that are present in the same
* position in the data tree and with the same number of values to the output handle
*
*/
#include "eccodes.h"
2016-10-18 17:23:33 +00:00
static void usage(const char* progname);
2020-01-22 14:57:43 +00:00
int main(int argc, char* argv[])
{
2020-01-22 14:57:43 +00:00
FILE* f = NULL;
codes_handle* h = NULL;
2016-10-18 17:23:33 +00:00
codes_handle* ho = NULL;
long size;
2020-01-22 14:57:43 +00:00
char** keys = NULL;
size_t nkeys = 0, i;
int err = 0;
char* outfile = NULL;
2016-10-18 17:23:33 +00:00
const char* sampleName = "BUFR3";
2020-01-22 14:57:43 +00:00
const long ibitmap[] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 0 };
2020-01-22 14:57:43 +00:00
const long ud[] = { 307011, 7006, 10004, 222000, 101023, 31031, 1031, 1032, 101023, 33007,
225000, 236000, 101023, 31031, 1031, 1032, 8024, 101001, 225255, 225000,
236000, 101023, 31031, 1031, 1032, 8024, 101001, 225255,
1063, 2001, 4001, 4002, 4003, 4004, 4005, 5002,
6002, 7001, 7006, 11001, 11016, 11017, 11002 };
2016-10-18 17:23:33 +00:00
if (argc != 3) usage(argv[0]);
2020-01-22 14:57:43 +00:00
outfile = argv[2];
2020-01-22 14:57:43 +00:00
f = fopen(argv[1], "rb");
if (!f) {
2016-10-18 17:23:33 +00:00
perror(argv[1]);
exit(1);
}
ho = codes_bufr_handle_new_from_samples(NULL, sampleName);
if (ho == NULL) {
2020-05-14 19:21:31 +00:00
fprintf(stderr, "Error: creating BUFR from %s\n", sampleName);
2016-10-18 17:23:33 +00:00
fclose(f);
return 1;
}
2020-01-22 14:57:43 +00:00
size = sizeof(ibitmap) / sizeof(ibitmap[0]);
2016-10-18 17:23:33 +00:00
CODES_CHECK(codes_set_long_array(ho, "inputDataPresentIndicator", ibitmap, size), 0);
CODES_CHECK(codes_set_long(ho, "bufrHeaderCentre", 98), 0);
CODES_CHECK(codes_set_long(ho, "updateSequenceNumber", 1), 0);
CODES_CHECK(codes_set_long(ho, "dataCategory", 0), 0);
CODES_CHECK(codes_set_long(ho, "dataSubCategory", 140), 0);
CODES_CHECK(codes_set_long(ho, "masterTablesVersionNumber", 13), 0);
CODES_CHECK(codes_set_long(ho, "localTablesVersionNumber", 1), 0);
CODES_CHECK(codes_set_long(ho, "typicalYearOfCentury", 15), 0);
CODES_CHECK(codes_set_long(ho, "typicalMonth", 5), 0);
CODES_CHECK(codes_set_long(ho, "typicalDay", 4), 0);
CODES_CHECK(codes_set_long(ho, "typicalHour", 9), 0);
CODES_CHECK(codes_set_long(ho, "typicalMinute", 30), 0);
CODES_CHECK(codes_set_long(ho, "numberOfSubsets", 1), 0);
CODES_CHECK(codes_set_long(ho, "observedData", 1), 0);
CODES_CHECK(codes_set_long(ho, "compressedData", 0), 0);
2020-01-22 14:57:43 +00:00
size = sizeof(ud) / sizeof(ud[0]);
codes_set_long_array(ho, "unexpandedDescriptors", ud, size);
2020-01-22 14:57:43 +00:00
while ((h = codes_handle_new_from_file(0, f, PRODUCT_BUFR, &err)) != NULL) {
2016-10-18 17:23:33 +00:00
/* codes_copy_key(h,ho,"unexpandedDescriptors",0); */
2020-01-22 14:57:43 +00:00
err = codes_set_long(h, "unpack", 1);
2016-10-25 10:42:20 +00:00
if (err) {
2020-05-14 19:21:31 +00:00
fprintf(stderr, "Error: Unable to unpack BUFR message. Quitting\n");
fprintf(stderr, " %s\n", codes_get_error_message(err));
2016-10-25 10:42:20 +00:00
return 1;
}
2016-10-18 17:23:33 +00:00
/* err=codes_bufr_copy_data(h,ho); */
2020-01-22 14:57:43 +00:00
keys = codes_bufr_copy_data_return_copied_keys(h, ho, &nkeys, &err);
for (i = 0; i < nkeys; i++) {
printf("Copied %s\n", keys[i]);
2016-10-18 17:23:33 +00:00
free(keys[i]);
}
printf("Total number of copied keys = %zu\n", nkeys);
2016-10-18 17:23:33 +00:00
free(keys);
2016-10-18 17:23:33 +00:00
codes_handle_delete(h);
}
fclose(f);
2020-01-22 14:57:43 +00:00
codes_write_message(ho, outfile, "w");
2016-10-18 17:23:33 +00:00
codes_handle_delete(ho);
2016-10-18 17:23:33 +00:00
return err;
}
2016-10-18 17:23:33 +00:00
static void usage(const char* progname)
{
2020-01-22 14:57:43 +00:00
printf("\nUsage: %s bufr_in bufr_out\n", progname);
2016-10-18 17:23:33 +00:00
exit(1);
}