Merdle:
Creo que break
no es aquí la mejor solución para detener este método;
¿Cómo puedo detener el método, cuando una vez establecido el objeto y gerente entitiy; en lugar de utilizar break
;
/**
* Convenience method for setting the given entity manager to the given
* object via reflection.
*
* @param object the object whose entity manager should be set
* @param em the entity manager that should be set
*/
protected void setEntityManager(Object object, EntityManager em) {
Field[] fields = object.getClass().getDeclaredFields();
for (Field f : fields) {
if (f.getType().isAssignableFrom(EntityManager.class)) {
f.setAccessible(true);
try {
f.set(object, em);
break;
} catch (IllegalArgumentException e) {
throw new RuntimeException(e);
} catch (IllegalAccessException e) {
throw new RuntimeException(e);
}
}
}
}
Ralf Renz:
Pensé en el uso de corrientes de este tipo:
protected void setEntityManager(Object object, EntityManager em) {
Optional<Field> f = Arrays.stream(object.getClass().getDeclaredFields())
.filter(x -> x.getType().isAssignableFrom(EntityManager.class)).findFirst();
if (f.isPresent()) {
f.get().setAccessible(true);
try {
f.get().set(object, em);
} catch (IllegalArgumentException e) {
throw new RuntimeException(e);
} catch (IllegalAccessException e) {
throw new RuntimeException(e);
}
}
}