eccodes/tools/taf_ls.c

277 lines
8.6 KiB
C
Raw Normal View History

2014-07-06 13:18:40 +00:00
/*
* Copyright 2005-2016 ECMWF.
2014-07-06 13:18:40 +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.
*/
#include "grib_tools.h"
grib_option grib_options[]={
2016-04-04 15:24:28 +00:00
/* {id, args, help}, on, command_line, value*/
{"f",0,0,1,0,0},
{"p:",0,0,0,1,0},
{"F:",0,0,1,1,"%g"},
{"P:",0,0,0,1,0},
{"w:",0,0,0,1,0},
{"j",0,"json output\n",0,1,0},
{"B:",0,0,0,1,0},
{"l:",0,0,0,1,0},
{"s:",0,0,0,1,0},
{"i:",0,0,0,1,0},
{"n:",0,0,1,1,"ls"},
{"m",0,0,0,1,0},
{"V",0,0,0,1,0},
{"W:",0,0,1,1,"10"},
{"S",0,0,1,0,0},
{"M",0,0,0,1,0},
{"H",0,0,1,0,0},
{"g",0,0,0,1,0},
{"P",0,0,1,0,0},
{"T:",0,0,1,0,"F"},
{"7",0,0,0,1,0},
{"v",0,0,1,0,0},
{"x",0,0,0,1,0}
2014-07-06 13:18:40 +00:00
};
2016-04-04 15:24:28 +00:00
char* grib_tool_description="List content of TAF files printing values of "
"some keys.\n\tIt does not fail when a key is not found.";
2014-07-06 13:18:40 +00:00
char* grib_tool_name="taf_ls";
char* grib_tool_usage="[options] file file ...";
static char* new_handle="";
int grib_options_count=sizeof(grib_options)/sizeof(grib_option);
double lat=0;
double lon=0;
int mode=0;
static int json=0;
2016-04-04 15:24:28 +00:00
int main(int argc, char *argv[])
{
return grib_tool(argc,argv);
}
2014-07-06 13:18:40 +00:00
/*
2016-04-04 15:24:28 +00:00
This is executed before processing the options with
getopt and therefore it is the right place for hacking
2014-07-06 13:18:40 +00:00
the arguments if needed
2016-04-04 15:24:28 +00:00
*/
int grib_tool_before_getopt(grib_runtime_options* options)
{
return 0;
2014-07-06 13:18:40 +00:00
}
/*
The options have been parsed and the structure
grib_runtime_options* options has been loaded.
2016-04-04 15:24:28 +00:00
Initialisation and startup can be done here
*/
int grib_tool_init(grib_runtime_options* options)
{
if (grib_options_on("j")) {
options->verbose=0;
json=1;
2014-07-06 13:18:40 +00:00
}
2016-04-04 15:24:28 +00:00
if (json) printf("[\n");
2014-07-06 13:18:40 +00:00
2016-04-04 15:24:28 +00:00
return 0;
2014-07-06 13:18:40 +00:00
}
/*
A new file is being parsed. The file name is file. This function is called every time
a new input file name is processed, before opening the file.
2016-04-04 15:24:28 +00:00
*/
int grib_tool_new_filename_action(grib_runtime_options* options,const char* file)
{
return 0;
}
2014-07-06 13:18:40 +00:00
2016-04-04 15:24:28 +00:00
int grib_tool_new_file_action(grib_runtime_options* options,grib_tools_file* file)
{
return 0;
2014-07-06 13:18:40 +00:00
}
2016-04-04 15:24:28 +00:00
static void print_key_values(grib_runtime_options* options,grib_handle* h)
{
int i;
int ret=0;
char* s="\"keys\" : {";
double dvalue=0;
long lvalue=0;
char value[MAX_STRING_LEN];
size_t len=MAX_STRING_LEN;
for (i=0;i<options->print_keys_count;i++) {
ret=GRIB_SUCCESS;
printf("%s",s);
len=MAX_STRING_LEN;
printf("\"%s\" : ",options->print_keys[i].name);
if (grib_is_missing(h,options->print_keys[i].name,&ret) && ret==GRIB_SUCCESS)
printf("\"missing\"");
else if ( ret == GRIB_SUCCESS ) {
if (options->print_keys[i].type == GRIB_TYPE_UNDEFINED)
grib_get_native_type(h,options->print_keys[i].name,&(options->print_keys[i].type));
switch (options->print_keys[i].type) {
case GRIB_TYPE_STRING:
ret=grib_get_string( h,options->print_keys[i].name,value,&len);
printf("\"%s\"",value);
break;
case GRIB_TYPE_DOUBLE:
ret=grib_get_double( h,options->print_keys[i].name,&dvalue);
printf("%g",dvalue);
break;
case GRIB_TYPE_LONG:
ret=grib_get_long( h,options->print_keys[i].name,&lvalue);
printf("%ld",lvalue);
break;
default:
printf("invalid_type");
}
}
if (ret == GRIB_NOT_FOUND) printf("null");
s=", ";
}
printf("}");
2014-07-06 13:18:40 +00:00
}
/* A new handle is available from the current input file and can be processed here.
2016-04-04 15:24:28 +00:00
The handle available in this function is in the set of messages satisfying the constraint of the
2014-07-06 13:18:40 +00:00
-w option. They are not to be skipped.
2016-04-04 15:24:28 +00:00
*/
int grib_tool_new_handle_action(grib_runtime_options* options, grib_handle* h)
{
size_t size=4;
double v=0;
int err=0;
int i;
2014-07-06 13:18:40 +00:00
2016-04-04 15:24:28 +00:00
if (!options->skip) {
2014-07-06 13:18:40 +00:00
2016-04-04 15:24:28 +00:00
if (options->set_values_count != 0)
err=grib_set_values(h,options->set_values,options->set_values_count);
2014-07-06 13:18:40 +00:00
2016-04-04 15:24:28 +00:00
if( err != GRIB_SUCCESS && options->fail) exit(err);
}
2014-07-06 13:18:40 +00:00
2016-04-04 15:24:28 +00:00
if (options->latlon) {
int err=0;
double min;
if (!n) n=grib_nearest_new(h,&err);
GRIB_CHECK_NOLINE(err,0);
GRIB_CHECK_NOLINE(grib_nearest_find(n,h,lat,lon,0,
options->lats,options->lons,options->values,
options->distances,options->indexes,&size),0);
if (!options->latlon_mask) {
min=options->distances[0];
options->latlon_idx=0;
i=0;
for (i=1;i<4;i++) {
if (min>options->distances[i]) {
min=options->distances[i];
options->latlon_idx=i;
}
}
}
2014-07-06 13:18:40 +00:00
2016-04-04 15:24:28 +00:00
if (json) {
char* s="\n[\n";
double missingValue=9999;
char value[MAX_STRING_LEN];
size_t len=MAX_STRING_LEN;
printf("%s",new_handle);
printf( "{\n");
print_key_values(options,h);
printf("\n, \"selected\" : %d",options->latlon_idx);
printf(", \"method\" : ");
if (options->latlon_mask) printf("\"nearest_land\"");
else printf("\"nearest\"");
printf("\n, \"neighbours\" : ");
for (i=0;i<4;i++) {
printf("%s",s);
len=MAX_STRING_LEN;
printf("{\"index\" : %d, \"latitude\" : %g, \"longitude\" : %g, \"distance\" : %g, "
"\"distance_unit\" : \"km\", ",
(int)options->indexes[i],options->lats[i],options->lons[i],
options->distances[i]);
if (grib_get_double_element(h,"values",options->indexes[i],&v) == GRIB_SUCCESS) {
if (v==missingValue) printf("\"value\" : null ");
else printf("\"value\" : %g ",v);
}
if (grib_get_string( h,"units",value,&len)==GRIB_SUCCESS)
printf(", \"unit\" : \"%s\"",value);
if (options->latlon_mask)
printf(", \"mask_value\"=%.2f",options->mask_values[i]);
printf("}");
s="\n,";
}
printf("\n]");
printf("\n}");
}
2014-07-06 13:18:40 +00:00
2016-04-04 15:24:28 +00:00
}
new_handle="\n,";
return 0;
2014-07-06 13:18:40 +00:00
}
/* A new handle to skip is available. At this point something can be done
with the message to be skipped before deleting the handle. */
2016-04-04 15:24:28 +00:00
int grib_tool_skip_handle(grib_runtime_options* options, grib_handle* h)
{
grib_handle_delete(h);
return 0;
2014-07-06 13:18:40 +00:00
}
/* key values can be printed in this function. Headers are already printed if requested.*/
2016-04-04 15:24:28 +00:00
void grib_tool_print_key_values(grib_runtime_options* options,grib_handle* h)
{
grib_print_key_values(options,h);
2014-07-06 13:18:40 +00:00
}
/* this is executed after the last message in the last file is processed */
2016-04-04 15:24:28 +00:00
int grib_tool_finalise_action(grib_runtime_options* options)
{
int i=0;
if (options->latlon && options->verbose) {
printf("Input Point: latitude=%.2f longitude=%.2f\n",lat,lon);
printf("Grid Point chosen #%d index=%d latitude=%.2f longitude=%.2f distance=%.2f (Km)\n",
options->latlon_idx+1,(int)options->indexes[options->latlon_idx],
options->lats[options->latlon_idx],
options->lons[options->latlon_idx],
options->distances[options->latlon_idx]);
if (options->latlon_mask) {
printf("Mask values:\n");
for (i=0;i<4;i++) {
printf("- %d - index=%d latitude=%.2f longitude=%.2f distance=%.2f (Km) value=%.2f\n",
i+1,(int)options->indexes[i],options->lats[i],options->lons[i],
options->distances[i],options->mask_values[i]);
}
} else {
printf("Other grid Points\n");
for (i=0;i<4;i++) {
printf("- %d - index=%d latitude=%.2f longitude=%.2f distance=%.2f (Km)\n",
i+1,(int)options->indexes[i],options->lats[i],options->lons[i],
options->distances[i]);
}
}
}
2014-07-06 13:18:40 +00:00
if (n) grib_nearest_delete(n);
2016-04-04 15:24:28 +00:00
if (json) printf("\n]\n");
2016-04-04 15:24:28 +00:00
return 0;
}
int grib_no_handle_action(grib_runtime_options* options, int err)
2016-04-04 15:24:28 +00:00
{
fprintf(dump_file,"\t\t\"ERROR: unreadable message\"\n");
return 0;
}