CurryInfo: contracts-3.1.0 / Test.Contract.withContract1ND

definition:
withContract1ND :: (Show a, Show b) => String
                -> (a -> Values Bool) -> (a -> b -> Values Bool) -> (b -> b)
                -> (a -> b) -> a -> b
withContract1ND fname precond postcond postobserve fun arg
  |  checkPreND fname (precond arg) (showATerm arg)
  &> checkPostND fname (postcond arg result)
               (unwords [showATerm arg, "->", showATerm (postobserve result)])
  = result
 where result = fun arg
demand:
argument 7
deterministic:
deterministic operation
failfree:
<FAILING>
indeterministic:
might be indeterministic
infix:
no fixity defined
iotype:
{(_,_,_,_,_,_,_,_) |-> _}
name:
withContract1ND
precedence:
no precedence defined
result-values:
_
signature:
(Prelude.Show a, Prelude.Show b) => String -> (a
-> Control.Search.SetFunctions.Values Prelude.Bool) -> (a -> b
-> Control.Search.SetFunctions.Values Prelude.Bool) -> (b -> b) -> (a -> b) -> a
-> b
solution-complete:
operation might suspend on free variables
terminating:
possibly non-terminating
totally-defined:
possibly non-reducible on same data term