use crate::{ActiveValue, Value};
use std::ops::{Rem, RemAssign};
impl<V> Rem<ActiveValue<V>> for ActiveValue<V>
where
V: Into<Value> + Copy + PartialEq + Rem<V, Output = V> + Default,
{
type Output = Self;
fn rem(mut self, rhs: ActiveValue<V>) -> Self::Output {
match &mut self {
ActiveValue::Changed(nv, ov) => match rhs {
ActiveValue::Changed(rnv, _) => self = ActiveValue::Changed(*nv % rnv, ov.clone()),
ActiveValue::Unchanged(rv) => self = ActiveValue::Changed(*nv % rv, ov.clone()),
ActiveValue::NotSet => (),
},
ActiveValue::Unchanged(v) => match rhs {
ActiveValue::Changed(rnv, _) => self = ActiveValue::Changed(*v % rnv, Box::new(self.clone())),
ActiveValue::Unchanged(rv) => self = ActiveValue::Changed(*v % rv, Box::new(self.clone())),
ActiveValue::NotSet => (),
},
ActiveValue::NotSet => match rhs {
ActiveValue::Changed(rnv, _) => self = ActiveValue::Changed(V::default() % rnv, Box::new(self.clone())),
ActiveValue::Unchanged(rv) => self = ActiveValue::Changed(V::default() % rv, Box::new(self.clone())),
ActiveValue::NotSet => (),
},
};
self
}
}
impl<V> RemAssign<ActiveValue<V>> for ActiveValue<V>
where
V: Into<Value> + Copy + PartialEq + Rem<V, Output = V> + Default,
{
fn rem_assign(&mut self, rhs: Self) {
match self {
ActiveValue::Changed(nv, ov) => match rhs {
ActiveValue::Changed(rnv, _) => *self = ActiveValue::Changed(*nv % rnv, ov.clone()),
ActiveValue::Unchanged(rv) => *self = ActiveValue::Changed(*nv % rv, ov.clone()),
ActiveValue::NotSet => (),
},
ActiveValue::Unchanged(v) => match rhs {
ActiveValue::Changed(rnv, _) => *self = ActiveValue::Changed(*v % rnv, Box::new(self.clone())),
ActiveValue::Unchanged(rv) => *self = ActiveValue::Changed(*v % rv, Box::new(self.clone())),
ActiveValue::NotSet => (),
},
ActiveValue::NotSet => match rhs {
ActiveValue::Changed(rnv, _) => *self = ActiveValue::Changed(V::default() % rnv, Box::new(self.clone())),
ActiveValue::Unchanged(rv) => *self = ActiveValue::Changed(V::default() % rv, Box::new(self.clone())),
ActiveValue::NotSet => (),
},
};
}
}
impl<V> Rem<&ActiveValue<V>> for ActiveValue<V>
where
V: Into<Value> + Copy + PartialEq + Rem<V, Output = V> + Default,
{
type Output = Self;
fn rem(mut self, rhs: &ActiveValue<V>) -> Self::Output {
match &mut self {
ActiveValue::Changed(nv, ov) => match rhs {
ActiveValue::Changed(rnv, _) => self = ActiveValue::Changed(*nv % *rnv, ov.clone()),
ActiveValue::Unchanged(rv) => self = ActiveValue::Changed(*nv % *rv, ov.clone()),
ActiveValue::NotSet => (),
},
ActiveValue::Unchanged(v) => match rhs {
ActiveValue::Changed(rnv, _) => self = ActiveValue::Changed(*v % *rnv, Box::new(self.clone())),
ActiveValue::Unchanged(rv) => self = ActiveValue::Changed(*v % *rv, Box::new(self.clone())),
ActiveValue::NotSet => (),
},
ActiveValue::NotSet => match rhs {
ActiveValue::Changed(rnv, _) => self = ActiveValue::Changed(V::default() % *rnv, Box::new(self.clone())),
ActiveValue::Unchanged(rv) => self = ActiveValue::Changed(V::default() % *rv, Box::new(self.clone())),
ActiveValue::NotSet => (),
},
};
self
}
}
impl<V> RemAssign<&ActiveValue<V>> for ActiveValue<V>
where
V: Into<Value> + Copy + PartialEq + Rem<V, Output = V> + Default,
{
fn rem_assign(&mut self, rhs: &Self) {
match self {
ActiveValue::Changed(nv, ov) => match rhs {
ActiveValue::Changed(rnv, _) => *self = ActiveValue::Changed(*nv % *rnv, ov.clone()),
ActiveValue::Unchanged(rv) => *self = ActiveValue::Changed(*nv % *rv, ov.clone()),
ActiveValue::NotSet => (),
},
ActiveValue::Unchanged(v) => match rhs {
ActiveValue::Changed(rnv, _) => *self = ActiveValue::Changed(*v % *rnv, Box::new(self.clone())),
ActiveValue::Unchanged(rv) => *self = ActiveValue::Changed(*v % *rv, Box::new(self.clone())),
ActiveValue::NotSet => (),
},
ActiveValue::NotSet => match rhs {
ActiveValue::Changed(rnv, _) => *self = ActiveValue::Changed(V::default() % *rnv, Box::new(self.clone())),
ActiveValue::Unchanged(rv) => *self = ActiveValue::Changed(V::default() % *rv, Box::new(self.clone())),
ActiveValue::NotSet => (),
},
};
}
}
impl<V> Rem<V> for ActiveValue<V>
where
V: Into<Value> + Copy + PartialEq + Rem<V, Output = V> + Default,
{
type Output = Self;
fn rem(mut self, rhs: V) -> Self::Output {
match &mut self {
ActiveValue::Changed(nv, ov) => self = ActiveValue::Changed(*nv % rhs, ov.clone()),
ActiveValue::Unchanged(v) => self = ActiveValue::Changed(*v % rhs, Box::new(self.clone())),
ActiveValue::NotSet => self = ActiveValue::Changed(V::default() % rhs, Box::new(ActiveValue::NotSet)),
};
self
}
}
impl<V> RemAssign<V> for ActiveValue<V>
where
V: Into<Value> + Copy + PartialEq + Rem<V, Output = V> + Default,
{
fn rem_assign(&mut self, rhs: V) {
match self {
ActiveValue::Changed(nv, ov) => *self = ActiveValue::Changed(*nv % rhs, ov.clone()),
ActiveValue::Unchanged(v) => *self = ActiveValue::Changed(*v % rhs, Box::new(self.clone())),
ActiveValue::NotSet => *self = ActiveValue::Changed(V::default() % rhs, Box::new(ActiveValue::NotSet)),
};
}
}