summaryrefslogtreecommitdiffstats
path: root/lib/Spreadsheet/ParseXLSX.pm
diff options
context:
space:
mode:
authorJesse Luehrs <doy@tozt.net>2016-06-25 13:59:34 -0400
committerJesse Luehrs <doy@tozt.net>2016-06-25 13:59:34 -0400
commit529f114e86dfd360db60df22bbb75830b219b12a (patch)
tree6bc406d3249249d6b48a7fa68d84b1cf99975810 /lib/Spreadsheet/ParseXLSX.pm
parent0815bd02ec1849fda6cf4666ca849bb4babdfe87 (diff)
downloadspreadsheet-parsexlsx-529f114e86dfd360db60df22bbb75830b219b12a.tar.gz
spreadsheet-parsexlsx-529f114e86dfd360db60df22bbb75830b219b12a.zip
support scalar refs as inputs too
for compatibility with Spreadsheet::ParseExcel
Diffstat (limited to 'lib/Spreadsheet/ParseXLSX.pm')
-rw-r--r--lib/Spreadsheet/ParseXLSX.pm12
1 files changed, 11 insertions, 1 deletions
diff --git a/lib/Spreadsheet/ParseXLSX.pm b/lib/Spreadsheet/ParseXLSX.pm
index c38cfc2..0ffbc43 100644
--- a/lib/Spreadsheet/ParseXLSX.pm
+++ b/lib/Spreadsheet/ParseXLSX.pm
@@ -88,13 +88,20 @@ sub parse {
$workbook->{File} = undef;
$workbook->{__tempfile} = $file;
}
+ elsif (ref($file) eq 'SCALAR') {
+ open my $fh, '+<', $file
+ or die "Can't create filehandle from memory data";
+ $zip->readFromFileHandle($fh) == Archive::Zip::AZ_OK
+ or die "Can't open scalar ref as a zip file";
+ $workbook->{File} = undef;
+ }
elsif (!ref($file)) {
$zip->read($file) == Archive::Zip::AZ_OK
or die "Can't open file '$file' as a zip file";
$workbook->{File} = $file;
}
else {
- die "Argument to 'new' must be a filename or open filehandle";
+ die "Argument to 'new' must be a filename, open filehandle, or scalar ref";
}
return $self->_parse_workbook($zip, $workbook, $formatter);
@@ -110,6 +117,9 @@ sub _check_signature {
$file->read($signature, 2);
$file->seek(-2, IO::File::SEEK_CUR);
}
+ elsif (ref($file) eq 'SCALAR') {
+ $signature = substr($$file, 0, 2);
+ }
elsif (!ref($file)) {
my $fh = IO::File->new($file, 'r');
$fh->read($signature, 2);