Edit report at https://bugs.php.net/bug.php?id=61038&edit=1

 ID:                 61038
 Updated by:         cataphr...@php.net
 Reported by:        su dot hang at yahoo dot com
 Summary:            unpack("a5", "str\0\0") does not work as expected
-Status:             Open
+Status:             Closed
 Type:               Bug
 Package:            *General Issues
 Operating System:   Linux (3.0.0-15-generic)
 PHP Version:        Irrelevant
-Assigned To:        
+Assigned To:        cataphract
 Block user comment: N
 Private report:     N

 New Comment:

Fixed in master only due to BC concerns.

Thank you.


Previous Comments:
------------------------------------------------------------------------
[2012-04-17 21:23:54] cataphr...@php.net

Automatic comment on behalf of googleguy@googleguy-virtualbox.(none)
Revision: 
http://git.php.net/?p=php-src.git;a=commit;h=4968fa644b0849321e1761e52b8db15dd46f9b75
Log: Fixed bug #61038; "Z" and better behavior for unpack()

------------------------------------------------------------------------
[2012-02-13 09:50:28] su dot hang at yahoo dot com

yes, that's right. 

"a", as in the spec, represents arbitrary binary string, with null-padding. so, 
if the specified unpack length is fixed, such as a constant number (like in 
"unpack('a10')"), then the unpacked string from "a" should have that length 
(unless, of course, if the input is insufficient). 

since "a" is arbitrary binary string, if it has several "\0"s at the end, php 
should not remove them as if it was a regular null-terminated string.

------------------------------------------------------------------------
[2012-02-13 08:39:00] cataphr...@php.net

I'm not sure I understand. Is the problem that 'a' (as opposed to 'A') on 
unpack should leave the string as is, as is the case with perl?

------------------------------------------------------------------------
[2012-02-10 16:53:54] su dot hang at yahoo dot com

sorry, please use the test script instead of the subject.

It is a bug because it is against the spec that "a" is an arbitrary binary 
string. 
If specified length is 5 then it should be null-padded at the end, rather than 
being 
truncated.

try unpack('a5', "\x12\x34\x00\x56\x00").
at least, to be consistent, the result string should terminate at the first 
"\0", 
instead of the trailing one.

btw, perl is handling it correctly.

------------------------------------------------------------------------
[2012-02-10 16:34:10] cataphr...@php.net

I don't see anything wrong here. 

unpack("a5", "foo\0\0")

removes the NULL padding from the input string. The 5 specifies only the size 
of the input to consume:

php > var_dump(unpack("a5", "foo\0"));
PHP Warning:  unpack(): Type a: not enough input, need 5, have 4 in php shell 
code on line 1

------------------------------------------------------------------------


The remainder of the comments for this report are too long. To view
the rest of the comments, please view the bug report online at

    https://bugs.php.net/bug.php?id=61038


-- 
Edit this bug report at https://bugs.php.net/bug.php?id=61038&edit=1

Reply via email to