Похоже, что он денормализует вывод и включает в себя контекст пространства имен вместе с узлами, которым на самом деле нужен контекст пространства имен.
Например, веб-страница для этого вопроса имеет встроенное пространство имен creativeCommons:
<feed xmlns="http://www.w3.org/2005/Atom" xmlns:creativeCommons="http://backend.userland.com/creativeCommonsRssModule" xmlns:thr="http://purl.org/syndication/thread/1.0">
<!-- snip -->
<creativeCommons:license>http://www.creativecommons.org/licenses/by-nc/2.5/rdf</creativeCommons:license>
<!-- snip -->
</feed>
Когда вы выводите xml, используя этот скрипт:
def root = new XmlParser().parseText("http://stackoverflow.com/feeds/question/227447".toURL().text)
println new XmlNodePrinter().print(root)
В итоге происходит перемещение пространства имен к узлу лицензии, которому необходимо это пространство имен. В этом случае не так уж и много, поскольку в этом пространстве имен только один узел. Если бы большая часть XML была пространством имен, это, вероятно, привело бы к еще большему скоплению вещей.
<feed xmlns="http://www.w3.org/2005/Atom">
<!-- snip -->
<creativeCommons:license xmlns:creativeCommons="http://backend.userland.com/creativeCommonsRssModule">
http://www.creativecommons.org/licenses/by-nc/2.5/rdf
</creativeCommons:license>
<!-- snip -->
</feed>
Если вы действительно хотите, чтобы узлы были нормализованы, вам нужно было бы внести некоторые изменения в XmlNodePrinter, чтобы сделать 2 прохода через XML, сначала собрать все используемые пространства имен, а 2-й - вывести их сверху, а не внутри Пространство имен Отличный исходный код на самом деле довольно читабелен и его не так сложно изменить, если вам это действительно нужно.