|
|
@@ -5,7 +5,7 @@ use rust_htslib::bam::{self, Record};
|
|
|
use uuid::Uuid;
|
|
|
use std::{
|
|
|
collections::{HashMap, VecDeque},
|
|
|
- fmt,
|
|
|
+ fmt, fs::File, io::BufWriter,
|
|
|
};
|
|
|
|
|
|
#[derive(Debug, Clone)]
|
|
|
@@ -321,6 +321,11 @@ impl Contig {
|
|
|
.sort_by(|a, b| a.target_start.cmp(&b.target_start));
|
|
|
}
|
|
|
|
|
|
+ pub fn to_igv(&mut seld) -> {
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ // bug cigar len != seq len
|
|
|
pub fn write_bam(&self, path: &str) -> Result<()> {
|
|
|
let aligner = Aligner::builder()
|
|
|
.asm5()
|
|
|
@@ -394,6 +399,15 @@ fn group_mappings(mappings: &mut Vec<Mapping>) -> Result<Vec<Vec<Mapping>>> {
|
|
|
Ok(alignments)
|
|
|
}
|
|
|
|
|
|
+// unique
|
|
|
+pub fn write_fastq(fastq_path: &str, d: &Vec<Record>) {
|
|
|
+ let file = File::create(fasta_path).unwrap();
|
|
|
+ let mut writer = BufWriter::new(file);
|
|
|
+ for record in d {
|
|
|
+ seq_io::fastq::write_parts(&mut writer, record.qname(), None, &record.seq().as_bytes(), record.qual());
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
#[cfg(test)]
|
|
|
mod tests {
|
|
|
use super::*;
|