V7/usr/src/cmd/uucp/gnsys.c
#include "uucp.h"
#define LSIZE 30 /* number of systems to store */
#define WSUFSIZE 6 /* work file name suffix size */
/*******
* gnsys(sname, dir, pre)
* char *sname, *dir, pre;
*
* gnsys - this routine will return the next
* system name which has work to be done.
* "pre" is the prefix for work files.
* "dir" is the directory to search.
* "sname" is a string of size DIRSIZ - WSUFSIZE.
*
* return codes:
* 0 - no more names
* 1 - name returned in sname
* FAIL - bad directory
*/
gnsys(sname, dir, pre)
char *sname, *dir, pre;
{
char *s, *p1, *p2;
char px[3];
static char *list[LSIZE];
static int nitem=0, n=0;
char sysname[NAMESIZE], filename[NAMESIZE];
FILE *fp;
px[0] = pre;
px[1] = '.';
px[2] = '\0';
if (nitem == 0) {
/* get list of systems with work */
int i;
fp = fopen(dir, "r");
ASSERT(fp != NULL, "BAD DIRECTRY %s\n", dir);
for (i = 0; i < LSIZE; i++)
list[i] = NULL;
while (gnamef(fp, filename) != 0) {
if (!prefix(px, filename))
continue;
p2 = filename + strlen(filename)
- WSUFSIZE;
p1 = filename + strlen(px);
for(s = sysname; p1 <= p2; p1++)
*s++ = *p1;
*s = '\0';
if (sysname[0] == '\0')
continue;
if (callok(sysname) == 0)
nitem = srchst(sysname, list, nitem);
if (LSIZE <= nitem) break;
}
fclose(fp);
}
if (nitem == 0)
return(0);
if (nitem <= n ) {
for (n = 0; n < nitem; n++)
if (list[n] != NULL)
free(list[n]);
nitem = n = 0;
return(0);
}
strcpy(sname, list[n++]);
return(1);
}
/***
* srchst(name, list, n)
* char *name, **list;
* int n;
*
* srchst - this routine will do a linear search
* of list (list) to find name (name).
* If the name is not found, it is added to the
* list.
* The number of items in the list (n) is
* returned (incremented if a name is added).
*
* return codes:
* n - the number of items in the list
*/
srchst(name, list, n)
char *name, **list;
int n;
{
int i;
char *p;
extern char *calloc();
for (i = 0; i < n; i++)
if (strcmp(name, list[i]) == 0)
break;
if (i >= n) {
if ((p = calloc(strlen(name) + 1, sizeof (char)))
== NULL)
return(n);
strcpy(p, name);
list[n++] = p;
}
return(n);
}