File: Test027.ML

package info (click to toggle)
polyml 5.6-8
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 31,892 kB
  • ctags: 34,453
  • sloc: cpp: 44,983; ansic: 24,520; asm: 14,850; sh: 11,730; makefile: 551; exp: 484; python: 253; awk: 91; sed: 9
file content (12 lines) | stat: -rw-r--r-- 358 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
(* Bug detected in Poly/ML 26/10/99. *)
(* This function permits equality on functions due to a failure to
   propagate the equality attribute on flexible records. *)

let
fun eqforfun (x: int->int, y: int->int) =
    case ({a=1,b=x}, {a=1,b=y}) of
        (xx as {a=1,...}, yy as {a=1, ...}) => xx = yy
      | _ => false
in
eqforfun(fn x=>x, fn x=>x)
end;