NetBSD/usr.sbin/sup/source/errmsg.c

76 lines
2.1 KiB
C
Raw Normal View History

/* $NetBSD: errmsg.c,v 1.3 1997/06/17 18:56:11 christos Exp $ */
1993-05-21 18:52:16 +04:00
/*
* Copyright (c) 1991 Carnegie Mellon University
* All Rights Reserved.
*
* Permission to use, copy, modify and distribute this software and its
* documentation is hereby granted, provided that both the copyright
* notice and this permission notice appear in all copies of the
* software, derivative works or modified versions, and any portions
* thereof, and that both notices appear in supporting documentation.
*
* CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
* CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
* ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
*
* Carnegie Mellon requests users of this software to return to
*
* Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
* School of Computer Science
* Carnegie Mellon University
* Pittsburgh PA 15213-3890
*
* any improvements or extensions that they make and grant Carnegie the rights
* to redistribute these changes.
*/
/*****************************************************************
* HISTORY
* 04-Mar-85 Rudy Nedved (ern) at Carnegie-Mellon University
* Create a CMU version of the BBN errmsg routine from scratch. It
* differs from the BBN errmsg routine in the fact that it uses a
* negative value to indicate using the current errno value...the
* BBN uses a negative OR zero value.
*/
#include "supcdefs.h"
#include "supextern.h"
#ifndef __NetBSD__
static char *itoa __P((char *, unsigned));
1993-05-21 18:52:16 +04:00
static char *itoa(p,n)
char *p;
unsigned n;
{
if (n >= 10)
p =itoa(p,n/10);
*p++ = (n%10)+'0';
return(p);
}
#endif
1993-05-21 18:52:16 +04:00
char *errmsg(cod)
int cod;
{
#ifndef __NetBSD__
extern int errno;
extern int sys_nerr;
extern char *sys_errlist[];
1993-05-21 18:52:16 +04:00
static char unkmsg[] = "Unknown error ";
static char unk[sizeof(unkmsg)+11]; /* trust us */
if (cod < 0) cod = errno;
if((cod >= 0) && (cod < sys_nerr))
return(sys_errlist[cod]);
strcpy(unk,unkmsg);
*itoa(&unk[sizeof(unkmsg)-1],cod) = '\0';
return(unk);
#else
return strerror(cod);
#endif
1993-05-21 18:52:16 +04:00
}