tiny cache clean-up
This commit is contained in:
parent
ec3366257f
commit
862d7f03ea
@ -6,6 +6,7 @@
|
|||||||
- vipsthumbnail retries with specified input profile if embedded profile is
|
- vipsthumbnail retries with specified input profile if embedded profile is
|
||||||
broken
|
broken
|
||||||
- add @profile option to pngsave, matching tiff and jpeg
|
- add @profile option to pngsave, matching tiff and jpeg
|
||||||
|
- fix a race in the operation cache [Lovell]
|
||||||
|
|
||||||
8/9/14 started 7.40.8
|
8/9/14 started 7.40.8
|
||||||
- fix configure on rhel6 [Lovell]
|
- fix configure on rhel6 [Lovell]
|
||||||
|
@ -599,12 +599,9 @@ vips_cache_ref( VipsOperation *operation )
|
|||||||
static void
|
static void
|
||||||
vips_cache_insert( VipsOperation *operation )
|
vips_cache_insert( VipsOperation *operation )
|
||||||
{
|
{
|
||||||
/* It must not be in cache.
|
|
||||||
*/
|
|
||||||
if( g_hash_table_lookup( vips_cache_table, operation ) )
|
|
||||||
return;
|
|
||||||
|
|
||||||
VipsOperationCacheEntry *entry = g_new( VipsOperationCacheEntry, 1 );
|
VipsOperationCacheEntry *entry = g_new( VipsOperationCacheEntry, 1 );
|
||||||
|
|
||||||
|
entry = g_new( VipsOperationCacheEntry, 1 );
|
||||||
entry->operation = operation;
|
entry->operation = operation;
|
||||||
entry->time = 0;
|
entry->time = 0;
|
||||||
entry->invalidate_id = 0;
|
entry->invalidate_id = 0;
|
||||||
@ -759,28 +756,38 @@ vips_cache_operation_buildp( VipsOperation **operation )
|
|||||||
*operation = hit->operation;
|
*operation = hit->operation;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* We have to unlock between search and add so that more than one
|
||||||
|
* _build() can run at once.
|
||||||
|
*/
|
||||||
g_mutex_unlock( vips_cache_lock );
|
g_mutex_unlock( vips_cache_lock );
|
||||||
|
|
||||||
if( !hit ) {
|
if( !hit ) {
|
||||||
if( vips_object_build( VIPS_OBJECT( *operation ) ) )
|
if( vips_object_build( VIPS_OBJECT( *operation ) ) )
|
||||||
return( -1 );
|
return( -1 );
|
||||||
|
|
||||||
/* Has to be after _build() so we can see output args.
|
|
||||||
*/
|
|
||||||
if( vips__cache_trace ) {
|
|
||||||
if( vips_operation_get_flags( *operation ) &
|
|
||||||
VIPS_OPERATION_NOCACHE )
|
|
||||||
printf( "vips cache : " );
|
|
||||||
else
|
|
||||||
printf( "vips cache+: " );
|
|
||||||
vips_object_print_summary( VIPS_OBJECT( *operation ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
g_mutex_lock( vips_cache_lock );
|
g_mutex_lock( vips_cache_lock );
|
||||||
|
|
||||||
if( !(vips_operation_get_flags( *operation ) &
|
/* If two threads call the same operation at the same time,
|
||||||
VIPS_OPERATION_NOCACHE) )
|
* we can get multiple adds. Let the first one win. See
|
||||||
vips_cache_insert( *operation );
|
* https://github.com/jcupitt/libvips/pull/181
|
||||||
|
*/
|
||||||
|
if( !g_hash_table_lookup( vips_cache_table, operation ) ) {
|
||||||
|
/* Has to be after _build() so we can see output args.
|
||||||
|
*/
|
||||||
|
if( vips__cache_trace ) {
|
||||||
|
if( vips_operation_get_flags( *operation ) &
|
||||||
|
VIPS_OPERATION_NOCACHE )
|
||||||
|
printf( "vips cache : " );
|
||||||
|
else
|
||||||
|
printf( "vips cache+: " );
|
||||||
|
vips_object_print_summary(
|
||||||
|
VIPS_OBJECT( *operation ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
if( !(vips_operation_get_flags( *operation ) &
|
||||||
|
VIPS_OPERATION_NOCACHE) )
|
||||||
|
vips_cache_insert( *operation );
|
||||||
|
}
|
||||||
|
|
||||||
g_mutex_unlock( vips_cache_lock );
|
g_mutex_unlock( vips_cache_lock );
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user