diff --git a/metals/src/main/scala/scala/meta/internal/metals/ClientConfiguration.scala b/metals/src/main/scala/scala/meta/internal/metals/ClientConfiguration.scala index efb57a805f5..1e444677271 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/ClientConfiguration.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/ClientConfiguration.scala @@ -162,6 +162,15 @@ final class ClientConfiguration( } yield true }.getOrElse(false) + def isInlayHintsRefreshEnabled(): Boolean = { + for { + capabilities <- clientCapabilities + workspace <- Option(capabilities.getWorkspace()) + inlayHints <- Option(workspace.getInlayHint()) + refreshSupport <- Option(inlayHints.getRefreshSupport()) + } yield refreshSupport.booleanValue() + }.getOrElse(false) + def hoverContentType(): ContentType = (for { capabilities <- clientCapabilities diff --git a/metals/src/main/scala/scala/meta/internal/metals/clients/language/ConfiguredLanguageClient.scala b/metals/src/main/scala/scala/meta/internal/metals/clients/language/ConfiguredLanguageClient.scala index 1c11679a178..3f13e88d13c 100644 --- a/metals/src/main/scala/scala/meta/internal/metals/clients/language/ConfiguredLanguageClient.scala +++ b/metals/src/main/scala/scala/meta/internal/metals/clients/language/ConfiguredLanguageClient.scala @@ -140,7 +140,10 @@ final class ConfiguredLanguageClient( } override def refreshInlayHints(): CompletableFuture[Void] = { - if (clientConfig.isInlayHintsEnabled()) { + if ( + clientConfig.isInlayHintsEnabled() && clientConfig + .isInlayHintsRefreshEnabled() + ) { underlying .refreshInlayHints() .handle { (msg, ex) =>