miqt/cmd/genbindings
2024-08-25 16:06:16 +12:00
..
cachedir
clang2il_test.go genbindings: use state machine tokenization for template parameters 2024-08-19 19:11:19 +12:00
clang2il.go genbindings: skip return types for more operator= overloads 2024-08-25 15:32:16 +12:00
clangexec.go
emitcabi.go genbindings: assorted pointer correctness fixes 2024-08-25 15:31:51 +12:00
emitgo.go genbindings: block use of binding-reserved word 'ret' 2024-08-25 15:32:08 +12:00
exceptions.go genbindings: more exceptions 2024-08-24 11:46:51 +12:00
intermediate.go genbindings: fixes for integer types 2024-08-25 15:31:21 +12:00
main.go genbindings: scan full qt include directory to find header files 2024-08-19 19:14:47 +12:00
README.md doc/README: update readme files 2024-08-25 16:06:16 +12:00
transformoptional.go genbindings: support optional parameters for ctors 2024-08-25 12:50:48 +12:00
transformoverload.go genbindings/transform: overload disambiguation must be based on go names 2024-08-22 19:20:15 +12:00
util.go

genbindings

The genbindings program regenerates the qt bindings.

Archicture design

Bindings are generated as follows:

  1. Scan input directory for header files.
  2. For each header file:
  3. Run clang --ast-dump=json to get a JSON ast.
    • This is somewhat slow, the results will be cached in ./cachedir after the first run.
  4. Convert Clang AST to our own intermediate representation.
  5. Emit CABI cpp/h pair.
    • The CABI is a projection of Qt into plain C. The translation unit itself is C++, but the header can be used as extern c.
  6. Emit Go binding file.

Configuration

It's tested to work on with Debian 12 / Qt 5.15 / Clang 14 / GCC 12.

You should check the following configuration:

  • Input directories containing Qt headers
  • All of exceptions.go