mirror of https://github.com/ecmwf/eccodes.git
188 lines
4.0 KiB
C++
188 lines
4.0 KiB
C++
/*
|
|
* (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 <stdio.h>
|
|
#include <string.h>
|
|
#include <unistd.h>
|
|
|
|
|
|
#include "grib_api_internal.h"
|
|
#include "loady.h"
|
|
#include "load.h"
|
|
|
|
FILE* fout;
|
|
|
|
extern FILE* load_in;
|
|
extern int load_parse();
|
|
extern int yylineno;
|
|
|
|
static grib_handle* h = 0;
|
|
|
|
static double* double_value = 0;
|
|
static size_t double_value_size = 0;
|
|
static size_t double_value_count = 0;
|
|
|
|
static long* long_value = 0;
|
|
static size_t long_value_size = 0;
|
|
static size_t long_value_count = 0;
|
|
|
|
static int err;
|
|
|
|
const char* out_file;
|
|
|
|
static void check(int code, const char* name)
|
|
{
|
|
if (code) {
|
|
printf("%s: cannot set %s: %s\n", prog, name, grib_get_error_message(code));
|
|
err++;
|
|
}
|
|
}
|
|
|
|
static grib_handle* handle()
|
|
{
|
|
if (h == 0)
|
|
h = grib_handle_new_from_samples(NULL, "GRIB1");
|
|
/* grib_dump_content(h,stdout,"debug",~0,NULL); */
|
|
return h;
|
|
}
|
|
|
|
void load_finish()
|
|
{
|
|
const void* buffer;
|
|
size_t size;
|
|
assert(h);
|
|
GRIB_CHECK(grib_get_message(h, &buffer, &size), "");
|
|
|
|
printf("%s: writing %ld bytes message\n", prog, (long)size);
|
|
|
|
if (fwrite(buffer, 1, size, fout) != size) {
|
|
perror(out_file);
|
|
exit(1);
|
|
}
|
|
grib_handle_delete(h);
|
|
h = NULL;
|
|
}
|
|
|
|
void load_missing(const char* name)
|
|
{
|
|
printf("grib_set_missing(%s)\n", name);
|
|
check(grib_set_missing(handle(), name), name);
|
|
}
|
|
|
|
void load_long(const char* name, long value)
|
|
{
|
|
printf("grib_set_long(%s,%ld)\n", name, value);
|
|
check(grib_set_long(handle(), name, value), name);
|
|
}
|
|
|
|
void load_string(const char* name, const char* value)
|
|
{
|
|
size_t s = strlen(value);
|
|
printf("grib_set_string(%s,%s)\n", name, value);
|
|
check(grib_set_string(handle(), name, value, &s), name);
|
|
}
|
|
|
|
void load_double(const char* name, double value)
|
|
{
|
|
printf("grib_set_double(%s,%g)\n", name, value);
|
|
check(grib_set_double(handle(), name, value), name);
|
|
}
|
|
|
|
void load_start_array()
|
|
{
|
|
if (double_value == NULL) {
|
|
double_value_size = 100000;
|
|
double_value = malloc(double_value_size * sizeof(double));
|
|
}
|
|
|
|
if (long_value == NULL) {
|
|
long_value_size = 100000;
|
|
long_value = malloc(long_value_size * sizeof(long));
|
|
}
|
|
|
|
double_value_count = 0;
|
|
long_value_count = 0;
|
|
}
|
|
|
|
|
|
void load_end_array(const char* name)
|
|
{
|
|
if (double_value_count == long_value_count) {
|
|
printf("grib_set_long_array(%s,%ld)\n", name, (long)long_value_count);
|
|
check(grib_set_long_array(handle(), name, long_value, long_value_count), name);
|
|
}
|
|
else {
|
|
printf("grib_set_double_array(%s,%ld)\n", name, (long)double_value_count);
|
|
check(grib_set_double_array(handle(), name, double_value, double_value_count), name);
|
|
}
|
|
}
|
|
|
|
|
|
void load_double_value(double value)
|
|
{
|
|
if (double_value_count == double_value_size) {
|
|
double_value_size += 100000;
|
|
double_value = realloc(double_value, double_value_size * sizeof(double));
|
|
}
|
|
|
|
double_value[double_value_count++] = value;
|
|
}
|
|
|
|
void load_long_value(long value)
|
|
{
|
|
if (long_value_count == long_value_size) {
|
|
long_value_size += 100000;
|
|
long_value = realloc(long_value, long_value_size * sizeof(long));
|
|
}
|
|
|
|
long_value[long_value_count++] = value;
|
|
|
|
load_double_value(value);
|
|
}
|
|
|
|
|
|
int load_wrap()
|
|
{
|
|
return 1;
|
|
}
|
|
int load_error(const char* msg)
|
|
{
|
|
printf("%s line %d\n", msg, yylineno);
|
|
err = 1;
|
|
return 1;
|
|
}
|
|
|
|
|
|
int load_file(const char* in, const char* out)
|
|
{
|
|
err = 0;
|
|
fout = fopen(out, "w");
|
|
if (!fout) {
|
|
perror(out);
|
|
return 1;
|
|
}
|
|
|
|
load_in = fopen(in, "r");
|
|
if (!load_in) {
|
|
perror(in);
|
|
return 1;
|
|
}
|
|
|
|
load_parse();
|
|
|
|
fclose(load_in);
|
|
if (fclose(fout)) {
|
|
perror(out);
|
|
return 1;
|
|
}
|
|
|
|
return err;
|
|
}
|