ccls/src/messages/cquery_vars.cc

52 lines
1.5 KiB
C++
Raw Normal View History

2017-12-06 03:32:33 +00:00
#include "message_handler.h"
#include "query_utils.h"
2017-12-29 16:29:47 +00:00
#include "queue_manager.h"
2017-12-06 03:32:33 +00:00
namespace {
struct Ipc_CqueryVars : public RequestMessage<Ipc_CqueryVars> {
2017-12-06 04:39:44 +00:00
const static IpcId kIpcId = IpcId::CqueryVars;
lsTextDocumentPositionParams params;
};
MAKE_REFLECT_STRUCT(Ipc_CqueryVars, id, params);
REGISTER_IPC_MESSAGE(Ipc_CqueryVars);
2017-12-06 03:32:33 +00:00
struct CqueryVarsHandler : BaseMessageHandler<Ipc_CqueryVars> {
void Run(Ipc_CqueryVars* request) override {
QueryFile* file;
if (!FindFileOrFail(db, project, request->id,
2017-12-06 03:32:33 +00:00
request->params.textDocument.uri.GetPath(), &file)) {
return;
}
WorkingFile* working_file =
working_files->GetFileByFilename(file->def->path);
Out_LocationList out;
out.id = request->id;
2018-02-10 06:51:58 +00:00
for (SymbolRef sym :
2017-12-06 03:32:33 +00:00
FindSymbolsAtLocation(working_file, file, request->params.position)) {
Id<void> id = sym.id;
2018-02-10 06:51:58 +00:00
switch (sym.kind) {
default:
break;
case SymbolKind::Var: {
2018-02-10 06:51:58 +00:00
QueryVar& var = db->GetVar(sym);
if (!var.def || !var.def->type)
continue;
id = *var.def->type;
}
// fallthrough
case SymbolKind::Type: {
QueryType& type = db->types[id.id];
out.result =
GetLsLocations(db, working_files, ToUses(db, type.instances));
break;
}
2017-12-06 03:32:33 +00:00
}
}
2017-12-24 00:25:18 +00:00
QueueManager::WriteStdout(IpcId::CqueryVars, out);
2017-12-06 03:32:33 +00:00
}
};
REGISTER_MESSAGE_HANDLER(CqueryVarsHandler);
} // namespace