net.sf.saxon.z.IntUnionPredicate Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of saxon-he Show documentation
Show all versions of saxon-he Show documentation
An OSGi bundle for Saxon-HE
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Copyright (c) 2013 Saxonica Limited.
// This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0.
// If a copy of the MPL was not distributed with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
// This Source Code Form is "Incompatible With Secondary Licenses", as defined by the Mozilla Public License, v. 2.0.
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
package net.sf.saxon.z;
/**
* An IntPredicate formed as the union of two other predicates: it matches
* an integer if either of the operands matches the integer
*/
public class IntUnionPredicate implements IntPredicate {
private IntPredicate p1;
private IntPredicate p2;
public IntUnionPredicate(IntPredicate p1, IntPredicate p2) {
this.p1 = p1;
this.p2 = p2;
}
/**
* Ask whether a given value matches this predicate
*
* @param value the value to be tested
* @return true if the value matches; false if it does not
*/
public boolean matches(int value) {
return p1.matches(value) || p2.matches(value);
}
/**
* Get the operands
* @return an array containing the two operands
*/
public IntPredicate[] getOperands() {
return new IntPredicate[]{p1, p2};
}
}