Skip to content

Implement gzipQ #33

@isovector

Description

@isovector

The following corresponds to gzip, but as a twin query. It took me a few hours to work my head around the twins module, so I thought I'd share it for the next unwitting passerby. Definitely worth a merge, IMO

gzipQ :: forall r. GenericQ (GenericQ [r]) -> GenericQ (GenericQ [r])
gzipQ f = go
  where
    go :: GenericQ (GenericQ [r])
    go x y = f x y <>
      if toConstr x == toConstr y
        then join $ gzipWithQ go x y
        else mempty

mkQQ :: (Monoid r, Typeable a, Typeable b) => (a -> b -> r) -> GenericQ (GenericQ r)
mkQQ f a1 a2 =
  case (cast a1, cast a2) of
    (Just x, Just y) -> f x y
    _ -> mempty

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions