Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src use strtonum from libc (Kamil Rytarowski)
details: https://anonhg.NetBSD.org/src/rev/ca8229e4e605
branches: trunk
changeset: 806035:ca8229e4e605
user: christos <christos%NetBSD.org@localhost>
date: Thu Jan 29 03:28:19 2015 +0000
description:
use strtonum from libc (Kamil Rytarowski)
diffstat:
usr.bin/sdiff/Makefile | 5 +-
usr.bin/sdiff/common.h | 6 +---
usr.bin/sdiff/strtonum.c | 68 --------------------------------------------
usr.sbin/gpioctl/Makefile | 5 +-
usr.sbin/gpioctl/gpioctl.c | 5 +--
usr.sbin/gpioctl/strtonum.c | 69 ---------------------------------------------
6 files changed, 8 insertions(+), 150 deletions(-)
diffs (211 lines):
diff -r e6c655cc0621 -r ca8229e4e605 usr.bin/sdiff/Makefile
--- a/usr.bin/sdiff/Makefile Thu Jan 29 03:27:06 2015 +0000
+++ b/usr.bin/sdiff/Makefile Thu Jan 29 03:28:19 2015 +0000
@@ -1,9 +1,10 @@
-# $NetBSD: Makefile,v 1.2 2009/04/14 22:15:26 lukem Exp $
+# $NetBSD: Makefile,v 1.3 2015/01/29 03:28:19 christos Exp $
WARNS?= 2 # XXX -Wcast-qual issues
PROG= sdiff
-SRCS= common.c edit.c sdiff.c strtonum.c
+SRCS= common.c edit.c sdiff.c
+CPPFLAGS+=-D_OPENBSD_SOURCE
LDADD+= -lutil
DPADD+= ${LIBUTIL}
diff -r e6c655cc0621 -r ca8229e4e605 usr.bin/sdiff/common.h
--- a/usr.bin/sdiff/common.h Thu Jan 29 03:27:06 2015 +0000
+++ b/usr.bin/sdiff/common.h Thu Jan 29 03:28:19 2015 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: common.h,v 1.1 2007/02/18 22:13:42 rmind Exp $ */
+/* $NetBSD: common.h,v 1.2 2015/01/29 03:28:19 christos Exp $ */
/* $OpenBSD: common.h,v 1.2 2006/05/25 03:20:32 ray Exp $ */
/*
@@ -7,7 +7,3 @@
*/
__dead void cleanup(const char *);
-
-long long
-strtonum(const char *numstr, long long minval, long long maxval,
- const char **errstrp);
diff -r e6c655cc0621 -r ca8229e4e605 usr.bin/sdiff/strtonum.c
--- a/usr.bin/sdiff/strtonum.c Thu Jan 29 03:27:06 2015 +0000
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,68 +0,0 @@
-/* $NetBSD: strtonum.c,v 1.1 2007/02/18 22:13:43 rmind Exp $ */
-/* $OpenBSD: strtonum.c,v 1.6 2004/08/03 19:38:01 millert Exp $ */
-
-/*
- * Copyright (c) 2004 Ted Unangst and Todd Miller
- * All rights reserved.
- *
- * Permission to use, copy, modify, and distribute this software for any
- * purpose with or without fee is hereby granted, provided that the above
- * copyright notice and this permission notice appear in all copies.
- *
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
- * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
- */
-
-#include <errno.h>
-#include <limits.h>
-#include <stdlib.h>
-
-#include "common.h"
-
-#define INVALID 1
-#define TOOSMALL 2
-#define TOOLARGE 3
-
-long long
-strtonum(const char *numstr, long long minval, long long maxval,
- const char **errstrp)
-{
- long long ll = 0;
- char *ep;
- int error = 0;
- struct errval {
- const char *errstr;
- int err;
- } ev[4] = {
- { NULL, 0 },
- { "invalid", EINVAL },
- { "too small", ERANGE },
- { "too large", ERANGE },
- };
-
- ev[0].err = errno;
- errno = 0;
- if (minval > maxval)
- error = INVALID;
- else {
- ll = strtoll(numstr, &ep, 10);
- if (numstr == ep || *ep != '\0')
- error = INVALID;
- else if ((ll == LLONG_MIN && errno == ERANGE) || ll < minval)
- error = TOOSMALL;
- else if ((ll == LLONG_MAX && errno == ERANGE) || ll > maxval)
- error = TOOLARGE;
- }
- if (errstrp != NULL)
- *errstrp = ev[error].errstr;
- errno = ev[error].err;
- if (error)
- ll = 0;
-
- return (ll);
-}
diff -r e6c655cc0621 -r ca8229e4e605 usr.sbin/gpioctl/Makefile
--- a/usr.sbin/gpioctl/Makefile Thu Jan 29 03:27:06 2015 +0000
+++ b/usr.sbin/gpioctl/Makefile Thu Jan 29 03:28:19 2015 +0000
@@ -1,7 +1,8 @@
-# $NetBSD: Makefile,v 1.4 2009/07/25 16:18:09 mbalmer Exp $
+# $NetBSD: Makefile,v 1.5 2015/01/29 03:30:06 christos Exp $
PROG= gpioctl
-SRCS= gpioctl.c strtonum.c
+SRCS= gpioctl.c
+CPPFLAGS+=-D_OPENBSD_SOURCE
MAN= gpioctl.8
diff -r e6c655cc0621 -r ca8229e4e605 usr.sbin/gpioctl/gpioctl.c
--- a/usr.sbin/gpioctl/gpioctl.c Thu Jan 29 03:27:06 2015 +0000
+++ b/usr.sbin/gpioctl/gpioctl.c Thu Jan 29 03:28:19 2015 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: gpioctl.c,v 1.20 2013/05/19 15:31:23 mbalmer Exp $ */
+/* $NetBSD: gpioctl.c,v 1.21 2015/01/29 03:30:06 christos Exp $ */
/*
* Copyright (c) 2008, 2010, 2011, 2013 Marc Balmer <mbalmer%NetBSD.org@localhost>
@@ -49,9 +49,6 @@
static void devattach(char *, int, uint32_t, uint32_t);
__dead static void usage(void);
-extern long long strtonum(const char *numstr, long long minval,
- long long maxval, const char **errstrp);
-
static const struct bitstr {
unsigned int mask;
const char *string;
diff -r e6c655cc0621 -r ca8229e4e605 usr.sbin/gpioctl/strtonum.c
--- a/usr.sbin/gpioctl/strtonum.c Thu Jan 29 03:27:06 2015 +0000
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,69 +0,0 @@
-/* $NetBSD: strtonum.c,v 1.1 2009/07/25 16:18:09 mbalmer Exp $ */
-/* $OpenBSD: strtonum.c,v 1.6 2004/08/03 19:38:01 millert Exp $ */
-
-/*
- * Copyright (c) 2004 Ted Unangst and Todd Miller
- * All rights reserved.
- *
- * Permission to use, copy, modify, and distribute this software for any
- * purpose with or without fee is hereby granted, provided that the above
- * copyright notice and this permission notice appear in all copies.
- *
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
- * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
- */
-
-#include <errno.h>
-#include <limits.h>
-#include <stdlib.h>
-
-#define INVALID 1
-#define TOOSMALL 2
-#define TOOLARGE 3
-
-long long strtonum(const char *numstr, long long minval, long long maxval,
- const char **errstrp);
-
-long long
-strtonum(const char *numstr, long long minval, long long maxval,
- const char **errstrp)
-{
- long long ll = 0;
- char *ep;
- int error = 0;
- struct errval {
- const char *errstr;
- int err;
- } ev[4] = {
- { NULL, 0 },
- { "invalid", EINVAL },
- { "too small", ERANGE },
- { "too large", ERANGE },
- };
-
- ev[0].err = errno;
- errno = 0;
- if (minval > maxval)
- error = INVALID;
- else {
- ll = strtoll(numstr, &ep, 10);
- if (numstr == ep || *ep != '\0')
- error = INVALID;
- else if ((ll == LLONG_MIN && errno == ERANGE) || ll < minval)
- error = TOOSMALL;
- else if ((ll == LLONG_MAX && errno == ERANGE) || ll > maxval)
- error = TOOLARGE;
- }
- if (errstrp != NULL)
- *errstrp = ev[error].errstr;
- errno = ev[error].err;
- if (error)
- ll = 0;
-
- return (ll);
-}
Home |
Main Index |
Thread Index |
Old Index