Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / lld / MachO / ExportTrie.h
blobaa7e3b0d4a14b17c51013184afd342f3375f09a1
1 //===- ExportTrie.h ---------------------------------------------*- C++ -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
9 #ifndef LLD_MACHO_EXPORT_TRIE_H
10 #define LLD_MACHO_EXPORT_TRIE_H
12 #include "llvm/ADT/ArrayRef.h"
13 #include "llvm/ADT/STLExtras.h"
15 #include <vector>
17 namespace lld::macho {
19 struct TrieNode;
20 class Symbol;
22 class TrieBuilder {
23 public:
24 ~TrieBuilder();
25 void setImageBase(uint64_t addr) { imageBase = addr; }
26 void addSymbol(const Symbol &sym) { exported.push_back(&sym); }
27 // Returns the size in bytes of the serialized trie.
28 size_t build();
29 void writeTo(uint8_t *buf) const;
31 private:
32 TrieNode *makeNode();
33 void sortAndBuild(llvm::MutableArrayRef<const Symbol *> vec, TrieNode *node,
34 size_t lastPos, size_t pos);
36 uint64_t imageBase = 0;
37 std::vector<const Symbol *> exported;
38 std::vector<TrieNode *> nodes;
41 using TrieEntryCallback =
42 llvm::function_ref<void(const llvm::Twine & /*name*/, uint64_t /*flags*/)>;
44 void parseTrie(const uint8_t *buf, size_t size, const TrieEntryCallback &);
46 } // namespace lld::macho
48 #endif