boltffi_bindgen 0.24.1

Code generation library for BoltFFI - generates Swift, Kotlin, and TypeScript bindings
Documentation
from __future__ import annotations
{% if module.uses_records() %}

from dataclasses import dataclass
{% endif %}
{% if module.uses_c_style_enums() %}

from enum import IntEnum
{% endif %}
{% if module.uses_sequence_parameter_annotations() %}

from collections.abc import Sequence
{% endif %}

MODULE_NAME: str
PACKAGE_NAME: str
PACKAGE_VERSION: str | None
{% if module.uses_records() %}

{% for record in module.records %}
@dataclass(frozen=True, slots=True)
class {{ record.class_name() }}:
{% for field in record.fields.iter() %}
    {{ field.python_name }}: {{ field.annotation() }}
{% endfor %}
{% for constructor in record.constructors %}

    @classmethod
    def {{ constructor.python_name }}(cls{% if !constructor.callable.parameters.is_empty() %}, {% for parameter in constructor.callable.parameters %}{{ parameter.name }}: {{ parameter.type_ref.parameter_annotation() }}{% if !loop.last %}, {% endif %}{% endfor %}{% endif %}) -> {{ constructor.callable.return_type.return_annotation() }}: ...
{% endfor %}
{% for method in record.methods %}

{% if method.is_static %}
    @staticmethod
    def {{ method.python_name }}({% for parameter in method.public_parameters() %}{{ parameter.name }}: {{ parameter.type_ref.parameter_annotation() }}{% if !loop.last %}, {% endif %}{% endfor %}) -> {{ method.callable.return_type.return_annotation() }}: ...
{% else %}
    def {{ method.python_name }}(self{% if !method.public_parameters().is_empty() %}, {% for parameter in method.public_parameters() %}{{ parameter.name }}: {{ parameter.type_ref.parameter_annotation() }}{% if !loop.last %}, {% endif %}{% endfor %}{% endif %}) -> {{ method.callable.return_type.return_annotation() }}: ...
{% endif %}
{% endfor %}
{% endfor %}
{% endif %}
{% if module.uses_c_style_enums() %}

{% for enumeration in module.enums %}
class {{ enumeration.class_name() }}(IntEnum):
{% for variant in enumeration.variants %}
    {{ variant.member_name }} = {{ variant.native_value }}
{% endfor %}
{% if enumeration.constructors.is_empty() && enumeration.methods.is_empty() %}
    pass
{% endif %}
{% for constructor in enumeration.constructors %}

    @classmethod
    def {{ constructor.python_name }}(cls{% if !constructor.callable.parameters.is_empty() %}, {% for parameter in constructor.callable.parameters %}{{ parameter.name }}: {{ parameter.type_ref.parameter_annotation() }}{% if !loop.last %}, {% endif %}{% endfor %}{% endif %}) -> {{ constructor.callable.return_type.return_annotation() }}: ...
{% endfor %}
{% for method in enumeration.methods %}

{% if method.is_static %}
    @staticmethod
    def {{ method.python_name }}({% for parameter in method.public_parameters() %}{{ parameter.name }}: {{ parameter.type_ref.parameter_annotation() }}{% if !loop.last %}, {% endif %}{% endfor %}) -> {{ method.callable.return_type.return_annotation() }}: ...
{% else %}
    def {{ method.python_name }}(self{% if !method.public_parameters().is_empty() %}, {% for parameter in method.public_parameters() %}{{ parameter.name }}: {{ parameter.type_ref.parameter_annotation() }}{% if !loop.last %}, {% endif %}{% endfor %}{% endif %}) -> {{ method.callable.return_type.return_annotation() }}: ...
{% endif %}
{% endfor %}
{% endfor %}
{% endif %}
{% if !module.functions.is_empty() %}

{% for function in module.functions %}
def {{ function.python_name }}({% for parameter in function.callable.parameters %}{{ parameter.name }}: {{ parameter.type_ref.parameter_annotation() }}{% if !loop.last %}, {% endif %}{% endfor %}) -> {{ function.callable.return_type.return_annotation() }}: ...
{% endfor %}
{% endif %}