mirror of
https://github.com/github/semantic.git
synced 2025-01-01 19:55:34 +03:00
Add a function to produce the name of a type.
This commit is contained in:
parent
8cfcd8b7bc
commit
132acddaeb
@ -2,6 +2,7 @@ module Data.Adjoined.Spec where
|
|||||||
|
|
||||||
import Data.Adjoined
|
import Data.Adjoined
|
||||||
import Data.Coalescent
|
import Data.Coalescent
|
||||||
|
import Data.Typeable
|
||||||
import Test.Hspec
|
import Test.Hspec
|
||||||
import Test.Hspec.QuickCheck
|
import Test.Hspec.QuickCheck
|
||||||
import Test.QuickCheck
|
import Test.QuickCheck
|
||||||
@ -51,3 +52,14 @@ instance Arbitrary a => Arbitrary (Coalesced a) where
|
|||||||
|
|
||||||
instance Monoid a => Coalescent (Coalesced a) where
|
instance Monoid a => Coalescent (Coalesced a) where
|
||||||
coalesce a b = Just (Coalesced (runCoalesced a `mappend` runCoalesced b))
|
coalesce a b = Just (Coalesced (runCoalesced a `mappend` runCoalesced b))
|
||||||
|
|
||||||
|
|
||||||
|
-- | Returns a string with the name of a type.
|
||||||
|
-- |
|
||||||
|
-- | Use with `asTypeOf` or `asGeneratedTypeOf` to show type names for parameters without fighting type variable scoping:
|
||||||
|
-- |
|
||||||
|
-- | showTypeOf (`asTypeOf` someTypeParametricValue)
|
||||||
|
showTypeOf :: Typeable a => (a -> a) -> String
|
||||||
|
showTypeOf f = show (typeRep (proxyOf f))
|
||||||
|
where proxyOf :: (a -> a) -> Proxy a
|
||||||
|
proxyOf _ = Proxy
|
||||||
|
Loading…
Reference in New Issue
Block a user