Class Unary<A,B>

java.lang.Object
eu.bandm.tools.paisley.Pattern<B>
eu.bandm.tools.paisley.Unary<A,B>
Type Parameters:
A - the target type of the contained subpattern
B - the target type of the containing pattern
All Implemented Interfaces:
Serializable, Cloneable
Direct Known Subclasses:
FlatMultiTransform, Proxy, Transform

public abstract class Unary<A,B> extends Pattern<B>
Abstract base class for patterns that contain one subpattern. Methods have default implementations that delegate to the subpattern.

Subclasses must implement the Pattern.match(A) method.

See Also:
  • Constructor Details

    • Unary

      protected Unary(Pattern<? super A> body)
      Creates a new pattern.
      Parameters:
      body -
      Throws:
      IllegalArgumentException - if body is null.
    • Unary

      protected Unary()
  • Method Details

    • getBody

      public Pattern<A> getBody()
    • setBody

      protected void setBody(Pattern<A> body)
    • clone

      public Pattern<B> clone()
      Description copied from class: Pattern
      Makes a matching-state copy if this pattern.

      Subclasses must override this method if necessary to honour the following rules for all transitively reachable patterns:

      • Subpatterns that are instances of Variable must be shared. This implies that Variable.clone() must return this.
      • Fields that do not refer to subpatterns, but to matching state (changed by invocations of Pattern.match(A), Pattern.matchAgain(), Pattern.cut() or Pattern.clear()) must be duplicated. If matching state changes are effected by modification of other objects, these must be duplicated. In summary, matching operations on this pattern and its copy must not interfere, with the exception of variable bindings.
      • Fields neither referring to subpatterns nor to matching state may be either shared or duplicated. The usage of such fields in a modifiable way (such that the distinction is relevant) is strongly deprecated.
      • Patterns whose fields need not be duplicated need not be duplicated themselves, but may return this.
      Overrides:
      clone in class Pattern<B>
    • matchAgain

      public boolean matchAgain()
      Description copied from class: Pattern
      Attempts to re-match this pattern against a previously matched object. If the class of this pattern imposes a specific order on matches, they are chosen in that order, beginning with the second one. The behaviour of this method is unspecified if the last matching attempt of this pattern has not been successful.

      Patterns classes that do not override this method are deterministic. Pattern classes that overwrite this method to provide additional matches should also override Pattern.isDeterministic().

      Overrides:
      matchAgain in class Pattern<B>
      Returns:
      true if the matching is successful, false if it fails. Which Variables are bound by a successful match depends. The default implementation always returns false.
      See Also:
    • cut

      public void cut(boolean recursively)
      Description copied from class: Pattern
      Disposes of all internal state related to nondeterminism.

      The default implementation does nothing. Subclasses that override this method should also override Pattern.clear(boolean) and ensure that it implies the effect of cut(false).

      Overrides:
      cut in class Pattern<B>
      Parameters:
      recursively - true if all subpatterns should be deactivated, false otherwise.
    • clear

      public void clear(boolean recursively)
      Description copied from class: Pattern
      Disposes of all internal state related to results and nondeterminism.

      The default implementation does nothing.

      Overrides:
      clear in class Pattern<B>
      Parameters:
      recursively - true if all subpatterns should be deactivated, false otherwise.
    • binds

      public boolean binds(Variable<?> variable)
      Description copied from class: Pattern
      Checks whether a variable is bound by this pattern.

      The default implementation returns false.

      Overrides:
      binds in class Pattern<B>
      Parameters:
      variable - a pattern variable
      Returns:
      true if the variable is guaranteed to have a meaningful value when this pattern is open, false otherwise.
    • preserves

      public boolean preserves(Variable<?> variable, boolean success)
      Description copied from class: Pattern
      Checks whether a variable is preserved by this pattern, conditionally on success or failure.

      The default implementation returns false.

      Overrides:
      preserves in class Pattern<B>
      Parameters:
      variable - a pattern variable
      success - specifies preservation on success or failure
      Returns:
      true if the variable value is guaranteed to be unaffected by a matching attempt with this pattern that returns a value equal to success.
    • preserves

      public boolean preserves(Variable<?> variable)
      Description copied from class: Pattern
      Checks whether a variable is preserved by this pattern, unconditionally.

      The default implementation returns false.

      Overrides:
      preserves in class Pattern<B>
      Parameters:
      variable - a pattern variable
      Returns:
      true if the variable value is guaranteed to be unaffected by any matching attempt with this pattern.
    • isDeterministic

      public boolean isDeterministic()
      Description copied from class: Pattern
      Checks whether this pattern is deterministic.

      The default implementation returns true.

      Overrides:
      isDeterministic in class Pattern<B>
      Returns:
      true if this pattern is guaranteed to match any object at most once, false otherwise.
      See Also:
    • toString

      public String toString()
      Overrides:
      toString in class Object
    • compileCut

      protected void compileCut(CompilationContext context, boolean recursively)
      Overrides:
      compileCut in class Pattern<B>
    • compileClear

      protected void compileClear(CompilationContext context, boolean recursively)
      Overrides:
      compileClear in class Pattern<B>