mirror of
https://github.com/jgoerzen/xbnet.git
synced 2025-02-19 16:53:49 -04:00
compiles
This commit is contained in:
parent
39c6302a49
commit
4f00654562
14
src/main.rs
14
src/main.rs
@ -31,6 +31,7 @@ mod xbrx;
|
|||||||
|
|
||||||
use std::path::PathBuf;
|
use std::path::PathBuf;
|
||||||
use structopt::StructOpt;
|
use structopt::StructOpt;
|
||||||
|
use tun_tap::Iface;
|
||||||
|
|
||||||
#[derive(Debug, StructOpt)]
|
#[derive(Debug, StructOpt)]
|
||||||
#[structopt(
|
#[structopt(
|
||||||
@ -73,6 +74,8 @@ enum Command {
|
|||||||
dest: String,
|
dest: String,
|
||||||
// FIXME: add a paremter to accept data from only that place
|
// FIXME: add a paremter to accept data from only that place
|
||||||
},
|
},
|
||||||
|
/// Create a virtual Ethernet interface and send frames across XBee
|
||||||
|
Tap,
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
@ -111,5 +114,16 @@ fn main() {
|
|||||||
// Make sure queued up data is sent
|
// Make sure queued up data is sent
|
||||||
let _ = writerthread.join();
|
let _ = writerthread.join();
|
||||||
}
|
}
|
||||||
|
Command::Tap => {
|
||||||
|
let tap_reader = tap::XBTap::new_tap(xb.mymac).expect("Failure initializing tap");
|
||||||
|
let tap_writer = tap_reader.clone();
|
||||||
|
let maxpacketsize = xb.maxpacketsize;
|
||||||
|
thread::spawn(move || {
|
||||||
|
tap_writer.frames_from_xb_processor(&mut xbreframer, &mut xb.ser_reader)
|
||||||
|
.expect("Failure in frames_from_xb_processor");
|
||||||
|
});
|
||||||
|
tap_reader.frames_from_tap_processor(maxpacketsize - 1, xbeesender)
|
||||||
|
.expect("Failure in frames_from_tap_processor");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user