如何从 TemplateHaskell 引用函数

问题描述

我无法从用 TemplateHaskell 生成的表达式中调用一些东西。假设我想使用“:”运算符来列出缺点。 我看到了语法 '(:) 但它对我不起作用。 我还尝试查找名称值并将 mkName ":" 包装到 (AppE (VarE (mkName ":")) 中,但以上都不起作用...

{-# LANGAUGE TemplateHaskell #-}
{-# LANGAUGE TemplateHaskellQuotes #-}
{-# LANGUAGE QuasiQuotes #-}
import Language.Haskell.TH
import Language.Haskell.TH.Syntax as S
import Language.Haskell.TH.Quote

useColon :: Q [Dec]
useColon = do
  let fName = mkName "f"
  pure [ FunD fName 
         [Clause []
          (normalB (InfixE (Just (LitE (IntegerL 1)))
                   '(:)
                    (Just (ListE [])))) []]
  ]

Syntax error on '(:)
  Perhaps you intended to use TemplateHaskell or TemplateHaskellQuotes
• In the Template Haskell quotation '(:)    | 36 |                                '(:)    |                                ^^^^

解决方法

我在 TH 扩展中创建了一个类型,我不得不使用 ConE 而不是 VarE

useColon :: Q [Dec]
useColon = do
  let fName = mkName "f"
  pure [ FunD fName [Clause []
                     (NormalB (InfixE (Just (LitE (IntegerL 1)))
                               (ConE '(:))
                               (Just (ListE [])))) []]]

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...