/* * 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); }