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

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for zuspec_be_sw-0.0.1.21462557391rc0-py3-none-any.whl
Algorithm Hash digest
SHA256 5fb0e216eff2a4cfd7ea6af1baad6866a32ffd6b71711a892cad9b53d563ae7f
MD5 93ebacac15abf33062121324890111e2
BLAKE2b-256 3c456f6c7a5c543adb8182faf7d07f59984aa3badd58b1c798a4c0980aabe55c

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