blob: a6127cfe6d1e767f9f693a1e08059048d627bc59 [file] [log] [blame]
/*
* Copyright (c) 2018, the Dart project authors. Please see the AUTHORS file
* for details. All rights reserved. Use of this source code is governed by a
* BSD-style license that can be found in the LICENSE file.
*
* This file has been automatically generated. Please do not edit it manually.
* To regenerate the file, use the script "pkg/analysis_server/tool/spec/generate_files".
*/
package org.dartlang.analysis.server.protocol;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import com.google.common.collect.Lists;
import com.google.dart.server.utilities.general.JsonUtilities;
import com.google.dart.server.utilities.general.ObjectUtilities;
import com.google.gson.JsonArray;
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
import com.google.gson.JsonPrimitive;
import org.apache.commons.lang3.builder.HashCodeBuilder;
import java.util.ArrayList;
import java.util.Iterator;
import org.apache.commons.lang3.StringUtils;
/**
* @coverage dart.server.generated.types
*/
@SuppressWarnings("unused")
public class ExtractMethodOptions extends RefactoringOptions {
public static final ExtractMethodOptions[] EMPTY_ARRAY = new ExtractMethodOptions[0];
public static final List<ExtractMethodOptions> EMPTY_LIST = Lists.newArrayList();
/**
* The return type that should be defined for the method.
*/
private String returnType;
/**
* True if a getter should be created rather than a method. It is an error if this field is true
* and the list of parameters is non-empty.
*/
private boolean createGetter;
/**
* The name that the method should be given.
*/
private String name;
/**
* The parameters that should be defined for the method.
*
* It is an error if a REQUIRED or NAMED parameter follows a POSITIONAL parameter. It is an error
* if a REQUIRED or POSITIONAL parameter follows a NAMED parameter.
*
* - To change the order and/or update proposed parameters, add parameters with the same
* identifiers as proposed.
* - To add new parameters, omit their identifier.
* - To remove some parameters, omit them in this list.
*/
private List<RefactoringMethodParameter> parameters;
/**
* True if all occurrences of the expression or statements should be replaced by an invocation of
* the method. The expression or statements used to initiate the refactoring will always be
* replaced.
*/
private boolean extractAll;
/**
* Constructor for {@link ExtractMethodOptions}.
*/
public ExtractMethodOptions(String returnType, boolean createGetter, String name, List<RefactoringMethodParameter> parameters, boolean extractAll) {
this.returnType = returnType;
this.createGetter = createGetter;
this.name = name;
this.parameters = parameters;
this.extractAll = extractAll;
}
@Override
public boolean equals(Object obj) {
if (obj instanceof ExtractMethodOptions) {
ExtractMethodOptions other = (ExtractMethodOptions) obj;
return
ObjectUtilities.equals(other.returnType, returnType) &&
other.createGetter == createGetter &&
ObjectUtilities.equals(other.name, name) &&
ObjectUtilities.equals(other.parameters, parameters) &&
other.extractAll == extractAll;
}
return false;
}
public static ExtractMethodOptions fromJson(JsonObject jsonObject) {
String returnType = jsonObject.get("returnType").getAsString();
boolean createGetter = jsonObject.get("createGetter").getAsBoolean();
String name = jsonObject.get("name").getAsString();
List<RefactoringMethodParameter> parameters = RefactoringMethodParameter.fromJsonArray(jsonObject.get("parameters").getAsJsonArray());
boolean extractAll = jsonObject.get("extractAll").getAsBoolean();
return new ExtractMethodOptions(returnType, createGetter, name, parameters, extractAll);
}
public static List<ExtractMethodOptions> fromJsonArray(JsonArray jsonArray) {
if (jsonArray == null) {
return EMPTY_LIST;
}
ArrayList<ExtractMethodOptions> list = new ArrayList<ExtractMethodOptions>(jsonArray.size());
Iterator<JsonElement> iterator = jsonArray.iterator();
while (iterator.hasNext()) {
list.add(fromJson(iterator.next().getAsJsonObject()));
}
return list;
}
/**
* True if a getter should be created rather than a method. It is an error if this field is true
* and the list of parameters is non-empty.
*/
public boolean createGetter() {
return createGetter;
}
/**
* True if all occurrences of the expression or statements should be replaced by an invocation of
* the method. The expression or statements used to initiate the refactoring will always be
* replaced.
*/
public boolean extractAll() {
return extractAll;
}
/**
* The name that the method should be given.
*/
public String getName() {
return name;
}
/**
* The parameters that should be defined for the method.
*
* It is an error if a REQUIRED or NAMED parameter follows a POSITIONAL parameter. It is an error
* if a REQUIRED or POSITIONAL parameter follows a NAMED parameter.
*
* - To change the order and/or update proposed parameters, add parameters with the same
* identifiers as proposed.
* - To add new parameters, omit their identifier.
* - To remove some parameters, omit them in this list.
*/
public List<RefactoringMethodParameter> getParameters() {
return parameters;
}
/**
* The return type that should be defined for the method.
*/
public String getReturnType() {
return returnType;
}
@Override
public int hashCode() {
HashCodeBuilder builder = new HashCodeBuilder();
builder.append(returnType);
builder.append(createGetter);
builder.append(name);
builder.append(parameters);
builder.append(extractAll);
return builder.toHashCode();
}
/**
* True if a getter should be created rather than a method. It is an error if this field is true
* and the list of parameters is non-empty.
*/
public void setCreateGetter(boolean createGetter) {
this.createGetter = createGetter;
}
/**
* True if all occurrences of the expression or statements should be replaced by an invocation of
* the method. The expression or statements used to initiate the refactoring will always be
* replaced.
*/
public void setExtractAll(boolean extractAll) {
this.extractAll = extractAll;
}
/**
* The name that the method should be given.
*/
public void setName(String name) {
this.name = name;
}
/**
* The parameters that should be defined for the method.
*
* It is an error if a REQUIRED or NAMED parameter follows a POSITIONAL parameter. It is an error
* if a REQUIRED or POSITIONAL parameter follows a NAMED parameter.
*
* - To change the order and/or update proposed parameters, add parameters with the same
* identifiers as proposed.
* - To add new parameters, omit their identifier.
* - To remove some parameters, omit them in this list.
*/
public void setParameters(List<RefactoringMethodParameter> parameters) {
this.parameters = parameters;
}
/**
* The return type that should be defined for the method.
*/
public void setReturnType(String returnType) {
this.returnType = returnType;
}
public JsonObject toJson() {
JsonObject jsonObject = new JsonObject();
jsonObject.addProperty("returnType", returnType);
jsonObject.addProperty("createGetter", createGetter);
jsonObject.addProperty("name", name);
JsonArray jsonArrayParameters = new JsonArray();
for (RefactoringMethodParameter elt : parameters) {
jsonArrayParameters.add(elt.toJson());
}
jsonObject.add("parameters", jsonArrayParameters);
jsonObject.addProperty("extractAll", extractAll);
return jsonObject;
}
@Override
public String toString() {
StringBuilder builder = new StringBuilder();
builder.append("[");
builder.append("returnType=");
builder.append(returnType + ", ");
builder.append("createGetter=");
builder.append(createGetter + ", ");
builder.append("name=");
builder.append(name + ", ");
builder.append("parameters=");
builder.append(StringUtils.join(parameters, ", ") + ", ");
builder.append("extractAll=");
builder.append(extractAll);
builder.append("]");
return builder.toString();
}
}