1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-16 13:31:16 +00:00

Allow to display symbols and line infos for symbols.

git-svn-id: svn://svn.cc65.org/cc65/trunk@5219 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
uz 2011-08-18 20:34:31 +00:00
parent 3a079ff332
commit 1527d26e91
2 changed files with 221 additions and 3 deletions

View File

@ -4534,7 +4534,7 @@ static void ProcessSymInfo (InputData* D)
}
/* Resolve the line infos for the symbol definition */
for (J = 0; I < CollCount (&S->DefLineInfoList); ++J) {
for (J = 0; J < CollCount (&S->DefLineInfoList); ++J) {
/* Get the id of this line info */
unsigned LineId = CollIdAt (&S->DefLineInfoList, J);
@ -4554,7 +4554,7 @@ static void ProcessSymInfo (InputData* D)
}
/* Resolve the line infos for symbol references */
for (J = 0; I < CollCount (&S->RefLineInfoList); ++J) {
for (J = 0; J < CollCount (&S->RefLineInfoList); ++J) {
/* Get the id of this line info */
unsigned LineId = CollIdAt (&S->RefLineInfoList, J);

View File

@ -93,6 +93,15 @@ static void CmdShowSegment (Collection* Args);
static void CmdShowSource (Collection* Args);
/* Show source files from the debug info file */
static void CmdShowSymbol (Collection* Args);
/* Show symbols */
static void CmdShowSymDef (Collection* Args);
/* Show lines from for a symbol definition */
static void CmdShowSymRef (Collection* Args);
/* Show lines from for symbol references */
static void CmdUnload (Collection* Args attribute ((unused)));
/* Unload a debug info file */
@ -124,6 +133,7 @@ enum {
SegmentId,
SourceId,
SpanId,
SymbolId
};
/* Structure that contains a command description */
@ -207,6 +217,21 @@ static const CmdEntry ShowCmds[] = {
"Show sources. May be followed by one or more source file ids.",
-1,
CmdShowSource
}, {
"symbol",
"Show symbols. May be followed by one or more symbol or scope ids.",
-2,
CmdShowSymbol
}, {
"symdef",
"Show where a symbol was defined. May be followed by one or more symbol ids.",
-2,
CmdShowSymDef
}, {
"symref",
"Show where a symbol was referenced. May be followed by one or more symbol ids.",
-2,
CmdShowSymRef
},
};
@ -374,6 +399,7 @@ static unsigned FindIdType (const char* TypeName)
{ "m", ModuleId },
{ "mod", ModuleId },
{ "module", ModuleId },
{ "s", SymbolId },
{ "sc", ScopeId },
{ "scope", ScopeId },
{ "seg", SegmentId },
@ -382,6 +408,8 @@ static unsigned FindIdType (const char* TypeName)
{ "src", SourceId },
{ "sp", SpanId },
{ "span", SpanId },
{ "sym", SymbolId },
{ "symbol", SymbolId },
};
unsigned I;
@ -653,7 +681,7 @@ static void PrintSources (const cc65_sourceinfo* S)
for (I = 0, D = S->data; I < S->count; ++I, ++D) {
PrintId (D->source_id, 8);
Print ("%-30s", D->source_name);
Print ("%7lu ", D->source_size);
PrintNumber (D->source_size, 7, 9);
PrintTime (D->source_mtime, 0);
NewLine ();
}
@ -661,6 +689,39 @@ static void PrintSources (const cc65_sourceinfo* S)
static void PrintSymbolHeader (void)
/* Output a header for a list of symbols */
{
/* Header */
PrintLine (" id name type size value export seg scope parent");
PrintSeparator ();
}
static void PrintSymbols (const cc65_symbolinfo* S)
/* Output a list of symbols */
{
unsigned I;
const cc65_symboldata* D;
/* Segments */
for (I = 0, D = S->data; I < S->count; ++I, ++D) {
PrintId (D->symbol_id, 6);
Print ("%-20s", D->symbol_name);
PrintNumber (D->symbol_type, 4, 6);
PrintNumber (D->symbol_size, 4, 6);
PrintNumber (D->symbol_value, 5, 7);
PrintId (D->export_id, 7);
PrintId (D->segment_id, 6);
PrintId (D->scope_id, 6);
PrintId (D->parent_id, 0);
NewLine ();
}
}
/*****************************************************************************/
/* Debug file handling */
/*****************************************************************************/
@ -839,12 +900,25 @@ static void CmdShowLine (Collection* Args)
if (GetId (CollConstAt (Args, I), &Id, &IdType)) {
/* Fetch list depending on type */
switch (IdType) {
case LineId:
L = cc65_line_byid (Info, Id);
break;
case SourceId:
L = cc65_line_bysource (Info, Id);
break;
case SymbolId:
/* ### not very clean */
L = cc65_line_bysymdef (Info, Id);
if (L) {
PrintLines (L);
cc65_free_lineinfo (Info, L);
}
L = cc65_line_bysymref (Info, Id);
break;
default:
L = 0;
PrintLine ("Invalid id type");
@ -1169,7 +1243,151 @@ static void CmdShowSource (Collection* Args)
}
}
}
}
static void CmdShowSymbol (Collection* Args)
/* Show symbols */
{
const cc65_symbolinfo* S;
unsigned I;
/* Be sure a file is loaded */
if (!FileIsLoaded ()) {
return;
}
/* Output the header */
PrintSymbolHeader ();
for (I = 0; I < CollCount (Args); ++I) {
/* Parse the argument */
unsigned Id;
unsigned IdType = SymbolId;
if (GetId (CollConstAt (Args, I), &Id, &IdType)) {
/* Fetch list depending on type */
switch (IdType) {
case ScopeId:
S = cc65_symbol_byscope (Info, Id);
break;
case SymbolId:
S = cc65_symbol_byid (Info, Id);
break;
default:
S = 0;
PrintLine ("Invalid id type");
break;
}
} else {
/* Ignore the invalid id */
S = 0;
}
/* Output the list */
if (S) {
PrintSymbols (S);
cc65_free_symbolinfo (Info, S);
}
}
}
static void CmdShowSymDef (Collection* Args)
/* Show lines from for a symbol definition */
{
const cc65_lineinfo* L;
unsigned I;
/* Be sure a file is loaded */
if (!FileIsLoaded ()) {
return;
}
/* Output the header */
PrintLineHeader ();
for (I = 0; I < CollCount (Args); ++I) {
/* Parse the argument */
unsigned Id;
unsigned IdType = SymbolId;
if (GetId (CollConstAt (Args, I), &Id, &IdType)) {
/* Fetch list depending on type */
switch (IdType) {
case SymbolId:
L = cc65_line_bysymdef (Info, Id);
break;
default:
L = 0;
PrintLine ("Invalid id type");
break;
}
} else {
/* Ignore the invalid id */
L = 0;
}
/* Output the list */
if (L) {
PrintLines (L);
cc65_free_lineinfo (Info, L);
}
}
}
static void CmdShowSymRef (Collection* Args)
/* Show lines from for symbol references */
{
const cc65_lineinfo* L;
unsigned I;
/* Be sure a file is loaded */
if (!FileIsLoaded ()) {
return;
}
/* Output the header */
PrintLineHeader ();
for (I = 0; I < CollCount (Args); ++I) {
/* Parse the argument */
unsigned Id;
unsigned IdType = SymbolId;
if (GetId (CollConstAt (Args, I), &Id, &IdType)) {
/* Fetch list depending on type */
switch (IdType) {
case SymbolId:
L = cc65_line_bysymref (Info, Id);
break;
default:
L = 0;
PrintLine ("Invalid id type");
break;
}
} else {
/* Ignore the invalid id */
L = 0;
}
/* Output the list */
if (L) {
PrintLines (L);
cc65_free_lineinfo (Info, L);
}
}
}