libexplain  1.4.D001
libexplain/mktemp_on_error.c
Go to the documentation of this file.
00001 /*
00002  * libexplain - Explain errno values returned by libc functions
00003  * Copyright (C) 2010-2013 Peter Miller
00004  *
00005  * This program is free software; you can redistribute it and/or modify it
00006  * under the terms of the GNU Lesser General Public License as published by
00007  * the Free Software Foundation; either version 3 of the License, or (at
00008  * your option) any later version.
00009  *
00010  * This program is distributed in the hope that it will be useful,but
00011  * WITHOUT ANY WARRANTY; without even the implied warranty
00012  * ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNULesser
00013  * General Public License for more details.
00014  *
00015  * You should have received a copy of the GNU Lesser General Public License
00016  * along with this program. If not, see <http://www.gnu.org/licenses/>.
00017  */
00018 
00019 #include <libexplain/ac/errno.h>
00020 #include <libexplain/ac/stdlib.h>
00021 
00022 #include <libexplain/mktemp.h>
00023 #include <libexplain/output.h>
00024 
00025 
00026 char *
00027 explain_mktemp_on_error(char *templat)
00028 {
00029     char            first;
00030     char            *result;
00031 
00032     /*
00033      * From mktemp(3)...
00034      *
00035      *     "The mktemp() function always returns template.  If a unique name
00036      *     was created, the last six bytes of template will have been modified
00037      *     in such a way that the resulting name is unique (i.e., does not
00038      *     exist already).  If a unique name could not be created, template is
00039      *     made an empty string."
00040      *
00041      * So, instead of returning a NULL pointer like the vast majority of libc
00042      * functions, this one returns the orginal string, but sets the first byte
00043      * to '\0'.  Sheesh!  This makes our job much harder.
00044      */
00045     first = templat[0];
00046     result = mktemp(templat);
00047     /* assert(result == templat); */
00048     if (result[0] == '\0')
00049     {
00050         int             hold_errno;
00051 
00052         hold_errno = errno;
00053         /* assert(templat[0] == '\0'); */
00054         templat[0] = first;
00055         explain_output_error("%s", explain_errno_mktemp(hold_errno, templat));
00056         templat[0] = '\0';
00057         errno = hold_errno;
00058     }
00059     return result;
00060 }
00061 
00062 
00063 /* vim: set ts=8 sw=4 et : */