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.21772069871rc0-py3-none-any.whl (77.0 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for zuspec_be_sw-0.0.1.21772069871rc0-py3-none-any.whl
Algorithm Hash digest
SHA256 cc4547b123c26a84b57e7698516208ff57703b69ec99ae7fc34d206fd49d64f1
MD5 897a8b12e8287ca3ce0faf0ab7172dfa
BLAKE2b-256 2049188bd0553066d7216b93b58a94036cea0fcbbe2f6430f7c59cfdca965822

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