blob: 3d04bc34f0eb8d63ad023af7bcbb5a3e4d38d8ff [file] [log] [blame]
Daniel Dunbar2538f7a2009-07-24 07:04:27 +00001//===-- Twine.cpp - Fast Temporary String Concatenation -------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#include "llvm/ADT/Twine.h"
Daniel Dunbarb7be0e82009-08-19 18:09:47 +000011#include "llvm/ADT/SmallString.h"
David Greene2b965b02010-01-05 01:28:40 +000012#include "llvm/Support/Debug.h"
Daniel Dunbar2538f7a2009-07-24 07:04:27 +000013#include "llvm/Support/raw_ostream.h"
14using namespace llvm;
15
16std::string Twine::str() const {
Frits van Bommel331dbca2011-07-15 11:05:37 +000017 // If we're storing only a std::string, just return it.
18 if (LHSKind == StdStringKind && RHSKind == EmptyKind)
Chris Lattner3f25ee02011-07-24 20:44:30 +000019 return *LHS.stdString;
Frits van Bommel331dbca2011-07-15 11:05:37 +000020
21 // Otherwise, flatten and copy the contents first.
Daniel Dunbarb7be0e82009-08-19 18:09:47 +000022 SmallString<256> Vec;
Benjamin Kramerb357e062010-01-13 12:45:23 +000023 return toStringRef(Vec).str();
Daniel Dunbar2538f7a2009-07-24 07:04:27 +000024}
25
26void Twine::toVector(SmallVectorImpl<char> &Out) const {
27 raw_svector_ostream OS(Out);
28 print(OS);
29}
30
Benjamin Kramerb357e062010-01-13 12:45:23 +000031StringRef Twine::toStringRef(SmallVectorImpl<char> &Out) const {
32 if (isSingleStringRef())
33 return getSingleStringRef();
34 toVector(Out);
35 return StringRef(Out.data(), Out.size());
36}
37
Michael J. Spencer7dc7ac32010-12-01 20:37:30 +000038StringRef Twine::toNullTerminatedStringRef(SmallVectorImpl<char> &Out) const {
Michael J. Spencer0dda5432010-12-03 05:42:25 +000039 if (isUnary()) {
40 switch (getLHSKind()) {
41 case CStringKind:
42 // Already null terminated, yay!
Chris Lattner3f25ee02011-07-24 20:44:30 +000043 return StringRef(LHS.cString);
Michael J. Spencer0dda5432010-12-03 05:42:25 +000044 case StdStringKind: {
Chris Lattner3f25ee02011-07-24 20:44:30 +000045 const std::string *str = LHS.stdString;
Frits van Bommel331dbca2011-07-15 11:05:37 +000046 return StringRef(str->c_str(), str->size());
47 }
Michael J. Spencer0dda5432010-12-03 05:42:25 +000048 default:
49 break;
50 }
Michael J. Spencer7dc7ac32010-12-01 20:37:30 +000051 }
52 toVector(Out);
53 Out.push_back(0);
54 Out.pop_back();
55 return StringRef(Out.data(), Out.size());
56}
57
Chris Lattner3f25ee02011-07-24 20:44:30 +000058void Twine::printOneChild(raw_ostream &OS, Child Ptr,
Daniel Dunbar2538f7a2009-07-24 07:04:27 +000059 NodeKind Kind) const {
60 switch (Kind) {
61 case Twine::NullKind: break;
62 case Twine::EmptyKind: break;
Daniel Dunbar763457e2009-07-29 07:08:44 +000063 case Twine::TwineKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +000064 Ptr.twine->print(OS);
Daniel Dunbar763457e2009-07-29 07:08:44 +000065 break;
Michael J. Spencer326990f2010-11-26 04:16:08 +000066 case Twine::CStringKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +000067 OS << Ptr.cString;
Daniel Dunbar2538f7a2009-07-24 07:04:27 +000068 break;
69 case Twine::StdStringKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +000070 OS << *Ptr.stdString;
Daniel Dunbar2538f7a2009-07-24 07:04:27 +000071 break;
72 case Twine::StringRefKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +000073 OS << *Ptr.stringRef;
74 break;
75 case Twine::CharKind:
76 OS << Ptr.character;
Daniel Dunbar2538f7a2009-07-24 07:04:27 +000077 break;
Daniel Dunbar2d8bc0f2009-07-30 21:15:14 +000078 case Twine::DecUIKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +000079 OS << Ptr.decUI;
Daniel Dunbar0165a2c2009-07-30 03:47:15 +000080 break;
Daniel Dunbar2d8bc0f2009-07-30 21:15:14 +000081 case Twine::DecIKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +000082 OS << Ptr.decI;
Daniel Dunbar0165a2c2009-07-30 03:47:15 +000083 break;
Daniel Dunbar2d8bc0f2009-07-30 21:15:14 +000084 case Twine::DecULKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +000085 OS << *Ptr.decUL;
Daniel Dunbar763457e2009-07-29 07:08:44 +000086 break;
Daniel Dunbar2d8bc0f2009-07-30 21:15:14 +000087 case Twine::DecLKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +000088 OS << *Ptr.decL;
Daniel Dunbar2d8bc0f2009-07-30 21:15:14 +000089 break;
90 case Twine::DecULLKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +000091 OS << *Ptr.decULL;
Daniel Dunbar2d8bc0f2009-07-30 21:15:14 +000092 break;
93 case Twine::DecLLKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +000094 OS << *Ptr.decLL;
Daniel Dunbar763457e2009-07-29 07:08:44 +000095 break;
96 case Twine::UHexKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +000097 OS.write_hex(*Ptr.uHex);
Daniel Dunbar2538f7a2009-07-24 07:04:27 +000098 break;
99 }
100}
101
Chris Lattner3f25ee02011-07-24 20:44:30 +0000102void Twine::printOneChildRepr(raw_ostream &OS, Child Ptr,
Daniel Dunbar2538f7a2009-07-24 07:04:27 +0000103 NodeKind Kind) const {
104 switch (Kind) {
105 case Twine::NullKind:
106 OS << "null"; break;
107 case Twine::EmptyKind:
108 OS << "empty"; break;
Daniel Dunbar2538f7a2009-07-24 07:04:27 +0000109 case Twine::TwineKind:
110 OS << "rope:";
Chris Lattner3f25ee02011-07-24 20:44:30 +0000111 Ptr.twine->printRepr(OS);
Daniel Dunbar2538f7a2009-07-24 07:04:27 +0000112 break;
Daniel Dunbar763457e2009-07-29 07:08:44 +0000113 case Twine::CStringKind:
114 OS << "cstring:\""
Chris Lattner3f25ee02011-07-24 20:44:30 +0000115 << Ptr.cString << "\"";
Daniel Dunbar763457e2009-07-29 07:08:44 +0000116 break;
117 case Twine::StdStringKind:
118 OS << "std::string:\""
Chris Lattner3f25ee02011-07-24 20:44:30 +0000119 << Ptr.stdString << "\"";
Daniel Dunbar763457e2009-07-29 07:08:44 +0000120 break;
121 case Twine::StringRefKind:
122 OS << "stringref:\""
Chris Lattner3f25ee02011-07-24 20:44:30 +0000123 << Ptr.stringRef << "\"";
124 break;
125 case Twine::CharKind:
126 OS << "char:\"" << Ptr.character << "\"";
Daniel Dunbar763457e2009-07-29 07:08:44 +0000127 break;
Daniel Dunbar2d8bc0f2009-07-30 21:15:14 +0000128 case Twine::DecUIKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +0000129 OS << "decUI:\"" << Ptr.decUI << "\"";
Daniel Dunbar763457e2009-07-29 07:08:44 +0000130 break;
Daniel Dunbar2d8bc0f2009-07-30 21:15:14 +0000131 case Twine::DecIKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +0000132 OS << "decI:\"" << Ptr.decI << "\"";
Daniel Dunbar0165a2c2009-07-30 03:47:15 +0000133 break;
Daniel Dunbar2d8bc0f2009-07-30 21:15:14 +0000134 case Twine::DecULKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +0000135 OS << "decUL:\"" << *Ptr.decUL << "\"";
Daniel Dunbar0165a2c2009-07-30 03:47:15 +0000136 break;
Daniel Dunbar2d8bc0f2009-07-30 21:15:14 +0000137 case Twine::DecLKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +0000138 OS << "decL:\"" << *Ptr.decL << "\"";
Daniel Dunbar2d8bc0f2009-07-30 21:15:14 +0000139 break;
140 case Twine::DecULLKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +0000141 OS << "decULL:\"" << *Ptr.decULL << "\"";
Daniel Dunbar2d8bc0f2009-07-30 21:15:14 +0000142 break;
143 case Twine::DecLLKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +0000144 OS << "decLL:\"" << *Ptr.decLL << "\"";
Daniel Dunbar763457e2009-07-29 07:08:44 +0000145 break;
146 case Twine::UHexKind:
Chris Lattner3f25ee02011-07-24 20:44:30 +0000147 OS << "uhex:\"" << Ptr.uHex << "\"";
Daniel Dunbar763457e2009-07-29 07:08:44 +0000148 break;
Daniel Dunbar2538f7a2009-07-24 07:04:27 +0000149 }
150}
151
152void Twine::print(raw_ostream &OS) const {
153 printOneChild(OS, LHS, getLHSKind());
154 printOneChild(OS, RHS, getRHSKind());
155}
156
157void Twine::printRepr(raw_ostream &OS) const {
158 OS << "(Twine ";
159 printOneChildRepr(OS, LHS, getLHSKind());
160 OS << " ";
161 printOneChildRepr(OS, RHS, getRHSKind());
162 OS << ")";
163}
164
165void Twine::dump() const {
David Greene2b965b02010-01-05 01:28:40 +0000166 print(llvm::dbgs());
Daniel Dunbar2538f7a2009-07-24 07:04:27 +0000167}
168
169void Twine::dumpRepr() const {
David Greene2b965b02010-01-05 01:28:40 +0000170 printRepr(llvm::dbgs());
Daniel Dunbar2538f7a2009-07-24 07:04:27 +0000171}