Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ndsev/zserio

zero sugar, zero fat, zero serialization overhead
https://github.com/ndsev/zserio

code-generation compactness cpp data-structures grpc java schema-language serialization serialization-framework sqlite wire-format

Last synced: about 2 months ago
JSON representation

zero sugar, zero fat, zero serialization overhead

Awesome Lists containing this project

README

        

***z***ero ***seri***alization ***o***verhead

[![](https://github.com/ndsev/zserio/actions/workflows/build_linux.yml/badge.svg)](https://github.com/ndsev/zserio/actions/workflows/build_linux.yml)
[![](https://github.com/ndsev/zserio/actions/workflows/build_windows.yml/badge.svg)](https://github.com/ndsev/zserio/actions/workflows/build_windows.yml)
[![](https://github.com/ndsev/zserio/actions/workflows/codeql_autosar.yml/badge.svg)](https://github.com/ndsev/zserio/actions/workflows/codeql_autosar.yml)
[![](https://img.shields.io/conan/v/zserio)](https://conan.io/center/recipes/zserio)
[![](https://img.shields.io/maven-central/v/io.github.ndsev/zserio)](https://central.sonatype.com/artifact/io.github.ndsev/zserio)
[![](https://img.shields.io/pypi/v/zserio.svg)](https://pypi.org/pypi/zserio/)
[![](https://img.shields.io/endpoint?url=https://zserio.org/doc/runtime/latest/cpp/coverage/clang/coverage_github_badge.json)](https://zserio.org/doc/runtime/latest/cpp/coverage/clang)
[![](https://img.shields.io/endpoint?url=https://zserio.org/doc/runtime/latest/java/coverage/coverage_github_badge.json)](https://zserio.org/doc/runtime/latest/java/coverage)
[![](https://img.shields.io/endpoint?url=https://zserio.org/doc/runtime/latest/python/coverage/coverage_github_badge.json)](https://zserio.org/doc/runtime/latest/python/coverage)
[![](https://sonarcloud.io/api/project_badges/measure?project=ndsev_zserio&metric=alert_status)](https://sonarcloud.io/summary/new_code?id=ndsev_zserio)
[![](https://img.shields.io/github/release-date/ndsev/zserio)](https://github.com/ndsev/zserio/releases/latest)
[![](https://img.shields.io/github/commits-since/ndsev/zserio/latest)](https://github.com/ndsev/zserio/commits/master)
[![](https://img.shields.io/github/commit-activity/m/ndsev/zserio)](https://github.com/ndsev/zserio/commits/master)
[![](https://img.shields.io/github/watchers/ndsev/zserio.svg)](https://github.com/ndsev/zserio/watchers)
[![](https://img.shields.io/github/forks/ndsev/zserio.svg)](https://github.com/ndsev/zserio/network/members)
[![](https://img.shields.io/github/stars/ndsev/zserio.svg?color=yellow)](https://github.com/ndsev/zserio/stargazers)

--------

Zserio is a framework for serializing structured data with a compact and efficient way with low overhead.

You can define your structured data in [Zserio language](doc/ZserioLanguageOverview.md) and then you can use
special generated source code in [several languages](#language-support) to easily write and read your data to
and from a [binary](doc/ZserioEncodingGuide.md) or a [text](doc/ZserioJsonGuide.md) stream.

No time to read? Go to the [quick start](#quick-start) or [download latest release](https://github.com/ndsev/zserio/releases/latest).

In for the numbers? Head over to [benchmarks](benchmarks/README.md).

Questions? Check the [FAQs](doc/FAQ.md).

More documentation? Go to the [documentation](#documentation).

--------

## Language support

Zserio supports the following code generators:

- [C++ Generator](compiler/extensions/cpp/README.md) together with [runtime library](https://zserio.org/doc/runtime/latest/cpp)
using C++11, and developed with special attention to [functional safety](compiler/extensions/cpp/README.md#functional-safety)
and [performance](https://github.com/ndsev/zserio-protobuf-benchmarks)
- [Java Generator](compiler/extensions/java/README.md) together with [runtime library](https://zserio.org/doc/runtime/latest/java)
- [Python Generator](compiler/extensions/python/README.md) together with [runtime library](https://zserio.org/doc/runtime/latest/python)

In addition to these, Zserio provides specialized text generators for documentation and export

- [Doc Generator](compiler/extensions/doc/README.md)
- [XML Generator](compiler/extensions/xml/README.md)

## Introduction

The Zserio serialization framework allows you to serialize data in a compact and efficient way.

The key features include

- compactness (smaller than most other serializers)
- advanced schema definition options
- cross-platform
- multiple programming languages

It can be retrofitted on top of almost any other serialization language or model, since it gives the developer
powerful low-level access.

It features simple and compound data structures and provides advanced features for controlling at design time
what writers will be able to fill in.

Zserio does have a very simple wire format described at [Zserio Encoding Guide](doc/ZserioEncodingGuide.md).

Zserio supports as well serialization and deserialization in JSON format described at
[Zserio JSON Guide](doc/ZserioJsonGuide.md).

## Quick Start

To be able to serialize data with Zserio, you have to follow these basic steps:

1. Download the runtimes and the Zserio compiler from [Github Releases](https://github.com/ndsev/zserio/releases/latest)
2. Set up your development environment with the Zserio runtime
3. Write the schema definition
4. Compile the schema and generate code
5. Serialize/deserialize using the generated code

You can find the detailed quick start tutorial in their respective repositories:

- [C++ Tutorial](https://github.com/ndsev/zserio-tutorial-cpp#zserio-c-quick-start-tutorial)
- [Java Tutorial](https://github.com/ndsev/zserio-tutorial-java#zserio-java-quick-start-tutorial)
- [Python Tutorial](https://github.com/ndsev/zserio-tutorial-python#zserio-python-quick-start-tutorial)

Or try [Interactive Zserio Compiler](https://share.streamlit.io/zserio-streamlit/zserio-streamlit/interactive_zserio.py)
based on [Streamlit](https://streamlit.io).

## Features overview

- [Optional elements](doc/ZserioLanguageOverview.md#optional-members)
- [Constraints](doc/ZserioLanguageOverview.md#constraints)
- [Default values](doc/ZserioLanguageOverview.md#default-values)
- [Parameters](doc/ZserioLanguageOverview.md#parameterized-types)
- [Alignments](doc/ZserioLanguageOverview.md#alignment)
- [Offsets](doc/ZserioLanguageOverview.md#offsets)
- [Arrays with indexed offsets](doc/ZserioLanguageOverview.md#indexed-offsets)
- [Packed arrays](doc/ZserioLanguageOverview.md#packed-arrays)
- [Templates](doc/ZserioLanguageOverview.md#templates)
- [Generic services](#services)
- [Generic Pub/Sub](#pubsub)
- [SQLite extension](doc/ZserioLanguageOverview.md#sqlite-extension)

## Documentation

Documentation of the schema language can be found in the
[Zserio Language Overview](doc/ZserioLanguageOverview.md).

Schema language reference can be found in [Quick Reference](doc/ZserioQuickReference.md).

Explanation how zserio encodes data to the wire format can be found in the
[Zserio Encoding Guide](doc/ZserioEncodingGuide.md).

Explanation how zserio encodes data to the JSON format can be found in the
[Zserio JSON Guide](doc/ZserioJsonGuide.md).

Explanation how zserio schema can be extended not to break backward or forward compatibility can be found in the
[Zserio Schema Evolution Guide](doc/ZserioSchemaEvolutionGuide.md).

Explanation how to deal with all possible backward incompatibilities that can occur after updating of Zserio
can be found in the [Zserio Compatibility Guide](doc/ZserioCompatibilityGuide.md).

User Guide can be found in the [Zserio Compiler User Guide](doc/ZserioUserGuide.md).

Build instructions can be found in the [Zserio Compiler Build Instructions](doc/ZserioBuildInstructions.md).

C++ users can find more information in the
[C++ Tutorial](https://github.com/ndsev/zserio-tutorial-cpp#zserio-c-quick-start-tutorial).

Java users can find more information in the
[Java Tutorial](https://github.com/ndsev/zserio-tutorial-java#zserio-java-quick-start-tutorial).

Python users can find more information in the
[Python Tutorial](https://github.com/ndsev/zserio-tutorial-python#zserio-python-quick-start-tutorial).

Check out as well the [Zserio Types Mapping](doc/ZserioTypesMapping.md) for types mapping description.

### Extensions

Zserio extension is any Java [extension](https://docs.oracle.com/javase/tutorial/ext/index.html) which
implements [`zserio.tools.Extension`](https://github.com/ndsev/zserio/blob/master/compiler/core/src/zserio/tools/Extension.java)
interface.

For example, if you need to implement a new code generator for Zserio, you need to implement special Zserio
extension. Or another example could be a Zserio extension which only prints some schema statistics and it does
not generate anything.

Each Zserio extension should be packed in a single jar file.

All Zserio extensions which are available on the Java classpath are automatically loaded during Zserio compiler
startup.

More information how to implement a new Zserio extension can be found in the
[Zserio extension sample](https://github.com/ndsev/zserio-extension-sample#zserio-extension-sample).

### Services

[Service types](doc/ZserioLanguageOverview.md#service-types) allow to define generic service interfaces.
But note that no underlying communication library is provided by Zserio. Zserio only defines the generic
interface and users are responsible for its implementation. However, Zserio provides sample implementations
of several services backends:
* [C++ Zserio Service gRPC backend](https://github.com/ndsev/zserio-service-grpc-cpp)
* [Java Zserio Service RMI backend](https://github.com/ndsev/zserio-service-rmi-java)
* [Python Zserio Service HTTP backend](https://github.com/ndsev/zserio-service-http-python)

### Pub/Sub

[Pubsub types](doc/ZserioLanguageOverview.md#pubsub-types) allow to define generic
[Pub/Sub](https://en.wikipedia.org/wiki/Publish%E2%80%93subscribe_pattern) clients.
Users are responsible for implementation of the generic Pub/Sub client interface provided
by Zserio. However, Zserio provides sample implementations of several Pub/Sub backends:
* [C++ Zserio Pub/Sub Mosquitto backend](https://github.com/ndsev/zserio-pubsub-mosquitto-cpp)
* [Java Zserio Pub/Sub Paho MQTT backend](https://github.com/ndsev/zserio-pubsub-paho-mqtt-java)
* [Python Zserio Pub/Sub Paho MQTT backend](https://github.com/ndsev/zserio-pubsub-paho-mqtt-python)

Note that Zserio doesn't provide any Pub/Sub server. There are various implementations of servers
(e.g. [mosquitto](https://github.com/eclipse/mosquitto)) and it's the responsibility of the user's Pub/Sub
client implementation to communicate with the appropriate server.

## Contributions

Contributions are very welcome but we encourage to open a
[discussion](https://github.com/ndsev/zserio/discussions/new/choose) or
an [issue](https://github.com/ndsev/zserio/issues/new/choose) first to agree on a solution or to avoid useless
work in case we are already solving a similar problem. Please see [Contribution Guide](CONTRIBUTING.md).