-
Notifications
You must be signed in to change notification settings - Fork 380
/
Copy pathDisplay.idr
98 lines (87 loc) · 3.61 KB
/
Display.idr
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
module Idris.Doc.Display
import Core.Case.CaseTree
import Core.Case.CaseTree.Pretty
import Core.Context
import Core.Env
import Data.String
import Idris.IDEMode.Holes
import Idris.Pretty
import Idris.Resugar
import Idris.Syntax
import Idris.Syntax.Views
%hide Symbols.equals
%default covering
export
displayType : {auto c : Ref Ctxt Defs} ->
{auto s : Ref Syn SyntaxInfo} ->
(shortName : Bool) -> Defs -> (Name, Int, GlobalDef) ->
Core (Doc IdrisSyntax)
displayType shortName defs (n, i, gdef)
= maybe (do tm <- resugar [] !(normaliseHoles defs [] (type gdef))
nm <- aliasName (fullname gdef)
let nm = ifThenElse shortName (dropNS nm) nm
let prig = prettyRig gdef.multiplicity
let ann = showCategory id gdef
pure (prig <+> ann (cast $ prettyOp True nm) <++> colon <++> pretty tm))
(\num => prettyHole defs [] n num (type gdef))
(isHole gdef)
export
displayTerm : {auto c : Ref Ctxt Defs} ->
{auto s : Ref Syn SyntaxInfo} ->
Defs -> ClosedTerm ->
Core (Doc IdrisSyntax)
displayTerm defs tm
= do ptm <- resugar [] !(normaliseHoles defs [] tm)
pure (pretty ptm)
export
displayClause : {auto c : Ref Ctxt Defs} ->
{auto s : Ref Syn SyntaxInfo} ->
Defs -> (vs ** (Env Term vs, Term vs, Term vs)) ->
Core (Doc IdrisSyntax)
displayClause defs (vs ** (env, lhs, rhs))
= do lhstm <- resugar env !(normaliseHoles defs env lhs)
rhstm <- resugar env !(normaliseHoles defs env rhs)
pure (prettyLHS lhstm <++> equals <++> pretty rhstm)
where
prettyLHS : IPTerm -> Doc IdrisSyntax
prettyLHS (PRef _ op) = cast $ prettyOp True op.rawName
prettyLHS t = pretty t
export
displayPats : {auto c : Ref Ctxt Defs} ->
{auto s : Ref Syn SyntaxInfo} ->
(shortName : Bool) -> Defs -> (Name, Int, GlobalDef) ->
Core (Doc IdrisSyntax)
displayPats shortName defs (n, idx, gdef)
= case definition gdef of
PMDef _ _ _ _ pats =>
do ty <- displayType shortName defs (n, idx, gdef)
ps <- traverse (displayClause defs) pats
pure (vsep (ty :: ps))
_ => pure (pretty0 n <++> reflow "is not a pattern matching definition")
export
displayImpl : {auto c : Ref Ctxt Defs} ->
{auto s : Ref Syn SyntaxInfo} ->
Defs -> (Name, Int, GlobalDef) ->
Core (Doc IdrisSyntax)
displayImpl defs (n, idx, gdef)
= case definition gdef of
PMDef _ _ ct _ [(vars ** (env, _, rhs))] =>
do rhstm <- resugar env !(normaliseHoles defs env rhs)
let (_, args) = getFnArgs defaultKindedName rhstm
defs <- get Ctxt
pds <- map catMaybes $ for args $ \ arg => do
let (_, expr) = underLams (unArg arg)
let (PRef _ kn, _) = getFnArgs defaultKindedName expr
| _ => pure Nothing
log "doc.implementation" 20 $ "Got name \{show @{Raw} kn}"
let (ns, DN dn nm) = splitNS (kn.fullName)
| _ => do log "doc.implementation" 10 $ "Invalid name \{show @{Raw} kn}"
pure Nothing
let nm = NS ns nm
Just (idx, gdef) <- lookupCtxtExactI kn.fullName (gamma defs)
| _ => do log "doc.implementation" 10 $ "Couldn't find \{show @{Raw} nm}"
pure Nothing
pdef <- displayPats True defs (nm, idx, gdef)
pure (Just pdef)
pure (vcat $ intersperse "" pds)
_ => pure (pretty0 n <++> reflow "is not an implementation definition")