let addr = ip_packet_addr::<true>(header)?;
if addr != ic.link.client.0 { throw!(PE::Dst(addr)) }
Ok(())
- }, |o| Ok({ rx_queue.push(o); }),
+ }, |(o,())| Ok({ rx_queue.push(o); }),
|e| error!("{} #{}: rx discarding: {}", &ic, req_num, e))
{
Ok(()) => reporter.lock().success(),
pub struct ErrorOnlyBad;
#[throws(ErrorOnlyBad)]
-pub fn checkn<AC, EH, OUT, M: SlipMime+Copy>(
+pub fn checkn<AC, EH, OUT, ACR, M: SlipMime+Copy>(
mime: M,
mtu: u32,
data: &[u8],
addr_chk: AC,
mut out: OUT,
mut error_handler: EH
-) where AC: Fn(&[u8]) -> Result<(), PacketError> + Copy,
- OUT: FnMut(Box<[u8]>) -> Result<(), PacketError>,
+) where AC: Fn(&[u8]) -> Result<ACR, PacketError> + Copy,
+ OUT: FnMut((Box<[u8]>, ACR)) -> Result<(), PacketError>,
EH: FnMut(PacketError),
{
// eprintln!("before: {:?}", DumpHex(data));
match (||{
let checked = check1(mime, mtu, packet, addr_chk);
if matches!(checked, Err(PacketError::Empty)) { return Ok::<_,PE>(()) }
- let (packet, _acr) = checked?;
- out(packet)?;
+ out(checked?)?;
ok = true;
Ok::<_,PE>(())
})() {