001: /*
002: * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
003: *
004: * Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
005: *
006: * The contents of this file are subject to the terms of either the GNU
007: * General Public License Version 2 only ("GPL") or the Common
008: * Development and Distribution License("CDDL") (collectively, the
009: * "License"). You may not use this file except in compliance with the
010: * License. You can obtain a copy of the License at
011: * http://www.netbeans.org/cddl-gplv2.html
012: * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
013: * specific language governing permissions and limitations under the
014: * License. When distributing the software, include this License Header
015: * Notice in each file and include the License file at
016: * nbbuild/licenses/CDDL-GPL-2-CP. Sun designates this
017: * particular file as subject to the "Classpath" exception as provided
018: * by Sun in the GPL Version 2 section of the License file that
019: * accompanied this code. If applicable, add the following below the
020: * License Header, with the fields enclosed by brackets [] replaced by
021: * your own identifying information:
022: * "Portions Copyrighted [year] [name of copyright owner]"
023: *
024: * Contributor(s):
025: *
026: * The Original Software is NetBeans. The Initial Developer of the Original
027: * Software is Sun Microsystems, Inc. Portions Copyright 1997-2007 Sun
028: * Microsystems, Inc. All Rights Reserved.
029: *
030: * If you wish your version of this file to be governed by only the CDDL
031: * or only the GPL Version 2, indicate your decision by adding
032: * "[Contributor] elects to include this software in this distribution
033: * under the [CDDL or GPL Version 2] license." If you do not indicate a
034: * single choice of license, a recipient has the option to distribute
035: * your version of this file under either the CDDL, the GPL Version 2 or
036: * to extend the choice of license to its licensees as provided above.
037: * However, if you add GPL Version 2 code and therefore, elected the GPL
038: * Version 2 license, then the option applies only if the new code is
039: * made subject to such option by the copyright holder.
040: */
041:
042: /*
043: * WebserviceRefHandler.java
044: *
045: * Created on October 2, 2006, 12:21 PM
046: *
047: * To change this template, choose Tools | Template Manager
048: * and open the template in the editor.
049: */
050:
051: package org.netbeans.modules.compapp.javaee.annotation.handler;
052:
053: import java.util.ArrayList;
054: import java.util.Collection;
055: import java.util.List;
056: import java.util.logging.Logger;
057: import javax.xml.namespace.QName;
058: import org.netbeans.modules.classfile.Annotation;
059: import org.netbeans.modules.classfile.ClassFile;
060: import org.netbeans.modules.classfile.ClassName;
061: import org.netbeans.modules.classfile.Variable;
062: import org.netbeans.modules.compapp.javaee.codegen.model.Endpoint;
063:
064: /**
065: *
066: * @author gpatil
067: */
068: public class WebserviceRefHandler implements AnnotationHandler {
069: private List<Endpoint> endPoints = new ArrayList<Endpoint>();
070: private static Logger logger = Logger
071: .getLogger(WebserviceRefHandler.class.getName());
072:
073: public WebserviceRefHandler() {
074: }
075:
076: public String getAnnotationClassConstant() {
077: return ANNO_WEB_SERVICE_REF;
078: }
079:
080: public void handle(ClassFileLoader cl, ClassFile theClass) {
081: Collection<Variable> fields = theClass.getVariables();
082: ClassFile typeClass = null;
083: Annotation anno = null;
084:
085: if ((fields != null) && (fields.size() > 0)) {
086: for (Variable field : fields) {
087: anno = field.getAnnotation(ClassName
088: .getClassName(ANNO_WEB_SERVICE_REF));
089: if (anno != null) {
090: String type = field.getDescriptor();
091: typeClass = cl.getClassFileFromInternalName(type);
092: processWebserviceClient(cl, typeClass);
093: }
094: }
095: }
096: }
097:
098: public void processWebserviceClient(ClassFileLoader cl,
099: ClassFile theClass) {
100: Annotation annoWsc = theClass.getAnnotation(ClassName
101: .getClassName(ANNO_WEBSERVICE_CLIENT));
102: Annotation annoWep = null;
103: if (annoWsc != null) {
104: NBAnnonationWrapper wsc = new NBAnnonationWrapper(annoWsc);
105: //WebEndpoint
106: Collection<org.netbeans.modules.classfile.Method> mthds = theClass
107: .getMethods();
108: if ((mthds != null) && (mthds.size() > 0)) {
109: for (org.netbeans.modules.classfile.Method method : mthds) {
110: annoWep = method.getAnnotation(ClassName
111: .getClassName(ANNO_WEB_ENDPOINT));
112: if (annoWep != null) {
113: NBAnnonationWrapper wep = new NBAnnonationWrapper(
114: annoWep);
115: QName serviceName = new QName(wsc
116: .getStringValue(PROP_TNS), wsc
117: .getStringValue(PROP_NAME));
118: String returnType = method.getReturnType();
119: ClassFile returnClass = cl
120: .getClassFileFromInternalName(returnType);
121: QName portType = getPortType(returnClass);
122: Endpoint ep = new Endpoint(
123: Endpoint.EndPointType.Consumer, wep
124: .getStringValue(PROP_NAME),
125: (portType == null) ? null : portType,
126: serviceName);
127: this .endPoints.add(ep);
128: }
129: }
130: }
131: }
132: }
133:
134: private QName getPortType(ClassFile cls) {
135: QName ret = null;
136: Annotation annoWs = cls.getAnnotation(ClassName
137: .getClassName(ANNO_WEB_SERVICE));
138: if (annoWs != null) {
139: NBAnnonationWrapper ws = new NBAnnonationWrapper(annoWs);
140: ret = new QName(ws.getStringValue(PROP_TNS), ws
141: .getStringValue(PROP_NAME));
142: }
143: return ret;
144: }
145:
146: public List<Endpoint> getEndPoints() {
147: return this .endPoints;
148: }
149:
150: public void resetEndPoints() {
151: this.endPoints.clear();
152: }
153: }
|