Fix various new clippy warnings from 1.40

This commit is contained in:
Sebastian Dröge 2019-12-22 09:59:23 +02:00
parent d2e508eca1
commit fedf4b664a
31 changed files with 101 additions and 108 deletions

View file

@ -168,7 +168,7 @@ fn main_loop(pipeline: gst::Pipeline) -> Result<(), Error> {
.map(|s| String::from(s.get_path_string())) .map(|s| String::from(s.get_path_string()))
.unwrap_or_else(|| String::from("None")), .unwrap_or_else(|| String::from("None")),
error: err.get_error().description().into(), error: err.get_error().description().into(),
debug: Some(err.get_debug().unwrap().to_string()), debug: err.get_debug(),
cause: err.get_error(), cause: err.get_error(),
} }
.into()); .into());

View file

@ -160,7 +160,7 @@ fn main_loop(pipeline: gst::Pipeline) -> Result<(), Error> {
.map(|s| String::from(s.get_path_string())) .map(|s| String::from(s.get_path_string()))
.unwrap_or_else(|| String::from("None")), .unwrap_or_else(|| String::from("None")),
error: err.get_error().description().into(), error: err.get_error().description().into(),
debug: Some(err.get_debug().unwrap().to_string()), debug: err.get_debug(),
cause: err.get_error(), cause: err.get_error(),
} }
.into()); .into());

View file

@ -281,7 +281,7 @@ fn example_main() -> Result<(), Error> {
.map(|s| String::from(s.get_path_string())) .map(|s| String::from(s.get_path_string()))
.unwrap_or_else(|| String::from("None")), .unwrap_or_else(|| String::from("None")),
error: err.get_error().description().into(), error: err.get_error().description().into(),
debug: Some(err.get_debug().unwrap().to_string()), debug: err.get_debug(),
cause: err.get_error(), cause: err.get_error(),
} }
.into()), .into()),
@ -295,7 +295,7 @@ fn example_main() -> Result<(), Error> {
.map(|s| String::from(s.get_path_string())) .map(|s| String::from(s.get_path_string()))
.unwrap_or_else(|| String::from("None")), .unwrap_or_else(|| String::from("None")),
error: err.get_error().description().into(), error: err.get_error().description().into(),
debug: Some(err.get_debug().unwrap().to_string()), debug: err.get_debug(),
cause: err.get_error(), cause: err.get_error(),
} }
.into()); .into());

View file

@ -311,7 +311,7 @@ fn example_main() -> Result<(), Error> {
.map(|s| String::from(s.get_path_string())) .map(|s| String::from(s.get_path_string()))
.unwrap_or_else(|| String::from("None")), .unwrap_or_else(|| String::from("None")),
error: err.get_error().description().into(), error: err.get_error().description().into(),
debug: Some(err.get_debug().unwrap().to_string()), debug: err.get_debug(),
cause: err.get_error(), cause: err.get_error(),
} }
.into()), .into()),
@ -325,7 +325,7 @@ fn example_main() -> Result<(), Error> {
.map(|s| String::from(s.get_path_string())) .map(|s| String::from(s.get_path_string()))
.unwrap_or_else(|| String::from("None")), .unwrap_or_else(|| String::from("None")),
error: err.get_error().description().into(), error: err.get_error().description().into(),
debug: Some(err.get_debug().unwrap().to_string()), debug: err.get_debug(),
cause: err.get_error(), cause: err.get_error(),
} }
.into()); .into());

View file

@ -594,7 +594,7 @@ impl App {
.map(|s| String::from(s.get_path_string())) .map(|s| String::from(s.get_path_string()))
.unwrap_or_else(|| String::from("None")), .unwrap_or_else(|| String::from("None")),
error: err.get_error().description().into(), error: err.get_error().description().into(),
debug: Some(err.get_debug().unwrap().to_string()), debug: err.get_debug(),
cause: err.get_error(), cause: err.get_error(),
} }
.into()); .into());

View file

@ -144,7 +144,6 @@ fn create_ui(app: &gtk::Application) {
// simplifies the code within the callback. What this actually does, however, is creating // simplifies the code within the callback. What this actually does, however, is creating
// a memory leak. // a memory leak.
let video_overlay = sink let video_overlay = sink
.clone()
.dynamic_cast::<gst_video::VideoOverlay>() .dynamic_cast::<gst_video::VideoOverlay>()
.unwrap() .unwrap()
.downgrade(); .downgrade();

View file

@ -213,7 +213,6 @@ fn create_pipeline() -> Result<gst::Pipeline, Error> {
}) })
.unwrap(); .unwrap();
let drawer_clone = drawer.clone();
// Add a signal handler to the overlay's "caps-changed" signal. This could e.g. // Add a signal handler to the overlay's "caps-changed" signal. This could e.g.
// be called when the sink that we render to does not support resizing the image // be called when the sink that we render to does not support resizing the image
// itself - but the user just changed the window-size. The element after the overlay // itself - but the user just changed the window-size. The element after the overlay
@ -226,7 +225,6 @@ fn create_pipeline() -> Result<gst::Pipeline, Error> {
let _overlay = args[0].get::<gst::Element>().unwrap().unwrap(); let _overlay = args[0].get::<gst::Element>().unwrap().unwrap();
let caps = args[1].get::<gst::Caps>().unwrap().unwrap(); let caps = args[1].get::<gst::Caps>().unwrap().unwrap();
let drawer = &drawer_clone;
let mut drawer = drawer.lock().unwrap(); let mut drawer = drawer.lock().unwrap();
drawer.info = Some(gst_video::VideoInfo::from_caps(&caps).unwrap()); drawer.info = Some(gst_video::VideoInfo::from_caps(&caps).unwrap());
@ -257,7 +255,7 @@ fn main_loop(pipeline: gst::Pipeline) -> Result<(), Error> {
.map(|s| String::from(s.get_path_string())) .map(|s| String::from(s.get_path_string()))
.unwrap_or_else(|| String::from("None")), .unwrap_or_else(|| String::from("None")),
error: err.get_error().description().into(), error: err.get_error().description().into(),
debug: Some(err.get_debug().unwrap().to_string()), debug: err.get_debug(),
cause: err.get_error(), cause: err.get_error(),
} }
.into()); .into());

View file

@ -275,7 +275,7 @@ fn example_main() -> Result<(), Error> {
.map(|s| String::from(s.get_path_string())) .map(|s| String::from(s.get_path_string()))
.unwrap_or_else(|| String::from("None")), .unwrap_or_else(|| String::from("None")),
error: err.get_error().description().into(), error: err.get_error().description().into(),
debug: Some(err.get_debug().unwrap().to_string()), debug: err.get_debug(),
cause: err.get_error(), cause: err.get_error(),
} }
.into()); .into());

View file

@ -146,9 +146,8 @@ fn example_main() -> Result<(), Error> {
let sinkpad = get_static_pad(&sink, "sink")?; let sinkpad = get_static_pad(&sink, "sink")?;
srcpad.link(&sinkpad)?; srcpad.link(&sinkpad)?;
let convclone = conv.clone(); src.connect_pad_added(
src.connect_pad_added(move |decodebin, src_pad| { move |decodebin, src_pad| match connect_decodebin_pad(&src_pad, &conv) {
match connect_decodebin_pad(&src_pad, &convclone) {
Ok(_) => (), Ok(_) => (),
Err(err) => { Err(err) => {
gst_element_error!( gst_element_error!(
@ -158,8 +157,8 @@ fn example_main() -> Result<(), Error> {
["{}", err] ["{}", err]
); );
} }
} },
}); );
let video_caps = gst::Caps::new_simple("video/x-raw", &[]); let video_caps = gst::Caps::new_simple("video/x-raw", &[]);
@ -199,7 +198,7 @@ fn example_main() -> Result<(), Error> {
.map(|s| String::from(s.get_path_string())) .map(|s| String::from(s.get_path_string()))
.unwrap_or_else(|| String::from("None")), .unwrap_or_else(|| String::from("None")),
error: err.get_error().description().into(), error: err.get_error().description().into(),
debug: Some(err.get_debug().unwrap().to_string()), debug: err.get_debug(),
cause: err.get_error(), cause: err.get_error(),
} }
.into()); .into());

View file

@ -385,7 +385,7 @@ fn main_loop(pipeline: gst::Pipeline) -> Result<(), Error> {
.map(|s| String::from(s.get_path_string())) .map(|s| String::from(s.get_path_string()))
.unwrap_or_else(|| String::from("None")), .unwrap_or_else(|| String::from("None")),
error: err.get_error().description().into(), error: err.get_error().description().into(),
debug: Some(err.get_debug().unwrap().to_string()), debug: err.get_debug(),
cause: err.get_error(), cause: err.get_error(),
} }
.into()); .into());

View file

@ -109,7 +109,7 @@ fn example_main() -> Result<(), Error> {
.unwrap_or_else(|| "None".into()) .unwrap_or_else(|| "None".into())
.to_string(), .to_string(),
error: err.get_error().description().into(), error: err.get_error().description().into(),
debug: Some(err.get_debug().unwrap().to_string()), debug: err.get_debug(),
cause: err.get_error(), cause: err.get_error(),
} }
.into()); .into());

View file

@ -175,7 +175,7 @@ fn example_main() -> Result<(), Error> {
.map(|s| String::from(s.get_path_string())) .map(|s| String::from(s.get_path_string()))
.unwrap_or_else(|| String::from("None")), .unwrap_or_else(|| String::from("None")),
error: err.get_error().description().into(), error: err.get_error().description().into(),
debug: Some(err.get_debug().unwrap().to_string()), debug: err.get_debug(),
cause: err.get_error(), cause: err.get_error(),
} }
.into()); .into());

View file

@ -488,19 +488,19 @@ mod tests {
use auto::EncodingVideoProfile; use auto::EncodingVideoProfile;
use gst; use gst;
const AUDIO_PROFILE_NAME: &'static str = "audio-profile"; const AUDIO_PROFILE_NAME: &str = "audio-profile";
const AUDIO_PROFILE_DESCRIPTION: &'static str = "audio-profile-description"; const AUDIO_PROFILE_DESCRIPTION: &str = "audio-profile-description";
const PRESET: &'static str = "preset"; const PRESET: &str = "preset";
const PRESET_NAME: &'static str = "preset-name"; const PRESET_NAME: &str = "preset-name";
const PRESENCE: u32 = 5; const PRESENCE: u32 = 5;
const ALLOW_DYNAMIC_OUTPUT: bool = false; const ALLOW_DYNAMIC_OUTPUT: bool = false;
const ENABLED: bool = false; const ENABLED: bool = false;
const VIDEO_PROFILE_NAME: &'static str = "video-profile"; const VIDEO_PROFILE_NAME: &str = "video-profile";
const VIDEO_PROFILE_DESCRIPTION: &'static str = "video-profile-description"; const VIDEO_PROFILE_DESCRIPTION: &str = "video-profile-description";
const CONTAINER_PROFILE_NAME: &'static str = "container-profile"; const CONTAINER_PROFILE_NAME: &str = "container-profile";
const CONTAINER_PROFILE_DESCRIPTION: &'static str = "container-profile-description"; const CONTAINER_PROFILE_DESCRIPTION: &str = "container-profile-description";
// Video profile exclusive attributes // Video profile exclusive attributes
const PASS: u32 = 8; const PASS: u32 = 8;

View file

@ -156,7 +156,6 @@ mod tests {
l.run(); l.run();
let res = res_store.lock().unwrap().take().unwrap(); let res = res_store.lock().unwrap().take().unwrap();
assert!(res.is_ok(), "Error {}", res.unwrap_err());
let res = res.unwrap(); let res = res.unwrap();
let converted_out_caps = res.get_caps().unwrap(); let converted_out_caps = res.get_caps().unwrap();

View file

@ -973,13 +973,13 @@ mod tests {
.expect("Failed to create VideoInfo"); .expect("Failed to create VideoInfo");
assert_eq!(info.stride(), [1920, 1920]); assert_eq!(info.stride(), [1920, 1920]);
assert_eq!(info.offset(), [0, 2073600]); assert_eq!(info.offset(), [0, 2_073_600]);
let mut align = ::VideoAlignment::new(0, 0, 0, 8, &[0; VIDEO_MAX_PLANES]); let mut align = ::VideoAlignment::new(0, 0, 0, 8, &[0; VIDEO_MAX_PLANES]);
assert!(info.align(&mut align)); assert!(info.align(&mut align));
assert_eq!(info.stride(), [1928, 1928]); assert_eq!(info.stride(), [1928, 1928]);
assert_eq!(info.offset(), [0, 2082240]); assert_eq!(info.offset(), [0, 2_082_240]);
} }
#[cfg(any(feature = "v1_12", feature = "dox"))] #[cfg(any(feature = "v1_12", feature = "dox"))]

View file

@ -247,7 +247,7 @@ mod tests {
let mut pretty_config = ron::ser::PrettyConfig::default(); let mut pretty_config = ron::ser::PrettyConfig::default();
pretty_config.new_line = "".to_string(); pretty_config.new_line = "".to_string();
let res = ron::ser::to_string_pretty(&caps, pretty_config.clone()); let res = ron::ser::to_string_pretty(&caps, pretty_config);
assert_eq!( assert_eq!(
Ok(concat!( Ok(concat!(
"Some([", "Some([",
@ -279,7 +279,7 @@ mod tests {
let mut pretty_config = ron::ser::PrettyConfig::default(); let mut pretty_config = ron::ser::PrettyConfig::default();
pretty_config.new_line = "".to_string(); pretty_config.new_line = "".to_string();
let res = ron::ser::to_string_pretty(&caps, pretty_config.clone()); let res = ron::ser::to_string_pretty(&caps, pretty_config);
assert_eq!( assert_eq!(
Ok(concat!( Ok(concat!(
"Some([", "Some([",
@ -339,7 +339,7 @@ mod tests {
assert_eq!(Ok("Any".to_owned()), res); assert_eq!(Ok("Any".to_owned()), res);
let caps_empty = Caps::new_empty(); let caps_empty = Caps::new_empty();
let res = ron::ser::to_string_pretty(&caps_empty, pretty_config.clone()); let res = ron::ser::to_string_pretty(&caps_empty, pretty_config);
assert_eq!(Ok("Empty".to_owned()), res); assert_eq!(Ok("Empty".to_owned()), res);
} }

View file

@ -106,13 +106,7 @@ impl ClockId {
unsafe { unsafe {
let res = let res =
gst_sys::gst_clock_id_compare_func(self.to_glib_none().0, other.to_glib_none().0); gst_sys::gst_clock_id_compare_func(self.to_glib_none().0, other.to_glib_none().0);
if res < 0 { res.cmp(&0)
cmp::Ordering::Less
} else if res > 0 {
cmp::Ordering::Greater
} else {
cmp::Ordering::Equal
}
} }
} }

View file

@ -87,13 +87,7 @@ impl cmp::PartialOrd for DateTime {
fn partial_cmp(&self, other: &Self) -> Option<cmp::Ordering> { fn partial_cmp(&self, other: &Self) -> Option<cmp::Ordering> {
#[inline] #[inline]
fn get_cmp(delta: i32) -> Option<cmp::Ordering> { fn get_cmp(delta: i32) -> Option<cmp::Ordering> {
Some(if delta < 0 { Some(delta.cmp(&0))
cmp::Ordering::Less
} else if delta == 0 {
cmp::Ordering::Equal
} else {
cmp::Ordering::Greater
})
} }
if !(self.has_year() && other.has_year()) { if !(self.has_year() && other.has_year()) {
@ -239,6 +233,7 @@ impl fmt::Display for DateTime {
mod tests { mod tests {
use super::*; use super::*;
#[allow(clippy::cognitive_complexity)]
#[test] #[test]
fn test_to_utc() { fn test_to_utc() {
::init().unwrap(); ::init().unwrap();

View file

@ -197,7 +197,7 @@ mod tests {
assert_eq!(Ok("YM(2018, 5)".to_owned()), res); assert_eq!(Ok("YM(2018, 5)".to_owned()), res);
let datetime = DateTime::new_y(2018); let datetime = DateTime::new_y(2018);
let res = ron::ser::to_string_pretty(&datetime, pretty_config.clone()); let res = ron::ser::to_string_pretty(&datetime, pretty_config);
assert_eq!(Ok("Y(2018)".to_owned()), res); assert_eq!(Ok("Y(2018)".to_owned()), res);
} }

View file

@ -68,13 +68,7 @@ impl cmp::Ord for Seqnum {
fn cmp(&self, other: &Seqnum) -> cmp::Ordering { fn cmp(&self, other: &Seqnum) -> cmp::Ordering {
unsafe { unsafe {
let ret = gst_sys::gst_util_seqnum_compare(self.0, other.0); let ret = gst_sys::gst_util_seqnum_compare(self.0, other.0);
if ret < 0 { ret.cmp(&0)
cmp::Ordering::Less
} else if ret > 0 {
cmp::Ordering::Greater
} else {
cmp::Ordering::Equal
}
} }
} }
} }

View file

@ -125,7 +125,7 @@ mod tests {
assert_eq!("{\"Other\":[\"Percent\",42]}".to_owned(), res); assert_eq!("{\"Other\":[\"Percent\",42]}".to_owned(), res);
let value = GenericFormattedValue::Other(Format::__Unknown(7), 42); let value = GenericFormattedValue::Other(Format::__Unknown(7), 42);
let res = ron::ser::to_string_pretty(&value, pretty_config.clone()); let res = ron::ser::to_string_pretty(&value, pretty_config);
assert_eq!(Ok("Other(__Unknown(7), 42)".to_owned()), res); assert_eq!(Ok("Other(__Unknown(7), 42)".to_owned()), res);
let res = serde_json::to_string(&value).unwrap(); let res = serde_json::to_string(&value).unwrap();
assert_eq!("{\"Other\":[{\"__Unknown\":7},42]}".to_owned(), res); assert_eq!("{\"Other\":[{\"__Unknown\":7},42]}".to_owned(), res);

View file

@ -474,7 +474,7 @@ mod tests {
let log_fn = debug_add_log_function(handler); let log_fn = debug_add_log_function(handler);
gst_info!(cat, obj: &obj, "meh"); gst_info!(cat, obj: &obj, "meh");
let _ = receiver.recv().unwrap(); receiver.recv().unwrap();
debug_remove_log_function(log_fn); debug_remove_log_function(log_fn);

View file

@ -117,7 +117,7 @@ mod tests {
let notify = Arc::new(Mutex::new(None)); let notify = Arc::new(Mutex::new(None));
let notify_clone = notify.clone(); let notify_clone = notify.clone();
bin.connect_deep_notify(None, move |_, id, prop| { bin.connect_deep_notify(None, move |_, id, prop| {
*notify_clone.lock().unwrap() = Some((id.clone(), String::from(prop.get_name()))); *notify_clone.lock().unwrap() = Some((id.clone(), prop.get_name()));
}); });
identity.set_property("silent", &false).unwrap(); identity.set_property("silent", &false).unwrap();

View file

@ -191,8 +191,8 @@ mod tests {
segment.get_flags(), segment.get_flags(),
SegmentFlags::RESET | SegmentFlags::SEGMENT SegmentFlags::RESET | SegmentFlags::SEGMENT
); );
assert_eq!(segment.get_rate(), 1f64); assert!((segment.get_rate() - 1f64).abs() < std::f64::EPSILON);
assert_eq!(segment.get_applied_rate(), 0.9f64); assert!((segment.get_applied_rate() - 0.9f64).abs() < std::f64::EPSILON);
assert_eq!(segment.get_format(), Format::Time); assert_eq!(segment.get_format(), Format::Time);
assert_eq!( assert_eq!(
segment.get_base(), segment.get_base(),
@ -254,8 +254,8 @@ mod tests {
fmt_seg.get_flags(), fmt_seg.get_flags(),
SegmentFlags::RESET | SegmentFlags::SEGMENT SegmentFlags::RESET | SegmentFlags::SEGMENT
); );
assert_eq!(fmt_seg.get_rate(), 1f64); assert!((fmt_seg.get_rate() - 1f64).abs() < std::f64::EPSILON);
assert_eq!(fmt_seg.get_applied_rate(), 0.9f64); assert!((fmt_seg.get_applied_rate() - 0.9f64).abs() < std::f64::EPSILON);
assert_eq!(fmt_seg.get_format(), Format::Time); assert_eq!(fmt_seg.get_format(), Format::Time);
assert_eq!(fmt_seg.get_base(), ClockTime::from_nseconds(123)); assert_eq!(fmt_seg.get_base(), ClockTime::from_nseconds(123));
assert_eq!(fmt_seg.get_offset(), ClockTime::from_nseconds(42)); assert_eq!(fmt_seg.get_offset(), ClockTime::from_nseconds(42));
@ -286,8 +286,10 @@ mod tests {
let segment_de: Segment = ron::de::from_str(segment_se.as_str()).unwrap(); let segment_de: Segment = ron::de::from_str(segment_se.as_str()).unwrap();
assert_eq!(segment_de.get_flags(), segment.get_flags()); assert_eq!(segment_de.get_flags(), segment.get_flags());
assert_eq!(segment_de.get_rate(), segment.get_rate()); assert!((segment_de.get_rate() - segment.get_rate()).abs() < std::f64::EPSILON);
assert_eq!(segment_de.get_applied_rate(), segment.get_applied_rate()); assert!(
(segment_de.get_applied_rate() - segment.get_applied_rate()).abs() < std::f64::EPSILON
);
assert_eq!(segment_de.get_format(), segment.get_format()); assert_eq!(segment_de.get_format(), segment.get_format());
assert_eq!(segment_de.get_base(), segment.get_base()); assert_eq!(segment_de.get_base(), segment.get_base());
assert_eq!(segment_de.get_offset(), segment.get_offset()); assert_eq!(segment_de.get_offset(), segment.get_offset());

View file

@ -523,13 +523,13 @@ mod tests {
use super::*; use super::*;
use glib; use glib;
use glib::subclass; use glib::subclass;
use std::sync::Mutex; use std::sync::atomic;
struct TestElement { struct TestElement {
srcpad: ::Pad, srcpad: ::Pad,
sinkpad: ::Pad, sinkpad: ::Pad,
n_buffers: Mutex<u32>, n_buffers: atomic::AtomicU32,
reached_playing: Mutex<bool>, reached_playing: atomic::AtomicBool,
} }
impl TestElement { impl TestElement {
@ -578,7 +578,7 @@ mod tests {
_element: &::Element, _element: &::Element,
buffer: ::Buffer, buffer: ::Buffer,
) -> Result<::FlowSuccess, ::FlowError> { ) -> Result<::FlowSuccess, ::FlowError> {
*self.n_buffers.lock().unwrap() += 1; self.n_buffers.fetch_add(1, atomic::Ordering::SeqCst);
self.srcpad.push(buffer) self.srcpad.push(buffer)
} }
@ -616,8 +616,8 @@ mod tests {
TestElement::set_pad_functions(&sinkpad, &srcpad); TestElement::set_pad_functions(&sinkpad, &srcpad);
Self { Self {
n_buffers: Mutex::new(0), n_buffers: atomic::AtomicU32::new(0),
reached_playing: Mutex::new(false), reached_playing: atomic::AtomicBool::new(false),
srcpad, srcpad,
sinkpad, sinkpad,
} }
@ -665,7 +665,7 @@ mod tests {
let res = self.parent_change_state(element, transition)?; let res = self.parent_change_state(element, transition)?;
if transition == ::StateChange::PausedToPlaying { if transition == ::StateChange::PausedToPlaying {
*self.reached_playing.lock().unwrap() = true; self.reached_playing.store(true, atomic::Ordering::SeqCst);
} }
Ok(res) Ok(res)
@ -706,7 +706,7 @@ mod tests {
pipeline.set_state(::State::Null).unwrap(); pipeline.set_state(::State::Null).unwrap();
let imp = TestElement::from_instance(&element); let imp = TestElement::from_instance(&element);
assert_eq!(*imp.n_buffers.lock().unwrap(), 100); assert_eq!(imp.n_buffers.load(atomic::Ordering::SeqCst), 100);
assert_eq!(*imp.reached_playing.lock().unwrap(), true); assert_eq!(imp.reached_playing.load(atomic::Ordering::SeqCst), true);
} }
} }

View file

@ -102,11 +102,11 @@ mod tests {
use crate::prelude::*; use crate::prelude::*;
use glib; use glib;
use glib::subclass; use glib::subclass;
use std::sync::Mutex; use std::sync::atomic;
struct TestPad { struct TestPad {
linked: Mutex<bool>, linked: atomic::AtomicBool,
unlinked: Mutex<bool>, unlinked: atomic::AtomicBool,
} }
impl ObjectSubclass for TestPad { impl ObjectSubclass for TestPad {
@ -119,8 +119,8 @@ mod tests {
fn new() -> Self { fn new() -> Self {
Self { Self {
linked: Mutex::new(false), linked: atomic::AtomicBool::new(false),
unlinked: Mutex::new(false), unlinked: atomic::AtomicBool::new(false),
} }
} }
} }
@ -131,12 +131,12 @@ mod tests {
impl PadImpl for TestPad { impl PadImpl for TestPad {
fn linked(&self, pad: &Pad, peer: &Pad) { fn linked(&self, pad: &Pad, peer: &Pad) {
*self.linked.lock().unwrap() = true; self.linked.store(true, atomic::Ordering::SeqCst);
self.parent_linked(pad, peer) self.parent_linked(pad, peer)
} }
fn unlinked(&self, pad: &Pad, peer: &Pad) { fn unlinked(&self, pad: &Pad, peer: &Pad) {
*self.unlinked.lock().unwrap() = true; self.unlinked.store(true, atomic::Ordering::SeqCst);
self.parent_unlinked(pad, peer) self.parent_unlinked(pad, peer)
} }
} }
@ -160,7 +160,7 @@ mod tests {
pad.unlink(&otherpad).unwrap(); pad.unlink(&otherpad).unwrap();
let imp = TestPad::from_instance(&pad); let imp = TestPad::from_instance(&pad);
assert!(*imp.linked.lock().unwrap()); assert!(imp.linked.load(atomic::Ordering::SeqCst));
assert!(*imp.unlinked.lock().unwrap()); assert!(imp.unlinked.load(atomic::Ordering::SeqCst));
} }
} }

View file

@ -893,7 +893,7 @@ mod tests {
{ {
let tags = tags.get_mut().unwrap(); let tags = tags.get_mut().unwrap();
tags.add::<Title>(&"some title", TagMergeMode::Append); tags.add::<Title>(&"some title", TagMergeMode::Append);
tags.add::<Duration>(&(::SECOND * 120).into(), TagMergeMode::Append); tags.add::<Duration>(&(::SECOND * 120), TagMergeMode::Append);
} }
assert_eq!( assert_eq!(
tags.to_string(), tags.to_string(),
@ -910,7 +910,7 @@ mod tests {
{ {
let tags = tags.get_mut().unwrap(); let tags = tags.get_mut().unwrap();
tags.add::<Title>(&"some title", TagMergeMode::Append); tags.add::<Title>(&"some title", TagMergeMode::Append);
tags.add::<Duration>(&(::SECOND * 120).into(), TagMergeMode::Append); tags.add::<Duration>(&(::SECOND * 120), TagMergeMode::Append);
} }
assert_eq!(tags.get::<Title>().unwrap().get(), Some("some title")); assert_eq!(tags.get::<Title>().unwrap().get(), Some("some title"));
@ -939,6 +939,7 @@ mod tests {
} }
#[test] #[test]
#[allow(clippy::cognitive_complexity)]
fn test_generic() { fn test_generic() {
::init().unwrap(); ::init().unwrap();

View file

@ -17,6 +17,7 @@ use serde::ser;
use serde::ser::{Serialize, SerializeSeq, SerializeStruct, SerializeTuple, Serializer}; use serde::ser::{Serialize, SerializeSeq, SerializeStruct, SerializeTuple, Serializer};
use std::cell::RefCell; use std::cell::RefCell;
use std::cmp;
use std::fmt; use std::fmt;
use std::rc::Rc; use std::rc::Rc;
@ -123,18 +124,20 @@ struct TagListSer<'a>(&'a TagListRef);
impl<'a> Serialize for TagListSer<'a> { impl<'a> Serialize for TagListSer<'a> {
fn serialize<S: Serializer>(&self, serializer: S) -> Result<S::Ok, S::Error> { fn serialize<S: Serializer>(&self, serializer: S) -> Result<S::Ok, S::Error> {
let tag_count = self.0.n_tags(); let tag_count = self.0.n_tags();
if tag_count > 0 { match tag_count.cmp(&0) {
cmp::Ordering::Greater => {
let mut seq = serializer.serialize_seq(Some(tag_count as usize))?; let mut seq = serializer.serialize_seq(Some(tag_count as usize))?;
let tag_list_iter = self.0.iter_generic(); let tag_list_iter = self.0.iter_generic();
for (tag_name, tag_iter) in tag_list_iter { for (tag_name, tag_iter) in tag_list_iter {
seq.serialize_element(&TagsSer::new(tag_name, tag_iter))?; seq.serialize_element(&TagsSer::new(tag_name, tag_iter))?;
} }
seq.end() seq.end()
} else if tag_count == 0 { }
cmp::Ordering::Equal => {
let seq = serializer.serialize_seq(None)?; let seq = serializer.serialize_seq(None)?;
seq.end() seq.end()
} else { }
Err(ser::Error::custom("tag count < 0")) cmp::Ordering::Less => Err(ser::Error::custom("tag count < 0")),
} }
} }
} }
@ -337,7 +340,7 @@ mod tests {
let tags = tags.get_mut().unwrap(); let tags = tags.get_mut().unwrap();
tags.add::<Title>(&"a title", TagMergeMode::Append); // String tags.add::<Title>(&"a title", TagMergeMode::Append); // String
tags.add::<Title>(&"another title", TagMergeMode::Append); // String tags.add::<Title>(&"another title", TagMergeMode::Append); // String
tags.add::<Duration>(&(::SECOND * 120).into(), TagMergeMode::Append); // u64 tags.add::<Duration>(&(::SECOND * 120), TagMergeMode::Append); // u64
tags.add::<Bitrate>(&96_000, TagMergeMode::Append); // u32 tags.add::<Bitrate>(&96_000, TagMergeMode::Append); // u32
tags.add::<TrackGain>(&1f64, TagMergeMode::Append); // f64 tags.add::<TrackGain>(&1f64, TagMergeMode::Append); // f64
tags.add::<Date>( tags.add::<Date>(
@ -485,7 +488,9 @@ mod tests {
::SECOND * 120 ::SECOND * 120
); );
assert_eq!(tags.get_index::<Bitrate>(0).unwrap().get_some(), 96_000); assert_eq!(tags.get_index::<Bitrate>(0).unwrap().get_some(), 96_000);
assert_eq!(tags.get_index::<TrackGain>(0).unwrap().get_some(), 1f64); assert!(
(tags.get_index::<TrackGain>(0).unwrap().get_some() - 1f64).abs() < std::f64::EPSILON
);
assert_eq!( assert_eq!(
tags.get_index::<Date>(0).unwrap().get().unwrap(), tags.get_index::<Date>(0).unwrap().get().unwrap(),
glib::Date::new_dmy(28, glib::DateMonth::May, 2018) glib::Date::new_dmy(28, glib::DateMonth::May, 2018)
@ -524,7 +529,9 @@ mod tests {
Some("another title") Some("another title")
); );
assert_eq!(tags.get_index::<Bitrate>(0).unwrap().get_some(), 96_000); assert_eq!(tags.get_index::<Bitrate>(0).unwrap().get_some(), 96_000);
assert_eq!(tags.get_index::<TrackGain>(0).unwrap().get_some(), 1f64); assert!(
(tags.get_index::<TrackGain>(0).unwrap().get_some() - 1f64).abs() < std::f64::EPSILON
);
assert_eq!( assert_eq!(
tags.get_index::<Date>(0).unwrap().get().unwrap(), tags.get_index::<Date>(0).unwrap().get().unwrap(),
glib::Date::new_dmy(28, glib::DateMonth::May, 2018) glib::Date::new_dmy(28, glib::DateMonth::May, 2018)
@ -552,7 +559,7 @@ mod tests {
tags.set_scope(TagScope::Global); tags.set_scope(TagScope::Global);
tags.add::<Title>(&"a title", TagMergeMode::Append); // String tags.add::<Title>(&"a title", TagMergeMode::Append); // String
tags.add::<Title>(&"another title", TagMergeMode::Append); // String tags.add::<Title>(&"another title", TagMergeMode::Append); // String
tags.add::<Duration>(&(::SECOND * 120).into(), TagMergeMode::Append); // u64 tags.add::<Duration>(&(::SECOND * 120), TagMergeMode::Append); // u64
tags.add::<Bitrate>(&96_000, TagMergeMode::Append); // u32 tags.add::<Bitrate>(&96_000, TagMergeMode::Append); // u32
tags.add::<TrackGain>(&1f64, TagMergeMode::Append); // f64 tags.add::<TrackGain>(&1f64, TagMergeMode::Append); // f64
tags.add::<Date>( tags.add::<Date>(
@ -593,9 +600,11 @@ mod tests {
tags_de.get_index::<Bitrate>(0).unwrap().get_some(), tags_de.get_index::<Bitrate>(0).unwrap().get_some(),
tags.get_index::<Bitrate>(0).unwrap().get_some(), tags.get_index::<Bitrate>(0).unwrap().get_some(),
); );
assert_eq!( assert!(
tags_de.get_index::<TrackGain>(0).unwrap().get_some(), (tags_de.get_index::<TrackGain>(0).unwrap().get_some()
tags.get_index::<TrackGain>(0).unwrap().get_some(), - tags.get_index::<TrackGain>(0).unwrap().get_some())
.abs()
< std::f64::EPSILON
); );
assert_eq!( assert_eq!(
tags_de.get_index::<Date>(0).unwrap().get(), tags_de.get_index::<Date>(0).unwrap().get(),

View file

@ -283,6 +283,7 @@ mod tests {
); );
} }
#[allow(clippy::cognitive_complexity)]
#[test] #[test]
fn test_deserialize() { fn test_deserialize() {
use tags::Title; use tags::Title;
@ -417,6 +418,7 @@ mod tests {
assert_eq!(0, chapter2.get_sub_entries().len()); assert_eq!(0, chapter2.get_sub_entries().len());
} }
#[allow(clippy::cognitive_complexity)]
#[test] #[test]
fn test_serde_roundtrip() { fn test_serde_roundtrip() {
::init().unwrap(); ::init().unwrap();

View file

@ -913,9 +913,9 @@ mod tests {
let f1 = ::Fraction::new(1, 2); let f1 = ::Fraction::new(1, 2);
let f2 = ::Fraction::new(2, 3); let f2 = ::Fraction::new(2, 3);
let mut f3 = f1 * f2; let mut f3 = f1 * f2;
let f4 = f1 * &f2; let f4 = f1 * f2;
f3 *= f2; f3 *= f2;
f3 *= &f4; f3 *= f4;
assert_eq!(f3, ::Fraction::new(2, 27)); assert_eq!(f3, ::Fraction::new(2, 27));
} }

View file

@ -348,7 +348,7 @@ mod tests {
// Bitmask // Bitmask
let bitmask = Bitmask::new(1024 + 128 + 32); let bitmask = Bitmask::new(1024 + 128 + 32);
let res = ron::ser::to_string_pretty(&bitmask, pretty_config.clone()); let res = ron::ser::to_string_pretty(&bitmask, pretty_config);
assert_eq!(Ok("(1184)".to_owned()), res); assert_eq!(Ok("(1184)".to_owned()), res);
let res = serde_json::to_string(&bitmask).unwrap(); let res = serde_json::to_string(&bitmask).unwrap();
@ -448,7 +448,7 @@ mod tests {
&send_value_date_time_none, &send_value_date_time_none,
]); ]);
let res = ron::ser::to_string_pretty(&list, pretty_config.clone()); let res = ron::ser::to_string_pretty(&list, pretty_config);
assert_eq!( assert_eq!(
Ok(concat!( Ok(concat!(
r#"["#, r#"["#,
@ -555,6 +555,7 @@ mod tests {
assert_eq!(bitmask_de, bitmask); assert_eq!(bitmask_de, bitmask);
} }
#[allow(clippy::cognitive_complexity)]
#[test] #[test]
fn test_deserialize_collections() { fn test_deserialize_collections() {
::init().unwrap(); ::init().unwrap();