3 /* strerror.c --- ANSI C compatible system error routine
5 Copyright (C) 1986, 1988, 1989, 1991, 2002, 2003 Free Software
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2, or (at your option)
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software Foundation,
20 Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
28 /* Don't include <stdio.h>, since it may or may not declare
29 sys_errlist and its declarations may collide with ours. Just
30 declare the stuff that we need directly. Standard hosted C89
31 implementations define strerror and they don't need this strerror
32 function, so take some liberties with the standard to cater to
33 ancient or limited freestanding implementations. */
34 int sprintf (char *, char const *, ...);
36 extern char *sys_errlist
[];
41 static char const fmt
[] = "Unknown error (%d)";
42 static char mesg
[sizeof fmt
+ sizeof n
* CHAR_BIT
/ 3];
44 if (n
< 0 || n
>= sys_nerr
)
46 sprintf (mesg
, fmt
, n
);
50 return sys_errlist
[n
];