CurryInfo: rewriting-3.0.0 / Rewriting.Term.showTerm

definition:
showTerm :: (f -> String) -> Term f -> String
showTerm s = showTerm' False
  where
    showTerm' _ (TermVar v)     = showVarIdx v
    showTerm' b (TermCons c ts) = case ts of
      []     -> cstr
      [l, r] -> if any isAlphaNum cstr
                  then prefixString -- no infix notation
                  else parensIf b (showTerm' True l ++ " " ++ cstr ++ " " ++
                                   showTerm' True r)
      _      -> prefixString
     where
      cstr         = s c
      prefixString = cstr ++ "("
                          ++ intercalate "," (map (showTerm' False) ts) ++ ")"
demand:
no demanded arguments
deterministic:
deterministic operation
documentation:
--- Transforms a term into a string representation.
failfree:
<FAILING>
indeterministic:
referentially transparent operation
infix:
no fixity defined
iotype:
{(_) |-> {showTerm.showTerm'.6}}
name:
showTerm
precedence:
no precedence defined
result-values:
{showTerm.showTerm'.6}
signature:
(a -> String) -> Term a -> String
solution-complete:
operation might suspend on free variables
terminating:
possibly non-terminating
totally-defined:
possibly non-reducible on same data term