Alright, I have a hankering again to port Ruby FFI ;). One question: should the port be written in pure Ruby, or should this be a C# library in the same vein as YAML (IronRuby.Libraries.Yaml)? I was leaning towards the latter, where I would branch from IronLanguages/Main, adding a *Libraries.FFI* folder beside *Libraries.Yaml*. Cheers, -Charles
on 2011-03-23 05:41
on 2011-03-23 07:14
It would be easier to write the core implementation as regular C# library (i.e. not IronRuby.Libraries.*) and write the public API in Ruby that would internally call to that library. The Ruby file could call load_assembly 'CoreFFI.dll' and then use the classes defined there. This way you don't even need to include the code to IronRuby main repo, it could be a separate gem. Tomas From: ironruby-core-bounces@rubyforge.org [mailto:ironruby-core-bounces@rubyforge.org] On Behalf Of Charles Strahan Sent: Tuesday, March 22, 2011 6:30 PM To: ironruby-core@rubyforge.org Subject: [Ironruby-core] Ruby FFI port Alright, I have a hankering again to port Ruby FFI ;). One question: should the port be written in pure Ruby, or should this be a C# library in the same vein as YAML (IronRuby.Libraries.Yaml)? I was leaning towards the latter, where I would branch from IronLanguages/Main, adding a Libraries.FFI folder beside Libraries.Yaml. Cheers, -Charles
on 2011-03-23 07:16
Another idea... what about starting from http://github.com/ffi and replacing the C extension with C# code? Not sure if it will work but it's at least worth looking at. Or perhaps you can also look at what JRuby is doing. Tomas From: ironruby-core-bounces@rubyforge.org [mailto:ironruby-core-bounces@rubyforge.org] On Behalf Of Charles Strahan Sent: Tuesday, March 22, 2011 6:30 PM To: ironruby-core@rubyforge.org Subject: [Ironruby-core] Ruby FFI port Alright, I have a hankering again to port Ruby FFI ;). One question: should the port be written in pure Ruby, or should this be a C# library in the same vein as YAML (IronRuby.Libraries.Yaml)? I was leaning towards the latter, where I would branch from IronLanguages/Main, adding a Libraries.FFI folder beside Libraries.Yaml. Cheers, -Charles
on 2011-03-24 21:10
> Another idea what about starting from http://github.com/ffi and replacing > the C extension with C# code? That's a great idea, Tomas. I'll need some immediate gratification to keep me from getting discouraged; porting the C funcs piecemeal sounds like a good way to get *something* working. I've forked FFI<https://github.com/cstrahan/iron-ffi>- I'll try to lay out a foundation tonight. -Charles On Wed, Mar 23, 2011 at 12:29 AM, Tomas Matousek <
on 2011-03-24 21:54
I've successfully built the FFI gem on my Win7 x64 machine, but the specs currently fail: *E:/Source/ffi/lib/ffi/library.rb:147:in `attach_function': Function 'strdup' not* * found in [msvcrt.dll] (FFI::NotFoundError)* * from E:/Source/ffi/spec/ffi/strptr_spec.rb:33:in `<module:StrPtr>'* This is a known problem, but it hasn't been fixed yet: http://groups.google.com/group/ruby-ffi/browse_thr... > Thats just a symbol lookup problem. All the traditional libc symbols > in msvcrt.dll have an underscore prepended, so that test should have a > special case for win32 in it. My first goal is to fix any failing specs. Any help would be appreciated. -Charles On Thu, Mar 24, 2011 at 1:58 PM, Charles Strahan <
on 2011-03-25 00:42
I've fixed the problem in the spec <https://github.com/ffi/ffi/pull/82>, and all specs pass now. Time to start porting the C code to C#. -Charles On Thu, Mar 24, 2011 at 3:19 PM, Charles Strahan <
on 2011-03-25 01:24
On 25 March 2011 04:58, Charles Strahan <charles.c.strahan@gmail.com> wrote: > >> Another idea what about starting fromhttp://github.com/ffiand replacing >> the C extension with C# code? > > That's a great idea, Tomas. I'll need some immediate gratification to keep > me from getting discouraged; porting the C funcspiecemeal sounds like a > good way to get something working. I'veforked FFI - I'll try to lay out a > foundation tonight. If you want some easy wins, The first classes you'll want to implement are: 1) FFI::Type - this is used by much of the rest of the system, e.g. to identify arguments and struct field types. At a minimum, you need to implement #size and #alignment, and have FFI::Type instances for 8, 16, 32, 64 bit signed/unsigned integers, float, double and pointer defined as the constants FFI::Type::UINT8, FFI::Type::INT8, etc. 2) FFI::Pointer - instances of this are used to represent a native pointer. To get things up and running, you can stub this out with just the basic initialize() method. Most of the accessor methods can be done later. 3) FFI::DynamicLibrary - kinda useful for loading libraries and locating symbols within said library. 4) FFI::Function - the swiss army knife class for calling functions, and creating C => ruby callbacks. Ignore the callback aspect of this for now, and just get ruby => C calling working. That will take you a little while, but you'll be able to at least get simple functions like 'puts' from libc callable from FFI.
on 2011-03-25 11:40
Sweet - thank you for the tip, Wayne! Here's my current plan: - All Ruby classes defined inside of ffi_c will be ported to Ruby, where I'll call into my C# lib where it makes sense. - Because my poor brain can only handle so much context-switching, I'll stub out all of the Ruby classes with methods that will simply *raise "not implemented"*. - I'll follow Wayne's advice to get some simple clib funcs working. - Port the rest of ffi_c When all is said and done, it looks like I shouldn't need to touch a single line of FFI's Ruby code - I *should* only need to implement classes (or parts thereof) that are defined in ffi_c. One thing I will need to figure later is the name of the dll that contains dlopen/dlsym/etc for each platform. I'm willing to be that I'll be able to piece that together with decent accuracy by looking at FFI.map_library_name. -Charles
on 2011-03-25 14:50
That sounds like a good plan. Much of the CRuby version of FFI used to be written in ruby, until people had the quaint notion that it shouldn't be as slow as it was, and I moved most of the implementation into C. dlopen and friends are usually in the libdl library on most unixen. I can't remember where the windows equivalents live.
Please log in before posting. Registration is free and takes only a minute.
Existing account
(Switch to SSL-encrypted connection)
NEW: Do you have a Google/GoogleMail or Yahoo account? No registration required!
Log in with Google account | Log in with Yahoo account
Log in with Google account | Log in with Yahoo account
No account? Register here.