One fairly clear thing is that the mzlib manual can move into the compatibility-lib.<div><br></div><div>We could move the mzlib-specific files from (the collection) tests/racket into a new tests/mzlib and put that into the compatibility-lib.</div>
<div><br></div><div>But that probably requires actual adjustments because tests/racket is load-based ...</div><div><br></div><div>Probably all of the mzlib-specific tests could be made to run in a #lang context without too much trouble, tho.</div>
<div><br></div><div>Robby<br><br>On Thursday, June 27, 2013, Sam Tobin-Hochstadt  wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">I&#39;ve kept tests and docs where they are, because I don&#39;t know what, if<br>

any, plans Matthew might already have about splitting those.  I&#39;m<br>
happy to follow such plans as needed.<br>
<br>
Sam<br>
<br>
On Thu, Jun 27, 2013 at 10:48 PM, Robby Findler<br>
&lt;<a>robby@eecs.northwestern.edu</a>&gt; wrote:<br>
&gt; Is there a plan for moving the mzlib tests and docs from pkgs/racket-lib to<br>
&gt; pkgs/compatibility-lib? (I didn&#39;t move the mzlib/contract ones yet because I<br>
&gt; wasn&#39;t sure what to do. I can do stuff, tho, if you&#39;re not already.)<br>
&gt;<br>
&gt; Robby<br>
&gt;<br>
&gt; On Thursday, June 27, 2013, Sam Tobin-Hochstadt wrote:<br>
&gt;&gt;<br>
&gt;&gt; Yes, since `scheme/mzscheme` is the same language for the (many) parts<br>
&gt;&gt; of the core that need it.  There are a number of other small bits that<br>
&gt;&gt; I&#39;ll do as well.<br>
&gt;&gt;<br>
&gt;&gt; On Thu, Jun 27, 2013 at 8:45 PM, Robby Findler<br>
&gt;&gt; &lt;<a>robby@eecs.northwestern.edu</a>&gt; wrote:<br>
&gt;&gt; &gt; Did you consider moving &quot;#lang mzscheme&quot; out as well?<br>
&gt;&gt; &gt;<br>
&gt;&gt; &gt; Robby<br>
&gt;&gt; &gt;<br>
&gt;&gt; &gt;<br>
&gt;&gt; &gt; On Thursday, June 27, 2013, Sam Tobin-Hochstadt wrote:<br>
&gt;&gt; &gt;&gt;<br>
&gt;&gt; &gt;&gt; I&#39;ve now pushed this set of changes, which pass all the racket tests<br>
&gt;&gt; &gt;&gt; and build the whole system cleanly.  I think the next steps are:<br>
&gt;&gt; &gt;&gt;<br>
&gt;&gt; &gt;&gt; - Robby is going to move mzlib/contract.<br>
&gt;&gt; &gt;&gt; - Matthew is going to modify mzlib/compiler and mzlib/unit200.<br>
&gt;&gt; &gt;&gt; - Ryan is working on shrinking the db collection.<br>
&gt;&gt; &gt;&gt; - I posted about shrinking the `pkg` collection and working toward<br>
&gt;&gt; &gt;&gt; removing parts of the `net` collection.<br>
&gt;&gt; &gt;&gt;<br>
&gt;&gt; &gt;&gt; There are also some parts of some collections that aren&#39;t needed. Much<br>
&gt;&gt; &gt;&gt; of `openssl` could go if `pkg` was split. The decompiler and<br>
&gt;&gt; &gt;&gt; demodularizer could potentially be moved out. Perhaps distributed<br>
&gt;&gt; &gt;&gt; places could move.<br>
&gt;&gt; &gt;&gt;<br>
&gt;&gt; &gt;&gt; Other things to would, in my estimation, be much harder, and would<br>
&gt;&gt; &gt;&gt; probably be things that are part of `#lang racket`, like the class or<br>
&gt;&gt; &gt;&gt; unit systems or `match`, or things that are deeply intertwined with<br>
&gt;&gt; &gt;&gt; `raco setup`, like planet.<br>
&gt;&gt; &gt;&gt;<br>
&gt;&gt; &gt;&gt; Sam<br>
&gt;&gt; &gt;&gt;<br>
&gt;&gt; &gt;&gt; On Wed, Jun 26, 2013 at 6:38 PM, Robby Findler<br>
&gt;&gt; &gt;&gt; &lt;<a>robby@eecs.northwestern.edu</a>&gt; wrote:<br>
&gt;&gt; &gt;&gt; &gt; I can move mzlib/contract after you get done with other stuff.<br>
&gt;&gt; &gt;&gt; &gt;<br>
&gt;&gt; &gt;&gt; &gt; Robby<br>
&gt;&gt; &gt;&gt; &gt;<br>
&gt;&gt; &gt;&gt; &gt;<br>
&gt;&gt; &gt;&gt; &gt; On Wednesday, June 26, 2013, Sam Tobin-Hochstadt wrote:<br>
&gt;&gt; &gt;&gt; &gt;&gt;<br>
&gt;&gt; &gt;&gt; &gt;&gt; On Tue, Jun 25, 2013 at 4:32 PM, Sam Tobin-Hochstadt<br>
&gt;&gt; &gt;&gt; &gt;&gt; &lt;<a>samth@ccs.neu.edu</a>&gt;<br>
&gt;&gt; &gt;&gt; &gt;&gt; wrote:<br>
&gt;&gt; &gt;&gt; &gt;&gt; &gt; While moving some files around between packages, I realized that<br>
&gt;&gt; &gt;&gt; &gt;&gt; &gt; there<br>
&gt;&gt; &gt;&gt; &gt;&gt; &gt; are a number of things that could be moved out of the core and<br>
&gt;&gt; &gt;&gt; &gt;&gt; &gt; into<br>
&gt;&gt; &gt;&gt; &gt;&gt; &gt; packages.  Here&#39;s a partial list of things that I think are not<br>
&gt;&gt; &gt;&gt; &gt;&gt; &gt; needed<br>
&gt;&gt; &gt;&gt; &gt;&gt; &gt; at all by the rest of the core:<br>
&gt;&gt; &gt;&gt; &gt;&gt;<br>
&gt;&gt; &gt;&gt; &gt;&gt; I&#39;ve now done the first step of this work.  You can see the results<br>
&gt;&gt; &gt;&gt; &gt;&gt; here: <a href="https://github.com/plt/racket/pull/373" target="_blank">https://github.com/plt/racket/pull/373</a><br>
&gt;&gt; &gt;&gt; &gt;&gt;<br>
&gt;&gt; &gt;&gt; &gt;&gt; This works to the degree that the core still compiles.  No other<br>
&gt;&gt; &gt;&gt; &gt;&gt; testing has happened yet -- that&#39;s the next step. A number of<br>
&gt;&gt; &gt;&gt; &gt;&gt; packages<br>
&gt;&gt; &gt;&gt; &gt;&gt; will need additional dependencies.<br>
&gt;&gt; &gt;&gt; &gt;&gt;<br>
&gt;&gt; &gt;&gt; &gt;&gt; I&#39;d like to get feedback on exactly how this is organized.  In<br>
&gt;&gt; &gt;&gt; &gt;&gt; particular, a bunch of things are now in a `compatibility-lib`<br>
&gt;&gt; &gt;&gt; &gt;&gt; collection:<br>
&gt;&gt; &gt;&gt; &gt;&gt;<br>
&gt;&gt; &gt;&gt; &gt;&gt; * almost all of `mzlib`<br>
&gt;&gt; &gt;&gt; &gt;&gt; * `compatibility/*`<br>
&gt;&gt; &gt;&gt; &gt;&gt; * `racket/mpair` and `racket/mlist`<br>
&gt;&gt; &gt;&gt; &gt;&gt;<br>
&gt;&gt; &gt;&gt; &gt;&gt; There&#39;s also the following new packages: `e</blockquote></div>