mirror of
https://github.com/RPCSX/llvm.git
synced 2025-05-15 20:15:58 +00:00

Previously parsing of these were all grouped together into a single master class that could parse any type of debug info fragment. With writing forthcoming, the complexity of each individual fragment is enough to warrant them having their own classes so that reading and writing of each fragment type can be grouped together, but isolated from the code for reading and writing other fragment types. In doing so, I found a place where parsing code was duplicated for the FileChecksums fragment, across llvm-readobj and the CodeView library, and one of the implementations had a bug. Now that the codepaths are merged, the bug is resolved. Differential Revision: https://reviews.llvm.org/D32547 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@301557 91177308-0d34-0410-b5e6-96231b3b80d8
48 lines
1.5 KiB
C++
48 lines
1.5 KiB
C++
//===- ModuleDebugFragmentRecord.cpp -----------------------------*- C++-*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/DebugInfo/CodeView/ModuleDebugFragmentRecord.h"
|
|
|
|
#include "llvm/Support/BinaryStreamReader.h"
|
|
|
|
using namespace llvm;
|
|
using namespace llvm::codeview;
|
|
|
|
ModuleDebugFragmentRecord::ModuleDebugFragmentRecord()
|
|
: Kind(ModuleDebugFragmentKind::None) {}
|
|
|
|
ModuleDebugFragmentRecord::ModuleDebugFragmentRecord(
|
|
ModuleDebugFragmentKind Kind, BinaryStreamRef Data)
|
|
: Kind(Kind), Data(Data) {}
|
|
|
|
Error ModuleDebugFragmentRecord::initialize(BinaryStreamRef Stream,
|
|
ModuleDebugFragmentRecord &Info) {
|
|
const ModuleDebugFragmentHeader *Header;
|
|
BinaryStreamReader Reader(Stream);
|
|
if (auto EC = Reader.readObject(Header))
|
|
return EC;
|
|
|
|
ModuleDebugFragmentKind Kind =
|
|
static_cast<ModuleDebugFragmentKind>(uint32_t(Header->Kind));
|
|
if (auto EC = Reader.readStreamRef(Info.Data, Header->Length))
|
|
return EC;
|
|
Info.Kind = Kind;
|
|
return Error::success();
|
|
}
|
|
|
|
uint32_t ModuleDebugFragmentRecord::getRecordLength() const {
|
|
return sizeof(ModuleDebugFragmentHeader) + Data.getLength();
|
|
}
|
|
|
|
ModuleDebugFragmentKind ModuleDebugFragmentRecord::kind() const { return Kind; }
|
|
|
|
BinaryStreamRef ModuleDebugFragmentRecord::getRecordData() const {
|
|
return Data;
|
|
}
|