2010-06-03 21:24:43 +08:00
|
|
|
/*
|
2018-12-07 05:13:56 +08:00
|
|
|
* Copyright 2018, University Corporation for Atmospheric Research
|
2010-06-03 21:24:43 +08:00
|
|
|
* See netcdf/COPYRIGHT file for copying and redistribution conditions.
|
|
|
|
*/
|
|
|
|
#ifndef _NC_H_
|
|
|
|
#define _NC_H_
|
|
|
|
|
2012-09-07 03:44:03 +08:00
|
|
|
#include "config.h"
|
|
|
|
#include "netcdf.h"
|
|
|
|
|
|
|
|
/* There's an external ncid (ext_ncid) and an internal ncid
|
|
|
|
* (int_ncid). The ext_ncid is the ncid returned to the user. If
|
|
|
|
* the user has opened or created a netcdf-4 file, then the
|
|
|
|
* ext_ncid is the same as the int_ncid. If he has opened or
|
|
|
|
* created a netcdf-3 file ext_ncid (which the user sees) is
|
|
|
|
* different from the int_ncid, which is the ncid returned by the
|
|
|
|
* netcdf-3 layer, which insists on inventing its own ncids,
|
|
|
|
* regardless of what is already in use due to previously opened
|
|
|
|
* netcdf-4 files. The ext_ncid contains the ncid for the root
|
|
|
|
* group (i.e. group zero). */
|
|
|
|
|
2015-12-29 01:36:05 +08:00
|
|
|
/* Common Shared Structure for all Dispatched Objects */
|
2012-09-07 03:44:03 +08:00
|
|
|
typedef struct NC {
|
|
|
|
int ext_ncid;
|
|
|
|
int int_ncid;
|
2019-03-31 04:06:20 +08:00
|
|
|
const struct NC_Dispatch* dispatch;
|
2012-09-07 03:44:03 +08:00
|
|
|
void* dispatchdata; /*per-'file' data; points to e.g. NC3_INFO data*/
|
|
|
|
char* path;
|
2013-12-23 03:53:20 +08:00
|
|
|
int mode; /* as provided to nc_open/nc_create */
|
2012-09-07 03:44:03 +08:00
|
|
|
} NC;
|
2010-06-03 21:24:43 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Counted string for names and such
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
/* all xdr'd */
|
|
|
|
size_t nchars;
|
2017-03-12 03:33:58 +08:00
|
|
|
char *cp;
|
2010-06-03 21:24:43 +08:00
|
|
|
} NC_string;
|
|
|
|
|
2012-09-07 03:44:03 +08:00
|
|
|
/* Define functions that are used across multiple dispatchers */
|
|
|
|
|
2010-06-03 21:24:43 +08:00
|
|
|
/* Begin defined in string.c */
|
|
|
|
extern void
|
|
|
|
free_NC_string(NC_string *ncstrp);
|
|
|
|
|
|
|
|
extern int
|
|
|
|
NC_check_name(const char *name);
|
|
|
|
|
|
|
|
extern NC_string *
|
|
|
|
new_NC_string(size_t slen, const char *str);
|
|
|
|
extern int
|
|
|
|
set_NC_string(NC_string *ncstrp, const char *str);
|
|
|
|
|
|
|
|
/* End defined in string.c */
|
|
|
|
|
|
|
|
extern int
|
|
|
|
NC_check_id(int ncid, NC **ncpp);
|
|
|
|
|
2012-09-07 03:44:03 +08:00
|
|
|
/* Create a pseudo file descriptor that does not
|
|
|
|
overlap real file descriptors */
|
|
|
|
extern int nc__pseudofd(void);
|
2010-06-03 21:24:43 +08:00
|
|
|
|
2012-09-07 03:44:03 +08:00
|
|
|
/* This function gets a current default create flag */
|
|
|
|
extern int nc_get_default_format(void);
|
2010-06-03 21:24:43 +08:00
|
|
|
|
|
|
|
extern int add_to_NCList(NC*);
|
|
|
|
extern void del_from_NCList(NC*);/* does not free object */
|
|
|
|
extern NC* find_in_NCList(int ext_ncid);
|
2014-03-08 03:04:38 +08:00
|
|
|
extern NC* find_in_NCList_by_name(const char*);
|
2019-09-17 01:28:18 +08:00
|
|
|
extern int move_in_NCList(NC *ncp, int new_id);
|
2010-06-03 21:24:43 +08:00
|
|
|
extern void free_NCList(void);/* reclaim whole list */
|
|
|
|
extern int count_NCList(void); /* return # of entries in NClist */
|
2016-05-04 11:17:06 +08:00
|
|
|
extern int iterate_NCList(int i,NC**); /* Walk from 0 ...; ERANGE return => stop */
|
2010-06-03 21:24:43 +08:00
|
|
|
|
2012-09-07 03:44:03 +08:00
|
|
|
/* Defined in nc.c */
|
|
|
|
extern void free_NC(NC*);
|
2019-09-30 02:59:28 +08:00
|
|
|
extern int new_NC(const struct NC_Dispatch*, const char*, int, NC**);
|
2017-03-09 08:01:10 +08:00
|
|
|
|
2010-06-03 21:24:43 +08:00
|
|
|
#endif /* _NC_H_ */
|