minimap2 0.2.22.0 → 0.2.24.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (101) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +60 -76
  3. data/ext/Rakefile +55 -0
  4. data/ext/cmappy/cmappy.c +129 -0
  5. data/ext/cmappy/cmappy.h +44 -0
  6. data/ext/minimap2/FAQ.md +46 -0
  7. data/ext/minimap2/LICENSE.txt +24 -0
  8. data/ext/minimap2/MANIFEST.in +10 -0
  9. data/ext/minimap2/Makefile +132 -0
  10. data/ext/minimap2/Makefile.simde +97 -0
  11. data/ext/minimap2/NEWS.md +821 -0
  12. data/ext/minimap2/README.md +403 -0
  13. data/ext/minimap2/align.c +1020 -0
  14. data/ext/minimap2/bseq.c +169 -0
  15. data/ext/minimap2/bseq.h +64 -0
  16. data/ext/minimap2/code_of_conduct.md +30 -0
  17. data/ext/minimap2/cookbook.md +243 -0
  18. data/ext/minimap2/esterr.c +64 -0
  19. data/ext/minimap2/example.c +63 -0
  20. data/ext/minimap2/format.c +559 -0
  21. data/ext/minimap2/hit.c +466 -0
  22. data/ext/minimap2/index.c +775 -0
  23. data/ext/minimap2/kalloc.c +205 -0
  24. data/ext/minimap2/kalloc.h +76 -0
  25. data/ext/minimap2/kdq.h +132 -0
  26. data/ext/minimap2/ketopt.h +120 -0
  27. data/ext/minimap2/khash.h +615 -0
  28. data/ext/minimap2/krmq.h +474 -0
  29. data/ext/minimap2/kseq.h +256 -0
  30. data/ext/minimap2/ksort.h +153 -0
  31. data/ext/minimap2/ksw2.h +184 -0
  32. data/ext/minimap2/ksw2_dispatch.c +96 -0
  33. data/ext/minimap2/ksw2_extd2_sse.c +402 -0
  34. data/ext/minimap2/ksw2_exts2_sse.c +416 -0
  35. data/ext/minimap2/ksw2_extz2_sse.c +313 -0
  36. data/ext/minimap2/ksw2_ll_sse.c +152 -0
  37. data/ext/minimap2/kthread.c +159 -0
  38. data/ext/minimap2/kthread.h +15 -0
  39. data/ext/minimap2/kvec.h +105 -0
  40. data/ext/minimap2/lchain.c +369 -0
  41. data/ext/minimap2/main.c +459 -0
  42. data/ext/minimap2/map.c +714 -0
  43. data/ext/minimap2/minimap.h +410 -0
  44. data/ext/minimap2/minimap2.1 +725 -0
  45. data/ext/minimap2/misc/README.md +179 -0
  46. data/ext/minimap2/misc/mmphase.js +335 -0
  47. data/ext/minimap2/misc/paftools.js +3149 -0
  48. data/ext/minimap2/misc.c +162 -0
  49. data/ext/minimap2/mmpriv.h +132 -0
  50. data/ext/minimap2/options.c +234 -0
  51. data/ext/minimap2/pe.c +177 -0
  52. data/ext/minimap2/python/README.rst +196 -0
  53. data/ext/minimap2/python/cmappy.h +152 -0
  54. data/ext/minimap2/python/cmappy.pxd +153 -0
  55. data/ext/minimap2/python/mappy.pyx +273 -0
  56. data/ext/minimap2/python/minimap2.py +39 -0
  57. data/ext/minimap2/sdust.c +213 -0
  58. data/ext/minimap2/sdust.h +25 -0
  59. data/ext/minimap2/seed.c +131 -0
  60. data/ext/minimap2/setup.py +55 -0
  61. data/ext/minimap2/sketch.c +143 -0
  62. data/ext/minimap2/splitidx.c +84 -0
  63. data/ext/minimap2/sse2neon/emmintrin.h +1689 -0
  64. data/ext/minimap2/test/MT-human.fa +278 -0
  65. data/ext/minimap2/test/MT-orang.fa +276 -0
  66. data/ext/minimap2/test/q-inv.fa +4 -0
  67. data/ext/minimap2/test/q2.fa +2 -0
  68. data/ext/minimap2/test/t-inv.fa +127 -0
  69. data/ext/minimap2/test/t2.fa +2 -0
  70. data/ext/minimap2/tex/Makefile +21 -0
  71. data/ext/minimap2/tex/bioinfo.cls +930 -0
  72. data/ext/minimap2/tex/blasr-mc.eval +17 -0
  73. data/ext/minimap2/tex/bowtie2-s3.sam.eval +28 -0
  74. data/ext/minimap2/tex/bwa-s3.sam.eval +52 -0
  75. data/ext/minimap2/tex/bwa.eval +55 -0
  76. data/ext/minimap2/tex/eval2roc.pl +33 -0
  77. data/ext/minimap2/tex/graphmap.eval +4 -0
  78. data/ext/minimap2/tex/hs38-simu.sh +10 -0
  79. data/ext/minimap2/tex/minialign.eval +49 -0
  80. data/ext/minimap2/tex/minimap2.bib +460 -0
  81. data/ext/minimap2/tex/minimap2.tex +724 -0
  82. data/ext/minimap2/tex/mm2-s3.sam.eval +62 -0
  83. data/ext/minimap2/tex/mm2-update.tex +240 -0
  84. data/ext/minimap2/tex/mm2.approx.eval +12 -0
  85. data/ext/minimap2/tex/mm2.eval +13 -0
  86. data/ext/minimap2/tex/natbib.bst +1288 -0
  87. data/ext/minimap2/tex/natbib.sty +803 -0
  88. data/ext/minimap2/tex/ngmlr.eval +38 -0
  89. data/ext/minimap2/tex/roc.gp +60 -0
  90. data/ext/minimap2/tex/snap-s3.sam.eval +62 -0
  91. data/ext/minimap2.patch +19 -0
  92. data/lib/minimap2/aligner.rb +4 -4
  93. data/lib/minimap2/alignment.rb +11 -11
  94. data/lib/minimap2/ffi/constants.rb +20 -16
  95. data/lib/minimap2/ffi/functions.rb +5 -0
  96. data/lib/minimap2/ffi.rb +4 -5
  97. data/lib/minimap2/version.rb +2 -2
  98. data/lib/minimap2.rb +51 -15
  99. metadata +97 -79
  100. data/lib/minimap2/ffi_helper.rb +0 -53
  101. data/vendor/libminimap2.so +0 -0
@@ -0,0 +1,410 @@
1
+ #ifndef MINIMAP2_H
2
+ #define MINIMAP2_H
3
+
4
+ #include <stdint.h>
5
+ #include <stdio.h>
6
+ #include <sys/types.h>
7
+
8
+ #define MM_F_NO_DIAG 0x001 // no exact diagonal hit
9
+ #define MM_F_NO_DUAL 0x002 // skip pairs where query name is lexicographically larger than target name
10
+ #define MM_F_CIGAR 0x004
11
+ #define MM_F_OUT_SAM 0x008
12
+ #define MM_F_NO_QUAL 0x010
13
+ #define MM_F_OUT_CG 0x020
14
+ #define MM_F_OUT_CS 0x040
15
+ #define MM_F_SPLICE 0x080 // splice mode
16
+ #define MM_F_SPLICE_FOR 0x100 // match GT-AG
17
+ #define MM_F_SPLICE_REV 0x200 // match CT-AC, the reverse complement of GT-AG
18
+ #define MM_F_NO_LJOIN 0x400
19
+ #define MM_F_OUT_CS_LONG 0x800
20
+ #define MM_F_SR 0x1000
21
+ #define MM_F_FRAG_MODE 0x2000
22
+ #define MM_F_NO_PRINT_2ND 0x4000
23
+ #define MM_F_2_IO_THREADS 0x8000
24
+ #define MM_F_LONG_CIGAR 0x10000
25
+ #define MM_F_INDEPEND_SEG 0x20000
26
+ #define MM_F_SPLICE_FLANK 0x40000
27
+ #define MM_F_SOFTCLIP 0x80000
28
+ #define MM_F_FOR_ONLY 0x100000
29
+ #define MM_F_REV_ONLY 0x200000
30
+ #define MM_F_HEAP_SORT 0x400000
31
+ #define MM_F_ALL_CHAINS 0x800000
32
+ #define MM_F_OUT_MD 0x1000000
33
+ #define MM_F_COPY_COMMENT 0x2000000
34
+ #define MM_F_EQX 0x4000000 // use =/X instead of M
35
+ #define MM_F_PAF_NO_HIT 0x8000000 // output unmapped reads to PAF
36
+ #define MM_F_NO_END_FLT 0x10000000
37
+ #define MM_F_HARD_MLEVEL 0x20000000
38
+ #define MM_F_SAM_HIT_ONLY 0x40000000
39
+ #define MM_F_RMQ (0x80000000LL)
40
+ #define MM_F_QSTRAND (0x100000000LL)
41
+ #define MM_F_NO_INV (0x200000000LL)
42
+ #define MM_F_NO_HASH_NAME (0x400000000LL)
43
+
44
+ #define MM_I_HPC 0x1
45
+ #define MM_I_NO_SEQ 0x2
46
+ #define MM_I_NO_NAME 0x4
47
+
48
+ #define MM_IDX_MAGIC "MMI\2"
49
+
50
+ #define MM_MAX_SEG 255
51
+
52
+ #define MM_CIGAR_MATCH 0
53
+ #define MM_CIGAR_INS 1
54
+ #define MM_CIGAR_DEL 2
55
+ #define MM_CIGAR_N_SKIP 3
56
+ #define MM_CIGAR_SOFTCLIP 4
57
+ #define MM_CIGAR_HARDCLIP 5
58
+ #define MM_CIGAR_PADDING 6
59
+ #define MM_CIGAR_EQ_MATCH 7
60
+ #define MM_CIGAR_X_MISMATCH 8
61
+
62
+ #define MM_CIGAR_STR "MIDNSHP=XB"
63
+
64
+ #ifdef __cplusplus
65
+ extern "C" {
66
+ #endif
67
+
68
+ // emulate 128-bit integers and arrays
69
+ typedef struct { uint64_t x, y; } mm128_t;
70
+ typedef struct { size_t n, m; mm128_t *a; } mm128_v;
71
+
72
+ // minimap2 index
73
+ typedef struct {
74
+ char *name; // name of the db sequence
75
+ uint64_t offset; // offset in mm_idx_t::S
76
+ uint32_t len; // length
77
+ uint32_t is_alt;
78
+ } mm_idx_seq_t;
79
+
80
+ typedef struct {
81
+ int32_t b, w, k, flag;
82
+ uint32_t n_seq; // number of reference sequences
83
+ int32_t index;
84
+ int32_t n_alt;
85
+ mm_idx_seq_t *seq; // sequence name, length and offset
86
+ uint32_t *S; // 4-bit packed sequence
87
+ struct mm_idx_bucket_s *B; // index (hidden)
88
+ struct mm_idx_intv_s *I; // intervals (hidden)
89
+ void *km, *h;
90
+ } mm_idx_t;
91
+
92
+ // minimap2 alignment
93
+ typedef struct {
94
+ uint32_t capacity; // the capacity of cigar[]
95
+ int32_t dp_score, dp_max, dp_max2; // DP score; score of the max-scoring segment; score of the best alternate mappings
96
+ uint32_t n_ambi:30, trans_strand:2; // number of ambiguous bases; transcript strand: 0 for unknown, 1 for +, 2 for -
97
+ uint32_t n_cigar; // number of cigar operations in cigar[]
98
+ uint32_t cigar[];
99
+ } mm_extra_t;
100
+
101
+ typedef struct {
102
+ int32_t id; // ID for internal uses (see also parent below)
103
+ int32_t cnt; // number of minimizers; if on the reverse strand
104
+ int32_t rid; // reference index; if this is an alignment from inversion rescue
105
+ int32_t score; // DP alignment score
106
+ int32_t qs, qe, rs, re; // query start and end; reference start and end
107
+ int32_t parent, subsc; // parent==id if primary; best alternate mapping score
108
+ int32_t as; // offset in the a[] array (for internal uses only)
109
+ int32_t mlen, blen; // seeded exact match length; seeded alignment block length
110
+ int32_t n_sub; // number of suboptimal mappings
111
+ int32_t score0; // initial chaining score (before chain merging/spliting)
112
+ uint32_t mapq:8, split:2, rev:1, inv:1, sam_pri:1, proper_frag:1, pe_thru:1, seg_split:1, seg_id:8, split_inv:1, is_alt:1, strand_retained:1, dummy:5;
113
+ uint32_t hash;
114
+ float div;
115
+ mm_extra_t *p;
116
+ } mm_reg1_t;
117
+
118
+ // indexing and mapping options
119
+ typedef struct {
120
+ short k, w, flag, bucket_bits;
121
+ int64_t mini_batch_size;
122
+ uint64_t batch_size;
123
+ } mm_idxopt_t;
124
+
125
+ typedef struct {
126
+ int64_t flag; // see MM_F_* macros
127
+ int seed;
128
+ int sdust_thres; // score threshold for SDUST; 0 to disable
129
+
130
+ int max_qlen; // max query length
131
+
132
+ int bw, bw_long; // bandwidth
133
+ int max_gap, max_gap_ref; // break a chain if there are no minimizers in a max_gap window
134
+ int max_frag_len;
135
+ int max_chain_skip, max_chain_iter;
136
+ int min_cnt; // min number of minimizers on each chain
137
+ int min_chain_score; // min chaining score
138
+ float chain_gap_scale;
139
+ float chain_skip_scale;
140
+ int rmq_size_cap, rmq_inner_dist;
141
+ int rmq_rescue_size;
142
+ float rmq_rescue_ratio;
143
+
144
+ float mask_level;
145
+ int mask_len;
146
+ float pri_ratio;
147
+ int best_n; // top best_n chains are subjected to DP alignment
148
+
149
+ float alt_drop;
150
+
151
+ int a, b, q, e, q2, e2; // matching score, mismatch, gap-open and gap-ext penalties
152
+ int sc_ambi; // score when one or both bases are "N"
153
+ int noncan; // cost of non-canonical splicing sites
154
+ int junc_bonus;
155
+ int zdrop, zdrop_inv; // break alignment if alignment score drops too fast along the diagonal
156
+ int end_bonus;
157
+ int min_dp_max; // drop an alignment if the score of the max scoring segment is below this threshold
158
+ int min_ksw_len;
159
+ int anchor_ext_len, anchor_ext_shift;
160
+ float max_clip_ratio; // drop an alignment if BOTH ends are clipped above this ratio
161
+
162
+ int rank_min_len;
163
+ float rank_frac;
164
+
165
+ int pe_ori, pe_bonus;
166
+
167
+ float mid_occ_frac; // only used by mm_mapopt_update(); see below
168
+ float q_occ_frac;
169
+ int32_t min_mid_occ, max_mid_occ;
170
+ int32_t mid_occ; // ignore seeds with occurrences above this threshold
171
+ int32_t max_occ, max_max_occ, occ_dist;
172
+ int64_t mini_batch_size; // size of a batch of query bases to process in parallel
173
+ int64_t max_sw_mat;
174
+ int64_t cap_kalloc;
175
+
176
+ const char *split_prefix;
177
+ } mm_mapopt_t;
178
+
179
+ // index reader
180
+ typedef struct {
181
+ int is_idx, n_parts;
182
+ int64_t idx_size;
183
+ mm_idxopt_t opt;
184
+ FILE *fp_out;
185
+ union {
186
+ struct mm_bseq_file_s *seq;
187
+ FILE *idx;
188
+ } fp;
189
+ } mm_idx_reader_t;
190
+
191
+ // memory buffer for thread-local storage during mapping
192
+ typedef struct mm_tbuf_s mm_tbuf_t;
193
+
194
+ // global variables
195
+ extern int mm_verbose, mm_dbg_flag; // verbose level: 0 for no info, 1 for error, 2 for warning, 3 for message (default); debugging flag
196
+ extern double mm_realtime0; // wall-clock timer
197
+
198
+ /**
199
+ * Set default or preset parameters
200
+ *
201
+ * @param preset NULL to set all parameters as default; otherwise apply preset to affected parameters
202
+ * @param io pointer to indexing parameters
203
+ * @param mo pointer to mapping parameters
204
+ *
205
+ * @return 0 if success; -1 if _present_ unknown
206
+ */
207
+ int mm_set_opt(const char *preset, mm_idxopt_t *io, mm_mapopt_t *mo);
208
+ int mm_check_opt(const mm_idxopt_t *io, const mm_mapopt_t *mo);
209
+
210
+ /**
211
+ * Update mm_mapopt_t::mid_occ via mm_mapopt_t::mid_occ_frac
212
+ *
213
+ * If mm_mapopt_t::mid_occ is 0, this function sets it to a number such that no
214
+ * more than mm_mapopt_t::mid_occ_frac of minimizers in the index have a higher
215
+ * occurrence.
216
+ *
217
+ * @param opt mapping parameters
218
+ * @param mi minimap2 index
219
+ */
220
+ void mm_mapopt_update(mm_mapopt_t *opt, const mm_idx_t *mi);
221
+
222
+ void mm_mapopt_max_intron_len(mm_mapopt_t *opt, int max_intron_len);
223
+
224
+ /**
225
+ * Initialize an index reader
226
+ *
227
+ * @param fn index or fasta/fastq file name (this function tests the file type)
228
+ * @param opt indexing parameters
229
+ * @param fn_out if not NULL, write built index to this file
230
+ *
231
+ * @return an index reader on success; NULL if fail to open _fn_
232
+ */
233
+ mm_idx_reader_t *mm_idx_reader_open(const char *fn, const mm_idxopt_t *opt, const char *fn_out);
234
+
235
+ /**
236
+ * Read/build an index
237
+ *
238
+ * If the input file is an index file, this function reads one part of the
239
+ * index and returns. If the input file is a sequence file (fasta or fastq),
240
+ * this function constructs the index for about mm_idxopt_t::batch_size bases.
241
+ * Importantly, for a huge collection of sequences, this function may only
242
+ * return an index for part of sequences. It needs to be repeatedly called
243
+ * to traverse the entire index/sequence file.
244
+ *
245
+ * @param r index reader
246
+ * @param n_threads number of threads for constructing index
247
+ *
248
+ * @return an index on success; NULL if reaching the end of the input file
249
+ */
250
+ mm_idx_t *mm_idx_reader_read(mm_idx_reader_t *r, int n_threads);
251
+
252
+ /**
253
+ * Destroy/deallocate an index reader
254
+ *
255
+ * @param r index reader
256
+ */
257
+ void mm_idx_reader_close(mm_idx_reader_t *r);
258
+
259
+ int mm_idx_reader_eof(const mm_idx_reader_t *r);
260
+
261
+ /**
262
+ * Check whether the file contains a minimap2 index
263
+ *
264
+ * @param fn file name
265
+ *
266
+ * @return the file size if fn is an index file; 0 if fn is not.
267
+ */
268
+ int64_t mm_idx_is_idx(const char *fn);
269
+
270
+ /**
271
+ * Load a part of an index
272
+ *
273
+ * Given a uni-part index, this function loads the entire index into memory.
274
+ * Given a multi-part index, it loads one part only and places the file pointer
275
+ * at the end of that part.
276
+ *
277
+ * @param fp pointer to FILE object
278
+ *
279
+ * @return minimap2 index read from fp
280
+ */
281
+ mm_idx_t *mm_idx_load(FILE *fp);
282
+
283
+ /**
284
+ * Append an index (or one part of a full index) to file
285
+ *
286
+ * @param fp pointer to FILE object
287
+ * @param mi minimap2 index
288
+ */
289
+ void mm_idx_dump(FILE *fp, const mm_idx_t *mi);
290
+
291
+ /**
292
+ * Create an index from strings in memory
293
+ *
294
+ * @param w minimizer window size
295
+ * @param k minimizer k-mer size
296
+ * @param is_hpc use HPC k-mer if true
297
+ * @param bucket_bits number of bits for the first level of the hash table
298
+ * @param n number of sequences
299
+ * @param seq sequences in A/C/G/T
300
+ * @param name sequence names; could be NULL
301
+ *
302
+ * @return minimap2 index
303
+ */
304
+ mm_idx_t *mm_idx_str(int w, int k, int is_hpc, int bucket_bits, int n, const char **seq, const char **name);
305
+
306
+ /**
307
+ * Print index statistics to stderr
308
+ *
309
+ * @param mi minimap2 index
310
+ */
311
+ void mm_idx_stat(const mm_idx_t *idx);
312
+
313
+ /**
314
+ * Destroy/deallocate an index
315
+ *
316
+ * @param r minimap2 index
317
+ */
318
+ void mm_idx_destroy(mm_idx_t *mi);
319
+
320
+ /**
321
+ * Initialize a thread-local buffer for mapping
322
+ *
323
+ * Each mapping thread requires a buffer specific to the thread (see mm_map()
324
+ * below). The primary purpose of this buffer is to reduce frequent heap
325
+ * allocations across threads. A buffer shall not be used by two or more
326
+ * threads.
327
+ *
328
+ * @return pointer to a thread-local buffer
329
+ */
330
+ mm_tbuf_t *mm_tbuf_init(void);
331
+
332
+ /**
333
+ * Destroy/deallocate a thread-local buffer for mapping
334
+ *
335
+ * @param b the buffer
336
+ */
337
+ void mm_tbuf_destroy(mm_tbuf_t *b);
338
+
339
+ void *mm_tbuf_get_km(mm_tbuf_t *b);
340
+
341
+ /**
342
+ * Align a query sequence against an index
343
+ *
344
+ * This function possibly finds multiple alignments of the query sequence.
345
+ * The returned array and the mm_reg1_t::p field of each element are allocated
346
+ * with malloc().
347
+ *
348
+ * @param mi minimap2 index
349
+ * @param l_seq length of the query sequence
350
+ * @param seq the query sequence
351
+ * @param n_regs number of hits (out)
352
+ * @param b thread-local buffer; two mm_map() calls shall not use one buffer at the same time!
353
+ * @param opt mapping parameters
354
+ * @param name query name, used for all-vs-all overlapping and debugging
355
+ *
356
+ * @return an array of hits which need to be deallocated with free() together
357
+ * with mm_reg1_t::p of each element. The size is written to _n_regs_.
358
+ */
359
+ mm_reg1_t *mm_map(const mm_idx_t *mi, int l_seq, const char *seq, int *n_regs, mm_tbuf_t *b, const mm_mapopt_t *opt, const char *name);
360
+
361
+ void mm_map_frag(const mm_idx_t *mi, int n_segs, const int *qlens, const char **seqs, int *n_regs, mm_reg1_t **regs, mm_tbuf_t *b, const mm_mapopt_t *opt, const char *qname);
362
+
363
+ /**
364
+ * Align a fasta/fastq file and print alignments to stdout
365
+ *
366
+ * @param idx minimap2 index
367
+ * @param fn fasta/fastq file name
368
+ * @param opt mapping parameters
369
+ * @param n_threads number of threads
370
+ *
371
+ * @return 0 on success; -1 if _fn_ can't be read
372
+ */
373
+ int mm_map_file(const mm_idx_t *idx, const char *fn, const mm_mapopt_t *opt, int n_threads);
374
+
375
+ int mm_map_file_frag(const mm_idx_t *idx, int n_segs, const char **fn, const mm_mapopt_t *opt, int n_threads);
376
+
377
+ /**
378
+ * Generate the cs tag (new in 2.12)
379
+ *
380
+ * @param km memory blocks; set to NULL if unsure
381
+ * @param buf buffer to write the cs/MD tag; typicall NULL on the first call
382
+ * @param max_len max length of the buffer; typically set to 0 on the first call
383
+ * @param mi index
384
+ * @param r alignment
385
+ * @param seq query sequence
386
+ * @param no_iden true to use : instead of =
387
+ *
388
+ * @return the length of cs
389
+ */
390
+ int mm_gen_cs(void *km, char **buf, int *max_len, const mm_idx_t *mi, const mm_reg1_t *r, const char *seq, int no_iden);
391
+ int mm_gen_MD(void *km, char **buf, int *max_len, const mm_idx_t *mi, const mm_reg1_t *r, const char *seq);
392
+
393
+ // query sequence name and sequence in the minimap2 index
394
+ int mm_idx_index_name(mm_idx_t *mi);
395
+ int mm_idx_name2id(const mm_idx_t *mi, const char *name);
396
+ int mm_idx_getseq(const mm_idx_t *mi, uint32_t rid, uint32_t st, uint32_t en, uint8_t *seq);
397
+
398
+ int mm_idx_alt_read(mm_idx_t *mi, const char *fn);
399
+ int mm_idx_bed_read(mm_idx_t *mi, const char *fn, int read_junc);
400
+ int mm_idx_bed_junc(const mm_idx_t *mi, int32_t ctg, int32_t st, int32_t en, uint8_t *s);
401
+
402
+ // deprecated APIs for backward compatibility
403
+ void mm_mapopt_init(mm_mapopt_t *opt);
404
+ mm_idx_t *mm_idx_build(const char *fn, int w, int k, int flag, int n_threads);
405
+
406
+ #ifdef __cplusplus
407
+ }
408
+ #endif
409
+
410
+ #endif // MINIMAP2_H