# HG changeset patch # User Adam Chlipala # Date 1221420053 14400 # Node ID 5ccb1c6412e48702c20575387fe3b894817aca54 # Parent 075b36dbb1a458711a9aa9bd9d33250cf401b565 Push writes inside lets diff -r 075b36dbb1a4 -r 5ccb1c6412e4 src/mono_opt.sml --- a/src/mono_opt.sml Sun Sep 14 15:10:04 2008 -0400 +++ b/src/mono_opt.sml Sun Sep 14 15:20:53 2008 -0400 @@ -301,6 +301,9 @@ initial = (ERecord [], loc), body = (optExp (EWrite e', loc), loc)} + | EWrite (ELet (x, t, e1, e2), loc) => + optExp (ELet (x, t, e1, (EWrite e2, loc)), loc) + | _ => e and optExp e = #1 (U.Exp.map {typ = typ, exp = exp} e)