<div dir="ltr"><div dir="ltr">Thanks Sam, apologies if I'm being dumb, but I'm not seeing the relevance of 'boilerplate'.</div><div><br></div><div>I'm not trying to implement other compilers' language extensions (as would be clear from my occasional posts on the Hugs list). If you want GHC extensions, use GHC.</div><div><br></div><div>There's no hope of writing stock H98 or even H2010 code. The last Hugs release (2006, used in HugsMode) has extensions way beyond the H2010 standard. I'm not trying to write code that's portable between GHC/Hugs.</div><div><br></div><div>I'm tinkering with Hugs to give it semantics that GHC doesn't support/not even with all its extensions switched on. I'm tinkering in Hugs because it seems to be achievable whereas I just have no idea how to build GHC; and I suspect that even if I figured that out, tinkering inside GHC would be orders of magnitude more complex, because I'd keep running into all sorts of type-acrobat stuff from all of GHC's extensions.</div><div><br></div><div>And I say "more complex" even though GHC is written in Haskell, and Hugs is written in C++ and I'd never programmed in C++ before working on Hugs; and even though C++ is imperative code, not functional. Hugs mostly uses vanilla C, with the ++ providing sourcecode edit directives -- so it goes some way towards the macro-generator of 'boilerplate' anyway.</div><div><br></div><div>Realistically for 'industrial strength' applications like Cabal, GHC is the only game in town. Cabal should be conservative and not try to use 'bleeding edge' GHC extensions, but things like MultiParam TypeClasses, FlexibleInstances are very hard to do without (Hugs supports both). What's more, I don't see how a macro-generator like 'boilerplate' is going to help. It's not like you can macro-'translate' code using MPTCs back to H98.</div><div><br></div><div>AntC</div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, 15 Oct 2020 at 02:48, Sam Halliday <<a href="mailto:sam.halliday@gmail.com">sam.halliday@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><br>
Sorry, I should have started a fresh email instead of responding to the<br>
mailing list.<br>
<br>
I just meant generally this might be of interest to you. The ability to<br>
generate the code that many language extensions are generating,<br>
therefore no need to add support in hugs. Making it easier for people to<br>
write portable stock Haskell98 code. Maybe even things like Cabal could<br>
be rewritten to use less extensions.<br>
<br>
Anthony Clayden wrote:<br>
> Hi Sam,<br>
><br>
> I'm not seeing what relevance `boilerplate` has to anything I wrote.<br>
><br>
> The compiler is generating the type for the constructors within a datatype<br>
> (whether or not the decl gives a context).<br>
><br>
> On Wed, 14 Oct 2020 at 18:55, Sam Halliday <<a href="mailto:sam.halliday@gmail.com" target="_blank">sam.halliday@gmail.com</a>> wrote:<br>
><br>
>><br>
>> Hi Anthony,<br>
>><br>
>> Did you see this?<br>
>><br>
>>   <a href="http://hackage.haskell.org/package/boilerplate" rel="noreferrer" target="_blank">http://hackage.haskell.org/package/boilerplate</a><br>
>><br>
>><br>
>><br>
<br>
-- <br>
Best regards,<br>
Sam<br>
</blockquote></div></div>