Mountain/RPC/CocoonService/Initialization/
InitExtensionHost.rs1
2use tonic::{Response, Status};
7
8use crate::{
9 ApplicationState::DTO::WorkspaceFolderStateDTO::WorkspaceFolderStateDTO,
10 RPC::CocoonService::CocoonServiceImpl,
11 Vine::Generated::{Empty, InitExtensionHostRequest},
12 dev_log,
13};
14
15pub async fn Fn(Service:&CocoonServiceImpl, Request:InitExtensionHostRequest) -> Result<Response<Empty>, Status> {
16 dev_log!(
17 "cocoon",
18 "[CocoonService] Initializing extension host with {} workspace folders",
19 Request.workspace_folders.len()
20 );
21
22 for Folder in &Request.workspace_folders {
23 dev_log!(
24 "cocoon",
25 "[CocoonService] Workspace folder: {} ({})",
26 Folder.name,
27 Folder.uri.as_ref().map(|U| &U.value).unwrap_or(&String::new())
28 );
29 }
30
31 dev_log!("cocoon", "[CocoonService] Configuration: {} keys", Request.configuration.len());
32
33 let Folders:Vec<WorkspaceFolderStateDTO> = Request
34 .workspace_folders
35 .iter()
36 .enumerate()
37 .filter_map(|(Index, F)| {
38 let URI = F.uri.as_ref().map(|U| U.value.as_str()).unwrap_or("");
39 url::Url::parse(URI)
40 .ok()
41 .and_then(|Parsed| WorkspaceFolderStateDTO::New(Parsed, F.name.clone(), Index).ok())
42 })
43 .collect();
44
45 if !Folders.is_empty() {
46 Service.environment.ApplicationState.Workspace.SetWorkspaceFolders(Folders);
47
48 dev_log!(
49 "cocoon",
50 "[CocoonService] Workspace folders stored: {}",
51 Request.workspace_folders.len()
52 );
53 }
54
55 Ok(Response::new(Empty {}))
56}