-Efortran test with multi message passing ECC-292

This commit is contained in:
Enrico Fucile 2016-07-19 17:12:52 +01:00
parent 57ad56beeb
commit 3ad5f69e1a
7 changed files with 47 additions and 33 deletions

View File

@ -15,7 +15,7 @@ static void footer (grib_dumper*,grib_handle*);
typedef struct grib_dumper_NAME { typedef struct grib_dumper_NAME {
grib_dumper dumper; grib_dumper dumper;
MEMBERS MEMBERS
} grib_dumper_NAME; } grib_dumper_NAME;
extern grib_dumper_class* SUPER; extern grib_dumper_class* SUPER;

View File

@ -405,7 +405,6 @@ void codes_dump_content(grib_handle* h,FILE* out,const char* mode, unsigned long
{ {
grib_dump_content(h, out, mode, option_flags, arg); grib_dump_content(h, out, mode, option_flags, arg);
} }
/* GTS, GRIBEX */ /* GTS, GRIBEX */
/******************************************************************************/ /******************************************************************************/
void codes_gts_header_off(grib_context* c) void codes_gts_header_off(grib_context* c)

View File

@ -653,6 +653,7 @@ struct grib_dumper {
unsigned long option_flags; unsigned long option_flags;
void* arg; void* arg;
int depth; int depth;
long count;
grib_handle* handle; grib_handle* handle;
grib_dumper_class* cclass; grib_dumper_class* cclass;
}; };

View File

@ -916,6 +916,7 @@ void grib_dump_accessors_block(grib_dumper *dumper, grib_block_of_accessors *blo
void grib_dump_accessors_list(grib_dumper *dumper, grib_accessors_list *al); void grib_dump_accessors_list(grib_dumper *dumper, grib_accessors_list *al);
int grib_print(grib_handle *h, const char *name, grib_dumper *d); int grib_print(grib_handle *h, const char *name, grib_dumper *d);
void grib_dump_content(grib_handle *h, FILE *f, const char *mode, unsigned long option_flags, void *data); void grib_dump_content(grib_handle *h, FILE *f, const char *mode, unsigned long option_flags, void *data);
grib_dumper* grib_dump_content_with_dumper(grib_handle *h, grib_dumper* dumper,FILE *f, const char *mode, unsigned long option_flags, void *data);
void codes_dump_bufr_flat(grib_accessors_list *al, grib_handle *h, FILE *f, const char *mode, unsigned long option_flags, void *data); void codes_dump_bufr_flat(grib_accessors_list *al, grib_handle *h, FILE *f, const char *mode, unsigned long option_flags, void *data);
/* grib_context.c */ /* grib_context.c */

View File

@ -93,6 +93,22 @@ void grib_dump_content(grib_handle* h, FILE* f,const char* mode,unsigned long op
grib_dumper_delete(dumper); grib_dumper_delete(dumper);
} }
grib_dumper* grib_dump_content_with_dumper(grib_handle* h, grib_dumper* dumper, FILE* f,const char* mode,unsigned long option_flags,void *data)
{
long count=1;
if (dumper!=NULL) {
count=dumper->count;
count++;
}
dumper = grib_dumper_factory(mode?mode:"serialize",h,f,option_flags,data);
dumper->count=count;
grib_dump_header(dumper,h);
grib_dump_accessors_block(dumper,h->root->block);
grib_dump_footer(dumper,h);
return dumper;
}
void codes_dump_bufr_flat(grib_accessors_list* al,grib_handle* h, FILE* f,const char* mode,unsigned long option_flags,void *data) void codes_dump_bufr_flat(grib_accessors_list* al,grib_handle* h, FILE* f,const char* mode,unsigned long option_flags,void *data)
{ {
grib_dumper* dumper = NULL; grib_dumper* dumper = NULL;

View File

@ -22,7 +22,6 @@
IMPLEMENTS = init;destroy IMPLEMENTS = init;destroy
IMPLEMENTS = header;footer IMPLEMENTS = header;footer
MEMBERS = long section_offset MEMBERS = long section_offset
MEMBERS = long begin
MEMBERS = long empty MEMBERS = long empty
MEMBERS = long end MEMBERS = long end
MEMBERS = long isLeaf MEMBERS = long isLeaf
@ -62,7 +61,6 @@ typedef struct grib_dumper_fortran {
grib_dumper dumper; grib_dumper dumper;
/* Members defined in fortran */ /* Members defined in fortran */
long section_offset; long section_offset;
long begin;
long empty; long empty;
long end; long end;
long isLeaf; long isLeaf;
@ -153,6 +151,7 @@ static int init(grib_dumper* d)
grib_context* c=d->handle->context; grib_context* c=d->handle->context;
self->section_offset=0; self->section_offset=0;
self->empty=1; self->empty=1;
d->count=1;
self->isLeaf=0; self->isLeaf=0;
self->isAttribute=0; self->isAttribute=0;
self->keys=grib_context_malloc_clear(c,sizeof(grib_string_list)); self->keys=grib_context_malloc_clear(c,sizeof(grib_string_list));
@ -213,7 +212,6 @@ static void dump_values(grib_dumper* d,grib_accessor* a)
err=grib_unpack_double(a,&value,&size); err=grib_unpack_double(a,&value,&size);
} }
self->begin=0;
self->empty=0; self->empty=0;
if (size>1) { if (size>1) {
@ -292,7 +290,6 @@ static void dump_long(grib_dumper* d,grib_accessor* a,const char* comment)
err=grib_unpack_long(a,&value,&size); err=grib_unpack_long(a,&value,&size);
} }
self->begin=0;
self->empty=0; self->empty=0;
if (size>1) { if (size>1) {
@ -355,7 +352,6 @@ static void dump_double(grib_dumper* d,grib_accessor* a,const char* comment)
if ( (a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0 || (a->flags & GRIB_ACCESSOR_FLAG_READ_ONLY) != 0) if ( (a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0 || (a->flags & GRIB_ACCESSOR_FLAG_READ_ONLY) != 0)
return; return;
self->begin=0;
self->empty=0; self->empty=0;
r=get_key_rank(h,self->keys,a->name); r=get_key_rank(h,self->keys,a->name);
@ -402,7 +398,6 @@ static void dump_string_array(grib_dumper* d,grib_accessor* a,const char* commen
fprintf(self->dumper.out," svalues=(/"); fprintf(self->dumper.out," svalues=(/");
self->begin=0;
self->empty=0; self->empty=0;
@ -459,8 +454,6 @@ static void dump_string(grib_dumper* d,grib_accessor* a,const char* comment)
return; return;
} }
else self->begin=0;
self->empty=0; self->empty=0;
err = grib_unpack_string(a,value,&size); err = grib_unpack_string(a,value,&size);
@ -535,7 +528,6 @@ static void dump_section(grib_dumper* d,grib_accessor* a,grib_block_of_accessors
) { ) {
grib_handle* h=grib_handle_of_accessor(a); grib_handle* h=grib_handle_of_accessor(a);
depth=2; depth=2;
self->begin=1;
self->empty=1; self->empty=1;
depth+=2; depth+=2;
_dump_long_array(h,self->dumper.out,"dataPresentIndicator","inputDataPresentIndicator"); _dump_long_array(h,self->dumper.out,"dataPresentIndicator","inputDataPresentIndicator");
@ -547,7 +539,6 @@ static void dump_section(grib_dumper* d,grib_accessor* a,grib_block_of_accessors
} else if (!grib_inline_strcmp(a->name,"groupNumber")) { } else if (!grib_inline_strcmp(a->name,"groupNumber")) {
if ( (a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0) if ( (a->flags & GRIB_ACCESSOR_FLAG_DUMP) == 0)
return; return;
self->begin=1;
self->empty=1; self->empty=1;
depth+=2; depth+=2;
grib_dump_accessors_block(d,block); grib_dump_accessors_block(d,block);
@ -606,7 +597,7 @@ static void header(grib_dumper* d,grib_handle* h) {
if (localSectionPresent && bufrHeaderCentre==98 ) { if (localSectionPresent && bufrHeaderCentre==98 ) {
grib_get_long(h,"isSatellite",&isSatellite); grib_get_long(h,"isSatellite",&isSatellite);
if (isSatellite) if (isSatellite)
sprintf(sampleName,"BUFR%ld_local_satellite.bufr",edition); sprintf(sampleName,"BUFR%ld_local_satellite.bufr",edition);
else else
sprintf(sampleName,"BUFR%ld_local.bufr",edition); sprintf(sampleName,"BUFR%ld_local.bufr",edition);
@ -614,25 +605,24 @@ static void header(grib_dumper* d,grib_handle* h) {
sprintf(sampleName,"BUFR%ld.bufr",edition); sprintf(sampleName,"BUFR%ld.bufr",edition);
} }
fprintf(self->dumper.out,"! This program has been automatically generated with bufr_dump -Efortran\n"); if (d->count<2) {
fprintf(self->dumper.out,"program bufr_create_message\n"); fprintf(self->dumper.out,"! This program has been automatically generated with bufr_dump -Efortran\n");
fprintf(self->dumper.out," use eccodes\n"); fprintf(self->dumper.out,"program bufr_create_message\n");
fprintf(self->dumper.out," implicit none\n"); fprintf(self->dumper.out," use eccodes\n");
fprintf(self->dumper.out," integer :: iret\n"); fprintf(self->dumper.out," implicit none\n");
fprintf(self->dumper.out," integer :: outfile\n"); fprintf(self->dumper.out," integer :: iret\n");
fprintf(self->dumper.out," integer :: ibufr\n"); fprintf(self->dumper.out," integer :: outfile\n");
fprintf(self->dumper.out," integer :: count=0\n"); fprintf(self->dumper.out," integer :: ibufr\n");
fprintf(self->dumper.out," integer(kind=4), dimension(:), allocatable :: ivalues\n"); fprintf(self->dumper.out," integer :: count=0\n");
fprintf(self->dumper.out," integer :: strsize\n"); fprintf(self->dumper.out," integer(kind=4), dimension(:), allocatable :: ivalues\n");
fprintf(self->dumper.out," integer, parameter :: max_strsize = 100\n"); fprintf(self->dumper.out," integer :: strsize\n");
fprintf(self->dumper.out," character(len=max_strsize) , dimension(:),allocatable :: svalues\n"); fprintf(self->dumper.out," integer, parameter :: max_strsize = 100\n");
fprintf(self->dumper.out," real(kind=8), dimension(:), allocatable :: rvalues\n"); fprintf(self->dumper.out," character(len=max_strsize) , dimension(:),allocatable :: svalues\n");
/* fprintf(self->dumper.out,"\n\n call codes_open_file(infile,'infile.bufr','r')\n"); */ fprintf(self->dumper.out," real(kind=8), dimension(:), allocatable :: rvalues\n");
/* fprintf(self->dumper.out," call codes_bufr_new_from_file(infile,ibufr,iret)\n"); */ }
fprintf(self->dumper.out," call codes_bufr_new_from_samples(ibufr,'%s',iret)\n",sampleName); fprintf(self->dumper.out," call codes_bufr_new_from_samples(ibufr,'%s',iret)\n",sampleName);
fprintf(self->dumper.out," if (iret/=CODES_SUCCESS) then\n"); fprintf(self->dumper.out," if (iret/=CODES_SUCCESS) then\n");
fprintf(self->dumper.out," print *,'ERROR reading BUFR from input file'\n"); fprintf(self->dumper.out," print *,'ERROR creating BUFR from %s'\n",sampleName);
fprintf(self->dumper.out," stop 1\n"); fprintf(self->dumper.out," stop 1\n");
fprintf(self->dumper.out," endif\n"); fprintf(self->dumper.out," endif\n");
} }
@ -640,12 +630,15 @@ static void header(grib_dumper* d,grib_handle* h) {
static void footer(grib_dumper* d,grib_handle* h) { static void footer(grib_dumper* d,grib_handle* h) {
grib_dumper_fortran *self = (grib_dumper_fortran*)d; grib_dumper_fortran *self = (grib_dumper_fortran*)d;
fprintf(self->dumper.out," call codes_set(ibufr,'pack',1)\n"); fprintf(self->dumper.out," call codes_set(ibufr,'pack',1)\n");
fprintf(self->dumper.out," call codes_open_file(outfile,'outfile.bufr','w')\n"); if (d->count==1)
fprintf(self->dumper.out," call codes_open_file(outfile,'outfile.bufr','w')\n");
else
fprintf(self->dumper.out," call codes_open_file(outfile,'outfile.bufr','a')\n");
fprintf(self->dumper.out," call codes_write(ibufr,outfile)\n"); fprintf(self->dumper.out," call codes_write(ibufr,outfile)\n");
fprintf(self->dumper.out," call codes_close_file(outfile)\n"); fprintf(self->dumper.out," call codes_close_file(outfile)\n");
fprintf(self->dumper.out," call codes_release(ibufr)\n"); fprintf(self->dumper.out," call codes_release(ibufr)\n");
fprintf(self->dumper.out," if(allocated(ivalues)) deallocate(ivalues)\n"); fprintf(self->dumper.out," if(allocated(ivalues)) deallocate(ivalues)\n");
fprintf(self->dumper.out," if(allocated(rvalues)) deallocate(rvalues)\n"); fprintf(self->dumper.out," if(allocated(rvalues)) deallocate(rvalues)\n");
fprintf(self->dumper.out," if(allocated(svalues)) deallocate(svalues)\n"); fprintf(self->dumper.out," if(allocated(svalues)) deallocate(svalues)\n");
fprintf(self->dumper.out,"end program bufr_create_message\n");
} }

View File

@ -53,6 +53,7 @@ char* grib_tool_usage="[options] file file ...";
static int json=0; static int json=0;
static char* json_option=0; static char* json_option=0;
static int first_handle=1; static int first_handle=1;
static grib_dumper* dumper=0;
int grib_options_count=sizeof(grib_options)/sizeof(grib_option); int grib_options_count=sizeof(grib_options)/sizeof(grib_option);
@ -233,7 +234,7 @@ int grib_tool_new_handle_action(grib_runtime_options* options, grib_handle* h)
options->error=err; options->error=err;
return err; return err;
} }
grib_dump_content(h,stdout,options->dump_mode,options->dump_flags,0); dumper=grib_dump_content_with_dumper(h,dumper,stdout,options->dump_mode,options->dump_flags,0);
} }
return 0; return 0;
@ -256,6 +257,9 @@ int grib_tool_finalise_action(grib_runtime_options* options)
if (!strcmp(options->dump_mode,"filter")) { if (!strcmp(options->dump_mode,"filter")) {
fprintf(stdout,"set pack=1;\nwrite;\n"); fprintf(stdout,"set pack=1;\nwrite;\n");
} }
if (!strcmp(options->dump_mode,"fortran")) {
fprintf(stdout,"end program bufr_create_message\n");
}
return 0; return 0;
} }