annotate lib/error.h @ 17342:c75939cb6254

merge with default branch
author Michael Goffioul <michael.goffioul@gmail.com>
date Thu, 21 Feb 2013 14:57:31 +0000
parents e542fd46ad6f
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1268
a6946b537568 update from fsf
Jim Meyering <jim@meyering.net>
parents: 765
diff changeset
1 /* Declaration for error-reporting function
17249
e542fd46ad6f maint: update all copyright year number ranges
Eric Blake <eblake@redhat.com>
parents: 16235
diff changeset
2 Copyright (C) 1995-1997, 2003, 2006, 2008-2013 Free Software Foundation,
14079
97fc9a21a8fb maint: update almost all copyright ranges to include 2011
Jim Meyering <meyering@redhat.com>
parents: 12762
diff changeset
3 Inc.
4739
04758f7475fd Merge changes from glibc.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4636
diff changeset
4 This file is part of the GNU C Library.
1268
a6946b537568 update from fsf
Jim Meyering <jim@meyering.net>
parents: 765
diff changeset
5
9309
bbbbbf4cd1c5 Change copyright notice from GPLv2+ to GPLv3+.
Bruno Haible <bruno@clisp.org>
parents: 7088
diff changeset
6 This program is free software: you can redistribute it and/or modify
4739
04758f7475fd Merge changes from glibc.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4636
diff changeset
7 it under the terms of the GNU General Public License as published by
9309
bbbbbf4cd1c5 Change copyright notice from GPLv2+ to GPLv3+.
Bruno Haible <bruno@clisp.org>
parents: 7088
diff changeset
8 the Free Software Foundation; either version 3 of the License, or
bbbbbf4cd1c5 Change copyright notice from GPLv2+ to GPLv3+.
Bruno Haible <bruno@clisp.org>
parents: 7088
diff changeset
9 (at your option) any later version.
402
b07b357a880e Update and add copyright.
Jim Meyering <jim@meyering.net>
parents: 367
diff changeset
10
725
ea86caa7c2cc indent copyright comment.
Jim Meyering <jim@meyering.net>
parents: 653
diff changeset
11 This program is distributed in the hope that it will be useful,
ea86caa7c2cc indent copyright comment.
Jim Meyering <jim@meyering.net>
parents: 653
diff changeset
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
ea86caa7c2cc indent copyright comment.
Jim Meyering <jim@meyering.net>
parents: 653
diff changeset
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
ea86caa7c2cc indent copyright comment.
Jim Meyering <jim@meyering.net>
parents: 653
diff changeset
14 GNU General Public License for more details.
572
55f487a8aeab Update from libc.
Jim Meyering <jim@meyering.net>
parents: 536
diff changeset
15
9309
bbbbbf4cd1c5 Change copyright notice from GPLv2+ to GPLv3+.
Bruno Haible <bruno@clisp.org>
parents: 7088
diff changeset
16 You should have received a copy of the GNU General Public License
bbbbbf4cd1c5 Change copyright notice from GPLv2+ to GPLv3+.
Bruno Haible <bruno@clisp.org>
parents: 7088
diff changeset
17 along with this program. If not, see <http://www.gnu.org/licenses/>. */
367
Jim Meyering <jim@meyering.net>
parents:
diff changeset
18
1268
a6946b537568 update from fsf
Jim Meyering <jim@meyering.net>
parents: 765
diff changeset
19 #ifndef _ERROR_H
a6946b537568 update from fsf
Jim Meyering <jim@meyering.net>
parents: 765
diff changeset
20 #define _ERROR_H 1
a6946b537568 update from fsf
Jim Meyering <jim@meyering.net>
parents: 765
diff changeset
21
12762
410eaa89fb57 Avoid a link error due to the __printf__ symbol.
Bruno Haible <bruno@clisp.org>
parents: 12559
diff changeset
22 /* The __attribute__ feature is available in gcc versions 2.5 and later.
410eaa89fb57 Avoid a link error due to the __printf__ symbol.
Bruno Haible <bruno@clisp.org>
parents: 12559
diff changeset
23 The __-protected variants of the attributes 'format' and 'printf' are
410eaa89fb57 Avoid a link error due to the __printf__ symbol.
Bruno Haible <bruno@clisp.org>
parents: 12559
diff changeset
24 accepted by gcc versions 2.6.4 (effectively 2.7) and later.
14350
4cf3b58aaf12 Don't interfere with a program's definition of __attribute__.
Bruno Haible <bruno@clisp.org>
parents: 14079
diff changeset
25 We enable _GL_ATTRIBUTE_FORMAT only if these are supported too, because
12762
410eaa89fb57 Avoid a link error due to the __printf__ symbol.
Bruno Haible <bruno@clisp.org>
parents: 12559
diff changeset
26 gnulib and libintl do '#define printf __printf__' when they override
410eaa89fb57 Avoid a link error due to the __printf__ symbol.
Bruno Haible <bruno@clisp.org>
parents: 12559
diff changeset
27 the 'printf' function. */
14350
4cf3b58aaf12 Don't interfere with a program's definition of __attribute__.
Bruno Haible <bruno@clisp.org>
parents: 14079
diff changeset
28 #if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 7)
4cf3b58aaf12 Don't interfere with a program's definition of __attribute__.
Bruno Haible <bruno@clisp.org>
parents: 14079
diff changeset
29 # define _GL_ATTRIBUTE_FORMAT(spec) __attribute__ ((__format__ spec))
4cf3b58aaf12 Don't interfere with a program's definition of __attribute__.
Bruno Haible <bruno@clisp.org>
parents: 14079
diff changeset
30 #else
4cf3b58aaf12 Don't interfere with a program's definition of __attribute__.
Bruno Haible <bruno@clisp.org>
parents: 14079
diff changeset
31 # define _GL_ATTRIBUTE_FORMAT(spec) /* empty */
1268
a6946b537568 update from fsf
Jim Meyering <jim@meyering.net>
parents: 765
diff changeset
32 #endif
402
b07b357a880e Update and add copyright.
Jim Meyering <jim@meyering.net>
parents: 367
diff changeset
33
12421
e8d2c6fc33ad Use spaces for indentation, not tabs.
Bruno Haible <bruno@clisp.org>
parents: 9613
diff changeset
34 #ifdef __cplusplus
1268
a6946b537568 update from fsf
Jim Meyering <jim@meyering.net>
parents: 765
diff changeset
35 extern "C" {
a6946b537568 update from fsf
Jim Meyering <jim@meyering.net>
parents: 765
diff changeset
36 #endif
a6946b537568 update from fsf
Jim Meyering <jim@meyering.net>
parents: 765
diff changeset
37
16235
18a38c9615f0 In commentary, do not use ` to quote.
Paul Eggert <eggert@cs.ucla.edu>
parents: 16201
diff changeset
38 /* Print a message with 'fprintf (stderr, FORMAT, ...)';
572
55f487a8aeab Update from libc.
Jim Meyering <jim@meyering.net>
parents: 536
diff changeset
39 if ERRNUM is nonzero, follow it with ": " and strerror (ERRNUM).
16235
18a38c9615f0 In commentary, do not use ` to quote.
Paul Eggert <eggert@cs.ucla.edu>
parents: 16201
diff changeset
40 If STATUS is nonzero, terminate the program with 'exit (STATUS)'. */
572
55f487a8aeab Update from libc.
Jim Meyering <jim@meyering.net>
parents: 536
diff changeset
41
4739
04758f7475fd Merge changes from glibc.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4636
diff changeset
42 extern void error (int __status, int __errnum, const char *__format, ...)
14350
4cf3b58aaf12 Don't interfere with a program's definition of __attribute__.
Bruno Haible <bruno@clisp.org>
parents: 14079
diff changeset
43 _GL_ATTRIBUTE_FORMAT ((__printf__, 3, 4));
572
55f487a8aeab Update from libc.
Jim Meyering <jim@meyering.net>
parents: 536
diff changeset
44
4739
04758f7475fd Merge changes from glibc.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4636
diff changeset
45 extern void error_at_line (int __status, int __errnum, const char *__fname,
12421
e8d2c6fc33ad Use spaces for indentation, not tabs.
Bruno Haible <bruno@clisp.org>
parents: 9613
diff changeset
46 unsigned int __lineno, const char *__format, ...)
14350
4cf3b58aaf12 Don't interfere with a program's definition of __attribute__.
Bruno Haible <bruno@clisp.org>
parents: 14079
diff changeset
47 _GL_ATTRIBUTE_FORMAT ((__printf__, 5, 6));
572
55f487a8aeab Update from libc.
Jim Meyering <jim@meyering.net>
parents: 536
diff changeset
48
55f487a8aeab Update from libc.
Jim Meyering <jim@meyering.net>
parents: 536
diff changeset
49 /* If NULL, error will flush stdout, then print on stderr the program
55f487a8aeab Update from libc.
Jim Meyering <jim@meyering.net>
parents: 536
diff changeset
50 name, a colon and a space. Otherwise, error will call this
55f487a8aeab Update from libc.
Jim Meyering <jim@meyering.net>
parents: 536
diff changeset
51 function without parameters instead. */
55f487a8aeab Update from libc.
Jim Meyering <jim@meyering.net>
parents: 536
diff changeset
52 extern void (*error_print_progname) (void);
55f487a8aeab Update from libc.
Jim Meyering <jim@meyering.net>
parents: 536
diff changeset
53
16235
18a38c9615f0 In commentary, do not use ` to quote.
Paul Eggert <eggert@cs.ucla.edu>
parents: 16201
diff changeset
54 /* This variable is incremented each time 'error' is called. */
440
79626753a234 merge with 1.11.1a
Jim Meyering <jim@meyering.net>
parents: 411
diff changeset
55 extern unsigned int error_message_count;
79626753a234 merge with 1.11.1a
Jim Meyering <jim@meyering.net>
parents: 411
diff changeset
56
572
55f487a8aeab Update from libc.
Jim Meyering <jim@meyering.net>
parents: 536
diff changeset
57 /* Sometimes we want to have at most one error per line. This
55f487a8aeab Update from libc.
Jim Meyering <jim@meyering.net>
parents: 536
diff changeset
58 variable controls whether this mode is selected or not. */
55f487a8aeab Update from libc.
Jim Meyering <jim@meyering.net>
parents: 536
diff changeset
59 extern int error_one_per_line;
55f487a8aeab Update from libc.
Jim Meyering <jim@meyering.net>
parents: 536
diff changeset
60
12421
e8d2c6fc33ad Use spaces for indentation, not tabs.
Bruno Haible <bruno@clisp.org>
parents: 9613
diff changeset
61 #ifdef __cplusplus
1268
a6946b537568 update from fsf
Jim Meyering <jim@meyering.net>
parents: 765
diff changeset
62 }
a6946b537568 update from fsf
Jim Meyering <jim@meyering.net>
parents: 765
diff changeset
63 #endif
a6946b537568 update from fsf
Jim Meyering <jim@meyering.net>
parents: 765
diff changeset
64
a6946b537568 update from fsf
Jim Meyering <jim@meyering.net>
parents: 765
diff changeset
65 #endif /* error.h */