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

org.dinky.shaded.paimon.format.FileFormat Maven / Gradle / Ivy

The newest version!
/*
 * 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.
 */

package org.dinky.shaded.paimon.format;

import org.dinky.shaded.paimon.CoreOptions;
import org.dinky.shaded.paimon.annotation.VisibleForTesting;
import org.dinky.shaded.paimon.format.FileFormatFactory.FormatContext;
import org.dinky.shaded.paimon.options.Options;
import org.dinky.shaded.paimon.predicate.Predicate;
import org.dinky.shaded.paimon.statistics.FieldStatsCollector;
import org.dinky.shaded.paimon.types.RowType;

import javax.annotation.Nullable;

import java.util.ArrayList;
import java.util.List;
import java.util.Optional;
import java.util.ServiceLoader;

/**
 * Factory class which creates reader and writer factories for specific file format.
 *
 * 

NOTE: This class must be thread safe. */ public abstract class FileFormat { protected String formatIdentifier; protected FileFormat(String formatIdentifier) { this.formatIdentifier = formatIdentifier; } public String getFormatIdentifier() { return formatIdentifier; } /** * Create a {@link FormatReaderFactory} from the type, with projection pushed down. * * @param projectedRowType Type with projection. * @param filters A list of filters in conjunctive form for filtering on a best-effort basis. */ public abstract FormatReaderFactory createReaderFactory( RowType projectedRowType, @Nullable List filters); /** Create a {@link FormatWriterFactory} from the type. */ public abstract FormatWriterFactory createWriterFactory(RowType type); /** Validate data field type supported or not. */ public abstract void validateDataFields(RowType rowType); public FormatReaderFactory createReaderFactory(RowType rowType) { return createReaderFactory(rowType, new ArrayList<>()); } public Optional createStatsExtractor( RowType type, FieldStatsCollector.Factory[] statsCollectors) { return Optional.empty(); } @VisibleForTesting public static FileFormat fromIdentifier(String identifier, Options options) { return fromIdentifier(identifier, new FormatContext(options, 1024)); } /** Create a {@link FileFormat} from format identifier and format options. */ public static FileFormat fromIdentifier(String identifier, FormatContext context) { Optional format = fromIdentifier(identifier, context, FileFormat.class.getClassLoader()); return format.orElseGet( () -> fromIdentifier(identifier, context, FileFormat.class.getClassLoader()) .orElseThrow( () -> new RuntimeException( String.format( "Could not find any factories that implement '%s' in the classpath.", FileFormatFactory.class .getName())))); } private static Optional fromIdentifier( String formatIdentifier, FormatContext context, ClassLoader classLoader) { ServiceLoader serviceLoader = ServiceLoader.load(FileFormatFactory.class, classLoader); for (FileFormatFactory factory : serviceLoader) { if (factory.identifier().equals(formatIdentifier.toLowerCase())) { return Optional.of(factory.create(context)); } } return Optional.empty(); } public static FileFormat getFileFormat(Options options, String formatIdentifier) { int readBatchSize = options.get(CoreOptions.READ_BATCH_SIZE); return FileFormat.fromIdentifier( formatIdentifier, new FormatContext(options.removePrefix(formatIdentifier + "."), readBatchSize)); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy