lean4-htt/tests/lean/ppNotationCode.lean.expected.out
2022-10-16 08:40:01 -07:00

85 lines
4.4 KiB
Text

[Elab.definition.body] «term_+++_» : Lean.TrailingParserDescr :=
Lean.ParserDescr.trailingNode `term_+++_ 45 46
(Lean.ParserDescr.binary `andthen (Lean.ParserDescr.symbol "+++") (Lean.ParserDescr.cat `term 46))
[Elab.definition.body] «_aux_ppNotationCode___macroRules_term_+++__1» : Lean.Macro :=
fun x =>
let_fun __discr := x;
if Lean.Syntax.isOfKind __discr `term_+++_ = true then
let_fun __discr_1 := Lean.Syntax.getArg __discr 0;
let_fun __discr_2 := Lean.Syntax.getArg __discr 1;
let_fun __discr := Lean.Syntax.getArg __discr 2;
let_fun rhs := { raw := __discr };
let_fun lhs := { raw := __discr_1 };
do
let info ← Lean.MonadRef.mkInfoFromRefPos
let scp ← Lean.getCurrMacroScope
let mainModule ← Lean.getMainModule
pure
{ raw :=
Lean.Syntax.node2 info `Lean.Parser.Term.app
(Lean.Syntax.ident info (String.toSubstring' "Nat.add") (Lean.addMacroScope mainModule `Nat.add scp)
[Lean.Syntax.Preresolved.decl `Nat.add [], Lean.Syntax.Preresolved.namespace `Nat.add])
(Lean.Syntax.node2 info `null lhs.raw rhs.raw) }.raw
else
let_fun __discr := x;
throw Lean.Macro.Exception.unsupportedSyntax
[Elab.definition.body] _aux_ppNotationCode___unexpand_Nat_add_1 : Lean.PrettyPrinter.Unexpander :=
fun x =>
let_fun __discr := x;
if Lean.Syntax.isOfKind __discr `Lean.Parser.Term.app = true then
let_fun __discr_1 := Lean.Syntax.getArg __discr 0;
bif false || Lean.Syntax.isOfKind __discr_1 `ident then
let_fun __discr_2 := Lean.Syntax.getArg __discr 1;
if Lean.Syntax.matchesNull __discr_2 2 = true then
let_fun __discr := Lean.Syntax.getArg __discr_2 0;
let_fun __discr_3 := Lean.Syntax.getArg __discr_2 1;
let_fun rhs := { raw := __discr_3 };
let_fun lhs := { raw := __discr };
let_fun f := { raw := __discr_1 };
Lean.withRef f.raw do
let info ← Lean.MonadRef.mkInfoFromRefPos
let _ ← Lean.getCurrMacroScope
let _ ← Lean.getMainModule
pure { raw := Lean.Syntax.node3 info `term_+++_ lhs.raw (Lean.Syntax.atom info "+++") rhs.raw }.raw
else
let_fun __discr := Lean.Syntax.getArg __discr 1;
throw ()
else
let_fun __discr_2 := Lean.Syntax.getArg __discr 0;
if Lean.Syntax.isOfKind __discr_2 `Lean.Parser.Term.app = true then
let_fun __discr_3 := Lean.Syntax.getArg __discr_2 0;
bif false || Lean.Syntax.isOfKind __discr_3 `ident then
let_fun __discr_4 := Lean.Syntax.getArg __discr_2 1;
if Lean.Syntax.matchesNull __discr_4 2 = true then
let_fun __discr_5 := Lean.Syntax.getArg __discr_4 0;
let_fun __discr_6 := Lean.Syntax.getArg __discr_4 1;
let_fun __discr := Lean.Syntax.getArg __discr 1;
let_fun moreArgs := Lean.TSyntaxArray.mk (Lean.Syntax.getArgs __discr);
let_fun rhs := { raw := __discr_6 };
let_fun lhs := { raw := __discr_5 };
let_fun f := { raw := __discr_3 };
Lean.withRef f.raw do
let info ← Lean.MonadRef.mkInfoFromRefPos
let _ ← Lean.getCurrMacroScope
let _ ← Lean.getMainModule
pure
{ raw :=
Lean.Syntax.node2 info `Lean.Parser.Term.app
(Lean.Syntax.node3 info `term_+++_ lhs.raw (Lean.Syntax.atom info "+++") rhs.raw)
(Lean.Syntax.node info `null (Array.append #[] (Lean.TSyntaxArray.raw moreArgs))) }.raw
else
let_fun __discr_5 := Lean.Syntax.getArg __discr_2 1;
let_fun __discr := Lean.Syntax.getArg __discr 1;
throw ()
else
let_fun __discr_4 := Lean.Syntax.getArg __discr_2 0;
let_fun __discr_5 := Lean.Syntax.getArg __discr_2 1;
let_fun __discr := Lean.Syntax.getArg __discr 1;
throw ()
else
let_fun __discr_3 := Lean.Syntax.getArg __discr 0;
let_fun __discr := Lean.Syntax.getArg __discr 1;
throw ()
else
let_fun __discr := x;
throw ()