--- a/refactoring.api/src/org/netbeans/modules/refactoring/api/MoveRefactoring.java
+++ a/refactoring.api/src/org/netbeans/modules/refactoring/api/MoveRefactoring.java
@@ -58,7 +58,7 @@
* @see AbstractRefactoring
* @see RefactoringSession
* @author Jan Becicka
- */
+ */
public final class MoveRefactoring extends AbstractRefactoring {
private Lookup target;
@@ -70,6 +70,7 @@
*
Module | Types the Module Understands | Implementation |
* Refactoring API (Default impl.) | {@link org.openide.filsuystems.FileObject}(s) | Does file(s) move |
* Java Refactoring | {@link org.openide.filsuystems.FileObject}(s) with content type text/x-java | Does refactoring inside .java files |
+ * | {@link org.netbeans.api.java.source.TreePathHandle}(s) | Does refactoring of members in .java files |
*
* @param objectsToMove store your objects into Lookup
*/
@@ -86,6 +87,7 @@
* Creates direstory corresponding to specified {@link java.net.URL} if does not
* exist and moves all FileObjects into this folder. |
* Java Refactoring | {@link java.net.URL} | Does move refactoring inside .java files |
+ * | {@link org.netbeans.api.java.source.TreePathHandle} | Does refactoring of members in .java files |
*
* @param target
*/
--- a/refactoring.java/apichanges.xml
+++ a/refactoring.java/apichanges.xml
@@ -49,6 +49,21 @@
Java Refactoring API
+
+
+ Added new Move Members Properties.
+
+
+
+
+
+
+ Add an api for the Java Move Members Properties.
+
+
+
+
+
Added new refactoring and dependent change in ChangeParameterRefactoring.
--- a/refactoring.java/nbproject/project.properties
+++ a/refactoring.java/nbproject/project.properties
@@ -1,7 +1,7 @@
javac.source=1.6
javadoc.arch=${basedir}/arch.xml
-spec.version.base=1.30.0
+spec.version.base=1.31.0
#test configs
test.config.find.includes=\
**/FindUsagesSuite.class
--- a/refactoring.java/src/org/netbeans/modules/refactoring/java/api/JavaMoveMembersProperties.java
+++ a/refactoring.java/src/org/netbeans/modules/refactoring/java/api/JavaMoveMembersProperties.java
@@ -0,0 +1,182 @@
+/*
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
+ *
+ * Copyright 2011 Oracle and/or its affiliates. All rights reserved.
+ *
+ * Oracle and Java are registered trademarks of Oracle and/or its affiliates.
+ * Other names may be trademarks of their respective owners.
+ *
+ * The contents of this file are subject to the terms of either the GNU
+ * General Public License Version 2 only ("GPL") or the Common
+ * Development and Distribution License("CDDL") (collectively, the
+ * "License"). You may not use this file except in compliance with the
+ * License. You can obtain a copy of the License at
+ * http://www.netbeans.org/cddl-gplv2.html
+ * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
+ * specific language governing permissions and limitations under the
+ * License. When distributing the software, include this License Header
+ * Notice in each file and include the License file at
+ * nbbuild/licenses/CDDL-GPL-2-CP. Oracle designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Oracle in the GPL Version 2 section of the License file that
+ * accompanied this code. If applicable, add the following below the
+ * License Header, with the fields enclosed by brackets [] replaced by
+ * your own identifying information:
+ * "Portions Copyrighted [year] [name of copyright owner]"
+ *
+ * If you wish your version of this file to be governed by only the CDDL
+ * or only the GPL Version 2, indicate your decision by adding
+ * "[Contributor] elects to include this software in this distribution
+ * under the [CDDL or GPL Version 2] license." If you do not indicate a
+ * single choice of license, a recipient has the option to distribute
+ * your version of this file under either the CDDL, the GPL Version 2 or
+ * to extend the choice of license to its licensees as provided above.
+ * However, if you add GPL Version 2 code and therefore, elected the GPL
+ * Version 2 license, then the option applies only if the new code is
+ * made subject to such option by the copyright holder.
+ *
+ * Contributor(s):
+ *
+ * Portions Copyrighted 2011 Sun Microsystems, Inc.
+ */
+package org.netbeans.modules.refactoring.java.api;
+
+import org.netbeans.modules.refactoring.api.MoveRefactoring;
+
+/**
+ * This class is just holder for properties of the Java Move Members
+ * Refactoring. Refactoring itself is implemented in plugins.
+ *
+ * @see org.netbeans.modules.refactoring.api.MoveRefactoring
+ * @see org.netbeans.modules.refactoring.api.Context
+ * @author Ralph Ruijs
+ * @since 1.31
+ */
+public final class JavaMoveMembersProperties {
+
+ private Visibility visibility;
+ private boolean delegate;
+ private boolean addDeprecated;
+ private boolean updateJavaDoc;
+
+ /**
+ * Constructs a new JavaMoveMembersProperties object.
+ */
+ public JavaMoveMembersProperties() {
+ visibility = Visibility.ESCALATE;
+ delegate = false;
+ addDeprecated = false;
+ updateJavaDoc = true;
+ }
+
+ /**
+ * The new visibility of the members.
+ *
+ * @return visibility
+ */
+ public Visibility getVisibility() {
+ return visibility;
+ }
+
+ /**
+ * The new visibility of the members.
+ *
+ * @param visibility the visibility to use
+ */
+ public void setVisibility(Visibility visibility) {
+ this.visibility = visibility;
+ }
+
+ /**
+ * Leave the old method in place and let it delegate to the new location.
+ * All references to the method will not be touched.
+ *
+ * @return true if the old method will delegate to the new location, false
+ * otherwise
+ */
+ public boolean isDelegate() {
+ return delegate;
+ }
+
+ /**
+ * Leave the old method in place and let it delegate to the new location.
+ * All references to the method will not be touched.
+ *
+ * @param delegate true if the old method needs delegate to the new location
+ */
+ public void setDelegate(boolean delegate) {
+ this.delegate = delegate;
+ }
+
+ /**
+ * Add a deprecated tag to the JavaDoc of the delegating method.
+ *
+ * @return true if a deprecated tag needs to be added, false otherwise
+ */
+ public boolean isAddDeprecated() {
+ return addDeprecated;
+ }
+
+ /**
+ * Add a deprecated tag to the JavaDoc of the delegating method.
+ *
+ * @param addDeprecated true if a deprecated tag has to be added to the
+ * delegate method
+ */
+ public void setAddDeprecated(boolean addDeprecated) {
+ this.addDeprecated = addDeprecated;
+ }
+
+ /**
+ * Update or create the JavaDoc for moved methods.
+ *
+ * @return true if JavaDoc will be created or the existing will be updated,
+ * false otherwise
+ */
+ public boolean isUpdateJavaDoc() {
+ return updateJavaDoc;
+ }
+
+ /**
+ * Add a deprecated tag to the javadoc of the delegating method.
+ *
+ * @param updateJavaDoc true if the method's JavaDoc needs to be created or
+ * updated.
+ */
+ public void setUpdateJavaDoc(boolean updateJavaDoc) {
+ this.updateJavaDoc = updateJavaDoc;
+ }
+
+ /**
+ * Used to specify visibility level. It can either be set explicitly, or set
+ * to Escalate to automatically raise it to a necessary level.
+ */
+ public static enum Visibility {
+
+ /**
+ * Escalate, automatically raise the visibility to a necessary level,
+ * based on usages.
+ */
+ ESCALATE,
+ /**
+ * As is, keep the current visibility level of the member.
+ */
+ ASIS,
+ /**
+ * Change to, or keep, the visibility public.
+ */
+ PUBLIC,
+ /**
+ * Change to, or keep, the visibility protected.
+ */
+ PROTECTED,
+ /**
+ * Change to, or keep, the visibility the default level.
+ */
+ DEFAULT,
+ /**
+ * Change to, or keep, the visibility private.
+ */
+ PRIVATE
+ }
+}