LLVM  16.0.0git
StringSaver.h
Go to the documentation of this file.
1 //===- llvm/Support/StringSaver.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 //===----------------------------------------------------------------------===//
8 
9 #ifndef LLVM_SUPPORT_STRINGSAVER_H
10 #define LLVM_SUPPORT_STRINGSAVER_H
11 
12 #include "llvm/ADT/DenseSet.h"
13 #include "llvm/ADT/StringRef.h"
14 #include "llvm/ADT/Twine.h"
15 #include "llvm/Support/Allocator.h"
16 
17 namespace llvm {
18 
19 /// Saves strings in the provided stable storage and returns a
20 /// StringRef with a stable character pointer.
21 class StringSaver final {
22  BumpPtrAllocator &Alloc;
23 
24 public:
25  StringSaver(BumpPtrAllocator &Alloc) : Alloc(Alloc) {}
26 
27  BumpPtrAllocator &getAllocator() const { return Alloc; }
28 
29  // All returned strings are null-terminated: *save(S).end() == 0.
30  StringRef save(const char *S) { return save(StringRef(S)); }
32  StringRef save(const Twine &S) { return save(StringRef(S.str())); }
33  StringRef save(const std::string &S) { return save(StringRef(S)); }
34 };
35 
36 /// Saves strings in the provided stable storage and returns a StringRef with a
37 /// stable character pointer. Saving the same string yields the same StringRef.
38 ///
39 /// Compared to StringSaver, it does more work but avoids saving the same string
40 /// multiple times.
41 ///
42 /// Compared to StringPool, it performs fewer allocations but doesn't support
43 /// refcounting/deletion.
44 class UniqueStringSaver final {
45  StringSaver Strings;
47 
48 public:
49  UniqueStringSaver(BumpPtrAllocator &Alloc) : Strings(Alloc) {}
50 
51  // All returned strings are null-terminated: *save(S).end() == 0.
52  StringRef save(const char *S) { return save(StringRef(S)); }
54  StringRef save(const Twine &S) { return save(StringRef(S.str())); }
55  StringRef save(const std::string &S) { return save(StringRef(S)); }
56 };
57 
58 }
59 #endif
llvm
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
StringRef.h
Allocator.h
llvm::UniqueStringSaver::save
StringRef save(const Twine &S)
Definition: StringSaver.h:54
llvm::UniqueStringSaver
Saves strings in the provided stable storage and returns a StringRef with a stable character pointer.
Definition: StringSaver.h:44
Twine.h
DenseSet.h
llvm::DenseSet< llvm::StringRef >
llvm::StringSaver::StringSaver
StringSaver(BumpPtrAllocator &Alloc)
Definition: StringSaver.h:25
llvm::BumpPtrAllocatorImpl
Allocate memory in an ever growing pool, as if by bump-pointer.
Definition: Allocator.h:63
llvm::StringSaver::save
StringRef save(const std::string &S)
Definition: StringSaver.h:33
llvm::UniqueStringSaver::save
StringRef save(const char *S)
Definition: StringSaver.h:52
llvm::UniqueStringSaver::UniqueStringSaver
UniqueStringSaver(BumpPtrAllocator &Alloc)
Definition: StringSaver.h:49
llvm::StringSaver
Saves strings in the provided stable storage and returns a StringRef with a stable character pointer.
Definition: StringSaver.h:21
llvm::StringRef
StringRef - Represent a constant reference to a string, i.e.
Definition: StringRef.h:50
llvm::UniqueStringSaver::save
StringRef save(const std::string &S)
Definition: StringSaver.h:55
S
add sub stmia L5 ldr r0 bl L_printf $stub Instead of a and a wouldn t it be better to do three moves *Return an aggregate type is even return S
Definition: README.txt:210
llvm::StringSaver::getAllocator
BumpPtrAllocator & getAllocator() const
Definition: StringSaver.h:27
llvm::Twine
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
Definition: Twine.h:81
llvm::StringSaver::save
StringRef save(const Twine &S)
Definition: StringSaver.h:32
llvm::StringSaver::save
StringRef save(const char *S)
Definition: StringSaver.h:30