eccodes/src/grib_vdarray.c

128 lines
3.4 KiB
C
Raw Normal View History

/*
2020-01-28 14:32:34 +00:00
* (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"
2018-04-12 11:36:39 +00:00
/* For debugging purposes */
void grib_vdarray_print(const char* title, const grib_vdarray* vdarray)
{
size_t i;
2020-01-22 14:48:06 +00:00
char text[100] = {0,};
2018-04-12 11:36:39 +00:00
Assert(vdarray);
printf("%s: vdarray.n=%lu\n", title, (unsigned long)vdarray->n);
2020-01-22 13:10:59 +00:00
for (i = 0; i < vdarray->n; i++) {
2018-06-07 16:27:18 +00:00
sprintf(text, " vdarray->v[%lu]", (unsigned long)i);
2018-04-12 11:36:39 +00:00
grib_darray_print(text, vdarray->v[i]);
}
printf("\n");
}
2020-01-22 13:10:59 +00:00
grib_vdarray* grib_vdarray_new(grib_context* c, size_t size, size_t incsize)
2015-12-22 17:55:45 +00:00
{
2020-01-22 13:10:59 +00:00
grib_vdarray* v = NULL;
if (!c)
c = grib_context_get_default();
v = (grib_vdarray*)grib_context_malloc_clear(c, sizeof(grib_vdarray));
2015-12-22 17:55:45 +00:00
if (!v) {
2020-01-22 13:10:59 +00:00
grib_context_log(c, GRIB_LOG_ERROR,
"grib_vdarray_new unable to allocate %d bytes\n", sizeof(grib_vdarray));
2015-12-22 17:55:45 +00:00
return NULL;
}
2020-01-22 13:10:59 +00:00
v->size = size;
v->n = 0;
v->incsize = incsize;
v->v = (grib_darray**)grib_context_malloc_clear(c, sizeof(grib_darray*) * size);
2015-12-22 17:55:45 +00:00
if (!v->v) {
2020-01-22 13:10:59 +00:00
grib_context_log(c, GRIB_LOG_ERROR,
"grib_vdarray_new unable to allocate %d bytes\n", sizeof(grib_darray*) * size);
2015-12-22 17:55:45 +00:00
return NULL;
}
return v;
}
2020-01-22 13:10:59 +00:00
grib_vdarray* grib_vdarray_resize(grib_context* c, grib_vdarray* v)
2015-12-22 17:55:45 +00:00
{
2020-01-22 13:10:59 +00:00
int newsize = v->incsize + v->size;
2020-01-22 13:10:59 +00:00
if (!c)
c = grib_context_get_default();
2020-01-22 13:10:59 +00:00
v->v = (grib_darray**)grib_context_realloc(c, v->v, newsize * sizeof(grib_darray*));
v->size = newsize;
2015-12-22 17:55:45 +00:00
if (!v->v) {
2020-01-22 13:10:59 +00:00
grib_context_log(c, GRIB_LOG_ERROR,
"grib_vdarray_resize unable to allocate %d bytes\n", sizeof(grib_darray*) * newsize);
2015-12-22 17:55:45 +00:00
return NULL;
}
return v;
}
2020-01-22 13:10:59 +00:00
grib_vdarray* grib_vdarray_push(grib_context* c, grib_vdarray* v, grib_darray* val)
2015-12-22 17:55:45 +00:00
{
2020-01-22 13:10:59 +00:00
size_t start_size = 100;
size_t start_incsize = 100;
if (!v)
v = grib_vdarray_new(c, start_size, start_incsize);
2020-01-22 13:10:59 +00:00
if (v->n >= v->size)
v = grib_vdarray_resize(c, v);
v->v[v->n] = val;
2015-12-22 17:55:45 +00:00
v->n++;
return v;
}
2020-01-22 13:10:59 +00:00
void grib_vdarray_delete(grib_context* c, grib_vdarray* v)
2015-12-22 17:55:45 +00:00
{
2020-01-22 13:10:59 +00:00
if (!v)
return;
if (!c)
grib_context_get_default();
if (v->v)
grib_context_free(c, v->v);
grib_context_free(c, v);
}
2020-01-22 13:10:59 +00:00
void grib_vdarray_delete_content(grib_context* c, grib_vdarray* v)
2015-12-22 17:55:45 +00:00
{
int i;
2020-01-22 13:10:59 +00:00
if (!v || !v->v)
return;
if (!c)
grib_context_get_default();
for (i = 0; i < v->n; i++) {
grib_darray_delete(c, v->v[i]);
v->v[i] = 0;
2015-12-22 17:55:45 +00:00
}
2020-01-22 13:10:59 +00:00
v->n = 0;
}
2020-01-22 13:10:59 +00:00
grib_darray** grib_vdarray_get_array(grib_context* c, grib_vdarray* v)
2015-12-22 17:55:45 +00:00
{
grib_darray** ret;
int i;
2020-01-22 13:10:59 +00:00
if (!v)
return NULL;
ret = (grib_darray**)grib_context_malloc_clear(c, sizeof(grib_darray*) * v->n);
for (i = 0; i < v->n; i++)
ret[i] = v->v[i];
2015-12-22 17:55:45 +00:00
return ret;
}
2020-01-22 13:10:59 +00:00
size_t grib_vdarray_used_size(grib_vdarray* v)
{
return v->n;
}