mirror of
https://github.com/darlinghq/darling-libcxx.git
synced 2024-11-30 07:10:33 +00:00
Only initialize the streams cout/wcout/cerr/wcerr etc once, rather than any time Init::Init is called. Fixes PR#43300
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@371864 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
6e538bcf49
commit
dbc7f4efd2
@ -97,7 +97,13 @@ static void force_locale_initialization() {
|
||||
#endif
|
||||
}
|
||||
|
||||
ios_base::Init::Init()
|
||||
class DoIOSInit {
|
||||
public:
|
||||
DoIOSInit();
|
||||
~DoIOSInit();
|
||||
};
|
||||
|
||||
DoIOSInit::DoIOSInit()
|
||||
{
|
||||
force_locale_initialization();
|
||||
|
||||
@ -126,7 +132,7 @@ ios_base::Init::Init()
|
||||
#endif
|
||||
}
|
||||
|
||||
ios_base::Init::~Init()
|
||||
DoIOSInit::~DoIOSInit()
|
||||
{
|
||||
#ifndef _LIBCPP_HAS_NO_STDOUT
|
||||
ostream* cout_ptr = reinterpret_cast<ostream*>(cout);
|
||||
@ -141,4 +147,13 @@ ios_base::Init::~Init()
|
||||
wclog_ptr->flush();
|
||||
}
|
||||
|
||||
ios_base::Init::Init()
|
||||
{
|
||||
static DoIOSInit init_the_streams; // gets initialized once
|
||||
}
|
||||
|
||||
ios_base::Init::~Init()
|
||||
{
|
||||
}
|
||||
|
||||
_LIBCPP_END_NAMESPACE_STD
|
||||
|
@ -0,0 +1,32 @@
|
||||
//===----------------------------------------------------------------------===//
|
||||
//
|
||||
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
||||
// See https://llvm.org/LICENSE.txt for license information.
|
||||
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include <iostream>
|
||||
#include <cassert>
|
||||
|
||||
#include "test_macros.h"
|
||||
|
||||
// Test to make sure that the streams only get initialized once
|
||||
// Taken from https://bugs.llvm.org/show_bug.cgi?id=43300
|
||||
|
||||
int main(int, char**)
|
||||
{
|
||||
|
||||
std::cout << "Hello!";
|
||||
std::ios_base::fmtflags stock_flags = std::cout.flags();
|
||||
|
||||
std::cout << std::boolalpha << true;
|
||||
std::ios_base::fmtflags ba_flags = std::cout.flags();
|
||||
assert(stock_flags != ba_flags);
|
||||
|
||||
std::ios_base::Init init_streams;
|
||||
std::ios_base::fmtflags after_init = std::cout.flags();
|
||||
assert(after_init == ba_flags);
|
||||
|
||||
return 0;
|
||||
}
|
Loading…
Reference in New Issue
Block a user