1
0
mirror of https://frontier.innolan.net/rainlance/amiga-tz.git synced 2025-12-06 21:44:59 +00:00
Files
amiga-tz/zdump.c
Arthur David Olson 3d736e3275 new format
SCCS-file: zdump.c
SCCS-SID: 2.9
2012-07-18 03:01:39 -04:00

161 lines
3.3 KiB
C

#
#include "stdio.h"
#ifdef OBJECTID
static char sccsid[] = "%W%";
#endif
#include "time.h"
#include "tzfile.h"
#ifndef TRUE
#define TRUE 1
#define FALSE 0
#endif
extern char * asctime();
extern struct tm * gmtime();
extern int optind;
extern char * sprintf();
extern long time();
extern char * tz_abbr;
static int longest;
static long
tzdecode(codep)
char * codep;
{
register int i;
register long result;
result = 0;
for (i = 0; i < 4; ++i)
result = (result << 8) | (codep[i] & 0xff);
return result;
}
main(argc, argv)
int argc;
char * argv[];
{
register FILE * fp;
register int i, j, c;
register int vflag;
long now;
int timecnt;
char buf[BUFSIZ];
vflag = 0;
while ((c = getopt(argc, argv, "v")) == 'v')
vflag = 1;
if (c != EOF || optind == argc - 1 && strcmp(argv[optind], "=") == 0) {
(void) fprintf(stderr, "%s: usage is %s [ -v ] zonename ...\n",
argv[0], argv[0]);
exit(1);
}
(void) time(&now);
longest = 0;
for (i = optind; i < argc; ++i)
if (strlen(argv[i]) > longest)
longest = strlen(argv[i]);
for (i = optind; i < argc; ++i) {
if (settz(argv[i]) != 0) {
(void) fprintf(stderr, "%s: settz(\"%s\") failed\n",
argv[0], argv[i]);
exit(1);
}
show(argv[i], now, FALSE);
if (!vflag)
continue;
if (argv[i][0] == '/')
fp = fopen(argv[i], "r");
else {
j = strlen(TZDIR) + 1 + strlen(argv[i]) + 1;
if (j > sizeof buf) {
(void) fprintf(stderr,
"%s: timezone name %s/%s is too long\n",
argv[0], TZDIR, argv[i]);
exit(1);
}
(void) sprintf(buf, "%s/%s", TZDIR, argv[i]);
fp = fopen(buf, "r");
}
if (fp == NULL) {
(void) fprintf(stderr, "%s: Can't open ", argv[0]);
perror(argv[i]);
exit(1);
}
{
struct tzhead * tzhp;
char code[4];
(void) fseek(fp, (long) sizeof tzhp->tzh_reserved, 0);
if (fread((char *) code, sizeof code, 1, fp) != 1)
readerr(fp, argv[0], argv[i]);
timecnt = tzdecode(code);
(void) fseek(fp, (long) (2 * sizeof code), 1);
}
show(argv[i], 0x80000000, TRUE);
show(argv[i], 0x80000000 + 24 * 60 * 60, TRUE);
for (j = 0; j < timecnt; ++j) {
char code[4];
long t;
if (fread((char *) code, sizeof code, 1, fp) != 1)
readerr(fp, argv[0], argv[i]);
t = tzdecode(code);
show(argv[i], t - 1, TRUE);
show(argv[i], t, TRUE);
}
if (fclose(fp)) {
(void) fprintf(stderr, "%s: Error closing ", argv[0]);
perror(argv[i]);
exit(1);
}
show(argv[i], 0x7fffffff - 24 * 60 * 60, TRUE);
show(argv[i], 0x7fffffff, TRUE);
}
if (fflush(stdout) || ferror(stdout)) {
(void) fprintf(stderr, "%s: Error writing standard output ",
argv[0]);
perror("standard output");
exit(1);
}
return 0;
}
static
show(zone, t, v)
char * zone;
long t;
{
struct tm * tmp;
extern struct tm * localtime();
(void) printf("%-*s ", longest, zone);
if (v)
(void) printf("%.24s GMT = ", asctime(gmtime(&t)));
tmp = localtime(&t);
(void) printf("%.24s", asctime(tmp));
if (*tz_abbr != '\0')
(void) printf(" %s", tz_abbr);
if (v)
(void) printf(" isdst=%d", tmp->tm_isdst);
(void) printf("\n");
}
static
readerr(fp, progname, filename)
FILE * fp;
char * progname;
char * filename;
{
(void) fprintf(stderr, "%s: Error reading ", progname);
if (ferror(fp))
perror(filename);
else (void) fprintf(stderr, "%s: Premature EOF\n", filename);
exit(1);
}