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 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115
|
#ifndef BM_CMD_ARGS_H__INCLUDED__
#define BM_CMD_ARGS_H__INCLUDED__
inline
void show_help()
{
std::cerr
<< "BitMagic DNA k-mer build example (c) 2019" << std::endl
<< "-fa file-name -- input FASTA file" << std::endl
<< "-k size -- k-mer size (4,8,16,..24) " << std::endl
<< "-kd file-name -- k-mer dictionary file (output)" << std::endl
<< "-j number-of-threads -- number of parallel jobs to run" << std::endl
<< "-diag -- run diagnostics" << std::endl
<< "-timing -- collect timings" << std::endl
;
}
// cmd-line arguments parser
//
inline
int parse_args(int argc, char *argv[])
{
for (int i = 1; i < argc; ++i)
{
std::string arg = argv[i];
if ((arg == "-h") || (arg == "--help"))
{
show_help();
return 0;
}
if (arg == "-fa" || arg == "--fa")
{
if (i + 1 < argc)
{
ifa_name = argv[++i];
}
else
{
std::cerr << "Error: -fa requires file name" << std::endl;
return 1;
}
continue;
}
if (arg == "-kd" || arg == "--kd")
{
if (i + 1 < argc)
{
ikd_name = argv[++i];
}
else
{
std::cerr << "Error: -kd requires file name" << std::endl;
return 1;
}
continue;
}
if (arg == "-k" || arg == "--k")
{
if (i + 1 < argc)
{
std::string ksize_str = argv[++i];
if (ksize_str.empty())
{
std::cerr << "Error: -k requires size" << std::endl;
return 1;
}
ik_size = (unsigned)std::stoi(ksize_str);
if (ik_size < 2)
{
ik_size = 8;
}
if (ik_size > 24)
{
std::cerr << "Error: unsupported k-mer size (too big)" << std::endl;
return 1;
}
}
else
{
std::cerr << "Error: -k requires size" << std::endl;
return 1;
}
continue;
}
if (arg == "-j" || arg == "--j")
{
if (i + 1 < argc)
{
parallel_jobs = unsigned(::atoi(argv[++i]));
}
else
{
std::cerr << "Error: -j requires number of jobs" << std::endl;
return 1;
}
continue;
}
if (arg == "-diag" || arg == "--diag" || arg == "-d" || arg == "--d")
is_diag = true;
if (arg == "-timing" || arg == "--timing" || arg == "-t" || arg == "--t")
is_timing = true;
if (arg == "-bench" || arg == "--bench" || arg == "-b" || arg == "--b")
is_bench = true;
} // for i
return 0;
}
#endif
|