Files
rust/crates/ra_lsp_server/src/bin/main.rs

99 lines
3.0 KiB
Rust
Raw Normal View History

2020-02-18 12:11:32 +01:00
//! Driver for rust-analyzer.
//!
//! Based on cli flags, either spawns an LSP server, or runs a batch analysis
2020-02-17 19:03:03 +01:00
mod args;
2019-08-30 20:18:57 +03:00
use lsp_server::Connection;
2020-02-17 19:03:03 +01:00
use ra_lsp_server::{cli, from_json, show_message, Result, ServerConfig};
2019-04-02 17:52:04 +03:00
use ra_prof;
2018-08-10 15:07:43 +03:00
2020-02-17 19:03:03 +01:00
use crate::args::HelpPrinted;
2018-08-10 15:07:43 +03:00
fn main() -> Result<()> {
2019-08-31 14:47:37 +03:00
setup_logging()?;
2020-02-17 19:03:03 +01:00
let args = match args::Args::parse()? {
Ok(it) => it,
Err(HelpPrinted) => return Ok(()),
};
match args.command {
args::Command::Parse { no_dump } => cli::parse(no_dump)?,
args::Command::Symbols => cli::symbols()?,
args::Command::Highlight { rainbow } => cli::highlight(rainbow)?,
args::Command::Stats { randomize, memory_usage, only, with_deps, path } => {
cli::analysis_stats(
args.verbosity,
memory_usage,
path.as_ref(),
only.as_ref().map(String::as_ref),
with_deps,
randomize,
)?
}
args::Command::Bench { path, what } => {
cli::analysis_bench(args.verbosity, path.as_ref(), what)?
}
args::Command::RunServer => run_server()?,
args::Command::Version => println!("rust-analyzer {}", env!("REV")),
2019-12-09 15:59:04 +01:00
}
2019-08-31 14:47:37 +03:00
Ok(())
}
fn setup_logging() -> Result<()> {
2019-06-15 12:58:17 +03:00
std::env::set_var("RUST_BACKTRACE", "short");
2019-11-29 19:35:03 -05:00
env_logger::try_init()?;
2020-02-16 18:04:08 +01:00
ra_prof::init();
2019-08-31 14:47:37 +03:00
Ok(())
2018-08-10 17:49:45 +03:00
}
2018-11-08 18:43:02 +03:00
2019-08-31 14:47:37 +03:00
fn run_server() -> Result<()> {
log::info!("lifecycle: server started");
2019-08-30 20:18:57 +03:00
let (connection, io_threads) = Connection::stdio();
let server_capabilities = serde_json::to_value(ra_lsp_server::server_capabilities()).unwrap();
2019-08-30 20:18:57 +03:00
let initialize_params = connection.initialize(server_capabilities)?;
let initialize_params =
from_json::<lsp_types::InitializeParams>("InitializeParams", initialize_params)?;
2020-01-13 16:20:47 -05:00
if let Some(client_info) = initialize_params.client_info {
log::info!("Client '{}' {}", client_info.name, client_info.version.unwrap_or_default());
}
2019-08-31 14:47:37 +03:00
let cwd = std::env::current_dir()?;
2019-08-30 20:18:57 +03:00
let root = initialize_params.root_uri.and_then(|it| it.to_file_path().ok()).unwrap_or(cwd);
let workspace_roots = initialize_params
.workspace_folders
.map(|workspaces| {
workspaces.into_iter().filter_map(|it| it.uri.to_file_path().ok()).collect::<Vec<_>>()
})
.filter(|workspaces| !workspaces.is_empty())
.unwrap_or_else(|| vec![root]);
let server_config = initialize_params
2019-08-30 20:18:57 +03:00
.initialization_options
.and_then(|v| {
from_json::<ServerConfig>("config", v)
2019-08-30 20:18:57 +03:00
.map_err(|e| {
log::error!("{}", e);
show_message(lsp_types::MessageType::Error, e.to_string(), &connection.sender);
2019-08-30 20:18:57 +03:00
})
.ok()
})
.unwrap_or_default();
ra_lsp_server::main_loop(
workspace_roots,
initialize_params.capabilities,
server_config,
connection,
2019-08-30 20:18:57 +03:00
)?;
2018-12-06 21:03:39 +03:00
log::info!("shutting down IO...");
io_threads.join()?;
2018-12-06 21:03:39 +03:00
log::info!("... IO is down");
2018-09-01 17:40:45 +03:00
Ok(())
2018-08-10 17:49:45 +03:00
}