Juan Pollacchi:
Es necesario cambiar el código de abajo:
protected void checkNoDuplicateLabels( List<CompileResult> compileResult ) {
Set<Label> infos = new HashSet<>();
for ( AbstractTypeInfo info : infoRepo.getList() ) {
if ( info instanceof Label ) {
Label label = (Label) info;
if ( infos.contains( label ) ) {
compileResult.add( new CompileResult( Severity.FATAL, MessageFormat.format( "Duplicate label found! \n Type: '{0}' \n Language: '{1}'", label.getType(), label.getLanguage() ) ) );
}
infos.add( label );
}
}
}
En una corriente. Sé que una manera de utilizar conjuntos con corrientes es mediante la implementación de AtomicReferences, que sustituiría a la primera línea del método en esto:
AtomicReference<Set<Label>> infos = new AtomicReference<>( new HashSet<Label>() );
¿Cómo puedo conseguir la misma funcionalidad que el bucle está haciendo ahora con una corriente?
ETO:
Puede hacerlo sin AtomicReference
:
BinaryOperator<Label> logDuplicate = (label1, label2) -> {
// Log label2 as duplicate
compileResult.add(new CompileResult(Severity.FATAL, MessageFormat.format("Duplicate label found! \n Type: '{0}' \n Language: '{1}'", label2.getType(), label2.getLanguage())));
return label1;
};
Set<Label> infos = infoRepo.getList()
.stream()
.filter(Label.class::isInstance)
.map(Label.class::cast)
.collect(toMap(identity(), identity(), logDuplicate, HashMap::new))
.keySet();
Actualizar:
import static java.util.stream.Collectors.toMap;
import static java.util.function.Function.identity;