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.
In reply to unpack 'C/a*' and context weirdness by BrowserUk
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |