Mountain/RPC/CocoonService/Provider/
ProvideSignatureHelp.rs1#![allow(non_snake_case)]
2
3use serde_json::json;
6use tonic::{Response, Status};
7use url::Url;
8use CommonLibrary::LanguageFeature::{
9 DTO::PositionDTO::PositionDTO,
10 LanguageFeatureProviderRegistry::LanguageFeatureProviderRegistry,
11};
12
13use crate::{
14 RPC::CocoonService::CocoonServiceImpl,
15 Vine::Generated::{ProvideSignatureHelpRequest, ProvideSignatureHelpResponse},
16 dev_log,
17};
18
19pub async fn Fn(
20 Service:&CocoonServiceImpl,
21 Request:ProvideSignatureHelpRequest,
22) -> Result<Response<ProvideSignatureHelpResponse>, Status> {
23 dev_log!("cocoon", "[CocoonService] Providing signature help");
24 let URI = Request.uri.as_ref().map(|U| U.value.as_str()).unwrap_or("");
25 let DocumentURI = Url::parse(URI).map_err(|E| Status::invalid_argument(format!("Invalid URI: {}", E)))?;
26 let Position_ = Request.position.as_ref();
27 let PositionDTO_ = PositionDTO {
28 LineNumber:Position_.map(|P| P.line).unwrap_or(0),
29 Column:Position_.map(|P| P.character).unwrap_or(0),
30 };
31 let ContextDTO = json!({ "triggerKind": 1, "isRetrigger": false });
32 match Service
33 .environment
34 .ProvideSignatureHelp(DocumentURI, PositionDTO_, ContextDTO)
35 .await
36 {
37 Ok(_) => Ok(Response::new(ProvideSignatureHelpResponse::default())),
38 Err(Error) => Err(Status::internal(format!("Signature help failed: {}", Error))),
39 }
40}