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

com.google.common.collect.BstMutationRule Maven / Gradle / Ivy

There is a newer version: 3.9
Show newest version
/*
 * Copyright (C) 2011 The Guava Authors
 *
 * 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.google.common.collect;

import static com.google.common.base.Preconditions.checkNotNull;

import com.google.common.annotations.GwtCompatible;

/**
 * A rule for a local mutation to a binary search tree, that changes at most one entry. In addition
 * to specifying how it modifies a particular entry via a {@code BstModifier}, it specifies a
 * {@link BstBalancePolicy} for rebalancing the tree after the modification is performed and a
 * {@link BstNodeFactory} for constructing newly rebalanced nodes.
 *
 * @author Louis Wasserman
 * @param  The key type of the nodes in binary search trees that this rule can modify.
 * @param  The type of the nodes in binary search trees that this rule can modify.
 */
@GwtCompatible
final class BstMutationRule> {
  /**
   * Constructs a {@code BstMutationRule} with the specified modifier, balance policy, and node
   * factory.
   */
  public static > BstMutationRule createRule(
      BstModifier modifier, BstBalancePolicy balancePolicy,
      BstNodeFactory nodeFactory) {
    return new BstMutationRule(modifier, balancePolicy, nodeFactory);
  }

  private final BstModifier modifier;
  private final BstBalancePolicy balancePolicy;
  private final BstNodeFactory nodeFactory;

  private BstMutationRule(BstModifier modifier, BstBalancePolicy balancePolicy,
      BstNodeFactory nodeFactory) {
    this.balancePolicy = checkNotNull(balancePolicy);
    this.nodeFactory = checkNotNull(nodeFactory);
    this.modifier = checkNotNull(modifier);
  }

  /**
   * Returns the {@link BstModifier} that specifies the change to a targeted entry in a binary
   * search tree.
   */
  public BstModifier getModifier() {
    return modifier;
  }

  /**
   * Returns the policy used to rebalance nodes in the tree after this modification has been
   * performed.
   */
  public BstBalancePolicy getBalancePolicy() {
    return balancePolicy;
  }

  /**
   * Returns the node factory used to create new nodes in the tree after this modification has been
   * performed.
   */
  public BstNodeFactory getNodeFactory() {
    return nodeFactory;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy