MimIR 0.1
MimIR is my Intermediate Representation
Loading...
Searching...
No Matches

Optimistically performs β-reduction (aka inlining). More...

#include <mim/pass/beta_red.h>

Inheritance diagram for mim::BetaRed:
[legend]

Public Types

using Data = LamSet
Public Types inherited from mim::FPPass< BetaRed, Def >
using Super
using Data
 Default.

Public Member Functions

 BetaRed (World &world, flags_t annex)
void keep (Lam *lam)
Public Member Functions inherited from mim::FPPass< BetaRed, Def >
 FPPass (World &world, std::string name)
bool fixed_point () const override
Public Member Functions inherited from mim::RWPass< BetaRed, Def >
 RWPass (World &world, std::string name)
bool inspect () const override
 Should the PassMan even consider this pass?
Defcurr_mut () const
Public Member Functions inherited from mim::Pass
 Pass (World &world, std::string name)
 Pass (World &world, flags_t annex)
virtual void init (PassMan *)
PassManman ()
const PassManman () const
size_t index () const
virtual const Defrewrite (const Var *var)
virtual const Defrewrite (const Proxy *proxy)
virtual undo_t analyze (const Var *)
virtual void enter ()
 Invoked just before Pass::rewriteing PassMan::curr_mut's body.
virtual void prepare ()
 Invoked once before entering the main rewrite loop.
const Proxyproxy (const Def *type, Defs ops, u32 tag=0)
const Proxyisa_proxy (const Def *def, u32 tag=0)
 Check whether given def is a Proxy whose Proxy::pass matches this Pass's IPass::index.
const Proxyas_proxy (const Def *def, u32 tag=0)
Public Member Functions inherited from mim::Stage
Worldworld ()
Driverdriver ()
Loglog () const
std::string_view name () const
flags_t annex () const
 Stage (World &world, std::string name)
 Stage (World &world, flags_t annex)
virtual ~Stage ()=default
virtual std::unique_ptr< Stagerecreate ()
 Creates a new instance; needed by a fixed-point PhaseMan.
virtual void apply (const App *)
 Invoked if your Stage has additional args.
virtual void apply (Stage &)
 Dito, but invoked by Stage::recreate.

Private Member Functions

const Defrewrite (const Def *) override
undo_t analyze (const Proxy *) override
undo_t analyze (const Def *) override

Additional Inherited Members

static auto create (const Flags2Stages &stages, const Def *def)
template<class A, class P>
static void hook (Flags2Stages &stages)
Protected Member Functions inherited from mim::FPPass< BetaRed, Def >
const auto & states () const
auto & data ()
undo_t curr_undo () const
 Current undo point.
undo_t undo_visit (Def *mut) const
 Retrieves the point to backtrack to just before mut was seen the very first time.
undo_t undo_enter (Def *mut) const
 Retrieves the point to backtrack to just before rewriting mut's body.
Protected Attributes inherited from mim::Stage
std::string name_

Detailed Description

Optimistically performs β-reduction (aka inlining).

β-reduction of f e happens if f only occurs exactly once in the program in callee position.

Definition at line 9 of file beta_red.h.

Member Typedef Documentation

◆ Data

Definition at line 14 of file beta_red.h.

Constructor & Destructor Documentation

◆ BetaRed()

mim::BetaRed::BetaRed ( World & world,
flags_t annex )
inline

Member Function Documentation

◆ analyze() [1/2]

◆ analyze() [2/2]

undo_t mim::BetaRed::analyze ( const Proxy * proxy)
overrideprivatevirtual

◆ keep()

void mim::BetaRed::keep ( Lam * lam)
inline

Definition at line 16 of file beta_red.h.

◆ rewrite()

const Def * mim::BetaRed::rewrite ( const Def * def)
overrideprivatevirtual

The documentation for this class was generated from the following files: