com.netease.arctic.shade.org.apache.iceberg.BaseRewriteFiles 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 com.netease.arctic.shade.org.apache.iceberg;
import java.util.Set;
import com.netease.arctic.shade.org.apache.iceberg.relocated.com.google.common.base.Preconditions;
import com.netease.arctic.shade.org.apache.iceberg.relocated.com.google.common.collect.ImmutableSet;
import com.netease.arctic.shade.org.apache.iceberg.relocated.com.google.common.collect.Sets;
class BaseRewriteFiles extends MergingSnapshotProducer implements RewriteFiles {
private final Set replacedDataFiles = Sets.newHashSet();
private Long startingSnapshotId = null;
BaseRewriteFiles(String tableName, TableOperations ops) {
super(tableName, ops);
// replace files must fail if any of the deleted paths is missing and cannot be deleted
failMissingDeletePaths();
}
@Override
protected RewriteFiles self() {
return this;
}
@Override
protected String operation() {
return DataOperations.REPLACE;
}
private void verifyInputAndOutputFiles(Set dataFilesToDelete, Set deleteFilesToDelete,
Set dataFilesToAdd, Set deleteFilesToAdd) {
Preconditions.checkNotNull(dataFilesToDelete, "Data files to delete can not be null");
Preconditions.checkNotNull(deleteFilesToDelete, "Delete files to delete can not be null");
Preconditions.checkNotNull(dataFilesToAdd, "Data files to add can not be null");
Preconditions.checkNotNull(deleteFilesToAdd, "Delete files to add can not be null");
int filesToDelete = 0;
filesToDelete += dataFilesToDelete.size();
filesToDelete += deleteFilesToDelete.size();
Preconditions.checkArgument(filesToDelete > 0, "Files to delete cannot be null or empty");
if (deleteFilesToDelete.isEmpty()) {
Preconditions.checkArgument(deleteFilesToAdd.isEmpty(),
"Delete files to add must be empty because there's no delete file to be rewritten");
}
}
@Override
public RewriteFiles rewriteFiles(Set filesToDelete, Set filesToAdd, long sequenceNumber) {
setNewFilesSequenceNumber(sequenceNumber);
return rewriteFiles(filesToDelete, ImmutableSet.of(), filesToAdd, ImmutableSet.of());
}
@Override
public RewriteFiles rewriteFiles(Set dataFilesToReplace, Set deleteFilesToReplace,
Set dataFilesToAdd, Set deleteFilesToAdd) {
verifyInputAndOutputFiles(dataFilesToReplace, deleteFilesToReplace, dataFilesToAdd, deleteFilesToAdd);
replacedDataFiles.addAll(dataFilesToReplace);
for (DataFile dataFile : dataFilesToReplace) {
delete(dataFile);
}
for (DeleteFile deleteFile : deleteFilesToReplace) {
delete(deleteFile);
}
for (DataFile dataFile : dataFilesToAdd) {
add(dataFile);
}
for (DeleteFile deleteFile : deleteFilesToAdd) {
add(deleteFile);
}
return this;
}
@Override
public RewriteFiles validateFromSnapshot(long snapshotId) {
this.startingSnapshotId = snapshotId;
return this;
}
@Override
protected void validate(TableMetadata base) {
if (replacedDataFiles.size() > 0) {
// if there are replaced data files, there cannot be any new row-level deletes for those data files
validateNoNewDeletesForDataFiles(base, startingSnapshotId, replacedDataFiles);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy