2020-04-03 19:16:54 +08:00
|
|
|
//! Driver for proc macro server
|
internal: cleanup proc macro server error handlig
When dealing with proc macros, there are two very different kinds of
errors:
* first, usual errors of "proc macro panicked on this particular input"
* second, the proc macro server might day if the user, eg, kills it
First kind of errors are expected and are a normal output, while the
second kind are genuine IO-errors.
For this reason, we use a curious nested result here: `Result<Result<T,
E1>, E2>` pattern, which is 100% inspired by http://sled.rs/errors.html
2021-08-31 19:01:39 +03:00
|
|
|
use std::io;
|
2020-04-03 19:16:54 +08:00
|
|
|
|
2020-08-13 12:07:28 +02:00
|
|
|
use proc_macro_api::msg::{self, Message};
|
internal: cleanup proc macro server error handlig
When dealing with proc macros, there are two very different kinds of
errors:
* first, usual errors of "proc macro panicked on this particular input"
* second, the proc macro server might day if the user, eg, kills it
First kind of errors are expected and are a normal output, while the
second kind are genuine IO-errors.
For this reason, we use a curious nested result here: `Result<Result<T,
E1>, E2>` pattern, which is 100% inspired by http://sled.rs/errors.html
2021-08-31 19:01:39 +03:00
|
|
|
|
|
|
|
use crate::ProcMacroSrv;
|
2020-04-01 13:11:26 +08:00
|
|
|
|
2020-04-24 01:38:58 +08:00
|
|
|
pub fn run() -> io::Result<()> {
|
2020-04-24 10:23:01 +08:00
|
|
|
let mut srv = ProcMacroSrv::default();
|
2021-03-24 03:47:08 +08:00
|
|
|
let mut buf = String::new();
|
2020-04-24 10:23:01 +08:00
|
|
|
|
2021-03-24 03:47:08 +08:00
|
|
|
while let Some(req) = read_request(&mut buf)? {
|
2020-04-20 21:26:10 +03:00
|
|
|
let res = match req {
|
internal: cleanup proc macro server error handlig
When dealing with proc macros, there are two very different kinds of
errors:
* first, usual errors of "proc macro panicked on this particular input"
* second, the proc macro server might day if the user, eg, kills it
First kind of errors are expected and are a normal output, while the
second kind are genuine IO-errors.
For this reason, we use a curious nested result here: `Result<Result<T,
E1>, E2>` pattern, which is 100% inspired by http://sled.rs/errors.html
2021-08-31 19:01:39 +03:00
|
|
|
msg::Request::ListMacros { dylib_path } => {
|
|
|
|
msg::Response::ListMacros(srv.list_macros(&dylib_path))
|
2020-04-01 13:11:26 +08:00
|
|
|
}
|
internal: cleanup proc macro server error handlig
When dealing with proc macros, there are two very different kinds of
errors:
* first, usual errors of "proc macro panicked on this particular input"
* second, the proc macro server might day if the user, eg, kills it
First kind of errors are expected and are a normal output, while the
second kind are genuine IO-errors.
For this reason, we use a curious nested result here: `Result<Result<T,
E1>, E2>` pattern, which is 100% inspired by http://sled.rs/errors.html
2021-08-31 19:01:39 +03:00
|
|
|
msg::Request::ExpandMacro(task) => msg::Response::ExpandMacro(srv.expand(task)),
|
2020-04-20 21:26:10 +03:00
|
|
|
};
|
internal: cleanup proc macro server error handlig
When dealing with proc macros, there are two very different kinds of
errors:
* first, usual errors of "proc macro panicked on this particular input"
* second, the proc macro server might day if the user, eg, kills it
First kind of errors are expected and are a normal output, while the
second kind are genuine IO-errors.
For this reason, we use a curious nested result here: `Result<Result<T,
E1>, E2>` pattern, which is 100% inspired by http://sled.rs/errors.html
2021-08-31 19:01:39 +03:00
|
|
|
write_response(res)?
|
2020-04-01 13:11:26 +08:00
|
|
|
}
|
2020-04-24 09:27:37 +08:00
|
|
|
|
|
|
|
Ok(())
|
2020-04-01 13:11:26 +08:00
|
|
|
}
|
2020-04-20 21:26:10 +03:00
|
|
|
|
2021-03-24 03:47:08 +08:00
|
|
|
fn read_request(buf: &mut String) -> io::Result<Option<msg::Request>> {
|
|
|
|
msg::Request::read(&mut io::stdin().lock(), buf)
|
2020-04-20 21:26:10 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
fn write_response(msg: msg::Response) -> io::Result<()> {
|
|
|
|
msg.write(&mut io::stdout().lock())
|
|
|
|
}
|