Merge branch 'tazz4843:master' into fix/progress-callback-crash
This commit is contained in:
commit
138020527c
2 changed files with 49 additions and 23 deletions
|
|
@ -376,6 +376,7 @@ impl<'a, 'b> FullParams<'a, 'b> {
|
|||
/// Do not use this function unless you know what you are doing.
|
||||
/// * Be careful not to mutate the state of the whisper_context pointer returned in the callback.
|
||||
/// This could cause undefined behavior, as this violates the thread-safety guarantees of the underlying C library.
|
||||
/// **Warning** Can't be used with DTW. DTW will produce inconsistent callback invocation
|
||||
///
|
||||
/// Defaults to None.
|
||||
pub unsafe fn set_new_segment_callback(
|
||||
|
|
@ -389,6 +390,7 @@ impl<'a, 'b> FullParams<'a, 'b> {
|
|||
///
|
||||
/// # Safety
|
||||
/// See the safety notes for `set_new_segment_callback`.
|
||||
/// **Warning** Can't be used with DTW. DTW will produce inconsistent callback invocation
|
||||
///
|
||||
/// Defaults to None.
|
||||
pub unsafe fn set_new_segment_callback_user_data(&mut self, user_data: *mut std::ffi::c_void) {
|
||||
|
|
@ -399,6 +401,7 @@ impl<'a, 'b> FullParams<'a, 'b> {
|
|||
///
|
||||
/// Provides a limited segment_callback to ensure safety.
|
||||
/// See `set_new_segment_callback` if you need to use `whisper_context` and `whisper_state`
|
||||
/// **Warning** Can't be used with DTW. DTW will produce inconsistent callback invocation
|
||||
///
|
||||
/// Defaults to None.
|
||||
pub fn set_segment_callback_safe<O, F>(&mut self, closure: O)
|
||||
|
|
@ -419,15 +422,20 @@ impl<'a, 'b> FullParams<'a, 'b> {
|
|||
{
|
||||
unsafe {
|
||||
let user_data = &mut *(user_data as *mut SegmentCallbackFn);
|
||||
let text = whisper_rs_sys::whisper_full_get_segment_text_from_state(state, n_new);
|
||||
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 = CStr::from_ptr(text);
|
||||
|
||||
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);
|
||||
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);
|
||||
|
||||
match text.to_str() {
|
||||
Ok(n) => user_data(SegmentCallbackData {
|
||||
segment: n_new + 1,
|
||||
segment: i,
|
||||
start_timestamp: t0,
|
||||
end_timestamp: t1,
|
||||
text: n.to_string(),
|
||||
|
|
@ -436,6 +444,7 @@ impl<'a, 'b> FullParams<'a, 'b> {
|
|||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
match closure.into() {
|
||||
Some(closure) => {
|
||||
|
|
@ -462,6 +471,7 @@ impl<'a, 'b> FullParams<'a, 'b> {
|
|||
///
|
||||
/// Provides a limited segment_callback to ensure safety with lossy handling of bad UTF-8 characters.
|
||||
/// See `set_new_segment_callback` if you need to use `whisper_context` and `whisper_state`.
|
||||
/// **Warning** Can't be used with DTW. DTW will produce inconsistent callback invocation
|
||||
///
|
||||
/// Defaults to None.
|
||||
pub fn set_segment_callback_safe_lossy<O, F>(&mut self, closure: O)
|
||||
|
|
@ -482,19 +492,25 @@ impl<'a, 'b> FullParams<'a, 'b> {
|
|||
{
|
||||
unsafe {
|
||||
let user_data = &mut *(user_data as *mut SegmentCallbackFn);
|
||||
let text = whisper_rs_sys::whisper_full_get_segment_text_from_state(state, n_new);
|
||||
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 = CStr::from_ptr(text);
|
||||
|
||||
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);
|
||||
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);
|
||||
user_data(SegmentCallbackData {
|
||||
segment: n_new,
|
||||
segment: i,
|
||||
start_timestamp: t0,
|
||||
end_timestamp: t1,
|
||||
text: text.to_string_lossy().to_string(),
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
match closure.into() {
|
||||
Some(closure) => {
|
||||
|
|
|
|||
12
sys/build.rs
12
sys/build.rs
|
|
@ -164,6 +164,10 @@ fn main() {
|
|||
.very_verbose(true)
|
||||
.pic(true);
|
||||
|
||||
if cfg!(target_os = "windows") {
|
||||
config.cxxflag("/utf-8");
|
||||
}
|
||||
|
||||
if cfg!(feature = "coreml") {
|
||||
config.define("WHISPER_COREML", "ON");
|
||||
config.define("WHISPER_COREML_ALLOW_FALLBACK", "1");
|
||||
|
|
@ -214,6 +218,12 @@ fn main() {
|
|||
|
||||
if cfg!(feature = "openblas") {
|
||||
config.define("GGML_BLAS", "ON");
|
||||
config.define("GGML_BLAS_VENDOR", "OpenBLAS");
|
||||
if env::var("BLAS_INCLUDE_DIRS").is_err() {
|
||||
panic!("BLAS_INCLUDE_DIRS environment variable must be set when using OpenBLAS");
|
||||
}
|
||||
config.define("BLAS_INCLUDE_DIRS", env::var("BLAS_INCLUDE_DIRS").unwrap());
|
||||
println!("cargo:rerun-if-env-changed=BLAS_INCLUDE_DIRS");
|
||||
}
|
||||
|
||||
if cfg!(feature = "metal") {
|
||||
|
|
@ -255,7 +265,7 @@ fn main() {
|
|||
println!("cargo:rustc-link-lib=static=ggml");
|
||||
println!("cargo:rustc-link-lib=static=ggml-base");
|
||||
println!("cargo:rustc-link-lib=static=ggml-cpu");
|
||||
if cfg!(target_os = "macos") {
|
||||
if cfg!(target_os = "macos") || cfg!(feature = "openblas") {
|
||||
println!("cargo:rustc-link-lib=static=ggml-blas");
|
||||
}
|
||||
if cfg!(feature = "vulkan") {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue