ffi 1.0.0 → 1.17.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- checksums.yaml.gz.sig +4 -0
- data/CHANGELOG.md +465 -0
- data/COPYING +49 -0
- data/Gemfile +21 -0
- data/LICENSE +21 -11
- data/LICENSE.SPECS +22 -0
- data/README.md +137 -0
- data/Rakefile +165 -148
- data/ext/ffi_c/AbstractMemory.c +716 -97
- data/ext/ffi_c/AbstractMemory.h +38 -17
- data/ext/ffi_c/ArrayType.c +102 -33
- data/ext/ffi_c/ArrayType.h +20 -18
- data/ext/ffi_c/Buffer.c +229 -54
- data/ext/ffi_c/Call.c +211 -100
- data/ext/ffi_c/Call.h +46 -28
- data/ext/ffi_c/ClosurePool.c +110 -81
- data/ext/ffi_c/ClosurePool.h +31 -1
- data/ext/ffi_c/DynamicLibrary.c +216 -54
- data/ext/ffi_c/DynamicLibrary.h +76 -0
- data/ext/ffi_c/Function.c +527 -164
- data/ext/ffi_c/Function.h +24 -20
- data/ext/ffi_c/FunctionInfo.c +151 -50
- data/ext/ffi_c/LastError.c +112 -28
- data/ext/ffi_c/LastError.h +29 -0
- data/ext/ffi_c/LongDouble.c +65 -0
- data/ext/ffi_c/LongDouble.h +47 -0
- data/ext/ffi_c/MappedType.c +107 -42
- data/ext/ffi_c/MappedType.h +20 -20
- data/ext/ffi_c/MemoryPointer.c +108 -46
- data/ext/ffi_c/MemoryPointer.h +33 -4
- data/ext/ffi_c/MethodHandle.c +71 -67
- data/ext/ffi_c/MethodHandle.h +26 -23
- data/ext/ffi_c/Platform.c +42 -25
- data/ext/ffi_c/Platform.h +32 -3
- data/ext/ffi_c/Pointer.c +324 -51
- data/ext/ffi_c/Pointer.h +29 -18
- data/ext/ffi_c/Struct.c +434 -161
- data/ext/ffi_c/Struct.h +47 -27
- data/ext/ffi_c/StructByValue.c +74 -37
- data/ext/ffi_c/StructByValue.h +20 -18
- data/ext/ffi_c/StructLayout.c +358 -87
- data/ext/ffi_c/Thread.c +129 -0
- data/ext/ffi_c/Thread.h +76 -0
- data/ext/ffi_c/Type.c +241 -76
- data/ext/ffi_c/Type.h +27 -11
- data/ext/ffi_c/Types.c +54 -34
- data/ext/ffi_c/Types.h +24 -24
- data/ext/ffi_c/Variadic.c +151 -55
- data/ext/ffi_c/compat.h +48 -38
- data/ext/ffi_c/extconf.rb +106 -34
- data/ext/ffi_c/ffi.c +35 -26
- data/ext/ffi_c/libffi/.allow-ai-service +0 -0
- data/ext/ffi_c/libffi/.appveyor/site.exp +16 -0
- data/ext/ffi_c/libffi/.appveyor/unix-noexec.exp +7 -0
- data/ext/ffi_c/libffi/.appveyor.yml +84 -0
- data/ext/ffi_c/libffi/.ci/ar-lib +270 -0
- data/ext/ffi_c/libffi/.ci/bfin-sim.exp +58 -0
- data/ext/ffi_c/libffi/.ci/build-cross-in-container.sh +18 -0
- data/ext/ffi_c/libffi/.ci/build-in-container.sh +10 -0
- data/ext/ffi_c/libffi/.ci/build.sh +124 -0
- data/ext/ffi_c/libffi/.ci/compile +351 -0
- data/ext/ffi_c/libffi/.ci/install.sh +78 -0
- data/ext/ffi_c/libffi/.ci/m32r-sim.exp +58 -0
- data/ext/ffi_c/libffi/.ci/moxie-sim.exp +60 -0
- data/ext/ffi_c/libffi/.ci/msvs-detect +1103 -0
- data/ext/ffi_c/libffi/.ci/or1k-sim.exp +58 -0
- data/ext/ffi_c/libffi/.ci/powerpc-eabisim.exp +58 -0
- data/ext/ffi_c/libffi/.ci/site.exp +29 -0
- data/ext/ffi_c/libffi/.ci/wine-sim.exp +55 -0
- data/ext/ffi_c/libffi/.circleci/config.yml +156 -0
- data/ext/ffi_c/libffi/.gitattributes +4 -0
- data/ext/ffi_c/libffi/.github/issue_template.md +10 -0
- data/ext/ffi_c/libffi/.github/workflows/build.yml +479 -0
- data/ext/ffi_c/libffi/.github/workflows/emscripten.yml +172 -0
- data/ext/ffi_c/libffi/.gitignore +46 -0
- data/ext/ffi_c/libffi/{ChangeLog → ChangeLog.old} +6528 -3180
- data/ext/ffi_c/libffi/LICENSE +3 -3
- data/ext/ffi_c/libffi/LICENSE-BUILDTOOLS +353 -0
- data/ext/ffi_c/libffi/Makefile.am +132 -162
- data/ext/ffi_c/libffi/Makefile.in +1339 -1003
- data/ext/ffi_c/libffi/README.md +531 -0
- data/ext/ffi_c/libffi/acinclude.m4 +289 -4
- data/ext/ffi_c/libffi/autogen.sh +2 -0
- data/ext/ffi_c/libffi/compile +227 -21
- data/ext/ffi_c/libffi/config.guess +1034 -778
- data/ext/ffi_c/libffi/config.sub +1394 -1204
- data/ext/ffi_c/libffi/configure +14327 -8503
- data/ext/ffi_c/libffi/configure.ac +294 -247
- data/ext/ffi_c/libffi/configure.host +330 -4
- data/ext/ffi_c/libffi/doc/Makefile.am +3 -0
- data/ext/ffi_c/libffi/doc/Makefile.in +818 -0
- data/ext/ffi_c/libffi/doc/libffi.texi +572 -67
- data/ext/ffi_c/libffi/doc/version.texi +4 -4
- data/ext/ffi_c/libffi/fficonfig.h.in +53 -46
- data/ext/ffi_c/libffi/generate-darwin-source-and-headers.py +312 -0
- data/ext/ffi_c/libffi/include/Makefile.am +3 -3
- data/ext/ffi_c/libffi/include/Makefile.in +219 -79
- data/ext/ffi_c/libffi/include/ffi.h.in +230 -111
- data/ext/ffi_c/libffi/include/ffi_cfi.h +76 -0
- data/ext/ffi_c/libffi/include/ffi_common.h +78 -16
- data/ext/ffi_c/libffi/include/tramp.h +45 -0
- data/ext/ffi_c/libffi/install-sh +402 -184
- data/ext/ffi_c/libffi/libffi.map.in +81 -0
- data/ext/ffi_c/libffi/libffi.pc.in +3 -2
- data/ext/ffi_c/libffi/libffi.xcodeproj/project.pbxproj +997 -0
- data/ext/ffi_c/libffi/libtool-ldflags +106 -0
- data/ext/ffi_c/libffi/libtool-version +2 -2
- data/ext/ffi_c/libffi/ltmain.sh +5752 -2722
- data/ext/ffi_c/libffi/m4/asmcfi.m4 +13 -0
- data/ext/ffi_c/libffi/m4/ax_append_flag.m4 +50 -0
- data/ext/ffi_c/libffi/m4/ax_cc_maxopt.m4 +198 -0
- data/ext/ffi_c/libffi/m4/ax_cflags_warn_all.m4 +158 -0
- data/ext/ffi_c/libffi/m4/ax_check_compile_flag.m4 +53 -0
- data/ext/ffi_c/libffi/m4/ax_compiler_vendor.m4 +119 -0
- data/ext/ffi_c/libffi/m4/ax_configure_args.m4 +49 -0
- data/ext/ffi_c/libffi/m4/ax_enable_builddir.m4 +302 -0
- data/ext/ffi_c/libffi/m4/ax_gcc_archflag.m4 +267 -0
- data/ext/ffi_c/libffi/m4/ax_gcc_x86_cpuid.m4 +89 -0
- data/ext/ffi_c/libffi/m4/ax_prepend_flag.m4 +51 -0
- data/ext/ffi_c/libffi/m4/ax_require_defined.m4 +37 -0
- data/ext/ffi_c/libffi/make_sunver.pl +333 -0
- data/ext/ffi_c/libffi/man/Makefile.am +2 -2
- data/ext/ffi_c/libffi/man/Makefile.in +174 -57
- data/ext/ffi_c/libffi/man/ffi.3 +10 -0
- data/ext/ffi_c/libffi/man/ffi_prep_cif.3 +6 -4
- data/ext/ffi_c/libffi/man/ffi_prep_cif_var.3 +73 -0
- data/ext/ffi_c/libffi/missing +155 -300
- 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 +353 -0
- data/ext/ffi_c/libffi/src/aarch64/ffi.c +1142 -0
- data/ext/ffi_c/libffi/src/aarch64/ffitarget.h +97 -0
- data/ext/ffi_c/libffi/src/aarch64/internal.h +100 -0
- data/ext/ffi_c/libffi/src/aarch64/sysv.S +695 -0
- data/ext/ffi_c/libffi/src/aarch64/win64_armasm.S +506 -0
- data/ext/ffi_c/libffi/src/alpha/ffi.c +335 -98
- data/ext/ffi_c/libffi/src/alpha/ffitarget.h +10 -1
- data/ext/ffi_c/libffi/src/alpha/internal.h +23 -0
- data/ext/ffi_c/libffi/src/alpha/osf.S +162 -246
- data/ext/ffi_c/libffi/src/arc/arcompact.S +210 -0
- data/ext/ffi_c/libffi/src/arc/ffi.c +443 -0
- data/ext/ffi_c/libffi/src/arc/ffitarget.h +67 -0
- data/ext/ffi_c/libffi/src/arm/ffi.c +806 -194
- data/ext/ffi_c/libffi/src/arm/ffitarget.h +43 -3
- data/ext/ffi_c/libffi/src/arm/internal.h +17 -0
- data/ext/ffi_c/libffi/src/arm/sysv.S +381 -231
- data/ext/ffi_c/libffi/src/arm/sysv_msvc_arm32.S +311 -0
- data/ext/ffi_c/libffi/src/avr32/ffi.c +4 -2
- data/ext/ffi_c/libffi/src/avr32/ffitarget.h +8 -3
- data/ext/ffi_c/libffi/src/bfin/ffi.c +196 -0
- data/ext/ffi_c/libffi/src/bfin/ffitarget.h +43 -0
- data/ext/ffi_c/libffi/src/bfin/sysv.S +179 -0
- data/ext/ffi_c/libffi/src/closures.c +574 -100
- data/ext/ffi_c/libffi/src/cris/ffi.c +11 -8
- data/ext/ffi_c/libffi/src/cris/ffitarget.h +8 -3
- data/ext/ffi_c/libffi/src/csky/ffi.c +395 -0
- data/ext/ffi_c/libffi/src/csky/ffitarget.h +63 -0
- data/ext/ffi_c/libffi/src/csky/sysv.S +371 -0
- data/ext/ffi_c/libffi/src/debug.c +8 -3
- data/ext/ffi_c/libffi/src/dlmalloc.c +89 -17
- data/ext/ffi_c/libffi/src/frv/ffi.c +2 -2
- data/ext/ffi_c/libffi/src/frv/ffitarget.h +8 -7
- data/ext/ffi_c/libffi/src/ia64/ffi.c +48 -12
- data/ext/ffi_c/libffi/src/ia64/ffitarget.h +10 -4
- data/ext/ffi_c/libffi/src/ia64/unix.S +28 -3
- data/ext/ffi_c/libffi/src/java_raw_api.c +24 -6
- data/ext/ffi_c/libffi/src/kvx/asm.h +5 -0
- data/ext/ffi_c/libffi/src/kvx/ffi.c +273 -0
- data/ext/ffi_c/libffi/src/kvx/ffitarget.h +75 -0
- data/ext/ffi_c/libffi/src/kvx/sysv.S +127 -0
- data/ext/ffi_c/libffi/src/loongarch64/ffi.c +624 -0
- data/ext/ffi_c/libffi/src/loongarch64/ffitarget.h +82 -0
- data/ext/ffi_c/libffi/src/loongarch64/sysv.S +327 -0
- data/ext/ffi_c/libffi/src/m32r/ffi.c +32 -15
- data/ext/ffi_c/libffi/src/m32r/ffitarget.h +8 -3
- data/ext/ffi_c/libffi/src/m68k/ffi.c +97 -13
- data/ext/ffi_c/libffi/src/m68k/ffitarget.h +8 -3
- data/ext/ffi_c/libffi/src/m68k/sysv.S +148 -25
- data/ext/ffi_c/libffi/src/m88k/ffi.c +400 -0
- data/ext/ffi_c/libffi/src/m88k/ffitarget.h +49 -0
- data/ext/ffi_c/libffi/src/m88k/obsd.S +209 -0
- data/ext/ffi_c/libffi/src/metag/ffi.c +330 -0
- data/ext/ffi_c/libffi/src/metag/ffitarget.h +53 -0
- data/ext/ffi_c/libffi/src/metag/sysv.S +311 -0
- data/ext/ffi_c/libffi/src/microblaze/ffi.c +321 -0
- data/ext/ffi_c/libffi/src/microblaze/ffitarget.h +53 -0
- data/ext/ffi_c/libffi/src/microblaze/sysv.S +302 -0
- data/ext/ffi_c/libffi/src/mips/ffi.c +392 -104
- data/ext/ffi_c/libffi/src/mips/ffitarget.h +40 -24
- data/ext/ffi_c/libffi/src/mips/n32.S +325 -93
- data/ext/ffi_c/libffi/src/mips/o32.S +211 -31
- data/ext/ffi_c/libffi/src/moxie/eabi.S +101 -0
- data/ext/ffi_c/libffi/src/moxie/ffi.c +310 -0
- data/ext/ffi_c/libffi/src/moxie/ffitarget.h +52 -0
- data/ext/ffi_c/libffi/src/nios2/ffi.c +304 -0
- data/ext/ffi_c/libffi/src/nios2/ffitarget.h +52 -0
- data/ext/ffi_c/libffi/src/nios2/sysv.S +136 -0
- data/ext/ffi_c/libffi/src/or1k/ffi.c +341 -0
- data/ext/ffi_c/libffi/src/or1k/ffitarget.h +58 -0
- data/ext/ffi_c/libffi/src/or1k/sysv.S +107 -0
- data/ext/ffi_c/libffi/src/pa/ffi.c +68 -111
- data/ext/ffi_c/libffi/src/pa/ffi64.c +614 -0
- data/ext/ffi_c/libffi/src/pa/ffitarget.h +34 -17
- data/ext/ffi_c/libffi/src/pa/hpux32.S +87 -38
- data/ext/ffi_c/libffi/src/pa/hpux64.S +681 -0
- data/ext/ffi_c/libffi/src/pa/linux.S +109 -39
- data/ext/ffi_c/libffi/src/powerpc/aix.S +250 -8
- data/ext/ffi_c/libffi/src/powerpc/aix_closure.S +255 -4
- data/ext/ffi_c/libffi/src/powerpc/asm.h +3 -3
- data/ext/ffi_c/libffi/src/powerpc/darwin.S +211 -78
- data/ext/ffi_c/libffi/src/powerpc/darwin_closure.S +356 -102
- data/ext/ffi_c/libffi/src/powerpc/ffi.c +108 -1375
- data/ext/ffi_c/libffi/src/powerpc/ffi_darwin.c +746 -210
- data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +1153 -0
- data/ext/ffi_c/libffi/src/powerpc/ffi_powerpc.h +105 -0
- data/ext/ffi_c/libffi/src/powerpc/ffi_sysv.c +923 -0
- data/ext/ffi_c/libffi/src/powerpc/ffitarget.h +126 -48
- data/ext/ffi_c/libffi/src/powerpc/linux64.S +191 -85
- data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +438 -108
- data/ext/ffi_c/libffi/src/powerpc/ppc_closure.S +138 -68
- data/ext/ffi_c/libffi/src/powerpc/sysv.S +73 -119
- data/ext/ffi_c/libffi/src/powerpc/t-aix +5 -0
- data/ext/ffi_c/libffi/src/prep_cif.c +141 -32
- data/ext/ffi_c/libffi/src/raw_api.c +18 -5
- data/ext/ffi_c/libffi/src/riscv/ffi.c +514 -0
- data/ext/ffi_c/libffi/src/riscv/ffitarget.h +69 -0
- data/ext/ffi_c/libffi/src/riscv/sysv.S +293 -0
- data/ext/ffi_c/libffi/src/s390/ffi.c +294 -318
- data/ext/ffi_c/libffi/src/s390/ffitarget.h +13 -3
- data/ext/ffi_c/libffi/src/s390/internal.h +11 -0
- data/ext/ffi_c/libffi/src/s390/sysv.S +257 -366
- data/ext/ffi_c/libffi/src/sh/ffi.c +4 -3
- data/ext/ffi_c/libffi/src/sh/ffitarget.h +8 -3
- data/ext/ffi_c/libffi/src/sh64/ffi.c +3 -2
- data/ext/ffi_c/libffi/src/sh64/ffitarget.h +8 -3
- data/ext/ffi_c/libffi/src/sparc/ffi.c +334 -491
- data/ext/ffi_c/libffi/src/sparc/ffi64.c +630 -0
- data/ext/ffi_c/libffi/src/sparc/ffitarget.h +20 -5
- data/ext/ffi_c/libffi/src/sparc/internal.h +26 -0
- data/ext/ffi_c/libffi/src/sparc/v8.S +364 -234
- data/ext/ffi_c/libffi/src/sparc/v9.S +340 -207
- data/ext/ffi_c/libffi/src/tile/ffi.c +355 -0
- data/ext/ffi_c/libffi/src/tile/ffitarget.h +65 -0
- data/ext/ffi_c/libffi/src/tile/tile.S +360 -0
- data/ext/ffi_c/libffi/src/tramp.c +716 -0
- data/ext/ffi_c/libffi/src/types.c +48 -19
- data/ext/ffi_c/libffi/src/vax/elfbsd.S +195 -0
- data/ext/ffi_c/libffi/src/vax/ffi.c +276 -0
- data/ext/ffi_c/libffi/src/vax/ffitarget.h +49 -0
- data/ext/ffi_c/libffi/src/wasm32/ffi.c +947 -0
- data/ext/ffi_c/libffi/src/wasm32/ffitarget.h +62 -0
- data/ext/ffi_c/libffi/src/x86/asmnames.h +30 -0
- data/ext/ffi_c/libffi/src/x86/ffi.c +690 -540
- data/ext/ffi_c/libffi/src/x86/ffi64.c +450 -126
- data/ext/ffi_c/libffi/src/x86/ffitarget.h +86 -42
- data/ext/ffi_c/libffi/src/x86/ffiw64.c +361 -0
- data/ext/ffi_c/libffi/src/x86/internal.h +43 -0
- data/ext/ffi_c/libffi/src/x86/internal64.h +36 -0
- data/ext/ffi_c/libffi/src/x86/sysv.S +1199 -381
- data/ext/ffi_c/libffi/src/x86/sysv_intel.S +998 -0
- data/ext/ffi_c/libffi/src/x86/unix64.S +587 -298
- data/ext/ffi_c/libffi/src/x86/win64.S +251 -457
- data/ext/ffi_c/libffi/src/x86/win64_intel.S +238 -0
- data/ext/ffi_c/libffi/src/xtensa/ffi.c +306 -0
- data/ext/ffi_c/libffi/src/xtensa/ffitarget.h +57 -0
- data/ext/ffi_c/libffi/src/xtensa/sysv.S +268 -0
- data/ext/ffi_c/libffi/stamp-h.in +1 -0
- data/ext/ffi_c/libffi/testsuite/Makefile.am +80 -73
- data/ext/ffi_c/libffi/testsuite/Makefile.in +251 -117
- data/ext/ffi_c/libffi/testsuite/emscripten/build-tests.sh +54 -0
- data/ext/ffi_c/libffi/testsuite/emscripten/build.sh +63 -0
- data/ext/ffi_c/libffi/testsuite/emscripten/conftest.py +86 -0
- data/ext/ffi_c/libffi/testsuite/emscripten/node-tests.sh +48 -0
- data/ext/ffi_c/libffi/testsuite/emscripten/test.html +7 -0
- data/ext/ffi_c/libffi/testsuite/emscripten/test_libffi.py +51 -0
- data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +682 -0
- data/ext/ffi_c/libffi/testsuite/lib/target-libpath.exp +22 -2
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/Makefile +28 -0
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/README +78 -0
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/alignof.h +50 -0
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/bhaible.exp +63 -0
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-call.c +1746 -0
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-callback.c +2885 -0
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/testcases.c +747 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/align_mixed.c +46 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/align_stdcall.c +46 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/bpo_38748.c +41 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/call.exp +28 -10
- data/ext/ffi_c/libffi/testsuite/libffi.call/callback.c +99 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/callback2.c +108 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/callback3.c +114 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/callback4.c +119 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/err_bad_typedef.c +4 -3
- data/ext/ffi_c/libffi/testsuite/libffi.call/ffitest.h +88 -42
- data/ext/ffi_c/libffi/testsuite/libffi.call/float1.c +3 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/float2.c +15 -12
- data/ext/ffi_c/libffi/testsuite/libffi.call/float3.c +4 -2
- data/ext/ffi_c/libffi/testsuite/libffi.call/float_va.c +110 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/many.c +6 -16
- data/ext/ffi_c/libffi/testsuite/libffi.call/many2.c +57 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/many_double.c +70 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/many_mixed.c +78 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/negint.c +0 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/offsets.c +46 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/pr1172638.c +127 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl.c +1 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_ldl.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll1.c +6 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_sc.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_sl.c +4 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_uc.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_ul.c +4 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/s55.c +60 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/strlen.c +9 -10
- data/ext/ffi_c/libffi/testsuite/libffi.call/strlen2.c +49 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/strlen3.c +49 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/strlen4.c +55 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct1.c +9 -7
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct10.c +57 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct2.c +7 -7
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct3.c +7 -6
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct4.c +9 -8
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct5.c +9 -8
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct6.c +9 -9
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct7.c +9 -9
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct8.c +9 -8
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct9.c +9 -8
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_2.c +63 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_3.c +65 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_3f.c +65 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_4.c +67 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_4f.c +67 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_big.c +93 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_small.c +61 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_return_2H.c +63 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_return_8H.c +90 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/uninitialized.c +61 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_1.c +78 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_2.c +220 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_3.c +154 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct1.c +134 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct2.c +134 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct3.c +140 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/closure.exp +67 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn0.c +3 -2
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn1.c +2 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn2.c +2 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn3.c +21 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn4.c +2 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn5.c +2 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn6.c +2 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_loc_fn0.c +7 -6
- data/ext/ffi_c/libffi/testsuite/{libffi.call/closure_stdcall.c → libffi.closures/closure_simple.c} +13 -16
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_12byte.c +22 -4
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_16byte.c +26 -4
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_18byte.c +28 -4
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_19byte.c +33 -4
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_1_1byte.c +8 -4
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte.c +23 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte1.c +25 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_24byte.c +40 -8
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_2byte.c +17 -4
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3_1byte.c +23 -4
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte1.c +17 -4
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte2.c +17 -4
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3float.c +113 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4_1byte.c +26 -4
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4byte.c +17 -4
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5_1_byte.c +33 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5byte.c +23 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_64byte.c +29 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6_1_byte.c +32 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6byte.c +28 -6
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7_1_byte.c +43 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7byte.c +29 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_8byte.c +18 -4
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte1.c +18 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte2.c +18 -6
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_double.c +23 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_float.c +23 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble.c +24 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split.c +44 -31
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split2.c +44 -9
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_pointer.c +23 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint16.c +22 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint32.c +22 -7
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint64.c +23 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint16.c +22 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint32.c +23 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint64.c +24 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_dbls_struct.c +7 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_double_va.c +21 -9
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_float.c +4 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble.c +13 -3
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble_va.c +34 -11
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_many_mixed_args.c +70 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_many_mixed_float_double.c +55 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_schar.c +5 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshort.c +6 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshortchar.c +9 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_uchar.c +9 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushort.c +6 -2
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushortchar.c +9 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer.c +7 -2
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer_stack.c +22 -10
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_schar.c +3 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sint.c +2 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sshort.c +3 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_struct_va1.c +125 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uchar.c +3 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uint.c +4 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uint_va.c +49 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ulong_va.c +49 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ulonglong.c +8 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ushort.c +3 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/err_bad_abi.c +2 -3
- data/ext/ffi_c/libffi/testsuite/libffi.closures/ffitest.h +1 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/huge_struct.c +57 -56
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct.c +38 -15
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct1.c +9 -9
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct10.c +19 -6
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct11.c +137 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct12.c +86 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct13.c +115 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct2.c +15 -6
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct3.c +15 -6
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct4.c +14 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct5.c +14 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct6.c +17 -6
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct7.c +14 -5
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct8.c +17 -6
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct9.c +17 -6
- data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs1.c +86 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs2.c +102 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs3.c +101 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large.c +7 -7
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large2.c +7 -7
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium.c +6 -6
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium2.c +7 -6
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/testclosure.c +8 -3
- data/ext/ffi_c/libffi/testsuite/{libffi.special → libffi.closures}/unwindtest.cc +4 -10
- data/ext/ffi_c/libffi/testsuite/{libffi.special → libffi.closures}/unwindtest_ffi_call.cc +4 -2
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex.inc +91 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_double.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_float.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_longdouble.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex.inc +42 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_double.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_float.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_longdouble.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct.inc +71 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_double.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_float.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_longdouble.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va.inc +80 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_double.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_float.c +16 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_longdouble.c +10 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.special/special.exp → libffi.complex/complex.exp} +9 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex.inc +51 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_double.inc +7 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_float.inc +7 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_longdouble.inc +7 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_double.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_float.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_int.c +86 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_longdouble.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/ffitest.h +1 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex.inc +78 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_double.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_float.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_longdouble.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex.inc +37 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1.inc +41 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_double.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_float.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_longdouble.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2.inc +44 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_double.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_float.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_longdouble.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_double.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_float.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_longdouble.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.go/aa-direct.c +34 -0
- data/ext/ffi_c/libffi/testsuite/libffi.go/closure1.c +28 -0
- data/ext/ffi_c/libffi/testsuite/libffi.go/ffitest.h +1 -0
- data/ext/ffi_c/libffi/testsuite/libffi.go/go.exp +36 -0
- data/ext/ffi_c/libffi/testsuite/libffi.go/static-chain.h +19 -0
- data/ext/ffi_c/libffi.bsd.mk +14 -8
- data/ext/ffi_c/libffi.darwin.mk +56 -26
- data/ext/ffi_c/libffi.gnu.mk +9 -6
- data/ext/ffi_c/libffi.mk +13 -8
- data/ext/ffi_c/libffi.vc.mk +26 -0
- data/ext/ffi_c/libffi.vc64.mk +26 -0
- data/ext/ffi_c/rbffi.h +34 -6
- data/ext/ffi_c/{endian.h → rbffi_endian.h} +21 -2
- data/ffi.gemspec +42 -0
- data/lib/ffi/abstract_memory.rb +44 -0
- data/lib/ffi/autopointer.rb +111 -52
- data/lib/ffi/compat.rb +43 -0
- data/lib/ffi/data_converter.rb +67 -0
- data/lib/ffi/dynamic_library.rb +118 -0
- data/lib/ffi/enum.rb +203 -22
- data/lib/ffi/errno.rb +27 -12
- data/lib/ffi/ffi.rb +88 -11
- data/lib/ffi/function.rb +71 -0
- data/lib/ffi/io.rb +35 -14
- data/lib/ffi/library.rb +382 -96
- data/lib/ffi/library_path.rb +109 -0
- data/lib/ffi/managedstruct.rb +64 -35
- data/lib/ffi/memorypointer.rb +1 -33
- data/lib/ffi/platform/aarch64-darwin/types.conf +130 -0
- data/lib/ffi/platform/aarch64-freebsd/types.conf +128 -0
- data/lib/ffi/platform/aarch64-freebsd12/types.conf +181 -0
- data/lib/ffi/platform/aarch64-linux/types.conf +175 -0
- data/lib/ffi/platform/aarch64-openbsd/types.conf +134 -0
- data/lib/ffi/platform/aarch64-windows/types.conf +52 -0
- 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 +132 -0
- data/lib/ffi/platform/hppa1.1-linux/types.conf +178 -0
- data/lib/ffi/platform/hppa2.0-linux/types.conf +178 -0
- data/lib/ffi/platform/i386-cygwin/types.conf +3 -0
- data/lib/ffi/platform/i386-darwin/types.conf +100 -0
- data/lib/ffi/platform/i386-freebsd/types.conf +152 -0
- data/lib/ffi/platform/i386-freebsd12/types.conf +152 -0
- data/lib/ffi/platform/i386-gnu/types.conf +107 -0
- data/lib/ffi/platform/i386-linux/types.conf +103 -0
- data/lib/ffi/platform/i386-netbsd/types.conf +126 -0
- data/lib/ffi/platform/i386-openbsd/types.conf +128 -0
- data/lib/ffi/platform/i386-solaris/types.conf +122 -0
- data/lib/ffi/platform/i386-windows/types.conf +52 -0
- data/lib/ffi/platform/ia64-linux/types.conf +104 -0
- data/lib/ffi/platform/loongarch64-linux/types.conf +141 -0
- data/lib/ffi/platform/mips-linux/types.conf +102 -0
- data/lib/ffi/platform/mips64-linux/types.conf +104 -0
- data/lib/ffi/platform/mips64el-linux/types.conf +104 -0
- data/lib/ffi/platform/mipsel-linux/types.conf +102 -0
- data/lib/ffi/platform/mipsisa32r6-linux/types.conf +102 -0
- data/lib/ffi/platform/mipsisa32r6el-linux/types.conf +102 -0
- data/lib/ffi/platform/mipsisa64r6-linux/types.conf +104 -0
- data/lib/ffi/platform/mipsisa64r6el-linux/types.conf +104 -0
- data/lib/ffi/platform/powerpc-aix/types.conf +180 -0
- data/lib/ffi/platform/powerpc-darwin/types.conf +100 -0
- data/lib/ffi/platform/powerpc-linux/types.conf +130 -0
- data/lib/ffi/platform/powerpc-openbsd/types.conf +156 -0
- data/lib/ffi/platform/powerpc64-linux/types.conf +104 -0
- data/lib/ffi/platform/powerpc64le-linux/types.conf +100 -0
- data/lib/ffi/platform/riscv64-linux/types.conf +104 -0
- data/lib/ffi/platform/s390-linux/types.conf +102 -0
- data/lib/ffi/platform/s390x-linux/types.conf +102 -0
- data/lib/ffi/platform/sparc-linux/types.conf +102 -0
- data/lib/ffi/platform/sparc-solaris/types.conf +128 -0
- data/lib/ffi/platform/sparcv9-linux/types.conf +102 -0
- data/lib/ffi/platform/sparcv9-openbsd/types.conf +156 -0
- data/lib/ffi/platform/sparcv9-solaris/types.conf +128 -0
- data/lib/ffi/platform/sw_64-linux/types.conf +141 -0
- data/lib/ffi/platform/x86_64-cygwin/types.conf +3 -0
- data/lib/ffi/platform/x86_64-darwin/types.conf +130 -0
- data/lib/ffi/platform/x86_64-dragonflybsd/types.conf +130 -0
- data/lib/ffi/platform/x86_64-freebsd/types.conf +128 -0
- data/lib/ffi/platform/x86_64-freebsd12/types.conf +158 -0
- data/lib/ffi/platform/x86_64-haiku/types.conf +117 -0
- data/lib/ffi/platform/x86_64-linux/types.conf +132 -0
- data/lib/ffi/platform/x86_64-msys/types.conf +119 -0
- data/lib/ffi/platform/x86_64-netbsd/types.conf +128 -0
- data/lib/ffi/platform/x86_64-openbsd/types.conf +134 -0
- data/lib/ffi/platform/x86_64-solaris/types.conf +122 -0
- data/lib/ffi/platform/x86_64-windows/types.conf +52 -0
- data/lib/ffi/platform.rb +110 -34
- data/lib/ffi/pointer.rb +117 -90
- data/lib/ffi/struct.rb +101 -70
- data/lib/ffi/struct_by_reference.rb +72 -0
- data/lib/ffi/struct_layout.rb +96 -0
- data/lib/ffi/struct_layout_builder.rb +90 -21
- data/lib/ffi/tools/const_generator.rb +86 -31
- data/lib/ffi/tools/generator.rb +49 -2
- data/lib/ffi/tools/generator_task.rb +13 -16
- data/lib/ffi/tools/struct_generator.rb +6 -5
- data/lib/ffi/tools/types_generator.rb +25 -11
- data/lib/ffi/types.rb +105 -36
- data/lib/ffi/union.rb +23 -12
- data/lib/ffi/variadic.rb +44 -29
- data/lib/ffi/version.rb +3 -0
- data/lib/ffi.rb +25 -9
- data/rakelib/ffi_gem_helper.rb +65 -0
- data/samples/getlogin.rb +8 -0
- data/samples/getpid.rb +8 -0
- data/samples/gettimeofday.rb +18 -0
- data/samples/hello.rb +8 -0
- data/samples/hello_ractor.rb +11 -0
- data/samples/inotify.rb +60 -0
- data/samples/pty.rb +75 -0
- data/samples/qsort.rb +20 -0
- data/samples/qsort_ractor.rb +28 -0
- data/sig/ffi/abstract_memory.rbs +165 -0
- data/sig/ffi/auto_pointer.rbs +26 -0
- data/sig/ffi/buffer.rbs +18 -0
- data/sig/ffi/data_converter.rbs +10 -0
- data/sig/ffi/dynamic_library.rbs +9 -0
- data/sig/ffi/enum.rbs +38 -0
- data/sig/ffi/function.rbs +39 -0
- data/sig/ffi/library.rbs +42 -0
- data/sig/ffi/native_type.rbs +86 -0
- data/sig/ffi/pointer.rbs +42 -0
- data/sig/ffi/struct.rbs +76 -0
- data/sig/ffi/struct_by_reference.rbs +11 -0
- data/sig/ffi/struct_by_value.rbs +7 -0
- data/sig/ffi/struct_layout.rbs +9 -0
- data/sig/ffi/struct_layout_builder.rbs +5 -0
- data/sig/ffi/type.rbs +39 -0
- data/sig/ffi.rbs +26 -0
- data.tar.gz.sig +0 -0
- metadata +547 -248
- metadata.gz.sig +0 -0
- data/History.txt +0 -109
- data/README.rdoc +0 -70
- data/ext/ffi_c/DataConverter.c +0 -62
- data/ext/ffi_c/StructByReference.c +0 -150
- data/ext/ffi_c/StructByReference.h +0 -50
- data/ext/ffi_c/libffi/ChangeLog.libffi +0 -658
- data/ext/ffi_c/libffi/ChangeLog.libgcj +0 -40
- data/ext/ffi_c/libffi/ChangeLog.v1 +0 -764
- data/ext/ffi_c/libffi/README +0 -306
- data/ext/ffi_c/libffi/aclocal.m4 +0 -8998
- data/ext/ffi_c/libffi/depcomp +0 -584
- data/ext/ffi_c/libffi/doc/libffi.info +0 -533
- data/ext/ffi_c/libffi/doc/stamp-vti +0 -4
- data/ext/ffi_c/libffi/m4/libtool.m4 +0 -7360
- data/ext/ffi_c/libffi/m4/ltoptions.m4 +0 -368
- data/ext/ffi_c/libffi/m4/ltsugar.m4 +0 -123
- data/ext/ffi_c/libffi/m4/ltversion.m4 +0 -23
- data/ext/ffi_c/libffi/m4/lt~obsolete.m4 +0 -92
- data/ext/ffi_c/libffi/mdate-sh +0 -201
- data/ext/ffi_c/libffi/src/x86/darwin.S +0 -444
- data/ext/ffi_c/libffi/src/x86/darwin64.S +0 -416
- data/ext/ffi_c/libffi/src/x86/freebsd.S +0 -458
- data/ext/ffi_c/libffi/src/x86/win32.S +0 -877
- data/ext/ffi_c/libffi/testsuite/lib/libffi-dg.exp +0 -300
- data/ext/ffi_c/libffi/testsuite/libffi.call/many_win32.c +0 -63
- data/ext/ffi_c/libffi/testsuite/libffi.call/strlen_win32.c +0 -44
- data/ext/ffi_c/libffi/testsuite/libffi.special/ffitestcxx.h +0 -96
- data/ext/ffi_c/libffi/texinfo.tex +0 -7210
- data/gen/Rakefile +0 -14
- data/spec/ffi/async_callback_spec.rb +0 -23
- data/spec/ffi/bool_spec.rb +0 -24
- data/spec/ffi/buffer_spec.rb +0 -202
- data/spec/ffi/callback_spec.rb +0 -653
- data/spec/ffi/custom_param_type.rb +0 -31
- data/spec/ffi/custom_type_spec.rb +0 -73
- data/spec/ffi/enum_spec.rb +0 -183
- data/spec/ffi/errno_spec.rb +0 -13
- data/spec/ffi/ffi_spec.rb +0 -24
- data/spec/ffi/function_spec.rb +0 -73
- data/spec/ffi/library_spec.rb +0 -174
- data/spec/ffi/managed_struct_spec.rb +0 -56
- data/spec/ffi/number_spec.rb +0 -231
- data/spec/ffi/pointer_spec.rb +0 -210
- data/spec/ffi/rbx/attach_function_spec.rb +0 -28
- data/spec/ffi/rbx/memory_pointer_spec.rb +0 -109
- data/spec/ffi/rbx/spec_helper.rb +0 -1
- data/spec/ffi/rbx/struct_spec.rb +0 -13
- data/spec/ffi/spec_helper.rb +0 -21
- data/spec/ffi/string_spec.rb +0 -103
- data/spec/ffi/strptr_spec.rb +0 -36
- data/spec/ffi/struct_callback_spec.rb +0 -64
- data/spec/ffi/struct_initialize_spec.rb +0 -30
- data/spec/ffi/struct_packed_spec.rb +0 -46
- data/spec/ffi/struct_spec.rb +0 -638
- data/spec/ffi/typedef_spec.rb +0 -62
- data/spec/ffi/union_spec.rb +0 -60
- data/spec/ffi/variadic_spec.rb +0 -84
- data/spec/spec.opts +0 -4
- data/tasks/ann.rake +0 -80
- data/tasks/extension.rake +0 -25
- data/tasks/gem.rake +0 -200
- data/tasks/git.rake +0 -41
- data/tasks/notes.rake +0 -27
- data/tasks/post_load.rake +0 -34
- data/tasks/rdoc.rake +0 -50
- data/tasks/rubyforge.rake +0 -55
- data/tasks/setup.rb +0 -301
- data/tasks/spec.rake +0 -54
- data/tasks/svn.rake +0 -47
- data/tasks/test.rake +0 -40
- /data/ext/ffi_c/libffi/testsuite/libffi.call/{pyobjc-tc.c → pyobjc_tc.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}/problem1.c +0 -0
@@ -45,16 +45,16 @@ else
|
|
45
45
|
|
46
46
|
# Unlike /dev/zero, the MAP_ANON(YMOUS) defines can be probed for.
|
47
47
|
AC_CACHE_CHECK([for MAP_ANON(YMOUS)], ac_cv_decl_map_anon,
|
48
|
-
[
|
49
|
-
[#include <sys/types.h>
|
48
|
+
[AC_COMPILE_IFELSE(
|
49
|
+
[AC_LANG_PROGRAM([[#include <sys/types.h>
|
50
50
|
#include <sys/mman.h>
|
51
51
|
#include <unistd.h>
|
52
52
|
|
53
53
|
#ifndef MAP_ANONYMOUS
|
54
54
|
#define MAP_ANONYMOUS MAP_ANON
|
55
55
|
#endif
|
56
|
-
],
|
57
|
-
[int n = MAP_ANONYMOUS;],
|
56
|
+
]],
|
57
|
+
[[int n = MAP_ANONYMOUS;]])],
|
58
58
|
ac_cv_decl_map_anon=yes,
|
59
59
|
ac_cv_decl_map_anon=no)])
|
60
60
|
|
@@ -90,3 +90,288 @@ if test $ac_cv_func_mmap_anon = yes; then
|
|
90
90
|
[Define if mmap with MAP_ANON(YMOUS) works.])
|
91
91
|
fi
|
92
92
|
])
|
93
|
+
|
94
|
+
dnl ----------------------------------------------------------------------
|
95
|
+
dnl This whole bit snagged from libstdc++-v3, via libatomic.
|
96
|
+
|
97
|
+
dnl
|
98
|
+
dnl LIBFFI_ENABLE
|
99
|
+
dnl (FEATURE, DEFAULT, HELP-ARG, HELP-STRING)
|
100
|
+
dnl (FEATURE, DEFAULT, HELP-ARG, HELP-STRING, permit a|b|c)
|
101
|
+
dnl (FEATURE, DEFAULT, HELP-ARG, HELP-STRING, SHELL-CODE-HANDLER)
|
102
|
+
dnl
|
103
|
+
dnl See docs/html/17_intro/configury.html#enable for documentation.
|
104
|
+
dnl
|
105
|
+
m4_define([LIBFFI_ENABLE],[dnl
|
106
|
+
m4_define([_g_switch],[--enable-$1])dnl
|
107
|
+
m4_define([_g_help],[AS_HELP_STRING([_g_switch$3],[$4 @<:@default=$2@:>@])])dnl
|
108
|
+
AC_ARG_ENABLE($1,_g_help,
|
109
|
+
m4_bmatch([$5],
|
110
|
+
[^permit ],
|
111
|
+
[[
|
112
|
+
case "$enableval" in
|
113
|
+
m4_bpatsubst([$5],[permit ])) ;;
|
114
|
+
*) AC_MSG_ERROR(Unknown argument to enable/disable $1) ;;
|
115
|
+
dnl Idea for future: generate a URL pointing to
|
116
|
+
dnl "onlinedocs/configopts.html#whatever"
|
117
|
+
esac
|
118
|
+
]],
|
119
|
+
[^$],
|
120
|
+
[[
|
121
|
+
case "$enableval" in
|
122
|
+
yes|no) ;;
|
123
|
+
*) AC_MSG_ERROR(Argument to enable/disable $1 must be yes or no) ;;
|
124
|
+
esac
|
125
|
+
]],
|
126
|
+
[[$5]]),
|
127
|
+
[enable_]m4_bpatsubst([$1],-,_)[=][$2])
|
128
|
+
m4_undefine([_g_switch])dnl
|
129
|
+
m4_undefine([_g_help])dnl
|
130
|
+
])
|
131
|
+
|
132
|
+
dnl
|
133
|
+
dnl If GNU ld is in use, check to see if tricky linker opts can be used. If
|
134
|
+
dnl the native linker is in use, all variables will be defined to something
|
135
|
+
dnl safe (like an empty string).
|
136
|
+
dnl
|
137
|
+
dnl Defines:
|
138
|
+
dnl SECTION_LDFLAGS='-Wl,--gc-sections' if possible
|
139
|
+
dnl OPT_LDFLAGS='-Wl,-O1' if possible
|
140
|
+
dnl LD (as a side effect of testing)
|
141
|
+
dnl Sets:
|
142
|
+
dnl with_gnu_ld
|
143
|
+
dnl libat_ld_is_gold (possibly)
|
144
|
+
dnl libat_gnu_ld_version (possibly)
|
145
|
+
dnl
|
146
|
+
dnl The last will be a single integer, e.g., version 1.23.45.0.67.89 will
|
147
|
+
dnl set libat_gnu_ld_version to 12345. Zeros cause problems.
|
148
|
+
dnl
|
149
|
+
AC_DEFUN([LIBFFI_CHECK_LINKER_FEATURES], [
|
150
|
+
# If we're not using GNU ld, then there's no point in even trying these
|
151
|
+
# tests. Check for that first. We should have already tested for gld
|
152
|
+
# by now (in libtool), but require it now just to be safe...
|
153
|
+
test -z "$SECTION_LDFLAGS" && SECTION_LDFLAGS=''
|
154
|
+
test -z "$OPT_LDFLAGS" && OPT_LDFLAGS=''
|
155
|
+
AC_REQUIRE([LT_PATH_LD])
|
156
|
+
AC_REQUIRE([AC_PROG_AWK])
|
157
|
+
|
158
|
+
# The name set by libtool depends on the version of libtool. Shame on us
|
159
|
+
# for depending on an impl detail, but c'est la vie. Older versions used
|
160
|
+
# ac_cv_prog_gnu_ld, but now it's lt_cv_prog_gnu_ld, and is copied back on
|
161
|
+
# top of with_gnu_ld (which is also set by --with-gnu-ld, so that actually
|
162
|
+
# makes sense). We'll test with_gnu_ld everywhere else, so if that isn't
|
163
|
+
# set (hence we're using an older libtool), then set it.
|
164
|
+
if test x${with_gnu_ld+set} != xset; then
|
165
|
+
if test x${ac_cv_prog_gnu_ld+set} != xset; then
|
166
|
+
# We got through "ac_require(ac_prog_ld)" and still not set? Huh?
|
167
|
+
with_gnu_ld=no
|
168
|
+
else
|
169
|
+
with_gnu_ld=$ac_cv_prog_gnu_ld
|
170
|
+
fi
|
171
|
+
fi
|
172
|
+
|
173
|
+
# Start by getting the version number. I think the libtool test already
|
174
|
+
# does some of this, but throws away the result.
|
175
|
+
libat_ld_is_gold=no
|
176
|
+
if $LD --version 2>/dev/null | grep 'GNU gold'> /dev/null 2>&1; then
|
177
|
+
libat_ld_is_gold=yes
|
178
|
+
fi
|
179
|
+
libat_ld_is_lld=no
|
180
|
+
if $LD --version 2>/dev/null | grep 'LLD '> /dev/null 2>&1; then
|
181
|
+
libat_ld_is_lld=yes
|
182
|
+
fi
|
183
|
+
changequote(,)
|
184
|
+
ldver=`$LD --version 2>/dev/null |
|
185
|
+
sed -e 's/GNU gold /GNU ld /;s/GNU ld version /GNU ld /;s/GNU ld ([^)]*) /GNU ld /;s/GNU ld \([0-9.][0-9.]*\).*/\1/; q'`
|
186
|
+
changequote([,])
|
187
|
+
libat_gnu_ld_version=`echo $ldver | \
|
188
|
+
$AWK -F. '{ if (NF<3) [$]3=0; print ([$]1*100+[$]2)*100+[$]3 }'`
|
189
|
+
|
190
|
+
# Set --gc-sections.
|
191
|
+
if test "$with_gnu_ld" = "notbroken"; then
|
192
|
+
# GNU ld it is! Joy and bunny rabbits!
|
193
|
+
|
194
|
+
# All these tests are for C++; save the language and the compiler flags.
|
195
|
+
# Need to do this so that g++ won't try to link in libstdc++
|
196
|
+
ac_test_CFLAGS="${CFLAGS+set}"
|
197
|
+
ac_save_CFLAGS="$CFLAGS"
|
198
|
+
CFLAGS='-x c++ -Wl,--gc-sections'
|
199
|
+
|
200
|
+
# Check for -Wl,--gc-sections
|
201
|
+
# XXX This test is broken at the moment, as symbols required for linking
|
202
|
+
# are now in libsupc++ (not built yet). In addition, this test has
|
203
|
+
# cored on solaris in the past. In addition, --gc-sections doesn't
|
204
|
+
# really work at the moment (keeps on discarding used sections, first
|
205
|
+
# .eh_frame and now some of the glibc sections for iconv).
|
206
|
+
# Bzzzzt. Thanks for playing, maybe next time.
|
207
|
+
AC_MSG_CHECKING([for ld that supports -Wl,--gc-sections])
|
208
|
+
AC_RUN_IFELSE([AC_LANG_SOURCE([[
|
209
|
+
int main(void)
|
210
|
+
{
|
211
|
+
try { throw 1; }
|
212
|
+
catch (...) { };
|
213
|
+
return 0;
|
214
|
+
}
|
215
|
+
]])],[ac_sectionLDflags=yes],[ac_sectionLDflags=no],[ac_sectionLDflags=yes])
|
216
|
+
if test "$ac_test_CFLAGS" = set; then
|
217
|
+
CFLAGS="$ac_save_CFLAGS"
|
218
|
+
else
|
219
|
+
# this is the suspicious part
|
220
|
+
CFLAGS=''
|
221
|
+
fi
|
222
|
+
if test "$ac_sectionLDflags" = "yes"; then
|
223
|
+
SECTION_LDFLAGS="-Wl,--gc-sections $SECTION_LDFLAGS"
|
224
|
+
fi
|
225
|
+
AC_MSG_RESULT($ac_sectionLDflags)
|
226
|
+
fi
|
227
|
+
|
228
|
+
# Set linker optimization flags.
|
229
|
+
if test x"$with_gnu_ld" = x"yes"; then
|
230
|
+
OPT_LDFLAGS="-Wl,-O1 $OPT_LDFLAGS"
|
231
|
+
fi
|
232
|
+
|
233
|
+
AC_SUBST(SECTION_LDFLAGS)
|
234
|
+
AC_SUBST(OPT_LDFLAGS)
|
235
|
+
])
|
236
|
+
|
237
|
+
|
238
|
+
dnl
|
239
|
+
dnl Add version tags to symbols in shared library (or not), additionally
|
240
|
+
dnl marking other symbols as private/local (or not).
|
241
|
+
dnl
|
242
|
+
dnl --enable-symvers=style adds a version script to the linker call when
|
243
|
+
dnl creating the shared library. The choice of version script is
|
244
|
+
dnl controlled by 'style'.
|
245
|
+
dnl --disable-symvers does not.
|
246
|
+
dnl + Usage: LIBFFI_ENABLE_SYMVERS[(DEFAULT)]
|
247
|
+
dnl Where DEFAULT is either 'yes' or 'no'. Passing `yes' tries to
|
248
|
+
dnl choose a default style based on linker characteristics. Passing
|
249
|
+
dnl 'no' disables versioning.
|
250
|
+
dnl
|
251
|
+
AC_DEFUN([LIBFFI_ENABLE_SYMVERS], [
|
252
|
+
|
253
|
+
LIBFFI_ENABLE(symvers,yes,[=STYLE],
|
254
|
+
[enables symbol versioning of the shared library],
|
255
|
+
[permit yes|no|gnu*|sun])
|
256
|
+
|
257
|
+
# If we never went through the LIBFFI_CHECK_LINKER_FEATURES macro, then we
|
258
|
+
# don't know enough about $LD to do tricks...
|
259
|
+
AC_REQUIRE([LIBFFI_CHECK_LINKER_FEATURES])
|
260
|
+
|
261
|
+
# Turn a 'yes' into a suitable default.
|
262
|
+
if test x$enable_symvers = xyes ; then
|
263
|
+
# FIXME The following test is too strict, in theory.
|
264
|
+
if test $enable_shared = no || test "x$LD" = x; then
|
265
|
+
enable_symvers=no
|
266
|
+
else
|
267
|
+
if test $with_gnu_ld = yes ; then
|
268
|
+
enable_symvers=gnu
|
269
|
+
else
|
270
|
+
case ${target_os} in
|
271
|
+
# Sun symbol versioning exists since Solaris 2.5.
|
272
|
+
solaris2.[[5-9]]* | solaris2.1[[0-9]]*)
|
273
|
+
enable_symvers=sun ;;
|
274
|
+
*)
|
275
|
+
enable_symvers=no ;;
|
276
|
+
esac
|
277
|
+
fi
|
278
|
+
fi
|
279
|
+
fi
|
280
|
+
|
281
|
+
# Check if 'sun' was requested on non-Solaris 2 platforms.
|
282
|
+
if test x$enable_symvers = xsun ; then
|
283
|
+
case ${target_os} in
|
284
|
+
solaris2*)
|
285
|
+
# All fine.
|
286
|
+
;;
|
287
|
+
*)
|
288
|
+
# Unlikely to work.
|
289
|
+
AC_MSG_WARN([=== You have requested Sun symbol versioning, but])
|
290
|
+
AC_MSG_WARN([=== you are not targetting Solaris 2.])
|
291
|
+
AC_MSG_WARN([=== Symbol versioning will be disabled.])
|
292
|
+
enable_symvers=no
|
293
|
+
;;
|
294
|
+
esac
|
295
|
+
fi
|
296
|
+
|
297
|
+
# Check to see if libgcc_s exists, indicating that shared libgcc is possible.
|
298
|
+
if test $enable_symvers != no; then
|
299
|
+
AC_MSG_CHECKING([for shared libgcc])
|
300
|
+
ac_save_CFLAGS="$CFLAGS"
|
301
|
+
CFLAGS=' -lgcc_s'
|
302
|
+
AC_LINK_IFELSE([AC_LANG_PROGRAM([[]], [[return 0;]])],[libat_shared_libgcc=yes],[libat_shared_libgcc=no])
|
303
|
+
CFLAGS="$ac_save_CFLAGS"
|
304
|
+
if test $libat_shared_libgcc = no; then
|
305
|
+
cat > conftest.c <<EOF
|
306
|
+
int main (void) { return 0; }
|
307
|
+
EOF
|
308
|
+
changequote(,)dnl
|
309
|
+
libat_libgcc_s_suffix=`${CC-cc} $CFLAGS $CPPFLAGS $LDFLAGS \
|
310
|
+
-shared -shared-libgcc -o conftest.so \
|
311
|
+
conftest.c -v 2>&1 >/dev/null \
|
312
|
+
| sed -n 's/^.* -lgcc_s\([^ ]*\) .*$/\1/p'`
|
313
|
+
changequote([,])dnl
|
314
|
+
rm -f conftest.c conftest.so
|
315
|
+
if test x${libat_libgcc_s_suffix+set} = xset; then
|
316
|
+
CFLAGS=" -lgcc_s$libat_libgcc_s_suffix"
|
317
|
+
AC_LINK_IFELSE([AC_LANG_PROGRAM([[]], [[return 0;]])],[libat_shared_libgcc=yes],[])
|
318
|
+
CFLAGS="$ac_save_CFLAGS"
|
319
|
+
fi
|
320
|
+
fi
|
321
|
+
AC_MSG_RESULT($libat_shared_libgcc)
|
322
|
+
fi
|
323
|
+
|
324
|
+
# For GNU ld, we need at least this version. The format is described in
|
325
|
+
# LIBFFI_CHECK_LINKER_FEATURES above.
|
326
|
+
libat_min_gnu_ld_version=21400
|
327
|
+
# XXXXXXXXXXX libat_gnu_ld_version=21390
|
328
|
+
|
329
|
+
# Check to see if unspecified "yes" value can win, given results above.
|
330
|
+
# Change "yes" into either "no" or a style name.
|
331
|
+
if test $enable_symvers != no && test $libat_shared_libgcc = yes; then
|
332
|
+
if test $with_gnu_ld = yes; then
|
333
|
+
if test $libat_gnu_ld_version -ge $libat_min_gnu_ld_version ; then
|
334
|
+
enable_symvers=gnu
|
335
|
+
elif test $libat_ld_is_gold = yes ; then
|
336
|
+
enable_symvers=gnu
|
337
|
+
elif test $libat_ld_is_lld = yes ; then
|
338
|
+
enable_symvers=gnu
|
339
|
+
else
|
340
|
+
# The right tools, the right setup, but too old. Fallbacks?
|
341
|
+
AC_MSG_WARN(=== Linker version $libat_gnu_ld_version is too old for)
|
342
|
+
AC_MSG_WARN(=== full symbol versioning support in this release of GCC.)
|
343
|
+
AC_MSG_WARN(=== You would need to upgrade your binutils to version)
|
344
|
+
AC_MSG_WARN(=== $libat_min_gnu_ld_version or later and rebuild GCC.)
|
345
|
+
if test $libat_gnu_ld_version -ge 21200 ; then
|
346
|
+
# Globbing fix is present, proper block support is not.
|
347
|
+
dnl AC_MSG_WARN([=== Dude, you are soooo close. Maybe we can fake it.])
|
348
|
+
dnl enable_symvers=???
|
349
|
+
AC_MSG_WARN([=== Symbol versioning will be disabled.])
|
350
|
+
enable_symvers=no
|
351
|
+
else
|
352
|
+
# 2.11 or older.
|
353
|
+
AC_MSG_WARN([=== Symbol versioning will be disabled.])
|
354
|
+
enable_symvers=no
|
355
|
+
fi
|
356
|
+
fi
|
357
|
+
elif test $enable_symvers = sun; then
|
358
|
+
: All interesting versions of Sun ld support sun style symbol versioning.
|
359
|
+
else
|
360
|
+
# just fail for now
|
361
|
+
AC_MSG_WARN([=== You have requested some kind of symbol versioning, but])
|
362
|
+
AC_MSG_WARN([=== either you are not using a supported linker, or you are])
|
363
|
+
AC_MSG_WARN([=== not building a shared libgcc_s (which is required).])
|
364
|
+
AC_MSG_WARN([=== Symbol versioning will be disabled.])
|
365
|
+
enable_symvers=no
|
366
|
+
fi
|
367
|
+
fi
|
368
|
+
if test $enable_symvers = gnu; then
|
369
|
+
AC_DEFINE(LIBFFI_GNU_SYMBOL_VERSIONING, 1,
|
370
|
+
[Define to 1 if GNU symbol versioning is used for libatomic.])
|
371
|
+
fi
|
372
|
+
|
373
|
+
AM_CONDITIONAL(LIBFFI_BUILD_VERSIONED_SHLIB, test $enable_symvers != no)
|
374
|
+
AM_CONDITIONAL(LIBFFI_BUILD_VERSIONED_SHLIB_GNU, test $enable_symvers = gnu)
|
375
|
+
AM_CONDITIONAL(LIBFFI_BUILD_VERSIONED_SHLIB_SUN, test $enable_symvers = sun)
|
376
|
+
AC_MSG_NOTICE(versioning on shared library symbols is $enable_symvers)
|
377
|
+
])
|
data/ext/ffi_c/libffi/compile
CHANGED
@@ -1,9 +1,9 @@
|
|
1
1
|
#! /bin/sh
|
2
|
-
# Wrapper for compilers which do not understand
|
2
|
+
# Wrapper for compilers which do not understand '-c -o'.
|
3
3
|
|
4
|
-
scriptversion=
|
4
|
+
scriptversion=2018-03-07.03; # UTC
|
5
5
|
|
6
|
-
# Copyright (C) 1999
|
6
|
+
# Copyright (C) 1999-2021 Free Software Foundation, Inc.
|
7
7
|
# Written by Tom Tromey <tromey@cygnus.com>.
|
8
8
|
#
|
9
9
|
# This program is free software; you can redistribute it and/or modify
|
@@ -17,8 +17,7 @@ scriptversion=2005-05-14.22
|
|
17
17
|
# GNU General Public License for more details.
|
18
18
|
#
|
19
19
|
# You should have received a copy of the GNU General Public License
|
20
|
-
# along with this program
|
21
|
-
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
20
|
+
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
22
21
|
|
23
22
|
# As a special exception to the GNU General Public License, if you
|
24
23
|
# distribute this file as part of a program that contains a
|
@@ -29,21 +28,224 @@ scriptversion=2005-05-14.22
|
|
29
28
|
# bugs to <bug-automake@gnu.org> or send patches to
|
30
29
|
# <automake-patches@gnu.org>.
|
31
30
|
|
31
|
+
nl='
|
32
|
+
'
|
33
|
+
|
34
|
+
# We need space, tab and new line, in precisely that order. Quoting is
|
35
|
+
# there to prevent tools from complaining about whitespace usage.
|
36
|
+
IFS=" "" $nl"
|
37
|
+
|
38
|
+
file_conv=
|
39
|
+
|
40
|
+
# func_file_conv build_file lazy
|
41
|
+
# Convert a $build file to $host form and store it in $file
|
42
|
+
# Currently only supports Windows hosts. If the determined conversion
|
43
|
+
# type is listed in (the comma separated) LAZY, no conversion will
|
44
|
+
# take place.
|
45
|
+
func_file_conv ()
|
46
|
+
{
|
47
|
+
file=$1
|
48
|
+
case $file in
|
49
|
+
/ | /[!/]*) # absolute file, and not a UNC file
|
50
|
+
if test -z "$file_conv"; then
|
51
|
+
# lazily determine how to convert abs files
|
52
|
+
case `uname -s` in
|
53
|
+
MINGW*)
|
54
|
+
file_conv=mingw
|
55
|
+
;;
|
56
|
+
CYGWIN* | MSYS*)
|
57
|
+
file_conv=cygwin
|
58
|
+
;;
|
59
|
+
*)
|
60
|
+
file_conv=wine
|
61
|
+
;;
|
62
|
+
esac
|
63
|
+
fi
|
64
|
+
case $file_conv/,$2, in
|
65
|
+
*,$file_conv,*)
|
66
|
+
;;
|
67
|
+
mingw/*)
|
68
|
+
file=`cmd //C echo "$file " | sed -e 's/"\(.*\) " *$/\1/'`
|
69
|
+
;;
|
70
|
+
cygwin/* | msys/*)
|
71
|
+
file=`cygpath -m "$file" || echo "$file"`
|
72
|
+
;;
|
73
|
+
wine/*)
|
74
|
+
file=`winepath -w "$file" || echo "$file"`
|
75
|
+
;;
|
76
|
+
esac
|
77
|
+
;;
|
78
|
+
esac
|
79
|
+
}
|
80
|
+
|
81
|
+
# func_cl_dashL linkdir
|
82
|
+
# Make cl look for libraries in LINKDIR
|
83
|
+
func_cl_dashL ()
|
84
|
+
{
|
85
|
+
func_file_conv "$1"
|
86
|
+
if test -z "$lib_path"; then
|
87
|
+
lib_path=$file
|
88
|
+
else
|
89
|
+
lib_path="$lib_path;$file"
|
90
|
+
fi
|
91
|
+
linker_opts="$linker_opts -LIBPATH:$file"
|
92
|
+
}
|
93
|
+
|
94
|
+
# func_cl_dashl library
|
95
|
+
# Do a library search-path lookup for cl
|
96
|
+
func_cl_dashl ()
|
97
|
+
{
|
98
|
+
lib=$1
|
99
|
+
found=no
|
100
|
+
save_IFS=$IFS
|
101
|
+
IFS=';'
|
102
|
+
for dir in $lib_path $LIB
|
103
|
+
do
|
104
|
+
IFS=$save_IFS
|
105
|
+
if $shared && test -f "$dir/$lib.dll.lib"; then
|
106
|
+
found=yes
|
107
|
+
lib=$dir/$lib.dll.lib
|
108
|
+
break
|
109
|
+
fi
|
110
|
+
if test -f "$dir/$lib.lib"; then
|
111
|
+
found=yes
|
112
|
+
lib=$dir/$lib.lib
|
113
|
+
break
|
114
|
+
fi
|
115
|
+
if test -f "$dir/lib$lib.a"; then
|
116
|
+
found=yes
|
117
|
+
lib=$dir/lib$lib.a
|
118
|
+
break
|
119
|
+
fi
|
120
|
+
done
|
121
|
+
IFS=$save_IFS
|
122
|
+
|
123
|
+
if test "$found" != yes; then
|
124
|
+
lib=$lib.lib
|
125
|
+
fi
|
126
|
+
}
|
127
|
+
|
128
|
+
# func_cl_wrapper cl arg...
|
129
|
+
# Adjust compile command to suit cl
|
130
|
+
func_cl_wrapper ()
|
131
|
+
{
|
132
|
+
# Assume a capable shell
|
133
|
+
lib_path=
|
134
|
+
shared=:
|
135
|
+
linker_opts=
|
136
|
+
for arg
|
137
|
+
do
|
138
|
+
if test -n "$eat"; then
|
139
|
+
eat=
|
140
|
+
else
|
141
|
+
case $1 in
|
142
|
+
-o)
|
143
|
+
# configure might choose to run compile as 'compile cc -o foo foo.c'.
|
144
|
+
eat=1
|
145
|
+
case $2 in
|
146
|
+
*.o | *.[oO][bB][jJ])
|
147
|
+
func_file_conv "$2"
|
148
|
+
set x "$@" -Fo"$file"
|
149
|
+
shift
|
150
|
+
;;
|
151
|
+
*)
|
152
|
+
func_file_conv "$2"
|
153
|
+
set x "$@" -Fe"$file"
|
154
|
+
shift
|
155
|
+
;;
|
156
|
+
esac
|
157
|
+
;;
|
158
|
+
-I)
|
159
|
+
eat=1
|
160
|
+
func_file_conv "$2" mingw
|
161
|
+
set x "$@" -I"$file"
|
162
|
+
shift
|
163
|
+
;;
|
164
|
+
-I*)
|
165
|
+
func_file_conv "${1#-I}" mingw
|
166
|
+
set x "$@" -I"$file"
|
167
|
+
shift
|
168
|
+
;;
|
169
|
+
-l)
|
170
|
+
eat=1
|
171
|
+
func_cl_dashl "$2"
|
172
|
+
set x "$@" "$lib"
|
173
|
+
shift
|
174
|
+
;;
|
175
|
+
-l*)
|
176
|
+
func_cl_dashl "${1#-l}"
|
177
|
+
set x "$@" "$lib"
|
178
|
+
shift
|
179
|
+
;;
|
180
|
+
-L)
|
181
|
+
eat=1
|
182
|
+
func_cl_dashL "$2"
|
183
|
+
;;
|
184
|
+
-L*)
|
185
|
+
func_cl_dashL "${1#-L}"
|
186
|
+
;;
|
187
|
+
-static)
|
188
|
+
shared=false
|
189
|
+
;;
|
190
|
+
-Wl,*)
|
191
|
+
arg=${1#-Wl,}
|
192
|
+
save_ifs="$IFS"; IFS=','
|
193
|
+
for flag in $arg; do
|
194
|
+
IFS="$save_ifs"
|
195
|
+
linker_opts="$linker_opts $flag"
|
196
|
+
done
|
197
|
+
IFS="$save_ifs"
|
198
|
+
;;
|
199
|
+
-Xlinker)
|
200
|
+
eat=1
|
201
|
+
linker_opts="$linker_opts $2"
|
202
|
+
;;
|
203
|
+
-*)
|
204
|
+
set x "$@" "$1"
|
205
|
+
shift
|
206
|
+
;;
|
207
|
+
*.cc | *.CC | *.cxx | *.CXX | *.[cC]++)
|
208
|
+
func_file_conv "$1"
|
209
|
+
set x "$@" -Tp"$file"
|
210
|
+
shift
|
211
|
+
;;
|
212
|
+
*.c | *.cpp | *.CPP | *.lib | *.LIB | *.Lib | *.OBJ | *.obj | *.[oO])
|
213
|
+
func_file_conv "$1" mingw
|
214
|
+
set x "$@" "$file"
|
215
|
+
shift
|
216
|
+
;;
|
217
|
+
*)
|
218
|
+
set x "$@" "$1"
|
219
|
+
shift
|
220
|
+
;;
|
221
|
+
esac
|
222
|
+
fi
|
223
|
+
shift
|
224
|
+
done
|
225
|
+
if test -n "$linker_opts"; then
|
226
|
+
linker_opts="-link$linker_opts"
|
227
|
+
fi
|
228
|
+
exec "$@" $linker_opts
|
229
|
+
exit 1
|
230
|
+
}
|
231
|
+
|
232
|
+
eat=
|
233
|
+
|
32
234
|
case $1 in
|
33
235
|
'')
|
34
|
-
echo "$0: No command. Try
|
236
|
+
echo "$0: No command. Try '$0 --help' for more information." 1>&2
|
35
237
|
exit 1;
|
36
238
|
;;
|
37
239
|
-h | --h*)
|
38
240
|
cat <<\EOF
|
39
241
|
Usage: compile [--help] [--version] PROGRAM [ARGS]
|
40
242
|
|
41
|
-
Wrapper for compilers which do not understand
|
42
|
-
Remove
|
243
|
+
Wrapper for compilers which do not understand '-c -o'.
|
244
|
+
Remove '-o dest.o' from ARGS, run PROGRAM with the remaining
|
43
245
|
arguments, and rename the output as expected.
|
44
246
|
|
45
247
|
If you are trying to build a whole package this is not the
|
46
|
-
right script to run: please start by reading the file
|
248
|
+
right script to run: please start by reading the file 'INSTALL'.
|
47
249
|
|
48
250
|
Report bugs to <bug-automake@gnu.org>.
|
49
251
|
EOF
|
@@ -53,11 +255,14 @@ EOF
|
|
53
255
|
echo "compile $scriptversion"
|
54
256
|
exit $?
|
55
257
|
;;
|
258
|
+
cl | *[/\\]cl | cl.exe | *[/\\]cl.exe | \
|
259
|
+
icl | *[/\\]icl | icl.exe | *[/\\]icl.exe )
|
260
|
+
func_cl_wrapper "$@" # Doesn't return...
|
261
|
+
;;
|
56
262
|
esac
|
57
263
|
|
58
264
|
ofile=
|
59
265
|
cfile=
|
60
|
-
eat=
|
61
266
|
|
62
267
|
for arg
|
63
268
|
do
|
@@ -66,8 +271,8 @@ do
|
|
66
271
|
else
|
67
272
|
case $1 in
|
68
273
|
-o)
|
69
|
-
# configure might choose to run compile as
|
70
|
-
# So we strip
|
274
|
+
# configure might choose to run compile as 'compile cc -o foo foo.c'.
|
275
|
+
# So we strip '-o arg' only if arg is an object.
|
71
276
|
eat=1
|
72
277
|
case $2 in
|
73
278
|
*.o | *.obj)
|
@@ -94,22 +299,22 @@ do
|
|
94
299
|
done
|
95
300
|
|
96
301
|
if test -z "$ofile" || test -z "$cfile"; then
|
97
|
-
# If no
|
302
|
+
# If no '-o' option was seen then we might have been invoked from a
|
98
303
|
# pattern rule where we don't need one. That is ok -- this is a
|
99
304
|
# normal compilation that the losing compiler can handle. If no
|
100
|
-
#
|
305
|
+
# '.c' file was seen then we are probably linking. That is also
|
101
306
|
# ok.
|
102
307
|
exec "$@"
|
103
308
|
fi
|
104
309
|
|
105
310
|
# Name of file we expect compiler to create.
|
106
|
-
cofile=`echo "$cfile" | sed
|
311
|
+
cofile=`echo "$cfile" | sed 's|^.*[\\/]||; s|^[a-zA-Z]:||; s/\.c$/.o/'`
|
107
312
|
|
108
313
|
# Create the lock directory.
|
109
|
-
# Note: use
|
314
|
+
# Note: use '[/\\:.-]' here to ensure that we don't use the same name
|
110
315
|
# that we are using for the .o file. Also, base the name on the expected
|
111
316
|
# object file name, since that is what matters with a parallel build.
|
112
|
-
lockdir=`echo "$cofile" | sed -e 's|[
|
317
|
+
lockdir=`echo "$cofile" | sed -e 's|[/\\:.-]|_|g'`.d
|
113
318
|
while true; do
|
114
319
|
if mkdir "$lockdir" >/dev/null 2>&1; then
|
115
320
|
break
|
@@ -124,9 +329,9 @@ trap "rmdir '$lockdir'; exit 1" 1 2 15
|
|
124
329
|
ret=$?
|
125
330
|
|
126
331
|
if test -f "$cofile"; then
|
127
|
-
mv "$cofile" "$ofile"
|
332
|
+
test "$cofile" = "$ofile" || mv "$cofile" "$ofile"
|
128
333
|
elif test -f "${cofile}bj"; then
|
129
|
-
mv "${cofile}bj" "$ofile"
|
334
|
+
test "${cofile}bj" = "$ofile" || mv "${cofile}bj" "$ofile"
|
130
335
|
fi
|
131
336
|
|
132
337
|
rmdir "$lockdir"
|
@@ -135,8 +340,9 @@ exit $ret
|
|
135
340
|
# Local Variables:
|
136
341
|
# mode: shell-script
|
137
342
|
# sh-indentation: 2
|
138
|
-
# eval: (add-hook '
|
343
|
+
# eval: (add-hook 'before-save-hook 'time-stamp)
|
139
344
|
# time-stamp-start: "scriptversion="
|
140
345
|
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
141
|
-
# time-stamp-
|
346
|
+
# time-stamp-time-zone: "UTC0"
|
347
|
+
# time-stamp-end: "; # UTC"
|
142
348
|
# End:
|