<html>
<head>
<style>
.hmmessage P
{
margin:0px;
padding:0px
}
body.hmmessage
{
FONT-SIZE: 10pt;
FONT-FAMILY:Tahoma
}
</style>
</head>
<body class='hmmessage'>Let me cut to the chase, again:<BR>
 <BR>
 Everyone will probably be satisfied. <BR>
 For a very small "everyone". :) <BR>
 <BR>
The underlying implementation shall be "heavily" parameterized.<BR>
There shall be three visible pre packaged configurations.<BR>
Power users, and clever and crazy people can experiment beyond those three.<BR>
The EXACT three configurations is SLIGHTLY up in the air, but is likely to be:<BR>
 <BR>
NT386<BR>
  same as today, integrated backend, Win32 GUI, msvc*.dll, native win32 kernel threads, native backslashy paths (and perhaps increased compat with forward slashes, some of that is already in, m3core, but not yet cm3), Visual C++ compiler and linker.<BR>
 <BR>
NT386MINGNU<BR>
  same as today's (recent) NT386GNU, but with Trestle-on-Win32 also working <BR>
   external backend, gcc compiler and linker, but otherwise same as NT386<BR>
  One small wrinkle here is there is no m3gdb, but you can use the m3gdb from the next one, or Cygwin's gdb.<BR>
 <BR>
NT386GNU<BR>
  As GNU as possible. pthreads (uncertain), X Windows (CygwinX), Cygwin C library, stupid looking paths that start /cygdrive, wierdo symlinks that don't interoperate well with the rest of the system (attempting to run cc.exe crashes ntvdm.exe, for example), "link" makes file system links (or at least strange files) instead of linking programs, a slow and perhaps fragile copy-immediately implementation of fork, problems running one type of program from another because you don't know which command line parameters and which environment variables represent paths or lists of paths and therefore how to translate them, etc. <BR><BR>
The underlying parameters, which are largely independent and which you can change individually, but which you will actually just ignore usually, shall be:<BR>
 <BR>
  modula-3 backend<BR>
     integrated 0<BR>
     cm3cg 1<BR>
   This might be replaced by the existing 0-3 variable.<BR>
 <BR>
  C compiler  <BR>
    Visual C++ cl 0<BR>
    gcc 1<BR>
    In future this could be redefined as decimal digit or a character to accomodate other choices.<BR>
 <BR>
  linker<BR>
     Visual C++ link 0<BR>
     gcc 1<BR>
    In future this could be redefined as decimal digit or a character to accomodate other choices.<BR>
 <BR>
   Threading library<BR>
     Native Win32 kernel threads 0<BR>
     Cygwin pthreads which are probably layered on native Win32 kernel threads 1<BR>
     This is the one area where people have suggested using native Win32 functionality instead of Cygwin<BR>
     vtalaram user threads probably not available<BR>
     fiber user threads probably not available<BR>
          This would have been better than vtalaram, but not Win9x compatible<BR>
     If anyone wanted user vtlaram or fiber, this could be extended. It probably always should have been fibers instead of setjmp/longjmp where fibers are available...<BR>
 <BR>
   Window library<BR>
      Native Win32 gui 0 (hopefully with bugs to be worked out) <BR>
      X Windows via CygwinX 1 (hopefully the binaries are X server agnostic, and even work against a remote Unix machine?)<BR>
 <BR>
    C library<BR>
      native msvcr* through Visual C++ or MinGWin 0<BR>
      Cygwin and its path oddities 1 <BR>
 <BR>
The current notion of "OSTYPE" becomes much less useful here, as it previously embodied multiple factors.<BR>
 It wasn't all that useful anyway, imho, but as a way to reduce the matrix of targets down to two, the same two in multiple places. Now, in a few places, you check a more specific variable. Theoretically, I don't have to change cm3 here, just the config file and some m3makefiles. Because, tricky tricky, the main thing cm3 cares about is the backend "mode", and that does match up above with the 0/1. There are actually 4 modes and I should maybe hoist that up to be the variable, very maybe. A few m3makefiles will have to change, in small ways.<BR>
 <BR>
  Therefore, NT386 is all 0s, NT386GNU shall be all 1s, except maybe threading, and NT386MINGNU shall be a mix -- backend, C compiler, linker 1, the rest 0. Besides that, what I haven't in my head yet, is that individual m3makefiles should be able to ask for one compiler or the other. The base system won't do that, but user systems could, if they have some code that depends on one compiler or the other and they are going to link it together. For this purpose, for exposing these features to users, possibly values other than "0" and "1" are needed.<BR>
 <BR>
If the configuration is one of these three combinations, build_dir is translated as shown.<BR>
Otherwise, it is "NT386-" plus the unreadable string of 0s and 1s.<BR>
 <BR>
This is essentially already commited. NT386 works this way. NT386MINGNU works this, but is for now called NT386GNU, and doesn't have any Trestle yet. The new/old Cygwin NT386GNU isn't active yet, but easily should be.<BR>
 <BR>
There are three config files, NT386, NT386MINGNU, NT386GNU, they are all just a few lines and then include NT386.common.<BR>
 <BR>
Oh, one more thing I haven't worked out is how the user asks for one target or another.<BR>
It is probably via the environment variable CM3_TARGET, though in reality, "TARGET" for all of these shall be NT386.<BR>
 <BR>
Any questions?<BR>
Don't ask me when Cygwin NT386GNU will be active or when the names will flip. I will try it soon.<BR>
 <BR>
This <EM>is essentiallyalready in the tree</EM>, with a little bit of "temporary, for compat" sprinkled in to avoid renaming NT386GNU/MINGNU just yet, and the Cygwinish stuff not active, no X Windows on NT386 yet..groundwork is laid, I think I've stopped thinking through the indecisiveness, I just keep hearing the two extreme sides, the Windows users who want Windows (do you even care about the gcc backend? It's slow. It generates inefficient code. It supports Longint) and a few Unix users who might reluctantly use Windows a little more if their backend slowed down and their libraries changed...<BR>
 <BR>
Personally my main goal here is to not feel guilty about not finishing the LONGINT support yet in the integrated backend.<BR>
I'd still like to finish that, but it was taking embarassingly long.<BR>
 <BR>
I'd also like an uber-cross build environment, where I can build anything from anything. Getting cm3cg working was part of that. I'm not sure I have the patience to build gcc and ld/binutils that many times though.<BR>
 <BR>
   - Jay<BR><BR><BR>

<HR id=stopSpelling>
<BR>
> Date: Wed, 23 Jan 2008 08:06:20 +0100<BR>> From: lemming@henning-thielemann.de<BR>> Subject: Re: [M3devel] platform/build_dir is a big tuple?<BR>> To: rcoleburn@scires.com<BR>> CC: m3devel@elegosoft.com; jayk123@hotmail.com<BR>> <BR>> <BR>> On Tue, 22 Jan 2008, Randy Coleburn wrote:<BR>> <BR>> > Jay:<BR>> ><BR>> > For my part on Windows, I am happy to stay with the underlying OS, the<BR>> > native windows threading, the integrated backend, and use the free<BR>> > Microsoft Visual Studio tools. I don't really want to have to<BR>> > install/use cygwin or any of the other variants. When I see target =<BR>> > NT386, this list is what I am expecting. For the cm3 newbie coming from<BR>> > a Microsoft Windows environment, I think this list would be the most<BR>> > appealing and pose the least barrier to getting starting. Yes, I still<BR>> > will work on the installer program once I'm satisfied that I have a good<BR>> > working cm3 on Windows.<BR>> <BR>> One year ago I was in the situation to port one of my Modula-3 programs<BR>> from Linux to Windows in order to hand it over to a Windows user. As I<BR>> never use Windows, I have only a plain Windows installation on my machine<BR>> with almost no tools other than cm3. I was glad to be able to run cm3<BR>> immediately and to find all libraries that I needed in binary form without<BR>> Cygwin dependencies - otherwise not only I had to install that on my<BR>> machine but I also would have to persuade the other Windows guy to install<BR>> it as well. Summarized I strongly vote for NT386 being Windows with least<BR>> dependencies on other packages.<BR><BR><br /><hr />Connect and share in new ways with Windows Live. <a href='http://www.windowslive.com/share.html?ocid=TXT_TAGHM_Wave2_sharelife_012008' target='_new'>Get it now!</a></body>
</html>