uutraf - UUCP statistics for HoneyDanBer
    Greg Hackney 
    news1 at texbell.swbt.com
       
    Mon Nov  6 08:26:57 AEST 1989
    
    
  
uutraf - Produces UUCP transfer statistics - HoneyDanBer (BNU) UUCP only
The program summarizes the output of the UUCP 'xferstats' program,
and gives the transfer statistics by system, giving such things as
the average transmission speed, connect time, and the volume of traffic.
Command line options can be specified for sorting the output by volume,
connect time, xfer rates, etc. For speed and security, the program is
C (no shell calls), and requires no special privileges to run.
Thanks to Doug Davis and David Butler for the sorting functions and
other stuff they did.
--
Greg Hackney
hack at texbell.swbt.com
#! /bin/sh
# This is a shell archive.  Remove anything before this line, then unpack
# it by saving it into a file and typing "sh file".  To overwrite existing
# files, type "sh file -c".  You can also feed this as standard input via
# unshar, or by typing "sh <file", e.g..  If this archive is complete, you
# will see the following message at the end:
#		"End of archive 1 (of 1)."
# Contents:  Makefile defs.h uutraf.1 uutraf.c uutraf.h uutraf.nro
# Wrapped by root at texbell on Sun Nov  5 15:09:20 1989
PATH=/bin:/usr/bin:/usr/ucb ; export PATH
if test -f 'Makefile' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'Makefile'\"
else
echo shar: Extracting \"'Makefile'\" \(948 characters\)
sed "s/^X//" >'Makefile' <<'END_OF_FILE'
X#       @(#) FILE:	Makefile
X#       @(#) Release:	1.1
X#       @(#) Rel. Date:	11/5/89
X#       @(#) Author: Greg Hackney (hack at texbell.swbt.com)
X#
X#     Makefile for uutraf
X#
X#     Usage:
X#     make uutraf
X#     make man
X#     make install
X#     make clean
X#     make clobber
X#     make shar
X
XBIN=/usr/lbin
X
XCFLAGS = -O
X
XCATMAN = /usr/catman/l_man/man1
X
XFORMATTER = nroff -man
X
XOBJECTS = uutraf.o
XSOURCES = uutraf.c
XINCLUDES = uutraf.h defs.h
X
X
Xdefault: all
X
Xall: uutraf man
X
Xman: uutraf.man
X
Xuutraf: $(OBJECTS)
X	cc $(CFLAGS) $(LFLAGS) $(OBJECTS) -o uutraf $(LIBS)
X
X$(OBJECTS): $(INCLUDES)
X	cc $(CFLAGS) -c $<
X
Xuutraf.man: uutraf.1
X	$(FORMATTER) uutraf.1 > uutraf.man
X
Xinstall: all
X	cp uutraf $(BIN)/uutraf
X	chmod 755 $(BIN)/uutraf
X	cp uutraf.man $(CATMAN)/uutraf.1
X	chmod 644 $(CATMAN)/uutraf.1
X	pack $(CATMAN)/uutraf.1
X
Xclean:
X	rm -f *.o
X
Xclobber: clean
X	rm -f uutraf uutraf.man
X
Xshar:
X	shar Makefile uutraf.1 $(INCLUDES) $(SOURCES) > uutraf.shar
END_OF_FILE
if test 948 -ne `wc -c <'Makefile'`; then
    echo shar: \"'Makefile'\" unpacked with wrong size!
fi
# end of 'Makefile'
fi
if test -f 'defs.h' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'defs.h'\"
else
echo shar: Extracting \"'defs.h'\" \(1386 characters\)
sed "s/^X//" >'defs.h' <<'END_OF_FILE'
X/*
X
X       @(#) FILE:	defs.h
X       @(#) Release:	1.1
X       @(#) Rel. Date:	11/5/89
X       @(#) Author:     Greg Hackney (hack at texbell.swbt.com)
X
X*/
X
X/* This file contains user defined parameters */
X
X
X#define STATFILE "/usr/spool/uucp/.Admin/xferstats"
X		/* default HDB style xferstats file */
X
X/* default way to sort */
X#define DEFAULT (RECEIVED | XMIT) /* Total number of bytes */
X
X/* you can instead pick from one of these for the default sorting method.
X	Sort by number of bytes
X	#define DEFAULT (RECEIVED)
X	#define DEFAULT (XMIT)
X	#define DEFAULT (RECEIVED | XMIT)
X	#define DEFAULT (RECEIVED | REVERSE)
X	#define DEFAULT (XMIT | REVERSE)
X	#define DEFAULT (RECEIVED | XMIT | REVERSE)
X
X	Sort by transfer rate
X	#define DEFAULT (R_CPS)
X	#define DEFAULT (X_CPS)
X	#define DEFAULT (R_CPS | X_CPS)
X	#define DEFAULT (R_CPS | REVERSE)
X	#define DEFAULT (X_CPS | REVERSE)
X	#define DEFAULT (R_CPS | X_CPS | REVERSE)
X
X	Sort by number of file transactions
X	#define DEFAULT (R_NUMB)
X	#define DEFAULT (X_NUMB)
X	#define DEFAULT (R_NUMB | X_NUMB)
X	#define DEFAULT (R_NUMB | REVERSE)
X	#define DEFAULT (X_NUMB | REVERSE)
X	#define DEFAULT (R_NUMB | X_NUMB | REVERSE)
X
X	Sort by modem clock time
X	#define DEFAULT (R_TIME)
X	#define DEFAULT (X_TIME)
X	#define DEFAULT (X_TIME | R_TIME)
X	#define DEFAULT (R_TIME | REVERSE)
X	#define DEFAULT (X_TIME | REVERSE)
X	#define DEFAULT (X_TIME | R_TIME | REVERSE)
X	*/
X
END_OF_FILE
if test 1386 -ne `wc -c <'defs.h'`; then
    echo shar: \"'defs.h'\" unpacked with wrong size!
fi
# end of 'defs.h'
fi
if test -f 'uutraf.1' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'uutraf.1'\"
else
echo shar: Extracting \"'uutraf.1'\" \(1356 characters\)
sed "s/^X//" >'uutraf.1' <<'END_OF_FILE'
X.TH UUTRAF USENET
X.SH NAME
Xuutraf
X- UUCP file transfer statistics 
X.SH SYNOPSIS
X.B uutraf
X[options] [xferstat_file | -]
X.br
X.SH DESCRIPTION
X.I uutraf
Xanalyzes uucp log files, and provides a report on transfer statistics,
Xusing a default sorting format, or an optional user specified sorting format.
X.SH OPTIONS
X.B \-s
Xtake the input from stdin rather than a file.
X.br
X.sp
XSorting Options:
X.br
X.B \-b[r|x|b]
Xby number of bytes  <r>ecd, <x>mit, or <b>oth.
X.br
X.B \-c[r|x|b]
Xby transfer rate in <r>ecv, <x>mit, or <b>oth.
X.br
X.B \-n[r|x|b]
Xby number of files  <r>ecd, <x>mit, or <b>oth.
X.br
X.B \-t[r|x|b]
Xby connect time in  <r>ecv, <x>mit, or <b>oth.
X.br
X.B \-a
Xsort in asending order, rather than desending.
X.br
X.SH EXAMPLES
X.B uutraf \-bb
Xwill display the total bytes transfered, in desending order.
XThis is also the default sorting method.
X.PP
X.B uutraf \-cx
Xwill display the connections with the fastest transfer rates,
Xin decending order.
X.PP
X.B uutraf \-txa
Xwill display the connections by total amount of modem connect time,
Xin ascending sort order.
X.PP
X.SH BUGS
XOnly works with HoneyDanBer (BNU) UUCP systems.
X.br
XMultiple sorting options may not work as you would hope.
X.SH NOTES
XComments and bug reports are welcomed.
X.SH AUTHOR
XGreg Hackney, hack at texbell.swbt.com
X.br
X.SH CONTRIBUTORS
XDoug Davis, doug at letni.uucp
X.br
XDavid Butler, gdb at ninja.uucp
X
END_OF_FILE
if test 1356 -ne `wc -c <'uutraf.1'`; then
    echo shar: \"'uutraf.1'\" unpacked with wrong size!
fi
# end of 'uutraf.1'
fi
if test -f 'uutraf.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'uutraf.c'\"
else
echo shar: Extracting \"'uutraf.c'\" \(10769 characters\)
sed "s/^X//" >'uutraf.c' <<'END_OF_FILE'
X/*
X
X       @(#) FILE:	uutraf.c
X       @(#) Release:	1.1
X       @(#) Rel. Date:	11/5/89
X       @(#) Author:     Greg Hackney (hack at texbell.swbt.com)
X
X*/
X
Xstatic char sccsid[] = "@(#) file uutraf.c : rel 1.1 : mod 11/5/89";
X
X#include "uutraf.h"
X#include "defs.h"
X
Xstatic char
XLog_name[1024]=STATFILE; /* name of BNU style xfer file, see defs.h */
X
Xstatic
Xfloat	bytes_recv, /* total bytes received */
X	bytes_xmit, /* total bytes transbitted */
X	sec_recv,  /* total seconds spent in receive */
X	sec_xmit;  /* total seconds spent in transmit */
X
Xstatic
Xlong
X	num_recv,   /* total number of files received */
X	num_xmit;   /* total number of files transmitted */
X
Xmain(argc, argv)
Xint argc;
Xchar *argv[];
X{
X	int how = 0;         /* default sort method, see defs.h  */
X	register LINK *slot; /* pointer to element               */
X	float bytes,	     /* number of bytes in the uucp xfer */
X    	seconds;             /* number of seconds the xfer took  */
X	int c;
X
X
X	/*Check for options*/
X	while(( c = getopt(argc,argv, "ab:c:n:t:s")) != EOF){
X		switch(c) {
X		case 'a':   /* sort in ascending vs. descending order */
X			how |= REVERSE;
X			break;
X		case 'b':   /* sort by bytes xmitted and/or received */
X			switch(*optarg) {
X			case 'b':
X				how |= (RECEIVED | XMIT);
X				break;
X			case 'r':
X				how |= RECEIVED;
X				break;
X			case 'x':
X				how |= XMIT;
X				break;
X			default:
X				usage_err(argv[0]);
X				break;
X			}
X			break;
X		case 'c':   /* sort by xfer rate xmitted and/or received */
X			switch(*optarg) {
X			case 'b':
X				how |= (R_CPS | X_CPS);
X				break;
X			case 'r':
X				how |= R_CPS;
X				break;
X			case 'x':
X				how |= X_CPS;
X				break;
X			default:
X				usage_err(argv[0]);
X				break;
X			}
X			break;
X		case 'n':   /* number of transactions */
X			switch(*optarg) {
X			case 'b':
X				how |= (R_NUMB | X_NUMB);
X				break;
X			case 'r':
X				how |= R_NUMB;
X				break;
X			case 'x':
X				how |= X_NUMB;
X				break;
X			default:
X				usage_err(argv[0]);
X				break;
X			}
X			break;
X		case 't':   /* sort by clock time */
X			switch(*optarg) {
X			case 'b':
X				how |= (R_TIME | X_TIME);
X				break;
X			case 'r':
X				how |= R_TIME;
X				break;
X			case 'x':
X				how |= X_TIME;
X				break;
X			default:
X				usage_err(argv[0]);
X				break;
X			}
X			break;
X		case 's':   /* Use stdin instead of normal xferstat file */
X			logfile = stdin;
X			break;
X		default:
X			usage_err(argv[0]);
X			break;
X		}
X	}
X
X	/* Use default sorting method if none was chosen */
X	if ((how == REVERSE) || !how)
X		how |= DEFAULT;
X
X	if(argc != optind) {	/*input from an optional file name*/
X		if((argc - optind) > 1) /*more than 1 file*/
X			usage_err(argv[0]);
X		if(logfile != (FILE *)NULL) /* If stdin was already specified */
X			usage_err(argv[0]);
X		strcpy(Log_name, argv[--argc]);
X		if((strcmp(Log_name,"-"))==0)
X			logfile=stdin;
X		}
X	else {
X		if(logfile == (FILE *)NULL)
X			strcpy(Log_name,STATFILE);
X		}
X		
X	/* See if specified file can be read */
X	if (logfile == (FILE *) NULL){ /* not stdin */
X		if((logfile=fopen(Log_name, "r"))==NULL){
X			fprintf(stderr,"%s: Can't open the xferstat file %s for reading\n",argv[0],Log_name);
X			exit(1);
X			}
X	}
X	/* initialize the linked list */
X	record = (LINK *) NULL;
X
X	while (fgets(buf, 512, logfile) != NULL) {
X
X		/* look for the node name */
X		if ((sys = strtok(buf, "!")) == NULL) {
X			continue;
X		}
X
X		/* skip over unwanted data up to the "]" in the string */
X		if ((string = strtok((char *) NULL, "]")) == NULL) {
X			continue;
X		}
X
X		/* parse the remainder of the data string */
X		if ((string = strtok((char *) NULL, "\n")) == NULL) {
X			continue;
X		}
X
X		/* convert the information */
X		if (sscanf(string, "%s %f / %f",
X		    flow, &bytes, &seconds) == EOF) {
X			continue;
X		}
X
X		if (strcmp(flow, OUT) == 0) {  /* outgoing uucp */
X			/* assign an array slot for this node name */
X			if ((slot = getslot(sys)) == (LINK *) NULL) {
X				exit(1);
X			}
X			slot->xmit += bytes;
X			slot->xmit_time += seconds;
X			slot->xmit_cnt++;
X			bytes_xmit += bytes; /* summary totals */
X			sec_xmit += seconds;
X			num_xmit++;
X		} else if (strcmp(flow, IN) == 0) {  /* incoming uucp */
X			/* assign an array slot for this node name */
X			if ((slot = getslot(sys)) == (LINK *) NULL) {
X				exit(1);
X			}
X			slot->recv += bytes;
X			slot->recv_time += seconds;
X			slot->recv_cnt++;
X			bytes_recv += bytes; /* summary totals */
X			sec_recv += seconds;
X			num_recv++;
X		}
X	}
X	sortrun(how);	/* sort it */
X	printrun();	/* print it out */
X	fclose(logfile);
X	exit(0);
X}
X
Xstatic LINK *
Xgetslot(s)   /* returns an link struct to the system name specified. */
Xchar *s;
X{
X	LINK *work, *last;
X
X	work = record;
X	if (work == (LINK *) NULL) { /* must be the first time thru */
X		work = (LINK *) malloc(sizeof(LINK) + strlen(s));
X		if (work == (LINK *) NULL) {
X			perror("getslot() malloc() failed, returning NULL -- ");
X			return(work);
X		}
X		zeroit(work);
X		strcpy(work->sysname, s);
X		record = work;
X		return(work);
X	}
X
X	while (work != (LINK *) NULL){
X		if (!strcmp(work->sysname, s)) {
X			return(work);
X		}
X		last = work;
X		work = work->next;
X	}
X
X	/* create a new link */
X	if ((work = (LINK *) malloc(sizeof(LINK) + strlen(s))) ==
X	    (LINK *) NULL) {
X		perror("getslot() malloc() failed, returning NULL -- ");
X		return(work);
X	}
X
X	zeroit(work);
X	last->next = work;
X	work->prev = last;
X	strcpy(work->sysname, s);
X	return(work);
X}
X
Xstatic
Xzeroit(l)
XLINK *l;
X{
X	/* added for portability vs. memset/bzero */
X	l->prev		= (LINK *) NULL;
X	l->next		= (LINK *) NULL;
X	l->recv         = 0.0;
X	l->recv_time    = 0.0;
X	l->recv_cnt     = 0L;
X	l->xmit		= 0.0;
X	l->xmit_time    = 0.0;
X	l->xmit_cnt     = 0L;
X	l->sysname[0]	= '\0';
X}
X
Xprintrun()
X{
X	LINK *work;
X	int count;
X
X	printf("%-8s ", "Remote");
X	printf("%9s ", "K-Bytes");
X	printf("%9s ", "K-Bytes");
X	printf("%9s ", "K-Bytes");
X	printf("%6s ", "Hours");
X	printf("%6s ", "Hours");
X	printf("%5s ", "AvCPS");
X	printf("%5s ", "AvCPS");
X	printf("%4s ", "#");
X	printf("%4s\n", "#");
X
X	printf("%-8s ", "SiteName");
X	printf("%9s ", "Recv");
X	printf("%9s ", "Xmit");
X	printf("%9s ", "Total");
X	printf("%6s ", "Recv");
X	printf("%6s ", "Xmit");
X	printf("%5s ", "Recv");
X	printf("%5s ", "Xmit");
X	printf("%4s ", "Recv");
X	printf("%4s\n", "Xmit");
X
X	printf("%s ", "--------");
X	printf("%s ", "---------");
X	printf("%s ", "---------");
X	printf("%s ", "---------");
X	printf("%s ", "------");
X	printf("%s ", "------");
X	printf("%s ", "-----");
X	printf("%s ", "-----");
X	printf("%s ", "----");
X	printf("%s\n", "----");
X
X	for (work = record; work != (LINK *) NULL;) {
X		count++;
X		strncpy(buf, work->sysname, 9);
X		buf[9]='\0';
X		printf("%-9s", buf);
X		sprintf(buf, "%.3f", work->recv / 1000);
X		printf("%9s ", buf);
X		sprintf(buf, "%.3f", work->xmit / 1000);
X		printf("%9s ", buf);
X		sprintf(buf, "%.3f", (work->xmit + work->recv) / 1000);
X		printf("%9s ", buf);
X		sprintf(buf, "%.2f", work->recv_time / 3600);
X		printf("%6s ", buf);
X		sprintf(buf, "%.2f", work->xmit_time / 3600);
X		printf("%6s ", buf);
X		if (work->recv_time != 0.0) { /* divide by zero ? */
X			sprintf(buf, "%5.0f", work->recv / work->recv_time);
X		} else {
X			sprintf(buf, "0");
X		}
X		printf("%5s ", buf);
X		if(work->xmit_time != 0.0) { /* divide by zero ? */
X			sprintf(buf, "%5.0f", work->xmit / work->xmit_time);
X		} else {
X			sprintf(buf, "0");
X		}
X		printf("%5s ", buf);
X		printf("%4d ", work->recv_cnt);
X		printf("%4d\n", work->xmit_cnt);
X		work = work->next;
X	}
X	/* summary statement at the end */
X	printf("\n-----<Summary>-----\n");
X	printf("Total active uucp sites:   ");
X	sprintf(buf,"%d",count); comma_fy();
X	printf("%8s\n\n",buf);
X
X	/* total files */
X	printf("Total files rec'd:  ");
X	sprintf(buf,"%ld",num_recv); comma_fy();
X	printf("%15s\n",buf);
X	printf("Total files xmit:   ");
X	sprintf(buf,"%ld",num_xmit); comma_fy();
X	printf("%15s\n",buf);
X	printf("Total files:        ");
X	sprintf(buf,"%ld",num_xmit + num_recv); comma_fy();
X	printf("%15s\n\n",buf);
X
X	/* total time */
X	printf("Total hours in recv: ");
X	sprintf(buf,"%.2f",sec_recv / 3600);
X	printf("%14s\n",buf);
X	printf("Total hours in xmit: ");
X	sprintf(buf,"%.2f",sec_xmit / 3600);
X	printf("%14s\n",buf);
X	printf("Total modem hours:  ");
X	sprintf(buf,"%.2f",(sec_recv + sec_xmit) / 3600);
X	printf("%15s\n\n",buf);
X
X	/* total bytes */
X	printf("Total bytes rec'd:  ");
X	sprintf(buf,"%.0f",bytes_recv); comma_fy();
X	printf("%15s\n",buf);
X	printf("Total bytes xmit:   ");
X	sprintf(buf,"%.0f",bytes_xmit); comma_fy();
X	printf("%15s\n",buf);
X	printf("Total bytes:        ");
X	sprintf(buf,"%.0f",bytes_xmit + bytes_recv); comma_fy();
X	printf("%15s\n\n",buf);
X
X}
X
Xcomma_fy()  /* put commas in long numeric strings contained in buf[] */
X{
X	int i, ii, cnt;
X	char backw[25];
X
X	/* put string backwards inserting commas */
X	for(ii=0, cnt=0,i=strlen(buf) - 1; i >= 0 ; i--){
X		backw[ii++] = buf[i];
X		if(++cnt == 3){
X			if(buf[i-1] != '\0')
X				backw[ii++] = ',';
X			cnt = 0;
X		}
X	}
X	backw[ii] = '\0';
X
X	/* put string forward */
X	for(ii=0, cnt=0,i=strlen(backw) - 1; i >= 0 ; i--)
X		buf[ii++] = backw[i];
X	buf[ii]='\0';
X
X}
X
Xsortrun(how) 
Xunsigned short how;
X{
X	LINK *work;
X	int swapped;
X
X	do {
X		for (swapped = 0, work = record; work->next != (LINK *) NULL;) {
X			if (do_test(work, work->next, how) < 0) {
X				if (work->prev != (LINK *) NULL) {
X					work->prev->next = work->next;
X				} else {
X					record = work->next;
X				}
X				work->next->prev = work->prev;
X				work->prev = work->next;
X				if (work->next->next != (LINK *) NULL) {
X					work->next->next->prev = work;
X				}
X				work->next = work->next->next;
X				/* this is the weird one */
X				/* (work->prev was work->next) */
X				work->prev->next = work;
X				swapped = 1;
X			} else {
X				work = work->next;
X			}
X		}
X	} while (swapped);
X}
X
Xdo_test(a, b, how)
XLINK *a, *b;
Xunsigned short how;
X{
X	LINK *c;
X	long aw = 0L, bw = 0L;
X
X	/* reverse the sort, least to most */
X	if (how & REVERSE) {
X		/* swap the pointers around, faster than a complex if */
X		c = a;
X		a = b;
X		b = c;
X	}
X	if (how & RECEIVED) {
X		aw += a->recv;
X		bw += b->recv;
X	}
X	if (how & XMIT) {
X		aw += a->xmit;
X		bw += b->xmit;
X	}
X	if (how & R_TIME) {
X		aw += (long) a->recv_time;
X		bw += (long) b->recv_time;
X	}
X	if (how & X_TIME) {
X		aw += (long) a->xmit_time;
X		bw += (long) b->xmit_time;
X	}
X	if (how & R_CPS) {
X		if (a->recv_time != 0.0) {
X			aw += (long) (a->recv / a->recv_time);
X		}
X		if (b->recv_time != 0.0) {
X			bw += (long) (b->recv / b->recv_time);
X		}
X	}
X	if (how & X_CPS) {
X		if (a->xmit_time != 0.0) {
X			aw += (long) (a->xmit / a->xmit_time);
X		}
X		if (b->xmit_time != 0.0) {
X			bw += (long) (b->xmit / b->xmit_time);
X		}
X	}
X	if (how & R_NUMB) {
X		aw += a->recv_cnt;
X		bw += b->recv_cnt;
X	}
X	if (how & X_NUMB) {
X		aw += a->xmit_cnt;
X		bw += b->xmit_cnt;
X	}
X	return(aw - bw);
X}
Xusage_err(arg0)
Xchar *arg0;
X{
X	fprintf(stderr,"Usage: %s [options] [xferstat_file | -]\n", arg0);
X	fprintf(stderr,"%s\n",usage);
X	exit(1);
X}
X
END_OF_FILE
if test 10769 -ne `wc -c <'uutraf.c'`; then
    echo shar: \"'uutraf.c'\" unpacked with wrong size!
fi
# end of 'uutraf.c'
fi
if test -f 'uutraf.h' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'uutraf.h'\"
else
echo shar: Extracting \"'uutraf.h'\" \(2290 characters\)
sed "s/^X//" >'uutraf.h' <<'END_OF_FILE'
X/*
X
X       @(#) FILE:	uutraf.h
X       @(#) Release:	1.1
X       @(#) Rel. Date:	11/5/89
X       @(#) Author:     Greg Hackney (hack at texbell.swbt.com)
X
X*/
X
X#include <stdio.h>
X#include <string.h>
X
X
X/* these defines are part of the sort routine to figure out how
X * to sort the linked list 
X */
X#define REVERSE  0x0001  /* reverse the order, least to most */
X#define RECEIVED 0x0002  /* sort by received */
X#define XMIT     0x0004  /* sort by xmit */
X#define R_TIME   0x0010  /* sort by received time */
X#define X_TIME   0x0020  /* sort by xmit time */
X#define R_CPS    0x0100  /* sort by characters RECEIVED per second */
X#define X_CPS    0x0200  /* sort by characters TRANSMITTED per second */
X#define R_NUMB   0x1000  /* sort by number of RECEIVED transactions */
X#define X_NUMB   0x2000  /* sort by number of TRANSMITTED transactions */
X
X#define OUT	"->"  /*uucp flow direction indicator*/
X#define IN	"<-"  /*uucp flow direction indicator*/
X
Xtypedef struct link {
X	struct link *prev;	/* pointer to the previous entry */
X	struct link *next;	/* pointer to the next entry */
X	float recv;		/* num of bytes rec'd from remote system */
X	float recv_time; 	/* total seconds spent in receive */
X	long recv_cnt;		/* total number of files received */
X	float xmit;		/* num of bytes sent to remote system */
X	float xmit_time; 	/* total seconds spent in transmit */
X	long xmit_cnt;		/* total number of files sent */
X	char sysname[1];	/* name of remote system */
X} LINK;
X
X
Xstatic
XFILE	*logfile = (FILE *) NULL;  /* file pointer to the xferstats file */
X
Xstatic
XLINK *record = (LINK *) NULL, *getslot();
X
Xstatic
Xchar	*sys,		/* holds the name of the previous remote node name */
X	flow[10],	/* holds the direction of uucp flow */
X	buf[512],	/* general purpose */
X	*string;	/* general purpose */
X
Xstatic
Xfloat	bytes,		/* number of bytes in the uucp xfer */
X	seconds;	/* number of seconds the xfer took */
X
Xchar	*malloc(), *optarg;
Xint optind;
X
Xchar usage[]="\n\
X-s       use standard input instead of default xferstats file\n\
X-b[rxb]  sort by total bytes rec'd, xmit'ed, or both\n\
X-c[rxb]  sort by chars per second rec'd, xmit'ed, or both\n\
X-n[rxb]  sort by # of files rec'd, xmit'ed, or both\n\
X-t[rxb]  sort by total clock time in rec, xmit, or both\n\
X-a       sort in ascending vs. descending order\n";
END_OF_FILE
if test 2290 -ne `wc -c <'uutraf.h'`; then
    echo shar: \"'uutraf.h'\" unpacked with wrong size!
fi
# end of 'uutraf.h'
fi
if test -f 'uutraf.nro' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'uutraf.nro'\"
else
echo shar: Extracting \"'uutraf.nro'\" \(1657 characters\)
sed "s/^X//" >'uutraf.nro' <<'END_OF_FILE'
X
X
X
X     UUTRAF(USENET)            UNIX System V            UUTRAF(USENET)
X
X
X
X     NAME
X          uutraf - UUCP file transfer statistics
X
X     SYNOPSIS
X          uutraf [options] [xferstat_file | -]
X
X     DESCRIPTION
X          uutraf analyzes uucp log files, and provides a report on
X          transfer statistics, using a default sorting format, or an
X          optional user specified sorting format.
X
X     OPTIONS
X          -s take the input from stdin rather than a file.
X
X          Sorting Options:
X          -b[r|x|b] by number of bytes  <r>ecd, <x>mit, or <b>oth.
X          -c[r|x|b] by transfer rate in <r>ecv, <x>mit, or <b>oth.
X          -n[r|x|b] by number of files  <r>ecd, <x>mit, or <b>oth.
X          -t[r|x|b] by connect time in  <r>ecv, <x>mit, or <b>oth.
X          -a sort in asending order, rather than desending.
X
X     EXAMPLES
X          uutraf -bb will display the total bytes transfered, in
X          desending order.  This is also the default sorting method.
X
X          uutraf -cx will display the connections with the fastest
X          transfer rates, in decending order.
X
X          uutraf -txa will display the connections by total amount of
X          modem connect time, in ascending sort order.
X
X     BUGS
X          Only works with HoneyDanBer (BNU) UUCP systems.
X          Multiple sorting options may not work as you would hope.
X
X     NOTES
X          Comments and bug reports are welcomed.
X
X     AUTHOR
X          Greg Hackney, hack at texbell.swbt.com
X
X     CONTRIBUTORS
X          Doug Davis, doug at letni.uucp
X          David Butler, gdb at ninja.uucp
X
X
X
X
X
X
X
X
X
X
X
X     Page 1                                          (printed 11/5/89)
X
X
X
END_OF_FILE
if test 1657 -ne `wc -c <'uutraf.nro'`; then
    echo shar: \"'uutraf.nro'\" unpacked with wrong size!
fi
# end of 'uutraf.nro'
fi
echo shar: End of archive 1 \(of 1\).
cp /dev/null ark1isdone
MISSING=""
for I in 1 ; do
    if test ! -f ark${I}isdone ; then
	MISSING="${MISSING} ${I}"
    fi
done
if test "${MISSING}" = "" ; then
    echo You have the archive.
    rm -f ark[1-9]isdone
else
    echo You still need to unpack the following archives:
    echo "        " ${MISSING}
fi
##  End of shell archive.
exit 0
    
    
More information about the Alt.sources
mailing list