001: /*
002: * InitParameter.java
003: *
004: *
005: * Copyright (c) 2003 Rimfaxe ApS (www.rimfaxe.com).
006: * All rights reserved.
007: *
008: * This package is written by Lars Andersen <lars@rimfaxe.com>
009: * and licensed by Rimfaxe ApS.
010: *
011: * Redistribution and use in source and binary forms, with or without
012: * modification, are permitted provided that the following conditions
013: * are met:
014: *
015: * 1. Redistributions of source code must retain the above copyright
016: * notice, this list of conditions and the following disclaimer.
017: *
018: * 2. Redistributions in binary form must reproduce the above copyright
019: * notice, this list of conditions and the following disclaimer in
020: * the documentation and/or other materials provided with the
021: * distribution.
022: *
023: * 3. The end-user documentation included with the redistribution, if
024: * any, must include the following acknowlegement:
025: * "This product includes software developed by Rimfaxe ApS
026: (www.rimfaxe.com)"
027: * Alternately, this acknowlegement may appear in the software itself,
028: * if and wherever such third-party acknowlegements normally appear.
029: *
030: * 4. The names "Rimfaxe", "Rimfaxe Software", "Lars Andersen" and
031: * "Rimfaxe WebServer" must not be used to endorse or promote products
032: * derived from this software without prior written permission. For written
033: * permission, please contact info@rimfaxe.com
034: *
035: * 5. Products derived from this software may not be called "Rimfaxe"
036: * nor may "Rimfaxe" appear in their names without prior written
037: * permission of the Rimfaxe ApS.
038: *
039: * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
040: * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
041: * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
042: * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
043: * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
044: * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
045: * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
046: * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
047: * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
048: * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
049: * SUCH DAMAGE.
050: *
051: */
052:
053: package com.rimfaxe.webserver.webapp;
054:
055: import java.util.*;
056:
057: import org.w3c.dom.Attr;
058: import org.w3c.dom.Document;
059: import org.w3c.dom.NamedNodeMap;
060: import org.w3c.dom.Node;
061: import org.w3c.dom.NodeList;
062:
063: import com.rimfaxe.util.*;
064:
065: /**
066: *
067: * @author Lars Andersen
068: */
069: public class InitParameter {
070:
071: String name = "";
072: String value = "";
073:
074: /** Creates a new instance of InitParameter */
075: public InitParameter(Node node) {
076: traverse(node);
077: }
078:
079: public String getName() {
080: return name;
081: }
082:
083: public String getValue() {
084: return value;
085: }
086:
087: private String traverse(Node node) {
088:
089: StringBuffer str = new StringBuffer();
090:
091: if (node == null) {
092: return "";
093: }
094: int type = node.getNodeType();
095: switch (type) {
096:
097: case Node.DOCUMENT_NODE: {
098: traverse(((Document) node).getDocumentElement());
099: break;
100: }
101:
102: case Node.ELEMENT_NODE: {
103: if (node.getNodeName().equalsIgnoreCase("param-name")) {
104: NodeList children = node.getChildNodes();
105: if (children != null) {
106: int len = children.getLength();
107: for (int i = 0; i < len; i++) {
108: String val = traverse(children.item(i));
109: name = val.trim();
110: }
111: }
112: } else if (node.getNodeName().equalsIgnoreCase(
113: "param-value")) {
114: NodeList children = node.getChildNodes();
115: if (children != null) {
116: int len = children.getLength();
117: for (int i = 0; i < len; i++) {
118: String val = traverse(children.item(i));
119: value = val.trim();
120: }
121: }
122: } else {
123: NodeList children = node.getChildNodes();
124: if (children != null) {
125: int len = children.getLength();
126: for (int i = 0; i < len; i++) {
127: String val = traverse(children.item(i));
128: }
129: }
130: }
131: break;
132: }
133:
134: case Node.TEXT_NODE: {
135: //if (node instanceof TextImpl)
136: //{
137: str.append(node.getNodeValue());
138: //}
139: break;
140: }
141: }
142: return str.toString();
143: }
144:
145: public String toXML() {
146: StringBuffer buf = new StringBuffer();
147:
148: buf.append(" <init-param> \n");
149: buf.append(" <param-name>" + name + "</param-name> \n");
150: buf.append(" <param-value>" + value + "</param-value> \n");
151: buf.append(" </init-param>\n");
152:
153: return "" + buf;
154: }
155:
156: }
|