Opened 18 years ago
Last modified 8 years ago
#68 new defect
results of select don't contain required namespace prefixes
Reported by: | davidf@… | Owned by: | cmlenz |
---|---|---|---|
Priority: | major | Milestone: | 0.9 |
Component: | General | Version: | 0.3.3 |
Keywords: | Cc: | davidf@… |
Description
There are two commented out tests in path.py containing this description:
attributes that would need a namespace prefix that isn't in the prefix map would need to get an artificial prefix, but currently don't
A cutdown example is:
XML('<root xmlns:f="FOO"><foo f:bar="baz"/></root>').select("foo").render()
which returns
<foo bar="baz"/>
but should return something like
<foo xmlns:f="FOO" f:bar="baz"/>
Attachments (1)
Change History (10)
comment:1 Changed 18 years ago by David Fraser <davidf@…>
Changed 18 years ago by David Fraser <davidf@…>
initial stab at producing namespace code using the namespace dictionary
comment:2 Changed 18 years ago by David Fraser <davidf@…>
The attached patch (select-namespaces-68-stab1.patch) is an initial attempt to take the namespaces dictionary passed in and used that to look up and include namespaces.
This is not ideal but provides a way for me to at least pass namespaces in and get what I need for now. I'm not really sure that this is what the namespaces dictionary is intended for; in particular since it now breaks some other tests :-)
comment:3 Changed 18 years ago by cmlenz
[502] moved the code base further along to be able to support this, but doesn't yet use the passed in prefixes… that would require tracking where namespaces run out of scope, which will require a couple more LOCs.
comment:4 Changed 18 years ago by cmlenz
- Milestone changed from 0.4 to 0.5
I'll try to implement a more complete solution for this for the next release.
comment:5 Changed 17 years ago by cmlenz
- Milestone changed from 0.5 to 0.6
Postponing again, sorry :/
comment:6 Changed 15 years ago by cmlenz
- Milestone changed from 0.6 to 0.7
comment:7 Changed 15 years ago by anonymous
s
comment:8 Changed 15 years ago by Carsten Klein <carsten.klein@…>
Currently, elements and attributes, when prefixed, will be issued as START events using the following notation
namespace-url}element|attribute-name
Why not simply extend upon this using
prefix}namespace-url}attribute-name
That way, the prefixes could be preserved in the stream, as otherwise they will be lost. The benefit would be that they could be restored upon rendering the stream, which is currently not the case - genshi will introduce ns<n> prefixes upon rendering the stream.
comment:9 Changed 8 years ago by hodgestar
- Milestone changed from 0.7 to 0.9
Moved to milestone 0.9.
The actual example I was testing with:
The following python code
returns
instead of
i.e. the py: is missing