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