openat: don’t close (-1)
[gnulib.git] / lib / quote.h
blobf087a8548a844ada0aaacee13afbdd321db9ac75
1 /* quote.h - prototypes for quote.c
3 Copyright (C) 1998-2001, 2003, 2009-2024 Free Software Foundation, Inc.
5 This program is free software: you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation, either version 3 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program. If not, see <https://www.gnu.org/licenses/>. */
18 #ifndef QUOTE_H_
19 #define QUOTE_H_ 1
21 #include <stddef.h>
23 #ifdef __cplusplus
24 extern "C" {
25 #endif
28 /* The quoting options used by quote_n and quote. Its type is incomplete,
29 so it's useful only in expressions like '&quote_quoting_options'. */
30 extern struct quoting_options quote_quoting_options;
32 /* Return an unambiguous printable representation of ARG (of size
33 ARGSIZE), allocated in slot N, suitable for diagnostics. If
34 ARGSIZE is SIZE_MAX, use the string length of the argument for
35 ARGSIZE. */
36 char const *quote_n_mem (int n, char const *arg, size_t argsize);
38 /* Return an unambiguous printable representation of ARG (of size
39 ARGSIZE), suitable for diagnostics. If ARGSIZE is SIZE_MAX, use
40 the string length of the argument for ARGSIZE. */
41 char const *quote_mem (char const *arg, size_t argsize);
43 /* Return an unambiguous printable representation of ARG, allocated in
44 slot N, suitable for diagnostics. */
45 char const *quote_n (int n, char const *arg);
47 /* Return an unambiguous printable representation of ARG, suitable for
48 diagnostics. */
49 char const *quote (char const *arg);
52 #ifdef __cplusplus
54 #endif
56 #endif /* !QUOTE_H_ */