blob: 4726c8ab74940ca5b6d6317debabf2e6992f56ff [file] [log] [blame]
Daniel Dunbarafcf5b32009-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 Dunbarea579e32009-08-19 18:09:47 +000011#include "llvm/ADT/SmallString.h"
Nico Weber432a3882018-04-30 14:59:11 +000012#include "llvm/Config/llvm-config.h"
David Greenef92e6712010-01-05 01:28:40 +000013#include "llvm/Support/Debug.h"
Zachary Turnerde4be352016-12-17 00:38:15 +000014#include "llvm/Support/FormatVariadic.h"
Daniel Dunbarafcf5b32009-07-24 07:04:27 +000015#include "llvm/Support/raw_ostream.h"
16using namespace llvm;
17
18std::string Twine::str() const {
Frits van Bommelf8bf4c22011-07-15 11:05:37 +000019 // If we're storing only a std::string, just return it.
20 if (LHSKind == StdStringKind && RHSKind == EmptyKind)
Chris Lattner9650f062011-07-24 20:44:30 +000021 return *LHS.stdString;
Frits van Bommelf8bf4c22011-07-15 11:05:37 +000022
Zachary Turnerde4be352016-12-17 00:38:15 +000023 // If we're storing a formatv_object, we can avoid an extra copy by formatting
24 // it immediately and returning the result.
25 if (LHSKind == FormatvObjectKind && RHSKind == EmptyKind)
26 return LHS.formatvObject->str();
27
Frits van Bommelf8bf4c22011-07-15 11:05:37 +000028 // Otherwise, flatten and copy the contents first.
Daniel Dunbarea579e32009-08-19 18:09:47 +000029 SmallString<256> Vec;
Benjamin Kramer2e06b932010-01-13 12:45:23 +000030 return toStringRef(Vec).str();
Daniel Dunbarafcf5b32009-07-24 07:04:27 +000031}
32
33void Twine::toVector(SmallVectorImpl<char> &Out) const {
34 raw_svector_ostream OS(Out);
35 print(OS);
36}
37
Michael J. Spencerf2cc8282010-12-01 20:37:30 +000038StringRef Twine::toNullTerminatedStringRef(SmallVectorImpl<char> &Out) const {
Michael J. Spencer73e60d02010-12-03 05:42:25 +000039 if (isUnary()) {
40 switch (getLHSKind()) {
41 case CStringKind:
42 // Already null terminated, yay!
Chris Lattner9650f062011-07-24 20:44:30 +000043 return StringRef(LHS.cString);
Michael J. Spencer73e60d02010-12-03 05:42:25 +000044 case StdStringKind: {
Chris Lattner9650f062011-07-24 20:44:30 +000045 const std::string *str = LHS.stdString;
Frits van Bommelf8bf4c22011-07-15 11:05:37 +000046 return StringRef(str->c_str(), str->size());
47 }
Michael J. Spencer73e60d02010-12-03 05:42:25 +000048 default:
49 break;
50 }
Michael J. Spencerf2cc8282010-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 Lattner9650f062011-07-24 20:44:30 +000058void Twine::printOneChild(raw_ostream &OS, Child Ptr,
Daniel Dunbarafcf5b32009-07-24 07:04:27 +000059 NodeKind Kind) const {
60 switch (Kind) {
61 case Twine::NullKind: break;
62 case Twine::EmptyKind: break;
Daniel Dunbarb49994a2009-07-29 07:08:44 +000063 case Twine::TwineKind:
Chris Lattner9650f062011-07-24 20:44:30 +000064 Ptr.twine->print(OS);
Daniel Dunbarb49994a2009-07-29 07:08:44 +000065 break;
Michael J. Spencerf13f4422010-11-26 04:16:08 +000066 case Twine::CStringKind:
Chris Lattner9650f062011-07-24 20:44:30 +000067 OS << Ptr.cString;
Daniel Dunbarafcf5b32009-07-24 07:04:27 +000068 break;
69 case Twine::StdStringKind:
Chris Lattner9650f062011-07-24 20:44:30 +000070 OS << *Ptr.stdString;
Daniel Dunbarafcf5b32009-07-24 07:04:27 +000071 break;
72 case Twine::StringRefKind:
Chris Lattner9650f062011-07-24 20:44:30 +000073 OS << *Ptr.stringRef;
74 break;
Yaron Keren1ee89fc2015-03-17 09:51:17 +000075 case Twine::SmallStringKind:
76 OS << *Ptr.smallString;
77 break;
Zachary Turnerde4be352016-12-17 00:38:15 +000078 case Twine::FormatvObjectKind:
79 OS << *Ptr.formatvObject;
80 break;
Chris Lattner9650f062011-07-24 20:44:30 +000081 case Twine::CharKind:
82 OS << Ptr.character;
Daniel Dunbarafcf5b32009-07-24 07:04:27 +000083 break;
Daniel Dunbara91dd9b2009-07-30 21:15:14 +000084 case Twine::DecUIKind:
Chris Lattner9650f062011-07-24 20:44:30 +000085 OS << Ptr.decUI;
Daniel Dunbare8b32362009-07-30 03:47:15 +000086 break;
Daniel Dunbara91dd9b2009-07-30 21:15:14 +000087 case Twine::DecIKind:
Chris Lattner9650f062011-07-24 20:44:30 +000088 OS << Ptr.decI;
Daniel Dunbare8b32362009-07-30 03:47:15 +000089 break;
Daniel Dunbara91dd9b2009-07-30 21:15:14 +000090 case Twine::DecULKind:
Chris Lattner9650f062011-07-24 20:44:30 +000091 OS << *Ptr.decUL;
Daniel Dunbarb49994a2009-07-29 07:08:44 +000092 break;
Daniel Dunbara91dd9b2009-07-30 21:15:14 +000093 case Twine::DecLKind:
Chris Lattner9650f062011-07-24 20:44:30 +000094 OS << *Ptr.decL;
Daniel Dunbara91dd9b2009-07-30 21:15:14 +000095 break;
96 case Twine::DecULLKind:
Chris Lattner9650f062011-07-24 20:44:30 +000097 OS << *Ptr.decULL;
Daniel Dunbara91dd9b2009-07-30 21:15:14 +000098 break;
99 case Twine::DecLLKind:
Chris Lattner9650f062011-07-24 20:44:30 +0000100 OS << *Ptr.decLL;
Daniel Dunbarb49994a2009-07-29 07:08:44 +0000101 break;
102 case Twine::UHexKind:
Chris Lattner9650f062011-07-24 20:44:30 +0000103 OS.write_hex(*Ptr.uHex);
Daniel Dunbarafcf5b32009-07-24 07:04:27 +0000104 break;
105 }
106}
107
Chris Lattner9650f062011-07-24 20:44:30 +0000108void Twine::printOneChildRepr(raw_ostream &OS, Child Ptr,
Daniel Dunbarafcf5b32009-07-24 07:04:27 +0000109 NodeKind Kind) const {
110 switch (Kind) {
111 case Twine::NullKind:
112 OS << "null"; break;
113 case Twine::EmptyKind:
114 OS << "empty"; break;
Daniel Dunbarafcf5b32009-07-24 07:04:27 +0000115 case Twine::TwineKind:
116 OS << "rope:";
Chris Lattner9650f062011-07-24 20:44:30 +0000117 Ptr.twine->printRepr(OS);
Daniel Dunbarafcf5b32009-07-24 07:04:27 +0000118 break;
Daniel Dunbarb49994a2009-07-29 07:08:44 +0000119 case Twine::CStringKind:
120 OS << "cstring:\""
Chris Lattner9650f062011-07-24 20:44:30 +0000121 << Ptr.cString << "\"";
Daniel Dunbarb49994a2009-07-29 07:08:44 +0000122 break;
123 case Twine::StdStringKind:
Zachary Turner41a9ee92017-10-11 23:54:34 +0000124 OS << "std::string:\""
125 << Ptr.stdString << "\"";
Daniel Dunbarb49994a2009-07-29 07:08:44 +0000126 break;
127 case Twine::StringRefKind:
Zachary Turner41a9ee92017-10-11 23:54:34 +0000128 OS << "stringref:\""
129 << Ptr.stringRef << "\"";
Chris Lattner9650f062011-07-24 20:44:30 +0000130 break;
NAKAMURA Takumifb3bd712015-05-25 01:43:23 +0000131 case Twine::SmallStringKind:
NAKAMURA Takumi5582a6a2015-05-25 01:43:34 +0000132 OS << "smallstring:\"" << *Ptr.smallString << "\"";
NAKAMURA Takumifb3bd712015-05-25 01:43:23 +0000133 break;
Zachary Turnerde4be352016-12-17 00:38:15 +0000134 case Twine::FormatvObjectKind:
135 OS << "formatv:\"" << *Ptr.formatvObject << "\"";
136 break;
Chris Lattner9650f062011-07-24 20:44:30 +0000137 case Twine::CharKind:
138 OS << "char:\"" << Ptr.character << "\"";
Daniel Dunbarb49994a2009-07-29 07:08:44 +0000139 break;
Daniel Dunbara91dd9b2009-07-30 21:15:14 +0000140 case Twine::DecUIKind:
Chris Lattner9650f062011-07-24 20:44:30 +0000141 OS << "decUI:\"" << Ptr.decUI << "\"";
Daniel Dunbarb49994a2009-07-29 07:08:44 +0000142 break;
Daniel Dunbara91dd9b2009-07-30 21:15:14 +0000143 case Twine::DecIKind:
Chris Lattner9650f062011-07-24 20:44:30 +0000144 OS << "decI:\"" << Ptr.decI << "\"";
Daniel Dunbare8b32362009-07-30 03:47:15 +0000145 break;
Daniel Dunbara91dd9b2009-07-30 21:15:14 +0000146 case Twine::DecULKind:
Chris Lattner9650f062011-07-24 20:44:30 +0000147 OS << "decUL:\"" << *Ptr.decUL << "\"";
Daniel Dunbare8b32362009-07-30 03:47:15 +0000148 break;
Daniel Dunbara91dd9b2009-07-30 21:15:14 +0000149 case Twine::DecLKind:
Chris Lattner9650f062011-07-24 20:44:30 +0000150 OS << "decL:\"" << *Ptr.decL << "\"";
Daniel Dunbara91dd9b2009-07-30 21:15:14 +0000151 break;
152 case Twine::DecULLKind:
Chris Lattner9650f062011-07-24 20:44:30 +0000153 OS << "decULL:\"" << *Ptr.decULL << "\"";
Daniel Dunbara91dd9b2009-07-30 21:15:14 +0000154 break;
155 case Twine::DecLLKind:
Chris Lattner9650f062011-07-24 20:44:30 +0000156 OS << "decLL:\"" << *Ptr.decLL << "\"";
Daniel Dunbarb49994a2009-07-29 07:08:44 +0000157 break;
158 case Twine::UHexKind:
Chris Lattner9650f062011-07-24 20:44:30 +0000159 OS << "uhex:\"" << Ptr.uHex << "\"";
Daniel Dunbarb49994a2009-07-29 07:08:44 +0000160 break;
Daniel Dunbarafcf5b32009-07-24 07:04:27 +0000161 }
162}
163
164void Twine::print(raw_ostream &OS) const {
165 printOneChild(OS, LHS, getLHSKind());
166 printOneChild(OS, RHS, getRHSKind());
167}
168
169void Twine::printRepr(raw_ostream &OS) const {
170 OS << "(Twine ";
171 printOneChildRepr(OS, LHS, getLHSKind());
172 OS << " ";
173 printOneChildRepr(OS, RHS, getRHSKind());
174 OS << ")";
175}
176
Aaron Ballman615eb472017-10-15 14:32:27 +0000177#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
Yaron Kereneb2a2542016-01-29 20:50:44 +0000178LLVM_DUMP_METHOD void Twine::dump() const {
Eric Christophera13839f2014-02-26 23:27:16 +0000179 print(dbgs());
Daniel Dunbarafcf5b32009-07-24 07:04:27 +0000180}
181
Matthias Braun8c209aa2017-01-28 02:02:38 +0000182LLVM_DUMP_METHOD void Twine::dumpRepr() const {
Eric Christophera13839f2014-02-26 23:27:16 +0000183 printRepr(dbgs());
Daniel Dunbarafcf5b32009-07-24 07:04:27 +0000184}
Matthias Braun8c209aa2017-01-28 02:02:38 +0000185#endif