From b14bc2ae879e6f2b9489e6e55129a5ef6d11e029 Mon Sep 17 00:00:00 2001 From: Eric Wong Date: Fri, 28 Sep 2012 19:52:46 -0700 Subject: [PATCH] mogupload: avoid slurping regular files into memory This allows uploading of large files that do not fit into memory again. Data piped via stdin still uses a huge in-memory buffer since server support for Content-Range/Transfer-Encoding:chunked is inconsistent. --- mogupload | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) diff --git a/mogupload b/mogupload index 99e4a4c..086455b 100755 --- a/mogupload +++ b/mogupload @@ -44,10 +44,6 @@ A local file to upload. If '-', read file from STDIN instead. Dormando ELE -=head1 BUGS - -mogupload must buffer the upload in memory before transferring it. This makes it difficult to upload very large files. Future versions will lift this limitation. - =head1 LICENSE Licensed for use and redistribution under the same terms as Perl itself. @@ -70,7 +66,7 @@ my $filename = $c->{file}; die "Must specify a file to upload with --file" unless $filename; my $fh; -my $size = 0; +my $size; if ($filename eq '-') { $fh = *STDIN; } else { @@ -79,7 +75,7 @@ if ($filename eq '-') { open($fh, "< $filename") or die "Could not open " . $filename; } -my $mf = $mogc->new_file($c->{key}, $c->{class}, undef); +my $mf = $mogc->new_file($c->{key}, $c->{class}, $size); if ($mogc->errcode) { die "Error opening MogileFS file: " . $mogc->errstr; }