aboutsummaryrefslogtreecommitdiff
path: root/crates/ra_proc_macro_srv/src/main.rs
diff options
context:
space:
mode:
authorbors[bot] <26634292+bors[bot]@users.noreply.github.com>2020-04-03 13:06:04 +0100
committerGitHub <[email protected]>2020-04-03 13:06:04 +0100
commit1a8779bce07281f1fbde1166ded75bc5acaa0f27 (patch)
tree3c69ce23117592f5442bcfdfc165820394b775a3 /crates/ra_proc_macro_srv/src/main.rs
parentac91de1525662a602a1057709eb91a9b21ea3ac7 (diff)
parent9a2114b0dd6d3292216fa4d05e3c4cd219633f4b (diff)
Merge #3800
3800: Introduce ra_proc_macro_srv r=matklad a=edwin0cheng This PR add preliminary for server side of proc macro : 1. Add crate setup 2. IO for server side Co-authored-by: Edwin Cheng <[email protected]>
Diffstat (limited to 'crates/ra_proc_macro_srv/src/main.rs')
-rw-r--r--crates/ra_proc_macro_srv/src/main.rs55
1 files changed, 55 insertions, 0 deletions
diff --git a/crates/ra_proc_macro_srv/src/main.rs b/crates/ra_proc_macro_srv/src/main.rs
new file mode 100644
index 000000000..70743c1f4
--- /dev/null
+++ b/crates/ra_proc_macro_srv/src/main.rs
@@ -0,0 +1,55 @@
1//! Driver for proc macro server
2
3use ra_proc_macro::msg::{self, Message};
4use ra_proc_macro_srv::{expand_task, list_macros};
5
6use std::io;
7
8fn read_request() -> Result<Option<msg::Request>, io::Error> {
9 let stdin = io::stdin();
10 let mut stdin = stdin.lock();
11 msg::Request::read(&mut stdin)
12}
13
14fn write_response(res: Result<msg::Response, String>) -> Result<(), io::Error> {
15 let msg: msg::Response = match res {
16 Ok(res) => res,
17 Err(err) => msg::Response::Error(msg::ResponseError {
18 code: msg::ErrorCode::ExpansionError,
19 message: err,
20 }),
21 };
22
23 let stdout = io::stdout();
24 let mut stdout = stdout.lock();
25 msg.write(&mut stdout)
26}
27fn main() {
28 loop {
29 let req = match read_request() {
30 Err(err) => {
31 eprintln!("Read message error on ra_proc_macro_srv: {}", err.to_string());
32 continue;
33 }
34 Ok(None) => continue,
35 Ok(Some(req)) => req,
36 };
37
38 match req {
39 msg::Request::ListMacro(task) => {
40 if let Err(err) =
41 write_response(list_macros(&task).map(|it| msg::Response::ListMacro(it)))
42 {
43 eprintln!("Write message error on list macro: {}", err);
44 }
45 }
46 msg::Request::ExpansionMacro(task) => {
47 if let Err(err) =
48 write_response(expand_task(&task).map(|it| msg::Response::ExpansionMacro(it)))
49 {
50 eprintln!("Write message error on expansion macro: {}", err);
51 }
52 }
53 }
54 }
55}