Skip to main content

Generate Python ctypes bindings from shared libraries

Project description

dwarfbind

Generate Python ctypes bindings from shared libraries.

A tool to help generate Python ctypes bindings from shared libraries. It reads DWARF debug information from library files to understand C structures and types, then generates equivalent Python classes.

Features

  • Reads DWARF debug information to understand C types and structures
  • Generates Python ctypes classes that match the C structures
  • Handles complex type relationships and dependencies
  • Creates proper Python modules with types, symbols, and constants submodules
  • Provides clean imports like from mylib.types import MyStruct
  • Extracts constants and macros from header files
  • Automatically discovers library paths using pkg-config
  • Supports relative header paths (e.g., freerdp/freerdp.h with -I /usr/include/freerdp3)

Requirements

  • Python 3.12 or newer
  • Debug symbols for the libraries you want to analyze:
    # Install debug symbols for a specific package
    sudo dnf debuginfo-install libfreerdp3
    
    # Or enable debuginfo repos and install manually
    sudo dnf install 'dnf-command(debuginfo-install)'
    sudo dnf debuginfo-install libfreerdp3
    
  • C preprocessor (cpp) for header file analysis:
    # Install gcc which includes cpp
    sudo dnf install gcc
    
  • pkg-config for library and include path discovery:
    # Install pkg-config
    sudo dnf install pkgconf-pkg-config
    

Installation

Usage

Generate bindings for a shared library:

# Basic usage
dwarfbind /usr/lib/libexample.so

# Extract constants from headers
dwarfbind --headers example.h /usr/lib/libexample.so

# Add include paths for header processing
dwarfbind -I /usr/include -I /usr/local/include --headers example.h /usr/lib/libexample.so

# Specify output file
dwarfbind -o bindings.py /usr/lib/libexample.so

# Process multiple libraries at once
dwarfbind -o output/ libone.so libtwo.so

# Use pkg-config to find library and include paths
dwarfbind --pkgconfig freerdp3 --headers freerdp/freerdp.h

# Enable verbose output
dwarfbind -v /usr/lib/libexample.so

The generated bindings provide a clean Python API:

from ctypes import *
from example.types import MyStruct
from example.symbols import my_function
from example.constants import BUFFER_SIZE

# Create and use structures
structure = MyStruct()
structure.field = BUFFER_SIZE

# Call library functions
my_function.argtypes = [POINTER(MyStruct)]
my_function.restype = c_int
result = my_function(byref(structure))

Development

To set up a development environment:

# Install Python 3.12 or newer
uv python install 3.12
# Optional: install shims for python/python3
uv python install --default

# Create a virtual environment
uv venv -p 3.12
# Optional: activate the environment
source .venv/bin/activate

# Sync dependencies (including dev tools)
uv sync

# Run tests
uv run pytest

Contributing

Contributions are welcome! Please feel free to submit a Pull Request. See CONTRIBUTING.md for development setup, workflow guidelines, and coding style.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dwarfbind-0.1.2.tar.gz (61.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

dwarfbind-0.1.2-py3-none-any.whl (45.0 kB view details)

Uploaded Python 3

File details

Details for the file dwarfbind-0.1.2.tar.gz.

File metadata

  • Download URL: dwarfbind-0.1.2.tar.gz
  • Upload date:
  • Size: 61.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.8.11

File hashes

Hashes for dwarfbind-0.1.2.tar.gz
Algorithm Hash digest
SHA256 49f2c33baee005998668e274543f90200e37b571ac5398d711fb480f8696b86f
MD5 26b5c39c59aa7536adcf63287938261f
BLAKE2b-256 ccde5d37a3c46ce10d7e017e1aafaf15bb53ef12aad8c397d4783cce411a6f6e

See more details on using hashes here.

File details

Details for the file dwarfbind-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: dwarfbind-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 45.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.8.11

File hashes

Hashes for dwarfbind-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 68e998c07a83fc87a9f4cd9dd665a1fe0a25432842b1eaaab490e8f3da2aff31
MD5 d985b30e855fbe482cbaf9aacbe80e84
BLAKE2b-256 8ab6a54611343aa8417596b8802d4838c3793d28a335b48831421f9c855c4f78

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page