gstreamer: Implement Add<u32> for gst::Rank and fix comparison

While the enum is a signed integer, all operations inside GStreamer
(especially comparison) is based on unsigned integers.
This commit is contained in:
Sebastian Dröge 2019-06-04 10:21:26 +03:00
parent d44c293753
commit 620a9b2a95
3 changed files with 45 additions and 5 deletions

View file

@ -229,7 +229,7 @@ status = "generate"
name = "Gst.Rank" name = "Gst.Rank"
status = "generate" status = "generate"
[[object.derive]] [[object.derive]]
name = "Debug, PartialEq, Eq, Hash" name = "Debug"
[[object]] [[object]]
name = "Gst.TypeFindProbability" name = "Gst.TypeFindProbability"

View file

@ -1657,7 +1657,7 @@ impl SetValue for QOSType {
} }
} }
#[derive(Debug, PartialEq, Eq, Hash)] #[derive(Debug)]
#[derive(Clone, Copy)] #[derive(Clone, Copy)]
pub enum Rank { pub enum Rank {
None, None,

View file

@ -6,9 +6,9 @@
// option. This file may not be copied, modified, or distributed // option. This file may not be copied, modified, or distributed
// except according to those terms. // except according to those terms.
use std::cmp;
use std::error::Error; use std::error::Error;
use std::fmt; use std::fmt;
use std::{cmp, ops};
use ClockReturn; use ClockReturn;
use FlowReturn; use FlowReturn;
use PadLinkReturn; use PadLinkReturn;
@ -397,15 +397,55 @@ impl Ord for ::TypeFindProbability {
} }
} }
impl PartialEq for ::Rank {
fn eq(&self, other: &::Rank) -> bool {
(self.to_glib() as u32).eq(&(other.to_glib() as u32))
}
}
impl Eq for ::Rank {}
impl PartialOrd for ::Rank { impl PartialOrd for ::Rank {
fn partial_cmp(&self, other: &Self) -> Option<cmp::Ordering> { fn partial_cmp(&self, other: &Self) -> Option<cmp::Ordering> {
self.to_glib().partial_cmp(&other.to_glib()) (self.to_glib() as u32).partial_cmp(&(other.to_glib() as u32))
} }
} }
impl Ord for ::Rank { impl Ord for ::Rank {
fn cmp(&self, other: &Self) -> cmp::Ordering { fn cmp(&self, other: &Self) -> cmp::Ordering {
self.to_glib().cmp(&other.to_glib()) (self.to_glib() as u32).cmp(&(other.to_glib() as u32))
}
}
impl ops::Add<u32> for ::Rank {
type Output = ::Rank;
fn add(self, rhs: u32) -> ::Rank {
let res = (self.to_glib() as u32).saturating_add(rhs);
from_glib(res as i32)
}
}
impl ops::AddAssign<u32> for ::Rank {
fn add_assign(&mut self, rhs: u32) {
let res = (self.to_glib() as u32).saturating_add(rhs);
*self = from_glib(res as i32);
}
}
impl ops::Sub<u32> for ::Rank {
type Output = ::Rank;
fn sub(self, rhs: u32) -> ::Rank {
let res = (self.to_glib() as u32).saturating_sub(rhs);
from_glib(res as i32)
}
}
impl ops::SubAssign<u32> for ::Rank {
fn sub_assign(&mut self, rhs: u32) {
let res = (self.to_glib() as u32).saturating_sub(rhs);
*self = from_glib(res as i32);
} }
} }