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
22 Request:ProvideSignatureHelpRequest,
23) -> Result<Response<ProvideSignatureHelpResponse>, Status> {
24 dev_log!("cocoon", "[CocoonService] Providing signature help");
25
26 let URI = Request.uri.as_ref().map(|U| U.value.as_str()).unwrap_or("");
27
28 let DocumentURI = Url::parse(URI).map_err(|E| Status::invalid_argument(format!("Invalid URI: {}", E)))?;
29
30 let Position_ = Request.position.as_ref();
31
32 let PositionDTO_ = PositionDTO {
33 LineNumber:Position_.map(|P| P.line).unwrap_or(0),
34
35 Column:Position_.map(|P| P.character).unwrap_or(0),
36 };
37
38 let ContextDTO = json!({ "triggerKind": 1, "isRetrigger": false });
39
40 match Service
41 .environment
42 .ProvideSignatureHelp(DocumentURI, PositionDTO_, ContextDTO)
43 .await
44 {
45 Ok(_) => Ok(Response::new(ProvideSignatureHelpResponse::default())),
46
47 Err(Error) => Err(Status::internal(format!("Signature help failed: {}", Error))),
48 }
49}