fix: segment_callaback logic

This commit is contained in:
newfla 2025-02-25 15:56:16 +01:00
parent a5d279c31b
commit 684ec8e733

View file

@ -419,20 +419,15 @@ impl<'a, 'b> FullParams<'a, 'b> {
{
unsafe {
let user_data = &mut *(user_data as *mut SegmentCallbackFn);
let n_segments = whisper_rs_sys::whisper_full_n_segments_from_state(state);
let s0 = n_segments - n_new;
//let user_data = user_data as *mut Box<dyn FnMut(SegmentCallbackData)>;
for i in s0..n_segments {
let text = whisper_rs_sys::whisper_full_get_segment_text_from_state(state, i);
let text = whisper_rs_sys::whisper_full_get_segment_text_from_state(state, n_new);
let text = CStr::from_ptr(text);
let t0 = whisper_rs_sys::whisper_full_get_segment_t0_from_state(state, i);
let t1 = whisper_rs_sys::whisper_full_get_segment_t1_from_state(state, i);
let t0 = whisper_rs_sys::whisper_full_get_segment_t0_from_state(state, n_new);
let t1 = whisper_rs_sys::whisper_full_get_segment_t1_from_state(state, n_new);
match text.to_str() {
Ok(n) => user_data(SegmentCallbackData {
segment: i,
segment: n_new + 1,
start_timestamp: t0,
end_timestamp: t1,
text: n.to_string(),
@ -441,7 +436,6 @@ impl<'a, 'b> FullParams<'a, 'b> {
}
}
}
}
match closure.into() {
Some(closure) => {
@ -488,25 +482,19 @@ impl<'a, 'b> FullParams<'a, 'b> {
{
unsafe {
let user_data = &mut *(user_data as *mut SegmentCallbackFn);
let n_segments = whisper_rs_sys::whisper_full_n_segments_from_state(state);
let s0 = n_segments - n_new;
//let user_data = user_data as *mut Box<dyn FnMut(SegmentCallbackData)>;
for i in s0..n_segments {
let text = whisper_rs_sys::whisper_full_get_segment_text_from_state(state, i);
let text = whisper_rs_sys::whisper_full_get_segment_text_from_state(state, n_new);
let text = CStr::from_ptr(text);
let t0 = whisper_rs_sys::whisper_full_get_segment_t0_from_state(state, i);
let t1 = whisper_rs_sys::whisper_full_get_segment_t1_from_state(state, i);
let t0 = whisper_rs_sys::whisper_full_get_segment_t0_from_state(state, n_new);
let t1 = whisper_rs_sys::whisper_full_get_segment_t1_from_state(state, n_new);
user_data(SegmentCallbackData {
segment: i,
segment: n_new,
start_timestamp: t0,
end_timestamp: t1,
text: text.to_string_lossy().to_string(),
});
}
}
}
match closure.into() {
Some(closure) => {