--- ray/src/common/object.h 2003/03/12 04:59:04 2.11 +++ ray/src/common/object.h 2025/06/23 19:56:47 2.27 @@ -1,10 +1,15 @@ -/* RCSid $Id: object.h,v 2.11 2003/03/12 04:59:04 greg Exp $ */ +/* RCSid $Id: object.h,v 2.27 2025/06/23 19:56:47 greg 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 @@ -17,17 +22,17 @@ */ typedef struct { - short nsargs; /* # of string arguments */ - short nfargs; /* # of real arguments */ char **sarg; /* string arguments */ - FLOAT *farg; /* real arguments */ + RREAL *farg; /* real arguments */ + int nsargs; /* # of string arguments */ + int nfargs; /* # of real arguments */ #ifdef IARGS - short niargs; /* # of integer arguments */ + int niargs; /* # of integer arguments */ long *iarg; /* integer arguments */ #endif } FUNARGS; -#define MAXSTR 128 /* maximum string length */ +#define MAXSTR 512 /* maximum string (word) length */ /* * An object is defined as an index into an array of @@ -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,17 +57,17 @@ typedef struct { } OBJREC; #ifndef MAXOBJBLK -#ifdef BIGMEM -#define MAXOBJBLK 65535 /* maximum number of object blocks */ +#ifdef SMLMEM +#define MAXOBJBLK 16383 /* maximum number of object blocks */ #else -#define MAXOBJBLK 63 /* maximum number of object blocks */ +#define MAXOBJBLK 1048503 /* maximum number of object blocks */ #endif #endif extern OBJREC *objblock[MAXOBJBLK]; /* the object blocks */ extern OBJECT nobjects; /* # of objects */ -#define OBJBLKSHFT 9 +#define OBJBLKSHFT 11 #define OBJBLKSIZ (1<>OBJBLKSHFT]+((obj)&(OBJBLKSIZ-1))) @@ -74,50 +79,21 @@ extern OBJECT nobjects; /* # of objects */ * the objects in ascending order. */ -#define MAXSET 511 /* maximum object set size */ +#define MAXSET 8191 /* maximum object set size */ #define setfree(os) free((void *)(os)) -extern void (*addobjnotify[])(); /* people to notify of new objects */ +extern void (*addobjnotify[])(OBJECT); /* 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); extern OBJECT modifier(char *name); extern OBJECT object(char *oname); +extern int eqreal(double d1, double d2); +extern int eqobjects(OBJECT obj1, OBJECT obj2); extern void insertobject(OBJECT obj); -extern void clearobjndx(void); +extern void truncobjndx(void); /* defined in objset.c */ extern void insertelem(OBJECT *os, OBJECT obj); extern void deletelem(OBJECT *os, OBJECT obj); @@ -141,9 +117,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_ */ +