Fri Jul 5 12:22:51 1996 Roland McGrath <roland@delasyd.gnu.ai.mit.edu>
[glibc.git] / sysdeps / mach / _strerror.c
blob8b32f052e5070968033249a07ba160a31bd3ce01
1 /* Copyright (C) 1993, 1995 Free Software Foundation, Inc.
2 This file is part of the GNU C Library.
4 The GNU C Library is free software; you can redistribute it and/or
5 modify it under the terms of the GNU Library General Public License as
6 published by the Free Software Foundation; either version 2 of the
7 License, or (at your option) any later version.
9 The GNU C Library is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 Library General Public License for more details.
14 You should have received a copy of the GNU Library General Public
15 License along with the GNU C Library; see the file COPYING.LIB. If
16 not, write to the Free Software Foundation, Inc., 675 Mass Ave,
17 Cambridge, MA 02139, USA. */
19 #include <stdio.h>
20 #include <string.h>
21 #include <mach/error.h>
22 #include <errorlib.h>
23 #include "../stdio-common/_itoa.h"
25 /* Return a string describing the errno code in ERRNUM. */
26 char *
27 _strerror_internal (int errnum, char *buf, size_t buflen)
29 int system;
30 int sub;
31 int code;
32 const struct error_system *es;
33 extern void __mach_error_map_compat (int *);
35 __mach_error_map_compat (&errnum);
37 system = err_get_system (errnum);
38 sub = err_get_sub (errnum);
39 code = err_get_code (errnum);
41 if (system > err_max_system || ! __mach_error_systems[system].bad_sub)
43 const char *unk = _("Error in unknown error system: ");
44 const size_t unklen = strlen (unk);
45 char *p = buf + buflen;
46 *--p = '\0';
47 p = _itoa (errnum, p, 16, 1);
48 return memcpy (p - unklen, unk, unklen);
51 es = &__mach_error_systems[system];
53 if (sub >= es->max_sub)
54 return (char *) es->bad_sub;
56 if (code >= es->subsystem[sub].max_code)
58 const char *unk = _("Unknown error ");
59 const size_t unklen = strlen (unk);
60 char *p = buf + buflen;
61 size_t len = strlen (es->subsystem[sub].subsys_name);
62 *--p = '\0';
63 p = _itoa (errnum, p, 16, 1);
64 *p-- = ' ';
65 p = memcpy (p - len, es->subsystem[sub].subsys_name, len);
66 return memcpy (p - unklen, unk, unklen);
69 return (char *) _(es->subsystem[sub].codes[code]);