<div dir="ltr">Hello Chris,<div><br></div><div>That is what I am trying to do with this work.</div><div><br></div><div>There are still a number of problems that I need to address:</div><div><ul><li>Installing the resulting binaries</li>

<li>Signing (currently we are skipping this)</li><li>Ensure the binaries produced are identical with Make and msbuild</li><li>Add assertions to ensure that flags that we currently ignore are caught, in case we add new features in the future</li>

<li>Fix the C# compiler build (currently disabled)</li><li>Extend this to other components, so we can have the entire setup in a solution.</li></ul><div>Then we would have something that works.</div></div><div><br></div>
<div>
Miguel</div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Mon, May 26, 2014 at 11:04 AM, Chris Tacke <span dir="ltr"><<a href="mailto:ctacke@opennetcf.com" target="_blank">ctacke@opennetcf.com</a>></span> wrote:<br>

<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div lang="EN-US" link="#0563C1" vlink="#954F72"><div><p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">Miguel,<u></u><u></u></span></p>

<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"><u></u> <u></u></span></p><p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">This is great news. Are there any plans to update the build system to allow us to compile the runtime itself using Visual Studio (i.e. a Microsoft compiler)?  <u></u><u></u></span></p>

<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"><u></u> <u></u></span></p><p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">Now before everyone starts with the eye rolling and “why the hell would you want to do that?” questions, let me explain.  As of today, we can create applications in C# that will run on Windows and a large array of Linux machines (including Android) but Windows CE has been orphaned.  Microsoft is not putting any effort into the Compact Framework, but there are still people developing for Windows CE devices.  I’d like to put a last nail in the coffin of the Compact Framework by getting Mono supported on Windows CE so we can all move into using technology from the current decade, not the last one.  <u></u><u></u></span></p>

<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"><u></u> <u></u></span></p><p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">I don’t see any real path for getting the runtimes to compile for Windows CE  for ARM and 586 (not 686, since we have new Intel processors now that are 586 based).  There is an old (last touch in 2009) CeGCC project that might be a step, but I was hoping for something a little simpler.  I’m up for any suggestions.<u></u><u></u></span></p>

<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"><u></u> <u></u></span></p><p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">-Chris Tacke<u></u><u></u></span></p>

<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"><u></u> <u></u></span></p><p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"><u></u> <u></u></span></p>

<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"><u></u> <u></u></span></p><p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"><u></u> <u></u></span></p>

<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"><u></u> <u></u></span></p><div style="border:none;border-left:solid blue 1.5pt;padding:0in 0in 0in 4.0pt">

<div><div style="border:none;border-top:solid #e1e1e1 1.0pt;padding:3.0pt 0in 0in 0in"><p class="MsoNormal"><b><span style="font-size:11.0pt;font-family:"Calibri","sans-serif"">From:</span></b><span style="font-size:11.0pt;font-family:"Calibri","sans-serif""> <a href="mailto:mono-devel-list-bounces@lists.ximian.com" target="_blank">mono-devel-list-bounces@lists.ximian.com</a> [mailto:<a href="mailto:mono-devel-list-bounces@lists.ximian.com" target="_blank">mono-devel-list-bounces@lists.ximian.com</a>] <b>On Behalf Of </b>Miguel de Icaza<br>

<b>Sent:</b> Friday, May 23, 2014 9:59 PM<br><b>To:</b> mono-devel<br><b>Subject:</b> [Mono-dev] Update on Build System<u></u><u></u></span></p></div></div><div><div class="h5"><p class="MsoNormal"><u></u> <u></u></p><div>

<p class="MsoNormal">Hey guys,<u></u><u></u></p><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">#1 Makefile Build System Update<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p>

</div><div><p class="MsoNormal">So the clean staged setup has been added to mono/master and in practice most of you will never notice an improvement.   <u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p>

</div><div><p class="MsoNormal">Those working on libraries that had cross dependencies will enjoy reliable and working builds.   If you make a change in say System, and you type "make" in mcs/class/System, it will make sure that all the dependencies are properly compiled and the result will be stable.<u></u><u></u></p>

</div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">#2 MSBuild setup<u></u><u></u></p></div><div><p class="MsoNormal"><br>Based on the work above, I have updated the MSBuild setup, and it is now possible to build most of the managed code with xbuild.   This means that you can use this from Visual Studio or Xamarin Studio.<u></u><u></u></p>

</div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">Since xbuild does not support passing /keyfile to the C# compiler, I still have to fix about 6-7 assemblies that use -keyfile to be signed.   <u></u><u></u></p>

</div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">Once that happens, you should be able to build all of Mono's managed code with:<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p>

</div><div><p class="MsoNormal">xbuild msvc/scripts/net_4_5.sln<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">Currently I disabled generating project files for profiles other than 4.5, just because it is easier to debug this way.<u></u><u></u></p>

</div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">I am also a bit sad that our xbuild does not have any support for parallel builds, it would have been a neat hack to make the xbuild-based build system parallel and get this for free.<u></u><u></u></p>

</div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">#3 Future Parallel Work - Makefiles<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">I tried to implement parallel builds for mcs/class/Facades, and while it works, it regressed some of the other standard targets that we have (the other -local).   I will have to revisit this later.<u></u><u></u></p>

</div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">But the principle behind the patch that enabled this could be used for mcs/class and parallelize all the builds as well.   We only need to (a) generate the assembly dependencies [1] and (b) we need to figure out the -local target breakage (same stuff I broke for Facades).<u></u><u></u></p>

</div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">[1]  (which we have from the xbuild work above)<u></u><u></u></p></div><div><p class="MsoNormal">Miguel<u></u><u></u></p></div></div></div>

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