How to use iPOJO Manipulation Metadata

During the manipulation process, iPOJO gathers information about the manipulated classes. These metadata are stored inside the bundle manifest and are used to avoid reflection on the manipulated class. By using these metadata, your handler can check that the implementation class contains required fields, methods, check implemented interfaces.

Contained information

Manipulation metadata contains:

Field Metadata contains field name and type. Method Metadata contains method name, the sorted list of argument types and return type.

Building Manipulation Metadata

Manipulation (i.e. PojoMetadata) can be obtained form the factory of a (primitive) component type such as in:

public void configure(InstanceManager im, Element metadata, Dictionary configuration)  {
    ...
    PojoMetadata manipulation = getFactory().getPojoMetadata();
    ...
}

Getting Metadata

From the manipulation metadata, you can query manipulation information by using following methods:

From a Field Metadata object, you can obtain the field name, type, and 'reflective' type. From a Method Metadata object, you can obtain the method name, the argument type array, and the returned type ('void' for void method).

Creating Callback from Manipulation Metadata

You often need to invoke method on the POJO objects. iPOJO provides an helper class, named Callback, allow you to manage this invocation easily. You can obtain a Callback object from the Method Metadata. By this way, you are sure that the method exists in the implementation. To create the callback, use the following code:

PojoMetadata manip = getFactory().getPojoMetadata();
MethodMetadata method = manip.getMethod("your_method_name");
Callback cb = new Callback(method, im);

Then you can directly invoke your method:

Object[] args = ...;  // Build your argument array
cb.call(args);
...

Types & Reflective Types

When querying field (or a method argument) type, the API returns following code identifiers:

Array types are different from Java internal/reflective array types. To get the internal/reflective array type for field type you can use the getReflectiveType method.