ffi 1.15.4 → 1.16.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (312) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +0 -0
  3. data/CHANGELOG.md +90 -0
  4. data/Gemfile +1 -1
  5. data/README.md +3 -2
  6. data/Rakefile +28 -11
  7. data/ext/ffi_c/AbstractMemory.c +60 -36
  8. data/ext/ffi_c/AbstractMemory.h +3 -2
  9. data/ext/ffi_c/ArrayType.c +49 -13
  10. data/ext/ffi_c/ArrayType.h +1 -0
  11. data/ext/ffi_c/Buffer.c +86 -29
  12. data/ext/ffi_c/Call.c +18 -7
  13. data/ext/ffi_c/DynamicLibrary.c +89 -26
  14. data/ext/ffi_c/Function.c +244 -98
  15. data/ext/ffi_c/Function.h +1 -0
  16. data/ext/ffi_c/FunctionInfo.c +80 -24
  17. data/ext/ffi_c/LastError.c +25 -7
  18. data/ext/ffi_c/MappedType.c +66 -23
  19. data/ext/ffi_c/MappedType.h +0 -2
  20. data/ext/ffi_c/MemoryPointer.c +34 -7
  21. data/ext/ffi_c/MethodHandle.c +3 -1
  22. data/ext/ffi_c/Pointer.c +68 -29
  23. data/ext/ffi_c/Pointer.h +1 -0
  24. data/ext/ffi_c/Struct.c +155 -80
  25. data/ext/ffi_c/Struct.h +7 -4
  26. data/ext/ffi_c/StructByValue.c +48 -16
  27. data/ext/ffi_c/StructLayout.c +117 -48
  28. data/ext/ffi_c/Type.c +104 -36
  29. data/ext/ffi_c/Type.h +3 -1
  30. data/ext/ffi_c/Types.c +1 -1
  31. data/ext/ffi_c/Variadic.c +65 -23
  32. data/ext/ffi_c/compat.h +22 -22
  33. data/ext/ffi_c/extconf.rb +19 -2
  34. data/ext/ffi_c/ffi.c +4 -0
  35. data/ext/ffi_c/libffi/.appveyor/site.exp +16 -0
  36. data/ext/ffi_c/libffi/.appveyor/unix-noexec.exp +7 -0
  37. data/ext/ffi_c/libffi/.appveyor.yml +27 -9
  38. data/ext/ffi_c/libffi/.ci/build-cross-in-container.sh +18 -0
  39. data/ext/ffi_c/libffi/{.travis → .ci}/build-in-container.sh +4 -6
  40. data/ext/ffi_c/libffi/.ci/build.sh +124 -0
  41. data/ext/ffi_c/libffi/{.travis → .ci}/install.sh +14 -7
  42. data/ext/ffi_c/libffi/.ci/msvs-detect +1103 -0
  43. data/ext/ffi_c/libffi/{.travis → .ci}/site.exp +5 -3
  44. data/ext/ffi_c/libffi/.circleci/config.yml +156 -0
  45. data/ext/ffi_c/libffi/.github/workflows/build.yml +460 -0
  46. data/ext/ffi_c/libffi/.github/workflows/emscripten.yml +171 -0
  47. data/ext/ffi_c/libffi/.gitignore +10 -2
  48. data/ext/ffi_c/libffi/LICENSE +1 -1
  49. data/ext/ffi_c/libffi/Makefile.am +12 -5
  50. data/ext/ffi_c/libffi/Makefile.in +92 -34
  51. data/ext/ffi_c/libffi/README.md +144 -104
  52. data/ext/ffi_c/libffi/acinclude.m4 +10 -112
  53. data/ext/ffi_c/libffi/compile +348 -0
  54. data/ext/ffi_c/libffi/config.guess +623 -556
  55. data/ext/ffi_c/libffi/config.sub +75 -34
  56. data/ext/ffi_c/libffi/configure +4567 -3822
  57. data/ext/ffi_c/libffi/configure.ac +64 -28
  58. data/ext/ffi_c/libffi/configure.host +25 -6
  59. data/ext/ffi_c/libffi/doc/Makefile.in +9 -6
  60. data/ext/ffi_c/libffi/doc/libffi.texi +82 -33
  61. data/ext/ffi_c/libffi/doc/version.texi +4 -4
  62. data/ext/ffi_c/libffi/fficonfig.h.in +12 -47
  63. data/ext/ffi_c/libffi/generate-darwin-source-and-headers.py +163 -52
  64. data/ext/ffi_c/libffi/include/Makefile.am +1 -1
  65. data/ext/ffi_c/libffi/include/Makefile.in +10 -9
  66. data/ext/ffi_c/libffi/include/ffi.h.in +54 -50
  67. data/ext/ffi_c/libffi/include/ffi_cfi.h +21 -0
  68. data/ext/ffi_c/libffi/include/ffi_common.h +29 -0
  69. data/ext/ffi_c/libffi/include/tramp.h +45 -0
  70. data/ext/ffi_c/libffi/libtool-version +2 -2
  71. data/ext/ffi_c/libffi/ltmain.sh +512 -315
  72. data/ext/ffi_c/libffi/m4/ax_cc_maxopt.m4 +18 -14
  73. data/ext/ffi_c/libffi/m4/ax_cflags_warn_all.m4 +108 -72
  74. data/ext/ffi_c/libffi/m4/ax_compiler_vendor.m4 +76 -45
  75. data/ext/ffi_c/libffi/m4/ax_prepend_flag.m4 +51 -0
  76. data/ext/ffi_c/libffi/man/Makefile.in +9 -6
  77. data/ext/ffi_c/libffi/missing +1 -1
  78. data/ext/ffi_c/libffi/msvc_build/aarch64/aarch64_include/ffi.h +1 -1
  79. data/ext/ffi_c/libffi/msvcc.sh +1 -1
  80. data/ext/ffi_c/libffi/src/aarch64/ffi.c +146 -42
  81. data/ext/ffi_c/libffi/src/aarch64/internal.h +32 -0
  82. data/ext/ffi_c/libffi/src/aarch64/sysv.S +134 -42
  83. data/ext/ffi_c/libffi/src/arc/arcompact.S +169 -94
  84. data/ext/ffi_c/libffi/src/arc/ffi.c +325 -148
  85. data/ext/ffi_c/libffi/src/arc/ffitarget.h +14 -0
  86. data/ext/ffi_c/libffi/src/arm/ffi.c +62 -17
  87. data/ext/ffi_c/libffi/src/arm/ffitarget.h +3 -3
  88. data/ext/ffi_c/libffi/src/arm/internal.h +10 -0
  89. data/ext/ffi_c/libffi/src/arm/sysv.S +113 -42
  90. data/ext/ffi_c/libffi/src/closures.c +133 -47
  91. data/ext/ffi_c/libffi/src/dlmalloc.c +5 -0
  92. data/ext/ffi_c/libffi/src/ia64/ffi.c +12 -0
  93. data/ext/ffi_c/libffi/src/ia64/unix.S +20 -2
  94. data/ext/ffi_c/libffi/src/loongarch64/ffi.c +621 -0
  95. data/ext/ffi_c/libffi/src/loongarch64/ffitarget.h +82 -0
  96. data/ext/ffi_c/libffi/src/loongarch64/sysv.S +327 -0
  97. data/ext/ffi_c/libffi/src/m32r/ffi.c +31 -14
  98. data/ext/ffi_c/libffi/src/mips/ffi.c +240 -65
  99. data/ext/ffi_c/libffi/src/mips/ffitarget.h +7 -0
  100. data/ext/ffi_c/libffi/src/mips/n32.S +137 -28
  101. data/ext/ffi_c/libffi/src/mips/o32.S +61 -4
  102. data/ext/ffi_c/libffi/src/moxie/ffi.c +47 -22
  103. data/ext/ffi_c/libffi/src/or1k/ffi.c +25 -12
  104. data/ext/ffi_c/libffi/src/pa/ffi.c +32 -33
  105. data/ext/ffi_c/libffi/src/pa/ffi64.c +614 -0
  106. data/ext/ffi_c/libffi/src/pa/ffitarget.h +22 -8
  107. data/ext/ffi_c/libffi/src/pa/hpux32.S +83 -36
  108. data/ext/ffi_c/libffi/src/pa/hpux64.S +681 -0
  109. data/ext/ffi_c/libffi/src/pa/linux.S +82 -35
  110. data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +1 -1
  111. data/ext/ffi_c/libffi/src/powerpc/linux64.S +2 -0
  112. data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +2 -0
  113. data/ext/ffi_c/libffi/src/powerpc/t-aix +5 -0
  114. data/ext/ffi_c/libffi/src/prep_cif.c +22 -2
  115. data/ext/ffi_c/libffi/src/riscv/ffi.c +37 -4
  116. data/ext/ffi_c/libffi/src/sparc/ffi64.c +16 -0
  117. data/ext/ffi_c/libffi/src/tramp.c +716 -0
  118. data/ext/ffi_c/libffi/src/wasm32/ffi.c +934 -0
  119. data/ext/ffi_c/libffi/src/wasm32/ffitarget.h +62 -0
  120. data/ext/ffi_c/libffi/src/x86/ffi.c +99 -37
  121. data/ext/ffi_c/libffi/src/x86/ffi64.c +67 -12
  122. data/ext/ffi_c/libffi/src/x86/ffitarget.h +9 -5
  123. data/ext/ffi_c/libffi/src/x86/ffiw64.c +43 -0
  124. data/ext/ffi_c/libffi/src/x86/internal.h +14 -0
  125. data/ext/ffi_c/libffi/src/x86/internal64.h +14 -0
  126. data/ext/ffi_c/libffi/src/x86/sysv.S +172 -38
  127. data/ext/ffi_c/libffi/src/x86/sysv_intel.S +91 -88
  128. data/ext/ffi_c/libffi/src/x86/unix64.S +96 -6
  129. data/ext/ffi_c/libffi/src/x86/win64.S +20 -7
  130. data/ext/ffi_c/libffi/src/xtensa/ffi.c +16 -8
  131. data/ext/ffi_c/libffi/src/xtensa/ffitarget.h +4 -0
  132. data/ext/ffi_c/libffi/src/xtensa/sysv.S +26 -16
  133. data/ext/ffi_c/libffi/testsuite/Makefile.am +127 -114
  134. data/ext/ffi_c/libffi/testsuite/Makefile.in +136 -120
  135. data/ext/ffi_c/libffi/testsuite/emscripten/build-tests.sh +54 -0
  136. data/ext/ffi_c/libffi/testsuite/emscripten/build.sh +63 -0
  137. data/ext/ffi_c/libffi/testsuite/emscripten/conftest.py +80 -0
  138. data/ext/ffi_c/libffi/testsuite/emscripten/node-tests.sh +48 -0
  139. data/ext/ffi_c/libffi/testsuite/emscripten/test.html +7 -0
  140. data/ext/ffi_c/libffi/testsuite/emscripten/test_libffi.py +51 -0
  141. data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +43 -21
  142. data/ext/ffi_c/libffi/testsuite/lib/target-libpath.exp +2 -2
  143. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-call.c +1 -0
  144. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/testcases.c +5 -1
  145. data/ext/ffi_c/libffi/testsuite/libffi.call/bpo_38748.c +41 -0
  146. data/ext/ffi_c/libffi/testsuite/libffi.call/ffitest.h +28 -3
  147. data/ext/ffi_c/libffi/testsuite/libffi.call/float_va.c +3 -0
  148. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll1.c +5 -0
  149. data/ext/ffi_c/libffi/testsuite/libffi.call/return_sl.c +4 -0
  150. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ul.c +4 -0
  151. data/ext/ffi_c/libffi/testsuite/libffi.call/s55.c +60 -0
  152. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen.c +8 -9
  153. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen2.c +2 -2
  154. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen3.c +2 -2
  155. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen4.c +2 -2
  156. data/ext/ffi_c/libffi/testsuite/libffi.call/struct10.c +1 -1
  157. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_2.c +63 -0
  158. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_3.c +65 -0
  159. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_3f.c +65 -0
  160. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_4.c +67 -0
  161. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_4f.c +67 -0
  162. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_big.c +93 -0
  163. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_small.c +61 -0
  164. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_return_2H.c +63 -0
  165. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_return_8H.c +90 -0
  166. data/ext/ffi_c/libffi/testsuite/libffi.call/va_1.c +1 -119
  167. data/ext/ffi_c/libffi/testsuite/libffi.call/va_2.c +220 -0
  168. data/ext/ffi_c/libffi/testsuite/libffi.call/va_3.c +154 -0
  169. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct1.c +13 -0
  170. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct2.c +11 -0
  171. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct3.c +15 -0
  172. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn0.c +3 -2
  173. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn1.c +2 -0
  174. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn2.c +2 -0
  175. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn3.c +21 -1
  176. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn4.c +2 -0
  177. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn5.c +2 -0
  178. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn6.c +2 -0
  179. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_loc_fn0.c +7 -6
  180. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_simple.c +6 -0
  181. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_12byte.c +18 -0
  182. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_16byte.c +22 -0
  183. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_18byte.c +24 -0
  184. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_19byte.c +29 -0
  185. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_1_1byte.c +4 -0
  186. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_20byte.c +19 -1
  187. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_20byte1.c +21 -1
  188. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_24byte.c +35 -3
  189. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_2byte.c +13 -0
  190. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3_1byte.c +19 -0
  191. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3byte1.c +13 -0
  192. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3byte2.c +13 -0
  193. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3float.c +18 -0
  194. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_4_1byte.c +22 -0
  195. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_4byte.c +13 -0
  196. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_5_1_byte.c +29 -1
  197. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_5byte.c +19 -1
  198. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_64byte.c +24 -0
  199. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_6_1_byte.c +28 -1
  200. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_6byte.c +24 -2
  201. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_7_1_byte.c +39 -1
  202. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_7byte.c +25 -1
  203. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_8byte.c +14 -0
  204. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_9byte1.c +14 -1
  205. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_9byte2.c +14 -2
  206. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_double.c +19 -1
  207. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_float.c +19 -1
  208. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_longdouble.c +20 -1
  209. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_longdouble_split.c +40 -25
  210. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_longdouble_split2.c +40 -3
  211. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_pointer.c +19 -1
  212. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_sint16.c +18 -1
  213. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_sint32.c +18 -3
  214. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_sint64.c +18 -1
  215. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_uint16.c +18 -1
  216. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_uint32.c +19 -1
  217. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_uint64.c +19 -1
  218. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_dbls_struct.c +3 -1
  219. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_double_va.c +9 -1
  220. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_float.c +4 -0
  221. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_longdouble.c +11 -1
  222. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_longdouble_va.c +22 -3
  223. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_schar.c +5 -1
  224. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_sshort.c +6 -1
  225. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_sshortchar.c +9 -1
  226. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_uchar.c +9 -1
  227. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_ushort.c +6 -2
  228. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_ushortchar.c +9 -1
  229. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_pointer.c +5 -0
  230. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_pointer_stack.c +10 -0
  231. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_schar.c +3 -0
  232. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_sint.c +2 -0
  233. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_sshort.c +3 -0
  234. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_struct_va1.c +11 -0
  235. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uchar.c +3 -0
  236. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uint.c +4 -0
  237. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uint_va.c +4 -0
  238. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ulong_va.c +4 -0
  239. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ulonglong.c +2 -0
  240. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ushort.c +3 -0
  241. data/ext/ffi_c/libffi/testsuite/libffi.closures/ffitest.h +1 -138
  242. data/ext/ffi_c/libffi/testsuite/libffi.closures/huge_struct.c +21 -21
  243. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct.c +32 -9
  244. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct1.c +1 -1
  245. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct10.c +12 -0
  246. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct11.c +21 -5
  247. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct12.c +86 -0
  248. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct13.c +115 -0
  249. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct2.c +10 -1
  250. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct3.c +10 -1
  251. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct4.c +9 -0
  252. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct5.c +9 -0
  253. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct6.c +11 -0
  254. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct7.c +9 -0
  255. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct8.c +11 -0
  256. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct9.c +11 -0
  257. data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs1.c +86 -0
  258. data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs2.c +102 -0
  259. data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs3.c +101 -0
  260. data/ext/ffi_c/libffi/testsuite/libffi.closures/stret_medium.c +1 -1
  261. data/ext/ffi_c/libffi/testsuite/libffi.closures/stret_medium2.c +1 -1
  262. data/ext/ffi_c/libffi/testsuite/libffi.closures/testclosure.c +6 -1
  263. data/ext/ffi_c/libffi/testsuite/libffi.closures/unwindtest.cc +2 -1
  264. data/ext/ffi_c/libffi/testsuite/libffi.closures/unwindtest_ffi_call.cc +1 -0
  265. data/ext/ffi_c/libffi.bsd.mk +2 -2
  266. data/ext/ffi_c/libffi.gnu.mk +2 -2
  267. data/ext/ffi_c/rbffi.h +1 -1
  268. data/ffi.gemspec +3 -3
  269. data/lib/ffi/autopointer.rb +7 -22
  270. data/lib/ffi/compat.rb +43 -0
  271. data/lib/ffi/data_converter.rb +2 -2
  272. data/lib/ffi/dynamic_library.rb +89 -0
  273. data/lib/ffi/enum.rb +18 -11
  274. data/lib/ffi/ffi.rb +3 -0
  275. data/lib/ffi/function.rb +71 -0
  276. data/lib/ffi/library.rb +55 -71
  277. data/lib/ffi/library_path.rb +109 -0
  278. data/lib/ffi/managedstruct.rb +1 -1
  279. data/lib/ffi/platform/aarch64-windows/types.conf +52 -0
  280. data/lib/ffi/platform/hppa1.1-linux/types.conf +178 -0
  281. data/lib/ffi/platform/hppa2.0-linux/types.conf +178 -0
  282. data/lib/ffi/platform/loongarch64-linux/types.conf +141 -0
  283. data/lib/ffi/platform/sw_64-linux/types.conf +141 -0
  284. data/lib/ffi/platform.rb +15 -13
  285. data/lib/ffi/struct.rb +2 -1
  286. data/lib/ffi/struct_layout.rb +1 -1
  287. data/lib/ffi/struct_layout_builder.rb +1 -1
  288. data/lib/ffi/tools/const_generator.rb +5 -4
  289. data/lib/ffi/types.rb +32 -6
  290. data/lib/ffi/variadic.rb +19 -8
  291. data/lib/ffi/version.rb +1 -1
  292. data/rakelib/ffi_gem_helper.rb +1 -1
  293. data/samples/hello_ractor.rb +11 -0
  294. data/samples/qsort_ractor.rb +28 -0
  295. data.tar.gz.sig +0 -0
  296. metadata +103 -28
  297. metadata.gz.sig +0 -0
  298. data/ext/ffi_c/libffi/.travis/build-cross-in-container.sh +0 -14
  299. data/ext/ffi_c/libffi/.travis/build.sh +0 -142
  300. data/ext/ffi_c/libffi/.travis.yml +0 -83
  301. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uchar_va.c +0 -44
  302. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ushort_va.c +0 -44
  303. /data/ext/ffi_c/libffi/{.travis → .ci}/ar-lib +0 -0
  304. /data/ext/ffi_c/libffi/{.travis → .ci}/bfin-sim.exp +0 -0
  305. /data/ext/ffi_c/libffi/{.travis → .ci}/compile +0 -0
  306. /data/ext/ffi_c/libffi/{.travis → .ci}/m32r-sim.exp +0 -0
  307. /data/ext/ffi_c/libffi/{.travis → .ci}/moxie-sim.exp +0 -0
  308. /data/ext/ffi_c/libffi/{.travis → .ci}/or1k-sim.exp +0 -0
  309. /data/ext/ffi_c/libffi/{.travis → .ci}/powerpc-eabisim.exp +0 -0
  310. /data/ext/ffi_c/libffi/{.travis → .ci}/wine-sim.exp +0 -0
  311. /data/ext/ffi_c/libffi/testsuite/libffi.call/{pyobjc-tc.c → pyobjc_tc.c} +0 -0
  312. /data/lib/ffi/platform/{sparc64-linux → sparcv9-linux}/types.conf +0 -0
data/ext/ffi_c/Buffer.c CHANGED
@@ -1,7 +1,7 @@
1
1
  /*
2
2
  * Copyright (c) 2008-2010 Wayne Meissner
3
3
  * Copyright (C) 2009 Aman Gupta <aman@tmm1.net>
4
- *
4
+ *
5
5
  * Copyright (c) 2008-2013, Ruby FFI project contributors
6
6
  * All rights reserved.
7
7
  *
@@ -39,7 +39,7 @@
39
39
  #define BUFFER_EMBED_MAXLEN (8)
40
40
  typedef struct Buffer {
41
41
  AbstractMemory memory;
42
-
42
+
43
43
  union {
44
44
  VALUE rbParent; /* link to parent buffer */
45
45
  char* storage; /* start of malloc area */
@@ -49,9 +49,40 @@ typedef struct Buffer {
49
49
 
50
50
  static VALUE buffer_allocate(VALUE klass);
51
51
  static VALUE buffer_initialize(int argc, VALUE* argv, VALUE self);
52
- static void buffer_release(Buffer* ptr);
53
- static void buffer_mark(Buffer* ptr);
52
+ static void buffer_release(void *data);
53
+ static void buffer_mark(void *data);
54
+ static void buffer_compact(void *data);
54
55
  static VALUE buffer_free(VALUE self);
56
+ static size_t allocated_buffer_memsize(const void *data);
57
+ static size_t buffer_memsize(const void *data);
58
+
59
+ static const rb_data_type_t buffer_data_type = {
60
+ .wrap_struct_name = "FFI::Buffer",
61
+ .function = {
62
+ .dmark = buffer_mark,
63
+ .dfree = RUBY_TYPED_DEFAULT_FREE,
64
+ .dsize = buffer_memsize,
65
+ ffi_compact_callback( buffer_compact )
66
+ },
67
+ .parent = &rbffi_abstract_memory_data_type,
68
+ // IMPORTANT: WB_PROTECTED objects must only use the RB_OBJ_WRITE()
69
+ // macro to update VALUE references, as to trigger write barriers.
70
+ .flags = RUBY_TYPED_FREE_IMMEDIATELY | RUBY_TYPED_WB_PROTECTED | FFI_RUBY_TYPED_FROZEN_SHAREABLE
71
+ };
72
+
73
+ static const rb_data_type_t allocated_buffer_data_type = {
74
+ .wrap_struct_name = "FFI::Buffer(allocated)",
75
+ .function = {
76
+ .dmark = NULL,
77
+ .dfree = buffer_release,
78
+ .dsize = allocated_buffer_memsize,
79
+ },
80
+ .parent = &buffer_data_type,
81
+ // IMPORTANT: WB_PROTECTED objects must only use the RB_OBJ_WRITE()
82
+ // macro to update VALUE references, as to trigger write barriers.
83
+ .flags = RUBY_TYPED_FREE_IMMEDIATELY | RUBY_TYPED_WB_PROTECTED | FFI_RUBY_TYPED_FROZEN_SHAREABLE
84
+ };
85
+
55
86
 
56
87
  static VALUE BufferClass = Qnil;
57
88
 
@@ -61,21 +92,22 @@ buffer_allocate(VALUE klass)
61
92
  Buffer* buffer;
62
93
  VALUE obj;
63
94
 
64
- obj = Data_Make_Struct(klass, Buffer, NULL, buffer_release, buffer);
65
- buffer->data.rbParent = Qnil;
95
+ obj = TypedData_Make_Struct(klass, Buffer, &allocated_buffer_data_type, buffer);
96
+ RB_OBJ_WRITE(obj, &buffer->data.rbParent, Qnil);
66
97
  buffer->memory.flags = MEM_RD | MEM_WR;
67
98
 
68
99
  return obj;
69
100
  }
70
101
 
71
102
  static void
72
- buffer_release(Buffer* ptr)
103
+ buffer_release(void *data)
73
104
  {
105
+ Buffer *ptr = (Buffer *)data;
74
106
  if ((ptr->memory.flags & MEM_EMBED) == 0 && ptr->data.storage != NULL) {
75
107
  xfree(ptr->data.storage);
76
108
  ptr->data.storage = NULL;
77
109
  }
78
-
110
+
79
111
  xfree(ptr);
80
112
  }
81
113
 
@@ -95,7 +127,7 @@ buffer_initialize(int argc, VALUE* argv, VALUE self)
95
127
  Buffer* p;
96
128
  int nargs;
97
129
 
98
- Data_Get_Struct(self, Buffer, p);
130
+ TypedData_Get_Struct(self, Buffer, &buffer_data_type, p);
99
131
 
100
132
  nargs = rb_scan_args(argc, argv, "12", &rbSize, &rbCount, &rbClear);
101
133
  p->memory.typeSize = rbffi_type_size(rbSize);
@@ -110,11 +142,11 @@ buffer_initialize(int argc, VALUE* argv, VALUE self)
110
142
 
111
143
  /* ensure the memory is aligned on at least a 8 byte boundary */
112
144
  p->memory.address = (void *) (((uintptr_t) p->data.storage + 0x7) & (uintptr_t) ~0x7ULL);
113
-
145
+
114
146
  if (p->memory.size > 0 && (nargs < 3 || RTEST(rbClear))) {
115
147
  memset(p->memory.address, 0, p->memory.size);
116
148
  }
117
-
149
+
118
150
  } else {
119
151
  p->memory.flags |= MEM_EMBED;
120
152
  p->memory.address = (void *) &p->data.embed[0];
@@ -137,9 +169,9 @@ buffer_initialize_copy(VALUE self, VALUE other)
137
169
  {
138
170
  AbstractMemory* src;
139
171
  Buffer* dst;
140
-
141
- Data_Get_Struct(self, Buffer, dst);
142
- src = rbffi_AbstractMemory_Cast(other, BufferClass);
172
+
173
+ TypedData_Get_Struct(self, Buffer, &buffer_data_type, dst);
174
+ src = rbffi_AbstractMemory_Cast(other, &buffer_data_type);
143
175
  if ((dst->memory.flags & MEM_EMBED) == 0 && dst->data.storage != NULL) {
144
176
  xfree(dst->data.storage);
145
177
  }
@@ -148,11 +180,11 @@ buffer_initialize_copy(VALUE self, VALUE other)
148
180
  rb_raise(rb_eNoMemError, "failed to allocate memory size=%lu bytes", src->size);
149
181
  return Qnil;
150
182
  }
151
-
183
+
152
184
  dst->memory.address = (void *) (((uintptr_t) dst->data.storage + 0x7) & (uintptr_t) ~0x7ULL);
153
185
  dst->memory.size = src->size;
154
186
  dst->memory.typeSize = src->typeSize;
155
-
187
+
156
188
  /* finally, copy the actual buffer contents */
157
189
  memcpy(dst->memory.address, src->address, src->size);
158
190
 
@@ -171,16 +203,16 @@ slice(VALUE self, long offset, long len)
171
203
  Buffer* ptr;
172
204
  Buffer* result;
173
205
  VALUE obj = Qnil;
174
-
175
- Data_Get_Struct(self, Buffer, ptr);
206
+
207
+ TypedData_Get_Struct(self, Buffer, &buffer_data_type, ptr);
176
208
  checkBounds(&ptr->memory, offset, len);
177
209
 
178
- obj = Data_Make_Struct(BufferClass, Buffer, buffer_mark, -1, result);
210
+ obj = TypedData_Make_Struct(BufferClass, Buffer, &buffer_data_type, result);
179
211
  result->memory.address = ptr->memory.address + offset;
180
212
  result->memory.size = len;
181
213
  result->memory.flags = ptr->memory.flags;
182
214
  result->memory.typeSize = ptr->memory.typeSize;
183
- result->data.rbParent = self;
215
+ RB_OBJ_WRITE(obj, &result->data.rbParent, self);
184
216
 
185
217
  return obj;
186
218
  }
@@ -197,7 +229,7 @@ buffer_plus(VALUE self, VALUE rbOffset)
197
229
  Buffer* ptr;
198
230
  long offset = NUM2LONG(rbOffset);
199
231
 
200
- Data_Get_Struct(self, Buffer, ptr);
232
+ TypedData_Get_Struct(self, Buffer, &buffer_data_type, ptr);
201
233
 
202
234
  return slice(self, offset, ptr->memory.size - offset);
203
235
  }
@@ -226,10 +258,10 @@ buffer_inspect(VALUE self)
226
258
  char tmp[100];
227
259
  Buffer* ptr;
228
260
 
229
- Data_Get_Struct(self, Buffer, ptr);
261
+ TypedData_Get_Struct(self, Buffer, &buffer_data_type, ptr);
230
262
 
231
263
  snprintf(tmp, sizeof(tmp), "#<FFI:Buffer:%p address=%p size=%ld>", ptr, ptr->memory.address, ptr->memory.size);
232
-
264
+
233
265
  return rb_str_new2(tmp);
234
266
  }
235
267
 
@@ -255,7 +287,7 @@ buffer_order(int argc, VALUE* argv, VALUE self)
255
287
  {
256
288
  Buffer* ptr;
257
289
 
258
- Data_Get_Struct(self, Buffer, ptr);
290
+ TypedData_Get_Struct(self, Buffer, &buffer_data_type, ptr);
259
291
  if (argc == 0) {
260
292
  int order = (ptr->memory.flags & MEM_SWAP) == 0 ? BYTE_ORDER : SWAPPED_ORDER;
261
293
  return order == BIG_ENDIAN ? ID2SYM(rb_intern("big")) : ID2SYM(rb_intern("little"));
@@ -279,7 +311,7 @@ buffer_order(int argc, VALUE* argv, VALUE self)
279
311
  Buffer* p2;
280
312
  VALUE retval = slice(self, 0, ptr->memory.size);
281
313
 
282
- Data_Get_Struct(retval, Buffer, p2);
314
+ TypedData_Get_Struct(retval, Buffer, &buffer_data_type, p2);
283
315
  p2->memory.flags |= MEM_SWAP;
284
316
  return retval;
285
317
  }
@@ -294,7 +326,7 @@ buffer_free(VALUE self)
294
326
  {
295
327
  Buffer* ptr;
296
328
 
297
- Data_Get_Struct(self, Buffer, ptr);
329
+ TypedData_Get_Struct(self, Buffer, &buffer_data_type, ptr);
298
330
  if ((ptr->memory.flags & MEM_EMBED) == 0 && ptr->data.storage != NULL) {
299
331
  xfree(ptr->data.storage);
300
332
  ptr->data.storage = NULL;
@@ -304,9 +336,34 @@ buffer_free(VALUE self)
304
336
  }
305
337
 
306
338
  static void
307
- buffer_mark(Buffer* ptr)
339
+ buffer_mark(void *data)
340
+ {
341
+ Buffer *ptr = (Buffer *)data;
342
+ rb_gc_mark_movable(ptr->data.rbParent);
343
+ }
344
+
345
+ static void
346
+ buffer_compact(void *data)
347
+ {
348
+ Buffer *ptr = (Buffer *)data;
349
+ ffi_gc_location(ptr->data.rbParent);
350
+ }
351
+
352
+ static size_t
353
+ buffer_memsize(const void *data)
308
354
  {
309
- rb_gc_mark(ptr->data.rbParent);
355
+ return sizeof(Buffer);
356
+ }
357
+
358
+ static size_t
359
+ allocated_buffer_memsize(const void *data)
360
+ {
361
+ const Buffer *ptr = (const Buffer *)data;
362
+ size_t memsize = sizeof(Buffer);
363
+ if ((ptr->memory.flags & MEM_EMBED) == 0 && ptr->data.storage != NULL) {
364
+ memsize += ptr->memory.size;
365
+ }
366
+ return memsize;
310
367
  }
311
368
 
312
369
  void
@@ -348,7 +405,7 @@ rbffi_Buffer_Init(VALUE moduleFFI)
348
405
  rb_define_alias(rb_singleton_class(BufferClass), "new_in", "alloc_in");
349
406
  rb_define_alias(rb_singleton_class(BufferClass), "new_out", "alloc_out");
350
407
  rb_define_alias(rb_singleton_class(BufferClass), "new_inout", "alloc_inout");
351
-
408
+
352
409
  rb_define_method(BufferClass, "initialize", buffer_initialize, -1);
353
410
  rb_define_method(BufferClass, "initialize_copy", buffer_initialize_copy, 1);
354
411
  rb_define_method(BufferClass, "order", buffer_order, -1);
data/ext/ffi_c/Call.c CHANGED
@@ -71,7 +71,7 @@
71
71
  #define FLOAT32_ADJ (4)
72
72
  #define FLOAT64_ADJ (8)
73
73
  #define ADDRESS_ADJ (sizeof(void *))
74
- #define LONGDOUBLE_ADJ (ffi_type_longdouble.alignment)
74
+ #define LONGDOUBLE_ADJ (ffi_type_longdouble.alignment > sizeof(long double) ? ffi_type_longdouble.alignment : sizeof(long double))
75
75
 
76
76
  #endif /* USE_RAW */
77
77
 
@@ -420,11 +420,17 @@ getPointer(VALUE value, int type)
420
420
  {
421
421
  if (likely(type == T_DATA && rb_obj_is_kind_of(value, rbffi_AbstractMemoryClass))) {
422
422
 
423
- return ((AbstractMemory *) DATA_PTR(value))->address;
423
+ AbstractMemory *mem;
424
+ TypedData_Get_Struct(value, AbstractMemory, &rbffi_abstract_memory_data_type, mem);
425
+ return mem->address;
424
426
 
425
427
  } else if (type == T_DATA && rb_obj_is_kind_of(value, rbffi_StructClass)) {
426
428
 
427
- AbstractMemory* memory = ((Struct *) DATA_PTR(value))->pointer;
429
+ Struct* s;
430
+ AbstractMemory* memory;
431
+
432
+ TypedData_Get_Struct(value, Struct, &rbffi_struct_data_type, s);
433
+ memory = s->pointer;
428
434
  return memory != NULL ? memory->address : NULL;
429
435
 
430
436
  } else if (type == T_STRING) {
@@ -439,7 +445,9 @@ getPointer(VALUE value, int type)
439
445
 
440
446
  VALUE ptr = rb_funcall2(value, id_to_ptr, 0, NULL);
441
447
  if (rb_obj_is_kind_of(ptr, rbffi_AbstractMemoryClass) && TYPE(ptr) == T_DATA) {
442
- return ((AbstractMemory *) DATA_PTR(ptr))->address;
448
+ AbstractMemory *mem;
449
+ TypedData_Get_Struct(ptr, AbstractMemory, &rbffi_abstract_memory_data_type, mem);
450
+ return mem->address;
443
451
  }
444
452
  rb_raise(rb_eArgError, "to_ptr returned an invalid pointer");
445
453
  }
@@ -458,7 +466,9 @@ rbffi_GetInvoker(FunctionType *fnInfo)
458
466
  static void*
459
467
  callback_param(VALUE proc, VALUE cbInfo)
460
468
  {
461
- VALUE callback ;
469
+ VALUE callback;
470
+ AbstractMemory *mem;
471
+
462
472
  if (unlikely(proc == Qnil)) {
463
473
  return NULL ;
464
474
  }
@@ -466,14 +476,15 @@ callback_param(VALUE proc, VALUE cbInfo)
466
476
  /* Handle Function pointers here */
467
477
  if (rb_obj_is_kind_of(proc, rbffi_FunctionClass)) {
468
478
  AbstractMemory* ptr;
469
- Data_Get_Struct(proc, AbstractMemory, ptr);
479
+ TypedData_Get_Struct(proc, AbstractMemory, &rbffi_abstract_memory_data_type, ptr);
470
480
  return ptr->address;
471
481
  }
472
482
 
473
483
  callback = rbffi_Function_ForProc(cbInfo, proc);
474
484
  RB_GC_GUARD(callback);
475
485
 
476
- return ((AbstractMemory *) DATA_PTR(callback))->address;
486
+ TypedData_Get_Struct(callback, AbstractMemory, &rbffi_abstract_memory_data_type, mem);
487
+ return mem->address;
477
488
  }
478
489
 
479
490
 
@@ -50,17 +50,45 @@
50
50
 
51
51
  typedef struct LibrarySymbol_ {
52
52
  Pointer base;
53
- VALUE library;
54
53
  VALUE name;
55
54
  } LibrarySymbol;
56
55
 
57
- static VALUE library_initialize(VALUE self, VALUE libname, VALUE libflags);
58
- static void library_free(Library* lib);
59
56
 
57
+ static VALUE library_initialize(VALUE self, VALUE libname, VALUE libflags);
58
+ static void library_free(void *);
59
+ static size_t library_memsize(const void *);
60
60
 
61
61
  static VALUE symbol_allocate(VALUE klass);
62
62
  static VALUE symbol_new(VALUE library, void* address, VALUE name);
63
- static void symbol_mark(LibrarySymbol* sym);
63
+ static void symbol_mark(void *data);
64
+ static void symbol_compact(void *data);
65
+ static size_t symbol_memsize(const void *data);
66
+
67
+ static const rb_data_type_t rbffi_library_data_type = {
68
+ .wrap_struct_name = "FFI::DynamicLibrary",
69
+ .function = {
70
+ .dmark = NULL,
71
+ .dfree = library_free,
72
+ .dsize = library_memsize,
73
+ },
74
+ // IMPORTANT: WB_PROTECTED objects must only use the RB_OBJ_WRITE()
75
+ // macro to update VALUE references, as to trigger write barriers.
76
+ .flags = RUBY_TYPED_FREE_IMMEDIATELY | RUBY_TYPED_WB_PROTECTED | FFI_RUBY_TYPED_FROZEN_SHAREABLE
77
+ };
78
+
79
+ static const rb_data_type_t library_symbol_data_type = {
80
+ .wrap_struct_name = "FFI::DynamicLibrary::Symbol",
81
+ .function = {
82
+ .dmark = symbol_mark,
83
+ .dfree = RUBY_TYPED_DEFAULT_FREE,
84
+ .dsize = symbol_memsize,
85
+ ffi_compact_callback( symbol_compact )
86
+ },
87
+ .parent = &rbffi_pointer_data_type,
88
+ // IMPORTANT: WB_PROTECTED objects must only use the RB_OBJ_WRITE()
89
+ // macro to update VALUE references, as to trigger write barriers.
90
+ .flags = RUBY_TYPED_FREE_IMMEDIATELY | RUBY_TYPED_WB_PROTECTED | FFI_RUBY_TYPED_FROZEN_SHAREABLE
91
+ };
64
92
 
65
93
  static VALUE LibraryClass = Qnil, SymbolClass = Qnil;
66
94
 
@@ -80,7 +108,7 @@ static VALUE
80
108
  library_allocate(VALUE klass)
81
109
  {
82
110
  Library* library;
83
- return Data_Make_Struct(klass, Library, NULL, library_free, library);
111
+ return TypedData_Make_Struct(klass, Library, &rbffi_library_data_type, library);
84
112
  }
85
113
 
86
114
  /*
@@ -113,9 +141,9 @@ library_initialize(VALUE self, VALUE libname, VALUE libflags)
113
141
 
114
142
  Check_Type(libflags, T_FIXNUM);
115
143
 
116
- Data_Get_Struct(self, Library, library);
144
+ TypedData_Get_Struct(self, Library, &rbffi_library_data_type, library);
117
145
  flags = libflags != Qnil ? NUM2UINT(libflags) : 0;
118
-
146
+
119
147
  library->handle = dl_open(libname != Qnil ? StringValueCStr(libname) : NULL, flags);
120
148
  if (library->handle == NULL) {
121
149
  char errmsg[1024];
@@ -133,7 +161,9 @@ library_initialize(VALUE self, VALUE libname, VALUE libflags)
133
161
  library->handle = RTLD_DEFAULT;
134
162
  }
135
163
  #endif
136
- rb_iv_set(self, "@name", libname != Qnil ? libname : rb_str_new2("[current process]"));
164
+ rb_iv_set(self, "@name", libname != Qnil ? rb_str_new_frozen(libname) : rb_str_new2("[current process]"));
165
+
166
+ rb_obj_freeze(self);
137
167
  return self;
138
168
  }
139
169
 
@@ -144,9 +174,9 @@ library_dlsym(VALUE self, VALUE name)
144
174
  void* address = NULL;
145
175
  Check_Type(name, T_STRING);
146
176
 
147
- Data_Get_Struct(self, Library, library);
177
+ TypedData_Get_Struct(self, Library, &rbffi_library_data_type, library);
148
178
  address = dl_sym(library->handle, StringValueCStr(name));
149
-
179
+
150
180
  return address != NULL ? symbol_new(self, address, name) : Qnil;
151
181
  }
152
182
 
@@ -163,8 +193,10 @@ library_dlerror(VALUE self)
163
193
  }
164
194
 
165
195
  static void
166
- library_free(Library* library)
196
+ library_free(void *data)
167
197
  {
198
+ Library *library = (Library*)data;
199
+
168
200
  /* dlclose() on MacOS tends to segfault - avoid it */
169
201
  #ifndef __APPLE__
170
202
  if (library->handle != NULL) {
@@ -174,6 +206,12 @@ library_free(Library* library)
174
206
  xfree(library);
175
207
  }
176
208
 
209
+ static size_t
210
+ library_memsize(const void *data)
211
+ {
212
+ return sizeof(Library);
213
+ }
214
+
177
215
  #if (defined(_WIN32) || defined(__WIN32__)) && !defined(__CYGWIN__)
178
216
  static void*
179
217
  dl_open(const char* name, int flags)
@@ -189,8 +227,19 @@ dl_open(const char* name, int flags)
189
227
  static void
190
228
  dl_error(char* buf, int size)
191
229
  {
192
- FormatMessageA(FORMAT_MESSAGE_FROM_SYSTEM, NULL, GetLastError(),
193
- 0, buf, size, NULL);
230
+ // Get the last error code
231
+ DWORD error = GetLastError();
232
+
233
+ // Get the associated message
234
+ LPSTR message = NULL;
235
+ FormatMessageA(FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_ALLOCATE_BUFFER,
236
+ NULL, error, 0, (LPSTR)&message, 0, NULL);
237
+
238
+ // Update the passed in buffer
239
+ snprintf(buf, size, "Failed with error %d: %s", error, message);
240
+
241
+ // Free the allocated message
242
+ LocalFree(message);
194
243
  }
195
244
  #endif
196
245
 
@@ -198,10 +247,9 @@ static VALUE
198
247
  symbol_allocate(VALUE klass)
199
248
  {
200
249
  LibrarySymbol* sym;
201
- VALUE obj = Data_Make_Struct(klass, LibrarySymbol, NULL, -1, sym);
202
- sym->name = Qnil;
203
- sym->library = Qnil;
204
- sym->base.rbParent = Qnil;
250
+ VALUE obj = TypedData_Make_Struct(klass, LibrarySymbol, &library_symbol_data_type, sym);
251
+ RB_OBJ_WRITE(obj, &sym->base.rbParent, Qnil);
252
+ RB_OBJ_WRITE(obj, &sym->name, Qnil);
205
253
 
206
254
  return obj;
207
255
  }
@@ -224,23 +272,39 @@ static VALUE
224
272
  symbol_new(VALUE library, void* address, VALUE name)
225
273
  {
226
274
  LibrarySymbol* sym;
227
- VALUE obj = Data_Make_Struct(SymbolClass, LibrarySymbol, symbol_mark, -1, sym);
275
+ VALUE obj = TypedData_Make_Struct(SymbolClass, LibrarySymbol, &library_symbol_data_type, sym);
228
276
 
229
277
  sym->base.memory.address = address;
230
278
  sym->base.memory.size = LONG_MAX;
231
279
  sym->base.memory.typeSize = 1;
232
280
  sym->base.memory.flags = MEM_RD | MEM_WR;
233
- sym->library = library;
234
- sym->name = name;
281
+ RB_OBJ_WRITE(obj, &sym->base.rbParent, library);
282
+ RB_OBJ_WRITE(obj, &sym->name, rb_str_new_frozen(name));
235
283
 
284
+ rb_obj_freeze(obj);
236
285
  return obj;
237
286
  }
238
287
 
239
288
  static void
240
- symbol_mark(LibrarySymbol* sym)
289
+ symbol_mark(void *data)
290
+ {
291
+ LibrarySymbol *sym = (LibrarySymbol *)data;
292
+ rb_gc_mark_movable(sym->base.rbParent);
293
+ rb_gc_mark_movable(sym->name);
294
+ }
295
+
296
+ static void
297
+ symbol_compact(void *data)
241
298
  {
242
- rb_gc_mark(sym->library);
243
- rb_gc_mark(sym->name);
299
+ LibrarySymbol *sym = (LibrarySymbol *)data;
300
+ ffi_gc_location(sym->base.rbParent);
301
+ ffi_gc_location(sym->name);
302
+ }
303
+
304
+ static size_t
305
+ symbol_memsize(const void *data)
306
+ {
307
+ return sizeof(LibrarySymbol);
244
308
  }
245
309
 
246
310
  /*
@@ -254,8 +318,8 @@ symbol_inspect(VALUE self)
254
318
  LibrarySymbol* sym;
255
319
  char buf[256];
256
320
 
257
- Data_Get_Struct(self, LibrarySymbol, sym);
258
- snprintf(buf, sizeof(buf), "#<FFI::Library::Symbol name=%s address=%p>",
321
+ TypedData_Get_Struct(self, LibrarySymbol, &library_symbol_data_type, sym);
322
+ snprintf(buf, sizeof(buf), "#<FFI::DynamicLibrary::Symbol name=%s address=%p>",
259
323
  StringValueCStr(sym->name), sym->base.memory.address);
260
324
  return rb_str_new2(buf);
261
325
  }
@@ -331,4 +395,3 @@ rbffi_DynamicLibrary_Init(VALUE moduleFFI)
331
395
  #undef DEF
332
396
 
333
397
  }
334
-