ffi 1.9.25 → 1.12.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/{appveyor.yml → .appveyor.yml} +7 -2
- data/.gitignore +3 -0
- data/.gitmodules +1 -0
- data/.travis.yml +22 -30
- data/CHANGELOG.md +107 -0
- data/Gemfile +2 -2
- data/README.md +29 -17
- data/Rakefile +17 -89
- data/ext/ffi_c/AbstractMemory.c +5 -9
- data/ext/ffi_c/Call.c +18 -39
- data/ext/ffi_c/Call.h +4 -7
- data/ext/ffi_c/DynamicLibrary.c +1 -1
- data/ext/ffi_c/Function.c +29 -113
- data/ext/ffi_c/LastError.c +47 -2
- data/ext/ffi_c/LongDouble.c +7 -7
- data/ext/ffi_c/Platform.c +0 -47
- data/ext/ffi_c/Struct.c +47 -51
- data/ext/ffi_c/Struct.h +12 -6
- data/ext/ffi_c/StructLayout.c +13 -12
- data/ext/ffi_c/Thread.c +6 -222
- data/ext/ffi_c/Thread.h +2 -13
- data/ext/ffi_c/Type.c +0 -18
- data/ext/ffi_c/Type.h +0 -1
- data/ext/ffi_c/Types.c +1 -1
- data/ext/ffi_c/Variadic.c +9 -15
- data/ext/ffi_c/extconf.rb +34 -21
- data/ext/ffi_c/ffi.c +3 -8
- data/ext/ffi_c/libffi/.appveyor.yml +29 -13
- data/ext/ffi_c/libffi/.gitattributes +4 -0
- data/ext/ffi_c/libffi/.travis/bfin-sim.exp +58 -0
- data/ext/ffi_c/libffi/.travis/build-cross-in-container.sh +14 -0
- data/ext/ffi_c/libffi/.travis/build-in-container.sh +12 -0
- data/ext/ffi_c/libffi/.travis/build.sh +112 -8
- data/ext/ffi_c/libffi/.travis/install.sh +65 -16
- data/ext/ffi_c/libffi/.travis/m32r-sim.exp +58 -0
- data/ext/ffi_c/libffi/.travis/or1k-sim.exp +58 -0
- data/ext/ffi_c/libffi/.travis/powerpc-eabisim.exp +58 -0
- data/ext/ffi_c/libffi/.travis/site.exp +10 -1
- data/ext/ffi_c/libffi/.travis/wine-sim.exp +55 -0
- data/ext/ffi_c/libffi/.travis.yml +47 -2
- data/ext/ffi_c/libffi/{ChangeLog.libffi-3.1 → ChangeLog.old} +1407 -0
- data/ext/ffi_c/libffi/LICENSE +1 -1
- data/ext/ffi_c/libffi/LICENSE-BUILDTOOLS +5 -4
- data/ext/ffi_c/libffi/Makefile.am +33 -40
- data/ext/ffi_c/libffi/Makefile.in +392 -176
- data/ext/ffi_c/libffi/README.md +23 -8
- data/ext/ffi_c/libffi/configure +319 -343
- data/ext/ffi_c/libffi/configure.ac +6 -2
- data/ext/ffi_c/libffi/configure.host +26 -9
- data/ext/ffi_c/libffi/doc/Makefile.in +9 -5
- data/ext/ffi_c/libffi/doc/libffi.texi +26 -14
- data/ext/ffi_c/libffi/doc/version.texi +4 -4
- data/ext/ffi_c/libffi/fficonfig.h.in +4 -0
- data/ext/ffi_c/libffi/generate-darwin-source-and-headers.py +1 -3
- data/ext/ffi_c/libffi/include/Makefile.in +10 -6
- data/ext/ffi_c/libffi/include/ffi.h.in +11 -7
- data/ext/ffi_c/libffi/include/ffi_common.h +5 -1
- data/ext/ffi_c/libffi/install-sh +23 -13
- data/ext/ffi_c/libffi/libffi.xcodeproj/project.pbxproj +2 -48
- data/ext/ffi_c/libffi/ltmain.sh +153 -60
- data/ext/ffi_c/libffi/m4/asmcfi.m4 +1 -1
- data/ext/ffi_c/libffi/m4/ax_append_flag.m4 +5 -26
- data/ext/ffi_c/libffi/m4/ax_check_compile_flag.m4 +5 -26
- data/ext/ffi_c/libffi/m4/ax_compiler_vendor.m4 +2 -1
- data/ext/ffi_c/libffi/m4/ax_configure_args.m4 +5 -26
- data/ext/ffi_c/libffi/m4/ax_gcc_archflag.m4 +7 -3
- data/ext/ffi_c/libffi/make_sunver.pl +333 -0
- data/ext/ffi_c/libffi/man/Makefile.in +9 -5
- data/ext/ffi_c/libffi/missing +8 -8
- data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.sln +33 -0
- data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.vcxproj +130 -0
- data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.vcxproj.filters +57 -0
- data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.vcxproj.user +4 -0
- data/ext/ffi_c/libffi/msvc_build/aarch64/aarch64_include/ffi.h +511 -0
- data/ext/ffi_c/libffi/msvc_build/aarch64/aarch64_include/fficonfig.h +219 -0
- data/ext/ffi_c/libffi/msvcc.sh +27 -2
- data/ext/ffi_c/libffi/src/aarch64/ffi.c +126 -58
- data/ext/ffi_c/libffi/src/aarch64/ffitarget.h +13 -2
- data/ext/ffi_c/libffi/src/aarch64/sysv.S +8 -6
- data/ext/ffi_c/libffi/src/aarch64/win64_armasm.S +506 -0
- data/ext/ffi_c/libffi/src/arm/ffi.c +40 -5
- data/ext/ffi_c/libffi/src/arm/ffitarget.h +8 -1
- data/ext/ffi_c/libffi/src/arm/sysv.S +2 -0
- data/ext/ffi_c/libffi/src/arm/sysv_msvc_arm32.S +311 -0
- data/ext/ffi_c/libffi/src/closures.c +41 -9
- data/ext/ffi_c/libffi/src/frv/ffi.c +1 -1
- data/ext/ffi_c/libffi/src/metag/ffi.c +1 -1
- data/ext/ffi_c/libffi/src/mips/o32.S +2 -0
- data/ext/ffi_c/libffi/src/moxie/ffi.c +1 -1
- data/ext/ffi_c/libffi/src/pa/linux.S +23 -2
- data/ext/ffi_c/libffi/src/powerpc/ffi.c +6 -4
- data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +211 -32
- data/ext/ffi_c/libffi/src/powerpc/ffi_powerpc.h +18 -7
- data/ext/ffi_c/libffi/src/powerpc/ffitarget.h +10 -4
- data/ext/ffi_c/libffi/src/powerpc/linux64.S +83 -28
- data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +68 -4
- data/ext/ffi_c/libffi/src/prep_cif.c +4 -2
- data/ext/ffi_c/libffi/src/riscv/ffi.c +42 -6
- data/ext/ffi_c/libffi/src/riscv/ffitarget.h +1 -0
- data/ext/ffi_c/libffi/src/riscv/sysv.S +86 -7
- data/ext/ffi_c/libffi/src/x86/ffi.c +14 -6
- data/ext/ffi_c/libffi/src/x86/ffi64.c +5 -3
- data/ext/ffi_c/libffi/src/x86/ffiw64.c +5 -2
- data/ext/ffi_c/libffi/src/x86/sysv.S +90 -4
- data/ext/ffi_c/libffi/src/x86/sysv_intel.S +995 -0
- data/ext/ffi_c/libffi/src/x86/unix64.S +41 -0
- data/ext/ffi_c/libffi/src/x86/win64.S +5 -0
- data/ext/ffi_c/libffi/testsuite/Makefile.am +114 -109
- data/ext/ffi_c/libffi/testsuite/Makefile.in +124 -84
- data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +26 -22
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/bhaible.exp +7 -2
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-call.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-callback.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/call.exp +12 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/float2.c +9 -8
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_1.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/closure.exp +67 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/ffitest.h +138 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/huge_struct.c +1 -1
- data/ext/ffi_c/libffi.darwin.mk +1 -1
- data/ext/ffi_c/rbffi.h +0 -2
- data/ffi.gemspec +12 -5
- data/lib/ffi/data_converter.rb +67 -0
- data/lib/ffi/ffi.rb +2 -0
- data/lib/ffi/library.rb +6 -6
- data/lib/ffi/platform/aarch64-freebsd/types.conf +128 -0
- data/lib/ffi/platform/aarch64-freebsd12/types.conf +128 -0
- data/lib/ffi/platform/aarch64-linux/types.conf +81 -81
- data/lib/ffi/platform/arm-freebsd/types.conf +152 -0
- data/lib/ffi/platform/arm-freebsd12/types.conf +152 -0
- data/lib/ffi/platform/arm-linux/types.conf +79 -79
- data/lib/ffi/platform/i386-cygwin/types.conf +1 -1
- data/lib/ffi/platform/i386-darwin/types.conf +63 -63
- data/lib/ffi/platform/i386-freebsd/types.conf +89 -89
- data/lib/ffi/platform/i386-freebsd12/types.conf +152 -0
- data/lib/ffi/platform/i386-gnu/types.conf +84 -84
- data/lib/ffi/platform/i386-linux/types.conf +77 -77
- data/lib/ffi/platform/i386-netbsd/types.conf +87 -87
- data/lib/ffi/platform/i386-openbsd/types.conf +89 -89
- data/lib/ffi/platform/i386-solaris/types.conf +96 -96
- data/lib/ffi/platform/i386-windows/types.conf +84 -84
- data/lib/ffi/platform/ia64-linux/types.conf +79 -79
- data/lib/ffi/platform/mips-linux/types.conf +79 -79
- data/lib/ffi/platform/mips64-linux/types.conf +81 -81
- data/lib/ffi/platform/mips64el-linux/types.conf +81 -81
- data/lib/ffi/platform/mipsel-linux/types.conf +79 -79
- data/lib/ffi/platform/mipsisa32r6-linux/types.conf +79 -79
- data/lib/ffi/platform/mipsisa32r6el-linux/types.conf +79 -79
- data/lib/ffi/platform/mipsisa64r6-linux/types.conf +81 -81
- data/lib/ffi/platform/mipsisa64r6el-linux/types.conf +81 -81
- data/lib/ffi/platform/powerpc-aix/types.conf +155 -155
- data/lib/ffi/platform/powerpc-darwin/types.conf +63 -63
- data/lib/ffi/platform/powerpc-linux/types.conf +77 -77
- data/lib/ffi/platform/powerpc64-linux/types.conf +81 -81
- data/lib/ffi/platform/s390-linux/types.conf +79 -79
- data/lib/ffi/platform/s390x-linux/types.conf +79 -79
- data/lib/ffi/platform/sparc-linux/types.conf +79 -79
- data/lib/ffi/platform/sparc-solaris/types.conf +103 -103
- data/lib/ffi/platform/sparc64-linux/types.conf +79 -79
- data/lib/ffi/platform/sparcv9-solaris/types.conf +103 -103
- data/lib/ffi/platform/x86_64-cygwin/types.conf +1 -1
- data/lib/ffi/platform/x86_64-darwin/types.conf +84 -84
- data/lib/ffi/platform/x86_64-dragonflybsd/types.conf +148 -0
- data/lib/ffi/platform/x86_64-freebsd/types.conf +90 -90
- data/lib/ffi/platform/x86_64-freebsd12/types.conf +158 -0
- data/lib/ffi/platform/x86_64-linux/types.conf +86 -77
- data/lib/ffi/platform/x86_64-netbsd/types.conf +89 -89
- data/lib/ffi/platform/x86_64-openbsd/types.conf +86 -86
- data/lib/ffi/platform/x86_64-solaris/types.conf +96 -96
- data/lib/ffi/platform/x86_64-windows/types.conf +99 -99
- data/lib/ffi/platform.rb +13 -2
- data/lib/ffi/pointer.rb +5 -6
- data/lib/ffi/struct.rb +5 -66
- data/lib/ffi/struct_by_reference.rb +72 -0
- data/lib/ffi/struct_layout.rb +96 -0
- data/lib/ffi/tools/const_generator.rb +5 -4
- data/lib/ffi/tools/generator.rb +47 -2
- data/lib/ffi/tools/generator_task.rb +13 -17
- data/lib/ffi/tools/struct_generator.rb +4 -4
- data/lib/ffi/tools/types_generator.rb +5 -4
- data/lib/ffi/types.rb +1 -1
- data/lib/ffi/version.rb +1 -1
- metadata +144 -115
- data/ext/ffi_c/DataConverter.c +0 -91
- data/ext/ffi_c/StructByReference.c +0 -190
- data/ext/ffi_c/StructByReference.h +0 -50
- data/ext/ffi_c/libffi/ChangeLog.libffi +0 -584
- data/ext/ffi_c/libffi/ChangeLog.libgcj +0 -40
- data/ext/ffi_c/libffi/ChangeLog.v1 +0 -764
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn0.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn1.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn2.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn3.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn4.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn5.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn6.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_loc_fn0.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_simple.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_12byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_16byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_18byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_19byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_1_1byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte1.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_24byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_2byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3_1byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte1.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte2.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3float.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4_1byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5_1_byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_64byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6_1_byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7_1_byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_8byte.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte1.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte2.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_double.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_float.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split2.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_pointer.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint16.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint32.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint64.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint16.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint32.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint64.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_dbls_struct.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_double.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_double_va.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_float.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble_va.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_many_mixed_args.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_many_mixed_float_double.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_schar.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshort.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshortchar.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_uchar.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushort.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushortchar.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer_stack.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_schar.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sint.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sshort.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_struct_va1.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uchar.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uchar_va.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uint.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uint_va.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ulong_va.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ulonglong.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ushort.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ushort_va.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/err_bad_abi.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct1.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct10.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct11.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct2.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct3.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct4.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct5.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct6.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct7.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct8.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct9.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/problem1.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large2.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium2.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/testclosure.c +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/unwindtest.cc +0 -0
- /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/unwindtest_ffi_call.cc +0 -0
@@ -1,120 +1,120 @@
|
|
1
|
-
rbx.platform.typedef
|
2
|
-
rbx.platform.typedef.
|
1
|
+
rbx.platform.typedef.*addr_t = char
|
2
|
+
rbx.platform.typedef.__ULong = ulong
|
3
|
+
rbx.platform.typedef.__blkcnt32_t = long
|
4
|
+
rbx.platform.typedef.__blkcnt64_t = long_long
|
5
|
+
rbx.platform.typedef.__dev16_t = short
|
6
|
+
rbx.platform.typedef.__dev32_t = ulong
|
7
|
+
rbx.platform.typedef.__dev_t = short
|
8
|
+
rbx.platform.typedef.__gid16_t = ushort
|
9
|
+
rbx.platform.typedef.__gid32_t = ulong
|
10
|
+
rbx.platform.typedef.__gid_t = ushort
|
11
|
+
rbx.platform.typedef.__ino32_t = ulong
|
12
|
+
rbx.platform.typedef.__ino64_t = ulong_long
|
3
13
|
rbx.platform.typedef.__int16_t = short
|
4
|
-
rbx.platform.typedef.__uint16_t = ushort
|
5
|
-
rbx.platform.typedef.__int_least16_t = short
|
6
|
-
rbx.platform.typedef.__uint_least16_t = ushort
|
7
14
|
rbx.platform.typedef.__int32_t = int
|
8
|
-
rbx.platform.typedef.__uint32_t = uint
|
9
|
-
rbx.platform.typedef.__int_least32_t = int
|
10
|
-
rbx.platform.typedef.__uint_least32_t = uint
|
11
15
|
rbx.platform.typedef.__int64_t = long_long
|
12
|
-
rbx.platform.typedef.
|
13
|
-
rbx.platform.typedef.
|
14
|
-
rbx.platform.typedef.
|
16
|
+
rbx.platform.typedef.__int8_t = char
|
17
|
+
rbx.platform.typedef.__int_least16_t = short
|
18
|
+
rbx.platform.typedef.__int_least32_t = int
|
19
|
+
rbx.platform.typedef.__loff_t = long_long
|
20
|
+
rbx.platform.typedef.__off_t = long
|
21
|
+
rbx.platform.typedef.__pid_t = int
|
22
|
+
rbx.platform.typedef.__time32_t = long
|
23
|
+
rbx.platform.typedef.__time64_t = long_long
|
24
|
+
rbx.platform.typedef.__uid16_t = ushort
|
25
|
+
rbx.platform.typedef.__uid32_t = ulong
|
15
26
|
rbx.platform.typedef.__uid_t = ushort
|
16
|
-
rbx.platform.typedef.
|
17
|
-
rbx.platform.typedef.
|
18
|
-
rbx.platform.typedef.
|
19
|
-
rbx.platform.typedef.
|
27
|
+
rbx.platform.typedef.__uint16_t = ushort
|
28
|
+
rbx.platform.typedef.__uint32_t = uint
|
29
|
+
rbx.platform.typedef.__uint64_t = ulong_long
|
30
|
+
rbx.platform.typedef.__uint8_t = uchar
|
31
|
+
rbx.platform.typedef.__uint_least16_t = ushort
|
32
|
+
rbx.platform.typedef.__uint_least32_t = uint
|
33
|
+
rbx.platform.typedef._dev_t = uint
|
20
34
|
rbx.platform.typedef._fpos64_t = long_long
|
35
|
+
rbx.platform.typedef._fpos_t = long_long
|
36
|
+
rbx.platform.typedef._ino_t = ushort
|
37
|
+
rbx.platform.typedef._mode_t = ushort
|
38
|
+
rbx.platform.typedef._off64_t = long_long
|
39
|
+
rbx.platform.typedef._off_t = long
|
40
|
+
rbx.platform.typedef._sigset_t = ulong_long
|
21
41
|
rbx.platform.typedef._ssize_t = long_long
|
22
|
-
rbx.platform.typedef.
|
23
|
-
rbx.platform.typedef.
|
24
|
-
rbx.platform.typedef.
|
25
|
-
rbx.platform.typedef.ptrdiff_t = long_long
|
26
|
-
rbx.platform.typedef.size_t = ulong_long
|
27
|
-
rbx.platform.typedef.__off_t = long
|
28
|
-
rbx.platform.typedef.__pid_t = int
|
29
|
-
rbx.platform.typedef.__loff_t = long_long
|
30
|
-
rbx.platform.typedef.u_char = uchar
|
31
|
-
rbx.platform.typedef.u_short = ushort
|
32
|
-
rbx.platform.typedef.u_int = uint
|
33
|
-
rbx.platform.typedef.u_long = ulong
|
34
|
-
rbx.platform.typedef.ushort = ushort
|
35
|
-
rbx.platform.typedef.uint = uint
|
36
|
-
rbx.platform.typedef.ulong = ulong
|
42
|
+
rbx.platform.typedef.blkcnt_t = long_long
|
43
|
+
rbx.platform.typedef.blksize_t = long
|
44
|
+
rbx.platform.typedef.caddr_t = string
|
37
45
|
rbx.platform.typedef.clock_t = ulong
|
38
|
-
rbx.platform.typedef.
|
46
|
+
rbx.platform.typedef.clockid_t = ulong
|
39
47
|
rbx.platform.typedef.daddr_t = long
|
40
|
-
rbx.platform.typedef.
|
41
|
-
rbx.platform.typedef.
|
42
|
-
rbx.platform.typedef.ssize_t = int
|
43
|
-
rbx.platform.typedef.nlink_t = ushort
|
48
|
+
rbx.platform.typedef.dev_t = uint
|
49
|
+
rbx.platform.typedef.errno_t = int
|
44
50
|
rbx.platform.typedef.fd_mask = long
|
45
|
-
rbx.platform.typedef.
|
46
|
-
rbx.platform.typedef.
|
47
|
-
rbx.platform.typedef.
|
48
|
-
rbx.platform.typedef.
|
49
|
-
rbx.platform.typedef.
|
51
|
+
rbx.platform.typedef.fpos_t = long_long
|
52
|
+
rbx.platform.typedef.fsblkcnt_t = ulong
|
53
|
+
rbx.platform.typedef.fsfilcnt_t = ulong
|
54
|
+
rbx.platform.typedef.gid_t = ulong
|
55
|
+
rbx.platform.typedef.id_t = ulong
|
56
|
+
rbx.platform.typedef.ino_t = ushort
|
50
57
|
rbx.platform.typedef.int16_t = short
|
51
58
|
rbx.platform.typedef.int32_t = int
|
52
59
|
rbx.platform.typedef.int64_t = long_long
|
53
|
-
rbx.platform.typedef.
|
54
|
-
rbx.platform.typedef.uint16_t = ushort
|
55
|
-
rbx.platform.typedef.uint32_t = uint
|
56
|
-
rbx.platform.typedef.uint64_t = ulong_long
|
57
|
-
rbx.platform.typedef.int_least8_t = char
|
58
|
-
rbx.platform.typedef.int_least16_t = short
|
59
|
-
rbx.platform.typedef.int_least32_t = int
|
60
|
-
rbx.platform.typedef.int_least64_t = long_long
|
61
|
-
rbx.platform.typedef.uint_least8_t = uchar
|
62
|
-
rbx.platform.typedef.uint_least16_t = ushort
|
63
|
-
rbx.platform.typedef.uint_least32_t = uint
|
64
|
-
rbx.platform.typedef.uint_least64_t = ulong_long
|
65
|
-
rbx.platform.typedef.int_fast8_t = char
|
60
|
+
rbx.platform.typedef.int8_t = char
|
66
61
|
rbx.platform.typedef.int_fast16_t = int
|
67
62
|
rbx.platform.typedef.int_fast32_t = int
|
68
63
|
rbx.platform.typedef.int_fast64_t = long_long
|
69
|
-
rbx.platform.typedef.
|
64
|
+
rbx.platform.typedef.int_fast8_t = char
|
65
|
+
rbx.platform.typedef.int_least16_t = short
|
66
|
+
rbx.platform.typedef.int_least32_t = int
|
67
|
+
rbx.platform.typedef.int_least64_t = long_long
|
68
|
+
rbx.platform.typedef.int_least8_t = char
|
69
|
+
rbx.platform.typedef.intmax_t = long_long
|
70
|
+
rbx.platform.typedef.intptr_t = long_long
|
71
|
+
rbx.platform.typedef.key_t = long_long
|
72
|
+
rbx.platform.typedef.loff_t = long_long
|
73
|
+
rbx.platform.typedef.mode_t = ushort
|
74
|
+
rbx.platform.typedef.nlink_t = ushort
|
75
|
+
rbx.platform.typedef.off_t = long_long
|
76
|
+
rbx.platform.typedef.pid_t = int
|
77
|
+
rbx.platform.typedef.ptrdiff_t = long_long
|
78
|
+
rbx.platform.typedef.register_t = int
|
79
|
+
rbx.platform.typedef.rlim_t = ulong
|
80
|
+
rbx.platform.typedef.sa_family_t = ushort
|
81
|
+
rbx.platform.typedef.sig_atomic_t = int
|
82
|
+
rbx.platform.typedef.sigset_t = ulong
|
83
|
+
rbx.platform.typedef.size_t = ulong_long
|
84
|
+
rbx.platform.typedef.socklen_t = int
|
85
|
+
rbx.platform.typedef.ssize_t = int
|
86
|
+
rbx.platform.typedef.suseconds_t = long
|
87
|
+
rbx.platform.typedef.time_t = long_long
|
88
|
+
rbx.platform.typedef.timer_t = ulong
|
89
|
+
rbx.platform.typedef.u_char = uchar
|
90
|
+
rbx.platform.typedef.u_int = uint
|
91
|
+
rbx.platform.typedef.u_int16_t = ushort
|
92
|
+
rbx.platform.typedef.u_int32_t = uint
|
93
|
+
rbx.platform.typedef.u_int64_t = ulong_long
|
94
|
+
rbx.platform.typedef.u_int8_t = uchar
|
95
|
+
rbx.platform.typedef.u_long = ulong
|
96
|
+
rbx.platform.typedef.u_short = ushort
|
97
|
+
rbx.platform.typedef.uid_t = ulong
|
98
|
+
rbx.platform.typedef.uint = uint
|
99
|
+
rbx.platform.typedef.uint16_t = ushort
|
100
|
+
rbx.platform.typedef.uint32_t = uint
|
101
|
+
rbx.platform.typedef.uint64_t = ulong_long
|
102
|
+
rbx.platform.typedef.uint8_t = uchar
|
70
103
|
rbx.platform.typedef.uint_fast16_t = uint
|
71
104
|
rbx.platform.typedef.uint_fast32_t = uint
|
72
105
|
rbx.platform.typedef.uint_fast64_t = ulong_long
|
73
|
-
rbx.platform.typedef.
|
74
|
-
rbx.platform.typedef.
|
75
|
-
rbx.platform.typedef.
|
106
|
+
rbx.platform.typedef.uint_fast8_t = uchar
|
107
|
+
rbx.platform.typedef.uint_least16_t = ushort
|
108
|
+
rbx.platform.typedef.uint_least32_t = uint
|
109
|
+
rbx.platform.typedef.uint_least64_t = ulong_long
|
110
|
+
rbx.platform.typedef.uint_least8_t = uchar
|
76
111
|
rbx.platform.typedef.uintmax_t = ulong_long
|
77
|
-
rbx.platform.typedef.
|
78
|
-
rbx.platform.typedef.
|
79
|
-
rbx.platform.typedef.
|
80
|
-
rbx.platform.typedef.
|
81
|
-
rbx.platform.typedef._dev_t = uint
|
82
|
-
rbx.platform.typedef.dev_t = uint
|
83
|
-
rbx.platform.typedef.blksize_t = long
|
84
|
-
rbx.platform.typedef.__blkcnt32_t = long
|
85
|
-
rbx.platform.typedef.__blkcnt64_t = long_long
|
86
|
-
rbx.platform.typedef.blkcnt_t = long_long
|
87
|
-
rbx.platform.typedef.fsblkcnt_t = ulong
|
88
|
-
rbx.platform.typedef.fsfilcnt_t = ulong
|
89
|
-
rbx.platform.typedef.__uid16_t = ushort
|
90
|
-
rbx.platform.typedef.__uid32_t = ulong
|
91
|
-
rbx.platform.typedef.uid_t = ulong
|
92
|
-
rbx.platform.typedef.__gid16_t = ushort
|
93
|
-
rbx.platform.typedef.__gid32_t = ulong
|
94
|
-
rbx.platform.typedef.gid_t = ulong
|
95
|
-
rbx.platform.typedef.__ino32_t = ulong
|
96
|
-
rbx.platform.typedef.__ino64_t = ulong_long
|
97
|
-
rbx.platform.typedef.ino_t = ushort
|
98
|
-
rbx.platform.typedef._ino_t = ushort
|
99
|
-
rbx.platform.typedef.id_t = ulong
|
100
|
-
rbx.platform.typedef.key_t = long_long
|
112
|
+
rbx.platform.typedef.uintptr_t = ulong_long
|
113
|
+
rbx.platform.typedef.ulong = ulong
|
114
|
+
rbx.platform.typedef.useconds_t = ulong
|
115
|
+
rbx.platform.typedef.ushort = ushort
|
101
116
|
rbx.platform.typedef.vm_offset_t = ulong
|
102
117
|
rbx.platform.typedef.vm_size_t = ulong
|
103
|
-
rbx.platform.typedef.
|
104
|
-
rbx.platform.typedef.
|
105
|
-
rbx.platform.typedef.
|
106
|
-
rbx.platform.typedef.u_int64_t = ulong_long
|
107
|
-
rbx.platform.typedef.register_t = int
|
108
|
-
rbx.platform.typedef.*addr_t = char
|
109
|
-
rbx.platform.typedef.socklen_t = int
|
110
|
-
rbx.platform.typedef.sa_family_t = ushort
|
111
|
-
rbx.platform.typedef.__ULong = ulong
|
112
|
-
rbx.platform.typedef.sigset_t = ulong
|
113
|
-
rbx.platform.typedef.sig_atomic_t = int
|
114
|
-
rbx.platform.typedef.rlim_t = ulong
|
115
|
-
rbx.platform.typedef._sigset_t = ulong_long
|
116
|
-
rbx.platform.typedef.__time32_t = long
|
117
|
-
rbx.platform.typedef.__time64_t = long_long
|
118
|
-
rbx.platform.typedef.errno_t = int
|
119
|
-
rbx.platform.typedef._mode_t = ushort
|
120
|
-
rbx.platform.typedef.mode_t = ushort
|
118
|
+
rbx.platform.typedef.wchar_t = ushort
|
119
|
+
rbx.platform.typedef.wctype_t = ushort
|
120
|
+
rbx.platform.typedef.wint_t = uint
|
data/lib/ffi/platform.rb
CHANGED
@@ -46,6 +46,8 @@ module FFI
|
|
46
46
|
"netbsd"
|
47
47
|
when /openbsd/
|
48
48
|
"openbsd"
|
49
|
+
when /dragonfly/
|
50
|
+
"dragonflybsd"
|
49
51
|
when /sunos|solaris/
|
50
52
|
"solaris"
|
51
53
|
when /mingw|mswin/
|
@@ -54,6 +56,10 @@ module FFI
|
|
54
56
|
RbConfig::CONFIG['host_os'].downcase
|
55
57
|
end
|
56
58
|
|
59
|
+
OSVERSION = RbConfig::CONFIG['host_os'].gsub(/[^\d]/, '').to_i
|
60
|
+
|
61
|
+
CPU = RbConfig::CONFIG['host_cpu']
|
62
|
+
|
57
63
|
ARCH = case CPU.downcase
|
58
64
|
when /amd64|x86_64/
|
59
65
|
"x86_64"
|
@@ -82,16 +88,21 @@ module FFI
|
|
82
88
|
OS == os
|
83
89
|
end
|
84
90
|
|
85
|
-
NAME = "#{ARCH}-#{OS}"
|
86
91
|
IS_GNU = defined?(GNU_LIBC)
|
87
92
|
IS_LINUX = is_os("linux")
|
88
93
|
IS_MAC = is_os("darwin")
|
89
94
|
IS_FREEBSD = is_os("freebsd")
|
90
95
|
IS_NETBSD = is_os("netbsd")
|
91
96
|
IS_OPENBSD = is_os("openbsd")
|
97
|
+
IS_DRAGONFLYBSD = is_os("dragonfly")
|
92
98
|
IS_SOLARIS = is_os("solaris")
|
93
99
|
IS_WINDOWS = is_os("windows")
|
94
|
-
IS_BSD = IS_MAC || IS_FREEBSD || IS_NETBSD || IS_OPENBSD
|
100
|
+
IS_BSD = IS_MAC || IS_FREEBSD || IS_NETBSD || IS_OPENBSD || IS_DRAGONFLYBSD
|
101
|
+
|
102
|
+
# Add the version for known ABI breaks
|
103
|
+
name_version = "12" if IS_FREEBSD && OSVERSION >= 12 # 64-bit inodes
|
104
|
+
|
105
|
+
NAME = "#{ARCH}-#{OS}#{name_version}"
|
95
106
|
CONF_DIR = File.join(File.dirname(__FILE__), 'platform', NAME)
|
96
107
|
|
97
108
|
public
|
data/lib/ffi/pointer.rb
CHANGED
@@ -49,7 +49,7 @@ module FFI
|
|
49
49
|
# equivalent string if +len+ is not +nil+.
|
50
50
|
def read_string(len=nil)
|
51
51
|
if len
|
52
|
-
return '' if len == 0
|
52
|
+
return ''.b if len == 0
|
53
53
|
get_bytes(0, len)
|
54
54
|
else
|
55
55
|
get_string(0)
|
@@ -103,7 +103,7 @@ module FFI
|
|
103
103
|
# @return [Array]
|
104
104
|
# Read an array of +type+ of length +length+.
|
105
105
|
# @example
|
106
|
-
# ptr.read_array_of_type(TYPE_UINT8, :
|
106
|
+
# ptr.read_array_of_type(TYPE_UINT8, :read_uint8, 4) # -> [1, 2, 3, 4]
|
107
107
|
def read_array_of_type(type, reader, length)
|
108
108
|
ary = []
|
109
109
|
size = FFI.type_size(type)
|
@@ -124,10 +124,9 @@ module FFI
|
|
124
124
|
# ptr.write_array_of_type(TYPE_UINT8, :put_uint8, [1, 2, 3 ,4])
|
125
125
|
def write_array_of_type(type, writer, ary)
|
126
126
|
size = FFI.type_size(type)
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
tmp += size unless j == ary.length-1 # avoid OOB
|
127
|
+
ary.each_with_index { |val, i|
|
128
|
+
break unless i < self.size
|
129
|
+
self.send(writer, i * size, val)
|
131
130
|
}
|
132
131
|
self
|
133
132
|
end
|
data/lib/ffi/struct.rb
CHANGED
@@ -32,72 +32,12 @@
|
|
32
32
|
#
|
33
33
|
|
34
34
|
require 'ffi/platform'
|
35
|
+
require 'ffi/struct_layout'
|
35
36
|
require 'ffi/struct_layout_builder'
|
37
|
+
require 'ffi/struct_by_reference'
|
36
38
|
|
37
39
|
module FFI
|
38
40
|
|
39
|
-
class StructLayout
|
40
|
-
|
41
|
-
# @return [Array<Array(Symbol, Numeric)>
|
42
|
-
# Get an array of tuples (field name, offset of the field).
|
43
|
-
def offsets
|
44
|
-
members.map { |m| [ m, self[m].offset ] }
|
45
|
-
end
|
46
|
-
|
47
|
-
# @return [Numeric]
|
48
|
-
# Get the offset of a field.
|
49
|
-
def offset_of(field_name)
|
50
|
-
self[field_name].offset
|
51
|
-
end
|
52
|
-
|
53
|
-
# An enum {Field} in a {StructLayout}.
|
54
|
-
class Enum < Field
|
55
|
-
|
56
|
-
# @param [AbstractMemory] ptr pointer on a {Struct}
|
57
|
-
# @return [Object]
|
58
|
-
# Get an object of type {#type} from memory pointed by +ptr+.
|
59
|
-
def get(ptr)
|
60
|
-
type.find(ptr.get_int(offset))
|
61
|
-
end
|
62
|
-
|
63
|
-
# @param [AbstractMemory] ptr pointer on a {Struct}
|
64
|
-
# @param value
|
65
|
-
# @return [nil]
|
66
|
-
# Set +value+ into memory pointed by +ptr+.
|
67
|
-
def put(ptr, value)
|
68
|
-
ptr.put_int(offset, type.find(value))
|
69
|
-
end
|
70
|
-
|
71
|
-
end
|
72
|
-
|
73
|
-
class InnerStruct < Field
|
74
|
-
def get(ptr)
|
75
|
-
type.struct_class.new(ptr.slice(self.offset, self.size))
|
76
|
-
end
|
77
|
-
|
78
|
-
def put(ptr, value)
|
79
|
-
raise TypeError, "wrong value type (expected #{type.struct_class})" unless value.is_a?(type.struct_class)
|
80
|
-
ptr.slice(self.offset, self.size).__copy_from__(value.pointer, self.size)
|
81
|
-
end
|
82
|
-
end
|
83
|
-
|
84
|
-
class Mapped < Field
|
85
|
-
def initialize(name, offset, type, orig_field)
|
86
|
-
super(name, offset, type)
|
87
|
-
@orig_field = orig_field
|
88
|
-
end
|
89
|
-
|
90
|
-
def get(ptr)
|
91
|
-
type.from_native(@orig_field.get(ptr), nil)
|
92
|
-
end
|
93
|
-
|
94
|
-
def put(ptr, value)
|
95
|
-
@orig_field.put(ptr, type.to_native(value, nil))
|
96
|
-
end
|
97
|
-
end
|
98
|
-
end
|
99
|
-
|
100
|
-
|
101
41
|
class Struct
|
102
42
|
|
103
43
|
# Get struct size
|
@@ -250,7 +190,7 @@ module FFI
|
|
250
190
|
# :field2, :pointer, 6, # set offset to 6 for this field
|
251
191
|
# :field3, :string
|
252
192
|
# end
|
253
|
-
# @example Creating a layout from a hash +spec+
|
193
|
+
# @example Creating a layout from a hash +spec+
|
254
194
|
# class MyStructFromHash < Struct
|
255
195
|
# layout :field1 => :int,
|
256
196
|
# :field2 => :pointer,
|
@@ -262,9 +202,8 @@ module FFI
|
|
262
202
|
# :function2, callback([:pointer], :void),
|
263
203
|
# :field3, :string
|
264
204
|
# end
|
265
|
-
# @note Creating a layout from a hash +spec+ is supported only for Ruby 1.9.
|
266
205
|
def layout(*spec)
|
267
|
-
|
206
|
+
warn "[DEPRECATION] Struct layout is already defined for class #{self.inspect}. Redefinition as in #{caller[0]} will be disallowed in ffi-2.0." if defined?(@layout)
|
268
207
|
return @layout if spec.size == 0
|
269
208
|
|
270
209
|
builder = StructLayoutBuilder.new
|
@@ -296,7 +235,7 @@ module FFI
|
|
296
235
|
@packed = packed
|
297
236
|
end
|
298
237
|
alias :pack :packed
|
299
|
-
|
238
|
+
|
300
239
|
def aligned(alignment = 1)
|
301
240
|
@min_alignment = alignment
|
302
241
|
end
|
@@ -0,0 +1,72 @@
|
|
1
|
+
#
|
2
|
+
# Copyright (C) 2010 Wayne Meissner
|
3
|
+
#
|
4
|
+
# This file is part of ruby-ffi.
|
5
|
+
#
|
6
|
+
# All rights reserved.
|
7
|
+
#
|
8
|
+
# Redistribution and use in source and binary forms, with or without
|
9
|
+
# modification, are permitted provided that the following conditions are met:
|
10
|
+
#
|
11
|
+
# * Redistributions of source code must retain the above copyright notice, this
|
12
|
+
# list of conditions and the following disclaimer.
|
13
|
+
# * Redistributions in binary form must reproduce the above copyright notice
|
14
|
+
# this list of conditions and the following disclaimer in the documentation
|
15
|
+
# and/or other materials provided with the distribution.
|
16
|
+
# * Neither the name of the Ruby FFI project nor the names of its contributors
|
17
|
+
# may be used to endorse or promote products derived from this software
|
18
|
+
# without specific prior written permission.
|
19
|
+
#
|
20
|
+
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
21
|
+
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
22
|
+
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
23
|
+
# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
|
24
|
+
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
25
|
+
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
26
|
+
# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
27
|
+
# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
28
|
+
# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
29
|
+
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.#
|
30
|
+
|
31
|
+
module FFI
|
32
|
+
# This class includes the {FFI::DataConverter} module.
|
33
|
+
class StructByReference
|
34
|
+
include DataConverter
|
35
|
+
|
36
|
+
attr_reader :struct_class
|
37
|
+
|
38
|
+
# @param [Struct] struct_class
|
39
|
+
def initialize(struct_class)
|
40
|
+
unless Class === struct_class and struct_class < FFI::Struct
|
41
|
+
raise TypeError, 'wrong type (expected subclass of FFI::Struct)'
|
42
|
+
end
|
43
|
+
@struct_class = struct_class
|
44
|
+
end
|
45
|
+
|
46
|
+
# Always get {FFI::Type}::POINTER.
|
47
|
+
def native_type
|
48
|
+
FFI::Type::POINTER
|
49
|
+
end
|
50
|
+
|
51
|
+
# @param [nil, Struct] value
|
52
|
+
# @param [nil] ctx
|
53
|
+
# @return [AbstractMemory] Pointer on +value+.
|
54
|
+
def to_native(value, ctx)
|
55
|
+
return Pointer::NULL if value.nil?
|
56
|
+
|
57
|
+
unless @struct_class === value
|
58
|
+
raise TypeError, "wrong argument type #{value.class} (expected #{@struct_class})"
|
59
|
+
end
|
60
|
+
|
61
|
+
value.pointer
|
62
|
+
end
|
63
|
+
|
64
|
+
# @param [AbstractMemory] value
|
65
|
+
# @param [nil] ctx
|
66
|
+
# @return [Struct]
|
67
|
+
# Create a struct from content of memory +value+.
|
68
|
+
def from_native(value, ctx)
|
69
|
+
@struct_class.new(value)
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
@@ -0,0 +1,96 @@
|
|
1
|
+
#
|
2
|
+
# Copyright (C) 2008-2010 Wayne Meissner
|
3
|
+
# Copyright (C) 2008, 2009 Andrea Fazzi
|
4
|
+
# Copyright (C) 2008, 2009 Luc Heinrich
|
5
|
+
#
|
6
|
+
# This file is part of ruby-ffi.
|
7
|
+
#
|
8
|
+
# All rights reserved.
|
9
|
+
#
|
10
|
+
# Redistribution and use in source and binary forms, with or without
|
11
|
+
# modification, are permitted provided that the following conditions are met:
|
12
|
+
#
|
13
|
+
# * Redistributions of source code must retain the above copyright notice, this
|
14
|
+
# list of conditions and the following disclaimer.
|
15
|
+
# * Redistributions in binary form must reproduce the above copyright notice
|
16
|
+
# this list of conditions and the following disclaimer in the documentation
|
17
|
+
# and/or other materials provided with the distribution.
|
18
|
+
# * Neither the name of the Ruby FFI project nor the names of its contributors
|
19
|
+
# may be used to endorse or promote products derived from this software
|
20
|
+
# without specific prior written permission.
|
21
|
+
#
|
22
|
+
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
23
|
+
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
24
|
+
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
25
|
+
# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
|
26
|
+
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
27
|
+
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
28
|
+
# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
29
|
+
# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
30
|
+
# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
31
|
+
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
32
|
+
#
|
33
|
+
|
34
|
+
module FFI
|
35
|
+
|
36
|
+
class StructLayout
|
37
|
+
|
38
|
+
# @return [Array<Array(Symbol, Numeric)>
|
39
|
+
# Get an array of tuples (field name, offset of the field).
|
40
|
+
def offsets
|
41
|
+
members.map { |m| [ m, self[m].offset ] }
|
42
|
+
end
|
43
|
+
|
44
|
+
# @return [Numeric]
|
45
|
+
# Get the offset of a field.
|
46
|
+
def offset_of(field_name)
|
47
|
+
self[field_name].offset
|
48
|
+
end
|
49
|
+
|
50
|
+
# An enum {Field} in a {StructLayout}.
|
51
|
+
class Enum < Field
|
52
|
+
|
53
|
+
# @param [AbstractMemory] ptr pointer on a {Struct}
|
54
|
+
# @return [Object]
|
55
|
+
# Get an object of type {#type} from memory pointed by +ptr+.
|
56
|
+
def get(ptr)
|
57
|
+
type.find(ptr.get_int(offset))
|
58
|
+
end
|
59
|
+
|
60
|
+
# @param [AbstractMemory] ptr pointer on a {Struct}
|
61
|
+
# @param value
|
62
|
+
# @return [nil]
|
63
|
+
# Set +value+ into memory pointed by +ptr+.
|
64
|
+
def put(ptr, value)
|
65
|
+
ptr.put_int(offset, type.find(value))
|
66
|
+
end
|
67
|
+
|
68
|
+
end
|
69
|
+
|
70
|
+
class InnerStruct < Field
|
71
|
+
def get(ptr)
|
72
|
+
type.struct_class.new(ptr.slice(self.offset, self.size))
|
73
|
+
end
|
74
|
+
|
75
|
+
def put(ptr, value)
|
76
|
+
raise TypeError, "wrong value type (expected #{type.struct_class})" unless value.is_a?(type.struct_class)
|
77
|
+
ptr.slice(self.offset, self.size).__copy_from__(value.pointer, self.size)
|
78
|
+
end
|
79
|
+
end
|
80
|
+
|
81
|
+
class Mapped < Field
|
82
|
+
def initialize(name, offset, type, orig_field)
|
83
|
+
super(name, offset, type)
|
84
|
+
@orig_field = orig_field
|
85
|
+
end
|
86
|
+
|
87
|
+
def get(ptr)
|
88
|
+
type.from_native(@orig_field.get(ptr), nil)
|
89
|
+
end
|
90
|
+
|
91
|
+
def put(ptr, value)
|
92
|
+
@orig_field.put(ptr, type.to_native(value, nil))
|
93
|
+
end
|
94
|
+
end
|
95
|
+
end
|
96
|
+
end
|
@@ -6,6 +6,7 @@ module FFI
|
|
6
6
|
# ConstGenerator turns C constants into ruby values.
|
7
7
|
#
|
8
8
|
# @example a simple example for stdio
|
9
|
+
# require 'ffi/tools/const_generator'
|
9
10
|
# cg = FFI::ConstGenerator.new('stdio') do |gen|
|
10
11
|
# gen.const(:SEEK_SET)
|
11
12
|
# gen.const('SEEK_CUR')
|
@@ -25,10 +26,10 @@ module FFI
|
|
25
26
|
#
|
26
27
|
# The only option is +:required+, which if set to +true+ raises an error if a
|
27
28
|
# constant you have requested was not found.
|
28
|
-
#
|
29
|
+
#
|
29
30
|
# @param [#to_s] prefix
|
30
31
|
# @param [Hash] options
|
31
|
-
# @return
|
32
|
+
# @return
|
32
33
|
# @option options [Boolean] :required
|
33
34
|
# @overload initialize(prefix, options)
|
34
35
|
# @overload initialize(prefix, options) { |gen| ... }
|
@@ -79,7 +80,7 @@ module FFI
|
|
79
80
|
# @param [#call] converter convert the value from a string to the appropriate
|
80
81
|
# type for {#to_ruby}.
|
81
82
|
# @overload const(name, format=nil, cast='', ruby_name=nil) { |value| ... }
|
82
|
-
# Use a converter block. This block convert the value from a string to the
|
83
|
+
# Use a converter block. This block convert the value from a string to the
|
83
84
|
# appropriate type for {#to_ruby}.
|
84
85
|
# @yieldparam value constant value
|
85
86
|
def const(name, format = nil, cast = '', ruby_name = nil, converter = nil,
|
@@ -224,6 +225,6 @@ module FFI
|
|
224
225
|
"#{ruby_name} = #{converted_value}"
|
225
226
|
end
|
226
227
|
|
227
|
-
end
|
228
|
+
end
|
228
229
|
|
229
230
|
end
|
data/lib/ffi/tools/generator.rb
CHANGED
@@ -1,6 +1,51 @@
|
|
1
|
+
require 'ffi/tools/struct_generator'
|
2
|
+
require 'ffi/tools/const_generator'
|
3
|
+
|
1
4
|
module FFI
|
2
5
|
|
3
|
-
|
6
|
+
##
|
7
|
+
# Generate files with C structs for FFI::Struct and C constants.
|
8
|
+
#
|
9
|
+
# == A simple example
|
10
|
+
#
|
11
|
+
# In file +zlib.rb.ffi+:
|
12
|
+
# module Zlib
|
13
|
+
# @@@
|
14
|
+
# constants do |c|
|
15
|
+
# c.include "zlib.h"
|
16
|
+
# c.const :ZLIB_VERNUM
|
17
|
+
# end
|
18
|
+
# @@@
|
19
|
+
#
|
20
|
+
# class ZStream < FFI::Struct
|
21
|
+
#
|
22
|
+
# struct do |s|
|
23
|
+
# s.name "struct z_stream_s"
|
24
|
+
# s.include "zlib.h"
|
25
|
+
#
|
26
|
+
# s.field :next_in, :pointer
|
27
|
+
# s.field :avail_in, :uint
|
28
|
+
# s.field :total_in, :ulong
|
29
|
+
# end
|
30
|
+
# @@@
|
31
|
+
# end
|
32
|
+
# end
|
33
|
+
#
|
34
|
+
# Translate the file:
|
35
|
+
# require "ffi/tools/generator"
|
36
|
+
# FFI::Generator.new "zlib.rb.ffi", "zlib.rb"
|
37
|
+
#
|
38
|
+
# Generates the file +zlib.rb+ with constant values and offsets:
|
39
|
+
# module Zlib
|
40
|
+
# ZLIB_VERNUM = 4784
|
41
|
+
#
|
42
|
+
# class ZStream < FFI::Struct
|
43
|
+
# layout :next_in, :pointer, 0,
|
44
|
+
# :avail_in, :uint, 8,
|
45
|
+
# :total_in, :ulong, 16
|
46
|
+
# end
|
47
|
+
#
|
48
|
+
# @see FFI::Generator::Task for easy integration in a Rakefile
|
4
49
|
class Generator
|
5
50
|
|
6
51
|
def initialize(ffi_name, rb_name, options = {})
|
@@ -34,7 +79,7 @@ module FFI
|
|
34
79
|
end
|
35
80
|
|
36
81
|
open @rb_name, 'w' do |f|
|
37
|
-
f.puts "# This file is generated
|
82
|
+
f.puts "# This file is generated from `#{@ffi_name}'. Do not edit."
|
38
83
|
f.puts
|
39
84
|
f.puts new_file
|
40
85
|
end
|