Mercurial > urweb
changeset 1324:d596c7002ad8
More accurate/conservative leaky type detection in CjrPrint
author | Adam Chlipala <adamc@hcoop.net> |
---|---|
date | Sun, 28 Nov 2010 15:06:11 -0500 (2010-11-28) |
parents | 0d8bd8ae8417 |
children | fdf48f6ba418 |
files | src/cjr_print.sml |
diffstat | 1 files changed, 7 insertions(+), 3 deletions(-) [+] |
line wrap: on
line diff
--- a/src/cjr_print.sml Fri Nov 26 11:57:04 2010 -0500 +++ b/src/cjr_print.sml Sun Nov 28 15:06:11 2010 -0500 @@ -525,6 +525,10 @@ | _ => raise Fail "CjrPrint: getPargs" +val notLeakies = SS.fromList ["int", "float", "char", "time", "bool", "unit", "client", "channel", + "xhtml", "page", "xbody", "css_class"] +val notLeakies' = SS.fromList ["blob"] + fun notLeaky env allowHeapAllocated = let fun nl ok (t, _) = @@ -548,9 +552,9 @@ NONE => true | SOME t => nl ok' t) cons end) - | TFfi ("Basis", "string") => false - | TFfi ("Basis", "blob") => allowHeapAllocated - | TFfi _ => true + | TFfi ("Basis", t) => SS.member (notLeakies, t) + orelse (allowHeapAllocated andalso SS.member (notLeakies', t)) + | TFfi _ => false | TOption t => allowHeapAllocated andalso nl ok t | TList (t, _) => allowHeapAllocated andalso nl ok t in