Since the file is binary, you don't want to be reading it with angle brackets (<>) because you don't know if there are
ANY new line characters in the part of the file after the headers. Use
sysread, and keep adding to the buffer, until you see the end of headers marker. Then just remove the headers with a regex, and cycle through
syswrite and
sysread (with the appropriate sized buffer, like 16 or 64 K) until you reach the end of file.
Update: here is the example code:
my $buf="";
#append to buffer until headers are found and removed
while (!($buf=~s/^.*?#### end_ascii_header\n//)) {
sysread(INP,$buf,1024,length($buf));
}
syswrite(OUT,$buf,$length($buf));
#copy the rest of the file
while (sysread(INP,$buf,16384)) {
syswrite(OUT,$buf,length($buf));
}
P.s. In production code, checking the return values of
syswrite would be prudent.
Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
Read Where should I post X? if you're not absolutely sure you're posting in the right place.
Please read these before you post! —
Posts may use any of the Perl Monks Approved HTML tags:
- a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
| |
For: |
|
Use: |
| & | | & |
| < | | < |
| > | | > |
| [ | | [ |
| ] | | ] |
Link using PerlMonks shortcuts! What shortcuts can I use for linking?
See Writeup Formatting Tips and other pages linked from there for more info.