2018-11-23 19:11:47 +00:00
|
|
|
%module gribapi_swig
|
|
|
|
|
|
|
|
%include "cpointer.i"
|
|
|
|
%include "cstring.i"
|
|
|
|
%include "typemaps.i"
|
|
|
|
%include "cdata.i"
|
|
|
|
%include "carrays.i"
|
|
|
|
%include "grib_errors.h"
|
|
|
|
|
|
|
|
%{
|
|
|
|
#define SWIG_FILE_WITH_INIT
|
|
|
|
#include "grib_interface.h"
|
|
|
|
%}
|
|
|
|
|
|
|
|
%include "numpy.i"
|
|
|
|
%init %{
|
|
|
|
import_array();
|
|
|
|
%}
|
|
|
|
|
|
|
|
/* Converts a PyFile instance to a stdio FILE* for reading binary files */
|
|
|
|
%typemap(in) FILE* {
|
|
|
|
int fileDescriptor = PyObject_AsFileDescriptor($input);
|
|
|
|
/*printf("swig.i fileDescriptor=%d\n", fileDescriptor);*/
|
|
|
|
if(fileDescriptor >= 0) {
|
|
|
|
/* Convert file descriptor to a FILE pointer */
|
|
|
|
$1 = fdopen(fileDescriptor,"rb"); // needs to be rb+ (or wb) for write
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "$1_name must be a file type.");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
%pointer_class(int, intp);
|
|
|
|
%pointer_class(size_t, sizetp);
|
|
|
|
%pointer_class(long, longp);
|
|
|
|
%pointer_class(double, doublep);
|
|
|
|
%array_functions(double, doubleArray);
|
|
|
|
%array_functions(long, longArray);
|
|
|
|
%array_functions(int, intArray);
|
|
|
|
%array_functions(char*, stringArray);
|
|
|
|
|
|
|
|
// creation
|
|
|
|
int grib_c_new_from_file(FILE* f, int fd, char* fname, int* INOUT, int headers_only);
|
2018-11-26 14:09:46 +00:00
|
|
|
int grib_c_new_any_from_file(FILE* f, int fd, char* fname, int headers_only, int* INOUT);
|
2018-11-23 19:11:47 +00:00
|
|
|
int grib_c_new_bufr_from_file(FILE* f, int fd, char* fname, int headers_only, int* INOUT);
|
|
|
|
int grib_c_new_gts_from_file(FILE* f, int headers_only, int* INOUT);
|
|
|
|
int grib_c_new_metar_from_file(FILE* f, int headers_only, int* INOUT);
|
|
|
|
int grib_c_iterator_new(int* INPUT, int* OUTPUT, int* INPUT);
|
|
|
|
int grib_c_keys_iterator_new(int* INPUT, int* OUTPUT, char* name_space);
|
|
|
|
int codes_c_bufr_keys_iterator_new(int* INPUT, int* OUTPUT);
|
|
|
|
int grib_c_grib_new_from_samples(int* INOUT, char* name);
|
|
|
|
int grib_c_bufr_new_from_samples(int* INOUT, char* name);
|
|
|
|
int grib_c_index_new_from_file(char* file, char* keys, int* OUTPUT);
|
|
|
|
int grib_c_index_add_file(int* INPUT, char* file);
|
|
|
|
int grib_c_new_from_index(int *INPUT, int *INOUT);
|
|
|
|
int grib_c_index_write(int* INPUT, char* file);
|
|
|
|
int grib_c_index_read(char* file, int* OUTPUT);
|
|
|
|
int grib_c_new_from_message(int *INOUT, char *binmsg, size_t *INPUT);
|
|
|
|
// ---
|
|
|
|
|
|
|
|
%apply int* INPUT { int* fid };
|
|
|
|
%apply int* INPUT { int* gid };
|
|
|
|
%apply int* INPUT { int* iterid };
|
|
|
|
%apply int* INPUT { int* iid };
|
|
|
|
|
|
|
|
// file operations
|
2018-11-27 16:26:48 +00:00
|
|
|
int codes_c_close_file(int fd, char* fname);
|
2018-11-23 19:11:47 +00:00
|
|
|
int grib_c_count_in_file(FILE* f,int* OUTPUT);
|
|
|
|
// ---
|
|
|
|
|
|
|
|
/* Converts a PyFile instance to a stdio FILE* for writing binary files */
|
|
|
|
%typemap(in) FILE* {
|
|
|
|
int fileDescriptor = PyObject_AsFileDescriptor($input);
|
|
|
|
if(fileDescriptor >= 0) {
|
|
|
|
/* Convert file descriptor to a FILE pointer */
|
|
|
|
$1 = fdopen(fileDescriptor,"wb");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "$1_name must be a file type.");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// grib handle operations
|
|
|
|
int grib_c_release(int* gid);
|
|
|
|
int grib_c_write(int* gid, FILE* f);
|
|
|
|
int grib_c_get_size_long(int* gid, char* key, long* OUTPUT);
|
|
|
|
int grib_c_get_string_length(int* gid, char* key, size_t* OUTPUT);
|
|
|
|
int grib_c_clone(int* gid,int* INOUT);
|
|
|
|
int grib_c_copy_namespace(int* gid, char* name, int* INPUT);
|
|
|
|
int grib_c_get_message_size(int* gid, size_t* OUTPUT);
|
|
|
|
int grib_c_get_message_offset(int* gid, size_t* OUTPUT);
|
|
|
|
int grib_c_get_native_type(int* gid, char* key, int* OUTPUT);
|
|
|
|
// ---
|
|
|
|
|
|
|
|
// multi support
|
|
|
|
int grib_c_multi_new(int* OUTPUT);
|
|
|
|
int grib_c_multi_support_on(void);
|
|
|
|
int grib_c_multi_write(int* gid, FILE* f);
|
|
|
|
int grib_c_multi_support_off(void);
|
|
|
|
int grib_c_multi_release(int* gid);
|
|
|
|
int grib_c_multi_append(int* INPUT, int* INPUT,int* INPUT);
|
|
|
|
// ---
|
|
|
|
|
|
|
|
// gribex support
|
|
|
|
int grib_c_gribex_mode_on(void);
|
|
|
|
int grib_c_gribex_mode_off(void);
|
|
|
|
// ---
|
|
|
|
|
|
|
|
// keys iterator
|
|
|
|
int grib_c_keys_iterator_next(int* iterid);
|
|
|
|
int codes_c_bufr_keys_iterator_next(int* iterid);
|
|
|
|
int grib_c_keys_iterator_delete(int* iterid);
|
|
|
|
int codes_c_bufr_keys_iterator_delete(int* iterid);
|
|
|
|
int grib_c_skip_computed(int* iterid);
|
|
|
|
int grib_c_skip_coded(int* iterid);
|
|
|
|
int grib_c_skip_edition_specific(int* iterid);
|
|
|
|
int grib_c_skip_duplicates(int* iterid);
|
|
|
|
int grib_c_skip_read_only(int* iterid);
|
|
|
|
int grib_c_skip_function(int* iterid);
|
|
|
|
int grib_c_keys_iterator_rewind(int* iterid);
|
|
|
|
int codes_c_bufr_keys_iterator_rewind(int* iterid);
|
|
|
|
int grib_c_bufr_copy_data(int* gid, int* INOUT);
|
|
|
|
|
|
|
|
|
|
|
|
%cstring_bounded_output(char* name, 1024);
|
|
|
|
int grib_c_keys_iterator_get_name(int* iterid, char* name, int len);
|
|
|
|
int codes_c_bufr_keys_iterator_get_name(int* iterid, char* name, int len);
|
|
|
|
// ---
|
|
|
|
|
|
|
|
// indexing routines
|
|
|
|
int grib_c_index_get_size_long(int* iid, char* key, long* OUTPUT);
|
|
|
|
int grib_c_index_get_long(int* iid, char* key, long* val, int* size);
|
|
|
|
int grib_c_index_get_real8(int* iid, char* key, double* val, int* size);
|
|
|
|
%cstring_bounded_output(char* index_string_output, 1024*1024);
|
|
|
|
int grib_c_index_get_string(int* iid, char* key, char* index_string_output, int* INPUT, int* INOUT);
|
|
|
|
int grib_c_index_select_long(int *iid, char *key, long *INPUT);
|
|
|
|
int grib_c_index_select_real8(int *iid, char *key, double *INPUT);
|
|
|
|
int grib_c_index_select_string(int *iid, char *key, char *val);
|
|
|
|
int grib_c_index_release(int* iid);
|
|
|
|
// ---
|
|
|
|
|
|
|
|
// values iterator
|
|
|
|
int grib_c_iterator_delete(int* iterid);
|
|
|
|
int grib_c_iterator_next(int* iterid, double* OUTPUT, double* OUTPUT, double* OUTPUT);
|
|
|
|
// ---
|
|
|
|
|
|
|
|
// getting/setting key values
|
|
|
|
%cstring_output_withsize(char* string_val, size_t* string_size)
|
|
|
|
int grib_c_get_string(int* gid, char* key, char* string_val, size_t* string_size);
|
|
|
|
int grib_c_get_string_array(int* gid, char* key, char** array_string_val, size_t* size);
|
|
|
|
int grib_c_set_string(int* gid, char* key, char* sval, int len2);
|
|
|
|
int grib_c_get_long(int* gid, char* key, long* OUTPUT);
|
|
|
|
int grib_c_set_long(int* gid, char* key, long* INPUT);
|
|
|
|
int grib_c_get_double(int* gid, char* key, double* OUTPUT);
|
|
|
|
int grib_c_set_double(int* gid, char* key, double* INPUT);
|
|
|
|
int grib_c_set_real8_array(int* gid, char* key, double* val, int* size);
|
|
|
|
int grib_c_get_real8_array(int* gid, char* key, double* val, int* size);
|
|
|
|
int grib_c_get_long_array(int* gid, char* key, long* val, int* size);
|
|
|
|
int grib_c_set_long_array(int* gid, char* key, long* val, int* size);
|
|
|
|
int grib_c_get_real8_element(int* gid, char* key, int* INPUT, double* OUTPUT);
|
|
|
|
int grib_c_get_real8_elements(int* gid, char* key, int* index, double* val, int* size);
|
|
|
|
int grib_c_set_missing(int* gid, char* key);
|
|
|
|
int grib_c_set_key_vals(int* gid, char* keyvals);
|
|
|
|
int grib_c_is_missing(int* gid, char* key, int* OUTPUT);
|
|
|
|
int grib_c_is_defined(int* gid, char* key, int* OUTPUT);
|
|
|
|
|
|
|
|
// http://www.swig.org/Doc1.3/Python.html
|
|
|
|
// This tells SWIG to treat char ** as a special case
|
|
|
|
%typemap(in) char ** {
|
|
|
|
/* Check if is a list */
|
|
|
|
if (PyList_Check($input)) {
|
|
|
|
int size = PyList_Size($input);
|
|
|
|
int i = 0;
|
|
|
|
$1 = (char **) malloc((size+1)*sizeof(char *));
|
|
|
|
for (i = 0; i < size; i++) {
|
|
|
|
PyObject *o = PyList_GetItem($input,i);
|
|
|
|
if (PyString_Check(o))
|
|
|
|
$1[i] = PyString_AsString(PyList_GetItem($input,i));
|
|
|
|
else {
|
|
|
|
PyErr_SetString(PyExc_TypeError,"list must contain strings");
|
|
|
|
free($1);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$1[i] = 0; /* Last entry set to NULL */
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError,"not a list");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// This cleans up the char ** array we malloc'd before the function call
|
|
|
|
%typemap(freearg) char ** {
|
|
|
|
free((char *) $1);
|
|
|
|
}
|
|
|
|
int grib_c_set_string_array(int *gid, char *key, const char** val);
|
|
|
|
|
|
|
|
// Numpy Support
|
|
|
|
%apply (double* IN_ARRAY1, int DIM1) {(double* dpin_val, int dpin_val_dim1)};
|
|
|
|
%apply (long* IN_ARRAY1, int DIM1) {(long* lpin_val, int lpin_val_dim1)};
|
|
|
|
%apply (int* IN_ARRAY1, int DIM1) {(int* ipin_index, int ipin_index_dim1)};
|
|
|
|
%apply (double* ARGOUT_ARRAY1, int DIM1) {(double* dpout_val, int dpout_val_dim1)};
|
|
|
|
%apply (long* ARGOUT_ARRAY1, int DIM1) {(long* lpout_val, int lpout_val_dim1)};
|
|
|
|
|
|
|
|
%inline %{
|
|
|
|
//void with_numpy() {
|
|
|
|
// return;
|
|
|
|
//}
|
|
|
|
int grib_set_double_ndarray(int* gid, char* key, double* dpin_val, int dpin_val_dim1) {
|
|
|
|
return grib_c_set_real8_array(gid,key,dpin_val,&dpin_val_dim1);
|
|
|
|
}
|
|
|
|
int grib_set_long_ndarray(int* gid, char* key, long* lpin_val, int lpin_val_dim1) {
|
|
|
|
return grib_c_set_long_array(gid,key,lpin_val,&lpin_val_dim1);
|
|
|
|
}
|
|
|
|
int grib_get_double_ndarray(int* gid, char* key, double* dpout_val, int dpout_val_dim1) {
|
|
|
|
return grib_c_get_real8_array(gid,key,dpout_val,&dpout_val_dim1);
|
|
|
|
}
|
|
|
|
int grib_get_long_ndarray(int* gid, char* key, long* lpout_val, int lpout_val_dim1) {
|
|
|
|
return grib_c_get_long_array(gid,key,lpout_val,&lpout_val_dim1);
|
|
|
|
}
|
|
|
|
int grib_get_double_ndelements(int* gid, char* key, int* ipin_index, int ipin_index_dim1, double* dpout_val, int dpout_val_dim1) {
|
|
|
|
return grib_c_get_real8_elements(gid,key,ipin_index,dpout_val,&dpout_val_dim1);
|
|
|
|
}
|
|
|
|
%}
|
|
|
|
%clear double* dpin_val, int dpin_val_dim1;
|
|
|
|
%clear long* lpin_val, int lpin_val_dim1;
|
|
|
|
%clear int* ipout_val, int ipout_val_dim1;
|
|
|
|
%clear double* dpout_val, int dpout_val_dim1;
|
|
|
|
%clear long* lpout_val, int lpout_val_dim1;
|
|
|
|
|
|
|
|
// ---
|
|
|
|
|
|
|
|
// nearest
|
|
|
|
int grib_c_find_nearest_single(int* gid, int* INPUT, double* INPUT, double* INPUT, double* OUTPUT, double* OUTPUT, double* OUTPUT, double* OUTPUT, int* OUTPUT);
|
|
|
|
int grib_c_find_nearest_four_single(int* gid, int* INPUT, double* INPUT, double* INPUT, double* outlats, double* outlons, double* values, double* distances, int* indexes);
|
|
|
|
// ---
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Get the binary string message for a grib.
|
|
|
|
*
|
|
|
|
* Set the 3rd argument to nothing in 'cstring_output_allocate_size'.
|
|
|
|
* This is kind of difficult to explain, but, *msg will point directly to
|
|
|
|
* the binary message data of the current grib (which is stored in
|
|
|
|
* handle->buffer->data if I remember correctly) so freeing it will cause
|
|
|
|
* the binary message data in the grib_handle structure to be freed. This
|
|
|
|
* is a problem as grib_api does not know that, so it tries to free it
|
|
|
|
* itself (grib_release does that) resulting in a 'Segmentation fault'.
|
|
|
|
*/
|
|
|
|
%cstring_output_allocate_size(const void **binmsg, size_t *binmsglen,);
|
|
|
|
int grib_c_get_message(int *gid, const void **binmsg, size_t *binmsglen);
|
|
|
|
%clear const void **binmsg, size_t *binmsglen;
|
|
|
|
|
|
|
|
%clear int* fid;
|
|
|
|
%clear int* gid;
|
|
|
|
%clear int* iterid;
|
|
|
|
|
|
|
|
%cstring_bounded_output(char* error_message, 1024);
|
|
|
|
int grib_c_get_error_string(int* INPUT, char* error_message, int len);
|
|
|
|
|
|
|
|
void no_fail_on_wrong_length(int flag);
|
|
|
|
long grib_c_get_api_version();
|
|
|
|
void grib_c_gts_header_on();
|
|
|
|
void grib_c_gts_header_off();
|
|
|
|
void grib_c_set_definitions_path(const char* path);
|
|
|
|
void grib_c_set_samples_path(const char* path);
|