File: Test162.ML

package info (click to toggle)
polyml 5.8.1-1~exp1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 57,736 kB
  • sloc: cpp: 44,918; ansic: 26,921; asm: 13,495; sh: 4,670; makefile: 610; exp: 525; python: 253; awk: 91
file content (19 lines) | stat: -rw-r--r-- 420 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
(* Negative values require special treatment in Foreign.sml *)

val c = Foreign.breakConversion Foreign.cInt16;

fun checkValue v =
let
    val m = Foreign.Memory.malloc (#size (#ctype c));
    val _ = #store c (m, v);
    val result = #load c m before Foreign.Memory.free m
in
    if result <> v then raise Fail "Incorrect" else ()
end;

checkValue ~1;
checkValue 1;
checkValue 0;
checkValue 32767;
checkValue ~32768;