2020-06-01 16:26:37 +03:00
|
|
|
import Language.Reflection
|
|
|
|
|
|
|
|
%language ElabReflection
|
|
|
|
|
2020-06-03 00:41:37 +03:00
|
|
|
logPrims : Elab a
|
2020-06-01 16:26:37 +03:00
|
|
|
logPrims
|
|
|
|
= do ns <- getType `{{ (++) }}
|
|
|
|
traverse (\ (n, ty) =>
|
|
|
|
do logMsg 0 ("Name: " ++ show n)
|
|
|
|
logTerm 0 "Type" ty) ns
|
|
|
|
fail "Not really trying"
|
|
|
|
|
2020-06-03 00:41:37 +03:00
|
|
|
logDataCons : Elab a
|
2020-06-01 16:26:37 +03:00
|
|
|
logDataCons
|
|
|
|
= do [(n, _)] <- getType `{{ Nat }}
|
|
|
|
| _ => fail "Ambiguous name"
|
|
|
|
logMsg 0 ("Resolved name: " ++ show n)
|
|
|
|
logMsg 0 ("Constructors: " ++ show !(getCons n))
|
|
|
|
fail "Still not trying"
|
|
|
|
|
2020-06-03 00:41:37 +03:00
|
|
|
logBad : Elab a
|
2020-06-01 16:26:37 +03:00
|
|
|
logBad
|
|
|
|
= do [(n, _)] <- getType `{{ DoesntExist }}
|
|
|
|
| [] => fail "Undefined name"
|
|
|
|
| _ => fail "Ambiguous name"
|
|
|
|
logMsg 0 ("Resolved name: " ++ show n)
|
|
|
|
logMsg 0 ("Constructors: " ++ show !(getCons n))
|
|
|
|
fail "Still not trying"
|
|
|
|
|
2020-06-03 00:41:37 +03:00
|
|
|
tryGenSym : Elab a
|
2020-06-01 17:13:42 +03:00
|
|
|
tryGenSym
|
|
|
|
= do n <- genSym "plus"
|
|
|
|
ns <- inCurrentNS n
|
|
|
|
fail $ "failed after generating " ++ show ns
|
|
|
|
|
2020-06-01 16:26:37 +03:00
|
|
|
dummy1 : a
|
|
|
|
dummy1 = %runElab logPrims
|
|
|
|
|
|
|
|
dummy2 : a
|
|
|
|
dummy2 = %runElab logDataCons
|
|
|
|
|
|
|
|
dummy3 : a
|
|
|
|
dummy3 = %runElab logBad
|
|
|
|
|
2020-06-01 17:13:42 +03:00
|
|
|
dummy4 : a
|
|
|
|
dummy4 = %runElab tryGenSym
|
|
|
|
|