From 2306518ab6be1c323b46d41b33d481cc1bb65197 Mon Sep 17 00:00:00 2001 From: Menachem Fromer Date: Thu, 22 Nov 2012 01:45:18 -0500 Subject: [PATCH] Fix to deal with 'proper' options of casting --- .../pileup/AbstractReadBackedPileup.java | 22 ++++++++++++++----- 1 file changed, 17 insertions(+), 5 deletions(-) diff --git a/public/java/src/org/broadinstitute/sting/utils/pileup/AbstractReadBackedPileup.java b/public/java/src/org/broadinstitute/sting/utils/pileup/AbstractReadBackedPileup.java index d0ae68912..42938d2a6 100644 --- a/public/java/src/org/broadinstitute/sting/utils/pileup/AbstractReadBackedPileup.java +++ b/public/java/src/org/broadinstitute/sting/utils/pileup/AbstractReadBackedPileup.java @@ -1022,7 +1022,7 @@ public abstract class AbstractReadBackedPileup sortedElements = new TreeSet(new Comparator() { @Override @@ -1031,15 +1031,27 @@ public abstract class AbstractReadBackedPileup tracker = (UnifiedPileupElementTracker) pileupElementTracker; - for (PE pile : tracker) - sortedElements.add(pile); + + if (pileupElementTracker instanceof PerSamplePileupElementTracker) { + PerSamplePileupElementTracker tracker = (PerSamplePileupElementTracker) pileupElementTracker; + + for (final String sample : tracker.getSamples()) { + PileupElementTracker perSampleElements = tracker.getElements(sample); + for (PE pile : perSampleElements) + sortedElements.add(pile); + } + } + else { + UnifiedPileupElementTracker tracker = (UnifiedPileupElementTracker) pileupElementTracker; + for (PE pile : tracker) + sortedElements.add(pile); + } UnifiedPileupElementTracker sortedTracker = new UnifiedPileupElementTracker(); for (PE pile : sortedElements) sortedTracker.add(pile); - return (RBP) createNewPileup(this.getLocation(), sortedTracker); + return (RBP) createNewPileup(loc, sortedTracker); } @Override