mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
[CodeCompletion] Add 'IsSystem' flag to code completion result item
'key.is_system: 1' is added if the associated declaration is from a system module. rdar://problem/62617558
This commit is contained in:
@@ -215,6 +215,7 @@ static bool readCachedModule(llvm::MemoryBuffer *in,
|
||||
auto opKind = static_cast<CodeCompletionOperatorKind>(*cursor++);
|
||||
auto context = static_cast<SemanticContextKind>(*cursor++);
|
||||
auto notRecommended = static_cast<bool>(*cursor++);
|
||||
auto isSystem = static_cast<bool>(*cursor++);
|
||||
auto numBytesToErase = static_cast<unsigned>(*cursor++);
|
||||
auto oldCursor = cursor;
|
||||
auto chunkIndex = read32le(cursor);
|
||||
@@ -248,7 +249,7 @@ static bool readCachedModule(llvm::MemoryBuffer *in,
|
||||
CodeCompletionResult *result = nullptr;
|
||||
if (kind == CodeCompletionResult::Declaration) {
|
||||
result = new (*V.Sink.Allocator) CodeCompletionResult(
|
||||
context, numBytesToErase, string, declKind, moduleName,
|
||||
context, numBytesToErase, string, declKind, isSystem, moduleName,
|
||||
notRecommended, CodeCompletionResult::NotRecommendedReason::NoReason,
|
||||
briefDocComment, copyStringArray(*V.Sink.Allocator, assocUSRs),
|
||||
copyStringPairArray(*V.Sink.Allocator, declKeywords),
|
||||
@@ -371,6 +372,7 @@ static void writeCachedModule(llvm::raw_ostream &out,
|
||||
LE.write(static_cast<uint8_t>(CodeCompletionOperatorKind::None));
|
||||
LE.write(static_cast<uint8_t>(R->getSemanticContext()));
|
||||
LE.write(static_cast<uint8_t>(R->isNotRecommended()));
|
||||
LE.write(static_cast<uint8_t>(R->isSystem()));
|
||||
LE.write(static_cast<uint8_t>(R->getNumBytesToErase()));
|
||||
LE.write(
|
||||
static_cast<uint32_t>(addCompletionString(R->getCompletionString())));
|
||||
|
||||
Reference in New Issue
Block a user