From 8c6a87b3a3d1dc535887ac88a0048370c45ca936 Mon Sep 17 00:00:00 2001 From: Fangrui Song Date: Sat, 20 Jan 2018 16:17:28 -0800 Subject: [PATCH] Fix signatureHelp signature selection heuristic --- src/messages/text_document_signature_help.cc | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/src/messages/text_document_signature_help.cc b/src/messages/text_document_signature_help.cc index 4f42ff3e..2c3edb03 100644 --- a/src/messages/text_document_signature_help.cc +++ b/src/messages/text_document_signature_help.cc @@ -4,6 +4,8 @@ #include "queue_manager.h" #include "timer.h" +#include + namespace { struct Ipc_TextDocumentSignatureHelp : public RequestMessage { @@ -122,13 +124,17 @@ struct TextDocumentSignatureHelpHandler : MessageHandler { out.result.signatures.push_back(signature); } - // Guess the signature the user wants based on available parameter - // count. + // Prefer the signature with least parameter count but still larger + // than active_param. out.result.activeSignature = 0; - for (size_t i = 0; i < out.result.signatures.size(); ++i) { - if (active_param < out.result.signatures.size()) { - out.result.activeSignature = (int)i; - break; + if (out.result.signatures.size()) { + size_t num_parameters = SIZE_MAX; + for (size_t i = 0; i < out.result.signatures.size(); ++i) { + size_t t = out.result.signatures[i].parameters.size(); + if (active_param < t && t < num_parameters) { + out.result.activeSignature = int(i); + num_parameters = t; + } } }