[Haskell-cafe] generic filter through MonadPlus

Jason Dusek jason.dusek at gmail.com
Thu May 21 22:13:32 EDT 2009


  It seems reasonable that filter should be generic. The
  underlying container need only support some kind of traversal,
  a zero element and a concatenation that eliminates zeroes.

  A `Monad` provides traversal via `join` and `fmap`; the
  remaining qualities are satisfied by `MonadPlus`. I've put
  together an implementation of `filter` for `MonadPlus` that
  works well enough for lists (though it presents somewhat
  greater obstacles to efficient compilation).

  I'm not sure whether `filter` is important enough to warrant
  its own generics package -- it's one of many collection
  operations that need to be generified. I'd like to know what
  folks think about the use of `MonadPlus` in this case.

--
Jason Dusek


 |...an implementation of `filter`...|
  http://github.com/jsnx/genfil/blob/246026b975ec13587186681b7b346ae1e440d0c9/Data/Filter.hs


More information about the Haskell-Cafe mailing list