Blame gl/tempname.h

Packit a4aae4
/* Create a temporary file or directory.
Packit a4aae4
Packit a4aae4
   Copyright (C) 2006, 2009-2017 Free Software Foundation, Inc.
Packit a4aae4
Packit a4aae4
   This program is free software: you can redistribute it and/or modify
Packit a4aae4
   it under the terms of the GNU Lesser General Public License as published by
Packit a4aae4
   the Free Software Foundation; either version 3 of the License, or
Packit a4aae4
   (at your option) any later version.
Packit a4aae4
Packit a4aae4
   This program is distributed in the hope that it will be useful,
Packit a4aae4
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit a4aae4
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit a4aae4
   GNU Lesser General Public License for more details.
Packit a4aae4
Packit a4aae4
   You should have received a copy of the GNU Lesser General Public License
Packit a4aae4
   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
Packit a4aae4
Packit a4aae4
/* header written by Eric Blake */
Packit a4aae4
Packit a4aae4
#ifndef GL_TEMPNAME_H
Packit a4aae4
# define GL_TEMPNAME_H
Packit a4aae4
Packit a4aae4
# include <stdio.h>
Packit a4aae4
Packit a4aae4
# ifdef __GT_FILE
Packit a4aae4
#  define GT_FILE     __GT_FILE
Packit a4aae4
#  define GT_DIR      __GT_DIR
Packit a4aae4
#  define GT_NOCREATE __GT_NOCREATE
Packit a4aae4
# else
Packit a4aae4
#  define GT_FILE     0
Packit a4aae4
#  define GT_DIR      1
Packit a4aae4
#  define GT_NOCREATE 2
Packit a4aae4
# endif
Packit a4aae4
Packit a4aae4
#ifdef __cplusplus
Packit a4aae4
extern "C" {
Packit a4aae4
#endif
Packit a4aae4
Packit a4aae4
/* Generate a temporary file name based on TMPL.  TMPL must match the
Packit a4aae4
   rules for mk[s]temp (i.e. end in "XXXXXX", possibly with a suffix).
Packit a4aae4
   The name constructed does not exist at the time of the call to
Packit a4aae4
   gen_tempname.  TMPL is overwritten with the result.
Packit a4aae4
Packit a4aae4
   KIND may be one of:
Packit a4aae4
   GT_NOCREATE:         simply verify that the name does not exist
Packit a4aae4
                        at the time of the call.
Packit a4aae4
   GT_FILE:             create a large file using open(O_CREAT|O_EXCL)
Packit a4aae4
                        and return a read-write fd.  The file is mode 0600.
Packit a4aae4
   GT_DIR:              create a directory, which will be mode 0700.
Packit a4aae4
Packit a4aae4
   We use a clever algorithm to get hard-to-predict names. */
Packit a4aae4
extern int gen_tempname (char *tmpl, int suffixlen, int flags, int kind);
Packit a4aae4
Packit a4aae4
/* Similar to gen_tempname, but TRYFUNC is called for each temporary
Packit a4aae4
   name to try.  If TRYFUNC returns a non-negative number, TRY_GEN_TEMPNAME
Packit a4aae4
   returns with this value.  Otherwise, if errno is set to EEXIST, another
Packit a4aae4
   name is tried, or else TRY_GEN_TEMPNAME returns -1. */
Packit a4aae4
extern int try_tempname (char *tmpl, int suffixlen, void *args,
Packit a4aae4
                         int (*tryfunc) (char *, void *));
Packit a4aae4
Packit a4aae4
#ifdef __cplusplus
Packit a4aae4
}
Packit a4aae4
#endif
Packit a4aae4
Packit a4aae4
#endif /* GL_TEMPNAME_H */