--- ray/src/common/fropen.c 1990/12/08 09:28:15 1.1 +++ ray/src/common/fropen.c 1992/09/08 09:09:23 2.4 @@ -1,4 +1,4 @@ -/* Copyright (c) 1990 Regents of the University of California */ +/* Copyright (c) 1992 Regents of the University of California */ #ifndef lint static char SCCSid[] = "$SunId$ LBL"; @@ -10,20 +10,16 @@ static char SCCSid[] = "$SunId$ LBL"; #include -#ifndef DEFPATH -#define DEFPATH ":/usr/local/lib/ray" -#endif -#ifndef ULIBVAR -#define ULIBVAR "RAYPATH" -#endif +#include "paths.h" +char *libpath = NULL; /* library search path */ + FILE * fropen(fname) /* find file and open for reading */ register char *fname; { - extern char *strcpy(), *getenv(); - static char *searchpath; + extern char *strcpy(); FILE *fp; char pname[256]; register char *sp, *cp; @@ -31,22 +27,22 @@ register char *fname; if (fname == NULL) return(NULL); - if (fname[0] == '/' || fname[0] == '.') /* absolute path */ + if (fname[0] == DIRSEP || fname[0] == '.') /* absolute path */ return(fopen(fname, "r")); - if (searchpath == NULL) { /* get search path */ - searchpath = getenv(ULIBVAR); - if (searchpath == NULL) - searchpath = DEFPATH; + if (libpath == NULL) { /* get search path */ + libpath = getenv(ULIBVAR); + if (libpath == NULL) + libpath = DEFPATH; } /* check search path */ - sp = searchpath; + sp = libpath; do { cp = pname; - while (*sp && (*cp = *sp++) != ':') + while (*sp && (*cp = *sp++) != PATHSEP) cp++; - if (cp > pname && cp[-1] != '/') - *cp++ = '/'; + if (cp > pname && cp[-1] != DIRSEP) + *cp++ = DIRSEP; strcpy(cp, fname); if ((fp = fopen(pname, "r")) != NULL) return(fp); /* got it! */