Skip to main content

Zuspec C/C++ software backend

Project description

Zuspec Software Backend

The Zuspec Software (SW) Backend transforms Zuspec hardware component models into executable C/C++ code for simulation, testing, and modeling.

Features

  • Component Translation: Zuspec Components → C structs and functions
  • Async/Sync: Transforms async methods with optional sync conversion
  • Protocol Interfaces: Generates C API structs for Protocol types
  • Type Mapping: Maps Zuspec types to C types
  • Validation: Pre-generation compatibility checks
  • Compilation: Built-in GCC compiler interface
  • Test Execution: Automated test runner
  • Type Specialization: Optional monomorphization (experimental)

Installation

pip install zuspec-be-sw

Quick Start

import zuspec.dataclasses as zdc
from zuspec.be.sw import CGenerator, CValidator, CCompiler, TestRunner
from pathlib import Path

@zdc.dataclass
class Counter(zdc.Component):
    count: int = zdc.field(default=0)
    
    def increment(self):
        self.count += 1
    
    def get_count(self) -> int:
        return self.count

# Build → Validate → Generate → Compile → Run
factory = zdc.DataModelFactory()
ctxt = factory.build(Counter)

validator = CValidator()
assert validator.validate(ctxt)

gen = CGenerator(Path("output"))
sources = gen.generate(ctxt)

compiler = CCompiler(Path("output"))
exe = compiler.compile(sources, Path("output/test"))

runner = TestRunner()
result = runner.run(exe)

Generated C Code

typedef struct Counter {
    int count;
} Counter;

void Counter_init(Counter *self);
void Counter_increment(Counter *self);
int Counter_get_count(Counter *self);

Documentation

Requirements

  • Python >= 3.7
  • zuspec-dataclasses
  • C compiler (GCC)

License

Apache-2.0

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

zuspec_be_sw-0.0.1.20804669073rc0-py3-none-any.whl (77.0 kB view details)

Uploaded Python 3

File details

Details for the file zuspec_be_sw-0.0.1.20804669073rc0-py3-none-any.whl.

File metadata

File hashes

Hashes for zuspec_be_sw-0.0.1.20804669073rc0-py3-none-any.whl
Algorithm Hash digest
SHA256 729bb48e176f5372d6ddafc6917a5c582fe5474f41ff20f5fe966969c5cfcce8
MD5 7dd67335d2bbfeecbb52d9b18aad7d7d
BLAKE2b-256 262bffa1f9644c47c43b46c60d8acb3e0345bdc310ecbca3b1c98a05448ffdb2

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