php.net |  support |  documentation |  report a bug |  advanced search |  search howto |  statistics |  random bug |  login
Doc Bug #61877 Float keys not cast to int like with array
Submitted: 2012-04-30 02:23 UTC Modified: 2021-08-18 17:08 UTC
Votes:3
Avg. Score:3.7 ± 0.9
Reproduced:1 of 1 (100.0%)
Same Version:1 (100.0%)
Same OS:1 (100.0%)
From: fred dot stcm at gmail dot com Assigned:
Status: Verified Package: SimpleXML related
PHP Version: 5.4.1 OS:
Private report: No CVE-ID: None
 [2012-04-30 02:23 UTC] fred dot stcm at gmail dot com
Description:
------------
PHP Array manual:
"Floats are also cast to integers, which means that the fractional part will be 
truncated. E.g. the key 8.7 will actually be stored under 8."

But this rule is ignored by SimpleXML object's array.

Test script:
---------------
$xml = simplexml_load_string("<xml><number>0</number><number>1</number></xml>");

$i = (int) 1;
$d = (float) 1;

$xml->number[$d] = 999;

echo $xml->number[$d] .", ". $xml->number[$i];

Expected result:
----------------
999, 999

Actual result:
--------------
999, 1

Patches

simplexml-patch (last revision 2012-04-30 20:58 UTC by felipe@php.net)

Pull Requests

Pull requests:

History

AllCommentsChangesGit/SVN commitsRelated reports
 [2012-04-30 20:58 UTC] felipe@php.net
The following patch has been added/updated:

Patch Name: simplexml-patch
Revision:   1335819480
URL:        https://bugs.php.net/patch-display.php?bug=61877&patch=simplexml-patch&revision=1335819480
 [2020-03-27 01:04 UTC] carusogabriel@php.net
The following pull request has been associated:

Patch Name: Fix #61877: Make SimpleXMLElement respect PHP's array rule
On GitHub:  https://github.com/php/php-src/pull/5309
Patch:      https://github.com/php/php-src/pull/5309.patch
 [2021-08-18 17:08 UTC] cmb@php.net
-Summary: Array key not casted to Integer. +Summary: Float keys not cast to int like with array -Status: Open +Status: Verified -Type: Bug +Type: Documentation Problem
 [2021-08-18 17:08 UTC] cmb@php.net
> But this rule is ignored by SimpleXML object's array.

There is no SimpleXML object array, to begin with.
SimpleXMLElements are more like classes implementing ArrayAccess,
and ArrayAccess allows arbitrary type behavior regarding the keys.

Anyhow, as it is, SimpleXMLElement array access distinguishes
between integer and non-integer keys; the latter are cast to
string.  These have fundamentally different behavior, namely
integer keys are interpreted as n-th child, while string keys are
interpreted as attribute names.  So casting float keys to integer
would be a BC break, although float keys would create invalid XML
attribute names on write access, anyway.

To move forward with this ticket, I'm going to change to doc
problem; while there is some explanation of array access in the
examples section[1], this doesn't look complete and should better
be documented on the class summay page[2] (or at least linked from
there).  Even better yet, SimpleXML would actually implement
ArrayAccess (see request #52655).

If you, or anybody else, still feels float keys should be cast to
integer, please pursue the RFC process[3].

[1] <https://www.php.net/manual/en/simplexml.examples-basic.php>
[2] <https://www.php.net/manual/en/class.simplexmlelement.php>
[3] <https://wiki.php.net/rfc/howto>
 [2022-11-29 06:53 UTC] samanre32 at gmail dot com
Thanks for that. (https://www.dqfansurvey.one/)github.com
 [2024-07-12 10:08 UTC] krina234pestro at outlook dot com
The behavior you’re observing is due to how SimpleXML handles array keys differently from standard PHP arrays. In SimpleXML, the array keys are treated as strings, which means that even if you cast a float to an integer, it might not behave as expected. (https://github.com)(https://www.my-fordbenefits.com)
 
PHP Copyright © 2001-2024 The PHP Group
All rights reserved.
Last updated: Thu Sep 12 22:01:27 2024 UTC