1
0
mirror of https://github.com/cc65/cc65.git synced 2024-12-31 11:32:00 +00:00

Use CollTransfer where possible.

git-svn-id: svn://svn.cc65.org/cc65/trunk@5225 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
uz 2011-08-19 11:06:52 +00:00
parent 189a9bfb38
commit 88774521a3
3 changed files with 16 additions and 27 deletions

View File

@ -271,17 +271,13 @@ void DoneLineInfo (void)
void EndLine (LineInfo* LI)
/* End a line that is tracked by the given LineInfo structure */
{
unsigned I;
/* Close the spans for the line */
CloseSpans (&LI->OpenSpans);
/* Move the spans to the list of all spans for this line, then clear the
* list of open spans.
*/
for (I = 0; I < CollCount (&LI->OpenSpans); ++I) {
CollAppend (&LI->Spans, CollAtUnchecked (&LI->OpenSpans, I));
}
CollTransfer (&LI->Spans, &LI->OpenSpans);
CollDeleteAll (&LI->OpenSpans);
/* Line info is no longer active - remove it from the list of current
@ -376,23 +372,13 @@ void GetFullLineInfo (Collection* LineInfos)
{
unsigned I;
/* If the collection is currently empty, grow it as necessary */
if (CollCount (LineInfos) == 0) {
CollGrow (LineInfos, CollCount (&CurLineInfo));
}
/* Copy all valid line infos to the collection */
/* Bum the reference counter for all active line infos */
for (I = 0; I < CollCount (&CurLineInfo); ++I) {
/* Get the line info from the slot */
LineInfo* LI = CollAt (&CurLineInfo, I);
/* Bump the reference counter */
++LI->RefCount;
/* Return it to the caller */
CollAppend (LineInfos, LI);
++((LineInfo*)CollAt (&CurLineInfo, I))->RefCount;
}
/* Copy all line infos over */
CollTransfer (LineInfos, &CurLineInfo);
}

View File

@ -419,6 +419,9 @@ void SymExport (SymEntry* S, unsigned char AddrSize, unsigned Flags)
/* Set the symbol data */
S->Flags |= (SF_EXPORT | SF_REFERENCED | Flags);
/* Remember line info for this reference */
CollAppend (&S->RefLines, GetAsmLineInfo ());
}

View File

@ -503,11 +503,9 @@ static void SymCheckUndefined (SymEntry* S)
}
}
if (S->Flags & SF_REFERENCED) {
unsigned I;
/* Mark as referenced and move the line info */
Sym->Flags |= SF_REFERENCED;
for (I = 0; I < CollCount (&S->RefLines); ++I) {
CollAppend (&Sym->RefLines, CollAtUnchecked (&S->RefLines, I));
}
CollTransfer (&Sym->RefLines, &S->RefLines);
CollDeleteAll (&S->RefLines);
}
@ -564,9 +562,11 @@ void SymCheck (void)
*/
if (S->Flags & SF_GLOBAL) {
if (S->Flags & SF_DEFINED) {
SymExportFromGlobal (S);
} else {
SymImportFromGlobal (S);
printf ("ExportFromGlobal: %s\n", SB_GetConstBuf (GetSymName (S)));
SymExportFromGlobal (S);
} else {
printf ("ImportFromGlobal: %s\n", SB_GetConstBuf (GetSymName (S)));
SymImportFromGlobal (S);
}
}