(1) The HTML5 spec permits xmlns="http://www.w3.org/1999/xhtml"; to be added on any HTML element. However, XMLmind editor does not allow the xmlns attribute be added except as root element. So if I want to add xmlns="http://www.w3.org/1999/xhtml"; to a <table> element, XXE does not permit it do be done. I wish that XXE would permit this to be done. The usecase I have in mind is pasting a HTML element into a <foreignObject> section of a <svg> element - and similar usecases - for this use case, I would like to prepare the HTML elements to be pasted, by first addign the xmlns="http://www.w3.org/1999/xhtml";.

(2) I created a document svg-test.svg with the content of the example document found on this page: <https://developer.mozilla.org/en-US/docs/Web/SVG/Element/foreignObject>. However, when XXE opened that file, the <div> found inside the SVG <foreignObject> section, became transformed from

 * <div xmlns="http://www.w3.org/1999/xhtml";>

to

* <ns2:div>

OK, so much for that SVG document example. But as XXE is not an SVG editor, it is perhaps only to be expected that the behavior for such documents is unpredictable.

However, from time to time, if I empbed a SVG section inside a XHTML file, I sometimes - or I would say: rather regularily - experience the same kind of behavior: the <svg> element becomes <ns:svg>. In particular, this seems to happen if the embedded <svg> element contains <foreignObject> which, in turn, contains an HTML section.


(As I often use the <xinclude> element - which has its own namespace, I (ir)regularily have the same experience with that element - it becomses auto-transformed to <ns:include>.)

I might have an original document where everything works OK, but then I make a copy of that document, and open the copy in XXE, and suddenly the "foreign" elements get prefixed with <ns: - for no obvious reason. To me, the original document and the copy document seems to have - and do have - identical content, but when XXE opens them, the copy is given a different treatment than the original.

The workaround I tend to use is EITHER to "massage" the source code until it "clicks" OR to not "naïvely" copy a document, but rather to add elements via XXE’s interface. But I always lose a litle time on making it work ...

So to sum up: This message contains two RFEs: (1) allow xmlns="implied-ns" to be added and (2) make it so that XXE does not, in certain (hard to pinpoint) cases automatically transform <foo xmlns="bar"> into <bar:foo>.

Leif Halvard Silli
--
XMLmind XML Editor Support List
xmleditor-support@xmlmind.com
https://www.xmlmind.com/mailman/listinfo/xmleditor-support

Reply via email to