llvm-project/llvm/lib/DebugInfo/CodeView/SymbolRecordHelpers.cpp
serge-sans-paille 81cde474e2 Cleanup LLVMDebugInfoCodeView headers
Major user-facing changes:

Many headers in llvm/DebugInfo/CodeView no longer include
llvm/Support/BinaryStreamReader.h or llvm/Support/BinaryStreamWriter.h,
those headers may need to be included manually.

Several headers in llvm/DebugInfo/CodeView no longer include
llvm/DebugInfo/CodeView/EnumTables.h or llvm/DebugInfo/CodeView/CodeView.h,
those headers may need to be included manually.

Some statistics:
$ clang++ -E  -Iinclude -I../llvm/include ../llvm/lib/DebugInfo/CodeView/*.cpp -std=c++14 -fno-rtti -fno-exceptions | wc -l
after:  2794466
before: 2832765

Discourse thread on the topic: https://discourse.llvm.org/t/include-what-you-use-include-cleanup/

Differential Revision: https://reviews.llvm.org/D119092
2022-02-08 16:00:36 +01:00

94 lines
2.8 KiB
C++

//===- SymbolRecordHelpers.cpp ----------------------------------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#include "llvm/DebugInfo/CodeView/SymbolRecordHelpers.h"
#include "llvm/ADT/ArrayRef.h"
#include "llvm/DebugInfo/CodeView/SymbolDeserializer.h"
using namespace llvm;
using namespace llvm::codeview;
template <typename RecordT> static RecordT createRecord(const CVSymbol &sym) {
RecordT record(static_cast<SymbolRecordKind>(sym.kind()));
cantFail(SymbolDeserializer::deserializeAs<RecordT>(sym, record));
return record;
}
uint32_t llvm::codeview::getScopeEndOffset(const CVSymbol &Sym) {
assert(symbolOpensScope(Sym.kind()));
switch (Sym.kind()) {
case SymbolKind::S_GPROC32:
case SymbolKind::S_LPROC32:
case SymbolKind::S_GPROC32_ID:
case SymbolKind::S_LPROC32_ID:
case SymbolKind::S_LPROC32_DPC:
case SymbolKind::S_LPROC32_DPC_ID: {
ProcSym Proc = createRecord<ProcSym>(Sym);
return Proc.End;
}
case SymbolKind::S_BLOCK32: {
BlockSym Block = createRecord<BlockSym>(Sym);
return Block.End;
}
case SymbolKind::S_THUNK32: {
Thunk32Sym Thunk = createRecord<Thunk32Sym>(Sym);
return Thunk.End;
}
case SymbolKind::S_INLINESITE: {
InlineSiteSym Site = createRecord<InlineSiteSym>(Sym);
return Site.End;
}
default:
assert(false && "Unknown record type");
return 0;
}
}
uint32_t
llvm::codeview::getScopeParentOffset(const llvm::codeview::CVSymbol &Sym) {
assert(symbolOpensScope(Sym.kind()));
switch (Sym.kind()) {
case SymbolKind::S_GPROC32:
case SymbolKind::S_LPROC32:
case SymbolKind::S_GPROC32_ID:
case SymbolKind::S_LPROC32_ID:
case SymbolKind::S_LPROC32_DPC:
case SymbolKind::S_LPROC32_DPC_ID: {
ProcSym Proc = createRecord<ProcSym>(Sym);
return Proc.Parent;
}
case SymbolKind::S_BLOCK32: {
BlockSym Block = createRecord<BlockSym>(Sym);
return Block.Parent;
}
case SymbolKind::S_THUNK32: {
Thunk32Sym Thunk = createRecord<Thunk32Sym>(Sym);
return Thunk.Parent;
}
case SymbolKind::S_INLINESITE: {
InlineSiteSym Site = createRecord<InlineSiteSym>(Sym);
return Site.Parent;
}
default:
assert(false && "Unknown record type");
return 0;
}
}
CVSymbolArray
llvm::codeview::limitSymbolArrayToScope(const CVSymbolArray &Symbols,
uint32_t ScopeBegin) {
CVSymbol Opener = *Symbols.at(ScopeBegin);
assert(symbolOpensScope(Opener.kind()));
uint32_t EndOffset = getScopeEndOffset(Opener);
CVSymbol Closer = *Symbols.at(EndOffset);
EndOffset += Closer.RecordData.size();
return Symbols.substream(ScopeBegin, EndOffset);
}