2013-03-25 12:04:10 +00:00
|
|
|
/*
|
2020-01-28 14:32:34 +00:00
|
|
|
* (C) Copyright 2005- ECMWF.
|
2013-03-25 12:04:10 +00:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Author: Enrico Fucile
|
|
|
|
* date: 14/06/2010
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "grib_api_internal.h"
|
|
|
|
|
|
|
|
|
2020-01-22 13:10:59 +00:00
|
|
|
grib_points* grib_box_get_points(grib_box* box, double north, double west, double south, double east, int* err)
|
2013-03-25 12:04:10 +00:00
|
|
|
{
|
2020-01-22 13:10:59 +00:00
|
|
|
grib_box_class* c = box->cclass;
|
2022-01-31 14:07:07 +00:00
|
|
|
fprintf(stderr, "Warning: The grib_box_get_points function is deprecated and will be removed later.");
|
2020-01-22 13:10:59 +00:00
|
|
|
while (c) {
|
|
|
|
grib_box_class* s = c->super ? *(c->super) : NULL;
|
|
|
|
if (c->get_points) {
|
|
|
|
return c->get_points(box, north, west, south, east, err);
|
|
|
|
}
|
|
|
|
c = s;
|
|
|
|
}
|
|
|
|
Assert(0);
|
|
|
|
return 0;
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* For this one, ALL init are called */
|
|
|
|
|
2020-01-22 13:10:59 +00:00
|
|
|
static int init_box(grib_box_class* c, grib_box* i, grib_handle* h, grib_arguments* args)
|
2013-03-25 12:04:10 +00:00
|
|
|
{
|
2020-01-22 13:10:59 +00:00
|
|
|
if (c) {
|
|
|
|
int ret = GRIB_SUCCESS;
|
|
|
|
grib_box_class* s = c->super ? *(c->super) : NULL;
|
|
|
|
if (!c->inited) {
|
|
|
|
if (c->init_class)
|
|
|
|
c->init_class(c);
|
|
|
|
c->inited = 1;
|
|
|
|
}
|
|
|
|
if (s)
|
|
|
|
ret = init_box(s, i, h, args);
|
|
|
|
|
|
|
|
if (ret != GRIB_SUCCESS)
|
|
|
|
return ret;
|
|
|
|
|
|
|
|
if (c->init)
|
|
|
|
return c->init(i, h, args);
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|
2020-01-22 13:10:59 +00:00
|
|
|
return GRIB_INTERNAL_ERROR;
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|
|
|
|
|
2020-01-22 13:10:59 +00:00
|
|
|
int grib_box_init(grib_box* box, grib_handle* h, grib_arguments* args)
|
2013-03-25 12:04:10 +00:00
|
|
|
{
|
2020-01-22 13:10:59 +00:00
|
|
|
return init_box(box->cclass, box, h, args);
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* For this one, ALL destroy are called */
|
|
|
|
|
2020-01-22 13:10:59 +00:00
|
|
|
int grib_box_delete(grib_box* box)
|
2013-03-25 12:04:10 +00:00
|
|
|
{
|
2020-01-22 13:10:59 +00:00
|
|
|
grib_box_class* c = box->cclass;
|
|
|
|
while (c) {
|
|
|
|
grib_box_class* s = c->super ? *(c->super) : NULL;
|
|
|
|
if (c->destroy)
|
|
|
|
c->destroy(box);
|
|
|
|
c = s;
|
|
|
|
}
|
|
|
|
return 0;
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|
|
|
|
|
2020-01-22 13:10:59 +00:00
|
|
|
grib_points* grib_points_new(grib_context* c, size_t size)
|
|
|
|
{
|
|
|
|
grib_points* points = (grib_points*)grib_context_malloc_clear(c, sizeof(grib_points));
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2020-01-22 13:10:59 +00:00
|
|
|
points->latitudes = (double*)grib_context_malloc_clear(c, sizeof(double) * size);
|
|
|
|
points->longitudes = (double*)grib_context_malloc_clear(c, sizeof(double) * size);
|
|
|
|
points->indexes = (size_t*)grib_context_malloc_clear(c, sizeof(double) * size);
|
|
|
|
points->group_start = (size_t*)grib_context_malloc_clear(c, sizeof(double) * size);
|
|
|
|
points->group_len = (size_t*)grib_context_malloc_clear(c, sizeof(double) * size);
|
|
|
|
points->size = size;
|
|
|
|
points->context = c;
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2020-01-22 13:10:59 +00:00
|
|
|
return points;
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|
|
|
|
|
2020-01-22 13:10:59 +00:00
|
|
|
void grib_points_delete(grib_points* points)
|
|
|
|
{
|
|
|
|
grib_context* c;
|
|
|
|
if (!points)
|
|
|
|
return;
|
|
|
|
|
|
|
|
c = points->context;
|
|
|
|
grib_context_free(c, points->latitudes);
|
|
|
|
grib_context_free(c, points->longitudes);
|
|
|
|
grib_context_free(c, points->indexes);
|
|
|
|
grib_context_free(c, points->group_start);
|
|
|
|
grib_context_free(c, points->group_len);
|
|
|
|
grib_context_free(c, points);
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|