feat: Store Format instead of Syntax in DocInfo

main
Henrik Böving 2021-12-18 00:01:31 +01:00
parent 4380fe088d
commit d18e71966c
1 changed files with 25 additions and 23 deletions

View File

@ -15,14 +15,14 @@ namespace DocGen4
open Lean Meta PrettyPrinter Std open Lean Meta PrettyPrinter Std
abbrev InfoSyntax := (Syntax × RBMap Delaborator.Pos Elab.Info compare) abbrev InfoFormat := (Format × RBMap Delaborator.Pos Elab.Info compare)
structure NameInfo where structure NameInfo where
name : Name name : Name
type : InfoSyntax type : InfoFormat
def NameInfo.prettyPrint (i : NameInfo) : CoreM String := do def NameInfo.prettyPrint (i : NameInfo) : String :=
s!"{i.name} : {←PrettyPrinter.formatTerm i.type.fst}" s!"{i.name} : {i.type.fst}"
structure Info extends NameInfo where structure Info extends NameInfo where
doc : Option String doc : Option String
@ -34,11 +34,11 @@ structure AxiomInfo extends Info where
structure TheoremInfo extends Info structure TheoremInfo extends Info
structure OpaqueInfo extends Info where structure OpaqueInfo extends Info where
value : InfoSyntax value : InfoFormat
isUnsafe : Bool isUnsafe : Bool
structure DefinitionInfo extends Info where structure DefinitionInfo extends Info where
--value : InfoSyntax --value : InfoFormat
unsafeInformation : DefinitionSafety unsafeInformation : DefinitionSafety
hints : ReducibilityHints hints : ReducibilityHints
@ -65,7 +65,7 @@ structure StructureInfo extends Info where
structure ClassInfo extends StructureInfo where structure ClassInfo extends StructureInfo where
hasOutParam : Bool hasOutParam : Bool
instances : Array InfoSyntax instances : Array InfoFormat
inductive DocInfo where inductive DocInfo where
| axiomInfo (info : AxiomInfo) : DocInfo | axiomInfo (info : AxiomInfo) : DocInfo
@ -83,11 +83,13 @@ structure Module where
members : Array DocInfo members : Array DocInfo
deriving Inhabited deriving Inhabited
def prettyPrintTerm (expr : Expr) : MetaM InfoSyntax := do def prettyPrintTerm (expr : Expr) : MetaM InfoFormat := do
let ((expr, _), _) ← Elab.Term.TermElabM.run $ Elab.Term.levelMVarToParam (←instantiateMVars expr) let ((expr, _), _) ← Elab.Term.TermElabM.run $ Elab.Term.levelMVarToParam (←instantiateMVars expr)
let (stx, info) ← delabCore Name.anonymous [] expr let (stx, info) ← delabCore Name.anonymous [] expr
let stx := sanitizeSyntax stx |>.run' { options := ←getOptions } let stx := sanitizeSyntax stx |>.run' { options := ←getOptions }
(←parenthesizeTerm stx, info) let stx ← parenthesizeTerm stx
let fmt ← PrettyPrinter.formatTerm stx
(fmt, info)
def Info.ofConstantVal (v : ConstantVal) : MetaM Info := do def Info.ofConstantVal (v : ConstantVal) : MetaM Info := do
let env ← getEnv let env ← getEnv
@ -120,7 +122,7 @@ def DefinitionInfo.ofDefinitionVal (v : DefinitionVal) : MetaM DefinitionInfo :=
--let value ← prettyPrintTerm v.value --let value ← prettyPrintTerm v.value
return DefinitionInfo.mk info v.safety v.hints return DefinitionInfo.mk info v.safety v.hints
def getConstructorType (ctor : Name) : MetaM InfoSyntax := do def getConstructorType (ctor : Name) : MetaM InfoFormat := do
let env ← getEnv let env ← getEnv
match env.find? ctor with match env.find? ctor with
| some (ConstantInfo.ctorInfo i) => ←prettyPrintTerm i.type | some (ConstantInfo.ctorInfo i) => ←prettyPrintTerm i.type
@ -233,22 +235,22 @@ def ofConstant : (Name × ConstantInfo) → MetaM (Option DocInfo) := λ (name,
def prettyPrint (i : DocInfo) : CoreM String := do def prettyPrint (i : DocInfo) : CoreM String := do
match i with match i with
| axiomInfo i => s!"axiom {i.toNameInfo.prettyPrint}, doc string: {i.doc}" | axiomInfo i => s!"axiom {i.toNameInfo.prettyPrint}, doc string: {i.doc}"
| theoremInfo i => s!"theorem {i.toNameInfo.prettyPrint}, doc string: {i.doc}" | theoremInfo i => s!"theorem {i.toNameInfo.prettyPrint}, doc string: {i.doc}"
| opaqueInfo i => s!"constant {i.toNameInfo.prettyPrint}, doc string: {i.doc}" | opaqueInfo i => s!"constant {i.toNameInfo.prettyPrint}, doc string: {i.doc}"
| definitionInfo i => s!"def {i.toNameInfo.prettyPrint}, doc string: {i.doc}" | definitionInfo i => s!"def {i.toNameInfo.prettyPrint}, doc string: {i.doc}"
| instanceInfo i => s!"instance {i.toNameInfo.prettyPrint}, doc string: {i.doc}" | instanceInfo i => s!"instance {i.toNameInfo.prettyPrint}, doc string: {i.doc}"
| inductiveInfo i => | inductiveInfo i =>
let ctorString ← i.ctors.mapM NameInfo.prettyPrint let ctorString := i.ctors.map NameInfo.prettyPrint
s!"inductive {←i.toNameInfo.prettyPrint}, ctors: {ctorString}, doc string: {i.doc}" s!"inductive {←i.toNameInfo.prettyPrint}, ctors: {ctorString}, doc string: {i.doc}"
| structureInfo i => | structureInfo i =>
let ctorString i.ctor.prettyPrint let ctorString := i.ctor.prettyPrint
let fieldString ← i.fieldInfo.mapM (λ f => do s!"{f.name} : {←PrettyPrinter.formatTerm f.type.fst}") let fieldString := i.fieldInfo.map (λ f => s!"{f.name} : {f.type.fst}")
s!"structure {i.toNameInfo.prettyPrint} extends {i.parents}, ctor: {ctorString}, fields : {fieldString}, doc string: {i.doc}" s!"structure {i.toNameInfo.prettyPrint} extends {i.parents}, ctor: {ctorString}, fields : {fieldString}, doc string: {i.doc}"
| classInfo i => | classInfo i =>
let instanceString ← i.instances.mapM (PrettyPrinter.formatTerm ∘ Prod.fst) let instanceString := i.instances.map Prod.fst
let fieldString ← i.fieldInfo.mapM (NameInfo.prettyPrint ∘ FieldInfo.toNameInfo) let fieldString := i.fieldInfo.map (NameInfo.prettyPrint ∘ FieldInfo.toNameInfo)
s!"class {i.toNameInfo.prettyPrint} extends {i.parents}, fields: {fieldString}, instances : {instanceString}, doc string: {i.doc}" s!"class {i.toNameInfo.prettyPrint} extends {i.parents}, fields: {fieldString}, instances : {instanceString}, doc string: {i.doc}"
def getName : DocInfo → Name def getName : DocInfo → Name
| axiomInfo i => i.name | axiomInfo i => i.name
@ -270,7 +272,7 @@ def getKind : DocInfo → String
| structureInfo _ => "structure" | structureInfo _ => "structure"
| classInfo _ => "class" -- TODO: This is handled as structure right now | classInfo _ => "class" -- TODO: This is handled as structure right now
def getType : DocInfo → InfoSyntax def getType : DocInfo → InfoFormat
| axiomInfo i => i.type | axiomInfo i => i.type
| theoremInfo i => i.type | theoremInfo i => i.type
| opaqueInfo i => i.type | opaqueInfo i => i.type