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

io.lettuce.core.CompositeArgument Maven / Gradle / Ivy

Go to download

Advanced and thread-safe Java Redis client for synchronous, asynchronous, and reactive usage. Supports Cluster, Sentinel, Pipelining, Auto-Reconnect, Codecs and much more.

The newest version!
/*
 * Copyright 2011-Present, Redis Ltd. and Contributors
 * All rights reserved.
 *
 * Licensed under the MIT License.
 *
 * This file contains contributions from third-party contributors
 * 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
 *
 *      https://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 io.lettuce.core;

import io.lettuce.core.protocol.CommandArgs;

/**
 * Interface for composite command argument objects. Implementing classes of {@link CompositeArgument} consolidate multiple
 * arguments for a particular Redis command in to one type and reduce the amount of individual arguments passed in a method
 * signature.
 * 

* Command builder call {@link #build(CommandArgs)} during command construction to contribute command arguments for command * invocation. A composite argument is usually stateless as it can be reused multiple times by different commands. * * @author Mark Paluch * @since 5.0 * @see CommandArgs * @see SetArgs * @see ZAggregateArgs * @see GeoArgs */ public interface CompositeArgument { /** * Build command arguments and contribute arguments to {@link CommandArgs}. *

* Implementing classes are required to implement this method. Depending on the command nature and configured arguments, * this method may contribute arguments but is not required to add arguments if none are specified. * * @param args the command arguments, must not be {@code null}. * @param Key type. * @param Value type. */ void build(CommandArgs args); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy