public final class BasicMethodConstraints extends Object implements MethodConstraints, Serializable
MethodConstraints
, allowing limited
wildcard matching on method names and parameter types. Methods can be
specified by exact name and parameter types (matching a single method),
by exact name (matching all methods with that name), by name prefix
(matching all methods with names that start with that prefix), by name
suffix (matching all methods with names that end with that suffix), and
by a default that matches all methods. Normally instances of this class
should be obtained from a
Configuration
rather than being
explicitly constructed.Modifier and Type | Class and Description |
---|---|
static class |
BasicMethodConstraints.MethodDesc
Descriptor for specifying the constraints associated with one or
more methods allowing limited wildcard matching on method names and
parameter types.
|
Modifier and Type | Field and Description |
---|---|
private BasicMethodConstraints.MethodDesc[] |
descs
The ordered method descriptors.
|
private static ObjectStreamField[] |
serialPersistentFields |
private static long |
serialVersionUID |
Constructor and Description |
---|
BasicMethodConstraints(BasicMethodConstraints.MethodDesc[] descs)
Creates an instance with the specified ordered array of descriptors.
|
BasicMethodConstraints(InvocationConstraints constraints)
Creates an instance that maps all methods to the specified constraints.
|
Modifier and Type | Method and Description |
---|---|
private void |
check()
Throws IllegalArgumentException if the descriptors array is empty, or
if any descriptor is preceded by another descriptor that matches at
least the same methods.
|
private static void |
check(BasicMethodConstraints.MethodDesc prev,
BasicMethodConstraints.MethodDesc desc)
Throws IllegalArgumentException if the parameter types of prev cover
those of desc.
|
boolean |
equals(Object obj)
Two instances of this class are equal if they have the same descriptors
in the same order.
|
InvocationConstraints |
getConstraints(Method method)
Returns the constraints for the specified remote method as a
non-
null value. |
BasicMethodConstraints.MethodDesc[] |
getMethodDescs()
Returns the descriptors.
|
private static int |
hash(Object[] elements)
Returns the sum of the hash codes of all elements of the given array.
|
int |
hashCode()
Returns a hash code value for this object.
|
Iterator |
possibleConstraints()
Returns an iterator that yields all of the possible distinct
constraints that can be returned by
getConstraints , in arbitrary order and with duplicates permitted. |
private void |
readObject(ObjectInputStream s)
Verifies legal descriptor ordering.
|
private static void |
rethrow(RuntimeException e)
If the exception is a NullPointerException or IllegalArgumentException,
wrap it in an InvalidObjectException and throw that, otherwise rethrow
the exception as is.
|
String |
toString()
Returns a string representation of this object.
|
private static final long serialVersionUID
private static final ObjectStreamField[] serialPersistentFields
private final BasicMethodConstraints.MethodDesc[] descs
public BasicMethodConstraints(BasicMethodConstraints.MethodDesc[] descs)
getConstraints
method searches the
descriptors in the specified order. For any given descriptor in the
array, no preceding descriptor can match at least the same methods as
the given descriptor; that is, more specific descriptors must precede
less specific descriptors. The array passed to the constructor is
neither modified nor retained; subsequent changes to that array have
no effect on the instance created.descs
- the descriptorsNullPointerException
- if the argument is null
or
any element of the argument is null
IllegalArgumentException
- if the descriptors array is empty, or
if any descriptor is preceded by another descriptor that matches at
least the same methodspublic BasicMethodConstraints(InvocationConstraints constraints)
null
, which is treated the same as
an empty instance. Calling this constructor is equivalent to
constructing an instance of this class with an array containing a
single default descriptor constructed with the specified constraints.constraints
- the constraints, or null
private void check()
private static void check(BasicMethodConstraints.MethodDesc prev, BasicMethodConstraints.MethodDesc desc)
public InvocationConstraints getConstraints(Method method)
null
value. Searches the descriptors in order, and
returns the constraints in the first descriptor that matches the
method, or an empty constraints instance if there is no match.getConstraints
in interface MethodConstraints
method
- the methodnull
valueNullPointerException
- if the argument is null
public Iterator possibleConstraints()
MethodConstraints
getConstraints
, in arbitrary order and with duplicates permitted. The
iterator throws an UnsupportedOperationException
on any
attempt to remove an element.possibleConstraints
in interface MethodConstraints
getConstraints
,
in arbitrary order and with duplicates permittedpublic BasicMethodConstraints.MethodDesc[] getMethodDescs()
null
array
every time it is called.null
arraypublic int hashCode()
public String toString()
public boolean equals(Object obj)
private void readObject(ObjectInputStream s) throws IOException, ClassNotFoundException
InvalidObjectException
- if any descriptor is null
,
or the descriptors array is empty, or if any descriptor is preceded by
another descriptor that matches at least the same methodsIOException
ClassNotFoundException
private static int hash(Object[] elements)
private static void rethrow(RuntimeException e) throws InvalidObjectException
InvalidObjectException
Copyright 2007-2013, multiple authors.
Licensed under the Apache License, Version 2.0, see the NOTICE file for attributions.