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
40
41
42
43
use std::path::PathBuf;
use crate::gfa::gfa::GFAtk;
use crate::load::{load_gfa, load_gfa_stdin};
use crate::utils;
use anyhow::{bail, Result};
pub fn fasta(matches: &clap::ArgMatches) -> Result<()> {
let gfa_file = matches.get_one::<PathBuf>("GFA");
let gfa: GFAtk = match gfa_file {
Some(f) => {
let ext = f.extension();
match ext {
Some(e) => {
if e == "gfa" {
GFAtk(load_gfa(f)?)
} else {
bail!("Input is not a GFA.")
}
}
None => bail!("Could not read file."),
}
}
None => match utils::is_stdin() {
true => GFAtk(load_gfa_stdin(std::io::stdin().lock())?),
false => bail!("No input from STDIN. Run `gfatk extract -h` for help."),
},
};
gfa.print_sequences(None)?;
Ok(())
}