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

https://github.com/nobane/reflect_to

Generate type information in other languages based on rust types.
https://github.com/nobane/reflect_to

python reflection rtti rust typescript

Last synced: 18 days ago
JSON representation

Generate type information in other languages based on rust types.

Awesome Lists containing this project

README

          

# Reflect To

- Generate type information in other languages based on rust types.
- Adhere to `serde` serialization behaviors whenever possible.
- Builds upon a reusable [rtti](https://en.wikipedia.org/wiki/Run-time_type_information) foundation in rust.
- Supported language type conversions:
- typescript via `typescript`flag (on by default)
- python via `python` flag
- **NOTE**: Still an active WIP!

# Typescript Example

By using the `Reflect` derive:

```rs
use reflect_to::Reflect;
use serde::{Deserialize, Serialize};
use std::{collections::HashMap, path::PathBuf};

#[derive(Reflect, Serialize, Deserialize, Debug, Clone)]
#[serde(rename_all = "camelCase")]
pub struct User {
email: String,
is_active: bool,
uploaded_files: Vec,
profile_image: Option,
settings: UserSettings,
status: UserStatus,
}

#[derive(Reflect, Serialize, Deserialize, Debug, Clone)]
pub enum UserStatus {
Offline,
Online { status: String },
Unknown(String),
}

#[derive(Reflect, Serialize, Deserialize, Debug, Clone)]
pub struct UserPost {
post_name: Option,
contents: Vec,
}

#[derive(Reflect, Serialize, Deserialize, Debug, Clone)]
#[serde(rename_all = "camelCase")]
pub struct UserSettings {
theme_path: PathBuf,
email_notifications: bool,
#[serde(rename = "custom")]
custom_settings: HashMap,
}
```

the following type information can be generated at runtime (for instance as part of a wasm build process):

```ts
export interface User {
email: string;
isActive: boolean;
uploadedFiles: UserPost[];
profileImage: string | null;
settings: UserSettings;
status: UserStatus;
}

export type UserStatus =
"Offline"
| { "Online": {
status: string;
} }
| { "Unknown": string }

export interface UserPost {
post_name: string | null;
contents: string[];
}

export interface UserSettings {
themePath: string
emailNotifications: boolean
custom: Record;
}
```

# Demo

Run one of the examples via

```
cargo run --example to_python
```
or

```
cargo run --example to_typescript
```

# Documentation

For now, the best documentation is the [typescript](crates/to_typescript/examples/to_typescript.rs) and [python](crates/to_python/examples/to_python.rs) examples.