1 {-# LANGUAGE ConstraintKinds #-}
 
   2 {-# LANGUAGE UndecidableInstances #-}
 
   7 import Network.URI.Slug
 
   9 import Symantic.Classes (IsoFunctor, ProductFunctor, SumFunctor)
 
  13 usedRoutes :: Layouter a -> [a]
 
  14 usedRoutes repr = f <$> foldMap flatten (layout repr)
 
  17       LayoutNodeSlug a _s -> a
 
  19 usedSlugs :: Layouter a -> [[Slug]]
 
  20 usedSlugs repr = f <$> foldMap flatten (layout repr)
 
  23       LayoutNodeSlug _a s -> s
 
  25 {- | Gather symantics used for those tests to instantiate multiple interpreters
 
  26 on the same quantified 'repr'.
 
  28 class (IsoFunctor repr, ProductFunctor repr, SumFunctor repr, Slugable repr) => Testable repr
 
  30 instance (IsoFunctor repr, ProductFunctor repr, SumFunctor repr, Slugable repr) => Testable repr