blob: 3d2c5be2c33e42ef9df60e93d8c1c6e2e70fac46 [file] [log] [blame]
/*
* 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;
/**
* An node in the outline structure of a file.
*
* @coverage dart.server.generated.types
*/
@SuppressWarnings("unused")
public class Outline {
public static final Outline[] EMPTY_ARRAY = new Outline[0];
public static final List<Outline> EMPTY_LIST = Lists.newArrayList();
/**
* A description of the element represented by this node.
*/
private Element element;
/**
* The offset of the first character of the element. This is different than the offset in the
* Element, which is the offset of the name of the element. It can be used, for example, to map
* locations in the file back to an outline.
*/
private int offset;
/**
* The length of the element.
*/
private int length;
/**
* The offset of the first character of the element code, which is neither documentation, nor
* annotation.
*/
private int codeOffset;
/**
* The length of the element code.
*/
private int codeLength;
private final Outline parent;
private List<Outline> children;
/**
* Constructor for {@link Outline}.
*/
public Outline(Outline parent, Element element, int offset, int length, int codeOffset, int codeLength) {
this.parent = parent;
this.element = element;
this.offset = offset;
this.length = length;
this.codeOffset = codeOffset;
this.codeLength = codeLength;
}
public boolean containsInclusive(int x) {
return offset <= x && x <= offset + length;
}
@Override
public boolean equals(Object obj) {
if (obj instanceof Outline) {
Outline other = (Outline) obj;
return
ObjectUtilities.equals(other.element, element) &&
other.offset == offset &&
other.length == length &&
other.codeOffset == codeOffset &&
other.codeLength == codeLength &&
ObjectUtilities.equals(other.children, children);
}
return false;
}
public static Outline fromJson(Outline parent, JsonObject outlineObject) {
JsonObject elementObject = outlineObject.get("element").getAsJsonObject();
Element element = Element.fromJson(elementObject);
int offset = outlineObject.get("offset").getAsInt();
int length = outlineObject.get("length").getAsInt();
int codeOffset = outlineObject.get("codeOffset").getAsInt();
int codeLength = outlineObject.get("codeLength").getAsInt();
// create outline object
Outline outline = new Outline(parent, element, offset, length, codeOffset, codeLength);
// compute children recursively
List<Outline> childrenList = Lists.newArrayList();
JsonElement childrenJsonArray = outlineObject.get("children");
if (childrenJsonArray instanceof JsonArray) {
Iterator<JsonElement> childrenElementIterator = ((JsonArray) childrenJsonArray).iterator();
while (childrenElementIterator.hasNext()) {
JsonObject childObject = childrenElementIterator.next().getAsJsonObject();
childrenList.add(fromJson(outline, childObject));
}
}
outline.setChildren(childrenList);
return outline;
}
public Outline getParent() {
return parent;
}
/**
* The children of the node. The field will be omitted if the node has no children. Children are
* sorted by offset.
*/
public List<Outline> getChildren() {
return children;
}
/**
* The length of the element code.
*/
public int getCodeLength() {
return codeLength;
}
/**
* The offset of the first character of the element code, which is neither documentation, nor
* annotation.
*/
public int getCodeOffset() {
return codeOffset;
}
/**
* A description of the element represented by this node.
*/
public Element getElement() {
return element;
}
/**
* The length of the element.
*/
public int getLength() {
return length;
}
/**
* The offset of the first character of the element. This is different than the offset in the
* Element, which is the offset of the name of the element. It can be used, for example, to map
* locations in the file back to an outline.
*/
public int getOffset() {
return offset;
}
@Override
public int hashCode() {
HashCodeBuilder builder = new HashCodeBuilder();
builder.append(element);
builder.append(offset);
builder.append(length);
builder.append(codeOffset);
builder.append(codeLength);
builder.append(children);
return builder.toHashCode();
}
/**
* The children of the node. The field will be omitted if the node has no children. Children are
* sorted by offset.
*/
public void setChildren(List<Outline> children) {
this.children = children;
}
/**
* The length of the element code.
*/
public void setCodeLength(int codeLength) {
this.codeLength = codeLength;
}
/**
* The offset of the first character of the element code, which is neither documentation, nor
* annotation.
*/
public void setCodeOffset(int codeOffset) {
this.codeOffset = codeOffset;
}
/**
* A description of the element represented by this node.
*/
public void setElement(Element element) {
this.element = element;
}
/**
* The length of the element.
*/
public void setLength(int length) {
this.length = length;
}
/**
* The offset of the first character of the element. This is different than the offset in the
* Element, which is the offset of the name of the element. It can be used, for example, to map
* locations in the file back to an outline.
*/
public void setOffset(int offset) {
this.offset = offset;
}
@Override
public String toString() {
StringBuilder builder = new StringBuilder();
builder.append("[");
builder.append("element=");
builder.append(element + ", ");
builder.append("offset=");
builder.append(offset + ", ");
builder.append("length=");
builder.append(length + ", ");
builder.append("codeOffset=");
builder.append(codeOffset + ", ");
builder.append("codeLength=");
builder.append(codeLength + ", ");
builder.append("children=");
builder.append(StringUtils.join(children, ", "));
builder.append("]");
return builder.toString();
}
}