Namespaces
Variants
Actions

std::basic_osyncstream<CharT,Traits,Allocator>::emit

From cppreference.com
 
C++
 
Input/output library
 
std::basic_osyncstream
void emit();

Emits all buffered output and executes any pending flushes, by calling emit() on the underlying std::basic_syncbuf.

[edit] Parameters

(none)

[edit] Example

#include <iostream>
#include <syncstream>
 
int main()
{
    {
        std::osyncstream bout(std::cout);
        bout << "Hello," << '\n'; / no flush
        bout.emit(); / characters transferred; cout not flushed
        bout << "World!" << std::endl; / flush noted; cout not flushed
        bout.emit(); / characters transferred; cout flushed
        bout << "Greetings." << '\n'; / no flush
    } / destructor calls emit(): characters transferred; cout not flushed
 
    / emit can be used for local exception-handling on the wrapped stream
    std::osyncstream bout(std::cout);
    bout << "Hello, " << "World!" << '\n';
    try
    {
        bout.emit();
    }
    catch (...)
    {
        / handle exceptions
    }
}

Output:

Hello,
World!
Greetings.
Hello, World!

[edit] See also

destroys the basic_osyncstream and emits its internal buffer
(public member function) [edit]
atomically transmits the entire internal buffer to the wrapped streambuf
(public member function of std::basic_syncbuf<CharT,Traits,Allocator>) [edit]

Follow Lee on X/Twitter - Father, Husband, Serial builder creating AI, crypto, games & web tools. We are friends :) AI Will Come To Life!

Check out: eBank.nz (Art Generator) | Netwrck.com (AI Tools) | Text-Generator.io (AI API) | BitBank.nz (Crypto AI) | ReadingTime (Kids Reading) | RewordGame | BigMultiplayerChess | WebFiddle | How.nz | Helix AI Assistant