mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2025-01-09 00:14:10 -08:00
Adds several mappings to debug information
This commit is contained in:
parent
7153a8e2c9
commit
2c8902e94a
|
@ -50,6 +50,8 @@ public class DebugInformation {
|
|||
MultiMapping[] variableMappings;
|
||||
CFG[] controlFlowGraphs;
|
||||
List<ClassMetadata> classesMetadata;
|
||||
MethodEntrances methodEntrances;
|
||||
MethodTree methodTree;
|
||||
|
||||
public String[] getCoveredSourceFiles() {
|
||||
return fileNames.clone();
|
||||
|
@ -192,6 +194,23 @@ public class DebugInformation {
|
|||
return getCallSite(new GeneratedLocation(line, column));
|
||||
}
|
||||
|
||||
public GeneratedLocation[] getMethodEntrances(MethodReference methodRef) {
|
||||
Integer classIndex = classNameMap.get(methodRef.getClassName());
|
||||
if (classIndex == null) {
|
||||
return new GeneratedLocation[0];
|
||||
}
|
||||
Integer methodIndex = methodMap.get(methodRef.getDescriptor().toString());
|
||||
if (methodIndex == null) {
|
||||
return new GeneratedLocation[0];
|
||||
}
|
||||
long exact = ((long)classIndex << 32) | methodIndex;
|
||||
Integer index = exactMethodMap.get(exact);
|
||||
if (index == null) {
|
||||
return new GeneratedLocation[0];
|
||||
}
|
||||
return methodEntrances.getEntrances(index);
|
||||
}
|
||||
|
||||
private <T> T componentByKey(Mapping mapping, T[] values, GeneratedLocation location) {
|
||||
int keyIndex = indexByKey(mapping, location);
|
||||
int valueIndex = keyIndex >= 0 ? mapping.values[keyIndex] : -1;
|
||||
|
@ -232,6 +251,12 @@ public class DebugInformation {
|
|||
return reader.read();
|
||||
}
|
||||
|
||||
void rebuild() {
|
||||
rebuildMaps();
|
||||
rebuildFileDescriptions();
|
||||
rebuildEntrances();
|
||||
}
|
||||
|
||||
void rebuildMaps() {
|
||||
fileNameMap = mapArray(fileNames);
|
||||
classNameMap = mapArray(classNames);
|
||||
|
@ -285,6 +310,107 @@ public class DebugInformation {
|
|||
fileDescriptions = builder.build();
|
||||
}
|
||||
|
||||
void rebuildEntrances() {
|
||||
methodEntrances = new MethodEntrancesBuilder().build();
|
||||
}
|
||||
|
||||
void rebuildMethodTree() {
|
||||
for (int i = 0; i < classesMetadata.size(); ++i) {
|
||||
ClassMetadata clsData = classesMetadata.get(i);
|
||||
clsData.parentId;
|
||||
}
|
||||
}
|
||||
|
||||
class MethodEntrancesBuilder {
|
||||
int[] start;
|
||||
IntegerArray data;
|
||||
IntegerArray next;
|
||||
int methodIndex;
|
||||
int classIndex;
|
||||
|
||||
public MethodEntrances build() {
|
||||
methodIndex = -1;
|
||||
classIndex = -1;
|
||||
start = new int[exactMethods.length];
|
||||
Arrays.fill(start, -1);
|
||||
data = new IntegerArray(0);
|
||||
next = new IntegerArray(0);
|
||||
int methodMappingIndex = 0;
|
||||
int classMappingIndex = 0;
|
||||
while (methodMappingIndex < methodMapping.lines.length &&
|
||||
classMappingIndex < classMapping.lines.length) {
|
||||
GeneratedLocation methodLoc = new GeneratedLocation(methodMapping.lines[methodMappingIndex],
|
||||
methodMapping.columns[methodMappingIndex]);
|
||||
GeneratedLocation classLoc = new GeneratedLocation(classMapping.lines[classMappingIndex],
|
||||
classMapping.columns[classMappingIndex]);
|
||||
int cmp = methodLoc.compareTo(classLoc);
|
||||
if (cmp < 0) {
|
||||
methodIndex = methodMapping.values[methodMappingIndex++];
|
||||
addMethodEntrance(methodLoc);
|
||||
} else if (cmp > 0) {
|
||||
classIndex = classMapping.values[classMappingIndex++];
|
||||
addMethodEntrance(classLoc);
|
||||
} else {
|
||||
methodIndex = methodMapping.values[methodMappingIndex++];
|
||||
classIndex = classMapping.values[classMappingIndex++];
|
||||
addMethodEntrance(classLoc);
|
||||
}
|
||||
}
|
||||
while (methodMappingIndex < methodMapping.lines.length) {
|
||||
GeneratedLocation methodLoc = new GeneratedLocation(methodMapping.lines[methodMappingIndex],
|
||||
methodMapping.columns[methodMappingIndex]);
|
||||
methodIndex = methodMapping.values[methodMappingIndex++];
|
||||
addMethodEntrance(methodLoc);
|
||||
}
|
||||
while (classMappingIndex < classMapping.lines.length) {
|
||||
GeneratedLocation classLoc = new GeneratedLocation(classMapping.lines[classMappingIndex],
|
||||
classMapping.columns[classMappingIndex]);
|
||||
classIndex = classMapping.values[classMappingIndex++];
|
||||
addMethodEntrance(classLoc);
|
||||
}
|
||||
return assemble();
|
||||
}
|
||||
|
||||
private void addMethodEntrance(GeneratedLocation location) {
|
||||
int lineIndex = indexByKey(lineMapping, location);
|
||||
if (lineIndex < 0) {
|
||||
return;
|
||||
}
|
||||
if (lineMapping.values[lineIndex] < 0) {
|
||||
return;
|
||||
}
|
||||
long exactMethod = ((long)classIndex << 32) | methodIndex;
|
||||
Integer exactMethodIndex = exactMethodMap.get(exactMethod);
|
||||
if (exactMethodIndex == null) {
|
||||
return;
|
||||
}
|
||||
int ptr = start[exactMethodIndex];
|
||||
start[exactMethodIndex] = data.size();
|
||||
next.add(ptr);
|
||||
data.add(location.getColumn());
|
||||
ptr = data.size();
|
||||
next.add(ptr);
|
||||
data.add(location.getLine());
|
||||
start[exactMethodIndex] = data.size();
|
||||
}
|
||||
|
||||
private MethodEntrances assemble() {
|
||||
MethodEntrances entrances = new MethodEntrances();
|
||||
entrances.offsets = new int[start.length + 1];
|
||||
entrances.data = new int[data.size()];
|
||||
int index = 0;
|
||||
for (int i = 0; i < start.length; ++i) {
|
||||
int ptr = start[i];
|
||||
while (ptr != -1) {
|
||||
entrances.data[index++] = data.get(ptr);
|
||||
ptr = next.get(ptr);
|
||||
}
|
||||
entrances.offsets[i + 1] = index;
|
||||
}
|
||||
return entrances;
|
||||
}
|
||||
}
|
||||
|
||||
static class FileDescriptionBuilder {
|
||||
FileDescriptionProto[] files;
|
||||
int lastFileIndex = -1;
|
||||
|
@ -452,4 +578,44 @@ public class DebugInformation {
|
|||
int[] files;
|
||||
int[] offsets;
|
||||
}
|
||||
|
||||
static class MethodEntrances {
|
||||
int[] data;
|
||||
int[] offsets;
|
||||
|
||||
public GeneratedLocation[] getEntrances(int index) {
|
||||
if (index < 0 || index > offsets.length - 1) {
|
||||
return new GeneratedLocation[0];
|
||||
}
|
||||
int start = offsets[index];
|
||||
int end = offsets[index + 1];
|
||||
GeneratedLocation[] result = new GeneratedLocation[(end - start) / 2];
|
||||
for (int i = 0; i < result.length; ++i) {
|
||||
result[i] = new GeneratedLocation(data[start + i * 2], data[start + i * 2 + 1]);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
}
|
||||
|
||||
class MethodTree {
|
||||
int[] data;
|
||||
int[] offsets;
|
||||
|
||||
public MethodReference[] getOverridingMethods(int index) {
|
||||
if (index < 0 || index > offsets.length - 1) {
|
||||
return new MethodReference[0];
|
||||
}
|
||||
int start = offsets[index];
|
||||
int end = offsets[index + 1];
|
||||
MethodReference[] references = new MethodReference[end - start];
|
||||
for (int i = 0; i < references.length; ++i) {
|
||||
long item = exactMethods[data[start + i]];
|
||||
int classIndex = (int)(item >> 32);
|
||||
int methodIndex = (int)item;
|
||||
references[i] = new MethodReference(classNames[classIndex],
|
||||
MethodDescriptor.parse(methods[methodIndex]));
|
||||
}
|
||||
return references;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -212,9 +212,7 @@ public class DebugInformationBuilder implements DebugInformationEmitter {
|
|||
}
|
||||
}
|
||||
debugInformation.controlFlowGraphs = cfgs;
|
||||
|
||||
debugInformation.rebuildFileDescriptions();
|
||||
debugInformation.rebuildMaps();
|
||||
debugInformation.rebuild();
|
||||
}
|
||||
return debugInformation;
|
||||
}
|
||||
|
|
|
@ -50,8 +50,7 @@ class DebugInformationReader {
|
|||
debugInfo.variableMappings = readVariableMappings(debugInfo.variableNames.length);
|
||||
debugInfo.classesMetadata = readClassesMetadata(debugInfo.classNames.length);
|
||||
debugInfo.controlFlowGraphs = readCFGs(debugInfo.fileNames.length);
|
||||
debugInfo.rebuildFileDescriptions();
|
||||
debugInfo.rebuildMaps();
|
||||
debugInfo.rebuild();
|
||||
return debugInfo;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue
Block a user