1
0
Fork 0
mirror of https://github.com/eclipse-cdt/cdt synced 2025-07-14 04:25:21 +02:00

Allow to get the lineNumber from a offset of symbol

This commit is contained in:
Alain Magloire 2003-11-20 19:42:02 +00:00
parent a07655f08e
commit f9b97a95f4
5 changed files with 95 additions and 15 deletions

View file

@ -86,6 +86,7 @@ public interface IBinaryParser {
int getEndLine();
IPath getFilename();
int getType();
int getLineNumber(long offset);
}
IBinaryFile getBinary(IPath path) throws IOException;

View file

@ -58,11 +58,15 @@ public class BinaryObject extends BinaryFile implements IBinaryObject {
*/
public ISymbol getSymbol(long addr) {
ISymbol[] syms = getSymbols();
int i = Arrays.binarySearch(syms, new Long(addr));
if (i < 0 || i >= syms.length) {
int insertion = Arrays.binarySearch(syms, new Long(addr));
if (insertion > 0) {
return syms[insertion];
}
if (insertion == -1) {
return null;
}
return syms[i];
insertion = -insertion - 1;
return syms[insertion - 1];
}
/**
@ -256,6 +260,7 @@ public class BinaryObject extends BinaryFile implements IBinaryObject {
if (filename != null && filename.equals("??")) {
filename = null;
}
if (filename != null) {
if (cygpath != null) {
sym.filename = new Path(cygpath.getFileName(filename));

View file

@ -19,6 +19,8 @@ import org.eclipse.core.runtime.IPath;
public class Symbol implements ISymbol {
BinaryObject binary;
Addr2line addr2line;
long timestamp;
public IPath filename;
public int startLine;
@ -79,10 +81,9 @@ public class Symbol implements ISymbol {
public int getLineNumber(long offset) {
int line = -1;
try {
Addr2line addr2line = binary.getAddr2Line();
if (addr2line != null) {
line = addr2line.getLineNumber(addr + offset);
addr2line.dispose();
Addr2line addressToLine = startAddr2Line();
if (addressToLine != null) {
line = addressToLine.getLineNumber(addr + offset);
}
} catch (IOException e) {
}
@ -107,4 +108,37 @@ public class Symbol implements ISymbol {
return (thisVal < anotherVal ? -1 : (thisVal == anotherVal ? 0 : 1));
}
synchronized Addr2line startAddr2Line () {
if (addr2line == null) {
addr2line = binary.getAddr2Line();
if (addr2line != null) {
timestamp = System.currentTimeMillis();
Runnable worker = new Runnable () {
public void run() {
long diff = System.currentTimeMillis() - timestamp;
while (diff < 10000) {
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
break;
}
diff = System.currentTimeMillis() - timestamp;
}
stopAddr2Line();
}
};
new Thread(worker, "Addr2line Reaper").start();
}
} else {
timestamp = System.currentTimeMillis();
}
return addr2line;
}
synchronized void stopAddr2Line() {
if (addr2line != null) {
addr2line.dispose();
}
addr2line = null;
}
}

View file

@ -56,11 +56,15 @@ public class BinaryObject extends BinaryFile implements IBinaryObject {
*/
public ISymbol getSymbol(long addr) {
ISymbol[] syms = getSymbols();
int i = Arrays.binarySearch(syms, new Long(addr));
if (i < 0 || i >= syms.length) {
int insertion = Arrays.binarySearch(syms, new Long(addr));
if (insertion > 0) {
return syms[insertion];
}
if (insertion == -1) {
return null;
}
return syms[i];
insertion = -insertion - 1;
return syms[insertion - 1];
}
/**

View file

@ -19,6 +19,8 @@ import org.eclipse.core.runtime.IPath;
public class Symbol implements ISymbol, Comparable {
BinaryObject binary;
long timestamp;
Addr2line addr2line;
public IPath filename;
public int startLine;
@ -78,12 +80,11 @@ public class Symbol implements ISymbol, Comparable {
public int getLineNumber(long offset) {
int line = -1;
try {
Addr2line addr2line = binary.getAddr2Line();
if (addr2line != null) {
line = addr2line.getLineNumber(addr + offset);
addr2line.dispose();
Addr2line addressToLine = startAddr2Line();
if (addressToLine != null) {
line = addressToLine.getLineNumber(addr + offset);
}
} catch (IOException e) {
} catch (IOException e) {
}
return line;
}
@ -102,4 +103,39 @@ public class Symbol implements ISymbol, Comparable {
}
return (thisVal < anotherVal ? -1 : (thisVal == anotherVal ? 0 : 1));
}
synchronized Addr2line startAddr2Line () {
if (addr2line == null) {
addr2line = binary.getAddr2Line();
if (addr2line != null) {
timestamp = System.currentTimeMillis();
Runnable worker = new Runnable () {
public void run() {
long diff = System.currentTimeMillis() - timestamp;
while (diff < 10000) {
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
break;
}
diff = System.currentTimeMillis() - timestamp;
}
stopAddr2Line();
}
};
new Thread(worker, "Addr2line Reaper").start();
}
} else {
timestamp = System.currentTimeMillis();
}
return addr2line;
}
synchronized void stopAddr2Line() {
if (addr2line != null) {
addr2line.dispose();
}
addr2line = null;
}
}