Skip to main content

lance_namespace_reqwest_client/models/
partition_transform.rs

1/*
2 * Lance Namespace Specification
3 *
4 * This OpenAPI specification is a part of the Lance namespace specification. It contains 2 parts:  The `components/schemas`, `components/responses`, `components/examples`, `tags` sections define the request and response shape for each operation in a Lance Namespace across all implementations. See https://lance.org/format/namespace/operations for more details.  The `servers`, `security`, `paths`, `components/parameters` sections are for the Lance REST Namespace implementation, which defines a complete REST server that can work with Lance datasets. See https://lance.org/format/namespace/rest for more details. 
5 *
6 * The version of the OpenAPI document: 1.0.0
7 * 
8 * Generated by: https://openapi-generator.tech
9 */
10
11use crate::models;
12use serde::{Deserialize, Serialize};
13
14/// PartitionTransform : Well-known partition transform
15#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
16pub struct PartitionTransform {
17    /// Transform type (identity, year, month, day, hour, bucket, multi_bucket, truncate)
18    #[serde(rename = "type")]
19    pub r#type: String,
20    /// Number of buckets for bucket transforms
21    #[serde(rename = "num_buckets", skip_serializing_if = "Option::is_none")]
22    pub num_buckets: Option<i32>,
23    /// Truncation width for truncate transforms
24    #[serde(rename = "width", skip_serializing_if = "Option::is_none")]
25    pub width: Option<i32>,
26}
27
28impl PartitionTransform {
29    /// Well-known partition transform
30    pub fn new(r#type: String) -> PartitionTransform {
31        PartitionTransform {
32            r#type,
33            num_buckets: None,
34            width: None,
35        }
36    }
37}
38