All Downloads are FREE. Search and download functionalities are using the official Maven repository.

wvlet.airframe.parquet.ParquetCompat.scala Maven / Gradle / Ivy

package wvlet.airframe.parquet

import org.apache.hadoop.conf.Configuration
import org.apache.parquet.hadoop.{ParquetReader, ParquetWriter}
import wvlet.airframe.surface.Surface

trait ParquetCompat {

  inline def newWriter[A](
      path: String,
      // Hadoop filesystem specific configuration, e.g., fs.s3a.access.key
      hadoopConf: Configuration = new Configuration(),
      config: ParquetWriterAdapter.Builder[A] => ParquetWriterAdapter.Builder[A] =
        identity[ParquetWriterAdapter.Builder[A]](_)
  ): ParquetWriter[A] = {
    Parquet.newObjectWriter[A](Surface.of[A], path, hadoopConf, config)
  }

  inline def newReader[A](
      path: String,
      // Hadoop filesystem specific configuration, e.g., fs.s3a.access.key
      hadoopConf: Configuration = new Configuration(),
      config: ParquetReader.Builder[A] => ParquetReader.Builder[A] = identity[ParquetReader.Builder[A]](_)
  ): ParquetReader[A] = {
    Parquet.newObjectReader[A](Surface.of[A], path, hadoopConf, config)
  }

  inline def query[A](
      path: String,
      sql: String,
      hadoopConf: Configuration = new Configuration(),
      config: ParquetReader.Builder[A] => ParquetReader.Builder[A] = identity[ParquetReader.Builder[A]](_)
  ): ParquetReader[A] = {
    Parquet.queryObject[A](Surface.of[A], path, sql, hadoopConf, config)
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy