blob: a9bdc2461a41cc942488dabb582cefe074fc3a53 [file] [log] [blame]
Elliott Hughesb8a8cf02015-01-24 18:36:29 -08001/*
2 * Copyright (C) 2015 The Android Open Source Project
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in
12 * the documentation and/or other materials provided with the
13 * distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 */
28
Elliott Hughes462e90c2018-08-21 16:10:48 -070029#pragma once
30
31/**
32 * @file error.h
33 * @brief GNU error reporting functions.
34 */
Elliott Hughesb8a8cf02015-01-24 18:36:29 -080035
36#include <sys/cdefs.h>
37
38__BEGIN_DECLS
39
Elliott Hughes462e90c2018-08-21 16:10:48 -070040/**
Elliott Hughesbbd39aa2024-08-13 20:59:16 +000041 * [error_print_progname(3)](https://man7.org/linux/man-pages/man3/error_print_progname.3.html) is
Elliott Hughes462e90c2018-08-21 16:10:48 -070042 * a function pointer that, if non-null, is called by error() instead of prefixing errors with the
43 * program name.
44 *
45 * Available since API level 23.
46 */
Elliott Hughes462e90c2018-08-21 16:10:48 -070047
Dan Albert02ce4012024-10-25 19:13:49 +000048#if __BIONIC_AVAILABILITY_GUARD(23)
49extern void (* _Nullable error_print_progname)(void) __INTRODUCED_IN(23);
50
Elliott Hughes462e90c2018-08-21 16:10:48 -070051/**
Elliott Hughesbbd39aa2024-08-13 20:59:16 +000052 * [error_message_count(3)](https://man7.org/linux/man-pages/man3/error_message_count.3.html) is
Elliott Hughes462e90c2018-08-21 16:10:48 -070053 * a global count of the number of calls to error() and error_at_line().
54 *
55 * Available since API level 23.
56 */
Josh Gao14adff12016-04-29 12:00:55 -070057extern unsigned int error_message_count __INTRODUCED_IN(23);
Elliott Hughes462e90c2018-08-21 16:10:48 -070058
59/**
Elliott Hughesbbd39aa2024-08-13 20:59:16 +000060 * [error_one_per_line(3)](https://man7.org/linux/man-pages/man3/error_one_per_line.3.html) is
Elliott Hughes462e90c2018-08-21 16:10:48 -070061 * a global flag that if non-zero disables printing multiple errors with the same filename and
62 * line number.
63 *
64 * Available since API level 23.
65 */
Josh Gao14adff12016-04-29 12:00:55 -070066extern int error_one_per_line __INTRODUCED_IN(23);
Elliott Hughesb8a8cf02015-01-24 18:36:29 -080067
Elliott Hughes462e90c2018-08-21 16:10:48 -070068/**
Elliott Hughesbbd39aa2024-08-13 20:59:16 +000069 * [error(3)](https://man7.org/linux/man-pages/man3/error.3.html) formats the given printf()-like
Elliott Hughes462e90c2018-08-21 16:10:48 -070070 * error message, preceded by the program name. Calls exit if `__status` is non-zero, and appends
71 * the result of strerror() if `__errno` is non-zero.
72 *
73 * Available since API level 23.
74 */
zijunzhao377954f2023-02-16 23:29:54 +000075void error(int __status, int __errno, const char* _Nonnull __fmt, ...) __printflike(3, 4) __INTRODUCED_IN(23);
Elliott Hughes462e90c2018-08-21 16:10:48 -070076
77/**
Elliott Hughesbbd39aa2024-08-13 20:59:16 +000078 * [error_at_line(3)](https://man7.org/linux/man-pages/man3/error_at_line.3.html) formats the given
Elliott Hughes462e90c2018-08-21 16:10:48 -070079 * printf()-like error message, preceded by the program name and the given filename and line number.
80 * Calls exit if `__status` is non-zero, and appends the result of strerror() if `__errno` is
81 * non-zero.
82 *
83 * Available since API level 23.
84 */
zijunzhao377954f2023-02-16 23:29:54 +000085void error_at_line(int __status, int __errno, const char* _Nonnull __filename, unsigned int __line_number, const char* _Nonnull __fmt, ...) __printflike(5, 6) __INTRODUCED_IN(23);
Dan Albert02ce4012024-10-25 19:13:49 +000086#endif /* __BIONIC_AVAILABILITY_GUARD(23) */
87
Elliott Hughes5470c182016-07-22 11:36:17 -070088
Elliott Hughesb8a8cf02015-01-24 18:36:29 -080089__END_DECLS