1IO::Compress::Bzip2(3pm)Perl Programmers Reference GuideIO::Compress::Bzip2(3pm)
2
3
4
6 IO::Compress::Bzip2 - Write bzip2 files/buffers
7
9 use IO::Compress::Bzip2 qw(bzip2 $Bzip2Error) ;
10
11 my $status = bzip2 $input => $output [,OPTS]
12 or die "bzip2 failed: $Bzip2Error\n";
13
14 my $z = new IO::Compress::Bzip2 $output [,OPTS]
15 or die "bzip2 failed: $Bzip2Error\n";
16
17 $z->print($string);
18 $z->printf($format, $string);
19 $z->write($string);
20 $z->syswrite($string [, $length, $offset]);
21 $z->flush();
22 $z->tell();
23 $z->eof();
24 $z->seek($position, $whence);
25 $z->binmode();
26 $z->fileno();
27 $z->opened();
28 $z->autoflush();
29 $z->input_line_number();
30 $z->newStream( [OPTS] );
31
32 $z->close() ;
33
34 $Bzip2Error ;
35
36 # IO::File mode
37
38 print $z $string;
39 printf $z $format, $string;
40 tell $z
41 eof $z
42 seek $z, $position, $whence
43 binmode $z
44 fileno $z
45 close $z ;
46
48 This module provides a Perl interface that allows writing bzip2
49 compressed data to files or buffer.
50
51 For reading bzip2 files/buffers, see the companion module
52 IO::Uncompress::Bunzip2.
53
55 A top-level function, "bzip2", is provided to carry out "one-shot"
56 compression between buffers and/or files. For finer control over the
57 compression process, see the "OO Interface" section.
58
59 use IO::Compress::Bzip2 qw(bzip2 $Bzip2Error) ;
60
61 bzip2 $input => $output [,OPTS]
62 or die "bzip2 failed: $Bzip2Error\n";
63
64 The functional interface needs Perl5.005 or better.
65
66 bzip2 $input => $output [, OPTS]
67 "bzip2" expects at least two parameters, $input and $output.
68
69 The $input parameter
70
71 The parameter, $input, is used to define the source of the uncompressed
72 data.
73
74 It can take one of the following forms:
75
76 A filename
77 If the $input parameter is a simple scalar, it is assumed to be a
78 filename. This file will be opened for reading and the input data
79 will be read from it.
80
81 A filehandle
82 If the $input parameter is a filehandle, the input data will be
83 read from it. The string '-' can be used as an alias for standard
84 input.
85
86 A scalar reference
87 If $input is a scalar reference, the input data will be read from
88 $$input.
89
90 An array reference
91 If $input is an array reference, each element in the array must be
92 a filename.
93
94 The input data will be read from each file in turn.
95
96 The complete array will be walked to ensure that it only contains
97 valid filenames before any data is compressed.
98
99 An Input FileGlob string
100 If $input is a string that is delimited by the characters "<" and
101 ">" "bzip2" will assume that it is an input fileglob string. The
102 input is the list of files that match the fileglob.
103
104 If the fileglob does not match any files ...
105
106 See File::GlobMapper for more details.
107
108 If the $input parameter is any other type, "undef" will be returned.
109
110 The $output parameter
111
112 The parameter $output is used to control the destination of the
113 compressed data. This parameter can take one of these forms.
114
115 A filename
116 If the $output parameter is a simple scalar, it is assumed to be a
117 filename. This file will be opened for writing and the compressed
118 data will be written to it.
119
120 A filehandle
121 If the $output parameter is a filehandle, the compressed data will
122 be written to it. The string '-' can be used as an alias for
123 standard output.
124
125 A scalar reference
126 If $output is a scalar reference, the compressed data will be
127 stored in $$output.
128
129 An Array Reference
130 If $output is an array reference, the compressed data will be
131 pushed onto the array.
132
133 An Output FileGlob
134 If $output is a string that is delimited by the characters "<" and
135 ">" "bzip2" will assume that it is an output fileglob string. The
136 output is the list of files that match the fileglob.
137
138 When $output is an fileglob string, $input must also be a fileglob
139 string. Anything else is an error.
140
141 If the $output parameter is any other type, "undef" will be returned.
142
143 Notes
144 When $input maps to multiple files/buffers and $output is a single
145 file/buffer the input files/buffers will be stored in $output as a
146 concatenated series of compressed data streams.
147
148 Optional Parameters
149 Unless specified below, the optional parameters for "bzip2", "OPTS",
150 are the same as those used with the OO interface defined in the
151 "Constructor Options" section below.
152
153 "AutoClose => 0|1"
154 This option applies to any input or output data streams to "bzip2"
155 that are filehandles.
156
157 If "AutoClose" is specified, and the value is true, it will result
158 in all input and/or output filehandles being closed once "bzip2"
159 has completed.
160
161 This parameter defaults to 0.
162
163 "BinModeIn => 0|1"
164 When reading from a file or filehandle, set "binmode" before
165 reading.
166
167 Defaults to 0.
168
169 "Append => 0|1"
170 TODO
171
172 Examples
173 To read the contents of the file "file1.txt" and write the compressed
174 data to the file "file1.txt.bz2".
175
176 use strict ;
177 use warnings ;
178 use IO::Compress::Bzip2 qw(bzip2 $Bzip2Error) ;
179
180 my $input = "file1.txt";
181 bzip2 $input => "$input.bz2"
182 or die "bzip2 failed: $Bzip2Error\n";
183
184 To read from an existing Perl filehandle, $input, and write the
185 compressed data to a buffer, $buffer.
186
187 use strict ;
188 use warnings ;
189 use IO::Compress::Bzip2 qw(bzip2 $Bzip2Error) ;
190 use IO::File ;
191
192 my $input = new IO::File "<file1.txt"
193 or die "Cannot open 'file1.txt': $!\n" ;
194 my $buffer ;
195 bzip2 $input => \$buffer
196 or die "bzip2 failed: $Bzip2Error\n";
197
198 To compress all files in the directory "/my/home" that match "*.txt"
199 and store the compressed data in the same directory
200
201 use strict ;
202 use warnings ;
203 use IO::Compress::Bzip2 qw(bzip2 $Bzip2Error) ;
204
205 bzip2 '</my/home/*.txt>' => '<*.bz2>'
206 or die "bzip2 failed: $Bzip2Error\n";
207
208 and if you want to compress each file one at a time, this will do the
209 trick
210
211 use strict ;
212 use warnings ;
213 use IO::Compress::Bzip2 qw(bzip2 $Bzip2Error) ;
214
215 for my $input ( glob "/my/home/*.txt" )
216 {
217 my $output = "$input.bz2" ;
218 bzip2 $input => $output
219 or die "Error compressing '$input': $Bzip2Error\n";
220 }
221
223 Constructor
224 The format of the constructor for "IO::Compress::Bzip2" is shown below
225
226 my $z = new IO::Compress::Bzip2 $output [,OPTS]
227 or die "IO::Compress::Bzip2 failed: $Bzip2Error\n";
228
229 It returns an "IO::Compress::Bzip2" object on success and undef on
230 failure. The variable $Bzip2Error will contain an error message on
231 failure.
232
233 If you are running Perl 5.005 or better the object, $z, returned from
234 IO::Compress::Bzip2 can be used exactly like an IO::File filehandle.
235 This means that all normal output file operations can be carried out
236 with $z. For example, to write to a compressed file/buffer you can use
237 either of these forms
238
239 $z->print("hello world\n");
240 print $z "hello world\n";
241
242 The mandatory parameter $output is used to control the destination of
243 the compressed data. This parameter can take one of these forms.
244
245 A filename
246 If the $output parameter is a simple scalar, it is assumed to be a
247 filename. This file will be opened for writing and the compressed
248 data will be written to it.
249
250 A filehandle
251 If the $output parameter is a filehandle, the compressed data will
252 be written to it. The string '-' can be used as an alias for
253 standard output.
254
255 A scalar reference
256 If $output is a scalar reference, the compressed data will be
257 stored in $$output.
258
259 If the $output parameter is any other type, "IO::Compress::Bzip2"::new
260 will return undef.
261
262 Constructor Options
263 "OPTS" is any combination of the following options:
264
265 "AutoClose => 0|1"
266 This option is only valid when the $output parameter is a
267 filehandle. If specified, and the value is true, it will result in
268 the $output being closed once either the "close" method is called
269 or the "IO::Compress::Bzip2" object is destroyed.
270
271 This parameter defaults to 0.
272
273 "Append => 0|1"
274 Opens $output in append mode.
275
276 The behaviour of this option is dependent on the type of $output.
277
278 · A Buffer
279
280 If $output is a buffer and "Append" is enabled, all
281 compressed data will be append to the end if $output.
282 Otherwise $output will be cleared before any data is written
283 to it.
284
285 · A Filename
286
287 If $output is a filename and "Append" is enabled, the file
288 will be opened in append mode. Otherwise the contents of the
289 file, if any, will be truncated before any compressed data is
290 written to it.
291
292 · A Filehandle
293
294 If $output is a filehandle, the file pointer will be
295 positioned to the end of the file via a call to "seek" before
296 any compressed data is written to it. Otherwise the file
297 pointer will not be moved.
298
299 This parameter defaults to 0.
300
301 "BlockSize100K => number"
302 Specify the number of 100K blocks bzip2 uses during compression.
303
304 Valid values are from 1 to 9, where 9 is best compression.
305
306 The default is 1.
307
308 "WorkFactor => number"
309 Specifies how much effort bzip2 should take before resorting to a
310 slower fallback compression algorithm.
311
312 Valid values range from 0 to 250, where 0 means use the default
313 value 30.
314
315 The default is 0.
316
317 "Strict => 0|1"
318 This is a placeholder option.
319
320 Examples
321 TODO
322
324 print
325 Usage is
326
327 $z->print($data)
328 print $z $data
329
330 Compresses and outputs the contents of the $data parameter. This has
331 the same behaviour as the "print" built-in.
332
333 Returns true if successful.
334
335 printf
336 Usage is
337
338 $z->printf($format, $data)
339 printf $z $format, $data
340
341 Compresses and outputs the contents of the $data parameter.
342
343 Returns true if successful.
344
345 syswrite
346 Usage is
347
348 $z->syswrite $data
349 $z->syswrite $data, $length
350 $z->syswrite $data, $length, $offset
351
352 Compresses and outputs the contents of the $data parameter.
353
354 Returns the number of uncompressed bytes written, or "undef" if
355 unsuccessful.
356
357 write
358 Usage is
359
360 $z->write $data
361 $z->write $data, $length
362 $z->write $data, $length, $offset
363
364 Compresses and outputs the contents of the $data parameter.
365
366 Returns the number of uncompressed bytes written, or "undef" if
367 unsuccessful.
368
369 flush
370 Usage is
371
372 $z->flush;
373
374 Flushes any pending compressed data to the output file/buffer.
375
376 TODO
377
378 Returns true on success.
379
380 tell
381 Usage is
382
383 $z->tell()
384 tell $z
385
386 Returns the uncompressed file offset.
387
388 eof
389 Usage is
390
391 $z->eof();
392 eof($z);
393
394 Returns true if the "close" method has been called.
395
396 seek
397 $z->seek($position, $whence);
398 seek($z, $position, $whence);
399
400 Provides a sub-set of the "seek" functionality, with the restriction
401 that it is only legal to seek forward in the output file/buffer. It is
402 a fatal error to attempt to seek backward.
403
404 Empty parts of the file/buffer will have NULL (0x00) bytes written to
405 them.
406
407 The $whence parameter takes one the usual values, namely SEEK_SET,
408 SEEK_CUR or SEEK_END.
409
410 Returns 1 on success, 0 on failure.
411
412 binmode
413 Usage is
414
415 $z->binmode
416 binmode $z ;
417
418 This is a noop provided for completeness.
419
420 opened
421 $z->opened()
422
423 Returns true if the object currently refers to a opened file/buffer.
424
425 autoflush
426 my $prev = $z->autoflush()
427 my $prev = $z->autoflush(EXPR)
428
429 If the $z object is associated with a file or a filehandle, this method
430 returns the current autoflush setting for the underlying filehandle. If
431 "EXPR" is present, and is non-zero, it will enable flushing after every
432 write/print operation.
433
434 If $z is associated with a buffer, this method has no effect and always
435 returns "undef".
436
437 Note that the special variable $| cannot be used to set or retrieve the
438 autoflush setting.
439
440 input_line_number
441 $z->input_line_number()
442 $z->input_line_number(EXPR)
443
444 This method always returns "undef" when compressing.
445
446 fileno
447 $z->fileno()
448 fileno($z)
449
450 If the $z object is associated with a file or a filehandle, "fileno"
451 will return the underlying file descriptor. Once the "close" method is
452 called "fileno" will return "undef".
453
454 If the $z object is is associated with a buffer, this method will
455 return "undef".
456
457 close
458 $z->close() ;
459 close $z ;
460
461 Flushes any pending compressed data and then closes the output
462 file/buffer.
463
464 For most versions of Perl this method will be automatically invoked if
465 the IO::Compress::Bzip2 object is destroyed (either explicitly or by
466 the variable with the reference to the object going out of scope). The
467 exceptions are Perl versions 5.005 through 5.00504 and 5.8.0. In these
468 cases, the "close" method will be called automatically, but not until
469 global destruction of all live objects when the program is terminating.
470
471 Therefore, if you want your scripts to be able to run on all versions
472 of Perl, you should call "close" explicitly and not rely on automatic
473 closing.
474
475 Returns true on success, otherwise 0.
476
477 If the "AutoClose" option has been enabled when the IO::Compress::Bzip2
478 object was created, and the object is associated with a file, the
479 underlying file will also be closed.
480
481 newStream([OPTS])
482 Usage is
483
484 $z->newStream( [OPTS] )
485
486 Closes the current compressed data stream and starts a new one.
487
488 OPTS consists of any of the the options that are available when
489 creating the $z object.
490
491 See the "Constructor Options" section for more details.
492
494 No symbolic constants are required by this IO::Compress::Bzip2 at
495 present.
496
497 :all Imports "bzip2" and $Bzip2Error. Same as doing this
498
499 use IO::Compress::Bzip2 qw(bzip2 $Bzip2Error) ;
500
502 Apache::GZip Revisited
503 See IO::Compress::Bzip2::FAQ
504
505 Working with Net::FTP
506 See IO::Compress::Bzip2::FAQ
507
509 Compress::Zlib, IO::Compress::Gzip, IO::Uncompress::Gunzip,
510 IO::Compress::Deflate, IO::Uncompress::Inflate,
511 IO::Compress::RawDeflate, IO::Uncompress::RawInflate,
512 IO::Uncompress::Bunzip2, IO::Compress::Lzop, IO::Uncompress::UnLzop,
513 IO::Compress::Lzf, IO::Uncompress::UnLzf, IO::Uncompress::AnyInflate,
514 IO::Uncompress::AnyUncompress
515
516 Compress::Zlib::FAQ
517
518 File::GlobMapper, Archive::Zip, Archive::Tar, IO::Zlib
519
520 The primary site for the bzip2 program is http://www.bzip.org.
521
522 See the module Compress::Bzip2
523
525 This module was written by Paul Marquess, pmqs@cpan.org.
526
528 See the Changes file.
529
531 Copyright (c) 2005-2008 Paul Marquess. All rights reserved.
532
533 This program is free software; you can redistribute it and/or modify it
534 under the same terms as Perl itself.
535
536
537
538perl v5.10.1 2017-03-22 IO::Compress::Bzip2(3pm)