textwrap: Update for textwrap 0.15 API changes

This commit is contained in:
Sebastian Dröge 2022-02-27 11:00:30 +02:00
parent 88262e596d
commit cb0a67fc31
2 changed files with 10 additions and 40 deletions

View file

@ -10,7 +10,7 @@ repository = "https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs"
[dependencies] [dependencies]
once_cell = "1.0" once_cell = "1.0"
textwrap = { version = "0.14", features = ["hyphenation"] } textwrap = { version = "0.15", features = ["hyphenation"] }
hyphenation = "0.8" hyphenation = "0.8"
[dependencies.gst] [dependencies.gst]

View file

@ -53,36 +53,8 @@ impl Default for Settings {
} }
} }
// FIXME: https://github.com/mgeisler/textwrap/issues/412
#[derive(Debug)]
struct WrappedWordSplitter(Box<dyn textwrap::word_splitters::WordSplitter + Send>);
impl textwrap::word_splitters::WordSplitter for WrappedWordSplitter {
fn split_points(&self, word: &str) -> Vec<usize> {
self.0.split_points(word)
}
}
impl Clone for WrappedWordSplitter {
fn clone(&self) -> Self {
WrappedWordSplitter(unsafe {
std::mem::transmute::<
Box<dyn textwrap::word_splitters::WordSplitter + 'static>,
Box<dyn textwrap::word_splitters::WordSplitter + Send + 'static>,
>(self.0.clone_box())
})
}
}
struct State { struct State {
options: Option< options: Option<textwrap::Options<'static>>,
textwrap::Options<
'static,
textwrap::wrap_algorithms::OptimalFit,
textwrap::word_separators::UnicodeBreakProperties,
WrappedWordSplitter,
>,
>,
current_text: String, current_text: String,
start_ts: Option<gst::ClockTime>, start_ts: Option<gst::ClockTime>,
@ -121,7 +93,9 @@ impl TextWrap {
return; return;
} }
state.options = if let Some(dictionary) = &settings.dictionary { let mut options = textwrap::Options::new(settings.columns as usize);
if let Some(dictionary) = &settings.dictionary {
let dict_file = match File::open(dictionary) { let dict_file = match File::open(dictionary) {
Err(err) => { Err(err) => {
gst_error!(CAT, obj: element, "Failed to open dictionary file: {}", err); gst_error!(CAT, obj: element, "Failed to open dictionary file: {}", err);
@ -144,16 +118,12 @@ impl TextWrap {
Ok(standard) => standard, Ok(standard) => standard,
}; };
Some(textwrap::Options::with_word_splitter( options.word_splitter = textwrap::WordSplitter::Hyphenation(standard);
settings.columns as usize,
WrappedWordSplitter(Box::new(standard)),
))
} else { } else {
Some(textwrap::Options::with_word_splitter( options.word_splitter = textwrap::WordSplitter::NoHyphenation;
settings.columns as usize, }
WrappedWordSplitter(Box::new(textwrap::word_splitters::NoHyphenation)),
)) state.options = Some(options);
};
} }
fn sink_chain( fn sink_chain(