package ctypes

  1. Overview
  2. Docs
Combinators for binding to C libraries without writing any C

Install

Dune Dependency

Authors

Maintainers

Sources

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

Description

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!

To install the optional ctypes-foreign interface (which uses libffi to provide dynamic access to foreign libraries), you will need to also install the ctypes-foreign package.

opam install ctypes-foreign

This will make the ctypes-foreign ocamlfind subpackage available.

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 (5)

  1. bigarray-compat
  2. dune-configurator
  3. integers
  4. ocaml >= "4.03.0" & < "5.2"
  5. dune >= "2.9"

Dev Dependencies (4)

  1. odoc with-doc
  2. conf-pkg-config with-test
  3. conf-fts with-test & os != "win32"
  4. ounit2 with-test

  1. ahrocksdb
  2. antic < "0.4.0"
  3. arakoon >= "1.8.6" & < "1.8.12"
  4. arb < "0.4.0"
  5. argon2
  6. arrayjit
  7. async_ssl >= "v0.15.0"
  8. avroc
  9. bimage-unix
  10. bitgenerators
  11. calcium < "0.4.0"
  12. cf
  13. checked_oint
  14. cmark
  15. cmarker
  16. ctypes-build
  17. ctypes-foreign = "0.21.1"
  18. ctypes-zarith
  19. ctypes_stubs_js
  20. decompress >= "1.3.0" & < "1.5.3"
  21. directories
  22. dlm >= "0.3.3"
  23. eigen >= "0.1.4"
  24. eris
  25. extism < "1.1.0"
  26. flint
  27. fsevents
  28. gccjit
  29. gdal >= "0.10.0"
  30. gobject-introspection
  31. gpiod
  32. gr
  33. guile
  34. hardcaml-llvmsim >= "0.3.0"
  35. hardcaml-vpi
  36. hardcaml_c
  37. hardcaml_verilator
  38. hdr_histogram
  39. imguiml
  40. iocaml-kernel >= "0.4.4"
  41. kqueue < "0.2.0"
  42. libdash >= "0.3"
  43. libirmin
  44. libudev < "0.2.1"
  45. lilv
  46. llama-cpp-ocaml
  47. llvm >= "3.7"
  48. lp-glpk
  49. lp-gurobi
  50. luv
  51. luv_unix
  52. lz4 >= "1.3.0"
  53. mariadb >= "1.1.2" & < "1.1.5"
  54. memcpy >= "0.2.2"
  55. mmdb
  56. monocypher
  57. mpg123
  58. nanomsg
  59. nebula
  60. netlink >= "0.3.4"
  61. octez-l2-libs
  62. octez-libs
  63. opasswd >= "1.3.1"
  64. opencc < "transition"
  65. opencc0
  66. opencc1
  67. opencc1_1
  68. orocksdb
  69. osbx < "1.1.1"
  70. osx-acl
  71. osx-attr >= "0.2.0"
  72. osx-cf >= "0.1.1"
  73. osx-fsevents >= "0.1.1"
  74. osx-membership
  75. osx-mount >= "0.1.1"
  76. osx-secure-transport
  77. osx-xattr >= "0.3.0"
  78. owl >= "0.9.0"
  79. pari
  80. pari-bindings
  81. pci < "1.0.1"
  82. pg_query
  83. pkcs11-driver
  84. pkcs11-rev
  85. portaudio_c_bindings
  86. portmidi
  87. posix-base
  88. posix-bindings
  89. posix-getopt >= "2.0.0"
  90. posix-signal
  91. posix-socket
  92. posix-socket-unix
  93. posix-time2
  94. posix-types
  95. posix-uname
  96. ppx_cstubs >= "0.7.0"
  97. protocol-9p < "0.5.1"
  98. py >= "1.1"
  99. quickjs
  100. raygui
  101. raylib
  102. reed-solomon-erasure
  103. rfc1951 >= "1.3.0"
  104. sanlock
  105. sarek >= "20210823"
  106. sattools
  107. sodium >= "0.2.0" & < "0.3.0"
  108. spin >= "0.8.0"
  109. spoc >= "20170724"
  110. srt
  111. stk_iconv
  112. swipl
  113. sys-socket
  114. sys-socket-unix
  115. tensorflow
  116. tezos-hacl
  117. tezos-hacl-glue-unix < "11.0"
  118. tezos-sapling >= "11.1"
  119. tezos-wasmer
  120. tgls = "0.8.3"
  121. torch
  122. tsdl >= "0.8.1" & < "0.9.1" | >= "1.0.0"
  123. tsdl-image >= "0.3.0"
  124. tsdl-mixer
  125. tsdl-ttf >= "0.3"
  126. unix-errno >= "0.4.1" & < "0.5.0" | >= "0.6.2"
  127. unix-fcntl >= "0.3.3"
  128. unix-sys-resource
  129. unix-sys-stat
  130. unix-time
  131. unix-type-representations >= "0.1.1"
  132. wasmer
  133. wasmtime
  134. xedbindings
  135. xxhash
  136. yaml
  137. yara
  138. yices2_bindings
  139. zstandard
  140. zstd >= "0.4"

Conflicts

None

OCaml

Innovation. Community. Security.