mirror of https://github.com/ecmwf/eccodes.git
Refactoring
This commit is contained in:
parent
d8d4e26654
commit
422ef77000
|
@ -1190,7 +1190,7 @@ long grib_get_decimal_scale_fact(double max, double min, long bpval, long binary
|
||||||
/*grib_handle *grib_internal_sample(grib_context *c, const char *name);*/
|
/*grib_handle *grib_internal_sample(grib_context *c, const char *name);*/
|
||||||
grib_handle* grib_external_template(grib_context* c, const char* name);
|
grib_handle* grib_external_template(grib_context* c, const char* name);
|
||||||
grib_handle* bufr_external_template(grib_context* c, const char* name);
|
grib_handle* bufr_external_template(grib_context* c, const char* name);
|
||||||
char* grib_external_template_path(grib_context* c, const char* name);
|
char* get_external_template_path(grib_context* c, const char* name);
|
||||||
|
|
||||||
/* grib_dependency.c */
|
/* grib_dependency.c */
|
||||||
grib_handle* grib_handle_of_accessor(const grib_accessor* a);
|
grib_handle* grib_handle_of_accessor(const grib_accessor* a);
|
||||||
|
|
|
@ -49,7 +49,7 @@ grib_handle* grib_internal_sample(grib_context* c,const char* name)
|
||||||
#define ECC_PATH_DELIMITER_CHAR ':'
|
#define ECC_PATH_DELIMITER_CHAR ':'
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static grib_handle* try_template(grib_context* c, const char* dir, const char* name)
|
static grib_handle* try_product_template(grib_context* c, ProductKind product_kind, const char* dir, const char* name)
|
||||||
{
|
{
|
||||||
char path[1024];
|
char path[1024];
|
||||||
grib_handle* g = NULL;
|
grib_handle* g = NULL;
|
||||||
|
@ -61,7 +61,7 @@ static grib_handle* try_template(grib_context* c, const char* dir, const char* n
|
||||||
sprintf(path, "%s/%s.tmpl", dir, name);
|
sprintf(path, "%s/%s.tmpl", dir, name);
|
||||||
|
|
||||||
if (c->debug) {
|
if (c->debug) {
|
||||||
fprintf(stderr, "ECCODES DEBUG try_template path='%s'\n", path);
|
fprintf(stderr, "ECCODES DEBUG try_product_template path='%s'\n", path);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (codes_access(path, F_OK) == 0) {
|
if (codes_access(path, F_OK) == 0) {
|
||||||
|
@ -70,40 +70,14 @@ static grib_handle* try_template(grib_context* c, const char* dir, const char* n
|
||||||
grib_context_log(c, GRIB_LOG_PERROR, "cannot open %s", path);
|
grib_context_log(c, GRIB_LOG_PERROR, "cannot open %s", path);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
g = grib_handle_new_from_file(c, f, &err);
|
if (product_kind == PRODUCT_BUFR) {
|
||||||
if (!g) {
|
g = codes_bufr_handle_new_from_file(c, f, &err);
|
||||||
grib_context_log(c, GRIB_LOG_ERROR, "cannot create GRIB handle from %s", path);
|
} else {
|
||||||
|
/* Note: Pseudo GRIBs like DIAG and BUDG also come here */
|
||||||
|
g = grib_handle_new_from_file(c, f, &err);
|
||||||
}
|
}
|
||||||
fclose(f);
|
|
||||||
}
|
|
||||||
|
|
||||||
return g;
|
|
||||||
}
|
|
||||||
|
|
||||||
static grib_handle* try_bufr_template(grib_context* c, const char* dir, const char* name)
|
|
||||||
{
|
|
||||||
char path[1024];
|
|
||||||
grib_handle* g = NULL;
|
|
||||||
int err = 0;
|
|
||||||
|
|
||||||
if (string_ends_with(name, ".tmpl"))
|
|
||||||
sprintf(path, "%s/%s", dir, name);
|
|
||||||
else
|
|
||||||
sprintf(path, "%s/%s.tmpl", dir, name);
|
|
||||||
|
|
||||||
if (c->debug) {
|
|
||||||
fprintf(stderr, "ECCODES DEBUG try_template path='%s'\n", path);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (codes_access(path, F_OK) == 0) {
|
|
||||||
FILE* f = codes_fopen(path, "r");
|
|
||||||
if (!f) {
|
|
||||||
grib_context_log(c, GRIB_LOG_PERROR, "cannot open %s", path);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
g = codes_bufr_handle_new_from_file(c, f, &err);
|
|
||||||
if (!g) {
|
if (!g) {
|
||||||
grib_context_log(c, GRIB_LOG_ERROR, "cannot create BUFR handle from %s", path);
|
grib_context_log(c, GRIB_LOG_ERROR, "cannot create handle from %s", path);
|
||||||
}
|
}
|
||||||
fclose(f);
|
fclose(f);
|
||||||
}
|
}
|
||||||
|
@ -139,7 +113,7 @@ grib_handle* grib_external_template(grib_context* c, const char* name)
|
||||||
while (*base) {
|
while (*base) {
|
||||||
if (*base == ECC_PATH_DELIMITER_CHAR) {
|
if (*base == ECC_PATH_DELIMITER_CHAR) {
|
||||||
*p = 0;
|
*p = 0;
|
||||||
g = try_template(c, buffer, name);
|
g = try_product_template(c, PRODUCT_GRIB, buffer, name);
|
||||||
if (g)
|
if (g)
|
||||||
return g;
|
return g;
|
||||||
p = buffer;
|
p = buffer;
|
||||||
|
@ -149,7 +123,7 @@ grib_handle* grib_external_template(grib_context* c, const char* name)
|
||||||
}
|
}
|
||||||
|
|
||||||
*p = 0;
|
*p = 0;
|
||||||
return g = try_template(c, buffer, name);
|
return g = try_product_template(c, PRODUCT_GRIB, buffer, name);
|
||||||
}
|
}
|
||||||
|
|
||||||
grib_handle* bufr_external_template(grib_context* c, const char* name)
|
grib_handle* bufr_external_template(grib_context* c, const char* name)
|
||||||
|
@ -165,7 +139,7 @@ grib_handle* bufr_external_template(grib_context* c, const char* name)
|
||||||
while (*base) {
|
while (*base) {
|
||||||
if (*base == ECC_PATH_DELIMITER_CHAR) {
|
if (*base == ECC_PATH_DELIMITER_CHAR) {
|
||||||
*p = 0;
|
*p = 0;
|
||||||
g = try_bufr_template(c, buffer, name);
|
g = try_product_template(c, PRODUCT_BUFR, buffer, name);
|
||||||
if (g)
|
if (g)
|
||||||
return g;
|
return g;
|
||||||
p = buffer;
|
p = buffer;
|
||||||
|
@ -175,11 +149,11 @@ grib_handle* bufr_external_template(grib_context* c, const char* name)
|
||||||
}
|
}
|
||||||
|
|
||||||
*p = 0;
|
*p = 0;
|
||||||
g = try_bufr_template(c, buffer, name);
|
g = try_product_template(c, PRODUCT_BUFR, buffer, name);
|
||||||
return g;
|
return g;
|
||||||
}
|
}
|
||||||
|
|
||||||
char* grib_external_template_path(grib_context* c, const char* name)
|
char* get_external_template_path(grib_context* c, const char* name)
|
||||||
{
|
{
|
||||||
const char* base = c->grib_samples_path;
|
const char* base = c->grib_samples_path;
|
||||||
char buffer[1024];
|
char buffer[1024];
|
||||||
|
|
|
@ -58,7 +58,7 @@ int main(int argc, char* argv[])
|
||||||
}
|
}
|
||||||
|
|
||||||
if (resource_type == SAMPLE) {
|
if (resource_type == SAMPLE) {
|
||||||
full_path = grib_external_template_path(c, resource_path);
|
full_path = get_external_template_path(c, resource_path);
|
||||||
}
|
}
|
||||||
else if (resource_type == DEFINITION) {
|
else if (resource_type == DEFINITION) {
|
||||||
full_path = grib_context_full_defs_path(c, resource_path);
|
full_path = grib_context_full_defs_path(c, resource_path);
|
||||||
|
|
Loading…
Reference in New Issue