001: /*
002: * The Apache Software License, Version 1.1
003: *
004: *
005: * Copyright (c) 2002 The Apache Software Foundation. All rights
006: * reserved.
007: *
008: * Redistribution and use in source and binary forms, with or without
009: * modification, are permitted provided that the following conditions
010: * are met:
011: *
012: * 1. Redistributions of source code must retain the above copyright
013: * notice, this list of conditions and the following disclaimer.
014: *
015: * 2. Redistributions in binary form must reproduce the above copyright
016: * notice, this list of conditions and the following disclaimer in
017: * the documentation and/or other materials provided with the
018: * distribution.
019: *
020: * 3. The end-user documentation included with the redistribution,
021: * if any, must include the following acknowledgment:
022: * "This product includes software developed by the
023: * Apache Software Foundation (http://www.apache.org/)."
024: * Alternately, this acknowledgment may appear in the software itself,
025: * if and wherever such third-party acknowledgments normally appear.
026: *
027: * 4. The names "WSIF" and "Apache Software Foundation" must
028: * not be used to endorse or promote products derived from this
029: * software without prior written permission. For written
030: * permission, please contact apache@apache.org.
031: *
032: * 5. Products derived from this software may not be called "Apache",
033: * nor may "Apache" appear in their name, without prior written
034: * permission of the Apache Software Foundation.
035: *
036: * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
037: * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
038: * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
039: * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
040: * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
041: * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
042: * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
043: * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
044: * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
045: * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
046: * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
047: * SUCH DAMAGE.
048: * ====================================================================
049: *
050: * This software consists of voluntary contributions made by many
051: * individuals on behalf of the Apache Software Foundation and was
052: * originally based on software copyright (c) 2001, 2002, International
053: * Business Machines, Inc., http://www.apache.org. For more
054: * information on the Apache Software Foundation, please see
055: * <http://www.apache.org/>.
056: */
057:
058: package org.apache.wsif.wsdl.extensions.java;
059:
060: import java.util.List;
061:
062: import javax.wsdl.extensions.ExtensibilityElement;
063: import javax.xml.namespace.QName;
064:
065: import com.ibm.wsdl.util.StringUtils;
066:
067: /**
068: * @author Gerhard Pfau <gpfau@de.ibm.com>
069: * @author Ant Elder <antelder@apache.org>
070: * @author Jeremy Hughes <hughesj@apache.org>
071: */
072: public class JavaOperation implements ExtensibilityElement,
073: java.io.Serializable {
074:
075: private static final long serialVersionUID = 1L;
076:
077: protected QName fieldElementType = JavaBindingConstants.Q_ELEM_JAVA_OPERATION;
078: // Uses the wrapper type so we can tell if it was set or not.
079:
080: protected Boolean fieldRequired = null;
081: protected String fieldMethodName;
082: protected String fieldMethodType;
083: protected List fieldParameterOrder;
084: protected String fieldReturnPart;
085:
086: /**
087: * Get the type of this extensibility element.
088: *
089: * @return the extensibility element's type
090: */
091: public QName getElementType() {
092: return fieldElementType;
093: }
094:
095: public String getMethodName() {
096: return fieldMethodName;
097: }
098:
099: public String getMethodType() {
100: return fieldMethodType;
101: }
102:
103: public List getParameterOrder() {
104: return fieldParameterOrder;
105: }
106:
107: public String getReturnPart() {
108: return fieldReturnPart;
109: }
110:
111: /**
112: * Get whether or not the semantics of this extension
113: * are required. Relates to the wsdl:required attribute.
114: */
115: public Boolean getRequired() {
116: return fieldRequired;
117: }
118:
119: /**
120: * Set the type of this extensibility element.
121: *
122: * @param elementType the type
123: */
124: public void setElementType(QName elementType) {
125: fieldElementType = elementType;
126: }
127:
128: public void setMethodName(String newMethodName) {
129: fieldMethodName = newMethodName;
130: }
131:
132: public void setMethodType(String newMethodType) {
133: fieldMethodType = newMethodType;
134: }
135:
136: public void setParameterOrder(String newParameterOrderStr) {
137: if (newParameterOrderStr != null) {
138: fieldParameterOrder = StringUtils
139: .parseNMTokens(newParameterOrderStr);
140: }
141: }
142:
143: public void setReturnPart(String newReturnPart) {
144: fieldReturnPart = newReturnPart;
145: }
146:
147: /**
148: * Set whether or not the semantics of this extension
149: * are required. Relates to the wsdl:required attribute.
150: */
151: public void setRequired(Boolean required) {
152: fieldRequired = required;
153: }
154:
155: public String toString() {
156: StringBuffer strBuf = new StringBuffer(super .toString());
157:
158: strBuf.append("\nJavaOperation (" + fieldElementType + "):");
159: strBuf.append("\nrequired=" + fieldRequired);
160:
161: strBuf.append("\nmethodName=" + fieldMethodName);
162: strBuf.append("\nmethodType=" + fieldMethodType);
163: strBuf.append("\nparameterOrder=" + fieldParameterOrder);
164: strBuf.append("\nreturnPart=" + fieldReturnPart);
165:
166: return strBuf.toString();
167: }
168: }
|