Package org.apache.juneau.swap
Class SurrogateSwap<T,F>
java.lang.Object
org.apache.juneau.swap.ObjectSwap<T,F>
org.apache.juneau.swap.SurrogateSwap<T,F>
- Type Parameters:
T
- The class type that this transform applies to.F
- The transformed class type.
-
Field Summary
Fields inherited from class org.apache.juneau.swap.ObjectSwap
NULL
-
Constructor Summary
ModifierConstructorDescriptionprotected
SurrogateSwap
(Class<T> forClass, Constructor<F> constructor, Method unswapMethod) Constructor. -
Method Summary
Modifier and TypeMethodDescriptionstatic List<SurrogateSwap<?,
?>> findObjectSwaps
(Class<?> c, BeanContext bc) Given the specified surrogate class, return the list of object swaps.swap
(BeanSession session, T o) If this transform is to be used to serialize non-serializable objects, it must implement this method.unswap
(BeanSession session, F f, ClassMeta<?> hint) If this transform is to be used to reconstitute objects that aren't true Java beans, it must implement this method.Methods inherited from class org.apache.juneau.swap.ObjectSwap
forMediaTypes, forMediaTypes, getNormalClass, getSwapClass, getSwapClassMeta, isNormalObject, isSwappedObject, match, swap, toString, unswap, withTemplate, withTemplate
-
Constructor Details
-
SurrogateSwap
Constructor.- Parameters:
forClass
- The normal class.constructor
- The constructor on the surrogate class that takes the normal class as a parameter.unswapMethod
- The static method that converts surrogate objects into normal objects.
-
-
Method Details
-
findObjectSwaps
Given the specified surrogate class, return the list of object swaps.A transform is returned for each public 1-arg constructor found. Returns an empty list if no public 1-arg constructors are found.
- Parameters:
c
- The surrogate class.bc
- The bean context to use for looking up annotations.- Returns:
- The list of object swaps that apply to this class.
-
swap
Description copied from class:ObjectSwap
If this transform is to be used to serialize non-serializable objects, it must implement this method.The object must be converted into one of the following serializable types:
-
String
-
Number
-
Boolean
-
Collection
containing anything on this list. -
Map
containing anything on this list. - A java bean with properties of anything on this list.
- An array of anything on this list.
- Overrides:
swap
in classObjectSwap<T,
F> - Parameters:
session
- The bean session to use to get the class meta. This is always going to be the same bean context that created this swap.o
- The object to be transformed.- Returns:
- The transformed object.
- Throws:
SerializeException
-
-
unswap
Description copied from class:ObjectSwap
If this transform is to be used to reconstitute objects that aren't true Java beans, it must implement this method.- Overrides:
unswap
in classObjectSwap<T,
F> - Parameters:
session
- The bean session to use to get the class meta. This is always going to be the same bean context that created this swap.f
- The transformed object.hint
- If possible, the parser will try to tell you the object type being created. For example, on a serialized date, this may tell you that the object being created must be of typeGregorianCalendar
.
This may benull if the parser cannot make this determination.- Returns:
- The narrowed object.
- Throws:
ParseException
-