use O_TMPFILE, if available
If O_TNMPFILE is available, use it. This is a linux extension that creates an unlinked file, so it'll be closed by the system when the last associated fd is closed. see https://github.com/jcupitt/libvips/pull/930
This commit is contained in:
parent
1e647a2af4
commit
06802e4110
@ -12,6 +12,7 @@
|
|||||||
- drop incompatible ICC profiles before save
|
- drop incompatible ICC profiles before save
|
||||||
- better hasalpha rules
|
- better hasalpha rules
|
||||||
- create funcs always make MULTIBAND (ie. no alpha)
|
- create funcs always make MULTIBAND (ie. no alpha)
|
||||||
|
- use O_TMPFILE, if available [Alexander--]
|
||||||
|
|
||||||
12/3/18 started 8.6.4
|
12/3/18 started 8.6.4
|
||||||
- better fitting of fonts with overhanging edges, thanks Adrià
|
- better fitting of fonts with overhanging edges, thanks Adrià
|
||||||
|
@ -21,6 +21,8 @@
|
|||||||
* - use expat for xml read, printf for xml write
|
* - use expat for xml read, printf for xml write
|
||||||
* 16/8/17
|
* 16/8/17
|
||||||
* - validate strs as being utf-8 before we write
|
* - validate strs as being utf-8 before we write
|
||||||
|
* 9/4/18 Alexander--
|
||||||
|
* - use O_TMPFILE, if available
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -55,6 +57,10 @@
|
|||||||
#define DEBUG
|
#define DEBUG
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* Enable linux extensions like O_TMPFILE, if available.
|
||||||
|
*/
|
||||||
|
#define _GNU_SOURCE
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
#endif /*HAVE_CONFIG_H*/
|
#endif /*HAVE_CONFIG_H*/
|
||||||
@ -69,12 +75,12 @@
|
|||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <fcntl.h>
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <fcntl.h>
|
||||||
#ifdef HAVE_SYS_FILE_H
|
#ifdef HAVE_SYS_FILE_H
|
||||||
#include <sys/file.h>
|
#include <sys/file.h>
|
||||||
#endif /*HAVE_SYS_FILE_H*/
|
#endif /*HAVE_SYS_FILE_H*/
|
||||||
#include <sys/stat.h>
|
|
||||||
#ifdef HAVE_UNISTD_H
|
#ifdef HAVE_UNISTD_H
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#endif /*HAVE_UNISTD_H*/
|
#endif /*HAVE_UNISTD_H*/
|
||||||
@ -181,8 +187,26 @@ vips__open_image_write( const char *filename, gboolean temp )
|
|||||||
|
|
||||||
flags = MODE_WRITE;
|
flags = MODE_WRITE;
|
||||||
|
|
||||||
|
#ifdef O_TMPFILE
|
||||||
|
/* Linux-only extension creates an unlinked file. CREAT and TRUNC must
|
||||||
|
* be clear. The filename arg to open() must name a directory.
|
||||||
|
*/
|
||||||
|
if( temp ) {
|
||||||
|
char *dirname;
|
||||||
|
|
||||||
|
flags |= O_TMPFILE;
|
||||||
|
flags &= ~O_CREAT;
|
||||||
|
flags &= ~O_TRUNC;
|
||||||
|
|
||||||
|
dirname = g_path_get_dirname( filename );
|
||||||
|
fd = vips_tracked_open( dirname, flags, 0666 );
|
||||||
|
g_free( dirname );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
fd = vips_tracked_open( filename, flags, 0666 );
|
||||||
|
#else /*!O_TMPFILE*/
|
||||||
#ifdef _O_TEMPORARY
|
#ifdef _O_TEMPORARY
|
||||||
/* On Windows, setting O_TEMP gets the file automatically
|
/* On Windows, setting _O_TEMPORARY gets the file automatically
|
||||||
* deleted on process exit, even if the processes crashes. See
|
* deleted on process exit, even if the processes crashes. See
|
||||||
* vips_image_rewind() for what we do to help on *nix.
|
* vips_image_rewind() for what we do to help on *nix.
|
||||||
*/
|
*/
|
||||||
@ -190,10 +214,12 @@ vips__open_image_write( const char *filename, gboolean temp )
|
|||||||
flags |= _O_TEMPORARY;
|
flags |= _O_TEMPORARY;
|
||||||
#endif /*_O_TEMPORARY*/
|
#endif /*_O_TEMPORARY*/
|
||||||
|
|
||||||
if( (fd = vips_tracked_open( filename, flags, 0666 )) < 0 ) {
|
fd = vips_tracked_open( filename, flags, 0666 );
|
||||||
|
#endif /*O_TMPFILE*/
|
||||||
|
|
||||||
|
if( fd < 0 ) {
|
||||||
vips_error_system( errno, "VipsImage",
|
vips_error_system( errno, "VipsImage",
|
||||||
_( "unable to write to \"%s\"" ),
|
_( "unable to write to \"%s\"" ), filename );
|
||||||
filename );
|
|
||||||
return( -1 );
|
return( -1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user