diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2017-12-18 20:10:56 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2017-12-18 20:10:56 +0000 | 
| commit | 044eb2f6afba375a914ac9d8024f8f5142bb912e (patch) | |
| tree | 1475247dc9f9fe5be155ebd4c9069c75aadf8c20 /lib/DebugInfo/CodeView/StringsAndChecksums.cpp | |
| parent | eb70dddbd77e120e5d490bd8fbe7ff3f8fa81c6b (diff) | |
Notes
Diffstat (limited to 'lib/DebugInfo/CodeView/StringsAndChecksums.cpp')
| -rw-r--r-- | lib/DebugInfo/CodeView/StringsAndChecksums.cpp | 28 | 
1 files changed, 25 insertions, 3 deletions
| diff --git a/lib/DebugInfo/CodeView/StringsAndChecksums.cpp b/lib/DebugInfo/CodeView/StringsAndChecksums.cpp index 306af1d1ef6b..85d9dbb8c7df 100644 --- a/lib/DebugInfo/CodeView/StringsAndChecksums.cpp +++ b/lib/DebugInfo/CodeView/StringsAndChecksums.cpp @@ -35,14 +35,36 @@ void StringsAndChecksumsRef::initializeStrings(    assert(SR.kind() == DebugSubsectionKind::StringTable);    assert(!Strings && "Found a string table even though we already have one!"); -  OwnedStrings = llvm::make_unique<DebugStringTableSubsectionRef>(); +  OwnedStrings = std::make_shared<DebugStringTableSubsectionRef>();    consumeError(OwnedStrings->initialize(SR.getRecordData()));    Strings = OwnedStrings.get();  } +void StringsAndChecksumsRef::reset() { +  resetStrings(); +  resetChecksums(); +} + +void StringsAndChecksumsRef::resetStrings() { +  OwnedStrings.reset(); +  Strings = nullptr; +} + +void StringsAndChecksumsRef::resetChecksums() { +  OwnedChecksums.reset(); +  Checksums = nullptr; +} + +void StringsAndChecksumsRef::setStrings( +    const DebugStringTableSubsectionRef &StringsRef) { +  OwnedStrings = std::make_shared<DebugStringTableSubsectionRef>(); +  *OwnedStrings = StringsRef; +  Strings = OwnedStrings.get(); +} +  void StringsAndChecksumsRef::setChecksums(      const DebugChecksumsSubsectionRef &CS) { -  OwnedChecksums = llvm::make_unique<DebugChecksumsSubsectionRef>(); +  OwnedChecksums = std::make_shared<DebugChecksumsSubsectionRef>();    *OwnedChecksums = CS;    Checksums = OwnedChecksums.get();  } @@ -53,7 +75,7 @@ void StringsAndChecksumsRef::initializeChecksums(    if (Checksums)      return; -  OwnedChecksums = llvm::make_unique<DebugChecksumsSubsectionRef>(); +  OwnedChecksums = std::make_shared<DebugChecksumsSubsectionRef>();    consumeError(OwnedChecksums->initialize(FCR.getRecordData()));    Checksums = OwnedChecksums.get();  } | 
