From aecc32c71f98d65cef6c0585d1e5cbdfc4de05ea Mon Sep 17 00:00:00 2001 From: JoshuaBatty Date: Thu, 28 Nov 2024 10:40:40 +1100 Subject: [PATCH] only show return type for fns if one exists --- sway-lsp/src/capabilities/document_symbol.rs | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/sway-lsp/src/capabilities/document_symbol.rs b/sway-lsp/src/capabilities/document_symbol.rs index 213c90ca826..67b6909229f 100644 --- a/sway-lsp/src/capabilities/document_symbol.rs +++ b/sway-lsp/src/capabilities/document_symbol.rs @@ -380,8 +380,14 @@ fn fn_decl_detail(parameters: &[TyFunctionParameter], return_type: &TypeArgument .map(|p| format!("{}: {}", p.name, p.type_argument.span.as_str())) .collect::>() .join(", "); - let return_type = return_type.span.as_str(); - format!("fn({}) -> {}", params, return_type) + + // Check for the presence of a CallPathTree, and if it exists, add it to the return type. + let return_type = return_type + .call_path_tree + .as_ref() + .map(|_| format!(" -> {}", return_type.span.as_str())) + .unwrap_or_default(); + format!("fn({}){}", params, return_type) } /// Extracts the header of a sway construct such as an `impl` block or `abi` declaration,