1*9880d681SAndroid Build Coastguard Worker //===--- raw_ostream.cpp - Implement the raw_ostream classes --------------===//
2*9880d681SAndroid Build Coastguard Worker //
3*9880d681SAndroid Build Coastguard Worker // The LLVM Compiler Infrastructure
4*9880d681SAndroid Build Coastguard Worker //
5*9880d681SAndroid Build Coastguard Worker // This file is distributed under the University of Illinois Open Source
6*9880d681SAndroid Build Coastguard Worker // License. See LICENSE.TXT for details.
7*9880d681SAndroid Build Coastguard Worker //
8*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
9*9880d681SAndroid Build Coastguard Worker //
10*9880d681SAndroid Build Coastguard Worker // This implements support for bulk buffered stream output.
11*9880d681SAndroid Build Coastguard Worker //
12*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
13*9880d681SAndroid Build Coastguard Worker
14*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/raw_ostream.h"
15*9880d681SAndroid Build Coastguard Worker #include "llvm/ADT/STLExtras.h"
16*9880d681SAndroid Build Coastguard Worker #include "llvm/ADT/SmallVector.h"
17*9880d681SAndroid Build Coastguard Worker #include "llvm/ADT/StringExtras.h"
18*9880d681SAndroid Build Coastguard Worker #include "llvm/Config/config.h"
19*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/Compiler.h"
20*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/ErrorHandling.h"
21*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/FileSystem.h"
22*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/Format.h"
23*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/MathExtras.h"
24*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/Process.h"
25*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/Program.h"
26*9880d681SAndroid Build Coastguard Worker #include <cctype>
27*9880d681SAndroid Build Coastguard Worker #include <cerrno>
28*9880d681SAndroid Build Coastguard Worker #include <sys/stat.h>
29*9880d681SAndroid Build Coastguard Worker #include <system_error>
30*9880d681SAndroid Build Coastguard Worker
31*9880d681SAndroid Build Coastguard Worker // <fcntl.h> may provide O_BINARY.
32*9880d681SAndroid Build Coastguard Worker #if defined(HAVE_FCNTL_H)
33*9880d681SAndroid Build Coastguard Worker # include <fcntl.h>
34*9880d681SAndroid Build Coastguard Worker #endif
35*9880d681SAndroid Build Coastguard Worker
36*9880d681SAndroid Build Coastguard Worker #if defined(HAVE_UNISTD_H)
37*9880d681SAndroid Build Coastguard Worker # include <unistd.h>
38*9880d681SAndroid Build Coastguard Worker #endif
39*9880d681SAndroid Build Coastguard Worker #if defined(HAVE_SYS_UIO_H) && defined(HAVE_WRITEV)
40*9880d681SAndroid Build Coastguard Worker # include <sys/uio.h>
41*9880d681SAndroid Build Coastguard Worker #endif
42*9880d681SAndroid Build Coastguard Worker
43*9880d681SAndroid Build Coastguard Worker #if defined(__CYGWIN__)
44*9880d681SAndroid Build Coastguard Worker #include <io.h>
45*9880d681SAndroid Build Coastguard Worker #endif
46*9880d681SAndroid Build Coastguard Worker
47*9880d681SAndroid Build Coastguard Worker #if defined(_MSC_VER)
48*9880d681SAndroid Build Coastguard Worker #include <io.h>
49*9880d681SAndroid Build Coastguard Worker #ifndef STDIN_FILENO
50*9880d681SAndroid Build Coastguard Worker # define STDIN_FILENO 0
51*9880d681SAndroid Build Coastguard Worker #endif
52*9880d681SAndroid Build Coastguard Worker #ifndef STDOUT_FILENO
53*9880d681SAndroid Build Coastguard Worker # define STDOUT_FILENO 1
54*9880d681SAndroid Build Coastguard Worker #endif
55*9880d681SAndroid Build Coastguard Worker #ifndef STDERR_FILENO
56*9880d681SAndroid Build Coastguard Worker # define STDERR_FILENO 2
57*9880d681SAndroid Build Coastguard Worker #endif
58*9880d681SAndroid Build Coastguard Worker #endif
59*9880d681SAndroid Build Coastguard Worker
60*9880d681SAndroid Build Coastguard Worker #ifdef LLVM_ON_WIN32
61*9880d681SAndroid Build Coastguard Worker #include "Windows/WindowsSupport.h"
62*9880d681SAndroid Build Coastguard Worker #endif
63*9880d681SAndroid Build Coastguard Worker
64*9880d681SAndroid Build Coastguard Worker using namespace llvm;
65*9880d681SAndroid Build Coastguard Worker
~raw_ostream()66*9880d681SAndroid Build Coastguard Worker raw_ostream::~raw_ostream() {
67*9880d681SAndroid Build Coastguard Worker // raw_ostream's subclasses should take care to flush the buffer
68*9880d681SAndroid Build Coastguard Worker // in their destructors.
69*9880d681SAndroid Build Coastguard Worker assert(OutBufCur == OutBufStart &&
70*9880d681SAndroid Build Coastguard Worker "raw_ostream destructor called with non-empty buffer!");
71*9880d681SAndroid Build Coastguard Worker
72*9880d681SAndroid Build Coastguard Worker if (BufferMode == InternalBuffer)
73*9880d681SAndroid Build Coastguard Worker delete [] OutBufStart;
74*9880d681SAndroid Build Coastguard Worker }
75*9880d681SAndroid Build Coastguard Worker
76*9880d681SAndroid Build Coastguard Worker // An out of line virtual method to provide a home for the class vtable.
handle()77*9880d681SAndroid Build Coastguard Worker void raw_ostream::handle() {}
78*9880d681SAndroid Build Coastguard Worker
preferred_buffer_size() const79*9880d681SAndroid Build Coastguard Worker size_t raw_ostream::preferred_buffer_size() const {
80*9880d681SAndroid Build Coastguard Worker // BUFSIZ is intended to be a reasonable default.
81*9880d681SAndroid Build Coastguard Worker return BUFSIZ;
82*9880d681SAndroid Build Coastguard Worker }
83*9880d681SAndroid Build Coastguard Worker
SetBuffered()84*9880d681SAndroid Build Coastguard Worker void raw_ostream::SetBuffered() {
85*9880d681SAndroid Build Coastguard Worker // Ask the subclass to determine an appropriate buffer size.
86*9880d681SAndroid Build Coastguard Worker if (size_t Size = preferred_buffer_size())
87*9880d681SAndroid Build Coastguard Worker SetBufferSize(Size);
88*9880d681SAndroid Build Coastguard Worker else
89*9880d681SAndroid Build Coastguard Worker // It may return 0, meaning this stream should be unbuffered.
90*9880d681SAndroid Build Coastguard Worker SetUnbuffered();
91*9880d681SAndroid Build Coastguard Worker }
92*9880d681SAndroid Build Coastguard Worker
SetBufferAndMode(char * BufferStart,size_t Size,BufferKind Mode)93*9880d681SAndroid Build Coastguard Worker void raw_ostream::SetBufferAndMode(char *BufferStart, size_t Size,
94*9880d681SAndroid Build Coastguard Worker BufferKind Mode) {
95*9880d681SAndroid Build Coastguard Worker assert(((Mode == Unbuffered && !BufferStart && Size == 0) ||
96*9880d681SAndroid Build Coastguard Worker (Mode != Unbuffered && BufferStart && Size != 0)) &&
97*9880d681SAndroid Build Coastguard Worker "stream must be unbuffered or have at least one byte");
98*9880d681SAndroid Build Coastguard Worker // Make sure the current buffer is free of content (we can't flush here; the
99*9880d681SAndroid Build Coastguard Worker // child buffer management logic will be in write_impl).
100*9880d681SAndroid Build Coastguard Worker assert(GetNumBytesInBuffer() == 0 && "Current buffer is non-empty!");
101*9880d681SAndroid Build Coastguard Worker
102*9880d681SAndroid Build Coastguard Worker if (BufferMode == InternalBuffer)
103*9880d681SAndroid Build Coastguard Worker delete [] OutBufStart;
104*9880d681SAndroid Build Coastguard Worker OutBufStart = BufferStart;
105*9880d681SAndroid Build Coastguard Worker OutBufEnd = OutBufStart+Size;
106*9880d681SAndroid Build Coastguard Worker OutBufCur = OutBufStart;
107*9880d681SAndroid Build Coastguard Worker BufferMode = Mode;
108*9880d681SAndroid Build Coastguard Worker
109*9880d681SAndroid Build Coastguard Worker assert(OutBufStart <= OutBufEnd && "Invalid size!");
110*9880d681SAndroid Build Coastguard Worker }
111*9880d681SAndroid Build Coastguard Worker
operator <<(unsigned long N)112*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_ostream::operator<<(unsigned long N) {
113*9880d681SAndroid Build Coastguard Worker // Zero is a special case.
114*9880d681SAndroid Build Coastguard Worker if (N == 0)
115*9880d681SAndroid Build Coastguard Worker return *this << '0';
116*9880d681SAndroid Build Coastguard Worker
117*9880d681SAndroid Build Coastguard Worker char NumberBuffer[20];
118*9880d681SAndroid Build Coastguard Worker char *EndPtr = NumberBuffer+sizeof(NumberBuffer);
119*9880d681SAndroid Build Coastguard Worker char *CurPtr = EndPtr;
120*9880d681SAndroid Build Coastguard Worker
121*9880d681SAndroid Build Coastguard Worker while (N) {
122*9880d681SAndroid Build Coastguard Worker *--CurPtr = '0' + char(N % 10);
123*9880d681SAndroid Build Coastguard Worker N /= 10;
124*9880d681SAndroid Build Coastguard Worker }
125*9880d681SAndroid Build Coastguard Worker return write(CurPtr, EndPtr-CurPtr);
126*9880d681SAndroid Build Coastguard Worker }
127*9880d681SAndroid Build Coastguard Worker
operator <<(long N)128*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_ostream::operator<<(long N) {
129*9880d681SAndroid Build Coastguard Worker if (N < 0) {
130*9880d681SAndroid Build Coastguard Worker *this << '-';
131*9880d681SAndroid Build Coastguard Worker // Avoid undefined behavior on LONG_MIN with a cast.
132*9880d681SAndroid Build Coastguard Worker N = -(unsigned long)N;
133*9880d681SAndroid Build Coastguard Worker }
134*9880d681SAndroid Build Coastguard Worker
135*9880d681SAndroid Build Coastguard Worker return this->operator<<(static_cast<unsigned long>(N));
136*9880d681SAndroid Build Coastguard Worker }
137*9880d681SAndroid Build Coastguard Worker
operator <<(unsigned long long N)138*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_ostream::operator<<(unsigned long long N) {
139*9880d681SAndroid Build Coastguard Worker // Output using 32-bit div/mod when possible.
140*9880d681SAndroid Build Coastguard Worker if (N == static_cast<unsigned long>(N))
141*9880d681SAndroid Build Coastguard Worker return this->operator<<(static_cast<unsigned long>(N));
142*9880d681SAndroid Build Coastguard Worker
143*9880d681SAndroid Build Coastguard Worker char NumberBuffer[20];
144*9880d681SAndroid Build Coastguard Worker char *EndPtr = std::end(NumberBuffer);
145*9880d681SAndroid Build Coastguard Worker char *CurPtr = EndPtr;
146*9880d681SAndroid Build Coastguard Worker
147*9880d681SAndroid Build Coastguard Worker while (N) {
148*9880d681SAndroid Build Coastguard Worker *--CurPtr = '0' + char(N % 10);
149*9880d681SAndroid Build Coastguard Worker N /= 10;
150*9880d681SAndroid Build Coastguard Worker }
151*9880d681SAndroid Build Coastguard Worker return write(CurPtr, EndPtr-CurPtr);
152*9880d681SAndroid Build Coastguard Worker }
153*9880d681SAndroid Build Coastguard Worker
operator <<(long long N)154*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_ostream::operator<<(long long N) {
155*9880d681SAndroid Build Coastguard Worker if (N < 0) {
156*9880d681SAndroid Build Coastguard Worker *this << '-';
157*9880d681SAndroid Build Coastguard Worker // Avoid undefined behavior on INT64_MIN with a cast.
158*9880d681SAndroid Build Coastguard Worker N = -(unsigned long long)N;
159*9880d681SAndroid Build Coastguard Worker }
160*9880d681SAndroid Build Coastguard Worker
161*9880d681SAndroid Build Coastguard Worker return this->operator<<(static_cast<unsigned long long>(N));
162*9880d681SAndroid Build Coastguard Worker }
163*9880d681SAndroid Build Coastguard Worker
write_hex(unsigned long long N)164*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_ostream::write_hex(unsigned long long N) {
165*9880d681SAndroid Build Coastguard Worker // Zero is a special case.
166*9880d681SAndroid Build Coastguard Worker if (N == 0)
167*9880d681SAndroid Build Coastguard Worker return *this << '0';
168*9880d681SAndroid Build Coastguard Worker
169*9880d681SAndroid Build Coastguard Worker char NumberBuffer[16];
170*9880d681SAndroid Build Coastguard Worker char *EndPtr = std::end(NumberBuffer);
171*9880d681SAndroid Build Coastguard Worker char *CurPtr = EndPtr;
172*9880d681SAndroid Build Coastguard Worker
173*9880d681SAndroid Build Coastguard Worker while (N) {
174*9880d681SAndroid Build Coastguard Worker unsigned char x = static_cast<unsigned char>(N) % 16;
175*9880d681SAndroid Build Coastguard Worker *--CurPtr = hexdigit(x, /*LowerCase*/true);
176*9880d681SAndroid Build Coastguard Worker N /= 16;
177*9880d681SAndroid Build Coastguard Worker }
178*9880d681SAndroid Build Coastguard Worker
179*9880d681SAndroid Build Coastguard Worker return write(CurPtr, EndPtr-CurPtr);
180*9880d681SAndroid Build Coastguard Worker }
181*9880d681SAndroid Build Coastguard Worker
write_escaped(StringRef Str,bool UseHexEscapes)182*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_ostream::write_escaped(StringRef Str,
183*9880d681SAndroid Build Coastguard Worker bool UseHexEscapes) {
184*9880d681SAndroid Build Coastguard Worker for (unsigned char c : Str) {
185*9880d681SAndroid Build Coastguard Worker switch (c) {
186*9880d681SAndroid Build Coastguard Worker case '\\':
187*9880d681SAndroid Build Coastguard Worker *this << '\\' << '\\';
188*9880d681SAndroid Build Coastguard Worker break;
189*9880d681SAndroid Build Coastguard Worker case '\t':
190*9880d681SAndroid Build Coastguard Worker *this << '\\' << 't';
191*9880d681SAndroid Build Coastguard Worker break;
192*9880d681SAndroid Build Coastguard Worker case '\n':
193*9880d681SAndroid Build Coastguard Worker *this << '\\' << 'n';
194*9880d681SAndroid Build Coastguard Worker break;
195*9880d681SAndroid Build Coastguard Worker case '"':
196*9880d681SAndroid Build Coastguard Worker *this << '\\' << '"';
197*9880d681SAndroid Build Coastguard Worker break;
198*9880d681SAndroid Build Coastguard Worker default:
199*9880d681SAndroid Build Coastguard Worker if (std::isprint(c)) {
200*9880d681SAndroid Build Coastguard Worker *this << c;
201*9880d681SAndroid Build Coastguard Worker break;
202*9880d681SAndroid Build Coastguard Worker }
203*9880d681SAndroid Build Coastguard Worker
204*9880d681SAndroid Build Coastguard Worker // Write out the escaped representation.
205*9880d681SAndroid Build Coastguard Worker if (UseHexEscapes) {
206*9880d681SAndroid Build Coastguard Worker *this << '\\' << 'x';
207*9880d681SAndroid Build Coastguard Worker *this << hexdigit((c >> 4 & 0xF));
208*9880d681SAndroid Build Coastguard Worker *this << hexdigit((c >> 0) & 0xF);
209*9880d681SAndroid Build Coastguard Worker } else {
210*9880d681SAndroid Build Coastguard Worker // Always use a full 3-character octal escape.
211*9880d681SAndroid Build Coastguard Worker *this << '\\';
212*9880d681SAndroid Build Coastguard Worker *this << char('0' + ((c >> 6) & 7));
213*9880d681SAndroid Build Coastguard Worker *this << char('0' + ((c >> 3) & 7));
214*9880d681SAndroid Build Coastguard Worker *this << char('0' + ((c >> 0) & 7));
215*9880d681SAndroid Build Coastguard Worker }
216*9880d681SAndroid Build Coastguard Worker }
217*9880d681SAndroid Build Coastguard Worker }
218*9880d681SAndroid Build Coastguard Worker
219*9880d681SAndroid Build Coastguard Worker return *this;
220*9880d681SAndroid Build Coastguard Worker }
221*9880d681SAndroid Build Coastguard Worker
operator <<(const void * P)222*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_ostream::operator<<(const void *P) {
223*9880d681SAndroid Build Coastguard Worker *this << '0' << 'x';
224*9880d681SAndroid Build Coastguard Worker
225*9880d681SAndroid Build Coastguard Worker return write_hex((uintptr_t) P);
226*9880d681SAndroid Build Coastguard Worker }
227*9880d681SAndroid Build Coastguard Worker
operator <<(double N)228*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_ostream::operator<<(double N) {
229*9880d681SAndroid Build Coastguard Worker #ifdef _WIN32
230*9880d681SAndroid Build Coastguard Worker // On MSVCRT and compatible, output of %e is incompatible to Posix
231*9880d681SAndroid Build Coastguard Worker // by default. Number of exponent digits should be at least 2. "%+03d"
232*9880d681SAndroid Build Coastguard Worker // FIXME: Implement our formatter to here or Support/Format.h!
233*9880d681SAndroid Build Coastguard Worker #if defined(__MINGW32__)
234*9880d681SAndroid Build Coastguard Worker // FIXME: It should be generic to C++11.
235*9880d681SAndroid Build Coastguard Worker if (N == 0.0 && std::signbit(N))
236*9880d681SAndroid Build Coastguard Worker return *this << "-0.000000e+00";
237*9880d681SAndroid Build Coastguard Worker #else
238*9880d681SAndroid Build Coastguard Worker int fpcl = _fpclass(N);
239*9880d681SAndroid Build Coastguard Worker
240*9880d681SAndroid Build Coastguard Worker // negative zero
241*9880d681SAndroid Build Coastguard Worker if (fpcl == _FPCLASS_NZ)
242*9880d681SAndroid Build Coastguard Worker return *this << "-0.000000e+00";
243*9880d681SAndroid Build Coastguard Worker #endif
244*9880d681SAndroid Build Coastguard Worker
245*9880d681SAndroid Build Coastguard Worker char buf[16];
246*9880d681SAndroid Build Coastguard Worker unsigned len;
247*9880d681SAndroid Build Coastguard Worker len = format("%e", N).snprint(buf, sizeof(buf));
248*9880d681SAndroid Build Coastguard Worker if (len <= sizeof(buf) - 2) {
249*9880d681SAndroid Build Coastguard Worker if (len >= 5 && buf[len - 5] == 'e' && buf[len - 3] == '0') {
250*9880d681SAndroid Build Coastguard Worker int cs = buf[len - 4];
251*9880d681SAndroid Build Coastguard Worker if (cs == '+' || cs == '-') {
252*9880d681SAndroid Build Coastguard Worker int c1 = buf[len - 2];
253*9880d681SAndroid Build Coastguard Worker int c0 = buf[len - 1];
254*9880d681SAndroid Build Coastguard Worker if (isdigit(static_cast<unsigned char>(c1)) &&
255*9880d681SAndroid Build Coastguard Worker isdigit(static_cast<unsigned char>(c0))) {
256*9880d681SAndroid Build Coastguard Worker // Trim leading '0': "...e+012" -> "...e+12\0"
257*9880d681SAndroid Build Coastguard Worker buf[len - 3] = c1;
258*9880d681SAndroid Build Coastguard Worker buf[len - 2] = c0;
259*9880d681SAndroid Build Coastguard Worker buf[--len] = 0;
260*9880d681SAndroid Build Coastguard Worker }
261*9880d681SAndroid Build Coastguard Worker }
262*9880d681SAndroid Build Coastguard Worker }
263*9880d681SAndroid Build Coastguard Worker return this->operator<<(buf);
264*9880d681SAndroid Build Coastguard Worker }
265*9880d681SAndroid Build Coastguard Worker #endif
266*9880d681SAndroid Build Coastguard Worker return this->operator<<(format("%e", N));
267*9880d681SAndroid Build Coastguard Worker }
268*9880d681SAndroid Build Coastguard Worker
269*9880d681SAndroid Build Coastguard Worker
270*9880d681SAndroid Build Coastguard Worker
flush_nonempty()271*9880d681SAndroid Build Coastguard Worker void raw_ostream::flush_nonempty() {
272*9880d681SAndroid Build Coastguard Worker assert(OutBufCur > OutBufStart && "Invalid call to flush_nonempty.");
273*9880d681SAndroid Build Coastguard Worker size_t Length = OutBufCur - OutBufStart;
274*9880d681SAndroid Build Coastguard Worker OutBufCur = OutBufStart;
275*9880d681SAndroid Build Coastguard Worker write_impl(OutBufStart, Length);
276*9880d681SAndroid Build Coastguard Worker }
277*9880d681SAndroid Build Coastguard Worker
write(unsigned char C)278*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_ostream::write(unsigned char C) {
279*9880d681SAndroid Build Coastguard Worker // Group exceptional cases into a single branch.
280*9880d681SAndroid Build Coastguard Worker if (LLVM_UNLIKELY(OutBufCur >= OutBufEnd)) {
281*9880d681SAndroid Build Coastguard Worker if (LLVM_UNLIKELY(!OutBufStart)) {
282*9880d681SAndroid Build Coastguard Worker if (BufferMode == Unbuffered) {
283*9880d681SAndroid Build Coastguard Worker write_impl(reinterpret_cast<char*>(&C), 1);
284*9880d681SAndroid Build Coastguard Worker return *this;
285*9880d681SAndroid Build Coastguard Worker }
286*9880d681SAndroid Build Coastguard Worker // Set up a buffer and start over.
287*9880d681SAndroid Build Coastguard Worker SetBuffered();
288*9880d681SAndroid Build Coastguard Worker return write(C);
289*9880d681SAndroid Build Coastguard Worker }
290*9880d681SAndroid Build Coastguard Worker
291*9880d681SAndroid Build Coastguard Worker flush_nonempty();
292*9880d681SAndroid Build Coastguard Worker }
293*9880d681SAndroid Build Coastguard Worker
294*9880d681SAndroid Build Coastguard Worker *OutBufCur++ = C;
295*9880d681SAndroid Build Coastguard Worker return *this;
296*9880d681SAndroid Build Coastguard Worker }
297*9880d681SAndroid Build Coastguard Worker
write(const char * Ptr,size_t Size)298*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_ostream::write(const char *Ptr, size_t Size) {
299*9880d681SAndroid Build Coastguard Worker // Group exceptional cases into a single branch.
300*9880d681SAndroid Build Coastguard Worker if (LLVM_UNLIKELY(size_t(OutBufEnd - OutBufCur) < Size)) {
301*9880d681SAndroid Build Coastguard Worker if (LLVM_UNLIKELY(!OutBufStart)) {
302*9880d681SAndroid Build Coastguard Worker if (BufferMode == Unbuffered) {
303*9880d681SAndroid Build Coastguard Worker write_impl(Ptr, Size);
304*9880d681SAndroid Build Coastguard Worker return *this;
305*9880d681SAndroid Build Coastguard Worker }
306*9880d681SAndroid Build Coastguard Worker // Set up a buffer and start over.
307*9880d681SAndroid Build Coastguard Worker SetBuffered();
308*9880d681SAndroid Build Coastguard Worker return write(Ptr, Size);
309*9880d681SAndroid Build Coastguard Worker }
310*9880d681SAndroid Build Coastguard Worker
311*9880d681SAndroid Build Coastguard Worker size_t NumBytes = OutBufEnd - OutBufCur;
312*9880d681SAndroid Build Coastguard Worker
313*9880d681SAndroid Build Coastguard Worker // If the buffer is empty at this point we have a string that is larger
314*9880d681SAndroid Build Coastguard Worker // than the buffer. Directly write the chunk that is a multiple of the
315*9880d681SAndroid Build Coastguard Worker // preferred buffer size and put the remainder in the buffer.
316*9880d681SAndroid Build Coastguard Worker if (LLVM_UNLIKELY(OutBufCur == OutBufStart)) {
317*9880d681SAndroid Build Coastguard Worker assert(NumBytes != 0 && "undefined behavior");
318*9880d681SAndroid Build Coastguard Worker size_t BytesToWrite = Size - (Size % NumBytes);
319*9880d681SAndroid Build Coastguard Worker write_impl(Ptr, BytesToWrite);
320*9880d681SAndroid Build Coastguard Worker size_t BytesRemaining = Size - BytesToWrite;
321*9880d681SAndroid Build Coastguard Worker if (BytesRemaining > size_t(OutBufEnd - OutBufCur)) {
322*9880d681SAndroid Build Coastguard Worker // Too much left over to copy into our buffer.
323*9880d681SAndroid Build Coastguard Worker return write(Ptr + BytesToWrite, BytesRemaining);
324*9880d681SAndroid Build Coastguard Worker }
325*9880d681SAndroid Build Coastguard Worker copy_to_buffer(Ptr + BytesToWrite, BytesRemaining);
326*9880d681SAndroid Build Coastguard Worker return *this;
327*9880d681SAndroid Build Coastguard Worker }
328*9880d681SAndroid Build Coastguard Worker
329*9880d681SAndroid Build Coastguard Worker // We don't have enough space in the buffer to fit the string in. Insert as
330*9880d681SAndroid Build Coastguard Worker // much as possible, flush and start over with the remainder.
331*9880d681SAndroid Build Coastguard Worker copy_to_buffer(Ptr, NumBytes);
332*9880d681SAndroid Build Coastguard Worker flush_nonempty();
333*9880d681SAndroid Build Coastguard Worker return write(Ptr + NumBytes, Size - NumBytes);
334*9880d681SAndroid Build Coastguard Worker }
335*9880d681SAndroid Build Coastguard Worker
336*9880d681SAndroid Build Coastguard Worker copy_to_buffer(Ptr, Size);
337*9880d681SAndroid Build Coastguard Worker
338*9880d681SAndroid Build Coastguard Worker return *this;
339*9880d681SAndroid Build Coastguard Worker }
340*9880d681SAndroid Build Coastguard Worker
copy_to_buffer(const char * Ptr,size_t Size)341*9880d681SAndroid Build Coastguard Worker void raw_ostream::copy_to_buffer(const char *Ptr, size_t Size) {
342*9880d681SAndroid Build Coastguard Worker assert(Size <= size_t(OutBufEnd - OutBufCur) && "Buffer overrun!");
343*9880d681SAndroid Build Coastguard Worker
344*9880d681SAndroid Build Coastguard Worker // Handle short strings specially, memcpy isn't very good at very short
345*9880d681SAndroid Build Coastguard Worker // strings.
346*9880d681SAndroid Build Coastguard Worker switch (Size) {
347*9880d681SAndroid Build Coastguard Worker case 4: OutBufCur[3] = Ptr[3]; // FALL THROUGH
348*9880d681SAndroid Build Coastguard Worker case 3: OutBufCur[2] = Ptr[2]; // FALL THROUGH
349*9880d681SAndroid Build Coastguard Worker case 2: OutBufCur[1] = Ptr[1]; // FALL THROUGH
350*9880d681SAndroid Build Coastguard Worker case 1: OutBufCur[0] = Ptr[0]; // FALL THROUGH
351*9880d681SAndroid Build Coastguard Worker case 0: break;
352*9880d681SAndroid Build Coastguard Worker default:
353*9880d681SAndroid Build Coastguard Worker memcpy(OutBufCur, Ptr, Size);
354*9880d681SAndroid Build Coastguard Worker break;
355*9880d681SAndroid Build Coastguard Worker }
356*9880d681SAndroid Build Coastguard Worker
357*9880d681SAndroid Build Coastguard Worker OutBufCur += Size;
358*9880d681SAndroid Build Coastguard Worker }
359*9880d681SAndroid Build Coastguard Worker
360*9880d681SAndroid Build Coastguard Worker // Formatted output.
operator <<(const format_object_base & Fmt)361*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_ostream::operator<<(const format_object_base &Fmt) {
362*9880d681SAndroid Build Coastguard Worker // If we have more than a few bytes left in our output buffer, try
363*9880d681SAndroid Build Coastguard Worker // formatting directly onto its end.
364*9880d681SAndroid Build Coastguard Worker size_t NextBufferSize = 127;
365*9880d681SAndroid Build Coastguard Worker size_t BufferBytesLeft = OutBufEnd - OutBufCur;
366*9880d681SAndroid Build Coastguard Worker if (BufferBytesLeft > 3) {
367*9880d681SAndroid Build Coastguard Worker size_t BytesUsed = Fmt.print(OutBufCur, BufferBytesLeft);
368*9880d681SAndroid Build Coastguard Worker
369*9880d681SAndroid Build Coastguard Worker // Common case is that we have plenty of space.
370*9880d681SAndroid Build Coastguard Worker if (BytesUsed <= BufferBytesLeft) {
371*9880d681SAndroid Build Coastguard Worker OutBufCur += BytesUsed;
372*9880d681SAndroid Build Coastguard Worker return *this;
373*9880d681SAndroid Build Coastguard Worker }
374*9880d681SAndroid Build Coastguard Worker
375*9880d681SAndroid Build Coastguard Worker // Otherwise, we overflowed and the return value tells us the size to try
376*9880d681SAndroid Build Coastguard Worker // again with.
377*9880d681SAndroid Build Coastguard Worker NextBufferSize = BytesUsed;
378*9880d681SAndroid Build Coastguard Worker }
379*9880d681SAndroid Build Coastguard Worker
380*9880d681SAndroid Build Coastguard Worker // If we got here, we didn't have enough space in the output buffer for the
381*9880d681SAndroid Build Coastguard Worker // string. Try printing into a SmallVector that is resized to have enough
382*9880d681SAndroid Build Coastguard Worker // space. Iterate until we win.
383*9880d681SAndroid Build Coastguard Worker SmallVector<char, 128> V;
384*9880d681SAndroid Build Coastguard Worker
385*9880d681SAndroid Build Coastguard Worker while (1) {
386*9880d681SAndroid Build Coastguard Worker V.resize(NextBufferSize);
387*9880d681SAndroid Build Coastguard Worker
388*9880d681SAndroid Build Coastguard Worker // Try formatting into the SmallVector.
389*9880d681SAndroid Build Coastguard Worker size_t BytesUsed = Fmt.print(V.data(), NextBufferSize);
390*9880d681SAndroid Build Coastguard Worker
391*9880d681SAndroid Build Coastguard Worker // If BytesUsed fit into the vector, we win.
392*9880d681SAndroid Build Coastguard Worker if (BytesUsed <= NextBufferSize)
393*9880d681SAndroid Build Coastguard Worker return write(V.data(), BytesUsed);
394*9880d681SAndroid Build Coastguard Worker
395*9880d681SAndroid Build Coastguard Worker // Otherwise, try again with a new size.
396*9880d681SAndroid Build Coastguard Worker assert(BytesUsed > NextBufferSize && "Didn't grow buffer!?");
397*9880d681SAndroid Build Coastguard Worker NextBufferSize = BytesUsed;
398*9880d681SAndroid Build Coastguard Worker }
399*9880d681SAndroid Build Coastguard Worker }
400*9880d681SAndroid Build Coastguard Worker
operator <<(const FormattedString & FS)401*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_ostream::operator<<(const FormattedString &FS) {
402*9880d681SAndroid Build Coastguard Worker unsigned Len = FS.Str.size();
403*9880d681SAndroid Build Coastguard Worker int PadAmount = FS.Width - Len;
404*9880d681SAndroid Build Coastguard Worker if (FS.RightJustify && (PadAmount > 0))
405*9880d681SAndroid Build Coastguard Worker this->indent(PadAmount);
406*9880d681SAndroid Build Coastguard Worker this->operator<<(FS.Str);
407*9880d681SAndroid Build Coastguard Worker if (!FS.RightJustify && (PadAmount > 0))
408*9880d681SAndroid Build Coastguard Worker this->indent(PadAmount);
409*9880d681SAndroid Build Coastguard Worker return *this;
410*9880d681SAndroid Build Coastguard Worker }
411*9880d681SAndroid Build Coastguard Worker
operator <<(const FormattedNumber & FN)412*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_ostream::operator<<(const FormattedNumber &FN) {
413*9880d681SAndroid Build Coastguard Worker if (FN.Hex) {
414*9880d681SAndroid Build Coastguard Worker unsigned Nibbles = (64 - countLeadingZeros(FN.HexValue)+3)/4;
415*9880d681SAndroid Build Coastguard Worker unsigned PrefixChars = FN.HexPrefix ? 2 : 0;
416*9880d681SAndroid Build Coastguard Worker unsigned Width = std::max(FN.Width, Nibbles + PrefixChars);
417*9880d681SAndroid Build Coastguard Worker
418*9880d681SAndroid Build Coastguard Worker char NumberBuffer[20] = "0x0000000000000000";
419*9880d681SAndroid Build Coastguard Worker if (!FN.HexPrefix)
420*9880d681SAndroid Build Coastguard Worker NumberBuffer[1] = '0';
421*9880d681SAndroid Build Coastguard Worker char *EndPtr = NumberBuffer+Width;
422*9880d681SAndroid Build Coastguard Worker char *CurPtr = EndPtr;
423*9880d681SAndroid Build Coastguard Worker unsigned long long N = FN.HexValue;
424*9880d681SAndroid Build Coastguard Worker while (N) {
425*9880d681SAndroid Build Coastguard Worker unsigned char x = static_cast<unsigned char>(N) % 16;
426*9880d681SAndroid Build Coastguard Worker *--CurPtr = hexdigit(x, !FN.Upper);
427*9880d681SAndroid Build Coastguard Worker N /= 16;
428*9880d681SAndroid Build Coastguard Worker }
429*9880d681SAndroid Build Coastguard Worker
430*9880d681SAndroid Build Coastguard Worker return write(NumberBuffer, Width);
431*9880d681SAndroid Build Coastguard Worker } else {
432*9880d681SAndroid Build Coastguard Worker // Zero is a special case.
433*9880d681SAndroid Build Coastguard Worker if (FN.DecValue == 0) {
434*9880d681SAndroid Build Coastguard Worker this->indent(FN.Width-1);
435*9880d681SAndroid Build Coastguard Worker return *this << '0';
436*9880d681SAndroid Build Coastguard Worker }
437*9880d681SAndroid Build Coastguard Worker char NumberBuffer[32];
438*9880d681SAndroid Build Coastguard Worker char *EndPtr = NumberBuffer+sizeof(NumberBuffer);
439*9880d681SAndroid Build Coastguard Worker char *CurPtr = EndPtr;
440*9880d681SAndroid Build Coastguard Worker bool Neg = (FN.DecValue < 0);
441*9880d681SAndroid Build Coastguard Worker uint64_t N = Neg ? -static_cast<uint64_t>(FN.DecValue) : FN.DecValue;
442*9880d681SAndroid Build Coastguard Worker while (N) {
443*9880d681SAndroid Build Coastguard Worker *--CurPtr = '0' + char(N % 10);
444*9880d681SAndroid Build Coastguard Worker N /= 10;
445*9880d681SAndroid Build Coastguard Worker }
446*9880d681SAndroid Build Coastguard Worker int Len = EndPtr - CurPtr;
447*9880d681SAndroid Build Coastguard Worker int Pad = FN.Width - Len;
448*9880d681SAndroid Build Coastguard Worker if (Neg)
449*9880d681SAndroid Build Coastguard Worker --Pad;
450*9880d681SAndroid Build Coastguard Worker if (Pad > 0)
451*9880d681SAndroid Build Coastguard Worker this->indent(Pad);
452*9880d681SAndroid Build Coastguard Worker if (Neg)
453*9880d681SAndroid Build Coastguard Worker *this << '-';
454*9880d681SAndroid Build Coastguard Worker return write(CurPtr, Len);
455*9880d681SAndroid Build Coastguard Worker }
456*9880d681SAndroid Build Coastguard Worker }
457*9880d681SAndroid Build Coastguard Worker
458*9880d681SAndroid Build Coastguard Worker
459*9880d681SAndroid Build Coastguard Worker /// indent - Insert 'NumSpaces' spaces.
indent(unsigned NumSpaces)460*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_ostream::indent(unsigned NumSpaces) {
461*9880d681SAndroid Build Coastguard Worker static const char Spaces[] = " "
462*9880d681SAndroid Build Coastguard Worker " "
463*9880d681SAndroid Build Coastguard Worker " ";
464*9880d681SAndroid Build Coastguard Worker
465*9880d681SAndroid Build Coastguard Worker // Usually the indentation is small, handle it with a fastpath.
466*9880d681SAndroid Build Coastguard Worker if (NumSpaces < array_lengthof(Spaces))
467*9880d681SAndroid Build Coastguard Worker return write(Spaces, NumSpaces);
468*9880d681SAndroid Build Coastguard Worker
469*9880d681SAndroid Build Coastguard Worker while (NumSpaces) {
470*9880d681SAndroid Build Coastguard Worker unsigned NumToWrite = std::min(NumSpaces,
471*9880d681SAndroid Build Coastguard Worker (unsigned)array_lengthof(Spaces)-1);
472*9880d681SAndroid Build Coastguard Worker write(Spaces, NumToWrite);
473*9880d681SAndroid Build Coastguard Worker NumSpaces -= NumToWrite;
474*9880d681SAndroid Build Coastguard Worker }
475*9880d681SAndroid Build Coastguard Worker return *this;
476*9880d681SAndroid Build Coastguard Worker }
477*9880d681SAndroid Build Coastguard Worker
478*9880d681SAndroid Build Coastguard Worker
479*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
480*9880d681SAndroid Build Coastguard Worker // Formatted Output
481*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
482*9880d681SAndroid Build Coastguard Worker
483*9880d681SAndroid Build Coastguard Worker // Out of line virtual method.
home()484*9880d681SAndroid Build Coastguard Worker void format_object_base::home() {
485*9880d681SAndroid Build Coastguard Worker }
486*9880d681SAndroid Build Coastguard Worker
487*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
488*9880d681SAndroid Build Coastguard Worker // raw_fd_ostream
489*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
490*9880d681SAndroid Build Coastguard Worker
getFD(StringRef Filename,std::error_code & EC,sys::fs::OpenFlags Flags)491*9880d681SAndroid Build Coastguard Worker static int getFD(StringRef Filename, std::error_code &EC,
492*9880d681SAndroid Build Coastguard Worker sys::fs::OpenFlags Flags) {
493*9880d681SAndroid Build Coastguard Worker // Handle "-" as stdout. Note that when we do this, we consider ourself
494*9880d681SAndroid Build Coastguard Worker // the owner of stdout. This means that we can do things like close the
495*9880d681SAndroid Build Coastguard Worker // file descriptor when we're done and set the "binary" flag globally.
496*9880d681SAndroid Build Coastguard Worker if (Filename == "-") {
497*9880d681SAndroid Build Coastguard Worker EC = std::error_code();
498*9880d681SAndroid Build Coastguard Worker // If user requested binary then put stdout into binary mode if
499*9880d681SAndroid Build Coastguard Worker // possible.
500*9880d681SAndroid Build Coastguard Worker if (!(Flags & sys::fs::F_Text))
501*9880d681SAndroid Build Coastguard Worker sys::ChangeStdoutToBinary();
502*9880d681SAndroid Build Coastguard Worker return STDOUT_FILENO;
503*9880d681SAndroid Build Coastguard Worker }
504*9880d681SAndroid Build Coastguard Worker
505*9880d681SAndroid Build Coastguard Worker int FD;
506*9880d681SAndroid Build Coastguard Worker EC = sys::fs::openFileForWrite(Filename, FD, Flags);
507*9880d681SAndroid Build Coastguard Worker if (EC)
508*9880d681SAndroid Build Coastguard Worker return -1;
509*9880d681SAndroid Build Coastguard Worker
510*9880d681SAndroid Build Coastguard Worker return FD;
511*9880d681SAndroid Build Coastguard Worker }
512*9880d681SAndroid Build Coastguard Worker
raw_fd_ostream(StringRef Filename,std::error_code & EC,sys::fs::OpenFlags Flags)513*9880d681SAndroid Build Coastguard Worker raw_fd_ostream::raw_fd_ostream(StringRef Filename, std::error_code &EC,
514*9880d681SAndroid Build Coastguard Worker sys::fs::OpenFlags Flags)
515*9880d681SAndroid Build Coastguard Worker : raw_fd_ostream(getFD(Filename, EC, Flags), true) {}
516*9880d681SAndroid Build Coastguard Worker
517*9880d681SAndroid Build Coastguard Worker /// FD is the file descriptor that this writes to. If ShouldClose is true, this
518*9880d681SAndroid Build Coastguard Worker /// closes the file when the stream is destroyed.
raw_fd_ostream(int fd,bool shouldClose,bool unbuffered)519*9880d681SAndroid Build Coastguard Worker raw_fd_ostream::raw_fd_ostream(int fd, bool shouldClose, bool unbuffered)
520*9880d681SAndroid Build Coastguard Worker : raw_pwrite_stream(unbuffered), FD(fd), ShouldClose(shouldClose),
521*9880d681SAndroid Build Coastguard Worker Error(false) {
522*9880d681SAndroid Build Coastguard Worker if (FD < 0 ) {
523*9880d681SAndroid Build Coastguard Worker ShouldClose = false;
524*9880d681SAndroid Build Coastguard Worker return;
525*9880d681SAndroid Build Coastguard Worker }
526*9880d681SAndroid Build Coastguard Worker
527*9880d681SAndroid Build Coastguard Worker // Get the starting position.
528*9880d681SAndroid Build Coastguard Worker off_t loc = ::lseek(FD, 0, SEEK_CUR);
529*9880d681SAndroid Build Coastguard Worker #ifdef LLVM_ON_WIN32
530*9880d681SAndroid Build Coastguard Worker // MSVCRT's _lseek(SEEK_CUR) doesn't return -1 for pipes.
531*9880d681SAndroid Build Coastguard Worker sys::fs::file_status Status;
532*9880d681SAndroid Build Coastguard Worker std::error_code EC = status(FD, Status);
533*9880d681SAndroid Build Coastguard Worker SupportsSeeking = !EC && Status.type() == sys::fs::file_type::regular_file;
534*9880d681SAndroid Build Coastguard Worker #else
535*9880d681SAndroid Build Coastguard Worker SupportsSeeking = loc != (off_t)-1;
536*9880d681SAndroid Build Coastguard Worker #endif
537*9880d681SAndroid Build Coastguard Worker if (!SupportsSeeking)
538*9880d681SAndroid Build Coastguard Worker pos = 0;
539*9880d681SAndroid Build Coastguard Worker else
540*9880d681SAndroid Build Coastguard Worker pos = static_cast<uint64_t>(loc);
541*9880d681SAndroid Build Coastguard Worker }
542*9880d681SAndroid Build Coastguard Worker
~raw_fd_ostream()543*9880d681SAndroid Build Coastguard Worker raw_fd_ostream::~raw_fd_ostream() {
544*9880d681SAndroid Build Coastguard Worker if (FD >= 0) {
545*9880d681SAndroid Build Coastguard Worker flush();
546*9880d681SAndroid Build Coastguard Worker if (ShouldClose && sys::Process::SafelyCloseFileDescriptor(FD))
547*9880d681SAndroid Build Coastguard Worker error_detected();
548*9880d681SAndroid Build Coastguard Worker }
549*9880d681SAndroid Build Coastguard Worker
550*9880d681SAndroid Build Coastguard Worker #ifdef __MINGW32__
551*9880d681SAndroid Build Coastguard Worker // On mingw, global dtors should not call exit().
552*9880d681SAndroid Build Coastguard Worker // report_fatal_error() invokes exit(). We know report_fatal_error()
553*9880d681SAndroid Build Coastguard Worker // might not write messages to stderr when any errors were detected
554*9880d681SAndroid Build Coastguard Worker // on FD == 2.
555*9880d681SAndroid Build Coastguard Worker if (FD == 2) return;
556*9880d681SAndroid Build Coastguard Worker #endif
557*9880d681SAndroid Build Coastguard Worker
558*9880d681SAndroid Build Coastguard Worker // If there are any pending errors, report them now. Clients wishing
559*9880d681SAndroid Build Coastguard Worker // to avoid report_fatal_error calls should check for errors with
560*9880d681SAndroid Build Coastguard Worker // has_error() and clear the error flag with clear_error() before
561*9880d681SAndroid Build Coastguard Worker // destructing raw_ostream objects which may have errors.
562*9880d681SAndroid Build Coastguard Worker if (has_error())
563*9880d681SAndroid Build Coastguard Worker report_fatal_error("IO failure on output stream.", /*GenCrashDiag=*/false);
564*9880d681SAndroid Build Coastguard Worker }
565*9880d681SAndroid Build Coastguard Worker
566*9880d681SAndroid Build Coastguard Worker
write_impl(const char * Ptr,size_t Size)567*9880d681SAndroid Build Coastguard Worker void raw_fd_ostream::write_impl(const char *Ptr, size_t Size) {
568*9880d681SAndroid Build Coastguard Worker assert(FD >= 0 && "File already closed.");
569*9880d681SAndroid Build Coastguard Worker pos += Size;
570*9880d681SAndroid Build Coastguard Worker
571*9880d681SAndroid Build Coastguard Worker #ifndef LLVM_ON_WIN32
572*9880d681SAndroid Build Coastguard Worker bool ShouldWriteInChunks = false;
573*9880d681SAndroid Build Coastguard Worker #else
574*9880d681SAndroid Build Coastguard Worker // Writing a large size of output to Windows console returns ENOMEM. It seems
575*9880d681SAndroid Build Coastguard Worker // that, prior to Windows 8, WriteFile() is redirecting to WriteConsole(), and
576*9880d681SAndroid Build Coastguard Worker // the latter has a size limit (66000 bytes or less, depending on heap usage).
577*9880d681SAndroid Build Coastguard Worker bool ShouldWriteInChunks = !!::_isatty(FD) && !RunningWindows8OrGreater();
578*9880d681SAndroid Build Coastguard Worker #endif
579*9880d681SAndroid Build Coastguard Worker
580*9880d681SAndroid Build Coastguard Worker do {
581*9880d681SAndroid Build Coastguard Worker size_t ChunkSize = Size;
582*9880d681SAndroid Build Coastguard Worker if (ChunkSize > 32767 && ShouldWriteInChunks)
583*9880d681SAndroid Build Coastguard Worker ChunkSize = 32767;
584*9880d681SAndroid Build Coastguard Worker
585*9880d681SAndroid Build Coastguard Worker ssize_t ret = ::write(FD, Ptr, ChunkSize);
586*9880d681SAndroid Build Coastguard Worker
587*9880d681SAndroid Build Coastguard Worker if (ret < 0) {
588*9880d681SAndroid Build Coastguard Worker // If it's a recoverable error, swallow it and retry the write.
589*9880d681SAndroid Build Coastguard Worker //
590*9880d681SAndroid Build Coastguard Worker // Ideally we wouldn't ever see EAGAIN or EWOULDBLOCK here, since
591*9880d681SAndroid Build Coastguard Worker // raw_ostream isn't designed to do non-blocking I/O. However, some
592*9880d681SAndroid Build Coastguard Worker // programs, such as old versions of bjam, have mistakenly used
593*9880d681SAndroid Build Coastguard Worker // O_NONBLOCK. For compatibility, emulate blocking semantics by
594*9880d681SAndroid Build Coastguard Worker // spinning until the write succeeds. If you don't want spinning,
595*9880d681SAndroid Build Coastguard Worker // don't use O_NONBLOCK file descriptors with raw_ostream.
596*9880d681SAndroid Build Coastguard Worker if (errno == EINTR || errno == EAGAIN
597*9880d681SAndroid Build Coastguard Worker #ifdef EWOULDBLOCK
598*9880d681SAndroid Build Coastguard Worker || errno == EWOULDBLOCK
599*9880d681SAndroid Build Coastguard Worker #endif
600*9880d681SAndroid Build Coastguard Worker )
601*9880d681SAndroid Build Coastguard Worker continue;
602*9880d681SAndroid Build Coastguard Worker
603*9880d681SAndroid Build Coastguard Worker // Otherwise it's a non-recoverable error. Note it and quit.
604*9880d681SAndroid Build Coastguard Worker error_detected();
605*9880d681SAndroid Build Coastguard Worker break;
606*9880d681SAndroid Build Coastguard Worker }
607*9880d681SAndroid Build Coastguard Worker
608*9880d681SAndroid Build Coastguard Worker // The write may have written some or all of the data. Update the
609*9880d681SAndroid Build Coastguard Worker // size and buffer pointer to reflect the remainder that needs
610*9880d681SAndroid Build Coastguard Worker // to be written. If there are no bytes left, we're done.
611*9880d681SAndroid Build Coastguard Worker Ptr += ret;
612*9880d681SAndroid Build Coastguard Worker Size -= ret;
613*9880d681SAndroid Build Coastguard Worker } while (Size > 0);
614*9880d681SAndroid Build Coastguard Worker }
615*9880d681SAndroid Build Coastguard Worker
close()616*9880d681SAndroid Build Coastguard Worker void raw_fd_ostream::close() {
617*9880d681SAndroid Build Coastguard Worker assert(ShouldClose);
618*9880d681SAndroid Build Coastguard Worker ShouldClose = false;
619*9880d681SAndroid Build Coastguard Worker flush();
620*9880d681SAndroid Build Coastguard Worker if (sys::Process::SafelyCloseFileDescriptor(FD))
621*9880d681SAndroid Build Coastguard Worker error_detected();
622*9880d681SAndroid Build Coastguard Worker FD = -1;
623*9880d681SAndroid Build Coastguard Worker }
624*9880d681SAndroid Build Coastguard Worker
seek(uint64_t off)625*9880d681SAndroid Build Coastguard Worker uint64_t raw_fd_ostream::seek(uint64_t off) {
626*9880d681SAndroid Build Coastguard Worker assert(SupportsSeeking && "Stream does not support seeking!");
627*9880d681SAndroid Build Coastguard Worker flush();
628*9880d681SAndroid Build Coastguard Worker pos = ::lseek(FD, off, SEEK_SET);
629*9880d681SAndroid Build Coastguard Worker if (pos == (uint64_t)-1)
630*9880d681SAndroid Build Coastguard Worker error_detected();
631*9880d681SAndroid Build Coastguard Worker return pos;
632*9880d681SAndroid Build Coastguard Worker }
633*9880d681SAndroid Build Coastguard Worker
pwrite_impl(const char * Ptr,size_t Size,uint64_t Offset)634*9880d681SAndroid Build Coastguard Worker void raw_fd_ostream::pwrite_impl(const char *Ptr, size_t Size,
635*9880d681SAndroid Build Coastguard Worker uint64_t Offset) {
636*9880d681SAndroid Build Coastguard Worker uint64_t Pos = tell();
637*9880d681SAndroid Build Coastguard Worker seek(Offset);
638*9880d681SAndroid Build Coastguard Worker write(Ptr, Size);
639*9880d681SAndroid Build Coastguard Worker seek(Pos);
640*9880d681SAndroid Build Coastguard Worker }
641*9880d681SAndroid Build Coastguard Worker
preferred_buffer_size() const642*9880d681SAndroid Build Coastguard Worker size_t raw_fd_ostream::preferred_buffer_size() const {
643*9880d681SAndroid Build Coastguard Worker #if !defined(_MSC_VER) && !defined(__MINGW32__) && !defined(__minix)
644*9880d681SAndroid Build Coastguard Worker // Windows and Minix have no st_blksize.
645*9880d681SAndroid Build Coastguard Worker assert(FD >= 0 && "File not yet open!");
646*9880d681SAndroid Build Coastguard Worker struct stat statbuf;
647*9880d681SAndroid Build Coastguard Worker if (fstat(FD, &statbuf) != 0)
648*9880d681SAndroid Build Coastguard Worker return 0;
649*9880d681SAndroid Build Coastguard Worker
650*9880d681SAndroid Build Coastguard Worker // If this is a terminal, don't use buffering. Line buffering
651*9880d681SAndroid Build Coastguard Worker // would be a more traditional thing to do, but it's not worth
652*9880d681SAndroid Build Coastguard Worker // the complexity.
653*9880d681SAndroid Build Coastguard Worker if (S_ISCHR(statbuf.st_mode) && isatty(FD))
654*9880d681SAndroid Build Coastguard Worker return 0;
655*9880d681SAndroid Build Coastguard Worker // Return the preferred block size.
656*9880d681SAndroid Build Coastguard Worker return statbuf.st_blksize;
657*9880d681SAndroid Build Coastguard Worker #else
658*9880d681SAndroid Build Coastguard Worker return raw_ostream::preferred_buffer_size();
659*9880d681SAndroid Build Coastguard Worker #endif
660*9880d681SAndroid Build Coastguard Worker }
661*9880d681SAndroid Build Coastguard Worker
changeColor(enum Colors colors,bool bold,bool bg)662*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_fd_ostream::changeColor(enum Colors colors, bool bold,
663*9880d681SAndroid Build Coastguard Worker bool bg) {
664*9880d681SAndroid Build Coastguard Worker if (sys::Process::ColorNeedsFlush())
665*9880d681SAndroid Build Coastguard Worker flush();
666*9880d681SAndroid Build Coastguard Worker const char *colorcode =
667*9880d681SAndroid Build Coastguard Worker (colors == SAVEDCOLOR) ? sys::Process::OutputBold(bg)
668*9880d681SAndroid Build Coastguard Worker : sys::Process::OutputColor(colors, bold, bg);
669*9880d681SAndroid Build Coastguard Worker if (colorcode) {
670*9880d681SAndroid Build Coastguard Worker size_t len = strlen(colorcode);
671*9880d681SAndroid Build Coastguard Worker write(colorcode, len);
672*9880d681SAndroid Build Coastguard Worker // don't account colors towards output characters
673*9880d681SAndroid Build Coastguard Worker pos -= len;
674*9880d681SAndroid Build Coastguard Worker }
675*9880d681SAndroid Build Coastguard Worker return *this;
676*9880d681SAndroid Build Coastguard Worker }
677*9880d681SAndroid Build Coastguard Worker
resetColor()678*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_fd_ostream::resetColor() {
679*9880d681SAndroid Build Coastguard Worker if (sys::Process::ColorNeedsFlush())
680*9880d681SAndroid Build Coastguard Worker flush();
681*9880d681SAndroid Build Coastguard Worker const char *colorcode = sys::Process::ResetColor();
682*9880d681SAndroid Build Coastguard Worker if (colorcode) {
683*9880d681SAndroid Build Coastguard Worker size_t len = strlen(colorcode);
684*9880d681SAndroid Build Coastguard Worker write(colorcode, len);
685*9880d681SAndroid Build Coastguard Worker // don't account colors towards output characters
686*9880d681SAndroid Build Coastguard Worker pos -= len;
687*9880d681SAndroid Build Coastguard Worker }
688*9880d681SAndroid Build Coastguard Worker return *this;
689*9880d681SAndroid Build Coastguard Worker }
690*9880d681SAndroid Build Coastguard Worker
reverseColor()691*9880d681SAndroid Build Coastguard Worker raw_ostream &raw_fd_ostream::reverseColor() {
692*9880d681SAndroid Build Coastguard Worker if (sys::Process::ColorNeedsFlush())
693*9880d681SAndroid Build Coastguard Worker flush();
694*9880d681SAndroid Build Coastguard Worker const char *colorcode = sys::Process::OutputReverse();
695*9880d681SAndroid Build Coastguard Worker if (colorcode) {
696*9880d681SAndroid Build Coastguard Worker size_t len = strlen(colorcode);
697*9880d681SAndroid Build Coastguard Worker write(colorcode, len);
698*9880d681SAndroid Build Coastguard Worker // don't account colors towards output characters
699*9880d681SAndroid Build Coastguard Worker pos -= len;
700*9880d681SAndroid Build Coastguard Worker }
701*9880d681SAndroid Build Coastguard Worker return *this;
702*9880d681SAndroid Build Coastguard Worker }
703*9880d681SAndroid Build Coastguard Worker
is_displayed() const704*9880d681SAndroid Build Coastguard Worker bool raw_fd_ostream::is_displayed() const {
705*9880d681SAndroid Build Coastguard Worker return sys::Process::FileDescriptorIsDisplayed(FD);
706*9880d681SAndroid Build Coastguard Worker }
707*9880d681SAndroid Build Coastguard Worker
has_colors() const708*9880d681SAndroid Build Coastguard Worker bool raw_fd_ostream::has_colors() const {
709*9880d681SAndroid Build Coastguard Worker return sys::Process::FileDescriptorHasColors(FD);
710*9880d681SAndroid Build Coastguard Worker }
711*9880d681SAndroid Build Coastguard Worker
712*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
713*9880d681SAndroid Build Coastguard Worker // outs(), errs(), nulls()
714*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
715*9880d681SAndroid Build Coastguard Worker
716*9880d681SAndroid Build Coastguard Worker /// outs() - This returns a reference to a raw_ostream for standard output.
717*9880d681SAndroid Build Coastguard Worker /// Use it like: outs() << "foo" << "bar";
outs()718*9880d681SAndroid Build Coastguard Worker raw_ostream &llvm::outs() {
719*9880d681SAndroid Build Coastguard Worker // Set buffer settings to model stdout behavior. Delete the file descriptor
720*9880d681SAndroid Build Coastguard Worker // when the program exits, forcing error detection. This means that if you
721*9880d681SAndroid Build Coastguard Worker // ever call outs(), you can't open another raw_fd_ostream on stdout, as we'll
722*9880d681SAndroid Build Coastguard Worker // close stdout twice and print an error the second time.
723*9880d681SAndroid Build Coastguard Worker std::error_code EC;
724*9880d681SAndroid Build Coastguard Worker static raw_fd_ostream S("-", EC, sys::fs::F_None);
725*9880d681SAndroid Build Coastguard Worker assert(!EC);
726*9880d681SAndroid Build Coastguard Worker return S;
727*9880d681SAndroid Build Coastguard Worker }
728*9880d681SAndroid Build Coastguard Worker
729*9880d681SAndroid Build Coastguard Worker /// errs() - This returns a reference to a raw_ostream for standard error.
730*9880d681SAndroid Build Coastguard Worker /// Use it like: errs() << "foo" << "bar";
errs()731*9880d681SAndroid Build Coastguard Worker raw_ostream &llvm::errs() {
732*9880d681SAndroid Build Coastguard Worker // Set standard error to be unbuffered by default.
733*9880d681SAndroid Build Coastguard Worker static raw_fd_ostream S(STDERR_FILENO, false, true);
734*9880d681SAndroid Build Coastguard Worker return S;
735*9880d681SAndroid Build Coastguard Worker }
736*9880d681SAndroid Build Coastguard Worker
737*9880d681SAndroid Build Coastguard Worker /// nulls() - This returns a reference to a raw_ostream which discards output.
nulls()738*9880d681SAndroid Build Coastguard Worker raw_ostream &llvm::nulls() {
739*9880d681SAndroid Build Coastguard Worker static raw_null_ostream S;
740*9880d681SAndroid Build Coastguard Worker return S;
741*9880d681SAndroid Build Coastguard Worker }
742*9880d681SAndroid Build Coastguard Worker
743*9880d681SAndroid Build Coastguard Worker
744*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
745*9880d681SAndroid Build Coastguard Worker // raw_string_ostream
746*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
747*9880d681SAndroid Build Coastguard Worker
~raw_string_ostream()748*9880d681SAndroid Build Coastguard Worker raw_string_ostream::~raw_string_ostream() {
749*9880d681SAndroid Build Coastguard Worker flush();
750*9880d681SAndroid Build Coastguard Worker }
751*9880d681SAndroid Build Coastguard Worker
write_impl(const char * Ptr,size_t Size)752*9880d681SAndroid Build Coastguard Worker void raw_string_ostream::write_impl(const char *Ptr, size_t Size) {
753*9880d681SAndroid Build Coastguard Worker OS.append(Ptr, Size);
754*9880d681SAndroid Build Coastguard Worker }
755*9880d681SAndroid Build Coastguard Worker
756*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
757*9880d681SAndroid Build Coastguard Worker // raw_svector_ostream
758*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
759*9880d681SAndroid Build Coastguard Worker
current_pos() const760*9880d681SAndroid Build Coastguard Worker uint64_t raw_svector_ostream::current_pos() const { return OS.size(); }
761*9880d681SAndroid Build Coastguard Worker
write_impl(const char * Ptr,size_t Size)762*9880d681SAndroid Build Coastguard Worker void raw_svector_ostream::write_impl(const char *Ptr, size_t Size) {
763*9880d681SAndroid Build Coastguard Worker OS.append(Ptr, Ptr + Size);
764*9880d681SAndroid Build Coastguard Worker }
765*9880d681SAndroid Build Coastguard Worker
pwrite_impl(const char * Ptr,size_t Size,uint64_t Offset)766*9880d681SAndroid Build Coastguard Worker void raw_svector_ostream::pwrite_impl(const char *Ptr, size_t Size,
767*9880d681SAndroid Build Coastguard Worker uint64_t Offset) {
768*9880d681SAndroid Build Coastguard Worker memcpy(OS.data() + Offset, Ptr, Size);
769*9880d681SAndroid Build Coastguard Worker }
770*9880d681SAndroid Build Coastguard Worker
771*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
772*9880d681SAndroid Build Coastguard Worker // raw_null_ostream
773*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
774*9880d681SAndroid Build Coastguard Worker
~raw_null_ostream()775*9880d681SAndroid Build Coastguard Worker raw_null_ostream::~raw_null_ostream() {
776*9880d681SAndroid Build Coastguard Worker #ifndef NDEBUG
777*9880d681SAndroid Build Coastguard Worker // ~raw_ostream asserts that the buffer is empty. This isn't necessary
778*9880d681SAndroid Build Coastguard Worker // with raw_null_ostream, but it's better to have raw_null_ostream follow
779*9880d681SAndroid Build Coastguard Worker // the rules than to change the rules just for raw_null_ostream.
780*9880d681SAndroid Build Coastguard Worker flush();
781*9880d681SAndroid Build Coastguard Worker #endif
782*9880d681SAndroid Build Coastguard Worker }
783*9880d681SAndroid Build Coastguard Worker
write_impl(const char * Ptr,size_t Size)784*9880d681SAndroid Build Coastguard Worker void raw_null_ostream::write_impl(const char *Ptr, size_t Size) {
785*9880d681SAndroid Build Coastguard Worker }
786*9880d681SAndroid Build Coastguard Worker
current_pos() const787*9880d681SAndroid Build Coastguard Worker uint64_t raw_null_ostream::current_pos() const {
788*9880d681SAndroid Build Coastguard Worker return 0;
789*9880d681SAndroid Build Coastguard Worker }
790*9880d681SAndroid Build Coastguard Worker
pwrite_impl(const char * Ptr,size_t Size,uint64_t Offset)791*9880d681SAndroid Build Coastguard Worker void raw_null_ostream::pwrite_impl(const char *Ptr, size_t Size,
792*9880d681SAndroid Build Coastguard Worker uint64_t Offset) {}
793