mirror of
https://github.com/Unidata/netcdf-c.git
synced 2025-01-18 15:55:12 +08:00
73 lines
2.7 KiB
C
73 lines
2.7 KiB
C
#ifndef NCGEN_UTIL_H
|
|
#define NCGEN_UTIL_H
|
|
/*********************************************************************
|
|
* Copyright 2018, UCAR/Unidata
|
|
* See netcdf/COPYRIGHT file for copying and redistribution conditions.
|
|
* $Header: /upc/share/CVS/netcdf-3/ncgen/util.h,v 1.3 2010/04/04 19:39:57 dmh Exp $
|
|
*********************************************************************/
|
|
|
|
#include <stddef.h>
|
|
#define MAX(x,y) ((x)>(y)?(x):(y))
|
|
|
|
extern void expe2d(char*);
|
|
extern int pow2(int);
|
|
extern void tztrim(char*);
|
|
extern unsigned int chartohex(char c);
|
|
|
|
extern void reclaimvardata(List*);
|
|
extern void reclaimattptrs(void*, long);
|
|
extern void cleanup(void);
|
|
extern char* fullname(Symbol*);
|
|
|
|
extern int isunlimited0(Dimset*);
|
|
extern int hasunlimited(Dimset* dimset);
|
|
extern int classicunlimited(Dimset* dimset);
|
|
extern int isbounded(Dimset* dimset);
|
|
extern char* nctypename(nc_type);
|
|
extern char* ncclassname(nc_class);
|
|
extern size_t ncsize(nc_type);
|
|
|
|
extern nc_type signedtype(nc_type nctype);
|
|
extern nc_type unsignedtype(nc_type nctype);
|
|
|
|
/* We have several versions of primitive testing*/
|
|
extern int isinttype(nc_type nctype); /* some kind of integer*/
|
|
extern int isuinttype(nc_type nctype); /* some kind of integer*/
|
|
extern int isfloattype(nc_type nctype); /* some kind of float*/
|
|
extern int isclassicprim(nc_type); /* a classic primitive type*/
|
|
extern int isclassicprimplus(nc_type); /* classic + String*/
|
|
extern int isprim(nc_type); /* a netcdf4 primitive type*/
|
|
extern int isprimplus(nc_type); /* a netcdf4 primitive type + OPAQUE + ENUM*/
|
|
|
|
extern void collectpath(Symbol* grp, List* grpstack);
|
|
extern List* prefixdup(List*);
|
|
extern int prefixeq(List*,List*);
|
|
#define prefixlen(sequence) (listlength(sequence))
|
|
|
|
extern char* poolalloc(size_t);
|
|
extern char* pooldup(const char*);
|
|
extern char* poolcat(const char* s1, const char* s2);
|
|
|
|
/* compute the total n-dimensional size as 1 long array;
|
|
if stop == 0, then stop = dimset->ndims.
|
|
*/
|
|
extern size_t crossproduct(Dimset* dimset, int start, int stop);
|
|
extern int findunlimited(Dimset* dimset, int start);
|
|
extern int findlastunlimited(Dimset* dimset);
|
|
extern int countunlimited(Dimset* dimset);
|
|
|
|
extern unsigned char* makebytestring(char* s, size_t* lenp);
|
|
extern size_t getpadding(size_t offset, size_t alignment);
|
|
|
|
extern void check_err(const int stat, const int line, const char* file, const char* func);
|
|
extern void check_err2(const int stat, const int cdlline, const int line, const char* file, const char* func);
|
|
extern const char* kind_string(int kind);
|
|
extern int getrootid(int grpid);
|
|
|
|
/* Inline functions */
|
|
#define isunlimited(dimset,i) ((dimset)->dimsyms[i]->dim.isunlimited)
|
|
#define declsizefor(dimset,i) ((dimset)->dimsyms[i]->dim.declsize)
|
|
#define rankfor(dimset) ((dimset)->ndims)
|
|
|
|
#endif /*NCGEN_UTIL_H*/
|