software.amazon.awssdk.utils.builder.SdkBuilder Maven / Gradle / Ivy
/*
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file 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 software.amazon.awssdk.utils.builder;
import java.util.function.Consumer;
import software.amazon.awssdk.annotations.SdkPublicApi;
/**
* A mutable object that can be used to create an immutable object of type T.
*
* @param the builder type (this)
* @param the type that the builder will build
*/
@SdkPublicApi
public interface SdkBuilder, T> extends Buildable {
/**
* An immutable object that is created from the
* properties that have been set on the builder.
*
* @return an instance of T
*/
@Override
T build();
/**
* A convenience operator that takes something that will
* mutate the builder in some way and allows inclusion of it
* in chaining operations. For example instead of:
*
*
* Builder builder = ClassBeingBuilt.builder();
* builder = Util.addSomeDetailToTheBuilder(builder);
* ClassBeingBuilt clz = builder.build();
*
*
* This can be done in a statement:
*
*
* ClassBeingBuilt = ClassBeingBuilt.builder().applyMutation(Util::addSomeDetailToTheBuilder).build();
*
*
* @param mutator the function that mutates the builder
* @return B the mutated builder instance
*/
@SuppressWarnings("unchecked")
default B applyMutation(Consumer mutator) {
mutator.accept((B) this);
return (B) this;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy