Say I have a data type like so:
data NumCol = Empty |
Single Int |
Pair Int Int |
Lots [Int]
Now I wish to filter out the elements matching a given constructor from a [NumCol]
. I can write it for, say, Pair
:
get_pairs :: [NumCol] -> [NumCol]
get_pairs = filter is_pair
where is_pair (Pair _ _) = True
is_pair _ = False
This works, but it's not generic. I have to write a separate function for is_single
, is_lots
, etc.
I wish instead I could write:
get_pairs = filter (== Pair)
But this only works for type constructors that take no arguments (i.e. Empty
).
So the question is, how can I write a function that takes a value and a constructor, and returns whether the value matches the constructor?
question from:https://stackoverflow.com/questions/25587501/test-if-a-value-matches-a-constructor