<p dir="ltr">I'm not sure if it really could work out at all. The concept is that I want the newtype wrapper to get the class defaults the wrapped type would have gotten (whether the wrapped type is actually a class instance or not).</p>
<div class="gmail_quote">On Aug 24, 2015 8:39 AM, "Richard Eisenberg" <<a href="mailto:eir@cis.upenn.edu">eir@cis.upenn.edu</a>> wrote:<br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word"><div>I have a hard time fully understanding this request without more context. But I do think I understand the last paragraph. And it seems bound to create class incoherence. What if someone else *does* write that orphan instance you're avoiding writing?</div><div><br></div><div>Richard</div><br><div><div>On Aug 22, 2015, at 12:54 PM, David Feuer <<a href="mailto:david.feuer@gmail.com" target="_blank">david.feuer@gmail.com</a>> wrote:</div><br><blockquote type="cite"><p dir="ltr">>From time to time, a library lacks an instance for something that I want. For example, I may need to convert</p><p dir="ltr">data Foo = Bar (Vector Baz)</p><p dir="ltr">to FishFood, but (to avoid unreasonable dependencies) Vector doesn't have a ToFishFood instance, so I can't just write</p><p dir="ltr">instance ToFishFood Foo</p><p dir="ltr">and (using Generic magic) be done with it. Instead, I must write the instance completely by hand, which could be painful. I *could* write an orphan instance, but orphans are evil.</p><p dir="ltr">What I wish I could do:</p><p dir="ltr">newtype Vec a = Vec (Vector a)</p><p dir="ltr">instance ToFishFood a => (newtype Vec) a where<br>
-- if needed<br>
toFishFood (v :: Vector a) = ...</p><p dir="ltr">That is, I want to write a super-secret orphan instance for Vector and transfer it to Vec via GND precisely when it is legal to do so. The secret instance could itself be derived (if the constructors are visible) or could make use of default member definitions.</p>
_______________________________________________<br>ghc-devs mailing list<br><a href="mailto:ghc-devs@haskell.org" target="_blank">ghc-devs@haskell.org</a><br><a href="http://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-devs" target="_blank">http://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-devs</a><br></blockquote></div><br></div></blockquote></div>