Skip to content

Instantly share code, notes, and snippets.

@hgiasac
Created January 4, 2019 17:55
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save hgiasac/e891bb8eeb86c021a9958c9d865338fd to your computer and use it in GitHub Desktop.
Save hgiasac/e891bb8eeb86c021a9958c9d865338fd to your computer and use it in GitHub Desktop.
data AppResult t where
App :: TypeRep a -> TypeRep b -> AppResult (a b)
splitApp :: TypeRep a -> Maybe (AppResult a)
splitApp (TrApp _ ra rb) = Just $ App ra rb
splitApp _ = Nothing
dynFst :: Dynamic -> Maybe Dynamic
dynFst (Dyn rpab x) = do
App rpa rb <- splitApp rpab
App rp ra <- splitApp rpa
Refl <- eqT rp (typeRep :: TypeRep (,))
return $ Dyn ra (fst x)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment