Mercurial > urweb
view demo/refFun.ur @ 1675:13dad713da35
New, more principled heuristic for Especialize: only specialize uniform function arguments; that is, arguments that don't change across recursive calls
author | Adam Chlipala <adam@chlipala.net> |
---|---|
date | Wed, 11 Jan 2012 13:53:35 -0500 |
parents | 1a317a707d71 |
children |
line wrap: on
line source
functor Make(M : sig type data val inj : sql_injectable data end) = struct type ref = int sequence s table t : { Id : int, Data : M.data } PRIMARY KEY Id fun new d = id <- nextval s; dml (INSERT INTO t (Id, Data) VALUES ({[id]}, {[d]})); return id fun read r = o <- oneOrNoRows (SELECT t.Data FROM t WHERE t.Id = {[r]}); case o of None => error <xml>You already deleted that ref!</xml> | Some r => return r.T.Data fun write r d = dml (UPDATE t SET Data = {[d]} WHERE Id = {[r]}) fun delete r = dml (DELETE FROM t WHERE Id = {[r]}) end