<div dir="ltr"><br><br><div class="gmail_quote">On Thu, Mar 12, 2015 at 10:39 AM Zachary Ware <<a href="mailto:zachary.ware%2Bpydev@gmail.com">zachary.ware+pydev@gmail.com</a>> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">I started this message about 3 months ago; at this point I'm just<br>
getting it posted so it stops rotting in my Drafts folder.<br></blockquote><div><br></div><div>Thanks for looking into this!</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
On Mon, Dec 22, 2014 at 3:49 PM, Jim J. Jewett <<a href="mailto:jimjjewett@gmail.com" target="_blank">jimjjewett@gmail.com</a>> wrote:<br>
> On Thu, Dec 18, 2014, at 14:13, Maciej Fijalkowski wrote:<br>
>> ... <a href="http://bugs.python.org/issue23085" target="_blank">http://bugs.python.org/<u></u>issue23085</a> ...<br>
>> is there any reason any more for libffi being included in CPython?<br>
><br>
><br>
> Paul Moore wrote:<br>
>> Probably the easiest way of moving this forward would be for someone<br>
>> to identify the CPython-specific patches in the current version ...<br>
><br>
> Christian Heimes wrote:<br>
>> That's easy. All patches are tracked in the diff file<br>
>> <a href="https://hg.python.org/cpython/file/3de678cd184d/Modules/_ctypes/libffi.diff" target="_blank">https://hg.python.org/cpython/<u></u>file/3de678cd184d/Modules/_<u></u>ctypes/libffi.diff</a><br>
><br>
> That (200+ lines) doesn't seem to have all the C changes, such as the<br>
> win64 sizeof changes from issue 11835.<br>
<br>
I took a little bit of time to look at this a while ago.  Something<br>
that quickly became clear that I'm not sure everybody is on the same<br>
page about (I, for one, had no idea previously) is that libffi for<br>
Windows and libffi for everything else are entirely separate beasts:<br>
the Windows build pulls all of its libffi source from<br>
Modules/_ctypes/libffi_msvc and doesn't even touch<br>
Modules/_ctypes/libffi (which is libffi for nearly everything else).<br>
Most of the files in libffi_msvc haven't been touched in about 4<br>
years, except for a couple fixes by Steve Dower recently.<br>
README.ctypes in that folder states that the files were taken from the<br>
libffi CVS tree in 2004 and there have been some custom modifications<br>
since then, so there is really very little resemblance between<br>
libffi_msvc and current libffi.<br></blockquote><div><br></div><div>That's what I was afraid of.</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
There's also 'libffi_arm_wince' and 'libffi_osx'.  I would be fairly<br>
amazed if Python itself built on any version of Windows CE; personally<br>
I would be for ripping out any supposed support that we have for it<br>
(though if somebody is actually using it and it works, it's not<br>
hurting anything and should stay).  That's a completely different<br>
issue, though.<br>
<br>
I'm all for ditching our 'libffi_msvc' in favor of adding libffi as<br>
another 'external' for the Windows build.  I have managed to get<br>
_ctypes to build on Windows using vanilla libffi sources, prepared<br>
using their configure script from within Git Bash and built with our<br>
usual Windows build system (properly patched).  Unfortunately, making<br>
things usable will take some work on ctypes itself, which I'm not<br>
qualified to do. I'm happy to pass on my procedure and patches for<br>
getting to the point of successful compilation to anyone who feels up<br>
to fixing the things that are broken.<br></blockquote><div><br></div><div>So it seems possible to use upstream libffi but will require some work.</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
As for the lightly-patched version of libffi that we keep around for<br>
Linux et. al., looking at the diff file I don't see that there's a<br>
whole lot of reason to keep it around.<br></blockquote><div><br></div><div>For UNIX OSs we could probably rely on the system libffi then. What's the situation on OS X? Anyone know if it has libffi, or would be need to be pulled in to be used like on Windows?</div></div></div>