事实证明,有一种方法可以创建嵌套的可观察列表,不仅适用于 EMF 列表功能,还适用于所有类型的可观察列表。
诀窍是将该MasterDetailObservables.detailValues
方法与返回可观察列表的工厂一起使用。
Network network = TryingFactory.eINSTANCE.createNetwork();
network.getMasters().add(TryingFactory.eINSTANCE.createMaster());
network.getMasters().add(TryingFactory.eINSTANCE.createMaster());
network.getMasters().get(0).getSlaves().add(TryingFactory.eINSTANCE.createSlave());
network.getMasters().get(1).getSlaves().add(TryingFactory.eINSTANCE.createSlave());
network.getMasters().get(1).getSlaves().add(TryingFactory.eINSTANCE.createSlave());
IObservableList<Master> masterList = EMFProperties.list(Literals.NETWORK__MASTERS).observe(network);
IObservableList<IObservableList<Slave>> nestedLists = MasterDetailObservables.detailValues(masterList,
master -> Observables.constantObservableValue(masterList.getRealm(),
EMFProperties.list(Literals.MASTER__SLAVES).observe(master),
IObservableList.class),
IObservableList.class);
// Dispose nested lists when they are removed from the top-level list
nestedLists.addListChangeListener(event -> event.diff.accept(new ListDiffVisitor<IObservableList<?>>() {
@Override
public void handleRemove(int index, IObservableList<?> element) {
element.dispose();
}
@Override public void handleAdd(int index, IObservableList<?> element) {}
@Override public void handleMove(int oldIndex, int newIndex, IObservableList<?> element) {}
}));
nestedLists.forEach(System.out::println);
// Prints:
// [trying.impl.SlaveImpl@7692d9cc]
// [trying.impl.SlaveImpl@75f32542, trying.impl.SlaveImpl@7f1302d6]