LLDB mainline
StreamAsynchronousIO.cpp
Go to the documentation of this file.
1//===-- StreamAsynchronousIO.cpp ------------------------------------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
10
11#include "lldb/Core/Debugger.h"
13
14using namespace lldb;
15using namespace lldb_private;
16
18 Debugger &debugger, StreamAsynchronousIO::ForSTDOUT for_stdout)
19 : Stream(0, 4, eByteOrderBig, debugger.GetUseColor()), m_debugger(debugger),
20 m_data(), m_for_stdout(for_stdout) {}
21
23 // Flush when we destroy to make sure we display the data.
24 Flush();
25}
26
28 if (!m_data.empty()) {
29 m_debugger.PrintAsync(m_data.data(), m_data.size(), m_for_stdout);
30 m_data.clear();
31 }
32}
33
34size_t StreamAsynchronousIO::WriteImpl(const void *s, size_t length) {
35 m_data.append((const char *)s, length);
36 return length;
37}
A class to manage flag bits.
Definition Debugger.h:80
void Flush() override
Flush the stream.
StreamAsynchronousIO(Debugger &debugger, ForSTDOUT for_stdout)
size_t WriteImpl(const void *src, size_t src_len) override
Output character bytes to the stream.
Stream(uint32_t flags, uint32_t addr_size, lldb::ByteOrder byte_order, bool colors=false)
Construct with flags and address size and byte order.
Definition Stream.cpp:27
A class that represents a running process on the host machine.