mirror of
https://github.com/llvm/llvm-project.git
synced 2025-05-01 19:56:05 +00:00

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
35 lines
1.1 KiB
C++
35 lines
1.1 KiB
C++
//===- DebugSymbolsSubsection.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/DebugSymbolsSubsection.h"
|
|
#include "llvm/Support/BinaryStreamWriter.h"
|
|
|
|
using namespace llvm;
|
|
using namespace llvm::codeview;
|
|
|
|
Error DebugSymbolsSubsectionRef::initialize(BinaryStreamReader Reader) {
|
|
return Reader.readArray(Records, Reader.getLength());
|
|
}
|
|
|
|
uint32_t DebugSymbolsSubsection::calculateSerializedSize() const {
|
|
return Length;
|
|
}
|
|
|
|
Error DebugSymbolsSubsection::commit(BinaryStreamWriter &Writer) const {
|
|
for (const auto &Record : Records) {
|
|
if (auto EC = Writer.writeBytes(Record.RecordData))
|
|
return EC;
|
|
}
|
|
return Error::success();
|
|
}
|
|
|
|
void DebugSymbolsSubsection::addSymbol(CVSymbol Symbol) {
|
|
Records.push_back(Symbol);
|
|
Length += Symbol.length();
|
|
}
|