From be57d1fbec6ebc3864802d5a4f41d97ae7ffb737 Mon Sep 17 00:00:00 2001 From: shawnlaffan Date: Sat, 17 Aug 2024 15:50:39 +1000 Subject: [PATCH] Use File::Path::Tiny to clean up temp dir This avoids thread-based issues with File::Path as used by File::Temp. --- lib/Excel/Writer/XLSX/Workbook.pm | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/lib/Excel/Writer/XLSX/Workbook.pm b/lib/Excel/Writer/XLSX/Workbook.pm index 3df96a45..221b4162 100644 --- a/lib/Excel/Writer/XLSX/Workbook.pm +++ b/lib/Excel/Writer/XLSX/Workbook.pm @@ -298,6 +298,11 @@ sub DESTROY { local ( $@, $!, $^E, $? ); $self->close() if not $self->{_fileclosed}; + if (defined $self->{_tempdir_object} && -d $self->{_tempdir_object}) { + use File::Path::Tiny; + # say STDERR $self->{_tempdir_object}; + File::Path::Tiny::rm($self->{_tempdir_object}->dirname, 1); + } delete $self->{_tempdir_object}; } @@ -1129,14 +1134,15 @@ sub get_default_url_format { sub _store_workbook { my $self = shift; - my $tempdir = File::Temp->newdir( DIR => $self->{_tempdir} ); + my $tempdir = File::Temp->newdir(DIR => $self->{_tempdir}); - # Store the File::Temp object within $self so that the temporary files + # Store the temp dir object within $self so that the temporary files # are only removed when the workbook object is destroyed. - # This control over timing is required because the removal - # of File::Temp temporary directories is not thread-safe. + # This control over timing is required because File::Temp uses + # File::Path for directory removal, and it is not thread-safe + # so we need to use a different cleanup approach. + $tempdir->unlink_on_destroy(0); $self->{_tempdir_object} = $tempdir; - my $packager = Excel::Writer::XLSX::Package::Packager->new(); my $zip = Archive::Zip->new();