1
/* Copyright 2002, 2003 Elliotte Rusty Harold
3
This library is free software; you can redistribute it and/or modify
4
it under the terms of version 2.1 of the GNU Lesser General Public
5
License as published by the Free Software Foundation.
7
This library is distributed in the hope that it will be useful,
8
but WITHOUT ANY WARRANTY; without even the implied warranty of
9
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10
GNU Lesser General Public License for more details.
12
You should have received a copy of the GNU Lesser General Public
13
License along with this library; if not, write to the
14
Free Software Foundation, Inc., 59 Temple Place, Suite 330,
15
Boston, MA 02111-1307 USA
17
You can contact Elliotte Rusty Harold by sending e-mail to
18
elharo@metalab.unc.edu. Please include the word "XOM" in the
19
subject line. The XOM home page is located at http://www.xom.nu/
21
package nu.xom.samples;
23
import java.io.IOException;
25
import nu.xom.Attribute;
26
import nu.xom.Builder;
27
import nu.xom.Document;
28
import nu.xom.Element;
29
import nu.xom.NodeFactory;
31
import nu.xom.ParsingException;
35
* A filter that converts attributes to child elements.
36
* This does not apply to namespace declaration attributes
37
* such as <code>xmlns</code> and <code>xmlns:<i>prefix</i></code>.
40
* @author Elliotte Rusty Harold
43
public class AttributesToElements extends NodeFactory {
45
private boolean maintainTypes = false;
47
public AttributesToElements() {}
49
public AttributesToElements(boolean maintainTypes) {
50
this.maintainTypes = maintainTypes;
53
public Nodes makeAttribute(String name, String URI,
54
String value, Attribute.Type type) {
56
Element element = new Element(name, URI);
57
element.appendChild(value);
59
&& !type.equals(Attribute.Type.UNDECLARED)
60
&& !type.equals(Attribute.Type.ENUMERATION)) {
61
Attribute xsiType = new Attribute("xsi:type",
62
"http://www.w3.org/2001/XMLSchema-instance", type.getName());
63
element.addAttribute(xsiType);
65
return new Nodes(element);
68
public static void main(String[] args) {
70
if (args.length <= 0) {
72
"Usage: java nu.xom.samples.AttributesToElements URL"
78
Builder parser = new Builder(new AttributesToElements());
79
Document doc = parser.build(args[0]);
80
EZSerializer.write(doc, System.out);
82
catch (ParsingException ex) {
83
System.out.println(args[0] + " is not well-formed.");
84
System.out.println(ex.getMessage());
86
catch (IOException ex) {
88
"Due to an IOException, the parser could not read "