effers/examples/main.rs

76 lines
1.5 KiB
Rust
Raw Normal View History

2022-01-19 20:56:39 +00:00
use effers::program;
#[program(Smth => Printer(print as p), Logger(mut debug, mut info))]
2022-01-19 20:56:39 +00:00
fn smth(val: u8) -> u8 {
p("hey hi hello");
debug("this is a debug-level log");
info("this is a info-level log");
val + 3
}
#[program(Printer(mut print as p))]
2022-01-21 10:40:23 +00:00
fn other_program() {
p("hey hi hello");
}
2022-01-19 20:56:39 +00:00
fn main() {
// call the first program twice
2022-01-19 20:56:39 +00:00
let result: u8 = Smth.add(IoPrinter).add(FileLogger).run(3);
assert_eq!(result, 6);
let other_result: u8 = Smth
.add(IoPrinter)
.add(NetworkLogger {
credentials: "secret password".to_string(),
})
.run(8);
assert_eq!(other_result, 11);
// other program
2022-01-21 10:40:23 +00:00
OtherProgram.add(IoPrinter).run();
2022-01-19 20:56:39 +00:00
}
trait Printer {
fn print(&self, s: &str);
2022-01-19 20:56:39 +00:00
}
trait Logger {
fn debug(&mut self, s: &str);
fn info(&mut self, s: &str);
}
struct IoPrinter;
impl Printer for IoPrinter {
fn print(&self, s: &str) {
2022-01-19 20:56:39 +00:00
println!("{}", s)
}
}
struct FileLogger;
impl Logger for FileLogger {
fn debug(&mut self, s: &str) {
println!("debug: {}", s)
}
fn info(&mut self, s: &str) {
println!("info: {}", s)
}
}
struct NetworkLogger {
credentials: String,
}
impl Logger for NetworkLogger {
fn debug(&mut self, s: &str) {
println!(
"debug through network: {}; with password {}",
s, self.credentials
)
}
fn info(&mut self, s: &str) {
println!(
"info through network: {}; with password {}",
s, self.credentials
)
}
}