mirror of
https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs.git
synced 2025-01-08 02:05:26 +00:00
Update various dependencies
This commit is contained in:
parent
add7fd2693
commit
4e0c3374bd
10 changed files with 65 additions and 27 deletions
|
@ -14,16 +14,16 @@ bytes = "1.0"
|
|||
futures = "0.3"
|
||||
gst = { package = "gstreamer", version = "0.17" }
|
||||
gst-base = { package = "gstreamer-base", version = "0.17" }
|
||||
rusoto_core = "0.46"
|
||||
rusoto_s3 = "0.46"
|
||||
rusoto_credential = "0.46"
|
||||
rusoto_signature = "0.46"
|
||||
rusoto_core = "0.47"
|
||||
rusoto_s3 = "0.47"
|
||||
rusoto_credential = "0.47"
|
||||
rusoto_signature = "0.47"
|
||||
url = "2"
|
||||
percent-encoding = "2"
|
||||
tokio = { version = "1.0", features = [ "rt-multi-thread" ] }
|
||||
async-tungstenite = { version = "0.13", features = ["tokio", "tokio-runtime", "tokio-native-tls"] }
|
||||
nom = "6"
|
||||
crc = "1.8.1"
|
||||
async-tungstenite = { version = "0.14", features = ["tokio", "tokio-runtime", "tokio-native-tls"] }
|
||||
nom = "7"
|
||||
crc = "2"
|
||||
byteorder = "1.3.4"
|
||||
once_cell = "1.0"
|
||||
serde = "1"
|
||||
|
|
|
@ -16,7 +16,6 @@
|
|||
// Boston, MA 02110-1335, USA.
|
||||
|
||||
use byteorder::{BigEndian, WriteBytesExt};
|
||||
use crc::crc32;
|
||||
use nom::{
|
||||
self, bytes::complete::take, combinator::map_res, multi::many0, number::complete::be_u16,
|
||||
number::complete::be_u32, number::complete::be_u8, sequence::tuple, IResult,
|
||||
|
@ -24,6 +23,8 @@ use nom::{
|
|||
use std::borrow::Cow;
|
||||
use std::io::{self, Write};
|
||||
|
||||
const CRC: crc::Crc<u32> = crc::Crc::<u32>::new(&crc::CRC_32_BZIP2);
|
||||
|
||||
#[derive(Debug)]
|
||||
struct Prelude {
|
||||
total_bytes: u32,
|
||||
|
@ -87,11 +88,11 @@ pub fn encode_packet(payload: &[u8], headers: &[Header]) -> Result<Vec<u8>, io::
|
|||
(&mut res[0..4]).write_u32::<BigEndian>(total_length as u32)?;
|
||||
|
||||
// Rewrite the prelude crc since we replaced the lengths
|
||||
let prelude_crc = crc32::checksum_ieee(&res[0..8]);
|
||||
let prelude_crc = CRC.checksum(&res[0..8]);
|
||||
(&mut res[8..12]).write_u32::<BigEndian>(prelude_crc)?;
|
||||
|
||||
// Message CRC
|
||||
let message_crc = crc32::checksum_ieee(&res);
|
||||
let message_crc = CRC.checksum(&res);
|
||||
res.write_u32::<BigEndian>(message_crc)?;
|
||||
|
||||
Ok(res)
|
||||
|
@ -101,7 +102,7 @@ fn parse_prelude(input: &[u8]) -> IResult<&[u8], Prelude> {
|
|||
map_res(
|
||||
tuple((be_u32, be_u32, be_u32)),
|
||||
|(total_bytes, header_bytes, prelude_crc)| {
|
||||
let sum = crc32::checksum_ieee(&input[0..8]);
|
||||
let sum = CRC.checksum(&input[0..8]);
|
||||
if prelude_crc != sum {
|
||||
return Err(nom::Err::Error((
|
||||
"Prelude CRC doesn't match",
|
||||
|
@ -148,7 +149,7 @@ pub fn parse_packet(input: &[u8]) -> IResult<&[u8], Packet> {
|
|||
let (remainder, prelude) = parse_prelude(input)?;
|
||||
|
||||
// Check the crc of the whole input
|
||||
let sum = crc32::checksum_ieee(&input[..input.len() - 4]);
|
||||
let sum = CRC.checksum(&input[..input.len() - 4]);
|
||||
let (_, msg_crc) = be_u32(&input[input.len() - 4..])?;
|
||||
|
||||
if msg_crc != sum {
|
||||
|
|
|
@ -9,7 +9,7 @@ repository = "https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs"
|
|||
|
||||
[dependencies]
|
||||
once_cell = "1.0"
|
||||
regex = "1"
|
||||
regex = "1.5"
|
||||
|
||||
[dependencies.gst]
|
||||
version = "0.17"
|
||||
|
|
|
@ -9,7 +9,7 @@ repository = "https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs"
|
|||
|
||||
[dependencies]
|
||||
once_cell = "1.0"
|
||||
textwrap = { version = "0.13.2", features = ["hyphenation"] }
|
||||
textwrap = { version = "0.14", features = ["hyphenation"] }
|
||||
hyphenation = "0.8"
|
||||
|
||||
[dependencies.gst]
|
||||
|
|
|
@ -62,8 +62,36 @@ 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 {
|
||||
options: Option<textwrap::Options<'static, Box<dyn textwrap::WordSplitter + Send>>>,
|
||||
options: Option<
|
||||
textwrap::Options<
|
||||
'static,
|
||||
textwrap::wrap_algorithms::OptimalFit,
|
||||
textwrap::word_separators::UnicodeBreakProperties,
|
||||
WrappedWordSplitter,
|
||||
>,
|
||||
>,
|
||||
|
||||
current_text: String,
|
||||
start_ts: Option<gst::ClockTime>,
|
||||
|
@ -125,14 +153,14 @@ impl TextWrap {
|
|||
Ok(standard) => standard,
|
||||
};
|
||||
|
||||
Some(textwrap::Options::with_splitter(
|
||||
Some(textwrap::Options::with_word_splitter(
|
||||
settings.columns as usize,
|
||||
Box::new(standard),
|
||||
WrappedWordSplitter(Box::new(standard)),
|
||||
))
|
||||
} else {
|
||||
Some(textwrap::Options::with_splitter(
|
||||
Some(textwrap::Options::with_word_splitter(
|
||||
settings.columns as usize,
|
||||
Box::new(textwrap::NoHyphenation),
|
||||
WrappedWordSplitter(Box::new(textwrap::word_splitters::NoHyphenation)),
|
||||
))
|
||||
};
|
||||
}
|
||||
|
@ -221,7 +249,7 @@ impl TextWrap {
|
|||
.as_ref()
|
||||
.expect("We should have a wrapper by now");
|
||||
|
||||
let lines = textwrap::wrap(¤t_text, options);
|
||||
let lines = textwrap::wrap(¤t_text, &*options);
|
||||
let mut chunks = lines.chunks(n_lines as usize).peekable();
|
||||
let mut trailing = "".to_string();
|
||||
|
||||
|
@ -287,7 +315,7 @@ impl TextWrap {
|
|||
.options
|
||||
.as_ref()
|
||||
.expect("We should have a wrapper by now");
|
||||
textwrap::fill(data, options)
|
||||
textwrap::fill(data, &*options)
|
||||
};
|
||||
|
||||
// If the lines property was set, we want to split the result into buffers
|
||||
|
|
|
@ -9,7 +9,7 @@ repository = "https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs"
|
|||
|
||||
[dependencies]
|
||||
anyhow = "1"
|
||||
nom = "6.0"
|
||||
nom = "7.0"
|
||||
either = "1"
|
||||
uuid = { version = "0.8", features = ["v4"] }
|
||||
chrono = "0.4"
|
||||
|
|
|
@ -257,7 +257,7 @@ fn mcc_payload(s: &[u8]) -> IResult<&[u8], Vec<u8>> {
|
|||
|
||||
context(
|
||||
"invalid MCC payload",
|
||||
fold_many1(mcc_payload_item, Vec::new(), |mut acc: Vec<_>, item| {
|
||||
fold_many1(mcc_payload_item, Vec::new, |mut acc: Vec<_>, item| {
|
||||
match item {
|
||||
Either::Left(val) => acc.push(val),
|
||||
Either::Right(vals) => acc.extend_from_slice(vals),
|
||||
|
|
|
@ -109,7 +109,7 @@ fn scc_payload(s: &[u8]) -> IResult<&[u8], Vec<u8>> {
|
|||
|
||||
context(
|
||||
"invalid SCC payload",
|
||||
fold_many1(parse_item, Vec::new(), |mut acc: Vec<_>, item| {
|
||||
fold_many1(parse_item, Vec::new, |mut acc: Vec<_>, item| {
|
||||
acc.push(item.0);
|
||||
acc.push(item.1);
|
||||
acc
|
||||
|
|
|
@ -10,7 +10,7 @@ description = "An PNG encoder/decoder written in pure Rust"
|
|||
[dependencies]
|
||||
gst = { package = "gstreamer", version = "0.17" }
|
||||
gst_video = { package = "gstreamer-video", version = "0.17" }
|
||||
png = "0.16.3"
|
||||
png = "0.17"
|
||||
once_cell = "1"
|
||||
parking_lot = "0.11"
|
||||
atomic_refcell = "0.1"
|
||||
|
|
|
@ -124,8 +124,8 @@ impl State {
|
|||
gst_video::VideoFormat::Gray8 | gst_video::VideoFormat::Gray16Be => {
|
||||
png::ColorType::Grayscale
|
||||
}
|
||||
gst_video::VideoFormat::Rgb => png::ColorType::RGB,
|
||||
gst_video::VideoFormat::Rgba => png::ColorType::RGBA,
|
||||
gst_video::VideoFormat::Rgb => png::ColorType::Rgb,
|
||||
gst_video::VideoFormat::Rgba => png::ColorType::Rgba,
|
||||
_ => {
|
||||
gst_error!(CAT, "format is not supported yet");
|
||||
unreachable!()
|
||||
|
@ -333,6 +333,15 @@ impl VideoEncoderImpl for PngEncoder {
|
|||
let mut state_guard = self.state.lock();
|
||||
let state = state_guard.as_mut().ok_or(gst::FlowError::NotNegotiated)?;
|
||||
|
||||
// FIXME: https://github.com/image-rs/image-png/issues/301
|
||||
{
|
||||
let settings = self.settings.lock();
|
||||
state.reset(*settings).map_err(|err| {
|
||||
err.log_with_object(element);
|
||||
gst::FlowError::Error
|
||||
})?;
|
||||
}
|
||||
|
||||
gst_debug!(
|
||||
CAT,
|
||||
obj: element,
|
||||
|
|
Loading…
Reference in a new issue