package ctypes-foreign

  1. Overview
  2. Docs
Dynamic access to foreign C libraries using Ctypes

Install

Dune Dependency

Authors

Maintainers

Sources

0.21.1.tar.gz
sha256=6f2b3b0f26c202b75ed7df3867fd9580d3e592af4944875b92ec0ee3ca7e14ff
md5=8b201d932741c5096854e5eb39139b90

Description

This installs the ctypes-foreign interface which uses libffi to provide dynamic access to foreign libraries.

Tags

org:mirage

Published: 21 Jul 2023

README

README.md

ctypes is a library for binding to C libraries using pure OCaml. The primary aim is to make writing C extensions as straightforward as possible.

The core of ctypes is a set of combinators for describing the structure of C types -- numeric types, arrays, pointers, structs, unions and functions. You can use these combinators to describe the types of the functions that you want to call, then bind directly to those functions -- all without writing or generating any C!

Usage

Suppose you want to bind to the following C functions:

   int sigemptyset(sigset_t *set);
   int sigfillset(sigset_t *set);
   int sigaddset(sigset_t *set, int signum);
   int sigdelset(sigset_t *set, int signum);
   int sigismember(const sigset_t *set, int signum);

Using ctypes you can describe the interfaces to these functions as follows:

   let sigemptyset = foreign "sigemptyset" (ptr sigset_t @-> returning int)
   let sigfillset = foreign "sigfillset" (ptr sigset_t @-> returning int)
   let sigaddset = foreign "sigaddset" (ptr sigset_t @-> int @-> returning int)
   let sigdelset = foreign "sigdelset" (ptr sigset_t @-> int @-> returning int)
   let sigismember = foreign "sigismember" (ptr sigset_t @-> int @-> returning int)

The names bound by this code have the types you might expect:

   val sigemptyset : sigset_t ptr -> int
   val sigfillset : sigset_t ptr -> int
   val sigaddset : sigset_t ptr -> int -> int
   val sigdelset : sigset_t ptr -> int -> int
   val sigismember : sigset_t ptr -> int -> int

That's all there is to it. Unlike the usual way of writing C extensions, there are no C "stub" functions to write, so there's much less opportunity for error.

The documentation and source distribution contain more complex examples, involving structs, unions, arrays, callback functions, and so on, and show how to create and use C values (like instances of sigset_t ptr) in OCaml.

Links

Dependencies (6)

  1. conf-libffi >= "2.0.0"
  2. conf-pkg-config
  3. dune-configurator
  4. ctypes = version
  5. ocaml >= "4.03.0"
  6. dune >= "2.9"

Dev Dependencies (7)

  1. odoc with-doc
  2. conf-fts with-test & os != "win32"
  3. stdlib-shims with-test
  4. conf-ncurses with-test
  5. ounit2 with-test
  6. lwt with-test & >= "2.4.7"
  7. integers with-test & >= "0.2.2"

Used by (94)

  1. arakoon >= "1.8.6" & < "1.8.12"
  2. argon2
  3. arrayjit < "0.4.1"
  4. async_ssl != "112.24.02" & < "113.33.05" | >= "v0.10.0"
  5. avroc
  6. bimage-unix
  7. bls12-381 = "0.3.15"
  8. bls12-381-legacy < "0.4.4"
  9. bls12-381-unix < "1.0.2"
  10. cf
  11. checked_oint
  12. cmark
  13. cmarker
  14. ctypes >= "0.7.0" & < "0.21.1"
  15. ctypes-zarith
  16. cudajit
  17. directories < "0.3"
  18. extism < "1.1.0"
  19. flock
  20. gccjit
  21. gdal >= "0.3.0"
  22. gobject-introspection
  23. gpiod
  24. gr
  25. gsasl
  26. guile
  27. hacl-star-raw < "0.4.4"
  28. hardcaml-llvmsim
  29. hardcaml-vpi
  30. hardcaml_c
  31. hardcaml_verilator
  32. hdr_histogram
  33. imguiml
  34. iocaml >= "0.4.3"
  35. iocaml-kernel >= "0.4.4"
  36. libdash
  37. libirmin
  38. libudev
  39. lilv
  40. llama-cpp-ocaml
  41. lmdb < "1.0"
  42. lp-glpk < "0.4.0"
  43. lp-gurobi
  44. mariadb < "1.1.4"
  45. memtrace_viewer < "v0.15.0"
  46. mmdb
  47. mpg123
  48. nanomsg
  49. nebula
  50. netlink >= "0.2.1"
  51. ocephes >= "0.8.1"
  52. octez-l2-libs
  53. opasswd >= "0.9.3"
  54. opencc < "transition"
  55. opencc0
  56. opencc1
  57. opencc1_1
  58. orocksdb
  59. osbx < "1.1.1"
  60. osx-cf
  61. osx-secure-transport
  62. pari
  63. pari-bindings
  64. pg_query
  65. pkcs11 < "0.9.0"
  66. pkcs11-driver
  67. pkcs11-rev
  68. portaudio_c_bindings
  69. portmidi
  70. posix-getopt < "2.0.0"
  71. py
  72. qcstm >= "0.1.1"
  73. reed-solomon-erasure
  74. sarek >= "20210823"
  75. sattools
  76. sodium >= "0.2.0" & < "0.3.0"
  77. spoc >= "20170724"
  78. srt >= "0.2.2"
  79. stk_iconv
  80. swipl
  81. tensorflow
  82. tezos-sapling >= "10.2" & < "13.0"
  83. tezos-wasmer
  84. tgls >= "0.8.3"
  85. torch
  86. tsdl >= "0.8.1"
  87. tsdl-image
  88. tsdl-mixer
  89. tsdl-ttf
  90. unix-type-representations < "0.1.1"
  91. wasmer
  92. wasmtime
  93. yara
  94. yices2_bindings

Conflicts

None

OCaml

Innovation. Community. Security.