view dmd/InlineCostState.d @ 178:e3afd1303184

Many small bugs fixed Made all classes derive from TObject to detect memory leaks (functionality is disabled for now) Began work on overriding backend memory allocations (to avoid memory leaks)
author korDen
date Sun, 17 Oct 2010 07:42:00 +0400
parents e28b18c23469
children
line wrap: on
line source

module dmd.InlineCostState;

import dmd.common;
import dmd.FuncDeclaration;
import dmd.Expression;

struct InlineCostState
{
    int nested;
    int hasthis;
    int hdrscan;    // !=0 if inline scan for 'header' content
    FuncDeclaration fd;
}

const int COST_MAX = 250;

int arrayInlineCost(InlineCostState* ics, Expressions arguments)
{
	int cost = 0;

    if (arguments)
    {
		foreach (e; arguments)
		{   
			if (e)
				cost += e.inlineCost(ics);
		}
    }
    return cost;
}