This is searchp.c in view mode; [Download] [Up]
/* * Copyright (c) 1990 Carnegie Mellon University * All Rights Reserved. * * Permission to use, copy, modify and distribute this software and its * documentation is hereby granted, provided that both the copyright * notice and this permission notice appear in all copies of the * software, derivative works or modified versions, and any portions * thereof, and that both notices appear in supporting documentation. * * THE SOFTWARE IS PROVIDED "AS IS" AND CARNEGIE MELLON UNIVERSITY * DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT * SHALL CARNEGIE MELLON UNIVERSITY BE LIABLE FOR ANY SPECIAL, DIRECT, * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF * CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. * * Users of this software agree to return to Carnegie Mellon any * improvements or extensions that they make and grant Carnegie the * rights to redistribute these changes. * * Export of this software is permitted only after complying with the * regulations of the U.S. Deptartment of Commerce relating to the * Export of Technical Data. */ /* searchp -- search through pathlist for file * * Usage: p = searchp (path,file,fullname,func); * char *p, *path, *file, *fullname; * int (*func)(); * * Searchp will parse "path", a list of pathnames separated * by colons, prepending each pathname to "file". The resulting * filename will be passed to "func", a function provided by the * user. This function must return zero if the search is * successful (i.e. ended), and non-zero if the search must * continue. If the function returns zero (success), then * searching stops, the full filename is placed into "fullname", * and searchp returns 0. If the pathnames are all unsuccessfully * examined, then searchp returns -1. * If "file" begins with a slash, it is assumed to be an * absolute pathname and the "path" list is not used. Note * that this rule is used by Bell's cc also; whereas Bell's * sh uses the rule that any filename which CONTAINS a slash * is assumed to be absolute. The execlp and execvp procedures * also use this latter rule. In my opinion, this is bogosity. * * HISTORY * $Log: searchp.c,v $ * Revision 1.2 90/12/11 17:58:36 mja * Add copyright/disclaimer for distribution. * * 01-Apr-86 Rudy Nedved (ern) at Carnegie-Mellon University * 4.1BSD system ignores trailing slashes. 4.2BSD does not. * Therefore don't add a seperating slash if there is a null * filename. * * 23-Oct-82 Steven Shafer (sas) at Carnegie-Mellon University * Fixed two bugs: (1) calling function as "func" instead of * "(*func)", (2) omitting trailing null name implied by trailing * colon in path. Latter bug fixed by introducing "lastchar" and * changing final loop test to look for "*lastchar" instead of * "*nextpath". * * 20-Nov-79 Steven Shafer (sas) at Carnegie-Mellon University * Created for VAX. If you're thinking of using this, you probably * should look at openp() and fopenp() (or the "want..." routines) * instead. * */ int searchp (path,file,fullname,func) char *path,*file,*fullname; int (*func)(); { register char *nextpath,*nextchar,*fname,*lastchar; int failure; nextpath = ((*file == '/') ? "" : path); do { fname = fullname; nextchar = nextpath; while (*nextchar && (*nextchar != ':')) *fname++ = *nextchar++; if (nextchar != nextpath && *file) *fname++ = '/'; lastchar = nextchar; nextpath = ((*nextchar) ? nextchar + 1 : nextchar); nextchar = file; /* append file */ while (*nextchar) *fname++ = *nextchar++; *fname = '\0'; failure = (*func) (fullname); } while (failure && (*lastchar)); return (failure ? -1 : 0); }
These are the contents of the former NiCE NeXT User Group NeXTSTEP/OpenStep software archive, currently hosted by Netfuture.ch.