//===- StringTableBuilder.h - String table building utility -----*- 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_MC_STRINGTABLEBUILDER_H #define LLVM_MC_STRINGTABLEBUILDER_H #include "llvm/ADT/CachedHashString.h" #include "llvm/ADT/DenseMap.h" #include "llvm/ADT/StringRef.h" #include "llvm/Support/Alignment.h" #include #include namespace llvm { class raw_ostream; /// Utility for building string tables with deduplicated suffixes. class StringTableBuilder { public: enum Kind { ELF, WinCOFF, MachO, MachO64, MachOLinked, MachO64Linked, RAW, DWARF, XCOFF, DXContainer }; private: DenseMap StringIndexMap; size_t Size = 0; Kind K; Align Alignment; bool Finalized = false; void finalizeStringTable(bool Optimize); void initSize(); public: StringTableBuilder(Kind K, Align Alignment = Align(1)); ~StringTableBuilder(); /// Add a string to the builder. Returns the position of S in the /// table. The position will be changed if finalize is used. /// Can only be used before the table is finalized. size_t add(CachedHashStringRef S); size_t add(StringRef S) { return add(CachedHashStringRef(S)); } /// Analyze the strings and build the final table. No more strings can /// be added after this point. void finalize(); /// Finalize the string table without reording it. In this mode, offsets /// returned by add will still be valid. void finalizeInOrder(); /// Get the offest of a string in the string table. Can only be used /// after the table is finalized. size_t getOffset(CachedHashStringRef S) const; size_t getOffset(StringRef S) const { return getOffset(CachedHashStringRef(S)); } /// Check if a string is contained in the string table. Since this class /// doesn't store the string values, this function can be used to check if /// storage needs to be done prior to adding the string. bool contains(StringRef S) const { return contains(CachedHashStringRef(S)); } bool contains(CachedHashStringRef S) const { return StringIndexMap.count(S); } size_t getSize() const { return Size; } void clear(); void write(raw_ostream &OS) const; void write(uint8_t *Buf) const; bool isFinalized() const { return Finalized; } }; } // end namespace llvm #endif // LLVM_MC_STRINGTABLEBUILDER_H