File: test_consensus_seq_id.cpp

package info (click to toggle)
ivar 1.3%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 3,924 kB
  • sloc: cpp: 4,907; javascript: 866; sh: 120; makefile: 37
file content (39 lines) | stat: -rwxr-xr-x 1,654 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
#include<iostream>
#include<fstream>
#include<string>
#include "../src/call_consensus_pileup.h"
#include "../src/allele_functions.h"

int call_cns_check_outfile(std::string seq_id, std::string prefix, char gap, bool call_min_depth, int min_depth){
  std::string path = "../data/test.gap.sorted.mpileup";
  std::string expctd_hdr = "";
  std::ifstream mplp(path);
  call_consensus_from_plup(mplp, seq_id, prefix, 20, 0, min_depth, gap, call_min_depth);
  std::ifstream outFile(prefix+".fa");
  std::string l;
  getline(outFile, l);		// header
  if(seq_id.empty()) {
    char *o = new char[prefix.length() + 1];
    strcpy(o, prefix.c_str());
    expctd_hdr = ">Consensus_" + std::string(basename(o)) + "_threshold_0_quality_20";
    
  } else {
    expctd_hdr = ">" + seq_id;
  }

  return l.compare(expctd_hdr);
}

int main() {
  int num_success = 0;
  std::string c_ = "CTGCTGGGTCATGGGCCCATCATGATGGTCTTGGCGATTCTAGCCTTTTTGAGATTCACGGCAATCAAGCCATCACTGGGTCTCATCAATAGATGGGGTTCAGTGGGGAAAAAAGAGGCTATGGAAACAATAAAGAAGTTCAAGAAAGAT------------------------------AGGAAGGAGAAGAAGAGACGWGGCGCAGATACTAGTGTCGGAATTGTTGGMCTCCTGCTGACCACAGCTATGGMAGCGGAGGTCACKAGACGTGGGAGTGCATACTATATGTACTTGGACWGAAACGATGCKGGGGAGGCCATATCTTTTCCAACCACATTGGGGTTGAATAAGTG";
  num_success = call_cns_check_outfile("TESTID", "../data/test.gap", '-', true, 0);
  std::cout << num_success << std::endl;
  num_success += call_cns_check_outfile("", "../data/test.gap", 'N', true, 0);
  std::cout << num_success << std::endl;
  num_success += call_cns_check_outfile("TESTID2", "../data/test.gap", 'N', false, 0);
  std::cout << num_success << std::endl;
  if(num_success == 0)
    return 0;
  return -1;
}