This commit is contained in:
John Cupitt 2010-01-14 16:49:45 +00:00
parent 8bbc47edef
commit fe42882030
3 changed files with 46 additions and 17 deletions

View File

@ -100,12 +100,20 @@ system_image_vec( im_object *argv )
IMAGE *out_image; IMAGE *out_image;
if( (out_image = im_system_image( in, if( !(out_image = im_system_image( in,
in_format, out_format, cmd, log )) ) in_format, out_format, cmd, log )) ) {
im_copy_file( out_image, out ); im_error( "im_system_image", "%s", *log );
im_free( *log );
return( -1 );
}
if( im_copy_file( out_image, out ) ||
im_add_close_callback( out,
(im_callback_fn) im_close, out_image, NULL ) ) {
im_close( out_image );
return( -1 );
}
/* We always succeed, but out may be invalid.
*/
return( 0 ); return( 0 );
} }

View File

@ -71,8 +71,22 @@ system_image( IMAGE *im,
VipsBuf buf = VIPS_BUF_STATIC( txt ); VipsBuf buf = VIPS_BUF_STATIC( txt );
int result; int result;
if( im_copy( im, in_image ) || /* We have to generate the comnmand-line before we close in_image.
!(fp = im_popenf( cmd_format, "r", in_name, out_name )) ) */
im_snprintf( line, IM_MAX_STRSIZE, cmd_format, in_name, out_name );
/* in_image usually needs to be closed before it'll write. Argh! And
* it'll be deleted on close too. skdaljfhaslkdf
*
* Perhaps we should do -write-on-close earlier? evalend? Or a new
* signal which im_generate() can emit when it connects to an image?
*/
if( im_copy( im, in_image ) ) {
im_close( in_image );
return( -1 );
}
if( im_close( in_image ) ||
!(fp = im_popenf( "%s", "r", line )) )
return( -1 ); return( -1 );
while( fgets( line, IM_MAX_STRSIZE, fp ) ) while( fgets( line, IM_MAX_STRSIZE, fp ) )
@ -84,6 +98,14 @@ system_image( IMAGE *im,
if( log ) if( log )
*log = im_strdup( NULL, vips_buf_all( &buf ) ); *log = im_strdup( NULL, vips_buf_all( &buf ) );
if( result ) {
IMAGE *t;
if( !(t = im_open_local( out_image, out_name, "r" )) ||
im_copy( t, out_image ) )
return( -1 );
}
return( result ); return( result );
} }
@ -110,8 +132,7 @@ system_image( IMAGE *im,
The caller would open the output file, either with im_open(), or with it's The caller would open the output file, either with im_open(), or with it's
own system (nip2 has it's own open file thing to give progress feedback and own system (nip2 has it's own open file thing to give progress feedback and
use disc for format conversion), and be responsible for deleting the temp use disc for format conversion), and be responsible for deleting the temp output file at some point.
output file at some point.
*/ */
@ -126,18 +147,18 @@ im_system_image( IMAGE *im,
if( log ) if( log )
*log = NULL; *log = NULL;
in_image = im__open_temp( in_format ); if( !(in_image = im__open_temp( in_format )) )
out_image = im__open_temp( out_format ); return( NULL );
if( !(out_image = im__open_temp( out_format )) ) {
if( !in_image ||
!out_image ||
system_image( im, in_image, out_image, cmd_format, log ) ) {
im_close( in_image ); im_close( in_image );
return( NULL );
}
if( system_image( im, in_image, out_image, cmd_format, log ) ) {
im_close( out_image ); im_close( out_image );
return( NULL ); return( NULL );
} }
im_close( in_image );
return( out_image ); return( out_image );
} }

View File

@ -452,7 +452,7 @@ im_open( const char *filename, const char *mode )
"vips" ) == 0 ) "vips" ) == 0 )
im = im_openout( filename ); im = im_openout( filename );
else { else {
if( !(im = im_open( "im_open:lw:1", "p" )) ) if( !(im = im_open( filename, "p" )) )
return( NULL ); return( NULL );
if( attach_sb( im, format->save, filename ) ) { if( attach_sb( im, format->save, filename ) ) {
im_close( im ); im_close( im );