--- ray/src/cv/mgflib/parser.h 1994/06/30 11:07:38 1.11 +++ ray/src/cv/mgflib/parser.h 1994/07/01 10:18:36 1.12 @@ -201,7 +201,6 @@ extern double normalize(FVECT); /* normalize a vector #define C_CDXY 010 /* flag if defined w/ xy */ typedef struct { - char *name; /* material name */ int clock; /* incremented each change */ short flags; /* what's been set */ short ssamp[C_CNSS]; /* spectral samples, min wl to max */ @@ -209,7 +208,7 @@ typedef struct { float cx, cy; /* xy chromaticity value */ } C_COLOR; -#define C_DEFCOLOR { NULL, 0, C_CDXY|C_CSXY|C_CSSPEC,\ +#define C_DEFCOLOR { 1, C_CDXY|C_CSXY|C_CSSPEC,\ {C_CMAXV,C_CMAXV,C_CMAXV,C_CMAXV,C_CMAXV,\ C_CMAXV,C_CMAXV,C_CMAXV,C_CMAXV,C_CMAXV,C_CMAXV,\ C_CMAXV,C_CMAXV,C_CMAXV,C_CMAXV,C_CMAXV,C_CMAXV,\ @@ -219,19 +218,19 @@ typedef struct { C_CMAXV,C_CMAXV,C_CMAXV,C_CMAXV,C_CMAXV,C_CMAXV},\ (long)C_CNSS*C_CMAXV, 1./3., 1./3. } -#define C_CIEX { "_cie_x", 0, C_CDSPEC|C_CSSPEC|C_CSXY,\ +#define C_CIEX { 1, C_CDSPEC|C_CSSPEC|C_CSXY,\ {14,42,143,435,1344,2839,3483,3362,2908,1954,956,\ 320,49,93,633,1655,2904,4334,5945,7621,9163,10263,\ 10622,10026,8544,6424,4479,2835,1649,874,468,227,\ 114,58,29,14,7,3,2,1,0}, 106836L, .735, .265 } -#define C_CIEY { "_cie_y", 0, C_CDSPEC|C_CSSPEC|C_CSXY,\ +#define C_CIEY { 1, C_CDSPEC|C_CSSPEC|C_CSXY,\ {0,1,4,12,40,116,230,380,600,910,1390,2080,3230,\ 5030,7100,8620,9540,9950,9950,9520,8700,7570,6310,\ 5030,3810,2650,1750,1070,610,320,170,82,41,21,10,\ 5,2,1,1,0,0}, 106856L, .274, .717 } -#define C_CIEZ { "_cie_z", 0, C_CDSPEC|C_CSSPEC|C_CSXY,\ +#define C_CIEZ { 1, C_CDSPEC|C_CSSPEC|C_CSXY,\ {65,201,679,2074,6456,13856,17471,17721,16692,\ 12876,8130,4652,2720,1582,782,422,203,87,39,21,17,\ 11,8,3,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},\ @@ -240,7 +239,6 @@ typedef struct { #define c_cval(c,l) ((double)(c)->ssamp[((l)-C_MINWL)/C_CWLI] / (c)->sum) typedef struct { - char *name; /* material name */ int clock; /* incremented each change -- resettable */ float rd; /* diffuse reflectance */ C_COLOR rd_c; /* diffuse reflectance color */ @@ -257,18 +255,20 @@ typedef struct { } C_MATERIAL; /* material context */ typedef struct { - char *name; /* vector name */ int clock; /* incremented each change -- resettable */ FVECT p, n; /* point and normal */ } C_VERTEX; /* vertex context */ -#define C_DEFMATERIAL {NULL,0,0.,C_DEFCOLOR,0.,C_DEFCOLOR,0.,C_DEFCOLOR,\ +#define C_DEFMATERIAL {1,0.,C_DEFCOLOR,0.,C_DEFCOLOR,0.,C_DEFCOLOR,\ 0.,C_DEFCOLOR,0.,0.,C_DEFCOLOR,0.} -#define C_DEFVERTEX {NULL,0,{0.,0.,0.},{0.,0.,0.}} +#define C_DEFVERTEX {1,{0.,0.,0.},{0.,0.,0.}} extern C_COLOR *c_ccolor; /* the current color */ +extern char *c_ccname; /* current color name */ extern C_MATERIAL *c_cmaterial; /* the current material */ +extern char *c_cmname; /* current material name */ extern C_VERTEX *c_cvertex; /* the current vertex */ +extern char *c_cvname; /* current vertex name */ #ifdef NOPROTO extern int c_hcolor(); /* handle color entity */