V7/usr/src/cmd/uucp/uulog.c

Find at most related files.
including files from this version of Unix.

#include "uucp.h"
#include "uucpdefs.h"
#include <signal.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <sys/dir.h>

int Stop = 0;

/*******
 *
 *	uulog  -  this program will append all update files in
 *	directory (LOGDIR) to the log file (logf) and remove the
 *	update files.
 *
 *	options:
 *		-n  -  nominal time for delete of lock file
 *		-s  -  system name for search
 *		-u  -  user name for search
 *		-x  -  turn on debug outputs
 *
 *	exit codes:
 *		0  -  normal
 *		1  -  lock file problems
 *
 */


#define NOMTIME 3600L


main(argc, argv)
char *argv[];
{
	FILE *plogf, *lsp;
	char filename[NAMESIZE];
	time_t nomtime;
	char *system, *user;

	extern int onintr(), intr1();
	char buf[BUFSIZ], u[20], s[20];

	nomtime = NOMTIME;
	system = user = NULL;


	while (argc>1 && argv[1][0] == '-') {
		switch (argv[1][1]) {
		case 'd':
			printf("-d option removed\n");
			break;
		case 'n':
			nomtime = atoi(&argv[1][2]); break;
		case 's':
			system = &argv[1][2];
			break;
		case 'u':
			user = &argv[1][2];
			break;
		case 'x':
			Debug = atoi(&argv[1][2]);
			if (Debug <= 0)
				Debug = 1;
			break;
		default:
			printf("unknown flag %s\n", argv[1]); break;
		}
		--argc;  argv++;
	}

	DEBUG(4, "%s\n", "START");
	chdir(LOGDIR);
	if (ulockf(LOGLOCK, nomtime) != 0)
		exit(0);
	signal(SIGHUP, intr1);
	signal(SIGINT,intr1);
	signal(SIGQUIT, intr1);

	if ((plogf = fopen(LOGFILE, "a")) == NULL) {
		rmlock(LOGLOCK);
		printf("can't open %s\n", LOGFILE);
		exit(0);
	}
	lsp = fopen(LOGDIR, "r");
	ASSERT(lsp != NULL, "CAN NOT OPEN %s", LOGDIR);
	while ((gnamef(lsp, filename)) != 0) {
		DEBUG(4, "file-%s\n", filename);
		if (prefix(LOGPREFIX, filename)) {
			DEBUG(4, "copy file %s\n", filename);
			if (appendf(plogf, filename) == SUCCESS) {
				unlink(filename);
			}
		}
	}
	fclose(lsp);
	fclose(plogf);
	chmod(LOGFILE, 0666);
	rmlock(NULL);
	if (user == NULL && system == NULL)
		exit(0);
	if (Stop)
		exit(0);
	signal(SIGHUP, onintr);
	signal(SIGINT, onintr);
	signal(SIGQUIT, onintr);

	plogf = fopen(LOGFILE, "r");
	ASSERT(plogf != NULL, "CAN NOT OPEN %s", LOGFILE);
	while (fgets(buf, BUFSIZ, plogf) != NULL) {
		sscanf(buf, "%s%s", u, s);
		DEBUG(4, "u s %s ", u);
		DEBUG(4, "%s  ", s);
		DEBUG(4, "%s", buf);
		if (user != NULL && !prefix(user, u))
			continue;
		if (system != NULL && !prefix(system, s))
			continue;
		fputs(buf, stdout);
	}
	exit(0);
}




/***
 *	onintr()
 *
 *	onintr  -  interrupt routine
 *		remove lock file
 *
 */

onintr()
{
	rmlock(NULL);
	exit(0);
}


intr1()
{
	signal(SIGINT, intr1);
	signal(SIGHUP, intr1);
	signal(SIGQUIT, intr1);
	Stop = 1;
	return;
}

cleanup(code)
int code;
{
	exit(code);
}


/*******
 *	appendf(fp, entryf)	append file (entryf) to fp file
 *	FILE *fp;
 *	char *entryf;
 *
 *	return codes:
		SUCCESS - ok
 *		FAIL - file not readable
 */

appendf(fp, entryf)
FILE *fp;
char *entryf;
{
	FILE *pentryf;
	char ltext[513];

	if ((pentryf = fopen(entryf, "r")) == NULL) {
		/* file entryf not readable */
		return(FAIL);
	}
	while (fgets(ltext, 512, pentryf)) fputs(ltext, fp);
	fclose(pentryf);
	return(SUCCESS);
}