BrowserUk has asked for the wisdom of the Perl Monks concerning the following question:
I'm trying to make use of the pack/unpack pattern 'C/a*' but am encountering several sorts of weirdness.
If I do
my $packed = pack 'C/a*', 'the quick brown fox'; print "'$packed'";
I get '?the quick brown fox'. The string, prefixed with a 1-byte length.
And when I do
print unpack('C/a*', $packed);
I get the quick brown fox. The original string minus the length prefix. Great!
However, when I do
my $data = unpack 'C/a*', $packed; print "'$data'";
I get 19 the length of the string? Ah, Context!. Scalar/versus list. So I tried:
my @data = unpack 'C/a*', $packed; print scalar @data, ':', join '|', @data;
and got 1:the quick brown fox. The array has one element, and its the string not then length?
So then I tried
my ($len, $val) = unpack 'C/a*', $packed; print "$len:$val;";
and got
Use of uninitialized value in concatenation (.) or string at C:\test\t +est.pl line 16. the quick brown fox:;
So, unpack with a template of 'C/a*' returns the length and not the string in a scalar context and a one element list consisting of just the string, but not the length in a list context.
So to get both pieces of information I have to call unpack twice?
my $len = unpack 'C/a*', $packed; my ($data) = unpack 'C/a*', $packed;
Or just do the latter and use length.
Conclusion: This is, at the very least, unintuative, non-DWIM, perverse and undocumented, and quite possibly a bug?
Worthy of a perlbug?
Examine what is said, not who speaks.
The 7th Rule of perl club is -- pearl clubs are easily damaged. Use a diamond club instead.
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re: unpack 'C/a*' and context weirdness
by jmcnamara (Monsignor) on Feb 14, 2003 at 22:16 UTC | |
by BrowserUk (Patriarch) on Feb 14, 2003 at 23:28 UTC | |
by jasonk (Parson) on Feb 15, 2003 at 15:40 UTC | |
by BrowserUk (Patriarch) on Feb 15, 2003 at 15:55 UTC | |
|
Re: unpack 'C/a*' and context weirdness
by jsprat (Curate) on Feb 14, 2003 at 22:08 UTC | |
|
Re: unpack 'C/a*' and context weirdness
by robartes (Priest) on Feb 14, 2003 at 22:27 UTC | |
|
Re: unpack 'C/a*' and context weirdness
by bart (Canon) on Feb 15, 2003 at 01:36 UTC | |
by BrowserUk (Patriarch) on Feb 15, 2003 at 02:07 UTC | |
|
Re: unpack 'C/a*' and context weirdness
by diotalevi (Canon) on Feb 15, 2003 at 14:07 UTC |