Simon,<br><br>I am familiar with the GHC library as I had used it a year or so ago to create a very cheap Haddock knockoff. I used the GHC library to do the type inference (which Haddock didn't do at the time) and to deal with elements that didn't have source code available. I remember that I created it specifically because I couldn't get Haddock to work on the GHC API in a useful way. I am looking forward to the result of the SoC project.
<br><br>IIRC, the GHC API needs to be modified to provide (better) support for parsing and typechecking code with syntax errors. That is something that I can probably do when I get to that point.<br><br>Even if a tool is implemented using the GHC library, it is likely that it would need to limit itself to some subset of GHC's features. For example, an IDE that had a &quot;define instance&quot; feature would need special code to deal with associated types. Similarly, it is better for a tool to refuse to operate on code using implicit parameters rather than (silently) fail to handle them properly, because people tend to hate tools that are really convenienty but occasionally mess up their programs.
<br><br>Regards, <br>Brian<br><br><br><div><span class="gmail_quote">On 8/18/06, <b class="gmail_sendername">Simon Peyton-Jones</b>
 &lt;<a href="mailto:simonpj@microsoft.com" target="_blank" onclick="return top.js.OpenExtLink(window,event,this)">
simonpj@microsoft.com</a>&gt; wrote:</span><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
<div>








<div link="blue" vlink="purple" lang="EN-GB">

<div>

<p><span style="font-size: 11pt; color: rgb(31, 73, 125);">Brian</span></p>

<p><span style="font-size: 11pt; color: rgb(31, 73, 125);">&nbsp;</span></p>

<p><span style="font-size: 11pt; color: rgb(31, 73, 125);">Great! </span></p>

<p><span style="font-size: 11pt; color: rgb(31, 73, 125);">&nbsp;</span></p>

<p><span style="font-size: 11pt; color: rgb(31, 73, 125);">You might like to consider using GHC as a library</span></p>

<p><span style="font-size: 11pt; color: rgb(31, 73, 125);">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <a href="http://haskell.org/haskellwiki/GHC/As_a_library" target="_blank" onclick="return top.js.OpenExtLink(window,event,this)">http://haskell.org/haskellwiki/GHC/As_a_library
</a></span></p>

<p><span style="font-size: 11pt; color: rgb(31, 73, 125);">&nbsp;</span></p>

<p><span style="font-size: 11pt; color: rgb(31, 73, 125);">The advantage is that you just &quot;import GHC&quot; and then you can
parse all of Haskell (including GHC's extensions).&nbsp; Then you can rename it to
resolve lexical scopes, typecheck, and so on.&nbsp; It will certainly deal with all
of Darcs… because GHC compiles Darcs.</span></p>

<p><span style="font-size: 11pt; color: rgb(31, 73, 125);">&nbsp;</span></p>

<p><span style="font-size: 11pt; color: rgb(31, 73, 125);">It's all supposed to be a good basis for tools that consume and
analyse Haskell programs, which is exactly what you propose to do.&nbsp; Example,
there's a summer-of-code project to use it for Haddock.</span></p>

<p><span style="font-size: 11pt; color: rgb(31, 73, 125);">&nbsp;</span></p>

<p><span style="font-size: 11pt; color: rgb(31, 73, 125);">That said, the API is really just what we needed to build GHC
itself.&nbsp; It needs a serious design effort.&nbsp; One of the things that would motivate
such an effort would be &quot;customers&quot; saying &quot;I needed to do X with the API and
it was inconvenient/impossible&quot;.&nbsp; Still, it does work, today.</span></p>

<p><span style="font-size: 11pt; color: rgb(31, 73, 125);">&nbsp;</span></p>

<p><span style="font-size: 11pt; color: rgb(31, 73, 125);">Simon</span></p>

<p><span style="font-size: 11pt; color: rgb(31, 73, 125);">&nbsp;</span></p>

<div style="border-style: none none none solid; border-color: -moz-use-text-color -moz-use-text-color -moz-use-text-color blue; border-width: medium medium medium 1.5pt; padding: 0cm 0cm 0cm 4pt;">

<div>

<div style="border-style: solid none none; border-color: rgb(145, 192, 255) -moz-use-text-color -moz-use-text-color; border-width: 1pt medium medium; padding: 3pt 0cm 0cm;">

<p><b><span style="font-size: 9pt;" lang="EN-US">From:</span></b><span style="font-size: 9pt;" lang="EN-US">
<a href="mailto:haskell-cafe-bounces@haskell.org" target="_blank" onclick="return top.js.OpenExtLink(window,event,this)">haskell-cafe-bounces@haskell.org</a> [mailto:<a href="mailto:haskell-cafe-bounces@haskell.org" target="_blank" onclick="return top.js.OpenExtLink(window,event,this)">



haskell-cafe-bounces@haskell.org</a>] <b>On
Behalf Of </b>Brian Smith<br>
<b>Sent:</b> 17 August 2006 17:01<br>
<b>To:</b> <a href="mailto:haskell-cafe@haskell.org" target="_blank" onclick="return top.js.OpenExtLink(window,event,this)">haskell-cafe@haskell.org</a><br>
<b>Subject:</b> [Haskell-cafe] Description of Haskell extensions used by
FPTOOLS</span></p>

</div>

</div></div><div><span>

<p>&nbsp;</p>

<p>Is there any design document for the FPTOOLS libraries or
some description of language features that are (allowed to be) used in them?<br>
<br>
I am going to be taking some significant time off from my normal jobs in the
upcoming months. During part of that time, I would like to do some work to
improve the Haskell toolchain. This involves creating or improving tools that
parse and analyze Haskell code. My goal is to have these tools support enough
of Haskell to be able to handle at least the most important libraries used by
Haskell programmers. In particular, this includes all or most of the libraries
in FPTOOLS. Plus, I want these tools to operate on Darcs as it is an obvious
poster-child for Haskell. Thus, I need to support Haskell 98 plus all the
extensions being used in Darcs and FPTOOLS as of approx. March, 2007 (as I
intened to start working again at that time). <br>
<br>
It would be very nice if there was some document that described &quot;Haskell
98 plus all the extensions being used in Darcs and FPTOOLS as of March,
2007.&quot; Besides being useful to me, it would be a useful guide for
potential contributors to FPTOOLS. <br>
<br>
Regards,<br>
Brian</p>

</span></div><div></div>

</div>

</div>


</div></blockquote></div><br>