NeoMutt  2025-01-09-41-g086358
Teaching an old dog new tricks
DOXYGEN
Loading...
Searching...
No Matches
tmp.h File Reference

Create Temporary Files. More...

#include <stdio.h>
+ Include dependency graph for tmp.h:
+ This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Macros

#define buf_mktemp(buf)   buf_mktemp_pfx_sfx(buf, "neomutt", NULL)
 
#define buf_mktemp_pfx_sfx(buf, prefix, suffix)   buf_mktemp_full(buf, prefix, suffix, __FILE__, __LINE__)
 
#define mutt_file_mkstemp()   mutt_file_mkstemp_full(__FILE__, __LINE__, __func__)
 

Functions

void buf_mktemp_full (struct Buffer *buf, const char *prefix, const char *suffix, const char *src, int line)
 Create a temporary file.
 
FILE * mutt_file_mkstemp_full (const char *file, int line, const char *func)
 Create temporary file safely.
 

Detailed Description

Create Temporary Files.

Authors
  • Richard Russon

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.

Definition in file tmp.h.

Macro Definition Documentation

◆ buf_mktemp

#define buf_mktemp (   buf)    buf_mktemp_pfx_sfx(buf, "neomutt", NULL)

Definition at line 33 of file tmp.h.

◆ buf_mktemp_pfx_sfx

#define buf_mktemp_pfx_sfx (   buf,
  prefix,
  suffix 
)    buf_mktemp_full(buf, prefix, suffix, __FILE__, __LINE__)

Definition at line 34 of file tmp.h.

◆ mutt_file_mkstemp

#define mutt_file_mkstemp ( )    mutt_file_mkstemp_full(__FILE__, __LINE__, __func__)

Definition at line 36 of file tmp.h.

Function Documentation

◆ buf_mktemp_full()

void buf_mktemp_full ( struct Buffer buf,
const char *  prefix,
const char *  suffix,
const char *  src,
int  line 
)

Create a temporary file.

Parameters
bufBuffer for result
prefixPrefix for filename
suffixSuffix for filename
srcSource file of caller
lineSource line number of caller

Definition at line 50 of file tmp.c.

52{
53 const char *const c_tmp_dir = cs_subset_path(NeoMutt->sub, "tmp_dir");
54 buf_printf(buf, "%s/%s-%s-%d-%d-%" PRIu64 "%s%s", NONULL(c_tmp_dir),
55 NONULL(prefix), NONULL(ShortHostname), (int) getuid(),
56 (int) getpid(), mutt_rand64(), suffix ? "." : "", NONULL(suffix));
57
58 mutt_debug(LL_DEBUG3, "%s:%d: buf_mktemp returns \"%s\"\n", src, line, buf_string(buf));
59 if (unlink(buf_string(buf)) && (errno != ENOENT))
60 {
61 mutt_debug(LL_DEBUG1, "%s:%d: ERROR: unlink(\"%s\"): %s (errno %d)\n", src,
62 line, buf_string(buf), strerror(errno), errno);
63 }
64}
int buf_printf(struct Buffer *buf, const char *fmt,...)
Format a string overwriting a Buffer.
Definition: buffer.c:161
static const char * buf_string(const struct Buffer *buf)
Convert a buffer to a const char * "string".
Definition: buffer.h:96
const char * cs_subset_path(const struct ConfigSubset *sub, const char *name)
Get a path config item by name.
Definition: helpers.c:168
char * ShortHostname
Short version of the hostname.
Definition: globals.c:38
#define mutt_debug(LEVEL,...)
Definition: logging2.h:89
@ LL_DEBUG3
Log at debug level 3.
Definition: logging2.h:45
@ LL_DEBUG1
Log at debug level 1.
Definition: logging2.h:43
uint64_t mutt_rand64(void)
Create a 64-bit random number.
Definition: random.c:123
#define NONULL(x)
Definition: string2.h:37
Container for Accounts, Notifications.
Definition: neomutt.h:42
struct ConfigSubset * sub
Inherited config items.
Definition: neomutt.h:46
+ Here is the call graph for this function:

◆ mutt_file_mkstemp_full()

FILE * mutt_file_mkstemp_full ( const char *  file,
int  line,
const char *  func 
)

Create temporary file safely.

Parameters
fileSource file of caller
lineSource line number of caller
funcFunction name of caller
Return values
ptrFILE handle
NULLError, see errno

Create and immediately unlink a temp file using mkstemp().

Definition at line 76 of file tmp.c.

77{
78 char name[PATH_MAX] = { 0 };
79
80 const char *const c_tmp_dir = cs_subset_path(NeoMutt->sub, "tmp_dir");
81 int n = snprintf(name, sizeof(name), "%s/neomutt-XXXXXX", NONULL(c_tmp_dir));
82 if (n < 0)
83 return NULL;
84
85 int fd = mkstemp(name);
86 if (fd == -1)
87 return NULL;
88
89 FILE *fp = fdopen(fd, "w+");
90
91 if ((unlink(name) != 0) && (errno != ENOENT))
92 {
94 return NULL;
95 }
96
97 MuttLogger(0, file, line, func, 1, "created temp file '%s'\n", name);
98 return fp;
99}
#define mutt_file_fclose(FP)
Definition: file.h:139
int(*) log_dispatcher_ MuttLogger)
#define PATH_MAX
Definition: mutt.h:42
+ Here is the call graph for this function: