Convert full_get_segment_* and similar to use an internal helper instead of duplicating code
This commit is contained in:
parent
099faf4e2e
commit
9a96b0e1c3
1 changed files with 33 additions and 37 deletions
|
|
@ -346,25 +346,43 @@ impl WhisperState {
|
||||||
Ok(unsafe { whisper_rs_sys::whisper_full_get_segment_t1_from_state(self.ptr, segment) })
|
Ok(unsafe { whisper_rs_sys::whisper_full_get_segment_t1_from_state(self.ptr, segment) })
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn full_get_segment_raw(&self, segment: c_int) -> Result<&CStr, WhisperError> {
|
||||||
|
let ret =
|
||||||
|
unsafe { whisper_rs_sys::whisper_full_get_segment_text_from_state(self.ptr, segment) };
|
||||||
|
if ret.is_null() {
|
||||||
|
return Err(WhisperError::NullPointer);
|
||||||
|
}
|
||||||
|
unsafe { Ok(CStr::from_ptr(ret)) }
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Get the raw bytes of the specified segment.
|
||||||
|
///
|
||||||
|
/// # Arguments
|
||||||
|
/// * segment: Segment index.
|
||||||
|
///
|
||||||
|
/// # Returns
|
||||||
|
/// `Ok(Vec<u8>)` on success, with the returned bytes or
|
||||||
|
/// `Err(WhisperError::NullPointer)` on failure (this is the only possible error)
|
||||||
|
///
|
||||||
|
/// # C++ equivalent
|
||||||
|
/// `const char * whisper_full_get_segment_text(struct whisper_context * ctx, int i_segment)`
|
||||||
|
pub fn full_get_segment_bytes(&self, segment: c_int) -> Result<Vec<u8>, WhisperError> {
|
||||||
|
Ok(self.full_get_segment_raw(segment)?.to_bytes().to_vec())
|
||||||
|
}
|
||||||
|
|
||||||
/// Get the text of the specified segment.
|
/// Get the text of the specified segment.
|
||||||
///
|
///
|
||||||
/// # Arguments
|
/// # Arguments
|
||||||
/// * segment: Segment index.
|
/// * segment: Segment index.
|
||||||
///
|
///
|
||||||
/// # Returns
|
/// # Returns
|
||||||
/// Ok(String) on success, Err(WhisperError) on failure.
|
/// `Ok(String)` on success, with the UTF-8 validated string, or
|
||||||
|
/// `Err(WhisperError)` on failure (either `NullPointer` or `InvalidUtf8`)
|
||||||
///
|
///
|
||||||
/// # C++ equivalent
|
/// # C++ equivalent
|
||||||
/// `const char * whisper_full_get_segment_text(struct whisper_context * ctx, int i_segment)`
|
/// `const char * whisper_full_get_segment_text(struct whisper_context * ctx, int i_segment)`
|
||||||
pub fn full_get_segment_text(&self, segment: c_int) -> Result<String, WhisperError> {
|
pub fn full_get_segment_text(&self, segment: c_int) -> Result<String, WhisperError> {
|
||||||
let ret =
|
Ok(self.full_get_segment_raw(segment)?.to_str()?.to_string())
|
||||||
unsafe { whisper_rs_sys::whisper_full_get_segment_text_from_state(self.ptr, segment) };
|
|
||||||
if ret.is_null() {
|
|
||||||
return Err(WhisperError::NullPointer);
|
|
||||||
}
|
|
||||||
let c_str = unsafe { CStr::from_ptr(ret) };
|
|
||||||
let r_str = c_str.to_str()?;
|
|
||||||
Ok(r_str.to_string())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Get the text of the specified segment.
|
/// Get the text of the specified segment.
|
||||||
|
|
@ -376,38 +394,16 @@ impl WhisperState {
|
||||||
/// * segment: Segment index.
|
/// * segment: Segment index.
|
||||||
///
|
///
|
||||||
/// # Returns
|
/// # Returns
|
||||||
/// Ok(String) on success, Err(WhisperError) on failure.
|
/// `Ok(String)` on success, or
|
||||||
|
/// `Err(WhisperError::NullPointer)` on failure (this is the only possible error)
|
||||||
///
|
///
|
||||||
/// # C++ equivalent
|
/// # C++ equivalent
|
||||||
/// `const char * whisper_full_get_segment_text(struct whisper_context * ctx, int i_segment)`
|
/// `const char * whisper_full_get_segment_text(struct whisper_context * ctx, int i_segment)`
|
||||||
pub fn full_get_segment_text_lossy(&self, segment: c_int) -> Result<String, WhisperError> {
|
pub fn full_get_segment_text_lossy(&self, segment: c_int) -> Result<String, WhisperError> {
|
||||||
let ret =
|
Ok(self
|
||||||
unsafe { whisper_rs_sys::whisper_full_get_segment_text_from_state(self.ptr, segment) };
|
.full_get_segment_raw(segment)?
|
||||||
if ret.is_null() {
|
.to_string_lossy()
|
||||||
return Err(WhisperError::NullPointer);
|
.to_string())
|
||||||
}
|
|
||||||
let c_str = unsafe { CStr::from_ptr(ret) };
|
|
||||||
Ok(c_str.to_string_lossy().to_string())
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Get the bytes of the specified segment.
|
|
||||||
///
|
|
||||||
/// # Arguments
|
|
||||||
/// * segment: Segment index.
|
|
||||||
///
|
|
||||||
/// # Returns
|
|
||||||
/// `Ok(Vec<u8>)` on success, `Err(WhisperError)` on failure.
|
|
||||||
///
|
|
||||||
/// # C++ equivalent
|
|
||||||
/// `const char * whisper_full_get_segment_text(struct whisper_context * ctx, int i_segment)`
|
|
||||||
pub fn full_get_segment_bytes(&self, segment: c_int) -> Result<Vec<u8>, WhisperError> {
|
|
||||||
let ret =
|
|
||||||
unsafe { whisper_rs_sys::whisper_full_get_segment_text_from_state(self.ptr, segment) };
|
|
||||||
if ret.is_null() {
|
|
||||||
return Err(WhisperError::NullPointer);
|
|
||||||
}
|
|
||||||
let c_str = unsafe { CStr::from_ptr(ret) };
|
|
||||||
Ok(c_str.to_bytes().to_vec())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Get number of tokens in the specified segment.
|
/// Get number of tokens in the specified segment.
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue