diff --git a/src/main/scala/com/fulcrumgenomics/bam/ZipperBams.scala b/src/main/scala/com/fulcrumgenomics/bam/ZipperBams.scala index e618fcf7a..0f0ed2008 100644 --- a/src/main/scala/com/fulcrumgenomics/bam/ZipperBams.scala +++ b/src/main/scala/com/fulcrumgenomics/bam/ZipperBams.scala @@ -86,12 +86,17 @@ private[bam] object ZipperBams extends LazyLogging { // Build a new header using the given sequence dictionary val header = new SAMFileHeader(dict) + // Copy over comments, RGs and PGs, letting mapped override unmapped if there are conflicts - Iterator(unmapped, mapped).foreach { old => - old.getComments.iterator().foreach(header.addComment) - old.getReadGroups.iterator().foreach(header.addReadGroup) - old.getProgramRecords.iterator().foreach(header.addProgramRecord) - } + val mappedComments = mapped.getComments.toSet + val mappedReadGroups = mapped.getReadGroups.toSet + val mappedProgramRecords = mapped.getProgramRecords.toSet + unmapped.getComments.filterNot(mappedComments.contains).foreach(header.addComment) + unmapped.getReadGroups.filterNot(mappedReadGroups.contains).foreach(header.addReadGroup) + unmapped.getProgramRecords.filterNot(mappedProgramRecords.contains).foreach(header.addProgramRecord) + mapped.getComments.foreach(header.addComment) + mapped.getReadGroups.foreach(header.addReadGroup) + mapped.getProgramRecords.foreach(header.addProgramRecord) // Set the sort and group order header.setSortOrder(unmapped.getSortOrder)