Mercurial > projects > ddmd
view dmd/ThrowStatement.d @ 165:25ede4f66bda
Temporarily disabled GC (again) because phobos fails to compile with it (looks like some ObjSymbols are being falsely collected, see Library.d:666)
Getting rid of global state (i.e global and static variables) to allow running concurrent compilation
author | korDen |
---|---|
date | Thu, 30 Sep 2010 10:04:32 +0400 |
parents | 60bb0fe4563e |
children | af724d3510d7 |
line wrap: on
line source
module dmd.ThrowStatement; import dmd.common; import dmd.Statement; import dmd.Expression; import dmd.Loc; import dmd.IRState; import dmd.InlineScanState; import dmd.HdrGenState; import dmd.OutBuffer; import dmd.Scope; import dmd.Expression; import dmd.FuncDeclaration; import dmd.BE; import dmd.backend.Util; import dmd.backend.Blockx; import dmd.backend.elem; import dmd.backend.RTLSYM; import dmd.backend.OPER; import dmd.backend.TYM; class ThrowStatement : Statement { Expression exp; this(Loc loc, Expression exp) { super(loc); this.exp = exp; } override Statement syntaxCopy() { ThrowStatement s = new ThrowStatement(loc, exp.syntaxCopy()); return s; } override Statement semantic(Scope sc) { //printf("ThrowStatement::semantic()\n"); FuncDeclaration fd = sc.parent.isFuncDeclaration(); fd.hasReturnExp |= 2; version(DMDV1) { // See bugzilla 3388. Should this be or not? if (sc.incontract) error("Throw statements cannot be in contracts"); } exp = exp.semantic(sc); exp = resolveProperties(sc, exp); if (!exp.type.toBasetype().isClassHandle()) error("can only throw class objects, not type %s", exp.type.toChars()); return this; } override void toCBuffer(OutBuffer buf, HdrGenState* hgs) { assert(false); } override BE blockExit() { return BE.BEthrow; // obviously } override Statement inlineScan(InlineScanState* iss) { if (exp) exp = exp.inlineScan(iss); return this; } override void toIR(IRState* irs) { // throw(exp) Blockx *blx = irs.blx; incUsage(irs, loc); elem *e = exp.toElem(irs); static if (false) { e = el_bin(OPcall, TYvoid, el_var(rtlsym[RTLSYM_LTHROW]),e); } else { e = el_bin(OPcall, TYvoid, el_var(rtlsym[RTLSYM_THROW]),e); } block_appendexp(blx.curblock, e); } }