Clang Project

include/errno.h
1/* Copyright (C) 1991-2016 Free Software Foundation, Inc.
2   This file is part of the GNU C Library.
3
4   The GNU C Library is free software; you can redistribute it and/or
5   modify it under the terms of the GNU Lesser General Public
6   License as published by the Free Software Foundation; either
7   version 2.1 of the License, or (at your option) any later version.
8
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   Lesser General Public License for more details.
13
14   You should have received a copy of the GNU Lesser General Public
15   License along with the GNU C Library; if not, see
16   <http://www.gnu.org/licenses/>.  */
17
18/*
19 * ISO C99 Standard: 7.5 Errors <errno.h>
20 */
21
22#ifndef _ERRNO_H
23
24/* The includer defined __need_Emath if he wants only the definitions
25   of EDOM and ERANGE, and not everything else.  */
26#ifndef __need_Emath
27define _ERRNO_H 1
28include <features.h>
29#endif
30
31__BEGIN_DECLS
32
33/* Get the error number constants from the system-specific file.
34   This file will test __need_Emath and _ERRNO_H.  */
35#include <bits/errno.h>
36#undef __need_Emath
37
38#ifdef _ERRNO_H
39
40/* Declare the `errno' variable, unless it's defined as a macro by
41   bits/errno.h.  This is the case in GNU, where it is a per-thread
42   variable.  This redeclaration using the macro still works, but it
43   will be a function declaration without a prototype and may trigger
44   a -Wstrict-prototypes warning.  */
45#ifndef errno
46extern int errno;
47#endif
48
49#ifdef __USE_GNU
50
51/* The full and simple forms of the name with which the program was
52   invoked.  These variables are set up automatically at startup based on
53   the value of ARGV[0] (this works only if you use GNU ld).  */
54extern char *program_invocation_name, *program_invocation_short_name;
55#endif /* __USE_GNU */
56#endif /* _ERRNO_H */
57
58__END_DECLS
59
60#endif /* _ERRNO_H */
61
62/* The Hurd <bits/errno.h> defines `error_t' as an enumerated type so
63   that printing `error_t' values in the debugger shows the names.  We
64   might need this definition sometimes even if this file was included
65   before.  */
66#if defined __USE_GNU || defined __need_error_t
67ifndef __error_t_defined
68typedef int error_t;
69#  define __error_t_defined 1
70endif
71# undef __need_error_t
72#endif
73