aboutsummaryrefslogtreecommitdiff
path: root/lld/MachO/ExportTrie.h
diff options
context:
space:
mode:
Diffstat (limited to 'lld/MachO/ExportTrie.h')
-rw-r--r--lld/MachO/ExportTrie.h47
1 files changed, 47 insertions, 0 deletions
diff --git a/lld/MachO/ExportTrie.h b/lld/MachO/ExportTrie.h
new file mode 100644
index 000000000000..2bd8c33db9a0
--- /dev/null
+++ b/lld/MachO/ExportTrie.h
@@ -0,0 +1,47 @@
+//===- ExportTrie.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 LLD_MACHO_EXPORT_TRIE_H
+#define LLD_MACHO_EXPORT_TRIE_H
+
+#include "llvm/ADT/ArrayRef.h"
+#include "llvm/ADT/STLExtras.h"
+
+#include <vector>
+
+namespace lld {
+namespace macho {
+
+struct TrieNode;
+class Symbol;
+
+class TrieBuilder {
+public:
+ void addSymbol(const Symbol &sym) { exported.push_back(&sym); }
+ // Returns the size in bytes of the serialized trie.
+ size_t build();
+ void writeTo(uint8_t *buf) const;
+
+private:
+ TrieNode *makeNode();
+ void sortAndBuild(llvm::MutableArrayRef<const Symbol *> vec, TrieNode *node,
+ size_t lastPos, size_t pos);
+
+ std::vector<const Symbol *> exported;
+ std::vector<TrieNode *> nodes;
+};
+
+using TrieEntryCallback =
+ llvm::function_ref<void(const llvm::Twine & /*name*/, uint64_t /*flags*/)>;
+
+void parseTrie(const uint8_t *buf, size_t size, const TrieEntryCallback &);
+
+} // namespace macho
+} // namespace lld
+
+#endif