| /* |
| * Copyright (c) 2019, 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; |
| |
| /** |
| * A description of a set of changes to a single file. |
| * |
| * @coverage dart.server.generated.types |
| */ |
| @SuppressWarnings("unused") |
| public class SourceFileEdit { |
| |
| public static final SourceFileEdit[] EMPTY_ARRAY = new SourceFileEdit[0]; |
| |
| public static final List<SourceFileEdit> EMPTY_LIST = Lists.newArrayList(); |
| |
| /** |
| * The file containing the code to be modified. |
| */ |
| private final String file; |
| |
| /** |
| * The modification stamp of the file at the moment when the change was created, in milliseconds |
| * since the "Unix epoch". Will be -1 if the file did not exist and should be created. The client |
| * may use this field to make sure that the file was not changed since then, so it is safe to apply |
| * the change. |
| */ |
| private final long fileStamp; |
| |
| /** |
| * A list of the edits used to effect the change. |
| */ |
| private final List<SourceEdit> edits; |
| |
| /** |
| * Constructor for {@link SourceFileEdit}. |
| */ |
| public SourceFileEdit(String file, long fileStamp, List<SourceEdit> edits) { |
| this.file = file; |
| this.fileStamp = fileStamp; |
| this.edits = edits; |
| } |
| |
| @Override |
| public boolean equals(Object obj) { |
| if (obj instanceof SourceFileEdit) { |
| SourceFileEdit other = (SourceFileEdit) obj; |
| return |
| ObjectUtilities.equals(other.file, file) && |
| other.fileStamp == fileStamp && |
| ObjectUtilities.equals(other.edits, edits); |
| } |
| return false; |
| } |
| |
| public static SourceFileEdit fromJson(JsonObject jsonObject) { |
| String file = jsonObject.get("file").getAsString(); |
| long fileStamp = jsonObject.get("fileStamp").getAsLong(); |
| List<SourceEdit> edits = SourceEdit.fromJsonArray(jsonObject.get("edits").getAsJsonArray()); |
| return new SourceFileEdit(file, fileStamp, edits); |
| } |
| |
| public static List<SourceFileEdit> fromJsonArray(JsonArray jsonArray) { |
| if (jsonArray == null) { |
| return EMPTY_LIST; |
| } |
| ArrayList<SourceFileEdit> list = new ArrayList<SourceFileEdit>(jsonArray.size()); |
| Iterator<JsonElement> iterator = jsonArray.iterator(); |
| while (iterator.hasNext()) { |
| list.add(fromJson(iterator.next().getAsJsonObject())); |
| } |
| return list; |
| } |
| |
| /** |
| * A list of the edits used to effect the change. |
| */ |
| public List<SourceEdit> getEdits() { |
| return edits; |
| } |
| |
| /** |
| * The file containing the code to be modified. |
| */ |
| public String getFile() { |
| return file; |
| } |
| |
| /** |
| * The modification stamp of the file at the moment when the change was created, in milliseconds |
| * since the "Unix epoch". Will be -1 if the file did not exist and should be created. The client |
| * may use this field to make sure that the file was not changed since then, so it is safe to apply |
| * the change. |
| */ |
| public long getFileStamp() { |
| return fileStamp; |
| } |
| |
| @Override |
| public int hashCode() { |
| HashCodeBuilder builder = new HashCodeBuilder(); |
| builder.append(file); |
| builder.append(fileStamp); |
| builder.append(edits); |
| return builder.toHashCode(); |
| } |
| |
| public JsonObject toJson() { |
| JsonObject jsonObject = new JsonObject(); |
| jsonObject.addProperty("file", file); |
| jsonObject.addProperty("fileStamp", fileStamp); |
| JsonArray jsonArrayEdits = new JsonArray(); |
| for (SourceEdit elt : edits) { |
| jsonArrayEdits.add(elt.toJson()); |
| } |
| jsonObject.add("edits", jsonArrayEdits); |
| return jsonObject; |
| } |
| |
| @Override |
| public String toString() { |
| StringBuilder builder = new StringBuilder(); |
| builder.append("["); |
| builder.append("file="); |
| builder.append(file + ", "); |
| builder.append("fileStamp="); |
| builder.append(fileStamp + ", "); |
| builder.append("edits="); |
| builder.append(StringUtils.join(edits, ", ")); |
| builder.append("]"); |
| return builder.toString(); |
| } |
| |
| } |