datafusion_python/common/df_schema.rs
1// Licensed to the Apache Software Foundation (ASF) under one
2// or more contributor license agreements. See the NOTICE file
3// distributed with this work for additional information
4// regarding copyright ownership. The ASF licenses this file
5// to you under the Apache License, Version 2.0 (the
6// "License"); you may not use this file except in compliance
7// with the License. You may obtain a copy of the License at
8//
9// http://www.apache.org/licenses/LICENSE-2.0
10//
11// Unless required by applicable law or agreed to in writing,
12// software distributed under the License is distributed on an
13// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14// KIND, either express or implied. See the License for the
15// specific language governing permissions and limitations
16// under the License.
17
18use std::sync::Arc;
19
20use datafusion::common::DFSchema;
21use pyo3::prelude::*;
22
23#[derive(Debug, Clone)]
24#[pyclass(name = "DFSchema", module = "datafusion.common", subclass)]
25pub struct PyDFSchema {
26 schema: Arc<DFSchema>,
27}
28
29impl From<PyDFSchema> for DFSchema {
30 fn from(schema: PyDFSchema) -> DFSchema {
31 (*schema.schema).clone()
32 }
33}
34
35impl From<DFSchema> for PyDFSchema {
36 fn from(schema: DFSchema) -> PyDFSchema {
37 PyDFSchema {
38 schema: Arc::new(schema),
39 }
40 }
41}
42
43#[pymethods]
44impl PyDFSchema {
45 #[pyo3(name = "empty")]
46 #[staticmethod]
47 fn py_empty() -> PyResult<Self> {
48 Ok(Self {
49 schema: Arc::new(DFSchema::empty()),
50 })
51 }
52
53 #[pyo3(name = "field_names")]
54 fn py_field_names(&self) -> PyResult<Vec<String>> {
55 Ok(self.schema.field_names())
56 }
57}