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 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115
|
(*
** for testing
** [libats/libc/stdlib]
*)
(* ****** ****** *)
//
#include
"share/atspre_staload.hats"
//
staload UN = $UNSAFE // aliasing
//
(* ****** ****** *)
//
staload
UNI = "libats/libc/SATS/unistd.sats"
//
(* ****** ****** *)
staload "libats/libc/SATS/stdlib.sats"
staload _ = "libats/libc/DATS/stdlib.dats"
(* ****** ****** *)
val () =
{
val u = getenv_gc ("USER")
val () = println! ("$USER = ", u)
val () = strptr_free (u)
} // end of [val]
(* ****** ****** *)
val () = {
val seed = 31415926U
val () = srand (seed)
val r1 = rand ()
val r2 = rand ()
val () = srand (seed)
val () = assertloc (r1 = rand ())
val () = assertloc (r2 = rand ())
var seed_r: uint = seed
val r1 = rand_r (seed_r)
val r2 = rand_r (seed_r)
var seed_r: uint = seed
val () = assertloc (r1 = rand_r (seed_r))
val () = assertloc (r2 = rand_r (seed_r))
} // end of [val]
(* ****** ****** *)
val () = {
val seed = 31415926U
val () = srandom (seed)
val l1 = random ()
val l2 = random ()
val () = srandom (seed)
val () = assertloc (l1 = random ())
val () = assertloc (l2 = random ())
} // end of [val]
(* ****** ****** *)
val () = {
//
val () = srand48 (27182828L)
val d1 = drand48 ()
val d2 = drand48 ()
val () = srand48 (27182828L)
val () = assertloc (d1 = drand48 ())
val () = assertloc (d2 = drand48 ())
//
val () = srand48 (27182828L)
val l1 = lrand48 ()
val l2 = lrand48 ()
val () = srand48 (27182828L)
val () = assertloc (l1 = lrand48 ())
val () = assertloc (l2 = lrand48 ())
//
val () = srand48 (27182828L)
val m1 = mrand48 ()
val m2 = mrand48 ()
val () = srand48 (27182828L)
val () = assertloc (m1 = mrand48 ())
val () = assertloc (m2 = mrand48 ())
//
} // end of [val]
(* ****** ****** *)
val () = {
//
val str = "scratch-XXXXXX"
val str2 = string1_copy (str)
val fdes = mkstemp (str2)
val () = assertloc (fdes >= 0)
val () = assertloc ($UNI.close (fdes) = 0)
val () = assertloc ($UNI.unlink ($UN.strnptr2string(str2)) = 0)
val () = strnptr_free (str2)
//
} // end of [val]
(* ****** ****** *)
val () = {
val () = assertloc (system ("ls -l > /dev/null") = 0)
} // end of [val]
(* ****** ****** *)
implement main0 () = ()
(* ****** ****** *)
(* end of [libats_libc_stdlib.dats] *)
|