mirror of https://github.com/ecmwf/eccodes.git
Dead code removal
This commit is contained in:
parent
713e64eb4a
commit
5031df4af9
|
@ -0,0 +1,273 @@
|
|||
/*
|
||||
* (C) Copyright 2005- ECMWF.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
/******************************
|
||||
* Enrico Fucile
|
||||
*****************************/
|
||||
|
||||
#include "grib_api_internal.h"
|
||||
|
||||
/*
|
||||
This is used by make_class.pl
|
||||
|
||||
START_CLASS_DEF
|
||||
CLASS = accessor
|
||||
SUPER = grib_accessor_class_gen
|
||||
IMPLEMENTS = init
|
||||
IMPLEMENTS = unpack_double
|
||||
IMPLEMENTS = pack_double
|
||||
IMPLEMENTS = value_count
|
||||
MEMBERS=const char* missing_value
|
||||
MEMBERS=const char* number_of_values
|
||||
MEMBERS=const char* number_of_points
|
||||
MEMBERS=const char* latitude_of_first_point
|
||||
MEMBERS=const char* ni
|
||||
|
||||
END_CLASS_DEF
|
||||
*/
|
||||
|
||||
/* START_CLASS_IMP */
|
||||
|
||||
/*
|
||||
|
||||
Don't edit anything between START_CLASS_IMP and END_CLASS_IMP
|
||||
Instead edit values between START_CLASS_DEF and END_CLASS_DEF
|
||||
or edit "accessor.class" and rerun ./make_class.pl
|
||||
|
||||
*/
|
||||
|
||||
static int pack_double(grib_accessor*, const double* val, size_t* len);
|
||||
static int unpack_double(grib_accessor*, double* val, size_t* len);
|
||||
static int value_count(grib_accessor*, long*);
|
||||
static void init(grib_accessor*, const long, grib_arguments*);
|
||||
//static void init_class(grib_accessor_class*);
|
||||
|
||||
typedef struct grib_accessor_gds_not_present_bitmap
|
||||
{
|
||||
grib_accessor att;
|
||||
/* Members defined in gen */
|
||||
/* Members defined in gds_not_present_bitmap */
|
||||
const char* missing_value;
|
||||
const char* number_of_values;
|
||||
const char* number_of_points;
|
||||
const char* latitude_of_first_point;
|
||||
const char* ni;
|
||||
} grib_accessor_gds_not_present_bitmap;
|
||||
|
||||
extern grib_accessor_class* grib_accessor_class_gen;
|
||||
|
||||
static grib_accessor_class _grib_accessor_class_gds_not_present_bitmap = {
|
||||
&grib_accessor_class_gen, /* super */
|
||||
"gds_not_present_bitmap", /* name */
|
||||
sizeof(grib_accessor_gds_not_present_bitmap), /* size */
|
||||
0, /* inited */
|
||||
0, /* init_class */
|
||||
&init, /* init */
|
||||
0, /* post_init */
|
||||
0, /* destroy */
|
||||
0, /* dump */
|
||||
0, /* next_offset */
|
||||
0, /* get length of string */
|
||||
&value_count, /* get number of values */
|
||||
0, /* get number of bytes */
|
||||
0, /* get offset to bytes */
|
||||
0, /* get native type */
|
||||
0, /* get sub_section */
|
||||
0, /* pack_missing */
|
||||
0, /* is_missing */
|
||||
0, /* pack_long */
|
||||
0, /* unpack_long */
|
||||
&pack_double, /* pack_double */
|
||||
0, /* pack_float */
|
||||
&unpack_double, /* unpack_double */
|
||||
0, /* unpack_float */
|
||||
0, /* pack_string */
|
||||
0, /* unpack_string */
|
||||
0, /* pack_string_array */
|
||||
0, /* unpack_string_array */
|
||||
0, /* pack_bytes */
|
||||
0, /* unpack_bytes */
|
||||
0, /* pack_expression */
|
||||
0, /* notify_change */
|
||||
0, /* update_size */
|
||||
0, /* preferred_size */
|
||||
0, /* resize */
|
||||
0, /* nearest_smaller_value */
|
||||
0, /* next accessor */
|
||||
0, /* compare vs. another accessor */
|
||||
0, /* unpack only ith value (double) */
|
||||
0, /* unpack only ith value (float) */
|
||||
0, /* unpack a given set of elements (double) */
|
||||
0, /* unpack a given set of elements (float) */
|
||||
0, /* unpack a subarray */
|
||||
0, /* clear */
|
||||
0, /* clone accessor */
|
||||
};
|
||||
|
||||
|
||||
grib_accessor_class* grib_accessor_class_gds_not_present_bitmap = &_grib_accessor_class_gds_not_present_bitmap;
|
||||
|
||||
|
||||
//static void init_class(grib_accessor_class* c)
|
||||
//{
|
||||
// INIT
|
||||
//}
|
||||
|
||||
/* END_CLASS_IMP */
|
||||
|
||||
static void init(grib_accessor* a, const long v, grib_arguments* args)
|
||||
{
|
||||
int n = 0;
|
||||
grib_accessor_gds_not_present_bitmap* self = (grib_accessor_gds_not_present_bitmap*)a;
|
||||
|
||||
self->missing_value = grib_arguments_get_name(grib_handle_of_accessor(a), args, n++);
|
||||
self->number_of_values = grib_arguments_get_name(grib_handle_of_accessor(a), args, n++);
|
||||
self->number_of_points = grib_arguments_get_name(grib_handle_of_accessor(a), args, n++);
|
||||
self->latitude_of_first_point = grib_arguments_get_name(grib_handle_of_accessor(a), args, n++);
|
||||
self->ni = grib_arguments_get_name(grib_handle_of_accessor(a), args, n++);
|
||||
a->length = 0;
|
||||
}
|
||||
|
||||
static int value_count(grib_accessor* a, long* number_of_points)
|
||||
{
|
||||
grib_accessor_gds_not_present_bitmap* self = (grib_accessor_gds_not_present_bitmap*)a;
|
||||
*number_of_points = 0;
|
||||
return grib_get_long_internal(grib_handle_of_accessor(a), self->number_of_points, number_of_points);
|
||||
}
|
||||
|
||||
static int unpack_double(grib_accessor* a, double* val, size_t* len)
|
||||
{
|
||||
grib_accessor_gds_not_present_bitmap* self = (grib_accessor_gds_not_present_bitmap*)a;
|
||||
|
||||
long number_of_points = 0, number_of_values = 0, ni = 0;
|
||||
long latitude_of_first_point = 0;
|
||||
size_t i = 0;
|
||||
size_t n_vals = 0;
|
||||
long nn = 0;
|
||||
long missing_value;
|
||||
|
||||
int err = 0;
|
||||
double* coded_vals = NULL;
|
||||
err = grib_value_count(a, &nn);
|
||||
n_vals = nn;
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
if ((err = grib_get_long(grib_handle_of_accessor(a), self->number_of_points, &number_of_points)) != GRIB_SUCCESS)
|
||||
return err;
|
||||
|
||||
if ((err = grib_get_long(grib_handle_of_accessor(a), self->number_of_values, &number_of_values)) != GRIB_SUCCESS)
|
||||
return err;
|
||||
|
||||
if ((err = grib_get_long(grib_handle_of_accessor(a), self->latitude_of_first_point, &latitude_of_first_point)) != GRIB_SUCCESS)
|
||||
return err;
|
||||
|
||||
if ((err = grib_get_long(grib_handle_of_accessor(a), self->missing_value, &missing_value)) != GRIB_SUCCESS)
|
||||
return err;
|
||||
|
||||
if ((err = grib_get_long(grib_handle_of_accessor(a), self->ni, &ni)) != GRIB_SUCCESS)
|
||||
return err;
|
||||
|
||||
if (*len < number_of_points) {
|
||||
*len = n_vals;
|
||||
return GRIB_ARRAY_TOO_SMALL;
|
||||
}
|
||||
|
||||
if (number_of_values > 0) {
|
||||
coded_vals = (double*)grib_context_malloc(a->context, number_of_values * sizeof(double));
|
||||
|
||||
if (coded_vals == NULL)
|
||||
return GRIB_OUT_OF_MEMORY;
|
||||
}
|
||||
|
||||
if (latitude_of_first_point == 0) {
|
||||
for (i = 0; i < number_of_values; i++)
|
||||
val[i] = 1;
|
||||
for (i = number_of_values; i < number_of_points; i++)
|
||||
val[i] = 0;
|
||||
}
|
||||
else {
|
||||
for (i = 0; i < ni - 1; i++)
|
||||
val[i] = 0;
|
||||
for (i = ni - 1; i < number_of_points; i++)
|
||||
val[i] = 1;
|
||||
}
|
||||
|
||||
*len = number_of_points;
|
||||
|
||||
grib_context_free(a->context, coded_vals);
|
||||
return err;
|
||||
}
|
||||
|
||||
#if 0
|
||||
|
||||
static void grib_set_bit_on( unsigned char* p, long *bitp){
|
||||
unsigned char o = 1;
|
||||
p += (*bitp >> 3);
|
||||
o <<= 7-((*bitp)%8);
|
||||
*p |= o;
|
||||
(*bitp)+=1;
|
||||
}
|
||||
static int pack_double(grib_accessor* a, const double* val,size_t *len)
|
||||
{
|
||||
grib_accessor_gds_not_present_bitmap* self = (grib_accessor_gds_not_present_bitmap*)a;
|
||||
|
||||
size_t tlen;
|
||||
|
||||
unsigned char* buf = NULL;
|
||||
long i;
|
||||
int err = 0;
|
||||
long pos = 0;
|
||||
long bmaplen = 0;
|
||||
const int bit_padding = 16;
|
||||
double miss_values = 0;
|
||||
tlen = ((*len+bit_padding-1)/bit_padding*bit_padding)/8;
|
||||
|
||||
if((err = grib_get_double_internal(grib_handle_of_accessor(a), self->missing_value, &miss_values)) != GRIB_SUCCESS)
|
||||
{
|
||||
grib_context_log(a->context, GRIB_LOG_ERROR, "grib_accessor_class_bitmap : pack_double : Cannot unpack %s err=%d ",self->missing_value,err);
|
||||
return err;
|
||||
}
|
||||
|
||||
buf = grib_context_malloc_clear(a->context,tlen);
|
||||
if(!buf) return GRIB_OUT_OF_MEMORY;
|
||||
pos=0;
|
||||
for(i=0;i<*len;i++)
|
||||
{
|
||||
if (val[i] == miss_values)
|
||||
pos++;
|
||||
else{
|
||||
bmaplen++;
|
||||
grib_set_bit_on(buf, &pos);
|
||||
}
|
||||
}
|
||||
|
||||
if((err = grib_set_long_internal(grib_handle_of_accessor(a), self->unusedBits,tlen*8 - *len )) != GRIB_SUCCESS) {
|
||||
grib_context_log(a->context, GRIB_LOG_ERROR, "grib_accessor_class_bitmap : pack_double : Cannot pack %s err=%d ",self->unusedBits,err);
|
||||
grib_context_free(a->context,buf);
|
||||
return err;
|
||||
}
|
||||
|
||||
|
||||
grib_buffer_replace(a, buf, tlen,1,1);
|
||||
|
||||
grib_context_free(a->context,buf);
|
||||
|
||||
return GRIB_SUCCESS;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
static int pack_double(grib_accessor* a, const double* val, size_t* len)
|
||||
{
|
||||
return GRIB_NOT_IMPLEMENTED;
|
||||
}
|
||||
|
||||
#endif
|
|
@ -160,11 +160,9 @@ static int grib_get_codeflag(grib_accessor* a, long code, char* codename)
|
|||
return GRIB_FILE_NOT_FOUND;
|
||||
}
|
||||
|
||||
#if 0
|
||||
strcpy(codename, self->tablename);
|
||||
strcat(codename,": ");
|
||||
j = strlen(codename);
|
||||
#endif
|
||||
// strcpy(codename, self->tablename);
|
||||
// strcat(codename,": ");
|
||||
// j = strlen(codename);
|
||||
|
||||
while (fgets(line, sizeof(line) - 1, f)) {
|
||||
sscanf(line, "%49s %49s", num, bval);
|
||||
|
|
|
@ -390,7 +390,7 @@ static void uint_char(unsigned int i, unsigned char* p)
|
|||
p[1] = (i >> 16) & 255;
|
||||
p[2] = (i >> 8) & 255;
|
||||
p[3] = (i)&255;
|
||||
}
|
||||
}
|
||||
|
||||
static unsigned char* mk_bms(grib_accessor* a, double* data, unsigned int* ndata)
|
||||
{
|
||||
|
|
|
@ -121,10 +121,11 @@ static void init(grib_accessor* a, const long l, grib_arguments* c)
|
|||
{
|
||||
int n = 0;
|
||||
grib_accessor_gds_is_present* self = (grib_accessor_gds_is_present*)a;
|
||||
self->gds_present = grib_arguments_get_name(grib_handle_of_accessor(a), c, n++);
|
||||
self->grid_definition = grib_arguments_get_name(grib_handle_of_accessor(a), c, n++);
|
||||
self->bitmap_present = grib_arguments_get_name(grib_handle_of_accessor(a), c, n++);
|
||||
self->values = grib_arguments_get_name(grib_handle_of_accessor(a), c, n++);
|
||||
grib_handle* h = grib_handle_of_accessor(a);
|
||||
self->gds_present = grib_arguments_get_name(h, c, n++);
|
||||
self->grid_definition = grib_arguments_get_name(h, c, n++);
|
||||
self->bitmap_present = grib_arguments_get_name(h, c, n++);
|
||||
self->values = grib_arguments_get_name(h, c, n++);
|
||||
|
||||
a->flags |= GRIB_ACCESSOR_FLAG_FUNCTION;
|
||||
a->flags |= GRIB_ACCESSOR_FLAG_HIDDEN;
|
||||
|
@ -133,13 +134,13 @@ static void init(grib_accessor* a, const long l, grib_arguments* c)
|
|||
|
||||
static int pack_long(grib_accessor* a, const long* val, size_t* len)
|
||||
{
|
||||
grib_accessor_gds_is_present* self = (grib_accessor_gds_is_present*)a;
|
||||
long missing = 255;
|
||||
int ret = 0;
|
||||
size_t size = 0;
|
||||
double* values;
|
||||
double* values = NULL;
|
||||
grib_context* c = a->context;
|
||||
grib_handle* h = grib_handle_of_accessor(a);
|
||||
grib_accessor_gds_is_present* self = (grib_accessor_gds_is_present*)a;
|
||||
|
||||
if (*val != 1)
|
||||
return GRIB_NOT_IMPLEMENTED;
|
||||
|
|
|
@ -126,12 +126,13 @@ static void init(grib_accessor* a, const long v, grib_arguments* args)
|
|||
{
|
||||
int n = 0;
|
||||
grib_accessor_gds_not_present_bitmap* self = (grib_accessor_gds_not_present_bitmap*)a;
|
||||
grib_handle* hand = grib_handle_of_accessor(a);
|
||||
|
||||
self->missing_value = grib_arguments_get_name(grib_handle_of_accessor(a), args, n++);
|
||||
self->number_of_values = grib_arguments_get_name(grib_handle_of_accessor(a), args, n++);
|
||||
self->number_of_points = grib_arguments_get_name(grib_handle_of_accessor(a), args, n++);
|
||||
self->latitude_of_first_point = grib_arguments_get_name(grib_handle_of_accessor(a), args, n++);
|
||||
self->ni = grib_arguments_get_name(grib_handle_of_accessor(a), args, n++);
|
||||
self->missing_value = grib_arguments_get_name(hand, args, n++);
|
||||
self->number_of_values = grib_arguments_get_name(hand, args, n++);
|
||||
self->number_of_points = grib_arguments_get_name(hand, args, n++);
|
||||
self->latitude_of_first_point = grib_arguments_get_name(hand, args, n++);
|
||||
self->ni = grib_arguments_get_name(hand, args, n++);
|
||||
a->length = 0;
|
||||
}
|
||||
|
||||
|
@ -145,6 +146,7 @@ static int value_count(grib_accessor* a, long* number_of_points)
|
|||
static int unpack_double(grib_accessor* a, double* val, size_t* len)
|
||||
{
|
||||
grib_accessor_gds_not_present_bitmap* self = (grib_accessor_gds_not_present_bitmap*)a;
|
||||
grib_handle* hand = grib_handle_of_accessor(a);
|
||||
|
||||
long number_of_points = 0, number_of_values = 0, ni = 0;
|
||||
long latitude_of_first_point = 0;
|
||||
|
@ -160,19 +162,19 @@ static int unpack_double(grib_accessor* a, double* val, size_t* len)
|
|||
if (err)
|
||||
return err;
|
||||
|
||||
if ((err = grib_get_long(grib_handle_of_accessor(a), self->number_of_points, &number_of_points)) != GRIB_SUCCESS)
|
||||
if ((err = grib_get_long(hand, self->number_of_points, &number_of_points)) != GRIB_SUCCESS)
|
||||
return err;
|
||||
|
||||
if ((err = grib_get_long(grib_handle_of_accessor(a), self->number_of_values, &number_of_values)) != GRIB_SUCCESS)
|
||||
if ((err = grib_get_long(hand, self->number_of_values, &number_of_values)) != GRIB_SUCCESS)
|
||||
return err;
|
||||
|
||||
if ((err = grib_get_long(grib_handle_of_accessor(a), self->latitude_of_first_point, &latitude_of_first_point)) != GRIB_SUCCESS)
|
||||
if ((err = grib_get_long(hand, self->latitude_of_first_point, &latitude_of_first_point)) != GRIB_SUCCESS)
|
||||
return err;
|
||||
|
||||
if ((err = grib_get_long(grib_handle_of_accessor(a), self->missing_value, &missing_value)) != GRIB_SUCCESS)
|
||||
if ((err = grib_get_long(hand, self->missing_value, &missing_value)) != GRIB_SUCCESS)
|
||||
return err;
|
||||
|
||||
if ((err = grib_get_long(grib_handle_of_accessor(a), self->ni, &ni)) != GRIB_SUCCESS)
|
||||
if ((err = grib_get_long(hand, self->ni, &ni)) != GRIB_SUCCESS)
|
||||
return err;
|
||||
|
||||
if (*len < number_of_points) {
|
||||
|
@ -206,68 +208,9 @@ static int unpack_double(grib_accessor* a, double* val, size_t* len)
|
|||
return err;
|
||||
}
|
||||
|
||||
#if 0
|
||||
|
||||
static void grib_set_bit_on( unsigned char* p, long *bitp){
|
||||
unsigned char o = 1;
|
||||
p += (*bitp >> 3);
|
||||
o <<= 7-((*bitp)%8);
|
||||
*p |= o;
|
||||
(*bitp)+=1;
|
||||
}
|
||||
|
||||
static int pack_double(grib_accessor* a, const double* val,size_t *len){
|
||||
grib_accessor_gds_not_present_bitmap* self = (grib_accessor_gds_not_present_bitmap*)a;
|
||||
|
||||
size_t tlen;
|
||||
|
||||
unsigned char* buf = NULL;
|
||||
long i;
|
||||
int err = 0;
|
||||
long pos = 0;
|
||||
long bmaplen = 0;
|
||||
const int bit_padding = 16;
|
||||
double miss_values = 0;
|
||||
tlen = ((*len+bit_padding-1)/bit_padding*bit_padding)/8;
|
||||
|
||||
if((err = grib_get_double_internal(grib_handle_of_accessor(a), self->missing_value, &miss_values)) != GRIB_SUCCESS)
|
||||
{
|
||||
grib_context_log(a->context, GRIB_LOG_ERROR, "grib_accessor_class_bitmap : pack_double : Cannot unpack %s err=%d ",self->missing_value,err);
|
||||
return err;
|
||||
}
|
||||
|
||||
buf = grib_context_malloc_clear(a->context,tlen);
|
||||
if(!buf) return GRIB_OUT_OF_MEMORY;
|
||||
pos=0;
|
||||
for(i=0;i<*len;i++)
|
||||
{
|
||||
if (val[i] == miss_values)
|
||||
pos++;
|
||||
else{
|
||||
bmaplen++;
|
||||
grib_set_bit_on(buf, &pos);
|
||||
}
|
||||
}
|
||||
|
||||
if((err = grib_set_long_internal(grib_handle_of_accessor(a), self->unusedBits,tlen*8 - *len )) != GRIB_SUCCESS) {
|
||||
grib_context_log(a->context, GRIB_LOG_ERROR, "grib_accessor_class_bitmap : pack_double : Cannot pack %s err=%d ",self->unusedBits,err);
|
||||
grib_context_free(a->context,buf);
|
||||
return err;
|
||||
}
|
||||
|
||||
|
||||
grib_buffer_replace(a, buf, tlen,1,1);
|
||||
|
||||
grib_context_free(a->context,buf);
|
||||
|
||||
return GRIB_SUCCESS;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
static int pack_double(grib_accessor* a, const double* val, size_t* len)
|
||||
{
|
||||
// See deprecated/grib_accessor_class_gds_not_present_bitmap.cc for
|
||||
// a possible implementation
|
||||
return GRIB_NOT_IMPLEMENTED;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
|
|
@ -178,7 +178,6 @@ static int is_missing(grib_accessor* a){
|
|||
Assert( ret == 0);
|
||||
return value == GRIB_MISSING_LONG;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
*/
|
||||
|
@ -277,12 +276,10 @@ static int pack_string(grib_accessor* a, const char* val, size_t* len)
|
|||
{
|
||||
long v = 0; /* The converted value */
|
||||
|
||||
#if 0
|
||||
/* Requires more work e.g. filter */
|
||||
if (strcmp_nocase(val, "missing")==0) {
|
||||
return pack_missing(a);
|
||||
}
|
||||
#endif
|
||||
// Requires more work e.g. filter
|
||||
//if (strcmp_nocase(val, "missing")==0) {
|
||||
// return pack_missing(a);
|
||||
//}
|
||||
|
||||
if (string_to_long(val, &v) != GRIB_SUCCESS) {
|
||||
grib_context_log(a->context, GRIB_LOG_ERROR,
|
||||
|
|
Loading…
Reference in New Issue