Anforderungen  |   Konzepte  |   Entwurf  |   Entwicklung  |   Qualitätssicherung  |   Lebenszyklus  |   Steuerung
 
 
 
 


Quelle  serde.rs   Sprache: unbekannt

 
Spracherkennung für: .rs vermutete Sprache: Unknown {[0] [0] [0]} [Methode: Schwerpunktbildung, einfache Gewichte, sechs Dimensionen]

//! Serde utilities.

/// Serialize/deserialize fixed or variable-length bytes from/into Base64 strings.
pub(crate) mod base64 {
    /// Serialize/deserialize fixed-length bytes from/into Base64 strings.
    pub(crate) mod fixed_length {
        use core::fmt;

        use data_encoding::BASE64;
        use serde::{
            Deserializer, Serialize as _, Serializer,
            de::{Error, Visitor},
        };

        pub(crate) fn serialize<S: Serializer, const N: usize>(
            value: &[u8; N],
            serializer: S,
        ) -> Result<S::Ok, S::Error> {
            BASE64.encode(value).serialize(serializer)
        }

        pub(crate) fn deserialize<'de, D: Deserializer<'de>, const N: usize>(
            deserializer: D,
        ) -> Result<[u8; N], D::Error> {
            struct Base64Visitor<const N: usize>;
            impl<const N: usize> Visitor<'_> for Base64Visitor<N> {
                type Value = [u8; N];

                fn expecting(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
                    write!(formatter, "a base64 string containing {N} bytes")
                }

                fn visit_str<E: Error>(self, value: &str) -> Result<Self::Value, E> {
                    let encoded = value.as_bytes();
                    let length = BASE64.decode_len(encoded.len()).map_err(Error::custom)?;
                    if length < N || length > N.saturating_add(2) {
                        return Err(Error::custom(format_args!(
                            "invalid length {length}, expected at most {}",
                            N.saturating_add(2)
                        )));
                    }
                    let decoded = BASE64.decode(encoded).map_err(|error| Error::custom(error))?;
                    let length = decoded.len();
                    decoded.try_into().map_err(|_| {
                        Error::custom(format_args!("invalid decoded length {length}, expected {N}",))
                    })
                }
            }
            deserializer.deserialize_str(Base64Visitor)
        }
    }

    /// Serialize/deserialize variable-length bytes from/into Base64 strings.
    pub(crate) mod variable_length {
        use core::fmt;

        use data_encoding::BASE64;
        use serde::{
            Deserializer, Serialize as _, Serializer,
            de::{Error, Visitor},
        };

        pub(crate) fn serialize<S: Serializer>(value: &[u8], serializer: S) -> Result<S::Ok, S::Error> {
            BASE64.encode(value).serialize(serializer)
        }

        pub(crate) fn deserialize<'de, D: Deserializer<'de>>(deserializer: D) -> Result<Vec<u8>, D::Error> {
            struct Base64Visitor;
            impl Visitor<'_> for Base64Visitor {
                type Value = Vec<u8>;

                fn expecting(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
                    write!(
                        formatter,
                        "a base64 string containing an arbitrary amount of bytes"
                    )
                }

                fn visit_str<E: Error>(self, value: &str) -> Result<Self::Value, E> {
                    let encoded = value.as_bytes();
                    BASE64.decode(encoded).map_err(|error| Error::custom(error))
                }
            }
            deserializer.deserialize_str(Base64Visitor)
        }
    }
}

/// Serialize/deserialize strings.
pub(crate) mod string {
    /// Serialize a string by [`std::string::ToString`]
    pub(crate) mod to_string {
        use serde::{Serialize as _, Serializer};

        pub(crate) fn serialize<S: Serializer, T: ToString>(
            value: &T,
            serializer: S,
        ) -> Result<S::Ok, S::Error> {
            value.to_string().serialize(serializer)
        }
    }

    /// Deserialize [`String`] by [`core::str::FromStr`].
    pub(crate) mod from_str {
        use core::{
            fmt::{self},
            marker::PhantomData,
            str::FromStr,
        };

        use serde::{
            Deserializer,
            de::{Error, Visitor},
        };

        pub(crate) fn deserialize<'de, D: Deserializer<'de>, T>(deserializer: D) -> Result<T, D::Error>
        where
            T: FromStr,
            T::Err: fmt::Display,
        {
            struct TVisitor<TI>(PhantomData<TI>);
            impl<TI: FromStr> Visitor<'_> for TVisitor<TI>
            where
                TI::Err: fmt::Display,
            {
                type Value = TI;

                fn expecting(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
                    write!(formatter, "valid matching string")
                }

                fn visit_str<E: Error>(self, value: &str) -> Result<Self::Value, E> {
                    value.parse::<Self::Value>().map_err(Error::custom)
                }
            }
            deserializer.deserialize_string(TVisitor(PhantomData))
        }
    }

    /// Deserialize [`Option<String>`] by converting empty strings into [`None`] and non-empty strings into
    /// [`Some`].
    pub(crate) mod empty_to_optional {
        use core::fmt;

        use serde::{
            Deserializer,
            de::{Error, Visitor},
        };

        pub(crate) fn deserialize<'de, D: Deserializer<'de>>(
            deserializer: D,
        ) -> Result<Option<String>, D::Error> {
            struct StringVisitor;
            impl Visitor<'_> for StringVisitor {
                type Value = Option<String>;

                fn expecting(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
                    write!(formatter, "a string")
                }

                fn visit_string<E: Error>(self, value: String) -> Result<Self::Value, E> {
                    Ok(if value.is_empty() { None } else { Some(value) })
                }

                fn visit_str<E: Error>(self, value: &str) -> Result<Self::Value, E> {
                    Ok(if value.is_empty() {
                        None
                    } else {
                        Some(value.to_owned())
                    })
                }
            }
            deserializer.deserialize_string(StringVisitor)
        }
    }
}

[Dauer der Verarbeitung: 0.16 Sekunden, vorverarbeitet 2026-04-27]

                                                                                                                                                                                                                                                                                                                                                                                                     


Neuigkeiten

     Aktuelles
     Motto des Tages

Software

     Produkte
     Quellcodebibliothek

Aktivitäten

     Artikel über Sicherheit
     Anleitung zur Aktivierung von SSL

Muße

     Gedichte
     Musik
     Bilder

Jenseits des Üblichen ....
    

Besucherstatistik

Besucherstatistik

Monitoring

Montastic status badge