rfc:fix_list_behavior_inconsistency

This is an old revision of the document!


PHP RFC: Fix list() behavior inconsistency

Introduction

According to PHP documentation list() construct doesn't work with strings. However in some cases it works.

$ php -r 'list($a,$b) = "aa";var_dump($a,$b);'
NULL
NULL
$ php -r '$a[0]="ab"; list($a,$b) = $a[0]; var_dump($a,$b);'
string(1) "a"
string(1) "b"

This behavior caused by implementation feature and wasn't made on purpose.

Proposal

Make list() behave with strings in consistent way. There are two options:

Disable string handling in all cases

This will disable undocumented feature and it may break some existing PHP code.

Enable string handling in all cases

This will make the following code work.

list($a,$b) = "str";

Instead of assignment NULL into $a and $b, it'll assign 's' and 't' characters. However, it also may break some existing PHP code.

Backward Incompatible Changes

Both options may affect existing PHP code.

Proposed PHP Version(s)

PHP7

Vote

This project requires a 2/3 majority, between first and second or third options.

Voting started on 2014-09-25 and ends 2014-10-02.

Fix list() behavior inconsistency?
Real name don't fix disable string handling in all cases enable string handling in all cases
ab   
aharvey   
ajf   
auroraeosrose   
bukka   
bwoebi   
datibbaw   
daverandom   
derick   
dmitry   
fmk   
gwynne   
hywan   
jedibc   
kalle   
kassner   
keyur   
klaussilveira   
krakjoe   
laruence   
leigh   
levim   
lstrojny   
mbeccati   
mike   
nikic   
pajoye   
patrickallaert   
pierrick   
rasmus   
rdlowrey   
remi   
stas   
Final result: 0 17 16
This poll has been closed.

Patches and Tests

The implementation is not really a problem.

rfc/fix_list_behavior_inconsistency.1412414461.txt.gz · Last modified: (external edit)