use super::*;
use crate::message::packer::*;
use shared::error::*;
#[derive(Default, Debug, Clone, PartialEq, Eq)]
pub(crate) struct TxtResource {
pub(crate) txt: Vec<String>,
}
impl fmt::Display for TxtResource {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
if self.txt.is_empty() {
write!(f, "dnsmessage.TXTResource{{txt: {{}}}}",)
} else {
write!(f, "dnsmessage.TXTResource{{txt: {{{}}}", self.txt.join(","))
}
}
}
impl ResourceBody for TxtResource {
fn real_type(&self) -> DnsType {
DnsType::Txt
}
fn pack(
&self,
mut msg: Vec<u8>,
_compression: &mut Option<HashMap<String, usize>>,
_compression_off: usize,
) -> Result<Vec<u8>> {
for s in &self.txt {
msg = pack_str(msg, s)?
}
Ok(msg)
}
fn unpack(&mut self, msg: &[u8], mut off: usize, length: usize) -> Result<usize> {
let mut txts = vec![];
let mut n = 0;
while n < length {
let (t, new_off) = unpack_str(msg, off)?;
off = new_off;
if length < n + t.len() + 1 {
return Err(Error::ErrCalcLen);
}
n += t.len() + 1;
txts.push(t);
}
self.txt = txts;
Ok(off)
}
fn as_any(&self) -> &dyn Any {
self
}
}