GRIB-735: Performance: decoding large grib1 files from some centres

This commit is contained in:
Shahram Najm 2015-03-20 11:17:19 +00:00
parent 4297cd350d
commit d02a4674fb
1 changed files with 44 additions and 7 deletions

View File

@ -216,6 +216,26 @@ static void init(grib_accessor* a, const long len, grib_arguments* params) {
} }
static int str_eq(const char* a, const char* b)
{
if ( a && b && (strcmp(a,b)==0) )
return 1;
return 0;
}
static void dump_codetable(grib_codetable* atable)
{
grib_codetable* next = NULL;
int count = 0;
next=atable;
while(next) {
printf("[%.2d] CodeTable Dump: f0=%s f1=%s\n", count, next->filename[0], next->filename[1]);
count++;
next = next->next;
}
}
static grib_codetable* load_table(grib_accessor_codetable* self) static grib_codetable* load_table(grib_accessor_codetable* self)
{ {
size_t size = 0; size_t size = 0;
@ -256,13 +276,25 @@ static grib_codetable* load_table(grib_accessor_codetable* self)
localFilename=grib_context_full_defs_path(c,localRecomposed); localFilename=grib_context_full_defs_path(c,localRecomposed);
} }
/*printf("%s: Looking in cache: f=%s lf=%s\n", self->att.name, filename, localFilename);*/
next=c->codetable; next=c->codetable;
while(next) { while(next) {
if ((filename && next->filename[0] && strcmp(filename,next->filename[0]) == 0) && if ((filename && next->filename[0] && strcmp(filename,next->filename[0]) == 0) &&
((localFilename==0 && next->filename[1]==NULL) || ((localFilename==0 && next->filename[1]==NULL) ||
((localFilename!=0 && next->filename[1]!=NULL) ((localFilename!=0 && next->filename[1]!=NULL)
&& strcmp(localFilename,next->filename[1]) ==0)) ) && strcmp(localFilename,next->filename[1]) ==0)) )
{
return next; return next;
}
/* Special case: see GRIB-735 */
if (filename==NULL && localFilename!=NULL)
{
if ( str_eq(localFilename, next->filename[0]) ||
str_eq(localFilename, next->filename[1]) )
{
return next;
}
}
next = next->next; next = next->next;
} }
@ -277,9 +309,13 @@ static grib_codetable* load_table(grib_accessor_codetable* self)
t = (grib_codetable*)grib_context_malloc_clear_persistent(c,sizeof(grib_codetable) + t = (grib_codetable*)grib_context_malloc_clear_persistent(c,sizeof(grib_codetable) +
(size-1)*sizeof(code_table_entry)); (size-1)*sizeof(code_table_entry));
if (filename!=0) grib_load_codetable(c,filename,recomposed,size,t); if (filename!=0)
grib_load_codetable(c,filename,recomposed,size,t);
if (localFilename!=0) grib_load_codetable(c,localFilename,localRecomposed,size,t); if (localFilename!=0)
grib_load_codetable(c,localFilename,localRecomposed,size,t);
/*dump_codetable(c->codetable);*/
if (t->filename[0]==NULL && t->filename[1]==NULL) { if (t->filename[0]==NULL && t->filename[1]==NULL) {
grib_context_free_persistent(c,t); grib_context_free_persistent(c,t);
@ -291,11 +327,11 @@ static grib_codetable* load_table(grib_accessor_codetable* self)
} }
static int grib_load_codetable(grib_context* c,const char* filename, static int grib_load_codetable(grib_context* c,const char* filename,
const char* recomposed_name,size_t size,grib_codetable* t) { const char* recomposed_name,size_t size,grib_codetable* t)
{
char line[1024]; char line[1024];
FILE *f = NULL; FILE *f = NULL;
int lineNumber = 0; int lineNumber = 0;
grib_context_log(c,GRIB_LOG_DEBUG,"Loading code table from %s",filename); grib_context_log(c,GRIB_LOG_DEBUG,"Loading code table from %s",filename);
f=fopen(filename, "r"); f=fopen(filename, "r");
@ -558,11 +594,12 @@ static int pack_string(grib_accessor* a, const char* buffer, size_t *len)
typedef int (*cmpproc)(const char*, const char*); typedef int (*cmpproc)(const char*, const char*);
#ifndef ECCODES_ON_WINDOWS #ifndef ECCODES_ON_WINDOWS
cmpproc cmp = a->flags | GRIB_ACCESSOR_FLAG_LOWERCASE ? grib_strcasecmp : strcmp; cmpproc cmp = (a->flags | GRIB_ACCESSOR_FLAG_LOWERCASE) ? grib_strcasecmp : strcmp;
#else #else
/* Microsoft Windows Visual Studio support */ /* Microsoft Windows Visual Studio support */
cmpproc cmp = a->flags | GRIB_ACCESSOR_FLAG_LOWERCASE ? stricmp : strcmp; cmpproc cmp = (a->flags | GRIB_ACCESSOR_FLAG_LOWERCASE) ? stricmp : strcmp;
#endif #endif
if(!self->table) self->table = load_table(self); if(!self->table) self->table = load_table(self);
table=self->table; table=self->table;