#[allow(non_upper_case_globals)]
#[allow(non_snake_case)]
#[allow(non_camel_case_types)]
#[allow(unused)]
mod wfa {
include!(concat!(env!("OUT_DIR"), "/bindings_wfa.rs"));
}
fn linear_score(a: &[i8], b: &[i8], sub: i32, indel: i32) -> i32 {
unsafe {
let mut attributes = wfa::wavefront_aligner_attr_default;
attributes.heuristic.strategy = wfa::wf_heuristic_strategy_wf_heuristic_none;
attributes.alignment_scope = wfa::alignment_scope_t_compute_score;
attributes.distance_metric = wfa::distance_metric_t_gap_affine;
attributes.affine_penalties.mismatch = mismatch as i32;
attributes.affine_penalties.gap_opening = gap_open as i32;
attributes.affine_penalties.gap_extension = gap_extend as i32;
let wf_aligner = wfa::wavefront_aligner_new(&mut attributes);
let status = wfa::wavefront_align(
wf_aligner,
a.as_ptr(),
a.len() as i32,
b.as_ptr(),
b.len() as i32,
);
assert_eq!(status, 0);
let score = (*wf_aligner).cigar.score;
wfa::wavefront_aligner_delete(wf_aligner);
score
}
}