File: Test103.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 (29 lines) | stat: -rw-r--r-- 859 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
23
24
25
26
27
28
29
(* Code-generator bug in X86 development version.  The stack adjustment is wrong. *)

datatype cterm = Cterm of { thy_ref: int, t: int, T: int, maxidx: int, sorts: int};

PolyML.Compiler.maxInlineSize := 1;
fun read_prop s = Cterm {maxidx = ~1, thy_ref = valOf(Int.fromString s), t = 0, T = 0, sorts = 0};
PolyML.Compiler.maxInlineSize := 40;

val transitive_thm =
  (
  let
    val qqq = ref 0
    val xy = read_prop "123";
    val yz = read_prop "124";
    val xythm =
      let
      val _ =
        let
            val ct as Cterm {thy_ref, t, T, maxidx, sorts} = xy
        in
          if maxidx = ~1 then ct
          else
            Cterm {maxidx = t, thy_ref = thy_ref, t = t, T = T, sorts = sorts}
        end;
      in
        0
      end;
  in case xy of Cterm{sorts=0, ...} => () | _ => raise Fail "bad" end
  ) (*handle Match => raise Match*);