Blame support/support.h

Packit 6c4009
/* Common extra functions.
Packit 6c4009
   Copyright (C) 2016-2018 Free Software Foundation, Inc.
Packit 6c4009
   This file is part of the GNU C Library.
Packit 6c4009
Packit 6c4009
   The GNU C Library is free software; you can redistribute it and/or
Packit 6c4009
   modify it under the terms of the GNU Lesser General Public
Packit 6c4009
   License as published by the Free Software Foundation; either
Packit 6c4009
   version 2.1 of the License, or (at your option) any later version.
Packit 6c4009
Packit 6c4009
   The GNU C Library is distributed in the hope that it will be useful,
Packit 6c4009
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 6c4009
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 6c4009
   Lesser General Public License for more details.
Packit 6c4009
Packit 6c4009
   You should have received a copy of the GNU Lesser General Public
Packit 6c4009
   License along with the GNU C Library; if not, see
Packit 6c4009
   <http://www.gnu.org/licenses/>.  */
Packit 6c4009
Packit 6c4009
/* This header file should only contain definitions compatible with
Packit 6c4009
   C90.  (Using __attribute__ is fine because <features.h> provides a
Packit 6c4009
   fallback.)  */
Packit 6c4009
Packit 6c4009
#ifndef SUPPORT_H
Packit 6c4009
#define SUPPORT_H
Packit 6c4009
Packit 6c4009
#include <stddef.h>
Packit 6c4009
#include <sys/cdefs.h>
Packit 6c4009
Packit 6c4009
__BEGIN_DECLS
Packit 6c4009
Packit 6c4009
/* Write a message to standard output.  Can be used in signal
Packit 6c4009
   handlers.  */
Packit 6c4009
void write_message (const char *message) __attribute__ ((nonnull (1)));
Packit 6c4009
Packit 6c4009
/* Avoid all the buffer overflow messages on stderr.  */
Packit 6c4009
void ignore_stderr (void);
Packit 6c4009
Packit 6c4009
/* Set fortification error handler.  Used when tests want to verify that bad
Packit 6c4009
   code is caught by the library.  */
Packit 6c4009
void set_fortify_handler (void (*handler) (int sig));
Packit 6c4009
Packit 6c4009
/* Report an out-of-memory error for the allocation of SIZE bytes in
Packit 6c4009
   FUNCTION, terminating the process.  */
Packit 6c4009
void oom_error (const char *function, size_t size)
Packit 6c4009
  __attribute__ ((nonnull (1)));
Packit 6c4009
Packit 6c4009
/* Return a pointer to a memory region of SIZE bytes.  The memory is
Packit 6c4009
   initialized to zero and will be shared with subprocesses (across
Packit 6c4009
   fork).  The returned pointer must be freed using
Packit 6c4009
   support_shared_free; it is not compatible with the malloc
Packit 6c4009
   functions.  */
Packit 6c4009
void *support_shared_allocate (size_t size);
Packit 6c4009
Packit 6c4009
/* Deallocate a pointer returned by support_shared_allocate.  */
Packit 6c4009
void support_shared_free (void *);
Packit 6c4009
Packit 6c4009
/* Write CONTENTS to the file PATH.  Create or truncate the file as
Packit 6c4009
   needed.  The file mode is 0666 masked by the umask.  Terminate the
Packit 6c4009
   process on error.  */
Packit 6c4009
void support_write_file_string (const char *path, const char *contents);
Packit 6c4009
Packit 6c4009
/* Quote the contents of the byte array starting at BLOB, of LENGTH
Packit 6c4009
   bytes, in such a way that the result string can be included in a C
Packit 6c4009
   literal (in single/double quotes, without putting the quotes into
Packit 6c4009
   the result).  */
Packit 6c4009
char *support_quote_blob (const void *blob, size_t length);
Packit 6c4009
Packit 6c4009
/* Error-checking wrapper functions which terminate the process on
Packit 6c4009
   error.  */
Packit 6c4009
Packit 6c4009
void *xmalloc (size_t) __attribute__ ((malloc));
Packit 6c4009
void *xcalloc (size_t n, size_t s) __attribute__ ((malloc));
Packit 6c4009
void *xrealloc (void *p, size_t n);
Packit 6c4009
char *xasprintf (const char *format, ...)
Packit 6c4009
  __attribute__ ((format (printf, 1, 2), malloc));
Packit 6c4009
char *xstrdup (const char *);
Packit 6c4009
char *xstrndup (const char *, size_t);
Packit 6c4009
Packit 6c4009
__END_DECLS
Packit 6c4009
Packit 6c4009
#endif /* SUPPORT_H */