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

sirius.kernel.commons.Monoflop Maven / Gradle / Ivy

/*
 * Made with all the love in the world
 * by scireum in Remshalden, Germany
 *
 * Copyright by scireum GmbH
 * http://www.scireum.de - [email protected]
 */

package sirius.kernel.commons;

/**
 * Represents a boolean state variable, which can be toggled once from false to true.
 * 

* All successive calls will not change the internal state, and return constantly true (or respectively). *

* This is particularly useful in loops where the first iteration must be handled differently. Therefore two more * functions are provided: {@link #firstCall()} and {@link #successiveCall()} which can be used like shown here: *

 * {@code
 * Monoflop mono = Monoflop.create();
 * StringBuilder sb = new StringBuilder();
 * for(String value : somelist) {
 *     if (mono.successiveCall()) {
 *         sb.append(", ");
 *     }
 *     sb.append(value);
 * }
 * System.out.println(sb.toString());
 * }
 * 
*/ public class Monoflop { private boolean toggled = false; /* * Use the static constructor create() */ private Monoflop() { } /** * Creates a new monoflop. * * @return a new monoflop which was not toggled yet. */ public static Monoflop create() { return new Monoflop(); } /** * Toggles the monoflop and returns its state before it was toggled. *

* If the monoflop is in its initial state, this will return false (and toggle the monoflop). * Therefore all successive class will return true. * * @return false if the monoflop was not toggled yet, true for all successive calls */ public boolean toggle() { if (toggled) { return true; } toggled = true; return false; } /** * Toggles the monoflop and returns its state before it was toggled. *

* If the monoflop is in its initial state, this will return true (and toggle the monoflop). * Therefore all successive class will return false. * * @return true if the monoflop was not toggled yet, false for all successive calls */ public boolean inverseToggle() { return !toggle(); } /** * Reads and then toggles the monoflop. *

* If the monoflop is in its initial state, this will return true (and toggle the monoflop). * Therefore all successive class will return false. *

* This is just an alias for {@link #inverseToggle()}. * * @return true if the monoflop was not toggled yet, false for all successive calls */ public boolean firstCall() { return inverseToggle(); } /** * Reads and then toggles the monoflop. *

* If the monoflop is in its initial state, this will return false (and toggle the monoflop). * Therefore all successive class will return true. *

* This is just an alias for {@link #toggle()}. * * @return false if the monoflop was not toggled yet, true for all successive calls */ public boolean successiveCall() { return toggle(); } /** * Reads the internal state without toggling it. * * @return false if the monoflop is in its initial state, true otherwise */ public boolean isToggled() { return toggled; } @Override public String toString() { return "Monoflop (Toggled: " + toggled + ")"; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy