Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/birkenfeld/serde-pickle

Rust (de)serialization for the Python pickle format.
https://github.com/birkenfeld/serde-pickle

Last synced: 4 days ago
JSON representation

Rust (de)serialization for the Python pickle format.

Awesome Lists containing this project

README

        

Serde Pickle Serialization Library
==================================

[![Build Status](https://github.com/birkenfeld/serde-pickle/actions/workflows/main.yml/badge.svg)](https://github.com/birkenfeld/serde-pickle/actions/workflows/main.yml)
[![Latest Version](https://img.shields.io/crates/v/serde-pickle.svg)](https://crates.io/crates/serde-pickle)

[Documentation](https://docs.rs/serde-pickle)

This crate is a Rust library for parsing and generating Python pickle
streams. It is built upon [Serde](https://github.com/serde-rs/serde), a high
performance generic serialization framework.

Installation
============

This crate works with Cargo and can be found on
[crates.io](https://crates.io/crates/serde-pickle) with a `Cargo.toml` like:

```toml
[dependencies]
serde = "1.0"
serde-pickle = "1.1"
```

Requirements
============

Minimum supported Rust version is 1.63.0.

Usage
=====

As with other serde serialization implementations, this library provides
toplevel functions for simple en/decoding of supported objects.

Example:

```rust
use std::collections::BTreeMap;

fn main() {
let mut map = BTreeMap::new();
map.insert("x".to_string(), 1.0);
map.insert("y".to_string(), 2.0);

// Serialize the map into a pickle stream.
// The second argument are serialization options.
let serialized = serde_pickle::to_vec(&map, Default::default()).unwrap();

// Deserialize the pickle stream back into a map.
// Because we compare it to the original `map` below, Rust infers
// the type of `deserialized` and lets serde work its magic.
// The second argument are additional deserialization options.
let deserialized = serde_pickle::from_slice(&serialized, Default::default()).unwrap();
assert_eq!(map, deserialized);
}
```

Serializing and deserializing structs and enums that implement the
serde-provided traits is supported, and works analogous to other crates
(using `serde_derive`).