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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
//===-- Twine.cpp - Fast Temporary String Concatenation -------------------===//
//
// The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
#include "llvm/ADT/Twine.h"
#include "llvm/Support/raw_ostream.h"
using namespace llvm;
std::string Twine::str() const {
std::string Res;
raw_string_ostream OS(Res);
print(OS);
return Res;
}
void Twine::toVector(SmallVectorImpl<char> &Out) const {
// FIXME: This is very inefficient, since we are creating a large raw_ostream
// buffer -- hitting malloc, which we were supposed to avoid -- all when we
// have this pretty little small vector available.
//
// The best way to fix this is to make raw_svector_ostream do the right thing
// and be efficient, by augmenting the base raw_ostream with the ability to
// have the buffer managed by a concrete implementation.
raw_svector_ostream OS(Out);
print(OS);
}
void Twine::printOneChild(raw_ostream &OS, const void *Ptr,
NodeKind Kind) const {
switch (Kind) {
case Twine::NullKind: break;
case Twine::EmptyKind: break;
case Twine::TwineKind:
static_cast<const Twine*>(Ptr)->print(OS);
break;
case Twine::CStringKind:
OS << static_cast<const char*>(Ptr);
break;
case Twine::StdStringKind:
OS << *static_cast<const std::string*>(Ptr);
break;
case Twine::StringRefKind:
OS << *static_cast<const StringRef*>(Ptr);
break;
case Twine::UDec32Kind:
OS << *static_cast<const uint32_t*>(Ptr);
break;
case Twine::SDec32Kind:
OS << *static_cast<const int32_t*>(Ptr);
break;
case Twine::UDec64Kind:
OS << *static_cast<const uint64_t*>(Ptr);
break;
case Twine::SDec64Kind:
OS << *static_cast<const int64_t*>(Ptr);
break;
case Twine::UHexKind:
OS.write_hex(*static_cast<const uint64_t*>(Ptr));
break;
}
}
void Twine::printOneChildRepr(raw_ostream &OS, const void *Ptr,
NodeKind Kind) const {
switch (Kind) {
case Twine::NullKind:
OS << "null"; break;
case Twine::EmptyKind:
OS << "empty"; break;
case Twine::TwineKind:
OS << "rope:";
static_cast<const Twine*>(Ptr)->printRepr(OS);
break;
case Twine::CStringKind:
OS << "cstring:\""
<< static_cast<const char*>(Ptr) << "\"";
break;
case Twine::StdStringKind:
OS << "std::string:\""
<< static_cast<const std::string*>(Ptr) << "\"";
break;
case Twine::StringRefKind:
OS << "stringref:\""
<< static_cast<const StringRef*>(Ptr) << "\"";
break;
case Twine::UDec32Kind:
OS << "udec32:" << static_cast<const uint64_t*>(Ptr) << "\"";
break;
case Twine::SDec32Kind:
OS << "sdec32:" << static_cast<const int64_t*>(Ptr) << "\"";
break;
case Twine::UDec64Kind:
OS << "udec64:" << static_cast<const uint64_t*>(Ptr) << "\"";
break;
case Twine::SDec64Kind:
OS << "sdec64:" << static_cast<const int64_t*>(Ptr) << "\"";
break;
case Twine::UHexKind:
OS << "uhex:" << static_cast<const uint64_t*>(Ptr) << "\"";
break;
}
}
void Twine::print(raw_ostream &OS) const {
printOneChild(OS, LHS, getLHSKind());
printOneChild(OS, RHS, getRHSKind());
}
void Twine::printRepr(raw_ostream &OS) const {
OS << "(Twine ";
printOneChildRepr(OS, LHS, getLHSKind());
OS << " ";
printOneChildRepr(OS, RHS, getRHSKind());
OS << ")";
}
void Twine::dump() const {
print(llvm::errs());
}
void Twine::dumpRepr() const {
printRepr(llvm::errs());
}
|