--- ray/src/common/object.h 2003/03/10 17:13:29 2.10 +++ ray/src/common/object.h 2003/07/17 09:21:29 2.17 @@ -1,10 +1,15 @@ -/* RCSid $Id: object.h,v 2.10 2003/03/10 17:13:29 greg Exp $ */ +/* RCSid $Id: object.h,v 2.17 2003/07/17 09:21:29 schorsch Exp $ */ /* * object.h - header file for routines using objects and object sets. + * + * Include after "standard.h" */ +#ifndef _RAD_OBJECT_H_ +#define _RAD_OBJECT_H_ +#ifdef __cplusplus +extern "C" { +#endif -#include "copyright.h" - #ifndef OCTREE #define OCTREE int #endif @@ -20,7 +25,7 @@ typedef struct { short nsargs; /* # of string arguments */ short nfargs; /* # of real arguments */ char **sarg; /* string arguments */ - FLOAT *farg; /* real arguments */ + RREAL *farg; /* real arguments */ #ifdef IARGS short niargs; /* # of integer arguments */ long *iarg; /* integer arguments */ @@ -36,10 +41,10 @@ typedef struct { */ #ifndef OBJECT -#ifdef BIGMEM -#define OBJECT int4 /* index to object array */ +#ifdef SMLMEM +#define OBJECT int16 /* index to object array */ #else -#define OBJECT int2 /* index to object array */ +#define OBJECT int32 /* index to object array */ #endif #endif @@ -52,10 +57,10 @@ typedef struct { } OBJREC; #ifndef MAXOBJBLK -#ifdef BIGMEM -#define MAXOBJBLK 65535 /* maximum number of object blocks */ -#else +#ifdef SMLMEM #define MAXOBJBLK 63 /* maximum number of object blocks */ +#else +#define MAXOBJBLK 65535 /* maximum number of object blocks */ #endif #endif @@ -74,43 +79,12 @@ extern OBJECT nobjects; /* # of objects */ * the objects in ascending order. */ -#define MAXSET 127 /* maximum object set size */ +#define MAXSET 511 /* maximum object set size */ #define setfree(os) free((void *)(os)) extern void (*addobjnotify[])(); /* people to notify of new objects */ -#ifdef NOPROTO - -extern OBJECT objndx(); -extern OBJECT lastmod(); -extern OBJECT modifier(); -extern OBJECT object(); -extern void insertobject(); -extern void clearobjndx(); -extern void insertelem(); -extern void deletelem(); -extern int inset(); -extern int setequal(); -extern void setcopy(); -extern OBJECT * setsave(); -extern void setunion(); -extern void setintersect(); -extern OCTREE fullnode(); -extern void objset(); -extern int dosets(); -extern void donesets(); -extern int otype(); -extern void objerror(); -extern int readfargs(); -extern void freefargs(); -extern void readobj(); -extern void getobject(); -extern OBJECT newobject(); -extern void freeobjects(); -extern int free_os(); - -#else /* defined in modobject.c */ extern OBJECT objndx(OBJREC *op); extern OBJECT lastmod(OBJECT obj, char *mname); @@ -141,9 +115,14 @@ extern void freefargs(FUNARGS *fa); /* defined in readobj.c */ extern void readobj(char *inpspec); extern void getobject(char *name, FILE *fp); -extern OBJECT newobject(); +extern OBJECT newobject(void); extern void freeobjects(int firstobj, int nobjs); /* defined in free_os.c */ extern int free_os(OBJREC *op); -#endif /* NOPROTO */ + +#ifdef __cplusplus +} +#endif +#endif /* _RAD_OBJECT_H_ */ +