该reflection
软件包提供了一个类
class Reifies s a | s -> a where reflect :: proxy s -> a
和一个功能
reify :: a -> (forall s . Reifies s a => Proxy s -> r) -> r
只有这些,例如,通过给出实例,可能会使事情变得非常糟糕
instance Reifies s Int where reflect _ = 0
这可能很糟糕,例如,
reify (1 :: Int) $ \p -> reflect p
可以合法地生成1(通过通常的反射过程)或0(通过在应用之前专门化传递的函数reify
).
实际上,这个特定的漏洞似乎被包含在中的一些Reifies
实例所阻止Data.Reflection
.我描述的邪恶实例将被重复拒绝.如果启用了重叠实例,我相信重复带来的不确定性可能会阻碍专业化.
不过,我想知道是否有一些方法可以在一个阴暗的实例中暴露这个,也许是在GADT或其他类似的帮助下.