<div dir="auto"><div>Simon,<div dir="auto"><br></div><div dir="auto">Great and thorough explanation!</div><div dir="auto"><br></div><div dir="auto">Indeed the CLC was not sufficiently thorough here. I'm really sorry to anyone this deprecation notice has negatively impacted (Conal and Sandy, probably others). I should have been more vocal in the past about my thoughts that this was a bad idea. Since then, even more has been discovered which shows this to not be good overall. Again, I'm very sorry to anyone the deprecation notice may have negatively affected, and we will work harder to make sure things like this happen with as little frequency as possible.</div><div dir="auto"><br></div><div dir="auto">Also, FWIW, I'm in favour of (C), do nothing but correct the documentation, because I actually do use D.S.{First,Last} relatively often, especially with Foldable1. As I mentioned on the GHC Trac, I use both of these qualified.</div><div dir="auto"><br></div><div dir="auto">Thanks Simon for all of your work and all of your sleuthing.</div><br><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Apr 10, 2020, 8:30 PM Simon Jakobi via Libraries <<a href="mailto:libraries@haskell.org">libraries@haskell.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi!<br>
<br>
For two years there has been a plan ([1], [12]) to deprecate and<br>
eventually remove Data.Monoid.{First,Last} ([13]), in order to resolve<br>
the name conflict with Data.Semigroup.{First,Last} ([14]).<br>
<br>
While implementing ([2]) this plan in GHC and the core libraries, and<br>
testing the migration in a few packages, I encountered some<br>
difficulties which made me question whether the benefits of the<br>
deprecation would outweigh its costs:<br>
<br>
* Code that previously used Data.Monoid.{First,Last} becomes noisier.<br>
See e.g. a patch to migrate the summoner package ([3]).<br>
<br>
* Higher Kinded Data applications of D.M.{First,Last} such as in<br>
higgledy ([4]) are difficult to migrate, partly due to missing<br>
instances for D.S.{First,Last} ([5]).<br>
<br>
* Additionally, there's an important difference in the strictness of<br>
the Semigroup instances for D.M.{First.Last} and the suggested<br>
replacement of (Maybe D.S.{First,Last}): [6], [9].<br>
<br>
In sum, the existing migration story is painful in multiple ways.<br>
<br>
Moreover, D.S.{First,Last} don't actually seem to be useful in<br>
practice. I couldn't find any code using them except to define the<br>
usual newtype instances.<br>
<br>
In consequence, I think the deprecation should be scrapped, and the<br>
documentation of base updated accordingly.<br>
<br>
Regarding alternative ways to resolve the name clash, I see the<br>
following options:<br>
<br>
A) Deprecate and remove D.S.{First,Last}.<br>
B) Rename D.S.{First,Last}.<br>
C) Do nothing. Haskellers are already used to handling the name clash,<br>
usually via qualified imports.<br>
<br>
I would also like to mention that the process surrounding the<br>
deprecation has IMHO been somewhat less than ideal:<br>
<br>
1. The deprecation was apparently decided without much research on how<br>
D.M.{First,Last} are being used in the ecosystem, and without properly<br>
testing the suggested migration.<br>
<br>
2. Apart from the brief discussion on the libraries mailing list and<br>
changes to the haddocks ([7], [8]) for D.M.{First,Last}, there appears<br>
not to have been any announcement of the planned deprecation.<br>
<br>
3. When, shortly after the haddocks changes, the strictness<br>
differences between D.M.First and (Maybe D.S.First) were pointed out<br>
on the libraries mailing list ([9]), the deprecation was apparently<br>
not reconsidered, nor the documentation updated. I myself wasn't aware<br>
of this aspect while I worked on the deprecation!<br>
<br>
4. I should have sent this email 9 months ago, when I stopped working<br>
on the deprecation. The incorrect information in the haddocks has<br>
since caused some confusion ([10], [11]).<br>
<br>
What do you think?<br>
<br>
Cheers,<br>
Simon<br>
<br>
[1] <a href="https://mail.haskell.org/pipermail/libraries/2018-April/028712.html" rel="noreferrer noreferrer" target="_blank">https://mail.haskell.org/pipermail/libraries/2018-April/028712.html</a><br>
[2] <a href="https://gitlab.haskell.org/ghc/ghc/-/merge_requests/842" rel="noreferrer noreferrer" target="_blank">https://gitlab.haskell.org/ghc/ghc/-/merge_requests/842</a><br>
[3] <a href="https://github.com/kowainik/summoner/pull/319" rel="noreferrer noreferrer" target="_blank">https://github.com/kowainik/summoner/pull/319</a><br>
[4] <a href="https://github.com/i-am-tom/higgledy/issues/4" rel="noreferrer noreferrer" target="_blank">https://github.com/i-am-tom/higgledy/issues/4</a><br>
[5] <a href="https://gitlab.haskell.org/ghc/ghc/issues/16636" rel="noreferrer noreferrer" target="_blank">https://gitlab.haskell.org/ghc/ghc/issues/16636</a><br>
[6] <a href="https://gitlab.haskell.org/ghc/ghc/issues/17967" rel="noreferrer noreferrer" target="_blank">https://gitlab.haskell.org/ghc/ghc/issues/17967</a><br>
[7] <a href="https://gitlab.haskell.org/ghc/ghc/-/commit/e34e30e492a7bc40e3da5a05b8e297acb0aeeadc" rel="noreferrer noreferrer" target="_blank">https://gitlab.haskell.org/ghc/ghc/-/commit/e34e30e492a7bc40e3da5a05b8e297acb0aeeadc</a><br>
[8] <a href="https://gitlab.haskell.org/ghc/ghc/-/commit/cf35ab9ac7e0f33e39af6af16ecf850e24c2cb79" rel="noreferrer noreferrer" target="_blank">https://gitlab.haskell.org/ghc/ghc/-/commit/cf35ab9ac7e0f33e39af6af16ecf850e24c2cb79</a><br>
[9] <a href="https://mail.haskell.org/pipermail/libraries/2018-May/028818.html" rel="noreferrer noreferrer" target="_blank">https://mail.haskell.org/pipermail/libraries/2018-May/028818.html</a><br>
[10] <a href="https://github.com/conal/checkers/issues/44" rel="noreferrer noreferrer" target="_blank">https://github.com/conal/checkers/issues/44</a><br>
[11] <a href="https://gitlab.haskell.org/ghc/ghc/issues/18041" rel="noreferrer noreferrer" target="_blank">https://gitlab.haskell.org/ghc/ghc/issues/18041</a><br>
[12] <a href="https://gitlab.haskell.org/ghc/ghc/issues/15028" rel="noreferrer noreferrer" target="_blank">https://gitlab.haskell.org/ghc/ghc/issues/15028</a><br>
[13] <a href="http://downloads.haskell.org/~ghc/8.10.1/docs/html/libraries/base-4.14.0.0/Data-Monoid.html#t:First" rel="noreferrer noreferrer" target="_blank">http://downloads.haskell.org/~ghc/8.10.1/docs/html/libraries/base-4.14.0.0/Data-Monoid.html#t:First</a><br>
[14] <a href="http://downloads.haskell.org/~ghc/8.10.1/docs/html/libraries/base-4.14.0.0/Data-Semigroup.html#t:First" rel="noreferrer noreferrer" target="_blank">http://downloads.haskell.org/~ghc/8.10.1/docs/html/libraries/base-4.14.0.0/Data-Semigroup.html#t:First</a><br>
_______________________________________________<br>
Libraries mailing list<br>
<a href="mailto:Libraries@haskell.org" target="_blank" rel="noreferrer">Libraries@haskell.org</a><br>
<a href="http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries" rel="noreferrer noreferrer" target="_blank">http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries</a><br>
</blockquote></div></div></div>