Merge pull request #4 from ephraimkunz/print-system-info

Fix print_system_info to correctly return a static &str
This commit is contained in:
0/0 2022-12-04 11:09:08 -07:00 committed by GitHub
commit 5fb138f5b7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 11 additions and 7 deletions

View File

@ -1,7 +1,7 @@
//! Standalone functions that have no associated type.
use crate::WhisperToken;
use std::ffi::{c_int, CString};
use std::ffi::{c_int, CStr, CString};
/// Return the id of the specified language, returns -1 if not found
///
@ -47,6 +47,8 @@ pub fn token_transcribe() -> WhisperToken {
///
/// # C++ equivalent
/// `const char * whisper_print_system_info()`
pub fn print_system_info() {
unsafe { whisper_rs_sys::whisper_print_system_info() };
pub fn print_system_info() -> &'static str {
let c_buf = unsafe { whisper_rs_sys::whisper_print_system_info() };
let c_str = unsafe { CStr::from_ptr(c_buf) };
c_str.to_str().unwrap()
}

View File

@ -111,6 +111,7 @@ pub fn convert_stereo_to_mono_audio_simd(samples: &[f32]) -> Vec<f32> {
mono
}
#[cfg(feature = "simd")]
#[cfg(test)]
mod test {
use super::*;

View File

@ -363,7 +363,7 @@ impl WhisperContext {
unsafe { whisper_rs_sys::whisper_token_beg(self.ctx) }
}
/// Print performance statistics to stdout.
/// Print performance statistics to stderr.
///
/// # C++ equivalent
/// `void whisper_print_timings(struct whisper_context * ctx)`

View File

@ -12,7 +12,8 @@ fn main() {
let _: u64 = std::fs::copy(
"src/bindings.rs",
env::var("OUT_DIR").unwrap() + "/bindings.rs",
).expect("Failed to copy bindings.rs");
)
.expect("Failed to copy bindings.rs");
} else {
let bindings = bindgen::Builder::default()
.header("wrapper.h")