<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Sat, Jan 16, 2016 at 6:00 AM, Mariano Martinez Peck <span dir="ltr">&lt;<a href="mailto:marianopeck@gmail.com" target="_blank">marianopeck@gmail.com</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"> <br><div dir="ltr">Hi all,<div><br></div><div>Sorry for reviving an old thread but I thought it was better to continue the discussion here because of the context. </div><div>As you may have read, the other day I released a first approeach to a subset of OSProcess based on FFI (posix_spwan() family of functions):</div><div><br></div><div><a href="https://github.com/marianopeck/OSSubprocess" target="_blank">https://github.com/marianopeck/OSSubprocess</a><br></div><div><br></div><div> And with that in mind, I wanted to share a few things with you. The main 2 problems I found with implementing this with FFI was:</div><div><br></div><div>1) We have all already agree and discussed that fork+exec cannot be done in separate FFI calls. So at the very min you need either a plugin method that does the fork()+exec() OR wrapping a lib like posix_spwan()</div><div><br></div><div>2) The other main problem, is, as you all said (and mostly  Nicolas), is the problems with the preprocessor (constants, macros, etc).</div><div><br></div><div>With all that said, I was able to get my stuff working. However, I am still using some primitives of OSProcess plugin because of 2). </div><div><br></div><div>I read Eliot idea and what I don&#39;t like is the need of a C compiler in the user machine. I think that&#39;s a high constrain. Then Igor suggested that WE (developers and maintainers of a certain tool) are the ones that compiles the little C program to extract constant values etc and then WE provide as part of our source code, some packages with some SharedPool depending on the platform/OS. And Igor approach looked a bit better to me.</div></div></blockquote><div><br></div><div style="color:rgb(0,0,0);font-size:12.8px"><br class=""><br></div><div style="color:rgb(0,0,0);font-size:12.8px">You misunderstand the proposal.  The C compiler is needed /only when changing the set of constants/, i.e. when /developing/ the interface.  The C compiler is /not/ needed when deploying.</div><div style="color:rgb(0,0,0);font-size:12.8px"><br></div><div style="color:rgb(0,0,0);font-size:12.8px">The idea is to</div><div style="color:rgb(0,0,0);font-size:12.8px">a) at development time, e.g. when a new variable is added to a SharedPool containing platform constants, a C program is autogenerated that outputs in some format a description of the names and values of all the constants defined in the pool.  One convenient notation is e.g. STON.  For the purposes of this discussion let&#39;s assume we&#39;re using ston, but any format the image an parse (or indeed a shared object the image can load on teh current pkatform) will do.  The output of the autogenerated C program would be called something like &lt;SharedPoolName&gt;.&lt;PlatformName&gt;.ston, e.g. UnixConstants.MacOSX64.ston or UnixConstants.Linux32.ston.  The ston files can easily be parsed by facilities in the Smalltalk image.</div><div style="color:rgb(0,0,0);font-size:12.8px"><br></div><div style="color:rgb(0,0,0);font-size:12.8px">b) when deploying the system to a set of platforms one includes all the relevant platform-specific ston files.</div><div style="color:rgb(0,0,0);font-size:12.8px"><br></div><div style="color:rgb(0,0,0);font-size:12.8px">c) at startup the image checks its current platform.  If the platform is the same that it was saved on, no action is taken.  But if the platform as changed then the relevant ston file is selected, parsed, and the values for the variables in the shared pool updated to reflect the values of the current platform.</div><div style="color:rgb(0,0,0);font-size:12.8px"><br></div><div style="color:rgb(0,0,0);font-size:12.8px">So the C compiler is only needed when developing the interface, not when deploying it.</div><div style="color:rgb(0,0,0);font-size:12.8px"><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="ltr"><div><br></div><div>Then Nicolas made a point that if we plan to manage all that complexity at the image level it may become a hell too. </div><div><br></div><div>So.... what if we take a simpler (probably not better) approach and we consider the &quot;c program that exports constants and sizes&quot; a VM Plugin? Let&#39;s say we have a UnixPreprocessorPlugin (that would work for OSX, Linux and other&#39;s Unix I imagine for the time being) which provides a function (that is exported) which answers an array of arrays. For each constant, we include the name of the constant, the value, and the sizeof().  Then from image side, we simply do one FFI call, we get the large array and we adapt it to a SharedPool or whatever kind of object representing that info. </div></div></blockquote><div><br></div><div style="color:rgb(0,0,0);font-size:12.8px"><br class=""><br></div><div><span style="color:rgb(0,0,0);font-size:12.8px">This is what I suggestred in teh first place.  That what is autogenerated is a shared object (be it a plgin or a dll doesn&#39;t matter, it is machine code generated by a C compiler form an autogenerated C program compiled with the platform&#39;s C compiler) that can be loaded at run-time and interrogated to fetch the values of a set of variables.  But I think that the textual notation suggested above is simpler.  The test files are easier to distribute and change.</span>  Shared objects and plugins have a habit of going stale, and there needs to be metadata in there to describe the set of constants etc, which is tricky to generate and parse because it is binary (pointer sizes, etc, etc).  Instead a simple textual format should be much more robust.  One could even edit by hand to add new constants.  It would be easy to make the textual file a versioned file.  Etc, etc.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="ltr"><div><br></div><div>I know that different users will need different constants. But let&#39;s say the infrastructure (plugin etc) is already done. And let&#39;s say I am a user that I want to build something with FFI and I need some constants that I see are not defined. Then I can simply add the ones I need in the plugin, and next VM release will have those. If Cog gets moved to Github, then this is even easier. Everybody can do a PR with the constants he needs. And in fact, if we have the infrastructure in place, I think that we each of us spend half an hour, we may have almost everything we need. </div><div><br></div><div>For example, I can add myself all those for signals (to use kill() from FFI), all those from fcntl (to make none blocking pipes), all those from wait()/waitpid() family (so that I can do a waitpid() with WNOHANG), etc etc etc.</div><div><br></div><div>I know it&#39;s not the best approach but it&#39;s something that could be done very easily and would allow A LOT of stuff to be moved to FFI just because we have no access to preprocess constants or sizeof()  (to know how to allocate). I also know this won&#39;t cover macros and other stuff. But still.</div><div><br></div><div>If you think this is a good idea, I can spend the time to do it. </div><div><br></div><div>Cheers, </div><div><br></div><div><br></div><div><br></div><div><br></div><div><br></div><div><br></div><div><br></div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, May 10, 2012 at 10:09 AM, Nick Ager <span dir="ltr">&lt;<a href="mailto:nick.ager@gmail.com" target="_blank">nick.ager@gmail.com</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div>&lt;snip&gt;</div><span><div><span style="border-collapse:collapse;color:rgb(34,34,34);font-family:arial,sans-serif;font-size:13px">Well, like opendbx, maybe because opengl has quite standard interface...</span></div>
</span><div><span style="border-collapse:collapse;color:rgb(34,34,34);font-family:arial,sans-serif;font-size:13px">&lt;/snip&gt;</span></div><div><br></div><div>and</div><div><br></div><div>&lt;snip&gt;</div><span>
<div><span style="border-collapse:collapse;color:rgb(34,34,34);font-family:arial,sans-serif;font-size:13px">It&#39;s not that it&#39;s not doable, it&#39;s that we gonna reinvent gaz plant<br>and it gonna be so boring...<br>
I&#39;d like to see a proof of concept, even if we restrict to libc, libm,<br>kernel.dll, msvcrt.dll ...</span></div></span><div>&lt;/snip&gt;</div><div><br></div><div>&lt;snip&gt;</div><span><div><span style="border-collapse:collapse;color:rgb(34,34,34);font-family:arial,sans-serif;font-size:13px">Is the unix style select()<br>
ubiquitous or should I use WaitForMultipleObject() on Windows? Are<br>specification of read/write streams implementation machine independant<br>(bsd/sysv/others...) </span></div></span><div><span style="border-collapse:collapse;color:rgb(34,34,34);font-family:arial,sans-serif;font-size:13px">&lt;/snip&gt;</span></div>
<div><br></div><div>Perhaps *a* way forward is to try to find existing projects which have already created cross-platform abstractions for platform specific functionality. Then we can use FFI to access that interface in a similar way to OpenGL and OpenDBX. For example NodeJs works across unixes - perhaps they have a useful cross-platform abstraction, boost  has abstractions of IPC etc </div><span><font color="#888888">
<div><br></div><div>Nick</div>
</font></span></blockquote></div><br><br clear="all"><div><br></div>-- <br><div>Mariano<br><a href="http://marianopeck.wordpress.com" target="_blank">http://marianopeck.wordpress.com</a><br></div>
</div>
<br></blockquote></div><br><br clear="all"><div><br></div>-- <br><div class="gmail_signature"><div dir="ltr"><div><span style="font-size:small;border-collapse:separate"><div>_,,,^..^,,,_<br></div><div>best, Eliot</div></span></div></div></div>
</div></div>