X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fdatamodel%2FDBRefEntry.java;h=ec6dcf8d76a0b83a986fc00a74b3b59d8ada17bc;hb=5299e0d9142887a30889e8277d12039f10e5c36f;hp=11e77d85a138ec545ddbd37c4287ce30ccdb0e7f;hpb=9a0e53e18ba1280658e1424c5e08b90e7beeebde;p=jalview.git diff --git a/src/jalview/datamodel/DBRefEntry.java b/src/jalview/datamodel/DBRefEntry.java index 11e77d8..ec6dcf8 100755 --- a/src/jalview/datamodel/DBRefEntry.java +++ b/src/jalview/datamodel/DBRefEntry.java @@ -23,6 +23,7 @@ package jalview.datamodel; import jalview.api.DBRefEntryI; import java.util.Arrays; +import java.util.List; public class DBRefEntry implements DBRefEntryI { @@ -281,7 +282,7 @@ public class DBRefEntry implements DBRefEntryI } @Override - public boolean isPrimary() + public boolean isPrimaryCandidate() { /* * if a map is present, unless it is 1:1 and has no SequenceI mate, it cannot be a primary reference. @@ -297,12 +298,15 @@ public class DBRefEntry implements DBRefEntryI { return false; } - // check map is really 1:1, no shifts allowed. - if (map.getMap().getFromHighest() != map.getMap().getToHighest() - && map.getMap().getFromLowest() != map.getMap().getToLowest() - && !Arrays.equals( - map.getMap().getFromRanges().toArray(new int[0][]), - map.getMap().getToRanges().toArray(new int[0][]))) + // check map is between identical single contiguous ranges + List fromRanges = map.getMap().getFromRanges(); + List toRanges = map.getMap().getToRanges(); + if (fromRanges.size() != 1 || toRanges.size() != 1) + { + return false; + } + if (fromRanges.get(0)[0] != toRanges.get(0)[0] + || fromRanges.get(0)[1] != toRanges.get(0)[1]) { return false; }