cxf-commits mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From e..@apache.org
Subject svn commit: r576776 - /incubator/cxf/trunk/maven-plugins/codegen-plugin/src/main/java/org/apache/cxf/maven_plugin/Java2WSMojo.java
Date Tue, 18 Sep 2007 08:42:16 GMT
Author: ema
Date: Tue Sep 18 01:42:15 2007
New Revision: 576776

URL: http://svn.apache.org/viewvc?rev=576776&view=rev
Log:
Added java2ws maven plugin

Added:
    incubator/cxf/trunk/maven-plugins/codegen-plugin/src/main/java/org/apache/cxf/maven_plugin/Java2WSMojo.java

Added: incubator/cxf/trunk/maven-plugins/codegen-plugin/src/main/java/org/apache/cxf/maven_plugin/Java2WSMojo.java
URL: http://svn.apache.org/viewvc/incubator/cxf/trunk/maven-plugins/codegen-plugin/src/main/java/org/apache/cxf/maven_plugin/Java2WSMojo.java?rev=576776&view=auto
==============================================================================
--- incubator/cxf/trunk/maven-plugins/codegen-plugin/src/main/java/org/apache/cxf/maven_plugin/Java2WSMojo.java
(added)
+++ incubator/cxf/trunk/maven-plugins/codegen-plugin/src/main/java/org/apache/cxf/maven_plugin/Java2WSMojo.java
Tue Sep 18 01:42:15 2007
@@ -0,0 +1,265 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+package org.apache.cxf.maven_plugin;
+
+import java.io.File;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.StringTokenizer;
+
+import org.apache.cxf.helpers.FileUtils;
+import org.apache.cxf.tools.java2ws.JavaToWS;
+import org.apache.maven.plugin.AbstractMojo;
+import org.apache.maven.plugin.MojoExecutionException;
+import org.apache.maven.project.MavenProject;
+import org.apache.tools.ant.ExitException;
+import org.apache.tools.ant.util.optional.NoExitSecurityManager;
+
+/**
+ * @goal java2ws
+ * @description CXF Java To Webservice Tool
+ */
+public class Java2WSMojo extends AbstractMojo {
+    /**
+     * @parameter 
+     * @required
+     */
+    private String className;
+
+    /**
+     * @parameter  expression="${project.build.outputDirectory}"
+     * @required
+     */
+    private String classpath;
+
+    /**
+     * @parameter
+     */
+    private String outputFile;
+    
+    /**
+     * @parameter
+     */
+    private Boolean soap12;
+
+    /**
+     * @parameter
+     */
+    private String targetNamespace;
+
+    /**
+     * @parameter
+     */
+    private String serviceName;
+
+    /**
+     * @parameter
+     */
+    private Boolean verbose;
+
+    /**
+     * @parameter
+     */
+    private Boolean quiet;
+
+    /**
+     * @parameter  expression="${project.compileClasspathElements}"
+     * @required
+     */
+    private List classpathElements;
+
+    /**
+     * @parameter expression="${project}"
+     * @required
+     */
+    private MavenProject project;
+
+    /**
+     * @parameter
+     */
+    private String argline;
+    
+    /**
+     * @parameter
+     */
+    private String frontend;
+    
+    /**
+     * @parameter
+     */
+    private String databinding;
+    /**
+     * @parameter default-value="false"
+     */
+    private Boolean genWsdl;
+    /**
+     * @parameter default-value="false"
+     */
+    private Boolean genServer;
+    /**
+     * @parameter default-value="false"
+     */
+    private Boolean genClient;
+    /**
+     * @parameter default-value="false"
+     */
+    private Boolean genWrapperbean;
+    
+    
+    public void execute() throws MojoExecutionException {
+        StringBuffer buf = new StringBuffer();
+        for (Object classpathElement : classpathElements) {
+            buf.append(classpathElement.toString());
+            buf.append(File.pathSeparatorChar);
+        }
+        String newCp = buf.toString();
+        String cp = System.getProperty("java.class.path");
+        SecurityManager oldSm = System.getSecurityManager();
+        try {
+            System.setProperty("java.class.path", newCp);
+            System.setSecurityManager(new NoExitSecurityManager());
+            processJavaClass();
+        } finally {
+            System.setSecurityManager(oldSm);
+            System.setProperty("java.class.path", cp);
+        }
+
+        System.gc();
+    }
+
+    private void processJavaClass() throws MojoExecutionException {
+        List<String> args = new ArrayList<String>();
+
+        // outputfile arg
+        if (outputFile == null && project != null) {
+            // Put the wsdl in target/generated/wsdl
+            int i = className.lastIndexOf('.');
+            // Prone to OoBE, but then it's wrong anyway
+            String name = className.substring(i + 1); 
+            outputFile = (project.getBuild().getDirectory() + "/generated/wsdl/" + name +
".wsdl")
+                .replace("/", File.separator);
+        }
+        if (outputFile != null) {
+            // JavaToWSDL freaks out if the directory of the outputfile doesn't exist, so
lets
+            // create it since there's no easy way for the user to create it beforehand in
maven
+            FileUtils.mkDir(new File(outputFile).getParentFile());
+            args.add("-o");
+            args.add(outputFile);
+
+            /*
+              Contributor's comment:
+              Sometimes JavaToWSDL creates Java code for the wrappers.  I don't *think* this
is
+              needed by the end user.
+            */
+            
+            // Commiter's comment:
+            // Yes, it's required, it's defined in the JAXWS spec.
+
+            if (project != null) {
+                project.addCompileSourceRoot(new File(outputFile).getParentFile().getAbsolutePath());
+            }
+        }
+        
+        if (frontend != null) {
+            args.add("-frontend");
+            args.add(frontend);
+        }
+        
+        if (databinding != null) {
+            args.add("-databinding");
+            args.add(databinding);
+        }
+        
+        if (genWrapperbean) {
+            args.add("-wrapperbean");
+        }
+        
+        if (genWsdl) {
+            args.add("-wsdl");
+        }
+        
+        if (genServer) {
+            args.add("-server");
+        }
+        
+        if (genClient) {
+            args.add("-client");
+        }
+        
+        // classpath arg
+        args.add("-cp");
+        args.add(classpath);
+
+        // soap12 arg
+        if (soap12 != null && soap12.booleanValue()) {
+            args.add("-soap12");
+        }
+
+        // target namespace arg
+        if (targetNamespace != null) {
+            args.add("-t");
+            args.add(targetNamespace);
+        }
+
+        // servicename arg
+        if (serviceName != null) {
+            args.add("-servicename");
+            args.add(serviceName);
+        }
+
+        // verbose arg
+        if (verbose != null && verbose.booleanValue()) {
+            args.add("-verbose");
+        }
+
+        // quiet arg
+        if (quiet != null && quiet.booleanValue()) {
+            args.add("-quiet");
+        }
+
+        if (argline != null) {
+            StringTokenizer stoken = new StringTokenizer(argline, " ");
+            while (stoken.hasMoreTokens()) {
+                args.add(stoken.nextToken());
+            }
+        }
+
+        // classname arg
+        args.add(className);
+
+        try {
+            String exitOnFinish = System.getProperty("exitOnFinish", "");
+            try {
+                System.setProperty("exitOnFinish", "YES");
+                JavaToWS.main(args.toArray(new String[args.size()]));
+            } catch (ExitException e) {
+                if (e.getStatus() != 0) {
+                    throw e;
+                }
+            } finally {
+                System.setProperty("exitOnFinish", exitOnFinish);
+            }
+        } catch (Throwable e) {
+            getLog().debug(e);
+            throw new MojoExecutionException(e.getMessage(), e);
+        }
+    }
+       
+}
\ No newline at end of file



Mime
View raw message