[libcxx-commits] [libcxx] [libc++] Avoid including <ostream> in <fstream> and <strstream> (PR #116014)
Nikolas Klauser via libcxx-commits
libcxx-commits at lists.llvm.org
Thu Nov 14 10:11:45 PST 2024
https://github.com/philnik777 updated https://github.com/llvm/llvm-project/pull/116014
>From e68205837e3d2baa5d9e414483646925ac182da2 Mon Sep 17 00:00:00 2001
From: Nikolas Klauser <nikolasklauser at berlin.de>
Date: Wed, 13 Nov 2024 11:00:01 +0100
Subject: [PATCH] [libc++] Avoid including <ostream> in <fstream> and
<strstream>
---
libcxx/include/fstream | 4 +++-
libcxx/include/strstream | 3 ++-
libcxx/test/libcxx/transitive_includes/cxx23.csv | 12 ------------
libcxx/test/libcxx/transitive_includes/cxx26.csv | 12 ------------
4 files changed, 5 insertions(+), 26 deletions(-)
diff --git a/libcxx/include/fstream b/libcxx/include/fstream
index e3b9abbbdcf056..e188bfc9042a7c 100644
--- a/libcxx/include/fstream
+++ b/libcxx/include/fstream
@@ -193,6 +193,8 @@ typedef basic_fstream<wchar_t> wfstream;
#include <__fwd/fstream.h>
#include <__locale>
#include <__memory/addressof.h>
+#include <__memory/unique_ptr.h>
+#include <__ostream/basic_ostream.h>
#include <__type_traits/enable_if.h>
#include <__type_traits/is_same.h>
#include <__utility/move.h>
@@ -200,7 +202,7 @@ typedef basic_fstream<wchar_t> wfstream;
#include <__utility/unreachable.h>
#include <cstdio>
#include <istream>
-#include <ostream>
+#include <streambuf>
#include <typeinfo>
#include <version>
diff --git a/libcxx/include/strstream b/libcxx/include/strstream
index 9ff4024a7c7e21..b263fe1a76ad22 100644
--- a/libcxx/include/strstream
+++ b/libcxx/include/strstream
@@ -130,8 +130,9 @@ private:
*/
#include <__config>
+#include <__ostream/basic_ostream.h>
#include <istream>
-#include <ostream>
+#include <streambuf>
#include <version>
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
diff --git a/libcxx/test/libcxx/transitive_includes/cxx23.csv b/libcxx/test/libcxx/transitive_includes/cxx23.csv
index 854ad1b5df6f1e..c0cabf49f81a5d 100644
--- a/libcxx/test/libcxx/transitive_includes/cxx23.csv
+++ b/libcxx/test/libcxx/transitive_includes/cxx23.csv
@@ -410,13 +410,11 @@ forward_list limits
forward_list new
forward_list tuple
forward_list version
-fstream array
fstream bitset
fstream cctype
fstream cerrno
fstream climits
fstream clocale
-fstream cmath
fstream compare
fstream cstddef
fstream cstdint
@@ -427,7 +425,6 @@ fstream ctime
fstream cwchar
fstream cwctype
fstream filesystem
-fstream format
fstream initializer_list
fstream iomanip
fstream ios
@@ -436,9 +433,6 @@ fstream istream
fstream limits
fstream locale
fstream new
-fstream optional
-fstream ostream
-fstream print
fstream ratio
fstream stdexcept
fstream streambuf
@@ -1081,13 +1075,11 @@ string_view limits
string_view new
string_view stdexcept
string_view version
-strstream array
strstream bitset
strstream cctype
strstream cerrno
strstream climits
strstream clocale
-strstream cmath
strstream compare
strstream cstddef
strstream cstdint
@@ -1097,7 +1089,6 @@ strstream cstring
strstream ctime
strstream cwchar
strstream cwctype
-strstream format
strstream initializer_list
strstream ios
strstream iosfwd
@@ -1105,9 +1096,6 @@ strstream istream
strstream limits
strstream locale
strstream new
-strstream optional
-strstream ostream
-strstream print
strstream ratio
strstream stdexcept
strstream streambuf
diff --git a/libcxx/test/libcxx/transitive_includes/cxx26.csv b/libcxx/test/libcxx/transitive_includes/cxx26.csv
index ba2faaee5e3757..5bbf5b41047b5d 100644
--- a/libcxx/test/libcxx/transitive_includes/cxx26.csv
+++ b/libcxx/test/libcxx/transitive_includes/cxx26.csv
@@ -410,13 +410,11 @@ forward_list limits
forward_list new
forward_list tuple
forward_list version
-fstream array
fstream bitset
fstream cctype
fstream cerrno
fstream climits
fstream clocale
-fstream cmath
fstream compare
fstream cstddef
fstream cstdint
@@ -426,7 +424,6 @@ fstream cstring
fstream ctime
fstream cwchar
fstream cwctype
-fstream format
fstream initializer_list
fstream iomanip
fstream ios
@@ -435,9 +432,6 @@ fstream istream
fstream limits
fstream locale
fstream new
-fstream optional
-fstream ostream
-fstream print
fstream ratio
fstream stdexcept
fstream streambuf
@@ -1080,13 +1074,11 @@ string_view limits
string_view new
string_view stdexcept
string_view version
-strstream array
strstream bitset
strstream cctype
strstream cerrno
strstream climits
strstream clocale
-strstream cmath
strstream compare
strstream cstddef
strstream cstdint
@@ -1096,7 +1088,6 @@ strstream cstring
strstream ctime
strstream cwchar
strstream cwctype
-strstream format
strstream initializer_list
strstream ios
strstream iosfwd
@@ -1104,9 +1095,6 @@ strstream istream
strstream limits
strstream locale
strstream new
-strstream optional
-strstream ostream
-strstream print
strstream ratio
strstream stdexcept
strstream streambuf
More information about the libcxx-commits
mailing list