summaryrefslogtreecommitdiff
path: root/usr.sbin/rdate/rdate.c
diff options
context:
space:
mode:
authorJakob Schlyter <jakob@cvs.openbsd.org>2002-09-08 12:33:43 +0000
committerJakob Schlyter <jakob@cvs.openbsd.org>2002-09-08 12:33:43 +0000
commitd6d7c19b6453cc5f0611a112e08627402a9b6aa5 (patch)
treed3b5942adc3fc1977dff9bbee5690fe879f0e8ab /usr.sbin/rdate/rdate.c
parent85e069ce9aafde0883c1f3bd8b7754d8e4c1cd2b (diff)
add leap second support for rfc868, from thorsten glaser
Diffstat (limited to 'usr.sbin/rdate/rdate.c')
-rw-r--r--usr.sbin/rdate/rdate.c25
1 files changed, 11 insertions, 14 deletions
diff --git a/usr.sbin/rdate/rdate.c b/usr.sbin/rdate/rdate.c
index ce470ba835b..7add012eab4 100644
--- a/usr.sbin/rdate/rdate.c
+++ b/usr.sbin/rdate/rdate.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: rdate.c,v 1.18 2002/08/10 21:37:28 jakob Exp $ */
+/* $OpenBSD: rdate.c,v 1.19 2002/09/08 12:33:42 jakob Exp $ */
/* $NetBSD: rdate.c,v 1.4 1996/03/16 12:37:45 pk Exp $ */
/*
@@ -42,7 +42,7 @@
#if 0
from: static char rcsid[] = "$NetBSD: rdate.c,v 1.3 1996/02/22 06:59:18 thorpej Exp $";
#else
-static const char rcsid[] = "$OpenBSD: rdate.c,v 1.18 2002/08/10 21:37:28 jakob Exp $";
+static const char rcsid[] = "$OpenBSD: rdate.c,v 1.19 2002/09/08 12:33:42 jakob Exp $";
#endif
#endif /* lint */
@@ -63,18 +63,17 @@ static const char rcsid[] = "$OpenBSD: rdate.c,v 1.18 2002/08/10 21:37:28 jakob
#define logwtmp(a,b,c)
#endif
-void rfc868time_client (const char *, struct timeval *, struct timeval *);
-void ntp_client (const char *, struct timeval *, struct timeval *);
+void rfc868time_client (const char *, struct timeval *, struct timeval *, int);
+void ntp_client (const char *, struct timeval *, struct timeval *, int);
extern char *__progname;
-extern int corrleaps;
void
usage()
{
- (void) fprintf(stderr, "Usage: %s [-npsa] host\n", __progname);
+ (void) fprintf(stderr, "Usage: %s [-ncpsa] host\n", __progname);
(void) fprintf(stderr, " -n: use SNTP instead of RFC868 time protocol\n");
- (void) fprintf(stderr, " -N: use SNTP and correct leap seconds\n");
+ (void) fprintf(stderr, " -c: correct leap second count\n");
(void) fprintf(stderr, " -p: just print, don't set\n");
(void) fprintf(stderr, " -s: just set, don't print\n");
(void) fprintf(stderr, " -a: use adjtime instead of instant change\n");
@@ -85,14 +84,14 @@ int
main(int argc, char **argv)
{
int pr = 0, silent = 0, ntp = 0, verbose = 0;
- int slidetime = 0;
+ int slidetime = 0, corrleaps = 0;
char *hname;
extern int optind;
int c;
struct timeval new, adjust;
- while ((c = getopt(argc, argv, "psanNv")) != -1)
+ while ((c = getopt(argc, argv, "psancv")) != -1)
switch (c) {
case 'p':
pr++;
@@ -108,11 +107,9 @@ main(int argc, char **argv)
case 'n':
ntp++;
- corrleaps = 0;
break;
- case 'N':
- ntp++;
+ case 'c':
corrleaps = 1;
break;
@@ -132,9 +129,9 @@ main(int argc, char **argv)
hname = argv[optind];
if (ntp)
- ntp_client(hname, &new, &adjust);
+ ntp_client(hname, &new, &adjust, corrleaps);
else
- rfc868time_client(hname, &new, &adjust);
+ rfc868time_client(hname, &new, &adjust, corrleaps);
if (!pr) {
if (!slidetime) {