mirror of
				https://github.com/jart/cosmopolitan.git
				synced 2025-10-26 03:00:57 +00:00 
			
		
		
		
	Fix std::filesystem
This change makes a second pass, at fixing the errno issue with libcxx's filesystem code. Previously, 89.01% of LLVM's test suite was passing and now 98.59% of their tests pass. Best of all, it's now possible for Clang to be built as a working APE binary that can to compile the Cosmopolitan repository. Please note it has only been vetted so far for some objects, and more work would obviously need to be done in cosmo, to fix warnings.
This commit is contained in:
		
							parent
							
								
									0d7c272d3f
								
							
						
					
					
						commit
						77d3a07ff2
					
				
					 14 changed files with 408 additions and 69 deletions
				
			
		
							
								
								
									
										2
									
								
								third_party/libcxx/BUILD.mk
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								third_party/libcxx/BUILD.mk
									
										
									
									
										vendored
									
									
								
							|  | @ -1094,11 +1094,11 @@ third_party/libcxx/fs/filesystem_clock.cpp \ | |||
| third_party/libcxx/fs/filesystem_error.cpp \ | ||||
| third_party/libcxx/fs/int128_builtins.cpp \ | ||||
| third_party/libcxx/fs/operations.cpp \ | ||||
| third_party/libcxx/fs/cosmo.cpp \ | ||||
| third_party/libcxx/fs/path.cpp \ | ||||
| third_party/libcxx/ryu/d2fixed.cpp \ | ||||
| third_party/libcxx/ryu/d2s.cpp \ | ||||
| third_party/libcxx/ryu/f2s.cpp \ | ||||
| third_party/libcxx/errc.cpp \ | ||||
| 
 | ||||
| THIRD_PARTY_LIBCXX_A_HDRS_CHECKEM = \
 | ||||
| third_party/libcxx/__assertion_handler \ | ||||
|  |  | |||
							
								
								
									
										4
									
								
								third_party/libcxx/__system_error/errc.h
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								third_party/libcxx/__system_error/errc.h
									
										
									
									
										vendored
									
									
								
							|  | @ -141,6 +141,7 @@ _LIBCPP_BEGIN_NAMESPACE_STD | |||
| // This leads to the odd pushing and popping of the deprecated
 | ||||
| // diagnostic.
 | ||||
| _LIBCPP_DECLARE_STRONG_ENUM(errc){ | ||||
|   success = 0, | ||||
|     address_family_not_supported = 65536, //       = EAFNOSUPPORT,
 | ||||
|           address_in_use, //                     = EADDRINUSE,
 | ||||
|           address_not_available, //              = EADDRNOTAVAIL,
 | ||||
|  | @ -221,6 +222,9 @@ _LIBCPP_DECLARE_STRONG_ENUM(errc){ | |||
|     wrong_protocol_type}; | ||||
| _LIBCPP_DECLARE_STRONG_ENUM_EPILOG(errc) | ||||
| 
 | ||||
| errc __err_to_errc(int) noexcept; | ||||
| int __errc_to_err(errc) noexcept; | ||||
| 
 | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
| 
 | ||||
| #endif // _LIBCPP___ERRC
 | ||||
|  |  | |||
							
								
								
									
										13
									
								
								third_party/libcxx/__system_error/error_code.h
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										13
									
								
								third_party/libcxx/__system_error/error_code.h
									
										
									
									
										vendored
									
									
								
							|  | @ -46,8 +46,9 @@ class _LIBCPP_EXPORTED_FROM_ABI error_code { | |||
| 
 | ||||
| public: | ||||
|   _LIBCPP_HIDE_FROM_ABI error_code() _NOEXCEPT : __val_(0), __cat_(&system_category()) {} | ||||
| 
 | ||||
|   _LIBCPP_HIDE_FROM_ABI error_code(int __val, const error_category& __cat) _NOEXCEPT : __val_(__val), __cat_(&__cat) {} | ||||
|   _LIBCPP_HIDE_FROM_ABI error_code(errc __val) _NOEXCEPT : __val_(__errc_to_err(__val)), __cat_(&system_category()) {} | ||||
|   _LIBCPP_HIDE_FROM_ABI error_code(int __val, const error_category& __cat) _NOEXCEPT : __val_(__errc_to_err((errc)__val)), __cat_(&__cat) {} | ||||
|   _LIBCPP_HIDE_FROM_ABI error_code(errc __val, const error_category& __cat) _NOEXCEPT : __val_(__errc_to_err(__val)), __cat_(&__cat) {} | ||||
| 
 | ||||
|   template <class _Ep, __enable_if_t<is_error_code_enum<_Ep>::value, int> = 0> | ||||
|   _LIBCPP_HIDE_FROM_ABI error_code(_Ep __e) _NOEXCEPT { | ||||
|  | @ -72,7 +73,7 @@ public: | |||
|     __cat_ = &system_category(); | ||||
|   } | ||||
| 
 | ||||
|   _LIBCPP_HIDE_FROM_ABI int value() const _NOEXCEPT { return __val_; } | ||||
|   _LIBCPP_HIDE_FROM_ABI int value() const _NOEXCEPT { return __errc_to_err((errc)__val_); } | ||||
| 
 | ||||
|   _LIBCPP_HIDE_FROM_ABI const error_category& category() const _NOEXCEPT { return *__cat_; } | ||||
| 
 | ||||
|  | @ -86,13 +87,17 @@ public: | |||
| }; | ||||
| 
 | ||||
| inline _LIBCPP_HIDE_FROM_ABI error_code make_error_code(errc __e) _NOEXCEPT { | ||||
|   return error_code(static_cast<int>(__e), generic_category()); | ||||
|   return error_code(__e, generic_category()); | ||||
| } | ||||
| 
 | ||||
| inline _LIBCPP_HIDE_FROM_ABI bool operator==(const error_code& __x, const error_code& __y) _NOEXCEPT { | ||||
|   return __x.category() == __y.category() && __x.value() == __y.value(); | ||||
| } | ||||
| 
 | ||||
| inline _LIBCPP_HIDE_FROM_ABI bool operator==(const error_code& __x, errc __y) _NOEXCEPT { | ||||
|   return __x == error_code(__y, __x.category()); | ||||
| } | ||||
| 
 | ||||
| inline _LIBCPP_HIDE_FROM_ABI bool operator==(const error_code& __x, const error_condition& __y) _NOEXCEPT { | ||||
|   return __x.category().equivalent(__x.value(), __y) || __y.category().equivalent(__x, __y.value()); | ||||
| } | ||||
|  |  | |||
|  | @ -54,8 +54,12 @@ class _LIBCPP_EXPORTED_FROM_ABI error_condition { | |||
| public: | ||||
|   _LIBCPP_HIDE_FROM_ABI error_condition() _NOEXCEPT : __val_(0), __cat_(&generic_category()) {} | ||||
| 
 | ||||
|   _LIBCPP_HIDE_FROM_ABI error_condition(errc __val, const error_category& __cat) _NOEXCEPT | ||||
|       : __val_(__errc_to_err(__val)), | ||||
|         __cat_(&__cat) {} | ||||
| 
 | ||||
|   _LIBCPP_HIDE_FROM_ABI error_condition(int __val, const error_category& __cat) _NOEXCEPT | ||||
|       : __val_(__val), | ||||
|       : __val_(__errc_to_err((errc)__val)), | ||||
|         __cat_(&__cat) {} | ||||
| 
 | ||||
|   template <class _Ep, __enable_if_t<is_error_condition_enum<_Ep>::value, int> = 0> | ||||
|  | @ -81,7 +85,7 @@ public: | |||
|     __cat_ = &generic_category(); | ||||
|   } | ||||
| 
 | ||||
|   _LIBCPP_HIDE_FROM_ABI int value() const _NOEXCEPT { return __val_; } | ||||
|   _LIBCPP_HIDE_FROM_ABI int value() const _NOEXCEPT { return __errc_to_err((errc)__val_); } | ||||
| 
 | ||||
|   _LIBCPP_HIDE_FROM_ABI const error_category& category() const _NOEXCEPT { return *__cat_; } | ||||
|   string message() const; | ||||
|  | @ -90,7 +94,7 @@ public: | |||
| }; | ||||
| 
 | ||||
| inline _LIBCPP_HIDE_FROM_ABI error_condition make_error_condition(errc __e) _NOEXCEPT { | ||||
|   return error_condition(static_cast<int>(__e), generic_category()); | ||||
|   return error_condition(__e, generic_category()); | ||||
| } | ||||
| 
 | ||||
| inline _LIBCPP_HIDE_FROM_ABI bool operator==(const error_condition& __x, const error_condition& __y) _NOEXCEPT { | ||||
|  |  | |||
|  | @ -11,6 +11,7 @@ | |||
| #define _LIBCPP___SYSTEM_ERROR_SYSTEM_ERROR_H | ||||
| 
 | ||||
| #include <__config> | ||||
| #include <__system_error/errc.h> | ||||
| #include <__system_error/error_category.h> | ||||
| #include <__system_error/error_code.h> | ||||
| #include <__verbose_abort> | ||||
|  |  | |||
|  | @ -1,11 +1,8 @@ | |||
| #ifdef __COSMOPOLITAN__ | ||||
| #include <filesystem> | ||||
| #include <__system_error/errc.h> | ||||
| 
 | ||||
| _LIBCPP_BEGIN_NAMESPACE_FILESYSTEM | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
| 
 | ||||
| namespace detail { | ||||
| 
 | ||||
| std::errc __cosmo_err_to_errc_impl(int err) { | ||||
| static std::errc __err_to_errc_impl(int err) noexcept { | ||||
|   if (err == EAFNOSUPPORT) return errc::address_family_not_supported; | ||||
|   if (err == EADDRINUSE) return errc::address_in_use; | ||||
|   if (err == EADDRNOTAVAIL) return errc::address_not_available; | ||||
|  | @ -87,7 +84,7 @@ std::errc __cosmo_err_to_errc_impl(int err) { | |||
|   return errc::not_supported; | ||||
| } | ||||
| 
 | ||||
| int __cosmo_errc_to_err_impl(std::errc err) { | ||||
| static int __errc_to_err_impl(std::errc err) noexcept { | ||||
|   if (err == errc::address_family_not_supported) return EAFNOSUPPORT; | ||||
|   if (err == errc::address_in_use) return EADDRINUSE; | ||||
|   if (err == errc::address_not_available) return EADDRNOTAVAIL; | ||||
|  | @ -169,20 +166,20 @@ int __cosmo_errc_to_err_impl(std::errc err) { | |||
|   return ENOTSUP; | ||||
| } | ||||
| 
 | ||||
| std::errc __cosmo_err_to_errc(int err) { | ||||
| std::errc __err_to_errc(int err) noexcept { | ||||
|   if (!err) | ||||
|     return (std::errc)0; | ||||
|   if (err >= 65536) | ||||
|     return (std::errc)err; | ||||
|   return __cosmo_err_to_errc_impl(err); | ||||
|   return __err_to_errc_impl(err); | ||||
| } | ||||
| 
 | ||||
| int __cosmo_errc_to_err(std::errc err) { | ||||
| int __errc_to_err(std::errc err) noexcept { | ||||
|   if (!(int)err) | ||||
|     return 0; | ||||
|   if ((int)err < 65536) | ||||
|     return (int)err; | ||||
|   return __cosmo_errc_to_err_impl(err); | ||||
|   return __errc_to_err_impl(err); | ||||
| } | ||||
| 
 | ||||
| } // end namespace detail
 | ||||
| 
 | ||||
| _LIBCPP_END_NAMESPACE_FILESYSTEM | ||||
| 
 | ||||
| #endif // __COSMOPOLITAN__
 | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
							
								
								
									
										8
									
								
								third_party/libcxx/fs/directory_iterator.cpp
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								third_party/libcxx/fs/directory_iterator.cpp
									
										
									
									
										vendored
									
									
								
							|  | @ -118,11 +118,7 @@ public: | |||
|     if ((__stream_ = ::opendir(root.c_str())) == nullptr) { | ||||
|       ec                      = detail::capture_errno(); | ||||
|       const bool allow_eacces = bool(opts & directory_options::skip_permission_denied); | ||||
| #ifdef __COSMOPOLITAN__ | ||||
|       if (allow_eacces && ec.value() == (int)errc::permission_denied) | ||||
| #else | ||||
|       if (allow_eacces && ec.value() == EACCES) | ||||
| #endif | ||||
|         ec.clear(); | ||||
|       return; | ||||
|     } | ||||
|  | @ -311,11 +307,7 @@ bool recursive_directory_iterator::__try_recursion(error_code* ec) { | |||
|   } | ||||
|   if (m_ec) { | ||||
|     const bool allow_eacess = bool(__imp_->__options_ & directory_options::skip_permission_denied); | ||||
| #ifdef __COSMOPOLITAN__ | ||||
|     if (m_ec.value() == (int)errc::permission_denied && allow_eacess) { | ||||
| #else | ||||
|     if (m_ec.value() == EACCES && allow_eacess) { | ||||
| #endif | ||||
|       if (ec) | ||||
|         ec->clear(); | ||||
|     } else { | ||||
|  |  | |||
							
								
								
									
										9
									
								
								third_party/libcxx/fs/error.h
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								third_party/libcxx/fs/error.h
									
										
									
									
										vendored
									
									
								
							|  | @ -98,16 +98,9 @@ inline errc __win_err_to_errc(int err) { | |||
| 
 | ||||
| #endif // _LIBCPP_WIN32API
 | ||||
| 
 | ||||
| errc __cosmo_err_to_errc(int); | ||||
| int __cosmo_errc_to_err(errc); | ||||
| 
 | ||||
| inline error_code capture_errno() { | ||||
|   _LIBCPP_ASSERT_INTERNAL(errno != 0, "Expected errno to be non-zero"); | ||||
| #ifdef __COSMOPOLITAN__ | ||||
|   return error_code((int)__cosmo_err_to_errc(errno), generic_category()); | ||||
| #else | ||||
|   return error_code(errno, generic_category()); | ||||
| #endif | ||||
|   return error_code((int)__err_to_errc(errno), generic_category()); | ||||
| } | ||||
| 
 | ||||
| #if defined(_LIBCPP_WIN32API) | ||||
|  |  | |||
							
								
								
									
										4
									
								
								third_party/libcxx/fs/file_descriptor.h
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								third_party/libcxx/fs/file_descriptor.h
									
										
									
									
										vendored
									
									
								
							|  | @ -194,12 +194,8 @@ inline perms posix_get_perms(const StatT& st) noexcept { return static_cast<perm | |||
| inline file_status create_file_status(error_code& m_ec, path const& p, const StatT& path_stat, error_code* ec) { | ||||
|   if (ec) | ||||
|     *ec = m_ec; | ||||
| #ifdef __COSMOPOLITAN__ | ||||
|   if (m_ec && (m_ec.value() == (int)errc::no_such_file_or_directory || | ||||
|                m_ec.value() == (int)errc::not_a_directory)) { | ||||
| #else | ||||
|   if (m_ec && (m_ec.value() == ENOENT || m_ec.value() == ENOTDIR)) { | ||||
| #endif | ||||
|     return file_status(file_type::not_found); | ||||
|   } else if (m_ec) { | ||||
|     ErrorHandler<void> err("posix_stat", ec, &p); | ||||
|  |  | |||
							
								
								
									
										1
									
								
								third_party/libcxx/ios
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								third_party/libcxx/ios
									
										
									
									
										vendored
									
									
								
							|  | @ -13,6 +13,7 @@ | |||
| /* | ||||
|     ios synopsis | ||||
| 
 | ||||
| #include "third_party/libcxx/__system_error/error_code.h" | ||||
| #include <iosfwd> | ||||
| 
 | ||||
| namespace std | ||||
|  |  | |||
							
								
								
									
										2
									
								
								third_party/libcxx/system_error
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								third_party/libcxx/system_error
									
										
									
									
										vendored
									
									
								
							|  | @ -146,8 +146,8 @@ template <> struct hash<std::error_condition>; | |||
| 
 | ||||
| #include <__config> | ||||
| #include <__system_error/errc.h> | ||||
| #include <__system_error/error_category.h> | ||||
| #include <__system_error/error_code.h> | ||||
| #include <__system_error/error_category.h> | ||||
| #include <__system_error/error_condition.h> | ||||
| #include <__system_error/system_error.h> | ||||
| #include <version> | ||||
|  |  | |||
							
								
								
									
										31
									
								
								third_party/libcxx/system_error.cpp
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										31
									
								
								third_party/libcxx/system_error.cpp
									
										
									
									
										vendored
									
									
								
							|  | @ -16,6 +16,7 @@ | |||
| #include <string.h> | ||||
| #include <string> | ||||
| #include <system_error> | ||||
| #include <__system_error/errc.h> | ||||
| 
 | ||||
| #include "config_elast.h" | ||||
| 
 | ||||
|  | @ -23,10 +24,6 @@ | |||
| #  include <android/api-level.h> | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __COSMOPOLITAN__ | ||||
| #include <fs/error.h> | ||||
| #endif | ||||
| 
 | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
| 
 | ||||
| namespace { | ||||
|  | @ -39,9 +36,7 @@ string do_strerror_r(int ev); | |||
| 
 | ||||
| #  if defined(_LIBCPP_MSVCRT_LIKE) | ||||
| string do_strerror_r(int ev) { | ||||
| #ifdef __COSMOPOLITAN__ | ||||
|   ev = (int)filesystem::detail::__cosmo_errc_to_err(ev); | ||||
| #endif | ||||
|   ev = __errc_to_err(ev); | ||||
|   char buffer[strerror_buff_size]; | ||||
|   if (::strerror_s(buffer, strerror_buff_size, ev) == 0) | ||||
|     return string(buffer); | ||||
|  | @ -88,9 +83,7 @@ string do_strerror_r(int ev) { | |||
|   // Preserve errno around the call. (The C++ standard requires that
 | ||||
|   // system_error functions not modify errno).
 | ||||
|   const int old_errno       = errno; | ||||
| #ifdef __COSMOPOLITAN__ | ||||
|   ev = filesystem::detail::__cosmo_errc_to_err((errc)ev); | ||||
| #endif | ||||
|   ev = __errc_to_err((errc)ev); | ||||
|   const char* error_message = handle_strerror_r_return(::strerror_r(ev, buffer, strerror_buff_size), buffer); | ||||
|   // If we didn't get any message, print one now.
 | ||||
|   if (!error_message[0]) { | ||||
|  | @ -139,9 +132,7 @@ public: | |||
| const char* __generic_error_category::name() const noexcept { return "generic"; } | ||||
| 
 | ||||
| string __generic_error_category::message(int ev) const { | ||||
| #ifdef __COSMOPOLITAN__ | ||||
|   ev = filesystem::detail::__cosmo_errc_to_err((errc)ev); | ||||
| #endif | ||||
|   ev = __errc_to_err((errc)ev); | ||||
| #ifdef _LIBCPP_ELAST | ||||
|   if (ev > _LIBCPP_ELAST) | ||||
|     return string("unspecified generic_category error"); | ||||
|  | @ -169,9 +160,7 @@ public: | |||
| const char* __system_error_category::name() const noexcept { return "system"; } | ||||
| 
 | ||||
| string __system_error_category::message(int ev) const { | ||||
| #ifdef __COSMOPOLITAN__ | ||||
|   ev = filesystem::detail::__cosmo_errc_to_err((errc)ev); | ||||
| #endif | ||||
|   ev = __errc_to_err((errc)ev); | ||||
| #ifdef _LIBCPP_ELAST | ||||
|   if (ev > _LIBCPP_ELAST) | ||||
|     return string("unspecified system_category error"); | ||||
|  | @ -180,9 +169,7 @@ string __system_error_category::message(int ev) const { | |||
| } | ||||
| 
 | ||||
| error_condition __system_error_category::default_error_condition(int ev) const noexcept { | ||||
| #ifdef __COSMOPOLITAN__ | ||||
|   ev = filesystem::detail::__cosmo_errc_to_err((errc)ev); | ||||
| #endif | ||||
|   ev = __errc_to_err((errc)ev); | ||||
| #ifdef _LIBCPP_ELAST | ||||
|   if (ev > _LIBCPP_ELAST) | ||||
|     return error_condition(ev, system_category()); | ||||
|  | @ -231,11 +218,7 @@ system_error::~system_error() noexcept {} | |||
| 
 | ||||
| void __throw_system_error(int ev, const char* what_arg) { | ||||
| #ifndef _LIBCPP_HAS_NO_EXCEPTIONS | ||||
| #ifdef __COSMOPOLITAN__ | ||||
|   std::__throw_system_error(error_code((int)filesystem::detail::__cosmo_err_to_errc(ev), system_category()), what_arg); | ||||
| #else | ||||
|   std::__throw_system_error(error_code(ev, system_category()), what_arg); | ||||
| #endif | ||||
|   std::__throw_system_error(error_code((int)__err_to_errc(ev), system_category()), what_arg); | ||||
| #else | ||||
|   // The above could also handle the no-exception case, but for size, avoid referencing system_category() unnecessarily.
 | ||||
|   _LIBCPP_VERBOSE_ABORT( | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue