ID: 34276 Updated by: [EMAIL PROTECTED] Reported By: molily at gmx dot de -Status: Bogus +Status: Closed Bug Type: DOM XML related Operating System: Gentoo Linux PHP Version: 5CVS-2005-08-27 (snap) New Comment:
This bug has been fixed in CVS. Snapshots of the sources are packaged every three hours; this change will be in the next snapshot. You can grab the snapshot at http://snaps.php.net/. Thank you for the report, and for helping us make PHP better. Yup, missed that part of the initial report Previous Comments: ------------------------------------------------------------------------ [2005-08-27 21:46:35] molily at gmx dot de Thanks, this explains why the first getAttributeNS call in the example doesn't work as I expected. The workaround is getAttributeNS(null, "attra") as per DOM 3 Core. The same goes for setAttributeNS if you want to set an attribute without namespace (it's possible to handle these attributes as if they use the default namespace, but there is this silly rule in XML Namespaces). But what's about the setAttributeNS problem? $b->setAttributeNS('http://namespaces.molily.de/x', 'attrc', 'attrc'); Why does this add an attribute with the namespace prefix »y«? (see actual result: y:attrc="attrc" and expected result: attrc="attrc") »y« is the prefix for the other namespace used in the example document. After running setAttributeNS, the attribute »attrc« should be explicitly in the mentioned namespace »http://namespaces.molily.de/x«. The rule »default namespaces do not apply directly to attributes« doesn't apply. Why isn't it possible to getAttributeNS('http://namespaces.molily.de/x', 'attrc') after that? By the way, getAttributeNS('http://namespaces.molily.de/y', 'attrc') works, but why? I never told to use namespace »y«, but it is used probably because it is the only namespace declared with prefix. ------------------------------------------------------------------------ [2005-08-27 03:32:03] [EMAIL PROTECTED] Thank you for taking the time to write to us, but this is not a bug. Please double-check the documentation available at http://www.php.net/manual/ and the instructions on how to report a bug at http://bugs.php.net/how-to-report.php you misunderstood DOM 2 Core / XML Namespaces. Attributes dont inherit from default namespace. ------------------------------------------------------------------------ [2005-08-27 02:26:27] molily at gmx dot de Description: ------------ It's not possible to use hasAttributeNS and getAttributeNS on attributes from the default namespace (i.e. without namespace prefix). They do not find the right attribute. In addition to this, setAttributeNS cannot set an attribute in the default namespace. The new atttribute gets an incorrect namespace prefix. I'm using the latest source snapshot php5-200508262230 (standard configuration but --without-pear) with libxml 2.6.20 (-r2 in Gentoo Portage). Is this a libxml problem, like many DOM extension bugs before? Or do I misunderstand DOM 2 Core / XML Namespaces? Reproduce code: --------------- <?php $dom = DOMDocument::loadXML('<a xmlns="http://namespaces.molily.de/x" xmlns:y="http://namespaces.molily.de/y" attra="attra" y:attrb="attrb" />'); $b = $dom->documentElement; var_dump($b->hasAttributeNS('http://namespaces.molily.de/x', 'attra')); var_dump($b->hasAttributeNS('http://namespaces.molily.de/y', 'attrb')); var_dump($b->getAttributeNS('http://namespaces.molily.de/x', 'attra')); var_dump($b->getAttributeNS('http://namespaces.molily.de/y', 'attrb')); $b->setAttributeNS('http://namespaces.molily.de/x', 'attra', 'attra neu'); $b->setAttributeNS('http://namespaces.molily.de/y', 'attrb', 'attrb neu'); $b->setAttributeNS('http://namespaces.molily.de/x', 'attrc', 'attrc'); $b->setAttributeNS('http://namespaces.molily.de/y', 'attrd', 'attrd'); echo("\n"); var_dump($b->getAttributeNS('http://namespaces.molily.de/x', 'attra')); var_dump($b->getAttributeNS('http://namespaces.molily.de/y', 'attrb')); var_dump($b->getAttributeNS('http://namespaces.molily.de/x', 'attrc')); var_dump($b->getAttributeNS('http://namespaces.molily.de/y', 'attrd')); echo("\n"); var_dump($b->attributes->length); echo($dom->saveXML()); ?> Expected result: ---------------- (As far as I know:) bool(true) bool(true) string(5) "attra" string(5) "attrb" string(9) "attra neu" string(9) "attrb neu" string(5) "attrc" string(5) "attrd" int(4) <?xml version="1.0"?> <a xmlns="http://namespaces.molily.de/x" xmlns:y="http://namespaces.molily.de/y" attra="attra neu" y:attrb="attrb neu" attrc="attrc" y:attrd="attrd"/> Actual result: -------------- bool(false) bool(true) string(0) "" string(5) "attrb" string(0) "" string(9) "attrb neu" string(0) "" string(5) "attrd" int(5) <?xml version="1.0"?> <a xmlns="http://namespaces.molily.de/x" xmlns:y="http://namespaces.molily.de/y" attra="attra" y:attrb="attrb neu" y:attra="attra neu" y:attrc="attrc" y:attrd="attrd"/> ------------------------------------------------------------------------ -- Edit this bug report at http://bugs.php.net/?id=34276&edit=1