| 1 | < | /* Copyright (c) 1988 Regents of the University of California */ | 
| 1 | > | /* Copyright (c) 1990 Regents of the University of California */ | 
| 2 |  |  | 
| 3 |  | /* SCCSid "$SunId$ LBL" */ | 
| 4 |  |  | 
| 12 |  |  | 
| 13 |  | #include  <errno.h> | 
| 14 |  |  | 
| 15 | < | #include  "fvect.h" | 
| 15 | > | #include  "mat4.h" | 
| 16 | > | /* regular transformation */ | 
| 17 | > | typedef struct { | 
| 18 | > | MAT4  xfm;                              /* transform matrix */ | 
| 19 | > | double  sca;                            /* scalefactor */ | 
| 20 | > | }  XF; | 
| 21 | > | /* complemetary tranformation */ | 
| 22 | > | typedef struct { | 
| 23 | > | XF  f;                                  /* forward */ | 
| 24 | > | XF  b;                                  /* backward */ | 
| 25 | > | }  FULLXF; | 
| 26 |  |  | 
| 17 | – | #define  FHUGE          (1e10)          /* large real number */ | 
| 18 | – | #define  FTINY          (1e-6)          /* small real number */ | 
| 19 | – |  | 
| 27 |  | #ifdef  M_PI | 
| 28 |  | #define  PI             M_PI | 
| 29 |  | #else | 
| 48 |  |  | 
| 49 |  | extern int  errno;                      /* system error number */ | 
| 50 |  |  | 
| 51 | + | /* memory operations */ | 
| 52 | + | #ifdef  STRUCTASSIGN | 
| 53 | + | #define  copystruct(d,s)        (*(d) = *(s)) | 
| 54 | + | #else | 
| 55 | + | #define  copystruct(d,s)        bcopy((char *)(s),(char *)(d),sizeof(*(d))) | 
| 56 | + | #endif | 
| 57 | + |  | 
| 58 | + | #ifndef  BSD | 
| 59 | + | #define  bcopy(s,d,n)           (void)memcpy(d,s,n) | 
| 60 | + | #define  bzero(d,n)             (void)memset(d,0,n) | 
| 61 | + | #define  bcmp(b1,b2,n)          memcmp(b1,b2,n) | 
| 62 | + | extern char  *memcpy(), *memset(); | 
| 63 | + | #define  index                  strchr | 
| 64 | + | #define  rindex                 strrchr | 
| 65 | + | #endif | 
| 66 | + |  | 
| 67 |  | extern char  *sskip(); | 
| 68 | < | extern char  *getpath(); | 
| 68 | > | extern char  *getpath(), *getenv(); | 
| 69 |  | extern char  *malloc(), *calloc(), *realloc(); | 
| 70 |  | extern char  *bmalloc(), *savestr(), *savqstr(); |