mirror of
https://github.com/xomboverlord/ldc.git
synced 2026-02-26 00:23:14 +01:00
Backed out changeset [369996c08420].
The argument and order dependent numbering of static ctors/dtors generally doesn't matter because other modules shouldn't reference their symbols. The next changeset will fix a LDC bug that caused such references within ModuleInfo.
This commit is contained in:
10
dmd/func.c
10
dmd/func.c
@@ -2420,7 +2420,7 @@ void DtorDeclaration::toCBuffer(OutBuffer *buf, HdrGenState *hgs)
|
||||
|
||||
StaticCtorDeclaration::StaticCtorDeclaration(Loc loc, Loc endloc)
|
||||
: FuncDeclaration(loc, endloc,
|
||||
Lexer::idPool("_staticCtor"), STCstatic, NULL)
|
||||
Identifier::generateId("_staticCtor"), STCstatic, NULL)
|
||||
{
|
||||
}
|
||||
|
||||
@@ -2438,9 +2438,6 @@ void StaticCtorDeclaration::semantic(Scope *sc)
|
||||
{
|
||||
//printf("StaticCtorDeclaration::semantic()\n");
|
||||
|
||||
// get ourselves a scope-unique id
|
||||
ident = sc->module->generateId(ident);
|
||||
|
||||
type = new TypeFunction(NULL, Type::tvoid, FALSE, LINKd);
|
||||
|
||||
/* If the static ctor appears within a template instantiation,
|
||||
@@ -2524,7 +2521,7 @@ void StaticCtorDeclaration::toCBuffer(OutBuffer *buf, HdrGenState *hgs)
|
||||
|
||||
StaticDtorDeclaration::StaticDtorDeclaration(Loc loc, Loc endloc)
|
||||
: FuncDeclaration(loc, endloc,
|
||||
Lexer::idPool("_staticDtor"), STCstatic, NULL)
|
||||
Identifier::generateId("_staticDtor"), STCstatic, NULL)
|
||||
{
|
||||
vgate = NULL;
|
||||
}
|
||||
@@ -2541,9 +2538,6 @@ Dsymbol *StaticDtorDeclaration::syntaxCopy(Dsymbol *s)
|
||||
|
||||
void StaticDtorDeclaration::semantic(Scope *sc)
|
||||
{
|
||||
// get ourselves a scope-unique id
|
||||
ident = sc->module->generateId(ident);
|
||||
|
||||
ClassDeclaration *cd;
|
||||
Type *tret;
|
||||
|
||||
|
||||
@@ -130,7 +130,6 @@ Module::Module(char *filename, Identifier *ident, int doDocComment, int doHdrGen
|
||||
llvmForceLogging = false;
|
||||
this->doDocComment = doDocComment;
|
||||
this->doHdrGen = doHdrGen;
|
||||
uniqueId = 0;
|
||||
}
|
||||
|
||||
File* Module::buildFilePath(char* forcename, char* path, char* ext)
|
||||
@@ -1008,8 +1007,3 @@ DsymbolTable *Package::resolve(Array *packages, Dsymbol **pparent, Package **ppk
|
||||
}
|
||||
return dst;
|
||||
}
|
||||
|
||||
Identifier* Module::generateId(Identifier* id)
|
||||
{
|
||||
return Identifier::generateId(id->string, uniqueId++);
|
||||
}
|
||||
|
||||
@@ -179,10 +179,6 @@ struct Module : Package
|
||||
|
||||
// array ops emitted in this module already
|
||||
StringTable arrayfuncs;
|
||||
|
||||
// for numbering staticCtors etc.
|
||||
int uniqueId;
|
||||
Identifier* generateId(Identifier* id);
|
||||
};
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user