001: /*
002: * Licensed to the Apache Software Foundation (ASF) under one or more
003: * contributor license agreements. See the NOTICE file distributed with
004: * this work for additional information regarding copyright ownership.
005: * The ASF licenses this file to You under the Apache License, Version 2.0
006: * (the "License"); you may not use this file except in compliance with
007: * the License. You may obtain a copy of the License at
008: *
009: * http://www.apache.org/licenses/LICENSE-2.0
010: *
011: * Unless required by applicable law or agreed to in writing, software
012: * distributed under the License is distributed on an "AS IS" BASIS,
013: * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
014: * See the License for the specific language governing permissions and
015: * limitations under the License.
016: */
017:
018: package org.apache.commons.betwixt.schema;
019:
020: import org.apache.commons.betwixt.AttributeDescriptor;
021:
022: /**
023: * Models the attribute element in an XML schema.
024: * @author <a href='http://jakarta.apache.org/'>Jakarta Commons Team</a>
025: * @version $Revision: 438373 $
026: */
027: public class Attribute {
028:
029: private String name;
030: private String type;
031:
032: public Attribute() {
033: }
034:
035: public Attribute(String name, String type) {
036: setName(name);
037: setType(type);
038: }
039:
040: public Attribute(AttributeDescriptor attributeDescriptor) {
041: this (attributeDescriptor.getQualifiedName(), "xsd:string");
042: }
043:
044: /**
045: * Gets the attribute name
046: * @return name of this attribute, not null
047: */
048: public String getName() {
049: return name;
050: }
051:
052: /**
053: * Sets the attribute name
054: * @param string the name for this attribute, not null
055: */
056: public void setName(String string) {
057: name = string;
058: }
059:
060: /**
061: * Gets the attribute type
062: * @return the type of this attribute
063: */
064: public String getType() {
065: return type;
066: }
067:
068: /**
069: * Sets the attribute type
070: * @param string the attribute type
071: */
072: public void setType(String string) {
073: type = string;
074: }
075:
076: public int hashCode() {
077: return 0;
078: }
079:
080: public boolean equals(Object obj) {
081: boolean result = false;
082: if (obj instanceof Attribute) {
083: Attribute attribute = (Attribute) obj;
084: result = isEqual(type, attribute.type)
085: && isEqual(name, attribute.name);
086: }
087: return result;
088: }
089:
090: /**
091: * Null safe equals method
092: * @param one
093: * @param two
094: * @return
095: */
096: private boolean isEqual(String one, String two) {
097: boolean result = false;
098: if (one == null) {
099: result = (two == null);
100: } else {
101: result = one.equals(two);
102: }
103:
104: return result;
105: }
106:
107: public String toString() {
108: return "<xsd:attribute name='" + name + "' type='" + type
109: + "'/>";
110: }
111:
112: }
|