remogatto-ffi 0.5.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (324) hide show
  1. data/LICENSE +51 -0
  2. data/README.rdoc +69 -0
  3. data/Rakefile +144 -0
  4. data/ext/ffi_c/AbstractMemory.c +489 -0
  5. data/ext/ffi_c/AbstractMemory.h +160 -0
  6. data/ext/ffi_c/ArrayType.c +129 -0
  7. data/ext/ffi_c/ArrayType.h +58 -0
  8. data/ext/ffi_c/AutoPointer.c +61 -0
  9. data/ext/ffi_c/AutoPointer.h +18 -0
  10. data/ext/ffi_c/Buffer.c +187 -0
  11. data/ext/ffi_c/Call.c +431 -0
  12. data/ext/ffi_c/Call.h +77 -0
  13. data/ext/ffi_c/DynamicLibrary.c +216 -0
  14. data/ext/ffi_c/DynamicLibrary.h +22 -0
  15. data/ext/ffi_c/Function.c +498 -0
  16. data/ext/ffi_c/Function.h +73 -0
  17. data/ext/ffi_c/FunctionInfo.c +213 -0
  18. data/ext/ffi_c/LastError.c +159 -0
  19. data/ext/ffi_c/LastError.h +18 -0
  20. data/ext/ffi_c/MemoryPointer.c +178 -0
  21. data/ext/ffi_c/MemoryPointer.h +20 -0
  22. data/ext/ffi_c/MethodHandle.c +356 -0
  23. data/ext/ffi_c/MethodHandle.h +53 -0
  24. data/ext/ffi_c/Platform.c +59 -0
  25. data/ext/ffi_c/Platform.h +16 -0
  26. data/ext/ffi_c/Pointer.c +217 -0
  27. data/ext/ffi_c/Pointer.h +49 -0
  28. data/ext/ffi_c/Struct.c +770 -0
  29. data/ext/ffi_c/Struct.h +80 -0
  30. data/ext/ffi_c/StructByValue.c +140 -0
  31. data/ext/ffi_c/StructByValue.h +53 -0
  32. data/ext/ffi_c/StructLayout.c +450 -0
  33. data/ext/ffi_c/Type.c +329 -0
  34. data/ext/ffi_c/Type.h +57 -0
  35. data/ext/ffi_c/Types.c +103 -0
  36. data/ext/ffi_c/Types.h +85 -0
  37. data/ext/ffi_c/Variadic.c +260 -0
  38. data/ext/ffi_c/compat.h +72 -0
  39. data/ext/ffi_c/endian.h +40 -0
  40. data/ext/ffi_c/extconf.rb +34 -0
  41. data/ext/ffi_c/ffi.c +80 -0
  42. data/ext/ffi_c/libffi.bsd.mk +34 -0
  43. data/ext/ffi_c/libffi.darwin.mk +75 -0
  44. data/ext/ffi_c/libffi.gnu.mk +29 -0
  45. data/ext/ffi_c/libffi.mk +13 -0
  46. data/ext/ffi_c/libffi/ChangeLog +3243 -0
  47. data/ext/ffi_c/libffi/ChangeLog.libffi +347 -0
  48. data/ext/ffi_c/libffi/ChangeLog.libgcj +40 -0
  49. data/ext/ffi_c/libffi/ChangeLog.v1 +764 -0
  50. data/ext/ffi_c/libffi/LICENSE +21 -0
  51. data/ext/ffi_c/libffi/Makefile.am +177 -0
  52. data/ext/ffi_c/libffi/Makefile.in +1640 -0
  53. data/ext/ffi_c/libffi/README +328 -0
  54. data/ext/ffi_c/libffi/TODO +1 -0
  55. data/ext/ffi_c/libffi/acinclude.m4 +92 -0
  56. data/ext/ffi_c/libffi/aclocal.m4 +7516 -0
  57. data/ext/ffi_c/libffi/compile +142 -0
  58. data/ext/ffi_c/libffi/config.guess +1516 -0
  59. data/ext/ffi_c/libffi/config.sub +1626 -0
  60. data/ext/ffi_c/libffi/configure +24414 -0
  61. data/ext/ffi_c/libffi/configure.ac +365 -0
  62. data/ext/ffi_c/libffi/configure.host +11 -0
  63. data/ext/ffi_c/libffi/depcomp +584 -0
  64. data/ext/ffi_c/libffi/doc/libffi.info +533 -0
  65. data/ext/ffi_c/libffi/doc/libffi.texi +541 -0
  66. data/ext/ffi_c/libffi/doc/stamp-vti +4 -0
  67. data/ext/ffi_c/libffi/doc/version.texi +4 -0
  68. data/ext/ffi_c/libffi/fficonfig.h.in +160 -0
  69. data/ext/ffi_c/libffi/include/Makefile.am +9 -0
  70. data/ext/ffi_c/libffi/include/Makefile.in +422 -0
  71. data/ext/ffi_c/libffi/include/ffi.h.in +393 -0
  72. data/ext/ffi_c/libffi/include/ffi_common.h +98 -0
  73. data/ext/ffi_c/libffi/install-sh +323 -0
  74. data/ext/ffi_c/libffi/libffi.pc.in +10 -0
  75. data/ext/ffi_c/libffi/libtool-version +29 -0
  76. data/ext/ffi_c/libffi/ltcf-c.sh +861 -0
  77. data/ext/ffi_c/libffi/ltcf-cxx.sh +1069 -0
  78. data/ext/ffi_c/libffi/ltcf-gcj.sh +700 -0
  79. data/ext/ffi_c/libffi/ltconfig +2862 -0
  80. data/ext/ffi_c/libffi/ltmain.sh +6930 -0
  81. data/ext/ffi_c/libffi/man/Makefile.am +8 -0
  82. data/ext/ffi_c/libffi/man/Makefile.in +395 -0
  83. data/ext/ffi_c/libffi/man/ffi.3 +31 -0
  84. data/ext/ffi_c/libffi/man/ffi_call.3 +103 -0
  85. data/ext/ffi_c/libffi/man/ffi_prep_cif.3 +66 -0
  86. data/ext/ffi_c/libffi/mdate-sh +201 -0
  87. data/ext/ffi_c/libffi/missing +353 -0
  88. data/ext/ffi_c/libffi/mkinstalldirs +158 -0
  89. data/ext/ffi_c/libffi/src/alpha/ffi.c +284 -0
  90. data/ext/ffi_c/libffi/src/alpha/ffitarget.h +48 -0
  91. data/ext/ffi_c/libffi/src/alpha/osf.S +366 -0
  92. data/ext/ffi_c/libffi/src/arm/ffi.c +309 -0
  93. data/ext/ffi_c/libffi/src/arm/ffitarget.h +49 -0
  94. data/ext/ffi_c/libffi/src/arm/sysv.S +299 -0
  95. data/ext/ffi_c/libffi/src/closures.c +596 -0
  96. data/ext/ffi_c/libffi/src/cris/ffi.c +383 -0
  97. data/ext/ffi_c/libffi/src/cris/ffitarget.h +51 -0
  98. data/ext/ffi_c/libffi/src/cris/sysv.S +215 -0
  99. data/ext/ffi_c/libffi/src/debug.c +59 -0
  100. data/ext/ffi_c/libffi/src/dlmalloc.c +5099 -0
  101. data/ext/ffi_c/libffi/src/frv/eabi.S +128 -0
  102. data/ext/ffi_c/libffi/src/frv/ffi.c +292 -0
  103. data/ext/ffi_c/libffi/src/frv/ffitarget.h +61 -0
  104. data/ext/ffi_c/libffi/src/ia64/ffi.c +580 -0
  105. data/ext/ffi_c/libffi/src/ia64/ffitarget.h +50 -0
  106. data/ext/ffi_c/libffi/src/ia64/ia64_flags.h +40 -0
  107. data/ext/ffi_c/libffi/src/ia64/unix.S +560 -0
  108. data/ext/ffi_c/libffi/src/java_raw_api.c +359 -0
  109. data/ext/ffi_c/libffi/src/m32r/ffi.c +232 -0
  110. data/ext/ffi_c/libffi/src/m32r/ffitarget.h +48 -0
  111. data/ext/ffi_c/libffi/src/m32r/sysv.S +121 -0
  112. data/ext/ffi_c/libffi/src/m68k/ffi.c +278 -0
  113. data/ext/ffi_c/libffi/src/m68k/ffitarget.h +49 -0
  114. data/ext/ffi_c/libffi/src/m68k/sysv.S +234 -0
  115. data/ext/ffi_c/libffi/src/mips/ffi.c +926 -0
  116. data/ext/ffi_c/libffi/src/mips/ffitarget.h +202 -0
  117. data/ext/ffi_c/libffi/src/mips/n32.S +534 -0
  118. data/ext/ffi_c/libffi/src/mips/o32.S +381 -0
  119. data/ext/ffi_c/libffi/src/pa/ffi.c +709 -0
  120. data/ext/ffi_c/libffi/src/pa/ffitarget.h +77 -0
  121. data/ext/ffi_c/libffi/src/pa/hpux32.S +368 -0
  122. data/ext/ffi_c/libffi/src/pa/linux.S +357 -0
  123. data/ext/ffi_c/libffi/src/powerpc/aix.S +225 -0
  124. data/ext/ffi_c/libffi/src/powerpc/aix_closure.S +247 -0
  125. data/ext/ffi_c/libffi/src/powerpc/asm.h +125 -0
  126. data/ext/ffi_c/libffi/src/powerpc/darwin.S +245 -0
  127. data/ext/ffi_c/libffi/src/powerpc/darwin_closure.S +317 -0
  128. data/ext/ffi_c/libffi/src/powerpc/ffi.c +1429 -0
  129. data/ext/ffi_c/libffi/src/powerpc/ffi_darwin.c +800 -0
  130. data/ext/ffi_c/libffi/src/powerpc/ffitarget.h +118 -0
  131. data/ext/ffi_c/libffi/src/powerpc/linux64.S +187 -0
  132. data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +236 -0
  133. data/ext/ffi_c/libffi/src/powerpc/ppc_closure.S +327 -0
  134. data/ext/ffi_c/libffi/src/powerpc/sysv.S +230 -0
  135. data/ext/ffi_c/libffi/src/prep_cif.c +174 -0
  136. data/ext/ffi_c/libffi/src/raw_api.c +254 -0
  137. data/ext/ffi_c/libffi/src/s390/ffi.c +780 -0
  138. data/ext/ffi_c/libffi/src/s390/ffitarget.h +60 -0
  139. data/ext/ffi_c/libffi/src/s390/sysv.S +434 -0
  140. data/ext/ffi_c/libffi/src/sh/ffi.c +716 -0
  141. data/ext/ffi_c/libffi/src/sh/ffitarget.h +49 -0
  142. data/ext/ffi_c/libffi/src/sh/sysv.S +850 -0
  143. data/ext/ffi_c/libffi/src/sh64/ffi.c +453 -0
  144. data/ext/ffi_c/libffi/src/sh64/ffitarget.h +53 -0
  145. data/ext/ffi_c/libffi/src/sh64/sysv.S +530 -0
  146. data/ext/ffi_c/libffi/src/sparc/ffi.c +610 -0
  147. data/ext/ffi_c/libffi/src/sparc/ffitarget.h +66 -0
  148. data/ext/ffi_c/libffi/src/sparc/v8.S +272 -0
  149. data/ext/ffi_c/libffi/src/sparc/v9.S +307 -0
  150. data/ext/ffi_c/libffi/src/types.c +77 -0
  151. data/ext/ffi_c/libffi/src/x86/darwin.S +443 -0
  152. data/ext/ffi_c/libffi/src/x86/darwin64.S +416 -0
  153. data/ext/ffi_c/libffi/src/x86/ffi.c +475 -0
  154. data/ext/ffi_c/libffi/src/x86/ffi64.c +572 -0
  155. data/ext/ffi_c/libffi/src/x86/ffitarget.h +90 -0
  156. data/ext/ffi_c/libffi/src/x86/freebsd.S +458 -0
  157. data/ext/ffi_c/libffi/src/x86/sysv.S +437 -0
  158. data/ext/ffi_c/libffi/src/x86/unix64.S +418 -0
  159. data/ext/ffi_c/libffi/src/x86/win32.S +391 -0
  160. data/ext/ffi_c/libffi/testsuite/Makefile.am +71 -0
  161. data/ext/ffi_c/libffi/testsuite/Makefile.in +447 -0
  162. data/ext/ffi_c/libffi/testsuite/config/default.exp +1 -0
  163. data/ext/ffi_c/libffi/testsuite/lib/libffi-dg.exp +289 -0
  164. data/ext/ffi_c/libffi/testsuite/lib/target-libpath.exp +263 -0
  165. data/ext/ffi_c/libffi/testsuite/lib/wrapper.exp +45 -0
  166. data/ext/ffi_c/libffi/testsuite/libffi.call/call.exp +36 -0
  167. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn0.c +97 -0
  168. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn1.c +89 -0
  169. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn2.c +89 -0
  170. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn3.c +90 -0
  171. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn4.c +97 -0
  172. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn5.c +99 -0
  173. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn6.c +98 -0
  174. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_stdcall.c +72 -0
  175. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_12byte.c +102 -0
  176. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_16byte.c +103 -0
  177. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_18byte.c +104 -0
  178. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_19byte.c +110 -0
  179. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_1_1byte.c +97 -0
  180. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_20byte.c +99 -0
  181. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_20byte1.c +101 -0
  182. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_24byte.c +121 -0
  183. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_2byte.c +98 -0
  184. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3_1byte.c +103 -0
  185. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3byte1.c +98 -0
  186. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3byte2.c +98 -0
  187. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_4_1byte.c +106 -0
  188. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_4byte.c +98 -0
  189. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_5_1_byte.c +117 -0
  190. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_5byte.c +106 -0
  191. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_64byte.c +132 -0
  192. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_6_1_byte.c +121 -0
  193. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_6byte.c +107 -0
  194. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_7_1_byte.c +125 -0
  195. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_7byte.c +105 -0
  196. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_8byte.c +96 -0
  197. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_9byte1.c +98 -0
  198. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_9byte2.c +99 -0
  199. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_double.c +101 -0
  200. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_float.c +99 -0
  201. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_longdouble.c +100 -0
  202. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_pointer.c +101 -0
  203. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint16.c +99 -0
  204. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint32.c +99 -0
  205. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint64.c +99 -0
  206. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint16.c +99 -0
  207. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint32.c +99 -0
  208. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint64.c +100 -0
  209. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_double.c +51 -0
  210. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_float.c +51 -0
  211. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_schar.c +82 -0
  212. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_sshort.c +82 -0
  213. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_sshortchar.c +94 -0
  214. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_uchar.c +99 -0
  215. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_ushort.c +82 -0
  216. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_ushortchar.c +94 -0
  217. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_schar.c +52 -0
  218. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_sint.c +50 -0
  219. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_sshort.c +50 -0
  220. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uchar.c +50 -0
  221. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uint.c +51 -0
  222. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ulonglong.c +54 -0
  223. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ushort.c +51 -0
  224. data/ext/ffi_c/libffi/testsuite/libffi.call/ffitest.h +86 -0
  225. data/ext/ffi_c/libffi/testsuite/libffi.call/float.c +59 -0
  226. data/ext/ffi_c/libffi/testsuite/libffi.call/float1.c +58 -0
  227. data/ext/ffi_c/libffi/testsuite/libffi.call/float2.c +57 -0
  228. data/ext/ffi_c/libffi/testsuite/libffi.call/float3.c +72 -0
  229. data/ext/ffi_c/libffi/testsuite/libffi.call/float4.c +62 -0
  230. data/ext/ffi_c/libffi/testsuite/libffi.call/many.c +69 -0
  231. data/ext/ffi_c/libffi/testsuite/libffi.call/many_win32.c +63 -0
  232. data/ext/ffi_c/libffi/testsuite/libffi.call/negint.c +53 -0
  233. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct.c +160 -0
  234. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct1.c +169 -0
  235. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct10.c +141 -0
  236. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct2.c +118 -0
  237. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct3.c +119 -0
  238. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct4.c +119 -0
  239. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct5.c +120 -0
  240. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct6.c +139 -0
  241. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct7.c +119 -0
  242. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct8.c +139 -0
  243. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct9.c +139 -0
  244. data/ext/ffi_c/libffi/testsuite/libffi.call/problem1.c +98 -0
  245. data/ext/ffi_c/libffi/testsuite/libffi.call/promotion.c +59 -0
  246. data/ext/ffi_c/libffi/testsuite/libffi.call/pyobjc-tc.c +114 -0
  247. data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl.c +35 -0
  248. data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl1.c +43 -0
  249. data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl2.c +42 -0
  250. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl.c +35 -0
  251. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl1.c +36 -0
  252. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl2.c +49 -0
  253. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl3.c +42 -0
  254. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ldl.c +34 -0
  255. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll.c +41 -0
  256. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll1.c +42 -0
  257. data/ext/ffi_c/libffi/testsuite/libffi.call/return_sc.c +36 -0
  258. data/ext/ffi_c/libffi/testsuite/libffi.call/return_sl.c +38 -0
  259. data/ext/ffi_c/libffi/testsuite/libffi.call/return_uc.c +38 -0
  260. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ul.c +38 -0
  261. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen.c +44 -0
  262. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen_win32.c +44 -0
  263. data/ext/ffi_c/libffi/testsuite/libffi.call/struct1.c +65 -0
  264. data/ext/ffi_c/libffi/testsuite/libffi.call/struct2.c +67 -0
  265. data/ext/ffi_c/libffi/testsuite/libffi.call/struct3.c +59 -0
  266. data/ext/ffi_c/libffi/testsuite/libffi.call/struct4.c +63 -0
  267. data/ext/ffi_c/libffi/testsuite/libffi.call/struct5.c +65 -0
  268. data/ext/ffi_c/libffi/testsuite/libffi.call/struct6.c +64 -0
  269. data/ext/ffi_c/libffi/testsuite/libffi.call/struct7.c +74 -0
  270. data/ext/ffi_c/libffi/testsuite/libffi.call/struct8.c +80 -0
  271. data/ext/ffi_c/libffi/testsuite/libffi.call/struct9.c +67 -0
  272. data/ext/ffi_c/libffi/testsuite/libffi.special/ffitestcxx.h +86 -0
  273. data/ext/ffi_c/libffi/testsuite/libffi.special/special.exp +38 -0
  274. data/ext/ffi_c/libffi/testsuite/libffi.special/unwindtest.cc +123 -0
  275. data/ext/ffi_c/libffi/testsuite/libffi.special/unwindtest_ffi_call.cc +53 -0
  276. data/ext/ffi_c/libffi/texinfo.tex +7482 -0
  277. data/ext/ffi_c/rbffi.h +26 -0
  278. data/gen/Rakefile +12 -0
  279. data/lib/ffi.rb +11 -0
  280. data/lib/ffi/autopointer.rb +61 -0
  281. data/lib/ffi/buffer.rb +0 -0
  282. data/lib/ffi/callback.rb +10 -0
  283. data/lib/ffi/enum.rb +78 -0
  284. data/lib/ffi/errno.rb +8 -0
  285. data/lib/ffi/ffi.rb +99 -0
  286. data/lib/ffi/io.rb +21 -0
  287. data/lib/ffi/library.rb +218 -0
  288. data/lib/ffi/managedstruct.rb +55 -0
  289. data/lib/ffi/memorypointer.rb +73 -0
  290. data/lib/ffi/platform.rb +78 -0
  291. data/lib/ffi/pointer.rb +119 -0
  292. data/lib/ffi/struct.rb +164 -0
  293. data/lib/ffi/tools/const_generator.rb +177 -0
  294. data/lib/ffi/tools/generator.rb +58 -0
  295. data/lib/ffi/tools/generator_task.rb +35 -0
  296. data/lib/ffi/tools/struct_generator.rb +194 -0
  297. data/lib/ffi/tools/types_generator.rb +123 -0
  298. data/lib/ffi/types.rb +153 -0
  299. data/lib/ffi/union.rb +12 -0
  300. data/lib/ffi/variadic.rb +25 -0
  301. data/spec/ffi/bool_spec.rb +24 -0
  302. data/spec/ffi/buffer_spec.rb +202 -0
  303. data/spec/ffi/callback_spec.rb +591 -0
  304. data/spec/ffi/enum_spec.rb +164 -0
  305. data/spec/ffi/errno_spec.rb +13 -0
  306. data/spec/ffi/function_spec.rb +47 -0
  307. data/spec/ffi/library_spec.rb +144 -0
  308. data/spec/ffi/managed_struct_spec.rb +56 -0
  309. data/spec/ffi/number_spec.rb +231 -0
  310. data/spec/ffi/pointer_spec.rb +195 -0
  311. data/spec/ffi/rbx/attach_function_spec.rb +27 -0
  312. data/spec/ffi/rbx/memory_pointer_spec.rb +102 -0
  313. data/spec/ffi/rbx/spec_helper.rb +1 -0
  314. data/spec/ffi/rbx/struct_spec.rb +13 -0
  315. data/spec/ffi/spec_helper.rb +17 -0
  316. data/spec/ffi/string_spec.rb +103 -0
  317. data/spec/ffi/struct_callback_spec.rb +62 -0
  318. data/spec/ffi/struct_initialize_spec.rb +30 -0
  319. data/spec/ffi/struct_spec.rb +529 -0
  320. data/spec/ffi/typedef_spec.rb +48 -0
  321. data/spec/ffi/union_spec.rb +60 -0
  322. data/spec/ffi/variadic_spec.rb +84 -0
  323. data/spec/spec.opts +4 -0
  324. metadata +432 -0
@@ -0,0 +1,533 @@
1
+ This is ../libffi/doc/libffi.info, produced by makeinfo version 4.11
2
+ from ../libffi/doc/libffi.texi.
3
+
4
+ This manual is for Libffi, a portable foreign-function interface
5
+ library.
6
+
7
+ Copyright (C) 2008 Red Hat, Inc.
8
+
9
+ Permission is granted to copy, distribute and/or modify this
10
+ document under the terms of the GNU General Public License as
11
+ published by the Free Software Foundation; either version 2, or
12
+ (at your option) any later version. A copy of the license is
13
+ included in the section entitled "GNU General Public License".
14
+
15
+
16
+ INFO-DIR-SECTION
17
+ START-INFO-DIR-ENTRY
18
+ * libffi: (libffi). Portable foreign-function interface library.
19
+ END-INFO-DIR-ENTRY
20
+
21
+ 
22
+ File: libffi.info, Node: Top, Next: Introduction, Up: (dir)
23
+
24
+ libffi
25
+ ******
26
+
27
+ This manual is for Libffi, a portable foreign-function interface
28
+ library.
29
+
30
+ Copyright (C) 2008 Red Hat, Inc.
31
+
32
+ Permission is granted to copy, distribute and/or modify this
33
+ document under the terms of the GNU General Public License as
34
+ published by the Free Software Foundation; either version 2, or
35
+ (at your option) any later version. A copy of the license is
36
+ included in the section entitled "GNU General Public License".
37
+
38
+
39
+ * Menu:
40
+
41
+ * Introduction:: What is libffi?
42
+ * Using libffi:: How to use libffi.
43
+ * Missing Features:: Things libffi can't do.
44
+ * Index:: Index.
45
+
46
+ 
47
+ File: libffi.info, Node: Introduction, Next: Using libffi, Prev: Top, Up: Top
48
+
49
+ 1 What is libffi?
50
+ *****************
51
+
52
+ Compilers for high level languages generate code that follow certain
53
+ conventions. These conventions are necessary, in part, for separate
54
+ compilation to work. One such convention is the "calling convention".
55
+ The calling convention is a set of assumptions made by the compiler
56
+ about where function arguments will be found on entry to a function. A
57
+ calling convention also specifies where the return value for a function
58
+ is found. The calling convention is also sometimes called the "ABI" or
59
+ "Application Binary Interface".
60
+
61
+ Some programs may not know at the time of compilation what arguments
62
+ are to be passed to a function. For instance, an interpreter may be
63
+ told at run-time about the number and types of arguments used to call a
64
+ given function. `Libffi' can be used in such programs to provide a
65
+ bridge from the interpreter program to compiled code.
66
+
67
+ The `libffi' library provides a portable, high level programming
68
+ interface to various calling conventions. This allows a programmer to
69
+ call any function specified by a call interface description at run time.
70
+
71
+ FFI stands for Foreign Function Interface. A foreign function
72
+ interface is the popular name for the interface that allows code
73
+ written in one language to call code written in another language. The
74
+ `libffi' library really only provides the lowest, machine dependent
75
+ layer of a fully featured foreign function interface. A layer must
76
+ exist above `libffi' that handles type conversions for values passed
77
+ between the two languages.
78
+
79
+ 
80
+ File: libffi.info, Node: Using libffi, Next: Missing Features, Prev: Introduction, Up: Top
81
+
82
+ 2 Using libffi
83
+ **************
84
+
85
+ * Menu:
86
+
87
+ * The Basics:: The basic libffi API.
88
+ * Simple Example:: A simple example.
89
+ * Types:: libffi type descriptions.
90
+ * Multiple ABIs:: Different passing styles on one platform.
91
+ * The Closure API:: Writing a generic function.
92
+
93
+ 
94
+ File: libffi.info, Node: The Basics, Next: Simple Example, Up: Using libffi
95
+
96
+ 2.1 The Basics
97
+ ==============
98
+
99
+ `Libffi' assumes that you have a pointer to the function you wish to
100
+ call and that you know the number and types of arguments to pass it, as
101
+ well as the return type of the function.
102
+
103
+ The first thing you must do is create an `ffi_cif' object that
104
+ matches the signature of the function you wish to call. This is a
105
+ separate step because it is common to make multiple calls using a
106
+ single `ffi_cif'. The "cif" in `ffi_cif' stands for Call InterFace.
107
+ To prepare a call interface object, use the function `ffi_prep_cif'.
108
+
109
+ -- Function: ffi_status ffi_prep_cif (ffi_cif *CIF, ffi_abi ABI,
110
+ unsigned int NARGS, ffi_type *RTYPE, ffi_type **ARGTYPES)
111
+ This initializes CIF according to the given parameters.
112
+
113
+ ABI is the ABI to use; normally `FFI_DEFAULT_ABI' is what you
114
+ want. *note Multiple ABIs:: for more information.
115
+
116
+ NARGS is the number of arguments that this function accepts.
117
+ `libffi' does not yet handle varargs functions; see *note Missing
118
+ Features:: for more information.
119
+
120
+ RTYPE is a pointer to an `ffi_type' structure that describes the
121
+ return type of the function. *Note Types::.
122
+
123
+ ARGTYPES is a vector of `ffi_type' pointers. ARGTYPES must have
124
+ NARGS elements. If NARGS is 0, this argument is ignored.
125
+
126
+ `ffi_prep_cif' returns a `libffi' status code, of type
127
+ `ffi_status'. This will be either `FFI_OK' if everything worked
128
+ properly; `FFI_BAD_TYPEDEF' if one of the `ffi_type' objects is
129
+ incorrect; or `FFI_BAD_ABI' if the ABI parameter is invalid.
130
+
131
+ To call a function using an initialized `ffi_cif', use the
132
+ `ffi_call' function:
133
+
134
+ -- Function: void ffi_call (ffi_cif *CIF, void *FN, void *RVALUE, void
135
+ **AVALUES)
136
+ This calls the function FN according to the description given in
137
+ CIF. CIF must have already been prepared using `ffi_prep_cif'.
138
+
139
+ RVALUE is a pointer to a chunk of memory that will hold the result
140
+ of the function call. This must be large enough to hold the
141
+ result and must be suitably aligned; it is the caller's
142
+ responsibility to ensure this. If CIF declares that the function
143
+ returns `void' (using `ffi_type_void'), then RVALUE is ignored.
144
+ If RVALUE is `NULL', then the return value is discarded.
145
+
146
+ AVALUES is a vector of `void *' pointers that point to the memory
147
+ locations holding the argument values for a call. If CIF declares
148
+ that the function has no arguments (i.e., NARGS was 0), then
149
+ AVALUES is ignored.
150
+
151
+ 
152
+ File: libffi.info, Node: Simple Example, Next: Types, Prev: The Basics, Up: Using libffi
153
+
154
+ 2.2 Simple Example
155
+ ==================
156
+
157
+ Here is a trivial example that calls `puts' a few times.
158
+
159
+ #include <stdio.h>
160
+ #include <ffi.h>
161
+
162
+ int main()
163
+ {
164
+ ffi_cif cif;
165
+ ffi_type *args[1];
166
+ void *values[1];
167
+ char *s;
168
+ int rc;
169
+
170
+ /* Initialize the argument info vectors */
171
+ args[0] = &ffi_type_pointer;
172
+ values[0] = &s;
173
+
174
+ /* Initialize the cif */
175
+ if (ffi_prep_cif(&cif, FFI_DEFAULT_ABI, 1,
176
+ &ffi_type_uint, args) == FFI_OK)
177
+ {
178
+ s = "Hello World!";
179
+ ffi_call(&cif, puts, &rc, values);
180
+ /* rc now holds the result of the call to puts */
181
+
182
+ /* values holds a pointer to the function's arg, so to
183
+ call puts() again all we need to do is change the
184
+ value of s */
185
+ s = "This is cool!";
186
+ ffi_call(&cif, puts, &rc, values);
187
+ }
188
+
189
+ return 0;
190
+ }
191
+
192
+ 
193
+ File: libffi.info, Node: Types, Next: Multiple ABIs, Prev: Simple Example, Up: Using libffi
194
+
195
+ 2.3 Types
196
+ =========
197
+
198
+ * Menu:
199
+
200
+ * Primitive Types:: Built-in types.
201
+ * Structures:: Structure types.
202
+ * Type Example:: Structure type example.
203
+
204
+ 
205
+ File: libffi.info, Node: Primitive Types, Next: Structures, Up: Types
206
+
207
+ 2.3.1 Primitive Types
208
+ ---------------------
209
+
210
+ `Libffi' provides a number of built-in type descriptors that can be
211
+ used to describe argument and return types:
212
+
213
+ `ffi_type_void'
214
+ The type `void'. This cannot be used for argument types, only for
215
+ return values.
216
+
217
+ `ffi_type_uint8'
218
+ An unsigned, 8-bit integer type.
219
+
220
+ `ffi_type_sint8'
221
+ A signed, 8-bit integer type.
222
+
223
+ `ffi_type_uint16'
224
+ An unsigned, 16-bit integer type.
225
+
226
+ `ffi_type_sint16'
227
+ A signed, 16-bit integer type.
228
+
229
+ `ffi_type_uint32'
230
+ An unsigned, 32-bit integer type.
231
+
232
+ `ffi_type_sint32'
233
+ A signed, 32-bit integer type.
234
+
235
+ `ffi_type_uint64'
236
+ An unsigned, 64-bit integer type.
237
+
238
+ `ffi_type_sint64'
239
+ A signed, 64-bit integer type.
240
+
241
+ `ffi_type_float'
242
+ The C `float' type.
243
+
244
+ `ffi_type_double'
245
+ The C `double' type.
246
+
247
+ `ffi_type_uchar'
248
+ The C `unsigned char' type.
249
+
250
+ `ffi_type_schar'
251
+ The C `signed char' type. (Note that there is not an exact
252
+ equivalent to the C `char' type in `libffi'; ordinarily you should
253
+ either use `ffi_type_schar' or `ffi_type_uchar' depending on
254
+ whether `char' is signed.)
255
+
256
+ `ffi_type_ushort'
257
+ The C `unsigned short' type.
258
+
259
+ `ffi_type_sshort'
260
+ The C `short' type.
261
+
262
+ `ffi_type_uint'
263
+ The C `unsigned int' type.
264
+
265
+ `ffi_type_sint'
266
+ The C `int' type.
267
+
268
+ `ffi_type_ulong'
269
+ The C `unsigned long' type.
270
+
271
+ `ffi_type_slong'
272
+ The C `long' type.
273
+
274
+ `ffi_type_longdouble'
275
+ On platforms that have a C `long double' type, this is defined.
276
+ On other platforms, it is not.
277
+
278
+ `ffi_type_pointer'
279
+ A generic `void *' pointer. You should use this for all pointers,
280
+ regardless of their real type.
281
+
282
+ Each of these is of type `ffi_type', so you must take the address
283
+ when passing to `ffi_prep_cif'.
284
+
285
+ 
286
+ File: libffi.info, Node: Structures, Next: Type Example, Prev: Primitive Types, Up: Types
287
+
288
+ 2.3.2 Structures
289
+ ----------------
290
+
291
+ Although `libffi' has no special support for unions or bit-fields, it
292
+ is perfectly happy passing structures back and forth. You must first
293
+ describe the structure to `libffi' by creating a new `ffi_type' object
294
+ for it.
295
+
296
+ -- ffi_type:
297
+ The `ffi_type' has the following members:
298
+ `size_t size'
299
+ This is set by `libffi'; you should initialize it to zero.
300
+
301
+ `unsigned short alignment'
302
+ This is set by `libffi'; you should initialize it to zero.
303
+
304
+ `unsigned short type'
305
+ For a structure, this should be set to `FFI_TYPE_STRUCT'.
306
+
307
+ `ffi_type **elements'
308
+ This is a `NULL'-terminated array of pointers to `ffi_type'
309
+ objects. There is one element per field of the struct.
310
+
311
+ 
312
+ File: libffi.info, Node: Type Example, Prev: Structures, Up: Types
313
+
314
+ 2.3.3 Type Example
315
+ ------------------
316
+
317
+ The following example initializes a `ffi_type' object representing the
318
+ `tm' struct from Linux's `time.h'.
319
+
320
+ Here is how the struct is defined:
321
+
322
+ struct tm {
323
+ int tm_sec;
324
+ int tm_min;
325
+ int tm_hour;
326
+ int tm_mday;
327
+ int tm_mon;
328
+ int tm_year;
329
+ int tm_wday;
330
+ int tm_yday;
331
+ int tm_isdst;
332
+ /* Those are for future use. */
333
+ long int __tm_gmtoff__;
334
+ __const char *__tm_zone__;
335
+ };
336
+
337
+ Here is the corresponding code to describe this struct to `libffi':
338
+
339
+ {
340
+ ffi_type tm_type;
341
+ ffi_type *tm_type_elements[12];
342
+ int i;
343
+
344
+ tm_type.size = tm_type.alignment = 0;
345
+ tm_type.elements = &tm_type_elements;
346
+
347
+ for (i = 0; i < 9; i++)
348
+ tm_type_elements[i] = &ffi_type_sint;
349
+
350
+ tm_type_elements[9] = &ffi_type_slong;
351
+ tm_type_elements[10] = &ffi_type_pointer;
352
+ tm_type_elements[11] = NULL;
353
+
354
+ /* tm_type can now be used to represent tm argument types and
355
+ return types for ffi_prep_cif() */
356
+ }
357
+
358
+ 
359
+ File: libffi.info, Node: Multiple ABIs, Next: The Closure API, Prev: Types, Up: Using libffi
360
+
361
+ 2.4 Multiple ABIs
362
+ =================
363
+
364
+ A given platform may provide multiple different ABIs at once. For
365
+ instance, the x86 platform has both `stdcall' and `fastcall' functions.
366
+
367
+ `libffi' provides some support for this. However, this is
368
+ necessarily platform-specific.
369
+
370
+ 
371
+ File: libffi.info, Node: The Closure API, Prev: Multiple ABIs, Up: Using libffi
372
+
373
+ 2.5 The Closure API
374
+ ===================
375
+
376
+ `libffi' also provides a way to write a generic function - a function
377
+ that can accept and decode any combination of arguments. This can be
378
+ useful when writing an interpreter, or to provide wrappers for
379
+ arbitrary functions.
380
+
381
+ This facility is called the "closure API". Closures are not
382
+ supported on all platforms; you can check the `FFI_CLOSURES' define to
383
+ determine whether they are supported on the current platform.
384
+
385
+ Because closures work by assembling a tiny function at runtime, they
386
+ require special allocation on platforms that have a non-executable
387
+ heap. Memory management for closures is handled by a pair of functions:
388
+
389
+ -- Function: void *ffi_closure_alloc (size_t SIZE, void **CODE)
390
+ Allocate a chunk of memory holding SIZE bytes. This returns a
391
+ pointer to the writable address, and sets *CODE to the
392
+ corresponding executable address.
393
+
394
+ SIZE should be sufficient to hold a `ffi_closure' object.
395
+
396
+ -- Function: void ffi_closure_free (void *WRITABLE)
397
+ Free memory allocated using `ffi_closure_alloc'. The argument is
398
+ the writable address that was returned.
399
+
400
+ Once you have allocated the memory for a closure, you must construct
401
+ a `ffi_cif' describing the function call. Finally you can prepare the
402
+ closure function:
403
+
404
+ -- Function: ffi_status ffi_prep_closure_loc (ffi_closure *CLOSURE,
405
+ ffi_cif *CIF, void (*FUN) (ffi_cif *CIF, void *RET, void
406
+ **ARGS, void *USER_DATA), void *USER_DATA, void *CODELOC)
407
+ Prepare a closure function.
408
+
409
+ CLOSURE is the address of a `ffi_closure' object; this is the
410
+ writable address returned by `ffi_closure_alloc'.
411
+
412
+ CIF is the `ffi_cif' describing the function parameters.
413
+
414
+ USER_DATA is an arbitrary datum that is passed, uninterpreted, to
415
+ your closure function.
416
+
417
+ CODELOC is the executable address returned by `ffi_closure_alloc'.
418
+
419
+ FUN is the function which will be called when the closure is
420
+ invoked. It is called with the arguments:
421
+ CIF
422
+ The `ffi_cif' passed to `ffi_prep_closure_loc'.
423
+
424
+ RET
425
+ A pointer to the memory used for the function's return value.
426
+ FUN must fill this, unless the function is declared as
427
+ returning `void'.
428
+
429
+ ARGS
430
+ A vector of pointers to memory holding the arguments to the
431
+ function.
432
+
433
+ USER_DATA
434
+ The same USER_DATA that was passed to `ffi_prep_closure_loc'.
435
+
436
+ `ffi_prep_closure_loc' will return `FFI_OK' if everything went ok,
437
+ and something else on error.
438
+
439
+ After calling `ffi_prep_closure_loc', you can cast CODELOC to the
440
+ appropriate pointer-to-function type.
441
+
442
+ You may see old code referring to `ffi_prep_closure'. This function
443
+ is deprecated, as it cannot handle the need for separate writable and
444
+ executable addresses.
445
+
446
+ 
447
+ File: libffi.info, Node: Missing Features, Next: Index, Prev: Using libffi, Up: Top
448
+
449
+ 3 Missing Features
450
+ ******************
451
+
452
+ `libffi' is missing a few features. We welcome patches to add support
453
+ for these.
454
+
455
+ * There is no support for calling varargs functions. This may work
456
+ on some platforms, depending on how the ABI is defined, but it is
457
+ not reliable.
458
+
459
+ * There is no support for bit fields in structures.
460
+
461
+ * The closure API is
462
+
463
+ * The "raw" API is undocumented.
464
+
465
+ 
466
+ File: libffi.info, Node: Index, Prev: Missing Features, Up: Top
467
+
468
+ Index
469
+ *****
470
+
471
+ [index]
472
+ * Menu:
473
+
474
+ * : Structures. (line 12)
475
+ * ABI: Introduction. (line 13)
476
+ * Application Binary Interface: Introduction. (line 13)
477
+ * calling convention: Introduction. (line 13)
478
+ * cif: The Basics. (line 14)
479
+ * closure API: The Closure API. (line 13)
480
+ * closures: The Closure API. (line 13)
481
+ * FFI: Introduction. (line 31)
482
+ * ffi_call: The Basics. (line 41)
483
+ * ffi_closure_alloca: The Closure API. (line 19)
484
+ * ffi_closure_free: The Closure API. (line 26)
485
+ * FFI_CLOSURES: The Closure API. (line 13)
486
+ * ffi_prep_cif: The Basics. (line 16)
487
+ * ffi_prep_closure_loc: The Closure API. (line 34)
488
+ * ffi_status <1>: The Closure API. (line 37)
489
+ * ffi_status: The Basics. (line 18)
490
+ * ffi_type: Structures. (line 11)
491
+ * ffi_type_double: Primitive Types. (line 41)
492
+ * ffi_type_float: Primitive Types. (line 38)
493
+ * ffi_type_longdouble: Primitive Types. (line 71)
494
+ * ffi_type_pointer: Primitive Types. (line 75)
495
+ * ffi_type_schar: Primitive Types. (line 47)
496
+ * ffi_type_sint: Primitive Types. (line 62)
497
+ * ffi_type_sint16: Primitive Types. (line 23)
498
+ * ffi_type_sint32: Primitive Types. (line 29)
499
+ * ffi_type_sint64: Primitive Types. (line 35)
500
+ * ffi_type_sint8: Primitive Types. (line 17)
501
+ * ffi_type_slong: Primitive Types. (line 68)
502
+ * ffi_type_sshort: Primitive Types. (line 56)
503
+ * ffi_type_uchar: Primitive Types. (line 44)
504
+ * ffi_type_uint: Primitive Types. (line 59)
505
+ * ffi_type_uint16: Primitive Types. (line 20)
506
+ * ffi_type_uint32: Primitive Types. (line 26)
507
+ * ffi_type_uint64: Primitive Types. (line 32)
508
+ * ffi_type_uint8: Primitive Types. (line 14)
509
+ * ffi_type_ulong: Primitive Types. (line 65)
510
+ * ffi_type_ushort: Primitive Types. (line 53)
511
+ * ffi_type_void: Primitive Types. (line 10)
512
+ * Foreign Function Interface: Introduction. (line 31)
513
+ * void <1>: The Closure API. (line 20)
514
+ * void: The Basics. (line 43)
515
+
516
+
517
+ 
518
+ Tag Table:
519
+ Node: Top688
520
+ Node: Introduction1424
521
+ Node: Using libffi3060
522
+ Node: The Basics3495
523
+ Node: Simple Example6102
524
+ Node: Types7129
525
+ Node: Primitive Types7412
526
+ Node: Structures9232
527
+ Node: Type Example10092
528
+ Node: Multiple ABIs11315
529
+ Node: The Closure API11686
530
+ Node: Missing Features14606
531
+ Node: Index15099
532
+ 
533
+ End Tag Table