--- ray/src/common/rtio.h 2016/03/03 22:09:59 3.11 +++ ray/src/common/rtio.h 2023/06/08 17:48:01 3.29 @@ -1,4 +1,4 @@ -/* RCSid $Id: rtio.h,v 3.11 2016/03/03 22:09:59 greg Exp $ */ +/* RCSid $Id: rtio.h,v 3.29 2023/06/08 17:48:01 greg Exp $ */ /* * Radiance i/o and string routines */ @@ -10,24 +10,69 @@ #include #include #include +#include #ifdef getc_unlocked /* avoid horrendous overhead of flockfile */ #undef getc +#undef getchar #undef putc +#undef putchar #define getc getc_unlocked +#define getchar getchar_unlocked #define putc putc_unlocked +#define putchar putchar_unlocked +#ifndef __cplusplus +#undef feof +#undef ferror +#define feof feof_unlocked +#define ferror ferror_unlocked #endif +#endif #ifdef __cplusplus extern "C" { #endif + /* identify header lines */ +#define MAXFMTLEN 64 +#define isheadid(s) headidval(NULL,s) +#define isformat(s) formatval(NULL,s) +#define isdate(s) dateval(NULL,s) +#define isgmt(s) gmtval(NULL,s) + +#define LATLONSTR "LATLONG=" +#define LLATLONSTR 8 +#define islatlon(hl) (!strncmp(hl,LATLONSTR,LLATLONSTR)) +#define latlonval(ll,hl) sscanf((hl)+LLATLONSTR, "%f %f", \ + &(ll)[0],&(ll)[1]) +#define fputlatlon(lat,lon,fp) fprintf(fp,"%s %.6f %.6f\n",LATLONSTR,lat,lon) + /* defined in header.c */ +extern void newheader(const char *t, FILE *fp); +extern int headidval(char *r, const char *s); +extern int dateval(time_t *t, const char *s); +extern int gmtval(time_t *t, const char *s); +extern void fputdate(time_t t, FILE *fp); +extern void fputnow(FILE *fp); +extern void printargs(int ac, char **av, FILE *fp); +extern int formatval(char fmt[MAXFMTLEN], const char *s); +extern void fputformat(const char *s, FILE *fp); +extern int nativebigendian(void); +extern int isbigendian(const char *s); +extern void fputendian(FILE *fp); +typedef int gethfunc(char *s, void *p); /* callback to process header lines */ +extern int getheader(FILE *fp, gethfunc *f, void *p); +extern int globmatch(const char *pat, const char *str); +extern int checkheader(FILE *fin, char fmt[MAXFMTLEN], FILE *fout); + /* defined in fltdepth.c */ +extern int open_float_depth(const char *fname, long expected_length); /* defined in badarg.c */ -extern int badarg(int ac, char **av, char *fl); +extern int badarg(int ac, char **av, const char *fl); /* defined in expandarg.c */ +extern int envexpchr, filexpchr; extern int expandarg(int *acp, char ***avp, int n); /* defined in fdate.c */ -extern time_t fdate(char *fname); -extern int setfdate(char *fname, long ftim); +extern time_t fdate(const char *fname); +extern time_t fddate(int fd); +extern int setfdate(const char *fname, long ftim); /* defined in fgetline.c */ extern char *fgetline(char *s, int n, FILE *fp); /* defined in fgetval.c */ @@ -45,33 +90,33 @@ extern char *gethomedir(char *uname, char *path, int p /* defined in getpath.c */ extern char *getpath(char *fname, char *searchpath, int mode); /* defined in byteswap.c */ -extern void swap16(char *wp, int n); -extern void swap32(char *wp, int n); -extern void swap64(char *wp, int n); +extern void swap16(char *wp, size_t n); +extern void swap32(char *wp, size_t n); +extern void swap64(char *wp, size_t n); /* defined in portio.c */ -extern void putstr(char *s, FILE *fp); -extern void putint(long i, int siz, FILE *fp); -extern void putflt(double f, FILE *fp); -extern int putbinary(char *s, int elsiz, int nel, FILE *fp); +extern int putstr(char *s, FILE *fp); +extern int putint(long i, int siz, FILE *fp); +extern int putflt(double f, FILE *fp); +extern size_t putbinary(const void *s, size_t elsiz, size_t nel, FILE *fp); extern char *getstr(char *s, FILE *fp); extern long getint(int siz, FILE *fp); extern double getflt(FILE *fp); -extern int getbinary(char *s, int elsiz, int nel, FILE *fp); +extern size_t getbinary(void *s, size_t elsiz, size_t nel, FILE *fp); /* defined in rexpr.c */ extern int ecompile(char *sp, int iflg, int wflag); extern char *expsave(void); extern void expset(char *ep); extern char *eindex(char *sp); /* defined in savestr.c */ -extern char *savestr(char *str); +extern char *savestr(const char *str); extern void freestr(char *s); -extern int shash(char *s); +extern int shash(const char *s); /* defined in savqstr.c */ extern char *savqstr(char *s); extern void freeqstr(char *s); /* defined in wordfile.c */ -extern int wordfile(char **words, char *fname); -extern int wordstring(char **avl, char *str); +extern int wordfile(char **words, int nargs, char *fname); +extern int wordstring(char **avl, int nargs, char *str); /* defined in words.c */ extern char *atos(char *rs, int nb, char *s); extern char *nextword(char *cp, int nb, char *s); @@ -87,6 +132,11 @@ extern int isfltd(char *s, char *ds); extern float * matchlamp(char *s); extern int loadlamps(char *file); extern void freelamps(void); + +#ifndef strlcpy /* defined in option strlcpy.c */ +extern size_t strlcpy(char *dst, const char *src, size_t siz); +extern size_t strlcat(char *dst, const char *src, size_t siz); +#endif #ifdef __cplusplus }