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

com.azure.core.implementation.Option Maven / Gradle / Ivy

// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.

package com.azure.core.implementation;

import java.util.NoSuchElementException;
import java.util.Objects;

/**
 * The Option type to describe tri-state. Every Option instance is in one of the three states: a state representing a
 * non-null-value, null-value, or no-value.
 *
 * 

Code sample

* *
 * // An Option with non-null-value.
 * Option<String> skuOption = Option.of("basic");
 * if (skuOption.isInitialized()) {
 *     // Option.isInitialized() returns true because option is initialized with a non-null value.
 *     System.out.println(skuOption.getValue()); // print: "basic"
 * }
 *
 * // An Option with null-value.
 * Option<String> descriptionOption = Option.of(null);
 * if (descriptionOption.isInitialized()) {
 *     // Option.isInitialized() returns true because option is initialized with an explicit null-value.
 *     System.out.println(skuOption.getValue()); // print: null
 * }
 *
 * // An Option with no-value.
 * Option<String> uninitializedOption = Option.uninitialized();
 * if (!uninitializedOption.isInitialized()) {
 *     // Option.isInitialized() returns false because option is uninitialized.
 *     System.out.println("not initialized");
 * }
 *
 * // Attempting to access the value when an option has no-value will throw 'NoSuchElementException'
 * try {
 *     uninitializedOption.getValue();
 * } catch (NoSuchElementException exception) {
 *     System.out.println(exception.getMessage()); // print: 'No value initialized'
 * }
 * 
* * * @param The value type. */ public final class Option { private static final Option UNINITIALIZED = new Option<>(); private static final Option EMPTY = new Option<>(null); private final boolean isInitialized; private final T value; /** * Returns an {@link Option} with the specified null-value or non-null-value. * * @param The value type. * @param value the value. * @return an {@link Option} with the value present. */ public static Option of(T value) { return value == null ? empty() : new Option<>(value); } /** * Returns an {@link Option} with null-value. *

* {@code Option.empty()} is a syntactic sugar for {@code Option.of(null)}. *

* * @param The value type. * @return an {@link Option} with a null-value. */ public static Option empty() { @SuppressWarnings("unchecked") Option empty = (Option) EMPTY; return empty; } /** * Returns an {@link Option} instance with no-value. * * @param Type of the non-existent value. * @return An Option type with no-value. */ public static Option uninitialized() { @SuppressWarnings("unchecked") Option uninitialized = (Option) UNINITIALIZED; return uninitialized; } /** * Return {@code true} if this instance is initialized with a null-value or non-null-value, otherwise {@code * false}. * * @return {@code true} if a value has been initialized, otherwise {@code false} */ public boolean isInitialized() { return this.isInitialized; } /** * Gets the value in the {@link Option}. * * @return The {@code null} (null-value) or non-null-value that the {@link Option} is initialized with. * @throws NoSuchElementException thrown if the {@link Option} is in no-value state. */ public T getValue() { if (!this.isInitialized) { throw new NoSuchElementException("No value initialized"); } return this.value; } /** * Indicates whether some other object is "equal to" this Option. The other object is considered equal if: *
    *
  • it is also an {@code Option} and; *
  • both instances are not initialized or; *
  • both instances are initialized and values are "equal to" each other via {@code equals()}. *
* * @param obj an object to be tested for equality * @return {code true} if the other object is "equal to" this object otherwise {@code false} */ @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (!(obj instanceof Option)) { return false; } Option other = (Option) obj; if (this.isInitialized ^ other.isInitialized) { // one is 'initialized' and the other one is not. return false; } // both are 'initialized' or 'not-initialized'. return Objects.equals(value, other.value); } /** * Returns hash code of the value this Option is initialized with or -1 if in uninitialized state. *

* The value 0 will be returned when initialized with {@code null}. *

* * @return hash code of the value this Option is initialized with or -1 if in uninitialized state. */ @Override public int hashCode() { if (!this.isInitialized) { return -1; } return Objects.hashCode(value); } private Option() { this.isInitialized = false; this.value = null; } private Option(T value) { this.isInitialized = true; this.value = value; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy