generalized monotonic constructor optimisation so that it works with e.g. the product type
structure ROOT =
struct
structure Codegen =
struct
fun lookup ((k, v) :: xs) l =
(if ((k : string) = l) then SOME v else lookup xs l)
| lookup [] l = NONE;
end; (*struct Codegen*)
end; (*struct ROOT*)