ID:               40793
 Updated by:       [EMAIL PROTECTED]
 Reported By:      camka at email dot ee
-Status:           Open
+Status:           Bogus
 Bug Type:         XMLRPC-EPI related
 Operating System: windows
 PHP Version:      5.2.1
 New Comment:

>Sory, but I slightly disagree.
It's hard to disagree with a fact.
The function IS designed this way and is_array() check is not that
ugly, dirty, unclear and confusing.

Whether it was reasonable implementation or not - that's a different
question.
The XMLRPC extension is unmaintained for a long time and I personally
do not feel willing enough to change it's behavior just because it
requires one is_array() call.

And this is definitely not a BUG, but a change request.

Actually we have simular things in many places - for example, fread()
and fwrite() emit a notice when invalid stream passed, even though
fopen() might return FALSE. 
And you have to use those "unnecessary, confusing, ugly, dirty and
unclear" checks to be sure the stream is valid.


Previous Comments:
------------------------------------------------------------------------

[2007-03-13 13:41:04] camka at email dot ee

Sory, but I slightly disagree.

In current implementation I must implicitly check, if decoded xml
response is array or not before passing it to xmlrpc_is_fault(),
otherwise it gives me a notice. This is just unnecessary additional
confusing check to do, which makes a code dirty and unclear. If this
check would be inside is_fault function the implementation would be
more incapsulated and simple for developer using xmlrpc ext. 

Or may be there is another way to check whether the response contains a
fault or not?

thank you

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

[2007-03-13 12:51:54] [EMAIL PROTECTED]

The function is supposed to accept only arrays by design.

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

[2007-03-13 12:41:37] camka at email dot ee

Description:
------------
xmlrpc_is_fault is supposed to accept a result returned by
xmlrpc_decode. 

As xmlrpc_decode can return non-array value, xmlrpc_is_fault throws a
notice:

xmlrpc_is_fault() : Array argument expected

which is incorrect, as it is common to simply pass the decoded xml
response directly into is_fault() function to check, whether it has
been fault or not.

Reproduce code:
---------------
<?
var_dump(xmlrpc_is_fault(xmlrpc_decode('<?xml version="1.0"
encoding="utf-8"?><methodResponse><params><param><value><int>2</int></value></param></params></methodResponse>',
'utf-8')));

Expected result:
----------------
bool(false)

Actual result:
--------------
Notice: PHPDocument8 line 2 - xmlrpc_is_fault() 
[function.xmlrpc-is-fault]: Array argument expected

bool(false)


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


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

Reply via email to