xref: /aosp_15_r20/external/llvm/lib/Support/raw_ostream.cpp (revision 9880d6810fe72a1726cb53787c6711e909410d58)
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