Skip to content
This repository has been archived by the owner on Jul 3, 2024. It is now read-only.

Commit

Permalink
fix(solidity/core/slither-server): cleaned code and added workspace c…
Browse files Browse the repository at this point in the history
…wd to slither command
  • Loading branch information
0xSwapFeeder committed Feb 22, 2024
1 parent e6b1cd9 commit a4c8a32
Show file tree
Hide file tree
Showing 5 changed files with 46 additions and 181 deletions.
131 changes: 0 additions & 131 deletions toolchains/solidity/core/Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 0 additions & 1 deletion toolchains/solidity/core/crates/slither-server/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -19,5 +19,4 @@ colored = "2.0.4"
thiserror = "1.0.50"
glob = "0.3.1"
toml = "0.8.8"
tokio-utils = "0.1.2"
tokio-util = "0.7.10"
76 changes: 35 additions & 41 deletions toolchains/solidity/core/crates/slither-server/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ use crate::{error::SlitherError, slither::parse_slither_out, types::*};

use std::sync::Arc;
use std::vec;
use tokio::sync::Mutex;
use tokio::sync::{Mutex, MutexGuard};
use tokio_util::sync::CancellationToken;
use tower_lsp::jsonrpc::Result;
use tower_lsp::lsp_types::*;
Expand Down Expand Up @@ -56,8 +56,12 @@ impl LanguageServer for Backend {
self.client
.log_message(MessageType::INFO, "Initializing diagnostic receiver ...")
.await;

let mut receiver = self.data.lock().await.receiver.take().unwrap();
let mut state = self.data.lock().await;
state.workspace = match params.workspace_folders {
Some(workspaces) => normalize_slither_path(workspaces[0].uri.path()),
None => normalize_slither_path(params.root_uri.unwrap().path()),
};
let mut receiver = state.receiver.take().unwrap();
let client = self.client.clone();
self.join_handle
.lock()
Expand All @@ -76,19 +80,13 @@ impl LanguageServer for Backend {
)
.await;

let folders = params.workspace_folders;
if let Some(folder) = folders {
eprintln!("Initializing filters ...");
match self.initialize_filters(folder).await {
Ok(_) => {
eprintln!("Filters initialized!");
}
Err(e) => {
eprintln!("Error while initializing filters: {:?}", e);
}
match self.initialize_filters(&mut state) {
Ok(_) => {
eprintln!("Filters initialized!");
}
Err(e) => {
eprintln!("Error while initializing filters: {:?}", e);
}
} else {
eprintln!("No workspace folders found!");
}

Ok(InitializeResult {
Expand Down Expand Up @@ -183,7 +181,6 @@ impl Backend {
let state = self.data.lock().await;
for lib in state.libs_paths.iter() {
let fsrc = format!("/{}/", lib.replace('\"', ""));
eprintln!("Check path: '{}' contains lib: '{}'", path, fsrc);
if path.contains(&fsrc) {
return true;
}
Expand All @@ -195,7 +192,6 @@ impl Backend {
let state = self.data.lock().await;
for src in state.src_paths.iter() {
let fsrc = format!("/{}/", src.replace('\"', ""));
eprintln!("Check path: '{}' contains src: '{}'", path, fsrc);
if path.contains(&fsrc) {
return true;
}
Expand All @@ -207,51 +203,49 @@ impl Backend {
let state = self.data.lock().await;
for test in state.tests_paths.iter() {
let fsrc = format!("/{}/", test.replace('\"', ""));
eprintln!("Check path: '{}' contains test: '{}'", path, fsrc);
if path.contains(&fsrc) {
return true;
}
}
false
}

async fn initialize_filters(&self, workspaces: Vec<WorkspaceFolder>) -> Result<()> {
let mut state = self.data.lock().await;
fn initialize_filters(&self, state: &mut MutexGuard<SlitherData>) -> Result<()> {
//register all work directories folder aliases using foundry.toml for each workspace folder
for folder in workspaces {
let folderpath = normalize_slither_path(folder.uri.path());
let foundry_path = find_foundry_toml_config(&folderpath);
if let Ok(path) = foundry_path {
let foundry = std::fs::read_to_string(path.clone());
match foundry {
Ok(foundry) => {
parse_foundry_toml(foundry, &mut state);
}
Err(e) => {
eprintln!(
"Error while reading foundry.toml file: {:?}, path: {}",
e, path
);
}
}
let foundry_path = find_foundry_toml_config(&state.workspace);
if let Ok(path) = foundry_path {
let foundry = std::fs::read_to_string(path.clone());
match foundry {
Ok(foundry) => {
parse_foundry_toml(foundry, state);
}
Err(e) => {
eprintln!(
"Error while reading foundry.toml file: {:?}, path: {}",
e, path
);
}
}
}
Ok(())
}

async fn launch_slither(&self, uri: Url) {
let filepath = normalize_slither_path(uri.path());
let mut state = self.data.lock().await;
let token = CancellationToken::new();
let clone = token.clone();
self.data.lock().await.slither_processes.push(token);
let sender_handle = self.data.lock().await.sender.clone();
state.slither_processes.push(token);
let sender_handle = state.sender.clone();
let client = self.client.clone();
let workspace = state.workspace.clone();

tokio::spawn(async move {
tokio::select! {
_ = clone.cancelled() => {
eprintln!("SLITHER CANCELLED");
}
output = parse_slither_out(uri.path()) => {
output = parse_slither_out(&filepath, &workspace) => {
match output {
Ok(res) => {
let _ = sender_handle.send(SlitherDiag::new(uri, res)).await;
Expand All @@ -262,7 +256,7 @@ impl Backend {
MessageType::ERROR,
format!(
"File '{}' did generate an error while parsing the output: {:?}",
uri.path(),
filepath,
e
),
)
Expand All @@ -273,7 +267,7 @@ impl Backend {
client
.log_message(
MessageType::ERROR,
format!("File '{}' did generate an error: {:?}", uri.path(), e),
format!("File '{}' did generate an error: {:?}", filepath, e),
)
.await;
}
Expand Down
Loading

0 comments on commit a4c8a32

Please sign in to comment.