mirror of https://github.com/ecmwf/eccodes.git
193 lines
3.7 KiB
C
193 lines
3.7 KiB
C
/*
|
|
* Copyright 2005-2018 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;
|
|
}
|