#![allow(missing_docs)]
#![allow(clippy::trivially_copy_pass_by_ref)]
#![allow(clippy::missing_errors_doc)]
use core::convert::Infallible;
use core::fmt;
pub mod as_sat_per_kwu_floor {
use serde::{Deserialize, Deserializer, Serialize, Serializer};
use crate::{Amount, FeeRate};
#[inline]
pub fn serialize<S: Serializer>(f: &FeeRate, s: S) -> Result<S::Ok, S::Error> {
u64::serialize(&f.to_sat_per_kwu_floor(), s)
}
#[inline]
pub fn deserialize<'d, D: Deserializer<'d>>(d: D) -> Result<FeeRate, D::Error> {
let sat = u64::deserialize(d)?;
FeeRate::from_per_kwu(
Amount::from_sat(sat).map_err(|_| serde::de::Error::custom("amount out of range"))?,
)
.into_result()
.map_err(|_| serde::de::Error::custom("fee rate too big for sats/kwu"))
}
pub mod opt {
use core::fmt;
use serde::{de, Deserializer, Serializer};
use crate::FeeRate;
#[inline]
#[allow(clippy::ref_option)] pub fn serialize<S: Serializer>(f: &Option<FeeRate>, s: S) -> Result<S::Ok, S::Error> {
match *f {
Some(f) => s.serialize_some(&f.to_sat_per_kwu_floor()),
None => s.serialize_none(),
}
}
pub fn deserialize<'d, D: Deserializer<'d>>(d: D) -> Result<Option<FeeRate>, D::Error> {
struct VisitOpt;
impl<'de> de::Visitor<'de> for VisitOpt {
type Value = Option<FeeRate>;
fn expecting(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "an Option<u64>")
}
#[inline]
fn visit_none<E>(self) -> Result<Self::Value, E>
where
E: de::Error,
{
Ok(None)
}
#[inline]
fn visit_some<D>(self, d: D) -> Result<Self::Value, D::Error>
where
D: Deserializer<'de>,
{
Ok(Some(super::deserialize(d)?))
}
}
d.deserialize_option(VisitOpt)
}
}
#[cfg(feature = "alloc")]
pub mod vec {
use alloc::vec::Vec;
use core::fmt;
use serde::de::{self, SeqAccess};
use serde::{Deserialize, Deserializer, Serializer};
use crate::FeeRate;
pub fn serialize<S: Serializer>(f: &[FeeRate], s: S) -> Result<S::Ok, S::Error> {
s.collect_seq(f.iter().map(|rate| rate.to_sat_per_kwu_floor()))
}
pub fn deserialize<'d, D: Deserializer<'d>>(d: D) -> Result<Vec<FeeRate>, D::Error> {
struct VisitVec;
impl<'de> de::Visitor<'de> for VisitVec {
type Value = Vec<FeeRate>;
fn expecting(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "a sequence of u64")
}
fn visit_seq<A>(self, mut seq: A) -> Result<Self::Value, A::Error>
where
A: SeqAccess<'de>,
{
#[derive(Deserialize)]
#[serde(transparent)]
struct Wrapper(#[serde(with = "super")] FeeRate);
let mut out = Vec::with_capacity(seq.size_hint().unwrap_or(0));
while let Some(wrapped) = seq.next_element::<Wrapper>()? {
out.push(wrapped.0);
}
Ok(out)
}
}
d.deserialize_seq(VisitVec)
}
}
}
pub mod as_sat_per_vb_floor {
use serde::{Deserialize, Deserializer, Serialize, Serializer};
use crate::{Amount, FeeRate};
#[inline]
pub fn serialize<S: Serializer>(f: &FeeRate, s: S) -> Result<S::Ok, S::Error> {
u64::serialize(&f.to_sat_per_vb_floor(), s)
}
#[inline]
pub fn deserialize<'d, D: Deserializer<'d>>(d: D) -> Result<FeeRate, D::Error> {
let sat = u64::deserialize(d)?;
FeeRate::from_per_vb(
Amount::from_sat(sat).map_err(|_| serde::de::Error::custom("amount out of range"))?,
)
.into_result()
.map_err(|_| serde::de::Error::custom("fee rate too big for sats/vb"))
}
pub mod opt {
use core::fmt;
use serde::{de, Deserializer, Serializer};
use crate::fee_rate::FeeRate;
#[inline]
#[allow(clippy::ref_option)] pub fn serialize<S: Serializer>(f: &Option<FeeRate>, s: S) -> Result<S::Ok, S::Error> {
match *f {
Some(f) => s.serialize_some(&f.to_sat_per_vb_floor()),
None => s.serialize_none(),
}
}
pub fn deserialize<'d, D: Deserializer<'d>>(d: D) -> Result<Option<FeeRate>, D::Error> {
struct VisitOpt;
impl<'de> de::Visitor<'de> for VisitOpt {
type Value = Option<FeeRate>;
fn expecting(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "an Option<u64>")
}
#[inline]
fn visit_none<E>(self) -> Result<Self::Value, E>
where
E: de::Error,
{
Ok(None)
}
#[inline]
fn visit_some<D>(self, d: D) -> Result<Self::Value, D::Error>
where
D: Deserializer<'de>,
{
Ok(Some(super::deserialize(d)?))
}
}
d.deserialize_option(VisitOpt)
}
}
#[cfg(feature = "alloc")]
pub mod vec {
use alloc::vec::Vec;
use core::fmt;
use serde::de::{self, SeqAccess};
use serde::{Deserialize, Deserializer, Serializer};
use crate::FeeRate;
pub fn serialize<S: Serializer>(f: &[FeeRate], s: S) -> Result<S::Ok, S::Error> {
s.collect_seq(f.iter().map(|rate| rate.to_sat_per_vb_floor()))
}
pub fn deserialize<'d, D: Deserializer<'d>>(d: D) -> Result<Vec<FeeRate>, D::Error> {
struct VisitVec;
impl<'de> de::Visitor<'de> for VisitVec {
type Value = Vec<FeeRate>;
fn expecting(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "a sequence of u64")
}
fn visit_seq<A>(self, mut seq: A) -> Result<Self::Value, A::Error>
where
A: SeqAccess<'de>,
{
#[derive(Deserialize)]
#[serde(transparent)]
struct Wrapper(#[serde(with = "super")] FeeRate);
let mut out = Vec::with_capacity(seq.size_hint().unwrap_or(0));
while let Some(wrapped) = seq.next_element::<Wrapper>()? {
out.push(wrapped.0);
}
Ok(out)
}
}
d.deserialize_seq(VisitVec)
}
}
}
pub mod as_sat_per_vb_ceil {
use serde::{Deserialize, Deserializer, Serialize, Serializer};
use crate::{Amount, FeeRate};
#[inline]
pub fn serialize<S: Serializer>(f: &FeeRate, s: S) -> Result<S::Ok, S::Error> {
u64::serialize(&f.to_sat_per_vb_ceil(), s)
}
#[inline]
pub fn deserialize<'d, D: Deserializer<'d>>(d: D) -> Result<FeeRate, D::Error> {
let sat = u64::deserialize(d)?;
FeeRate::from_per_vb(
Amount::from_sat(sat).map_err(|_| serde::de::Error::custom("amount out of range"))?,
)
.into_result()
.map_err(|_| serde::de::Error::custom("fee rate too big for sats/vb"))
}
pub mod opt {
use core::fmt;
use serde::{de, Deserializer, Serializer};
use crate::fee_rate::FeeRate;
#[inline]
#[allow(clippy::ref_option)] pub fn serialize<S: Serializer>(f: &Option<FeeRate>, s: S) -> Result<S::Ok, S::Error> {
match *f {
Some(f) => s.serialize_some(&f.to_sat_per_vb_ceil()),
None => s.serialize_none(),
}
}
pub fn deserialize<'d, D: Deserializer<'d>>(d: D) -> Result<Option<FeeRate>, D::Error> {
struct VisitOpt;
impl<'de> de::Visitor<'de> for VisitOpt {
type Value = Option<FeeRate>;
fn expecting(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "an Option<u64>")
}
#[inline]
fn visit_none<E>(self) -> Result<Self::Value, E>
where
E: de::Error,
{
Ok(None)
}
#[inline]
fn visit_some<D>(self, d: D) -> Result<Self::Value, D::Error>
where
D: Deserializer<'de>,
{
Ok(Some(super::deserialize(d)?))
}
}
d.deserialize_option(VisitOpt)
}
}
#[cfg(feature = "alloc")]
pub mod vec {
use alloc::vec::Vec;
use core::fmt;
use serde::de::{self, SeqAccess};
use serde::{Deserialize, Deserializer, Serializer};
use crate::FeeRate;
pub fn serialize<S: Serializer>(f: &[FeeRate], s: S) -> Result<S::Ok, S::Error> {
s.collect_seq(f.iter().map(|rate| rate.to_sat_per_vb_ceil()))
}
pub fn deserialize<'d, D: Deserializer<'d>>(d: D) -> Result<Vec<FeeRate>, D::Error> {
struct VisitVec;
impl<'de> de::Visitor<'de> for VisitVec {
type Value = Vec<FeeRate>;
fn expecting(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "a sequence of u64")
}
fn visit_seq<A>(self, mut seq: A) -> Result<Self::Value, A::Error>
where
A: SeqAccess<'de>,
{
#[derive(Deserialize)]
#[serde(transparent)]
struct Wrapper(#[serde(with = "super")] FeeRate);
let mut out = Vec::with_capacity(seq.size_hint().unwrap_or(0));
while let Some(wrapped) = seq.next_element::<Wrapper>()? {
out.push(wrapped.0);
}
Ok(out)
}
}
d.deserialize_seq(VisitVec)
}
}
}
#[derive(Debug, Clone, PartialEq, Eq)]
#[non_exhaustive]
pub struct OverflowError;
impl From<Infallible> for OverflowError {
fn from(never: Infallible) -> Self { match never {} }
}
impl fmt::Display for OverflowError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "overflow occurred while deserializing fee rate per virtual byte")
}
}
#[cfg(feature = "std")]
impl std::error::Error for OverflowError {
#[inline]
fn source(&self) -> Option<&(dyn std::error::Error + 'static)> { None }
}