Merge branch 'eccodes' of ssh://software.ecmwf.int:7999/grib/grib_api into eccodes

This commit is contained in:
Sandor Kertesz 2015-02-03 09:06:19 +00:00
commit 55fa24ad04
5 changed files with 41 additions and 20 deletions

View File

@ -442,8 +442,13 @@ void grib_parser_include(const char* fname)
parse_file = path;
}
if (strcmp(parse_file,"-")==0) {
grib_context_log(grib_parser_context,GRIB_LOG_DEBUG,"parsing standard input");
f = stdin; /* read from std input */
} else {
grib_context_log(grib_parser_context,GRIB_LOG_DEBUG,"parsing include file %s",parse_file);
f = fopen(parse_file,"r");
}
/* for(i = 0; i < top ; i++) printf(" "); */
/* printf("PARSING %s\n",parse_file); */

View File

@ -116,6 +116,10 @@ set values = {
EOF
${tools_dir}/grib_filter temp.filt $ECCODES_SAMPLES_PATH/GRIB1.tmpl
# Test reading from stdin
echo 'set centre="kwbc";write;' | ${tools_dir}/grib_filter -o temp_filt.grib2 - $ECCODES_SAMPLES_PATH/GRIB2.tmpl
result=`${tools_dir}/grib_get -p centre temp_filt.grib2`
[ "$result" = "kwbc" ]
rm -f temp_filt.grib2 temp.filt
rm -f ${data_dir}/formatint.rules ${data_dir}/binop.rules

View File

@ -27,9 +27,9 @@ rm -f ${outfile}
count=`${tools_dir}/grib_count ${data_dir}/pad.grib`
if [ $count != 6 ]
then
if [ $count != 6 ]; then
echo grib_io problem
exit 1
fi
${tools_dir}/grib_count -v ${data_dir}/pad.grib >/dev/null

View File

@ -45,11 +45,9 @@ endforeach()
# Count tools. Same source code, different executable names
ecbuild_add_executable( TARGET grib_count
SOURCES codes_count.c
CONDITION ECCODES_INSTALL_ECMWF_TOOLS
LIBS grib_tools )
ecbuild_add_executable( TARGET bufr_count
SOURCES codes_count.c
CONDITION ECCODES_INSTALL_ECMWF_TOOLS
LIBS grib_tools )
# grib_list_keys

View File

@ -10,18 +10,18 @@
#include "grib_api_internal.h"
void usage(char* prog)
void usage(const char* prog)
{
printf("usage: %s infile1 infile2 ... \n",prog);
printf("usage: %s [-v] infile1 infile2 ... \n",prog);
exit(1);
}
static int check_file(FILE* in, int message_type, long *count)
static int count_messages(FILE* in, int message_type, unsigned long *count)
{
void* mesg=NULL;
size_t size=0;
off_t offset=0;
int err=0;
int err=GRIB_SUCCESS;
typedef void* (*wmo_read_proc)(FILE *, int, size_t *, off_t *, int *);
wmo_read_proc wmo_read = NULL;
grib_context* c=grib_context_get_default();
@ -44,11 +44,11 @@ static int check_file(FILE* in, int message_type, long *count)
int main(int argc,char* argv[])
{
FILE* infh;
FILE* infh = NULL;
char* filename;
int i;
int i, verbose=0;
int err=0;
long n=0,nn=0;
unsigned long count_total=0, count_curr=0;
int message_type = 0; /* GRIB, BUFR etc */
if (argc <2) usage(argv[0]);
@ -56,27 +56,41 @@ int main(int argc,char* argv[])
if (strstr(argv[0], "grib_count")) message_type = CODES_GRIB;
if (strstr(argv[0], "bufr_count")) message_type = CODES_BUFR;
n=0;
count_total=0;
for (i=1;i<argc;i++) {
if (strcmp(argv[i], "-v")==0) {
verbose = 1;
if (argc <3) usage(argv[0]);
continue;
}
filename=argv[i];
infh=fopen(filename,"r");
if (!infh) {
perror(filename);
exit(1);
}
nn=0;
err=check_file(infh, message_type, &nn);
if (err!=0) {
count_curr=0;
err=count_messages(infh, message_type, &count_curr);
if (err) {
fprintf(stderr,"Invalid message(s) found in %s\n", filename);
exit(err);
#ifdef DONT_EXIT_ON_BAD_APPLE
/* If we did not want to fail but warn and continue */
fclose(infh);
continue;
#endif
}
n+=nn;
if (verbose) printf ("%7lu %s\n", count_curr, filename);
count_total += count_curr;
fclose(infh);
}
printf("%ld\n",n);
if (verbose) {
printf("%7lu %s\n", count_total, "total");
} else {
printf("%lu\n", count_total);
}
return 0;
}