[Haskell-cafe] nubBy changed?

Ross Paterson ross at soi.city.ac.uk
Sun Mar 1 19:56:48 EST 2009


On Sun, Mar 01, 2009 at 02:30:34PM -1000, Tim Newsham wrote:
> Did nubBy change recently?  In 6.8.2 I could generate primes as:
>
>    nubBy (\a b -> b `mod` a == 0) [2..]
>
> but in 6.10.1 I have to use
>
>    nubBy (\a b -> a `mod` b == 0) [2..]
>
> Is this change intentional?  If so, what is the reason?

Tue Sep  2 10:29:50 BST 2008  Simon Marlow <marlowsd at gmail.com>
  * #2528: reverse the order of args to (==) in nubBy to match nub
  This only makes a difference when the (==) definition is not
  reflexive, but strictly speaking it does violate the report definition
  of nubBy, so we should fix it.

See also: http://hackage.haskell.org/trac/ghc/ticket/2528
http://www.haskell.org/onlinereport/list.html#sect17.6

The Report imposes the precondition that the relation be an equivalence,
so your use was out of spec.

Still, perhaps it would have been better to fix #2528 by changing nub
instead of nubBy.  As it is the USE_REPORT_PRELUDE versions of nub and
nubBy differ from the faster versions.  (And the comment on elem_by is
untrue.)


More information about the Haskell-Cafe mailing list