| /* |
| * Copyright (c) 2013, the Dart project authors. |
| * |
| * Licensed under the Eclipse Public License v1.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.eclipse.org/legal/epl-v10.html |
| * |
| * 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 com.google.dart.engine.services.refactoring; |
| |
| import com.google.dart.engine.ast.Expression; |
| import com.google.dart.engine.ast.Statement; |
| import com.google.dart.engine.services.status.RefactoringStatus; |
| |
| /** |
| * {@link Refactoring} to extract {@link Expression} or {@link Statement}s into method. |
| */ |
| public interface ExtractMethodRefactoring extends Refactoring { |
| /** |
| * @return {@code true} if selected code can be extracted as "getter". |
| */ |
| boolean canExtractGetter(); |
| |
| /** |
| * Validates the name set using {@link #setMethodName(String)}. |
| */ |
| RefactoringStatus checkMethodName(); |
| |
| /** |
| * Checks if the parameter names are valid. |
| */ |
| RefactoringStatus checkParameterNames(); |
| |
| /** |
| * @return {@code true} if getter should be extracted instead of normal method. |
| */ |
| boolean getExtractGetter(); |
| |
| /** |
| * @return the number of occurrences of the same source as selection. |
| */ |
| int getNumberOfOccurrences(); |
| |
| /** |
| * @return {@link Parameter}s describing parameters of the extracted expression of statements. |
| */ |
| Parameter[] getParameters(); |
| |
| /** |
| * @return <code>true</code> if all occurrences of selected expression or statement should be |
| * replaced. |
| */ |
| boolean getReplaceAllOccurrences(); |
| |
| /** |
| * @return the signature of the extracted method. |
| */ |
| String getSignature(); |
| |
| /** |
| * Specifies if getter should be extracted instead of normal method. |
| */ |
| void setExtractGetter(boolean extractGetter); |
| |
| /** |
| * Sets the name for new method. |
| */ |
| void setMethodName(String methodName); |
| |
| /** |
| * Sets reordered or/and updated {@link Parameter}s. |
| */ |
| void setParameters(Parameter[] parameters); |
| |
| /** |
| * Specifies if all occurrences of the selected expression or statements should be replaced. |
| */ |
| void setReplaceAllOccurrences(boolean replaceAllOccurrences); |
| } |