NAME

File::ReplaceBytes - read or replace arbitrary data in files

SYNOPSIS

Warning! These system calls are dangerous!

use File::ReplaceBytes qw(pread pwrite replacebytes);

open my $fh, '+<', $file or die "cannot open $file: $!\n";

# read 16 bytes at offset of 8 bytes into $buf
my $buf;
pread($fh, $buf, 16, 8);

# write these bytes out in various locations to same file
pwrite($fh, $buf);        # at beginning of file
pwrite($fh, $buf, 4);     # write just 4 bytes of $buf
pwrite($fh, $buf, 0, 32); # all of $buf at 32 bytes into file

# these two are equivalent
pwrite($fh, $buf, 0);
pwrite($fh, $buf, length $buf);

replacebytes('somefile', $buf, 42);

DESCRIPTION

This module employs the pread(2) and pwrite(2) system calls to perform highly unsavory operations on files. These calls do not update the filehandle position reported by sysseek($fh,0,1), and will doubtless cause problems if mixed with any sort of buffered I/O. The filehandles used MUST be file-based filehandles, and MUST NOT be in-memory filehandles or sockets...look, I warned you.

EXPORTS

pread

pread(FH,BUF,LENGTH)
pread(FH,BUF,LENGTH,OFFSET)

FH must be a file handle, BUF a scalar, LENGTH how many bytes to read into BUF, and optionally, how far into the filehandle to start reading at. The call may throw an exception (e.g. if FH is undef), or otherwise will return the number of bytes read, or 0 if EOF, or -1 on error. BUF will be tainted under taint mode.

pwrite

pwrite(FH,BUF)
pwrite(FH,BUF,LENGTH)
pwrite(FH,BUF,LENGTH,OFFSET)

FH must be a file handle, BUF a scalar, whose LENGTH will be written, or otherwise a specified LENGTH number of bytes--but not beyond that of BUF, because that would be so very naughty--optionally at the specified OFFSET in bytes. If LENGTH is 0, the contents of BUF will be written. The call may throw an exception if FH is undef. The return value is the number of bytes written, or -1 on error.

replacebytes

replacebytes(FILENAME,BUF)
replacebytes(FILENAME,BUF,OFFSET)

Accepts a filename and scalar buffer, and writes the buffer to the specified offset (zero if not specified) in the said file. Does not use PerlIO like the p* routines do, instead performs a direct open(2) call on the filename.

CAVEATS

Everything mentioned above plus yet more besides.

SECURITY CONSIDERATIONS

This module MUST NOT be used if untrusted user input can influence how the file handles are created, as who knows what the p* system calls will do with whatever fileno value Perl returns for some socket or in-memory data filehandle?

SEE ALSO

dd(1), hexdump(1), pread(2), pwrite(2) and your backups. You have backups, right? Backups are nice.

AUTHOR

thrig - Jeremy Mates (cpan:JMATES) <jmates at cpan.org>

COPYRIGHT AND LICENSE

Copyright (C) 2013 by Jeremy Mates

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.18 or, at your option, any later version of Perl 5 you may have available.