diff options
author | Niall O'Higgins <niallo@cvs.openbsd.org> | 2006-02-21 16:39:24 +0000 |
---|---|---|
committer | Niall O'Higgins <niallo@cvs.openbsd.org> | 2006-02-21 16:39:24 +0000 |
commit | 0cd88da2dbb9e95e5d8fb3f2d48aaa5a37580d26 (patch) | |
tree | 521efef16e116986ee8bddce67455f4a9bf7d1b8 /usr.bin/rcs/rcsprog.c | |
parent | 7956e13240b91ad207cb04ec2a30f3d013c3abc6 (diff) |
- fix some bugs when handling strange revision numbers (0 and 1). found by
my automatic tool.
ok xsa@
Diffstat (limited to 'usr.bin/rcs/rcsprog.c')
-rw-r--r-- | usr.bin/rcs/rcsprog.c | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/usr.bin/rcs/rcsprog.c b/usr.bin/rcs/rcsprog.c index 570b0e18a82..b5ffb9c993e 100644 --- a/usr.bin/rcs/rcsprog.c +++ b/usr.bin/rcs/rcsprog.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rcsprog.c,v 1.62 2006/01/25 08:01:00 xsa Exp $ */ +/* $OpenBSD: rcsprog.c,v 1.63 2006/02/21 16:39:23 niallo Exp $ */ /* * Copyright (c) 2005 Jean-Francois Brousseau <jfb@openbsd.org> * All rights reserved. @@ -70,6 +70,8 @@ static void rcs_attach_symbol(RCSFILE *, const char *); void rcs_set_rev(const char *str, RCSNUM **rev) { + RCSNUM *t; + if (str == NULL) return; @@ -78,6 +80,24 @@ rcs_set_rev(const char *str, RCSNUM **rev) if ((*rev = rcsnum_parse(str)) == NULL) fatal("bad revision number '%s'", str); + /* + * If 0 is specified as a revision number, exit and warn the user. + * This differs from GNU ci's plainly buggy behaviour, where 0 ends up + * being 0.1 and other weird stuff. + */ + t = rcsnum_parse("0"); + if (rcsnum_cmp(*rev, t, 0) == 0) + fatal("0 is not a valid revision number"); + rcsnum_free(t); + /* + * If 1 is specified as revision number, silently assume 1.1. + * This is what GNU ci does. + */ + t = rcsnum_parse(RCS_HEAD_INIT); + if (rcsnum_cmp(*rev, t, 0) > 0) + rcsnum_cpy(t, *rev, 0); + rcsnum_free(t); + } /* |