Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.landawn.abacus.util.Builder Maven / Gradle / Ivy
Go to download
A general programming library in Java/Android. It's easy to learn and simple to use with concise and powerful APIs.
/*
* Copyright (C) 2016 HaiYang Li
*
* Licensed 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.landawn.abacus.util;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Comparator;
import java.util.HashMap;
import java.util.HashSet;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
import com.landawn.abacus.util.NoCachingNoUpdating.DisposableObjArray;
import com.landawn.abacus.util.Throwables.Predicate;
import com.landawn.abacus.util.Tuple.Tuple2;
import com.landawn.abacus.util.Tuple.Tuple3;
import com.landawn.abacus.util.u.Optional;
import com.landawn.abacus.util.function.Function;
import com.landawn.abacus.util.function.Supplier;
import com.landawn.abacus.util.stream.Stream;
/**
*
* @author haiyangl
* @param
* @since 0.8
*/
public class Builder {
final T val;
Builder(T val) {
N.checkArgNotNull(val);
this.val = val;
}
/**
*
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
public static final BooleanListBuilder of(final BooleanList val) throws IllegalArgumentException {
return new BooleanListBuilder(val);
}
/**
*
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
public static final CharListBuilder of(final CharList val) throws IllegalArgumentException {
return new CharListBuilder(val);
}
/**
*
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
public static final ByteListBuilder of(final ByteList val) throws IllegalArgumentException {
return new ByteListBuilder(val);
}
/**
*
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
public static final ShortListBuilder of(final ShortList val) throws IllegalArgumentException {
return new ShortListBuilder(val);
}
/**
*
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
public static final IntListBuilder of(final IntList val) throws IllegalArgumentException {
return new IntListBuilder(val);
}
/**
*
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
public static final LongListBuilder of(final LongList val) throws IllegalArgumentException {
return new LongListBuilder(val);
}
/**
*
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
public static final FloatListBuilder of(final FloatList val) throws IllegalArgumentException {
return new FloatListBuilder(val);
}
/**
*
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
public static final DoubleListBuilder of(final DoubleList val) throws IllegalArgumentException {
return new DoubleListBuilder(val);
}
/**
*
* @param
* @param
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
public static final > ListBuilder of(L val) throws IllegalArgumentException {
return new ListBuilder<>(val);
}
/**
*
* @param
* @param
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
public static final > CollectionBuilder of(C val) throws IllegalArgumentException {
return new CollectionBuilder<>(val);
}
/**
*
* @param the key type
* @param the value type
* @param
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
public static final > MapBuilder of(M val) throws IllegalArgumentException {
return new MapBuilder<>(val);
}
/**
*
* @param
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
public static final MultisetBuilder of(Multiset val) throws IllegalArgumentException {
return new MultisetBuilder<>(val);
}
/**
*
* @param
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
public static final LongMultisetBuilder of(LongMultiset val) throws IllegalArgumentException {
return new LongMultisetBuilder<>(val);
}
/**
*
* @param the key type
* @param
* @param the value type
* @param
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
public static final , M extends Multimap> MultimapBuilder of(M val) throws IllegalArgumentException {
return new MultimapBuilder<>(val);
}
/**
*
* @param
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
public static final DataSetBuilder of(final DataSet val) throws IllegalArgumentException {
return new DataSetBuilder(val);
}
@SuppressWarnings("rawtypes")
private static final Map, Function> creatorMap = new HashMap<>();
static {
initCreatorMap();
}
@SuppressWarnings("rawtypes")
private static void initCreatorMap() {
creatorMap.put(BooleanList.class, val -> Builder.of((BooleanList) val));
creatorMap.put(CharList.class, val -> Builder.of((CharList) val));
creatorMap.put(ByteList.class, val -> Builder.of((ByteList) val));
creatorMap.put(ShortList.class, val -> Builder.of((ShortList) val));
creatorMap.put(IntList.class, val -> Builder.of((IntList) val));
creatorMap.put(LongList.class, val -> Builder.of((LongList) val));
creatorMap.put(FloatList.class, val -> Builder.of((FloatList) val));
creatorMap.put(DoubleList.class, val -> Builder.of((DoubleList) val));
creatorMap.put(List.class, val -> Builder.of((List) val));
creatorMap.put(ArrayList.class, val -> Builder.of((List) val));
creatorMap.put(LinkedList.class, val -> Builder.of((List) val));
creatorMap.put(Set.class, val -> Builder.of((Collection) val));
creatorMap.put(HashSet.class, val -> Builder.of((Collection) val));
creatorMap.put(LinkedHashSet.class, val -> Builder.of((Collection) val));
creatorMap.put(Map.class, val -> Builder.of((Map) val));
creatorMap.put(HashMap.class, val -> Builder.of((Map) val));
creatorMap.put(LinkedHashMap.class, val -> Builder.of((Map) val));
creatorMap.put(TreeMap.class, val -> Builder.of((Map) val));
creatorMap.put(Multiset.class, val -> Builder.of((Multiset) val));
creatorMap.put(LongMultiset.class, val -> Builder.of((LongMultiset) val));
creatorMap.put(Multimap.class, val -> Builder.of((Multimap) val));
creatorMap.put(ListMultimap.class, val -> Builder.of((Multimap) val));
creatorMap.put(SetMultimap.class, val -> Builder.of((Multimap) val));
creatorMap.put(DataSet.class, val -> Builder.of((DataSet) val));
creatorMap.put(RowDataSet.class, val -> Builder.of((DataSet) val));
}
/**
*
* @param
* @param val
* @return
* @throws IllegalArgumentException if the specified {@code val} is {@code null}.
*/
@SuppressWarnings("rawtypes")
public static final Builder of(T val) {
N.checkArgNotNull(val);
final Function func = creatorMap.get(val.getClass());
if (func != null) {
return func.apply(val);
}
Builder result = null;
if (val instanceof List) {
result = of((List) val);
} else if (val instanceof Collection) {
result = of((Collection) val);
} else if (val instanceof Map) {
result = of((Map) val);
} else if (val instanceof Multimap) {
result = of((Multimap) val);
} else if (val instanceof DataSet) {
result = of((DataSet) val);
} else if (val instanceof Multiset) {
result = of((Multiset) val);
} else if (val instanceof LongMultiset) {
result = of((LongMultiset) val);
} else {
result = new Builder<>(val);
}
return result;
}
// public static Builder get(final Supplier supplier) {
// return new Builder<>(supplier.get());
// }
public T val() {
return val;
}
/**
*
* @param
* @param
* @param mapper
* @return
* @throws E the e
*/
public Builder map(final Throwables.Function super T, R, E> mapper) throws E {
return of(mapper.apply(val));
}
/**
*
* @param
* @param predicate
* @return Optional
with the value if predicate
returns true,
* otherwise, return an empty Optional
* @throws E the e
*/
public Optional filter(final Throwables.Predicate super T, E> predicate) throws E {
return predicate.test(val) ? Optional.of(val) : Optional. empty();
}
/**
*
* @param
* @param consumer
* @return
* @throws E the e
*/
public Builder accept(final Throwables.Consumer super T, E> consumer) throws E {
consumer.accept(val);
return this;
}
/**
*
* @param
* @param
* @param func
* @return
* @throws E the e
*/
public R apply(final Throwables.Function super T, R, E> func) throws E {
return func.apply(val);
}
public Stream stream() {
return Stream.of(val);
}
// /**
// * Returns an empty Nullable
if {@code val()} is {@code null} while {@code targetType} is primitive or can't be assigned to {@code targetType}.
// * Please be aware that {@code null} can be assigned to any {@code Object} type except primitive types: {@code boolean/char/byte/short/int/long/double}.
// *
// * @param val
// * @param targetType
// * @return
// */
// @SuppressWarnings("unchecked")
// public Nullable castIfAssignable(final Class targetType) {
// if (N.isPrimitive(targetType)) {
// return val != null && N.wrapperOf(targetType).isAssignableFrom(val.getClass()) ? Nullable.of((TT) val) : Nullable. empty();
// }
//
// return val == null || targetType.isAssignableFrom(val.getClass()) ? Nullable.of((TT) val) : Nullable. empty();
// }
//
// /**
// *
// * @param b
// * @param actionForTrue do nothing if it's {@code null} even {@code b} is true.
// * @param actionForFalse do nothing if it's {@code null} even {@code b} is false.
// * @throws E1
// * @throws E2
// */
// public void ifOrElse(final boolean b, final Try.Consumer super T, E1> actionForTrue,
// final Try.Consumer super T, E2> actionForFalse) throws E1, E2 {
// if (b) {
// if (actionForTrue != null) {
// actionForTrue.accept(val);
// }
// } else {
// if (actionForFalse != null) {
// actionForFalse.accept(val);
// }
// }
// }
//
// /**
// *
// * @param predicate
// * @param actionForTrue do nothing if it's {@code null} even {@code b} is true.
// * @param actionForFalse do nothing if it's {@code null} even {@code b} is false.
// * @throws E0
// * @throws E1
// * @throws E2
// */
// public void ifOrElse(final Try.Predicate super T, E0> predicate,
// final Try.Consumer super T, E1> actionForTrue, final Try.Consumer super T, E2> actionForFalse) throws E0, E1, E2 {
// if (predicate.test(val)) {
// if (actionForTrue != null) {
// actionForTrue.accept(val);
// }
// } else {
// if (actionForFalse != null) {
// actionForFalse.accept(val);
// }
// }
// }
//
// /**
// * Returns an empty {@code Optional} if {@code cmd} is executed successfully, otherwise a {@code Optional} with the exception threw.
// *
// * @param cmd
// * @return
// */
// public Optional run(final Try.Consumer super T, ? extends Exception> cmd) {
// try {
// cmd.accept(val);
// return Optional.empty();
// } catch (Exception e) {
// return Optional.of(e);
// }
// }
//
// /**
// * Returns a {@code Pair} with {@code left=returnedValue, right=null} if {@code cmd} is executed successfully, otherwise a {@code Pair} with {@code left=null, right=exception}.
// *
// * @param cmd
// * @return
// */
// public Pair call(final Try.Function super T, R, ? extends Exception> cmd) {
// try {
// return Pair.of(cmd.apply(val), null);
// } catch (Exception e) {
// return Pair.of(null, e);
// }
// }
//
// /**
// * Returns a {@code Nullable} with the value returned by {@code action} or an empty {@code Nullable} if exception happens.
// *
// * @param cmd
// * @return
// */
// public Nullable tryOrEmpty(final Try.Function super T, R, ? extends Exception> cmd) {
// try {
// return Nullable.of(cmd.apply(val));
// } catch (Exception e) {
// return Nullable. empty();
// }
// }
/**
* The Class BooleanListBuilder.
*/
public static final class BooleanListBuilder extends Builder {
/**
* Instantiates a new boolean list builder.
*
* @param val
*/
BooleanListBuilder(BooleanList val) {
super(val);
}
/**
*
* @param index
* @param e
* @return
*/
public BooleanListBuilder set(int index, boolean e) {
val.set(index, e);
return this;
}
/**
*
* @param e
* @return
*/
public BooleanListBuilder add(boolean e) {
val.add(e);
return this;
}
/**
*
* @param index
* @param e
* @return
*/
public BooleanListBuilder add(int index, boolean e) {
val.add(index, e);
return this;
}
/**
* Adds the all.
*
* @param c
* @return
*/
public BooleanListBuilder addAll(BooleanList c) {
val.addAll(c);
return this;
}
/**
* Adds the all.
*
* @param index
* @param c
* @return
*/
public BooleanListBuilder addAll(int index, BooleanList c) {
val.addAll(index, c);
return this;
}
/**
*
* @param e
* @return
*/
public BooleanListBuilder remove(boolean e) {
val.remove(e);
return this;
}
// public BooleanListBuilder removeAllOccurrences(double e) {
// value.removeAllOccurrences(e);
//
// return this;
// }
/**
* Removes the all.
*
* @param c
* @return
*/
public BooleanListBuilder removeAll(BooleanList c) {
val.removeAll(c);
return this;
}
}
/**
* The Class CharListBuilder.
*/
public static final class CharListBuilder extends Builder {
/**
* Instantiates a new char list builder.
*
* @param val
*/
CharListBuilder(CharList val) {
super(val);
}
/**
*
* @param index
* @param e
* @return
*/
public CharListBuilder set(int index, char e) {
val.set(index, e);
return this;
}
/**
*
* @param e
* @return
*/
public CharListBuilder add(char e) {
val.add(e);
return this;
}
/**
*
* @param index
* @param e
* @return
*/
public CharListBuilder add(int index, char e) {
val.add(index, e);
return this;
}
/**
* Adds the all.
*
* @param c
* @return
*/
public CharListBuilder addAll(CharList c) {
val.addAll(c);
return this;
}
/**
* Adds the all.
*
* @param index
* @param c
* @return
*/
public CharListBuilder addAll(int index, CharList c) {
val.addAll(index, c);
return this;
}
/**
*
* @param e
* @return
*/
public CharListBuilder remove(char e) {
val.remove(e);
return this;
}
// public CharListBuilder removeAllOccurrences(double e) {
// value.removeAllOccurrences(e);
//
// return this;
// }
/**
* Removes the all.
*
* @param c
* @return
*/
public CharListBuilder removeAll(CharList c) {
val.removeAll(c);
return this;
}
}
/**
* The Class ByteListBuilder.
*/
public static final class ByteListBuilder extends Builder {
/**
* Instantiates a new byte list builder.
*
* @param val
*/
ByteListBuilder(ByteList val) {
super(val);
}
/**
*
* @param index
* @param e
* @return
*/
public ByteListBuilder set(int index, byte e) {
val.set(index, e);
return this;
}
/**
*
* @param e
* @return
*/
public ByteListBuilder add(byte e) {
val.add(e);
return this;
}
/**
*
* @param index
* @param e
* @return
*/
public ByteListBuilder add(int index, byte e) {
val.add(index, e);
return this;
}
/**
* Adds the all.
*
* @param c
* @return
*/
public ByteListBuilder addAll(ByteList c) {
val.addAll(c);
return this;
}
/**
* Adds the all.
*
* @param index
* @param c
* @return
*/
public ByteListBuilder addAll(int index, ByteList c) {
val.addAll(index, c);
return this;
}
/**
*
* @param e
* @return
*/
public ByteListBuilder remove(byte e) {
val.remove(e);
return this;
}
// public ByteListBuilder removeAllOccurrences(double e) {
// value.removeAllOccurrences(e);
//
// return this;
// }
/**
* Removes the all.
*
* @param c
* @return
*/
public ByteListBuilder removeAll(ByteList c) {
val.removeAll(c);
return this;
}
}
/**
* The Class ShortListBuilder.
*/
public static final class ShortListBuilder extends Builder {
/**
* Instantiates a new short list builder.
*
* @param val
*/
ShortListBuilder(ShortList val) {
super(val);
}
/**
*
* @param index
* @param e
* @return
*/
public ShortListBuilder set(int index, short e) {
val.set(index, e);
return this;
}
/**
*
* @param e
* @return
*/
public ShortListBuilder add(short e) {
val.add(e);
return this;
}
/**
*
* @param index
* @param e
* @return
*/
public ShortListBuilder add(int index, short e) {
val.add(index, e);
return this;
}
/**
* Adds the all.
*
* @param c
* @return
*/
public ShortListBuilder addAll(ShortList c) {
val.addAll(c);
return this;
}
/**
* Adds the all.
*
* @param index
* @param c
* @return
*/
public ShortListBuilder addAll(int index, ShortList c) {
val.addAll(index, c);
return this;
}
/**
*
* @param e
* @return
*/
public ShortListBuilder remove(short e) {
val.remove(e);
return this;
}
// public ShortListBuilder removeAllOccurrences(double e) {
// value.removeAllOccurrences(e);
//
// return this;
// }
/**
* Removes the all.
*
* @param c
* @return
*/
public ShortListBuilder removeAll(ShortList c) {
val.removeAll(c);
return this;
}
}
/**
* The Class IntListBuilder.
*/
public static final class IntListBuilder extends Builder {
/**
* Instantiates a new int list builder.
*
* @param val
*/
IntListBuilder(IntList val) {
super(val);
}
/**
*
* @param index
* @param e
* @return
*/
public IntListBuilder set(int index, int e) {
val.set(index, e);
return this;
}
/**
*
* @param e
* @return
*/
public IntListBuilder add(int e) {
val.add(e);
return this;
}
/**
*
* @param index
* @param e
* @return
*/
public IntListBuilder add(int index, int e) {
val.add(index, e);
return this;
}
/**
* Adds the all.
*
* @param c
* @return
*/
public IntListBuilder addAll(IntList c) {
val.addAll(c);
return this;
}
/**
* Adds the all.
*
* @param index
* @param c
* @return
*/
public IntListBuilder addAll(int index, IntList c) {
val.addAll(index, c);
return this;
}
/**
*
* @param e
* @return
*/
public IntListBuilder remove(int e) {
val.remove(e);
return this;
}
// public IntListBuilder removeAllOccurrences(double e) {
// value.removeAllOccurrences(e);
//
// return this;
// }
/**
* Removes the all.
*
* @param c
* @return
*/
public IntListBuilder removeAll(IntList c) {
val.removeAll(c);
return this;
}
}
/**
* The Class LongListBuilder.
*/
public static final class LongListBuilder extends Builder {
/**
* Instantiates a new long list builder.
*
* @param val
*/
LongListBuilder(LongList val) {
super(val);
}
/**
*
* @param index
* @param e
* @return
*/
public LongListBuilder set(int index, long e) {
val.set(index, e);
return this;
}
/**
*
* @param e
* @return
*/
public LongListBuilder add(long e) {
val.add(e);
return this;
}
/**
*
* @param index
* @param e
* @return
*/
public LongListBuilder add(int index, long e) {
val.add(index, e);
return this;
}
/**
* Adds the all.
*
* @param c
* @return
*/
public LongListBuilder addAll(LongList c) {
val.addAll(c);
return this;
}
/**
* Adds the all.
*
* @param index
* @param c
* @return
*/
public LongListBuilder addAll(int index, LongList c) {
val.addAll(index, c);
return this;
}
/**
*
* @param e
* @return
*/
public LongListBuilder remove(long e) {
val.remove(e);
return this;
}
// public LongListBuilder removeAllOccurrences(double e) {
// value.removeAllOccurrences(e);
//
// return this;
// }
/**
* Removes the all.
*
* @param c
* @return
*/
public LongListBuilder removeAll(LongList c) {
val.removeAll(c);
return this;
}
}
/**
* The Class FloatListBuilder.
*/
public static final class FloatListBuilder extends Builder {
/**
* Instantiates a new float list builder.
*
* @param val
*/
FloatListBuilder(FloatList val) {
super(val);
}
/**
*
* @param index
* @param e
* @return
*/
public FloatListBuilder set(int index, float e) {
val.set(index, e);
return this;
}
/**
*
* @param e
* @return
*/
public FloatListBuilder add(float e) {
val.add(e);
return this;
}
/**
*
* @param index
* @param e
* @return
*/
public FloatListBuilder add(int index, float e) {
val.add(index, e);
return this;
}
/**
* Adds the all.
*
* @param c
* @return
*/
public FloatListBuilder addAll(FloatList c) {
val.addAll(c);
return this;
}
/**
* Adds the all.
*
* @param index
* @param c
* @return
*/
public FloatListBuilder addAll(int index, FloatList c) {
val.addAll(index, c);
return this;
}
/**
*
* @param e
* @return
*/
public FloatListBuilder remove(float e) {
val.remove(e);
return this;
}
// public FloatListBuilder removeAllOccurrences(double e) {
// value.removeAllOccurrences(e);
//
// return this;
// }
/**
* Removes the all.
*
* @param c
* @return
*/
public FloatListBuilder removeAll(FloatList c) {
val.removeAll(c);
return this;
}
}
/**
* The Class DoubleListBuilder.
*/
public static final class DoubleListBuilder extends Builder {
/**
* Instantiates a new double list builder.
*
* @param val
*/
DoubleListBuilder(DoubleList val) {
super(val);
}
/**
*
* @param index
* @param e
* @return
*/
public DoubleListBuilder set(int index, double e) {
val.set(index, e);
return this;
}
/**
*
* @param e
* @return
*/
public DoubleListBuilder add(double e) {
val.add(e);
return this;
}
/**
*
* @param index
* @param e
* @return
*/
public DoubleListBuilder add(int index, double e) {
val.add(index, e);
return this;
}
/**
* Adds the all.
*
* @param c
* @return
*/
public DoubleListBuilder addAll(DoubleList c) {
val.addAll(c);
return this;
}
/**
* Adds the all.
*
* @param index
* @param c
* @return
*/
public DoubleListBuilder addAll(int index, DoubleList c) {
val.addAll(index, c);
return this;
}
/**
*
* @param e
* @return
*/
public DoubleListBuilder remove(double e) {
val.remove(e);
return this;
}
// public DoubleListBuilder removeAllOccurrences(double e) {
// value.removeAllOccurrences(e);
//
// return this;
// }
/**
* Removes the all.
*
* @param c
* @return
*/
public DoubleListBuilder removeAll(DoubleList c) {
val.removeAll(c);
return this;
}
}
/**
* The Class ListBuilder.
*
* @param
* @param
*/
public static final class ListBuilder> extends CollectionBuilder {
/**
* Instantiates a new list builder.
*
* @param c
*/
ListBuilder(L c) {
super(c);
}
/**
*
* @param index
* @param e
* @return
*/
public ListBuilder add(int index, T e) {
val.add(index, e);
return this;
}
/**
* Adds the all.
*
* @param index
* @param c
* @return
*/
public ListBuilder addAll(int index, Collection extends T> c) {
N.checkIndex(index, val.size());
if (N.notNullOrEmpty(c)) {
val.addAll(index, c);
}
return this;
}
/**
*
* @param index
* @return
*/
public ListBuilder remove(int index) {
val.remove(index);
return this;
}
}
/**
* The Class CollectionBuilder.
*
* @param
* @param
*/
public static class CollectionBuilder> extends Builder {
/**
* Instantiates a new collection builder.
*
* @param c
*/
CollectionBuilder(C c) {
super(c);
}
/**
*
* @param e
* @return
*/
public CollectionBuilder add(T e) {
val.add(e);
return this;
}
/**
* Adds the all.
*
* @param c
* @return
*/
public CollectionBuilder addAll(final Collection extends T> c) {
if (N.notNullOrEmpty(c)) {
val.addAll(c);
}
return this;
}
/**
*
* @param e
* @return
*/
public CollectionBuilder remove(Object e) {
val.remove(e);
return this;
}
/**
* Removes the all.
*
* @param c
* @return
*/
public CollectionBuilder removeAll(Collection> c) {
if (N.notNullOrEmpty(c)) {
val.removeAll(c);
}
return this;
}
}
/**
* The Class MultisetBuilder.
*
* @param
*/
public static final class MultisetBuilder extends Builder> {
/**
* Instantiates a new multiset builder.
*
* @param c
*/
MultisetBuilder(Multiset c) {
super(c);
}
/**
*
* @param e
* @return
*/
public MultisetBuilder add(T e) {
val.add(e);
return this;
}
/**
* Adds the all.
*
* @param c
* @return
*/
public MultisetBuilder addAll(final Collection extends T> c) {
val.addAll(c);
return this;
}
/**
* Adds the all.
*
* @param m
* @return
*/
public MultisetBuilder addAll(final Map extends T, Integer> m) {
val.addAll(m);
return this;
}
/**
* Adds the all.
*
* @param multiset
* @return
*/
public MultisetBuilder addAll(final Multiset extends T> multiset) {
val.addAll(multiset);
return this;
}
/**
*
* @param e
* @return
*/
public MultisetBuilder remove(Object e) {
val.remove(e);
return this;
}
/**
* Removes the all.
*
* @param c
* @return
*/
public MultisetBuilder removeAll(Collection> c) {
val.removeAll(c);
return this;
}
/**
* Removes the all.
*
* @param m
* @return
*/
public MultisetBuilder removeAll(final Map extends T, Integer> m) {
val.removeAll(m);
return this;
}
/**
* Removes the all.
*
* @param multiset
* @return
*/
public MultisetBuilder removeAll(Multiset extends T> multiset) {
val.removeAll(multiset);
return this;
}
}
/**
* The Class LongMultisetBuilder.
*
* @param
*/
public static final class LongMultisetBuilder extends Builder> {
/**
* Instantiates a new long multiset builder.
*
* @param c
*/
LongMultisetBuilder(LongMultiset c) {
super(c);
}
/**
*
* @param e
* @return
*/
public LongMultisetBuilder add(T e) {
val.add(e);
return this;
}
/**
* Adds the all.
*
* @param c
* @return
*/
public LongMultisetBuilder addAll(final Collection extends T> c) {
val.addAll(c);
return this;
}
/**
* Adds the all.
*
* @param m
* @return
*/
public LongMultisetBuilder addAll(final Map extends T, Long> m) {
val.addAll(m);
return this;
}
/**
* Adds the all.
*
* @param multiset
* @return
*/
public LongMultisetBuilder addAll(final LongMultiset extends T> multiset) {
val.addAll(multiset);
return this;
}
/**
*
* @param e
* @return
*/
public LongMultisetBuilder remove(Object e) {
val.remove(e);
return this;
}
/**
* Removes the all.
*
* @param c
* @return
*/
public LongMultisetBuilder removeAll(Collection> c) {
val.removeAll(c);
return this;
}
/**
* Removes the all.
*
* @param m
* @return
*/
public LongMultisetBuilder removeAll(final Map extends T, Long> m) {
val.removeAll(m);
return this;
}
/**
* Removes the all.
*
* @param multiset
* @return
*/
public LongMultisetBuilder removeAll(LongMultiset extends T> multiset) {
val.removeAll(multiset);
return this;
}
}
/**
* The Class MapBuilder.
*
* @param the key type
* @param the value type
* @param
*/
public static final class MapBuilder> extends Builder {
/**
* Instantiates a new map builder.
*
* @param m
*/
MapBuilder(M m) {
super(m);
}
/**
*
* @param k
* @param v
* @return
*/
public MapBuilder put(K k, V v) {
val.put(k, v);
return this;
}
/**
*
* @param m
* @return
*/
public MapBuilder putAll(Map extends K, ? extends V> m) {
if (N.notNullOrEmpty(m)) {
val.putAll(m);
}
return this;
}
/**
* Put if absent.
*
* @param key
* @param value
* @return
*/
public MapBuilder putIfAbsent(K key, V value) {
V v = val.get(key);
if (v == null) {
v = val.put(key, value);
}
return this;
}
/**
* Put if absent.
*
* @param key
* @param supplier
* @return
*/
public MapBuilder putIfAbsent(K key, Supplier supplier) {
V v = val.get(key);
if (v == null) {
v = val.put(key, supplier.get());
}
return this;
}
/**
*
* @param k
* @return
*/
public MapBuilder remove(Object k) {
val.remove(k);
return this;
}
/**
* Removes the all.
*
* @param keysToRemove
* @return
*/
public MapBuilder removeAll(Collection> keysToRemove) {
if (N.notNullOrEmpty(keysToRemove)) {
for (Object k : keysToRemove) {
val.remove(k);
}
}
return this;
}
}
/**
* The Class MultimapBuilder.
*
* @param the key type
* @param
* @param the value type
* @param
*/
public static final class MultimapBuilder, M extends Multimap> extends Builder {
/**
* Instantiates a new multimap builder.
*
* @param m
*/
MultimapBuilder(M m) {
super(m);
}
/**
*
* @param key
* @param e
* @return
*/
public MultimapBuilder put(K key, E e) {
val.put(key, e);
return this;
}
/**
*
* @param k
* @param c
* @return
*/
public MultimapBuilder putAll(final K k, final Collection extends E> c) {
val.putAll(k, c);
return this;
}
/**
*
* @param m
* @return
*/
public MultimapBuilder putAll(Map extends K, ? extends E> m) {
val.putAll(m);
return this;
}
/**
*
* @param m
* @return
*/
public MultimapBuilder putAll(Multimap extends K, ? extends E, ? extends V> m) {
val.putAll(m);
return this;
}
/**
*
* @param k
* @param e
* @return
*/
public MultimapBuilder remove(Object k, Object e) {
val.remove(k, e);
return this;
}
/**
* Removes the all.
*
* @param k
* @return
*/
public MultimapBuilder removeAll(Object k) {
val.removeAll(k);
return this;
}
/**
* Removes the all.
*
* @param k
* @param valuesToRemove
* @return
*/
public MultimapBuilder removeAll(Object k, Collection> valuesToRemove) {
val.removeAll(k, valuesToRemove);
return this;
}
/**
* Removes the all.
*
* @param m
* @return
*/
public MultimapBuilder removeAll(Map extends K, ? extends E> m) {
val.removeAll(m);
return this;
}
/**
* Removes the all.
*
* @param m
* @return
*/
public MultimapBuilder removeAll(Multimap, ?, ?> m) {
val.removeAll(m);
return this;
}
}
/**
* The Class DataSetBuilder.
*/
public static final class DataSetBuilder extends Builder {
/**
* Instantiates a new data set builder.
*
* @param ds
*/
DataSetBuilder(DataSet ds) {
super(ds);
}
/**
*
* @param columnName
* @param newColumnName
* @return
*/
public DataSetBuilder renameColumn(String columnName, String newColumnName) {
val.renameColumn(columnName, newColumnName);
return this;
}
/**
*
* @param oldNewNames
* @return
*/
public DataSetBuilder renameColumns(Map oldNewNames) {
val.renameColumns(oldNewNames);
return this;
}
/**
*
* @param
* @param columnName
* @param func
* @return
* @throws E the e
*/
public DataSetBuilder renameColumn(String columnName, Throwables.Function func) throws E {
val.renameColumn(columnName, func);
return this;
}
/**
*
* @param
* @param columnNames
* @param func
* @return
* @throws E the e
*/
public DataSetBuilder renameColumns(Collection columnNames, Throwables.Function func) throws E {
val.renameColumns(columnNames, func);
return this;
}
/**
*
* @param
* @param func
* @return
* @throws E the e
*/
public DataSetBuilder renameColumns(Throwables.Function func) throws E {
val.renameColumns(func);
return this;
}
/**
* Adds the column.
*
* @param columnName
* @param column
* @return
*/
public DataSetBuilder addColumn(String columnName, List> column) {
val.addColumn(columnName, column);
return this;
}
/**
* Adds the column.
*
* @param columnIndex
* @param columnName
* @param column
* @return
*/
public DataSetBuilder addColumn(int columnIndex, String columnName, List> column) {
val.addColumn(columnIndex, columnName, column);
return this;
}
/**
* Adds the column.
*
* @param
* @param
* @param newColumnName
* @param fromColumnName
* @param func
* @return
* @throws E the e
*/
public DataSetBuilder addColumn(String newColumnName, String fromColumnName, Throwables.Function func) throws E {
val.addColumn(newColumnName, fromColumnName, func);
return this;
}
/**
* Adds the column.
*
* @param
* @param
* @param columnIndex
* @param newColumnName
* @param fromColumnName
* @param func
* @return
* @throws E the e
*/
public DataSetBuilder addColumn(int columnIndex, String newColumnName, String fromColumnName,
Throwables.Function func) throws E {
val.addColumn(columnIndex, newColumnName, fromColumnName, func);
return this;
}
/**
* Adds the column.
*
* @param
* @param newColumnName
* @param fromColumnNames
* @param func
* @return
* @throws E the e
*/
public DataSetBuilder addColumn(String newColumnName, Collection fromColumnNames,
Throwables.Function super DisposableObjArray, ?, E> func) throws E {
val.addColumn(newColumnName, fromColumnNames, func);
return this;
}
/**
* Adds the column.
*
* @param
* @param columnIndex
* @param newColumnName
* @param fromColumnNames
* @param func
* @return
* @throws E the e
*/
public DataSetBuilder addColumn(int columnIndex, String newColumnName, Collection fromColumnNames,
Throwables.Function super DisposableObjArray, ?, E> func) throws E {
val.addColumn(columnIndex, newColumnName, fromColumnNames, func);
return this;
}
/**
* Adds the column.
*
* @param
* @param newColumnName
* @param fromColumnNames
* @param func
* @return
* @throws E the e
*/
public DataSetBuilder addColumn(String newColumnName, Tuple2 fromColumnNames,
Throwables.BiFunction, ?, ?, E> func) throws E {
val.addColumn(newColumnName, fromColumnNames, func);
return this;
}
/**
* Adds the column.
*
* @param
* @param columnIndex
* @param newColumnName
* @param fromColumnNames
* @param func
* @return
* @throws E the e
*/
public DataSetBuilder addColumn(int columnIndex, String newColumnName, Tuple2 fromColumnNames,
Throwables.BiFunction, ?, ?, E> func) throws E {
val.addColumn(columnIndex, newColumnName, fromColumnNames, func);
return this;
}
/**
* Adds the column.
*
* @param
* @param newColumnName
* @param fromColumnNames
* @param func
* @return
* @throws E the e
*/
public DataSetBuilder addColumn(String newColumnName, Tuple3 fromColumnNames,
Throwables.TriFunction, ?, ?, ?, E> func) throws E {
val.addColumn(newColumnName, fromColumnNames, func);
return this;
}
/**
* Adds the column.
*
* @param
* @param columnIndex
* @param newColumnName
* @param fromColumnNames
* @param func
* @return
* @throws E the e
*/
public DataSetBuilder addColumn(int columnIndex, String newColumnName, Tuple3 fromColumnNames,
Throwables.TriFunction, ?, ?, ?, E> func) throws E {
val.addColumn(columnIndex, newColumnName, fromColumnNames, func);
return this;
}
/**
* Removes the column.
*
* @param columnName
* @return
*/
public DataSetBuilder removeColumn(String columnName) {
val.removeColumn(columnName);
return this;
}
/**
* Removes the columns.
*
* @param columnNames
* @return
*/
public DataSetBuilder removeColumns(Collection columnNames) {
val.removeColumns(columnNames);
return this;
}
/**
* Removes the columns.
*
* @param
* @param filter
* @return
* @throws E the e
*/
public DataSetBuilder removeColumns(Predicate filter) throws E {
val.removeColumns(filter);
return this;
}
// /**
// * Removes the columns if.
// *
// * @param
// * @param filter
// * @return
// * @throws E the e
// * @deprecated replaced by {@code removeColumns}.
// */
// @Deprecated
// public DataSetBuilder removeColumnsIf(Predicate filter) throws E {
// val.removeColumnsIf(filter);
//
// return this;
// }
/**
*
* @param
* @param
* @param columnName
* @param func
* @return
* @throws E the e
*/
public DataSetBuilder updateColumn(String columnName, Throwables.Function func) throws E {
val.updateColumn(columnName, func);
return this;
}
/**
*
* @param
* @param
* @param columnNames
* @param func
* @return
* @throws E the e
*/
public DataSetBuilder updateColumns(Collection columnNames, Throwables.Function, ?, E> func) throws E {
val.updateColumns(columnNames, func);
return this;
}
/**
*
* @param columnName
* @param targetType
* @return
*/
public DataSetBuilder convertColumn(String columnName, Class> targetType) {
val.convertColumn(columnName, targetType);
return this;
}
/**
*
* @param columnTargetTypes
* @return
*/
public DataSetBuilder convertColumns(Map> columnTargetTypes) {
val.convertColumns(columnTargetTypes);
return this;
}
/**
*
* @param columnNames
* @param newColumnName
* @param newColumnClass
* @return
*/
public DataSetBuilder combineColumns(Collection columnNames, String newColumnName, Class> newColumnClass) {
val.combineColumns(columnNames, newColumnName, newColumnClass);
return this;
}
/**
*
* @param
* @param columnNames
* @param newColumnName
* @param combineFunc
* @return
* @throws E the e
*/
public DataSetBuilder combineColumns(Collection columnNames, String newColumnName,
Throwables.Function super DisposableObjArray, ?, E> combineFunc) throws E {
val.combineColumns(columnNames, newColumnName, combineFunc);
return this;
}
/**
*
* @param
* @param columnNames
* @param newColumnName
* @param combineFunc
* @return
* @throws E the e
*/
public DataSetBuilder combineColumns(Tuple2 columnNames, String newColumnName,
Throwables.BiFunction, ?, ?, E> combineFunc) throws E {
val.combineColumns(columnNames, newColumnName, combineFunc);
return this;
}
/**
*
* @param
* @param columnNames
* @param newColumnName
* @param combineFunc
* @return
* @throws E the e
*/
public DataSetBuilder combineColumns(Tuple3 columnNames, String newColumnName,
Throwables.TriFunction, ?, ?, ?, E> combineFunc) throws E {
val.combineColumns(columnNames, newColumnName, combineFunc);
return this;
}
/**
*
* @param
* @param columnNameFilter
* @param newColumnName
* @param newColumnClass
* @return
* @throws E the e
*/
public DataSetBuilder combineColumns(Throwables.Predicate columnNameFilter, String newColumnName,
Class> newColumnClass) throws E {
val.combineColumns(columnNameFilter, newColumnName, newColumnClass);
return this;
}
/**
*
* @param
* @param
* @param columnNameFilter
* @param newColumnName
* @param combineFunc
* @return
* @throws E the e
* @throws E2 the e2
*/
public DataSetBuilder combineColumns(Throwables.Predicate columnNameFilter, String newColumnName,
Throwables.Function super DisposableObjArray, ?, E2> combineFunc) throws E, E2 {
val.combineColumns(columnNameFilter, newColumnName, combineFunc);
return this;
}
/**
*
* @param
* @param
* @param columnName
* @param newColumnNames
* @param divideFunc
* @return
* @throws E the e
*/
public DataSetBuilder divideColumn(String columnName, Collection newColumnNames,
Throwables.Function, E> divideFunc) throws E {
val.divideColumn(columnName, newColumnNames, divideFunc);
return this;
}
/**
*
* @param
* @param
* @param columnName
* @param newColumnNames
* @param output
* @return
* @throws E the e
*/
public DataSetBuilder divideColumn(String columnName, Collection newColumnNames,
Throwables.BiConsumer output) throws E {
val.divideColumn(columnName, newColumnNames, output);
return this;
}
/**
*
* @param
* @param
* @param columnName
* @param newColumnNames
* @param output
* @return
* @throws E the e
*/
public DataSetBuilder divideColumn(String columnName, Tuple2 newColumnNames,
Throwables.BiConsumer, E> output) throws E {
val.divideColumn(columnName, newColumnNames, output);
return this;
}
/**
*
* @param
* @param
* @param columnName
* @param newColumnNames
* @param output
* @return
* @throws E the e
*/
public DataSetBuilder divideColumn(String columnName, Tuple3 newColumnNames,
Throwables.BiConsumer, E> output) throws E {
val.divideColumn(columnName, newColumnNames, output);
return this;
}
/**
*
* @param
* @param func
* @return
* @throws E the e
*/
public DataSetBuilder updateAll(Throwables.Function, ?, E> func) throws E {
val.updateAll(func);
return this;
}
/**
*
* @param
* @param func
* @param newValue
* @return
* @throws E the e
*/
public DataSetBuilder replaceIf(Throwables.Predicate, E> func, Object newValue) throws E {
val.replaceIf(func, newValue);
return this;
}
/**
*
* @param columnName
* @return
*/
public DataSetBuilder sortBy(String columnName) {
val.sortBy(columnName);
return this;
}
/**
*
* @param
* @param columnName
* @param cmp
* @return
*/
public DataSetBuilder sortBy(String columnName, Comparator cmp) {
val.sortBy(columnName, cmp);
return this;
}
/**
*
* @param columnNames
* @return
*/
public DataSetBuilder sortBy(Collection columnNames) {
val.sortBy(columnNames);
return this;
}
/**
*
* @param columnNames
* @param cmp
* @return
*/
public DataSetBuilder sortBy(Collection columnNames, Comparator super Object[]> cmp) {
val.sortBy(columnNames, cmp);
return this;
}
/**
*
* @param columnNames
* @param keyMapper
* @return
*/
@SuppressWarnings("rawtypes")
public DataSetBuilder sortBy(Collection columnNames, Function super DisposableObjArray, ? extends Comparable> keyMapper) {
val.sortBy(columnNames, keyMapper);
return this;
}
/**
* Parallel sort by.
*
* @param columnName
* @return
*/
public DataSetBuilder parallelSortBy(String columnName) {
val.parallelSortBy(columnName);
return this;
}
/**
* Parallel sort by.
*
* @param
* @param columnName
* @param cmp
* @return
*/
public DataSetBuilder parallelSortBy(String columnName, Comparator cmp) {
val.parallelSortBy(columnName, cmp);
return this;
}
/**
* Parallel sort by.
*
* @param columnNames
* @return
*/
public DataSetBuilder parallelSortBy(Collection columnNames) {
val.parallelSortBy(columnNames);
return this;
}
/**
* Parallel sort by.
*
* @param columnNames
* @param cmp
* @return
*/
public DataSetBuilder parallelSortBy(Collection columnNames, Comparator super Object[]> cmp) {
val.parallelSortBy(columnNames, cmp);
return this;
}
/**
* Parallel sort by.
*
* @param columnNames
* @param keyMapper
* @return
*/
@SuppressWarnings("rawtypes")
public DataSetBuilder parallelSortBy(Collection columnNames, Function super DisposableObjArray, ? extends Comparable> keyMapper) {
val.parallelSortBy(columnNames, keyMapper);
return this;
}
}
/**
* The Class X.
*
* @param
*/
public static final class X