[HUDI-2757] Implement Hudi AWS Glue sync (#5076)
This commit is contained in:
@@ -22,6 +22,7 @@ import org.apache.hudi.common.util.collection.Pair;
|
||||
|
||||
import java.lang.reflect.Array;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.Collections;
|
||||
import java.util.HashMap;
|
||||
import java.util.HashSet;
|
||||
@@ -32,12 +33,21 @@ import java.util.Objects;
|
||||
import java.util.Properties;
|
||||
import java.util.Set;
|
||||
import java.util.stream.Collectors;
|
||||
import java.util.stream.IntStream;
|
||||
import java.util.stream.Stream;
|
||||
|
||||
public class CollectionUtils {
|
||||
|
||||
public static final Properties EMPTY_PROPERTIES = new Properties();
|
||||
|
||||
public static boolean isNullOrEmpty(Collection<?> c) {
|
||||
return Objects.isNull(c) || c.isEmpty();
|
||||
}
|
||||
|
||||
public static boolean nonEmpty(Collection<?> c) {
|
||||
return !isNullOrEmpty(c);
|
||||
}
|
||||
|
||||
/**
|
||||
* Combines provided arrays into one
|
||||
*/
|
||||
@@ -105,6 +115,21 @@ public class CollectionUtils {
|
||||
return diff;
|
||||
}
|
||||
|
||||
public static <E> Stream<List<E>> batchesAsStream(List<E> list, int batchSize) {
|
||||
ValidationUtils.checkArgument(batchSize > 0, "batch size must be positive.");
|
||||
int total = list.size();
|
||||
if (total <= 0) {
|
||||
return Stream.empty();
|
||||
}
|
||||
int numFullBatches = (total - 1) / batchSize;
|
||||
return IntStream.range(0, numFullBatches + 1).mapToObj(
|
||||
n -> list.subList(n * batchSize, n == numFullBatches ? total : (n + 1) * batchSize));
|
||||
}
|
||||
|
||||
public static <E> List<List<E>> batches(List<E> list, int batchSize) {
|
||||
return batchesAsStream(list, batchSize).collect(Collectors.toList());
|
||||
}
|
||||
|
||||
/**
|
||||
* Determines whether two iterators contain equal elements in the same order. More specifically,
|
||||
* this method returns {@code true} if {@code iterator1} and {@code iterator2} contain the same
|
||||
|
||||
@@ -0,0 +1,34 @@
|
||||
/*
|
||||
* 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.apache.hudi.common.util;
|
||||
|
||||
import java.util.Map;
|
||||
import java.util.Objects;
|
||||
|
||||
public class MapUtils {
|
||||
|
||||
public static boolean isNullOrEmpty(Map<?, ?> m) {
|
||||
return Objects.isNull(m) || m.isEmpty();
|
||||
}
|
||||
|
||||
public static boolean nonEmpty(Map<?, ?> m) {
|
||||
return !isNullOrEmpty(m);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user