X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Futil%2FMappingUtils.java;fp=src%2Fjalview%2Futil%2FMappingUtils.java;h=515ff51f7795babb6408bc5f044c2af936dc93b7;hb=81dc9ebd9bd93355897a9c5c87733c0bdb3e5f3b;hp=ae4e55d3a31eea6ea64d8f4b742457627f03db1f;hpb=a24dd1c4927582a629b2ce43c3786abe1c247847;p=jalview.git diff --git a/src/jalview/util/MappingUtils.java b/src/jalview/util/MappingUtils.java index ae4e55d..515ff51 100644 --- a/src/jalview/util/MappingUtils.java +++ b/src/jalview/util/MappingUtils.java @@ -754,6 +754,13 @@ public final class MappingUtils public static List findMappingsForSequence( SequenceI sequence, List mappings) { + return findMappingsForSequenceAndOthers(sequence, mappings, null); + } + + public static List findMappingsForSequenceAndOthers( + SequenceI sequence, List mappings, + AlignmentI alignment) + { List result = new ArrayList(); if (sequence == null || mappings == null) { @@ -763,7 +770,31 @@ public final class MappingUtils { if (mapping.involvesSequence(sequence)) { - result.add(mapping); + if (alignment != null) + { + for (SequenceI otherseq : alignment.getSequences()) + { + if (otherseq == sequence + || (otherseq.getDatasetSequence() != null && (otherseq + .getDatasetSequence() == sequence || otherseq + .getDatasetSequence() == sequence + .getDatasetSequence()))) + { + // skip sequences in subset which directly relate to sequence + continue; + } + if (mapping.involvesSequence(otherseq)) + { + // selected a mapping contained in subselect alignment + result.add(mapping); + break; + } + } + } + else + { + result.add(mapping); + } } } return result;