LOGGER.debug("START findResources: {}", reqs);
// Install the unresolved resources into the cloned environment
List<Resource> unresolved = new ArrayList<Resource>();
for (Requirement req : reqs) {
Resource res = req.getResource();
if (env.getResource(res.getIdentity()) == null) {
env.addResource(res);
unresolved.add(res);
}
}
// Find the resources in the cloned environment
List<Resource> resources = new ArrayList<Resource>();
Set<Requirement> unstatisfied = new HashSet<Requirement>(reqs);
Map<Requirement, Resource> mapping = new HashMap<Requirement, Resource>();
findResources(env, unresolved, mapping, unstatisfied, resources);
// Remove abstract resources
Iterator<Resource> itres = resources.iterator();
while (itres.hasNext()) {
Resource res = itres.next();
if (ResourceUtils.isAbstract(res)) {
itres.remove();
}
}