mirror of
https://github.com/cc65/cc65.git
synced 2025-01-11 11:30:13 +00:00
Fragments and assertions reference LineInfo items instead of having separate
embedded FilePos items. git-svn-id: svn://svn.cc65.org/cc65/trunk@4915 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
parent
06e3152035
commit
6ddf79fc30
@ -6,7 +6,7 @@
|
||||
/* */
|
||||
/* */
|
||||
/* */
|
||||
/* (C) 2003-2009, Ullrich von Bassewitz */
|
||||
/* (C) 2003-2011, Ullrich von Bassewitz */
|
||||
/* Roemerstrasse 52 */
|
||||
/* D-70794 Filderstadt */
|
||||
/* EMail: uz@cc65.org */
|
||||
@ -43,6 +43,7 @@
|
||||
#include "error.h"
|
||||
#include "expr.h"
|
||||
#include "fileio.h"
|
||||
#include "lineinfo.h"
|
||||
#include "objdata.h"
|
||||
#include "spool.h"
|
||||
|
||||
@ -56,7 +57,7 @@
|
||||
|
||||
/* Assertion struct decl */
|
||||
struct Assertion {
|
||||
FilePos Pos; /* File position of assertion */
|
||||
Collection LineInfos; /* File position of assertion */
|
||||
ExprNode* Expr; /* Expression to evaluate */
|
||||
AssertAction Action; /* What to do */
|
||||
unsigned Msg; /* Message to print */
|
||||
@ -74,6 +75,30 @@ static Collection Assertions = STATIC_COLLECTION_INITIALIZER;
|
||||
|
||||
|
||||
|
||||
static const char* GetAssertionSourceName (const Assertion* A)
|
||||
/* Return the name of the source file for this assertion */
|
||||
{
|
||||
/* Each assertion has the basic info in line info #0 */
|
||||
const LineInfo* LI = CollConstAt (&A->LineInfos, 0);
|
||||
|
||||
/* Return the source file name */
|
||||
return GetSourceFileName (A->Obj, LI->Pos.Name);
|
||||
}
|
||||
|
||||
|
||||
|
||||
static unsigned long GetAssertionSourceLine (const Assertion* A)
|
||||
/* Return the source file line for this fragment */
|
||||
{
|
||||
/* Each assertion has the basic info in line info #0 */
|
||||
const LineInfo* LI = CollConstAt (&A->LineInfos, 0);
|
||||
|
||||
/* Return the source file line */
|
||||
return LI->Pos.Line;
|
||||
}
|
||||
|
||||
|
||||
|
||||
Assertion* ReadAssertion (FILE* F, struct ObjData* O)
|
||||
/* Read an assertion from the given file */
|
||||
{
|
||||
@ -84,7 +109,7 @@ Assertion* ReadAssertion (FILE* F, struct ObjData* O)
|
||||
A->Expr = ReadExpr (F, O);
|
||||
A->Action = (AssertAction) ReadVar (F);
|
||||
A->Msg = MakeGlobalStringId (O, ReadVar (F));
|
||||
ReadFilePos (F, &A->Pos);
|
||||
ReadLineInfoList (F, O, &A->LineInfos);
|
||||
|
||||
/* Set remaining fields */
|
||||
A->Obj = O;
|
||||
@ -106,6 +131,9 @@ void CheckAssertions (void)
|
||||
/* Walk over all assertions */
|
||||
for (I = 0; I < CollCount (&Assertions); ++I) {
|
||||
|
||||
const char* Module;
|
||||
unsigned long Line;
|
||||
|
||||
/* Get the assertion */
|
||||
Assertion* A = CollAtUnchecked (&Assertions, I);
|
||||
|
||||
@ -114,32 +142,35 @@ void CheckAssertions (void)
|
||||
continue;
|
||||
}
|
||||
|
||||
/* Retrieve module name and line number */
|
||||
Module = GetAssertionSourceName (A);
|
||||
Line = GetAssertionSourceLine (A);
|
||||
|
||||
/* If the expression is not constant, we're not able to handle it */
|
||||
if (!IsConstExpr (A->Expr)) {
|
||||
Warning ("Cannot evaluate assertion in module `%s', line %lu",
|
||||
GetSourceFileName (A->Obj, A->Pos.Name), A->Pos.Line);
|
||||
Module, Line);
|
||||
} else if (GetExprVal (A->Expr) == 0) {
|
||||
|
||||
/* Assertion failed */
|
||||
const char* Module = GetSourceFileName (A->Obj, A->Pos.Name);
|
||||
const char* Message = GetString (A->Msg);
|
||||
|
||||
switch (A->Action) {
|
||||
|
||||
case ASSERT_ACT_WARN:
|
||||
case ASSERT_ACT_LDWARN:
|
||||
Warning ("%s(%lu): %s", Module, A->Pos.Line, Message);
|
||||
Warning ("%s(%lu): %s", Module, Line, Message);
|
||||
break;
|
||||
|
||||
case ASSERT_ACT_ERROR:
|
||||
case ASSERT_ACT_LDERROR:
|
||||
Error ("%s(%lu): %s", Module, A->Pos.Line, Message);
|
||||
Error ("%s(%lu): %s", Module, Line, Message);
|
||||
break;
|
||||
|
||||
default:
|
||||
Internal ("Invalid assertion action (%u) in module `%s', "
|
||||
"line %lu (file corrupt?)",
|
||||
A->Action, Module, A->Pos.Line);
|
||||
A->Action, Module, Line);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -98,15 +98,20 @@ Fragment* NewFragment (unsigned char Type, unsigned Size, Section* S)
|
||||
|
||||
|
||||
|
||||
void AddLineInfo (Fragment* F, LineInfo* LI)
|
||||
/* Add the line info to the given fragment */
|
||||
void FragResolveLineInfos (Fragment* F)
|
||||
/* Resolve the back pointers for the line infos */
|
||||
{
|
||||
/* Point from the fragment to the line info ... */
|
||||
CollAppend (&F->LineInfos, LI);
|
||||
unsigned I;
|
||||
|
||||
/* ... and back from the line info to the fragment */
|
||||
/* Walk over all line infos for this fragment */
|
||||
for (I = 0; I < CollCount (&F->LineInfos); ++I) {
|
||||
/* Get a pointer to this line info */
|
||||
LineInfo* LI = CollAtUnchecked (&F->LineInfos, I);
|
||||
|
||||
/* Add the back pointer to the line info */
|
||||
CollAppend (&LI->Fragments, F);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
@ -86,8 +86,8 @@ struct Fragment {
|
||||
Fragment* NewFragment (unsigned char Type, unsigned Size, struct Section* S);
|
||||
/* Create a new fragment and insert it into the section S */
|
||||
|
||||
void AddLineInfo (Fragment* F, struct LineInfo* LI);
|
||||
/* Add the line info to the given fragment */
|
||||
void FragResolveLineInfos (Fragment* F);
|
||||
/* Resolve the back pointers for the line infos */
|
||||
|
||||
const char* GetFragmentSourceName (const Fragment* F);
|
||||
/* Return the name of the source file for this fragment */
|
||||
|
@ -6,7 +6,7 @@
|
||||
/* */
|
||||
/* */
|
||||
/* */
|
||||
/* (C) 2001-2010, Ullrich von Bassewitz */
|
||||
/* (C) 2001-2011, Ullrich von Bassewitz */
|
||||
/* Roemerstrasse 52 */
|
||||
/* D-70794 Filderstadt */
|
||||
/* EMail: uz@cc65.org */
|
||||
@ -69,7 +69,7 @@ static CodeRange* NewCodeRange (Segment* Seg, unsigned long Offs, unsigned long
|
||||
|
||||
|
||||
|
||||
LineInfo* NewLineInfo (ObjData* O, const FilePos* Pos)
|
||||
static LineInfo* NewLineInfo (ObjData* O, const FilePos* Pos)
|
||||
/* Create and return a new LineInfo struct */
|
||||
{
|
||||
/* Allocate memory */
|
||||
@ -103,6 +103,36 @@ LineInfo* ReadLineInfo (FILE* F, ObjData* O)
|
||||
|
||||
|
||||
|
||||
void ReadLineInfoList (FILE* F, ObjData* O, Collection* LineInfos)
|
||||
/* Read a list of line infos stored as a list of indices in the object file,
|
||||
* make real line infos from them and place them into the passed collection.
|
||||
*/
|
||||
{
|
||||
/* Read the number of line info indices that follow */
|
||||
unsigned LineInfoCount = ReadVar (F);
|
||||
|
||||
/* Read the line infos and resolve them */
|
||||
while (LineInfoCount--) {
|
||||
|
||||
/* Read an index */
|
||||
unsigned LineInfoIndex = ReadVar (F);
|
||||
|
||||
/* The line info index was written by the assembler and must
|
||||
* therefore be part of the line infos read from the object file.
|
||||
*/
|
||||
if (LineInfoIndex >= CollCount (&O->LineInfos)) {
|
||||
Internal ("Invalid line info index %u in module `%s'",
|
||||
LineInfoIndex,
|
||||
GetObjFileName (O));
|
||||
}
|
||||
|
||||
/* Add the line info to the collection */
|
||||
CollAppend (LineInfos, CollAt (&O->LineInfos, LineInfoIndex));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
static void AddCodeRange (LineInfo* LI, Segment* Seg, unsigned long Offs,
|
||||
unsigned long Size)
|
||||
/* Add a range of code to this line */
|
||||
|
@ -6,7 +6,7 @@
|
||||
/* */
|
||||
/* */
|
||||
/* */
|
||||
/* (C) 2001-2010, Ullrich von Bassewitz */
|
||||
/* (C) 2001-2011, Ullrich von Bassewitz */
|
||||
/* Roemerstrasse 52 */
|
||||
/* D-70794 Filderstadt */
|
||||
/* EMail: uz@cc65.org */
|
||||
@ -88,12 +88,14 @@ struct LineInfo {
|
||||
|
||||
|
||||
|
||||
LineInfo* NewLineInfo (struct ObjData* O, const FilePos* Pos);
|
||||
/* Create and return a new LineInfo struct */
|
||||
|
||||
LineInfo* ReadLineInfo (FILE* F, struct ObjData* O);
|
||||
/* Read a line info from a file and return it */
|
||||
|
||||
void ReadLineInfoList (FILE* F, struct ObjData* O, Collection* LineInfos);
|
||||
/* Read a list of line infos stored as a list of indices in the object file,
|
||||
* make real line infos from them and place them into the passed collection.
|
||||
*/
|
||||
|
||||
void RelocLineInfo (struct Segment* S);
|
||||
/* Relocate the line info for a segment. */
|
||||
|
||||
|
@ -6,7 +6,7 @@
|
||||
/* */
|
||||
/* */
|
||||
/* */
|
||||
/* (C) 1998-2010, Ullrich von Bassewitz */
|
||||
/* (C) 1998-2011, Ullrich von Bassewitz */
|
||||
/* Roemerstrasse 52 */
|
||||
/* D-70794 Filderstadt */
|
||||
/* EMail: uz@cc65.org */
|
||||
@ -78,23 +78,15 @@ ObjData* NewObjData (void)
|
||||
O->MTime = 0;
|
||||
O->Start = 0;
|
||||
O->Flags = 0;
|
||||
O->FileCount = 0;
|
||||
O->Files = EmptyCollection;
|
||||
O->SectionCount = 0;
|
||||
O->Sections = EmptyCollection;
|
||||
O->ExportCount = 0;
|
||||
O->Exports = EmptyCollection;
|
||||
O->ImportCount = 0;
|
||||
O->Imports = EmptyCollection;
|
||||
O->DbgSymCount = 0;
|
||||
O->DbgSyms = EmptyCollection;
|
||||
O->LineInfoCount = 0;
|
||||
O->LineInfos = EmptyCollection;
|
||||
O->StringCount = 0;
|
||||
O->Strings = 0;
|
||||
O->AssertionCount = 0;
|
||||
O->Assertions = EmptyCollection;
|
||||
O->ScopeCount = 0;
|
||||
O->Scopes = EmptyCollection;
|
||||
|
||||
/* Return the new entry */
|
||||
|
@ -6,7 +6,7 @@
|
||||
/* */
|
||||
/* */
|
||||
/* */
|
||||
/* (C) 1998-2010, Ullrich von Bassewitz */
|
||||
/* (C) 1998-2011, Ullrich von Bassewitz */
|
||||
/* Roemerstrasse 52 */
|
||||
/* D-70794 Filderstadt */
|
||||
/* EMail: uz@cc65.org */
|
||||
@ -64,23 +64,15 @@ struct ObjData {
|
||||
ObjHeader Header; /* Header of file */
|
||||
unsigned long Start; /* Start offset of data in library */
|
||||
unsigned Flags;
|
||||
unsigned FileCount; /* Input file count */
|
||||
Collection Files; /* List of input files */
|
||||
unsigned SectionCount; /* Count of sections in this object */
|
||||
Collection Sections; /* List of all sections */
|
||||
unsigned ExportCount; /* Count of exports */
|
||||
Collection Exports; /* List of all exports */
|
||||
unsigned ImportCount; /* Count of imports */
|
||||
Collection Imports; /* List of all imports */
|
||||
unsigned DbgSymCount; /* Count of debug symbols */
|
||||
Collection DbgSyms; /* List of debug symbols */
|
||||
unsigned LineInfoCount; /* Count of additional line infos */
|
||||
Collection LineInfos; /* List of additional line infos */
|
||||
Collection LineInfos; /* List of line infos */
|
||||
unsigned StringCount; /* Count of strings */
|
||||
unsigned* Strings; /* List of global string indices */
|
||||
unsigned AssertionCount; /* Count of module assertions */
|
||||
Collection Assertions; /* List of module assertions */
|
||||
unsigned ScopeCount; /* Count of scopes */
|
||||
Collection Scopes; /* List of scopes */
|
||||
};
|
||||
|
||||
|
@ -6,7 +6,7 @@
|
||||
/* */
|
||||
/* */
|
||||
/* */
|
||||
/* (C) 1998-2010, Ullrich von Bassewitz */
|
||||
/* (C) 1998-2011, Ullrich von Bassewitz */
|
||||
/* Roemerstrasse 52 */
|
||||
/* D-70794 Filderstadt */
|
||||
/* EMail: uz@cc65.org */
|
||||
@ -114,14 +114,15 @@ void ObjReadFiles (FILE* F, unsigned long Pos, ObjData* O)
|
||||
/* Read the files list from a file at the given position */
|
||||
{
|
||||
unsigned I;
|
||||
unsigned FileCount;
|
||||
|
||||
/* Seek to the correct position */
|
||||
FileSetPos (F, Pos);
|
||||
|
||||
/* Read the data */
|
||||
O->FileCount = ReadVar (F);
|
||||
CollGrow (&O->Files, O->FileCount);
|
||||
for (I = 0; I < O->FileCount; ++I) {
|
||||
FileCount = ReadVar (F);
|
||||
CollGrow (&O->Files, FileCount);
|
||||
for (I = 0; I < FileCount; ++I) {
|
||||
CollAppend (&O->Files, ReadFileInfo (F, O));
|
||||
}
|
||||
}
|
||||
@ -132,14 +133,15 @@ void ObjReadSections (FILE* F, unsigned long Pos, ObjData* O)
|
||||
/* Read the section data from a file at the given position */
|
||||
{
|
||||
unsigned I;
|
||||
unsigned SectionCount;
|
||||
|
||||
/* Seek to the correct position */
|
||||
FileSetPos (F, Pos);
|
||||
|
||||
/* Read the data */
|
||||
O->SectionCount = ReadVar (F);
|
||||
CollGrow (&O->Sections, O->SectionCount);
|
||||
for (I = 0; I < O->SectionCount; ++I) {
|
||||
SectionCount = ReadVar (F);
|
||||
CollGrow (&O->Sections, SectionCount);
|
||||
for (I = 0; I < SectionCount; ++I) {
|
||||
CollAppend (&O->Sections, ReadSection (F, O));
|
||||
}
|
||||
}
|
||||
@ -150,14 +152,15 @@ void ObjReadImports (FILE* F, unsigned long Pos, ObjData* O)
|
||||
/* Read the imports from a file at the given position */
|
||||
{
|
||||
unsigned I;
|
||||
unsigned ImportCount;
|
||||
|
||||
/* Seek to the correct position */
|
||||
FileSetPos (F, Pos);
|
||||
|
||||
/* Read the data */
|
||||
O->ImportCount = ReadVar (F);
|
||||
CollGrow (&O->Imports, O->ImportCount);
|
||||
for (I = 0; I < O->ImportCount; ++I) {
|
||||
ImportCount = ReadVar (F);
|
||||
CollGrow (&O->Imports, ImportCount);
|
||||
for (I = 0; I < ImportCount; ++I) {
|
||||
CollAppend (&O->Imports, ReadImport (F, O));
|
||||
}
|
||||
}
|
||||
@ -168,14 +171,15 @@ void ObjReadExports (FILE* F, unsigned long Pos, ObjData* O)
|
||||
/* Read the exports from a file at the given position */
|
||||
{
|
||||
unsigned I;
|
||||
unsigned ExportCount;
|
||||
|
||||
/* Seek to the correct position */
|
||||
FileSetPos (F, Pos);
|
||||
|
||||
/* Read the data */
|
||||
O->ExportCount = ReadVar (F);
|
||||
CollGrow (&O->Exports, O->ExportCount);
|
||||
for (I = 0; I < O->ExportCount; ++I) {
|
||||
ExportCount = ReadVar (F);
|
||||
CollGrow (&O->Exports, ExportCount);
|
||||
for (I = 0; I < ExportCount; ++I) {
|
||||
CollAppend (&O->Exports, ReadExport (F, O));
|
||||
}
|
||||
}
|
||||
@ -186,14 +190,15 @@ void ObjReadDbgSyms (FILE* F, unsigned long Pos, ObjData* O)
|
||||
/* Read the debug symbols from a file at the given position */
|
||||
{
|
||||
unsigned I;
|
||||
unsigned DbgSymCount;
|
||||
|
||||
/* Seek to the correct position */
|
||||
FileSetPos (F, Pos);
|
||||
|
||||
/* Read the data */
|
||||
O->DbgSymCount = ReadVar (F);
|
||||
CollGrow (&O->DbgSyms, O->DbgSymCount);
|
||||
for (I = 0; I < O->DbgSymCount; ++I) {
|
||||
DbgSymCount = ReadVar (F);
|
||||
CollGrow (&O->DbgSyms, DbgSymCount);
|
||||
for (I = 0; I < DbgSymCount; ++I) {
|
||||
CollAppend (&O->DbgSyms, ReadDbgSym (F, O));
|
||||
}
|
||||
}
|
||||
@ -204,14 +209,15 @@ void ObjReadLineInfos (FILE* F, unsigned long Pos, ObjData* O)
|
||||
/* Read the line infos from a file at the given position */
|
||||
{
|
||||
unsigned I;
|
||||
unsigned LineInfoCount;
|
||||
|
||||
/* Seek to the correct position */
|
||||
FileSetPos (F, Pos);
|
||||
|
||||
/* Read the data */
|
||||
O->LineInfoCount = ReadVar (F);
|
||||
CollGrow (&O->LineInfos, O->LineInfoCount);
|
||||
for (I = 0; I < O->LineInfoCount; ++I) {
|
||||
LineInfoCount = ReadVar (F);
|
||||
CollGrow (&O->LineInfos, LineInfoCount);
|
||||
for (I = 0; I < LineInfoCount; ++I) {
|
||||
CollAppend (&O->LineInfos, ReadLineInfo (F, O));
|
||||
}
|
||||
}
|
||||
@ -240,14 +246,15 @@ void ObjReadAssertions (FILE* F, unsigned long Pos, ObjData* O)
|
||||
/* Read the assertions from a file at the given offset */
|
||||
{
|
||||
unsigned I;
|
||||
unsigned AssertionCount;
|
||||
|
||||
/* Seek to the correct position */
|
||||
FileSetPos (F, Pos);
|
||||
|
||||
/* Read the data */
|
||||
O->AssertionCount = ReadVar (F);
|
||||
CollGrow (&O->Assertions, O->AssertionCount);
|
||||
for (I = 0; I < O->AssertionCount; ++I) {
|
||||
AssertionCount = ReadVar (F);
|
||||
CollGrow (&O->Assertions, AssertionCount);
|
||||
for (I = 0; I < AssertionCount; ++I) {
|
||||
CollAppend (&O->Assertions, ReadAssertion (F, O));
|
||||
}
|
||||
}
|
||||
@ -258,14 +265,15 @@ void ObjReadScopes (FILE* F, unsigned long Pos, ObjData* O)
|
||||
/* Read the scope table from a file at the given offset */
|
||||
{
|
||||
unsigned I;
|
||||
unsigned ScopeCount;
|
||||
|
||||
/* Seek to the correct position */
|
||||
FileSetPos (F, Pos);
|
||||
|
||||
/* Read the data */
|
||||
O->ScopeCount = ReadVar (F);
|
||||
CollGrow (&O->Scopes, O->ScopeCount);
|
||||
for (I = 0; I < O->ScopeCount; ++I) {
|
||||
ScopeCount = ReadVar (F);
|
||||
CollGrow (&O->Scopes, ScopeCount);
|
||||
for (I = 0; I < ScopeCount; ++I) {
|
||||
CollAppend (&O->Scopes, 0); /* ReadScope (F, O); ### not implemented */
|
||||
}
|
||||
}
|
||||
|
@ -6,7 +6,7 @@
|
||||
/* */
|
||||
/* */
|
||||
/* */
|
||||
/* (C) 1998-2010, Ullrich von Bassewitz */
|
||||
/* (C) 1998-2011, Ullrich von Bassewitz */
|
||||
/* Roemerstrasse 52 */
|
||||
/* D-70794 Filderstadt */
|
||||
/* EMail: uz@cc65.org */
|
||||
@ -211,7 +211,6 @@ Section* ReadSection (FILE* F, ObjData* O)
|
||||
unsigned FragCount;
|
||||
Segment* S;
|
||||
Section* Sec;
|
||||
LineInfo* LI;
|
||||
|
||||
/* Read the segment data */
|
||||
(void) Read32 (F); /* File size of data */
|
||||
@ -240,12 +239,9 @@ Section* ReadSection (FILE* F, ObjData* O)
|
||||
}
|
||||
|
||||
/* Start reading fragments from the file and insert them into the section . */
|
||||
LI = 0;
|
||||
while (FragCount--) {
|
||||
|
||||
Fragment* Frag;
|
||||
FilePos Pos;
|
||||
unsigned LineInfoIndex;
|
||||
|
||||
/* Read the fragment type */
|
||||
unsigned char Type = Read8 (F);
|
||||
@ -280,43 +276,11 @@ Section* ReadSection (FILE* F, ObjData* O)
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Read the file position of the fragment */
|
||||
ReadFilePos (F, &Pos);
|
||||
/* Read the line infos into the list of the fragment */
|
||||
ReadLineInfoList (F, O, &Frag->LineInfos);
|
||||
|
||||
/* Generate a LineInfo for this fragment. First check if this fragment
|
||||
* was generated by the same line than that before. If not, generate
|
||||
* a new LineInfo.
|
||||
*/
|
||||
if (LI == 0 || LI->Pos.Line != Pos.Line || LI->Pos.Col != Pos.Col ||
|
||||
LI->Pos.Name != Pos.Name) {
|
||||
/* We don't have a previous line info or this one is different */
|
||||
LI = NewLineInfo (O, &Pos);
|
||||
CollAppend (&O->LineInfos, LI);
|
||||
}
|
||||
AddLineInfo (Frag, LI);
|
||||
|
||||
/* Read additional line info and resolve it */
|
||||
LineInfoIndex = ReadVar (F);
|
||||
if (LineInfoIndex) {
|
||||
--LineInfoIndex;
|
||||
/* The line info index was written by the assembler and must
|
||||
* therefore be part of the line infos read from the object file.
|
||||
* To make sure this is true, don't compare against the count
|
||||
* of line infos in the collection (which grows) but against the
|
||||
* count initialized when reading from the file.
|
||||
*/
|
||||
if (LineInfoIndex >= O->LineInfoCount) {
|
||||
Internal ("In module `%s', file `%s', line %lu: Invalid line "
|
||||
"info with index %u (max count %u)",
|
||||
GetObjFileName (O),
|
||||
GetFragmentSourceName (Frag),
|
||||
GetFragmentSourceLine (Frag),
|
||||
LineInfoIndex,
|
||||
O->LineInfoCount);
|
||||
}
|
||||
/* Add line info to the fragment */
|
||||
AddLineInfo (Frag, CollAt (&O->LineInfos, LineInfoIndex));
|
||||
}
|
||||
/* Resolve the back pointers */
|
||||
FragResolveLineInfos (Frag);
|
||||
|
||||
/* Remember the module we had this fragment from */
|
||||
Frag->Obj = O;
|
||||
|
Loading…
x
Reference in New Issue
Block a user