reference, declaration → definition definition → references, declarations, derived classes, virtual overrides reference to multiple definitions → definitions unreferenced |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 | //===- MergingTypeTableBuilder.h ---------------------------------*- 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 // //===----------------------------------------------------------------------===// #ifndef LLVM_DEBUGINFO_CODEVIEW_MERGINGTYPETABLEBUILDER_H #define LLVM_DEBUGINFO_CODEVIEW_MERGINGTYPETABLEBUILDER_H #include "llvm/ADT/ArrayRef.h" #include "llvm/ADT/DenseSet.h" #include "llvm/ADT/SmallVector.h" #include "llvm/DebugInfo/CodeView/CodeView.h" #include "llvm/DebugInfo/CodeView/SimpleTypeSerializer.h" #include "llvm/DebugInfo/CodeView/TypeCollection.h" #include "llvm/DebugInfo/CodeView/TypeHashing.h" #include "llvm/DebugInfo/CodeView/TypeIndex.h" #include "llvm/Support/Allocator.h" #include <cassert> #include <cstdint> #include <memory> #include <vector> namespace llvm { namespace codeview { class ContinuationRecordBuilder; class MergingTypeTableBuilder : public TypeCollection { /// Storage for records. These need to outlive the TypeTableBuilder. BumpPtrAllocator &RecordStorage; /// A serializer that can write non-continuation leaf types. Only used as /// a convenience function so that we can provide an interface method to /// write an unserialized record. SimpleTypeSerializer SimpleSerializer; /// Hash table. DenseMap<LocallyHashedType, TypeIndex> HashedRecords; /// Contains a list of all records indexed by TypeIndex.toArrayIndex(). SmallVector<ArrayRef<uint8_t>, 2> SeenRecords; public: explicit MergingTypeTableBuilder(BumpPtrAllocator &Storage); ~MergingTypeTableBuilder(); // TypeTableCollection overrides Optional<TypeIndex> getFirst() override; Optional<TypeIndex> getNext(TypeIndex Prev) override; CVType getType(TypeIndex Index) override; StringRef getTypeName(TypeIndex Index) override; bool contains(TypeIndex Index) override; uint32_t size() override; uint32_t capacity() override; // public interface void reset(); TypeIndex nextTypeIndex() const; BumpPtrAllocator &getAllocator() { return RecordStorage; } ArrayRef<ArrayRef<uint8_t>> records() const; TypeIndex insertRecordAs(hash_code Hash, ArrayRef<uint8_t> &Record); TypeIndex insertRecordBytes(ArrayRef<uint8_t> &Record); TypeIndex insertRecord(ContinuationRecordBuilder &Builder); template <typename T> TypeIndex writeLeafType(T &Record) { ArrayRef<uint8_t> Data = SimpleSerializer.serialize(Record); return insertRecordBytes(Data); } }; } // end namespace codeview } // end namespace llvm #endif // LLVM_DEBUGINFO_CODEVIEW_MERGINGTYPETABLEBUILDER_H |