/*
 * Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
 * Use is subject to license terms.
 */

/*	Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T	*/
/*	  All Rights Reserved  	*/

/*
 * Copyright (c) 1980 Regents of the University of California.
 * All rights reserved. The Berkeley software License Agreement
 * specifies the terms and conditions for redistribution.
 */

#pragma ident	"%Z%%M%	%I%	%E% SMI"

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>

extern char *soutput, *tagout, usedir[];
union ptr {
	unsigned *a;
	long *b;
};

void
result(unsigned *mptr, int nf, FILE *fc)
{
	int i, c;
	char *s;
	long lp;
	extern int iflong;
	char res[100];
	union ptr master;

	if (iflong) {
		master.b = (long *)mptr;
	} else {
		master.a = mptr;
	}

	for (i = 0; i < nf; i++) {
		lp = iflong ? master.b[i] : master.a[i];
		fseek(fc, lp, 0);
		fgets(res, 100, fc);
		for (s = res; c = *s; s++)
			if (c == ';') {
				*s = 0;
				break;
			}
		if (tagout != 0) {
			if (res[0] == '/' || usedir[0] == 0)
				sprintf(tagout, "%s", res);
			else
				sprintf(tagout, "%s/%s", usedir, res);
			while (*tagout) tagout++;
		} else {
			if (res[0] != '/' || usedir[0] == 0)
				printf("%s/", usedir);
			printf("%s\n", res);
		}
	}
}

long
gdate(f)
FILE *f;
{
	struct stat sb;
	fstat(fileno(f), &sb);
	return (sb . st_mtime);
}