# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements.  See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership.  The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License.  You may obtain a copy of the License at
#
#   http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied.  See the License for the
# specific language governing permissions and limitations
# under the License.
from typing import List
[docs]
class JvmSedonaPythonConverter:
[docs]
    def __init__(self, jvm):
        self._jvm = jvm 
[docs]
    def translate_spatial_rdd_to_python(self, spatial_rdd):
        return self._jvm.PythonConverter.translateSpatialRDDToPython(spatial_rdd) 
[docs]
    def translate_spatial_pair_rdd_to_python(self, spatial_rdd):
        return self._jvm.PythonConverter.translateSpatialPairRDDToPython(spatial_rdd) 
[docs]
    def translate_spatial_pair_rdd_with_list_to_python(self, spatial_rdd):
        return self._jvm.PythonConverter.translateSpatialPairRDDWithListToPython(
            spatial_rdd
        ) 
[docs]
    def translate_python_rdd_to_java(self, java_rdd):
        return self._jvm.PythonConverter.translatePythonRDDToJava(java_rdd) 
[docs]
    def translate_geometry_seq_to_python(self, geometry_seq) -> List:
        return self._jvm.PythonConverter.translateGeometrySeqToPython(geometry_seq) 
 
[docs]
class JvmJoinParamsAdapter:
[docs]
    def __init__(self, jvm):
        self._jvm = jvm 
[docs]
    def adapt(self, useIndex: bool, indexType: str, joinBuildSide: str):
        return self._jvm.createJoinParams(useIndex, indexType, joinBuildSide) 
 
[docs]
class JvmRawJvmIndexRDDAdapter:
[docs]
    def __init__(self, jvm):
        self._jvm = jvm 
[docs]
    def setRawIndexRDD(self, spatial_rdd, index_rdd):
        self._jvm.RawJvmIndexAdapter.setRawIndexRDD(spatial_rdd, index_rdd) 
 
[docs]
class JvmSpatialObjectLoaderAdapter:
[docs]
    def __init__(self, jvm):
        self._jvm = jvm 
[docs]
    def loadPointSpatialRDD(self, jsc, path):
        return self._jvm.SpatialObjectLoaderAdapter.loadPointSpatialRDD(jsc, path) 
[docs]
    def loadPolygonSpatialRDD(self, jsc, path):
        self._jvm.SpatialObjectLoaderAdapter.loadPolygonSpatialRDD(jsc, path) 
[docs]
    def loadSpatialRDD(self, jsc, path):
        self._jvm.SpatialObjectLoaderAdapter.loadSpatialRDD(jsc, path) 
[docs]
    def loadLineStringSpatialRDD(self, jsc, path):
        self._jvm.SpatialObjectLoaderAdapter(jsc, path) 
[docs]
    def loadIndexRDD(self, jsc, path):
        self._jvm.SpatialObjectLoaderAdapter(jsc, path) 
 
[docs]
class JvmGeometryAdapter:
[docs]
    def __init__(self, jvm):
        self._jvm = jvm 
[docs]
    def translate_to_java(self, bytes):
        bytes_data = [el for el in bytes]
        return self._jvm.GeometryAdapter.translateToJava(bytes_data) 
 
[docs]
class SedonaPythonConverter:
[docs]
    def __init__(self, jvm):
        self.jvm = jvm 
[docs]
    def translate_spatial_rdd_to_python(self, spatial_rdd):
        return self.jvm.PythonConverter.translateSpatialRDDToPython(spatial_rdd) 
 
[docs]
class PythonRddToJavaRDDAdapter:
[docs]
    def __init__(self, jvm):
        self._jvm = jvm 
[docs]
    def deserialize_to_point_raw_rdd(self, java_spatial_rdd):
        return self._jvm.PythonRddToJavaRDDAdapter.deserializeToPointRawRDD(
            java_spatial_rdd
        ) 
[docs]
    def deserialize_to_polygon_raw_rdd(self, java_spatial_rdd):
        return self._jvm.PythonRddToJavaRDDAdapter.deserializeToPolygonRawRDD(
            java_spatial_rdd
        ) 
[docs]
    def deserialize_to_linestring_raw_rdd(self, java_spatial_rdd):
        return self._jvm.PythonRddToJavaRDDAdapter.deserializeToLineStringRawRDD(
            java_spatial_rdd
        ) 
 
[docs]
class SpatialObjectLoaderAdapter:
[docs]
    def __init__(self, jvm):
        self._jvm = jvm 
[docs]
    def load_point_spatial_rdd(self, sc, path):
        return self._jvm.SpatialObjectLoaderAdapter.loadPointSpatialRDD(sc, path) 
[docs]
    def load_polygon_spatial_rdd(self, sc, path):
        return self._jvm.SpatialObjectLoaderAdapter.loadPolygonSpatialRDD(sc, path) 
[docs]
    def load_spatial_rdd(self, sc, path):
        return self._jvm.SpatialObjectLoaderAdapter.loadSpatialRDD(sc, path) 
[docs]
    def load_line_string_spatial_rdd(self, sc, path):
        return self._jvm.SpatialObjectLoaderAdapter.loadLineStringSpatialRDD(sc, path) 
[docs]
    def load_index_rdd(self, sc, path):
        return self._jvm.SpatialObjectLoaderAdapter.loadIndexRDD(sc, path)