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: package org.netbeans.modules.refactoring.java.api;
042:
043: import java.util.Collections;
044: import java.util.HashSet;
045: import java.util.Set;
046: import javax.lang.model.element.Modifier;
047: import org.netbeans.api.java.source.TreePathHandle;
048: import org.netbeans.modules.refactoring.api.AbstractRefactoring;
049: import org.openide.util.lookup.Lookups;
050:
051: /**
052: * Refactoring used for changing encapsulate field.
053: * It creates getter and setter for given field and replaces all references.
054: * @author Tomas Hurka
055: * @author Jan Becicka
056: * @author Jan Pokorsky
057: */
058: public final class EncapsulateFieldRefactoring extends
059: AbstractRefactoring {
060: private String getterName, setterName;
061: private Set<Modifier> methodModifiers;
062: private Set<Modifier> fieldModifiers;
063: private boolean alwaysUseAccessors;
064:
065: /**
066: * Creates a new instance of EncapsulateFieldRefactoring
067: * @param field field to refactor
068: */
069: public EncapsulateFieldRefactoring(TreePathHandle field) {
070: super (Lookups.fixed(field));
071: }
072:
073: public TreePathHandle getSourceType() {
074: return getRefactoringSource().lookup(TreePathHandle.class);
075: }
076:
077: /**
078: * Getter for property getterName
079: * @return Value of property getterName
080: */
081: public String getGetterName() {
082: return getterName;
083: }
084:
085: /**
086: * Getter for property setterName
087: * @return Value of property setterName
088: */
089: public String getSetterName() {
090: return setterName;
091: }
092:
093: /**
094: * Getter for property methodModifiers
095: * @return Value of property methodModifiers
096: */
097: public Set<Modifier> getMethodModifiers() {
098: return methodModifiers;
099: }
100:
101: /**
102: * Getter for property fieldModifiers
103: * @return Value of property fieldModifiers
104: */
105: public Set<Modifier> getFieldModifiers() {
106: return fieldModifiers;
107: }
108:
109: /**
110: * Getter for boolean property alwaysUseAccessors
111: * @return Value of property alwaysUseAccessors
112: */
113: public boolean isAlwaysUseAccessors() {
114: return alwaysUseAccessors;
115: }
116:
117: /**
118: * Setter for getterName property
119: * @param getterName New value of getterName
120: */
121: public void setGetterName(String getterName) {
122: this .getterName = getterName;
123: }
124:
125: /**
126: * Setter for setterName property
127: * @param setterName New value of setterName
128: */
129: public void setSetterName(String setterName) {
130: this .setterName = setterName;
131: }
132:
133: /**
134: * Setter for methodModifiers property
135: * @param methodModifiers New value of methodModifiers
136: */
137: public void setMethodModifiers(Set<Modifier> methodModifiers) {
138: this .methodModifiers = Collections
139: .unmodifiableSet(new HashSet<Modifier>(methodModifiers));
140: }
141:
142: /**
143: * Setter for fieldModifiers property
144: * @param fieldModifiers New value of fieldModifiers
145: */
146: public void setFieldModifiers(Set<Modifier> fieldModifiers) {
147: this .fieldModifiers = Collections
148: .unmodifiableSet(new HashSet<Modifier>(fieldModifiers));
149: }
150:
151: /**
152: * Setter for alwaysUseAccessors property
153: * @param alwaysUseAccessors New value of alwaysUseAccessors
154: */
155: public void setAlwaysUseAccessors(boolean alwaysUseAccessors) {
156: this.alwaysUseAccessors = alwaysUseAccessors;
157: }
158: }
|