CurryInfo: contracts-3.1.0 / Test.Contract.withPreContract2

definition:
withPreContract2 :: (Show a, Show b) => String -> (a -> b -> Bool)
                 -> (a -> b -> c) -> a -> b -> c
withPreContract2 fname precond fun arg1 arg2
  | checkPre fname (precond arg1 arg2)
                      (unwords [showATerm arg1,showATerm arg2])
  = fun arg1 arg2
demand:
arguments 4 5
deterministic:
deterministic operation
failfree:
<FAILING>
indeterministic:
might be indeterministic
infix:
no fixity defined
iotype:
{(_,_,_,_,_,_,_) |-> _}
name:
withPreContract2
precedence:
no precedence defined
result-values:
_
signature:
(Prelude.Show a, Prelude.Show b) => String -> (a -> b -> Prelude.Bool) -> (a
-> b -> c) -> a -> b -> c
solution-complete:
operation might suspend on free variables
terminating:
possibly non-terminating
totally-defined:
possibly non-reducible on same data term