File: Test105.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 (22 lines) | stat: -rw-r--r-- 705 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
(* Another Isabelle crash: This caused a segfault. *)

datatype term = Const of string * int | $ of term * term;

PolyML.Compiler.maxInlineSize := 1;
fun aeconv(t, u) = case (t, u) of (Const(s, _), Const(y, _)) => s = y | _ => false;

PolyML.Compiler.maxInlineSize := 80;

infix 9 $;
exception TERM of string * term list;

fun dest_equals (Const ("==", _) $ t $ u) = (t, u)
  | dest_equals t = raise TERM ("dest_equals", [t]);

datatype thm = Thm of int * {tpairs: (term * term) list, prop: term};

fun is_trivial(Thm (_, {prop, ...})) = aeconv(dest_equals prop);

fun doFilter raw_eqs = List.filter is_trivial raw_eqs;

doFilter[Thm(1, {tpairs=[], prop=Const("==", 0) $ Const("a", 0) $ Const("a", 0)})];