Skip to content

Commit

Permalink
Merge branch 'byo-signing-sorter-impl' into sortedrecords-zonemd-remo…
Browse files Browse the repository at this point in the history
…ve-replace
  • Loading branch information
ximon18 committed Dec 3, 2024
2 parents 94b0de2 + ab9b219 commit 3ce8640
Show file tree
Hide file tree
Showing 4 changed files with 21 additions and 32 deletions.
4 changes: 2 additions & 2 deletions src/base/dig_printer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ impl<Octs: AsRef<[u8]>> fmt::Display for DigPrinter<'_, Octs> {
writeln!(
f,
";; ->>HEADER<<- opcode: {}, rcode: {}, id: {}",
header.opcode().display_zonefile(false, false),
header.opcode().display_zonefile(false),
header.rcode(),
header.id()
)?;
Expand Down Expand Up @@ -161,7 +161,7 @@ fn write_record_item(
let parsed = item.to_any_record::<AllRecordData<_, _>>();

match parsed {
Ok(item) => writeln!(f, "{}", item.display_zonefile(false, false)),
Ok(item) => writeln!(f, "{}", item.display_zonefile(false)),
Err(_) => writeln!(
f,
"; {} {} {} {} <invalid data>",
Expand Down
43 changes: 16 additions & 27 deletions src/base/zonefile_fmt.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,19 +13,18 @@ pub type Result = core::result::Result<(), Error>;

pub struct ZoneFileDisplay<'a, T: ?Sized> {
inner: &'a T,
multiline: bool,
tabbed: bool,
pretty: bool,
}

impl<T: ZonefileFmt + ?Sized> fmt::Display for ZoneFileDisplay<'_, T> {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
if self.multiline {
if self.pretty {
self.inner
.fmt(&mut MultiLineWriter::new(f))
.map_err(|_| fmt::Error)
} else {
self.inner
.fmt(&mut SimpleWriter::new(f, self.tabbed))
.fmt(&mut SimpleWriter::new(f))
.map_err(|_| fmt::Error)
}
}
Expand All @@ -42,15 +41,10 @@ pub trait ZonefileFmt {
///
/// The returned object will be displayed as zonefile when printed or
/// written using `fmt::Display`.
fn display_zonefile(
&self,
multiline: bool,
tabbed: bool,
) -> ZoneFileDisplay<'_, Self> {
fn display_zonefile(&self, pretty: bool) -> ZoneFileDisplay<'_, Self> {
ZoneFileDisplay {
inner: self,
multiline,
tabbed,
pretty,
}
}
}
Expand Down Expand Up @@ -94,26 +88,21 @@ pub trait FormatWriter: Sized {
struct SimpleWriter<W> {
first: bool,
writer: W,
tabbed: bool,
}

impl<W: fmt::Write> SimpleWriter<W> {
fn new(writer: W, tabbed: bool) -> Self {
fn new(writer: W) -> Self {
Self {
first: true,
writer,
tabbed,
}
}
}

impl<W: fmt::Write> FormatWriter for SimpleWriter<W> {
fn fmt_token(&mut self, args: fmt::Arguments<'_>) -> Result {
if !self.first {
match self.tabbed {
true => self.writer.write_char('\t')?,
false => self.writer.write_char(' ')?,
}
self.writer.write_char(' ')?;
}
self.first = false;
self.writer.write_fmt(args)?;
Expand Down Expand Up @@ -262,7 +251,7 @@ mod test {
let record = create_record(A::new("128.140.76.106".parse().unwrap()));
assert_eq!(
"example.com. 3600 IN A 128.140.76.106",
record.display_zonefile(false, false).to_string()
record.display_zonefile(false).to_string()
);
}

Expand All @@ -273,7 +262,7 @@ mod test {
));
assert_eq!(
"example.com. 3600 IN CNAME example.com.",
record.display_zonefile(false, false).to_string()
record.display_zonefile(false).to_string()
);
}

Expand All @@ -290,7 +279,7 @@ mod test {
);
assert_eq!(
"example.com. 3600 IN DS 5414 15 2 DEADBEEF",
record.display_zonefile(false, false).to_string()
record.display_zonefile(false).to_string()
);
assert_eq!(
[
Expand All @@ -300,7 +289,7 @@ mod test {
" DEADBEEF )",
]
.join("\n"),
record.display_zonefile(true, false).to_string()
record.display_zonefile(true).to_string()
);
}

Expand All @@ -317,7 +306,7 @@ mod test {
);
assert_eq!(
"example.com. 3600 IN CDS 5414 15 2 DEADBEEF",
record.display_zonefile(false, false).to_string()
record.display_zonefile(false).to_string()
);
}

Expand All @@ -329,7 +318,7 @@ mod test {
));
assert_eq!(
"example.com. 3600 IN MX 20 example.com.",
record.display_zonefile(false, false).to_string()
record.display_zonefile(false).to_string()
);
}

Expand All @@ -349,7 +338,7 @@ mod test {
more like a silly monkey with a typewriter accidentally writing \
some shakespeare along the way but it feels like I have to type \
e\" \"ven longer to hit that limit!\"",
record.display_zonefile(false, false).to_string()
record.display_zonefile(false).to_string()
);
}

Expand All @@ -362,7 +351,7 @@ mod test {
));
assert_eq!(
"example.com. 3600 IN HINFO \"Windows\" \"Windows Server\"",
record.display_zonefile(false, false).to_string()
record.display_zonefile(false).to_string()
);
}

Expand All @@ -379,7 +368,7 @@ mod test {
));
assert_eq!(
r#"example.com. 3600 IN NAPTR 100 50 "a" "z3950+N2L+N2C" "!^urn:cid:.+@([^\\.]+\\.)(.*)$!\\2!i" cidserver.example.com."#,
record.display_zonefile(false, false).to_string()
record.display_zonefile(false).to_string()
);
}
}
4 changes: 2 additions & 2 deletions src/rdata/nsec3.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1608,7 +1608,7 @@ mod test {
Nsec3::scan,
&rdata,
);
assert_eq!(&format!("{}", rdata.display_zonefile(false, false)), "1 10 11 626172 CPNMU A SRV");
assert_eq!(&format!("{}", rdata.display_zonefile(false)), "1 10 11 626172 CPNMU A SRV");
}

#[test]
Expand All @@ -1632,7 +1632,7 @@ mod test {
Nsec3::scan,
&rdata,
);
assert_eq!(&format!("{}", rdata.display_zonefile(false, false)), "1 10 11 - CPNMU A SRV");
assert_eq!(&format!("{}", rdata.display_zonefile(false)), "1 10 11 - CPNMU A SRV");
}

#[test]
Expand Down
2 changes: 1 addition & 1 deletion src/validate.rs
Original file line number Diff line number Diff line change
Expand Up @@ -322,7 +322,7 @@ impl<Octs: AsRef<[u8]>> Key<Octs> {
w,
"{} IN DNSKEY {}",
self.owner().fmt_with_dot(),
self.to_dnskey().display_zonefile(false, false),
self.to_dnskey().display_zonefile(false),
)
}

Expand Down

0 comments on commit 3ce8640

Please sign in to comment.