Compare commits
	
		
			1 Commits
		
	
	
		
			release_34
			...
			svn-tags/l
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 39f9709e7f | 
| @@ -1,4 +0,0 @@ | ||||
| { | ||||
|   "project_id" : "libcxx", | ||||
|   "conduit_uri" : "http://llvm-reviews.chandlerc.com/" | ||||
| } | ||||
							
								
								
									
										144
									
								
								CMakeLists.txt
									
									
									
									
									
								
							
							
						
						
									
										144
									
								
								CMakeLists.txt
									
									
									
									
									
								
							| @@ -14,9 +14,9 @@ set(PACKAGE_BUGREPORT "llvmbugs@cs.uiuc.edu") | ||||
|  | ||||
| # Add path for custom modules | ||||
| set(CMAKE_MODULE_PATH | ||||
|   ${CMAKE_MODULE_PATH} | ||||
|   "${CMAKE_CURRENT_SOURCE_DIR}/cmake" | ||||
|   "${CMAKE_CURRENT_SOURCE_DIR}/cmake/Modules" | ||||
|   ${CMAKE_MODULE_PATH} | ||||
|   ) | ||||
|  | ||||
| # Require out of source build. | ||||
| @@ -26,10 +26,6 @@ MACRO_ENSURE_OUT_OF_SOURCE_BUILD( | ||||
|  build directory and run 'cmake /path/to/${PROJECT_NAME} [options]' there." | ||||
|  ) | ||||
|  | ||||
| if(CMAKE_SOURCE_DIR STREQUAL CMAKE_CURRENT_SOURCE_DIR) | ||||
|   set(LIBCXX_BUILT_STANDALONE 1) | ||||
| endif() | ||||
|  | ||||
| #=============================================================================== | ||||
| # Setup CMake Options | ||||
| #=============================================================================== | ||||
| @@ -42,15 +38,6 @@ option(LIBCXX_ENABLE_PEDANTIC "Compile with pedantic enabled." ON) | ||||
| option(LIBCXX_ENABLE_WERROR "Fail and stop if a warning is triggered." OFF) | ||||
| option(LIBCXX_ENABLE_CXX0X "Enable -std=c++0x and use of c++0x language features if the compiler supports it." ON) | ||||
| option(LIBCXX_ENABLE_SHARED "Build libc++ as a shared library." ON) | ||||
| option(LIBCXX_INSTALL_SUPPORT_HEADERS "Install libc++ support headers." ON) | ||||
|  | ||||
| set(CXXABIS none libcxxabi libcxxrt libstdc++ libsupc++) | ||||
| if (NOT DEFINED LIBCXX_CXX_ABI) | ||||
|   set(LIBCXX_CXX_ABI "none") | ||||
| endif() | ||||
| set(LIBCXX_CXX_ABI "${LIBCXX_CXX_ABI}" CACHE STRING | ||||
|     "Specify C++ ABI library to use." FORCE) | ||||
| set_property(CACHE LIBCXX_CXX_ABI PROPERTY STRINGS ;${CXXABIS}) | ||||
|  | ||||
| #=============================================================================== | ||||
| # Configure System | ||||
| @@ -71,100 +58,6 @@ get_target_triple(LIBCXX_TARGET_TRIPLE | ||||
|   ) | ||||
| set(LIBCXX_TARGET_TRIPLE ${LIBCXX_TARGET_TRIPLE} CACHE STRING "Target triple.") | ||||
|  | ||||
| #=============================================================================== | ||||
| # Add an ABI library if appropriate | ||||
| #=============================================================================== | ||||
|  | ||||
| # | ||||
| # _setup_abi: Set up the build to use an ABI library | ||||
| # | ||||
| # Parameters: | ||||
| #   abidefines: A list of defines needed to compile libc++ with the ABI library | ||||
| #   abilibs   : A list of libraries to link against | ||||
| #   abifiles  : A list of files (which may be relative paths) to copy into the | ||||
| #               libc++ build tree for the build.  These files will also be | ||||
| #               installed alongside the libc++ headers. | ||||
| #   abidirs   : A list of relative paths to create under an include directory | ||||
| #               in the libc++ build directory. | ||||
| # | ||||
| macro(setup_abi_lib abipathvar abidefines abilibs abifiles abidirs) | ||||
|   list(APPEND LIBCXX_CXX_FEATURE_FLAGS ${abidefines}) | ||||
|   set(${abipathvar} "${${abipathvar}}" | ||||
|     CACHE STRINGS | ||||
|     "Paths to ABI include directories separate by ';'." | ||||
|     ) | ||||
|   set(LIBCXX_CXX_ABI_LIBRARIES ${abilibs}) | ||||
|   set(LIBCXX_ABILIB_FILES ${abifiles}) | ||||
|   file(MAKE_DIRECTORY "${CMAKE_BINARY_DIR}/include") | ||||
|   foreach(_d ${abidirs}) | ||||
|     file(MAKE_DIRECTORY "${CMAKE_BINARY_DIR}/include/${_d}") | ||||
|   endforeach() | ||||
|   set(LIBCXX_ABILIB_FILE_PATHS) | ||||
|   foreach(fpath ${LIBCXX_ABILIB_FILES}) | ||||
|     set(found FALSE) | ||||
|     foreach(incpath ${${abipathvar}}) | ||||
|       if (EXISTS "${incpath}/${fpath}") | ||||
|         set(found TRUE) | ||||
|         get_filename_component(dstdir ${fpath} PATH) | ||||
|         get_filename_component(ifile ${fpath} NAME) | ||||
|         add_custom_command( | ||||
|           OUTPUT "${CMAKE_BINARY_DIR}/include/${dstdir}/${ifile}" | ||||
|           COMMAND ${CMAKE_COMMAND} -E copy_if_different | ||||
|             "${incpath}/${fpath}" | ||||
|             "${CMAKE_BINARY_DIR}/include/${dstdir}" | ||||
|           MAIN_DEPENDENCY "${incpath}/${fpath}" | ||||
|           ) | ||||
|         list(APPEND LIBCXX_CXX_ABI_DEPS | ||||
|           "${CMAKE_BINARY_DIR}/include/${dstdir}/${ifile}" | ||||
|           ) | ||||
|       endif() | ||||
|     endforeach() | ||||
|     if (NOT found) | ||||
|       message(FATAL_ERROR "Failed to find ${fpath}") | ||||
|     endif() | ||||
|   endforeach() | ||||
|   add_custom_target(abilib_headers DEPENDS ${LIBCXX_CXX_ABI_DEPS}) | ||||
|   set(LIBCXX_CXX_ABI_DEPS abilib_headers) | ||||
|   include_directories("${CMAKE_BINARY_DIR}/include") | ||||
|   install(DIRECTORY "${CMAKE_BINARY_DIR}/include/" | ||||
|     DESTINATION include/c++/v1 | ||||
|     FILES_MATCHING | ||||
|     PATTERN "*" | ||||
|     ) | ||||
| endmacro() | ||||
|  | ||||
| if ("${LIBCXX_CXX_ABI}" STREQUAL "libstdc++" OR | ||||
|     "${LIBCXX_CXX_ABI}" STREQUAL "libsupc++") | ||||
|   set(_LIBSUPCXX_INCLUDE_FILES | ||||
|     cxxabi.h bits/c++config.h bits/os_defines.h bits/cpu_defines.h | ||||
|     bits/cxxabi_tweaks.h bits/cxxabi_forced.h | ||||
|     ) | ||||
|   if ("${LIBCXX_CXX_ABI}" STREQUAL "libstdc++") | ||||
|     set(_LIBSUPCXX_DEFINES "-DLIBSTDCXX") | ||||
|     set(_LIBSUPCXX_LIBNAME stdc++) | ||||
|   else() | ||||
|     set(_LIBSUPCXX_DEFINES "") | ||||
|     set(_LIBSUPCXX_LIBNAME supc++) | ||||
|   endif() | ||||
|   setup_abi_lib("LIBCXX_LIBSUPCXX_INCLUDE_PATHS" | ||||
|     "-D__GLIBCXX__ ${_LIBSUPCXX_DEFINES}" | ||||
|     "${_LIBSUPCXX_LIBNAME}" "${_LIBSUPCXX_INCLUDE_FILES}" "bits" | ||||
|     ) | ||||
| elseif ("${LIBCXX_CXX_ABI}" STREQUAL "libcxxabi") | ||||
|   setup_abi_lib("LIBCXX_LIBCXXABI_INCLUDE_PATHS" "" | ||||
|     "c++abi" "cxxabi.h" "" | ||||
|     ) | ||||
| elseif ("${LIBCXX_CXX_ABI}" STREQUAL "libcxxrt") | ||||
|   setup_abi_lib("LIBCXX_LIBCXXRT_INCLUDE_PATHS" "-DLIBCXXRT" | ||||
|     "cxxrt" "cxxabi.h;unwind.h;unwind-arm.h;unwind-itanium.h" "" | ||||
|     ) | ||||
| elseif (NOT "${LIBCXX_CXX_ABI}" STREQUAL "none") | ||||
|   message(FATAL_ERROR | ||||
|     "Currently libstdc++, libsupc++, libcxxabi, libcxxrt and none are " | ||||
|     "supported for c++ abi." | ||||
|     ) | ||||
| endif () | ||||
|  | ||||
| # Configure compiler. | ||||
| include(config-ix) | ||||
|  | ||||
| @@ -194,24 +87,17 @@ macro(append_if list condition var) | ||||
| endmacro() | ||||
|  | ||||
| # Get warning flags | ||||
| if (NOT MSVC) | ||||
|   append_if(LIBCXX_CXX_WARNING_FLAGS LIBCXX_HAS_WALL_FLAG -Wall) | ||||
|   set(LIBCXX_CXX_REQUIRED_FLAGS, -Werror=return-type) | ||||
| endif() | ||||
|  | ||||
| append_if(LIBCXX_CXX_WARNING_FLAGS LIBCXX_HAS_W_FLAG -W) | ||||
| append_if(LIBCXX_CXX_WARNING_FLAGS LIBCXX_HAS_WNO_UNUSED_PARAMETER_FLAG -Wno-unused-parameter) | ||||
| append_if(LIBCXX_CXX_WARNING_FLAGS LIBCXX_HAS_WWRITE_STRINGS_FLAG -Wwrite-strings) | ||||
| append_if(LIBCXX_CXX_WARNING_FLAGS LIBCXX_HAS_WNO_LONG_LONG_FLAG -Wno-long-long) | ||||
| append_if(LIBCXX_WARNING_FLAGS LIBCXX_HAS_WALL_FLAG -Wall) | ||||
| append_if(LIBCXX_WARNING_FLAGS LIBCXX_HAS_W_FLAG -W) | ||||
| append_if(LIBCXX_WARNING_FLAGS LIBCXX_HAS_WNO_UNUSED_PARAMETER_FLAG -Wno-unused-parameter) | ||||
| append_if(LIBCXX_WARNING_FLAGS LIBCXX_HAS_WWRITE_STRINGS_FLAG -Wwrite-strings) | ||||
| append_if(LIBCXX_WARNING_FLAGS LIBCXX_HAS_WNO_LONG_LONG_FLAG -Wno-long-long) | ||||
| if (LIBCXX_ENABLE_WERROR) | ||||
|   append_if(LIBCXX_CXX_WARNING_FLAGS LIBCXX_HAS_WERROR_FLAG -Werror) | ||||
|   append_if(LIBCXX_CXX_WARNING_FLAGS LIBCXX_HAS_WX_FLAG -WX) | ||||
| else() | ||||
|   append_if(LIBCXX_CXX_WARNING_FLAGS LIBCXX_HAS_WNO_ERROR_FLAG -Wno-error) | ||||
|   append_if(LIBCXX_CXX_WARNING_FLAGS LIBCXX_HAS_NO_WX_FLAG -WX-) | ||||
|   append_if(LIBCXX_WARNING_FLAGS LIBCXX_HAS_WERROR_FLAG -Werror) | ||||
|   append_if(LIBCXX_WARNING_FLAGS LIBCXX_HAS_WX_FLAG -WX) | ||||
| endif() | ||||
| if (LIBCXX_ENABLE_PEDANTIC) | ||||
|   append_if(LIBCXX_CXX_WARNING_FLAGS LIBCXX_HAS_PEDANTIC_FLAG -pedantic) | ||||
|   append_if(LIBCXX_WARNING_FLAGS LIBCXX_HAS_PEDANTIC_FLAG -pedantic) | ||||
| endif() | ||||
|  | ||||
| # Get feature flags. | ||||
| @@ -233,8 +119,7 @@ if (NOT LIBCXX_ENABLE_RTTI) | ||||
|   append_if(LIBCXX_CXX_FEATURE_FLAGS LIBCXX_HAS_FNO_RTTI_FLAG -fno-rtti) | ||||
| endif() | ||||
| # Assert | ||||
| string(TOUPPER "${CMAKE_BUILD_TYPE}" uppercase_CMAKE_BUILD_TYPE) | ||||
| if (LIBCXX_ENABLE_ASSERTIONS) | ||||
| if (LLVM_ENABLE_ASSERTIONS) | ||||
|   # MSVC doesn't like _DEBUG on release builds. See PR 4379. | ||||
|   if (NOT MSVC) | ||||
|     list(APPEND LIBCXX_CXX_FEATURE_FLAGS -D_DEBUG) | ||||
| @@ -249,16 +134,8 @@ else() | ||||
|     list(APPEND LIBCXX_CXX_FEATURE_FLAGS -DNDEBUG) | ||||
|   endif() | ||||
| endif() | ||||
| # Static library | ||||
| if (NOT LIBCXX_ENABLE_SHARED) | ||||
|   list(APPEND LIBCXX_CXX_FEATURE_FLAGS -D_LIBCPP_BUILD_STATIC) | ||||
| endif() | ||||
|  | ||||
| # This is the _ONLY_ place where add_definitions is called. | ||||
| if (MSVC) | ||||
|   add_definitions(-D_CRT_SECURE_NO_WARNINGS) | ||||
| endif() | ||||
|  | ||||
| add_definitions( | ||||
|  ${LIBCXX_CXX_REQUIRED_FLAGS} | ||||
|  ${LIBCXX_CXX_WARNING_FLAGS} | ||||
| @@ -270,7 +147,6 @@ add_definitions( | ||||
| #=============================================================================== | ||||
|  | ||||
| include_directories(include) | ||||
| add_subdirectory(include) | ||||
|  | ||||
| # Add source code. This also contains all of the logic for deciding linker flags | ||||
| # soname, etc... | ||||
|   | ||||
							
								
								
									
										111
									
								
								CREDITS.TXT
									
									
									
									
									
								
							
							
						
						
									
										111
									
								
								CREDITS.TXT
									
									
									
									
									
								
							| @@ -8,116 +8,11 @@ beautification by scripts.  The fields are: name (N), email (E), web-address | ||||
| (W), PGP key ID and fingerprint (P), description (D), and snail-mail address | ||||
| (S). | ||||
|  | ||||
| N: Saleem Abdulrasool | ||||
| E: compnerd@compnerd.org | ||||
| D: Minor patches and Linux fixes. | ||||
|  | ||||
| N: Dimitry Andric | ||||
| E: dimitry@andric.com | ||||
| D: Visibility fixes, minor FreeBSD portability patches. | ||||
|  | ||||
| N: Holger Arnold | ||||
| E: holgerar@gmail.com | ||||
| D: Minor fix. | ||||
|  | ||||
| N: Ruben Van Boxem | ||||
| E: vanboxem dot ruben at gmail dot com | ||||
| D: Initial Windows patches. | ||||
|  | ||||
| N: David Chisnall | ||||
| E: theraven at theravensnest dot org | ||||
| D: FreeBSD and Solaris ports, libcxxrt support, some atomics work. | ||||
|  | ||||
| N: Marshall Clow | ||||
| E: mclow.lists@gmail.com | ||||
| E: marshall@idio.com | ||||
| D: C++14 support, patches and bug fixes. | ||||
|  | ||||
| N: Bill Fisher | ||||
| E: william.w.fisher@gmail.com | ||||
| D: Regex bug fixes. | ||||
|  | ||||
| N: Matthew Dempsky | ||||
| E: matthew@dempsky.org | ||||
| D: Minor patches and bug fixes. | ||||
|  | ||||
| N: Google Inc. | ||||
| D: Copyright owner and contributor of the CityHash algorithm | ||||
|  | ||||
| N: Howard Hinnant | ||||
| E: hhinnant@apple.com | ||||
| D: Architect and primary author of libc++ | ||||
|  | ||||
| N: Hyeon-bin Jeong | ||||
| E: tuhertz@gmail.com | ||||
| N: Marshall Clow | ||||
| E: marshall@idio.com | ||||
| E: mclow@qualcomm.com | ||||
| D: Minor patches and bug fixes. | ||||
|  | ||||
| N: Argyrios Kyrtzidis | ||||
| E: kyrtzidis@apple.com | ||||
| D: Bug fixes. | ||||
|  | ||||
| N: Bruce Mitchener, Jr. | ||||
| E: bruce.mitchener@gmail.com | ||||
| D: Emscripten-related changes. | ||||
|  | ||||
| N: Michel Morin | ||||
| E: mimomorin@gmail.com | ||||
| D: Minor patches to is_convertible. | ||||
|  | ||||
| N: Andrew Morrow | ||||
| E: andrew.c.morrow@gmail.com | ||||
| D: Minor patches and Linux fixes. | ||||
|  | ||||
| N: Arvid Picciani | ||||
| E: aep at exys dot org | ||||
| D: Minor patches and musl port. | ||||
|  | ||||
| N: Bjorn Reese | ||||
| E: breese@users.sourceforge.net | ||||
| D: Initial regex prototype | ||||
|  | ||||
| N: Nico Rieck | ||||
| E: nico.rieck@gmail.com | ||||
| D: Windows fixes | ||||
|  | ||||
| N: Jonathan Sauer | ||||
| D: Minor patches, mostly related to constexpr | ||||
|  | ||||
| N: Craig Silverstein | ||||
| E: csilvers@google.com | ||||
| D: Implemented Cityhash as the string hash function on 64-bit machines | ||||
|  | ||||
| N: Richard Smith | ||||
| D: Minor patches. | ||||
|  | ||||
| N: Joerg Sonnenberger | ||||
| E: joerg@NetBSD.org | ||||
| D: NetBSD port. | ||||
|  | ||||
| N: Stephan Tolksdorf | ||||
| E: st@quanttec.com | ||||
| D: Minor <atomic> fix | ||||
|  | ||||
| N: Michael van der Westhuizen | ||||
| E: r1mikey at gmail dot com | ||||
|  | ||||
| N: Klaas de Vries | ||||
| E: klaas at klaasgaaf dot nl | ||||
| D: Minor bug fix. | ||||
|  | ||||
| N: Zhang Xiongpang | ||||
| E: zhangxiongpang@gmail.com | ||||
| D: Minor patches and bug fixes. | ||||
|  | ||||
| N: Xing Xue | ||||
| E: xingxue@ca.ibm.com | ||||
| D: AIX port | ||||
|  | ||||
| N: Zhihao Yuan | ||||
| E: lichray@gmail.com | ||||
| D: Standard compatibility fixes. | ||||
|  | ||||
| N: Jeffrey Yasskin | ||||
| E: jyasskin@gmail.com | ||||
| E: jyasskin@google.com | ||||
| D: Linux fixes. | ||||
|   | ||||
| @@ -14,7 +14,7 @@ Full text of the relevant licenses is included below. | ||||
| University of Illinois/NCSA | ||||
| Open Source License | ||||
|  | ||||
| Copyright (c) 2009-2013 by the contributors listed in CREDITS.TXT | ||||
| Copyright (c) 2009-2010 by the contributors listed in CREDITS.TXT | ||||
|  | ||||
| All rights reserved. | ||||
|  | ||||
| @@ -55,7 +55,7 @@ SOFTWARE. | ||||
|  | ||||
| ============================================================================== | ||||
|  | ||||
| Copyright (c) 2009-2013 by the contributors listed in CREDITS.TXT | ||||
| Copyright (c) 2009-2010 by the contributors listed in CREDITS.TXT | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| of this software and associated documentation files (the "Software"), to deal | ||||
|   | ||||
							
								
								
									
										46
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										46
									
								
								Makefile
									
									
									
									
									
								
							| @@ -1,5 +1,5 @@ | ||||
| ## | ||||
| # libc++ Makefile | ||||
| # libcpp Makefile | ||||
| ## | ||||
|  | ||||
| SRCDIRS = . | ||||
| @@ -9,18 +9,6 @@ OBJROOT=. | ||||
| SYMROOT=. | ||||
| export TRIPLE=-apple- | ||||
|  | ||||
| ifeq (,$(RC_INDIGO)) | ||||
| 	INSTALL_PREFIX="" | ||||
| else | ||||
| 	INSTALL_PREFIX="$(SDKROOT)" | ||||
| endif | ||||
| INSTALL_DIR=$(DSTROOT)/$(INSTALL_PREFIX) | ||||
|  | ||||
| .PHONY: help installsrc clean installheaders install | ||||
|  | ||||
| help:: | ||||
| 	@echo "Use make install DSTROOT=<destination>" | ||||
|  | ||||
| installsrc:: $(SRCROOT) | ||||
|  | ||||
| 	ditto $(SRCDIRS)/include $(SRCROOT)/include | ||||
| @@ -30,25 +18,21 @@ installsrc:: $(SRCROOT) | ||||
|  | ||||
| clean:: | ||||
|  | ||||
| # The installheaders target is used by clang's runtime/libcxx makefile. | ||||
| installheaders:: | ||||
| 	mkdir -p $(HEADER_DIR)/c++/v1/ext | ||||
| 	(cd $(SRCDIRS)/include && tar cf - --exclude=support .) | \ | ||||
| 	  (cd $(HEADER_DIR)/c++/v1 && tar xf -) | ||||
| 	chmod 755 $(HEADER_DIR)/c++/v1 | ||||
| 	chmod 644 $(HEADER_DIR)/c++/v1/* | ||||
| 	chmod 755 $(HEADER_DIR)/c++/v1/ext | ||||
| 	chmod 644 $(HEADER_DIR)/c++/v1/ext/* | ||||
| 	chmod 755 $(HEADER_DIR)/c++/v1/experimental | ||||
| 	chmod 644 $(HEADER_DIR)/c++/v1/experimental/* | ||||
| installhdrs:: | ||||
|  | ||||
| install:: | ||||
| 	mkdir -p $(DSTROOT)/usr/include/c++/v1/ext | ||||
| 	rsync -r --exclude=".*" $(SRCDIRS)/include/* $(DSTROOT)/usr/include/c++/v1/ | ||||
| 	chown -R root:wheel $(DSTROOT)/usr/include | ||||
| 	chmod 755 $(DSTROOT)/usr/include/c++/v1 | ||||
| 	chmod 644 $(DSTROOT)/usr/include/c++/v1/* | ||||
| 	chmod 755 $(DSTROOT)/usr/include/c++/v1/ext | ||||
| 	chmod 644 $(DSTROOT)/usr/include/c++/v1/ext/* | ||||
|  | ||||
| install:: installhdrs $(DESTDIR) | ||||
|  | ||||
| 	cd lib && ./buildit | ||||
| 	ditto lib/libc++.1.dylib $(SYMROOT)/usr/lib/libc++.1.dylib | ||||
| 	cd lib && dsymutil -o $(SYMROOT)/libc++.1.dylib.dSYM \ | ||||
| 	  $(SYMROOT)/usr/lib/libc++.1.dylib | ||||
| 	mkdir -p $(INSTALL_DIR)/usr/lib | ||||
| 	strip -S -o $(INSTALL_DIR)/usr/lib/libc++.1.dylib \ | ||||
| 	  $(SYMROOT)/usr/lib/libc++.1.dylib | ||||
| 	cd $(INSTALL_DIR)/usr/lib && ln -s libc++.1.dylib libc++.dylib | ||||
| 	cd lib && dsymutil -o $(SYMROOT)/libc++.1.dylib.dSYM  $(SYMROOT)/usr/lib/libc++.1.dylib | ||||
| 	mkdir -p $(DSTROOT)/usr/lib | ||||
| 	strip -S -o $(DSTROOT)/usr/lib/libc++.1.dylib $(SYMROOT)/usr/lib/libc++.1.dylib | ||||
| 	cd $(DSTROOT)/usr/lib && ln -s libc++.1.dylib libc++.dylib | ||||
|   | ||||
| @@ -13,11 +13,9 @@ check_cxx_compiler_flag(-Wwrite-strings       LIBCXX_HAS_WWRITE_STRINGS_FLAG) | ||||
| check_cxx_compiler_flag(-Wno-long-long        LIBCXX_HAS_WNO_LONG_LONG_FLAG) | ||||
| check_cxx_compiler_flag(-pedantic             LIBCXX_HAS_PEDANTIC_FLAG) | ||||
| check_cxx_compiler_flag(-Werror               LIBCXX_HAS_WERROR_FLAG) | ||||
| check_cxx_compiler_flag(-Wno-error            LIBCXX_HAS_WNO_ERROR_FLAG) | ||||
| check_cxx_compiler_flag(-fno-exceptions       LIBCXX_HAS_FNO_EXCEPTIONS_FLAG) | ||||
| check_cxx_compiler_flag(-fno-rtti             LIBCXX_HAS_FNO_RTTI_FLAG) | ||||
| check_cxx_compiler_flag(/WX                   LIBCXX_HAS_WX_FLAG) | ||||
| check_cxx_compiler_flag(/WX-                  LIBCXX_HAS_NO_WX_FLAG) | ||||
| check_cxx_compiler_flag(/EHsc                 LIBCXX_HAS_EHSC_FLAG) | ||||
| check_cxx_compiler_flag(/EHs-                 LIBCXX_HAS_NO_EHS_FLAG) | ||||
| check_cxx_compiler_flag(/EHa-                 LIBCXX_HAS_NO_EHA_FLAG) | ||||
| @@ -27,7 +25,6 @@ check_cxx_compiler_flag(/GR-                  LIBCXX_HAS_NO_GR_FLAG) | ||||
| check_library_exists(pthread pthread_create "" LIBCXX_HAS_PTHREAD_LIB) | ||||
| check_library_exists(c printf "" LIBCXX_HAS_C_LIB) | ||||
| check_library_exists(m ccos "" LIBCXX_HAS_M_LIB) | ||||
| check_library_exists(rt clock_gettime "" LIBCXX_HAS_RT_LIB) | ||||
| check_library_exists(gcc_s __gcc_personality_v0 "" LIBCXX_HAS_GCC_S_LIB) | ||||
|  | ||||
| # Check C++0x features | ||||
|   | ||||
| @@ -1,16 +0,0 @@ | ||||
| if (NOT LIBCXX_INSTALL_SUPPORT_HEADERS) | ||||
|   set(LIBCXX_SUPPORT_HEADER_PATTERN PATTERN "support" EXCLUDE) | ||||
| endif() | ||||
|  | ||||
| file(COPY . | ||||
|   DESTINATION "${CMAKE_BINARY_DIR}/include/c++/v1" | ||||
|   FILES_MATCHING | ||||
|   PATTERN "*" | ||||
|   PATTERN "CMakeLists.txt" EXCLUDE | ||||
|   PATTERN ".svn" EXCLUDE | ||||
|   ${LIBCXX_SUPPORT_HEADER_PATTERN} | ||||
|   ) | ||||
|  | ||||
| install(DIRECTORY "${CMAKE_BINARY_DIR}/include/c++/v1/" | ||||
|   DESTINATION include/c++/v1/ | ||||
|   ) | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										423
									
								
								include/__config
									
									
									
									
									
								
							
							
						
						
									
										423
									
								
								include/__config
									
									
									
									
									
								
							| @@ -11,15 +11,9 @@ | ||||
| #ifndef _LIBCPP_CONFIG | ||||
| #define _LIBCPP_CONFIG | ||||
|  | ||||
| #if !defined(_MSC_VER) || defined(__clang__) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| #ifdef __GNUC__ | ||||
| #define _GNUC_VER (__GNUC__ * 100 + __GNUC_MINOR__) | ||||
| #endif | ||||
|  | ||||
| #define _LIBCPP_VERSION 1101 | ||||
| #define _LIBCPP_VERSION 1000 | ||||
|  | ||||
| #define _LIBCPP_ABI_VERSION 1 | ||||
|  | ||||
| @@ -51,61 +45,8 @@ | ||||
| #   define _LIBCPP_LITTLE_ENDIAN 0 | ||||
| #   define _LIBCPP_BIG_ENDIAN    1 | ||||
| # endif  // _BYTE_ORDER == _LITTLE_ENDIAN | ||||
| # ifndef __LONG_LONG_SUPPORTED | ||||
| #  define _LIBCPP_HAS_NO_LONG_LONG | ||||
| # endif  // __LONG_LONG_SUPPORTED | ||||
| #endif  // __FreeBSD__ | ||||
|  | ||||
| #ifdef __NetBSD__ | ||||
| # include <sys/endian.h> | ||||
| #  if _BYTE_ORDER == _LITTLE_ENDIAN | ||||
| #   define _LIBCPP_LITTLE_ENDIAN 1 | ||||
| #   define _LIBCPP_BIG_ENDIAN    0 | ||||
| # else  // _BYTE_ORDER == _LITTLE_ENDIAN | ||||
| #   define _LIBCPP_LITTLE_ENDIAN 0 | ||||
| #   define _LIBCPP_BIG_ENDIAN    1 | ||||
| # endif  // _BYTE_ORDER == _LITTLE_ENDIAN | ||||
| # define _LIBCPP_HAS_QUICK_EXIT | ||||
| #endif  // __NetBSD__ | ||||
|  | ||||
| #ifdef _WIN32 | ||||
| #  define _LIBCPP_LITTLE_ENDIAN 1 | ||||
| #  define _LIBCPP_BIG_ENDIAN    0 | ||||
| // Compiler intrinsics (GCC or MSVC) | ||||
| #  if defined(__clang__) \ | ||||
|    || (defined(_MSC_VER) && _MSC_VER >= 1400) \ | ||||
|    || (defined(__GNUC__) && _GNUC_VER > 403) | ||||
| #    define _LIBCPP_HAS_IS_BASE_OF | ||||
| #  endif | ||||
| #  if defined(_MSC_VER) && !defined(__clang__) | ||||
| #    define _LIBCPP_MSVC // Using Microsoft Visual C++ compiler | ||||
| #    define _LIBCPP_TOSTRING2(x) #x | ||||
| #    define _LIBCPP_TOSTRING(x) _LIBCPP_TOSTRING2(x) | ||||
| #    define _LIBCPP_WARNING(x) __pragma(message(__FILE__ "(" _LIBCPP_TOSTRING(__LINE__) ") : warning note: " x)) | ||||
| #  endif | ||||
| #  // If mingw not explicitly detected, assume using MS C runtime only. | ||||
| #  ifndef __MINGW32__ | ||||
| #    define _LIBCPP_MSVCRT // Using Microsoft's C Runtime library | ||||
| #  endif | ||||
| #endif  // _WIN32 | ||||
|  | ||||
| #ifdef __linux__ | ||||
| #  if defined(__GNUC__) && _GNUC_VER >= 403 | ||||
| #    define _LIBCPP_HAS_IS_BASE_OF | ||||
| #  endif | ||||
| #endif | ||||
|  | ||||
| #ifdef __sun__ | ||||
| # include <sys/isa_defs.h> | ||||
| # ifdef _LITTLE_ENDIAN | ||||
| #   define _LIBCPP_LITTLE_ENDIAN 1 | ||||
| #   define _LIBCPP_BIG_ENDIAN    0 | ||||
| # else | ||||
| #   define _LIBCPP_LITTLE_ENDIAN 0 | ||||
| #   define _LIBCPP_BIG_ENDIAN    1 | ||||
| # endif | ||||
| #endif // __sun__ | ||||
|  | ||||
| #if !defined(_LIBCPP_LITTLE_ENDIAN) || !defined(_LIBCPP_BIG_ENDIAN) | ||||
| # include <endian.h> | ||||
| # if __BYTE_ORDER == __LITTLE_ENDIAN | ||||
| @@ -119,101 +60,34 @@ | ||||
| # endif | ||||
| #endif  // !defined(_LIBCPP_LITTLE_ENDIAN) || !defined(_LIBCPP_BIG_ENDIAN) | ||||
|  | ||||
| #ifdef _WIN32 | ||||
|  | ||||
| // only really useful for a DLL | ||||
| #ifdef _LIBCPP_DLL // this should be a compiler builtin define ideally... | ||||
| # ifdef cxx_EXPORTS | ||||
| #  define _LIBCPP_HIDDEN | ||||
| #  define _LIBCPP_FUNC_VIS __declspec(dllexport) | ||||
| #  define _LIBCPP_TYPE_VIS __declspec(dllexport) | ||||
| # else | ||||
| #  define _LIBCPP_HIDDEN | ||||
| #  define _LIBCPP_FUNC_VIS __declspec(dllimport) | ||||
| #  define _LIBCPP_TYPE_VIS __declspec(dllimport) | ||||
| # endif | ||||
| #else | ||||
| # define _LIBCPP_HIDDEN | ||||
| # define _LIBCPP_FUNC_VIS | ||||
| # define _LIBCPP_TYPE_VIS | ||||
| #ifndef _LIBCPP_VISIBILITY_TAG | ||||
| #define _LIBCPP_VISIBILITY_TAG 1 | ||||
| #endif | ||||
|  | ||||
| #define _LIBCPP_TYPE_VIS_ONLY | ||||
| #define _LIBCPP_FUNC_VIS_ONLY | ||||
|  | ||||
| #ifndef _LIBCPP_INLINE_VISIBILITY | ||||
| # ifdef _LIBCPP_MSVC | ||||
| #  define _LIBCPP_INLINE_VISIBILITY __forceinline | ||||
| # else // MinGW GCC and Clang | ||||
| #  define _LIBCPP_INLINE_VISIBILITY __attribute__ ((__always_inline__)) | ||||
| # endif | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_EXCEPTION_ABI | ||||
| #define _LIBCPP_EXCEPTION_ABI _LIBCPP_TYPE_VIS | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_ALWAYS_INLINE | ||||
| # ifdef _LIBCPP_MSVC | ||||
| #  define _LIBCPP_ALWAYS_INLINE __forceinline | ||||
| # endif | ||||
| #endif | ||||
|  | ||||
| #endif // _WIN32 | ||||
|  | ||||
| #ifndef __has_attribute | ||||
| #define __has_attribute(__x) 0 | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_HIDDEN | ||||
| #if _LIBCPP_VISIBILITY_TAG | ||||
| #define _LIBCPP_HIDDEN __attribute__ ((__visibility__("hidden"))) | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_FUNC_VIS | ||||
| #define _LIBCPP_FUNC_VIS __attribute__ ((__visibility__("default"))) | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_TYPE_VIS | ||||
| #  if __has_attribute(__type_visibility__) | ||||
| #    define _LIBCPP_TYPE_VIS __attribute__ ((__type_visibility__("default"))) | ||||
| #  else | ||||
| #    define _LIBCPP_TYPE_VIS __attribute__ ((__visibility__("default"))) | ||||
| #  endif | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_TYPE_VIS_ONLY | ||||
| # define _LIBCPP_TYPE_VIS_ONLY _LIBCPP_TYPE_VIS | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_FUNC_VIS_ONLY | ||||
| # define _LIBCPP_FUNC_VIS_ONLY _LIBCPP_FUNC_VIS | ||||
| #endif | ||||
| #define _LIBCPP_VISIBLE __attribute__ ((__visibility__("default"))) | ||||
| #else  // _LIBCPP_VISIBILITY_TAG | ||||
| #define _LIBCPP_HIDDEN | ||||
| #define _LIBCPP_VISIBLE | ||||
| #endif  // _LIBCPP_VISIBILITY_TAG | ||||
|  | ||||
| #ifndef _LIBCPP_INLINE_VISIBILITY | ||||
| #define _LIBCPP_INLINE_VISIBILITY __attribute__ ((__visibility__("hidden"), __always_inline__)) | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_EXCEPTION_ABI | ||||
| #define _LIBCPP_EXCEPTION_ABI _LIBCPP_TYPE_VIS | ||||
| #define _LIBCPP_EXCEPTION_ABI __attribute__ ((__visibility__("default"))) | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_ALWAYS_INLINE | ||||
| #define _LIBCPP_CANTTHROW __attribute__ ((__nothrow__)) | ||||
|  | ||||
| #define _LIBCPP_ALWAYS_INLINE  __attribute__ ((__visibility__("hidden"), __always_inline__)) | ||||
| #endif | ||||
|  | ||||
| #if defined(__clang__) | ||||
|  | ||||
| #if __has_feature(cxx_alignas) | ||||
| #  define _ALIGNAS_TYPE(x) alignas(x) | ||||
| #  define _ALIGNAS(x) alignas(x) | ||||
| #else | ||||
| #  define _ALIGNAS_TYPE(x) __attribute__((__aligned__(__alignof(x)))) | ||||
| #  define _ALIGNAS(x) __attribute__((__aligned__(x))) | ||||
| #endif | ||||
|  | ||||
| #if !__has_feature(cxx_alias_templates) | ||||
| #define _LIBCPP_HAS_NO_ADVANCED_SFINAE | ||||
| #define _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
| #endif | ||||
|  | ||||
| #ifndef __GXX_EXPERIMENTAL_CXX0X__ | ||||
| #ifdef __linux__ | ||||
| @@ -232,23 +106,15 @@ typedef __char32_t char32_t; | ||||
| #define _LIBCPP_NO_RTTI | ||||
| #endif | ||||
|  | ||||
| #if !(__has_feature(cxx_strong_enums)) | ||||
| #define _LIBCPP_HAS_NO_STRONG_ENUMS | ||||
| #endif | ||||
|  | ||||
| #if !(__has_feature(cxx_decltype)) | ||||
| #define _LIBCPP_HAS_NO_DECLTYPE | ||||
| #endif | ||||
|  | ||||
| #if __has_feature(cxx_attributes) | ||||
| #  define _LIBCPP_NORETURN [[noreturn]] | ||||
| #else | ||||
| #  define _LIBCPP_NORETURN __attribute__ ((noreturn)) | ||||
| #if !(__has_feature(cxx_attributes)) | ||||
| #define _LIBCPP_HAS_NO_ATTRIBUTES | ||||
| #endif | ||||
|  | ||||
| #if !(__has_feature(cxx_defaulted_functions)) | ||||
| #define _LIBCPP_HAS_NO_DEFAULTED_FUNCTIONS | ||||
| #endif  // !(__has_feature(cxx_defaulted_functions)) | ||||
|  | ||||
| #if !(__has_feature(cxx_deleted_functions)) | ||||
| #define _LIBCPP_HAS_NO_DELETED_FUNCTIONS | ||||
| @@ -274,10 +140,6 @@ typedef __char32_t char32_t; | ||||
| #define _LIBCPP_HAS_NO_AUTO_TYPE | ||||
| #endif | ||||
|  | ||||
| #if !(__has_feature(cxx_access_control_sfinae)) || !__has_feature(cxx_trailing_return) | ||||
| #define _LIBCPP_HAS_NO_ADVANCED_SFINAE | ||||
| #endif | ||||
|  | ||||
| #if !(__has_feature(cxx_variadic_templates)) | ||||
| #define _LIBCPP_HAS_NO_VARIADICS | ||||
| #endif | ||||
| @@ -286,72 +148,24 @@ typedef __char32_t char32_t; | ||||
| #define _LIBCPP_HAS_NO_TRAILING_RETURN | ||||
| #endif | ||||
|  | ||||
| #if !(__has_feature(cxx_generalized_initializers)) | ||||
| #define _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS | ||||
| #endif | ||||
|  | ||||
| #if __has_feature(is_base_of) | ||||
| #  define _LIBCPP_HAS_IS_BASE_OF | ||||
| #endif | ||||
|  | ||||
| // Objective-C++ features (opt-in) | ||||
| #if __has_feature(objc_arc) | ||||
| #define _LIBCPP_HAS_OBJC_ARC | ||||
| #endif | ||||
|  | ||||
| #if __has_feature(objc_arc_weak) | ||||
| #define _LIBCPP_HAS_OBJC_ARC_WEAK | ||||
| #define _LIBCPP_HAS_NO_STRONG_ENUMS | ||||
| #endif | ||||
|  | ||||
| #if !(__has_feature(cxx_constexpr)) | ||||
| #define _LIBCPP_HAS_NO_CONSTEXPR | ||||
| #endif | ||||
|  | ||||
| #if __ISO_C_VISIBLE >= 2011 || __cplusplus >= 201103L | ||||
| #if defined(__FreeBSD__) | ||||
| #define _LIBCPP_HAS_QUICK_EXIT | ||||
| #define _LIBCPP_HAS_C11_FEATURES | ||||
| #elif defined(__linux__) | ||||
| #include <features.h> | ||||
| #if __GLIBC_PREREQ(2, 15) | ||||
| #define _LIBCPP_HAS_QUICK_EXIT | ||||
| #endif | ||||
| #if __GLIBC_PREREQ(2, 17) | ||||
| #define _LIBCPP_HAS_C11_FEATURES | ||||
| #endif | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #if (__has_feature(cxx_noexcept)) | ||||
| #  define _NOEXCEPT noexcept | ||||
| #  define _NOEXCEPT_(x) noexcept(x) | ||||
| #else | ||||
| #  define _NOEXCEPT throw() | ||||
| #  define _NOEXCEPT_(x) | ||||
| #endif | ||||
|  | ||||
| #if __has_feature(underlying_type) | ||||
| #  define _LIBCXX_UNDERLYING_TYPE(T) __underlying_type(T) | ||||
| #endif | ||||
|  | ||||
| // Inline namespaces are available in Clang regardless of C++ dialect. | ||||
| #define _LIBCPP_BEGIN_NAMESPACE_STD namespace std {inline namespace _LIBCPP_NAMESPACE { | ||||
| #define _LIBCPP_END_NAMESPACE_STD  } } | ||||
| #define _VSTD std::_LIBCPP_NAMESPACE | ||||
| #define _STD std::_LIBCPP_NAMESPACE | ||||
|  | ||||
| namespace std { | ||||
|   inline namespace _LIBCPP_NAMESPACE { | ||||
|   } | ||||
| } | ||||
|  | ||||
| #if !(__has_feature(cxx_constexpr)) | ||||
| #define _LIBCPP_HAS_NO_CONSTEXPR | ||||
| #endif | ||||
|  | ||||
| // end defined(__clang__) | ||||
|  | ||||
| #elif defined(__GNUC__) | ||||
|  | ||||
| #define _ALIGNAS(x) __attribute__((__aligned__(x))) | ||||
| #define _ALIGNAS_TYPE(x) __attribute__((__aligned__(__alignof(x)))) | ||||
|  | ||||
| #define _LIBCPP_NORETURN __attribute__((noreturn)) | ||||
|  | ||||
| #if !__EXCEPTIONS | ||||
| #define _LIBCPP_NO_EXCEPTIONS | ||||
| #endif | ||||
| @@ -359,9 +173,6 @@ namespace std { | ||||
| #define _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
| #define _LIBCPP_HAS_NO_CONSTEXPR | ||||
|  | ||||
| #define _NOEXCEPT throw() | ||||
| #define _NOEXCEPT_(x) | ||||
|  | ||||
| #ifndef __GXX_EXPERIMENTAL_CXX0X__ | ||||
|  | ||||
| #define _LIBCPP_HAS_NO_ADVANCED_SFINAE | ||||
| @@ -380,25 +191,24 @@ namespace std { | ||||
| #define _LIBCPP_HAS_NO_TRAILING_RETURN | ||||
| #define _LIBCPP_HAS_NO_ALWAYS_INLINE_VARIADICS | ||||
|  | ||||
| #if _GNUC_VER < 403 | ||||
| #if !(__GNUC__ >= 4 && __GNUC_MINOR__ >= 3) | ||||
| #define _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| #endif | ||||
|  | ||||
| #if _GNUC_VER < 403 | ||||
| #if !(__GNUC__ >= 4 && __GNUC_MINOR__ >= 3) | ||||
| #define _LIBCPP_HAS_NO_STATIC_ASSERT | ||||
| #endif | ||||
|  | ||||
| #if _GNUC_VER < 404 | ||||
| #if !(__GNUC__ >= 4 && __GNUC_MINOR__ >= 4) | ||||
| #define _LIBCPP_HAS_NO_ADVANCED_SFINAE | ||||
| #define _LIBCPP_HAS_NO_DECLTYPE | ||||
| #define _LIBCPP_HAS_NO_DEFAULTED_FUNCTIONS | ||||
| #define _LIBCPP_HAS_NO_DELETED_FUNCTIONS | ||||
| #define _LIBCPP_HAS_NO_UNICODE_CHARS | ||||
| #define _LIBCPP_HAS_NO_VARIADICS | ||||
| #define _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS | ||||
| #endif  // _GNUC_VER < 404 | ||||
| #endif  // !(__GNUC__ >= 4 && __GNUC_MINOR__ >= 4) | ||||
|  | ||||
| #if _GNUC_VER < 406 | ||||
| #if !(__GNUC__ >= 4 && __GNUC_MINOR__ >= 6) | ||||
| #define _LIBCPP_HAS_NO_NULLPTR | ||||
| #endif | ||||
|  | ||||
| @@ -406,7 +216,7 @@ namespace std { | ||||
|  | ||||
| #define _LIBCPP_BEGIN_NAMESPACE_STD namespace std { namespace _LIBCPP_NAMESPACE { | ||||
| #define _LIBCPP_END_NAMESPACE_STD  } } | ||||
| #define _VSTD std::_LIBCPP_NAMESPACE | ||||
| #define _STD std::_LIBCPP_NAMESPACE | ||||
|  | ||||
| namespace std { | ||||
| namespace _LIBCPP_NAMESPACE { | ||||
| @@ -414,63 +224,7 @@ namespace _LIBCPP_NAMESPACE { | ||||
| using namespace _LIBCPP_NAMESPACE __attribute__((__strong__)); | ||||
| } | ||||
|  | ||||
| #elif defined(_LIBCPP_MSVC) | ||||
|  | ||||
| #define _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
| #define _LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER | ||||
| #define _LIBCPP_HAS_NO_CONSTEXPR | ||||
| #define _LIBCPP_HAS_NO_UNICODE_CHARS | ||||
| #define _LIBCPP_HAS_NO_DELETED_FUNCTIONS | ||||
| #define _LIBCPP_HAS_NO_DEFAULTED_FUNCTIONS | ||||
| #define __alignof__ __alignof | ||||
| #define _LIBCPP_NORETURN __declspec(noreturn) | ||||
| #define _ALIGNAS(x) __declspec(align(x)) | ||||
| #define _LIBCPP_HAS_NO_VARIADICS | ||||
|  | ||||
| #define _NOEXCEPT throw() | ||||
| #define _NOEXCEPT_(x) | ||||
|  | ||||
| #define _LIBCPP_BEGIN_NAMESPACE_STD namespace std { | ||||
| #define _LIBCPP_END_NAMESPACE_STD  } | ||||
| #define _VSTD std | ||||
|  | ||||
| #  define _LIBCPP_WEAK | ||||
| namespace std { | ||||
| } | ||||
|  | ||||
| #elif defined(__IBMCPP__) | ||||
|  | ||||
| #define _ALIGNAS(x) __attribute__((__aligned__(x))) | ||||
| #define _ALIGNAS_TYPE(x) __attribute__((__aligned__(__alignof(x)))) | ||||
| #define _ATTRIBUTE(x) __attribute__((x)) | ||||
| #define _LIBCPP_NORETURN __attribute__((noreturn)) | ||||
|  | ||||
| #define _NOEXCEPT throw() | ||||
| #define _NOEXCEPT_(x) | ||||
|  | ||||
| #define _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
| #define _LIBCPP_HAS_NO_ADVANCED_SFINAE | ||||
| #define _LIBCPP_HAS_NO_ALWAYS_INLINE_VARIADICS | ||||
| #define _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS | ||||
| #define _LIBCPP_HAS_NO_NULLPTR | ||||
| #define _LIBCPP_HAS_NO_UNICODE_CHARS | ||||
| #define _LIBCPP_HAS_NO_STRONG_ENUMS | ||||
| #define _LIBCPP_HAS_IS_BASE_OF | ||||
|  | ||||
| #if defined(_AIX) | ||||
| #define __MULTILOCALE_API | ||||
| #endif | ||||
|  | ||||
| #define _LIBCPP_BEGIN_NAMESPACE_STD namespace std {inline namespace _LIBCPP_NAMESPACE { | ||||
| #define _LIBCPP_END_NAMESPACE_STD  } } | ||||
| #define _VSTD std::_LIBCPP_NAMESPACE | ||||
|  | ||||
| namespace std { | ||||
|   inline namespace _LIBCPP_NAMESPACE { | ||||
|   } | ||||
| } | ||||
|  | ||||
| #endif // __clang__ || __GNUC___ || _MSC_VER || __IBMCPP__ | ||||
| #endif  // defined(__GNUC__) | ||||
|  | ||||
| #ifdef _LIBCPP_HAS_NO_UNICODE_CHARS | ||||
| typedef unsigned short char16_t; | ||||
| @@ -493,128 +247,11 @@ template <unsigned> struct __static_assert_check {}; | ||||
| #endif | ||||
|  | ||||
| #ifdef _LIBCPP_HAS_NO_CONSTEXPR | ||||
| #define _LIBCPP_CONSTEXPR | ||||
| #else | ||||
| #define _LIBCPP_CONSTEXPR constexpr | ||||
| #endif | ||||
|  | ||||
| #ifdef _LIBCPP_HAS_NO_DEFAULTED_FUNCTIONS | ||||
| #define _LIBCPP_DEFAULT {} | ||||
| #else | ||||
| #define _LIBCPP_DEFAULT = default; | ||||
| #endif | ||||
|  | ||||
| #ifdef __GNUC__ | ||||
| #define _NOALIAS __attribute__((__malloc__)) | ||||
| #else | ||||
| #define _NOALIAS | ||||
| #define constexpr const | ||||
| #endif | ||||
|  | ||||
| #ifndef __has_feature | ||||
| #define __has_feature(__x) 0 | ||||
| #endif | ||||
|  | ||||
| #if __has_feature(cxx_explicit_conversions) | ||||
| #   define _LIBCPP_EXPLICIT explicit | ||||
| #else | ||||
| #   define _LIBCPP_EXPLICIT | ||||
| #endif | ||||
|  | ||||
| #ifdef _LIBCPP_HAS_NO_STRONG_ENUMS | ||||
| #define _LIBCPP_DECLARE_STRONG_ENUM(x) struct _LIBCPP_TYPE_VIS x { enum __lx | ||||
| #define _LIBCPP_DECLARE_STRONG_ENUM_EPILOG(x) \ | ||||
|     __lx __v_; \ | ||||
|     _LIBCPP_ALWAYS_INLINE x(__lx __v) : __v_(__v) {} \ | ||||
|     _LIBCPP_ALWAYS_INLINE explicit x(int __v) : __v_(static_cast<__lx>(__v)) {} \ | ||||
|     _LIBCPP_ALWAYS_INLINE operator int() const {return __v_;} \ | ||||
|     }; | ||||
| #else  // _LIBCPP_HAS_NO_STRONG_ENUMS | ||||
| #define _LIBCPP_DECLARE_STRONG_ENUM(x) enum class _LIBCPP_TYPE_VIS x | ||||
| #define _LIBCPP_DECLARE_STRONG_ENUM_EPILOG(x) | ||||
| #endif  // _LIBCPP_HAS_NO_STRONG_ENUMS | ||||
|  | ||||
| #ifdef _LIBCPP_DEBUG | ||||
| #   if _LIBCPP_DEBUG == 0 | ||||
| #       define _LIBCPP_DEBUG_LEVEL 1 | ||||
| #   elif _LIBCPP_DEBUG == 1 | ||||
| #       define _LIBCPP_DEBUG_LEVEL 2 | ||||
| #   else | ||||
| #       error Supported values for _LIBCPP_DEBUG are 0 and 1 | ||||
| #   endif | ||||
| #   define _LIBCPP_EXTERN_TEMPLATE(...) | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_EXTERN_TEMPLATE | ||||
| #define _LIBCPP_EXTERN_TEMPLATE(...) | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_EXTERN_TEMPLATE2 | ||||
| #define _LIBCPP_EXTERN_TEMPLATE2(...) extern template __VA_ARGS__; | ||||
| #endif | ||||
|  | ||||
| #if defined(__APPLE__) || defined(__FreeBSD__) || defined(_WIN32) || defined(__sun__) || defined(__NetBSD__) | ||||
| #define _LIBCPP_LOCALE__L_EXTENSIONS 1 | ||||
| #endif | ||||
| #ifdef __FreeBSD__ | ||||
| #define _DECLARE_C99_LDBL_MATH 1 | ||||
| #endif | ||||
|  | ||||
| #if defined(__APPLE__) || defined(__FreeBSD__) | ||||
| #define _LIBCPP_HAS_DEFAULTRUNELOCALE | ||||
| #endif | ||||
|  | ||||
| #if defined(__APPLE__) || defined(__FreeBSD__) || defined(__sun__) | ||||
| #define _LIBCPP_WCTYPE_IS_MASK | ||||
| #endif | ||||
|  | ||||
| #if defined(__APPLE__) | ||||
| #ifndef _LIBCPP_TRIVIAL_PAIR_COPY_CTOR | ||||
| #  define _LIBCPP_TRIVIAL_PAIR_COPY_CTOR 0 | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_TRIVIAL_PAIR_COPY_CTOR | ||||
| #  define _LIBCPP_TRIVIAL_PAIR_COPY_CTOR 1 | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_STD_VER | ||||
| #  if  __cplusplus <= 201103L | ||||
| #    define _LIBCPP_STD_VER 11 | ||||
| #  else | ||||
| #    define _LIBCPP_STD_VER 13  // current year, or date of c++14 ratification | ||||
| #  endif | ||||
| #endif  // _LIBCPP_STD_VER | ||||
|  | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
| #define _LIBCPP_DEPRECATED [[deprecated]] | ||||
| #else | ||||
| #define _LIBCPP_DEPRECATED | ||||
| #endif | ||||
|  | ||||
| #if _LIBCPP_STD_VER <= 11 | ||||
| #define _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| #define _LIBCPP_EXPLICIT_AFTER_CXX11 | ||||
| #define _LIBCPP_DEPRECATED_AFTER_CXX11 | ||||
| #else | ||||
| #define _LIBCPP_CONSTEXPR_AFTER_CXX11 constexpr | ||||
| #define _LIBCPP_EXPLICIT_AFTER_CXX11 explicit | ||||
| #define _LIBCPP_DEPRECATED_AFTER_CXX11 [[deprecated]] | ||||
| #endif | ||||
|  | ||||
| // Try to find out if RTTI is disabled. | ||||
| // g++ and cl.exe have RTTI on by default and define a macro when it is. | ||||
| // g++ only defines the macro in 4.3.2 and onwards. | ||||
| #if !defined(_LIBCPP_NO_RTTI) | ||||
| #  if defined(__GNUG__) && (__GNUC__ >= 4 && \ | ||||
|    (__GNUC_MINOR__ >= 3 || __GNUC_PATCHLEVEL__ >= 2)) && !defined(__GXX_RTTI) | ||||
| #    define _LIBCPP_NO_RTTI | ||||
| #  elif (defined(_MSC_VER) && !defined(__clang__)) && !defined(_CPPRTTI) | ||||
| #    define _LIBCPP_NO_RTTI | ||||
| #  endif | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_WEAK | ||||
| #  define _LIBCPP_WEAK __attribute__((__weak__)) | ||||
| #endif | ||||
|  | ||||
| #endif  // _LIBCPP_CONFIG | ||||
|   | ||||
							
								
								
									
										218
									
								
								include/__debug
									
									
									
									
									
								
							
							
						
						
									
										218
									
								
								include/__debug
									
									
									
									
									
								
							| @@ -1,218 +0,0 @@ | ||||
| // -*- C++ -*- | ||||
| //===--------------------------- __debug ----------------------------------===// | ||||
| // | ||||
| //                     The LLVM Compiler Infrastructure | ||||
| // | ||||
| // This file is dual licensed under the MIT and the University of Illinois Open | ||||
| // Source Licenses. See LICENSE.TXT for details. | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| #ifndef _LIBCPP_DEBUG_H | ||||
| #define _LIBCPP_DEBUG_H | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| #if _LIBCPP_DEBUG_LEVEL >= 1 | ||||
|  | ||||
| #   include <cstdlib> | ||||
| #   include <cstdio> | ||||
| #   include <cstddef> | ||||
| #   ifndef _LIBCPP_ASSERT | ||||
| #      define _LIBCPP_ASSERT(x, m) ((x) ? (void)0 : (_VSTD::printf("%s\n", m), _VSTD::abort())) | ||||
| #   endif | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #if _LIBCPP_DEBUG_LEVEL >= 2 | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| struct _LIBCPP_TYPE_VIS __c_node; | ||||
|  | ||||
| struct _LIBCPP_TYPE_VIS __i_node | ||||
| { | ||||
|     void* __i_; | ||||
|     __i_node* __next_; | ||||
|     __c_node* __c_; | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_DELETED_FUNCTIONS | ||||
|     __i_node(const __i_node&) = delete; | ||||
|     __i_node& operator=(const __i_node&) = delete; | ||||
| #else | ||||
| private: | ||||
|     __i_node(const __i_node&); | ||||
|     __i_node& operator=(const __i_node&); | ||||
| public: | ||||
| #endif | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     __i_node(void* __i, __i_node* __next, __c_node* __c) | ||||
|         : __i_(__i), __next_(__next), __c_(__c) {} | ||||
|     ~__i_node(); | ||||
| }; | ||||
|  | ||||
| struct _LIBCPP_TYPE_VIS __c_node | ||||
| { | ||||
|     void* __c_; | ||||
|     __c_node* __next_; | ||||
|     __i_node** beg_; | ||||
|     __i_node** end_; | ||||
|     __i_node** cap_; | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_DELETED_FUNCTIONS | ||||
|     __c_node(const __c_node&) = delete; | ||||
|     __c_node& operator=(const __c_node&) = delete; | ||||
| #else | ||||
| private: | ||||
|     __c_node(const __c_node&); | ||||
|     __c_node& operator=(const __c_node&); | ||||
| public: | ||||
| #endif | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     __c_node(void* __c, __c_node* __next) | ||||
|         : __c_(__c), __next_(__next), beg_(nullptr), end_(nullptr), cap_(nullptr) {} | ||||
|     virtual ~__c_node(); | ||||
|  | ||||
|     virtual bool __dereferenceable(const void*) const = 0; | ||||
|     virtual bool __decrementable(const void*) const = 0; | ||||
|     virtual bool __addable(const void*, ptrdiff_t) const = 0; | ||||
|     virtual bool __subscriptable(const void*, ptrdiff_t) const = 0; | ||||
|  | ||||
|     void __add(__i_node* __i); | ||||
|     _LIBCPP_HIDDEN void __remove(__i_node* __i); | ||||
| }; | ||||
|  | ||||
| template <class _Cont> | ||||
| struct _C_node | ||||
|     : public __c_node | ||||
| { | ||||
|     _C_node(void* __c, __c_node* __n) | ||||
|         : __c_node(__c, __n) {} | ||||
|  | ||||
|     virtual bool __dereferenceable(const void*) const; | ||||
|     virtual bool __decrementable(const void*) const; | ||||
|     virtual bool __addable(const void*, ptrdiff_t) const; | ||||
|     virtual bool __subscriptable(const void*, ptrdiff_t) const; | ||||
| }; | ||||
|  | ||||
| template <class _Cont> | ||||
| bool | ||||
| _C_node<_Cont>::__dereferenceable(const void* __i) const | ||||
| { | ||||
|     typedef typename _Cont::const_iterator iterator; | ||||
|     const iterator* __j = static_cast<const iterator*>(__i); | ||||
|     _Cont* _Cp = static_cast<_Cont*>(__c_); | ||||
|     return _Cp->__dereferenceable(__j); | ||||
| } | ||||
|  | ||||
| template <class _Cont> | ||||
| bool | ||||
| _C_node<_Cont>::__decrementable(const void* __i) const | ||||
| { | ||||
|     typedef typename _Cont::const_iterator iterator; | ||||
|     const iterator* __j = static_cast<const iterator*>(__i); | ||||
|     _Cont* _Cp = static_cast<_Cont*>(__c_); | ||||
|     return _Cp->__decrementable(__j); | ||||
| } | ||||
|  | ||||
| template <class _Cont> | ||||
| bool | ||||
| _C_node<_Cont>::__addable(const void* __i, ptrdiff_t __n) const | ||||
| { | ||||
|     typedef typename _Cont::const_iterator iterator; | ||||
|     const iterator* __j = static_cast<const iterator*>(__i); | ||||
|     _Cont* _Cp = static_cast<_Cont*>(__c_); | ||||
|     return _Cp->__addable(__j, __n); | ||||
| } | ||||
|  | ||||
| template <class _Cont> | ||||
| bool | ||||
| _C_node<_Cont>::__subscriptable(const void* __i, ptrdiff_t __n) const | ||||
| { | ||||
|     typedef typename _Cont::const_iterator iterator; | ||||
|     const iterator* __j = static_cast<const iterator*>(__i); | ||||
|     _Cont* _Cp = static_cast<_Cont*>(__c_); | ||||
|     return _Cp->__subscriptable(__j, __n); | ||||
| } | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS __libcpp_db | ||||
| { | ||||
|     __c_node** __cbeg_; | ||||
|     __c_node** __cend_; | ||||
|     size_t   __csz_; | ||||
|     __i_node** __ibeg_; | ||||
|     __i_node** __iend_; | ||||
|     size_t   __isz_; | ||||
|  | ||||
|     __libcpp_db(); | ||||
| public: | ||||
| #ifndef _LIBCPP_HAS_NO_DELETED_FUNCTIONS | ||||
|     __libcpp_db(const __libcpp_db&) = delete; | ||||
|     __libcpp_db& operator=(const __libcpp_db&) = delete; | ||||
| #else | ||||
| private: | ||||
|     __libcpp_db(const __libcpp_db&); | ||||
|     __libcpp_db& operator=(const __libcpp_db&); | ||||
| public: | ||||
| #endif | ||||
|     ~__libcpp_db(); | ||||
|  | ||||
|     class __db_c_iterator; | ||||
|     class __db_c_const_iterator; | ||||
|     class __db_i_iterator; | ||||
|     class __db_i_const_iterator; | ||||
|  | ||||
|     __db_c_const_iterator __c_end() const; | ||||
|     __db_i_const_iterator __i_end() const; | ||||
|  | ||||
|     template <class _Cont> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void __insert_c(_Cont* __c) | ||||
|     { | ||||
|         __c_node* __n = __insert_c(static_cast<void*>(__c)); | ||||
|         ::new(__n) _C_node<_Cont>(__n->__c_, __n->__next_); | ||||
|     } | ||||
|  | ||||
|     void __insert_i(void* __i); | ||||
|     __c_node* __insert_c(void* __c); | ||||
|     void __erase_c(void* __c); | ||||
|  | ||||
|     void __insert_ic(void* __i, const void* __c); | ||||
|     void __iterator_copy(void* __i, const void* __i0); | ||||
|     void __erase_i(void* __i); | ||||
|  | ||||
|     void* __find_c_from_i(void* __i) const; | ||||
|     void __invalidate_all(void* __c); | ||||
|     __c_node* __find_c_and_lock(void* __c) const; | ||||
|     __c_node* __find_c(void* __c) const; | ||||
|     void unlock() const; | ||||
|  | ||||
|     void swap(void* __c1, void* __c2); | ||||
|  | ||||
|  | ||||
|     bool __dereferenceable(const void* __i) const; | ||||
|     bool __decrementable(const void* __i) const; | ||||
|     bool __addable(const void* __i, ptrdiff_t __n) const; | ||||
|     bool __subscriptable(const void* __i, ptrdiff_t __n) const; | ||||
|     bool __less_than_comparable(const void* __i, const void* __j) const; | ||||
| private: | ||||
|     _LIBCPP_HIDDEN | ||||
|     __i_node* __insert_iterator(void* __i); | ||||
|     _LIBCPP_HIDDEN | ||||
|     __i_node* __find_iterator(const void* __i) const; | ||||
|  | ||||
|     friend _LIBCPP_FUNC_VIS __libcpp_db* __get_db(); | ||||
| }; | ||||
|  | ||||
| _LIBCPP_FUNC_VIS __libcpp_db* __get_db(); | ||||
| _LIBCPP_FUNC_VIS const __libcpp_db* __get_const_db(); | ||||
|  | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #endif  // _LIBCPP_DEBUG_H | ||||
|  | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -15,116 +15,39 @@ | ||||
| #include <type_traits> | ||||
| #include <typeinfo> | ||||
| #include <exception> | ||||
| #include <new> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template <class _Arg, class _Result> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY unary_function | ||||
| struct _LIBCPP_VISIBLE unary_function | ||||
| { | ||||
|     typedef _Arg    argument_type; | ||||
|     typedef _Result result_type; | ||||
| }; | ||||
|  | ||||
| template <class _Arg1, class _Arg2, class _Result> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY binary_function | ||||
| struct _LIBCPP_VISIBLE binary_function | ||||
| { | ||||
|     typedef _Arg1   first_argument_type; | ||||
|     typedef _Arg2   second_argument_type; | ||||
|     typedef _Result result_type; | ||||
| }; | ||||
|  | ||||
| template <class _Tp> struct _LIBCPP_TYPE_VIS_ONLY hash; | ||||
| template <class _Tp> struct _LIBCPP_VISIBLE hash; | ||||
|  | ||||
| template <class _Tp> | ||||
| struct __has_result_type | ||||
| { | ||||
| private: | ||||
|     struct __two {char __lx; char __lxx;}; | ||||
|     struct __two {char _; char __;}; | ||||
|     template <class _Up> static __two __test(...); | ||||
|     template <class _Up> static char __test(typename _Up::result_type* = 0); | ||||
| public: | ||||
|     static const bool value = sizeof(__test<_Tp>(0)) == 1; | ||||
| }; | ||||
|  | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
| template <class _Tp = void> | ||||
| #else | ||||
| template <class _Tp> | ||||
| #endif | ||||
| struct _LIBCPP_TYPE_VIS_ONLY less : binary_function<_Tp, _Tp, bool> | ||||
| { | ||||
|     _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY  | ||||
|     bool operator()(const _Tp& __x, const _Tp& __y) const | ||||
|         {return __x < __y;} | ||||
| }; | ||||
|  | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
| template <> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY less<void> | ||||
| { | ||||
|     template <class _T1, class _T2>  | ||||
|     _LIBCPP_CONSTEXPR_AFTER_CXX11 _LIBCPP_INLINE_VISIBILITY | ||||
|     auto operator()(_T1&& __t, _T2&& __u) const | ||||
|         { return _VSTD::forward<_T1>(__t) < _VSTD::forward<_T2>(__u); } | ||||
|     typedef void is_transparent; | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| // addressof | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _Tp* | ||||
| addressof(_Tp& __x) _NOEXCEPT | ||||
| { | ||||
|     return (_Tp*)&reinterpret_cast<const volatile char&>(__x); | ||||
| } | ||||
|  | ||||
| #if defined(_LIBCPP_HAS_OBJC_ARC) && !defined(_LIBCPP_PREDEFINED_OBJC_ARC_ADDRESSOF) | ||||
| // Objective-C++ Automatic Reference Counting uses qualified pointers | ||||
| // that require special addressof() signatures. When | ||||
| // _LIBCPP_PREDEFINED_OBJC_ARC_ADDRESSOF is defined, the compiler | ||||
| // itself is providing these definitions. Otherwise, we provide them. | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| __strong _Tp* | ||||
| addressof(__strong _Tp& __x) _NOEXCEPT | ||||
| { | ||||
|   return &__x; | ||||
| } | ||||
|  | ||||
| #ifdef _LIBCPP_HAS_OBJC_ARC_WEAK | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| __weak _Tp* | ||||
| addressof(__weak _Tp& __x) _NOEXCEPT | ||||
| { | ||||
|   return &__x; | ||||
| } | ||||
| #endif | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| __autoreleasing _Tp* | ||||
| addressof(__autoreleasing _Tp& __x) _NOEXCEPT | ||||
| { | ||||
|   return &__x; | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| __unsafe_unretained _Tp* | ||||
| addressof(__unsafe_unretained _Tp& __x) _NOEXCEPT | ||||
| { | ||||
|   return &__x; | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #ifdef _LIBCPP_HAS_NO_VARIADICS | ||||
|  | ||||
| #include <__functional_base_03> | ||||
| @@ -137,11 +60,11 @@ template <class _Tp> | ||||
| struct __derives_from_unary_function | ||||
| { | ||||
| private: | ||||
|     struct __two {char __lx; char __lxx;}; | ||||
|     struct __two {char _; char __;}; | ||||
|     static __two __test(...); | ||||
|     template <class _Ap, class _Rp> | ||||
|         static unary_function<_Ap, _Rp> | ||||
|         __test(const volatile unary_function<_Ap, _Rp>*); | ||||
|     template <class _A, class _R> | ||||
|         static unary_function<_A, _R> | ||||
|         __test(const volatile unary_function<_A, _R>*); | ||||
| public: | ||||
|     static const bool value = !is_same<decltype(__test((_Tp*)0)), __two>::value; | ||||
|     typedef decltype(__test((_Tp*)0)) type; | ||||
| @@ -151,11 +74,11 @@ template <class _Tp> | ||||
| struct __derives_from_binary_function | ||||
| { | ||||
| private: | ||||
|     struct __two {char __lx; char __lxx;}; | ||||
|     struct __two {char _; char __;}; | ||||
|     static __two __test(...); | ||||
|     template <class _A1, class _A2, class _Rp> | ||||
|         static binary_function<_A1, _A2, _Rp> | ||||
|         __test(const volatile binary_function<_A1, _A2, _Rp>*); | ||||
|     template <class _A1, class _A2, class _R> | ||||
|         static binary_function<_A1, _A2, _R> | ||||
|         __test(const volatile binary_function<_A1, _A2, _R>*); | ||||
| public: | ||||
|     static const bool value = !is_same<decltype(__test((_Tp*)0)), __two>::value; | ||||
|     typedef decltype(__test((_Tp*)0)) type; | ||||
| @@ -206,221 +129,323 @@ struct __weak_result_type | ||||
|  | ||||
| // 0 argument case | ||||
|  | ||||
| template <class _Rp> | ||||
| struct __weak_result_type<_Rp ()> | ||||
| template <class _R> | ||||
| struct __weak_result_type<_R ()> | ||||
| { | ||||
|     typedef _Rp result_type; | ||||
|     typedef _R result_type; | ||||
| }; | ||||
|  | ||||
| template <class _Rp> | ||||
| struct __weak_result_type<_Rp (&)()> | ||||
| template <class _R> | ||||
| struct __weak_result_type<_R (&)()> | ||||
| { | ||||
|     typedef _Rp result_type; | ||||
|     typedef _R result_type; | ||||
| }; | ||||
|  | ||||
| template <class _Rp> | ||||
| struct __weak_result_type<_Rp (*)()> | ||||
| template <class _R> | ||||
| struct __weak_result_type<_R (*)()> | ||||
| { | ||||
|     typedef _Rp result_type; | ||||
|     typedef _R result_type; | ||||
| }; | ||||
|  | ||||
| // 1 argument case | ||||
|  | ||||
| template <class _Rp, class _A1> | ||||
| struct __weak_result_type<_Rp (_A1)> | ||||
|     : public unary_function<_A1, _Rp> | ||||
| template <class _R, class _A1> | ||||
| struct __weak_result_type<_R (_A1)> | ||||
|     : public unary_function<_A1, _R> | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _A1> | ||||
| struct __weak_result_type<_Rp (&)(_A1)> | ||||
|     : public unary_function<_A1, _Rp> | ||||
| template <class _R, class _A1> | ||||
| struct __weak_result_type<_R (&)(_A1)> | ||||
|     : public unary_function<_A1, _R> | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _A1> | ||||
| struct __weak_result_type<_Rp (*)(_A1)> | ||||
|     : public unary_function<_A1, _Rp> | ||||
| template <class _R, class _A1> | ||||
| struct __weak_result_type<_R (*)(_A1)> | ||||
|     : public unary_function<_A1, _R> | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _Cp> | ||||
| struct __weak_result_type<_Rp (_Cp::*)()> | ||||
|     : public unary_function<_Cp*, _Rp> | ||||
| template <class _R, class _C> | ||||
| struct __weak_result_type<_R (_C::*)()> | ||||
|     : public unary_function<_C*, _R> | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _Cp> | ||||
| struct __weak_result_type<_Rp (_Cp::*)() const> | ||||
|     : public unary_function<const _Cp*, _Rp> | ||||
| template <class _R, class _C> | ||||
| struct __weak_result_type<_R (_C::*)() const> | ||||
|     : public unary_function<const _C*, _R> | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _Cp> | ||||
| struct __weak_result_type<_Rp (_Cp::*)() volatile> | ||||
|     : public unary_function<volatile _Cp*, _Rp> | ||||
| template <class _R, class _C> | ||||
| struct __weak_result_type<_R (_C::*)() volatile> | ||||
|     : public unary_function<volatile _C*, _R> | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _Cp> | ||||
| struct __weak_result_type<_Rp (_Cp::*)() const volatile> | ||||
|     : public unary_function<const volatile _Cp*, _Rp> | ||||
| template <class _R, class _C> | ||||
| struct __weak_result_type<_R (_C::*)() const volatile> | ||||
|     : public unary_function<const volatile _C*, _R> | ||||
| { | ||||
| }; | ||||
|  | ||||
| // 2 argument case | ||||
|  | ||||
| template <class _Rp, class _A1, class _A2> | ||||
| struct __weak_result_type<_Rp (_A1, _A2)> | ||||
|     : public binary_function<_A1, _A2, _Rp> | ||||
| template <class _R, class _A1, class _A2> | ||||
| struct __weak_result_type<_R (_A1, _A2)> | ||||
|     : public binary_function<_A1, _A2, _R> | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _A1, class _A2> | ||||
| struct __weak_result_type<_Rp (*)(_A1, _A2)> | ||||
|     : public binary_function<_A1, _A2, _Rp> | ||||
| template <class _R, class _A1, class _A2> | ||||
| struct __weak_result_type<_R (*)(_A1, _A2)> | ||||
|     : public binary_function<_A1, _A2, _R> | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _A1, class _A2> | ||||
| struct __weak_result_type<_Rp (&)(_A1, _A2)> | ||||
|     : public binary_function<_A1, _A2, _Rp> | ||||
| template <class _R, class _A1, class _A2> | ||||
| struct __weak_result_type<_R (&)(_A1, _A2)> | ||||
|     : public binary_function<_A1, _A2, _R> | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _Cp, class _A1> | ||||
| struct __weak_result_type<_Rp (_Cp::*)(_A1)> | ||||
|     : public binary_function<_Cp*, _A1, _Rp> | ||||
| template <class _R, class _C, class _A1> | ||||
| struct __weak_result_type<_R (_C::*)(_A1)> | ||||
|     : public binary_function<_C*, _A1, _R> | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _Cp, class _A1> | ||||
| struct __weak_result_type<_Rp (_Cp::*)(_A1) const> | ||||
|     : public binary_function<const _Cp*, _A1, _Rp> | ||||
| template <class _R, class _C, class _A1> | ||||
| struct __weak_result_type<_R (_C::*)(_A1) const> | ||||
|     : public binary_function<const _C*, _A1, _R> | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _Cp, class _A1> | ||||
| struct __weak_result_type<_Rp (_Cp::*)(_A1) volatile> | ||||
|     : public binary_function<volatile _Cp*, _A1, _Rp> | ||||
| template <class _R, class _C, class _A1> | ||||
| struct __weak_result_type<_R (_C::*)(_A1) volatile> | ||||
|     : public binary_function<volatile _C*, _A1, _R> | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _Cp, class _A1> | ||||
| struct __weak_result_type<_Rp (_Cp::*)(_A1) const volatile> | ||||
|     : public binary_function<const volatile _Cp*, _A1, _Rp> | ||||
| template <class _R, class _C, class _A1> | ||||
| struct __weak_result_type<_R (_C::*)(_A1) const volatile> | ||||
|     : public binary_function<const volatile _C*, _A1, _R> | ||||
| { | ||||
| }; | ||||
|  | ||||
| // 3 or more arguments | ||||
|  | ||||
| template <class _Rp, class _A1, class _A2, class _A3, class ..._A4> | ||||
| struct __weak_result_type<_Rp (_A1, _A2, _A3, _A4...)> | ||||
| template <class _R, class _A1, class _A2, class _A3, class ..._A4> | ||||
| struct __weak_result_type<_R (_A1, _A2, _A3, _A4...)> | ||||
| { | ||||
|     typedef _Rp result_type; | ||||
|     typedef _R result_type; | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _A1, class _A2, class _A3, class ..._A4> | ||||
| struct __weak_result_type<_Rp (&)(_A1, _A2, _A3, _A4...)> | ||||
| template <class _R, class _A1, class _A2, class _A3, class ..._A4> | ||||
| struct __weak_result_type<_R (&)(_A1, _A2, _A3, _A4...)> | ||||
| { | ||||
|     typedef _Rp result_type; | ||||
|     typedef _R result_type; | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _A1, class _A2, class _A3, class ..._A4> | ||||
| struct __weak_result_type<_Rp (*)(_A1, _A2, _A3, _A4...)> | ||||
| template <class _R, class _A1, class _A2, class _A3, class ..._A4> | ||||
| struct __weak_result_type<_R (*)(_A1, _A2, _A3, _A4...)> | ||||
| { | ||||
|     typedef _Rp result_type; | ||||
|     typedef _R result_type; | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _Cp, class _A1, class _A2, class ..._A3> | ||||
| struct __weak_result_type<_Rp (_Cp::*)(_A1, _A2, _A3...)> | ||||
| template <class _R, class _C, class _A1, class _A2, class ..._A3> | ||||
| struct __weak_result_type<_R (_C::*)(_A1, _A2, _A3...)> | ||||
| { | ||||
|     typedef _Rp result_type; | ||||
|     typedef _R result_type; | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _Cp, class _A1, class _A2, class ..._A3> | ||||
| struct __weak_result_type<_Rp (_Cp::*)(_A1, _A2, _A3...) const> | ||||
| template <class _R, class _C, class _A1, class _A2, class ..._A3> | ||||
| struct __weak_result_type<_R (_C::*)(_A1, _A2, _A3...) const> | ||||
| { | ||||
|     typedef _Rp result_type; | ||||
|     typedef _R result_type; | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _Cp, class _A1, class _A2, class ..._A3> | ||||
| struct __weak_result_type<_Rp (_Cp::*)(_A1, _A2, _A3...) volatile> | ||||
| template <class _R, class _C, class _A1, class _A2, class ..._A3> | ||||
| struct __weak_result_type<_R (_C::*)(_A1, _A2, _A3...) volatile> | ||||
| { | ||||
|     typedef _Rp result_type; | ||||
|     typedef _R result_type; | ||||
| }; | ||||
|  | ||||
| template <class _Rp, class _Cp, class _A1, class _A2, class ..._A3> | ||||
| struct __weak_result_type<_Rp (_Cp::*)(_A1, _A2, _A3...) const volatile> | ||||
| template <class _R, class _C, class _A1, class _A2, class ..._A3> | ||||
| struct __weak_result_type<_R (_C::*)(_A1, _A2, _A3...) const volatile> | ||||
| { | ||||
|     typedef _Rp result_type; | ||||
|     typedef _R result_type; | ||||
| }; | ||||
|  | ||||
| // __invoke | ||||
|  | ||||
| // bullets 1 and 2 | ||||
| // first bullet | ||||
|  | ||||
| template <class _Fp, class _A0, class ..._Args, | ||||
|             class> | ||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| auto | ||||
| __invoke(_Fp&& __f, _A0&& __a0, _Args&& ...__args) | ||||
|     -> decltype((_VSTD::forward<_A0>(__a0).*__f)(_VSTD::forward<_Args>(__args)...)) | ||||
| typename enable_if | ||||
| < | ||||
|     sizeof...(_Param) == sizeof...(_Arg) && | ||||
|     is_base_of<_T, typename remove_reference<_T1>::type>::value, | ||||
|     _R | ||||
| >::type | ||||
| __invoke(_R (_T::*__f)(_Param...), _T1&& __t1, _Arg&& ...__arg) | ||||
| { | ||||
|     return (_VSTD::forward<_A0>(__a0).*__f)(_VSTD::forward<_Args>(__args)...); | ||||
|     return (_STD::forward<_T>(__t1).*__f)(_STD::forward<_Arg>(__arg)...); | ||||
| } | ||||
|  | ||||
| template <class _Fp, class _A0, class ..._Args, | ||||
|             class> | ||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| auto | ||||
| __invoke(_Fp&& __f, _A0&& __a0, _Args&& ...__args) | ||||
|     -> decltype(((*_VSTD::forward<_A0>(__a0)).*__f)(_VSTD::forward<_Args>(__args)...)) | ||||
| typename enable_if | ||||
| < | ||||
|     sizeof...(_Param) == sizeof...(_Arg) && | ||||
|     is_base_of<_T, typename remove_reference<_T1>::type>::value, | ||||
|     _R | ||||
| >::type | ||||
| __invoke(_R (_T::*__f)(_Param...) const, _T1&& __t1, _Arg&& ...__arg) | ||||
| { | ||||
|     return ((*_VSTD::forward<_A0>(__a0)).*__f)(_VSTD::forward<_Args>(__args)...); | ||||
|     return (_STD::forward<const _T>(__t1).*__f)(_STD::forward<_Arg>(__arg)...); | ||||
| } | ||||
|  | ||||
| // bullets 3 and 4 | ||||
|  | ||||
| template <class _Fp, class _A0, | ||||
|             class> | ||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| auto | ||||
| __invoke(_Fp&& __f, _A0&& __a0) | ||||
|     -> decltype(_VSTD::forward<_A0>(__a0).*__f) | ||||
| typename enable_if | ||||
| < | ||||
|     sizeof...(_Param) == sizeof...(_Arg) && | ||||
|     is_base_of<_T, typename remove_reference<_T1>::type>::value, | ||||
|     _R | ||||
| >::type | ||||
| __invoke(_R (_T::*__f)(_Param...) volatile, _T1&& __t1, _Arg&& ...__arg) | ||||
| { | ||||
|     return _VSTD::forward<_A0>(__a0).*__f; | ||||
|     return (_STD::forward<volatile _T>(__t1).*__f)(_STD::forward<_Arg>(__arg)...); | ||||
| } | ||||
|  | ||||
| template <class _Fp, class _A0, | ||||
|             class> | ||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| auto | ||||
| __invoke(_Fp&& __f, _A0&& __a0) | ||||
|     -> decltype((*_VSTD::forward<_A0>(__a0)).*__f) | ||||
| typename enable_if | ||||
| < | ||||
|     sizeof...(_Param) == sizeof...(_Arg) && | ||||
|     is_base_of<_T, typename remove_reference<_T1>::type>::value, | ||||
|     _R | ||||
| >::type | ||||
| __invoke(_R (_T::*__f)(_Param...) const volatile, _T1&& __t1, _Arg&& ...__arg) | ||||
| { | ||||
|     return (*_VSTD::forward<_A0>(__a0)).*__f; | ||||
|     return (_STD::forward<const volatile _T>(__t1).*__f)(_STD::forward<_Arg>(__arg)...); | ||||
| } | ||||
|  | ||||
| // bullet 5 | ||||
| // second bullet | ||||
|  | ||||
| template <class _Fp, class ..._Args> | ||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| auto | ||||
| __invoke(_Fp&& __f, _Args&& ...__args) | ||||
|     -> decltype(_VSTD::forward<_Fp>(__f)(_VSTD::forward<_Args>(__args)...)) | ||||
| typename enable_if | ||||
| < | ||||
|     sizeof...(_Param) == sizeof...(_Arg) && | ||||
|     !is_base_of<_T, typename remove_reference<_T1>::type>::value, | ||||
|     _R | ||||
| >::type | ||||
| __invoke(_R (_T::*__f)(_Param...), _T1&& __t1, _Arg&& ...__arg) | ||||
| { | ||||
|     return _VSTD::forward<_Fp>(__f)(_VSTD::forward<_Args>(__args)...); | ||||
|     return ((*_STD::forward<_T1>(__t1)).*__f)(_STD::forward<_Arg>(__arg)...); | ||||
| } | ||||
|  | ||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| typename enable_if | ||||
| < | ||||
|     sizeof...(_Param) == sizeof...(_Arg) && | ||||
|     !is_base_of<_T, typename remove_reference<_T1>::type>::value, | ||||
|     _R | ||||
| >::type | ||||
| __invoke(_R (_T::*__f)(_Param...) const, _T1&& __t1, _Arg&& ...__arg) | ||||
| { | ||||
|     return ((*_STD::forward<_T1>(__t1)).*__f)(_STD::forward<_Arg>(__arg)...); | ||||
| } | ||||
|  | ||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| typename enable_if | ||||
| < | ||||
|     sizeof...(_Param) == sizeof...(_Arg) && | ||||
|     !is_base_of<_T, typename remove_reference<_T1>::type>::value, | ||||
|     _R | ||||
| >::type | ||||
| __invoke(_R (_T::*__f)(_Param...) volatile, _T1&& __t1, _Arg&& ...__arg) | ||||
| { | ||||
|     return ((*_STD::forward<_T1>(__t1)).*__f)(_STD::forward<_Arg>(__arg)...); | ||||
| } | ||||
|  | ||||
| template <class _R, class _T, class _T1, class ..._Param, class ..._Arg> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| typename enable_if | ||||
| < | ||||
|     sizeof...(_Param) == sizeof...(_Arg) && | ||||
|     !is_base_of<_T, typename remove_reference<_T1>::type>::value, | ||||
|     _R | ||||
| >::type | ||||
| __invoke(_R (_T::*__f)(_Param...) const volatile, _T1&& __t1, _Arg&& ...__arg) | ||||
| { | ||||
|     return ((*_STD::forward<_T1>(__t1)).*__f)(_STD::forward<_Arg>(__arg)...); | ||||
| } | ||||
|  | ||||
| // third bullet | ||||
|  | ||||
| template <class _R, class _T, class _T1> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| typename enable_if | ||||
| < | ||||
|     is_base_of<_T, typename remove_reference<_T1>::type>::value, | ||||
|     typename __apply_cv<_T1, _R>::type&& | ||||
| >::type | ||||
| __invoke(_R _T::* __f, _T1&& __t1) | ||||
| { | ||||
|     return _STD::forward<_T1>(__t1).*__f; | ||||
| } | ||||
|  | ||||
| // forth bullet | ||||
|  | ||||
| template <class _T1, class _R, bool> | ||||
| struct __4th_helper | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _T1, class _R> | ||||
| struct __4th_helper<_T1, _R, true> | ||||
| { | ||||
|     typedef typename __apply_cv<decltype(*_STD::declval<_T1>()), _R>::type type; | ||||
| }; | ||||
|  | ||||
| template <class _R, class _T, class _T1> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| typename __4th_helper<_T1, _R, | ||||
|                       !is_base_of<_T, | ||||
|                                   typename remove_reference<_T1>::type | ||||
|                                  >::value | ||||
|                      >::type&& | ||||
| __invoke(_R _T::* __f, _T1&& __t1) | ||||
| { | ||||
|     return (*_STD::forward<_T1>(__t1)).*__f; | ||||
| } | ||||
|  | ||||
| // fifth bullet | ||||
|  | ||||
| template <class _F, class ..._T> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| typename result_of<_F(_T...)>::type | ||||
| __invoke(_F&& __f, _T&& ...__t) | ||||
| { | ||||
|     return _STD::forward<_F>(__f)(_STD::forward<_T>(__t)...); | ||||
| } | ||||
|  | ||||
| template <class _Tp, class ..._Args> | ||||
| struct __invoke_return | ||||
| { | ||||
|     typedef decltype(__invoke(_VSTD::declval<_Tp>(), _VSTD::declval<_Args>()...)) type; | ||||
|     typedef decltype(__invoke(_STD::declval<_Tp>(), _STD::declval<_Args>()...)) type; | ||||
| }; | ||||
|  | ||||
| template <class _Tp> | ||||
| class _LIBCPP_TYPE_VIS_ONLY reference_wrapper | ||||
| class _LIBCPP_VISIBLE reference_wrapper | ||||
|     : public __weak_result_type<_Tp> | ||||
| { | ||||
| public: | ||||
| @@ -431,23 +456,22 @@ private: | ||||
|  | ||||
| public: | ||||
|     // construct/copy/destroy | ||||
|     _LIBCPP_INLINE_VISIBILITY reference_wrapper(type& __f) _NOEXCEPT | ||||
|         : __f_(_VSTD::addressof(__f)) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY reference_wrapper(type& __f) : __f_(&__f) {} | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     private: reference_wrapper(type&&); public: // = delete; // do not bind to temps | ||||
| #endif | ||||
|  | ||||
|     // access | ||||
|     _LIBCPP_INLINE_VISIBILITY operator type&    () const _NOEXCEPT {return *__f_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY          type& get() const _NOEXCEPT {return *__f_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY operator type&    () const {return *__f_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY          type& get() const {return *__f_;} | ||||
|  | ||||
|     // invoke | ||||
|     template <class... _ArgTypes> | ||||
|        _LIBCPP_INLINE_VISIBILITY | ||||
|        typename __invoke_of<type&, _ArgTypes...>::type | ||||
|        typename __invoke_return<type&, _ArgTypes...>::type | ||||
|           operator() (_ArgTypes&&... __args) const | ||||
|           { | ||||
|               return __invoke(get(), _VSTD::forward<_ArgTypes>(__args)...); | ||||
|               return __invoke(get(), _STD::forward<_ArgTypes>(__args)...); | ||||
|           } | ||||
| }; | ||||
|  | ||||
| @@ -459,7 +483,7 @@ template <class _Tp> struct __is_reference_wrapper | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| reference_wrapper<_Tp> | ||||
| ref(_Tp& __t) _NOEXCEPT | ||||
| ref(_Tp& __t) | ||||
| { | ||||
|     return reference_wrapper<_Tp>(__t); | ||||
| } | ||||
| @@ -467,7 +491,7 @@ ref(_Tp& __t) _NOEXCEPT | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| reference_wrapper<_Tp> | ||||
| ref(reference_wrapper<_Tp> __t) _NOEXCEPT | ||||
| ref(reference_wrapper<_Tp> __t) | ||||
| { | ||||
|     return ref(__t.get()); | ||||
| } | ||||
| @@ -475,7 +499,7 @@ ref(reference_wrapper<_Tp> __t) _NOEXCEPT | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| reference_wrapper<const _Tp> | ||||
| cref(const _Tp& __t) _NOEXCEPT | ||||
| cref(const _Tp& __t) | ||||
| { | ||||
|     return reference_wrapper<const _Tp>(__t); | ||||
| } | ||||
| @@ -483,7 +507,7 @@ cref(const _Tp& __t) _NOEXCEPT | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| reference_wrapper<const _Tp> | ||||
| cref(reference_wrapper<_Tp> __t) _NOEXCEPT | ||||
| cref(reference_wrapper<_Tp> __t) | ||||
| { | ||||
|     return cref(__t.get()); | ||||
| } | ||||
| @@ -491,13 +515,13 @@ cref(reference_wrapper<_Tp> __t) _NOEXCEPT | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| #ifndef _LIBCPP_HAS_NO_DELETED_FUNCTIONS | ||||
|  | ||||
| template <class _Tp> void ref(const _Tp&&) = delete; | ||||
| template <class _Tp> void cref(const _Tp&&) = delete; | ||||
| template <class _Tp> void ref(const _Tp&& __t) = delete; | ||||
| template <class _Tp> void cref(const _Tp&& __t) = delete; | ||||
|  | ||||
| #else  // _LIBCPP_HAS_NO_DELETED_FUNCTIONS | ||||
|  | ||||
| template <class _Tp> void ref(const _Tp&&);// = delete; | ||||
| template <class _Tp> void cref(const _Tp&&);// = delete; | ||||
| template <class _Tp> void ref(const _Tp&& __t);// = delete; | ||||
| template <class _Tp> void cref(const _Tp&& __t);// = delete; | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_DELETED_FUNCTIONS | ||||
|  | ||||
| @@ -505,111 +529,6 @@ template <class _Tp> void cref(const _Tp&&);// = delete; | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||
|  | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
| template <class _Tp1, class _Tp2 = void> | ||||
| struct __is_transparent | ||||
| { | ||||
| private: | ||||
|     struct __two {char __lx; char __lxx;}; | ||||
|     template <class _Up> static __two __test(...); | ||||
|     template <class _Up> static char __test(typename _Up::is_transparent* = 0); | ||||
| public: | ||||
|     static const bool value = sizeof(__test<_Tp1>(0)) == 1; | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| // allocator_arg_t | ||||
|  | ||||
| struct _LIBCPP_TYPE_VIS_ONLY allocator_arg_t { }; | ||||
|  | ||||
| #if defined(_LIBCPP_HAS_NO_CONSTEXPR) || defined(_LIBCPP_BUILDING_MEMORY) | ||||
| extern const allocator_arg_t allocator_arg; | ||||
| #else | ||||
| constexpr allocator_arg_t allocator_arg = allocator_arg_t(); | ||||
| #endif | ||||
|  | ||||
| // uses_allocator | ||||
|  | ||||
| template <class _Tp> | ||||
| struct __has_allocator_type | ||||
| { | ||||
| private: | ||||
|     struct __two {char __lx; char __lxx;}; | ||||
|     template <class _Up> static __two __test(...); | ||||
|     template <class _Up> static char __test(typename _Up::allocator_type* = 0); | ||||
| public: | ||||
|     static const bool value = sizeof(__test<_Tp>(0)) == 1; | ||||
| }; | ||||
|  | ||||
| template <class _Tp, class _Alloc, bool = __has_allocator_type<_Tp>::value> | ||||
| struct __uses_allocator | ||||
|     : public integral_constant<bool, | ||||
|         is_convertible<_Alloc, typename _Tp::allocator_type>::value> | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _Tp, class _Alloc> | ||||
| struct __uses_allocator<_Tp, _Alloc, false> | ||||
|     : public false_type | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _Tp, class _Alloc> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY uses_allocator | ||||
|     : public __uses_allocator<_Tp, _Alloc> | ||||
| { | ||||
| }; | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||
|  | ||||
| // allocator construction | ||||
|  | ||||
| template <class _Tp, class _Alloc, class ..._Args> | ||||
| struct __uses_alloc_ctor_imp | ||||
| { | ||||
|     static const bool __ua = uses_allocator<_Tp, _Alloc>::value; | ||||
|     static const bool __ic = | ||||
|         is_constructible<_Tp, allocator_arg_t, _Alloc, _Args...>::value; | ||||
|     static const int value = __ua ? 2 - __ic : 0; | ||||
| }; | ||||
|  | ||||
| template <class _Tp, class _Alloc, class ..._Args> | ||||
| struct __uses_alloc_ctor | ||||
|     : integral_constant<int, __uses_alloc_ctor_imp<_Tp, _Alloc, _Args...>::value> | ||||
|     {}; | ||||
|  | ||||
| template <class _Tp, class _Allocator, class... _Args> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void __user_alloc_construct_impl (integral_constant<int, 0>, _Tp *__storage, const _Allocator &, _Args &&... __args ) | ||||
| { | ||||
|     new (__storage) _Tp (_VSTD::forward<_Args>(__args)...); | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Allocator, class... _Args> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void __user_alloc_construct_impl (integral_constant<int, 1>, _Tp *__storage, const _Allocator &__a, _Args &&... __args ) | ||||
| { | ||||
|     new (__storage) _Tp (allocator_arg, __a, _VSTD::forward<_Args>(__args)...); | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Allocator, class... _Args> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void __user_alloc_construct_impl (integral_constant<int, 2>, _Tp *__storage, const _Allocator &__a, _Args &&... __args ) | ||||
| { | ||||
|     new (__storage) _Tp (_VSTD::forward<_Args>(__args)..., __a); | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Allocator, class... _Args> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void __user_alloc_construct (_Tp *__storage, const _Allocator &__a, _Args &&... __args) | ||||
| {  | ||||
|     __user_alloc_construct_impl(  | ||||
|              __uses_alloc_ctor<_Tp, _Allocator>(),  | ||||
|              __storage, __a, _VSTD::forward<_Args>(__args)... | ||||
|         ); | ||||
| } | ||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
| #endif  // _LIBCPP_FUNCTIONAL_BASE | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1096
									
								
								include/__hash_table
									
									
									
									
									
								
							
							
						
						
									
										1096
									
								
								include/__hash_table
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										283
									
								
								include/__locale
									
									
									
									
									
								
							
							
						
						
									
										283
									
								
								include/__locale
									
									
									
									
									
								
							| @@ -19,38 +19,23 @@ | ||||
| #include <cstdint> | ||||
| #include <cctype> | ||||
| #include <locale.h> | ||||
| #if defined(_LIBCPP_MSVCRT) || defined(__MINGW32__) | ||||
| # include <support/win32/locale_win32.h> | ||||
| #elif _AIX | ||||
| # include <support/ibm/xlocale.h> | ||||
| #elif (defined(__GLIBC__) || defined(__APPLE__) || defined(__FreeBSD__) || defined(__sun__)) || defined(__EMSCRIPTEN__) || defined(__IBMCPP__) | ||||
| # include <xlocale.h> | ||||
| #endif  // _WIN32 || __GLIBC__ || __APPLE__ || __FreeBSD__ || __sun__ || __EMSCRIPTEN__ || __IBMCPP__ | ||||
| #include <xlocale.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS locale; | ||||
| class locale; | ||||
|  | ||||
| template <class _Facet> | ||||
| _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| has_facet(const locale&) _NOEXCEPT; | ||||
| template <class _Facet> bool has_facet(const locale&) throw(); | ||||
| template <class _Facet> const _Facet& use_facet(const locale&); | ||||
|  | ||||
| template <class _Facet> | ||||
| _LIBCPP_INLINE_VISIBILITY | ||||
| const _Facet& | ||||
| use_facet(const locale&); | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS locale | ||||
| class _LIBCPP_VISIBLE locale | ||||
| { | ||||
| public: | ||||
|     // types: | ||||
|     class _LIBCPP_TYPE_VIS facet; | ||||
|     class _LIBCPP_TYPE_VIS id; | ||||
|     class facet; | ||||
|     class id; | ||||
|  | ||||
|     typedef int category; | ||||
|     static const category // values assigned here are for exposition only | ||||
| @@ -64,8 +49,8 @@ public: | ||||
|         all = collate | ctype | monetary | numeric | time | messages; | ||||
|  | ||||
|     // construct/copy/destroy: | ||||
|     locale()  _NOEXCEPT; | ||||
|     locale(const locale&)  _NOEXCEPT; | ||||
|     locale() throw(); | ||||
|     locale(const locale&) throw(); | ||||
|     explicit locale(const char*); | ||||
|     explicit locale(const string&); | ||||
|     locale(const locale&, const char*, category); | ||||
| @@ -74,9 +59,9 @@ public: | ||||
|         _LIBCPP_INLINE_VISIBILITY locale(const locale&, _Facet*); | ||||
|     locale(const locale&, const locale&, category); | ||||
|  | ||||
|     ~locale(); | ||||
|     ~locale() throw(); | ||||
|  | ||||
|     const locale& operator=(const locale&)  _NOEXCEPT; | ||||
|     const locale& operator=(const locale&) throw(); | ||||
|  | ||||
|     template <class _Facet> locale combine(const locale&) const; | ||||
|  | ||||
| @@ -101,11 +86,11 @@ private: | ||||
|     bool has_facet(id&) const; | ||||
|     const facet* use_facet(id&) const; | ||||
|  | ||||
|     template <class _Facet> friend bool has_facet(const locale&)  _NOEXCEPT; | ||||
|     template <class _Facet> friend bool has_facet(const locale&) throw(); | ||||
|     template <class _Facet> friend const _Facet& use_facet(const locale&); | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS locale::facet | ||||
| class _LIBCPP_VISIBLE locale::facet | ||||
|     : public __shared_count | ||||
| { | ||||
| protected: | ||||
| @@ -118,17 +103,17 @@ protected: | ||||
| //    facet(const facet&) = delete;     // effectively done in __shared_count | ||||
| //    void operator=(const facet&) = delete; | ||||
| private: | ||||
|     virtual void __on_zero_shared() _NOEXCEPT; | ||||
|     virtual void __on_zero_shared(); | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS locale::id | ||||
| class _LIBCPP_VISIBLE locale::id | ||||
| { | ||||
|     once_flag      __flag_; | ||||
|     int32_t        __id_; | ||||
|  | ||||
|     static int32_t __next_id; | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR id() :__id_(0) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY id() {} | ||||
| private: | ||||
|     void __init(); | ||||
|     void operator=(const id&); // = delete; | ||||
| @@ -152,16 +137,16 @@ locale | ||||
| locale::combine(const locale& __other) const | ||||
| { | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     if (!_VSTD::has_facet<_Facet>(__other)) | ||||
|     if (!_STD::has_facet<_Facet>(__other)) | ||||
|         throw runtime_error("locale::combine: locale missing facet"); | ||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | ||||
|     return locale(*this, &const_cast<_Facet&>(_VSTD::use_facet<_Facet>(__other))); | ||||
|     return locale(*this, &const_cast<_Facet&>(_STD::use_facet<_Facet>(__other))); | ||||
| } | ||||
|  | ||||
| template <class _Facet> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| has_facet(const locale& __l)  _NOEXCEPT | ||||
| has_facet(const locale& __l) throw() | ||||
| { | ||||
|     return __l.has_facet(_Facet::id); | ||||
| } | ||||
| @@ -177,7 +162,7 @@ use_facet(const locale& __l) | ||||
| // template <class _CharT> class collate; | ||||
|  | ||||
| template <class _CharT> | ||||
| class _LIBCPP_TYPE_VIS_ONLY collate | ||||
| class _LIBCPP_VISIBLE collate | ||||
|     : public locale::facet | ||||
| { | ||||
| public: | ||||
| @@ -242,29 +227,29 @@ collate<_CharT>::do_compare(const char_type* __lo1, const char_type* __hi1, | ||||
|  | ||||
| template <class _CharT> | ||||
| long | ||||
| collate<_CharT>::do_hash(const char_type* __lo, const char_type* __hi) const | ||||
| collate<_CharT>::do_hash(const char_type* lo, const char_type* hi) const | ||||
| { | ||||
|     size_t __h = 0; | ||||
|     const size_t __sr = __CHAR_BIT__ * sizeof(size_t) - 8; | ||||
|     const size_t __mask = size_t(0xF) << (__sr + 4); | ||||
|     for(const char_type* __p = __lo; __p != __hi; ++__p) | ||||
|     size_t h = 0; | ||||
|     const size_t sr = __CHAR_BIT__ * sizeof(size_t) - 8; | ||||
|     const size_t mask = size_t(0xF) << (sr + 4); | ||||
|     for(const char_type* p = lo; p != hi; ++p) | ||||
|     { | ||||
|         __h = (__h << 4) + static_cast<size_t>(*__p); | ||||
|         size_t __g = __h & __mask; | ||||
|         __h ^= __g | (__g >> __sr); | ||||
|         h = (h << 4) + *p; | ||||
|         size_t g = h & mask; | ||||
|         h ^= g | (g >> sr); | ||||
|     } | ||||
|     return static_cast<long>(__h); | ||||
|     return static_cast<long>(h); | ||||
| } | ||||
|  | ||||
| _LIBCPP_EXTERN_TEMPLATE2(class _LIBCPP_TYPE_VIS collate<char>) | ||||
| _LIBCPP_EXTERN_TEMPLATE2(class _LIBCPP_TYPE_VIS collate<wchar_t>) | ||||
| extern template class _LIBCPP_VISIBLE collate<char>; | ||||
| extern template class _LIBCPP_VISIBLE collate<wchar_t>; | ||||
|  | ||||
| // template <class CharT> class collate_byname; | ||||
|  | ||||
| template <class _CharT> class _LIBCPP_TYPE_VIS_ONLY collate_byname; | ||||
| template <class _CharT> class _LIBCPP_VISIBLE collate_byname; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS collate_byname<char> | ||||
| class _LIBCPP_VISIBLE collate_byname<char> | ||||
|     : public collate<char> | ||||
| { | ||||
|     locale_t __l; | ||||
| @@ -283,7 +268,7 @@ protected: | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS collate_byname<wchar_t> | ||||
| class _LIBCPP_VISIBLE collate_byname<wchar_t> | ||||
|     : public collate<wchar_t> | ||||
| { | ||||
|     locale_t __l; | ||||
| @@ -307,18 +292,30 @@ bool | ||||
| locale::operator()(const basic_string<_CharT, _Traits, _Allocator>& __x, | ||||
|                    const basic_string<_CharT, _Traits, _Allocator>& __y) const | ||||
| { | ||||
|     return _VSTD::use_facet<_VSTD::collate<_CharT> >(*this).compare( | ||||
|     return _STD::use_facet<_STD::collate<_CharT> >(*this).compare( | ||||
|                                        __x.data(), __x.data() + __x.size(), | ||||
|                                        __y.data(), __y.data() + __y.size()) < 0; | ||||
| } | ||||
|  | ||||
| // template <class charT> class ctype | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS ctype_base | ||||
| class _LIBCPP_VISIBLE ctype_base | ||||
| { | ||||
| public: | ||||
| #ifdef __GLIBC__ | ||||
|     typedef unsigned short mask; | ||||
|     typedef __uint32_t mask; | ||||
|  | ||||
| #if __APPLE__ | ||||
|     static const mask space  = _CTYPE_S; | ||||
|     static const mask print  = _CTYPE_R; | ||||
|     static const mask cntrl  = _CTYPE_C; | ||||
|     static const mask upper  = _CTYPE_U; | ||||
|     static const mask lower  = _CTYPE_L; | ||||
|     static const mask alpha  = _CTYPE_A; | ||||
|     static const mask digit  = _CTYPE_D; | ||||
|     static const mask punct  = _CTYPE_P; | ||||
|     static const mask xdigit = _CTYPE_X; | ||||
|     static const mask blank  = _CTYPE_B; | ||||
| #else  // __APPLE__ | ||||
|     static const mask space  = _ISspace; | ||||
|     static const mask print  = _ISprint; | ||||
|     static const mask cntrl  = _IScntrl; | ||||
| @@ -329,75 +326,17 @@ public: | ||||
|     static const mask punct  = _ISpunct; | ||||
|     static const mask xdigit = _ISxdigit; | ||||
|     static const mask blank  = _ISblank; | ||||
| #elif defined(_WIN32) | ||||
|     typedef unsigned short mask; | ||||
|     static const mask space  = _SPACE; | ||||
|     static const mask print  = _BLANK|_PUNCT|_ALPHA|_DIGIT; | ||||
|     static const mask cntrl  = _CONTROL; | ||||
|     static const mask upper  = _UPPER; | ||||
|     static const mask lower  = _LOWER; | ||||
|     static const mask alpha  = _ALPHA; | ||||
|     static const mask digit  = _DIGIT; | ||||
|     static const mask punct  = _PUNCT; | ||||
|     static const mask xdigit = _HEX; | ||||
|     static const mask blank  = _BLANK; | ||||
| #elif defined(__APPLE__) || defined(__FreeBSD__) || defined(__EMSCRIPTEN__) || defined(__NetBSD__) | ||||
| #ifdef __APPLE__ | ||||
|     typedef __uint32_t mask; | ||||
| #elif defined(__FreeBSD__) | ||||
|     typedef unsigned long mask; | ||||
| #elif defined(__EMSCRIPTEN__) ||  defined(__NetBSD__) | ||||
|     typedef unsigned short mask; | ||||
| #endif | ||||
|     static const mask space  = _CTYPE_S; | ||||
|     static const mask print  = _CTYPE_R; | ||||
|     static const mask cntrl  = _CTYPE_C; | ||||
|     static const mask upper  = _CTYPE_U; | ||||
|     static const mask lower  = _CTYPE_L; | ||||
|     static const mask alpha  = _CTYPE_A; | ||||
|     static const mask digit  = _CTYPE_D; | ||||
|     static const mask punct  = _CTYPE_P; | ||||
|     static const mask xdigit = _CTYPE_X; | ||||
| # if defined(__NetBSD__) | ||||
|     static const mask blank  = _CTYPE_BL; | ||||
| # else | ||||
|     static const mask blank  = _CTYPE_B; | ||||
| # endif | ||||
| #elif defined(__sun__) || defined(_AIX) | ||||
|     typedef unsigned int mask; | ||||
|     static const mask space  = _ISSPACE; | ||||
|     static const mask print  = _ISPRINT; | ||||
|     static const mask cntrl  = _ISCNTRL; | ||||
|     static const mask upper  = _ISUPPER; | ||||
|     static const mask lower  = _ISLOWER; | ||||
|     static const mask alpha  = _ISALPHA; | ||||
|     static const mask digit  = _ISDIGIT; | ||||
|     static const mask punct  = _ISPUNCT; | ||||
|     static const mask xdigit = _ISXDIGIT; | ||||
|     static const mask blank  = _ISBLANK; | ||||
| #else  // __GLIBC__ || _WIN32 || __APPLE__ || __FreeBSD__ || __EMSCRIPTEN__ || __sun__ | ||||
|     typedef unsigned long mask; | ||||
|     static const mask space  = 1<<0; | ||||
|     static const mask print  = 1<<1; | ||||
|     static const mask cntrl  = 1<<2; | ||||
|     static const mask upper  = 1<<3; | ||||
|     static const mask lower  = 1<<4; | ||||
|     static const mask alpha  = 1<<5; | ||||
|     static const mask digit  = 1<<6; | ||||
|     static const mask punct  = 1<<7; | ||||
|     static const mask xdigit = 1<<8; | ||||
|     static const mask blank  = 1<<9; | ||||
| #endif  // __GLIBC__ || _WIN32 || __APPLE__ || __FreeBSD__ | ||||
| #endif  // __APPLE__ | ||||
|     static const mask alnum  = alpha | digit; | ||||
|     static const mask graph  = alnum | punct; | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE ctype_base() {} | ||||
| }; | ||||
|  | ||||
| template <class _CharT> class _LIBCPP_TYPE_VIS_ONLY ctype; | ||||
| template <class _CharT> class _LIBCPP_VISIBLE ctype; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS ctype<wchar_t> | ||||
| class _LIBCPP_VISIBLE ctype<wchar_t> | ||||
|     : public locale::facet, | ||||
|       public ctype_base | ||||
| { | ||||
| @@ -499,7 +438,7 @@ protected: | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS ctype<char> | ||||
| class _LIBCPP_VISIBLE ctype<char> | ||||
|     : public locale::facet, public ctype_base | ||||
| { | ||||
|     const mask* __tab_; | ||||
| @@ -512,14 +451,14 @@ public: | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     bool is(mask __m, char_type __c) const | ||||
|     { | ||||
|         return isascii(__c) ? (__tab_[static_cast<int>(__c)] & __m) !=0 : false; | ||||
|         return isascii(__c) ? __tab_[__c] & __m : false; | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     const char_type* is(const char_type* __low, const char_type* __high, mask* __vec) const | ||||
|     { | ||||
|         for (; __low != __high; ++__low, ++__vec) | ||||
|             *__vec = isascii(*__low) ? __tab_[static_cast<int>(*__low)] : 0; | ||||
|             *__vec = isascii(*__low) ? __tab_[*__low] : 0; | ||||
|         return __low; | ||||
|     } | ||||
|  | ||||
| @@ -527,7 +466,7 @@ public: | ||||
|     const char_type* scan_is (mask __m, const char_type* __low, const char_type* __high) const | ||||
|     { | ||||
|         for (; __low != __high; ++__low) | ||||
|             if (isascii(*__low) && (__tab_[static_cast<int>(*__low)] & __m)) | ||||
|             if (isascii(*__low) && (__tab_[*__low] & __m)) | ||||
|                 break; | ||||
|         return __low; | ||||
|     } | ||||
| @@ -536,7 +475,7 @@ public: | ||||
|     const char_type* scan_not(mask __m, const char_type* __low, const char_type* __high) const | ||||
|     { | ||||
|         for (; __low != __high; ++__low) | ||||
|             if (!(isascii(*__low) && (__tab_[static_cast<int>(*__low)] & __m))) | ||||
|             if (!(isascii(*__low) && (__tab_[*__low] & __m))) | ||||
|                 break; | ||||
|         return __low; | ||||
|     } | ||||
| @@ -596,16 +535,8 @@ public: | ||||
| #else | ||||
|     static const size_t table_size = 256;  // FIXME: Don't hardcode this. | ||||
| #endif | ||||
|     _LIBCPP_ALWAYS_INLINE const mask* table() const  _NOEXCEPT {return __tab_;} | ||||
|     static const mask* classic_table()  _NOEXCEPT; | ||||
| #if defined(__GLIBC__) || defined(__EMSCRIPTEN__) | ||||
|     static const int* __classic_upper_table() _NOEXCEPT; | ||||
|     static const int* __classic_lower_table() _NOEXCEPT; | ||||
| #endif | ||||
| #if defined(__NetBSD__) | ||||
|     static const short* __classic_upper_table() _NOEXCEPT; | ||||
|     static const short* __classic_lower_table() _NOEXCEPT; | ||||
| #endif | ||||
|     _LIBCPP_ALWAYS_INLINE const mask* table() const throw() {return __tab_;} | ||||
|     static const mask* classic_table() throw(); | ||||
|  | ||||
| protected: | ||||
|     ~ctype(); | ||||
| @@ -621,10 +552,10 @@ protected: | ||||
|  | ||||
| // template <class CharT> class ctype_byname; | ||||
|  | ||||
| template <class _CharT> class _LIBCPP_TYPE_VIS_ONLY ctype_byname; | ||||
| template <class _CharT> class _LIBCPP_VISIBLE ctype_byname; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS ctype_byname<char> | ||||
| class _LIBCPP_VISIBLE ctype_byname<char> | ||||
|     : public ctype<char> | ||||
| { | ||||
|     locale_t __l; | ||||
| @@ -642,7 +573,7 @@ protected: | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS ctype_byname<wchar_t> | ||||
| class _LIBCPP_VISIBLE ctype_byname<wchar_t> | ||||
|     : public ctype<wchar_t> | ||||
| { | ||||
|     locale_t __l; | ||||
| @@ -773,7 +704,7 @@ tolower(_CharT __c, const locale& __loc) | ||||
|  | ||||
| // codecvt_base | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS codecvt_base | ||||
| class _LIBCPP_VISIBLE codecvt_base | ||||
| { | ||||
| public: | ||||
|     _LIBCPP_ALWAYS_INLINE codecvt_base() {} | ||||
| @@ -782,12 +713,12 @@ public: | ||||
|  | ||||
| // template <class internT, class externT, class stateT> class codecvt; | ||||
|  | ||||
| template <class _InternT, class _ExternT, class _StateT> class _LIBCPP_TYPE_VIS_ONLY codecvt; | ||||
| template <class _InternT, class _ExternT, class _StateT> class _LIBCPP_VISIBLE codecvt; | ||||
|  | ||||
| // template <> class codecvt<char, char, mbstate_t> | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS codecvt<char, char, mbstate_t> | ||||
| class _LIBCPP_VISIBLE codecvt<char, char, mbstate_t> | ||||
|     : public locale::facet, | ||||
|       public codecvt_base | ||||
| { | ||||
| @@ -824,13 +755,13 @@ public: | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     int encoding() const  _NOEXCEPT | ||||
|     int encoding() const throw() | ||||
|     { | ||||
|         return do_encoding(); | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     bool always_noconv() const  _NOEXCEPT | ||||
|     bool always_noconv() const throw() | ||||
|     { | ||||
|         return do_always_noconv(); | ||||
|     } | ||||
| @@ -842,7 +773,7 @@ public: | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     int max_length() const  _NOEXCEPT | ||||
|     int max_length() const throw() | ||||
|     { | ||||
|         return do_max_length(); | ||||
|     } | ||||
| @@ -864,16 +795,16 @@ protected: | ||||
|                          intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; | ||||
|     virtual result do_unshift(state_type& __st, | ||||
|                               extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; | ||||
|     virtual int do_encoding() const  _NOEXCEPT; | ||||
|     virtual bool do_always_noconv() const  _NOEXCEPT; | ||||
|     virtual int do_encoding() const throw(); | ||||
|     virtual bool do_always_noconv() const throw(); | ||||
|     virtual int do_length(state_type& __st, const extern_type* __frm, const extern_type* __end, size_t __mx) const; | ||||
|     virtual int do_max_length() const  _NOEXCEPT; | ||||
|     virtual int do_max_length() const throw(); | ||||
| }; | ||||
|  | ||||
| // template <> class codecvt<wchar_t, char, mbstate_t> | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS codecvt<wchar_t, char, mbstate_t> | ||||
| class _LIBCPP_VISIBLE codecvt<wchar_t, char, mbstate_t> | ||||
|     : public locale::facet, | ||||
|       public codecvt_base | ||||
| { | ||||
| @@ -909,13 +840,13 @@ public: | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     int encoding() const  _NOEXCEPT | ||||
|     int encoding() const throw() | ||||
|     { | ||||
|         return do_encoding(); | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     bool always_noconv() const  _NOEXCEPT | ||||
|     bool always_noconv() const throw() | ||||
|     { | ||||
|         return do_always_noconv(); | ||||
|     } | ||||
| @@ -927,7 +858,7 @@ public: | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     int max_length() const  _NOEXCEPT | ||||
|     int max_length() const throw() | ||||
|     { | ||||
|         return do_max_length(); | ||||
|     } | ||||
| @@ -947,16 +878,16 @@ protected: | ||||
|                          intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; | ||||
|     virtual result do_unshift(state_type& __st, | ||||
|                               extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; | ||||
|     virtual int do_encoding() const  _NOEXCEPT; | ||||
|     virtual bool do_always_noconv() const  _NOEXCEPT; | ||||
|     virtual int do_encoding() const throw(); | ||||
|     virtual bool do_always_noconv() const throw(); | ||||
|     virtual int do_length(state_type&, const extern_type* __frm, const extern_type* __end, size_t __mx) const; | ||||
|     virtual int do_max_length() const  _NOEXCEPT; | ||||
|     virtual int do_max_length() const throw(); | ||||
| }; | ||||
|  | ||||
| // template <> class codecvt<char16_t, char, mbstate_t> | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS codecvt<char16_t, char, mbstate_t> | ||||
| class _LIBCPP_VISIBLE codecvt<char16_t, char, mbstate_t> | ||||
|     : public locale::facet, | ||||
|       public codecvt_base | ||||
| { | ||||
| @@ -993,13 +924,13 @@ public: | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     int encoding() const  _NOEXCEPT | ||||
|     int encoding() const throw() | ||||
|     { | ||||
|         return do_encoding(); | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     bool always_noconv() const  _NOEXCEPT | ||||
|     bool always_noconv() const throw() | ||||
|     { | ||||
|         return do_always_noconv(); | ||||
|     } | ||||
| @@ -1011,7 +942,7 @@ public: | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     int max_length() const  _NOEXCEPT | ||||
|     int max_length() const throw() | ||||
|     { | ||||
|         return do_max_length(); | ||||
|     } | ||||
| @@ -1033,16 +964,16 @@ protected: | ||||
|                          intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; | ||||
|     virtual result do_unshift(state_type& __st, | ||||
|                               extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; | ||||
|     virtual int do_encoding() const  _NOEXCEPT; | ||||
|     virtual bool do_always_noconv() const  _NOEXCEPT; | ||||
|     virtual int do_encoding() const throw(); | ||||
|     virtual bool do_always_noconv() const throw(); | ||||
|     virtual int do_length(state_type&, const extern_type* __frm, const extern_type* __end, size_t __mx) const; | ||||
|     virtual int do_max_length() const  _NOEXCEPT; | ||||
|     virtual int do_max_length() const throw(); | ||||
| }; | ||||
|  | ||||
| // template <> class codecvt<char32_t, char, mbstate_t> | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS codecvt<char32_t, char, mbstate_t> | ||||
| class _LIBCPP_VISIBLE codecvt<char32_t, char, mbstate_t> | ||||
|     : public locale::facet, | ||||
|       public codecvt_base | ||||
| { | ||||
| @@ -1079,13 +1010,13 @@ public: | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     int encoding() const  _NOEXCEPT | ||||
|     int encoding() const throw() | ||||
|     { | ||||
|         return do_encoding(); | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     bool always_noconv() const  _NOEXCEPT | ||||
|     bool always_noconv() const throw() | ||||
|     { | ||||
|         return do_always_noconv(); | ||||
|     } | ||||
| @@ -1097,7 +1028,7 @@ public: | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     int max_length() const  _NOEXCEPT | ||||
|     int max_length() const throw() | ||||
|     { | ||||
|         return do_max_length(); | ||||
|     } | ||||
| @@ -1119,16 +1050,16 @@ protected: | ||||
|                          intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; | ||||
|     virtual result do_unshift(state_type& __st, | ||||
|                               extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; | ||||
|     virtual int do_encoding() const  _NOEXCEPT; | ||||
|     virtual bool do_always_noconv() const  _NOEXCEPT; | ||||
|     virtual int do_encoding() const throw(); | ||||
|     virtual bool do_always_noconv() const throw(); | ||||
|     virtual int do_length(state_type&, const extern_type* __frm, const extern_type* __end, size_t __mx) const; | ||||
|     virtual int do_max_length() const  _NOEXCEPT; | ||||
|     virtual int do_max_length() const throw(); | ||||
| }; | ||||
|  | ||||
| // template <class _InternT, class _ExternT, class _StateT> class codecvt_byname | ||||
|  | ||||
| template <class _InternT, class _ExternT, class _StateT> | ||||
| class _LIBCPP_TYPE_VIS_ONLY codecvt_byname | ||||
| class _LIBCPP_VISIBLE codecvt_byname | ||||
|     : public codecvt<_InternT, _ExternT, _StateT> | ||||
| { | ||||
| public: | ||||
| @@ -1147,14 +1078,14 @@ codecvt_byname<_InternT, _ExternT, _StateT>::~codecvt_byname() | ||||
| { | ||||
| } | ||||
|  | ||||
| _LIBCPP_EXTERN_TEMPLATE2(class _LIBCPP_TYPE_VIS codecvt_byname<char, char, mbstate_t>) | ||||
| _LIBCPP_EXTERN_TEMPLATE2(class _LIBCPP_TYPE_VIS codecvt_byname<wchar_t, char, mbstate_t>) | ||||
| _LIBCPP_EXTERN_TEMPLATE2(class _LIBCPP_TYPE_VIS codecvt_byname<char16_t, char, mbstate_t>) | ||||
| _LIBCPP_EXTERN_TEMPLATE2(class _LIBCPP_TYPE_VIS codecvt_byname<char32_t, char, mbstate_t>) | ||||
| extern template class codecvt_byname<char, char, mbstate_t>; | ||||
| extern template class codecvt_byname<wchar_t, char, mbstate_t>; | ||||
| extern template class codecvt_byname<char16_t, char, mbstate_t>; | ||||
| extern template class codecvt_byname<char32_t, char, mbstate_t>; | ||||
|  | ||||
| _LIBCPP_FUNC_VIS void __throw_runtime_error(const char*); | ||||
| _LIBCPP_VISIBLE void __throw_runtime_error(const char*); | ||||
|  | ||||
| template <size_t _Np> | ||||
| template <size_t _N> | ||||
| struct __narrow_to_utf8 | ||||
| { | ||||
|     template <class _OutputIterator, class _CharT> | ||||
| @@ -1244,7 +1175,7 @@ struct __narrow_to_utf8<32> | ||||
|     } | ||||
| }; | ||||
|  | ||||
| template <size_t _Np> | ||||
| template <size_t _N> | ||||
| struct __widen_from_utf8 | ||||
| { | ||||
|     template <class _OutputIterator> | ||||
| @@ -1336,10 +1267,10 @@ struct __widen_from_utf8<32> | ||||
|  | ||||
| // template <class charT> class numpunct | ||||
|  | ||||
| template <class _CharT> class _LIBCPP_TYPE_VIS_ONLY numpunct; | ||||
| template <class _CharT> class _LIBCPP_VISIBLE numpunct; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS numpunct<char> | ||||
| class _LIBCPP_VISIBLE numpunct<char> | ||||
|     : public locale::facet | ||||
| { | ||||
| public: | ||||
| @@ -1370,7 +1301,7 @@ protected: | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS numpunct<wchar_t> | ||||
| class _LIBCPP_VISIBLE numpunct<wchar_t> | ||||
|     : public locale::facet | ||||
| { | ||||
| public: | ||||
| @@ -1402,10 +1333,10 @@ protected: | ||||
|  | ||||
| // template <class charT> class numpunct_byname | ||||
|  | ||||
| template <class charT> class _LIBCPP_TYPE_VIS_ONLY numpunct_byname; | ||||
| template <class charT> class _LIBCPP_VISIBLE numpunct_byname; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS numpunct_byname<char> | ||||
| class _LIBCPP_VISIBLE numpunct_byname<char> | ||||
| : public numpunct<char> | ||||
| { | ||||
| public: | ||||
| @@ -1423,7 +1354,7 @@ private: | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS numpunct_byname<wchar_t> | ||||
| class _LIBCPP_VISIBLE numpunct_byname<wchar_t> | ||||
| : public numpunct<wchar_t> | ||||
| { | ||||
| public: | ||||
|   | ||||
| @@ -16,23 +16,27 @@ | ||||
| #include <system_error> | ||||
| #include <pthread.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| #ifdef _LIBCPP_SHARED_LOCK | ||||
|  | ||||
| namespace ting { | ||||
| template <class> class shared_lock; | ||||
| template <class> class upgrade_lock; | ||||
| } | ||||
|  | ||||
| #endif  // _LIBCPP_SHARED_LOCK | ||||
|  | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS mutex | ||||
| class _LIBCPP_VISIBLE mutex | ||||
| { | ||||
|     pthread_mutex_t __m_; | ||||
|  | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
| #ifndef _LIBCPP_HAS_NO_CONSTEXPR | ||||
|      constexpr mutex() _NOEXCEPT : __m_(PTHREAD_MUTEX_INITIALIZER) {} | ||||
| #else | ||||
|      mutex() _NOEXCEPT {__m_ = (pthread_mutex_t)PTHREAD_MUTEX_INITIALIZER;} | ||||
| #endif | ||||
|      mutex() {__m_ = (pthread_mutex_t)PTHREAD_MUTEX_INITIALIZER;} | ||||
|      ~mutex(); | ||||
|  | ||||
| private: | ||||
| @@ -41,33 +45,31 @@ private: | ||||
|  | ||||
| public: | ||||
|     void lock(); | ||||
|     bool try_lock() _NOEXCEPT; | ||||
|     void unlock() _NOEXCEPT; | ||||
|     bool try_lock(); | ||||
|     void unlock(); | ||||
|  | ||||
|     typedef pthread_mutex_t* native_handle_type; | ||||
|     _LIBCPP_INLINE_VISIBILITY native_handle_type native_handle() {return &__m_;} | ||||
| }; | ||||
|  | ||||
| struct _LIBCPP_TYPE_VIS defer_lock_t {}; | ||||
| struct _LIBCPP_TYPE_VIS try_to_lock_t {}; | ||||
| struct _LIBCPP_TYPE_VIS adopt_lock_t {}; | ||||
| struct _LIBCPP_VISIBLE defer_lock_t {}; | ||||
| struct _LIBCPP_VISIBLE try_to_lock_t {}; | ||||
| struct _LIBCPP_VISIBLE adopt_lock_t {}; | ||||
|  | ||||
| #if defined(_LIBCPP_HAS_NO_CONSTEXPR) || defined(_LIBCPP_BUILDING_MUTEX) | ||||
| //constexpr | ||||
| extern const | ||||
| defer_lock_t  defer_lock; | ||||
|  | ||||
| extern const defer_lock_t  defer_lock; | ||||
| extern const try_to_lock_t try_to_lock; | ||||
| extern const adopt_lock_t  adopt_lock; | ||||
| //constexpr | ||||
| extern const | ||||
| try_to_lock_t try_to_lock; | ||||
|  | ||||
| #else | ||||
|  | ||||
| constexpr defer_lock_t  defer_lock  = defer_lock_t(); | ||||
| constexpr try_to_lock_t try_to_lock = try_to_lock_t(); | ||||
| constexpr adopt_lock_t  adopt_lock  = adopt_lock_t(); | ||||
|  | ||||
| #endif | ||||
| //constexpr | ||||
| extern const | ||||
| adopt_lock_t  adopt_lock; | ||||
|  | ||||
| template <class _Mutex> | ||||
| class _LIBCPP_TYPE_VIS_ONLY lock_guard | ||||
| class _LIBCPP_VISIBLE lock_guard | ||||
| { | ||||
| public: | ||||
|     typedef _Mutex mutex_type; | ||||
| @@ -91,7 +93,7 @@ private: | ||||
| }; | ||||
|  | ||||
| template <class _Mutex> | ||||
| class _LIBCPP_TYPE_VIS_ONLY unique_lock | ||||
| class _LIBCPP_VISIBLE unique_lock | ||||
| { | ||||
| public: | ||||
|     typedef _Mutex mutex_type; | ||||
| @@ -102,12 +104,12 @@ private: | ||||
|  | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     unique_lock() _NOEXCEPT : __m_(nullptr), __owns_(false) {} | ||||
|     unique_lock() : __m_(nullptr), __owns_(false) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit unique_lock(mutex_type& __m) | ||||
|         : __m_(&__m), __owns_(true) {__m_->lock();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     unique_lock(mutex_type& __m, defer_lock_t) _NOEXCEPT | ||||
|     unique_lock(mutex_type& __m, defer_lock_t) | ||||
|         : __m_(&__m), __owns_(false) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     unique_lock(mutex_type& __m, try_to_lock_t) | ||||
| @@ -137,11 +139,11 @@ private: | ||||
| public: | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     unique_lock(unique_lock&& __u) _NOEXCEPT | ||||
|     unique_lock(unique_lock&& __u) | ||||
|         : __m_(__u.__m_), __owns_(__u.__owns_) | ||||
|         {__u.__m_ = nullptr; __u.__owns_ = false;} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     unique_lock& operator=(unique_lock&& __u) _NOEXCEPT | ||||
|     unique_lock& operator=(unique_lock&& __u) | ||||
|         { | ||||
|             if (__owns_) | ||||
|                 __m_->unlock(); | ||||
| @@ -152,6 +154,27 @@ public: | ||||
|             return *this; | ||||
|         } | ||||
|  | ||||
| #ifdef _LIBCPP_SHARED_LOCK | ||||
|  | ||||
|     unique_lock(ting::shared_lock<mutex_type>&&, try_to_lock_t); | ||||
|     template <class _Clock, class _Duration> | ||||
|         unique_lock(ting::shared_lock<mutex_type>&&, | ||||
|                     const chrono::time_point<_Clock, _Duration>&); | ||||
|     template <class _Rep, class _Period> | ||||
|         unique_lock(ting::shared_lock<mutex_type>&&, | ||||
|                     const chrono::duration<_Rep, _Period>&); | ||||
|  | ||||
|     explicit unique_lock(ting::upgrade_lock<mutex_type>&&); | ||||
|     unique_lock(ting::upgrade_lock<mutex_type>&&, try_to_lock_t); | ||||
|     template <class _Clock, class _Duration> | ||||
|         unique_lock(ting::upgrade_lock<mutex_type>&&, | ||||
|                     const chrono::time_point<_Clock, _Duration>&); | ||||
|     template <class _Rep, class _Period> | ||||
|         unique_lock(ting::upgrade_lock<mutex_type>&&, | ||||
|                     const chrono::duration<_Rep, _Period>&); | ||||
|  | ||||
| #endif  // _LIBCPP_SHARED_LOCK | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
|     void lock(); | ||||
| @@ -165,13 +188,13 @@ public: | ||||
|     void unlock(); | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void swap(unique_lock& __u) _NOEXCEPT | ||||
|     void swap(unique_lock& __u) | ||||
|     { | ||||
|         _VSTD::swap(__m_, __u.__m_); | ||||
|         _VSTD::swap(__owns_, __u.__owns_); | ||||
|         _STD::swap(__m_, __u.__m_); | ||||
|         _STD::swap(__owns_, __u.__owns_); | ||||
|     } | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     mutex_type* release() _NOEXCEPT | ||||
|     mutex_type* release() | ||||
|     { | ||||
|         mutex_type* __m = __m_; | ||||
|         __m_ = nullptr; | ||||
| @@ -180,12 +203,12 @@ public: | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     bool owns_lock() const _NOEXCEPT {return __owns_;} | ||||
|     bool owns_lock() const {return __owns_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     _LIBCPP_EXPLICIT | ||||
|         operator bool () const _NOEXCEPT {return __owns_;} | ||||
| //    explicit | ||||
|         operator bool () const {return __owns_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     mutex_type* mutex() const _NOEXCEPT {return __m_;} | ||||
|     mutex_type* mutex() const {return __m_;} | ||||
| }; | ||||
|  | ||||
| template <class _Mutex> | ||||
| @@ -251,33 +274,28 @@ unique_lock<_Mutex>::unlock() | ||||
| template <class _Mutex> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| swap(unique_lock<_Mutex>& __x, unique_lock<_Mutex>& __y) _NOEXCEPT | ||||
|     {__x.swap(__y);} | ||||
| swap(unique_lock<_Mutex>& __x, unique_lock<_Mutex>& __y) {__x.swap(__y);} | ||||
|  | ||||
| struct _LIBCPP_TYPE_VIS cv_status | ||||
| struct _LIBCPP_VISIBLE cv_status | ||||
| { | ||||
|     enum __lx { | ||||
|     enum _ { | ||||
|         no_timeout, | ||||
|         timeout | ||||
|     }; | ||||
|  | ||||
|     __lx __v_; | ||||
|     _ __v_; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY cv_status(__lx __v) : __v_(__v) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY cv_status(_ __v) : __v_(__v) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY operator int() const {return __v_;} | ||||
|  | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS condition_variable | ||||
| class _LIBCPP_VISIBLE condition_variable | ||||
| { | ||||
|     pthread_cond_t __cv_; | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
| #ifndef _LIBCPP_HAS_NO_CONSTEXPR | ||||
|     constexpr condition_variable() : __cv_(PTHREAD_COND_INITIALIZER) {} | ||||
| #else | ||||
|     condition_variable() {__cv_ = (pthread_cond_t)PTHREAD_COND_INITIALIZER;} | ||||
| #endif | ||||
|     ~condition_variable(); | ||||
|  | ||||
| private: | ||||
| @@ -285,13 +303,18 @@ private: | ||||
|     condition_variable& operator=(const condition_variable&); // = delete; | ||||
|  | ||||
| public: | ||||
|     void notify_one() _NOEXCEPT; | ||||
|     void notify_all() _NOEXCEPT; | ||||
|     void notify_one(); | ||||
|     void notify_all(); | ||||
|  | ||||
|     void wait(unique_lock<mutex>& __lk); | ||||
|     template <class _Predicate> | ||||
|         void wait(unique_lock<mutex>& __lk, _Predicate __pred); | ||||
|  | ||||
|     template <class _Duration> | ||||
|         cv_status | ||||
|         wait_until(unique_lock<mutex>& __lk, | ||||
|                    const chrono::time_point<chrono::system_clock, _Duration>& __t); | ||||
|  | ||||
|     template <class _Clock, class _Duration> | ||||
|         cv_status | ||||
|         wait_until(unique_lock<mutex>& __lk, | ||||
| @@ -346,13 +369,28 @@ condition_variable::wait(unique_lock<mutex>& __lk, _Predicate __pred) | ||||
|         wait(__lk); | ||||
| } | ||||
|  | ||||
| template <class _Duration> | ||||
| cv_status | ||||
| condition_variable::wait_until(unique_lock<mutex>& __lk, | ||||
|                  const chrono::time_point<chrono::system_clock, _Duration>& __t) | ||||
| { | ||||
|     using namespace chrono; | ||||
|     typedef time_point<system_clock, nanoseconds> __nano_sys_tmpt; | ||||
|     __do_timed_wait(__lk, | ||||
|                   __nano_sys_tmpt(__ceil<nanoseconds>(__t.time_since_epoch()))); | ||||
|     return system_clock::now() < __t ? cv_status::no_timeout : | ||||
|                                        cv_status::timeout; | ||||
| } | ||||
|  | ||||
| template <class _Clock, class _Duration> | ||||
| cv_status | ||||
| condition_variable::wait_until(unique_lock<mutex>& __lk, | ||||
|                                const chrono::time_point<_Clock, _Duration>& __t) | ||||
| { | ||||
|     using namespace chrono; | ||||
|     wait_for(__lk, __t - _Clock::now()); | ||||
|     system_clock::time_point     __s_now = system_clock::now(); | ||||
|     typename _Clock::time_point  __c_now = _Clock::now(); | ||||
|     __do_timed_wait(__lk, __s_now + __ceil<nanoseconds>(__t - __c_now)); | ||||
|     return _Clock::now() < __t ? cv_status::no_timeout : cv_status::timeout; | ||||
| } | ||||
|  | ||||
| @@ -376,17 +414,9 @@ condition_variable::wait_for(unique_lock<mutex>& __lk, | ||||
|                              const chrono::duration<_Rep, _Period>& __d) | ||||
| { | ||||
|     using namespace chrono; | ||||
|     if (__d <= __d.zero()) | ||||
|         return cv_status::timeout; | ||||
|     typedef time_point<system_clock, duration<long double, nano> > __sys_tpf; | ||||
|     typedef time_point<system_clock, nanoseconds> __sys_tpi; | ||||
|     __sys_tpf _Max = __sys_tpi::max(); | ||||
|     system_clock::time_point __s_now = system_clock::now(); | ||||
|     steady_clock::time_point __c_now = steady_clock::now(); | ||||
|     if (_Max - __d > __s_now) | ||||
|         __do_timed_wait(__lk, __s_now + __ceil<nanoseconds>(__d)); | ||||
|     else | ||||
|         __do_timed_wait(__lk, __sys_tpi::max()); | ||||
|     __do_timed_wait(__lk, __s_now + __ceil<nanoseconds>(__d)); | ||||
|     return steady_clock::now() - __c_now < __d ? cv_status::no_timeout : | ||||
|                                                  cv_status::timeout; | ||||
| } | ||||
| @@ -399,7 +429,7 @@ condition_variable::wait_for(unique_lock<mutex>& __lk, | ||||
|                              _Predicate __pred) | ||||
| { | ||||
|     return wait_until(__lk, chrono::steady_clock::now() + __d, | ||||
|                       _VSTD::move(__pred)); | ||||
|                       _STD::move(__pred)); | ||||
| } | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|   | ||||
| @@ -6,11 +6,7 @@ | ||||
| #include <type_traits> | ||||
| #include <algorithm> | ||||
|  | ||||
| #include <__undef_min_max> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| @@ -51,36 +47,29 @@ public: | ||||
|     typedef typename add_lvalue_reference<allocator_type>::type __alloc_ref; | ||||
|     typedef typename add_lvalue_reference<allocator_type>::type __alloc_const_ref; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY __alloc_rr&           __alloc() _NOEXCEPT         {return __end_cap_.second();} | ||||
|     _LIBCPP_INLINE_VISIBILITY const __alloc_rr&     __alloc() const _NOEXCEPT   {return __end_cap_.second();} | ||||
|     _LIBCPP_INLINE_VISIBILITY pointer&              __end_cap() _NOEXCEPT       {return __end_cap_.first();} | ||||
|     _LIBCPP_INLINE_VISIBILITY const pointer&        __end_cap() const _NOEXCEPT {return __end_cap_.first();} | ||||
|     _LIBCPP_INLINE_VISIBILITY __alloc_rr&           __alloc()         {return __end_cap_.second();} | ||||
|     _LIBCPP_INLINE_VISIBILITY const __alloc_rr&     __alloc() const   {return __end_cap_.second();} | ||||
|     _LIBCPP_INLINE_VISIBILITY pointer&              __end_cap()       {return __end_cap_.first();} | ||||
|     _LIBCPP_INLINE_VISIBILITY const pointer&        __end_cap() const {return __end_cap_.first();} | ||||
|  | ||||
|     __split_buffer() | ||||
|         _NOEXCEPT_(is_nothrow_default_constructible<allocator_type>::value); | ||||
|     __split_buffer(); | ||||
|     explicit __split_buffer(__alloc_rr& __a); | ||||
|     explicit __split_buffer(const __alloc_rr& __a); | ||||
|     __split_buffer(size_type __cap, size_type __start, __alloc_rr& __a); | ||||
|     ~__split_buffer(); | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     __split_buffer(__split_buffer&& __c) | ||||
|         _NOEXCEPT_(is_nothrow_move_constructible<allocator_type>::value); | ||||
|     __split_buffer(__split_buffer&& __c); | ||||
|     __split_buffer(__split_buffer&& __c, const __alloc_rr& __a); | ||||
|     __split_buffer& operator=(__split_buffer&& __c) | ||||
|         _NOEXCEPT_((__alloc_traits::propagate_on_container_move_assignment::value && | ||||
|                 is_nothrow_move_assignable<allocator_type>::value) || | ||||
|                !__alloc_traits::propagate_on_container_move_assignment::value); | ||||
|     __split_buffer& operator=(__split_buffer&& __c); | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY       iterator begin() _NOEXCEPT       {return __begin_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator begin() const _NOEXCEPT {return __begin_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY       iterator end() _NOEXCEPT         {return __end_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator end() const _NOEXCEPT   {return __end_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY       iterator begin()       {return __begin_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator begin() const {return __begin_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY       iterator end()         {return __end_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator end() const   {return __end_;} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void clear() _NOEXCEPT | ||||
|         {__destruct_at_end(__begin_);} | ||||
|     _LIBCPP_INLINE_VISIBILITY void clear() {__destruct_at_end(__begin_);} | ||||
|     _LIBCPP_INLINE_VISIBILITY size_type size() const {return static_cast<size_type>(__end_ - __begin_);} | ||||
|     _LIBCPP_INLINE_VISIBILITY bool empty()     const {return __end_ == __begin_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY size_type capacity() const {return static_cast<size_type>(__end_cap() - __first_);} | ||||
| @@ -93,9 +82,9 @@ public: | ||||
|     _LIBCPP_INLINE_VISIBILITY const_reference back() const  {return *(__end_ - 1);} | ||||
|  | ||||
|     void reserve(size_type __n); | ||||
|     void shrink_to_fit() _NOEXCEPT; | ||||
|     void shrink_to_fit(); | ||||
|     void push_front(const_reference __x); | ||||
|     _LIBCPP_INLINE_VISIBILITY void push_back(const_reference __x); | ||||
|     void push_back(const_reference __x); | ||||
| #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) | ||||
|     void push_front(value_type&& __x); | ||||
|     void push_back(value_type&& __x); | ||||
| @@ -131,49 +120,40 @@ public: | ||||
|         void __destruct_at_begin(pointer __new_begin, false_type); | ||||
|         void __destruct_at_begin(pointer __new_begin, true_type); | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void __destruct_at_end(pointer __new_last) _NOEXCEPT | ||||
|         {__destruct_at_end(__new_last, false_type());} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|         void __destruct_at_end(pointer __new_last, false_type) _NOEXCEPT; | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|         void __destruct_at_end(pointer __new_last, true_type) _NOEXCEPT; | ||||
|     _LIBCPP_INLINE_VISIBILITY void __destruct_at_end(pointer __new_last) | ||||
|         {__destruct_at_end(__new_last, is_trivially_destructible<value_type>());} | ||||
|         void __destruct_at_end(pointer __new_last, false_type); | ||||
|         void __destruct_at_end(pointer __new_last, true_type); | ||||
|  | ||||
|     void swap(__split_buffer& __x) | ||||
|         _NOEXCEPT_(!__alloc_traits::propagate_on_container_swap::value|| | ||||
|                    __is_nothrow_swappable<__alloc_rr>::value); | ||||
|     void swap(__split_buffer& __x); | ||||
|  | ||||
|     bool __invariants() const; | ||||
|  | ||||
| private: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void __move_assign_alloc(__split_buffer& __c, true_type) | ||||
|         _NOEXCEPT_(is_nothrow_move_assignable<allocator_type>::value) | ||||
|     void __move_assign_alloc(const __split_buffer& __c, true_type) | ||||
|         { | ||||
|             __alloc() = _VSTD::move(__c.__alloc()); | ||||
|             __alloc() = _STD::move(__c.__alloc()); | ||||
|         } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void __move_assign_alloc(__split_buffer&, false_type) _NOEXCEPT | ||||
|     void __move_assign_alloc(const __split_buffer& __c, false_type) | ||||
|         {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     static void __swap_alloc(__alloc_rr& __x, __alloc_rr& __y) | ||||
|         _NOEXCEPT_(!__alloc_traits::propagate_on_container_swap::value|| | ||||
|                    __is_nothrow_swappable<__alloc_rr>::value) | ||||
|         {__swap_alloc(__x, __y, integral_constant<bool, | ||||
|                       __alloc_traits::propagate_on_container_swap::value>());} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     static void __swap_alloc(__alloc_rr& __x, __alloc_rr& __y, true_type) | ||||
|         _NOEXCEPT_(__is_nothrow_swappable<__alloc_rr>::value) | ||||
|         { | ||||
|             using _VSTD::swap; | ||||
|             using _STD::swap; | ||||
|             swap(__x, __y); | ||||
|         } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     static void __swap_alloc(__alloc_rr&, __alloc_rr&, false_type) _NOEXCEPT | ||||
|     static void __swap_alloc(__alloc_rr& __x, __alloc_rr& __y, false_type) | ||||
|         {} | ||||
| }; | ||||
|  | ||||
| @@ -214,7 +194,7 @@ __split_buffer<_Tp, _Allocator>::__construct_at_end(size_type __n) | ||||
|     __alloc_rr& __a = this->__alloc(); | ||||
|     do | ||||
|     { | ||||
|         __alloc_traits::construct(__a, _VSTD::__to_raw_pointer(this->__end_)); | ||||
|         __alloc_traits::construct(__a, _STD::__to_raw_pointer(this->__end_), value_type()); | ||||
|         ++this->__end_; | ||||
|         --__n; | ||||
|     } while (__n > 0); | ||||
| @@ -233,7 +213,7 @@ __split_buffer<_Tp, _Allocator>::__construct_at_end(size_type __n, const_referen | ||||
|     __alloc_rr& __a = this->__alloc(); | ||||
|     do | ||||
|     { | ||||
|         __alloc_traits::construct(__a, _VSTD::__to_raw_pointer(this->__end_), __x); | ||||
|         __alloc_traits::construct(__a, _STD::__to_raw_pointer(this->__end_), __x); | ||||
|         ++this->__end_; | ||||
|         --__n; | ||||
|     } while (__n > 0); | ||||
| @@ -255,14 +235,14 @@ __split_buffer<_Tp, _Allocator>::__construct_at_end(_InputIter __first, _InputIt | ||||
|         if (__end_ == __end_cap()) | ||||
|         { | ||||
|             size_type __old_cap = __end_cap() - __first_; | ||||
|             size_type __new_cap = _VSTD::max<size_type>(2 * __old_cap, 8); | ||||
|             size_type __new_cap = _STD::max<size_type>(2 * __old_cap, 8); | ||||
|             __split_buffer __buf(__new_cap, 0, __a); | ||||
|             for (pointer __p = __begin_; __p != __end_; ++__p, ++__buf.__end_) | ||||
|                 __alloc_traits::construct(__buf.__alloc(), | ||||
|                         _VSTD::__to_raw_pointer(__buf.__end_), _VSTD::move(*__p)); | ||||
|                         _STD::__to_raw_pointer(__buf.__end_), _STD::move(*__p)); | ||||
|             swap(__buf); | ||||
|         } | ||||
|         __alloc_traits::construct(__a, _VSTD::__to_raw_pointer(this->__end_), *__first); | ||||
|         __alloc_traits::construct(__a, _STD::__to_raw_pointer(this->__end_), *__first); | ||||
|         ++this->__end_; | ||||
|     } | ||||
| } | ||||
| @@ -279,22 +259,22 @@ __split_buffer<_Tp, _Allocator>::__construct_at_end(_ForwardIterator __first, _F | ||||
|     __alloc_rr& __a = this->__alloc(); | ||||
|     for (; __first != __last; ++__first) | ||||
|     { | ||||
|         __alloc_traits::construct(__a, _VSTD::__to_raw_pointer(this->__end_), *__first); | ||||
|         __alloc_traits::construct(__a, _STD::__to_raw_pointer(this->__end_), *__first); | ||||
|         ++this->__end_; | ||||
|     } | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Allocator> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| void | ||||
| __split_buffer<_Tp, _Allocator>::__destruct_at_begin(pointer __new_begin, false_type) | ||||
| { | ||||
|     while (__begin_ != __new_begin) | ||||
|         __alloc_traits::destroy(__alloc(), __to_raw_pointer(__begin_++)); | ||||
|     while (__begin_ < __new_begin) | ||||
|         __alloc_traits::destroy(__alloc(), __begin_++); | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Allocator> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| void | ||||
| __split_buffer<_Tp, _Allocator>::__destruct_at_begin(pointer __new_begin, true_type) | ||||
| { | ||||
| @@ -302,25 +282,25 @@ __split_buffer<_Tp, _Allocator>::__destruct_at_begin(pointer __new_begin, true_t | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Allocator> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| void | ||||
| __split_buffer<_Tp, _Allocator>::__destruct_at_end(pointer __new_last, false_type) _NOEXCEPT | ||||
| __split_buffer<_Tp, _Allocator>::__destruct_at_end(pointer __new_last, false_type) | ||||
| { | ||||
|     while (__new_last != __end_) | ||||
|         __alloc_traits::destroy(__alloc(), __to_raw_pointer(--__end_)); | ||||
|     while (__new_last < __end_) | ||||
|         __alloc_traits::destroy(__alloc(), --__end_); | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Allocator> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| void | ||||
| __split_buffer<_Tp, _Allocator>::__destruct_at_end(pointer __new_last, true_type) _NOEXCEPT | ||||
| __split_buffer<_Tp, _Allocator>::__destruct_at_end(pointer __new_last, true_type) | ||||
| { | ||||
|     __end_ = __new_last; | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Allocator> | ||||
| __split_buffer<_Tp, _Allocator>::__split_buffer(size_type __cap, size_type __start, __alloc_rr& __a) | ||||
|     : __end_cap_(nullptr, __a) | ||||
|     : __end_cap_(0, __a) | ||||
| { | ||||
|     __first_ = __cap != 0 ? __alloc_traits::allocate(__alloc(), __cap) : nullptr; | ||||
|     __begin_ = __end_ = __first_ + __start; | ||||
| @@ -328,24 +308,23 @@ __split_buffer<_Tp, _Allocator>::__split_buffer(size_type __cap, size_type __sta | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Allocator> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| __split_buffer<_Tp, _Allocator>::__split_buffer() | ||||
|     _NOEXCEPT_(is_nothrow_default_constructible<allocator_type>::value) | ||||
|     : __first_(nullptr), __begin_(nullptr), __end_(nullptr), __end_cap_(nullptr) | ||||
|     : __first_(0), __begin_(0), __end_(0), __end_cap_(0) | ||||
| { | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Allocator> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| __split_buffer<_Tp, _Allocator>::__split_buffer(__alloc_rr& __a) | ||||
|     : __first_(nullptr), __begin_(nullptr), __end_(nullptr), __end_cap_(nullptr, __a) | ||||
|     : __first_(0), __begin_(0), __end_(0), __end_cap_(0, __a) | ||||
| { | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Allocator> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| __split_buffer<_Tp, _Allocator>::__split_buffer(const __alloc_rr& __a) | ||||
|     : __first_(nullptr), __begin_(nullptr), __end_(nullptr), __end_cap_(nullptr, __a) | ||||
|     : __first_(0), __begin_(0), __end_(0), __end_cap_(0, __a) | ||||
| { | ||||
| } | ||||
|  | ||||
| @@ -361,11 +340,10 @@ __split_buffer<_Tp, _Allocator>::~__split_buffer() | ||||
|  | ||||
| template <class _Tp, class _Allocator> | ||||
| __split_buffer<_Tp, _Allocator>::__split_buffer(__split_buffer&& __c) | ||||
|     _NOEXCEPT_(is_nothrow_move_constructible<allocator_type>::value) | ||||
|     : __first_(_VSTD::move(__c.__first_)), | ||||
|       __begin_(_VSTD::move(__c.__begin_)), | ||||
|       __end_(_VSTD::move(__c.__end_)), | ||||
|       __end_cap_(_VSTD::move(__c.__end_cap_)) | ||||
|     : __first_(_STD::move(__c.__first_)), | ||||
|       __begin_(_STD::move(__c.__begin_)), | ||||
|       __end_(_STD::move(__c.__end_)), | ||||
|       __end_cap_(_STD::move(__c.__end_cap_)) | ||||
| { | ||||
|     __c.__first_ = nullptr; | ||||
|     __c.__begin_ = nullptr; | ||||
| @@ -394,17 +372,14 @@ __split_buffer<_Tp, _Allocator>::__split_buffer(__split_buffer&& __c, const __al | ||||
|         __first_ = __alloc_traits::allocate(__alloc(), __cap); | ||||
|         __begin_ = __end_ = __first_; | ||||
|         __end_cap() = __first_ + __cap; | ||||
|         typedef move_iterator<iterator> _Ip; | ||||
|         __construct_at_end(_Ip(__c.begin()), _Ip(__c.end())); | ||||
|         typedef move_iterator<iterator> _I; | ||||
|         __construct_at_end(_I(__c.begin()), _I(__c.end())); | ||||
|     } | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Allocator> | ||||
| __split_buffer<_Tp, _Allocator>& | ||||
| __split_buffer<_Tp, _Allocator>::operator=(__split_buffer&& __c) | ||||
|     _NOEXCEPT_((__alloc_traits::propagate_on_container_move_assignment::value && | ||||
|                 is_nothrow_move_assignable<allocator_type>::value) || | ||||
|                !__alloc_traits::propagate_on_container_move_assignment::value) | ||||
| { | ||||
|     clear(); | ||||
|     shrink_to_fit(); | ||||
| @@ -424,13 +399,11 @@ __split_buffer<_Tp, _Allocator>::operator=(__split_buffer&& __c) | ||||
| template <class _Tp, class _Allocator> | ||||
| void | ||||
| __split_buffer<_Tp, _Allocator>::swap(__split_buffer& __x) | ||||
|         _NOEXCEPT_(!__alloc_traits::propagate_on_container_swap::value|| | ||||
|                    __is_nothrow_swappable<__alloc_rr>::value) | ||||
| { | ||||
|     _VSTD::swap(__first_, __x.__first_); | ||||
|     _VSTD::swap(__begin_, __x.__begin_); | ||||
|     _VSTD::swap(__end_, __x.__end_); | ||||
|     _VSTD::swap(__end_cap(), __x.__end_cap()); | ||||
|     _STD::swap(__first_, __x.__first_); | ||||
|     _STD::swap(__begin_, __x.__begin_); | ||||
|     _STD::swap(__end_, __x.__end_); | ||||
|     _STD::swap(__end_cap(), __x.__end_cap()); | ||||
|     __swap_alloc(__alloc(), __x.__alloc()); | ||||
| } | ||||
|  | ||||
| @@ -443,16 +416,16 @@ __split_buffer<_Tp, _Allocator>::reserve(size_type __n) | ||||
|         __split_buffer<value_type, __alloc_rr&> __t(__n, 0, __alloc()); | ||||
|         __t.__construct_at_end(move_iterator<pointer>(__begin_), | ||||
|                                move_iterator<pointer>(__end_)); | ||||
|         _VSTD::swap(__first_, __t.__first_); | ||||
|         _VSTD::swap(__begin_, __t.__begin_); | ||||
|         _VSTD::swap(__end_, __t.__end_); | ||||
|         _VSTD::swap(__end_cap(), __t.__end_cap()); | ||||
|         _STD::swap(__first_, __t.__first_); | ||||
|         _STD::swap(__begin_, __t.__begin_); | ||||
|         _STD::swap(__end_, __t.__end_); | ||||
|         _STD::swap(__end_cap(), __t.__end_cap()); | ||||
|     } | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Allocator> | ||||
| void | ||||
| __split_buffer<_Tp, _Allocator>::shrink_to_fit() _NOEXCEPT | ||||
| __split_buffer<_Tp, _Allocator>::shrink_to_fit() | ||||
| { | ||||
|     if (capacity() > size()) | ||||
|     { | ||||
| @@ -464,10 +437,10 @@ __split_buffer<_Tp, _Allocator>::shrink_to_fit() _NOEXCEPT | ||||
|             __t.__construct_at_end(move_iterator<pointer>(__begin_), | ||||
|                                    move_iterator<pointer>(__end_)); | ||||
|             __t.__end_ = __t.__begin_ + (__end_ - __begin_); | ||||
|             _VSTD::swap(__first_, __t.__first_); | ||||
|             _VSTD::swap(__begin_, __t.__begin_); | ||||
|             _VSTD::swap(__end_, __t.__end_); | ||||
|             _VSTD::swap(__end_cap(), __t.__end_cap()); | ||||
|             _STD::swap(__first_, __t.__first_); | ||||
|             _STD::swap(__begin_, __t.__begin_); | ||||
|             _STD::swap(__end_, __t.__end_); | ||||
|             _STD::swap(__end_cap(), __t.__end_cap()); | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|         } | ||||
|         catch (...) | ||||
| @@ -487,22 +460,22 @@ __split_buffer<_Tp, _Allocator>::push_front(const_reference __x) | ||||
|         { | ||||
|             difference_type __d = __end_cap() - __end_; | ||||
|             __d = (__d + 1) / 2; | ||||
|             __begin_ = _VSTD::move_backward(__begin_, __end_, __end_ + __d); | ||||
|             __begin_ = _STD::move_backward(__begin_, __end_, __end_ + __d); | ||||
|             __end_ += __d; | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             size_type __c = max<size_type>(2 * static_cast<size_t>(__end_cap() - __first_), 1); | ||||
|             size_type __c = max<size_type>(2 * (__end_cap() - __first_), 1); | ||||
|             __split_buffer<value_type, __alloc_rr&> __t(__c, (__c + 3) / 4, __alloc()); | ||||
|             __t.__construct_at_end(move_iterator<pointer>(__begin_), | ||||
|                                    move_iterator<pointer>(__end_)); | ||||
|             _VSTD::swap(__first_, __t.__first_); | ||||
|             _VSTD::swap(__begin_, __t.__begin_); | ||||
|             _VSTD::swap(__end_, __t.__end_); | ||||
|             _VSTD::swap(__end_cap(), __t.__end_cap()); | ||||
|             _STD::swap(__first_, __t.__first_); | ||||
|             _STD::swap(__begin_, __t.__begin_); | ||||
|             _STD::swap(__end_, __t.__end_); | ||||
|             _STD::swap(__end_cap(), __t.__end_cap()); | ||||
|         } | ||||
|     } | ||||
|     __alloc_traits::construct(__alloc(), _VSTD::__to_raw_pointer(__begin_-1), __x); | ||||
|     __alloc_traits::construct(__alloc(), _STD::__to_raw_pointer(__begin_-1), __x); | ||||
|     --__begin_; | ||||
| } | ||||
|  | ||||
| @@ -518,30 +491,30 @@ __split_buffer<_Tp, _Allocator>::push_front(value_type&& __x) | ||||
|         { | ||||
|             difference_type __d = __end_cap() - __end_; | ||||
|             __d = (__d + 1) / 2; | ||||
|             __begin_ = _VSTD::move_backward(__begin_, __end_, __end_ + __d); | ||||
|             __begin_ = _STD::move_backward(__begin_, __end_, __end_ + __d); | ||||
|             __end_ += __d; | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             size_type __c = max<size_type>(2 * static_cast<size_t>(__end_cap() - __first_), 1); | ||||
|             size_type __c = max<size_type>(2 * (__end_cap() - __first_), 1); | ||||
|             __split_buffer<value_type, __alloc_rr&> __t(__c, (__c + 3) / 4, __alloc()); | ||||
|             __t.__construct_at_end(move_iterator<pointer>(__begin_), | ||||
|                                    move_iterator<pointer>(__end_)); | ||||
|             _VSTD::swap(__first_, __t.__first_); | ||||
|             _VSTD::swap(__begin_, __t.__begin_); | ||||
|             _VSTD::swap(__end_, __t.__end_); | ||||
|             _VSTD::swap(__end_cap(), __t.__end_cap()); | ||||
|             _STD::swap(__first_, __t.__first_); | ||||
|             _STD::swap(__begin_, __t.__begin_); | ||||
|             _STD::swap(__end_, __t.__end_); | ||||
|             _STD::swap(__end_cap(), __t.__end_cap()); | ||||
|         } | ||||
|     } | ||||
|     __alloc_traits::construct(__alloc(), _VSTD::__to_raw_pointer(__begin_-1), | ||||
|             _VSTD::move(__x)); | ||||
|     __alloc_traits::construct(__alloc(), _STD::__to_raw_pointer(__begin_-1), | ||||
|             _STD::move(__x)); | ||||
|     --__begin_; | ||||
| } | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
| template <class _Tp, class _Allocator> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| void | ||||
| __split_buffer<_Tp, _Allocator>::push_back(const_reference __x) | ||||
| { | ||||
| @@ -551,22 +524,22 @@ __split_buffer<_Tp, _Allocator>::push_back(const_reference __x) | ||||
|         { | ||||
|             difference_type __d = __begin_ - __first_; | ||||
|             __d = (__d + 1) / 2; | ||||
|             __end_ = _VSTD::move(__begin_, __end_, __begin_ - __d); | ||||
|             __end_ = _STD::move(__begin_, __end_, __begin_ - __d); | ||||
|             __begin_ -= __d; | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             size_type __c = max<size_type>(2 * static_cast<size_t>(__end_cap() - __first_), 1); | ||||
|             size_type __c = max<size_type>(2 * (__end_cap() - __first_), 1); | ||||
|             __split_buffer<value_type, __alloc_rr&> __t(__c, __c / 4, __alloc()); | ||||
|             __t.__construct_at_end(move_iterator<pointer>(__begin_), | ||||
|                                    move_iterator<pointer>(__end_)); | ||||
|             _VSTD::swap(__first_, __t.__first_); | ||||
|             _VSTD::swap(__begin_, __t.__begin_); | ||||
|             _VSTD::swap(__end_, __t.__end_); | ||||
|             _VSTD::swap(__end_cap(), __t.__end_cap()); | ||||
|             _STD::swap(__first_, __t.__first_); | ||||
|             _STD::swap(__begin_, __t.__begin_); | ||||
|             _STD::swap(__end_, __t.__end_); | ||||
|             _STD::swap(__end_cap(), __t.__end_cap()); | ||||
|         } | ||||
|     } | ||||
|     __alloc_traits::construct(__alloc(), _VSTD::__to_raw_pointer(__end_), __x); | ||||
|     __alloc_traits::construct(__alloc(), _STD::__to_raw_pointer(__end_), __x); | ||||
|     ++__end_; | ||||
| } | ||||
|  | ||||
| @@ -582,23 +555,23 @@ __split_buffer<_Tp, _Allocator>::push_back(value_type&& __x) | ||||
|         { | ||||
|             difference_type __d = __begin_ - __first_; | ||||
|             __d = (__d + 1) / 2; | ||||
|             __end_ = _VSTD::move(__begin_, __end_, __begin_ - __d); | ||||
|             __end_ = _STD::move(__begin_, __end_, __begin_ - __d); | ||||
|             __begin_ -= __d; | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             size_type __c = max<size_type>(2 * static_cast<size_t>(__end_cap() - __first_), 1); | ||||
|             size_type __c = max<size_type>(2 * (__end_cap() - __first_), 1); | ||||
|             __split_buffer<value_type, __alloc_rr&> __t(__c, __c / 4, __alloc()); | ||||
|             __t.__construct_at_end(move_iterator<pointer>(__begin_), | ||||
|                                    move_iterator<pointer>(__end_)); | ||||
|             _VSTD::swap(__first_, __t.__first_); | ||||
|             _VSTD::swap(__begin_, __t.__begin_); | ||||
|             _VSTD::swap(__end_, __t.__end_); | ||||
|             _VSTD::swap(__end_cap(), __t.__end_cap()); | ||||
|             _STD::swap(__first_, __t.__first_); | ||||
|             _STD::swap(__begin_, __t.__begin_); | ||||
|             _STD::swap(__end_, __t.__end_); | ||||
|             _STD::swap(__end_cap(), __t.__end_cap()); | ||||
|         } | ||||
|     } | ||||
|     __alloc_traits::construct(__alloc(), _VSTD::__to_raw_pointer(__end_), | ||||
|             _VSTD::move(__x)); | ||||
|     __alloc_traits::construct(__alloc(), _STD::__to_raw_pointer(__end_), | ||||
|             _STD::move(__x)); | ||||
|     ++__end_; | ||||
| } | ||||
|  | ||||
| @@ -615,23 +588,23 @@ __split_buffer<_Tp, _Allocator>::emplace_back(_Args&&... __args) | ||||
|         { | ||||
|             difference_type __d = __begin_ - __first_; | ||||
|             __d = (__d + 1) / 2; | ||||
|             __end_ = _VSTD::move(__begin_, __end_, __begin_ - __d); | ||||
|             __end_ = _STD::move(__begin_, __end_, __begin_ - __d); | ||||
|             __begin_ -= __d; | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             size_type __c = max<size_type>(2 * static_cast<size_t>(__end_cap() - __first_), 1); | ||||
|             size_type __c = max<size_type>(2 * (__end_cap() - __first_), 1); | ||||
|             __split_buffer<value_type, __alloc_rr&> __t(__c, __c / 4, __alloc()); | ||||
|             __t.__construct_at_end(move_iterator<pointer>(__begin_), | ||||
|                                    move_iterator<pointer>(__end_)); | ||||
|             _VSTD::swap(__first_, __t.__first_); | ||||
|             _VSTD::swap(__begin_, __t.__begin_); | ||||
|             _VSTD::swap(__end_, __t.__end_); | ||||
|             _VSTD::swap(__end_cap(), __t.__end_cap()); | ||||
|             _STD::swap(__first_, __t.__first_); | ||||
|             _STD::swap(__begin_, __t.__begin_); | ||||
|             _STD::swap(__end_, __t.__end_); | ||||
|             _STD::swap(__end_cap(), __t.__end_cap()); | ||||
|         } | ||||
|     } | ||||
|     __alloc_traits::construct(__alloc(), _VSTD::__to_raw_pointer(__end_), | ||||
|                               _VSTD::forward<_Args>(__args)...); | ||||
|     __alloc_traits::construct(__alloc(), _STD::__to_raw_pointer(__end_), | ||||
|                               _STD::forward<_Args>(__args)...); | ||||
|     ++__end_; | ||||
| } | ||||
|  | ||||
| @@ -639,16 +612,6 @@ __split_buffer<_Tp, _Allocator>::emplace_back(_Args&&... __args) | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
| template <class _Tp, class _Allocator> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| swap(__split_buffer<_Tp, _Allocator>& __x, __split_buffer<_Tp, _Allocator>& __y) | ||||
|         _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||
| { | ||||
|     __x.swap(__y); | ||||
| } | ||||
|  | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
| #endif  // _LIBCPP_SPLIT_BUFFER | ||||
|   | ||||
| @@ -15,26 +15,24 @@ | ||||
| #include <type_traits> | ||||
| #include <new> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template <class _Tp, size_t _Np> class _LIBCPP_HIDDEN __sso_allocator; | ||||
| template <class _Tp, size_t _N> class _LIBCPP_HIDDEN __sso_allocator; | ||||
|  | ||||
| template <size_t _Np> | ||||
| class _LIBCPP_HIDDEN __sso_allocator<void, _Np> | ||||
| template <size_t _N> | ||||
| class _LIBCPP_HIDDEN __sso_allocator<void, _N> | ||||
| { | ||||
| public: | ||||
|     typedef const void*       const_pointer; | ||||
|     typedef void              value_type; | ||||
| }; | ||||
|  | ||||
| template <class _Tp, size_t _Np> | ||||
| template <class _Tp, size_t _N> | ||||
| class _LIBCPP_HIDDEN __sso_allocator | ||||
| { | ||||
|     typename aligned_storage<sizeof(_Tp) * _Np>::type buf_; | ||||
|     typename aligned_storage<sizeof(_Tp) * _N>::type buf_; | ||||
|     bool __allocated_; | ||||
| public: | ||||
|     typedef size_t            size_type; | ||||
| @@ -43,14 +41,14 @@ public: | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY __sso_allocator() throw() : __allocated_(false) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY __sso_allocator(const __sso_allocator&) throw() : __allocated_(false) {} | ||||
|     template <class _Up> _LIBCPP_INLINE_VISIBILITY __sso_allocator(const __sso_allocator<_Up, _Np>&) throw() | ||||
|     template <class _Up> _LIBCPP_INLINE_VISIBILITY __sso_allocator(const __sso_allocator<_Up, _N>&) throw() | ||||
|          : __allocated_(false) {} | ||||
| private: | ||||
|     __sso_allocator& operator=(const __sso_allocator&); | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY pointer allocate(size_type __n, typename __sso_allocator<void, _Np>::const_pointer = 0) | ||||
|     _LIBCPP_INLINE_VISIBILITY pointer allocate(size_type __n, typename __sso_allocator<void, _N>::const_pointer = 0) | ||||
|     { | ||||
|         if (!__allocated_ && __n <= _Np) | ||||
|         if (!__allocated_ && __n <= _N) | ||||
|         { | ||||
|             __allocated_ = true; | ||||
|             return (pointer)&buf_; | ||||
|   | ||||
| @@ -17,15 +17,11 @@ | ||||
| #include <__locale> | ||||
| #include <cstdio> | ||||
|  | ||||
| #include <__undef_min_max> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| static const int __limit = 8; | ||||
| static const unsigned __limit = 8; | ||||
|  | ||||
| // __stdinbuf | ||||
|  | ||||
| @@ -41,7 +37,7 @@ public: | ||||
|     typedef typename traits_type::off_type   off_type; | ||||
|     typedef typename traits_type::state_type state_type; | ||||
|  | ||||
|     __stdinbuf(FILE* __fp, state_type* __st); | ||||
|     explicit __stdinbuf(FILE* __fp); | ||||
|  | ||||
| protected: | ||||
|     virtual int_type underflow(); | ||||
| @@ -53,10 +49,8 @@ private: | ||||
|  | ||||
|     FILE* __file_; | ||||
|     const codecvt<char_type, char, state_type>* __cv_; | ||||
|     state_type* __st_; | ||||
|     state_type __st_; | ||||
|     int __encoding_; | ||||
|     int_type __last_consumed_; | ||||
|     bool __last_consumed_is_next_; | ||||
|     bool __always_noconv_; | ||||
|  | ||||
|     __stdinbuf(const __stdinbuf&); | ||||
| @@ -66,11 +60,9 @@ private: | ||||
| }; | ||||
|  | ||||
| template <class _CharT> | ||||
| __stdinbuf<_CharT>::__stdinbuf(FILE* __fp, state_type* __st) | ||||
| __stdinbuf<_CharT>::__stdinbuf(FILE* __fp) | ||||
|     : __file_(__fp), | ||||
|       __st_(__st), | ||||
|       __last_consumed_(traits_type::eof()), | ||||
|       __last_consumed_is_next_(false) | ||||
|       __st_() | ||||
| { | ||||
|     imbue(this->getloc()); | ||||
| } | ||||
| @@ -104,21 +96,11 @@ template <class _CharT> | ||||
| typename __stdinbuf<_CharT>::int_type | ||||
| __stdinbuf<_CharT>::__getchar(bool __consume) | ||||
| { | ||||
|     if (__last_consumed_is_next_) | ||||
|     { | ||||
|         int_type __result = __last_consumed_; | ||||
|         if (__consume) | ||||
|         { | ||||
|             __last_consumed_ = traits_type::eof(); | ||||
|             __last_consumed_is_next_ = false; | ||||
|         } | ||||
|         return __result; | ||||
|     } | ||||
|     char __extbuf[__limit]; | ||||
|     int __nread = _VSTD::max(1, __encoding_); | ||||
|     int __nread = _STD::max(1, __encoding_); | ||||
|     for (int __i = 0; __i < __nread; ++__i) | ||||
|     { | ||||
|         int __c = getc(__file_); | ||||
|         char __c = getc(__file_); | ||||
|         if (__c == EOF) | ||||
|             return traits_type::eof(); | ||||
|         __extbuf[__i] = static_cast<char>(__c); | ||||
| @@ -133,19 +115,19 @@ __stdinbuf<_CharT>::__getchar(bool __consume) | ||||
|         codecvt_base::result __r; | ||||
|         do | ||||
|         { | ||||
|             state_type __sv_st = *__st_; | ||||
|             __r = __cv_->in(*__st_, __extbuf, __extbuf + __nread, __enxt, | ||||
|             state_type __sv_st = __st_; | ||||
|             __r = __cv_->in(__st_, __extbuf, __extbuf + __nread, __enxt, | ||||
|                                    &__1buf, &__1buf + 1, __inxt); | ||||
|             switch (__r) | ||||
|             { | ||||
|             case _VSTD::codecvt_base::ok: | ||||
|             case _STD::codecvt_base::ok: | ||||
|                 break; | ||||
|             case codecvt_base::partial: | ||||
|                 *__st_ = __sv_st; | ||||
|                 __st_ = __sv_st; | ||||
|                 if (__nread == sizeof(__extbuf)) | ||||
|                     return traits_type::eof(); | ||||
|                 { | ||||
|                     int __c = getc(__file_); | ||||
|                     char __c = getc(__file_); | ||||
|                     if (__c == EOF) | ||||
|                         return traits_type::eof(); | ||||
|                     __extbuf[__nread] = static_cast<char>(__c); | ||||
| @@ -154,22 +136,20 @@ __stdinbuf<_CharT>::__getchar(bool __consume) | ||||
|                 break; | ||||
|             case codecvt_base::error: | ||||
|                 return traits_type::eof(); | ||||
|             case _VSTD::codecvt_base::noconv: | ||||
|             case _STD::codecvt_base::noconv: | ||||
|                 __1buf = static_cast<char_type>(__extbuf[0]); | ||||
|                 break; | ||||
|             } | ||||
|         } while (__r == _VSTD::codecvt_base::partial); | ||||
|         } while (__r == _STD::codecvt_base::partial); | ||||
|     } | ||||
|     if (!__consume) | ||||
|     { | ||||
|         for (int __i = __nread; __i > 0;) | ||||
|         { | ||||
|             if (ungetc(traits_type::to_int_type(__extbuf[--__i]), __file_) == EOF) | ||||
|             if (ungetc(__extbuf[--__i], __file_) == EOF) | ||||
|                 return traits_type::eof(); | ||||
|         } | ||||
|     } | ||||
|     else | ||||
|         __last_consumed_ = traits_type::to_int_type(__1buf); | ||||
|     return traits_type::to_int_type(__1buf); | ||||
| } | ||||
|  | ||||
| @@ -178,41 +158,28 @@ typename __stdinbuf<_CharT>::int_type | ||||
| __stdinbuf<_CharT>::pbackfail(int_type __c) | ||||
| { | ||||
|     if (traits_type::eq_int_type(__c, traits_type::eof())) | ||||
|     { | ||||
|         if (!__last_consumed_is_next_) | ||||
|         { | ||||
|             __c = __last_consumed_; | ||||
|             __last_consumed_is_next_ = !traits_type::eq_int_type(__last_consumed_, | ||||
|                                                                  traits_type::eof()); | ||||
|         } | ||||
|         return __c; | ||||
|     } | ||||
|     if (__last_consumed_is_next_) | ||||
|     char __extbuf[__limit]; | ||||
|     char* __enxt; | ||||
|     const char_type __ci = traits_type::to_char_type(__c); | ||||
|     const char_type* __inxt; | ||||
|     switch (__cv_->out(__st_, &__ci, &__ci + 1, __inxt, | ||||
|                               __extbuf, __extbuf + sizeof(__extbuf), __enxt)) | ||||
|     { | ||||
|         char __extbuf[__limit]; | ||||
|         char* __enxt; | ||||
|         const char_type __ci = traits_type::to_char_type(__last_consumed_); | ||||
|         const char_type* __inxt; | ||||
|         switch (__cv_->out(*__st_, &__ci, &__ci + 1, __inxt, | ||||
|                                   __extbuf, __extbuf + sizeof(__extbuf), __enxt)) | ||||
|         { | ||||
|         case _VSTD::codecvt_base::ok: | ||||
|             break; | ||||
|         case _VSTD::codecvt_base::noconv: | ||||
|             __extbuf[0] = static_cast<char>(__last_consumed_); | ||||
|             __enxt = __extbuf + 1; | ||||
|             break; | ||||
|         case codecvt_base::partial: | ||||
|         case codecvt_base::error: | ||||
|             return traits_type::eof(); | ||||
|         } | ||||
|         while (__enxt > __extbuf) | ||||
|             if (ungetc(*--__enxt, __file_) == EOF) | ||||
|                 return traits_type::eof(); | ||||
|     case _STD::codecvt_base::ok: | ||||
|         break; | ||||
|     case _STD::codecvt_base::noconv: | ||||
|         __extbuf[0] = static_cast<char>(__c); | ||||
|         __enxt = __extbuf + 1; | ||||
|         break; | ||||
|     case codecvt_base::partial: | ||||
|     case codecvt_base::error: | ||||
|         return traits_type::eof(); | ||||
|     } | ||||
|     __last_consumed_ = __c; | ||||
|     __last_consumed_is_next_ = true; | ||||
|     return __c; | ||||
|     while (__enxt > __extbuf) | ||||
|         if (ungetc(*--__enxt, __file_) == EOF) | ||||
|             return traits_type::eof(); | ||||
|  return traits_type::not_eof(__c); | ||||
| } | ||||
|  | ||||
| // __stdoutbuf | ||||
| @@ -229,18 +196,17 @@ public: | ||||
|     typedef typename traits_type::off_type   off_type; | ||||
|     typedef typename traits_type::state_type state_type; | ||||
|  | ||||
|     __stdoutbuf(FILE* __fp, state_type* __st); | ||||
|     explicit __stdoutbuf(FILE* __fp); | ||||
|  | ||||
| protected: | ||||
|     virtual int_type overflow (int_type __c = traits_type::eof()); | ||||
|     virtual streamsize xsputn(const char_type* __s, streamsize __n); | ||||
|     virtual int sync(); | ||||
|     virtual void imbue(const locale& __loc); | ||||
|  | ||||
| private: | ||||
|     FILE* __file_; | ||||
|     const codecvt<char_type, char, state_type>* __cv_; | ||||
|     state_type* __st_; | ||||
|     state_type __st_; | ||||
|     bool __always_noconv_; | ||||
|  | ||||
|     __stdoutbuf(const __stdoutbuf&); | ||||
| @@ -248,10 +214,10 @@ private: | ||||
| }; | ||||
|  | ||||
| template <class _CharT> | ||||
| __stdoutbuf<_CharT>::__stdoutbuf(FILE* __fp, state_type* __st) | ||||
| __stdoutbuf<_CharT>::__stdoutbuf(FILE* __fp) | ||||
|     : __file_(__fp), | ||||
|       __cv_(&use_facet<codecvt<char_type, char, state_type> >(this->getloc())), | ||||
|       __st_(__st), | ||||
|       __st_(), | ||||
|       __always_noconv_(__cv_->always_noconv()) | ||||
| { | ||||
| } | ||||
| @@ -264,31 +230,30 @@ __stdoutbuf<_CharT>::overflow(int_type __c) | ||||
|     char_type __1buf; | ||||
|     if (!traits_type::eq_int_type(__c, traits_type::eof())) | ||||
|     { | ||||
|         __1buf = traits_type::to_char_type(__c); | ||||
|         this->setp(&__1buf, &__1buf+1); | ||||
|         *this->pptr() = traits_type::to_char_type(__c); | ||||
|         this->pbump(1); | ||||
|         if (__always_noconv_) | ||||
|         { | ||||
|             if (fwrite(&__1buf, sizeof(char_type), 1, __file_) != 1) | ||||
|             if (fwrite(this->pbase(), sizeof(char_type), 1, __file_) != 1) | ||||
|                 return traits_type::eof(); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             char* __extbe = __extbuf; | ||||
|             codecvt_base::result __r; | ||||
|             char_type* pbase = &__1buf; | ||||
|             char_type* pptr = pbase + 1; | ||||
|             char_type* epptr = pptr; | ||||
|             do | ||||
|             { | ||||
|                 const char_type* __e; | ||||
|                 __r = __cv_->out(*__st_, pbase, pptr, __e, | ||||
|                 __r = __cv_->out(__st_, this->pbase(), this->pptr(), __e, | ||||
|                                         __extbuf, | ||||
|                                         __extbuf + sizeof(__extbuf), | ||||
|                                         __extbe); | ||||
|                 if (__e == pbase) | ||||
|                 if (__e == this->pbase()) | ||||
|                     return traits_type::eof(); | ||||
|                 if (__r == codecvt_base::noconv) | ||||
|                 { | ||||
|                     if (fwrite(pbase, 1, 1, __file_) != 1) | ||||
|                     if (fwrite(this->pbase(), 1, 1, __file_) != 1) | ||||
|                         return traits_type::eof(); | ||||
|                 } | ||||
|                 else if (__r == codecvt_base::ok || __r == codecvt_base::partial) | ||||
| @@ -298,30 +263,19 @@ __stdoutbuf<_CharT>::overflow(int_type __c) | ||||
|                         return traits_type::eof(); | ||||
|                     if (__r == codecvt_base::partial) | ||||
|                     { | ||||
|                         pbase = (char_type*)__e; | ||||
|                         this->setp((char_type*)__e, this->pptr()); | ||||
|                         this->pbump(this->epptr() - this->pbase()); | ||||
|                     } | ||||
|                 } | ||||
|                 else | ||||
|                     return traits_type::eof(); | ||||
|             } while (__r == codecvt_base::partial); | ||||
|         } | ||||
|         this->setp(0, 0); | ||||
|     } | ||||
|     return traits_type::not_eof(__c); | ||||
| } | ||||
|  | ||||
| template <class _CharT> | ||||
| streamsize | ||||
| __stdoutbuf<_CharT>::xsputn(const char_type* __s, streamsize __n) | ||||
| { | ||||
|     if (__always_noconv_) | ||||
|         return fwrite(__s, sizeof(char_type), __n, __file_); | ||||
|     streamsize __i = 0; | ||||
|     for (; __i < __n; ++__i, ++__s) | ||||
|         if (overflow(traits_type::to_int_type(*__s)) == traits_type::eof()) | ||||
|             break; | ||||
|     return __i; | ||||
| } | ||||
|  | ||||
| template <class _CharT> | ||||
| int | ||||
| __stdoutbuf<_CharT>::sync() | ||||
| @@ -331,7 +285,7 @@ __stdoutbuf<_CharT>::sync() | ||||
|     do | ||||
|     { | ||||
|         char* __extbe; | ||||
|         __r = __cv_->unshift(*__st_, __extbuf, | ||||
|         __r = __cv_->unshift(__st_, __extbuf, | ||||
|                                     __extbuf + sizeof(__extbuf), | ||||
|                                     __extbe); | ||||
|         size_t __nmemb = static_cast<size_t>(__extbe - __extbuf); | ||||
|   | ||||
							
								
								
									
										455
									
								
								include/__tree
									
									
									
									
									
								
							
							
						
						
									
										455
									
								
								include/__tree
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -15,9 +15,7 @@ | ||||
| #include <cstddef> | ||||
| #include <type_traits> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| #ifdef _LIBCPP_HAS_NO_VARIADICS | ||||
|  | ||||
| @@ -27,46 +25,46 @@ | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template <class _Tp> class _LIBCPP_TYPE_VIS_ONLY tuple_size; | ||||
| template <class _Tp> class _LIBCPP_VISIBLE tuple_size; | ||||
|  | ||||
| template <class _Tp> | ||||
| class _LIBCPP_TYPE_VIS_ONLY tuple_size<const _Tp> | ||||
| class _LIBCPP_VISIBLE tuple_size<const _Tp> | ||||
|     : public tuple_size<_Tp> {}; | ||||
|  | ||||
| template <class _Tp> | ||||
| class _LIBCPP_TYPE_VIS_ONLY tuple_size<volatile _Tp> | ||||
| class _LIBCPP_VISIBLE tuple_size<volatile _Tp> | ||||
|     : public tuple_size<_Tp> {}; | ||||
|  | ||||
| template <class _Tp> | ||||
| class _LIBCPP_TYPE_VIS_ONLY tuple_size<const volatile _Tp> | ||||
| class _LIBCPP_VISIBLE tuple_size<const volatile _Tp> | ||||
|     : public tuple_size<_Tp> {}; | ||||
|  | ||||
| template <size_t _Ip, class _Tp> class _LIBCPP_TYPE_VIS_ONLY tuple_element; | ||||
| template <size_t _Ip, class _Tp> class _LIBCPP_VISIBLE tuple_element; | ||||
|  | ||||
| template <size_t _Ip, class _Tp> | ||||
| class _LIBCPP_TYPE_VIS_ONLY tuple_element<_Ip, const _Tp> | ||||
| class _LIBCPP_VISIBLE tuple_element<_Ip, const _Tp> | ||||
| { | ||||
| public: | ||||
|     typedef typename add_const<typename tuple_element<_Ip, _Tp>::type>::type type; | ||||
| }; | ||||
|  | ||||
| template <size_t _Ip, class _Tp> | ||||
| class _LIBCPP_TYPE_VIS_ONLY tuple_element<_Ip, volatile _Tp> | ||||
| class _LIBCPP_VISIBLE tuple_element<_Ip, volatile _Tp> | ||||
| { | ||||
| public: | ||||
|     typedef typename add_volatile<typename tuple_element<_Ip, _Tp>::type>::type type; | ||||
| }; | ||||
|  | ||||
| template <size_t _Ip, class _Tp> | ||||
| class _LIBCPP_TYPE_VIS_ONLY tuple_element<_Ip, const volatile _Tp> | ||||
| class _LIBCPP_VISIBLE tuple_element<_Ip, const volatile _Tp> | ||||
| { | ||||
| public: | ||||
|     typedef typename add_cv<typename tuple_element<_Ip, _Tp>::type>::type type; | ||||
| }; | ||||
|  | ||||
| template <class ..._Tp> class _LIBCPP_TYPE_VIS_ONLY tuple; | ||||
| template <class _T1, class _T2> struct _LIBCPP_TYPE_VIS_ONLY pair; | ||||
| template <class _Tp, size_t _Size> struct _LIBCPP_TYPE_VIS_ONLY array; | ||||
| template <class ..._Tp> class _LIBCPP_VISIBLE tuple; | ||||
| template <class _T1, class _T2> class _LIBCPP_VISIBLE pair; | ||||
| template <class _Tp, size_t _Size> struct _LIBCPP_VISIBLE array; | ||||
|  | ||||
| template <class _Tp> struct __tuple_like : false_type {}; | ||||
|  | ||||
| @@ -79,49 +77,40 @@ template <class _T1, class _T2> struct __tuple_like<pair<_T1, _T2> > : true_type | ||||
| template <class _Tp, size_t _Size> struct __tuple_like<array<_Tp, _Size> > : true_type {}; | ||||
|  | ||||
| template <size_t _Ip, class ..._Tp> | ||||
| _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| typename tuple_element<_Ip, tuple<_Tp...> >::type& | ||||
| get(tuple<_Tp...>&) _NOEXCEPT; | ||||
| get(tuple<_Tp...>&); | ||||
|  | ||||
| template <size_t _Ip, class ..._Tp> | ||||
| _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| const typename tuple_element<_Ip, tuple<_Tp...> >::type& | ||||
| get(const tuple<_Tp...>&) _NOEXCEPT; | ||||
| get(const tuple<_Tp...>&); | ||||
|  | ||||
| template <size_t _Ip, class ..._Tp> | ||||
| _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| typename tuple_element<_Ip, tuple<_Tp...> >::type&& | ||||
| get(tuple<_Tp...>&&) _NOEXCEPT; | ||||
| get(tuple<_Tp...>&&); | ||||
|  | ||||
| template <size_t _Ip, class _T1, class _T2> | ||||
| _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| typename tuple_element<_Ip, pair<_T1, _T2> >::type& | ||||
| get(pair<_T1, _T2>&) _NOEXCEPT; | ||||
| get(pair<_T1, _T2>&); | ||||
|  | ||||
| template <size_t _Ip, class _T1, class _T2> | ||||
| _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| const typename tuple_element<_Ip, pair<_T1, _T2> >::type& | ||||
| get(const pair<_T1, _T2>&) _NOEXCEPT; | ||||
| get(const pair<_T1, _T2>&); | ||||
|  | ||||
| template <size_t _Ip, class _T1, class _T2> | ||||
| _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| typename tuple_element<_Ip, pair<_T1, _T2> >::type&& | ||||
| get(pair<_T1, _T2>&&) _NOEXCEPT; | ||||
| get(pair<_T1, _T2>&&); | ||||
|  | ||||
| template <size_t _Ip, class _Tp, size_t _Size> | ||||
| _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| _Tp& | ||||
| get(array<_Tp, _Size>&) _NOEXCEPT; | ||||
| get(array<_Tp, _Size>&); | ||||
|  | ||||
| template <size_t _Ip, class _Tp, size_t _Size> | ||||
| _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| const _Tp& | ||||
| get(const array<_Tp, _Size>&) _NOEXCEPT; | ||||
| get(const array<_Tp, _Size>&); | ||||
|  | ||||
| template <size_t _Ip, class _Tp, size_t _Size> | ||||
| _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| _Tp&& | ||||
| get(array<_Tp, _Size>&&) _NOEXCEPT; | ||||
| get(array<_Tp, _Size>&&); | ||||
|  | ||||
| // __make_tuple_indices | ||||
|  | ||||
| @@ -154,7 +143,7 @@ struct __make_tuple_indices | ||||
| template <class ..._Tp> struct __tuple_types {}; | ||||
|  | ||||
| template <size_t _Ip> | ||||
| class _LIBCPP_TYPE_VIS_ONLY tuple_element<_Ip, __tuple_types<> > | ||||
| class _LIBCPP_VISIBLE tuple_element<_Ip, __tuple_types<> > | ||||
| { | ||||
| public: | ||||
|     static_assert(_Ip == 0, "tuple_element index out of range"); | ||||
| @@ -162,21 +151,21 @@ public: | ||||
| }; | ||||
|  | ||||
| template <class _Hp, class ..._Tp> | ||||
| class _LIBCPP_TYPE_VIS_ONLY tuple_element<0, __tuple_types<_Hp, _Tp...> > | ||||
| class _LIBCPP_VISIBLE tuple_element<0, __tuple_types<_Hp, _Tp...> > | ||||
| { | ||||
| public: | ||||
|     typedef _Hp type; | ||||
| }; | ||||
|  | ||||
| template <size_t _Ip, class _Hp, class ..._Tp> | ||||
| class _LIBCPP_TYPE_VIS_ONLY tuple_element<_Ip, __tuple_types<_Hp, _Tp...> > | ||||
| class _LIBCPP_VISIBLE tuple_element<_Ip, __tuple_types<_Hp, _Tp...> > | ||||
| { | ||||
| public: | ||||
|     typedef typename tuple_element<_Ip-1, __tuple_types<_Tp...> >::type type; | ||||
| }; | ||||
|  | ||||
| template <class ..._Tp> | ||||
| class _LIBCPP_TYPE_VIS_ONLY tuple_size<__tuple_types<_Tp...> > | ||||
| class _LIBCPP_VISIBLE tuple_size<__tuple_types<_Tp...> > | ||||
|     : public integral_constant<size_t, sizeof...(_Tp)> | ||||
| { | ||||
| }; | ||||
| @@ -225,7 +214,11 @@ struct __tuple_convertible_imp : public false_type {}; | ||||
| template <class _Tp0, class ..._Tp, class _Up0, class ..._Up> | ||||
| struct __tuple_convertible_imp<true, __tuple_types<_Tp0, _Tp...>, __tuple_types<_Up0, _Up...> > | ||||
|     : public integral_constant<bool, | ||||
| #if 1 // waiting on cwg 1170 | ||||
|                                is_convertible<_Tp0, _Up0>::value && | ||||
| #else | ||||
|                                is_constructible<_Up0, _Tp0>::value && | ||||
| #endif | ||||
|                                __tuple_convertible_imp<true, __tuple_types<_Tp...>, __tuple_types<_Up...> >::value> {}; | ||||
|  | ||||
| template <> | ||||
| @@ -244,33 +237,6 @@ struct __tuple_convertible<_Tp, _Up, true, true> | ||||
|              typename __make_tuple_types<_Tp>::type, typename __make_tuple_types<_Up>::type> | ||||
| {}; | ||||
|  | ||||
| // __tuple_constructible | ||||
|  | ||||
| template <bool, class _Tp, class _Up> | ||||
| struct __tuple_constructible_imp : public false_type {}; | ||||
|  | ||||
| template <class _Tp0, class ..._Tp, class _Up0, class ..._Up> | ||||
| struct __tuple_constructible_imp<true, __tuple_types<_Tp0, _Tp...>, __tuple_types<_Up0, _Up...> > | ||||
|     : public integral_constant<bool, | ||||
|                                is_constructible<_Up0, _Tp0>::value && | ||||
|                                __tuple_constructible_imp<true, __tuple_types<_Tp...>, __tuple_types<_Up...> >::value> {}; | ||||
|  | ||||
| template <> | ||||
| struct __tuple_constructible_imp<true, __tuple_types<>, __tuple_types<> > | ||||
|     : public true_type {}; | ||||
|  | ||||
| template <class _Tp, class _Up, bool = __tuple_like<typename remove_reference<_Tp>::type>::value, | ||||
|                                 bool = __tuple_like<_Up>::value> | ||||
| struct __tuple_constructible | ||||
|     : public false_type {}; | ||||
|  | ||||
| template <class _Tp, class _Up> | ||||
| struct __tuple_constructible<_Tp, _Up, true, true> | ||||
|     : public __tuple_constructible_imp<tuple_size<typename remove_reference<_Tp>::type>::value == | ||||
|                                      tuple_size<_Up>::value, | ||||
|              typename __make_tuple_types<_Tp>::type, typename __make_tuple_types<_Up>::type> | ||||
| {}; | ||||
|  | ||||
| // __tuple_assignable | ||||
|  | ||||
| template <bool, class _Tp, class _Up> | ||||
|   | ||||
| @@ -13,14 +13,12 @@ | ||||
|  | ||||
| #include <__config> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template <class _Tp> class _LIBCPP_TYPE_VIS_ONLY tuple_size; | ||||
| template <size_t _Ip, class _Tp> class _LIBCPP_TYPE_VIS_ONLY tuple_element; | ||||
| template <class _Tp> class _LIBCPP_VISIBLE tuple_size; | ||||
| template <size_t _Ip, class _Tp> class _LIBCPP_VISIBLE tuple_element; | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
| @@ -1,29 +0,0 @@ | ||||
| // -*- C++ -*- | ||||
| //===----------------------------------------------------------------------===// | ||||
| // | ||||
| //                     The LLVM Compiler Infrastructure | ||||
| // | ||||
| // This file is dual licensed under the MIT and the University of Illinois Open | ||||
| // Source Licenses. See LICENSE.TXT for details. | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| #ifdef min | ||||
| #if defined(_MSC_VER) && ! defined(__clang__) | ||||
| _LIBCPP_WARNING("macro min is incompatible with C++.  Try #define NOMINMAX " | ||||
|                 "before any Windows header. #undefing min") | ||||
| #else | ||||
| #warning: macro min is incompatible with C++.  #undefing min | ||||
| #endif | ||||
| #undef min | ||||
| #endif | ||||
|  | ||||
| #ifdef max | ||||
| #if defined(_MSC_VER) && ! defined(__clang__) | ||||
| _LIBCPP_WARNING("macro max is incompatible with C++.  Try #define NOMINMAX " | ||||
|                 "before any Windows header. #undefing max") | ||||
| #else | ||||
| #warning: macro max is incompatible with C++.  #undefing max | ||||
| #endif | ||||
| #undef max | ||||
| #endif | ||||
							
								
								
									
										1119
									
								
								include/algorithm
									
									
									
									
									
								
							
							
						
						
									
										1119
									
								
								include/algorithm
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										177
									
								
								include/array
									
									
									
									
									
								
							
							
						
						
									
										177
									
								
								include/array
									
									
									
									
									
								
							| @@ -34,42 +34,42 @@ struct array | ||||
|  | ||||
|     // No explicit construct/copy/destroy for aggregate type | ||||
|     void fill(const T& u); | ||||
|     void swap(array& a) noexcept(noexcept(swap(declval<T&>(), declval<T&>()))); | ||||
|     void swap(array& a); | ||||
|  | ||||
|     // iterators: | ||||
|     iterator begin() noexcept; | ||||
|     const_iterator begin() const noexcept; | ||||
|     iterator end() noexcept; | ||||
|     const_iterator end() const noexcept; | ||||
|     iterator begin(); | ||||
|     const_iterator begin() const; | ||||
|     iterator end(); | ||||
|     const_iterator end() const; | ||||
|  | ||||
|     reverse_iterator rbegin() noexcept; | ||||
|     const_reverse_iterator rbegin() const noexcept; | ||||
|     reverse_iterator rend() noexcept; | ||||
|     const_reverse_iterator rend() const noexcept; | ||||
|     reverse_iterator rbegin(); | ||||
|     const_reverse_iterator rbegin() const; | ||||
|     reverse_iterator rend(); | ||||
|     const_reverse_iterator rend() const; | ||||
|  | ||||
|     const_iterator cbegin() const noexcept; | ||||
|     const_iterator cend() const noexcept; | ||||
|     const_reverse_iterator crbegin() const noexcept; | ||||
|     const_reverse_iterator crend() const noexcept; | ||||
|     const_iterator cbegin() const; | ||||
|     const_iterator cend() const; | ||||
|     const_reverse_iterator crbegin() const; | ||||
|     const_reverse_iterator crend() const; | ||||
|  | ||||
|     // capacity: | ||||
|     constexpr size_type size() const noexcept; | ||||
|     constexpr size_type max_size() const noexcept; | ||||
|     constexpr bool empty() const noexcept; | ||||
|     constexpr size_type size() const; | ||||
|     constexpr size_type max_size() const; | ||||
|     bool empty() const; | ||||
|  | ||||
|     // element access: | ||||
|     reference operator[](size_type n); | ||||
|     const_reference operator[](size_type n) const; // constexpr in C++14 | ||||
|     const_reference at(size_type n) const; // constexpr in C++14 | ||||
|     const_reference operator[](size_type n) const; | ||||
|     const_reference at(size_type n) const; | ||||
|     reference at(size_type n); | ||||
|  | ||||
|     reference front(); | ||||
|     const_reference front() const; // constexpr in C++14 | ||||
|     const_reference front() const; | ||||
|     reference back(); | ||||
|     const_reference back() const; // constexpr in C++14 | ||||
|     const_reference back() const; | ||||
|  | ||||
|     T* data() noexcept; | ||||
|     const T* data() const noexcept; | ||||
|     T* data(); | ||||
|     const T* data() const; | ||||
| }; | ||||
|  | ||||
| template <class T, size_t N> | ||||
| @@ -86,15 +86,15 @@ template <class T, size_t N> | ||||
|   bool operator>=(const array<T,N>& x, const array<T,N>& y); | ||||
|  | ||||
| template <class T, size_t N > | ||||
|   void swap(array<T,N>& x, array<T,N>& y) noexcept(noexcept(x.swap(y))); | ||||
|   void swap(array<T,N>& x, array<T,N>& y); | ||||
|  | ||||
| template <class T> class tuple_size; | ||||
| template <int I, class T> class tuple_element; | ||||
| template <class T, size_t N> struct tuple_size<array<T, N>>; | ||||
| template <int I, class T, size_t N> struct tuple_element<I, array<T, N>>; | ||||
| template <int I, class T, size_t N> T& get(array<T, N>&) noexcept; // constexpr in C++14 | ||||
| template <int I, class T, size_t N> const T& get(const array<T, N>&) noexcept; // constexpr in C++14 | ||||
| template <int I, class T, size_t N> T&& get(array<T, N>&&) noexcept; // constexpr in C++14 | ||||
| template <int I, class T, size_t N> T& get(array<T, N>&); | ||||
| template <int I, class T, size_t N> const T& get(const array<T, N>&); | ||||
| template <int I, class T, size_t N> T&& get(array<T, N>&&); | ||||
|  | ||||
| }  // std | ||||
|  | ||||
| @@ -111,14 +111,12 @@ template <int I, class T, size_t N> T&& get(array<T, N>&&) noexcept; // constexp | ||||
|     #include <cassert> | ||||
| #endif | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template <class _Tp, size_t _Size> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY array | ||||
| struct _LIBCPP_VISIBLE array | ||||
| { | ||||
|     // types: | ||||
|     typedef array __self; | ||||
| @@ -138,62 +136,44 @@ struct _LIBCPP_TYPE_VIS_ONLY array | ||||
|  | ||||
|     // No explicit construct/copy/destroy for aggregate type | ||||
|     _LIBCPP_INLINE_VISIBILITY void fill(const value_type& __u) | ||||
|         {_VSTD::fill_n(__elems_, _Size, __u);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void swap(array& __a) _NOEXCEPT_(__is_nothrow_swappable<_Tp>::value) | ||||
|         {_VSTD::swap_ranges(__elems_, __elems_ + _Size, __a.__elems_);} | ||||
|         {_STD::fill_n(__elems_, _Size, __u);} | ||||
|     _LIBCPP_INLINE_VISIBILITY void swap(array& __a) | ||||
|         {_STD::swap_ranges(__elems_, __elems_ + _Size, __a.__elems_);} | ||||
|  | ||||
|     // iterators: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator begin() _NOEXCEPT {return iterator(__elems_);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator begin() const _NOEXCEPT {return const_iterator(__elems_);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator end() _NOEXCEPT {return iterator(__elems_ + _Size);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator end() const _NOEXCEPT {return const_iterator(__elems_ + _Size);} | ||||
|     _LIBCPP_INLINE_VISIBILITY iterator begin()             {return iterator(__elems_);} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator begin() const {return const_iterator(__elems_);} | ||||
|     _LIBCPP_INLINE_VISIBILITY iterator end()               {return iterator(__elems_ + _Size);} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator end() const   {return const_iterator(__elems_ + _Size);} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     reverse_iterator rbegin() _NOEXCEPT {return reverse_iterator(end());} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_reverse_iterator rbegin() const _NOEXCEPT {return const_reverse_iterator(end());} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     reverse_iterator rend() _NOEXCEPT {return reverse_iterator(begin());} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_reverse_iterator rend() const _NOEXCEPT {return const_reverse_iterator(begin());} | ||||
|     _LIBCPP_INLINE_VISIBILITY reverse_iterator rbegin()             {return reverse_iterator(end());} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_reverse_iterator rbegin() const {return const_reverse_iterator(end());} | ||||
|     _LIBCPP_INLINE_VISIBILITY reverse_iterator rend()               {return reverse_iterator(begin());} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_reverse_iterator rend() const   {return const_reverse_iterator(begin());} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator cbegin() const _NOEXCEPT {return begin();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator cend() const _NOEXCEPT {return end();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_reverse_iterator crbegin() const _NOEXCEPT {return rbegin();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_reverse_iterator crend() const _NOEXCEPT {return rend();} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator cbegin() const          {return begin();} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator cend() const            {return end();} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_reverse_iterator crbegin() const {return rbegin();} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_reverse_iterator crend() const   {return rend();} | ||||
|  | ||||
|     // capacity: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     _LIBCPP_CONSTEXPR size_type size() const _NOEXCEPT {return _Size;} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     _LIBCPP_CONSTEXPR size_type max_size() const _NOEXCEPT {return _Size;} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     _LIBCPP_CONSTEXPR bool empty() const _NOEXCEPT {return _Size == 0;} | ||||
|     _LIBCPP_INLINE_VISIBILITY /*constexpr*/ size_type size() const      {return _Size;} | ||||
|     _LIBCPP_INLINE_VISIBILITY /*constexpr*/ size_type max_size() const  {return _Size;} | ||||
|     _LIBCPP_INLINE_VISIBILITY bool empty() const                    {return _Size == 0;} | ||||
|  | ||||
|     // element access: | ||||
|     _LIBCPP_INLINE_VISIBILITY reference operator[](size_type __n)             {return __elems_[__n];} | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 const_reference operator[](size_type __n) const {return __elems_[__n];} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_reference operator[](size_type __n) const {return __elems_[__n];} | ||||
|     reference at(size_type __n); | ||||
|     _LIBCPP_CONSTEXPR_AFTER_CXX11 const_reference at(size_type __n) const; | ||||
|     const_reference at(size_type __n) const; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY reference front()             {return __elems_[0];} | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 const_reference front() const {return __elems_[0];} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_reference front() const {return __elems_[0];} | ||||
|     _LIBCPP_INLINE_VISIBILITY reference back()              {return __elems_[_Size > 0 ? _Size-1 : 0];} | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 const_reference back() const  {return __elems_[_Size > 0 ? _Size-1 : 0];} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_reference back() const  {return __elems_[_Size > 0 ? _Size-1 : 0];} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     value_type* data() _NOEXCEPT {return __elems_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const value_type* data() const _NOEXCEPT {return __elems_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY value_type* data()             {return __elems_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY const value_type* data() const {return __elems_;} | ||||
| }; | ||||
|  | ||||
| template <class _Tp, size_t _Size> | ||||
| @@ -210,7 +190,6 @@ array<_Tp, _Size>::at(size_type __n) | ||||
| } | ||||
|  | ||||
| template <class _Tp, size_t _Size> | ||||
| _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| typename array<_Tp, _Size>::const_reference | ||||
| array<_Tp, _Size>::at(size_type __n) const | ||||
| { | ||||
| @@ -224,15 +203,15 @@ array<_Tp, _Size>::at(size_type __n) const | ||||
| } | ||||
|  | ||||
| template <class _Tp, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| bool | ||||
| operator==(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | ||||
| { | ||||
|     return _VSTD::equal(__x.__elems_, __x.__elems_ + _Size, __y.__elems_); | ||||
|     return _STD::equal(__x.__elems_, __x.__elems_ + _Size, __y.__elems_); | ||||
| } | ||||
|  | ||||
| template <class _Tp, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| bool | ||||
| operator!=(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | ||||
| { | ||||
| @@ -240,15 +219,15 @@ operator!=(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | ||||
| } | ||||
|  | ||||
| template <class _Tp, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| bool | ||||
| operator<(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | ||||
| { | ||||
|     return _VSTD::lexicographical_compare(__x.__elems_, __x.__elems_ + _Size, __y.__elems_, __y.__elems_ + _Size); | ||||
|     return _STD::lexicographical_compare(__x.__elems_, __x.__elems_ + _Size, __y.__elems_, __y.__elems_ + _Size); | ||||
| } | ||||
|  | ||||
| template <class _Tp, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| bool | ||||
| operator>(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | ||||
| { | ||||
| @@ -256,7 +235,7 @@ operator>(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | ||||
| } | ||||
|  | ||||
| template <class _Tp, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| bool | ||||
| operator<=(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | ||||
| { | ||||
| @@ -264,7 +243,7 @@ operator<=(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | ||||
| } | ||||
|  | ||||
| template <class _Tp, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| bool | ||||
| operator>=(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | ||||
| { | ||||
| @@ -272,67 +251,59 @@ operator>=(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | ||||
| } | ||||
|  | ||||
| template <class _Tp, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| typename enable_if | ||||
| < | ||||
|     __is_swappable<_Tp>::value, | ||||
|     void | ||||
| >::type | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| void | ||||
| swap(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) | ||||
|                                   _NOEXCEPT_(__is_nothrow_swappable<_Tp>::value) | ||||
| { | ||||
|     __x.swap(__y); | ||||
| } | ||||
|  | ||||
| template <class _Tp, size_t _Size> | ||||
| class _LIBCPP_TYPE_VIS_ONLY tuple_size<array<_Tp, _Size> > | ||||
| class _LIBCPP_VISIBLE tuple_size<array<_Tp, _Size> > | ||||
|     : public integral_constant<size_t, _Size> {}; | ||||
|  | ||||
| template <class _Tp, size_t _Size> | ||||
| class _LIBCPP_TYPE_VIS_ONLY tuple_size<const array<_Tp, _Size> > | ||||
| class _LIBCPP_VISIBLE tuple_size<const array<_Tp, _Size> > | ||||
|     : public integral_constant<size_t, _Size> {}; | ||||
|  | ||||
| template <size_t _Ip, class _Tp, size_t _Size> | ||||
| class _LIBCPP_TYPE_VIS_ONLY tuple_element<_Ip, array<_Tp, _Size> > | ||||
| class _LIBCPP_VISIBLE tuple_element<_Ip, array<_Tp, _Size> > | ||||
| { | ||||
| public: | ||||
|     typedef _Tp type; | ||||
| }; | ||||
|  | ||||
| template <size_t _Ip, class _Tp, size_t _Size> | ||||
| class _LIBCPP_TYPE_VIS_ONLY tuple_element<_Ip, const array<_Tp, _Size> > | ||||
| class _LIBCPP_VISIBLE tuple_element<_Ip, const array<_Tp, _Size> > | ||||
| { | ||||
| public: | ||||
|     typedef const _Tp type; | ||||
| }; | ||||
|  | ||||
| template <size_t _Ip, class _Tp, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| _Tp& | ||||
| get(array<_Tp, _Size>& __a) _NOEXCEPT | ||||
| get(array<_Tp, _Size>& __a) | ||||
| { | ||||
|     static_assert(_Ip < _Size, "Index out of bounds in std::get<> (std::array)"); | ||||
|     return __a.__elems_[_Ip]; | ||||
|     return __a[_Ip]; | ||||
| } | ||||
|  | ||||
| template <size_t _Ip, class _Tp, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| const _Tp& | ||||
| get(const array<_Tp, _Size>& __a) _NOEXCEPT | ||||
| get(const array<_Tp, _Size>& __a) | ||||
| { | ||||
|     static_assert(_Ip < _Size, "Index out of bounds in std::get<> (const std::array)"); | ||||
|     return __a.__elems_[_Ip]; | ||||
|     return __a[_Ip]; | ||||
| } | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
| template <size_t _Ip, class _Tp, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| _LIBCPP_INLINE_VISIBILITY inline | ||||
| _Tp&& | ||||
| get(array<_Tp, _Size>&& __a) _NOEXCEPT | ||||
| get(array<_Tp, _Size>&& __a) | ||||
| { | ||||
|     static_assert(_Ip < _Size, "Index out of bounds in std::get<> (std::array &&)"); | ||||
|     return _VSTD::move(__a.__elems_[_Ip]); | ||||
|     return _STD::move(__a[_Ip]); | ||||
| } | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|   | ||||
							
								
								
									
										756
									
								
								include/atomic
									
									
									
									
									
								
							
							
						
						
									
										756
									
								
								include/atomic
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										394
									
								
								include/bitset
									
									
									
									
									
								
							
							
						
						
									
										394
									
								
								include/bitset
									
									
									
									
									
								
							| @@ -27,19 +27,19 @@ public: | ||||
|     class reference | ||||
|     { | ||||
|         friend class bitset; | ||||
|         reference() noexcept; | ||||
|         reference(); | ||||
|     public: | ||||
|         ~reference() noexcept; | ||||
|         reference& operator=(bool x) noexcept;           // for b[i] = x; | ||||
|         reference& operator=(const reference&) noexcept; // for b[i] = b[j]; | ||||
|         bool operator~() const noexcept;                 // flips the bit | ||||
|         operator bool() const noexcept;                  // for x = b[i]; | ||||
|         reference& flip() noexcept;                      // for b[i].flip(); | ||||
|         ~reference(); | ||||
|         reference& operator=(bool x);           // for b[i] = x; | ||||
|         reference& operator=(const reference&); // for b[i] = b[j]; | ||||
|         bool operator~() const;                 // flips the bit | ||||
|         operator bool() const;                  // for x = b[i]; | ||||
|         reference& flip();                      // for b[i].flip(); | ||||
|     }; | ||||
|  | ||||
|     // 23.3.5.1 constructors: | ||||
|     constexpr bitset() noexcept; | ||||
|     constexpr bitset(unsigned long long val) noexcept; | ||||
|     constexpr bitset(); | ||||
|     constexpr bitset(unsigned long long val); | ||||
|     template <class charT> | ||||
|         explicit bitset(const charT* str, | ||||
|                         typename basic_string<charT>::size_type n = basic_string<charT>::npos, | ||||
| @@ -52,17 +52,17 @@ public: | ||||
|                         charT zero = charT('0'), charT one = charT('1')); | ||||
|  | ||||
|     // 23.3.5.2 bitset operations: | ||||
|     bitset& operator&=(const bitset& rhs) noexcept; | ||||
|     bitset& operator|=(const bitset& rhs) noexcept; | ||||
|     bitset& operator^=(const bitset& rhs) noexcept; | ||||
|     bitset& operator<<=(size_t pos) noexcept; | ||||
|     bitset& operator>>=(size_t pos) noexcept; | ||||
|     bitset& set() noexcept; | ||||
|     bitset& operator&=(const bitset& rhs); | ||||
|     bitset& operator|=(const bitset& rhs); | ||||
|     bitset& operator^=(const bitset& rhs); | ||||
|     bitset& operator<<=(size_t pos); | ||||
|     bitset& operator>>=(size_t pos); | ||||
|     bitset& set(); | ||||
|     bitset& set(size_t pos, bool val = true); | ||||
|     bitset& reset() noexcept; | ||||
|     bitset& reset(); | ||||
|     bitset& reset(size_t pos); | ||||
|     bitset operator~() const noexcept; | ||||
|     bitset& flip() noexcept; | ||||
|     bitset operator~() const; | ||||
|     bitset& flip(); | ||||
|     bitset& flip(size_t pos); | ||||
|  | ||||
|     // element access: | ||||
| @@ -77,27 +77,27 @@ public: | ||||
|     template <class charT> | ||||
|         basic_string<charT, char_traits<charT>, allocator<charT> > to_string(charT zero = charT('0'), charT one = charT('1')) const; | ||||
|     basic_string<char, char_traits<char>, allocator<char> > to_string(char zero = '0', char one = '1') const; | ||||
|     size_t count() const noexcept; | ||||
|     constexpr size_t size() const noexcept; | ||||
|     bool operator==(const bitset& rhs) const noexcept; | ||||
|     bool operator!=(const bitset& rhs) const noexcept; | ||||
|     size_t count() const; | ||||
|     constexpr size_t size() const; | ||||
|     bool operator==(const bitset& rhs) const; | ||||
|     bool operator!=(const bitset& rhs) const; | ||||
|     bool test(size_t pos) const; | ||||
|     bool all() const noexcept; | ||||
|     bool any() const noexcept; | ||||
|     bool none() const noexcept; | ||||
|     bitset operator<<(size_t pos) const noexcept; | ||||
|     bitset operator>>(size_t pos) const noexcept; | ||||
|     bool all() const; | ||||
|     bool any() const; | ||||
|     bool none() const; | ||||
|     bitset operator<<(size_t pos) const; | ||||
|     bitset operator>>(size_t pos) const; | ||||
| }; | ||||
|  | ||||
| // 23.3.5.3 bitset operators: | ||||
| template <size_t N> | ||||
| bitset<N> operator&(const bitset<N>&, const bitset<N>&) noexcept; | ||||
| bitset<N> operator&(const bitset<N>&, const bitset<N>&); | ||||
|  | ||||
| template <size_t N> | ||||
| bitset<N> operator|(const bitset<N>&, const bitset<N>&) noexcept; | ||||
| bitset<N> operator|(const bitset<N>&, const bitset<N>&); | ||||
|  | ||||
| template <size_t N> | ||||
| bitset<N> operator^(const bitset<N>&, const bitset<N>&) noexcept; | ||||
| bitset<N> operator^(const bitset<N>&, const bitset<N>&); | ||||
|  | ||||
| template <class charT, class traits, size_t N> | ||||
| basic_istream<charT, traits>& | ||||
| @@ -113,9 +113,7 @@ template <size_t N> struct hash<std::bitset<N>>; | ||||
|  | ||||
| */ | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| #include <__config> | ||||
| #include <__bit_reference> | ||||
| @@ -129,28 +127,17 @@ template <size_t N> struct hash<std::bitset<N>>; | ||||
|     #include <cassert> | ||||
| #endif | ||||
|  | ||||
| #include <__undef_min_max> | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template <size_t _N_words, size_t _Size> | ||||
| class __bitset; | ||||
|  | ||||
| template <size_t _N_words, size_t _Size> | ||||
| struct __has_storage_type<__bitset<_N_words, _Size> > | ||||
| { | ||||
|     static const bool value = true; | ||||
| }; | ||||
|  | ||||
| template <size_t _N_words, size_t _Size> | ||||
| class __bitset | ||||
| { | ||||
| public: | ||||
|     typedef ptrdiff_t              difference_type; | ||||
|     typedef size_t                 size_type; | ||||
|     typedef size_type              __storage_type; | ||||
| protected: | ||||
|     typedef __bitset __self; | ||||
|     typedef size_type              __storage_type; | ||||
|     typedef       __storage_type*  __storage_pointer; | ||||
|     typedef const __storage_type*  __const_storage_pointer; | ||||
|     static const unsigned __bits_per_word = static_cast<unsigned>(sizeof(__storage_type) * CHAR_BIT); | ||||
| @@ -159,7 +146,7 @@ protected: | ||||
|     friend class __bit_const_reference<__bitset>; | ||||
|     friend class __bit_iterator<__bitset, false>; | ||||
|     friend class __bit_iterator<__bitset, true>; | ||||
|     friend struct __bit_array<__bitset>; | ||||
|     friend class __bit_array<__bitset>; | ||||
|  | ||||
|     __storage_type __first_[_N_words]; | ||||
|  | ||||
| @@ -168,36 +155,34 @@ protected: | ||||
|     typedef __bit_iterator<__bitset, false>            iterator; | ||||
|     typedef __bit_iterator<__bitset, true>             const_iterator; | ||||
|  | ||||
|     _LIBCPP_CONSTEXPR __bitset() _NOEXCEPT; | ||||
|     explicit _LIBCPP_CONSTEXPR __bitset(unsigned long long __v) _NOEXCEPT; | ||||
|     __bitset(); | ||||
|     explicit __bitset(unsigned long long __v); | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY reference __make_ref(size_t __pos) _NOEXCEPT | ||||
|     _LIBCPP_INLINE_VISIBILITY reference __make_ref(size_t __pos) | ||||
|         {return reference(__first_ + __pos / __bits_per_word, __storage_type(1) << __pos % __bits_per_word);} | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR const_reference __make_ref(size_t __pos) const _NOEXCEPT | ||||
|     _LIBCPP_INLINE_VISIBILITY const_reference __make_ref(size_t __pos) const | ||||
|         {return const_reference(__first_ + __pos / __bits_per_word, __storage_type(1) << __pos % __bits_per_word);} | ||||
|     _LIBCPP_INLINE_VISIBILITY iterator __make_iter(size_t __pos) _NOEXCEPT | ||||
|     _LIBCPP_INLINE_VISIBILITY iterator __make_iter(size_t __pos) | ||||
|         {return iterator(__first_ + __pos / __bits_per_word, __pos % __bits_per_word);} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator __make_iter(size_t __pos) const _NOEXCEPT | ||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator __make_iter(size_t __pos) const | ||||
|         {return const_iterator(__first_ + __pos / __bits_per_word, __pos % __bits_per_word);} | ||||
|  | ||||
|     void operator&=(const __bitset& __v) _NOEXCEPT; | ||||
|     void operator|=(const __bitset& __v) _NOEXCEPT; | ||||
|     void operator^=(const __bitset& __v) _NOEXCEPT; | ||||
|     void operator&=(const __bitset& __v); | ||||
|     void operator|=(const __bitset& __v); | ||||
|     void operator^=(const __bitset& __v); | ||||
|  | ||||
|     void flip() _NOEXCEPT; | ||||
|     void flip(); | ||||
|     _LIBCPP_INLINE_VISIBILITY unsigned long to_ulong() const | ||||
|         {return to_ulong(integral_constant<bool, _Size < sizeof(unsigned long) * CHAR_BIT>());} | ||||
|     _LIBCPP_INLINE_VISIBILITY unsigned long long to_ullong() const | ||||
|         {return to_ullong(integral_constant<bool, _Size < sizeof(unsigned long long) * CHAR_BIT>());} | ||||
|  | ||||
|     bool all() const _NOEXCEPT; | ||||
|     bool any() const _NOEXCEPT; | ||||
|     size_t __hash_code() const _NOEXCEPT; | ||||
|     bool all() const; | ||||
|     bool any() const; | ||||
|     size_t __hash_code() const; | ||||
| private: | ||||
| #ifdef _LIBCPP_HAS_NO_CONSTEXPR | ||||
|     void __init(unsigned long long __v, false_type) _NOEXCEPT; | ||||
|     void __init(unsigned long long __v, true_type) _NOEXCEPT; | ||||
| #endif  // _LIBCPP_HAS_NO_CONSTEXPR | ||||
|     void __init(unsigned long long __v, false_type); | ||||
|     void __init(unsigned long long __v, true_type); | ||||
|     unsigned long to_ulong(false_type) const; | ||||
|     unsigned long to_ulong(true_type) const; | ||||
|     unsigned long long to_ullong(false_type) const; | ||||
| @@ -208,65 +193,43 @@ private: | ||||
|  | ||||
| template <size_t _N_words, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| __bitset<_N_words, _Size>::__bitset() _NOEXCEPT | ||||
| #ifndef _LIBCPP_HAS_NO_CONSTEXPR | ||||
|     : __first_{0} | ||||
| #endif | ||||
| __bitset<_N_words, _Size>::__bitset() | ||||
| { | ||||
| #ifdef _LIBCPP_HAS_NO_CONSTEXPR | ||||
|     _VSTD::fill_n(__first_, _N_words, __storage_type(0)); | ||||
| #endif | ||||
|     _STD::fill_n(__first_, _N_words, __storage_type(0)); | ||||
| } | ||||
|  | ||||
| #ifdef _LIBCPP_HAS_NO_CONSTEXPR | ||||
|  | ||||
| template <size_t _N_words, size_t _Size> | ||||
| void | ||||
| __bitset<_N_words, _Size>::__init(unsigned long long __v, false_type) _NOEXCEPT | ||||
| __bitset<_N_words, _Size>::__init(unsigned long long __v, false_type) | ||||
| { | ||||
|     __storage_type __t[sizeof(unsigned long long) / sizeof(__storage_type)]; | ||||
|     for (size_t __i = 0; __i < sizeof(__t)/sizeof(__t[0]); ++__i, __v >>= __bits_per_word) | ||||
|         __t[__i] = static_cast<__storage_type>(__v); | ||||
|     _VSTD::copy(__t, __t + sizeof(__t)/sizeof(__t[0]), __first_); | ||||
|     _VSTD::fill(__first_ + sizeof(__t)/sizeof(__t[0]), __first_ + sizeof(__first_)/sizeof(__first_[0]), | ||||
|     _STD::copy(__t, __t + sizeof(__t)/sizeof(__t[0]), __first_); | ||||
|     _STD::fill(__first_ + sizeof(__t)/sizeof(__t[0]), __first_ + sizeof(__first_)/sizeof(__first_[0]), | ||||
|                __storage_type(0)); | ||||
| } | ||||
|  | ||||
| template <size_t _N_words, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| __bitset<_N_words, _Size>::__init(unsigned long long __v, true_type) _NOEXCEPT | ||||
| __bitset<_N_words, _Size>::__init(unsigned long long __v, true_type) | ||||
| { | ||||
|     __first_[0] = __v; | ||||
|     _VSTD::fill(__first_ + 1, __first_ + sizeof(__first_)/sizeof(__first_[0]), __storage_type(0)); | ||||
|     _STD::fill(__first_ + 1, __first_ + sizeof(__first_)/sizeof(__first_[0]), __storage_type(0)); | ||||
| } | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_CONSTEXPR | ||||
|  | ||||
| template <size_t _N_words, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| __bitset<_N_words, _Size>::__bitset(unsigned long long __v) _NOEXCEPT | ||||
| #ifndef _LIBCPP_HAS_NO_CONSTEXPR | ||||
| #if __SIZE_WIDTH__ == 64 | ||||
|     : __first_{__v} | ||||
| #elif __SIZE_WIDTH__ == 32 | ||||
|     : __first_{__v, __v >> __bits_per_word} | ||||
| #else | ||||
| #error This constructor has not been ported to this platform | ||||
| #endif | ||||
| #endif | ||||
| __bitset<_N_words, _Size>::__bitset(unsigned long long __v) | ||||
| { | ||||
| #ifdef _LIBCPP_HAS_NO_CONSTEXPR | ||||
|     __init(__v, integral_constant<bool, sizeof(unsigned long long) == sizeof(__storage_type)>()); | ||||
| #endif | ||||
| } | ||||
|  | ||||
| template <size_t _N_words, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| __bitset<_N_words, _Size>::operator&=(const __bitset& __v) _NOEXCEPT | ||||
| __bitset<_N_words, _Size>::operator&=(const __bitset& __v) | ||||
| { | ||||
|     for (size_type __i = 0; __i < _N_words; ++__i) | ||||
|         __first_[__i] &= __v.__first_[__i]; | ||||
| @@ -275,7 +238,7 @@ __bitset<_N_words, _Size>::operator&=(const __bitset& __v) _NOEXCEPT | ||||
| template <size_t _N_words, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| __bitset<_N_words, _Size>::operator|=(const __bitset& __v) _NOEXCEPT | ||||
| __bitset<_N_words, _Size>::operator|=(const __bitset& __v) | ||||
| { | ||||
|     for (size_type __i = 0; __i < _N_words; ++__i) | ||||
|         __first_[__i] |= __v.__first_[__i]; | ||||
| @@ -284,7 +247,7 @@ __bitset<_N_words, _Size>::operator|=(const __bitset& __v) _NOEXCEPT | ||||
| template <size_t _N_words, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| __bitset<_N_words, _Size>::operator^=(const __bitset& __v) _NOEXCEPT | ||||
| __bitset<_N_words, _Size>::operator^=(const __bitset& __v) | ||||
| { | ||||
|     for (size_type __i = 0; __i < _N_words; ++__i) | ||||
|         __first_[__i] ^= __v.__first_[__i]; | ||||
| @@ -292,7 +255,7 @@ __bitset<_N_words, _Size>::operator^=(const __bitset& __v) _NOEXCEPT | ||||
|  | ||||
| template <size_t _N_words, size_t _Size> | ||||
| void | ||||
| __bitset<_N_words, _Size>::flip() _NOEXCEPT | ||||
| __bitset<_N_words, _Size>::flip() | ||||
| { | ||||
|     // do middle whole words | ||||
|     size_type __n = _Size; | ||||
| @@ -314,7 +277,7 @@ unsigned long | ||||
| __bitset<_N_words, _Size>::to_ulong(false_type) const | ||||
| { | ||||
|     const_iterator __e = __make_iter(_Size); | ||||
|     const_iterator __i = _VSTD::find(__make_iter(sizeof(unsigned long) * CHAR_BIT), __e, true); | ||||
|     const_iterator __i = _STD::find(__make_iter(sizeof(unsigned long) * CHAR_BIT), __e, true); | ||||
|     if (__i != __e) | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|         throw overflow_error("bitset to_ulong overflow error"); | ||||
| @@ -337,7 +300,7 @@ unsigned long long | ||||
| __bitset<_N_words, _Size>::to_ullong(false_type) const | ||||
| { | ||||
|     const_iterator __e = __make_iter(_Size); | ||||
|     const_iterator __i = _VSTD::find(__make_iter(sizeof(unsigned long long) * CHAR_BIT), __e, true); | ||||
|     const_iterator __i = _STD::find(__make_iter(sizeof(unsigned long long) * CHAR_BIT), __e, true); | ||||
|     if (__i != __e) | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|         throw overflow_error("bitset to_ullong overflow error"); | ||||
| @@ -375,7 +338,7 @@ __bitset<_N_words, _Size>::to_ullong(true_type, true_type) const | ||||
|  | ||||
| template <size_t _N_words, size_t _Size> | ||||
| bool | ||||
| __bitset<_N_words, _Size>::all() const _NOEXCEPT | ||||
| __bitset<_N_words, _Size>::all() const | ||||
| { | ||||
|     // do middle whole words | ||||
|     size_type __n = _Size; | ||||
| @@ -395,7 +358,7 @@ __bitset<_N_words, _Size>::all() const _NOEXCEPT | ||||
|  | ||||
| template <size_t _N_words, size_t _Size> | ||||
| bool | ||||
| __bitset<_N_words, _Size>::any() const _NOEXCEPT | ||||
| __bitset<_N_words, _Size>::any() const | ||||
| { | ||||
|     // do middle whole words | ||||
|     size_type __n = _Size; | ||||
| @@ -416,7 +379,7 @@ __bitset<_N_words, _Size>::any() const _NOEXCEPT | ||||
| template <size_t _N_words, size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| size_t | ||||
| __bitset<_N_words, _Size>::__hash_code() const _NOEXCEPT | ||||
| __bitset<_N_words, _Size>::__hash_code() const | ||||
| { | ||||
|     size_t __h = 0; | ||||
|     for (size_type __i = 0; __i < _N_words; ++__i) | ||||
| @@ -430,9 +393,9 @@ class __bitset<1, _Size> | ||||
| public: | ||||
|     typedef ptrdiff_t              difference_type; | ||||
|     typedef size_t                 size_type; | ||||
|     typedef size_type              __storage_type; | ||||
| protected: | ||||
|     typedef __bitset __self; | ||||
|     typedef size_type              __storage_type; | ||||
|     typedef       __storage_type*  __storage_pointer; | ||||
|     typedef const __storage_type*  __const_storage_pointer; | ||||
|     static const unsigned __bits_per_word = static_cast<unsigned>(sizeof(__storage_type) * CHAR_BIT); | ||||
| @@ -441,7 +404,7 @@ protected: | ||||
|     friend class __bit_const_reference<__bitset>; | ||||
|     friend class __bit_iterator<__bitset, false>; | ||||
|     friend class __bit_iterator<__bitset, true>; | ||||
|     friend struct __bit_array<__bitset>; | ||||
|     friend class __bit_array<__bitset>; | ||||
|  | ||||
|     __storage_type __first_; | ||||
|  | ||||
| @@ -450,45 +413,43 @@ protected: | ||||
|     typedef __bit_iterator<__bitset, false>            iterator; | ||||
|     typedef __bit_iterator<__bitset, true>             const_iterator; | ||||
|  | ||||
|     _LIBCPP_CONSTEXPR __bitset() _NOEXCEPT; | ||||
|     explicit _LIBCPP_CONSTEXPR __bitset(unsigned long long __v) _NOEXCEPT; | ||||
|     __bitset(); | ||||
|     explicit __bitset(unsigned long long __v); | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY reference __make_ref(size_t __pos) _NOEXCEPT | ||||
|     _LIBCPP_INLINE_VISIBILITY reference __make_ref(size_t __pos) | ||||
|         {return reference(&__first_, __storage_type(1) << __pos);} | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR const_reference __make_ref(size_t __pos) const _NOEXCEPT | ||||
|     _LIBCPP_INLINE_VISIBILITY const_reference __make_ref(size_t __pos) const | ||||
|         {return const_reference(&__first_, __storage_type(1) << __pos);} | ||||
|     _LIBCPP_INLINE_VISIBILITY iterator __make_iter(size_t __pos) _NOEXCEPT | ||||
|     _LIBCPP_INLINE_VISIBILITY iterator __make_iter(size_t __pos) | ||||
|         {return iterator(&__first_ + __pos / __bits_per_word, __pos % __bits_per_word);} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator __make_iter(size_t __pos) const _NOEXCEPT | ||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator __make_iter(size_t __pos) const | ||||
|         {return const_iterator(&__first_ + __pos / __bits_per_word, __pos % __bits_per_word);} | ||||
|  | ||||
|     void operator&=(const __bitset& __v) _NOEXCEPT; | ||||
|     void operator|=(const __bitset& __v) _NOEXCEPT; | ||||
|     void operator^=(const __bitset& __v) _NOEXCEPT; | ||||
|     void operator&=(const __bitset& __v); | ||||
|     void operator|=(const __bitset& __v); | ||||
|     void operator^=(const __bitset& __v); | ||||
|  | ||||
|     void flip() _NOEXCEPT; | ||||
|     void flip(); | ||||
|  | ||||
|     unsigned long to_ulong() const; | ||||
|     unsigned long long to_ullong() const; | ||||
|  | ||||
|     bool all() const _NOEXCEPT; | ||||
|     bool any() const _NOEXCEPT; | ||||
|     bool all() const; | ||||
|     bool any() const; | ||||
|  | ||||
|     size_t __hash_code() const _NOEXCEPT; | ||||
|     size_t __hash_code() const; | ||||
| }; | ||||
|  | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| __bitset<1, _Size>::__bitset() _NOEXCEPT | ||||
| __bitset<1, _Size>::__bitset() | ||||
|     : __first_(0) | ||||
| { | ||||
| } | ||||
|  | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| __bitset<1, _Size>::__bitset(unsigned long long __v) _NOEXCEPT | ||||
| __bitset<1, _Size>::__bitset(unsigned long long __v) | ||||
|     : __first_(static_cast<__storage_type>(__v)) | ||||
| { | ||||
| } | ||||
| @@ -496,7 +457,7 @@ __bitset<1, _Size>::__bitset(unsigned long long __v) _NOEXCEPT | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| __bitset<1, _Size>::operator&=(const __bitset& __v) _NOEXCEPT | ||||
| __bitset<1, _Size>::operator&=(const __bitset& __v) | ||||
| { | ||||
|     __first_ &= __v.__first_; | ||||
| } | ||||
| @@ -504,7 +465,7 @@ __bitset<1, _Size>::operator&=(const __bitset& __v) _NOEXCEPT | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| __bitset<1, _Size>::operator|=(const __bitset& __v) _NOEXCEPT | ||||
| __bitset<1, _Size>::operator|=(const __bitset& __v) | ||||
| { | ||||
|     __first_ |= __v.__first_; | ||||
| } | ||||
| @@ -512,7 +473,7 @@ __bitset<1, _Size>::operator|=(const __bitset& __v) _NOEXCEPT | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| __bitset<1, _Size>::operator^=(const __bitset& __v) _NOEXCEPT | ||||
| __bitset<1, _Size>::operator^=(const __bitset& __v) | ||||
| { | ||||
|     __first_ ^= __v.__first_; | ||||
| } | ||||
| @@ -520,7 +481,7 @@ __bitset<1, _Size>::operator^=(const __bitset& __v) _NOEXCEPT | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| __bitset<1, _Size>::flip() _NOEXCEPT | ||||
| __bitset<1, _Size>::flip() | ||||
| { | ||||
|     __storage_type __m = ~__storage_type(0) >> (__bits_per_word - _Size); | ||||
|     __first_ = ~__first_; | ||||
| @@ -546,7 +507,7 @@ __bitset<1, _Size>::to_ullong() const | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| __bitset<1, _Size>::all() const _NOEXCEPT | ||||
| __bitset<1, _Size>::all() const | ||||
| { | ||||
|     __storage_type __m = ~__storage_type(0) >> (__bits_per_word - _Size); | ||||
|     return !(~__first_ & __m); | ||||
| @@ -555,7 +516,7 @@ __bitset<1, _Size>::all() const _NOEXCEPT | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| __bitset<1, _Size>::any() const _NOEXCEPT | ||||
| __bitset<1, _Size>::any() const | ||||
| { | ||||
|     __storage_type __m = ~__storage_type(0) >> (__bits_per_word - _Size); | ||||
|     return __first_ & __m; | ||||
| @@ -564,7 +525,7 @@ __bitset<1, _Size>::any() const _NOEXCEPT | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| size_t | ||||
| __bitset<1, _Size>::__hash_code() const _NOEXCEPT | ||||
| __bitset<1, _Size>::__hash_code() const | ||||
| { | ||||
|     return __first_; | ||||
| } | ||||
| @@ -575,9 +536,9 @@ class __bitset<0, 0> | ||||
| public: | ||||
|     typedef ptrdiff_t              difference_type; | ||||
|     typedef size_t                 size_type; | ||||
|     typedef size_type              __storage_type; | ||||
| protected: | ||||
|     typedef __bitset __self; | ||||
|     typedef size_type              __storage_type; | ||||
|     typedef       __storage_type*  __storage_pointer; | ||||
|     typedef const __storage_type*  __const_storage_pointer; | ||||
|     static const unsigned __bits_per_word = static_cast<unsigned>(sizeof(__storage_type) * CHAR_BIT); | ||||
| @@ -586,60 +547,57 @@ protected: | ||||
|     friend class __bit_const_reference<__bitset>; | ||||
|     friend class __bit_iterator<__bitset, false>; | ||||
|     friend class __bit_iterator<__bitset, true>; | ||||
|     friend struct __bit_array<__bitset>; | ||||
|     friend class __bit_array<__bitset>; | ||||
|  | ||||
|     typedef __bit_reference<__bitset>                  reference; | ||||
|     typedef __bit_const_reference<__bitset>            const_reference; | ||||
|     typedef __bit_iterator<__bitset, false>            iterator; | ||||
|     typedef __bit_iterator<__bitset, true>             const_iterator; | ||||
|  | ||||
|     _LIBCPP_CONSTEXPR __bitset() _NOEXCEPT; | ||||
|     explicit _LIBCPP_CONSTEXPR __bitset(unsigned long long) _NOEXCEPT; | ||||
|     __bitset(); | ||||
|     explicit __bitset(unsigned long long); | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY reference __make_ref(size_t) _NOEXCEPT | ||||
|     _LIBCPP_INLINE_VISIBILITY reference __make_ref(size_t) | ||||
|         {return reference(0, 1);} | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR const_reference __make_ref(size_t) const _NOEXCEPT | ||||
|     _LIBCPP_INLINE_VISIBILITY const_reference __make_ref(size_t) const | ||||
|         {return const_reference(0, 1);} | ||||
|     _LIBCPP_INLINE_VISIBILITY iterator __make_iter(size_t) _NOEXCEPT | ||||
|     _LIBCPP_INLINE_VISIBILITY iterator __make_iter(size_t __pos) | ||||
|         {return iterator(0, 0);} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator __make_iter(size_t) const _NOEXCEPT | ||||
|     _LIBCPP_INLINE_VISIBILITY const_iterator __make_iter(size_t __pos) const | ||||
|         {return const_iterator(0, 0);} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY void operator&=(const __bitset&) _NOEXCEPT {} | ||||
|     _LIBCPP_INLINE_VISIBILITY void operator|=(const __bitset&) _NOEXCEPT {} | ||||
|     _LIBCPP_INLINE_VISIBILITY void operator^=(const __bitset&) _NOEXCEPT {} | ||||
|     _LIBCPP_INLINE_VISIBILITY void operator&=(const __bitset&) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY void operator|=(const __bitset&) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY void operator^=(const __bitset&) {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY void flip() _NOEXCEPT {} | ||||
|     _LIBCPP_INLINE_VISIBILITY void flip() {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY unsigned long to_ulong() const {return 0;} | ||||
|     _LIBCPP_INLINE_VISIBILITY unsigned long long to_ullong() const {return 0;} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY bool all() const _NOEXCEPT {return true;} | ||||
|     _LIBCPP_INLINE_VISIBILITY bool any() const _NOEXCEPT {return false;} | ||||
|     _LIBCPP_INLINE_VISIBILITY bool all() const {return true;} | ||||
|     _LIBCPP_INLINE_VISIBILITY bool any() const {return false;} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY size_t __hash_code() const _NOEXCEPT {return 0;} | ||||
|     _LIBCPP_INLINE_VISIBILITY size_t __hash_code() const {return 0;} | ||||
| }; | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| __bitset<0, 0>::__bitset() _NOEXCEPT | ||||
| __bitset<0, 0>::__bitset() | ||||
| { | ||||
| } | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| __bitset<0, 0>::__bitset(unsigned long long) _NOEXCEPT | ||||
| __bitset<0, 0>::__bitset(unsigned long long) | ||||
| { | ||||
| } | ||||
|  | ||||
| template <size_t _Size> class _LIBCPP_TYPE_VIS_ONLY bitset; | ||||
| template <size_t _Size> struct _LIBCPP_TYPE_VIS_ONLY hash<bitset<_Size> >; | ||||
| template <size_t _Size> class bitset; | ||||
| template <size_t _Size> struct hash<bitset<_Size> >; | ||||
|  | ||||
| template <size_t _Size> | ||||
| class _LIBCPP_TYPE_VIS_ONLY bitset | ||||
| class _LIBCPP_VISIBLE bitset | ||||
|     : private __bitset<_Size == 0 ? 0 : (_Size - 1) / (sizeof(size_t) * CHAR_BIT) + 1, _Size> | ||||
| { | ||||
| public: | ||||
|     static const unsigned __n_words = _Size == 0 ? 0 : (_Size - 1) / (sizeof(size_t) * CHAR_BIT) + 1; | ||||
|     typedef __bitset<__n_words, _Size> base; | ||||
|  | ||||
| @@ -648,9 +606,8 @@ public: | ||||
|     typedef typename base::const_reference const_reference; | ||||
|  | ||||
|     // 23.3.5.1 constructors: | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR bitset() _NOEXCEPT {} | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR | ||||
|         bitset(unsigned long long __v) _NOEXCEPT : base(__v) {} | ||||
|     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY bitset() {} | ||||
|     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY bitset(unsigned long long __v) : base(__v) {} | ||||
|     template<class _CharT> | ||||
|         explicit bitset(const _CharT* __str, | ||||
|                         typename basic_string<_CharT>::size_type __n = basic_string<_CharT>::npos, | ||||
| @@ -663,22 +620,21 @@ public: | ||||
|                         _CharT __zero = _CharT('0'), _CharT __one = _CharT('1')); | ||||
|  | ||||
|     // 23.3.5.2 bitset operations: | ||||
|     bitset& operator&=(const bitset& __rhs) _NOEXCEPT; | ||||
|     bitset& operator|=(const bitset& __rhs) _NOEXCEPT; | ||||
|     bitset& operator^=(const bitset& __rhs) _NOEXCEPT; | ||||
|     bitset& operator<<=(size_t __pos) _NOEXCEPT; | ||||
|     bitset& operator>>=(size_t __pos) _NOEXCEPT; | ||||
|     bitset& set() _NOEXCEPT; | ||||
|     bitset& operator&=(const bitset& __rhs); | ||||
|     bitset& operator|=(const bitset& __rhs); | ||||
|     bitset& operator^=(const bitset& __rhs); | ||||
|     bitset& operator<<=(size_t __pos); | ||||
|     bitset& operator>>=(size_t __pos); | ||||
|     bitset& set(); | ||||
|     bitset& set(size_t __pos, bool __val = true); | ||||
|     bitset& reset() _NOEXCEPT; | ||||
|     bitset& reset(); | ||||
|     bitset& reset(size_t __pos); | ||||
|     bitset  operator~() const _NOEXCEPT; | ||||
|     bitset& flip() _NOEXCEPT; | ||||
|     bitset  operator~() const; | ||||
|     bitset& flip(); | ||||
|     bitset& flip(size_t __pos); | ||||
|  | ||||
|     // element access: | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR | ||||
|                               const_reference operator[](size_t __p) const {return base::__make_ref(__p);} | ||||
|     _LIBCPP_INLINE_VISIBILITY const_reference operator[](size_t __p) const {return base::__make_ref(__p);} | ||||
|     _LIBCPP_INLINE_VISIBILITY       reference operator[](size_t __p)       {return base::__make_ref(__p);} | ||||
|     unsigned long to_ulong() const; | ||||
|     unsigned long long to_ullong() const; | ||||
| @@ -693,21 +649,21 @@ public: | ||||
|                                                                                 _CharT __one = _CharT('1')) const; | ||||
|     basic_string<char, char_traits<char>, allocator<char> > to_string(char __zero = '0', | ||||
|                                                                       char __one = '1') const; | ||||
|     size_t count() const _NOEXCEPT; | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR size_t size() const _NOEXCEPT {return _Size;} | ||||
|     bool operator==(const bitset& __rhs) const _NOEXCEPT; | ||||
|     bool operator!=(const bitset& __rhs) const _NOEXCEPT; | ||||
|     size_t count() const; | ||||
|     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY size_t size() const {return _Size;} | ||||
|     bool operator==(const bitset& __rhs) const; | ||||
|     bool operator!=(const bitset& __rhs) const; | ||||
|     bool test(size_t __pos) const; | ||||
|     bool all() const _NOEXCEPT; | ||||
|     bool any() const _NOEXCEPT; | ||||
|     _LIBCPP_INLINE_VISIBILITY bool none() const _NOEXCEPT {return !any();} | ||||
|     bitset operator<<(size_t __pos) const _NOEXCEPT; | ||||
|     bitset operator>>(size_t __pos) const _NOEXCEPT; | ||||
|     bool all() const; | ||||
|     bool any() const; | ||||
|     _LIBCPP_INLINE_VISIBILITY bool none() const {return !any();} | ||||
|     bitset operator<<(size_t __pos) const; | ||||
|     bitset operator>>(size_t __pos) const; | ||||
|  | ||||
| private: | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     size_t __hash_code() const _NOEXCEPT {return base::__hash_code();} | ||||
|     size_t __hash_code() const {return base::__hash_code();} | ||||
|  | ||||
|     friend struct hash<bitset>; | ||||
| }; | ||||
| @@ -718,7 +674,7 @@ bitset<_Size>::bitset(const _CharT* __str, | ||||
|                       typename basic_string<_CharT>::size_type __n, | ||||
|                       _CharT __zero, _CharT __one) | ||||
| { | ||||
|     size_t __rlen = _VSTD::min(__n, char_traits<_CharT>::length(__str)); | ||||
|     size_t __rlen = _STD::min(__n, char_traits<_CharT>::length(__str)); | ||||
|     for (size_t __i = 0; __i < __rlen; ++__i) | ||||
|         if (__str[__i] != __zero && __str[__i] != __one) | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
| @@ -726,17 +682,17 @@ bitset<_Size>::bitset(const _CharT* __str, | ||||
| #else | ||||
|             assert(!"bitset string ctor has invalid argument"); | ||||
| #endif | ||||
|     size_t _Mp = _VSTD::min(__rlen, _Size); | ||||
|     size_t _M = _STD::min(__rlen, _Size); | ||||
|     size_t __i = 0; | ||||
|     for (; __i < _Mp; ++__i) | ||||
|     for (; __i < _M; ++__i) | ||||
|     { | ||||
|         _CharT __c = __str[_Mp - 1 - __i]; | ||||
|         _CharT __c = __str[_M - 1 - __i]; | ||||
|         if (__c == __zero) | ||||
|             (*this)[__i] = false; | ||||
|         else | ||||
|             (*this)[__i] = true; | ||||
|     } | ||||
|     _VSTD::fill(base::__make_iter(__i), base::__make_iter(_Size), false); | ||||
|     _STD::fill(base::__make_iter(__i), base::__make_iter(_Size), false); | ||||
| } | ||||
|  | ||||
| template <size_t _Size> | ||||
| @@ -752,7 +708,7 @@ bitset<_Size>::bitset(const basic_string<_CharT,_Traits,_Allocator>& __str, | ||||
| #else | ||||
|         assert(!"bitset string pos out of range"); | ||||
| #endif | ||||
|     size_t __rlen = _VSTD::min(__n, __str.size() - __pos); | ||||
|     size_t __rlen = _STD::min(__n, __str.size() - __pos); | ||||
|     for (size_t __i = __pos; __i < __pos + __rlen; ++__i) | ||||
|         if (!_Traits::eq(__str[__i], __zero) && !_Traits::eq(__str[__i], __one)) | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
| @@ -760,23 +716,23 @@ bitset<_Size>::bitset(const basic_string<_CharT,_Traits,_Allocator>& __str, | ||||
| #else | ||||
|             assert(!"bitset string ctor has invalid argument"); | ||||
| #endif | ||||
|     size_t _Mp = _VSTD::min(__rlen, _Size); | ||||
|     size_t _M = _STD::min(__rlen, _Size); | ||||
|     size_t __i = 0; | ||||
|     for (; __i < _Mp; ++__i) | ||||
|     for (; __i < _M; ++__i) | ||||
|     { | ||||
|         _CharT __c = __str[__pos + _Mp - 1 - __i]; | ||||
|         _CharT __c = __str[__pos + _M - 1 - __i]; | ||||
|         if (_Traits::eq(__c, __zero)) | ||||
|             (*this)[__i] = false; | ||||
|         else | ||||
|             (*this)[__i] = true; | ||||
|     } | ||||
|     _VSTD::fill(base::__make_iter(__i), base::__make_iter(_Size), false); | ||||
|     _STD::fill(base::__make_iter(__i), base::__make_iter(_Size), false); | ||||
| } | ||||
|  | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bitset<_Size>& | ||||
| bitset<_Size>::operator&=(const bitset& __rhs) _NOEXCEPT | ||||
| bitset<_Size>::operator&=(const bitset& __rhs) | ||||
| { | ||||
|     base::operator&=(__rhs); | ||||
|     return *this; | ||||
| @@ -785,7 +741,7 @@ bitset<_Size>::operator&=(const bitset& __rhs) _NOEXCEPT | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bitset<_Size>& | ||||
| bitset<_Size>::operator|=(const bitset& __rhs) _NOEXCEPT | ||||
| bitset<_Size>::operator|=(const bitset& __rhs) | ||||
| { | ||||
|     base::operator|=(__rhs); | ||||
|     return *this; | ||||
| @@ -794,7 +750,7 @@ bitset<_Size>::operator|=(const bitset& __rhs) _NOEXCEPT | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bitset<_Size>& | ||||
| bitset<_Size>::operator^=(const bitset& __rhs) _NOEXCEPT | ||||
| bitset<_Size>::operator^=(const bitset& __rhs) | ||||
| { | ||||
|     base::operator^=(__rhs); | ||||
|     return *this; | ||||
| @@ -802,30 +758,30 @@ bitset<_Size>::operator^=(const bitset& __rhs) _NOEXCEPT | ||||
|  | ||||
| template <size_t _Size> | ||||
| bitset<_Size>& | ||||
| bitset<_Size>::operator<<=(size_t __pos) _NOEXCEPT | ||||
| bitset<_Size>::operator<<=(size_t __pos) | ||||
| { | ||||
|     __pos = _VSTD::min(__pos, _Size); | ||||
|     _VSTD::copy_backward(base::__make_iter(0), base::__make_iter(_Size - __pos), base::__make_iter(_Size)); | ||||
|     _VSTD::fill_n(base::__make_iter(0), __pos, false); | ||||
|     __pos = _STD::min(__pos, _Size); | ||||
|     _STD::copy_backward(base::__make_iter(0), base::__make_iter(_Size - __pos), base::__make_iter(_Size)); | ||||
|     _STD::fill_n(base::__make_iter(0), __pos, false); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| template <size_t _Size> | ||||
| bitset<_Size>& | ||||
| bitset<_Size>::operator>>=(size_t __pos) _NOEXCEPT | ||||
| bitset<_Size>::operator>>=(size_t __pos) | ||||
| { | ||||
|     __pos = _VSTD::min(__pos, _Size); | ||||
|     _VSTD::copy(base::__make_iter(__pos), base::__make_iter(_Size), base::__make_iter(0)); | ||||
|     _VSTD::fill_n(base::__make_iter(_Size - __pos), __pos, false); | ||||
|     __pos = _STD::min(__pos, _Size); | ||||
|     _STD::copy(base::__make_iter(__pos), base::__make_iter(_Size), base::__make_iter(0)); | ||||
|     _STD::fill_n(base::__make_iter(_Size - __pos), __pos, false); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bitset<_Size>& | ||||
| bitset<_Size>::set() _NOEXCEPT | ||||
| bitset<_Size>::set() | ||||
| { | ||||
|     _VSTD::fill_n(base::__make_iter(0), _Size, true); | ||||
|     _STD::fill_n(base::__make_iter(0), _Size, true); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| @@ -846,9 +802,9 @@ bitset<_Size>::set(size_t __pos, bool __val) | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bitset<_Size>& | ||||
| bitset<_Size>::reset() _NOEXCEPT | ||||
| bitset<_Size>::reset() | ||||
| { | ||||
|     _VSTD::fill_n(base::__make_iter(0), _Size, false); | ||||
|     _STD::fill_n(base::__make_iter(0), _Size, false); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| @@ -869,7 +825,7 @@ bitset<_Size>::reset(size_t __pos) | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bitset<_Size> | ||||
| bitset<_Size>::operator~() const _NOEXCEPT | ||||
| bitset<_Size>::operator~() const | ||||
| { | ||||
|     bitset __x(*this); | ||||
|     __x.flip(); | ||||
| @@ -879,7 +835,7 @@ bitset<_Size>::operator~() const _NOEXCEPT | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bitset<_Size>& | ||||
| bitset<_Size>::flip() _NOEXCEPT | ||||
| bitset<_Size>::flip() | ||||
| { | ||||
|     base::flip(); | ||||
|     return *this; | ||||
| @@ -959,23 +915,23 @@ bitset<_Size>::to_string(char __zero, char __one) const | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| size_t | ||||
| bitset<_Size>::count() const _NOEXCEPT | ||||
| bitset<_Size>::count() const | ||||
| { | ||||
|     return static_cast<size_t>(_VSTD::count(base::__make_iter(0), base::__make_iter(_Size), true)); | ||||
|     return static_cast<size_t>(_STD::count(base::__make_iter(0), base::__make_iter(_Size), true)); | ||||
| } | ||||
|  | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| bitset<_Size>::operator==(const bitset& __rhs) const _NOEXCEPT | ||||
| bitset<_Size>::operator==(const bitset& __rhs) const | ||||
| { | ||||
|     return _VSTD::equal(base::__make_iter(0), base::__make_iter(_Size), __rhs.__make_iter(0)); | ||||
|     return _STD::equal(base::__make_iter(0), base::__make_iter(_Size), __rhs.__make_iter(0)); | ||||
| } | ||||
|  | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| bitset<_Size>::operator!=(const bitset& __rhs) const _NOEXCEPT | ||||
| bitset<_Size>::operator!=(const bitset& __rhs) const | ||||
| { | ||||
|     return !(*this == __rhs); | ||||
| } | ||||
| @@ -996,7 +952,7 @@ bitset<_Size>::test(size_t __pos) const | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| bitset<_Size>::all() const _NOEXCEPT | ||||
| bitset<_Size>::all() const | ||||
| { | ||||
|     return base::all(); | ||||
| } | ||||
| @@ -1004,7 +960,7 @@ bitset<_Size>::all() const _NOEXCEPT | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| bitset<_Size>::any() const _NOEXCEPT | ||||
| bitset<_Size>::any() const | ||||
| { | ||||
|     return base::any(); | ||||
| } | ||||
| @@ -1012,7 +968,7 @@ bitset<_Size>::any() const _NOEXCEPT | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bitset<_Size> | ||||
| bitset<_Size>::operator<<(size_t __pos) const _NOEXCEPT | ||||
| bitset<_Size>::operator<<(size_t __pos) const | ||||
| { | ||||
|     bitset __r = *this; | ||||
|     __r <<= __pos; | ||||
| @@ -1022,7 +978,7 @@ bitset<_Size>::operator<<(size_t __pos) const _NOEXCEPT | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bitset<_Size> | ||||
| bitset<_Size>::operator>>(size_t __pos) const _NOEXCEPT | ||||
| bitset<_Size>::operator>>(size_t __pos) const | ||||
| { | ||||
|     bitset __r = *this; | ||||
|     __r >>= __pos; | ||||
| @@ -1032,7 +988,7 @@ bitset<_Size>::operator>>(size_t __pos) const _NOEXCEPT | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bitset<_Size> | ||||
| operator&(const bitset<_Size>& __x, const bitset<_Size>& __y) _NOEXCEPT | ||||
| operator&(const bitset<_Size>& __x, const bitset<_Size>& __y) | ||||
| { | ||||
|     bitset<_Size> __r = __x; | ||||
|     __r &= __y; | ||||
| @@ -1042,7 +998,7 @@ operator&(const bitset<_Size>& __x, const bitset<_Size>& __y) _NOEXCEPT | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bitset<_Size> | ||||
| operator|(const bitset<_Size>& __x, const bitset<_Size>& __y) _NOEXCEPT | ||||
| operator|(const bitset<_Size>& __x, const bitset<_Size>& __y) | ||||
| { | ||||
|     bitset<_Size> __r = __x; | ||||
|     __r |= __y; | ||||
| @@ -1052,7 +1008,7 @@ operator|(const bitset<_Size>& __x, const bitset<_Size>& __y) _NOEXCEPT | ||||
| template <size_t _Size> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bitset<_Size> | ||||
| operator^(const bitset<_Size>& __x, const bitset<_Size>& __y) _NOEXCEPT | ||||
| operator^(const bitset<_Size>& __x, const bitset<_Size>& __y) | ||||
| { | ||||
|     bitset<_Size> __r = __x; | ||||
|     __r ^= __y; | ||||
| @@ -1060,22 +1016,14 @@ operator^(const bitset<_Size>& __x, const bitset<_Size>& __y) _NOEXCEPT | ||||
| } | ||||
|  | ||||
| template <size_t _Size> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY hash<bitset<_Size> > | ||||
| struct _LIBCPP_VISIBLE hash<bitset<_Size> > | ||||
|     : public unary_function<bitset<_Size>, size_t> | ||||
| { | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     size_t operator()(const bitset<_Size>& __bs) const _NOEXCEPT | ||||
|     size_t operator()(const bitset<_Size>& __bs) const | ||||
|         {return __bs.__hash_code();} | ||||
| }; | ||||
|  | ||||
| template <class _CharT, class _Traits, size_t _Size> | ||||
| basic_istream<_CharT, _Traits>& | ||||
| operator>>(basic_istream<_CharT, _Traits>& __is, bitset<_Size>& __x); | ||||
|  | ||||
| template <class _CharT, class _Traits, size_t _Size> | ||||
| basic_ostream<_CharT, _Traits>& | ||||
| operator<<(basic_ostream<_CharT, _Traits>& __os, const bitset<_Size>& __x); | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
| #endif  // _LIBCPP_BITSET | ||||
|   | ||||
| @@ -20,6 +20,4 @@ Macros: | ||||
| #include <__config> | ||||
| #include <assert.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|   | ||||
| @@ -20,9 +20,7 @@ | ||||
|  | ||||
| #include <complex> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| // hh 080623 Created | ||||
|  | ||||
|   | ||||
| @@ -37,13 +37,8 @@ int toupper(int c); | ||||
|  | ||||
| #include <__config> | ||||
| #include <ctype.h> | ||||
| #if defined(_LIBCPP_MSVCRT) | ||||
| #include "support/win32/support.h" | ||||
| #endif // _LIBCPP_MSVCRT | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
							
								
								
									
										318
									
								
								include/cerrno
									
									
									
									
									
								
							
							
						
						
									
										318
									
								
								include/cerrno
									
									
									
									
									
								
							| @@ -26,9 +26,7 @@ Macros: | ||||
| #include <__config> | ||||
| #include <errno.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| #if !defined(EOWNERDEAD) || !defined(ENOTRECOVERABLE) | ||||
|  | ||||
| @@ -74,320 +72,4 @@ const int __elast2 = 105; | ||||
|  | ||||
| #endif  // !defined(EOWNERDEAD) || !defined(ENOTRECOVERABLE) | ||||
|  | ||||
| //  supply errno values likely to be missing, particularly on Windows | ||||
|  | ||||
| #ifndef EAFNOSUPPORT | ||||
| #define EAFNOSUPPORT 9901 | ||||
| #endif | ||||
|  | ||||
| #ifndef EADDRINUSE | ||||
| #define EADDRINUSE 9902 | ||||
| #endif | ||||
|  | ||||
| #ifndef EADDRNOTAVAIL | ||||
| #define EADDRNOTAVAIL 9903 | ||||
| #endif | ||||
|  | ||||
| #ifndef EISCONN | ||||
| #define EISCONN 9904 | ||||
| #endif | ||||
|  | ||||
| #ifndef EBADMSG | ||||
| #define EBADMSG 9905 | ||||
| #endif | ||||
|  | ||||
| #ifndef ECONNABORTED | ||||
| #define ECONNABORTED 9906 | ||||
| #endif | ||||
|  | ||||
| #ifndef EALREADY | ||||
| #define EALREADY 9907 | ||||
| #endif | ||||
|  | ||||
| #ifndef ECONNREFUSED | ||||
| #define ECONNREFUSED 9908 | ||||
| #endif | ||||
|  | ||||
| #ifndef ECONNRESET | ||||
| #define ECONNRESET 9909 | ||||
| #endif | ||||
|  | ||||
| #ifndef EDESTADDRREQ | ||||
| #define EDESTADDRREQ 9910 | ||||
| #endif | ||||
|  | ||||
| #ifndef EHOSTUNREACH | ||||
| #define EHOSTUNREACH 9911 | ||||
| #endif | ||||
|  | ||||
| #ifndef EIDRM | ||||
| #define EIDRM 9912 | ||||
| #endif | ||||
|  | ||||
| #ifndef EMSGSIZE | ||||
| #define EMSGSIZE 9913 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENETDOWN | ||||
| #define ENETDOWN 9914 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENETRESET | ||||
| #define ENETRESET 9915 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENETUNREACH | ||||
| #define ENETUNREACH 9916 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOBUFS | ||||
| #define ENOBUFS 9917 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOLINK | ||||
| #define ENOLINK 9918 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENODATA | ||||
| #define ENODATA 9919 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOMSG | ||||
| #define ENOMSG 9920 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOPROTOOPT | ||||
| #define ENOPROTOOPT 9921 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOSR | ||||
| #define ENOSR 9922 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOTSOCK | ||||
| #define ENOTSOCK 9923 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOSTR | ||||
| #define ENOSTR 9924 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOTCONN | ||||
| #define ENOTCONN 9925 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOTSUP | ||||
| #define ENOTSUP 9926 | ||||
| #endif | ||||
|  | ||||
| #ifndef ECANCELED | ||||
| #define ECANCELED 9927 | ||||
| #endif | ||||
|  | ||||
| #ifndef EINPROGRESS | ||||
| #define EINPROGRESS 9928 | ||||
| #endif | ||||
|  | ||||
| #ifndef EOPNOTSUPP | ||||
| #define EOPNOTSUPP 9929 | ||||
| #endif | ||||
|  | ||||
| #ifndef EWOULDBLOCK | ||||
| #define EWOULDBLOCK 9930 | ||||
| #endif | ||||
|  | ||||
| #ifndef EOWNERDEAD | ||||
| #define EOWNERDEAD  9931 | ||||
| #endif | ||||
|  | ||||
| #ifndef EPROTO | ||||
| #define EPROTO 9932 | ||||
| #endif | ||||
|  | ||||
| #ifndef EPROTONOSUPPORT | ||||
| #define EPROTONOSUPPORT 9933 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOTRECOVERABLE | ||||
| #define ENOTRECOVERABLE 9934 | ||||
| #endif | ||||
|  | ||||
| #ifndef ETIME | ||||
| #define ETIME 9935 | ||||
| #endif | ||||
|  | ||||
| #ifndef ETXTBSY | ||||
| #define ETXTBSY 9936 | ||||
| #endif | ||||
|  | ||||
| #ifndef ETIMEDOUT | ||||
| #define ETIMEDOUT 9938 | ||||
| #endif | ||||
|  | ||||
| #ifndef ELOOP | ||||
| #define ELOOP 9939 | ||||
| #endif | ||||
|  | ||||
| #ifndef EOVERFLOW | ||||
| #define EOVERFLOW 9940 | ||||
| #endif | ||||
|  | ||||
| #ifndef EPROTOTYPE | ||||
| #define EPROTOTYPE 9941 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOSYS | ||||
| #define ENOSYS 9942 | ||||
| #endif | ||||
|  | ||||
| #ifndef EINVAL | ||||
| #define EINVAL 9943 | ||||
| #endif | ||||
|  | ||||
| #ifndef ERANGE | ||||
| #define ERANGE 9944 | ||||
| #endif | ||||
|  | ||||
| #ifndef EILSEQ | ||||
| #define EILSEQ 9945 | ||||
| #endif | ||||
|  | ||||
| //  Windows Mobile doesn't appear to define these: | ||||
|  | ||||
| #ifndef E2BIG | ||||
| #define E2BIG 9946 | ||||
| #endif | ||||
|  | ||||
| #ifndef EDOM | ||||
| #define EDOM 9947 | ||||
| #endif | ||||
|  | ||||
| #ifndef EFAULT | ||||
| #define EFAULT 9948 | ||||
| #endif | ||||
|  | ||||
| #ifndef EBADF | ||||
| #define EBADF 9949 | ||||
| #endif | ||||
|  | ||||
| #ifndef EPIPE | ||||
| #define EPIPE 9950 | ||||
| #endif | ||||
|  | ||||
| #ifndef EXDEV | ||||
| #define EXDEV 9951 | ||||
| #endif | ||||
|  | ||||
| #ifndef EBUSY | ||||
| #define EBUSY 9952 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOTEMPTY | ||||
| #define ENOTEMPTY 9953 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOEXEC | ||||
| #define ENOEXEC 9954 | ||||
| #endif | ||||
|  | ||||
| #ifndef EEXIST | ||||
| #define EEXIST 9955 | ||||
| #endif | ||||
|  | ||||
| #ifndef EFBIG | ||||
| #define EFBIG 9956 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENAMETOOLONG | ||||
| #define ENAMETOOLONG 9957 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOTTY | ||||
| #define ENOTTY 9958 | ||||
| #endif | ||||
|  | ||||
| #ifndef EINTR | ||||
| #define EINTR 9959 | ||||
| #endif | ||||
|  | ||||
| #ifndef ESPIPE | ||||
| #define ESPIPE 9960 | ||||
| #endif | ||||
|  | ||||
| #ifndef EIO | ||||
| #define EIO 9961 | ||||
| #endif | ||||
|  | ||||
| #ifndef EISDIR | ||||
| #define EISDIR 9962 | ||||
| #endif | ||||
|  | ||||
| #ifndef ECHILD | ||||
| #define ECHILD 9963 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOLCK | ||||
| #define ENOLCK 9964 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOSPC | ||||
| #define ENOSPC 9965 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENXIO | ||||
| #define ENXIO 9966 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENODEV | ||||
| #define ENODEV 9967 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOENT | ||||
| #define ENOENT 9968 | ||||
| #endif | ||||
|  | ||||
| #ifndef ESRCH | ||||
| #define ESRCH 9969 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOTDIR | ||||
| #define ENOTDIR 9970 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENOMEM | ||||
| #define ENOMEM 9971 | ||||
| #endif | ||||
|  | ||||
| #ifndef EPERM | ||||
| #define EPERM 9972 | ||||
| #endif | ||||
|  | ||||
| #ifndef EACCES | ||||
| #define EACCES 9973 | ||||
| #endif | ||||
|  | ||||
| #ifndef EROFS | ||||
| #define EROFS 9974 | ||||
| #endif | ||||
|  | ||||
| #ifndef EDEADLK | ||||
| #define EDEADLK 9975 | ||||
| #endif | ||||
|  | ||||
| #ifndef EAGAIN | ||||
| #define EAGAIN 9976 | ||||
| #endif | ||||
|  | ||||
| #ifndef ENFILE | ||||
| #define ENFILE 9977 | ||||
| #endif | ||||
|  | ||||
| #ifndef EMFILE | ||||
| #define EMFILE 9978 | ||||
| #endif | ||||
|  | ||||
| #ifndef EMLINK | ||||
| #define EMLINK 9979 | ||||
| #endif | ||||
|  | ||||
| #endif  // _LIBCPP_CERRNO | ||||
|   | ||||
| @@ -56,9 +56,7 @@ int feupdateenv(const fenv_t* envp); | ||||
| #include <__config> | ||||
| #include <fenv.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
| @@ -63,9 +63,7 @@ Macros: | ||||
| #include <__config> | ||||
| #include <float.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| #ifndef FLT_EVAL_METHOD | ||||
| #define FLT_EVAL_METHOD __FLT_EVAL_METHOD__ | ||||
|   | ||||
							
								
								
									
										376
									
								
								include/chrono
									
									
									
									
									
								
							
							
						
						
									
										376
									
								
								include/chrono
									
									
									
									
									
								
							| @@ -20,7 +20,6 @@ namespace chrono | ||||
| { | ||||
|  | ||||
| template <class ToDuration, class Rep, class Period> | ||||
| constexpr | ||||
| ToDuration | ||||
| duration_cast(const duration<Rep, Period>& fd); | ||||
|  | ||||
| @@ -30,9 +29,9 @@ template <class Rep> | ||||
| struct duration_values | ||||
| { | ||||
| public: | ||||
|     static constexpr Rep zero(); | ||||
|     static constexpr Rep max(); | ||||
|     static constexpr Rep min(); | ||||
|     static Rep zero(); | ||||
|     static Rep max(); | ||||
|     static Rep min(); | ||||
| }; | ||||
|  | ||||
| // duration | ||||
| @@ -47,9 +46,9 @@ public: | ||||
|     typedef Rep rep; | ||||
|     typedef Period period; | ||||
|  | ||||
|     constexpr duration() = default; | ||||
|     duration() = default; | ||||
|     template <class Rep2> | ||||
|         constexpr explicit duration(const Rep2& r, | ||||
|         explicit duration(const Rep2& r, | ||||
|             typename enable_if | ||||
|             < | ||||
|                is_convertible<Rep2, rep>::value && | ||||
| @@ -59,7 +58,7 @@ public: | ||||
|  | ||||
|     // conversions | ||||
|     template <class Rep2, class Period2> | ||||
|         constexpr duration(const duration<Rep2, Period2>& d, | ||||
|         duration(const duration<Rep2, Period2>& d, | ||||
|             typename enable_if | ||||
|             < | ||||
|                 treat_as_floating_point<rep>::value || | ||||
| @@ -68,12 +67,12 @@ public: | ||||
|  | ||||
|     // observer | ||||
|  | ||||
|     constexpr rep count() const; | ||||
|     rep count() const; | ||||
|  | ||||
|     // arithmetic | ||||
|  | ||||
|     constexpr duration  operator+() const; | ||||
|     constexpr duration  operator-() const; | ||||
|     duration  operator+() const; | ||||
|     duration  operator-() const; | ||||
|     duration& operator++(); | ||||
|     duration  operator++(int); | ||||
|     duration& operator--(); | ||||
| @@ -87,9 +86,9 @@ public: | ||||
|  | ||||
|     // special values | ||||
|  | ||||
|     static constexpr duration zero(); | ||||
|     static constexpr duration min(); | ||||
|     static constexpr duration max(); | ||||
|     static duration zero(); | ||||
|     static duration min(); | ||||
|     static duration max(); | ||||
| }; | ||||
|  | ||||
| typedef duration<long long,         nano> nanoseconds; | ||||
| @@ -111,16 +110,16 @@ private: | ||||
|     duration d_;  // exposition only | ||||
|  | ||||
| public: | ||||
|     time_point();  // has value "epoch" // constexpr in C++14 | ||||
|     explicit time_point(const duration& d);  // same as time_point() + d // constexpr in C++14 | ||||
|     time_point();  // has value "epoch" | ||||
|     explicit time_point(const duration& d);  // same as time_point() + d | ||||
|  | ||||
|     // conversions | ||||
|     template <class Duration2> | ||||
|        time_point(const time_point<clock, Duration2>& t); // constexpr in C++14 | ||||
|        time_point(const time_point<clock, Duration2>& t); | ||||
|  | ||||
|     // observer | ||||
|  | ||||
|     duration time_since_epoch() const; // constexpr in C++14 | ||||
|     duration time_since_epoch() const; | ||||
|  | ||||
|     // arithmetic | ||||
|  | ||||
| @@ -146,55 +145,43 @@ namespace chrono { | ||||
|  | ||||
| // duration arithmetic | ||||
| template <class Rep1, class Period1, class Rep2, class Period2> | ||||
|   constexpr | ||||
|   typename common_type<duration<Rep1, Period1>, duration<Rep2, Period2>>::type | ||||
|   operator+(const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs); | ||||
| template <class Rep1, class Period1, class Rep2, class Period2> | ||||
|   constexpr | ||||
|   typename common_type<duration<Rep1, Period1>, duration<Rep2, Period2>>::type | ||||
|   operator-(const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs); | ||||
| template <class Rep1, class Period, class Rep2> | ||||
|   constexpr | ||||
|   duration<typename common_type<Rep1, Rep2>::type, Period> | ||||
|   operator*(const duration<Rep1, Period>& d, const Rep2& s); | ||||
| template <class Rep1, class Period, class Rep2> | ||||
|   constexpr | ||||
|   duration<typename common_type<Rep1, Rep2>::type, Period> | ||||
|   operator*(const Rep1& s, const duration<Rep2, Period>& d); | ||||
| template <class Rep1, class Period, class Rep2> | ||||
|   constexpr | ||||
|   duration<typename common_type<Rep1, Rep2>::type, Period> | ||||
|   operator/(const duration<Rep1, Period>& d, const Rep2& s); | ||||
| template <class Rep1, class Period1, class Rep2, class Period2> | ||||
|   constexpr | ||||
|   typename common_type<Rep1, Rep2>::type | ||||
|   operator/(const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs); | ||||
|  | ||||
| // duration comparisons | ||||
| template <class Rep1, class Period1, class Rep2, class Period2> | ||||
|    constexpr | ||||
|    bool operator==(const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs); | ||||
| template <class Rep1, class Period1, class Rep2, class Period2> | ||||
|    constexpr | ||||
|    bool operator!=(const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs); | ||||
| template <class Rep1, class Period1, class Rep2, class Period2> | ||||
|    constexpr | ||||
|    bool operator< (const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs); | ||||
| template <class Rep1, class Period1, class Rep2, class Period2> | ||||
|    constexpr | ||||
|    bool operator<=(const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs); | ||||
| template <class Rep1, class Period1, class Rep2, class Period2> | ||||
|    constexpr | ||||
|    bool operator> (const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs); | ||||
| template <class Rep1, class Period1, class Rep2, class Period2> | ||||
|    constexpr | ||||
|    bool operator>=(const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs); | ||||
|  | ||||
| // duration_cast | ||||
| template <class ToDuration, class Rep, class Period> | ||||
|   ToDuration duration_cast(const duration<Rep, Period>& d); | ||||
|  | ||||
| // time_point arithmetic (all constexpr in C++14) | ||||
| // time_point arithmetic | ||||
| template <class Clock, class Duration1, class Rep2, class Period2> | ||||
|   time_point<Clock, typename common_type<Duration1, duration<Rep2, Period2>>::type> | ||||
|   operator+(const time_point<Clock, Duration1>& lhs, const duration<Rep2, Period2>& rhs); | ||||
| @@ -208,7 +195,7 @@ template <class Clock, class Duration1, class Duration2> | ||||
|   typename common_type<Duration1, Duration2>::type | ||||
|   operator-(const time_point<Clock, Duration1>& lhs, const time_point<Clock, Duration2>& rhs); | ||||
|  | ||||
| // time_point comparisons (all constexpr in C++14) | ||||
| // time_point comparisons | ||||
| template <class Clock, class Duration1, class Duration2> | ||||
|    bool operator==(const time_point<Clock, Duration1>& lhs, const time_point<Clock, Duration2>& rhs); | ||||
| template <class Clock, class Duration1, class Duration2> | ||||
| @@ -222,7 +209,7 @@ template <class Clock, class Duration1, class Duration2> | ||||
| template <class Clock, class Duration1, class Duration2> | ||||
|    bool operator>=(const time_point<Clock, Duration1>& lhs, const time_point<Clock, Duration2>& rhs); | ||||
|  | ||||
| // time_point_cast (constexpr in C++14) | ||||
| // time_point_cast | ||||
|  | ||||
| template <class ToDuration, class Clock, class Duration> | ||||
|   time_point<Clock, ToDuration> time_point_cast(const time_point<Clock, Duration>& t); | ||||
| @@ -236,11 +223,11 @@ public: | ||||
|     typedef duration::rep                    rep; | ||||
|     typedef duration::period                 period; | ||||
|     typedef chrono::time_point<system_clock> time_point; | ||||
|     static const bool is_steady =            false; // constexpr in C++14 | ||||
|     static const bool is_steady =            false; | ||||
|  | ||||
|     static time_point now() noexcept; | ||||
|     static time_t     to_time_t  (const time_point& __t) noexcept; | ||||
|     static time_point from_time_t(time_t __t) noexcept; | ||||
|     static time_point now(); | ||||
|     static time_t     to_time_t  (const time_point& __t); | ||||
|     static time_point from_time_t(time_t __t); | ||||
| }; | ||||
|  | ||||
| class steady_clock | ||||
| @@ -250,28 +237,15 @@ public: | ||||
|     typedef duration::rep                                 rep; | ||||
|     typedef duration::period                              period; | ||||
|     typedef chrono::time_point<steady_clock, duration>    time_point; | ||||
|     static const bool is_steady =                         true; // constexpr in C++14 | ||||
|     static const bool is_steady =                         true; | ||||
|  | ||||
|     static time_point now() noexcept; | ||||
|     static time_point now(); | ||||
| }; | ||||
|  | ||||
| typedef steady_clock high_resolution_clock; | ||||
|  | ||||
| }  // chrono | ||||
|  | ||||
| constexpr chrono::hours                                 operator "" h(unsigned long long); // C++14 | ||||
| constexpr chrono::duration<unspecified , ratio<3600,1>> operator "" h(long double); // C++14 | ||||
| constexpr chrono::minutes                               operator "" min(unsigned long long); // C++14 | ||||
| constexpr chrono::duration<unspecified , ratio<60,1>>   operator "" min(long double); // C++14 | ||||
| constexpr chrono::seconds                               operator "" s(unsigned long long); // C++14 | ||||
| constexpr chrono::duration<unspecified >                operator "" s(long double); // C++14 | ||||
| constexpr chrono::milliseconds                          operator "" ms(unsigned long long); // C++14 | ||||
| constexpr chrono::duration<unspecified , milli>         operator "" ms(long double); // C++14 | ||||
| constexpr chrono::microseconds                          operator "" us(unsigned long long); // C++14 | ||||
| constexpr chrono::duration<unspecified , micro>         operator "" us(long double); // C++14 | ||||
| constexpr chrono::nanoseconds                           operator "" ns(unsigned long long); // C++14 | ||||
| constexpr chrono::duration<unspecified , nano>          operator "" ns(long double); // C++14 | ||||
|  | ||||
| }  // std | ||||
| */ | ||||
|  | ||||
| @@ -281,18 +255,14 @@ constexpr chrono::duration<unspecified , nano>          operator "" ns(long doub | ||||
| #include <ratio> | ||||
| #include <limits> | ||||
|  | ||||
| #include <__undef_min_max> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| namespace chrono | ||||
| { | ||||
|  | ||||
| template <class _Rep, class _Period = ratio<1> > class _LIBCPP_TYPE_VIS_ONLY duration; | ||||
| template <class _Rep, class _Period = ratio<1> > class _LIBCPP_VISIBLE duration; | ||||
|  | ||||
| template <class _Tp> | ||||
| struct __is_duration : false_type {}; | ||||
| @@ -312,8 +282,8 @@ struct __is_duration<const volatile duration<_Rep, _Period> > : true_type  {}; | ||||
| } // chrono | ||||
|  | ||||
| template <class _Rep1, class _Period1, class _Rep2, class _Period2> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY common_type<chrono::duration<_Rep1, _Period1>, | ||||
|                                          chrono::duration<_Rep2, _Period2> > | ||||
| struct _LIBCPP_VISIBLE common_type<chrono::duration<_Rep1, _Period1>, | ||||
|                                    chrono::duration<_Rep2, _Period2> > | ||||
| { | ||||
|     typedef chrono::duration<typename common_type<_Rep1, _Rep2>::type, | ||||
|                              typename __ratio_gcd<_Period1, _Period2>::type> type; | ||||
| @@ -332,7 +302,7 @@ struct __duration_cast; | ||||
| template <class _FromDuration, class _ToDuration, class _Period> | ||||
| struct __duration_cast<_FromDuration, _ToDuration, _Period, true, true> | ||||
| { | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     _ToDuration operator()(const _FromDuration& __fd) const | ||||
|     { | ||||
|         return _ToDuration(static_cast<typename _ToDuration::rep>(__fd.count())); | ||||
| @@ -342,7 +312,7 @@ struct __duration_cast<_FromDuration, _ToDuration, _Period, true, true> | ||||
| template <class _FromDuration, class _ToDuration, class _Period> | ||||
| struct __duration_cast<_FromDuration, _ToDuration, _Period, true, false> | ||||
| { | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     _ToDuration operator()(const _FromDuration& __fd) const | ||||
|     { | ||||
|         typedef typename common_type<typename _ToDuration::rep, typename _FromDuration::rep, intmax_t>::type _Ct; | ||||
| @@ -354,7 +324,7 @@ struct __duration_cast<_FromDuration, _ToDuration, _Period, true, false> | ||||
| template <class _FromDuration, class _ToDuration, class _Period> | ||||
| struct __duration_cast<_FromDuration, _ToDuration, _Period, false, true> | ||||
| { | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     _ToDuration operator()(const _FromDuration& __fd) const | ||||
|     { | ||||
|         typedef typename common_type<typename _ToDuration::rep, typename _FromDuration::rep, intmax_t>::type _Ct; | ||||
| @@ -366,7 +336,7 @@ struct __duration_cast<_FromDuration, _ToDuration, _Period, false, true> | ||||
| template <class _FromDuration, class _ToDuration, class _Period> | ||||
| struct __duration_cast<_FromDuration, _ToDuration, _Period, false, false> | ||||
| { | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     _ToDuration operator()(const _FromDuration& __fd) const | ||||
|     { | ||||
|         typedef typename common_type<typename _ToDuration::rep, typename _FromDuration::rep, intmax_t>::type _Ct; | ||||
| @@ -378,7 +348,6 @@ struct __duration_cast<_FromDuration, _ToDuration, _Period, false, false> | ||||
|  | ||||
| template <class _ToDuration, class _Rep, class _Period> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| typename enable_if | ||||
| < | ||||
|     __is_duration<_ToDuration>::value, | ||||
| @@ -390,56 +359,25 @@ duration_cast(const duration<_Rep, _Period>& __fd) | ||||
| } | ||||
|  | ||||
| template <class _Rep> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY treat_as_floating_point : is_floating_point<_Rep> {}; | ||||
| struct _LIBCPP_VISIBLE treat_as_floating_point : is_floating_point<_Rep> {}; | ||||
|  | ||||
| template <class _Rep> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY duration_values | ||||
| struct _LIBCPP_VISIBLE duration_values | ||||
| { | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR _Rep zero() {return _Rep(0);} | ||||
|     _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR _Rep max()  {return numeric_limits<_Rep>::max();} | ||||
|     _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR _Rep min()  {return numeric_limits<_Rep>::lowest();} | ||||
|     _LIBCPP_INLINE_VISIBILITY static _Rep zero() {return _Rep(0);} | ||||
|     _LIBCPP_INLINE_VISIBILITY static _Rep max()  {return numeric_limits<_Rep>::max();} | ||||
|     _LIBCPP_INLINE_VISIBILITY static _Rep min()  {return numeric_limits<_Rep>::lowest();} | ||||
| }; | ||||
|  | ||||
| // duration | ||||
|  | ||||
| template <class _Rep, class _Period> | ||||
| class _LIBCPP_TYPE_VIS_ONLY duration | ||||
| class _LIBCPP_VISIBLE duration | ||||
| { | ||||
|     static_assert(!__is_duration<_Rep>::value, "A duration representation can not be a duration"); | ||||
|     static_assert(__is_ratio<_Period>::value, "Second template parameter of duration must be a std::ratio"); | ||||
|     static_assert(_Period::num > 0, "duration period must be positive"); | ||||
|  | ||||
|     template <class _R1, class _R2> | ||||
|     struct __no_overflow | ||||
|     { | ||||
|     private: | ||||
|         static const intmax_t __gcd_n1_n2 = __static_gcd<_R1::num, _R2::num>::value; | ||||
|         static const intmax_t __gcd_d1_d2 = __static_gcd<_R1::den, _R2::den>::value; | ||||
|         static const intmax_t __n1 = _R1::num / __gcd_n1_n2; | ||||
|         static const intmax_t __d1 = _R1::den / __gcd_d1_d2; | ||||
|         static const intmax_t __n2 = _R2::num / __gcd_n1_n2; | ||||
|         static const intmax_t __d2 = _R2::den / __gcd_d1_d2; | ||||
|         static const intmax_t max = -((intmax_t(1) << (sizeof(intmax_t) * CHAR_BIT - 1)) + 1); | ||||
|  | ||||
|         template <intmax_t _Xp, intmax_t _Yp, bool __overflow> | ||||
|         struct __mul    // __overflow == false | ||||
|         { | ||||
|             static const intmax_t value = _Xp * _Yp; | ||||
|         }; | ||||
|  | ||||
|         template <intmax_t _Xp, intmax_t _Yp> | ||||
|         struct __mul<_Xp, _Yp, true> | ||||
|         { | ||||
|             static const intmax_t value = 1; | ||||
|         }; | ||||
|  | ||||
|     public: | ||||
|         static const bool value = (__n1 <= max / __d2) && (__n2 <= max / __d1); | ||||
|         typedef ratio<__mul<__n1, __d2, !value>::value, | ||||
|                       __mul<__n2, __d1, !value>::value> type; | ||||
|     }; | ||||
|      | ||||
| public: | ||||
|     typedef _Rep rep; | ||||
|     typedef _Period period; | ||||
| @@ -447,15 +385,9 @@ private: | ||||
|     rep __rep_; | ||||
| public: | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR | ||||
| #ifndef _LIBCPP_HAS_NO_DEFAULTED_FUNCTIONS | ||||
|         duration() = default; | ||||
| #else | ||||
|         duration() {} | ||||
| #endif | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY duration() {} // = default; | ||||
|     template <class _Rep2> | ||||
|         _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         explicit duration(const _Rep2& __r, | ||||
|             typename enable_if | ||||
|             < | ||||
| @@ -467,25 +399,24 @@ public: | ||||
|  | ||||
|     // conversions | ||||
|     template <class _Rep2, class _Period2> | ||||
|         _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         duration(const duration<_Rep2, _Period2>& __d, | ||||
|             typename enable_if | ||||
|             < | ||||
|                 __no_overflow<_Period2, period>::value && ( | ||||
|                 treat_as_floating_point<rep>::value || | ||||
|                 (__no_overflow<_Period2, period>::type::den == 1 && | ||||
|                  !treat_as_floating_point<_Rep2>::value)) | ||||
|                 (ratio_divide<_Period2, period>::type::den == 1 && | ||||
|                  !treat_as_floating_point<_Rep2>::value) | ||||
|             >::type* = 0) | ||||
|                 : __rep_(_VSTD::chrono::duration_cast<duration>(__d).count()) {} | ||||
|                 : __rep_(_STD::chrono::duration_cast<duration>(__d).count()) {} | ||||
|  | ||||
|     // observer | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR rep count() const {return __rep_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY rep count() const {return __rep_;} | ||||
|  | ||||
|     // arithmetic | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR duration  operator+() const {return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR duration  operator-() const {return duration(-__rep_);} | ||||
|     _LIBCPP_INLINE_VISIBILITY duration  operator+() const {return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY duration  operator-() const {return duration(-__rep_);} | ||||
|     _LIBCPP_INLINE_VISIBILITY duration& operator++()      {++__rep_; return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY duration  operator++(int)   {return duration(__rep_++);} | ||||
|     _LIBCPP_INLINE_VISIBILITY duration& operator--()      {--__rep_; return *this;} | ||||
| @@ -501,9 +432,9 @@ public: | ||||
|  | ||||
|     // special values | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR duration zero() {return duration(duration_values<rep>::zero());} | ||||
|     _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR duration min()  {return duration(duration_values<rep>::min());} | ||||
|     _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR duration max()  {return duration(duration_values<rep>::max());} | ||||
|     _LIBCPP_INLINE_VISIBILITY static duration zero() {return duration(duration_values<rep>::zero());} | ||||
|     _LIBCPP_INLINE_VISIBILITY static duration min()  {return duration(duration_values<rep>::min());} | ||||
|     _LIBCPP_INLINE_VISIBILITY static duration max()  {return duration(duration_values<rep>::max());} | ||||
| }; | ||||
|  | ||||
| typedef duration<long long,         nano> nanoseconds; | ||||
| @@ -518,8 +449,8 @@ typedef duration<     long, ratio<3600> > hours; | ||||
| template <class _LhsDuration, class _RhsDuration> | ||||
| struct __duration_eq | ||||
| { | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR | ||||
|     bool operator()(const _LhsDuration& __lhs, const _RhsDuration& __rhs) const | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     bool operator()(const _LhsDuration& __lhs, const _RhsDuration& __rhs) | ||||
|         { | ||||
|             typedef typename common_type<_LhsDuration, _RhsDuration>::type _Ct; | ||||
|             return _Ct(__lhs).count() == _Ct(__rhs).count(); | ||||
| @@ -529,14 +460,13 @@ struct __duration_eq | ||||
| template <class _LhsDuration> | ||||
| struct __duration_eq<_LhsDuration, _LhsDuration> | ||||
| { | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR | ||||
|     bool operator()(const _LhsDuration& __lhs, const _LhsDuration& __rhs) const | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     bool operator()(const _LhsDuration& __lhs, const _LhsDuration& __rhs) | ||||
|         {return __lhs.count() == __rhs.count();} | ||||
| }; | ||||
|  | ||||
| template <class _Rep1, class _Period1, class _Rep2, class _Period2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| bool | ||||
| operator==(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs) | ||||
| { | ||||
| @@ -547,7 +477,6 @@ operator==(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period | ||||
|  | ||||
| template <class _Rep1, class _Period1, class _Rep2, class _Period2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| bool | ||||
| operator!=(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs) | ||||
| { | ||||
| @@ -559,8 +488,8 @@ operator!=(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period | ||||
| template <class _LhsDuration, class _RhsDuration> | ||||
| struct __duration_lt | ||||
| { | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR | ||||
|     bool operator()(const _LhsDuration& __lhs, const _RhsDuration& __rhs) const | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     bool operator()(const _LhsDuration& __lhs, const _RhsDuration& __rhs) | ||||
|         { | ||||
|             typedef typename common_type<_LhsDuration, _RhsDuration>::type _Ct; | ||||
|             return _Ct(__lhs).count() < _Ct(__rhs).count(); | ||||
| @@ -570,14 +499,13 @@ struct __duration_lt | ||||
| template <class _LhsDuration> | ||||
| struct __duration_lt<_LhsDuration, _LhsDuration> | ||||
| { | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR | ||||
|     bool operator()(const _LhsDuration& __lhs, const _LhsDuration& __rhs) const | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     bool operator()(const _LhsDuration& __lhs, const _LhsDuration& __rhs) | ||||
|         {return __lhs.count() < __rhs.count();} | ||||
| }; | ||||
|  | ||||
| template <class _Rep1, class _Period1, class _Rep2, class _Period2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| bool | ||||
| operator< (const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs) | ||||
| { | ||||
| @@ -588,7 +516,6 @@ operator< (const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period | ||||
|  | ||||
| template <class _Rep1, class _Period1, class _Rep2, class _Period2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| bool | ||||
| operator> (const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs) | ||||
| { | ||||
| @@ -599,7 +526,6 @@ operator> (const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period | ||||
|  | ||||
| template <class _Rep1, class _Period1, class _Rep2, class _Period2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| bool | ||||
| operator<=(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs) | ||||
| { | ||||
| @@ -610,7 +536,6 @@ operator<=(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period | ||||
|  | ||||
| template <class _Rep1, class _Period1, class _Rep2, class _Period2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| bool | ||||
| operator>=(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs) | ||||
| { | ||||
| @@ -621,31 +546,30 @@ operator>=(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period | ||||
|  | ||||
| template <class _Rep1, class _Period1, class _Rep2, class _Period2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type | ||||
| operator+(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs) | ||||
| { | ||||
|     typedef typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type _Cd; | ||||
|     return _Cd(_Cd(__lhs).count() + _Cd(__rhs).count()); | ||||
|     typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type __r = __lhs; | ||||
|     __r += __rhs; | ||||
|     return __r; | ||||
| } | ||||
|  | ||||
| // Duration - | ||||
|  | ||||
| template <class _Rep1, class _Period1, class _Rep2, class _Period2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type | ||||
| operator-(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs) | ||||
| { | ||||
|     typedef typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type _Cd; | ||||
|     return _Cd(_Cd(__lhs).count() - _Cd(__rhs).count()); | ||||
|     typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type __r = __lhs; | ||||
|     __r -= __rhs; | ||||
|     return __r; | ||||
| } | ||||
|  | ||||
| // Duration * | ||||
|  | ||||
| template <class _Rep1, class _Period, class _Rep2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| typename enable_if | ||||
| < | ||||
|     is_convertible<_Rep2, typename common_type<_Rep1, _Rep2>::type>::value, | ||||
| @@ -654,13 +578,13 @@ typename enable_if | ||||
| operator*(const duration<_Rep1, _Period>& __d, const _Rep2& __s) | ||||
| { | ||||
|     typedef typename common_type<_Rep1, _Rep2>::type _Cr; | ||||
|     typedef duration<_Cr, _Period> _Cd; | ||||
|     return _Cd(_Cd(__d).count() * static_cast<_Cr>(__s)); | ||||
|     duration<_Cr, _Period> __r = __d; | ||||
|     __r *= static_cast<_Cr>(__s); | ||||
|     return __r; | ||||
| } | ||||
|  | ||||
| template <class _Rep1, class _Period, class _Rep2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| typename enable_if | ||||
| < | ||||
|     is_convertible<_Rep1, typename common_type<_Rep1, _Rep2>::type>::value, | ||||
| @@ -699,18 +623,17 @@ struct __duration_divide_result<duration<_Rep1, _Period>, _Rep2, false> | ||||
|  | ||||
| template <class _Rep1, class _Period, class _Rep2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| typename __duration_divide_result<duration<_Rep1, _Period>, _Rep2>::type | ||||
| operator/(const duration<_Rep1, _Period>& __d, const _Rep2& __s) | ||||
| { | ||||
|     typedef typename common_type<_Rep1, _Rep2>::type _Cr; | ||||
|     typedef duration<_Cr, _Period> _Cd; | ||||
|     return _Cd(_Cd(__d).count() / static_cast<_Cr>(__s)); | ||||
|     duration<_Cr, _Period> __r = __d; | ||||
|     __r /= static_cast<_Cr>(__s); | ||||
|     return __r; | ||||
| } | ||||
|  | ||||
| template <class _Rep1, class _Period1, class _Rep2, class _Period2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| typename common_type<_Rep1, _Rep2>::type | ||||
| operator/(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs) | ||||
| { | ||||
| @@ -722,24 +645,23 @@ operator/(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2 | ||||
|  | ||||
| template <class _Rep1, class _Period, class _Rep2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| typename __duration_divide_result<duration<_Rep1, _Period>, _Rep2>::type | ||||
| operator%(const duration<_Rep1, _Period>& __d, const _Rep2& __s) | ||||
| { | ||||
|     typedef typename common_type<_Rep1, _Rep2>::type _Cr; | ||||
|     typedef duration<_Cr, _Period> _Cd; | ||||
|     return _Cd(_Cd(__d).count() % static_cast<_Cr>(__s)); | ||||
|     duration<_Cr, _Period> __r = __d; | ||||
|     __r %= static_cast<_Cr>(__s); | ||||
|     return __r; | ||||
| } | ||||
|  | ||||
| template <class _Rep1, class _Period1, class _Rep2, class _Period2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type | ||||
| operator%(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs) | ||||
| { | ||||
|     typedef typename common_type<_Rep1, _Rep2>::type _Cr; | ||||
|     typedef typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type _Cd; | ||||
|     return _Cd(static_cast<_Cr>(_Cd(__lhs).count()) % static_cast<_Cr>(_Cd(__rhs).count())); | ||||
|     typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type __r = __lhs; | ||||
|     __r %= __rhs; | ||||
|     return __r; | ||||
| } | ||||
|  | ||||
| ////////////////////////////////////////////////////////// | ||||
| @@ -747,7 +669,7 @@ operator%(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2 | ||||
| ////////////////////////////////////////////////////////// | ||||
|  | ||||
| template <class _Clock, class _Duration = typename _Clock::duration> | ||||
| class _LIBCPP_TYPE_VIS_ONLY time_point | ||||
| class _LIBCPP_VISIBLE time_point | ||||
| { | ||||
|     static_assert(__is_duration<_Duration>::value, | ||||
|                   "Second template parameter of time_point must be a std::chrono::duration"); | ||||
| @@ -760,12 +682,12 @@ private: | ||||
|     duration __d_; | ||||
|  | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 time_point() : __d_(duration::zero()) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 explicit time_point(const duration& __d) : __d_(__d) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY time_point() : __d_(duration::zero()) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit time_point(const duration& __d) : __d_(__d) {} | ||||
|  | ||||
|     // conversions | ||||
|     template <class _Duration2> | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     time_point(const time_point<clock, _Duration2>& t, | ||||
|         typename enable_if | ||||
|         < | ||||
| @@ -775,24 +697,24 @@ public: | ||||
|  | ||||
|     // observer | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 duration time_since_epoch() const {return __d_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY duration time_since_epoch() const {return __d_;} | ||||
|  | ||||
|     // arithmetic | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY time_point& operator+=(const duration& __d) {__d_ += __d; return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY time_point& operator-=(const duration& __d) {__d_ -= __d; return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY time_point& operator+=(const duration& __d) {__d_ += __d;} | ||||
|     _LIBCPP_INLINE_VISIBILITY time_point& operator-=(const duration& __d) {__d_ -= __d;} | ||||
|  | ||||
|     // special values | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR time_point min() {return time_point(duration::min());} | ||||
|     _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR time_point max() {return time_point(duration::max());} | ||||
|     _LIBCPP_INLINE_VISIBILITY static time_point min() {return time_point(duration::min());} | ||||
|     _LIBCPP_INLINE_VISIBILITY static time_point max() {return time_point(duration::max());} | ||||
| }; | ||||
|  | ||||
| } // chrono | ||||
|  | ||||
| template <class _Clock, class _Duration1, class _Duration2> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY common_type<chrono::time_point<_Clock, _Duration1>, | ||||
|                                          chrono::time_point<_Clock, _Duration2> > | ||||
| struct _LIBCPP_VISIBLE common_type<chrono::time_point<_Clock, _Duration1>, | ||||
|                                    chrono::time_point<_Clock, _Duration2> > | ||||
| { | ||||
|     typedef chrono::time_point<_Clock, typename common_type<_Duration1, _Duration2>::type> type; | ||||
| }; | ||||
| @@ -800,17 +722,17 @@ struct _LIBCPP_TYPE_VIS_ONLY common_type<chrono::time_point<_Clock, _Duration1>, | ||||
| namespace chrono { | ||||
|  | ||||
| template <class _ToDuration, class _Clock, class _Duration> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| time_point<_Clock, _ToDuration> | ||||
| time_point_cast(const time_point<_Clock, _Duration>& __t) | ||||
| { | ||||
|     return time_point<_Clock, _ToDuration>(_VSTD::chrono::duration_cast<_ToDuration>(__t.time_since_epoch())); | ||||
|     return time_point<_Clock, _ToDuration>(_STD::chrono::duration_cast<_ToDuration>(__t.time_since_epoch())); | ||||
| } | ||||
|  | ||||
| // time_point == | ||||
|  | ||||
| template <class _Clock, class _Duration1, class _Duration2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator==(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, _Duration2>& __rhs) | ||||
| { | ||||
| @@ -820,7 +742,7 @@ operator==(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, | ||||
| // time_point != | ||||
|  | ||||
| template <class _Clock, class _Duration1, class _Duration2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator!=(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, _Duration2>& __rhs) | ||||
| { | ||||
| @@ -830,7 +752,7 @@ operator!=(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, | ||||
| // time_point < | ||||
|  | ||||
| template <class _Clock, class _Duration1, class _Duration2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator<(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, _Duration2>& __rhs) | ||||
| { | ||||
| @@ -840,7 +762,7 @@ operator<(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, | ||||
| // time_point > | ||||
|  | ||||
| template <class _Clock, class _Duration1, class _Duration2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator>(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, _Duration2>& __rhs) | ||||
| { | ||||
| @@ -850,7 +772,7 @@ operator>(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, | ||||
| // time_point <= | ||||
|  | ||||
| template <class _Clock, class _Duration1, class _Duration2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator<=(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, _Duration2>& __rhs) | ||||
| { | ||||
| @@ -860,7 +782,7 @@ operator<=(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, | ||||
| // time_point >= | ||||
|  | ||||
| template <class _Clock, class _Duration1, class _Duration2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator>=(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, _Duration2>& __rhs) | ||||
| { | ||||
| @@ -870,18 +792,20 @@ operator>=(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, | ||||
| // time_point operator+(time_point x, duration y); | ||||
|  | ||||
| template <class _Clock, class _Duration1, class _Rep2, class _Period2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| time_point<_Clock, typename common_type<_Duration1, duration<_Rep2, _Period2> >::type> | ||||
| operator+(const time_point<_Clock, _Duration1>& __lhs, const duration<_Rep2, _Period2>& __rhs) | ||||
| { | ||||
|     typedef time_point<_Clock, typename common_type<_Duration1, duration<_Rep2, _Period2> >::type> _Tr; | ||||
|     return _Tr (__lhs.time_since_epoch() + __rhs); | ||||
|     _Tr __r(__lhs.time_since_epoch()); | ||||
|     __r += __rhs; | ||||
|     return __r; | ||||
| } | ||||
|  | ||||
| // time_point operator+(duration x, time_point y); | ||||
|  | ||||
| template <class _Rep1, class _Period1, class _Clock, class _Duration2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| time_point<_Clock, typename common_type<duration<_Rep1, _Period1>, _Duration2>::type> | ||||
| operator+(const duration<_Rep1, _Period1>& __lhs, const time_point<_Clock, _Duration2>& __rhs) | ||||
| { | ||||
| @@ -891,7 +815,7 @@ operator+(const duration<_Rep1, _Period1>& __lhs, const time_point<_Clock, _Dura | ||||
| // time_point operator-(time_point x, duration y); | ||||
|  | ||||
| template <class _Clock, class _Duration1, class _Rep2, class _Period2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| time_point<_Clock, typename common_type<_Duration1, duration<_Rep2, _Period2> >::type> | ||||
| operator-(const time_point<_Clock, _Duration1>& __lhs, const duration<_Rep2, _Period2>& __rhs) | ||||
| { | ||||
| @@ -901,7 +825,7 @@ operator-(const time_point<_Clock, _Duration1>& __lhs, const duration<_Rep2, _Pe | ||||
| // duration operator-(time_point x, time_point y); | ||||
|  | ||||
| template <class _Clock, class _Duration1, class _Duration2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| typename common_type<_Duration1, _Duration2>::type | ||||
| operator-(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, _Duration2>& __rhs) | ||||
| { | ||||
| @@ -912,116 +836,36 @@ operator-(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, | ||||
| /////////////////////// clocks /////////////////////////// | ||||
| ////////////////////////////////////////////////////////// | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS system_clock | ||||
| class _LIBCPP_VISIBLE system_clock | ||||
| { | ||||
| public: | ||||
|     typedef microseconds                     duration; | ||||
|     typedef duration::rep                    rep; | ||||
|     typedef duration::period                 period; | ||||
|     typedef chrono::time_point<system_clock> time_point; | ||||
|     static _LIBCPP_CONSTEXPR_AFTER_CXX11 const bool is_steady = false; | ||||
|     static const bool is_steady =            false; | ||||
|  | ||||
|     static time_point now() _NOEXCEPT; | ||||
|     static time_t     to_time_t  (const time_point& __t) _NOEXCEPT; | ||||
|     static time_point from_time_t(time_t __t) _NOEXCEPT; | ||||
|     static time_point now(); | ||||
|     static time_t     to_time_t  (const time_point& __t); | ||||
|     static time_point from_time_t(time_t __t); | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS steady_clock | ||||
| class _LIBCPP_VISIBLE steady_clock | ||||
| { | ||||
| public: | ||||
|     typedef nanoseconds                                   duration; | ||||
|     typedef duration::rep                                 rep; | ||||
|     typedef duration::period                              period; | ||||
|     typedef chrono::time_point<steady_clock, duration>    time_point; | ||||
|     static _LIBCPP_CONSTEXPR_AFTER_CXX11 const bool is_steady = true; | ||||
|     static const bool is_steady =                         true; | ||||
|  | ||||
|     static time_point now() _NOEXCEPT; | ||||
|     static time_point now(); | ||||
| }; | ||||
|  | ||||
| typedef steady_clock high_resolution_clock; | ||||
|  | ||||
| } // chrono | ||||
|  | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
| // Suffixes for duration literals [time.duration.literals] | ||||
| inline namespace literals | ||||
| {  | ||||
|   inline namespace chrono_literals | ||||
|   { | ||||
|  | ||||
|     constexpr chrono::hours operator"" h(unsigned long long __h) | ||||
|     { | ||||
|         return chrono::hours(static_cast<chrono::hours::rep>(__h)); | ||||
|     } | ||||
|  | ||||
|     constexpr chrono::duration<long double, ratio<3600,1>> operator"" h(long double __h) | ||||
|     { | ||||
|         return chrono::duration<long double, ratio<3600,1>>(__h); | ||||
|     } | ||||
|  | ||||
|  | ||||
|     constexpr chrono::minutes operator"" min(unsigned long long __m) | ||||
|     { | ||||
|         return chrono::minutes(static_cast<chrono::minutes::rep>(__m)); | ||||
|     } | ||||
|  | ||||
|     constexpr chrono::duration<long double, ratio<60,1>> operator"" min(long double __m) | ||||
|     { | ||||
|         return chrono::duration<long double, ratio<60,1>> (__m); | ||||
|     } | ||||
|  | ||||
|  | ||||
|     constexpr chrono::seconds operator"" s(unsigned long long __s) | ||||
|     { | ||||
|         return chrono::seconds(static_cast<chrono::seconds::rep>(__s)); | ||||
|     } | ||||
|  | ||||
|     constexpr chrono::duration<long double> operator"" s(long double __s) | ||||
|     { | ||||
|         return chrono::duration<long double> (__s); | ||||
|     } | ||||
|  | ||||
|  | ||||
|     constexpr chrono::milliseconds operator"" ms(unsigned long long __ms) | ||||
|     { | ||||
|         return chrono::milliseconds(static_cast<chrono::milliseconds::rep>(__ms)); | ||||
|     } | ||||
|  | ||||
|     constexpr chrono::duration<long double, milli> operator"" ms(long double __ms) | ||||
|     { | ||||
|         return chrono::duration<long double, milli>(__ms); | ||||
|     } | ||||
|  | ||||
|  | ||||
|     constexpr chrono::microseconds operator"" us(unsigned long long __us) | ||||
|     { | ||||
|         return chrono::microseconds(static_cast<chrono::microseconds::rep>(__us)); | ||||
|     } | ||||
|  | ||||
|     constexpr chrono::duration<long double, micro> operator"" us(long double __us) | ||||
|     { | ||||
|         return chrono::duration<long double, micro> (__us); | ||||
|     } | ||||
|      | ||||
|  | ||||
|     constexpr chrono::nanoseconds operator"" ns(unsigned long long __ns) | ||||
|     { | ||||
|         return chrono::nanoseconds(static_cast<chrono::nanoseconds::rep>(__ns)); | ||||
|     } | ||||
|  | ||||
|     constexpr chrono::duration<long double, nano> operator"" ns(long double __ns) | ||||
|     { | ||||
|         return chrono::duration<long double, nano> (__ns); | ||||
|     } | ||||
|  | ||||
| }} | ||||
|  | ||||
| namespace chrono { // hoist the literals into namespace std::chrono | ||||
|    using namespace literals::chrono_literals; | ||||
| } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
| #endif  // _LIBCPP_CHRONO | ||||
|   | ||||
| @@ -239,9 +239,7 @@ uintmax_t wcstoumax(const wchar_t* restrict nptr, wchar_t** restrict endptr, int | ||||
| #include <cstdint> | ||||
| #include <inttypes.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
| @@ -18,8 +18,6 @@ | ||||
|  | ||||
| #include <__config> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| #endif  // _LIBCPP_CISO646 | ||||
|   | ||||
| @@ -41,8 +41,6 @@ Macros: | ||||
| #include <__config> | ||||
| #include <limits.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| #endif  // _LIBCPP_CLIMITS | ||||
|   | ||||
| @@ -38,9 +38,7 @@ lconv* localeconv(); | ||||
| #include <__config> | ||||
| #include <locale.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
							
								
								
									
										1158
									
								
								include/cmath
									
									
									
									
									
								
							
							
						
						
									
										1158
									
								
								include/cmath
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -29,8 +29,7 @@ template <class Elem, unsigned long Maxcode = 0x10ffff, | ||||
| class codecvt_utf8 | ||||
|     : public codecvt<Elem, char, mbstate_t> | ||||
| { | ||||
|     explicit codecvt_utf8(size_t refs = 0); | ||||
|     ~codecvt_utf8(); | ||||
|     // unspecified | ||||
| }; | ||||
|  | ||||
| template <class Elem, unsigned long Maxcode = 0x10ffff, | ||||
| @@ -38,8 +37,7 @@ template <class Elem, unsigned long Maxcode = 0x10ffff, | ||||
| class codecvt_utf16 | ||||
|     : public codecvt<Elem, char, mbstate_t> | ||||
| { | ||||
|     explicit codecvt_utf16(size_t refs = 0); | ||||
|     ~codecvt_utf16(); | ||||
|     // unspecified | ||||
| }; | ||||
|  | ||||
| template <class Elem, unsigned long Maxcode = 0x10ffff, | ||||
| @@ -47,8 +45,7 @@ template <class Elem, unsigned long Maxcode = 0x10ffff, | ||||
| class codecvt_utf8_utf16 | ||||
|     : public codecvt<Elem, char, mbstate_t> | ||||
| { | ||||
|     explicit codecvt_utf8_utf16(size_t refs = 0); | ||||
|     ~codecvt_utf8_utf16(); | ||||
|     // unspecified | ||||
| }; | ||||
|  | ||||
| }  // std | ||||
| @@ -58,9 +55,7 @@ class codecvt_utf8_utf16 | ||||
| #include <__config> | ||||
| #include <__locale> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| @@ -76,7 +71,7 @@ enum codecvt_mode | ||||
| template <class _Elem> class __codecvt_utf8; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS __codecvt_utf8<wchar_t> | ||||
| class __codecvt_utf8<wchar_t> | ||||
|     : public codecvt<wchar_t, char, mbstate_t> | ||||
| { | ||||
|     unsigned long _Maxcode_; | ||||
| @@ -111,7 +106,7 @@ protected: | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS __codecvt_utf8<char16_t> | ||||
| class __codecvt_utf8<char16_t> | ||||
|     : public codecvt<char16_t, char, mbstate_t> | ||||
| { | ||||
|     unsigned long _Maxcode_; | ||||
| @@ -146,7 +141,7 @@ protected: | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS __codecvt_utf8<char32_t> | ||||
| class __codecvt_utf8<char32_t> | ||||
|     : public codecvt<char32_t, char, mbstate_t> | ||||
| { | ||||
|     unsigned long _Maxcode_; | ||||
| @@ -182,7 +177,7 @@ protected: | ||||
|  | ||||
| template <class _Elem, unsigned long _Maxcode = 0x10ffff, | ||||
|           codecvt_mode _Mode = (codecvt_mode)0> | ||||
| class _LIBCPP_TYPE_VIS_ONLY codecvt_utf8 | ||||
| class _LIBCPP_VISIBLE codecvt_utf8 | ||||
|     : public __codecvt_utf8<_Elem> | ||||
| { | ||||
| public: | ||||
| @@ -199,7 +194,7 @@ public: | ||||
| template <class _Elem, bool _LittleEndian> class __codecvt_utf16; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS __codecvt_utf16<wchar_t, false> | ||||
| class __codecvt_utf16<wchar_t, false> | ||||
|     : public codecvt<wchar_t, char, mbstate_t> | ||||
| { | ||||
|     unsigned long _Maxcode_; | ||||
| @@ -234,7 +229,7 @@ protected: | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS __codecvt_utf16<wchar_t, true> | ||||
| class __codecvt_utf16<wchar_t, true> | ||||
|     : public codecvt<wchar_t, char, mbstate_t> | ||||
| { | ||||
|     unsigned long _Maxcode_; | ||||
| @@ -269,7 +264,7 @@ protected: | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS __codecvt_utf16<char16_t, false> | ||||
| class __codecvt_utf16<char16_t, false> | ||||
|     : public codecvt<char16_t, char, mbstate_t> | ||||
| { | ||||
|     unsigned long _Maxcode_; | ||||
| @@ -304,7 +299,7 @@ protected: | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS __codecvt_utf16<char16_t, true> | ||||
| class __codecvt_utf16<char16_t, true> | ||||
|     : public codecvt<char16_t, char, mbstate_t> | ||||
| { | ||||
|     unsigned long _Maxcode_; | ||||
| @@ -339,7 +334,7 @@ protected: | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS __codecvt_utf16<char32_t, false> | ||||
| class __codecvt_utf16<char32_t, false> | ||||
|     : public codecvt<char32_t, char, mbstate_t> | ||||
| { | ||||
|     unsigned long _Maxcode_; | ||||
| @@ -374,7 +369,7 @@ protected: | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS __codecvt_utf16<char32_t, true> | ||||
| class __codecvt_utf16<char32_t, true> | ||||
|     : public codecvt<char32_t, char, mbstate_t> | ||||
| { | ||||
|     unsigned long _Maxcode_; | ||||
| @@ -410,7 +405,7 @@ protected: | ||||
|  | ||||
| template <class _Elem, unsigned long _Maxcode = 0x10ffff, | ||||
|           codecvt_mode _Mode = (codecvt_mode)0> | ||||
| class _LIBCPP_TYPE_VIS_ONLY codecvt_utf16 | ||||
| class _LIBCPP_VISIBLE codecvt_utf16 | ||||
|     : public __codecvt_utf16<_Elem, _Mode & little_endian> | ||||
| { | ||||
| public: | ||||
| @@ -427,7 +422,7 @@ public: | ||||
| template <class _Elem> class __codecvt_utf8_utf16; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS __codecvt_utf8_utf16<wchar_t> | ||||
| class __codecvt_utf8_utf16<wchar_t> | ||||
|     : public codecvt<wchar_t, char, mbstate_t> | ||||
| { | ||||
|     unsigned long _Maxcode_; | ||||
| @@ -462,7 +457,7 @@ protected: | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS __codecvt_utf8_utf16<char32_t> | ||||
| class __codecvt_utf8_utf16<char32_t> | ||||
|     : public codecvt<char32_t, char, mbstate_t> | ||||
| { | ||||
|     unsigned long _Maxcode_; | ||||
| @@ -497,7 +492,7 @@ protected: | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| class _LIBCPP_TYPE_VIS __codecvt_utf8_utf16<char16_t> | ||||
| class __codecvt_utf8_utf16<char16_t> | ||||
|     : public codecvt<char16_t, char, mbstate_t> | ||||
| { | ||||
|     unsigned long _Maxcode_; | ||||
| @@ -533,7 +528,7 @@ protected: | ||||
|  | ||||
| template <class _Elem, unsigned long _Maxcode = 0x10ffff, | ||||
|           codecvt_mode _Mode = (codecvt_mode)0> | ||||
| class _LIBCPP_TYPE_VIS_ONLY codecvt_utf8_utf16 | ||||
| class _LIBCPP_VISIBLE codecvt_utf8_utf16 | ||||
|     : public __codecvt_utf8_utf16<_Elem> | ||||
| { | ||||
| public: | ||||
|   | ||||
							
								
								
									
										223
									
								
								include/complex
									
									
									
									
									
								
							
							
						
						
									
										223
									
								
								include/complex
									
									
									
									
									
								
							| @@ -23,12 +23,12 @@ class complex | ||||
| public: | ||||
|     typedef T value_type; | ||||
|  | ||||
|     complex(const T& re = T(), const T& im = T()); // constexpr in C++14 | ||||
|     complex(const complex&);  // constexpr in C++14 | ||||
|     template<class X> complex(const complex<X>&);  // constexpr in C++14 | ||||
|     complex(const T& re = T(), const T& im = T()); | ||||
|     complex(const complex&); | ||||
|     template<class X> complex(const complex<X>&); | ||||
|  | ||||
|     T real() const; // constexpr in C++14 | ||||
|     T imag() const; // constexpr in C++14 | ||||
|     T real() const; | ||||
|     T imag() const; | ||||
|  | ||||
|     void real(T); | ||||
|     void imag(T); | ||||
| @@ -149,12 +149,12 @@ template<class T> complex<T> operator/(const complex<T>&, const T&); | ||||
| template<class T> complex<T> operator/(const T&, const complex<T>&); | ||||
| template<class T> complex<T> operator+(const complex<T>&); | ||||
| template<class T> complex<T> operator-(const complex<T>&); | ||||
| template<class T> bool operator==(const complex<T>&, const complex<T>&); // constexpr in C++14 | ||||
| template<class T> bool operator==(const complex<T>&, const T&); // constexpr in C++14 | ||||
| template<class T> bool operator==(const T&, const complex<T>&); // constexpr in C++14 | ||||
| template<class T> bool operator!=(const complex<T>&, const complex<T>&); // constexpr in C++14 | ||||
| template<class T> bool operator!=(const complex<T>&, const T&); // constexpr in C++14 | ||||
| template<class T> bool operator!=(const T&, const complex<T>&); // constexpr in C++14 | ||||
| template<class T> bool operator==(const complex<T>&, const complex<T>&); | ||||
| template<class T> bool operator==(const complex<T>&, const T&); | ||||
| template<class T> bool operator==(const T&, const complex<T>&); | ||||
| template<class T> bool operator!=(const complex<T>&, const complex<T>&); | ||||
| template<class T> bool operator!=(const complex<T>&, const T&); | ||||
| template<class T> bool operator!=(const T&, const complex<T>&); | ||||
|  | ||||
| template<class T, class charT, class traits> | ||||
|   basic_istream<charT, traits>& | ||||
| @@ -165,17 +165,17 @@ template<class T, class charT, class traits> | ||||
|  | ||||
| // 26.3.7 values: | ||||
|  | ||||
| template<class T>              T real(const complex<T>&); // constexpr in C++14 | ||||
|                      long double real(long double);       // constexpr in C++14 | ||||
|                           double real(double);            // constexpr in C++14 | ||||
| template<Integral T>      double real(T);                 // constexpr in C++14 | ||||
|                           float  real(float);             // constexpr in C++14 | ||||
| template<class T>              T real(const complex<T>&); | ||||
|                      long double real(long double); | ||||
|                           double real(double); | ||||
| template<Integral T>      double real(T); | ||||
|                           float  real(float); | ||||
|  | ||||
| template<class T>              T imag(const complex<T>&); // constexpr in C++14 | ||||
|                      long double imag(long double);       // constexpr in C++14 | ||||
|                           double imag(double);            // constexpr in C++14 | ||||
| template<Integral T>      double imag(T);                 // constexpr in C++14 | ||||
|                           float  imag(float);             // constexpr in C++14 | ||||
| template<class T>              T imag(const complex<T>&); | ||||
|                      long double imag(long double); | ||||
|                           double imag(double); | ||||
| template<Integral T>      double imag(T); | ||||
|                           float  imag(float); | ||||
|  | ||||
| template<class T> T abs(const complex<T>&); | ||||
|  | ||||
| @@ -249,19 +249,17 @@ template<class T, class charT, class traits> | ||||
|     #include <cassert> | ||||
| #endif | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template<class _Tp> class _LIBCPP_TYPE_VIS_ONLY complex; | ||||
| template<class _Tp> class _LIBCPP_VISIBLE complex; | ||||
|  | ||||
| template<class _Tp> complex<_Tp> operator*(const complex<_Tp>& __z, const complex<_Tp>& __w); | ||||
| template<class _Tp> complex<_Tp> operator/(const complex<_Tp>& __x, const complex<_Tp>& __y); | ||||
|  | ||||
| template<class _Tp> | ||||
| class _LIBCPP_TYPE_VIS_ONLY complex | ||||
| class _LIBCPP_VISIBLE complex | ||||
| { | ||||
| public: | ||||
|     typedef _Tp value_type; | ||||
| @@ -269,21 +267,20 @@ private: | ||||
|     value_type __re_; | ||||
|     value_type __im_; | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     complex(const value_type& __re = value_type(), const value_type& __im = value_type()) | ||||
|         : __re_(__re), __im_(__im) {} | ||||
|     template<class _Xp> _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
|     template<class _Xp> _LIBCPP_INLINE_VISIBILITY | ||||
|     complex(const complex<_Xp>& __c) | ||||
|         : __re_(__c.real()), __im_(__c.imag()) {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 value_type real() const {return __re_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 value_type imag() const {return __im_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY value_type real() const {return __re_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY value_type imag() const {return __im_;} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY void real(value_type __re) {__re_ = __re;} | ||||
|     _LIBCPP_INLINE_VISIBILITY void imag(value_type __im) {__im_ = __im;} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator= (const value_type& __re) | ||||
|         {__re_ = __re; __im_ = value_type(); return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator= (const value_type& __re) {__re_ = __re; return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator+=(const value_type& __re) {__re_ += __re; return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator-=(const value_type& __re) {__re_ -= __re; return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator*=(const value_type& __re) {__re_ *= __re; __im_ *= __re; return *this;} | ||||
| @@ -309,40 +306,39 @@ public: | ||||
|         } | ||||
|     template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator*=(const complex<_Xp>& __c) | ||||
|         { | ||||
|             *this = *this * complex(__c.real(), __c.imag()); | ||||
|             *this = *this * __c; | ||||
|             return *this; | ||||
|         } | ||||
|     template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator/=(const complex<_Xp>& __c) | ||||
|         { | ||||
|             *this = *this / complex(__c.real(), __c.imag()); | ||||
|             *this = *this / __c; | ||||
|             return *this; | ||||
|         } | ||||
| }; | ||||
|  | ||||
| template<> class _LIBCPP_TYPE_VIS_ONLY complex<double>; | ||||
| template<> class _LIBCPP_TYPE_VIS_ONLY complex<long double>; | ||||
| template<> class _LIBCPP_VISIBLE complex<double>; | ||||
| template<> class _LIBCPP_VISIBLE complex<long double>; | ||||
|  | ||||
| template<> | ||||
| class _LIBCPP_TYPE_VIS_ONLY complex<float> | ||||
| class _LIBCPP_VISIBLE complex<float> | ||||
| { | ||||
|     float __re_; | ||||
|     float __im_; | ||||
| public: | ||||
|     typedef float value_type; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR complex(float __re = 0.0f, float __im = 0.0f) | ||||
|     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY complex(float __re = 0.0f, float __im = 0.0f) | ||||
|         : __re_(__re), __im_(__im) {} | ||||
|     explicit _LIBCPP_CONSTEXPR complex(const complex<double>& __c); | ||||
|     explicit _LIBCPP_CONSTEXPR complex(const complex<long double>& __c); | ||||
|     explicit /*constexpr*/ complex(const complex<double>& __c); | ||||
|     explicit /*constexpr*/ complex(const complex<long double>& __c); | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR float real() const {return __re_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR float imag() const {return __im_;} | ||||
|     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY float real() const {return __re_;} | ||||
|     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY float imag() const {return __im_;} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY void real(value_type __re) {__re_ = __re;} | ||||
|     _LIBCPP_INLINE_VISIBILITY void imag(value_type __im) {__im_ = __im;} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator= (float __re) | ||||
|         {__re_ = __re; __im_ = value_type(); return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator= (float __re) {__re_ = __re; return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator+=(float __re) {__re_ += __re; return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator-=(float __re) {__re_ -= __re; return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator*=(float __re) {__re_ *= __re; __im_ *= __re; return *this;} | ||||
| @@ -368,37 +364,36 @@ public: | ||||
|         } | ||||
|     template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator*=(const complex<_Xp>& __c) | ||||
|         { | ||||
|             *this = *this * complex(__c.real(), __c.imag()); | ||||
|             *this = *this * __c; | ||||
|             return *this; | ||||
|         } | ||||
|     template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator/=(const complex<_Xp>& __c) | ||||
|         { | ||||
|             *this = *this / complex(__c.real(), __c.imag()); | ||||
|             *this = *this / __c; | ||||
|             return *this; | ||||
|         } | ||||
| }; | ||||
|  | ||||
| template<> | ||||
| class _LIBCPP_TYPE_VIS_ONLY complex<double> | ||||
| class _LIBCPP_VISIBLE complex<double> | ||||
| { | ||||
|     double __re_; | ||||
|     double __im_; | ||||
| public: | ||||
|     typedef double value_type; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR complex(double __re = 0.0, double __im = 0.0) | ||||
|     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY complex(double __re = 0.0, double __im = 0.0) | ||||
|         : __re_(__re), __im_(__im) {} | ||||
|     _LIBCPP_CONSTEXPR complex(const complex<float>& __c); | ||||
|     explicit _LIBCPP_CONSTEXPR complex(const complex<long double>& __c); | ||||
|     /*constexpr*/ complex(const complex<float>& __c); | ||||
|     explicit /*constexpr*/ complex(const complex<long double>& __c); | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR double real() const {return __re_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR double imag() const {return __im_;} | ||||
|     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY double real() const {return __re_;} | ||||
|     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY double imag() const {return __im_;} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY void real(value_type __re) {__re_ = __re;} | ||||
|     _LIBCPP_INLINE_VISIBILITY void imag(value_type __im) {__im_ = __im;} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator= (double __re) | ||||
|         {__re_ = __re; __im_ = value_type(); return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator= (double __re) {__re_ = __re; return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator+=(double __re) {__re_ += __re; return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator-=(double __re) {__re_ -= __re; return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator*=(double __re) {__re_ *= __re; __im_ *= __re; return *this;} | ||||
| @@ -424,37 +419,36 @@ public: | ||||
|         } | ||||
|     template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator*=(const complex<_Xp>& __c) | ||||
|         { | ||||
|             *this = *this * complex(__c.real(), __c.imag()); | ||||
|             *this = *this * __c; | ||||
|             return *this; | ||||
|         } | ||||
|     template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator/=(const complex<_Xp>& __c) | ||||
|         { | ||||
|             *this = *this / complex(__c.real(), __c.imag()); | ||||
|             *this = *this / __c; | ||||
|             return *this; | ||||
|         } | ||||
| }; | ||||
|  | ||||
| template<> | ||||
| class _LIBCPP_TYPE_VIS_ONLY complex<long double> | ||||
| class _LIBCPP_VISIBLE complex<long double> | ||||
| { | ||||
|     long double __re_; | ||||
|     long double __im_; | ||||
| public: | ||||
|     typedef long double value_type; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR complex(long double __re = 0.0L, long double __im = 0.0L) | ||||
|     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY complex(long double __re = 0.0L, long double __im = 0.0L) | ||||
|         : __re_(__re), __im_(__im) {} | ||||
|     _LIBCPP_CONSTEXPR complex(const complex<float>& __c); | ||||
|     _LIBCPP_CONSTEXPR complex(const complex<double>& __c); | ||||
|     /*constexpr*/ complex(const complex<float>& __c); | ||||
|     /*constexpr*/ complex(const complex<double>& __c); | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR long double real() const {return __re_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR long double imag() const {return __im_;} | ||||
|     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY long double real() const {return __re_;} | ||||
|     /*constexpr*/ _LIBCPP_INLINE_VISIBILITY long double imag() const {return __im_;} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY void real(value_type __re) {__re_ = __re;} | ||||
|     _LIBCPP_INLINE_VISIBILITY void imag(value_type __im) {__im_ = __im;} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator= (long double __re) | ||||
|         {__re_ = __re; __im_ = value_type(); return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator= (long double __re) {__re_ = __re; return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator+=(long double __re) {__re_ += __re; return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator-=(long double __re) {__re_ -= __re; return *this;} | ||||
|     _LIBCPP_INLINE_VISIBILITY complex& operator*=(long double __re) {__re_ *= __re; __im_ *= __re; return *this;} | ||||
| @@ -480,43 +474,43 @@ public: | ||||
|         } | ||||
|     template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator*=(const complex<_Xp>& __c) | ||||
|         { | ||||
|             *this = *this * complex(__c.real(), __c.imag()); | ||||
|             *this = *this * __c; | ||||
|             return *this; | ||||
|         } | ||||
|     template<class _Xp> _LIBCPP_INLINE_VISIBILITY complex& operator/=(const complex<_Xp>& __c) | ||||
|         { | ||||
|             *this = *this / complex(__c.real(), __c.imag()); | ||||
|             *this = *this / __c; | ||||
|             return *this; | ||||
|         } | ||||
| }; | ||||
|  | ||||
| //constexpr | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| complex<float>::complex(const complex<double>& __c) | ||||
|     : __re_(__c.real()), __im_(__c.imag()) {} | ||||
|  | ||||
| //constexpr | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| complex<float>::complex(const complex<long double>& __c) | ||||
|     : __re_(__c.real()), __im_(__c.imag()) {} | ||||
|  | ||||
| //constexpr | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| complex<double>::complex(const complex<float>& __c) | ||||
|     : __re_(__c.real()), __im_(__c.imag()) {} | ||||
|  | ||||
| //constexpr | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| complex<double>::complex(const complex<long double>& __c) | ||||
|     : __re_(__c.real()), __im_(__c.imag()) {} | ||||
|  | ||||
| //constexpr | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| complex<long double>::complex(const complex<float>& __c) | ||||
|     : __re_(__c.real()), __im_(__c.imag()) {} | ||||
|  | ||||
| //constexpr | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR | ||||
| complex<long double>::complex(const complex<double>& __c) | ||||
|     : __re_(__c.real()), __im_(__c.imag()) {} | ||||
|  | ||||
| @@ -740,7 +734,7 @@ operator-(const complex<_Tp>& __x) | ||||
| } | ||||
|  | ||||
| template<class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator==(const complex<_Tp>& __x, const complex<_Tp>& __y) | ||||
| { | ||||
| @@ -748,7 +742,7 @@ operator==(const complex<_Tp>& __x, const complex<_Tp>& __y) | ||||
| } | ||||
|  | ||||
| template<class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator==(const complex<_Tp>& __x, const _Tp& __y) | ||||
| { | ||||
| @@ -756,7 +750,7 @@ operator==(const complex<_Tp>& __x, const _Tp& __y) | ||||
| } | ||||
|  | ||||
| template<class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator==(const _Tp& __x, const complex<_Tp>& __y) | ||||
| { | ||||
| @@ -764,7 +758,7 @@ operator==(const _Tp& __x, const complex<_Tp>& __y) | ||||
| } | ||||
|  | ||||
| template<class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator!=(const complex<_Tp>& __x, const complex<_Tp>& __y) | ||||
| { | ||||
| @@ -772,7 +766,7 @@ operator!=(const complex<_Tp>& __x, const complex<_Tp>& __y) | ||||
| } | ||||
|  | ||||
| template<class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator!=(const complex<_Tp>& __x, const _Tp& __y) | ||||
| { | ||||
| @@ -780,7 +774,7 @@ operator!=(const complex<_Tp>& __x, const _Tp& __y) | ||||
| } | ||||
|  | ||||
| template<class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator!=(const _Tp& __x, const complex<_Tp>& __y) | ||||
| { | ||||
| @@ -792,21 +786,21 @@ operator!=(const _Tp& __x, const complex<_Tp>& __y) | ||||
| // real | ||||
|  | ||||
| template<class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _Tp | ||||
| real(const complex<_Tp>& __c) | ||||
| { | ||||
|     return __c.real(); | ||||
| } | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| long double | ||||
| real(long double __re) | ||||
| { | ||||
|     return __re; | ||||
| } | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| double | ||||
| real(double __re) | ||||
| { | ||||
| @@ -814,7 +808,7 @@ real(double __re) | ||||
| } | ||||
|  | ||||
| template<class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| typename enable_if | ||||
| < | ||||
|     is_integral<_Tp>::value, | ||||
| @@ -825,7 +819,7 @@ real(_Tp  __re) | ||||
|     return __re; | ||||
| } | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| float | ||||
| real(float  __re) | ||||
| { | ||||
| @@ -835,21 +829,21 @@ real(float  __re) | ||||
| // imag | ||||
|  | ||||
| template<class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _Tp | ||||
| imag(const complex<_Tp>& __c) | ||||
| { | ||||
|     return __c.imag(); | ||||
| } | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| long double | ||||
| imag(long double __re) | ||||
| { | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| double | ||||
| imag(double __re) | ||||
| { | ||||
| @@ -857,7 +851,7 @@ imag(double __re) | ||||
| } | ||||
|  | ||||
| template<class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| typename enable_if | ||||
| < | ||||
|     is_integral<_Tp>::value, | ||||
| @@ -868,7 +862,7 @@ imag(_Tp  __re) | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| float | ||||
| imag(float  __re) | ||||
| { | ||||
| @@ -1179,7 +1173,7 @@ complex<typename __promote<_Tp, _Up>::type> | ||||
| pow(const complex<_Tp>& __x, const complex<_Up>& __y) | ||||
| { | ||||
|     typedef complex<typename __promote<_Tp, _Up>::type> result_type; | ||||
|     return _VSTD::pow(result_type(__x), result_type(__y)); | ||||
|     return _STD::pow(result_type(__x), result_type(__y)); | ||||
| } | ||||
|  | ||||
| template<class _Tp, class _Up> | ||||
| @@ -1192,7 +1186,7 @@ typename enable_if | ||||
| pow(const complex<_Tp>& __x, const _Up& __y) | ||||
| { | ||||
|     typedef complex<typename __promote<_Tp, _Up>::type> result_type; | ||||
|     return _VSTD::pow(result_type(__x), result_type(__y)); | ||||
|     return _STD::pow(result_type(__x), result_type(__y)); | ||||
| } | ||||
|  | ||||
| template<class _Tp, class _Up> | ||||
| @@ -1205,7 +1199,7 @@ typename enable_if | ||||
| pow(const _Tp& __x, const complex<_Up>& __y) | ||||
| { | ||||
|     typedef complex<typename __promote<_Tp, _Up>::type> result_type; | ||||
|     return _VSTD::pow(result_type(__x), result_type(__y)); | ||||
|     return _STD::pow(result_type(__x), result_type(__y)); | ||||
| } | ||||
|  | ||||
| // asinh | ||||
| @@ -1249,12 +1243,10 @@ acosh(const complex<_Tp>& __x) | ||||
|         if (isnan(__x.imag())) | ||||
|             return complex<_Tp>(abs(__x.real()), __x.imag()); | ||||
|         if (isinf(__x.imag())) | ||||
|         { | ||||
|             if (__x.real() > 0) | ||||
|                 return complex<_Tp>(__x.real(), copysign(__pi * _Tp(0.25), __x.imag())); | ||||
|             else | ||||
|                 return complex<_Tp>(-__x.real(), copysign(__pi * _Tp(0.75), __x.imag())); | ||||
|         } | ||||
|         if (__x.real() < 0) | ||||
|             return complex<_Tp>(-__x.real(), copysign(__pi, __x.imag())); | ||||
|         return complex<_Tp>(__x.real(), copysign(_Tp(0), __x.imag())); | ||||
| @@ -1353,11 +1345,7 @@ tanh(const complex<_Tp>& __x) | ||||
|     _Tp __2r(_Tp(2) * __x.real()); | ||||
|     _Tp __2i(_Tp(2) * __x.imag()); | ||||
|     _Tp __d(cosh(__2r) + cos(__2i)); | ||||
|     _Tp __2rsh(sinh(__2r)); | ||||
|     if (isinf(__2rsh) && isinf(__d)) | ||||
|         return complex<_Tp>(__2rsh > _Tp(0) ? _Tp(1) : _Tp(-1), | ||||
|                             __2i > _Tp(0) ? _Tp(0) : _Tp(-0.)); | ||||
|     return  complex<_Tp>(__2rsh/__d, sin(__2i)/__d); | ||||
|     return  complex<_Tp>(sinh(__2r)/__d, sin(__2i)/__d); | ||||
| } | ||||
|  | ||||
| // asin | ||||
| @@ -1521,47 +1509,6 @@ operator<<(basic_ostream<_CharT, _Traits>& __os, const complex<_Tp>& __x) | ||||
|     return __os << __s.str(); | ||||
| } | ||||
|  | ||||
| #if _LIBCPP_STD_VER > 11  | ||||
| // Literal suffix for complex number literals [complex.literals] | ||||
| inline namespace literals | ||||
| {  | ||||
|   inline namespace complex_literals | ||||
|   { | ||||
|     constexpr complex<long double> operator""il(long double __im) | ||||
|     { | ||||
|         return { 0.0l, __im }; | ||||
|     } | ||||
|  | ||||
|     constexpr complex<long double> operator""il(unsigned long long __im) | ||||
|     { | ||||
|         return { 0.0l, static_cast<long double>(__im) }; | ||||
|     } | ||||
|  | ||||
|  | ||||
|     constexpr complex<double> operator""i(long double __im) | ||||
|     { | ||||
|         return { 0.0, static_cast<double>(__im) }; | ||||
|     } | ||||
|  | ||||
|     constexpr complex<double> operator""i(unsigned long long __im) | ||||
|     { | ||||
|         return { 0.0, static_cast<double>(__im) }; | ||||
|     } | ||||
|  | ||||
|  | ||||
|     constexpr complex<float> operator""if(long double __im) | ||||
|     { | ||||
|         return { 0.0f, static_cast<float>(__im) }; | ||||
|     } | ||||
|  | ||||
|     constexpr complex<float> operator""if(unsigned long long __im) | ||||
|     { | ||||
|         return { 0.0f, static_cast<float>(__im) }; | ||||
|     } | ||||
|   } | ||||
| } | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
| #endif  // _LIBCPP_COMPLEX | ||||
|   | ||||
| @@ -28,8 +28,6 @@ | ||||
|  | ||||
| #endif  // __cplusplus | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| #endif  // _LIBCPP_COMPLEX_H | ||||
|   | ||||
| @@ -28,8 +28,8 @@ public: | ||||
|     condition_variable(const condition_variable&) = delete; | ||||
|     condition_variable& operator=(const condition_variable&) = delete; | ||||
|  | ||||
|     void notify_one() noexcept; | ||||
|     void notify_all() noexcept; | ||||
|     void notify_one(); | ||||
|     void notify_all(); | ||||
|  | ||||
|     void wait(unique_lock<mutex>& lock); | ||||
|     template <class Predicate> | ||||
| @@ -72,8 +72,8 @@ public: | ||||
|     condition_variable_any(const condition_variable_any&) = delete; | ||||
|     condition_variable_any& operator=(const condition_variable_any&) = delete; | ||||
|  | ||||
|     void notify_one() noexcept; | ||||
|     void notify_all() noexcept; | ||||
|     void notify_one(); | ||||
|     void notify_all(); | ||||
|  | ||||
|     template <class Lock> | ||||
|         void wait(Lock& lock); | ||||
| @@ -111,21 +111,19 @@ public: | ||||
| #include <__mutex_base> | ||||
| #include <memory> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS condition_variable_any | ||||
| class _LIBCPP_VISIBLE condition_variable_any | ||||
| { | ||||
|     condition_variable __cv_; | ||||
|     shared_ptr<mutex>  __mut_; | ||||
| public: | ||||
|     condition_variable_any(); | ||||
|  | ||||
|     void notify_one() _NOEXCEPT; | ||||
|     void notify_all() _NOEXCEPT; | ||||
|     void notify_one(); | ||||
|     void notify_all(); | ||||
|  | ||||
|     template <class _Lock> | ||||
|         void wait(_Lock& __lock); | ||||
| @@ -161,17 +159,17 @@ condition_variable_any::condition_variable_any() | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| condition_variable_any::notify_one() _NOEXCEPT | ||||
| condition_variable_any::notify_one() | ||||
| { | ||||
|     {lock_guard<mutex> __lx(*__mut_);} | ||||
|     {lock_guard<mutex> _(*__mut_);} | ||||
|     __cv_.notify_one(); | ||||
| } | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| condition_variable_any::notify_all() _NOEXCEPT | ||||
| condition_variable_any::notify_all() | ||||
| { | ||||
|     {lock_guard<mutex> __lx(*__mut_);} | ||||
|     {lock_guard<mutex> _(*__mut_);} | ||||
|     __cv_.notify_all(); | ||||
| } | ||||
|  | ||||
| @@ -188,8 +186,8 @@ condition_variable_any::wait(_Lock& __lock) | ||||
|     shared_ptr<mutex> __mut = __mut_; | ||||
|     unique_lock<mutex> __lk(*__mut); | ||||
|     __lock.unlock(); | ||||
|     unique_ptr<_Lock, __lock_external> __lxx(&__lock); | ||||
|     lock_guard<unique_lock<mutex> > __lx(__lk, adopt_lock); | ||||
|     unique_ptr<_Lock, __lock_external> __(&__lock); | ||||
|     lock_guard<unique_lock<mutex> > _(__lk, adopt_lock); | ||||
|     __cv_.wait(__lk); | ||||
| }  // __mut_.unlock(), __lock.lock() | ||||
|  | ||||
| @@ -210,8 +208,8 @@ condition_variable_any::wait_until(_Lock& __lock, | ||||
|     shared_ptr<mutex> __mut = __mut_; | ||||
|     unique_lock<mutex> __lk(*__mut); | ||||
|     __lock.unlock(); | ||||
|     unique_ptr<_Lock, __lock_external> __lxx(&__lock); | ||||
|     lock_guard<unique_lock<mutex> > __lx(__lk, adopt_lock); | ||||
|     unique_ptr<_Lock, __lock_external> __(&__lock); | ||||
|     lock_guard<unique_lock<mutex> > _(__lk, adopt_lock); | ||||
|     return __cv_.wait_until(__lk, __t); | ||||
| }  // __mut_.unlock(), __lock.lock() | ||||
|  | ||||
| @@ -245,10 +243,10 @@ condition_variable_any::wait_for(_Lock& __lock, | ||||
|                                  _Predicate __pred) | ||||
| { | ||||
|     return wait_until(__lock, chrono::steady_clock::now() + __d, | ||||
|                       _VSTD::move(__pred)); | ||||
|                       _STD::move(__pred)); | ||||
| } | ||||
|  | ||||
| _LIBCPP_FUNC_VIS | ||||
| _LIBCPP_VISIBLE | ||||
| void notify_all_at_thread_exit(condition_variable& cond, unique_lock<mutex> lk); | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|   | ||||
| @@ -34,9 +34,7 @@ void longjmp(jmp_buf env, int val); | ||||
| #include <__config> | ||||
| #include <setjmp.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| #ifndef setjmp | ||||
| #define setjmp(env) setjmp(env) | ||||
|   | ||||
| @@ -43,9 +43,7 @@ int raise(int sig); | ||||
| #include <__config> | ||||
| #include <signal.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
| @@ -35,9 +35,7 @@ Types: | ||||
| #include <__config> | ||||
| #include <stdarg.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
| @@ -22,9 +22,7 @@ Macros: | ||||
|  | ||||
| #include <__config> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| #undef __bool_true_false_are_defined | ||||
| #define __bool_true_false_are_defined 1 | ||||
|   | ||||
| @@ -43,9 +43,7 @@ Types: | ||||
|  | ||||
| #include <stddef.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| @@ -56,48 +54,42 @@ typedef long double max_align_t; | ||||
|  | ||||
| #ifdef _LIBCPP_HAS_NO_NULLPTR | ||||
|  | ||||
| struct _LIBCPP_TYPE_VIS_ONLY nullptr_t | ||||
| struct _LIBCPP_VISIBLE nullptr_t | ||||
| { | ||||
|     void* __lx; | ||||
|     void* _; | ||||
|  | ||||
|     struct __nat {int __for_bool_;}; | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE _LIBCPP_CONSTEXPR nullptr_t() : __lx(0) {} | ||||
|     _LIBCPP_ALWAYS_INLINE _LIBCPP_CONSTEXPR nullptr_t(int __nat::*) : __lx(0) {} | ||||
|     _LIBCPP_ALWAYS_INLINE nullptr_t(int __nat::*) {} | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE _LIBCPP_CONSTEXPR operator int __nat::*() const {return 0;} | ||||
|     _LIBCPP_ALWAYS_INLINE operator int __nat::*() const {return 0;} | ||||
|  | ||||
|     template <class _Tp> | ||||
|         _LIBCPP_ALWAYS_INLINE _LIBCPP_CONSTEXPR | ||||
|         _LIBCPP_ALWAYS_INLINE | ||||
|         operator _Tp* () const {return 0;} | ||||
|  | ||||
|     template <class _Tp, class _Up> | ||||
|         _LIBCPP_ALWAYS_INLINE | ||||
|         operator _Tp _Up::* () const {return 0;} | ||||
|  | ||||
|     friend _LIBCPP_ALWAYS_INLINE _LIBCPP_CONSTEXPR bool operator==(nullptr_t, nullptr_t) {return true;} | ||||
|     friend _LIBCPP_ALWAYS_INLINE _LIBCPP_CONSTEXPR bool operator!=(nullptr_t, nullptr_t) {return false;} | ||||
|     friend _LIBCPP_ALWAYS_INLINE _LIBCPP_CONSTEXPR bool operator<(nullptr_t, nullptr_t) {return false;} | ||||
|     friend _LIBCPP_ALWAYS_INLINE _LIBCPP_CONSTEXPR bool operator<=(nullptr_t, nullptr_t) {return true;} | ||||
|     friend _LIBCPP_ALWAYS_INLINE _LIBCPP_CONSTEXPR bool operator>(nullptr_t, nullptr_t) {return false;} | ||||
|     friend _LIBCPP_ALWAYS_INLINE _LIBCPP_CONSTEXPR bool operator>=(nullptr_t, nullptr_t) {return true;} | ||||
|     friend _LIBCPP_ALWAYS_INLINE bool operator==(nullptr_t, nullptr_t) {return true;} | ||||
|     friend _LIBCPP_ALWAYS_INLINE bool operator!=(nullptr_t, nullptr_t) {return false;} | ||||
|     friend _LIBCPP_ALWAYS_INLINE bool operator<(nullptr_t, nullptr_t) {return false;} | ||||
|     friend _LIBCPP_ALWAYS_INLINE bool operator<=(nullptr_t, nullptr_t) {return true;} | ||||
|     friend _LIBCPP_ALWAYS_INLINE bool operator>(nullptr_t, nullptr_t) {return false;} | ||||
|     friend _LIBCPP_ALWAYS_INLINE bool operator>=(nullptr_t, nullptr_t) {return true;} | ||||
| }; | ||||
|  | ||||
| inline _LIBCPP_ALWAYS_INLINE _LIBCPP_CONSTEXPR nullptr_t __get_nullptr_t() {return nullptr_t(0);} | ||||
| inline _LIBCPP_ALWAYS_INLINE nullptr_t __get_nullptr_t() {return nullptr_t(0);} | ||||
|  | ||||
| #define nullptr _VSTD::__get_nullptr_t() | ||||
| #define nullptr _STD::__get_nullptr_t() | ||||
|  | ||||
| #else  // _LIBCPP_HAS_NO_NULLPTR | ||||
|  | ||||
| typedef decltype(nullptr) nullptr_t; | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_NULLPTR | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_NULLPTR | ||||
|  | ||||
| namespace std | ||||
| { | ||||
|     typedef decltype(nullptr) nullptr_t; | ||||
| } | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_NULLPTR | ||||
|  | ||||
| #endif  // _LIBCPP_CSTDDEF | ||||
|   | ||||
| @@ -144,9 +144,7 @@ Types: | ||||
| #include <__config> | ||||
| #include <stdint.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
| @@ -74,7 +74,7 @@ int fputc(int c, FILE* stream); | ||||
| int fputs(const char* restrict s, FILE* restrict stream); | ||||
| int getc(FILE* stream); | ||||
| int getchar(void); | ||||
| char* gets(char* s);  // removed in C++14 | ||||
| char* gets(char* s); | ||||
| int putc(int c, FILE* stream); | ||||
| int putchar(int c); | ||||
| int puts(const char* s); | ||||
| @@ -99,26 +99,7 @@ void perror(const char* s); | ||||
| #include <__config> | ||||
| #include <stdio.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| // snprintf | ||||
| #if defined(_LIBCPP_MSVCRT) | ||||
| #include "support/win32/support.h" | ||||
| #endif | ||||
|  | ||||
| #ifdef getc | ||||
| inline _LIBCPP_INLINE_VISIBILITY int __libcpp_getc(FILE* __stream) {return getc(__stream);} | ||||
| #undef getc | ||||
| inline _LIBCPP_INLINE_VISIBILITY int getc(FILE* __stream) {return __libcpp_getc(__stream);} | ||||
| #endif  // getc | ||||
|  | ||||
| #ifdef putc | ||||
| inline _LIBCPP_INLINE_VISIBILITY int __libcpp_putc(int __c, FILE* __stream) {return putc(__c, __stream);} | ||||
| #undef putc | ||||
| inline _LIBCPP_INLINE_VISIBILITY int putc(int __c, FILE* __stream) {return __libcpp_putc(__c, __stream);} | ||||
| #endif  // putc | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| @@ -143,24 +124,20 @@ using ::scanf; | ||||
| using ::snprintf; | ||||
| using ::sprintf; | ||||
| using ::sscanf; | ||||
| #ifndef _LIBCPP_MSVCRT | ||||
| using ::vfprintf; | ||||
| using ::vfscanf; | ||||
| using ::vscanf; | ||||
| using ::vsscanf; | ||||
| #endif // _LIBCPP_MSVCRT | ||||
| using ::vprintf; | ||||
| using ::vscanf; | ||||
| using ::vsnprintf; | ||||
| using ::vsprintf; | ||||
| using ::vsscanf; | ||||
| using ::fgetc; | ||||
| using ::fgets; | ||||
| using ::fputc; | ||||
| using ::fputs; | ||||
| using ::getc; | ||||
| using ::getchar; | ||||
| #if _LIBCPP_STD_VER <= 11 | ||||
| using ::gets; | ||||
| #endif | ||||
| using ::putc; | ||||
| using ::putchar; | ||||
| using ::puts; | ||||
|   | ||||
| @@ -74,9 +74,6 @@ int mbtowc(wchar_t* restrict pwc, const char* restrict s, size_t n); | ||||
| int wctomb(char* s, wchar_t wchar); | ||||
| size_t mbstowcs(wchar_t* restrict pwcs, const char* restrict s, size_t n); | ||||
| size_t wcstombs(char* restrict s, const wchar_t* restrict pwcs, size_t n); | ||||
| int at_quick_exit(void (*func)(void))                                     // C++11 | ||||
| void quick_exit(int status);                                              // C++11 | ||||
| void *aligned_alloc(size_t alignment, size_t size);                       // C11 | ||||
|  | ||||
| }  // std | ||||
|  | ||||
| @@ -84,39 +81,26 @@ void *aligned_alloc(size_t alignment, size_t size);                       // C11 | ||||
|  | ||||
| #include <__config> | ||||
| #include <stdlib.h> | ||||
| #ifdef _LIBCPP_MSVCRT | ||||
| #include "support/win32/locale_win32.h" | ||||
| #endif // _LIBCPP_MSVCRT | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| using ::size_t; | ||||
| using ::div_t; | ||||
| using ::ldiv_t; | ||||
| #ifndef _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::lldiv_t; | ||||
| #endif // _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::atof; | ||||
| using ::atoi; | ||||
| using ::atol; | ||||
| #ifndef _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::atoll; | ||||
| #endif // _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::strtod; | ||||
| using ::strtof; | ||||
| using ::strtold; | ||||
| using ::strtol; | ||||
| #ifndef _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::strtoll; | ||||
| #endif // _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::strtoul; | ||||
| #ifndef _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::strtoull; | ||||
| #endif // _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::rand; | ||||
| using ::srand; | ||||
| using ::calloc; | ||||
| @@ -133,39 +117,21 @@ using ::bsearch; | ||||
| using ::qsort; | ||||
| using ::abs; | ||||
| using ::labs; | ||||
| #ifndef _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::llabs; | ||||
| #endif // _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::div; | ||||
| using ::ldiv; | ||||
| #ifndef _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::lldiv; | ||||
| #endif // _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::mblen; | ||||
| using ::mbtowc; | ||||
| using ::wctomb; | ||||
| using ::mbstowcs; | ||||
| using ::wcstombs; | ||||
| #ifdef _LIBCPP_HAS_QUICK_EXIT | ||||
| using ::at_quick_exit; | ||||
| using ::quick_exit; | ||||
| #endif | ||||
| #ifdef _LIBCPP_HAS_C11_FEATURES | ||||
| using ::aligned_alloc; | ||||
| #endif | ||||
|  | ||||
| // MSVCRT already has the correct prototype in <stdlib.h> #ifdef __cplusplus | ||||
| #if !defined(_LIBCPP_MSVCRT) && !defined(__sun__) && !defined(_AIX) | ||||
| inline _LIBCPP_INLINE_VISIBILITY long      abs(     long __x) _NOEXCEPT {return  labs(__x);} | ||||
| #ifndef _LIBCPP_HAS_NO_LONG_LONG | ||||
| inline _LIBCPP_INLINE_VISIBILITY long long abs(long long __x) _NOEXCEPT {return llabs(__x);} | ||||
| #endif // _LIBCPP_HAS_NO_LONG_LONG | ||||
| inline _LIBCPP_INLINE_VISIBILITY long      abs(     long __x) {return  labs(__x);} | ||||
| inline _LIBCPP_INLINE_VISIBILITY long long abs(long long __x) {return llabs(__x);} | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY  ldiv_t div(     long __x,      long __y) _NOEXCEPT {return  ldiv(__x, __y);} | ||||
| #ifndef _LIBCPP_HAS_NO_LONG_LONG | ||||
| inline _LIBCPP_INLINE_VISIBILITY lldiv_t div(long long __x, long long __y) _NOEXCEPT {return lldiv(__x, __y);} | ||||
| #endif // _LIBCPP_HAS_NO_LONG_LONG | ||||
| #endif // _LIBCPP_MSVCRT | ||||
| inline _LIBCPP_INLINE_VISIBILITY  ldiv_t div(     long __x,      long __y) {return  ldiv(__x, __y);} | ||||
| inline _LIBCPP_INLINE_VISIBILITY lldiv_t div(long long __x, long long __y) {return lldiv(__x, __y);} | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
| @@ -60,9 +60,7 @@ size_t strlen(const char* s); | ||||
| #include <__config> | ||||
| #include <string.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| @@ -93,8 +91,7 @@ using ::strspn; | ||||
|  | ||||
| using ::strstr; | ||||
|  | ||||
| // MSVCRT, GNU libc and its derivates already have the correct prototype in <string.h> #ifdef __cplusplus | ||||
| #if !defined(__GLIBC__) && !defined(_LIBCPP_MSVCRT) && !defined(__sun__) && !defined(_STRING_H_CPLUSPLUS_98_CONFORMANCE_) | ||||
| #ifndef __GLIBC__ // GNU libc and its derivates already have the correct prototype in <string.h> #ifdef __cplusplus | ||||
| inline _LIBCPP_INLINE_VISIBILITY       char* strchr(      char* __s, int __c) {return ::strchr(__s, __c);} | ||||
| inline _LIBCPP_INLINE_VISIBILITY       char* strpbrk(      char* __s1, const char* __s2) {return ::strpbrk(__s1, __s2);} | ||||
| inline _LIBCPP_INLINE_VISIBILITY       char* strrchr(      char* __s, int __c) {return ::strrchr(__s, __c);} | ||||
|   | ||||
| @@ -22,8 +22,6 @@ | ||||
| #include <ccomplex> | ||||
| #include <cmath> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| #endif  // _LIBCPP_CTGMATH | ||||
|   | ||||
| @@ -47,9 +47,7 @@ size_t strftime(char* restrict s, size_t maxsize, const char* restrict format, | ||||
| #include <__config> | ||||
| #include <time.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
| @@ -106,13 +106,8 @@ size_t wcsrtombs(char* restrict dst, const wchar_t** restrict src, size_t len, | ||||
| #include <__config> | ||||
| #include <cwctype> | ||||
| #include <wchar.h> | ||||
| #if defined(_LIBCPP_MSVCRT) || defined(__MINGW32__) | ||||
| #include <support/win32/support.h> // pull in *swprintf defines | ||||
| #endif // _LIBCPP_MSVCRT | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| @@ -124,15 +119,13 @@ using ::FILE; | ||||
| using ::fwprintf; | ||||
| using ::fwscanf; | ||||
| using ::swprintf; | ||||
| using ::vfwprintf; | ||||
| using ::vswprintf; | ||||
| using ::vwprintf; | ||||
| #ifndef _LIBCPP_MSVCRT | ||||
| using ::swscanf; | ||||
| using ::vfwprintf; | ||||
| using ::vfwscanf; | ||||
| using ::vswprintf; | ||||
| using ::vswscanf; | ||||
| using ::vwprintf; | ||||
| using ::vwscanf; | ||||
| #endif // _LIBCPP_MSVCRT | ||||
| using ::wprintf; | ||||
| using ::wscanf; | ||||
| using ::fgetwc; | ||||
| @@ -146,18 +139,12 @@ using ::putwc; | ||||
| using ::putwchar; | ||||
| using ::ungetwc; | ||||
| using ::wcstod; | ||||
| #ifndef _LIBCPP_MSVCRT | ||||
| using ::wcstof; | ||||
| using ::wcstold; | ||||
| #endif // _LIBCPP_MSVCRT | ||||
| using ::wcstol; | ||||
| #ifndef _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::wcstoll; | ||||
| #endif // _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::wcstoul; | ||||
| #ifndef _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::wcstoull; | ||||
| #endif // _LIBCPP_HAS_NO_LONG_LONG | ||||
| using ::wcscpy; | ||||
| using ::wcsncpy; | ||||
| using ::wcscat; | ||||
| @@ -167,37 +154,28 @@ using ::wcscoll; | ||||
| using ::wcsncmp; | ||||
| using ::wcsxfrm; | ||||
|  | ||||
| #if defined(_WCHAR_H_CPLUSPLUS_98_CONFORMANCE_) | ||||
|  | ||||
| using ::wcschr; | ||||
| using ::wcspbrk; | ||||
| using ::wcsrchr; | ||||
| using ::wcsstr; | ||||
| using ::wmemchr; | ||||
|  | ||||
| #else | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY const wchar_t* wcschr(const wchar_t* __s, wchar_t __c) {return ::wcschr(__s, __c);} | ||||
| inline _LIBCPP_INLINE_VISIBILITY       wchar_t* wcschr(      wchar_t* __s, wchar_t __c) {return ::wcschr(__s, __c);} | ||||
|  | ||||
| using ::wcscspn; | ||||
| using ::wcslen; | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY const wchar_t* wcspbrk(const wchar_t* __s1, const wchar_t* __s2) {return ::wcspbrk(__s1, __s2);} | ||||
| inline _LIBCPP_INLINE_VISIBILITY       wchar_t* wcspbrk(      wchar_t* __s1, const wchar_t* __s2) {return ::wcspbrk(__s1, __s2);} | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY const wchar_t* wcsrchr(const wchar_t* __s, wchar_t __c) {return ::wcsrchr(__s, __c);} | ||||
| inline _LIBCPP_INLINE_VISIBILITY       wchar_t* wcsrchr(      wchar_t* __s, wchar_t __c) {return ::wcsrchr(__s, __c);} | ||||
|  | ||||
| using ::wcsspn; | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY const wchar_t* wcsstr(const wchar_t* __s1, const wchar_t* __s2) {return ::wcsstr(__s1, __s2);} | ||||
| inline _LIBCPP_INLINE_VISIBILITY       wchar_t* wcsstr(      wchar_t* __s1, const wchar_t* __s2) {return ::wcsstr(__s1, __s2);} | ||||
|  | ||||
| using ::wcstok; | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY const wchar_t* wmemchr(const wchar_t* __s, wchar_t __c, size_t __n) {return ::wmemchr(__s, __c, __n);} | ||||
| inline _LIBCPP_INLINE_VISIBILITY       wchar_t* wmemchr(      wchar_t* __s, wchar_t __c, size_t __n) {return ::wmemchr(__s, __c, __n);} | ||||
|  | ||||
| #endif | ||||
|  | ||||
| using ::wcscspn; | ||||
| using ::wcslen; | ||||
| using ::wcsspn; | ||||
| using ::wcstok; | ||||
| using ::wmemcmp; | ||||
| using ::wmemcpy; | ||||
| using ::wmemmove; | ||||
|   | ||||
| @@ -54,9 +54,7 @@ wctrans_t wctrans(const char* property); | ||||
| #include <cctype> | ||||
| #include <wctype.h> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
							
								
								
									
										551
									
								
								include/deque
									
									
									
									
									
								
							
							
						
						
									
										551
									
								
								include/deque
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -20,56 +20,56 @@ namespace std | ||||
| class exception | ||||
| { | ||||
| public: | ||||
|     exception() noexcept; | ||||
|     exception(const exception&) noexcept; | ||||
|     exception& operator=(const exception&) noexcept; | ||||
|     virtual ~exception() noexcept; | ||||
|     virtual const char* what() const noexcept; | ||||
|     exception() throw(); | ||||
|     exception(const exception&) throw(); | ||||
|     exception& operator=(const exception&) throw(); | ||||
|     virtual ~exception() throw(); | ||||
|     virtual const char* what() const throw(); | ||||
| }; | ||||
|  | ||||
| class bad_exception | ||||
|     : public exception | ||||
| { | ||||
| public: | ||||
|     bad_exception() noexcept; | ||||
|     bad_exception(const bad_exception&) noexcept; | ||||
|     bad_exception& operator=(const bad_exception&) noexcept; | ||||
|     virtual ~bad_exception() noexcept; | ||||
|     virtual const char* what() const noexcept; | ||||
|     bad_exception() throw(); | ||||
|     bad_exception(const bad_exception&) throw(); | ||||
|     bad_exception& operator=(const bad_exception&) throw(); | ||||
|     virtual ~bad_exception() throw(); | ||||
|     virtual const char* what() const throw(); | ||||
| }; | ||||
|  | ||||
| typedef void (*unexpected_handler)(); | ||||
| unexpected_handler set_unexpected(unexpected_handler  f ) noexcept; | ||||
| unexpected_handler get_unexpected() noexcept; | ||||
| [[noreturn]] void unexpected(); | ||||
| unexpected_handler set_unexpected(unexpected_handler  f ) throw(); | ||||
| unexpected_handler get_unexpected() throw(); | ||||
| void unexpected [[noreturn]] (); | ||||
|  | ||||
| typedef void (*terminate_handler)(); | ||||
| terminate_handler set_terminate(terminate_handler  f ) noexcept; | ||||
| terminate_handler get_terminate() noexcept; | ||||
| [[noreturn]] void terminate() noexcept; | ||||
| terminate_handler set_terminate(terminate_handler  f ) throw(); | ||||
| terminate_handler get_terminate() throw(); | ||||
| void terminate [[noreturn]] (); | ||||
|  | ||||
| bool uncaught_exception() noexcept; | ||||
| bool uncaught_exception() throw(); | ||||
|  | ||||
| typedef unspecified exception_ptr; | ||||
|  | ||||
| exception_ptr current_exception() noexcept; | ||||
| exception_ptr current_exception(); | ||||
| void rethrow_exception [[noreturn]] (exception_ptr p); | ||||
| template<class E> exception_ptr make_exception_ptr(E e) noexcept; | ||||
| template<class E> exception_ptr make_exception_ptr(E e); | ||||
|  | ||||
| class nested_exception | ||||
| { | ||||
| public: | ||||
|     nested_exception() noexcept; | ||||
|     nested_exception(const nested_exception&) noexcept = default; | ||||
|     nested_exception& operator=(const nested_exception&) noexcept = default; | ||||
|     nested_exception() throw(); | ||||
|     nested_exception(const nested_exception&) throw() = default; | ||||
|     nested_exception& operator=(const nested_exception&) throw() = default; | ||||
|     virtual ~nested_exception() = default; | ||||
|  | ||||
|     // access functions | ||||
|     [[noreturn]] void rethrow_nested() const; | ||||
|     exception_ptr nested_ptr() const noexcept; | ||||
|     void rethrow_nested [[noreturn]] () const; | ||||
|     exception_ptr nested_ptr() const; | ||||
| }; | ||||
|  | ||||
| template <class T> [[noreturn]] void throw_with_nested(T&& t); | ||||
| template <class T> void throw_with_nested [[noreturn]] (T&& t); | ||||
| template <class E> void rethrow_if_nested(const E& e); | ||||
|  | ||||
| }  // std | ||||
| @@ -80,9 +80,7 @@ template <class E> void rethrow_if_nested(const E& e); | ||||
| #include <cstddef> | ||||
| #include <type_traits> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| namespace std  // purposefully not using versioning namespace | ||||
| { | ||||
| @@ -90,65 +88,65 @@ namespace std  // purposefully not using versioning namespace | ||||
| class _LIBCPP_EXCEPTION_ABI exception | ||||
| { | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY exception() _NOEXCEPT {} | ||||
|     virtual ~exception() _NOEXCEPT; | ||||
|     virtual const char* what() const _NOEXCEPT; | ||||
|     _LIBCPP_INLINE_VISIBILITY exception() throw() {} | ||||
|     virtual ~exception() throw(); | ||||
|     virtual const char* what() const throw(); | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_EXCEPTION_ABI bad_exception | ||||
|     : public exception | ||||
| { | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY bad_exception() _NOEXCEPT {} | ||||
|     virtual ~bad_exception() _NOEXCEPT; | ||||
|     virtual const char* what() const _NOEXCEPT; | ||||
|     _LIBCPP_INLINE_VISIBILITY bad_exception() throw() {} | ||||
|     virtual ~bad_exception() throw(); | ||||
|     virtual const char* what() const throw(); | ||||
| }; | ||||
|  | ||||
| typedef void (*unexpected_handler)(); | ||||
| _LIBCPP_FUNC_VIS unexpected_handler set_unexpected(unexpected_handler) _NOEXCEPT; | ||||
| _LIBCPP_FUNC_VIS unexpected_handler get_unexpected() _NOEXCEPT; | ||||
| _LIBCPP_NORETURN _LIBCPP_FUNC_VIS void unexpected(); | ||||
| _LIBCPP_VISIBLE unexpected_handler set_unexpected(unexpected_handler) throw(); | ||||
| _LIBCPP_VISIBLE unexpected_handler get_unexpected() throw(); | ||||
| _LIBCPP_VISIBLE void unexpected(); | ||||
|  | ||||
| typedef void (*terminate_handler)(); | ||||
| _LIBCPP_FUNC_VIS terminate_handler set_terminate(terminate_handler) _NOEXCEPT; | ||||
| _LIBCPP_FUNC_VIS terminate_handler get_terminate() _NOEXCEPT; | ||||
| _LIBCPP_NORETURN _LIBCPP_FUNC_VIS void terminate() _NOEXCEPT; | ||||
| _LIBCPP_VISIBLE terminate_handler set_terminate(terminate_handler) throw(); | ||||
| _LIBCPP_VISIBLE terminate_handler get_terminate() throw(); | ||||
| _LIBCPP_VISIBLE void terminate() __attribute__((__noreturn__)); | ||||
|  | ||||
| _LIBCPP_FUNC_VIS bool uncaught_exception() _NOEXCEPT; | ||||
| _LIBCPP_VISIBLE bool uncaught_exception() throw(); | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS exception_ptr; | ||||
| class exception_ptr; | ||||
|  | ||||
| _LIBCPP_FUNC_VIS exception_ptr current_exception() _NOEXCEPT; | ||||
| _LIBCPP_NORETURN _LIBCPP_FUNC_VIS void rethrow_exception(exception_ptr); | ||||
| exception_ptr current_exception(); | ||||
| void rethrow_exception(exception_ptr);  // noreturn | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS exception_ptr | ||||
| class _LIBCPP_VISIBLE exception_ptr | ||||
| { | ||||
|     void* __ptr_; | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY exception_ptr() _NOEXCEPT : __ptr_() {} | ||||
|     _LIBCPP_INLINE_VISIBILITY exception_ptr(nullptr_t) _NOEXCEPT : __ptr_() {} | ||||
|     exception_ptr(const exception_ptr&) _NOEXCEPT; | ||||
|     exception_ptr& operator=(const exception_ptr&) _NOEXCEPT; | ||||
|     ~exception_ptr() _NOEXCEPT; | ||||
|     _LIBCPP_INLINE_VISIBILITY exception_ptr()  : __ptr_() {} | ||||
|     _LIBCPP_INLINE_VISIBILITY exception_ptr(nullptr_t) : __ptr_() {} | ||||
|     exception_ptr(const exception_ptr&); | ||||
|     exception_ptr& operator=(const exception_ptr&); | ||||
|     ~exception_ptr(); | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     _LIBCPP_EXPLICIT | ||||
|         operator bool() const _NOEXCEPT {return __ptr_ != nullptr;} | ||||
|     // explicit | ||||
|         operator bool() const {return __ptr_ != nullptr;} | ||||
|  | ||||
|     friend _LIBCPP_INLINE_VISIBILITY | ||||
|     bool operator==(const exception_ptr& __x, const exception_ptr& __y) _NOEXCEPT | ||||
|     bool operator==(const exception_ptr& __x, const exception_ptr& __y) | ||||
|         {return __x.__ptr_ == __y.__ptr_;} | ||||
|     friend _LIBCPP_INLINE_VISIBILITY | ||||
|     bool operator!=(const exception_ptr& __x, const exception_ptr& __y) _NOEXCEPT | ||||
|     bool operator!=(const exception_ptr& __x, const exception_ptr& __y) | ||||
|         {return !(__x == __y);} | ||||
|  | ||||
|     friend _LIBCPP_FUNC_VIS exception_ptr current_exception() _NOEXCEPT; | ||||
|     friend _LIBCPP_FUNC_VIS void rethrow_exception(exception_ptr); | ||||
|     friend exception_ptr current_exception(); | ||||
|     friend void rethrow_exception(exception_ptr);  // noreturn | ||||
| }; | ||||
|  | ||||
| template<class _Ep> | ||||
| template<class _E> | ||||
| exception_ptr | ||||
| make_exception_ptr(_Ep __e) _NOEXCEPT | ||||
| make_exception_ptr(_E __e) | ||||
| { | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     try | ||||
| @@ -168,14 +166,14 @@ class _LIBCPP_EXCEPTION_ABI nested_exception | ||||
| { | ||||
|     exception_ptr __ptr_; | ||||
| public: | ||||
|     nested_exception() _NOEXCEPT; | ||||
| //     nested_exception(const nested_exception&) noexcept = default; | ||||
| //     nested_exception& operator=(const nested_exception&) noexcept = default; | ||||
|     virtual ~nested_exception() _NOEXCEPT; | ||||
|     nested_exception(); | ||||
| //     nested_exception(const nested_exception&) throw() = default; | ||||
| //     nested_exception& operator=(const nested_exception&) throw() = default; | ||||
|     virtual ~nested_exception(); | ||||
|  | ||||
|     // access functions | ||||
|     _LIBCPP_NORETURN void rethrow_nested() const; | ||||
|     _LIBCPP_INLINE_VISIBILITY exception_ptr nested_ptr() const _NOEXCEPT {return __ptr_;} | ||||
|     void rethrow_nested /*[[noreturn]]*/ () const; | ||||
|     _LIBCPP_INLINE_VISIBILITY exception_ptr nested_ptr() const {return __ptr_;} | ||||
| }; | ||||
|  | ||||
| template <class _Tp> | ||||
| @@ -187,10 +185,9 @@ struct __nested | ||||
| }; | ||||
|  | ||||
| template <class _Tp> | ||||
| _LIBCPP_NORETURN | ||||
| void | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| throw_with_nested(_Tp&& __t, typename enable_if< | ||||
| throw_with_nested /*[[noreturn]]*/ (_Tp&& __t, typename enable_if< | ||||
|                   is_class<typename remove_reference<_Tp>::type>::value && | ||||
|                   !is_base_of<nested_exception, typename remove_reference<_Tp>::type>::value | ||||
|                                     >::type* = 0) | ||||
| @@ -201,15 +198,14 @@ throw_with_nested (_Tp& __t, typename enable_if< | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| { | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     throw __nested<typename remove_reference<_Tp>::type>(_VSTD::forward<_Tp>(__t)); | ||||
|     throw __nested<typename remove_reference<_Tp>::type>(_STD::forward<_Tp>(__t)); | ||||
| #endif | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| _LIBCPP_NORETURN | ||||
| void | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| throw_with_nested(_Tp&& __t, typename enable_if< | ||||
| throw_with_nested /*[[noreturn]]*/ (_Tp&& __t, typename enable_if< | ||||
|                   !is_class<typename remove_reference<_Tp>::type>::value || | ||||
|                   is_base_of<nested_exception, typename remove_reference<_Tp>::type>::value | ||||
|                                     >::type* = 0) | ||||
| @@ -220,15 +216,15 @@ throw_with_nested (_Tp& __t, typename enable_if< | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| { | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     throw _VSTD::forward<_Tp>(__t); | ||||
|     throw _STD::forward<_Tp>(__t); | ||||
| #endif | ||||
| } | ||||
|  | ||||
| template <class _Ep> | ||||
| template <class _E> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| rethrow_if_nested(const _Ep& __e, typename enable_if< | ||||
|                                    is_polymorphic<_Ep>::value | ||||
| rethrow_if_nested(const _E& __e, typename enable_if< | ||||
|                                    is_polymorphic<_E>::value | ||||
|                                                    >::type* = 0) | ||||
| { | ||||
|     const nested_exception* __nep = dynamic_cast<const nested_exception*>(&__e); | ||||
| @@ -236,11 +232,11 @@ rethrow_if_nested(const _Ep& __e, typename enable_if< | ||||
|         __nep->rethrow_nested(); | ||||
| } | ||||
|  | ||||
| template <class _Ep> | ||||
| template <class _E> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| rethrow_if_nested(const _Ep&, typename enable_if< | ||||
|                                    !is_polymorphic<_Ep>::value | ||||
| rethrow_if_nested(const _E& __e, typename enable_if< | ||||
|                                    !is_polymorphic<_E>::value | ||||
|                                                    >::type* = 0) | ||||
| { | ||||
| } | ||||
|   | ||||
| @@ -1,314 +0,0 @@ | ||||
| // -*- C++ -*- | ||||
| //===-------------------------- dynarray ----------------------------------===// | ||||
| // | ||||
| //                     The LLVM Compiler Infrastructure | ||||
| // | ||||
| // This file is dual licensed under the MIT and the University of Illinois Open | ||||
| // Source Licenses. See LICENSE.TXT for details. | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| #ifndef _LIBCPP_DYNARRAY | ||||
| #define _LIBCPP_DYNARRAY | ||||
|  | ||||
| #include <__config> | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|  | ||||
| /* | ||||
|     dynarray synopsis | ||||
|  | ||||
| namespace std { namespace experimental { | ||||
|  | ||||
| template< typename T > | ||||
| class dynarray | ||||
| { | ||||
|     // types: | ||||
|     typedef       T                               value_type; | ||||
|     typedef       T&                              reference; | ||||
|     typedef const T&                              const_reference; | ||||
|     typedef       T*                              pointer; | ||||
|     typedef const T*                              const_pointer; | ||||
|     typedef       implementation-defined          iterator; | ||||
|     typedef       implementation-defined          const_iterator; | ||||
|     typedef reverse_iterator<iterator>            reverse_iterator; | ||||
|     typedef reverse_iterator<const_iterator>      const_reverse_iterator; | ||||
|     typedef size_t                                size_type; | ||||
|     typedef ptrdiff_t                             difference_type; | ||||
|  | ||||
| public: | ||||
|     // construct/copy/destroy: | ||||
|     explicit dynarray(size_type c); | ||||
|     template <typename Alloc> | ||||
|       dynarray(size_type c, const Alloc& alloc); | ||||
|     dynarray(size_type c, const T& v); | ||||
|     template <typename Alloc> | ||||
|       dynarray(size_type c, const T& v, const Alloc& alloc); | ||||
|     dynarray(const dynarray& d); | ||||
|     template <typename Alloc> | ||||
|       dynarray(const dynarray& d, const Alloc& alloc); | ||||
|     dynarray(initializer_list<T>); | ||||
|     template <typename Alloc> | ||||
|       dynarray(initializer_list<T>, const Alloc& alloc); | ||||
|  | ||||
|     dynarray& operator=(const dynarray&) = delete; | ||||
|     ~dynarray(); | ||||
|  | ||||
|     // iterators: | ||||
|     iterator       begin()        noexcept; | ||||
|     const_iterator begin()  const noexcept; | ||||
|     const_iterator cbegin() const noexcept; | ||||
|     iterator       end()          noexcept; | ||||
|     const_iterator end()    const noexcept; | ||||
|     const_iterator cend()   const noexcept; | ||||
|  | ||||
|     reverse_iterator       rbegin()        noexcept; | ||||
|     const_reverse_iterator rbegin()  const noexcept; | ||||
|     const_reverse_iterator crbegin() const noexcept; | ||||
|     reverse_iterator       rend()          noexcept; | ||||
|     const_reverse_iterator rend()    const noexcept; | ||||
|     const_reverse_iterator crend()   const noexcept; | ||||
|  | ||||
|     // capacity: | ||||
|     size_type size()     const noexcept; | ||||
|     size_type max_size() const noexcept; | ||||
|     bool      empty()    const noexcept; | ||||
|  | ||||
|     // element access: | ||||
|     reference       operator[](size_type n); | ||||
|     const_reference operator[](size_type n) const; | ||||
|  | ||||
|     reference       front(); | ||||
|     const_reference front() const; | ||||
|     reference       back(); | ||||
|     const_reference back()  const; | ||||
|  | ||||
|     const_reference at(size_type n) const; | ||||
|     reference       at(size_type n); | ||||
|  | ||||
|     // data access: | ||||
|     T*       data()       noexcept; | ||||
|     const T* data() const noexcept; | ||||
|  | ||||
|     // mutating member functions: | ||||
|     void fill(const T& v); | ||||
| }; | ||||
|  | ||||
| }}  // std::experimental | ||||
|  | ||||
| */ | ||||
|  | ||||
| #include <__functional_base> | ||||
| #include <iterator> | ||||
| #include <stdexcept> | ||||
| #include <initializer_list> | ||||
| #include <new> | ||||
| #include <algorithm> | ||||
|  | ||||
| #if defined(_LIBCPP_NO_EXCEPTIONS) | ||||
|     #include <cassert> | ||||
| #endif | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| namespace std { namespace experimental { inline namespace __array_extensions_v1 { | ||||
|  | ||||
| template <class _Tp> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY dynarray | ||||
| { | ||||
| public: | ||||
|     // types: | ||||
|     typedef dynarray __self; | ||||
|     typedef _Tp                                   value_type; | ||||
|     typedef value_type&                           reference; | ||||
|     typedef const value_type&                     const_reference; | ||||
|     typedef value_type*                           iterator; | ||||
|     typedef const value_type*                     const_iterator; | ||||
|     typedef value_type*                           pointer; | ||||
|     typedef const value_type*                     const_pointer; | ||||
|     typedef size_t                                size_type; | ||||
|     typedef ptrdiff_t                             difference_type; | ||||
|     typedef std::reverse_iterator<iterator>       reverse_iterator; | ||||
|     typedef std::reverse_iterator<const_iterator> const_reverse_iterator; | ||||
|  | ||||
| private: | ||||
|     size_t                  __size_; | ||||
|     value_type *            __base_; | ||||
|     _LIBCPP_ALWAYS_INLINE dynarray () noexcept : __base_(nullptr), __size_(0) {} | ||||
|      | ||||
|     static inline _LIBCPP_INLINE_VISIBILITY value_type* __allocate ( size_t count ) | ||||
|     { | ||||
|         if ( numeric_limits<size_t>::max() / sizeof (value_type) <= count ) | ||||
|         { | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|             throw bad_array_length(); | ||||
| #else | ||||
|             assert(!"dynarray::allocation"); | ||||
| #endif | ||||
|         } | ||||
|         return static_cast<value_type *> (::operator new (sizeof(value_type) * count)); | ||||
|     } | ||||
|  | ||||
|     static inline _LIBCPP_INLINE_VISIBILITY void __deallocate ( value_type* __ptr ) noexcept | ||||
|     { | ||||
|         ::operator delete (static_cast<void *> (__ptr)); | ||||
|     } | ||||
|  | ||||
| public: | ||||
|  | ||||
|     explicit dynarray(size_type __c); | ||||
|     dynarray(size_type __c, const value_type& __v); | ||||
|     dynarray(const dynarray& __d); | ||||
|     dynarray(initializer_list<value_type>); | ||||
|  | ||||
| //  We're not implementing these right now. | ||||
| //  Waiting for the resolution of LWG issue #2235 | ||||
| //     template <typename _Alloc> | ||||
| //       dynarray(size_type __c, const _Alloc& __alloc); | ||||
| //     template <typename _Alloc> | ||||
| //       dynarray(size_type __c, const value_type& __v, const _Alloc& __alloc); | ||||
| //     template <typename _Alloc> | ||||
| //       dynarray(const dynarray& __d, const _Alloc& __alloc); | ||||
| //     template <typename _Alloc> | ||||
| //       dynarray(initializer_list<value_type>, const _Alloc& __alloc); | ||||
|  | ||||
|     dynarray& operator=(const dynarray&) = delete; | ||||
|     ~dynarray(); | ||||
|  | ||||
|     // iterators: | ||||
|     inline _LIBCPP_INLINE_VISIBILITY iterator       begin()        noexcept { return iterator(data()); } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY const_iterator begin()  const noexcept { return const_iterator(data()); } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY const_iterator cbegin() const noexcept { return const_iterator(data()); } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY iterator       end()          noexcept { return iterator(data() + __size_); } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY const_iterator end()    const noexcept { return const_iterator(data() + __size_); } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY const_iterator cend()   const noexcept { return const_iterator(data() + __size_); } | ||||
|  | ||||
|     inline _LIBCPP_INLINE_VISIBILITY reverse_iterator       rbegin()        noexcept { return reverse_iterator(end()); } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY const_reverse_iterator rbegin()  const noexcept { return const_reverse_iterator(end()); } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY const_reverse_iterator crbegin() const noexcept { return const_reverse_iterator(end()); } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY reverse_iterator       rend()          noexcept { return reverse_iterator(begin()); } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY const_reverse_iterator rend()    const noexcept { return const_reverse_iterator(begin()); } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY const_reverse_iterator crend()   const noexcept { return const_reverse_iterator(begin()); } | ||||
|  | ||||
|     // capacity: | ||||
|     inline _LIBCPP_INLINE_VISIBILITY size_type size()     const noexcept { return __size_; } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY size_type max_size() const noexcept { return __size_; } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY bool      empty()    const noexcept { return __size_ == 0; } | ||||
|  | ||||
|     // element access: | ||||
|     inline _LIBCPP_INLINE_VISIBILITY reference       operator[](size_type __n)       { return data()[__n]; } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY const_reference operator[](size_type __n) const { return data()[__n]; } | ||||
|  | ||||
|     inline _LIBCPP_INLINE_VISIBILITY reference       front()       { return data()[0]; } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY const_reference front() const { return data()[0]; } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY reference       back()        { return data()[__size_-1]; } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY const_reference back()  const { return data()[__size_-1]; } | ||||
|  | ||||
|     inline _LIBCPP_INLINE_VISIBILITY const_reference at(size_type __n) const; | ||||
|     inline _LIBCPP_INLINE_VISIBILITY reference       at(size_type __n); | ||||
|  | ||||
|     // data access: | ||||
|     inline _LIBCPP_INLINE_VISIBILITY _Tp*       data()       noexcept { return __base_; } | ||||
|     inline _LIBCPP_INLINE_VISIBILITY const _Tp* data() const noexcept { return __base_; } | ||||
|  | ||||
|     // mutating member functions: | ||||
|     inline _LIBCPP_INLINE_VISIBILITY void fill(const value_type& __v) { fill_n(begin(), __size_, __v); } | ||||
| }; | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| dynarray<_Tp>::dynarray(size_type __c) : dynarray () | ||||
| { | ||||
|     __base_ = __allocate (__c); | ||||
|     value_type *__data = data (); | ||||
|     for ( __size_ = 0; __size_ < __c; ++__size_, ++__data ) | ||||
|         ::new (__data) value_type; | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| dynarray<_Tp>::dynarray(size_type __c, const value_type& __v) : dynarray () | ||||
| { | ||||
|     __base_ = __allocate (__c); | ||||
|     value_type *__data = data (); | ||||
|     for ( __size_ = 0; __size_ < __c; ++__size_, ++__data ) | ||||
|         ::new (__data) value_type (__v); | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| dynarray<_Tp>::dynarray(initializer_list<value_type> __il) : dynarray () | ||||
| { | ||||
|     size_t sz = __il.size(); | ||||
|     __base_ = __allocate (sz); | ||||
|     value_type *__data = data (); | ||||
|     auto src = __il.begin(); | ||||
|     for ( __size_ = 0; __size_ < sz; ++__size_, ++__data, ++src ) | ||||
|         ::new (__data) value_type (*src); | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| dynarray<_Tp>::dynarray(const dynarray& __d) : dynarray () | ||||
| { | ||||
|     size_t sz = __d.size(); | ||||
|     __base_ = __allocate (sz); | ||||
|     value_type *__data = data (); | ||||
|     auto src = __d.begin(); | ||||
|     for ( __size_ = 0; __size_ < sz; ++__size_, ++__data, ++src ) | ||||
|         ::new (__data) value_type (*src); | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| dynarray<_Tp>::~dynarray() | ||||
| {  | ||||
|     value_type *__data = data () + __size_; | ||||
|     for ( size_t i = 0; i < __size_; ++i ) | ||||
|         (--__data)->value_type::~value_type(); | ||||
|     __deallocate ( __base_ ); | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| typename dynarray<_Tp>::reference | ||||
| dynarray<_Tp>::at(size_type __n) | ||||
| { | ||||
|     if (__n >= __size_) | ||||
|     { | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|         throw out_of_range("dynarray::at"); | ||||
| #else | ||||
|         assert(!"dynarray::at out_of_range"); | ||||
| #endif | ||||
|     } | ||||
|     return data()[__n]; | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| typename dynarray<_Tp>::const_reference | ||||
| dynarray<_Tp>::at(size_type __n) const | ||||
| { | ||||
|     if (__n >= __size_) | ||||
|     { | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|         throw out_of_range("dynarray::at"); | ||||
| #else | ||||
|         assert(!"dynarray::at out_of_range"); | ||||
| #endif | ||||
|     } | ||||
|     return data()[__n]; | ||||
| } | ||||
|  | ||||
| }}} | ||||
|  | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
| template <class _Tp, class _Alloc> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY uses_allocator<std::experimental::dynarray<_Tp>, _Alloc> : true_type {}; | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
| #endif  // if _LIBCPP_STD_VER > 11  | ||||
| #endif  // _LIBCPP_DYNARRAY | ||||
| @@ -1,699 +0,0 @@ | ||||
| // -*- C++ -*- | ||||
| //===-------------------------- optional ----------------------------------===// | ||||
| // | ||||
| //                     The LLVM Compiler Infrastructure | ||||
| // | ||||
| // This file is dual licensed under the MIT and the University of Illinois Open | ||||
| // Source Licenses. See LICENSE.TXT for details. | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| #ifndef _LIBCPP_OPTIONAL | ||||
| #define _LIBCPP_OPTIONAL | ||||
|  | ||||
| /* | ||||
|     optional synopsis | ||||
|  | ||||
| // C++1y | ||||
|  | ||||
| #include <initializer_list> | ||||
|  | ||||
| namespace std { namespace experimental { | ||||
|  | ||||
| // optional for object types | ||||
| template <class T> | ||||
| class optional | ||||
| { | ||||
| public: | ||||
|     typedef T value_type; | ||||
|  | ||||
|     // constructors | ||||
|     constexpr optional() noexcept; | ||||
|     constexpr optional(nullopt_t) noexcept; | ||||
|     optional(const optional&); | ||||
|     optional(optional&&) noexcept(is_nothrow_move_constructible<T>::value); | ||||
|     constexpr optional(const T&); | ||||
|     constexpr optional(T&&); | ||||
|     template <class... Args> constexpr explicit optional(in_place_t, Args&&...); | ||||
|     template <class U, class... Args> | ||||
|         constexpr explicit optional(in_place_t, initializer_list<U>, Args&&...); | ||||
|  | ||||
|     // destructor | ||||
|     ~optional(); | ||||
|  | ||||
|     // assignment | ||||
|     optional& operator=(nullopt_t) noexcept; | ||||
|     optional& operator=(const optional&); | ||||
|     optional& operator=(optional&&) | ||||
|         noexcept(is_nothrow_move_assignable<T>::value && | ||||
|                  is_nothrow_move_constructible<T>::value); | ||||
|     template <class U> optional& operator=(U&&); | ||||
|     template <class... Args> void emplace(Args&&...); | ||||
|     template <class U, class... Args> void emplace(initializer_list<U>, Args&&...); | ||||
|  | ||||
|     // swap | ||||
|     void swap(optional&) | ||||
|         noexcept(is_nothrow_move_constructible<T>::value && | ||||
|                  noexcept(swap(declval<T&>(), declval<T&>()))); | ||||
|  | ||||
|     // observers | ||||
|     constexpr T const* operator->() const; | ||||
|     T* operator->(); | ||||
|     constexpr T const& operator*() const; | ||||
|     T& operator*(); | ||||
|     constexpr explicit operator bool() const noexcept; | ||||
|     constexpr T const& value() const; | ||||
|     T& value(); | ||||
|     template <class U> constexpr T value_or(U&&) const&; | ||||
|     template <class U> T value_or(U&&) &&; | ||||
| }; | ||||
|  | ||||
| // In-place construction | ||||
| struct in_place_t{}; | ||||
| constexpr in_place_t in_place{}; | ||||
|  | ||||
| // Disengaged state indicator | ||||
| struct nullopt_t{see below}; | ||||
| constexpr nullopt_t nullopt(unspecified); | ||||
|  | ||||
| // class bad_optional_access | ||||
| class bad_optional_access | ||||
|     : public logic_error | ||||
| { | ||||
| public: | ||||
|     explicit bad_optional_access(const string& what_arg); | ||||
|     explicit bad_optional_access(const char* what_arg); | ||||
| }; | ||||
|  | ||||
| // Relational operators | ||||
| template <class T> constexpr bool operator==(const optional<T>&, const optional<T>&); | ||||
| template <class T> constexpr bool operator< (const optional<T>&, const optional<T>&); | ||||
|  | ||||
| // Comparison with nullopt | ||||
| template <class T> constexpr bool operator==(const optional<T>&, nullopt_t) noexcept; | ||||
| template <class T> constexpr bool operator==(nullopt_t, const optional<T>&) noexcept; | ||||
| template <class T> constexpr bool operator<(const optional<T>&, nullopt_t) noexcept; | ||||
| template <class T> constexpr bool operator<(nullopt_t, const optional<T>&) noexcept; | ||||
|  | ||||
| // Comparison with T | ||||
| template <class T> constexpr bool operator==(const optional<T>&, const T&); | ||||
| template <class T> constexpr bool operator==(const T&, const optional<T>&); | ||||
| template <class T> constexpr bool operator<(const optional<T>&, const T&); | ||||
| template <class T> constexpr bool operator<(const T&, const optional<T>&); | ||||
|  | ||||
| // Specialized algorithms | ||||
| template <class T> void swap(optional<T>&, optional<T>&) noexcept(see below); | ||||
| template <class T> constexpr optional<typename decay<T>::type> make_optional(T&&); | ||||
|  | ||||
| // hash support | ||||
| template <class T> struct hash; | ||||
| template <class T> struct hash<optional<T>>; | ||||
|  | ||||
| }}  // std::experimental | ||||
|  | ||||
| */ | ||||
|  | ||||
| #include <__config> | ||||
| #include <functional> | ||||
| #include <stdexcept> | ||||
|  | ||||
| namespace std { namespace experimental { | ||||
|  | ||||
| class _LIBCPP_EXCEPTION_ABI bad_optional_access | ||||
|     : public logic_error | ||||
| { | ||||
| public: | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit bad_optional_access(const string& __arg) | ||||
|         : logic_error(__arg) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit bad_optional_access(const char* __arg) | ||||
|         : logic_error(__arg) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY bad_optional_access(const bad_optional_access&) noexcept = default; | ||||
|     _LIBCPP_INLINE_VISIBILITY bad_optional_access& operator=(const bad_optional_access&) noexcept = default; | ||||
| #else | ||||
| private: | ||||
|     bad_optional_access(const bad_optional_access&); | ||||
|     bad_optional_access& operator=(const bad_optional_access&); | ||||
| public: | ||||
| #endif  // _LIBCPP_STD_VER > 11 | ||||
|     // Get the key function ~bad_optional_access() into the dylib even if not compiling for C++1y | ||||
|     virtual ~bad_optional_access() _NOEXCEPT; | ||||
| }; | ||||
|  | ||||
| }}  // std::experimental | ||||
|  | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|  | ||||
| #include <initializer_list> | ||||
| #include <type_traits> | ||||
| #include <new> | ||||
| #include <__functional_base> | ||||
|  | ||||
| #include <__undef_min_max> | ||||
|  | ||||
| #ifdef _LIBCPP_DEBUG | ||||
| #   include <__debug> | ||||
| #else | ||||
| #   define _LIBCPP_ASSERT(x, m) ((void)0) | ||||
| #endif | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| namespace std { namespace experimental { inline namespace __library_fundamentals_v1 { | ||||
|  | ||||
| struct in_place_t {}; | ||||
| constexpr in_place_t in_place{}; | ||||
|  | ||||
| struct nullopt_t | ||||
| { | ||||
|     explicit constexpr nullopt_t(int) noexcept {} | ||||
| }; | ||||
|  | ||||
| constexpr nullopt_t nullopt{0}; | ||||
|  | ||||
| template <class _Tp, bool = is_trivially_destructible<_Tp>::value> | ||||
| class __optional_storage | ||||
| { | ||||
| protected: | ||||
|     typedef _Tp value_type; | ||||
|     union | ||||
|     { | ||||
|         char __null_state_; | ||||
|         value_type __val_; | ||||
|     }; | ||||
|     bool __engaged_ = false; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     ~__optional_storage() | ||||
|     { | ||||
|         if (__engaged_) | ||||
|             __val_.~value_type(); | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr __optional_storage() noexcept | ||||
|         :  __null_state_('\0') {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     __optional_storage(const __optional_storage& __x) | ||||
|         :  __engaged_(__x.__engaged_) | ||||
|         { | ||||
|             if (__engaged_) | ||||
|                 ::new(_VSTD::addressof(__val_)) value_type(__x.__val_); | ||||
|         } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     __optional_storage(__optional_storage&& __x) | ||||
|                       noexcept(is_nothrow_move_constructible<value_type>::value) | ||||
|         :  __engaged_(__x.__engaged_) | ||||
|         { | ||||
|             if (__engaged_) | ||||
|                 ::new(_VSTD::addressof(__val_)) value_type(_VSTD::move(__x.__val_)); | ||||
|         } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr __optional_storage(const value_type& __v) | ||||
|         :  __val_(__v), | ||||
|            __engaged_(true) {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr __optional_storage(value_type&& __v) | ||||
|         :  __val_(_VSTD::move(__v)), | ||||
|            __engaged_(true) {} | ||||
|  | ||||
|     template <class... _Args> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr | ||||
|     explicit __optional_storage(in_place_t, _Args&&... __args) | ||||
|        :  __val_(_VSTD::forward<_Args>(__args)...), | ||||
|            __engaged_(true) {} | ||||
| }; | ||||
|  | ||||
| template <class _Tp> | ||||
| class __optional_storage<_Tp, true> | ||||
| { | ||||
| protected: | ||||
|     typedef _Tp value_type; | ||||
|     union | ||||
|     { | ||||
|         char __null_state_; | ||||
|         value_type __val_; | ||||
|     }; | ||||
|     bool __engaged_ = false; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr __optional_storage() noexcept | ||||
|         :  __null_state_('\0') {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     __optional_storage(const __optional_storage& __x) | ||||
|         :  __engaged_(__x.__engaged_) | ||||
|         { | ||||
|             if (__engaged_) | ||||
|                 ::new(_VSTD::addressof(__val_)) value_type(__x.__val_); | ||||
|         } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     __optional_storage(__optional_storage&& __x) | ||||
|                       noexcept(is_nothrow_move_constructible<value_type>::value) | ||||
|         :  __engaged_(__x.__engaged_) | ||||
|         { | ||||
|             if (__engaged_) | ||||
|                 ::new(_VSTD::addressof(__val_)) value_type(_VSTD::move(__x.__val_)); | ||||
|         } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr __optional_storage(const value_type& __v) | ||||
|         :  __val_(__v), | ||||
|            __engaged_(true) {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr __optional_storage(value_type&& __v) | ||||
|         :  __val_(_VSTD::move(__v)), | ||||
|            __engaged_(true) {} | ||||
|  | ||||
|     template <class... _Args> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr | ||||
|     explicit __optional_storage(in_place_t, _Args&&... __args) | ||||
|        :  __val_(_VSTD::forward<_Args>(__args)...), | ||||
|            __engaged_(true) {} | ||||
| }; | ||||
|  | ||||
| template <class _Tp> | ||||
| class optional | ||||
|     : private __optional_storage<_Tp> | ||||
| { | ||||
|     typedef __optional_storage<_Tp> __base; | ||||
| public: | ||||
|     typedef _Tp value_type; | ||||
|  | ||||
|     static_assert(!is_reference<value_type>::value, | ||||
|               "Instantiation of optional with a reference type is ill-formed."); | ||||
|     static_assert(!is_same<typename remove_cv<value_type>::type, in_place_t>::value, | ||||
|               "Instantiation of optional with a in_place_t type is ill-formed."); | ||||
|     static_assert(!is_same<typename remove_cv<value_type>::type, nullopt_t>::value, | ||||
|               "Instantiation of optional with a nullopt_t type is ill-formed."); | ||||
|     static_assert(is_object<value_type>::value, | ||||
|         "Instantiation of optional with a non-object type is undefined behavior."); | ||||
|     static_assert(is_nothrow_destructible<value_type>::value, | ||||
|         "Instantiation of optional with an object type that is not noexcept destructible is undefined behavior."); | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY constexpr optional() noexcept {} | ||||
|     _LIBCPP_INLINE_VISIBILITY optional(const optional&) = default; | ||||
|     _LIBCPP_INLINE_VISIBILITY optional(optional&&) = default; | ||||
|     _LIBCPP_INLINE_VISIBILITY ~optional() = default; | ||||
|     _LIBCPP_INLINE_VISIBILITY constexpr optional(nullopt_t) noexcept {} | ||||
|     _LIBCPP_INLINE_VISIBILITY constexpr optional(const value_type& __v) | ||||
|         : __base(__v) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY constexpr optional(value_type&& __v) | ||||
|         : __base(_VSTD::move(__v)) {} | ||||
|  | ||||
|     template <class... _Args, | ||||
|               class = typename enable_if | ||||
|                       < | ||||
|                            is_constructible<value_type, _Args...>::value | ||||
|                       >::type | ||||
|              > | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr | ||||
|     explicit optional(in_place_t, _Args&&... __args) | ||||
|         : __base(in_place, _VSTD::forward<_Args>(__args)...) {} | ||||
|  | ||||
|     template <class _Up, class... _Args, | ||||
|               class = typename enable_if | ||||
|                       < | ||||
|                            is_constructible<value_type, initializer_list<_Up>&, _Args...>::value | ||||
|                       >::type | ||||
|              > | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr | ||||
|     explicit optional(in_place_t, initializer_list<_Up> __il, _Args&&... __args) | ||||
|         : __base(in_place, __il, _VSTD::forward<_Args>(__args)...) {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     optional& operator=(nullopt_t) noexcept | ||||
|     { | ||||
|         if (this->__engaged_) | ||||
|         { | ||||
|             this->__val_.~value_type(); | ||||
|             this->__engaged_ = false; | ||||
|         } | ||||
|         return *this; | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     optional& | ||||
|     operator=(const optional& __opt) | ||||
|     { | ||||
|         if (this->__engaged_ == __opt.__engaged_) | ||||
|         { | ||||
|             if (this->__engaged_) | ||||
|                 this->__val_ = __opt.__val_; | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             if (this->__engaged_) | ||||
|                 this->__val_.~value_type(); | ||||
|             else | ||||
|                 ::new(_VSTD::addressof(this->__val_)) value_type(__opt.__val_); | ||||
|             this->__engaged_ = __opt.__engaged_; | ||||
|         } | ||||
|         return *this; | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     optional& | ||||
|     operator=(optional&& __opt) | ||||
|         noexcept(is_nothrow_move_assignable<value_type>::value && | ||||
|                  is_nothrow_move_constructible<value_type>::value) | ||||
|     { | ||||
|         if (this->__engaged_ == __opt.__engaged_) | ||||
|         { | ||||
|             if (this->__engaged_) | ||||
|                 this->__val_ = _VSTD::move(__opt.__val_); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             if (this->__engaged_) | ||||
|                 this->__val_.~value_type(); | ||||
|             else | ||||
|                 ::new(_VSTD::addressof(this->__val_)) value_type(_VSTD::move(__opt.__val_)); | ||||
|             this->__engaged_ = __opt.__engaged_; | ||||
|         } | ||||
|         return *this; | ||||
|     } | ||||
|  | ||||
|     template <class _Up, | ||||
|               class = typename enable_if | ||||
|                       < | ||||
|                           is_same<typename remove_reference<_Up>::type, value_type>::value && | ||||
|                           is_constructible<value_type, _Up>::value && | ||||
|                           is_assignable<value_type&, _Up>::value | ||||
|                       >::type | ||||
|              > | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     optional& | ||||
|     operator=(_Up&& __v) | ||||
|     { | ||||
|         if (this->__engaged_) | ||||
|             this->__val_ = _VSTD::forward<_Up>(__v); | ||||
|         else | ||||
|         { | ||||
|             ::new(_VSTD::addressof(this->__val_)) value_type(_VSTD::forward<_Up>(__v)); | ||||
|             this->__engaged_ = true; | ||||
|         } | ||||
|         return *this; | ||||
|     } | ||||
|  | ||||
|     template <class... _Args, | ||||
|               class = typename enable_if | ||||
|                       < | ||||
|                           is_constructible<value_type, _Args...>::value | ||||
|                       >::type | ||||
|              > | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void | ||||
|     emplace(_Args&&... __args) | ||||
|     { | ||||
|         *this = nullopt; | ||||
|         ::new(_VSTD::addressof(this->__val_)) value_type(_VSTD::forward<_Args>(__args)...); | ||||
|         this->__engaged_ = true; | ||||
|     } | ||||
|  | ||||
|     template <class _Up, class... _Args, | ||||
|               class = typename enable_if | ||||
|                       < | ||||
|                           is_constructible<value_type, initializer_list<_Up>&, _Args...>::value | ||||
|                       >::type | ||||
|              > | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void | ||||
|     emplace(initializer_list<_Up> __il, _Args&&... __args) | ||||
|     { | ||||
|         *this = nullopt; | ||||
|         ::new(_VSTD::addressof(this->__val_)) value_type(__il, _VSTD::forward<_Args>(__args)...); | ||||
|         this->__engaged_ = true; | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void | ||||
|     swap(optional& __opt) | ||||
|         noexcept(is_nothrow_move_constructible<value_type>::value && | ||||
|                  __is_nothrow_swappable<value_type>::value) | ||||
|     { | ||||
|         using _VSTD::swap; | ||||
|         if (this->__engaged_ == __opt.__engaged_) | ||||
|         { | ||||
|             if (this->__engaged_) | ||||
|                 swap(this->__val_, __opt.__val_); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             if (this->__engaged_) | ||||
|             { | ||||
|                 ::new(_VSTD::addressof(__opt.__val_)) value_type(_VSTD::move(this->__val_)); | ||||
|                 this->__val_.~value_type(); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 ::new(_VSTD::addressof(this->__val_)) value_type(_VSTD::move(__opt.__val_)); | ||||
|                 __opt.__val_.~value_type(); | ||||
|             } | ||||
|             swap(this->__engaged_, __opt.__engaged_); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr | ||||
|     value_type const* | ||||
|     operator->() const | ||||
|     { | ||||
|         _LIBCPP_ASSERT(this->__engaged_, "optional operator-> called for disengaged value"); | ||||
|         return __operator_arrow(__has_operator_addressof<value_type>{}); | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     value_type* | ||||
|     operator->() | ||||
|     { | ||||
|         _LIBCPP_ASSERT(this->__engaged_, "optional operator-> called for disengaged value"); | ||||
|         return _VSTD::addressof(this->__val_); | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr | ||||
|     const value_type& | ||||
|     operator*() const | ||||
|     { | ||||
|         _LIBCPP_ASSERT(this->__engaged_, "optional operator* called for disengaged value"); | ||||
|         return this->__val_; | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     value_type& | ||||
|     operator*() | ||||
|     { | ||||
|         _LIBCPP_ASSERT(this->__engaged_, "optional operator* called for disengaged value"); | ||||
|         return this->__val_; | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr explicit operator bool() const noexcept {return this->__engaged_;} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr value_type const& value() const | ||||
|     { | ||||
|         if (!this->__engaged_) | ||||
|             throw bad_optional_access("optional<T>::value: not engaged"); | ||||
|         return this->__val_; | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     value_type& value() | ||||
|     { | ||||
|         if (!this->__engaged_) | ||||
|             throw bad_optional_access("optional<T>::value: not engaged"); | ||||
|         return this->__val_; | ||||
|     } | ||||
|  | ||||
|     template <class _Up> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr value_type value_or(_Up&& __v) const& | ||||
|     { | ||||
|         static_assert(is_copy_constructible<value_type>::value, | ||||
|                       "optional<T>::value_or: T must be copy constructible"); | ||||
|         static_assert(is_convertible<_Up, value_type>::value, | ||||
|                       "optional<T>::value_or: U must be convertible to T"); | ||||
|         return this->__engaged_ ? this->__val_ : | ||||
|                                   static_cast<value_type>(_VSTD::forward<_Up>(__v)); | ||||
|     } | ||||
|  | ||||
|     template <class _Up> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     value_type value_or(_Up&& __v) && | ||||
|     { | ||||
|         static_assert(is_move_constructible<value_type>::value, | ||||
|                       "optional<T>::value_or: T must be move constructible"); | ||||
|         static_assert(is_convertible<_Up, value_type>::value, | ||||
|                       "optional<T>::value_or: U must be convertible to T"); | ||||
|         return this->__engaged_ ? _VSTD::move(this->__val_) : | ||||
|                                   static_cast<value_type>(_VSTD::forward<_Up>(__v)); | ||||
|     } | ||||
|  | ||||
| private: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     value_type const* | ||||
|     __operator_arrow(true_type) const | ||||
|     { | ||||
|         return _VSTD::addressof(this->__val_); | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     constexpr | ||||
|     value_type const* | ||||
|     __operator_arrow(false_type) const | ||||
|     { | ||||
|         return &this->__val_; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| constexpr | ||||
| bool | ||||
| operator==(const optional<_Tp>& __x, const optional<_Tp>& __y) | ||||
| { | ||||
|     if (static_cast<bool>(__x) != static_cast<bool>(__y)) | ||||
|         return false; | ||||
|     if (!static_cast<bool>(__x)) | ||||
|         return true; | ||||
|     return *__x == *__y; | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| constexpr | ||||
| bool | ||||
| operator<(const optional<_Tp>& __x, const optional<_Tp>& __y) | ||||
| { | ||||
|     if (!static_cast<bool>(__y)) | ||||
|         return false; | ||||
|     if (!static_cast<bool>(__x)) | ||||
|         return true; | ||||
|     return less<_Tp>{}(*__x, *__y); | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| constexpr | ||||
| bool | ||||
| operator==(const optional<_Tp>& __x, nullopt_t) noexcept | ||||
| { | ||||
|     return !static_cast<bool>(__x); | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| constexpr | ||||
| bool | ||||
| operator==(nullopt_t, const optional<_Tp>& __x) noexcept | ||||
| { | ||||
|     return !static_cast<bool>(__x); | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| constexpr | ||||
| bool | ||||
| operator<(const optional<_Tp>&, nullopt_t) noexcept | ||||
| { | ||||
|     return false; | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| constexpr | ||||
| bool | ||||
| operator<(nullopt_t, const optional<_Tp>& __x) noexcept | ||||
| { | ||||
|     return static_cast<bool>(__x); | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| constexpr | ||||
| bool | ||||
| operator==(const optional<_Tp>& __x, const _Tp& __v) | ||||
| { | ||||
|     return static_cast<bool>(__x) ? *__x == __v : false; | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| constexpr | ||||
| bool | ||||
| operator==(const _Tp& __v, const optional<_Tp>& __x) | ||||
| { | ||||
|     return static_cast<bool>(__x) ? *__x == __v : false; | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| constexpr | ||||
| bool | ||||
| operator<(const optional<_Tp>& __x, const _Tp& __v) | ||||
| { | ||||
|     return static_cast<bool>(__x) ? less<_Tp>{}(*__x, __v) : true; | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| constexpr | ||||
| bool | ||||
| operator<(const _Tp& __v, const optional<_Tp>& __x) | ||||
| { | ||||
|     return static_cast<bool>(__x) ? less<_Tp>{}(__v, *__x) : false; | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| swap(optional<_Tp>& __x, optional<_Tp>& __y) noexcept(noexcept(__x.swap(__y))) | ||||
| { | ||||
|     __x.swap(__y); | ||||
| } | ||||
|  | ||||
| template <class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| constexpr | ||||
| optional<typename decay<_Tp>::type> | ||||
| make_optional(_Tp&& __v) | ||||
| { | ||||
|     return optional<typename decay<_Tp>::type>(_VSTD::forward<_Tp>(__v)); | ||||
| } | ||||
|  | ||||
| }}}  // namespace std::experimental::__library_fundamentals_v1 | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template <class _Tp> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY hash<std::experimental::optional<_Tp> > | ||||
| { | ||||
|     typedef std::experimental::optional<_Tp> argument_type; | ||||
|     typedef size_t        result_type; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     result_type operator()(const argument_type& __opt) const _NOEXCEPT | ||||
|     { | ||||
|         return static_cast<bool>(__opt) ? hash<_Tp>()(*__opt) : 0; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
| #endif  // _LIBCPP_STD_VER > 11 | ||||
|  | ||||
| #endif  // _LIBCPP_ARRAY | ||||
| @@ -1,46 +0,0 @@ | ||||
| // -*- C++ -*- | ||||
| //===------------------------- hash_set ------------------------------------===// | ||||
| // | ||||
| //                     The LLVM Compiler Infrastructure | ||||
| // | ||||
| // This file is dual licensed under the MIT and the University of Illinois Open | ||||
| // Source Licenses. See LICENSE.TXT for details. | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| #ifndef _LIBCPP_EXT_HASH | ||||
| #define _LIBCPP_EXT_HASH | ||||
|  | ||||
| #pragma GCC system_header | ||||
|  | ||||
| #include <string> | ||||
| #include <cstring> | ||||
|  | ||||
| namespace __gnu_cxx { | ||||
| using namespace std; | ||||
|  | ||||
| template <typename _Tp> struct _LIBCPP_TYPE_VIS_ONLY hash : public std::hash<_Tp> | ||||
|     { }; | ||||
|  | ||||
| template <> struct _LIBCPP_TYPE_VIS_ONLY hash<const char*> | ||||
|     : public unary_function<const char*, size_t> | ||||
| { | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     size_t operator()(const char *__c) const _NOEXCEPT | ||||
|     { | ||||
|         return __do_string_hash(__c, __c + strlen(__c)); | ||||
|     } | ||||
| }; | ||||
|  | ||||
| template <> struct _LIBCPP_TYPE_VIS_ONLY hash<char *> | ||||
|     : public unary_function<char*, size_t> | ||||
| { | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     size_t operator()(char *__c) const _NOEXCEPT | ||||
|     { | ||||
|         return __do_string_hash<const char *>(__c, __c + strlen(__c)); | ||||
|     } | ||||
| }; | ||||
| } | ||||
|  | ||||
| #endif  // _LIBCPP_EXT_HASH | ||||
| @@ -203,15 +203,8 @@ template <class Key, class T, class Hash, class Pred, class Alloc> | ||||
| #include <__hash_table> | ||||
| #include <functional> | ||||
| #include <stdexcept> | ||||
| #include <ext/__hash> | ||||
|  | ||||
| #if __DEPRECATED | ||||
| #if defined(_MSC_VER) && ! defined(__clang__) | ||||
|     _LIBCPP_WARNING("Use of the header <ext/hash_map> is deprecated.  Migrate to <unordered_map>") | ||||
| #else | ||||
| #   warning Use of the header <ext/hash_map> is deprecated.  Migrate to <unordered_map> | ||||
| #endif | ||||
| #endif | ||||
| #warning Use of the header <ext/hash_map> is deprecated.  Migrate to <unordered_map> | ||||
|  | ||||
| #pragma GCC system_header | ||||
|  | ||||
| @@ -219,11 +212,7 @@ namespace __gnu_cxx { | ||||
|  | ||||
| using namespace std; | ||||
|  | ||||
| template <class _Tp, class _Hash, bool = is_empty<_Hash>::value | ||||
| #if __has_feature(is_final) | ||||
|                                          && !__is_final(_Hash) | ||||
| #endif | ||||
|         > | ||||
| template <class _Tp, class _Hash, bool = is_empty<_Hash>::value> | ||||
| class __hash_map_hasher | ||||
|     : private _Hash | ||||
| { | ||||
| @@ -255,11 +244,7 @@ public: | ||||
|         {return __hash_(__x);} | ||||
| }; | ||||
|  | ||||
| template <class _Tp, class _Pred, bool = is_empty<_Pred>::value | ||||
| #if __has_feature(is_final) | ||||
|                                          && !__is_final(_Pred) | ||||
| #endif | ||||
|          > | ||||
| template <class _Tp, class _Pred, bool = is_empty<_Pred>::value> | ||||
| class __hash_map_equal | ||||
|     : private _Pred | ||||
| { | ||||
| @@ -356,16 +341,16 @@ public: | ||||
|     void operator()(pointer __p) | ||||
|     { | ||||
|         if (__second_constructed) | ||||
|             __alloc_traits::destroy(__na_, _VSTD::addressof(__p->__value_.second)); | ||||
|             __alloc_traits::destroy(__na_, _STD::addressof(__p->__value_.second)); | ||||
|         if (__first_constructed) | ||||
|             __alloc_traits::destroy(__na_, _VSTD::addressof(__p->__value_.first)); | ||||
|             __alloc_traits::destroy(__na_, _STD::addressof(__p->__value_.first)); | ||||
|         if (__p) | ||||
|             __alloc_traits::deallocate(__na_, __p, 1); | ||||
|     } | ||||
| }; | ||||
|  | ||||
| template <class _HashIterator> | ||||
| class _LIBCPP_TYPE_VIS_ONLY __hash_map_iterator | ||||
| class _LIBCPP_VISIBLE __hash_map_iterator | ||||
| { | ||||
|     _HashIterator __i_; | ||||
|  | ||||
| @@ -408,15 +393,15 @@ public: | ||||
|     bool operator!=(const __hash_map_iterator& __x, const __hash_map_iterator& __y) | ||||
|         {return __x.__i_ != __y.__i_;} | ||||
|  | ||||
|     template <class, class, class, class, class> friend class _LIBCPP_TYPE_VIS_ONLY hash_map; | ||||
|     template <class, class, class, class, class> friend class _LIBCPP_TYPE_VIS_ONLY hash_multimap; | ||||
|     template <class> friend class _LIBCPP_TYPE_VIS_ONLY __hash_const_iterator; | ||||
|     template <class> friend class _LIBCPP_TYPE_VIS_ONLY __hash_const_local_iterator; | ||||
|     template <class> friend class _LIBCPP_TYPE_VIS_ONLY __hash_map_const_iterator; | ||||
|     template <class, class, class, class, class> friend class _LIBCPP_VISIBLE hash_map; | ||||
|     template <class, class, class, class, class> friend class _LIBCPP_VISIBLE hash_multimap; | ||||
|     template <class> friend class _LIBCPP_VISIBLE __hash_const_iterator; | ||||
|     template <class> friend class _LIBCPP_VISIBLE __hash_const_local_iterator; | ||||
|     template <class> friend class _LIBCPP_VISIBLE __hash_map_const_iterator; | ||||
| }; | ||||
|  | ||||
| template <class _HashIterator> | ||||
| class _LIBCPP_TYPE_VIS_ONLY __hash_map_const_iterator | ||||
| class _LIBCPP_VISIBLE __hash_map_const_iterator | ||||
| { | ||||
|     _HashIterator __i_; | ||||
|  | ||||
| @@ -467,21 +452,20 @@ public: | ||||
|     bool operator!=(const __hash_map_const_iterator& __x, const __hash_map_const_iterator& __y) | ||||
|         {return __x.__i_ != __y.__i_;} | ||||
|  | ||||
|     template <class, class, class, class, class> friend class _LIBCPP_TYPE_VIS_ONLY hash_map; | ||||
|     template <class, class, class, class, class> friend class _LIBCPP_TYPE_VIS_ONLY hash_multimap; | ||||
|     template <class> friend class _LIBCPP_TYPE_VIS_ONLY __hash_const_iterator; | ||||
|     template <class> friend class _LIBCPP_TYPE_VIS_ONLY __hash_const_local_iterator; | ||||
|     template <class, class, class, class, class> friend class _LIBCPP_VISIBLE hash_map; | ||||
|     template <class, class, class, class, class> friend class _LIBCPP_VISIBLE hash_multimap; | ||||
|     template <class> friend class _LIBCPP_VISIBLE __hash_const_iterator; | ||||
|     template <class> friend class _LIBCPP_VISIBLE __hash_const_local_iterator; | ||||
| }; | ||||
|  | ||||
| template <class _Key, class _Tp, class _Hash = hash<_Key>, class _Pred = equal_to<_Key>, | ||||
|           class _Alloc = allocator<pair<const _Key, _Tp> > > | ||||
| class _LIBCPP_TYPE_VIS_ONLY hash_map | ||||
| class _LIBCPP_VISIBLE hash_map | ||||
| { | ||||
| public: | ||||
|     // types | ||||
|     typedef _Key                                           key_type; | ||||
|     typedef _Tp                                            mapped_type; | ||||
|     typedef _Tp                                            data_type; | ||||
|     typedef _Hash                                          hasher; | ||||
|     typedef _Pred                                          key_equal; | ||||
|     typedef _Alloc                                         allocator_type; | ||||
| @@ -511,8 +495,8 @@ private: | ||||
|     typedef typename __table::__node_traits                __node_traits; | ||||
|     typedef typename __table::__node_allocator             __node_allocator; | ||||
|     typedef typename __table::__node                       __node; | ||||
|     typedef __hash_map_node_destructor<__node_allocator>   _Dp; | ||||
|     typedef unique_ptr<__node, _Dp>                         __node_holder; | ||||
|     typedef __hash_map_node_destructor<__node_allocator>   _D; | ||||
|     typedef unique_ptr<__node, _D>                         __node_holder; | ||||
|     typedef allocator_traits<allocator_type>               __alloc_traits; | ||||
| public: | ||||
|     typedef typename __alloc_traits::pointer         pointer; | ||||
| @@ -565,8 +549,6 @@ public: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     pair<iterator, bool> insert(const value_type& __x) | ||||
|         {return __table_.__insert_unique(__x);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator insert(const_iterator, const value_type& __x) {return insert(__x).first;} | ||||
|     template <class _InputIterator> | ||||
|         void insert(_InputIterator __first, _InputIterator __last); | ||||
|  | ||||
| @@ -683,12 +665,12 @@ typename hash_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__node_holder | ||||
| hash_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node(const key_type& __k) | ||||
| { | ||||
|     __node_allocator& __na = __table_.__node_alloc(); | ||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _Dp(__na)); | ||||
|     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.first), __k); | ||||
|     __node_holder __h(__node_traits::allocate(__na, 1), _D(__na)); | ||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.first), __k); | ||||
|     __h.get_deleter().__first_constructed = true; | ||||
|     __node_traits::construct(__na, _VSTD::addressof(__h->__value_.second)); | ||||
|     __node_traits::construct(__na, _STD::addressof(__h->__value_.second)); | ||||
|     __h.get_deleter().__second_constructed = true; | ||||
|     return _VSTD::move(__h);  // explicitly moved for C++03 | ||||
|     return _STD::move(__h); | ||||
| } | ||||
|  | ||||
| template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc> | ||||
| @@ -754,13 +736,12 @@ operator!=(const hash_map<_Key, _Tp, _Hash, _Pred, _Alloc>& __x, | ||||
|  | ||||
| template <class _Key, class _Tp, class _Hash = hash<_Key>, class _Pred = equal_to<_Key>, | ||||
|           class _Alloc = allocator<pair<const _Key, _Tp> > > | ||||
| class _LIBCPP_TYPE_VIS_ONLY hash_multimap | ||||
| class _LIBCPP_VISIBLE hash_multimap | ||||
| { | ||||
| public: | ||||
|     // types | ||||
|     typedef _Key                                           key_type; | ||||
|     typedef _Tp                                            mapped_type; | ||||
|     typedef _Tp                                            data_type; | ||||
|     typedef _Hash                                          hasher; | ||||
|     typedef _Pred                                          key_equal; | ||||
|     typedef _Alloc                                         allocator_type; | ||||
| @@ -788,8 +769,8 @@ private: | ||||
|     typedef typename __table::__node_traits                __node_traits; | ||||
|     typedef typename __table::__node_allocator             __node_allocator; | ||||
|     typedef typename __table::__node                       __node; | ||||
|     typedef __hash_map_node_destructor<__node_allocator>   _Dp; | ||||
|     typedef unique_ptr<__node, _Dp>                         __node_holder; | ||||
|     typedef __hash_map_node_destructor<__node_allocator>   _D; | ||||
|     typedef unique_ptr<__node, _D>                         __node_holder; | ||||
|     typedef allocator_traits<allocator_type>               __alloc_traits; | ||||
| public: | ||||
|     typedef typename __alloc_traits::pointer         pointer; | ||||
| @@ -842,8 +823,6 @@ public: | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator insert(const value_type& __x) {return __table_.__insert_multi(__x);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator insert(const_iterator, const value_type& __x) {return insert(__x);} | ||||
|     template <class _InputIterator> | ||||
|         void insert(_InputIterator __first, _InputIterator __last); | ||||
|  | ||||
| @@ -984,9 +963,9 @@ operator==(const hash_multimap<_Key, _Tp, _Hash, _Pred, _Alloc>& __x, | ||||
|     { | ||||
|         _EqRng __xeq = __x.equal_range(__i->first); | ||||
|         _EqRng __yeq = __y.equal_range(__i->first); | ||||
|         if (_VSTD::distance(__xeq.first, __xeq.second) != | ||||
|             _VSTD::distance(__yeq.first, __yeq.second) || | ||||
|                   !_VSTD::is_permutation(__xeq.first, __xeq.second, __yeq.first)) | ||||
|         if (_STD::distance(__xeq.first, __xeq.second) != | ||||
|             _STD::distance(__yeq.first, __yeq.second) || | ||||
|                   !_STD::is_permutation(__xeq.first, __xeq.second, __yeq.first)) | ||||
|             return false; | ||||
|         __i = __xeq.second; | ||||
|     } | ||||
|   | ||||
| @@ -196,23 +196,16 @@ template <class Value, class Hash, class Pred, class Alloc> | ||||
| #include <__config> | ||||
| #include <__hash_table> | ||||
| #include <functional> | ||||
| #include <ext/__hash> | ||||
|  | ||||
| #if __DEPRECATED | ||||
| #if defined(_MSC_VER) && ! defined(__clang__) | ||||
|     _LIBCPP_WARNING("Use of the header <ext/hash_set> is deprecated.  Migrate to <unordered_set>") | ||||
| #else | ||||
| #   warning Use of the header <ext/hash_set> is deprecated.  Migrate to <unordered_set> | ||||
| #endif | ||||
| #endif | ||||
| #warning Use of the header <ext/hash_set> is deprecated.  Migrate to <unordered_set> | ||||
|  | ||||
| namespace __gnu_cxx { | ||||
|  | ||||
| using namespace std; | ||||
|  | ||||
| template <class _Value, class _Hash = hash<_Value>, class _Pred = equal_to<_Value>, | ||||
| template <class _Value, class _Hash = std::hash<_Value>, class _Pred = equal_to<_Value>, | ||||
|           class _Alloc = allocator<_Value> > | ||||
| class _LIBCPP_TYPE_VIS_ONLY hash_set | ||||
| class _LIBCPP_VISIBLE hash_set | ||||
| { | ||||
| public: | ||||
|     // types | ||||
| @@ -279,8 +272,6 @@ public: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     pair<iterator, bool> insert(const value_type& __x) | ||||
|         {return __table_.__insert_unique(__x);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator insert(const_iterator, const value_type& __x) {return insert(__x).first;} | ||||
|     template <class _InputIterator> | ||||
|         void insert(_InputIterator __first, _InputIterator __last); | ||||
|  | ||||
| @@ -433,7 +424,7 @@ operator!=(const hash_set<_Value, _Hash, _Pred, _Alloc>& __x, | ||||
|  | ||||
| template <class _Value, class _Hash = hash<_Value>, class _Pred = equal_to<_Value>, | ||||
|           class _Alloc = allocator<_Value> > | ||||
| class _LIBCPP_TYPE_VIS_ONLY hash_multiset | ||||
| class _LIBCPP_VISIBLE hash_multiset | ||||
| { | ||||
| public: | ||||
|     // types | ||||
| @@ -499,8 +490,6 @@ public: | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator insert(const value_type& __x) {return __table_.__insert_multi(__x);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator insert(const_iterator, const value_type& __x) {return insert(__x);} | ||||
|     template <class _InputIterator> | ||||
|         void insert(_InputIterator __first, _InputIterator __last); | ||||
|  | ||||
| @@ -638,9 +627,9 @@ operator==(const hash_multiset<_Value, _Hash, _Pred, _Alloc>& __x, | ||||
|     { | ||||
|         _EqRng __xeq = __x.equal_range(*__i); | ||||
|         _EqRng __yeq = __y.equal_range(*__i); | ||||
|         if (_VSTD::distance(__xeq.first, __xeq.second) != | ||||
|             _VSTD::distance(__yeq.first, __yeq.second) || | ||||
|                   !_VSTD::is_permutation(__xeq.first, __xeq.second, __yeq.first)) | ||||
|         if (_STD::distance(__xeq.first, __xeq.second) != | ||||
|             _STD::distance(__yeq.first, __yeq.second) || | ||||
|                   !_STD::is_permutation(__xeq.first, __xeq.second, __yeq.first)) | ||||
|             return false; | ||||
|         __i = __xeq.second; | ||||
|     } | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										151
									
								
								include/fstream
									
									
									
									
									
								
							
							
						
						
									
										151
									
								
								include/fstream
									
									
									
									
									
								
							| @@ -171,16 +171,12 @@ typedef basic_fstream<wchar_t> wfstream; | ||||
| #include <__locale> | ||||
| #include <cstdio> | ||||
|  | ||||
| #include <__undef_min_max> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| class _LIBCPP_TYPE_VIS_ONLY basic_filebuf | ||||
| class _LIBCPP_VISIBLE basic_filebuf | ||||
|     : public basic_streambuf<_CharT, _Traits> | ||||
| { | ||||
| public: | ||||
| @@ -234,7 +230,6 @@ private: | ||||
|     FILE* __file_; | ||||
|     const codecvt<char_type, char, state_type>* __cv_; | ||||
|     state_type __st_; | ||||
|     state_type __st_last_; | ||||
|     ios_base::openmode __om_; | ||||
|     ios_base::openmode __cm_; | ||||
|     bool __owns_eb_; | ||||
| @@ -254,20 +249,14 @@ basic_filebuf<_CharT, _Traits>::basic_filebuf() | ||||
|       __intbuf_(0), | ||||
|       __ibs_(0), | ||||
|       __file_(0), | ||||
|       __cv_(nullptr), | ||||
|       __cv_(&use_facet<codecvt<char_type, char, state_type> >(this->getloc())), | ||||
|       __st_(), | ||||
|       __st_last_(), | ||||
|       __om_(0), | ||||
|       __cm_(0), | ||||
|       __owns_eb_(false), | ||||
|       __owns_ib_(false), | ||||
|       __always_noconv_(false) | ||||
|       __always_noconv_(__cv_->always_noconv()) | ||||
| { | ||||
|     if (has_facet<codecvt<char_type, char, state_type> >(this->getloc())) | ||||
|     { | ||||
|         __cv_ = &use_facet<codecvt<char_type, char, state_type> >(this->getloc()); | ||||
|         __always_noconv_ = __cv_->always_noconv(); | ||||
|     } | ||||
|     setbuf(0, 4096); | ||||
| } | ||||
|  | ||||
| @@ -295,7 +284,6 @@ basic_filebuf<_CharT, _Traits>::basic_filebuf(basic_filebuf&& __rhs) | ||||
|     __file_ = __rhs.__file_; | ||||
|     __cv_ = __rhs.__cv_; | ||||
|     __st_ = __rhs.__st_; | ||||
|     __st_last_ = __rhs.__st_last_; | ||||
|     __om_ = __rhs.__om_; | ||||
|     __cm_ = __rhs.__cm_; | ||||
|     __owns_eb_ = __rhs.__owns_eb_; | ||||
| @@ -328,7 +316,6 @@ basic_filebuf<_CharT, _Traits>::basic_filebuf(basic_filebuf&& __rhs) | ||||
|     __rhs.__ibs_ = 0; | ||||
|     __rhs.__file_ = 0; | ||||
|     __rhs.__st_ = state_type(); | ||||
|     __rhs.__st_last_ = state_type(); | ||||
|     __rhs.__om_ = 0; | ||||
|     __rhs.__cm_ = 0; | ||||
|     __rhs.__owns_eb_ = false; | ||||
| @@ -344,7 +331,6 @@ basic_filebuf<_CharT, _Traits>::operator=(basic_filebuf&& __rhs) | ||||
| { | ||||
|     close(); | ||||
|     swap(__rhs); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| @@ -376,9 +362,9 @@ basic_filebuf<_CharT, _Traits>::swap(basic_filebuf& __rhs) | ||||
|     basic_streambuf<char_type, traits_type>::swap(__rhs); | ||||
|     if (__extbuf_ != __extbuf_min_ && __rhs.__extbuf_ != __rhs.__extbuf_min_) | ||||
|     { | ||||
|         _VSTD::swap(__extbuf_, __rhs.__extbuf_); | ||||
|         _VSTD::swap(__extbufnext_, __rhs.__extbufnext_); | ||||
|         _VSTD::swap(__extbufend_, __rhs.__extbufend_); | ||||
|         _STD::swap(__extbuf_, __rhs.__extbuf_); | ||||
|         _STD::swap(__extbufnext_, __rhs.__extbufnext_); | ||||
|         _STD::swap(__extbufend_, __rhs.__extbufend_); | ||||
|     } | ||||
|     else | ||||
|     { | ||||
| @@ -401,18 +387,17 @@ basic_filebuf<_CharT, _Traits>::swap(basic_filebuf& __rhs) | ||||
|         __rhs.__extbufnext_ = __rhs.__extbuf_ + __ln; | ||||
|         __rhs.__extbufend_ = __rhs.__extbuf_ + __le; | ||||
|     } | ||||
|     _VSTD::swap(__ebs_, __rhs.__ebs_); | ||||
|     _VSTD::swap(__intbuf_, __rhs.__intbuf_); | ||||
|     _VSTD::swap(__ibs_, __rhs.__ibs_); | ||||
|     _VSTD::swap(__file_, __rhs.__file_); | ||||
|     _VSTD::swap(__cv_, __rhs.__cv_); | ||||
|     _VSTD::swap(__st_, __rhs.__st_); | ||||
|     _VSTD::swap(__st_last_, __rhs.__st_last_); | ||||
|     _VSTD::swap(__om_, __rhs.__om_); | ||||
|     _VSTD::swap(__cm_, __rhs.__cm_); | ||||
|     _VSTD::swap(__owns_eb_, __rhs.__owns_eb_); | ||||
|     _VSTD::swap(__owns_ib_, __rhs.__owns_ib_); | ||||
|     _VSTD::swap(__always_noconv_, __rhs.__always_noconv_); | ||||
|     _STD::swap(__ebs_, __rhs.__ebs_); | ||||
|     _STD::swap(__intbuf_, __rhs.__intbuf_); | ||||
|     _STD::swap(__ibs_, __rhs.__ibs_); | ||||
|     _STD::swap(__file_, __rhs.__file_); | ||||
|     _STD::swap(__cv_, __rhs.__cv_); | ||||
|     _STD::swap(__st_, __rhs.__st_); | ||||
|     _STD::swap(__om_, __rhs.__om_); | ||||
|     _STD::swap(__cm_, __rhs.__cm_); | ||||
|     _STD::swap(__owns_eb_, __rhs.__owns_eb_); | ||||
|     _STD::swap(__owns_ib_, __rhs.__owns_ib_); | ||||
|     _STD::swap(__always_noconv_, __rhs.__always_noconv_); | ||||
|     if (this->eback() == (char_type*)__rhs.__extbuf_min_) | ||||
|     { | ||||
|         ptrdiff_t __n = this->gptr() - this->eback(); | ||||
| @@ -560,7 +545,7 @@ basic_filebuf<_CharT, _Traits>::close() | ||||
|     { | ||||
|         __rt = this; | ||||
|         unique_ptr<FILE, int(*)(FILE*)> __h(__file_, fclose); | ||||
|         if (sync()) | ||||
|         if ((__cm_ & ios_base::out) && sync()) | ||||
|             __rt = 0; | ||||
|         if (fclose(__h.release()) == 0) | ||||
|             __file_ = 0; | ||||
| @@ -602,22 +587,18 @@ basic_filebuf<_CharT, _Traits>::underflow() | ||||
|             memmove(__extbuf_, __extbufnext_, __extbufend_ - __extbufnext_); | ||||
|             __extbufnext_ = __extbuf_ + (__extbufend_ - __extbufnext_); | ||||
|             __extbufend_ = __extbuf_ + (__extbuf_ == __extbuf_min_ ? sizeof(__extbuf_min_) : __ebs_); | ||||
|             size_t __nmemb = _VSTD::min(static_cast<size_t>(__ibs_ - __unget_sz), | ||||
|             size_t __nmemb = _STD::min(static_cast<size_t>(this->egptr() - this->eback() - __unget_sz), | ||||
|                                  static_cast<size_t>(__extbufend_ - __extbufnext_)); | ||||
|             codecvt_base::result __r; | ||||
|             __st_last_ = __st_; | ||||
|             state_type __svs = __st_; | ||||
|             size_t __nr = fread((void*)__extbufnext_, 1, __nmemb, __file_); | ||||
|             if (__nr != 0) | ||||
|             { | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|                 if (!__cv_) | ||||
|                     throw bad_cast(); | ||||
| #endif | ||||
|                 __extbufend_ = __extbufnext_ + __nr; | ||||
|                 char_type*  __inext; | ||||
|                 __r = __cv_->in(__st_, __extbuf_, __extbufend_, __extbufnext_, | ||||
|                                        this->eback() + __unget_sz, | ||||
|                                        this->eback() + __ibs_, __inext); | ||||
|                                        this->egptr(), __inext); | ||||
|                 if (__r == codecvt_base::noconv) | ||||
|                 { | ||||
|                     this->setg((char_type*)__extbuf_, (char_type*)__extbuf_, (char_type*)__extbufend_); | ||||
| @@ -691,10 +672,6 @@ basic_filebuf<_CharT, _Traits>::overflow(int_type __c) | ||||
|             codecvt_base::result __r; | ||||
|             do | ||||
|             { | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|                 if (!__cv_) | ||||
|                     throw bad_cast(); | ||||
| #endif | ||||
|                 const char_type* __e; | ||||
|                 __r = __cv_->out(__st_, this->pbase(), this->pptr(), __e, | ||||
|                                         __extbuf_, __extbuf_ + __ebs_, __extbe); | ||||
| @@ -784,10 +761,6 @@ typename basic_filebuf<_CharT, _Traits>::pos_type | ||||
| basic_filebuf<_CharT, _Traits>::seekoff(off_type __off, ios_base::seekdir __way, | ||||
|                                         ios_base::openmode) | ||||
| { | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     if (!__cv_) | ||||
|         throw bad_cast(); | ||||
| #endif | ||||
|     int __width = __cv_->encoding(); | ||||
|     if (__file_ == 0 || (__width <= 0 && __off != 0) || sync()) | ||||
|         return pos_type(off_type(-1)); | ||||
| @@ -807,15 +780,9 @@ basic_filebuf<_CharT, _Traits>::seekoff(off_type __off, ios_base::seekdir __way, | ||||
|     default: | ||||
|         return pos_type(off_type(-1)); | ||||
|     } | ||||
| #if _WIN32 | ||||
|     if (fseek(__file_, __width > 0 ? __width * __off : 0, __whence)) | ||||
|         return pos_type(off_type(-1)); | ||||
|     pos_type __r = ftell(__file_); | ||||
| #else | ||||
|     if (fseeko(__file_, __width > 0 ? __width * __off : 0, __whence)) | ||||
|         return pos_type(off_type(-1)); | ||||
|     pos_type __r = ftello(__file_); | ||||
| #endif | ||||
|     __r.state(__st_); | ||||
|     return __r; | ||||
| } | ||||
| @@ -826,14 +793,8 @@ basic_filebuf<_CharT, _Traits>::seekpos(pos_type __sp, ios_base::openmode) | ||||
| { | ||||
|     if (__file_ == 0 || sync()) | ||||
|         return pos_type(off_type(-1)); | ||||
| #if _WIN32 | ||||
|     if (fseek(__file_, __sp, SEEK_SET)) | ||||
|         return pos_type(off_type(-1)); | ||||
| #else | ||||
|     if (fseeko(__file_, __sp, SEEK_SET)) | ||||
|         return pos_type(off_type(-1)); | ||||
| #endif | ||||
|     __st_ = __sp.state(); | ||||
|     return __sp; | ||||
| } | ||||
|  | ||||
| @@ -843,10 +804,6 @@ basic_filebuf<_CharT, _Traits>::sync() | ||||
| { | ||||
|     if (__file_ == 0) | ||||
|         return 0; | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     if (!__cv_) | ||||
|         throw bad_cast(); | ||||
| #endif | ||||
|     if (__cm_ & ios_base::out) | ||||
|     { | ||||
|         if (this->pptr() != this->pbase()) | ||||
| @@ -869,8 +826,6 @@ basic_filebuf<_CharT, _Traits>::sync() | ||||
|     else if (__cm_ & ios_base::in) | ||||
|     { | ||||
|         off_type __c; | ||||
|         state_type __state = __st_last_; | ||||
|         bool __update_st = false; | ||||
|         if (__always_noconv_) | ||||
|             __c = this->egptr() - this->gptr(); | ||||
|         else | ||||
| @@ -883,24 +838,32 @@ basic_filebuf<_CharT, _Traits>::sync() | ||||
|             { | ||||
|                 if (this->gptr() != this->egptr()) | ||||
|                 { | ||||
|                     const int __off =  __cv_->length(__state, __extbuf_, | ||||
|                                                      __extbufnext_, | ||||
|                                                      this->gptr() - this->eback()); | ||||
|                     __c += __extbufnext_ - __extbuf_ - __off; | ||||
|                     __update_st = true; | ||||
|                     reverse(this->gptr(), this->egptr()); | ||||
|                     codecvt_base::result __r; | ||||
|                     const char_type* __e = this->gptr(); | ||||
|                     char* __extbe; | ||||
|                     do | ||||
|                     { | ||||
|                         __r = __cv_->out(__st_, __e, this->egptr(), __e, | ||||
|                                          __extbuf_, __extbuf_ + __ebs_, __extbe); | ||||
|                         switch (__r) | ||||
|                         { | ||||
|                         case codecvt_base::noconv: | ||||
|                             __c += this->egptr() - this->gptr(); | ||||
|                             break; | ||||
|                         case codecvt_base::ok: | ||||
|                         case codecvt_base::partial: | ||||
|                             __c += __extbe - __extbuf_; | ||||
|                             break; | ||||
|                         default: | ||||
|                             return -1; | ||||
|                         } | ||||
|                     } while (__r == codecvt_base::partial); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
| #if _WIN32 | ||||
|         if (fseek(__file_, -__c, SEEK_CUR)) | ||||
|             return -1; | ||||
| #else | ||||
|         if (fseeko(__file_, -__c, SEEK_CUR)) | ||||
|             return -1; | ||||
| #endif | ||||
|         if (__update_st) | ||||
|             __st_ = __state; | ||||
|         __extbufnext_ = __extbufend_ = __extbuf_; | ||||
|         this->setg(0, 0, 0); | ||||
|         __cm_ = 0; | ||||
|     } | ||||
| @@ -994,7 +957,7 @@ basic_filebuf<_CharT, _Traits>::__write_mode() | ||||
| // basic_ifstream | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| class _LIBCPP_TYPE_VIS_ONLY basic_ifstream | ||||
| class _LIBCPP_VISIBLE basic_ifstream | ||||
|     : public basic_istream<_CharT, _Traits> | ||||
| { | ||||
| public: | ||||
| @@ -1056,8 +1019,8 @@ basic_ifstream<_CharT, _Traits>::basic_ifstream(const string& __s, ios_base::ope | ||||
| template <class _CharT, class _Traits> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| basic_ifstream<_CharT, _Traits>::basic_ifstream(basic_ifstream&& __rhs) | ||||
|     : basic_istream<char_type, traits_type>(_VSTD::move(__rhs)), | ||||
|       __sb_(_VSTD::move(__rhs.__sb_)) | ||||
|     : basic_istream<char_type, traits_type>(_STD::move(__rhs)), | ||||
|       __sb_(_STD::move(__rhs.__sb_)) | ||||
| { | ||||
|     this->set_rdbuf(&__sb_); | ||||
| } | ||||
| @@ -1067,8 +1030,8 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| basic_ifstream<_CharT, _Traits>& | ||||
| basic_ifstream<_CharT, _Traits>::operator=(basic_ifstream&& __rhs) | ||||
| { | ||||
|     basic_istream<char_type, traits_type>::operator=(_VSTD::move(__rhs)); | ||||
|     __sb_ = _VSTD::move(__rhs.__sb_); | ||||
|     basic_istream<char_type, traits_type>::operator=(_STD::move(__rhs)); | ||||
|     __sb_ = _STD::move(__rhs.__sb_); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| @@ -1139,7 +1102,7 @@ basic_ifstream<_CharT, _Traits>::close() | ||||
| // basic_ofstream | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| class _LIBCPP_TYPE_VIS_ONLY basic_ofstream | ||||
| class _LIBCPP_VISIBLE basic_ofstream | ||||
|     : public basic_ostream<_CharT, _Traits> | ||||
| { | ||||
| public: | ||||
| @@ -1201,8 +1164,8 @@ basic_ofstream<_CharT, _Traits>::basic_ofstream(const string& __s, ios_base::ope | ||||
| template <class _CharT, class _Traits> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| basic_ofstream<_CharT, _Traits>::basic_ofstream(basic_ofstream&& __rhs) | ||||
|     : basic_ostream<char_type, traits_type>(_VSTD::move(__rhs)), | ||||
|       __sb_(_VSTD::move(__rhs.__sb_)) | ||||
|     : basic_ostream<char_type, traits_type>(_STD::move(__rhs)), | ||||
|       __sb_(_STD::move(__rhs.__sb_)) | ||||
| { | ||||
|     this->set_rdbuf(&__sb_); | ||||
| } | ||||
| @@ -1212,8 +1175,8 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| basic_ofstream<_CharT, _Traits>& | ||||
| basic_ofstream<_CharT, _Traits>::operator=(basic_ofstream&& __rhs) | ||||
| { | ||||
|     basic_ostream<char_type, traits_type>::operator=(_VSTD::move(__rhs)); | ||||
|     __sb_ = _VSTD::move(__rhs.__sb_); | ||||
|     basic_ostream<char_type, traits_type>::operator=(_STD::move(__rhs)); | ||||
|     __sb_ = _STD::move(__rhs.__sb_); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| @@ -1284,7 +1247,7 @@ basic_ofstream<_CharT, _Traits>::close() | ||||
| // basic_fstream | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| class _LIBCPP_TYPE_VIS_ONLY basic_fstream | ||||
| class _LIBCPP_VISIBLE basic_fstream | ||||
|     : public basic_iostream<_CharT, _Traits> | ||||
| { | ||||
| public: | ||||
| @@ -1346,8 +1309,8 @@ basic_fstream<_CharT, _Traits>::basic_fstream(const string& __s, ios_base::openm | ||||
| template <class _CharT, class _Traits> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| basic_fstream<_CharT, _Traits>::basic_fstream(basic_fstream&& __rhs) | ||||
|     : basic_iostream<char_type, traits_type>(_VSTD::move(__rhs)), | ||||
|       __sb_(_VSTD::move(__rhs.__sb_)) | ||||
|     : basic_iostream<char_type, traits_type>(_STD::move(__rhs)), | ||||
|       __sb_(_STD::move(__rhs.__sb_)) | ||||
| { | ||||
|     this->set_rdbuf(&__sb_); | ||||
| } | ||||
| @@ -1357,8 +1320,8 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| basic_fstream<_CharT, _Traits>& | ||||
| basic_fstream<_CharT, _Traits>::operator=(basic_fstream&& __rhs) | ||||
| { | ||||
|     basic_iostream<char_type, traits_type>::operator=(_VSTD::move(__rhs)); | ||||
|     __sb_ = _VSTD::move(__rhs.__sb_); | ||||
|     basic_iostream<char_type, traits_type>::operator=(_STD::move(__rhs)); | ||||
|     __sb_ = _STD::move(__rhs.__sb_); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
|   | ||||
							
								
								
									
										1497
									
								
								include/functional
									
									
									
									
									
								
							
							
						
						
									
										1497
									
								
								include/functional
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1368
									
								
								include/future
									
									
									
									
									
								
							
							
						
						
									
										1368
									
								
								include/future
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -29,15 +29,15 @@ public: | ||||
|     typedef const E* iterator; | ||||
|     typedef const E* const_iterator; | ||||
|  | ||||
|     initializer_list() noexcept; // constexpr in C++14 | ||||
|     initializer_list(); | ||||
|  | ||||
|     size_t   size()  const noexcept; // constexpr in C++14 | ||||
|     const E* begin() const noexcept; // constexpr in C++14 | ||||
|     const E* end()   const noexcept; // constexpr in C++14 | ||||
|     size_t   size()  const; | ||||
|     const E* begin() const; | ||||
|     const E* end()   const; | ||||
| }; | ||||
|  | ||||
| template<class E> const E* begin(initializer_list<E> il) noexcept; // constexpr in C++14 | ||||
| template<class E> const E* end(initializer_list<E> il) noexcept; // constexpr in C++14 | ||||
| template<class E> const E* begin(initializer_list<E> il); | ||||
| template<class E> const E* end(initializer_list<E> il); | ||||
|  | ||||
| }  // std | ||||
|  | ||||
| @@ -46,73 +46,54 @@ template<class E> const E* end(initializer_list<E> il) noexcept; // constexpr in | ||||
| #include <__config> | ||||
| #include <cstddef> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| namespace std  // purposefully not versioned | ||||
| { | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS | ||||
|  | ||||
| template<class _Ep> | ||||
| class _LIBCPP_TYPE_VIS_ONLY initializer_list | ||||
| template<class _E> | ||||
| class _LIBCPP_VISIBLE initializer_list | ||||
| { | ||||
|     const _Ep* __begin_; | ||||
|     const _E* __begin_; | ||||
|     size_t    __size_; | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
|     initializer_list(const _Ep* __b, size_t __s) _NOEXCEPT | ||||
|     initializer_list(const _E* __b, size_t __s) | ||||
|         : __begin_(__b), | ||||
|           __size_(__s) | ||||
|         {} | ||||
| public: | ||||
|     typedef _Ep        value_type; | ||||
|     typedef const _Ep& reference; | ||||
|     typedef const _Ep& const_reference; | ||||
|     typedef _E        value_type; | ||||
|     typedef const _E& reference; | ||||
|     typedef const _E& const_reference; | ||||
|     typedef size_t    size_type; | ||||
|  | ||||
|     typedef const _Ep* iterator; | ||||
|     typedef const _Ep* const_iterator; | ||||
|     typedef const _E* iterator; | ||||
|     typedef const _E* const_iterator; | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
|     initializer_list() _NOEXCEPT : __begin_(nullptr), __size_(0) {} | ||||
|     _LIBCPP_ALWAYS_INLINE initializer_list() : __begin_(nullptr), __size_(0) {} | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
|     size_t    size()  const _NOEXCEPT {return __size_;} | ||||
|      | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
|     const _Ep* begin() const _NOEXCEPT {return __begin_;} | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
|     const _Ep* end()   const _NOEXCEPT {return __begin_ + __size_;} | ||||
|     _LIBCPP_ALWAYS_INLINE size_t    size()  const {return __size_;} | ||||
|     _LIBCPP_ALWAYS_INLINE const _E* begin() const {return __begin_;} | ||||
|     _LIBCPP_ALWAYS_INLINE const _E* end()   const {return __begin_ + __size_;} | ||||
| }; | ||||
|  | ||||
| template<class _Ep> | ||||
| template<class _E> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| const _Ep* | ||||
| begin(initializer_list<_Ep> __il) _NOEXCEPT | ||||
| const _E* | ||||
| begin(initializer_list<_E> __il) | ||||
| { | ||||
|     return __il.begin(); | ||||
| } | ||||
|  | ||||
| template<class _Ep> | ||||
| template<class _E> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| _LIBCPP_CONSTEXPR_AFTER_CXX11 | ||||
| const _Ep* | ||||
| end(initializer_list<_Ep> __il) _NOEXCEPT | ||||
| const _E* | ||||
| end(initializer_list<_E> __il) | ||||
| { | ||||
|     return __il.end(); | ||||
| } | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS | ||||
|  | ||||
| }  // std | ||||
|  | ||||
| #endif  // _LIBCPP_INITIALIZER_LIST | ||||
|   | ||||
							
								
								
									
										203
									
								
								include/iomanip
									
									
									
									
									
								
							
							
						
						
									
										203
									
								
								include/iomanip
									
									
									
									
									
								
							| @@ -14,8 +14,6 @@ | ||||
| /* | ||||
|     iomanip synopsis | ||||
|  | ||||
| namespace std { | ||||
|  | ||||
| // types T1, T2, ... are unspecified implementation types | ||||
| T1 resetiosflags(ios_base::fmtflags mask); | ||||
| T2 setiosflags (ios_base::fmtflags mask); | ||||
| @@ -28,17 +26,6 @@ template <class charT, class moneyT> T8 put_money(const moneyT& mon, bool intl = | ||||
| template <class charT> T9 get_time(struct tm* tmb, const charT* fmt); | ||||
| template <class charT> T10 put_time(const struct tm* tmb, const charT* fmt); | ||||
|  | ||||
| template <class charT> | ||||
|   T11 quoted(const charT* s, charT delim=charT('"'), charT escape=charT('\\')); // C++14 | ||||
|  | ||||
| template <class charT, class traits, class Allocator> | ||||
|   T12 quoted(const basic_string<charT, traits, Allocator>& s, | ||||
|              charT delim=charT('"'), charT escape=charT('\\')); // C++14 | ||||
|  | ||||
| template <class charT, class traits, class Allocator> | ||||
|   T13 quoted(basic_string<charT, traits, Allocator>& s, | ||||
|              charT delim=charT('"'), charT escape=charT('\\')); // C++14 | ||||
|  | ||||
| }  // std | ||||
|  | ||||
| */ | ||||
| @@ -46,9 +33,7 @@ template <class charT, class traits, class Allocator> | ||||
| #include <__config> | ||||
| #include <istream> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| @@ -290,10 +275,10 @@ public: | ||||
|     __iom_t7(_MoneyT& __mon, bool __intl) | ||||
|         : __mon_(__mon), __intl_(__intl) {} | ||||
|  | ||||
|     template <class _CharT, class _Traits, class _Mp> | ||||
|     template <class _CharT, class _Traits, class _M> | ||||
|     friend | ||||
|     basic_istream<_CharT, _Traits>& | ||||
|     operator>>(basic_istream<_CharT, _Traits>& __is, const __iom_t7<_Mp>& __x); | ||||
|     operator>>(basic_istream<_CharT, _Traits>& __is, const __iom_t7<_M>& __x); | ||||
| }; | ||||
|  | ||||
| template <class _CharT, class _Traits, class _MoneyT> | ||||
| @@ -307,11 +292,11 @@ operator>>(basic_istream<_CharT, _Traits>& __is, const __iom_t7<_MoneyT>& __x) | ||||
|         typename basic_istream<_CharT, _Traits>::sentry __s(__is); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef istreambuf_iterator<_CharT, _Traits> _Ip; | ||||
|             typedef money_get<_CharT, _Ip> _Fp; | ||||
|             typedef istreambuf_iterator<_CharT, _Traits> _I; | ||||
|             typedef money_get<_CharT, _I> _F; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             const _Fp& __mf = use_facet<_Fp>(__is.getloc()); | ||||
|             __mf.get(_Ip(__is), _Ip(), __x.__intl_, __is, __err, __x.__mon_); | ||||
|             const _F& __mf = use_facet<_F>(__is.getloc()); | ||||
|             __mf.get(_I(__is), _I(), __x.__intl_, __is, __err, __x.__mon_); | ||||
|             __is.setstate(__err); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
| @@ -350,10 +335,10 @@ public: | ||||
|     __iom_t8(const _MoneyT& __mon, bool __intl) | ||||
|         : __mon_(__mon), __intl_(__intl) {} | ||||
|  | ||||
|     template <class _CharT, class _Traits, class _Mp> | ||||
|     template <class _CharT, class _Traits, class _M> | ||||
|     friend | ||||
|     basic_ostream<_CharT, _Traits>& | ||||
|     operator<<(basic_ostream<_CharT, _Traits>& __os, const __iom_t8<_Mp>& __x); | ||||
|     operator<<(basic_ostream<_CharT, _Traits>& __os, const __iom_t8<_M>& __x); | ||||
| }; | ||||
|  | ||||
| template <class _CharT, class _Traits, class _MoneyT> | ||||
| @@ -367,10 +352,10 @@ operator<<(basic_ostream<_CharT, _Traits>& __os, const __iom_t8<_MoneyT>& __x) | ||||
|         typename basic_ostream<_CharT, _Traits>::sentry __s(__os); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _Op; | ||||
|             typedef money_put<_CharT, _Op> _Fp; | ||||
|             const _Fp& __mf = use_facet<_Fp>(__os.getloc()); | ||||
|             if (__mf.put(_Op(__os), __x.__intl_, __os, __os.fill(), __x.__mon_).failed()) | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _O; | ||||
|             typedef money_put<_CharT, _O> _F; | ||||
|             const _F& __mf = use_facet<_F>(__os.getloc()); | ||||
|             if (__mf.put(_O(__os), __x.__intl_, __os, __os.fill(), __x.__mon_).failed()) | ||||
|                 __os.setstate(ios_base::badbit); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
| @@ -409,10 +394,10 @@ public: | ||||
|     __iom_t9(tm* __tm, const _CharT* __fmt) | ||||
|         : __tm_(__tm), __fmt_(__fmt) {} | ||||
|  | ||||
|     template <class _Cp, class _Traits> | ||||
|     template <class _C, class _Traits> | ||||
|     friend | ||||
|     basic_istream<_Cp, _Traits>& | ||||
|     operator>>(basic_istream<_Cp, _Traits>& __is, const __iom_t9<_Cp>& __x); | ||||
|     basic_istream<_C, _Traits>& | ||||
|     operator>>(basic_istream<_C, _Traits>& __is, const __iom_t9<_C>& __x); | ||||
| }; | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| @@ -426,11 +411,11 @@ operator>>(basic_istream<_CharT, _Traits>& __is, const __iom_t9<_CharT>& __x) | ||||
|         typename basic_istream<_CharT, _Traits>::sentry __s(__is); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef istreambuf_iterator<_CharT, _Traits> _Ip; | ||||
|             typedef time_get<_CharT, _Ip> _Fp; | ||||
|             typedef istreambuf_iterator<_CharT, _Traits> _I; | ||||
|             typedef time_get<_CharT, _I> _F; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             const _Fp& __tf = use_facet<_Fp>(__is.getloc()); | ||||
|             __tf.get(_Ip(__is), _Ip(), __is, __err, __x.__tm_, | ||||
|             const _F& __tf = use_facet<_F>(__is.getloc()); | ||||
|             __tf.get(_I(__is), _I(), __is, __err, __x.__tm_, | ||||
|                      __x.__fmt_, __x.__fmt_ + _Traits::length(__x.__fmt_)); | ||||
|             __is.setstate(__err); | ||||
|         } | ||||
| @@ -470,10 +455,10 @@ public: | ||||
|     __iom_t10(const tm* __tm, const _CharT* __fmt) | ||||
|         : __tm_(__tm), __fmt_(__fmt) {} | ||||
|  | ||||
|     template <class _Cp, class _Traits> | ||||
|     template <class _C, class _Traits> | ||||
|     friend | ||||
|     basic_ostream<_Cp, _Traits>& | ||||
|     operator<<(basic_ostream<_Cp, _Traits>& __os, const __iom_t10<_Cp>& __x); | ||||
|     basic_ostream<_C, _Traits>& | ||||
|     operator<<(basic_ostream<_C, _Traits>& __os, const __iom_t10<_C>& __x); | ||||
| }; | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| @@ -487,10 +472,10 @@ operator<<(basic_ostream<_CharT, _Traits>& __os, const __iom_t10<_CharT>& __x) | ||||
|         typename basic_ostream<_CharT, _Traits>::sentry __s(__os); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _Op; | ||||
|             typedef time_put<_CharT, _Op> _Fp; | ||||
|             const _Fp& __tf = use_facet<_Fp>(__os.getloc()); | ||||
|             if (__tf.put(_Op(__os), __os, __os.fill(), __x.__tm_, | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _O; | ||||
|             typedef time_put<_CharT, _O> _F; | ||||
|             const _F& __tf = use_facet<_F>(__os.getloc()); | ||||
|             if (__tf.put(_O(__os), __os, __os.fill(), __x.__tm_, | ||||
|                          __x.__fmt_, __x.__fmt_ + _Traits::length(__x.__fmt_)).failed()) | ||||
|                 __os.setstate(ios_base::badbit); | ||||
|         } | ||||
| @@ -512,142 +497,6 @@ put_time(const tm* __tm, const _CharT* __fmt) | ||||
|     return __iom_t10<_CharT>(__tm, __fmt); | ||||
| } | ||||
|  | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|  | ||||
| template <class _CharT, class _Traits, class _ForwardIterator> | ||||
| std::basic_ostream<_CharT, _Traits> & | ||||
| __quoted_output ( basic_ostream<_CharT, _Traits> &__os,  | ||||
|         _ForwardIterator __first, _ForwardIterator __last, _CharT __delim, _CharT __escape ) | ||||
| { | ||||
|     __os << __delim; | ||||
|     for ( ; __first != __last; ++ __first ) | ||||
|     { | ||||
|         if (_Traits::eq (*__first, __escape) || _Traits::eq (*__first, __delim)) | ||||
|             __os << __escape; | ||||
|         __os << *__first; | ||||
|     } | ||||
|     __os << __delim; | ||||
|     return __os; | ||||
| } | ||||
|  | ||||
| template <class _CharT, class _Traits, class _String> | ||||
| basic_istream<_CharT, _Traits> & | ||||
| __quoted_input ( basic_istream<_CharT, _Traits> &__is, _String & __string, _CharT __delim, _CharT __escape ) | ||||
| { | ||||
|     __string.clear (); | ||||
|     _CharT __c; | ||||
|     __is >> __c; | ||||
|     if ( __is.fail ()) | ||||
|         return __is; | ||||
|  | ||||
|     if (!_Traits::eq (__c, __delim))    // no delimiter, read the whole string | ||||
|     { | ||||
|         __is.unget (); | ||||
|         __is >> __string; | ||||
|         return __is; | ||||
|     } | ||||
|  | ||||
|     __save_flags<_CharT, _Traits> sf(__is); | ||||
|     noskipws (__is); | ||||
|     while (true) | ||||
|         { | ||||
|         __is >> __c; | ||||
|         if ( __is.fail ()) | ||||
|             break; | ||||
|         if (_Traits::eq (__c, __escape)) | ||||
|         { | ||||
|             __is >> __c; | ||||
|             if ( __is.fail ()) | ||||
|                 break; | ||||
|         } | ||||
|         else if (_Traits::eq (__c, __delim)) | ||||
|             break; | ||||
|         __string.push_back ( __c ); | ||||
|         } | ||||
|     return __is; | ||||
| } | ||||
|  | ||||
|  | ||||
| template <class _CharT, class _Iter, class _Traits=char_traits<_CharT>> | ||||
| struct __quoted_output_proxy | ||||
| { | ||||
|     _Iter  __first; | ||||
|     _Iter  __last; | ||||
|     _CharT  __delim; | ||||
|     _CharT  __escape; | ||||
|  | ||||
|     __quoted_output_proxy(_Iter __f, _Iter __l, _CharT __d, _CharT __e) | ||||
|     : __first(__f), __last(__l), __delim(__d), __escape(__e) {} | ||||
|     //  This would be a nice place for a string_ref  | ||||
| }; | ||||
|  | ||||
| template <class _CharT, class _Traits, class _Iter> | ||||
| basic_ostream<_CharT, _Traits>& operator<<( | ||||
|          basic_ostream<_CharT, _Traits>& __os,  | ||||
|          const __quoted_output_proxy<_CharT, _Iter, _Traits> & __proxy) | ||||
| { | ||||
|     return __quoted_output (__os, __proxy.__first, __proxy.__last, __proxy.__delim, __proxy.__escape); | ||||
| } | ||||
|  | ||||
| template <class _CharT, class _Traits, class _Allocator> | ||||
| struct __quoted_proxy | ||||
| { | ||||
|     basic_string<_CharT, _Traits, _Allocator> &__string; | ||||
|     _CharT  __delim; | ||||
|     _CharT  __escape; | ||||
|  | ||||
|     __quoted_proxy(basic_string<_CharT, _Traits, _Allocator> &__s, _CharT __d, _CharT __e) | ||||
|     : __string(__s), __delim(__d), __escape(__e) {} | ||||
| }; | ||||
|  | ||||
| template <class _CharT, class _Traits, class _Allocator> | ||||
| _LIBCPP_INLINE_VISIBILITY | ||||
| basic_ostream<_CharT, _Traits>& operator<<( | ||||
|         basic_ostream<_CharT, _Traits>& __os,  | ||||
|         const __quoted_proxy<_CharT, _Traits, _Allocator> & __proxy) | ||||
| { | ||||
|     return __quoted_output (__os, __proxy.__string.cbegin (), __proxy.__string.cend (), __proxy.__delim, __proxy.__escape); | ||||
| } | ||||
|  | ||||
| //  extractor for non-const basic_string& proxies | ||||
| template <class _CharT, class _Traits, class _Allocator> | ||||
| _LIBCPP_INLINE_VISIBILITY | ||||
| basic_istream<_CharT, _Traits>& operator>>( | ||||
|         basic_istream<_CharT, _Traits>& __is,  | ||||
|         const __quoted_proxy<_CharT, _Traits, _Allocator> & __proxy) | ||||
| { | ||||
|     return __quoted_input ( __is, __proxy.__string, __proxy.__delim, __proxy.__escape ); | ||||
| } | ||||
|  | ||||
|  | ||||
| template <class _CharT> | ||||
| _LIBCPP_INLINE_VISIBILITY | ||||
| __quoted_output_proxy<_CharT, const _CharT *> | ||||
| quoted ( const _CharT *__s, _CharT __delim = _CharT('"'), _CharT __escape =_CharT('\\')) | ||||
| { | ||||
|     const _CharT *__end = __s; | ||||
|     while ( *__end ) ++__end; | ||||
|     return __quoted_output_proxy<_CharT, const _CharT *> ( __s, __end, __delim, __escape ); | ||||
| } | ||||
|  | ||||
| template <class _CharT, class _Traits, class _Allocator> | ||||
| _LIBCPP_INLINE_VISIBILITY | ||||
| __quoted_output_proxy<_CharT, typename basic_string <_CharT, _Traits, _Allocator>::const_iterator> | ||||
| quoted ( const basic_string <_CharT, _Traits, _Allocator> &__s, _CharT __delim = _CharT('"'), _CharT __escape=_CharT('\\')) | ||||
| { | ||||
|     return __quoted_output_proxy<_CharT,  | ||||
|             typename basic_string <_CharT, _Traits, _Allocator>::const_iterator>  | ||||
|                     ( __s.cbegin(), __s.cend (), __delim, __escape ); | ||||
| } | ||||
|  | ||||
| template <class _CharT, class _Traits, class _Allocator> | ||||
| __quoted_proxy<_CharT, _Traits, _Allocator> | ||||
| quoted ( basic_string <_CharT, _Traits, _Allocator> &__s, _CharT __delim = _CharT('"'), _CharT __escape=_CharT('\\')) | ||||
| { | ||||
|     return __quoted_proxy<_CharT, _Traits, _Allocator>( __s, __delim, __escape ); | ||||
| } | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
| #endif  // _LIBCPP_IOMANIP | ||||
|   | ||||
							
								
								
									
										178
									
								
								include/ios
									
									
									
									
									
								
							
							
						
						
									
										178
									
								
								include/ios
									
									
									
									
									
								
							| @@ -29,43 +29,43 @@ public: | ||||
|     class failure; | ||||
|  | ||||
|     typedef T1 fmtflags; | ||||
|     static constexpr fmtflags boolalpha; | ||||
|     static constexpr fmtflags dec; | ||||
|     static constexpr fmtflags fixed; | ||||
|     static constexpr fmtflags hex; | ||||
|     static constexpr fmtflags internal; | ||||
|     static constexpr fmtflags left; | ||||
|     static constexpr fmtflags oct; | ||||
|     static constexpr fmtflags right; | ||||
|     static constexpr fmtflags scientific; | ||||
|     static constexpr fmtflags showbase; | ||||
|     static constexpr fmtflags showpoint; | ||||
|     static constexpr fmtflags showpos; | ||||
|     static constexpr fmtflags skipws; | ||||
|     static constexpr fmtflags unitbuf; | ||||
|     static constexpr fmtflags uppercase; | ||||
|     static constexpr fmtflags adjustfield; | ||||
|     static constexpr fmtflags basefield; | ||||
|     static constexpr fmtflags floatfield; | ||||
|     static const fmtflags boolalpha; | ||||
|     static const fmtflags dec; | ||||
|     static const fmtflags fixed; | ||||
|     static const fmtflags hex; | ||||
|     static const fmtflags internal; | ||||
|     static const fmtflags left; | ||||
|     static const fmtflags oct; | ||||
|     static const fmtflags right; | ||||
|     static const fmtflags scientific; | ||||
|     static const fmtflags showbase; | ||||
|     static const fmtflags showpoint; | ||||
|     static const fmtflags showpos; | ||||
|     static const fmtflags skipws; | ||||
|     static const fmtflags unitbuf; | ||||
|     static const fmtflags uppercase; | ||||
|     static const fmtflags adjustfield; | ||||
|     static const fmtflags basefield; | ||||
|     static const fmtflags floatfield; | ||||
|  | ||||
|     typedef T2 iostate; | ||||
|     static constexpr iostate badbit; | ||||
|     static constexpr iostate eofbit; | ||||
|     static constexpr iostate failbit; | ||||
|     static constexpr iostate goodbit; | ||||
|     static const iostate badbit; | ||||
|     static const iostate eofbit; | ||||
|     static const iostate failbit; | ||||
|     static const iostate goodbit; | ||||
|  | ||||
|     typedef T3 openmode; | ||||
|     static constexpr openmode app; | ||||
|     static constexpr openmode ate; | ||||
|     static constexpr openmode binary; | ||||
|     static constexpr openmode in; | ||||
|     static constexpr openmode out; | ||||
|     static constexpr openmode trunc; | ||||
|     static const openmode app; | ||||
|     static const openmode ate; | ||||
|     static const openmode binary; | ||||
|     static const openmode in; | ||||
|     static const openmode out; | ||||
|     static const openmode trunc; | ||||
|  | ||||
|     typedef T4 seekdir; | ||||
|     static constexpr seekdir beg; | ||||
|     static constexpr seekdir cur; | ||||
|     static constexpr seekdir end; | ||||
|     static const seekdir beg; | ||||
|     static const seekdir cur; | ||||
|     static const seekdir end; | ||||
|  | ||||
|     class Init; | ||||
|  | ||||
| @@ -160,7 +160,7 @@ protected: | ||||
|     basic_ios(); | ||||
|     void init(basic_streambuf<charT,traits>* sb); | ||||
|     void move(basic_ios& rhs); | ||||
|     void swap(basic_ios& rhs) noexcept; | ||||
|     void swap(basic_ios& rhs); | ||||
|     void set_rdbuf(basic_streambuf<charT, traits>* sb); | ||||
| }; | ||||
|  | ||||
| @@ -203,9 +203,9 @@ enum class io_errc | ||||
| }; | ||||
|  | ||||
| concept_map ErrorCodeEnum<io_errc> { }; | ||||
| error_code make_error_code(io_errc e) noexcept;  | ||||
| error_condition make_error_condition(io_errc e) noexcept;  | ||||
| storage-class-specifier const error_category& iostream_category() noexcept; | ||||
| error_code make_error_code(io_errc e); | ||||
| error_condition make_error_condition(io_errc e); | ||||
| storage-class-specifier const error_category& iostream_category; | ||||
|  | ||||
| }  // std | ||||
|  | ||||
| @@ -216,22 +216,16 @@ storage-class-specifier const error_category& iostream_category() noexcept; | ||||
| #include <__locale> | ||||
| #include <system_error> | ||||
|  | ||||
| #if __has_feature(cxx_atomic) | ||||
| #include <atomic>     // for __xindex_ | ||||
| #endif | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| typedef ptrdiff_t streamsize; | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS ios_base | ||||
| class _LIBCPP_VISIBLE ios_base | ||||
| { | ||||
| public: | ||||
|     class _LIBCPP_TYPE_VIS failure; | ||||
|     class failure; | ||||
|  | ||||
|     typedef unsigned int fmtflags; | ||||
|     static const fmtflags boolalpha   = 0x0001; | ||||
| @@ -272,10 +266,10 @@ public: | ||||
|     enum seekdir {beg, cur, end}; | ||||
|     typedef seekdir seek_dir; | ||||
|  | ||||
|     typedef _VSTD::streamoff streamoff; | ||||
|     typedef _VSTD::streampos streampos; | ||||
|     typedef _STD::streamoff streamoff; | ||||
|     typedef _STD::streampos streampos; | ||||
|  | ||||
|     class _LIBCPP_TYPE_VIS Init; | ||||
|     class Init; | ||||
|  | ||||
|     // 27.5.2.2 fmtflags state: | ||||
|     _LIBCPP_INLINE_VISIBILITY fmtflags flags() const; | ||||
| @@ -323,7 +317,7 @@ public: | ||||
|     _LIBCPP_INLINE_VISIBILITY bool bad() const; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY iostate exceptions() const; | ||||
|     _LIBCPP_INLINE_VISIBILITY void exceptions(iostate __iostate); | ||||
|     _LIBCPP_INLINE_VISIBILITY void exceptions(iostate __except); | ||||
|  | ||||
|     void __set_badbit_and_consider_rethrow(); | ||||
|     void __set_failbit_and_consider_rethrow(); | ||||
| @@ -346,7 +340,7 @@ protected: | ||||
|     void __call_callbacks(event); | ||||
|     void copyfmt(const ios_base&); | ||||
|     void move(ios_base&); | ||||
|     void swap(ios_base&) _NOEXCEPT; | ||||
|     void swap(ios_base&); | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|     void set_rdbuf(void* __sb) | ||||
| @@ -367,11 +361,7 @@ private: | ||||
|     int*            __index_; | ||||
|     size_t          __event_size_; | ||||
|     size_t          __event_cap_; | ||||
| #if __has_feature(cxx_atomic) | ||||
|     static atomic<int> __xindex_; | ||||
| #else | ||||
|     static int      __xindex_; | ||||
| #endif | ||||
|     long*           __iarray_; | ||||
|     size_t          __iarray_size_; | ||||
|     size_t          __iarray_cap_; | ||||
| @@ -381,33 +371,35 @@ private: | ||||
| }; | ||||
|  | ||||
| //enum class io_errc | ||||
| _LIBCPP_DECLARE_STRONG_ENUM(io_errc) | ||||
| struct _LIBCPP_VISIBLE io_errc | ||||
| { | ||||
| enum _ { | ||||
|     stream = 1 | ||||
| }; | ||||
| _LIBCPP_DECLARE_STRONG_ENUM_EPILOG(io_errc) | ||||
|     _ __v_; | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE io_errc(_ __v) : __v_(__v) {} | ||||
|     _LIBCPP_ALWAYS_INLINE operator int() const {return __v_;} | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY is_error_code_enum<io_errc> : public true_type { }; | ||||
|  | ||||
| #ifdef _LIBCPP_HAS_NO_STRONG_ENUMS | ||||
| struct _LIBCPP_VISIBLE is_error_code_enum<io_errc> : public true_type { }; | ||||
| template <> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY is_error_code_enum<io_errc::__lx> : public true_type { }; | ||||
| #endif | ||||
| struct _LIBCPP_VISIBLE is_error_code_enum<io_errc::_> : public true_type { }; | ||||
|  | ||||
| _LIBCPP_FUNC_VIS | ||||
| const error_category& iostream_category() _NOEXCEPT; | ||||
| _LIBCPP_VISIBLE | ||||
| const error_category& iostream_category(); | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| error_code | ||||
| make_error_code(io_errc __e) _NOEXCEPT | ||||
| make_error_code(io_errc __e) | ||||
| { | ||||
|     return error_code(static_cast<int>(__e), iostream_category()); | ||||
| } | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| error_condition | ||||
| make_error_condition(io_errc __e) _NOEXCEPT | ||||
| make_error_condition(io_errc __e) | ||||
| { | ||||
|     return error_condition(static_cast<int>(__e), iostream_category()); | ||||
| } | ||||
| @@ -421,7 +413,7 @@ public: | ||||
|     virtual ~failure() throw(); | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS ios_base::Init | ||||
| class _LIBCPP_VISIBLE ios_base::Init | ||||
| { | ||||
| public: | ||||
|     Init(); | ||||
| @@ -535,21 +527,21 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| ios_base::eof() const | ||||
| { | ||||
|     return (__rdstate_ & eofbit) != 0; | ||||
|     return __rdstate_ & eofbit; | ||||
| } | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| ios_base::fail() const | ||||
| { | ||||
|     return (__rdstate_ & (failbit | badbit)) != 0; | ||||
|     return __rdstate_ & (failbit | badbit); | ||||
| } | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| ios_base::bad() const | ||||
| { | ||||
|     return (__rdstate_ & badbit) != 0; | ||||
|     return __rdstate_ & badbit; | ||||
| } | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -561,14 +553,14 @@ ios_base::exceptions() const | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| ios_base::exceptions(iostate __iostate) | ||||
| ios_base::exceptions(iostate __except) | ||||
| { | ||||
|     __exceptions_ = __iostate; | ||||
|     __exceptions_ = __except; | ||||
|     clear(__rdstate_); | ||||
| } | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| class _LIBCPP_TYPE_VIS_ONLY basic_ios | ||||
| class _LIBCPP_VISIBLE basic_ios | ||||
|     : public ios_base | ||||
| { | ||||
| public: | ||||
| @@ -580,8 +572,7 @@ public: | ||||
|     typedef typename traits_type::pos_type pos_type; | ||||
|     typedef typename traits_type::off_type off_type; | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|         _LIBCPP_EXPLICIT | ||||
|     _LIBCPP_ALWAYS_INLINE // explicit | ||||
|         operator bool() const {return !fail();} | ||||
|     _LIBCPP_ALWAYS_INLINE bool operator!() const    {return  fail();} | ||||
|     _LIBCPP_ALWAYS_INLINE iostate rdstate() const   {return ios_base::rdstate();} | ||||
| @@ -593,7 +584,7 @@ public: | ||||
|     _LIBCPP_ALWAYS_INLINE bool bad() const  {return ios_base::bad();} | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE iostate exceptions() const {return ios_base::exceptions();} | ||||
|     _LIBCPP_ALWAYS_INLINE void exceptions(iostate __iostate) {ios_base::exceptions(__iostate);} | ||||
|     _LIBCPP_ALWAYS_INLINE void exceptions(iostate __except) {ios_base::exceptions(__except);} | ||||
|  | ||||
|     // 27.5.4.1 Constructor/destructor: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -640,12 +631,12 @@ protected: | ||||
|     void move(basic_ios&& __rhs) {move(__rhs);} | ||||
| #endif | ||||
|     _LIBCPP_INLINE_VISIBILITY  | ||||
|     void swap(basic_ios& __rhs) _NOEXCEPT; | ||||
|     void swap(basic_ios& __rhs); | ||||
|     _LIBCPP_INLINE_VISIBILITY  | ||||
|     void set_rdbuf(basic_streambuf<char_type, traits_type>* __sb); | ||||
| private: | ||||
|     basic_ostream<char_type, traits_type>* __tie_; | ||||
|      mutable int_type __fill_; | ||||
|     char_type __fill_; | ||||
| }; | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| @@ -667,7 +658,7 @@ basic_ios<_CharT, _Traits>::init(basic_streambuf<char_type, traits_type>* __sb) | ||||
| { | ||||
|     ios_base::init(__sb); | ||||
|     __tie_ = 0; | ||||
|     __fill_ = traits_type::eof(); | ||||
|     __fill_ = widen(' '); | ||||
| } | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| @@ -739,8 +730,6 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| _CharT | ||||
| basic_ios<_CharT, _Traits>::fill() const | ||||
| { | ||||
|     if (traits_type::eq_int_type(traits_type::eof(), __fill_)) | ||||
|         __fill_ = widen(' '); | ||||
|     return __fill_; | ||||
| } | ||||
|  | ||||
| @@ -784,11 +773,11 @@ basic_ios<_CharT, _Traits>::move(basic_ios& __rhs) | ||||
| template <class _CharT, class _Traits> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| basic_ios<_CharT, _Traits>::swap(basic_ios& __rhs) _NOEXCEPT | ||||
| basic_ios<_CharT, _Traits>::swap(basic_ios& __rhs) | ||||
| { | ||||
|     ios_base::swap(__rhs); | ||||
|     _VSTD::swap(__tie_, __rhs.__tie_); | ||||
|     _VSTD::swap(__fill_, __rhs.__fill_); | ||||
|     _STD::swap(__tie_, __rhs.__tie_); | ||||
|     _STD::swap(__fill_, __rhs.__fill_); | ||||
| } | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| @@ -991,33 +980,6 @@ defaultfloat(ios_base& __str) | ||||
|     return __str; | ||||
| } | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| class __save_flags | ||||
| { | ||||
|     typedef basic_ios<_CharT, _Traits> __stream_type; | ||||
|     typedef typename __stream_type::fmtflags fmtflags; | ||||
|  | ||||
|     __stream_type& __stream_; | ||||
|     fmtflags       __fmtflags_; | ||||
|     _CharT         __fill_; | ||||
|  | ||||
|     __save_flags(const __save_flags&); | ||||
|     __save_flags& operator=(const __save_flags&); | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit __save_flags(__stream_type& __stream) | ||||
|         : __stream_(__stream), | ||||
|           __fmtflags_(__stream.flags()), | ||||
|           __fill_(__stream.fill()) | ||||
|         {} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     ~__save_flags() | ||||
|     { | ||||
|         __stream_.flags(__fmtflags_); | ||||
|         __stream_.fill(__fill_); | ||||
|     } | ||||
| }; | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
| #endif  // _LIBCPP_IOS | ||||
|   | ||||
| @@ -20,7 +20,6 @@ namespace std | ||||
| template<class charT> struct char_traits; | ||||
| template<class T>     class allocator; | ||||
|  | ||||
| class ios_base; | ||||
| template <class charT, class traits = char_traits<charT> > class basic_ios; | ||||
|  | ||||
| template <class charT, class traits = char_traits<charT> > class basic_streambuf; | ||||
| @@ -89,55 +88,53 @@ typedef fpos<char_traits<wchar_t>::state_type> wstreampos; | ||||
| #include <__config> | ||||
| #include <wchar.h>  // for mbstate_t | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS ios_base; | ||||
| class ios_base; | ||||
|  | ||||
| template<class _CharT>  struct _LIBCPP_TYPE_VIS_ONLY char_traits; | ||||
| template<class _Tp>     class _LIBCPP_TYPE_VIS_ONLY allocator; | ||||
| template<class _CharT>  struct _LIBCPP_VISIBLE char_traits; | ||||
| template<class _Tp>     class _LIBCPP_VISIBLE allocator; | ||||
|  | ||||
| template <class _CharT, class _Traits = char_traits<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY basic_ios; | ||||
|     class _LIBCPP_VISIBLE basic_ios; | ||||
|  | ||||
| template <class _CharT, class _Traits = char_traits<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY basic_streambuf; | ||||
|     class _LIBCPP_VISIBLE basic_streambuf; | ||||
| template <class _CharT, class _Traits = char_traits<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY basic_istream; | ||||
|     class _LIBCPP_VISIBLE basic_istream; | ||||
| template <class _CharT, class _Traits = char_traits<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY basic_ostream; | ||||
|     class _LIBCPP_VISIBLE basic_ostream; | ||||
| template <class _CharT, class _Traits = char_traits<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY basic_iostream; | ||||
|     class _LIBCPP_VISIBLE basic_iostream; | ||||
|  | ||||
| template <class _CharT, class _Traits = char_traits<_CharT>, | ||||
|           class _Allocator = allocator<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY basic_stringbuf; | ||||
|     class _LIBCPP_VISIBLE basic_stringbuf; | ||||
| template <class _CharT, class _Traits = char_traits<_CharT>, | ||||
|           class _Allocator = allocator<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY basic_istringstream; | ||||
|     class _LIBCPP_VISIBLE basic_istringstream; | ||||
| template <class _CharT, class _Traits = char_traits<_CharT>, | ||||
|           class _Allocator = allocator<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY basic_ostringstream; | ||||
|     class _LIBCPP_VISIBLE basic_ostringstream; | ||||
| template <class _CharT, class _Traits = char_traits<_CharT>, | ||||
|           class _Allocator = allocator<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY basic_stringstream; | ||||
|     class _LIBCPP_VISIBLE basic_stringstream; | ||||
|  | ||||
| template <class _CharT, class _Traits = char_traits<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY basic_filebuf; | ||||
|     class _LIBCPP_VISIBLE basic_filebuf; | ||||
| template <class _CharT, class _Traits = char_traits<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY basic_ifstream; | ||||
|     class _LIBCPP_VISIBLE basic_ifstream; | ||||
| template <class _CharT, class _Traits = char_traits<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY basic_ofstream; | ||||
|     class _LIBCPP_VISIBLE basic_ofstream; | ||||
| template <class _CharT, class _Traits = char_traits<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY basic_fstream; | ||||
|     class _LIBCPP_VISIBLE basic_fstream; | ||||
|  | ||||
| template <class _CharT, class _Traits = char_traits<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY istreambuf_iterator; | ||||
|     class _LIBCPP_VISIBLE istreambuf_iterator; | ||||
| template <class _CharT, class _Traits = char_traits<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY ostreambuf_iterator; | ||||
|     class _LIBCPP_VISIBLE ostreambuf_iterator; | ||||
|  | ||||
| typedef basic_ios<char>              ios; | ||||
| typedef basic_ios<wchar_t>           wios; | ||||
| @@ -172,7 +169,7 @@ typedef basic_ifstream<wchar_t>      wifstream; | ||||
| typedef basic_ofstream<wchar_t>      wofstream; | ||||
| typedef basic_fstream<wchar_t>       wfstream; | ||||
|  | ||||
| template <class _State>             class _LIBCPP_TYPE_VIS_ONLY fpos; | ||||
| template <class _State>             class _LIBCPP_VISIBLE fpos; | ||||
| typedef fpos<mbstate_t>    streampos; | ||||
| typedef fpos<mbstate_t>    wstreampos; | ||||
| #ifndef _LIBCPP_HAS_NO_UNICODE_CHARS | ||||
| @@ -185,7 +182,7 @@ typedef long long streamoff;        // for char_traits in <string> | ||||
| template <class _CharT,             // for <stdexcept> | ||||
|           class _Traits = char_traits<_CharT>, | ||||
|           class _Allocator = allocator<_CharT> > | ||||
|     class _LIBCPP_TYPE_VIS_ONLY basic_string; | ||||
|     class _LIBCPP_VISIBLE basic_string; | ||||
| typedef basic_string<char, char_traits<char>, allocator<char> > string; | ||||
| typedef basic_string<wchar_t, char_traits<wchar_t>, allocator<wchar_t> > wstring; | ||||
|  | ||||
|   | ||||
| @@ -40,20 +40,18 @@ extern wostream wclog; | ||||
| #include <istream> | ||||
| #include <ostream> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| extern _LIBCPP_FUNC_VIS istream cin; | ||||
| extern _LIBCPP_FUNC_VIS ostream cout; | ||||
| extern _LIBCPP_FUNC_VIS ostream cerr; | ||||
| extern _LIBCPP_FUNC_VIS ostream clog; | ||||
| extern _LIBCPP_FUNC_VIS wistream wcin; | ||||
| extern _LIBCPP_FUNC_VIS wostream wcout; | ||||
| extern _LIBCPP_FUNC_VIS wostream wcerr; | ||||
| extern _LIBCPP_FUNC_VIS wostream wclog; | ||||
| extern _LIBCPP_VISIBLE istream cin; | ||||
| extern _LIBCPP_VISIBLE ostream cout; | ||||
| extern _LIBCPP_VISIBLE ostream cerr; | ||||
| extern _LIBCPP_VISIBLE ostream clog; | ||||
| extern _LIBCPP_VISIBLE wistream wcin; | ||||
| extern _LIBCPP_VISIBLE wostream wcout; | ||||
| extern _LIBCPP_VISIBLE wostream wcerr; | ||||
| extern _LIBCPP_VISIBLE wostream wclog; | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
							
								
								
									
										501
									
								
								include/istream
									
									
									
									
									
								
							
							
						
						
									
										501
									
								
								include/istream
									
									
									
									
									
								
							| @@ -155,16 +155,12 @@ template <class charT, class traits, class T> | ||||
| #include <__config> | ||||
| #include <ostream> | ||||
|  | ||||
| #include <__undef_min_max> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| class _LIBCPP_TYPE_VIS_ONLY basic_istream | ||||
| class _LIBCPP_VISIBLE basic_istream | ||||
|     : virtual public basic_ios<_CharT, _Traits> | ||||
| { | ||||
|     streamsize __gc_; | ||||
| @@ -181,20 +177,18 @@ public: | ||||
|     virtual ~basic_istream(); | ||||
| protected: | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     basic_istream(basic_istream&& __rhs); | ||||
| #endif | ||||
|  | ||||
|     // 27.7.1.1.2 Assign/swap: | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     basic_istream& operator=(basic_istream&& __rhs); | ||||
| #endif | ||||
|     void swap(basic_istream& __rhs); | ||||
| public: | ||||
|  | ||||
|     // 27.7.1.1.3 Prefix/suffix: | ||||
|     class _LIBCPP_TYPE_VIS_ONLY sentry; | ||||
|     class sentry; | ||||
|  | ||||
|     // 27.7.1.2 Formatted input: | ||||
|     basic_istream& operator>>(basic_istream& (*__pf)(basic_istream&)); | ||||
| @@ -244,7 +238,7 @@ public: | ||||
| }; | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| class _LIBCPP_TYPE_VIS_ONLY basic_istream<_CharT, _Traits>::sentry | ||||
| class _LIBCPP_VISIBLE basic_istream<_CharT, _Traits>::sentry | ||||
| { | ||||
|     bool __ok_; | ||||
|  | ||||
| @@ -256,7 +250,7 @@ public: | ||||
| //    ~sentry() = default; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|         _LIBCPP_EXPLICIT | ||||
|     // explicit | ||||
|         operator bool() const {return __ok_;} | ||||
| }; | ||||
|  | ||||
| @@ -271,10 +265,10 @@ basic_istream<_CharT, _Traits>::sentry::sentry(basic_istream<_CharT, _Traits>& _ | ||||
|             __is.tie()->flush(); | ||||
|         if (!__noskipws && (__is.flags() & ios_base::skipws)) | ||||
|         { | ||||
|             typedef istreambuf_iterator<_CharT, _Traits> _Ip; | ||||
|             typedef istreambuf_iterator<_CharT, _Traits> _I; | ||||
|             const ctype<_CharT>& __ct = use_facet<ctype<_CharT> >(__is.getloc()); | ||||
|             _Ip __i(__is); | ||||
|             _Ip __eof; | ||||
|             _I __i(__is); | ||||
|             _I __eof; | ||||
|             for (; __i != __eof; ++__i) | ||||
|                 if (!__ct.is(__ct.space, *__i)) | ||||
|                     break; | ||||
| @@ -327,7 +321,7 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| basic_istream<_CharT, _Traits>::swap(basic_istream& __rhs) | ||||
| { | ||||
|     _VSTD::swap(__gc_, __rhs.__gc_); | ||||
|     _STD::swap(__gc_, __rhs.__gc_); | ||||
|     basic_ios<char_type, traits_type>::swap(__rhs); | ||||
| } | ||||
|  | ||||
| @@ -342,10 +336,10 @@ basic_istream<_CharT, _Traits>::operator>>(unsigned short& __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _Ip; | ||||
|             typedef num_get<char_type, _Ip> _Fp; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             typedef num_get<char_type, _I> _F; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             use_facet<_Fp>(this->getloc()).get(_Ip(*this), _Ip(), *this, __err, __n); | ||||
|             use_facet<_F>(this->getloc()).get(_I(*this), _I(), *this, __err, __n); | ||||
|             this->setstate(__err); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
| @@ -369,10 +363,10 @@ basic_istream<_CharT, _Traits>::operator>>(unsigned int& __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _Ip; | ||||
|             typedef num_get<char_type, _Ip> _Fp; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             typedef num_get<char_type, _I> _F; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             use_facet<_Fp>(this->getloc()).get(_Ip(*this), _Ip(), *this, __err, __n); | ||||
|             use_facet<_F>(this->getloc()).get(_I(*this), _I(), *this, __err, __n); | ||||
|             this->setstate(__err); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
| @@ -396,10 +390,10 @@ basic_istream<_CharT, _Traits>::operator>>(long& __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _Ip; | ||||
|             typedef num_get<char_type, _Ip> _Fp; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             typedef num_get<char_type, _I> _F; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             use_facet<_Fp>(this->getloc()).get(_Ip(*this), _Ip(), *this, __err, __n); | ||||
|             use_facet<_F>(this->getloc()).get(_I(*this), _I(), *this, __err, __n); | ||||
|             this->setstate(__err); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
| @@ -423,10 +417,10 @@ basic_istream<_CharT, _Traits>::operator>>(unsigned long& __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _Ip; | ||||
|             typedef num_get<char_type, _Ip> _Fp; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             typedef num_get<char_type, _I> _F; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             use_facet<_Fp>(this->getloc()).get(_Ip(*this), _Ip(), *this, __err, __n); | ||||
|             use_facet<_F>(this->getloc()).get(_I(*this), _I(), *this, __err, __n); | ||||
|             this->setstate(__err); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
| @@ -450,10 +444,10 @@ basic_istream<_CharT, _Traits>::operator>>(long long& __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _Ip; | ||||
|             typedef num_get<char_type, _Ip> _Fp; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             typedef num_get<char_type, _I> _F; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             use_facet<_Fp>(this->getloc()).get(_Ip(*this), _Ip(), *this, __err, __n); | ||||
|             use_facet<_F>(this->getloc()).get(_I(*this), _I(), *this, __err, __n); | ||||
|             this->setstate(__err); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
| @@ -477,10 +471,10 @@ basic_istream<_CharT, _Traits>::operator>>(unsigned long long& __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _Ip; | ||||
|             typedef num_get<char_type, _Ip> _Fp; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             typedef num_get<char_type, _I> _F; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             use_facet<_Fp>(this->getloc()).get(_Ip(*this), _Ip(), *this, __err, __n); | ||||
|             use_facet<_F>(this->getloc()).get(_I(*this), _I(), *this, __err, __n); | ||||
|             this->setstate(__err); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
| @@ -504,10 +498,10 @@ basic_istream<_CharT, _Traits>::operator>>(float& __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _Ip; | ||||
|             typedef num_get<char_type, _Ip> _Fp; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             typedef num_get<char_type, _I> _F; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             use_facet<_Fp>(this->getloc()).get(_Ip(*this), _Ip(), *this, __err, __n); | ||||
|             use_facet<_F>(this->getloc()).get(_I(*this), _I(), *this, __err, __n); | ||||
|             this->setstate(__err); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
| @@ -531,10 +525,10 @@ basic_istream<_CharT, _Traits>::operator>>(double& __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _Ip; | ||||
|             typedef num_get<char_type, _Ip> _Fp; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             typedef num_get<char_type, _I> _F; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             use_facet<_Fp>(this->getloc()).get(_Ip(*this), _Ip(), *this, __err, __n); | ||||
|             use_facet<_F>(this->getloc()).get(_I(*this), _I(), *this, __err, __n); | ||||
|             this->setstate(__err); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
| @@ -558,10 +552,10 @@ basic_istream<_CharT, _Traits>::operator>>(long double& __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _Ip; | ||||
|             typedef num_get<char_type, _Ip> _Fp; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             typedef num_get<char_type, _I> _F; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             use_facet<_Fp>(this->getloc()).get(_Ip(*this), _Ip(), *this, __err, __n); | ||||
|             use_facet<_F>(this->getloc()).get(_I(*this), _I(), *this, __err, __n); | ||||
|             this->setstate(__err); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
| @@ -585,10 +579,10 @@ basic_istream<_CharT, _Traits>::operator>>(bool& __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _Ip; | ||||
|             typedef num_get<char_type, _Ip> _Fp; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             typedef num_get<char_type, _I> _F; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             use_facet<_Fp>(this->getloc()).get(_Ip(*this), _Ip(), *this, __err, __n); | ||||
|             use_facet<_F>(this->getloc()).get(_I(*this), _I(), *this, __err, __n); | ||||
|             this->setstate(__err); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
| @@ -612,10 +606,10 @@ basic_istream<_CharT, _Traits>::operator>>(void*& __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _Ip; | ||||
|             typedef num_get<char_type, _Ip> _Fp; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             typedef num_get<char_type, _I> _F; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             use_facet<_Fp>(this->getloc()).get(_Ip(*this), _Ip(), *this, __err, __n); | ||||
|             use_facet<_F>(this->getloc()).get(_I(*this), _I(), *this, __err, __n); | ||||
|             this->setstate(__err); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
| @@ -639,11 +633,11 @@ basic_istream<_CharT, _Traits>::operator>>(short& __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _Ip; | ||||
|             typedef num_get<char_type, _Ip> _Fp; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             typedef num_get<char_type, _I> _F; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             long __temp; | ||||
|             use_facet<_Fp>(this->getloc()).get(_Ip(*this), _Ip(), *this, __err, __temp); | ||||
|             use_facet<_F>(this->getloc()).get(_I(*this), _I(), *this, __err, __temp); | ||||
|             if (__temp < numeric_limits<short>::min()) | ||||
|             { | ||||
|                 __err |= ios_base::failbit; | ||||
| @@ -679,11 +673,11 @@ basic_istream<_CharT, _Traits>::operator>>(int& __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _Ip; | ||||
|             typedef num_get<char_type, _Ip> _Fp; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             typedef num_get<char_type, _I> _F; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             long __temp; | ||||
|             use_facet<_Fp>(this->getloc()).get(_Ip(*this), _Ip(), *this, __err, __temp); | ||||
|             use_facet<_F>(this->getloc()).get(_I(*this), _I(), *this, __err, __temp); | ||||
|             if (__temp < numeric_limits<int>::min()) | ||||
|             { | ||||
|                 __err |= ios_base::failbit; | ||||
| @@ -746,29 +740,26 @@ operator>>(basic_istream<_CharT, _Traits>& __is, _CharT* __s) | ||||
|         typename basic_istream<_CharT, _Traits>::sentry __sen(__is); | ||||
|         if (__sen) | ||||
|         { | ||||
|             typedef istreambuf_iterator<_CharT, _Traits> _I; | ||||
|             streamsize __n = __is.width(); | ||||
|             if (__n <= 0) | ||||
|             if (__n == 0) | ||||
|                 __n = numeric_limits<streamsize>::max() / sizeof(_CharT) - 1; | ||||
|             streamsize __c = 0; | ||||
|             const ctype<_CharT>& __ct = use_facet<ctype<_CharT> >(__is.getloc()); | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             while (__c < __n-1) | ||||
|             _I __i(__is); | ||||
|             _I __eof; | ||||
|             for (; __i != __eof && __c < __n-1; ++__i, ++__s, ++__c) | ||||
|             { | ||||
|                 typename _Traits::int_type __i = __is.rdbuf()->sgetc(); | ||||
|                 if (_Traits::eq_int_type(__i, _Traits::eof())) | ||||
|                 { | ||||
|                    __err |= ios_base::eofbit; | ||||
|                    break; | ||||
|                 } | ||||
|                 _CharT __ch = _Traits::to_char_type(__i); | ||||
|                 _CharT __ch = *__i; | ||||
|                 if (__ct.is(__ct.space, __ch)) | ||||
|                     break; | ||||
|                 *__s++ = __ch; | ||||
|                 ++__c; | ||||
|                  __is.rdbuf()->sbumpc(); | ||||
|                 *__s = __ch; | ||||
|             } | ||||
|             *__s = _CharT(); | ||||
|             __is.width(0); | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             if (__i == __eof) | ||||
|                __err |= ios_base::eofbit; | ||||
|             if (__c == 0) | ||||
|                __err |= ios_base::failbit; | ||||
|             __is.setstate(__err); | ||||
| @@ -810,11 +801,25 @@ operator>>(basic_istream<_CharT, _Traits>& __is, _CharT& __c) | ||||
|         typename basic_istream<_CharT, _Traits>::sentry __sen(__is); | ||||
|         if (__sen) | ||||
|         { | ||||
| #if 1 | ||||
|             typename _Traits::int_type __i = __is.rdbuf()->sbumpc(); | ||||
|             if (_Traits::eq_int_type(__i, _Traits::eof())) | ||||
|                 __is.setstate(ios_base::eofbit | ios_base::failbit); | ||||
|             else | ||||
|                 __c = _Traits::to_char_type(__i); | ||||
| #else | ||||
|             typedef istreambuf_iterator<_CharT, _Traits> _I; | ||||
|             _I __i(__is); | ||||
|             _I __eof; | ||||
|             if (__i != __eof) | ||||
|             { | ||||
|                 __c = *__i; | ||||
|                 if (++__i == __eof) | ||||
|                     __is.setstate(ios_base::eofbit); | ||||
|             } | ||||
|             else | ||||
|                 __is.setstate(ios_base::eofbit | ios_base::failbit); | ||||
| #endif | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     } | ||||
| @@ -854,42 +859,42 @@ basic_istream<_CharT, _Traits>::operator>>(basic_streambuf<char_type, traits_typ | ||||
|         sentry __s(*this, true); | ||||
|         if (__s) | ||||
|         { | ||||
|             streamsize __c = 0; | ||||
|             if (__sb) | ||||
|             { | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|                 try | ||||
|                 { | ||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | ||||
|                     ios_base::iostate __err = ios_base::goodbit; | ||||
|                     while (true) | ||||
|                     typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|                     typedef ostreambuf_iterator<char_type, traits_type> _O; | ||||
|                     _I __i(*this); | ||||
|                     _I __eof; | ||||
|                     _O __o(__sb); | ||||
|                     for (; __i != __eof; ++__i, ++__o, ++__c) | ||||
|                     { | ||||
|                         typename traits_type::int_type __i = this->rdbuf()->sgetc(); | ||||
|                         if (traits_type::eq_int_type(__i, _Traits::eof())) | ||||
|                         { | ||||
|                            __err |= ios_base::eofbit; | ||||
|                            break; | ||||
|                         } | ||||
|                         if (traits_type::eq_int_type( | ||||
|                                 __sb->sputc(traits_type::to_char_type(__i)), | ||||
|                                 traits_type::eof())) | ||||
|                         *__o = *__i; | ||||
|                         if (__o.failed()) | ||||
|                             break; | ||||
|                         ++__gc_; | ||||
|                         this->rdbuf()->sbumpc(); | ||||
|                     } | ||||
|                     if (__gc_ == 0) | ||||
|                     ios_base::iostate __err = ios_base::goodbit; | ||||
|                     if (__i == __eof) | ||||
|                        __err |= ios_base::eofbit; | ||||
|                     if (__c == 0) | ||||
|                        __err |= ios_base::failbit; | ||||
|                     this->setstate(__err); | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|                 } | ||||
|                 catch (...) | ||||
|                 { | ||||
|                     if (__gc_ == 0) | ||||
|                     if (__c == 0) | ||||
|                         this->__set_failbit_and_consider_rethrow(); | ||||
|                 } | ||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | ||||
|             } | ||||
|             else | ||||
|                 this->setstate(ios_base::failbit); | ||||
|             __gc_ = __c; | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     } | ||||
| @@ -914,11 +919,22 @@ basic_istream<_CharT, _Traits>::get() | ||||
|         sentry __s(*this, true); | ||||
|         if (__s) | ||||
|         { | ||||
|             __r = this->rdbuf()->sbumpc(); | ||||
|             if (traits_type::eq_int_type(__r, traits_type::eof())) | ||||
|                this->setstate(ios_base::failbit | ios_base::eofbit); | ||||
|             streamsize __c = 0; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             _I __i(*this); | ||||
|             _I __eof; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             if (__i != __eof) | ||||
|             { | ||||
|                 __r = traits_type::to_int_type(*__i); | ||||
|                 ++__c; | ||||
|                 if (++__i == __eof) | ||||
|                     __err |= ios_base::eofbit; | ||||
|             } | ||||
|             else | ||||
|                 __gc_ = 1; | ||||
|                 __err |= ios_base::failbit | ios_base::eofbit; | ||||
|             this->setstate(__err); | ||||
|             __gc_ = __c; | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     } | ||||
| @@ -953,31 +969,30 @@ basic_istream<_CharT, _Traits>::get(char_type* __s, streamsize __n, char_type __ | ||||
|         sentry __sen(*this, true); | ||||
|         if (__sen) | ||||
|         { | ||||
|             streamsize __c = 0; | ||||
|             if (__n > 0) | ||||
|             { | ||||
|                 ios_base::iostate __err = ios_base::goodbit; | ||||
|                 while (__gc_ < __n-1) | ||||
|                 typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|                 _I __i(*this); | ||||
|                 _I __eof; | ||||
|                 for (; __i != __eof && __n > 1; ++__i, ++__s, ++__c) | ||||
|                 { | ||||
|                     int_type __i = this->rdbuf()->sgetc(); | ||||
|                     if (traits_type::eq_int_type(__i, traits_type::eof())) | ||||
|                     { | ||||
|                        __err |= ios_base::eofbit; | ||||
|                        break; | ||||
|                     } | ||||
|                     char_type __ch = traits_type::to_char_type(__i); | ||||
|                     char_type __ch = *__i; | ||||
|                     if (traits_type::eq(__ch, __dlm)) | ||||
|                         break; | ||||
|                     *__s++ = __ch; | ||||
|                     ++__gc_; | ||||
|                      this->rdbuf()->sbumpc(); | ||||
|                     *__s = __ch; | ||||
|                 } | ||||
|                 *__s = char_type(); | ||||
|                 if (__gc_ == 0) | ||||
|                 ios_base::iostate __err = ios_base::goodbit; | ||||
|                 if (__i == __eof) | ||||
|                    __err |= ios_base::eofbit; | ||||
|                 if (__c == 0) | ||||
|                    __err |= ios_base::failbit; | ||||
|                 this->setstate(__err); | ||||
|             } | ||||
|             else | ||||
|                 this->setstate(ios_base::failbit); | ||||
|             __gc_ = __c; | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     } | ||||
| @@ -1010,36 +1025,38 @@ basic_istream<_CharT, _Traits>::get(basic_streambuf<char_type, traits_type>& __s | ||||
|         sentry __sen(*this, true); | ||||
|         if (__sen) | ||||
|         { | ||||
|             streamsize __c = 0; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|             try | ||||
|             { | ||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | ||||
|                 while (true) | ||||
|                 typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|                 typedef ostreambuf_iterator<char_type, traits_type> _O; | ||||
|                 _I __i(*this); | ||||
|                 _I __eof; | ||||
|                 _O __o(&__sb); | ||||
|                 for (; __i != __eof; ++__i, ++__o, ++__c) | ||||
|                 { | ||||
|                     typename traits_type::int_type __i = this->rdbuf()->sgetc(); | ||||
|                     if (traits_type::eq_int_type(__i, traits_type::eof())) | ||||
|                     { | ||||
|                        __err |= ios_base::eofbit; | ||||
|                        break; | ||||
|                     } | ||||
|                     char_type __ch = traits_type::to_char_type(__i); | ||||
|                     char_type __ch = *__i; | ||||
|                     if (traits_type::eq(__ch, __dlm)) | ||||
|                         break; | ||||
|                     if (traits_type::eq_int_type(__sb.sputc(__ch), traits_type::eof())) | ||||
|                     *__o = __ch; | ||||
|                     if (__o.failed()) | ||||
|                         break; | ||||
|                     ++__gc_; | ||||
|                     this->rdbuf()->sbumpc(); | ||||
|                 } | ||||
|                 if (__i == __eof) | ||||
|                    __err |= ios_base::eofbit; | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|             } | ||||
|             catch (...) | ||||
|             { | ||||
|             } | ||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | ||||
|             if (__gc_ == 0) | ||||
|             if (__c == 0) | ||||
|                __err |= ios_base::failbit; | ||||
|             this->setstate(__err); | ||||
|             __gc_ = __c; | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     } | ||||
| @@ -1071,36 +1088,33 @@ basic_istream<_CharT, _Traits>::getline(char_type* __s, streamsize __n, char_typ | ||||
|         sentry __sen(*this, true); | ||||
|         if (__sen) | ||||
|         { | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             while (true) | ||||
|             streamsize __c = 0; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             _I __i(*this); | ||||
|             _I __eof; | ||||
|             for (; __i != __eof; ++__s, --__n) | ||||
|             { | ||||
|                 typename traits_type::int_type __i = this->rdbuf()->sgetc(); | ||||
|                 if (traits_type::eq_int_type(__i, traits_type::eof())) | ||||
|                 { | ||||
|                    __err |= ios_base::eofbit; | ||||
|                    break; | ||||
|                 } | ||||
|                 char_type __ch = traits_type::to_char_type(__i); | ||||
|                 char_type __ch = *__i; | ||||
|                 ++__i; | ||||
|                 ++__c; | ||||
|                 if (traits_type::eq(__ch, __dlm)) | ||||
|                     break; | ||||
|                 if (__n < 2) | ||||
|                 { | ||||
|                     this->rdbuf()->sbumpc(); | ||||
|                     ++__gc_; | ||||
|                     this->setstate(ios_base::failbit); | ||||
|                     break; | ||||
|                 } | ||||
|                 if (__gc_ >= __n-1) | ||||
|                 { | ||||
|                     __err |= ios_base::failbit; | ||||
|                     break; | ||||
|                 } | ||||
|                 *__s++ = __ch; | ||||
|                 this->rdbuf()->sbumpc(); | ||||
|                 ++__gc_; | ||||
|                 *__s = __ch; | ||||
|             } | ||||
|             if (__n > 0) | ||||
|             if (__n) | ||||
|                 *__s = char_type(); | ||||
|             if (__gc_ == 0) | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             if (__i == __eof) | ||||
|                __err |= ios_base::eofbit; | ||||
|             if (__c == 0) | ||||
|                __err |= ios_base::failbit; | ||||
|             this->setstate(__err); | ||||
|             __gc_ = __c; | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     } | ||||
| @@ -1132,38 +1146,35 @@ basic_istream<_CharT, _Traits>::ignore(streamsize __n, int_type __dlm) | ||||
|         sentry __sen(*this, true); | ||||
|         if (__sen) | ||||
|         { | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             if (__n == numeric_limits<streamsize>::max()) | ||||
|             streamsize __c = 0; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             _I __i(*this); | ||||
|             _I __eof; | ||||
|             if (__n != numeric_limits<streamsize>::max()) | ||||
|             { | ||||
|                 while (true) | ||||
|                 for (; __n > 0 && __i != __eof; --__n) | ||||
|                 { | ||||
|                     typename traits_type::int_type __i = this->rdbuf()->sbumpc(); | ||||
|                     if (traits_type::eq_int_type(__i, traits_type::eof())) | ||||
|                     { | ||||
|                        __err |= ios_base::eofbit; | ||||
|                        break; | ||||
|                     } | ||||
|                     ++__gc_; | ||||
|                     if (traits_type::eq_int_type(__i, __dlm)) | ||||
|                     char_type __ch = *__i; | ||||
|                     ++__i; | ||||
|                     ++__c; | ||||
|                     if (traits_type::eq(__ch, __dlm)) | ||||
|                         break; | ||||
|                 } | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 while (__gc_ < __n) | ||||
|                 while (__i != __eof) | ||||
|                 { | ||||
|                     typename traits_type::int_type __i = this->rdbuf()->sbumpc(); | ||||
|                     if (traits_type::eq_int_type(__i, traits_type::eof())) | ||||
|                     { | ||||
|                        __err |= ios_base::eofbit; | ||||
|                        break; | ||||
|                     } | ||||
|                     ++__gc_; | ||||
|                     if (traits_type::eq_int_type(__i, __dlm)) | ||||
|                     char_type __ch = *__i; | ||||
|                     ++__i; | ||||
|                     ++__c; | ||||
|                     if (traits_type::eq(__ch, __dlm)) | ||||
|                         break; | ||||
|                 } | ||||
|             } | ||||
|             this->setstate(__err); | ||||
|             if (__i == __eof) | ||||
|                 this->setstate(ios_base::eofbit); | ||||
|             __gc_ = __c; | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     } | ||||
| @@ -1187,11 +1198,7 @@ basic_istream<_CharT, _Traits>::peek() | ||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | ||||
|         sentry __sen(*this, true); | ||||
|         if (__sen) | ||||
|         { | ||||
|             __r = this->rdbuf()->sgetc(); | ||||
|             if (traits_type::eq_int_type(__r, traits_type::eof())) | ||||
|                 this->setstate(ios_base::eofbit); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     } | ||||
|     catch (...) | ||||
| @@ -1214,9 +1221,20 @@ basic_istream<_CharT, _Traits>::read(char_type* __s, streamsize __n) | ||||
|         sentry __sen(*this, true); | ||||
|         if (__sen) | ||||
|         { | ||||
|             __gc_ = this->rdbuf()->sgetn(__s, __n); | ||||
|             if (__gc_ != __n) | ||||
|                 this->setstate(ios_base::failbit | ios_base::eofbit); | ||||
|             streamsize __c = 0; | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             _I __i(*this); | ||||
|             _I __eof; | ||||
|             for (; __i != __eof && __n > 0; ++__i, ++__s, ++__c, --__n) | ||||
|                 *__s = *__i; | ||||
|             if (__i == __eof) | ||||
|             { | ||||
|                 ios_base::iostate __err = ios_base::eofbit; | ||||
|                 if (__n > 0) | ||||
|                     __err |= ios_base::failbit; | ||||
|                 this->setstate(__err); | ||||
|             } | ||||
|             __gc_ = __c; | ||||
|         } | ||||
|         else | ||||
|             this->setstate(ios_base::failbit); | ||||
| @@ -1235,19 +1253,44 @@ streamsize | ||||
| basic_istream<_CharT, _Traits>::readsome(char_type* __s, streamsize __n) | ||||
| { | ||||
|     __gc_ = 0; | ||||
|     streamsize __c = this->rdbuf()->in_avail(); | ||||
|     switch (__c) | ||||
|     streamsize __c = 0; | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     try | ||||
|     { | ||||
|     case -1: | ||||
|         this->setstate(ios_base::eofbit); | ||||
|         break; | ||||
|     case 0: | ||||
|         break; | ||||
|     default: | ||||
|         read(__s, _VSTD::min(__c, __n)); | ||||
|         break; | ||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | ||||
|         sentry __sen(*this, true); | ||||
|         if (__sen) | ||||
|         { | ||||
|             typedef istreambuf_iterator<char_type, traits_type> _I; | ||||
|             _I __i(*this); | ||||
|             _I __eof; | ||||
|             __c = this->rdbuf()->in_avail(); | ||||
|             switch (__c) | ||||
|             { | ||||
|             case -1: | ||||
|                 __i = __eof; | ||||
|                 break; | ||||
|             case 0: | ||||
|                 break; | ||||
|             default: | ||||
|                 __c = _STD::min(__c, __n); | ||||
|                 for (streamsize __k = 0; __k < __c; ++__k, ++__s, ++__i) | ||||
|                     *__s = *__i; | ||||
|             } | ||||
|             if (__i == __eof) | ||||
|                 this->setstate(ios_base::eofbit); | ||||
|             __gc_ = __c; | ||||
|         } | ||||
|         else | ||||
|             this->setstate(ios_base::failbit); | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     } | ||||
|     return __gc_; | ||||
|     catch (...) | ||||
|     { | ||||
|         this->__set_badbit_and_consider_rethrow(); | ||||
|     } | ||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | ||||
|     return __c; | ||||
| } | ||||
|  | ||||
| template<class _CharT, class _Traits> | ||||
| @@ -1259,7 +1302,6 @@ basic_istream<_CharT, _Traits>::putback(char_type __c) | ||||
|     try | ||||
|     { | ||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | ||||
|         this->clear(this->rdstate() & ~ios_base::eofbit); | ||||
|         sentry __sen(*this, true); | ||||
|         if (__sen) | ||||
|         { | ||||
| @@ -1287,7 +1329,6 @@ basic_istream<_CharT, _Traits>::unget() | ||||
|     try | ||||
|     { | ||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | ||||
|         this->clear(this->rdstate() & ~ios_base::eofbit); | ||||
|         sentry __sen(*this, true); | ||||
|         if (__sen) | ||||
|         { | ||||
| @@ -1366,13 +1407,10 @@ basic_istream<_CharT, _Traits>::seekg(pos_type __pos) | ||||
|     try | ||||
|     { | ||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | ||||
|         this->clear(this->rdstate() & ~ios_base::eofbit); | ||||
|         sentry __sen(*this, true); | ||||
|         if (__sen) | ||||
|         { | ||||
|             if (this->rdbuf()->pubseekpos(__pos, ios_base::in) == pos_type(-1)) | ||||
|                 this->setstate(ios_base::failbit); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     } | ||||
|     catch (...) | ||||
| @@ -1393,10 +1431,7 @@ basic_istream<_CharT, _Traits>::seekg(off_type __off, ios_base::seekdir __dir) | ||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | ||||
|         sentry __sen(*this, true); | ||||
|         if (__sen) | ||||
|         { | ||||
|             if (this->rdbuf()->pubseekoff(__off, __dir, ios_base::in) == pos_type(-1)) | ||||
|                 this->setstate(ios_base::failbit); | ||||
|         } | ||||
|             this->rdbuf()->pubseekoff(__off, __dir, ios_base::in); | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     } | ||||
|     catch (...) | ||||
| @@ -1418,19 +1453,15 @@ ws(basic_istream<_CharT, _Traits>& __is) | ||||
|         typename basic_istream<_CharT, _Traits>::sentry __sen(__is, true); | ||||
|         if (__sen) | ||||
|         { | ||||
|             typedef istreambuf_iterator<_CharT, _Traits> _I; | ||||
|             const ctype<_CharT>& __ct = use_facet<ctype<_CharT> >(__is.getloc()); | ||||
|             while (true) | ||||
|             { | ||||
|                 typename _Traits::int_type __i = __is.rdbuf()->sgetc(); | ||||
|                 if (_Traits::eq_int_type(__i, _Traits::eof())) | ||||
|                 { | ||||
|                    __is.setstate(ios_base::eofbit); | ||||
|                    break; | ||||
|                 } | ||||
|                 if (!__ct.is(__ct.space, _Traits::to_char_type(__i))) | ||||
|             _I __i(__is); | ||||
|             _I __eof; | ||||
|             for (; __i != __eof; ++__i) | ||||
|                 if (!__ct.is(__ct.space, *__i)) | ||||
|                     break; | ||||
|                 __is.rdbuf()->sbumpc(); | ||||
|             } | ||||
|             if (__i == __eof) | ||||
|                 __is.setstate(ios_base::failbit | ios_base::eofbit); | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     } | ||||
| @@ -1456,7 +1487,7 @@ operator>>(basic_istream<_CharT, _Traits>&& __is, _Tp& __x) | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| class _LIBCPP_TYPE_VIS_ONLY basic_iostream | ||||
| class _LIBCPP_VISIBLE basic_iostream | ||||
|     : public basic_istream<_CharT, _Traits>, | ||||
|       public basic_ostream<_CharT, _Traits> | ||||
| { | ||||
| @@ -1473,13 +1504,11 @@ public: | ||||
|     virtual ~basic_iostream(); | ||||
| protected: | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     basic_iostream(basic_iostream&& __rhs); | ||||
| #endif | ||||
|  | ||||
|     // assign/swap | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     basic_iostream& operator=(basic_iostream&& __rhs); | ||||
| #endif | ||||
|     void swap(basic_iostream& __rhs); | ||||
| @@ -1498,7 +1527,7 @@ basic_iostream<_CharT, _Traits>::basic_iostream(basic_streambuf<char_type, trait | ||||
| template <class _CharT, class _Traits> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| basic_iostream<_CharT, _Traits>::basic_iostream(basic_iostream&& __rhs) | ||||
|     : basic_istream<_CharT, _Traits>(_VSTD::move(__rhs)) | ||||
|     : basic_istream<_CharT, _Traits>(_STD::move(__rhs)) | ||||
| { | ||||
| } | ||||
|  | ||||
| @@ -1539,30 +1568,27 @@ operator>>(basic_istream<_CharT, _Traits>& __is, | ||||
|         if (__sen) | ||||
|         { | ||||
|             __str.clear(); | ||||
|             typedef istreambuf_iterator<_CharT, _Traits> _I; | ||||
|             streamsize __n = __is.width(); | ||||
|             if (__n <= 0) | ||||
|             if (__n == 0) | ||||
|                 __n = __str.max_size(); | ||||
|             if (__n <= 0) | ||||
|             if (__n < 0) | ||||
|                 __n = numeric_limits<streamsize>::max(); | ||||
|             streamsize __c = 0; | ||||
|             const ctype<_CharT>& __ct = use_facet<ctype<_CharT> >(__is.getloc()); | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             while (__c < __n) | ||||
|             _I __i(__is); | ||||
|             _I __eof; | ||||
|             for (; __i != __eof && __c < __n; ++__i, ++__c) | ||||
|             { | ||||
|                 typename _Traits::int_type __i = __is.rdbuf()->sgetc(); | ||||
|                 if (_Traits::eq_int_type(__i, _Traits::eof())) | ||||
|                 { | ||||
|                    __err |= ios_base::eofbit; | ||||
|                    break; | ||||
|                 } | ||||
|                 _CharT __ch = _Traits::to_char_type(__i); | ||||
|                 _CharT __ch = *__i; | ||||
|                 if (__ct.is(__ct.space, __ch)) | ||||
|                     break; | ||||
|                 __str.push_back(__ch); | ||||
|                 ++__c; | ||||
|                  __is.rdbuf()->sbumpc(); | ||||
|             } | ||||
|             __is.width(0); | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             if (__i == __eof) | ||||
|                __err |= ios_base::eofbit; | ||||
|             if (__c == 0) | ||||
|                __err |= ios_base::failbit; | ||||
|             __is.setstate(__err); | ||||
| @@ -1592,28 +1618,31 @@ getline(basic_istream<_CharT, _Traits>& __is, | ||||
|         if (__sen) | ||||
|         { | ||||
|             __str.clear(); | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             streamsize __extr = 0; | ||||
|             while (true) | ||||
|             streamsize __c = 0; | ||||
|             typedef istreambuf_iterator<_CharT, _Traits> _I; | ||||
|             _I __i(__is); | ||||
|             _I __eof; | ||||
|             streamsize __n = __str.max_size(); | ||||
|             if (__n < 0) | ||||
|                 __n = numeric_limits<streamsize>::max(); | ||||
|             for (; __i != __eof;) | ||||
|             { | ||||
|                 typename _Traits::int_type __i = __is.rdbuf()->sbumpc(); | ||||
|                 if (_Traits::eq_int_type(__i, _Traits::eof())) | ||||
|                 { | ||||
|                    __err |= ios_base::eofbit; | ||||
|                    break; | ||||
|                 } | ||||
|                 ++__extr; | ||||
|                 _CharT __ch = _Traits::to_char_type(__i); | ||||
|                 _CharT __ch = *__i; | ||||
|                 ++__i; | ||||
|                 ++__c; | ||||
|                 if (_Traits::eq(__ch, __dlm)) | ||||
|                     break; | ||||
|                 __str.push_back(__ch); | ||||
|                 if (__str.size() == __str.max_size()) | ||||
|                 if (__c == __n) | ||||
|                 { | ||||
|                     __err |= ios_base::failbit; | ||||
|                     __is.setstate(ios_base::failbit); | ||||
|                     break; | ||||
|                 } | ||||
|                 __str.push_back(__ch); | ||||
|             } | ||||
|             if (__extr == 0) | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             if (__i == __eof) | ||||
|                __err |= ios_base::eofbit; | ||||
|             if (__c == 0) | ||||
|                __err |= ios_base::failbit; | ||||
|             __is.setstate(__err); | ||||
|         } | ||||
| @@ -1671,26 +1700,24 @@ operator>>(basic_istream<_CharT, _Traits>& __is, bitset<_Size>& __x) | ||||
|         { | ||||
|             basic_string<_CharT, _Traits> __str; | ||||
|             const ctype<_CharT>& __ct = use_facet<ctype<_CharT> >(__is.getloc()); | ||||
|             typedef istreambuf_iterator<_CharT, _Traits> _I; | ||||
|             streamsize __c = 0; | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             _CharT __zero = __ct.widen('0'); | ||||
|             _CharT __one = __ct.widen('1'); | ||||
|             while (__c < _Size) | ||||
|             _I __i(__is); | ||||
|             _I __eof; | ||||
|             for (; __i != __eof && __c < _Size; ++__i, ++__c) | ||||
|             { | ||||
|                 typename _Traits::int_type __i = __is.rdbuf()->sgetc(); | ||||
|                 if (_Traits::eq_int_type(__i, _Traits::eof())) | ||||
|                 { | ||||
|                    __err |= ios_base::eofbit; | ||||
|                    break; | ||||
|                 } | ||||
|                 _CharT __ch = _Traits::to_char_type(__i); | ||||
|                 if (!_Traits::eq(__ch, __zero) && !_Traits::eq(__ch, __one)) | ||||
|                 _CharT __ch = *__i; | ||||
|                 if (__ch != __zero && __ch != __one) | ||||
|                     break; | ||||
|                 __str.push_back(__ch); | ||||
|                 ++__c; | ||||
|                  __is.rdbuf()->sbumpc(); | ||||
|             } | ||||
|             __is.width(0); | ||||
|             __x = bitset<_Size>(__str); | ||||
|             ios_base::iostate __err = ios_base::goodbit; | ||||
|             if (__i == __eof) | ||||
|                __err |= ios_base::eofbit; | ||||
|             if (__c == 0) | ||||
|                __err |= ios_base::failbit; | ||||
|             __is.setstate(__err); | ||||
| @@ -1707,9 +1734,9 @@ operator>>(basic_istream<_CharT, _Traits>& __is, bitset<_Size>& __x) | ||||
|     return __is; | ||||
| } | ||||
|  | ||||
| _LIBCPP_EXTERN_TEMPLATE(class _LIBCPP_TYPE_VIS basic_istream<char>) | ||||
| _LIBCPP_EXTERN_TEMPLATE(class _LIBCPP_TYPE_VIS basic_istream<wchar_t>) | ||||
| _LIBCPP_EXTERN_TEMPLATE(class _LIBCPP_TYPE_VIS basic_iostream<char>) | ||||
| extern template class basic_istream<char>; | ||||
| extern template class basic_istream<wchar_t>; | ||||
| extern template class basic_iostream<char>; | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
							
								
								
									
										965
									
								
								include/iterator
									
									
									
									
									
								
							
							
						
						
									
										965
									
								
								include/iterator
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										928
									
								
								include/limits
									
									
									
									
									
								
							
							
						
						
									
										928
									
								
								include/limits
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1236
									
								
								include/list
									
									
									
									
									
								
							
							
						
						
									
										1236
									
								
								include/list
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1156
									
								
								include/locale
									
									
									
									
									
								
							
							
						
						
									
										1156
									
								
								include/locale
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1111
									
								
								include/map
									
									
									
									
									
								
							
							
						
						
									
										1111
									
								
								include/map
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										2815
									
								
								include/memory
									
									
									
									
									
								
							
							
						
						
									
										2815
									
								
								include/memory
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										127
									
								
								include/mutex
									
									
									
									
									
								
							
							
						
						
									
										127
									
								
								include/mutex
									
									
									
									
									
								
							| @@ -20,7 +20,7 @@ namespace std | ||||
| class mutex | ||||
| { | ||||
| public: | ||||
|      constexpr mutex() noexcept; | ||||
|      mutex(); | ||||
|      ~mutex(); | ||||
|  | ||||
|     mutex(const mutex&) = delete; | ||||
| @@ -44,7 +44,7 @@ public: | ||||
|     recursive_mutex& operator=(const recursive_mutex&) = delete; | ||||
|  | ||||
|     void lock(); | ||||
|     bool try_lock() noexcept; | ||||
|     bool try_lock(); | ||||
|     void unlock(); | ||||
|  | ||||
|     typedef pthread_mutex_t* native_handle_type; | ||||
| @@ -79,7 +79,7 @@ public: | ||||
|     recursive_timed_mutex& operator=(const recursive_timed_mutex&) = delete; | ||||
|  | ||||
|     void lock(); | ||||
|     bool try_lock() noexcept; | ||||
|     bool try_lock(); | ||||
|     template <class Rep, class Period> | ||||
|         bool try_lock_for(const chrono::duration<Rep, Period>& rel_time); | ||||
|     template <class Clock, class Duration> | ||||
| @@ -114,9 +114,9 @@ class unique_lock | ||||
| { | ||||
| public: | ||||
|     typedef Mutex mutex_type; | ||||
|     unique_lock() noexcept; | ||||
|     unique_lock(); | ||||
|     explicit unique_lock(mutex_type& m); | ||||
|     unique_lock(mutex_type& m, defer_lock_t) noexcept; | ||||
|     unique_lock(mutex_type& m, defer_lock_t); | ||||
|     unique_lock(mutex_type& m, try_to_lock_t); | ||||
|     unique_lock(mutex_type& m, adopt_lock_t); | ||||
|     template <class Clock, class Duration> | ||||
| @@ -128,8 +128,8 @@ public: | ||||
|     unique_lock(unique_lock const&) = delete; | ||||
|     unique_lock& operator=(unique_lock const&) = delete; | ||||
|  | ||||
|     unique_lock(unique_lock&& u) noexcept; | ||||
|     unique_lock& operator=(unique_lock&& u) noexcept; | ||||
|     unique_lock(unique_lock&& u); | ||||
|     unique_lock& operator=(unique_lock&& u); | ||||
|  | ||||
|     void lock(); | ||||
|     bool try_lock(); | ||||
| @@ -141,16 +141,16 @@ public: | ||||
|  | ||||
|     void unlock(); | ||||
|  | ||||
|     void swap(unique_lock& u) noexcept; | ||||
|     mutex_type* release() noexcept; | ||||
|     void swap(unique_lock& u); | ||||
|     mutex_type* release(); | ||||
|  | ||||
|     bool owns_lock() const noexcept; | ||||
|     explicit operator bool () const noexcept; | ||||
|     mutex_type* mutex() const noexcept; | ||||
|     bool owns_lock() const; | ||||
|     explicit operator bool () const; | ||||
|     mutex_type* mutex() const; | ||||
| }; | ||||
|  | ||||
| template <class Mutex> | ||||
|   void swap(unique_lock<Mutex>& x, unique_lock<Mutex>& y) noexcept; | ||||
|   void swap(unique_lock<Mutex>& x, unique_lock<Mutex>& y); | ||||
|  | ||||
| template <class L1, class L2, class... L3> | ||||
|   int try_lock(L1&, L2&, L3&...); | ||||
| @@ -159,7 +159,7 @@ template <class L1, class L2, class... L3> | ||||
|  | ||||
| struct once_flag | ||||
| { | ||||
|     constexpr once_flag() noexcept; | ||||
|     constexpr once_flag(); | ||||
|  | ||||
|     once_flag(const once_flag&) = delete; | ||||
|     once_flag& operator=(const once_flag&) = delete; | ||||
| @@ -175,19 +175,12 @@ template<class Callable, class ...Args> | ||||
| #include <__config> | ||||
| #include <__mutex_base> | ||||
| #include <functional> | ||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||
| #include <tuple> | ||||
| #endif | ||||
|  | ||||
| #include <__undef_min_max> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS recursive_mutex | ||||
| class _LIBCPP_VISIBLE recursive_mutex | ||||
| { | ||||
|     pthread_mutex_t __m_; | ||||
|  | ||||
| @@ -201,15 +194,15 @@ private: | ||||
|  | ||||
| public: | ||||
|     void lock(); | ||||
|     bool try_lock() _NOEXCEPT; | ||||
|     void unlock()  _NOEXCEPT; | ||||
|     bool try_lock(); | ||||
|     void unlock(); | ||||
|  | ||||
|     typedef pthread_mutex_t* native_handle_type; | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     native_handle_type native_handle() {return &__m_;} | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS timed_mutex | ||||
| class _LIBCPP_VISIBLE timed_mutex | ||||
| { | ||||
|     mutex              __m_; | ||||
|     condition_variable __cv_; | ||||
| @@ -224,14 +217,14 @@ private: | ||||
|  | ||||
| public: | ||||
|     void lock(); | ||||
|     bool try_lock() _NOEXCEPT; | ||||
|     bool try_lock(); | ||||
|     template <class _Rep, class _Period> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         bool try_lock_for(const chrono::duration<_Rep, _Period>& __d) | ||||
|             {return try_lock_until(chrono::steady_clock::now() + __d);} | ||||
|     template <class _Clock, class _Duration> | ||||
|         bool try_lock_until(const chrono::time_point<_Clock, _Duration>& __t); | ||||
|     void unlock() _NOEXCEPT; | ||||
|     void unlock(); | ||||
| }; | ||||
|  | ||||
| template <class _Clock, class _Duration> | ||||
| @@ -251,7 +244,7 @@ timed_mutex::try_lock_until(const chrono::time_point<_Clock, _Duration>& __t) | ||||
|     return false; | ||||
| } | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS recursive_timed_mutex | ||||
| class _LIBCPP_VISIBLE recursive_timed_mutex | ||||
| { | ||||
|     mutex              __m_; | ||||
|     condition_variable __cv_; | ||||
| @@ -267,14 +260,14 @@ private: | ||||
|  | ||||
| public: | ||||
|     void lock(); | ||||
|     bool try_lock() _NOEXCEPT; | ||||
|     bool try_lock(); | ||||
|     template <class _Rep, class _Period> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         bool try_lock_for(const chrono::duration<_Rep, _Period>& __d) | ||||
|             {return try_lock_until(chrono::steady_clock::now() + __d);} | ||||
|     template <class _Clock, class _Duration> | ||||
|         bool try_lock_until(const chrono::time_point<_Clock, _Duration>& __t); | ||||
|     void unlock() _NOEXCEPT; | ||||
|     void unlock(); | ||||
| }; | ||||
|  | ||||
| template <class _Clock, class _Duration> | ||||
| @@ -425,27 +418,25 @@ lock(_L0& __l0, _L1& __l1, _L2& __l2, _L3& ...__l3) | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||
|  | ||||
| struct _LIBCPP_TYPE_VIS once_flag; | ||||
| struct once_flag; | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||
|  | ||||
| template<class _Callable, class... _Args> | ||||
| _LIBCPP_INLINE_VISIBILITY | ||||
| void call_once(once_flag&, _Callable&&, _Args&&...); | ||||
|   void call_once(once_flag&, _Callable&&, _Args&&...); | ||||
|  | ||||
| #else  // _LIBCPP_HAS_NO_VARIADICS | ||||
|  | ||||
| template<class _Callable> | ||||
| _LIBCPP_INLINE_VISIBILITY | ||||
| void call_once(once_flag&, _Callable); | ||||
|   void call_once(once_flag&, _Callable); | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||
|  | ||||
| struct _LIBCPP_TYPE_VIS_ONLY once_flag | ||||
| struct _LIBCPP_VISIBLE once_flag | ||||
| { | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     _LIBCPP_CONSTEXPR | ||||
|         once_flag() _NOEXCEPT : __state_(0) {} | ||||
|     // constexpr | ||||
|         once_flag() {} | ||||
|  | ||||
| private: | ||||
|     once_flag(const once_flag&); // = delete; | ||||
| @@ -464,50 +455,17 @@ private: | ||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||
| }; | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||
|  | ||||
| template <class _Fp> | ||||
| template <class _F> | ||||
| class __call_once_param | ||||
| { | ||||
|     _Fp __f_; | ||||
|     _F __f_; | ||||
| public: | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit __call_once_param(_Fp&& __f) : __f_(_VSTD::move(__f)) {} | ||||
|     explicit __call_once_param(_F&& __f) : __f_(_STD::move(__f)) {} | ||||
| #else | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit __call_once_param(const _Fp& __f) : __f_(__f) {} | ||||
| #endif | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void operator()() | ||||
|     { | ||||
|         typedef typename __make_tuple_indices<tuple_size<_Fp>::value, 1>::type _Index; | ||||
|         __execute(_Index()); | ||||
|     } | ||||
|  | ||||
| private: | ||||
|     template <size_t ..._Indices> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void __execute(__tuple_indices<_Indices...>) | ||||
|     { | ||||
|         __invoke(_VSTD::move(_VSTD::get<0>(__f_)), _VSTD::move(_VSTD::get<_Indices>(__f_))...); | ||||
|     } | ||||
| }; | ||||
|  | ||||
| #else | ||||
|  | ||||
| template <class _Fp> | ||||
| class __call_once_param | ||||
| { | ||||
|     _Fp __f_; | ||||
| public: | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit __call_once_param(_Fp&& __f) : __f_(_VSTD::move(__f)) {} | ||||
| #else | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit __call_once_param(const _Fp& __f) : __f_(__f) {} | ||||
|     explicit __call_once_param(const _F& __f) : __f_(__f) {} | ||||
| #endif | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -517,17 +475,15 @@ public: | ||||
|     } | ||||
| }; | ||||
|  | ||||
| #endif | ||||
|  | ||||
| template <class _Fp> | ||||
| template <class _F> | ||||
| void | ||||
| __call_once_proxy(void* __vp) | ||||
| { | ||||
|     __call_once_param<_Fp>* __p = static_cast<__call_once_param<_Fp>*>(__vp); | ||||
|     __call_once_param<_F>* __p = static_cast<__call_once_param<_F>*>(__vp); | ||||
|     (*__p)(); | ||||
| } | ||||
|  | ||||
| _LIBCPP_FUNC_VIS void __call_once(volatile unsigned long&, void*, void(*)(void*)); | ||||
| void __call_once(volatile unsigned long&, void*, void(*)(void*)); | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||
|  | ||||
| @@ -536,12 +492,13 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| call_once(once_flag& __flag, _Callable&& __func, _Args&&... __args) | ||||
| { | ||||
|     if (__flag.__state_ != ~0ul) | ||||
|     if (__builtin_expect(__flag.__state_ , ~0ul) != ~0ul) | ||||
|     { | ||||
|         typedef tuple<typename decay<_Callable>::type, typename decay<_Args>::type...> _Gp; | ||||
|         __call_once_param<_Gp> __p(_Gp(__decay_copy(_VSTD::forward<_Callable>(__func)), | ||||
|                                 __decay_copy(_VSTD::forward<_Args>(__args))...)); | ||||
|         __call_once(__flag.__state_, &__p, &__call_once_proxy<_Gp>); | ||||
|         typedef decltype(std::bind(std::forward<_Callable>(__func), | ||||
|                          std::forward<_Args>(__args)...)) _G; | ||||
|         __call_once_param<_G> __p(std::bind(std::forward<_Callable>(__func), | ||||
|                                  std::forward<_Args>(__args)...)); | ||||
|         __call_once(__flag.__state_, &__p, &__call_once_proxy<_G>); | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
							
								
								
									
										126
									
								
								include/new
									
									
									
									
									
								
							
							
						
						
									
										126
									
								
								include/new
									
									
									
									
									
								
							| @@ -21,46 +21,35 @@ class bad_alloc | ||||
|     : public exception | ||||
| { | ||||
| public: | ||||
|     bad_alloc() noexcept; | ||||
|     bad_alloc(const bad_alloc&) noexcept; | ||||
|     bad_alloc& operator=(const bad_alloc&) noexcept; | ||||
|     virtual const char* what() const noexcept; | ||||
| }; | ||||
|  | ||||
| class bad_array_length : public bad_alloc // C++14 | ||||
| { | ||||
| public: | ||||
|     bad_array_length() noexcept; | ||||
| }; | ||||
|  | ||||
| class bad_array_new_length : public bad_alloc | ||||
| { | ||||
| public: | ||||
|     bad_array_new_length() noexcept; | ||||
|     bad_alloc() throw(); | ||||
|     bad_alloc(const bad_alloc&) throw(); | ||||
|     bad_alloc& operator=(const bad_alloc&) throw(); | ||||
|     virtual ~bad_alloc() throw(); | ||||
|     virtual const char* what() const throw(); | ||||
| }; | ||||
|  | ||||
| struct nothrow_t {}; | ||||
| extern const nothrow_t nothrow; | ||||
| typedef void (*new_handler)(); | ||||
| new_handler set_new_handler(new_handler new_p) noexcept; | ||||
| new_handler get_new_handler() noexcept; | ||||
| new_handler set_new_handler(new_handler new_p) throw(); | ||||
| new_handler get_new_handler() throw(); | ||||
|  | ||||
| }  // std | ||||
|  | ||||
| void* operator new(std::size_t size);                                   // replaceable | ||||
| void* operator new(std::size_t size, const std::nothrow_t&) noexcept;   // replaceable | ||||
| void  operator delete(void* ptr) noexcept;                              // replaceable | ||||
| void  operator delete(void* ptr, const std::nothrow_t&) noexcept;       // replaceable | ||||
| void* operator new(std::size_t size) throw(std::bad_alloc);            // replaceable | ||||
| void* operator new(std::size_t size, const std::nothrow_t&) throw();   // replaceable | ||||
| void  operator delete(void* ptr) throw();                              // replaceable | ||||
| void  operator delete(void* ptr, const std::nothrow_t&) throw();       // replaceable | ||||
|  | ||||
| void* operator new[](std::size_t size);                                 // replaceable | ||||
| void* operator new[](std::size_t size, const std::nothrow_t&) noexcept; // replaceable | ||||
| void  operator delete[](void* ptr) noexcept;                            // replaceable | ||||
| void  operator delete[](void* ptr, const std::nothrow_t&) noexcept;     // replaceable | ||||
| void* operator new[](std::size_t size) throw(std::bad_alloc);          // replaceable | ||||
| void* operator new[](std::size_t size, const std::nothrow_t&) throw(); // replaceable | ||||
| void  operator delete[](void* ptr) throw();                            // replaceable | ||||
| void  operator delete[](void* ptr, const std::nothrow_t&) throw();     // replaceable | ||||
|  | ||||
| void* operator new  (std::size_t size, void* ptr) noexcept; | ||||
| void* operator new[](std::size_t size, void* ptr) noexcept; | ||||
| void  operator delete  (void* ptr, void*) noexcept; | ||||
| void  operator delete[](void* ptr, void*) noexcept; | ||||
| void* operator new  (std::size_t size, void* ptr) throw(); | ||||
| void* operator new[](std::size_t size, void* ptr) throw(); | ||||
| void  operator delete  (void* ptr, void*) throw(); | ||||
| void  operator delete[](void* ptr, void*) throw(); | ||||
|  | ||||
| */ | ||||
|  | ||||
| @@ -68,9 +57,7 @@ void  operator delete[](void* ptr, void*) noexcept; | ||||
| #include <exception> | ||||
| #include <cstddef> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| namespace std  // purposefully not using versioning namespace | ||||
| { | ||||
| @@ -79,72 +66,43 @@ class _LIBCPP_EXCEPTION_ABI bad_alloc | ||||
|     : public exception | ||||
| { | ||||
| public: | ||||
|     bad_alloc() _NOEXCEPT; | ||||
|     virtual ~bad_alloc() _NOEXCEPT; | ||||
|     virtual const char* what() const _NOEXCEPT; | ||||
|     bad_alloc() throw(); | ||||
|     virtual ~bad_alloc() throw(); | ||||
|     virtual const char* what() const throw(); | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_EXCEPTION_ABI bad_array_new_length | ||||
|     : public bad_alloc | ||||
| { | ||||
| public: | ||||
|     bad_array_new_length() _NOEXCEPT; | ||||
|     virtual ~bad_array_new_length() _NOEXCEPT; | ||||
|     virtual const char* what() const _NOEXCEPT; | ||||
|     bad_array_new_length() throw(); | ||||
|     virtual ~bad_array_new_length() throw(); | ||||
|     virtual const char* what() const throw(); | ||||
| }; | ||||
|  | ||||
| #if defined(_LIBCPP_BUILDING_NEW) || (_LIBCPP_STD_VER > 11) | ||||
| void __throw_bad_alloc();  // not in C++ spec | ||||
|  | ||||
| class _LIBCPP_EXCEPTION_ABI bad_array_length | ||||
|     : public bad_alloc | ||||
| { | ||||
| public: | ||||
|     bad_array_length() _NOEXCEPT; | ||||
|     virtual ~bad_array_length() _NOEXCEPT; | ||||
|     virtual const char* what() const _NOEXCEPT; | ||||
| }; | ||||
|  | ||||
| #define _LIBCPP_BAD_ARRAY_LENGTH_DEFINED | ||||
|  | ||||
| #endif  // defined(_LIBCPP_BUILDING_NEW) || (_LIBCPP_STD_VER > 11) | ||||
|  | ||||
| _LIBCPP_FUNC_VIS void __throw_bad_alloc();  // not in C++ spec | ||||
|  | ||||
| struct _LIBCPP_TYPE_VIS nothrow_t {}; | ||||
| extern _LIBCPP_FUNC_VIS const nothrow_t nothrow; | ||||
| struct _LIBCPP_VISIBLE nothrow_t {}; | ||||
| extern _LIBCPP_VISIBLE const nothrow_t nothrow; | ||||
| typedef void (*new_handler)(); | ||||
| _LIBCPP_FUNC_VIS new_handler set_new_handler(new_handler) _NOEXCEPT; | ||||
| _LIBCPP_FUNC_VIS new_handler get_new_handler() _NOEXCEPT; | ||||
| _LIBCPP_VISIBLE new_handler set_new_handler(new_handler) throw(); | ||||
| _LIBCPP_VISIBLE new_handler get_new_handler() throw(); | ||||
|  | ||||
| }  // std | ||||
|  | ||||
| #if defined(_WIN32) && !defined(cxx_EXPORTS) | ||||
| # define _LIBCPP_NEW_DELETE_VIS _LIBCPP_FUNC_VIS_ONLY | ||||
| #else | ||||
| # define _LIBCPP_NEW_DELETE_VIS _LIBCPP_FUNC_VIS | ||||
| #endif | ||||
| _LIBCPP_VISIBLE void* operator new(std::size_t) throw(std::bad_alloc); | ||||
| _LIBCPP_VISIBLE void* operator new(std::size_t, const std::nothrow_t&) throw(); | ||||
| _LIBCPP_VISIBLE void  operator delete(void*) throw(); | ||||
| _LIBCPP_VISIBLE void  operator delete(void*, const std::nothrow_t&) throw(); | ||||
|  | ||||
| _LIBCPP_NEW_DELETE_VIS void* operator new(std::size_t __sz) | ||||
| #if !__has_feature(cxx_noexcept) | ||||
|     throw(std::bad_alloc) | ||||
| #endif | ||||
| ; | ||||
| _LIBCPP_NEW_DELETE_VIS void* operator new(std::size_t __sz, const std::nothrow_t&) _NOEXCEPT _NOALIAS; | ||||
| _LIBCPP_NEW_DELETE_VIS void  operator delete(void* __p) _NOEXCEPT; | ||||
| _LIBCPP_NEW_DELETE_VIS void  operator delete(void* __p, const std::nothrow_t&) _NOEXCEPT; | ||||
| _LIBCPP_VISIBLE void* operator new[](std::size_t) throw(std::bad_alloc); | ||||
| _LIBCPP_VISIBLE void* operator new[](std::size_t, const std::nothrow_t&) throw(); | ||||
| _LIBCPP_VISIBLE void  operator delete[](void*) throw(); | ||||
| _LIBCPP_VISIBLE void  operator delete[](void*, const std::nothrow_t&) throw(); | ||||
|  | ||||
| _LIBCPP_NEW_DELETE_VIS void* operator new[](std::size_t __sz) | ||||
| #if !__has_feature(cxx_noexcept) | ||||
|     throw(std::bad_alloc) | ||||
| #endif | ||||
| ; | ||||
| _LIBCPP_NEW_DELETE_VIS void* operator new[](std::size_t __sz, const std::nothrow_t&) _NOEXCEPT _NOALIAS; | ||||
| _LIBCPP_NEW_DELETE_VIS void  operator delete[](void* __p) _NOEXCEPT; | ||||
| _LIBCPP_NEW_DELETE_VIS void  operator delete[](void* __p, const std::nothrow_t&) _NOEXCEPT; | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY void* operator new  (std::size_t, void* __p) _NOEXCEPT {return __p;} | ||||
| inline _LIBCPP_INLINE_VISIBILITY void* operator new[](std::size_t, void* __p) _NOEXCEPT {return __p;} | ||||
| inline _LIBCPP_INLINE_VISIBILITY void  operator delete  (void*, void*) _NOEXCEPT {} | ||||
| inline _LIBCPP_INLINE_VISIBILITY void  operator delete[](void*, void*) _NOEXCEPT {} | ||||
| _LIBCPP_INLINE_VISIBILITY inline void* operator new  (std::size_t, void* __p) throw() {return __p;} | ||||
| _LIBCPP_INLINE_VISIBILITY inline void* operator new[](std::size_t, void* __p) throw() {return __p;} | ||||
| _LIBCPP_INLINE_VISIBILITY inline void  operator delete  (void*, void*) throw() {} | ||||
| _LIBCPP_INLINE_VISIBILITY inline void  operator delete[](void*, void*) throw() {} | ||||
|  | ||||
| #endif  // _LIBCPP_NEW | ||||
|   | ||||
| @@ -60,9 +60,7 @@ template <class ForwardIterator, class T> | ||||
| #include <__config> | ||||
| #include <iterator> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| @@ -157,7 +155,7 @@ adjacent_difference(_InputIterator __first, _InputIterator __last, _OutputIterat | ||||
|         { | ||||
|             typename iterator_traits<_InputIterator>::value_type __t2(*__first); | ||||
|             *__result = __t2 - __t1; | ||||
|             __t1 = _VSTD::move(__t2); | ||||
|             __t1 = __t2; | ||||
|         } | ||||
|     } | ||||
|     return __result; | ||||
| @@ -177,7 +175,7 @@ adjacent_difference(_InputIterator __first, _InputIterator __last, _OutputIterat | ||||
|         { | ||||
|             typename iterator_traits<_InputIterator>::value_type __t2(*__first); | ||||
|             *__result = __binary_op(__t2, __t1); | ||||
|             __t1 = _VSTD::move(__t2); | ||||
|             __t1 = __t2; | ||||
|         } | ||||
|     } | ||||
|     return __result; | ||||
| @@ -186,10 +184,10 @@ adjacent_difference(_InputIterator __first, _InputIterator __last, _OutputIterat | ||||
| template <class _ForwardIterator, class _Tp> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| iota(_ForwardIterator __first, _ForwardIterator __last, _Tp __value_) | ||||
| iota(_ForwardIterator __first, _ForwardIterator __last, _Tp __value) | ||||
| { | ||||
|     for (; __first != __last; ++__first, ++__value_) | ||||
|         *__first = __value_; | ||||
|     for (; __first != __last; ++__first, ++__value) | ||||
|         *__first = __value; | ||||
| } | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|   | ||||
							
								
								
									
										162
									
								
								include/ostream
									
									
									
									
									
								
							
							
						
						
									
										162
									
								
								include/ostream
									
									
									
									
									
								
							| @@ -32,7 +32,6 @@ public: | ||||
|     virtual ~basic_ostream(); | ||||
|  | ||||
|     // 27.7.2.3 Assign/swap | ||||
|     basic_ostream& operator=(const basic_ostream& rhs) = delete; // C++14 | ||||
|     basic_ostream& operator=(basic_ostream&& rhs); | ||||
|     void swap(basic_ostream& rhs); | ||||
|  | ||||
| @@ -134,14 +133,12 @@ template <class charT, class traits, class T> | ||||
| #include <iterator> | ||||
| #include <bitset> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| class _LIBCPP_TYPE_VIS_ONLY basic_ostream | ||||
| class _LIBCPP_VISIBLE basic_ostream | ||||
|     : virtual public basic_ios<_CharT, _Traits> | ||||
| { | ||||
| public: | ||||
| @@ -157,23 +154,18 @@ public: | ||||
|     virtual ~basic_ostream(); | ||||
| protected: | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     basic_ostream(basic_ostream&& __rhs); | ||||
| #endif | ||||
|  | ||||
|     // 27.7.2.3 Assign/swap | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|     basic_ostream& operator=(const basic_ostream&) = delete; | ||||
| #endif | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     basic_ostream& operator=(basic_ostream&& __rhs); | ||||
| #endif | ||||
|     void swap(basic_ostream& __rhs); | ||||
| public: | ||||
|  | ||||
|     // 27.7.2.4 Prefix/suffix: | ||||
|     class _LIBCPP_TYPE_VIS_ONLY sentry; | ||||
|     class sentry; | ||||
|  | ||||
|     // 27.7.2.6 Formatted output: | ||||
|     basic_ostream& operator<<(basic_ostream& (*__pf)(basic_ostream&)); | ||||
| @@ -211,7 +203,7 @@ protected: | ||||
| }; | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| class _LIBCPP_TYPE_VIS_ONLY basic_ostream<_CharT, _Traits>::sentry | ||||
| class _LIBCPP_VISIBLE basic_ostream<_CharT, _Traits>::sentry | ||||
| { | ||||
|     bool __ok_; | ||||
|     basic_ostream<_CharT, _Traits>& __os_; | ||||
| @@ -224,7 +216,7 @@ public: | ||||
|     ~sentry(); | ||||
|  | ||||
|     _LIBCPP_ALWAYS_INLINE | ||||
|         _LIBCPP_EXPLICIT | ||||
|     // explicit | ||||
|         operator bool() const {return __ok_;} | ||||
| }; | ||||
|  | ||||
| @@ -346,11 +338,11 @@ basic_ostream<_CharT, _Traits>::operator<<(basic_streambuf<char_type, traits_typ | ||||
|                 try | ||||
|                 { | ||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | ||||
|                     typedef istreambuf_iterator<_CharT, _Traits> _Ip; | ||||
|                     typedef ostreambuf_iterator<_CharT, _Traits> _Op; | ||||
|                     _Ip __i(__sb); | ||||
|                     _Ip __eof; | ||||
|                     _Op __o(*this); | ||||
|                     typedef istreambuf_iterator<_CharT, _Traits> _I; | ||||
|                     typedef ostreambuf_iterator<_CharT, _Traits> _O; | ||||
|                     _I __i(__sb); | ||||
|                     _I __eof; | ||||
|                     _O __o(*this); | ||||
|                     size_t __c = 0; | ||||
|                     for (; __i != __eof; ++__i, ++__o, ++__c) | ||||
|                     { | ||||
| @@ -392,8 +384,8 @@ basic_ostream<_CharT, _Traits>::operator<<(bool __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _Fp; | ||||
|             const _Fp& __f = use_facet<_Fp>(this->getloc()); | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _F; | ||||
|             const _F& __f = use_facet<_F>(this->getloc()); | ||||
|             if (__f.put(*this, *this, this->fill(), __n).failed()) | ||||
|                 this->setstate(ios_base::badbit | ios_base::failbit); | ||||
|         } | ||||
| @@ -419,8 +411,8 @@ basic_ostream<_CharT, _Traits>::operator<<(short __n) | ||||
|         if (__s) | ||||
|         { | ||||
|             ios_base::fmtflags __flags = ios_base::flags() & ios_base::basefield; | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _Fp; | ||||
|             const _Fp& __f = use_facet<_Fp>(this->getloc()); | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _F; | ||||
|             const _F& __f = use_facet<_F>(this->getloc()); | ||||
|             if (__f.put(*this, *this, this->fill(), | ||||
|                         __flags == ios_base::oct || __flags == ios_base::hex ? | ||||
|                         static_cast<long>(static_cast<unsigned short>(__n))  : | ||||
| @@ -448,8 +440,8 @@ basic_ostream<_CharT, _Traits>::operator<<(unsigned short __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _Fp; | ||||
|             const _Fp& __f = use_facet<_Fp>(this->getloc()); | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _F; | ||||
|             const _F& __f = use_facet<_F>(this->getloc()); | ||||
|             if (__f.put(*this, *this, this->fill(), static_cast<unsigned long>(__n)).failed()) | ||||
|                 this->setstate(ios_base::badbit | ios_base::failbit); | ||||
|         } | ||||
| @@ -475,8 +467,8 @@ basic_ostream<_CharT, _Traits>::operator<<(int __n) | ||||
|         if (__s) | ||||
|         { | ||||
|             ios_base::fmtflags __flags = ios_base::flags() & ios_base::basefield; | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _Fp; | ||||
|             const _Fp& __f = use_facet<_Fp>(this->getloc()); | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _F; | ||||
|             const _F& __f = use_facet<_F>(this->getloc()); | ||||
|             if (__f.put(*this, *this, this->fill(), | ||||
|                         __flags == ios_base::oct || __flags == ios_base::hex ? | ||||
|                         static_cast<long>(static_cast<unsigned int>(__n))  : | ||||
| @@ -504,8 +496,8 @@ basic_ostream<_CharT, _Traits>::operator<<(unsigned int __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _Fp; | ||||
|             const _Fp& __f = use_facet<_Fp>(this->getloc()); | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _F; | ||||
|             const _F& __f = use_facet<_F>(this->getloc()); | ||||
|             if (__f.put(*this, *this, this->fill(), static_cast<unsigned long>(__n)).failed()) | ||||
|                 this->setstate(ios_base::badbit | ios_base::failbit); | ||||
|         } | ||||
| @@ -530,8 +522,8 @@ basic_ostream<_CharT, _Traits>::operator<<(long __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _Fp; | ||||
|             const _Fp& __f = use_facet<_Fp>(this->getloc()); | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _F; | ||||
|             const _F& __f = use_facet<_F>(this->getloc()); | ||||
|             if (__f.put(*this, *this, this->fill(), __n).failed()) | ||||
|                 this->setstate(ios_base::badbit | ios_base::failbit); | ||||
|         } | ||||
| @@ -556,8 +548,8 @@ basic_ostream<_CharT, _Traits>::operator<<(unsigned long __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _Fp; | ||||
|             const _Fp& __f = use_facet<_Fp>(this->getloc()); | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _F; | ||||
|             const _F& __f = use_facet<_F>(this->getloc()); | ||||
|             if (__f.put(*this, *this, this->fill(), __n).failed()) | ||||
|                 this->setstate(ios_base::badbit | ios_base::failbit); | ||||
|         } | ||||
| @@ -582,8 +574,8 @@ basic_ostream<_CharT, _Traits>::operator<<(long long __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _Fp; | ||||
|             const _Fp& __f = use_facet<_Fp>(this->getloc()); | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _F; | ||||
|             const _F& __f = use_facet<_F>(this->getloc()); | ||||
|             if (__f.put(*this, *this, this->fill(), __n).failed()) | ||||
|                 this->setstate(ios_base::badbit | ios_base::failbit); | ||||
|         } | ||||
| @@ -608,8 +600,8 @@ basic_ostream<_CharT, _Traits>::operator<<(unsigned long long __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _Fp; | ||||
|             const _Fp& __f = use_facet<_Fp>(this->getloc()); | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _F; | ||||
|             const _F& __f = use_facet<_F>(this->getloc()); | ||||
|             if (__f.put(*this, *this, this->fill(), __n).failed()) | ||||
|                 this->setstate(ios_base::badbit | ios_base::failbit); | ||||
|         } | ||||
| @@ -634,8 +626,8 @@ basic_ostream<_CharT, _Traits>::operator<<(float __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _Fp; | ||||
|             const _Fp& __f = use_facet<_Fp>(this->getloc()); | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _F; | ||||
|             const _F& __f = use_facet<_F>(this->getloc()); | ||||
|             if (__f.put(*this, *this, this->fill(), static_cast<double>(__n)).failed()) | ||||
|                 this->setstate(ios_base::badbit | ios_base::failbit); | ||||
|         } | ||||
| @@ -660,8 +652,8 @@ basic_ostream<_CharT, _Traits>::operator<<(double __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _Fp; | ||||
|             const _Fp& __f = use_facet<_Fp>(this->getloc()); | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _F; | ||||
|             const _F& __f = use_facet<_F>(this->getloc()); | ||||
|             if (__f.put(*this, *this, this->fill(), __n).failed()) | ||||
|                 this->setstate(ios_base::badbit | ios_base::failbit); | ||||
|         } | ||||
| @@ -686,8 +678,8 @@ basic_ostream<_CharT, _Traits>::operator<<(long double __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _Fp; | ||||
|             const _Fp& __f = use_facet<_Fp>(this->getloc()); | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _F; | ||||
|             const _F& __f = use_facet<_F>(this->getloc()); | ||||
|             if (__f.put(*this, *this, this->fill(), __n).failed()) | ||||
|                 this->setstate(ios_base::badbit | ios_base::failbit); | ||||
|         } | ||||
| @@ -712,8 +704,8 @@ basic_ostream<_CharT, _Traits>::operator<<(const void* __n) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _Fp; | ||||
|             const _Fp& __f = use_facet<_Fp>(this->getloc()); | ||||
|             typedef num_put<char_type, ostreambuf_iterator<char_type, traits_type> > _F; | ||||
|             const _F& __f = use_facet<_F>(this->getloc()); | ||||
|             if (__f.put(*this, *this, this->fill(), __n).failed()) | ||||
|                 this->setstate(ios_base::badbit | ios_base::failbit); | ||||
|         } | ||||
| @@ -738,8 +730,8 @@ operator<<(basic_ostream<_CharT, _Traits>& __os, _CharT __c) | ||||
|         typename basic_ostream<_CharT, _Traits>::sentry __s(__os); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _Ip; | ||||
|             if (__pad_and_output(_Ip(__os), | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _I; | ||||
|             if (__pad_and_output(_I(__os), | ||||
|                                  &__c, | ||||
|                                  (__os.flags() & ios_base::adjustfield) == ios_base::left ? | ||||
|                                      &__c + 1 : | ||||
| @@ -771,8 +763,8 @@ operator<<(basic_ostream<_CharT, _Traits>& __os, char __cn) | ||||
|         if (__s) | ||||
|         { | ||||
|             _CharT __c = __os.widen(__cn); | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _Ip; | ||||
|             if (__pad_and_output(_Ip(__os), | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _I; | ||||
|             if (__pad_and_output(_I(__os), | ||||
|                                  &__c, | ||||
|                                  (__os.flags() & ios_base::adjustfield) == ios_base::left ? | ||||
|                                      &__c + 1 : | ||||
| @@ -803,8 +795,8 @@ operator<<(basic_ostream<char, _Traits>& __os, char __c) | ||||
|         typename basic_ostream<char, _Traits>::sentry __s(__os); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef ostreambuf_iterator<char, _Traits> _Ip; | ||||
|             if (__pad_and_output(_Ip(__os), | ||||
|             typedef ostreambuf_iterator<char, _Traits> _I; | ||||
|             if (__pad_and_output(_I(__os), | ||||
|                                  &__c, | ||||
|                                  (__os.flags() & ios_base::adjustfield) == ios_base::left ? | ||||
|                                      &__c + 1 : | ||||
| @@ -835,8 +827,8 @@ operator<<(basic_ostream<char, _Traits>& __os, signed char __c) | ||||
|         typename basic_ostream<char, _Traits>::sentry __s(__os); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef ostreambuf_iterator<char, _Traits> _Ip; | ||||
|             if (__pad_and_output(_Ip(__os), | ||||
|             typedef ostreambuf_iterator<char, _Traits> _I; | ||||
|             if (__pad_and_output(_I(__os), | ||||
|                                  (char*)&__c, | ||||
|                                  (__os.flags() & ios_base::adjustfield) == ios_base::left ? | ||||
|                                      (char*)&__c + 1 : | ||||
| @@ -867,8 +859,8 @@ operator<<(basic_ostream<char, _Traits>& __os, unsigned char __c) | ||||
|         typename basic_ostream<char, _Traits>::sentry __s(__os); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef ostreambuf_iterator<char, _Traits> _Ip; | ||||
|             if (__pad_and_output(_Ip(__os), | ||||
|             typedef ostreambuf_iterator<char, _Traits> _I; | ||||
|             if (__pad_and_output(_I(__os), | ||||
|                                  (char*)&__c, | ||||
|                                  (__os.flags() & ios_base::adjustfield) == ios_base::left ? | ||||
|                                      (char*)&__c + 1 : | ||||
| @@ -899,9 +891,9 @@ operator<<(basic_ostream<_CharT, _Traits>& __os, const _CharT* __str) | ||||
|         typename basic_ostream<_CharT, _Traits>::sentry __s(__os); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _Ip; | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _I; | ||||
|             size_t __len = _Traits::length(__str); | ||||
|             if (__pad_and_output(_Ip(__os), | ||||
|             if (__pad_and_output(_I(__os), | ||||
|                                  __str, | ||||
|                                  (__os.flags() & ios_base::adjustfield) == ios_base::left ? | ||||
|                                      __str + __len : | ||||
| @@ -932,7 +924,7 @@ operator<<(basic_ostream<_CharT, _Traits>& __os, const char* __strn) | ||||
|         typename basic_ostream<_CharT, _Traits>::sentry __s(__os); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _Ip; | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _I; | ||||
|             size_t __len = char_traits<char>::length(__strn); | ||||
|             const int __bs = 100; | ||||
|             _CharT __wbb[__bs]; | ||||
| @@ -947,7 +939,7 @@ operator<<(basic_ostream<_CharT, _Traits>& __os, const char* __strn) | ||||
|             } | ||||
|             for (_CharT* __p = __wb; *__strn != '\0'; ++__strn, ++__p) | ||||
|                 *__p = __os.widen(*__strn); | ||||
|             if (__pad_and_output(_Ip(__os), | ||||
|             if (__pad_and_output(_I(__os), | ||||
|                                  __wb, | ||||
|                                  (__os.flags() & ios_base::adjustfield) == ios_base::left ? | ||||
|                                      __wb + __len : | ||||
| @@ -978,9 +970,9 @@ operator<<(basic_ostream<char, _Traits>& __os, const char* __str) | ||||
|         typename basic_ostream<char, _Traits>::sentry __s(__os); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef ostreambuf_iterator<char, _Traits> _Ip; | ||||
|             typedef ostreambuf_iterator<char, _Traits> _I; | ||||
|             size_t __len = _Traits::length(__str); | ||||
|             if (__pad_and_output(_Ip(__os), | ||||
|             if (__pad_and_output(_I(__os), | ||||
|                                  __str, | ||||
|                                  (__os.flags() & ios_base::adjustfield) == ios_base::left ? | ||||
|                                      __str + __len : | ||||
| @@ -1011,9 +1003,9 @@ operator<<(basic_ostream<char, _Traits>& __os, const signed char* __str) | ||||
|         typename basic_ostream<char, _Traits>::sentry __s(__os); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef ostreambuf_iterator<char, _Traits> _Ip; | ||||
|             typedef ostreambuf_iterator<char, _Traits> _I; | ||||
|             size_t __len = _Traits::length((const char*)__str); | ||||
|             if (__pad_and_output(_Ip(__os), | ||||
|             if (__pad_and_output(_I(__os), | ||||
|                                  (const char*)__str, | ||||
|                                  (__os.flags() & ios_base::adjustfield) == ios_base::left ? | ||||
|                                      (const char*)__str + __len : | ||||
| @@ -1044,9 +1036,9 @@ operator<<(basic_ostream<char, _Traits>& __os, const unsigned char* __str) | ||||
|         typename basic_ostream<char, _Traits>::sentry __s(__os); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef ostreambuf_iterator<char, _Traits> _Ip; | ||||
|             typedef ostreambuf_iterator<char, _Traits> _I; | ||||
|             size_t __len = _Traits::length((const char*)__str); | ||||
|             if (__pad_and_output(_Ip(__os), | ||||
|             if (__pad_and_output(_I(__os), | ||||
|                                  (const char*)__str, | ||||
|                                  (__os.flags() & ios_base::adjustfield) == ios_base::left ? | ||||
|                                      (const char*)__str + __len : | ||||
| @@ -1077,8 +1069,8 @@ basic_ostream<_CharT, _Traits>::put(char_type __c) | ||||
|         sentry __s(*this); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _Op; | ||||
|             _Op __o(*this); | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _O; | ||||
|             _O __o(*this); | ||||
|             *__o = __c; | ||||
|             if (__o.failed()) | ||||
|                 this->setstate(ios_base::badbit); | ||||
| @@ -1104,8 +1096,17 @@ basic_ostream<_CharT, _Traits>::write(const char_type* __s, streamsize __n) | ||||
|         sentry __sen(*this); | ||||
|         if (__sen && __n) | ||||
|         { | ||||
|             if (this->rdbuf()->sputn(__s, __n) != __n) | ||||
|                 this->setstate(ios_base::badbit); | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _O; | ||||
|             _O __o(*this); | ||||
|             for (; __n; --__n, ++__o, ++__s) | ||||
|             { | ||||
|                 *__o = *__s; | ||||
|                 if (__o.failed()) | ||||
|                 { | ||||
|                     this->setstate(ios_base::badbit); | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | ||||
|     } | ||||
| @@ -1159,8 +1160,7 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| basic_ostream<_CharT, _Traits>& | ||||
| basic_ostream<_CharT, _Traits>::seekp(pos_type __pos) | ||||
| { | ||||
|     sentry __s(*this); | ||||
|     if (__s) | ||||
|     if (!this->fail()) | ||||
|     { | ||||
|         if (this->rdbuf()->pubseekpos(__pos, ios_base::out) == pos_type(-1)) | ||||
|             this->setstate(ios_base::failbit); | ||||
| @@ -1173,12 +1173,8 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| basic_ostream<_CharT, _Traits>& | ||||
| basic_ostream<_CharT, _Traits>::seekp(off_type __off, ios_base::seekdir __dir) | ||||
| { | ||||
|     sentry __s(*this); | ||||
|     if (__s) | ||||
|     { | ||||
|         if (this->rdbuf()->pubseekoff(__off, __dir, ios_base::out) == pos_type(-1)) | ||||
|             this->setstate(ios_base::failbit); | ||||
|     } | ||||
|     if (!this->fail()) | ||||
|         this->rdbuf()->pubseekoff(__off, __dir, ios_base::out); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| @@ -1218,12 +1214,12 @@ typename enable_if | ||||
| < | ||||
|     !is_lvalue_reference<_Stream>::value && | ||||
|     is_base_of<ios_base, _Stream>::value, | ||||
|     _Stream&& | ||||
|     _Stream& | ||||
| >::type | ||||
| operator<<(_Stream&& __os, const _Tp& __x) | ||||
| { | ||||
|     __os << __x; | ||||
|     return _VSTD::move(__os); | ||||
|     return __os; | ||||
| } | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| @@ -1240,9 +1236,9 @@ operator<<(basic_ostream<_CharT, _Traits>& __os, | ||||
|         typename basic_ostream<_CharT, _Traits>::sentry __s(__os); | ||||
|         if (__s) | ||||
|         { | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _Ip; | ||||
|             typedef ostreambuf_iterator<_CharT, _Traits> _I; | ||||
|             size_t __len = __str.size(); | ||||
|             if (__pad_and_output(_Ip(__os), | ||||
|             if (__pad_and_output(_I(__os), | ||||
|                                  __str.data(), | ||||
|                                  (__os.flags() & ios_base::adjustfield) == ios_base::left ? | ||||
|                                      __str.data() + __len : | ||||
| @@ -1270,10 +1266,10 @@ operator<<(basic_ostream<_CharT, _Traits>& __os, const error_code& __ec) | ||||
|     return __os << __ec.category().name() << ':' << __ec.value(); | ||||
| } | ||||
|  | ||||
| template<class _CharT, class _Traits, class _Yp> | ||||
| template<class _CharT, class _Traits, class _Y> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| basic_ostream<_CharT, _Traits>& | ||||
| operator<<(basic_ostream<_CharT, _Traits>& __os, shared_ptr<_Yp> const& __p) | ||||
| operator<<(basic_ostream<_CharT, _Traits>& __os, shared_ptr<_Y> const& __p) | ||||
| { | ||||
|     return __os << __p.get(); | ||||
| } | ||||
| @@ -1287,8 +1283,8 @@ operator<<(basic_ostream<_CharT, _Traits>& __os, const bitset<_Size>& __x) | ||||
|                          use_facet<ctype<_CharT> >(__os.getloc()).widen('1')); | ||||
| } | ||||
|  | ||||
| _LIBCPP_EXTERN_TEMPLATE(class _LIBCPP_TYPE_VIS basic_ostream<char>) | ||||
| _LIBCPP_EXTERN_TEMPLATE(class _LIBCPP_TYPE_VIS basic_ostream<wchar_t>) | ||||
| extern template class basic_ostream<char>; | ||||
| extern template class basic_ostream<wchar_t>; | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
							
								
								
									
										203
									
								
								include/queue
									
									
									
									
									
								
							
							
						
						
									
										203
									
								
								include/queue
									
									
									
									
									
								
							| @@ -31,28 +31,21 @@ protected: | ||||
|     container_type c; | ||||
|  | ||||
| public: | ||||
|     queue() = default; | ||||
|     ~queue() = default; | ||||
|  | ||||
|     queue(const queue& q) = default; | ||||
|     queue(queue&& q) = default; | ||||
|  | ||||
|     queue& operator=(const queue& q) = default; | ||||
|     queue& operator=(queue&& q) = default; | ||||
|  | ||||
|     queue(); | ||||
|     explicit queue(const container_type& c); | ||||
|     explicit queue(container_type&& c) | ||||
|     explicit queue(container_type&& c); | ||||
|     queue(queue&& q); | ||||
|     template <class Alloc> | ||||
|         explicit queue(const Alloc& a); | ||||
|     template <class Alloc> | ||||
|         queue(const container_type& c, const Alloc& a); | ||||
|     template <class Alloc> | ||||
|         queue(container_type&& c, const Alloc& a); | ||||
|     template <class Alloc> | ||||
|         queue(const queue& q, const Alloc& a); | ||||
|     template <class Alloc> | ||||
|         queue(queue&& q, const Alloc& a); | ||||
|  | ||||
|     queue& operator=(queue&& q); | ||||
|  | ||||
|     bool      empty() const; | ||||
|     size_type size() const; | ||||
|  | ||||
| @@ -66,7 +59,7 @@ public: | ||||
|     template <class... Args> void emplace(Args&&... args); | ||||
|     void pop(); | ||||
|  | ||||
|     void swap(queue& q) noexcept(noexcept(swap(c, q.c))); | ||||
|     void swap(queue& q); | ||||
| }; | ||||
|  | ||||
| template <class T, class Container> | ||||
| @@ -88,8 +81,7 @@ template <class T, class Container> | ||||
|   bool operator<=(const queue<T, Container>& x,const queue<T, Container>& y); | ||||
|  | ||||
| template <class T, class Container> | ||||
|   void swap(queue<T, Container>& x, queue<T, Container>& y) | ||||
|   noexcept(noexcept(x.swap(y))); | ||||
|   void swap(queue<T, Container>& x, queue<T, Container>& y); | ||||
|  | ||||
| template <class T, class Container = vector<T>, | ||||
|           class Compare = less<typename Container::value_type>> | ||||
| @@ -107,16 +99,7 @@ protected: | ||||
|     Compare comp; | ||||
|  | ||||
| public: | ||||
|     priority_queue() = default; | ||||
|     ~priority_queue() = default; | ||||
|  | ||||
|     priority_queue(const priority_queue& q) = default; | ||||
|     priority_queue(priority_queue&& q) = default; | ||||
|  | ||||
|     priority_queue& operator=(const priority_queue& q) = default; | ||||
|     priority_queue& operator=(priority_queue&& q) = default; | ||||
|  | ||||
|     explicit priority_queue(const Compare& comp); | ||||
|     explicit priority_queue(const Compare& comp = Compare()); | ||||
|     priority_queue(const Compare& comp, const container_type& c); | ||||
|     explicit priority_queue(const Compare& comp, container_type&& c); | ||||
|     template <class InputIterator> | ||||
| @@ -128,6 +111,8 @@ public: | ||||
|     template <class InputIterator> | ||||
|         priority_queue(InputIterator first, InputIterator last, | ||||
|                        const Compare& comp, container_type&& c); | ||||
|     priority_queue(priority_queue&& q); | ||||
|     priority_queue& operator=(priority_queue&& q); | ||||
|     template <class Alloc> | ||||
|         explicit priority_queue(const Alloc& a); | ||||
|     template <class Alloc> | ||||
| @@ -138,8 +123,6 @@ public: | ||||
|     template <class Alloc> | ||||
|         priority_queue(const Compare& comp, container_type&& c, | ||||
|                        const Alloc& a); | ||||
|     template <class Alloc> | ||||
|         priority_queue(const priority_queue& q, const Alloc& a); | ||||
|     template <class Alloc> | ||||
|         priority_queue(priority_queue&& q, const Alloc& a); | ||||
|  | ||||
| @@ -152,14 +135,12 @@ public: | ||||
|     template <class... Args> void emplace(Args&&... args); | ||||
|     void pop(); | ||||
|  | ||||
|     void swap(priority_queue& q) | ||||
|         noexcept(noexcept(swap(c, q.c)) && noexcept(swap(comp.q.comp))); | ||||
|     void swap(priority_queue& q); | ||||
| }; | ||||
|  | ||||
| template <class T, class Container, class Compare> | ||||
|   void swap(priority_queue<T, Container, Compare>& x, | ||||
|             priority_queue<T, Container, Compare>& y) | ||||
|             noexcept(noexcept(x.swap(y))); | ||||
|             priority_queue<T, Container, Compare>& y); | ||||
|  | ||||
| }  // std | ||||
|  | ||||
| @@ -171,26 +152,22 @@ template <class T, class Container, class Compare> | ||||
| #include <functional> | ||||
| #include <algorithm> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template <class _Tp, class _Container> class _LIBCPP_TYPE_VIS_ONLY queue; | ||||
| template <class _Tp, class _Container> class queue; | ||||
|  | ||||
| template <class _Tp, class _Container> | ||||
| _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator==(const queue<_Tp, _Container>& __x,const queue<_Tp, _Container>& __y); | ||||
|  | ||||
| template <class _Tp, class _Container> | ||||
| _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator< (const queue<_Tp, _Container>& __x,const queue<_Tp, _Container>& __y); | ||||
|  | ||||
| template <class _Tp, class _Container = deque<_Tp> > | ||||
| class _LIBCPP_TYPE_VIS_ONLY queue | ||||
| class _LIBCPP_VISIBLE queue | ||||
| { | ||||
| public: | ||||
|     typedef _Container                               container_type; | ||||
| @@ -204,35 +181,14 @@ protected: | ||||
|  | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     queue() | ||||
|         _NOEXCEPT_(is_nothrow_default_constructible<container_type>::value) | ||||
|         : c() {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     queue(const queue& __q) : c(__q.c) {} | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     queue(queue&& __q) | ||||
|         _NOEXCEPT_(is_nothrow_move_constructible<container_type>::value) | ||||
|         : c(_VSTD::move(__q.c)) {} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     queue& operator=(const queue& __q) {c = __q.c; return *this;} | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     queue& operator=(queue&& __q) | ||||
|         _NOEXCEPT_(is_nothrow_move_assignable<container_type>::value) | ||||
|         {c = _VSTD::move(__q.c); return *this;} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
|     queue() : c() {} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit queue(const container_type& __c)  : c(__c) {} | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit queue(container_type&& __c) : c(_VSTD::move(__c)) {} | ||||
|     explicit queue(container_type&& __c) : c(_STD::move(__c)) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     queue(queue&& __q) : c(_STD::move(__q.c)) {} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     template <class _Alloc> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -258,14 +214,20 @@ public: | ||||
|         queue(container_type&& __c, const _Alloc& __a, | ||||
|                        typename enable_if<uses_allocator<container_type, | ||||
|                                                          _Alloc>::value>::type* = 0) | ||||
|             : c(_VSTD::move(__c), __a) {} | ||||
|             : c(_STD::move(__c), __a) {} | ||||
|     template <class _Alloc> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         queue(queue&& __q, const _Alloc& __a, | ||||
|                        typename enable_if<uses_allocator<container_type, | ||||
|                                                          _Alloc>::value>::type* = 0) | ||||
|             : c(_VSTD::move(__q.c), __a) {} | ||||
|             : c(_STD::move(__q.c), __a) {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     queue& operator=(queue&& __q) | ||||
|     { | ||||
|         c = _STD::move(__q.c); | ||||
|         return *this; | ||||
|     } | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -286,12 +248,12 @@ public: | ||||
|     void push(const value_type& __v) {c.push_back(__v);} | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void push(value_type&& __v)      {c.push_back(_VSTD::move(__v));} | ||||
|     void push(value_type&& __v)      {c.push_back(_STD::move(__v));} | ||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||
|     template <class... _Args> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         void emplace(_Args&&... __args) | ||||
|             {c.emplace_back(_VSTD::forward<_Args>(__args)...);} | ||||
|             {c.emplace_back(_STD::forward<_Args>(__args)...);} | ||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -299,9 +261,8 @@ public: | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void swap(queue& __q) | ||||
|         _NOEXCEPT_(__is_nothrow_swappable<container_type>::value) | ||||
|     { | ||||
|         using _VSTD::swap; | ||||
|         using _STD::swap; | ||||
|         swap(c, __q.c); | ||||
|     } | ||||
|  | ||||
| @@ -370,20 +331,19 @@ template <class _Tp, class _Container> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| swap(queue<_Tp, _Container>& __x, queue<_Tp, _Container>& __y) | ||||
|     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||
| { | ||||
|     __x.swap(__y); | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Container, class _Alloc> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY uses_allocator<queue<_Tp, _Container>, _Alloc> | ||||
| struct _LIBCPP_VISIBLE uses_allocator<queue<_Tp, _Container>, _Alloc> | ||||
|     : public uses_allocator<_Container, _Alloc> | ||||
| { | ||||
| }; | ||||
|  | ||||
| template <class _Tp, class _Container = vector<_Tp>, | ||||
|           class _Compare = less<typename _Container::value_type> > | ||||
| class _LIBCPP_TYPE_VIS_ONLY priority_queue | ||||
| class _LIBCPP_VISIBLE priority_queue | ||||
| { | ||||
| public: | ||||
|     typedef _Container                               container_type; | ||||
| @@ -399,36 +359,7 @@ protected: | ||||
|  | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     priority_queue() | ||||
|         _NOEXCEPT_(is_nothrow_default_constructible<container_type>::value && | ||||
|                    is_nothrow_default_constructible<value_compare>::value) | ||||
|         : c(), comp() {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     priority_queue(const priority_queue& __q) : c(__q.c), comp(__q.comp) {} | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     priority_queue(priority_queue&& __q) | ||||
|         _NOEXCEPT_(is_nothrow_move_constructible<container_type>::value && | ||||
|                    is_nothrow_move_constructible<value_compare>::value) | ||||
|         : c(_VSTD::move(__q.c)), comp(_VSTD::move(__q.comp)) {} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     priority_queue& operator=(const priority_queue& __q) | ||||
|         {c = __q.c; comp = __q.comp; return *this;} | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     priority_queue& operator=(priority_queue&& __q) | ||||
|         _NOEXCEPT_(is_nothrow_move_assignable<container_type>::value && | ||||
|                    is_nothrow_move_assignable<value_compare>::value) | ||||
|         {c = _VSTD::move(__q.c); comp = _VSTD::move(__q.comp); return *this;} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit priority_queue(const value_compare& __comp) | ||||
|     explicit priority_queue(const value_compare& __comp = value_compare()) | ||||
|         : c(), comp(__comp) {} | ||||
|     priority_queue(const value_compare& __comp, const container_type& __c); | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| @@ -444,6 +375,8 @@ public: | ||||
|     template <class _InputIter> | ||||
|         priority_queue(_InputIter __f, _InputIter __l, | ||||
|                        const value_compare& __comp, container_type&& __c); | ||||
|     priority_queue(priority_queue&& __q); | ||||
|     priority_queue& operator=(priority_queue&& __q); | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     template <class _Alloc> | ||||
|         explicit priority_queue(const _Alloc& __a, | ||||
| @@ -490,9 +423,7 @@ public: | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     void pop(); | ||||
|  | ||||
|     void swap(priority_queue& __q) | ||||
|         _NOEXCEPT_(__is_nothrow_swappable<container_type>::value && | ||||
|                    __is_nothrow_swappable<value_compare>::value); | ||||
|     void swap(priority_queue& __q); | ||||
| }; | ||||
|  | ||||
| template <class _Tp, class _Container, class _Compare> | ||||
| @@ -502,7 +433,7 @@ priority_queue<_Tp, _Container, _Compare>::priority_queue(const _Compare& __comp | ||||
|     : c(__c), | ||||
|       comp(__comp) | ||||
| { | ||||
|     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||
|     _STD::make_heap(c.begin(), c.end(), comp); | ||||
| } | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| @@ -511,10 +442,10 @@ template <class _Tp, class _Container, class _Compare> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| priority_queue<_Tp, _Container, _Compare>::priority_queue(const value_compare& __comp, | ||||
|                                                           container_type&& __c) | ||||
|     : c(_VSTD::move(__c)), | ||||
|     : c(_STD::move(__c)), | ||||
|       comp(__comp) | ||||
| { | ||||
|     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||
|     _STD::make_heap(c.begin(), c.end(), comp); | ||||
| } | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| @@ -527,7 +458,7 @@ priority_queue<_Tp, _Container, _Compare>::priority_queue(_InputIter __f, _Input | ||||
|     : c(__f, __l), | ||||
|       comp(__comp) | ||||
| { | ||||
|     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||
|     _STD::make_heap(c.begin(), c.end(), comp); | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Container, class _Compare> | ||||
| @@ -540,7 +471,7 @@ priority_queue<_Tp, _Container, _Compare>::priority_queue(_InputIter __f, _Input | ||||
|       comp(__comp) | ||||
| { | ||||
|     c.insert(c.end(), __f, __l); | ||||
|     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||
|     _STD::make_heap(c.begin(), c.end(), comp); | ||||
| } | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| @@ -551,11 +482,28 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| priority_queue<_Tp, _Container, _Compare>::priority_queue(_InputIter __f, _InputIter __l, | ||||
|                                                           const value_compare& __comp, | ||||
|                                                           container_type&& __c) | ||||
|     : c(_VSTD::move(__c)), | ||||
|     : c(_STD::move(__c)), | ||||
|       comp(__comp) | ||||
| { | ||||
|     c.insert(c.end(), __f, __l); | ||||
|     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||
|     _STD::make_heap(c.begin(), c.end(), comp); | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Container, class _Compare> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| priority_queue<_Tp, _Container, _Compare>::priority_queue(priority_queue&& __q) | ||||
|     : c(_STD::move(__q.c)), | ||||
|       comp(_STD::move(__q.comp)) | ||||
| { | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Container, class _Compare> | ||||
| priority_queue<_Tp, _Container, _Compare>& | ||||
| priority_queue<_Tp, _Container, _Compare>::operator=(priority_queue&& __q) | ||||
| { | ||||
|     c = _STD::move(__q.c); | ||||
|     comp = _STD::move(__q.comp); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| @@ -593,7 +541,7 @@ priority_queue<_Tp, _Container, _Compare>::priority_queue(const value_compare& _ | ||||
|     : c(__c, __a), | ||||
|       comp(__comp) | ||||
| { | ||||
|     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||
|     _STD::make_heap(c.begin(), c.end(), comp); | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Container, class _Compare> | ||||
| @@ -606,7 +554,7 @@ priority_queue<_Tp, _Container, _Compare>::priority_queue(const priority_queue& | ||||
|     : c(__q.c, __a), | ||||
|       comp(__q.comp) | ||||
| { | ||||
|     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||
|     _STD::make_heap(c.begin(), c.end(), comp); | ||||
| } | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| @@ -619,10 +567,10 @@ priority_queue<_Tp, _Container, _Compare>::priority_queue(const value_compare& _ | ||||
|                                                           const _Alloc& __a, | ||||
|                        typename enable_if<uses_allocator<container_type, | ||||
|                                                          _Alloc>::value>::type*) | ||||
|     : c(_VSTD::move(__c), __a), | ||||
|     : c(_STD::move(__c), __a), | ||||
|       comp(__comp) | ||||
| { | ||||
|     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||
|     _STD::make_heap(c.begin(), c.end(), comp); | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Container, class _Compare> | ||||
| @@ -632,10 +580,10 @@ priority_queue<_Tp, _Container, _Compare>::priority_queue(priority_queue&& __q, | ||||
|                                                           const _Alloc& __a, | ||||
|                        typename enable_if<uses_allocator<container_type, | ||||
|                                                          _Alloc>::value>::type*) | ||||
|     : c(_VSTD::move(__q.c), __a), | ||||
|       comp(_VSTD::move(__q.comp)) | ||||
|     : c(_STD::move(__q.c), __a), | ||||
|       comp(_STD::move(__q.comp)) | ||||
| { | ||||
|     _VSTD::make_heap(c.begin(), c.end(), comp); | ||||
|     _STD::make_heap(c.begin(), c.end(), comp); | ||||
| } | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| @@ -646,7 +594,7 @@ void | ||||
| priority_queue<_Tp, _Container, _Compare>::push(const value_type& __v) | ||||
| { | ||||
|     c.push_back(__v); | ||||
|     _VSTD::push_heap(c.begin(), c.end(), comp); | ||||
|     _STD::push_heap(c.begin(), c.end(), comp); | ||||
| } | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| @@ -656,8 +604,8 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| priority_queue<_Tp, _Container, _Compare>::push(value_type&& __v) | ||||
| { | ||||
|     c.push_back(_VSTD::move(__v)); | ||||
|     _VSTD::push_heap(c.begin(), c.end(), comp); | ||||
|     c.push_back(_STD::move(__v)); | ||||
|     _STD::push_heap(c.begin(), c.end(), comp); | ||||
| } | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||
| @@ -668,8 +616,8 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| priority_queue<_Tp, _Container, _Compare>::emplace(_Args&&... __args) | ||||
| { | ||||
|     c.emplace_back(_VSTD::forward<_Args>(__args)...); | ||||
|     _VSTD::push_heap(c.begin(), c.end(), comp); | ||||
|     c.emplace_back(_STD::forward<_Args>(__args)...); | ||||
|     _STD::push_heap(c.begin(), c.end(), comp); | ||||
| } | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||
| @@ -680,7 +628,7 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| priority_queue<_Tp, _Container, _Compare>::pop() | ||||
| { | ||||
|     _VSTD::pop_heap(c.begin(), c.end(), comp); | ||||
|     _STD::pop_heap(c.begin(), c.end(), comp); | ||||
|     c.pop_back(); | ||||
| } | ||||
|  | ||||
| @@ -688,10 +636,8 @@ template <class _Tp, class _Container, class _Compare> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| priority_queue<_Tp, _Container, _Compare>::swap(priority_queue& __q) | ||||
|         _NOEXCEPT_(__is_nothrow_swappable<container_type>::value && | ||||
|                    __is_nothrow_swappable<value_compare>::value) | ||||
| { | ||||
|     using _VSTD::swap; | ||||
|     using _STD::swap; | ||||
|     swap(c, __q.c); | ||||
|     swap(comp, __q.comp); | ||||
| } | ||||
| @@ -701,13 +647,12 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| swap(priority_queue<_Tp, _Container, _Compare>& __x, | ||||
|      priority_queue<_Tp, _Container, _Compare>& __y) | ||||
|     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||
| { | ||||
|     __x.swap(__y); | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Container, class _Compare, class _Alloc> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY uses_allocator<priority_queue<_Tp, _Container, _Compare>, _Alloc> | ||||
| struct _LIBCPP_VISIBLE uses_allocator<priority_queue<_Tp, _Container, _Compare>, _Alloc> | ||||
|     : public uses_allocator<_Container, _Alloc> | ||||
| { | ||||
| }; | ||||
|   | ||||
							
								
								
									
										1267
									
								
								include/random
									
									
									
									
									
								
							
							
						
						
									
										1267
									
								
								include/random
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -70,11 +70,7 @@ typedef ratio<1000000000000000000000000, 1> yotta;  // not supported | ||||
| #include <climits> | ||||
| #include <type_traits> | ||||
|  | ||||
| #include <__undef_min_max> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| @@ -92,12 +88,6 @@ struct __static_gcd<_Xp, 0> | ||||
|     static const intmax_t value = _Xp; | ||||
| }; | ||||
|  | ||||
| template <> | ||||
| struct __static_gcd<0, 0> | ||||
| { | ||||
|     static const intmax_t value = 1; | ||||
| }; | ||||
|  | ||||
| // __static_lcm | ||||
|  | ||||
| template <intmax_t _Xp, intmax_t _Yp> | ||||
| @@ -231,7 +221,7 @@ public: | ||||
| }; | ||||
|  | ||||
| template <intmax_t _Num, intmax_t _Den = 1> | ||||
| class _LIBCPP_TYPE_VIS_ONLY ratio | ||||
| class _LIBCPP_VISIBLE ratio | ||||
| { | ||||
|     static_assert(__static_abs<_Num>::value >= 0, "ratio numerator is out of range"); | ||||
|     static_assert(_Den != 0, "ratio divide by 0"); | ||||
| @@ -284,19 +274,10 @@ public: | ||||
|         >::type type; | ||||
| }; | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
|  | ||||
| template <class _R1, class _R2> using ratio_multiply | ||||
|                                     = typename __ratio_multiply<_R1, _R2>::type; | ||||
|  | ||||
| #else  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
|  | ||||
| template <class _R1, class _R2> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY ratio_multiply | ||||
| struct _LIBCPP_VISIBLE ratio_multiply | ||||
|     : public __ratio_multiply<_R1, _R2>::type {}; | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
|  | ||||
| template <class _R1, class _R2> | ||||
| struct __ratio_divide | ||||
| { | ||||
| @@ -311,19 +292,10 @@ public: | ||||
|         >::type type; | ||||
| }; | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
|  | ||||
| template <class _R1, class _R2> using ratio_divide | ||||
|                                       = typename __ratio_divide<_R1, _R2>::type; | ||||
|  | ||||
| #else  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
|  | ||||
| template <class _R1, class _R2> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY ratio_divide | ||||
| struct _LIBCPP_VISIBLE ratio_divide | ||||
|     : public __ratio_divide<_R1, _R2>::type {}; | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
|  | ||||
| template <class _R1, class _R2> | ||||
| struct __ratio_add | ||||
| { | ||||
| @@ -346,19 +318,10 @@ public: | ||||
|         >::type type; | ||||
| }; | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
|  | ||||
| template <class _R1, class _R2> using ratio_add | ||||
|                                          = typename __ratio_add<_R1, _R2>::type; | ||||
|  | ||||
| #else  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
|  | ||||
| template <class _R1, class _R2> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY ratio_add | ||||
| struct _LIBCPP_VISIBLE ratio_add | ||||
|     : public __ratio_add<_R1, _R2>::type {}; | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
|  | ||||
| template <class _R1, class _R2> | ||||
| struct __ratio_subtract | ||||
| { | ||||
| @@ -381,27 +344,18 @@ public: | ||||
|         >::type type; | ||||
| }; | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
|  | ||||
| template <class _R1, class _R2> using ratio_subtract | ||||
|                                     = typename __ratio_subtract<_R1, _R2>::type; | ||||
|  | ||||
| #else  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
|  | ||||
| template <class _R1, class _R2> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY ratio_subtract | ||||
| struct _LIBCPP_VISIBLE ratio_subtract | ||||
|     : public __ratio_subtract<_R1, _R2>::type {}; | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_TEMPLATE_ALIASES | ||||
|  | ||||
| // ratio_equal | ||||
|  | ||||
| template <class _R1, class _R2> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY ratio_equal | ||||
| struct _LIBCPP_VISIBLE ratio_equal | ||||
|     : public integral_constant<bool, _R1::num == _R2::num && _R1::den == _R2::den> {}; | ||||
|  | ||||
| template <class _R1, class _R2> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY ratio_not_equal | ||||
| struct _LIBCPP_VISIBLE ratio_not_equal | ||||
|     : public integral_constant<bool, !ratio_equal<_R1, _R2>::value> {}; | ||||
|  | ||||
| // ratio_less | ||||
| @@ -414,27 +368,27 @@ struct __ratio_less1 | ||||
|     static const bool value = _Odd ? _Q2 < _Q1 : _Q1 < _Q2; | ||||
| }; | ||||
|  | ||||
| template <class _R1, class _R2, bool _Odd, intmax_t _Qp> | ||||
| struct __ratio_less1<_R1, _R2, _Odd, _Qp, 0, _Qp, 0> | ||||
| template <class _R1, class _R2, bool _Odd, intmax_t _Q> | ||||
| struct __ratio_less1<_R1, _R2, _Odd, _Q, 0, _Q, 0> | ||||
| { | ||||
|     static const bool value = false; | ||||
| }; | ||||
|  | ||||
| template <class _R1, class _R2, bool _Odd, intmax_t _Qp, intmax_t _M2> | ||||
| struct __ratio_less1<_R1, _R2, _Odd, _Qp, 0, _Qp, _M2> | ||||
| template <class _R1, class _R2, bool _Odd, intmax_t _Q, intmax_t _M2> | ||||
| struct __ratio_less1<_R1, _R2, _Odd, _Q, 0, _Q, _M2> | ||||
| { | ||||
|     static const bool value = !_Odd; | ||||
| }; | ||||
|  | ||||
| template <class _R1, class _R2, bool _Odd, intmax_t _Qp, intmax_t _M1> | ||||
| struct __ratio_less1<_R1, _R2, _Odd, _Qp, _M1, _Qp, 0> | ||||
| template <class _R1, class _R2, bool _Odd, intmax_t _Q, intmax_t _M1> | ||||
| struct __ratio_less1<_R1, _R2, _Odd, _Q, _M1, _Q, 0> | ||||
| { | ||||
|     static const bool value = _Odd; | ||||
| }; | ||||
|  | ||||
| template <class _R1, class _R2, bool _Odd, intmax_t _Qp, intmax_t _M1, | ||||
| template <class _R1, class _R2, bool _Odd, intmax_t _Q, intmax_t _M1, | ||||
|                                                         intmax_t _M2> | ||||
| struct __ratio_less1<_R1, _R2, _Odd, _Qp, _M1, _Qp, _M2> | ||||
| struct __ratio_less1<_R1, _R2, _Odd, _Q, _M1, _Q, _M2> | ||||
| { | ||||
|     static const bool value = __ratio_less1<ratio<_R1::den, _M1>, | ||||
|                                             ratio<_R2::den, _M2>, !_Odd>::value; | ||||
| @@ -460,19 +414,19 @@ struct __ratio_less<_R1, _R2, -1LL, -1LL> | ||||
| }; | ||||
|  | ||||
| template <class _R1, class _R2> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY ratio_less | ||||
| struct _LIBCPP_VISIBLE ratio_less | ||||
|     : public integral_constant<bool, __ratio_less<_R1, _R2>::value> {}; | ||||
|  | ||||
| template <class _R1, class _R2> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY ratio_less_equal | ||||
| struct _LIBCPP_VISIBLE ratio_less_equal | ||||
|     : public integral_constant<bool, !ratio_less<_R2, _R1>::value> {}; | ||||
|  | ||||
| template <class _R1, class _R2> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY ratio_greater | ||||
| struct _LIBCPP_VISIBLE ratio_greater | ||||
|     : public integral_constant<bool, ratio_less<_R2, _R1>::value> {}; | ||||
|  | ||||
| template <class _R1, class _R2> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY ratio_greater_equal | ||||
| struct _LIBCPP_VISIBLE ratio_greater_equal | ||||
|     : public integral_constant<bool, !ratio_less<_R1, _R2>::value> {}; | ||||
|  | ||||
| template <class _R1, class _R2> | ||||
|   | ||||
							
								
								
									
										502
									
								
								include/regex
									
									
									
									
									
								
							
							
						
						
									
										502
									
								
								include/regex
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -49,25 +49,24 @@ public: | ||||
|     scoped_allocator_adaptor(); | ||||
|     template <class OuterA2> | ||||
|         scoped_allocator_adaptor(OuterA2&& outerAlloc, | ||||
|                                  const InnerAllocs&... innerAllocs) noexcept; | ||||
|     scoped_allocator_adaptor(const scoped_allocator_adaptor& other) noexcept; | ||||
|     scoped_allocator_adaptor(scoped_allocator_adaptor&& other) noexcept; | ||||
|                                  const InnerAllocs&... innerAllocs); | ||||
|     scoped_allocator_adaptor(const scoped_allocator_adaptor& other); | ||||
|     template <class OuterA2> | ||||
|         scoped_allocator_adaptor(const scoped_allocator_adaptor<OuterA2, InnerAllocs...>& other) noexcept; | ||||
|         scoped_allocator_adaptor(const scoped_allocator_adaptor<OuterA2, InnerAllocs...>& other); | ||||
|     template <class OuterA2> | ||||
|         scoped_allocator_adaptor(const scoped_allocator_adaptor<OuterA2, InnerAllocs...>&& other) noexcept; | ||||
|         scoped_allocator_adaptor(const scoped_allocator_adaptor<OuterA2, InnerAllocs...>&& other); | ||||
|  | ||||
|     ~scoped_allocator_adaptor(); | ||||
|  | ||||
|     inner_allocator_type& inner_allocator() noexcept; | ||||
|     const inner_allocator_type& inner_allocator() const noexcept; | ||||
|     inner_allocator_type& inner_allocator(); | ||||
|     const inner_allocator_type& inner_allocator() const; | ||||
|  | ||||
|     outer_allocator_type& outer_allocator() noexcept; | ||||
|     const outer_allocator_type& outer_allocator() const noexcept; | ||||
|     outer_allocator_type& outer_allocator(); | ||||
|     const outer_allocator_type& outer_allocator() const; | ||||
|  | ||||
|     pointer allocate(size_type n); | ||||
|     pointer allocate(size_type n, const_void_pointer hint); | ||||
|     void deallocate(pointer p, size_type n) noexcept; | ||||
|     void deallocate(pointer p, size_type n); | ||||
|  | ||||
|     size_type max_size() const; | ||||
|     template <class T, class... Args> void construct(T* p, Args&& args); | ||||
| @@ -84,20 +83,18 @@ public: | ||||
|         void construct(pair<T1, T2>* p, pair<U, V>&& x); | ||||
|     template <class T> void destroy(T* p); | ||||
|  | ||||
|     template <class T> void destroy(T* p) noexcept; | ||||
|  | ||||
|     scoped_allocator_adaptor select_on_container_copy_construction() const noexcept; | ||||
|     scoped_allocator_adaptor select_on_container_copy_construction() const; | ||||
| }; | ||||
|  | ||||
| template <class OuterA1, class OuterA2, class... InnerAllocs> | ||||
|     bool | ||||
|     operator==(const scoped_allocator_adaptor<OuterA1, InnerAllocs...>& a, | ||||
|                const scoped_allocator_adaptor<OuterA2, InnerAllocs...>& b) noexcept; | ||||
|                const scoped_allocator_adaptor<OuterA2, InnerAllocs...>& b); | ||||
|  | ||||
| template <class OuterA1, class OuterA2, class... InnerAllocs> | ||||
|     bool | ||||
|     operator!=(const scoped_allocator_adaptor<OuterA1, InnerAllocs...>& a, | ||||
|                const scoped_allocator_adaptor<OuterA2, InnerAllocs...>& b) noexcept; | ||||
|                const scoped_allocator_adaptor<OuterA2, InnerAllocs...>& b); | ||||
|  | ||||
| }  // std | ||||
|  | ||||
| @@ -106,9 +103,7 @@ template <class OuterA1, class OuterA2, class... InnerAllocs> | ||||
| #include <__config> | ||||
| #include <memory> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| @@ -187,7 +182,7 @@ private: | ||||
| protected: | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     __scoped_allocator_storage() _NOEXCEPT {} | ||||
|     __scoped_allocator_storage() {} | ||||
|  | ||||
|     template <class _OuterA2, | ||||
|               class = typename enable_if< | ||||
| @@ -195,8 +190,8 @@ protected: | ||||
|                       >::type> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         __scoped_allocator_storage(_OuterA2&& __outerAlloc, | ||||
|                                    const _InnerAllocs& ...__innerAllocs) _NOEXCEPT | ||||
|             : outer_allocator_type(_VSTD::forward<_OuterA2>(__outerAlloc)), | ||||
|                                    const _InnerAllocs& ...__innerAllocs) | ||||
|             : outer_allocator_type(_STD::forward<_OuterA2>(__outerAlloc)), | ||||
|               __inner_(__innerAllocs...) {} | ||||
|  | ||||
|     template <class _OuterA2, | ||||
| @@ -205,7 +200,7 @@ protected: | ||||
|                       >::type> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         __scoped_allocator_storage( | ||||
|             const __scoped_allocator_storage<_OuterA2, _InnerAllocs...>& __other) _NOEXCEPT | ||||
|             const __scoped_allocator_storage<_OuterA2, _InnerAllocs...>& __other) | ||||
|             : outer_allocator_type(__other.outer_allocator()), | ||||
|               __inner_(__other.inner_allocator()) {} | ||||
|  | ||||
| @@ -215,9 +210,9 @@ protected: | ||||
|                       >::type> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         __scoped_allocator_storage( | ||||
|             __scoped_allocator_storage<_OuterA2, _InnerAllocs...>&& __other) _NOEXCEPT | ||||
|             : outer_allocator_type(_VSTD::move(__other.outer_allocator())), | ||||
|               __inner_(_VSTD::move(__other.inner_allocator())) {} | ||||
|             __scoped_allocator_storage<_OuterA2, _InnerAllocs...>&& __other) | ||||
|             : outer_allocator_type(_STD::move(__other.outer_allocator())), | ||||
|               __inner_(_STD::move(__other.inner_allocator())) {} | ||||
|  | ||||
|     template <class _OuterA2, | ||||
|               class = typename enable_if< | ||||
| @@ -225,27 +220,27 @@ protected: | ||||
|                       >::type> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         __scoped_allocator_storage(_OuterA2&& __o, | ||||
|                                    const inner_allocator_type& __i) _NOEXCEPT | ||||
|             : outer_allocator_type(_VSTD::forward<_OuterA2>(__o)), | ||||
|                                    const inner_allocator_type& __i) | ||||
|             : outer_allocator_type(_STD::forward<_OuterA2>(__o)), | ||||
|               __inner_(__i) | ||||
|         { | ||||
|         } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     inner_allocator_type& inner_allocator() _NOEXCEPT             {return __inner_;} | ||||
|     inner_allocator_type& inner_allocator()             {return __inner_;} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const inner_allocator_type& inner_allocator() const _NOEXCEPT {return __inner_;} | ||||
|     const inner_allocator_type& inner_allocator() const {return __inner_;} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     outer_allocator_type& outer_allocator() _NOEXCEPT | ||||
|     outer_allocator_type& outer_allocator() | ||||
|         {return static_cast<outer_allocator_type&>(*this);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const outer_allocator_type& outer_allocator() const _NOEXCEPT | ||||
|     const outer_allocator_type& outer_allocator() const | ||||
|         {return static_cast<const outer_allocator_type&>(*this);} | ||||
|  | ||||
|     scoped_allocator_adaptor<outer_allocator_type, _InnerAllocs...> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     select_on_container_copy_construction() const _NOEXCEPT | ||||
|     select_on_container_copy_construction() const | ||||
|         { | ||||
|             return scoped_allocator_adaptor<outer_allocator_type, _InnerAllocs...> | ||||
|             ( | ||||
| @@ -268,15 +263,15 @@ protected: | ||||
|     typedef scoped_allocator_adaptor<_OuterAlloc> inner_allocator_type; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     __scoped_allocator_storage() _NOEXCEPT {} | ||||
|     __scoped_allocator_storage() {} | ||||
|  | ||||
|     template <class _OuterA2, | ||||
|               class = typename enable_if< | ||||
|                         is_constructible<outer_allocator_type, _OuterA2>::value | ||||
|                       >::type> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         __scoped_allocator_storage(_OuterA2&& __outerAlloc) _NOEXCEPT | ||||
|             : outer_allocator_type(_VSTD::forward<_OuterA2>(__outerAlloc)) {} | ||||
|         __scoped_allocator_storage(_OuterA2&& __outerAlloc) | ||||
|             : outer_allocator_type(_STD::forward<_OuterA2>(__outerAlloc)) {} | ||||
|  | ||||
|     template <class _OuterA2, | ||||
|               class = typename enable_if< | ||||
| @@ -284,7 +279,7 @@ protected: | ||||
|                       >::type> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         __scoped_allocator_storage( | ||||
|             const __scoped_allocator_storage<_OuterA2>& __other) _NOEXCEPT | ||||
|             const __scoped_allocator_storage<_OuterA2>& __other) | ||||
|             : outer_allocator_type(__other.outer_allocator()) {} | ||||
|  | ||||
|     template <class _OuterA2, | ||||
| @@ -293,33 +288,33 @@ protected: | ||||
|                       >::type> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         __scoped_allocator_storage( | ||||
|             __scoped_allocator_storage<_OuterA2>&& __other) _NOEXCEPT | ||||
|             : outer_allocator_type(_VSTD::move(__other.outer_allocator())) {} | ||||
|             __scoped_allocator_storage<_OuterA2>&& __other) | ||||
|             : outer_allocator_type(_STD::move(__other.outer_allocator())) {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     inner_allocator_type& inner_allocator() _NOEXCEPT | ||||
|     inner_allocator_type& inner_allocator() | ||||
|         {return static_cast<inner_allocator_type&>(*this);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const inner_allocator_type& inner_allocator() const _NOEXCEPT | ||||
|     const inner_allocator_type& inner_allocator() const | ||||
|         {return static_cast<const inner_allocator_type&>(*this);} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     outer_allocator_type& outer_allocator() _NOEXCEPT | ||||
|     outer_allocator_type& outer_allocator() | ||||
|         {return static_cast<outer_allocator_type&>(*this);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const outer_allocator_type& outer_allocator() const _NOEXCEPT | ||||
|     const outer_allocator_type& outer_allocator() const | ||||
|         {return static_cast<const outer_allocator_type&>(*this);} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     scoped_allocator_adaptor<outer_allocator_type> | ||||
|     select_on_container_copy_construction() const _NOEXCEPT | ||||
|     select_on_container_copy_construction() const | ||||
|         {return scoped_allocator_adaptor<outer_allocator_type>( | ||||
|             allocator_traits<outer_allocator_type>:: | ||||
|                 select_on_container_copy_construction(outer_allocator()) | ||||
|         );} | ||||
|  | ||||
|     __scoped_allocator_storage(const outer_allocator_type& __o, | ||||
|                                const inner_allocator_type& __i) _NOEXCEPT; | ||||
|                                const inner_allocator_type& __i); | ||||
|  | ||||
|     template <class...> friend class __scoped_allocator_storage; | ||||
| }; | ||||
| @@ -348,7 +343,7 @@ struct __outermost | ||||
| { | ||||
|     typedef _Alloc type; | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     type& operator()(type& __a) const _NOEXCEPT {return __a;} | ||||
|     type& operator()(type& __a) const {return __a;} | ||||
| }; | ||||
|  | ||||
| template <class _Alloc> | ||||
| @@ -356,16 +351,16 @@ struct __outermost<_Alloc, true> | ||||
| { | ||||
|     typedef typename remove_reference | ||||
|                      < | ||||
|                         decltype(_VSTD::declval<_Alloc>().outer_allocator()) | ||||
|                         decltype(_STD::declval<_Alloc>().outer_allocator()) | ||||
|                      >::type                                    _OuterAlloc; | ||||
|     typedef typename __outermost<_OuterAlloc>::type             type; | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     type& operator()(_Alloc& __a) const _NOEXCEPT | ||||
|     type& operator()(_Alloc& __a) const | ||||
|         {return __outermost<_OuterAlloc>()(__a.outer_allocator());} | ||||
| }; | ||||
|  | ||||
| template <class _OuterAlloc, class... _InnerAllocs> | ||||
| class _LIBCPP_TYPE_VIS_ONLY scoped_allocator_adaptor<_OuterAlloc, _InnerAllocs...> | ||||
| class _LIBCPP_VISIBLE scoped_allocator_adaptor<_OuterAlloc, _InnerAllocs...> | ||||
|     : public __scoped_allocator_storage<_OuterAlloc, _InnerAllocs...> | ||||
| { | ||||
|     typedef __scoped_allocator_storage<_OuterAlloc, _InnerAllocs...> base; | ||||
| @@ -408,15 +403,15 @@ public: | ||||
|     }; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     scoped_allocator_adaptor() _NOEXCEPT {} | ||||
|     scoped_allocator_adaptor() {} | ||||
|     template <class _OuterA2, | ||||
|               class = typename enable_if< | ||||
|                         is_constructible<outer_allocator_type, _OuterA2>::value | ||||
|                       >::type> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         scoped_allocator_adaptor(_OuterA2&& __outerAlloc, | ||||
|                                  const _InnerAllocs& ...__innerAllocs) _NOEXCEPT | ||||
|             : base(_VSTD::forward<_OuterA2>(__outerAlloc), __innerAllocs...) {} | ||||
|                                  const _InnerAllocs& ...__innerAllocs) | ||||
|             : base(_STD::forward<_OuterA2>(__outerAlloc), __innerAllocs...) {} | ||||
|     // scoped_allocator_adaptor(const scoped_allocator_adaptor& __other) = default; | ||||
|     template <class _OuterA2, | ||||
|               class = typename enable_if< | ||||
| @@ -424,7 +419,7 @@ public: | ||||
|                       >::type> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         scoped_allocator_adaptor( | ||||
|             const scoped_allocator_adaptor<_OuterA2, _InnerAllocs...>& __other) _NOEXCEPT | ||||
|             const scoped_allocator_adaptor<_OuterA2, _InnerAllocs...>& __other) | ||||
|                 : base(__other) {} | ||||
|     template <class _OuterA2, | ||||
|               class = typename enable_if< | ||||
| @@ -432,23 +427,23 @@ public: | ||||
|                       >::type> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         scoped_allocator_adaptor( | ||||
|             scoped_allocator_adaptor<_OuterA2, _InnerAllocs...>&& __other) _NOEXCEPT | ||||
|                 : base(_VSTD::move(__other)) {} | ||||
|             scoped_allocator_adaptor<_OuterA2, _InnerAllocs...>&& __other) | ||||
|                 : base(_STD::move(__other)) {} | ||||
|  | ||||
|     // ~scoped_allocator_adaptor() = default; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     inner_allocator_type& inner_allocator() _NOEXCEPT | ||||
|     inner_allocator_type& inner_allocator() | ||||
|         {return base::inner_allocator();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const inner_allocator_type& inner_allocator() const _NOEXCEPT | ||||
|     const inner_allocator_type& inner_allocator() const | ||||
|         {return base::inner_allocator();} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     outer_allocator_type& outer_allocator() _NOEXCEPT | ||||
|     outer_allocator_type& outer_allocator() | ||||
|         {return base::outer_allocator();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const outer_allocator_type& outer_allocator() const _NOEXCEPT | ||||
|     const outer_allocator_type& outer_allocator() const | ||||
|         {return base::outer_allocator();} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -461,7 +456,7 @@ public: | ||||
|             allocate(outer_allocator(), __n, __hint);} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void deallocate(pointer __p, size_type __n) _NOEXCEPT | ||||
|     void deallocate(pointer __p, size_type __n) | ||||
|         {allocator_traits<outer_allocator_type>:: | ||||
|             deallocate(outer_allocator(), __p, __n);} | ||||
|  | ||||
| @@ -473,7 +468,7 @@ public: | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         void construct(_Tp* __p, _Args&& ...__args) | ||||
|             {__construct(__uses_alloc_ctor<_Tp, inner_allocator_type, _Args...>(), | ||||
|                          __p, _VSTD::forward<_Args>(__args)...);} | ||||
|                          __p, _STD::forward<_Args>(__args)...);} | ||||
|     template <class _Tp> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         void destroy(_Tp* __p) | ||||
| @@ -484,7 +479,7 @@ public: | ||||
|             } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     scoped_allocator_adaptor select_on_container_copy_construction() const _NOEXCEPT | ||||
|     scoped_allocator_adaptor select_on_container_copy_construction() const | ||||
|         {return base::select_on_container_copy_construction();} | ||||
|  | ||||
| private: | ||||
| @@ -495,8 +490,8 @@ private: | ||||
|                       >::type> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     scoped_allocator_adaptor(_OuterA2&& __o, | ||||
|                              const inner_allocator_type& __i) _NOEXCEPT | ||||
|         : base(_VSTD::forward<_OuterA2>(__o), __i) {} | ||||
|                              const inner_allocator_type& __i) | ||||
|         : base(_STD::forward<_OuterA2>(__o), __i) {} | ||||
|  | ||||
|     template <class _Tp, class... _Args> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -507,7 +502,7 @@ private: | ||||
|                 ( | ||||
|                     _OM()(outer_allocator()), | ||||
|                     __p, | ||||
|                     _VSTD::forward<_Args>(__args)... | ||||
|                     _STD::forward<_Args>(__args)... | ||||
|                 ); | ||||
|             } | ||||
|  | ||||
| @@ -522,7 +517,7 @@ private: | ||||
|                     __p, | ||||
|                     allocator_arg, | ||||
|                     inner_allocator(), | ||||
|                     _VSTD::forward<_Args>(__args)... | ||||
|                     _STD::forward<_Args>(__args)... | ||||
|                 ); | ||||
|             } | ||||
|  | ||||
| @@ -535,7 +530,7 @@ private: | ||||
|                 ( | ||||
|                     _OM()(outer_allocator()), | ||||
|                     __p, | ||||
|                     _VSTD::forward<_Args>(__args)..., | ||||
|                     _STD::forward<_Args>(__args)..., | ||||
|                     inner_allocator() | ||||
|                 ); | ||||
|             } | ||||
| @@ -547,16 +542,16 @@ template <class _OuterA1, class _OuterA2> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator==(const scoped_allocator_adaptor<_OuterA1>& __a, | ||||
|            const scoped_allocator_adaptor<_OuterA2>& __b) _NOEXCEPT | ||||
|            const scoped_allocator_adaptor<_OuterA2>& __b) | ||||
| { | ||||
|     return __a.outer_allocator() == __b.outer_allocator(); | ||||
| } | ||||
|  | ||||
| template <class _OuterA1, class _OuterA2, class _InnerA0, class... _InnerAllocs> | ||||
| template <class _OuterA1, class _OuterA2, class... _InnerAllocs> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator==(const scoped_allocator_adaptor<_OuterA1, _InnerA0, _InnerAllocs...>& __a, | ||||
|            const scoped_allocator_adaptor<_OuterA2, _InnerA0, _InnerAllocs...>& __b) _NOEXCEPT | ||||
| operator==(const scoped_allocator_adaptor<_OuterA1, _InnerAllocs...>& __a, | ||||
|            const scoped_allocator_adaptor<_OuterA2, _InnerAllocs...>& __b) | ||||
| { | ||||
|     return __a.outer_allocator() == __b.outer_allocator() && | ||||
|            __a.inner_allocator() == __b.inner_allocator(); | ||||
| @@ -566,7 +561,7 @@ template <class _OuterA1, class _OuterA2, class... _InnerAllocs> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator!=(const scoped_allocator_adaptor<_OuterA1, _InnerAllocs...>& __a, | ||||
|            const scoped_allocator_adaptor<_OuterA2, _InnerAllocs...>& __b) _NOEXCEPT | ||||
|            const scoped_allocator_adaptor<_OuterA2, _InnerAllocs...>& __b) | ||||
| { | ||||
|     return !(__a == __b); | ||||
| } | ||||
|   | ||||
							
								
								
									
										459
									
								
								include/set
									
									
									
									
									
								
							
							
						
						
									
										459
									
								
								include/set
									
									
									
									
									
								
							| @@ -42,12 +42,7 @@ public: | ||||
|     typedef std::reverse_iterator<const_iterator>    const_reverse_iterator; | ||||
|  | ||||
|     // construct/copy/destroy: | ||||
|     set() | ||||
|         noexcept( | ||||
|             is_nothrow_default_constructible<allocator_type>::value && | ||||
|             is_nothrow_default_constructible<key_compare>::value && | ||||
|             is_nothrow_copy_constructible<key_compare>::value); | ||||
|     explicit set(const value_compare& comp); | ||||
|     explicit set(const value_compare& comp = value_compare()); | ||||
|     set(const value_compare& comp, const allocator_type& a); | ||||
|     template <class InputIterator> | ||||
|         set(InputIterator first, InputIterator last, | ||||
| @@ -56,51 +51,39 @@ public: | ||||
|         set(InputIterator first, InputIterator last, const value_compare& comp, | ||||
|             const allocator_type& a); | ||||
|     set(const set& s); | ||||
|     set(set&& s) | ||||
|         noexcept( | ||||
|             is_nothrow_move_constructible<allocator_type>::value && | ||||
|             is_nothrow_move_constructible<key_compare>::value); | ||||
|     set(set&& s); | ||||
|     explicit set(const allocator_type& a); | ||||
|     set(const set& s, const allocator_type& a); | ||||
|     set(set&& s, const allocator_type& a); | ||||
|     set(initializer_list<value_type> il, const value_compare& comp = value_compare()); | ||||
|     set(initializer_list<value_type> il, const value_compare& comp, | ||||
|         const allocator_type& a); | ||||
|     template <class InputIterator> | ||||
|         set(InputIterator first, InputIterator last, const allocator_type& a) | ||||
|             : set(first, last, Compare(), a) {}  // C++14 | ||||
|     set(initializer_list<value_type> il, const allocator_type& a) | ||||
|         : set(il, Compare(), a) {}  // C++14 | ||||
|     ~set(); | ||||
|  | ||||
|     set& operator=(const set& s); | ||||
|     set& operator=(set&& s) | ||||
|         noexcept( | ||||
|             allocator_type::propagate_on_container_move_assignment::value && | ||||
|             is_nothrow_move_assignable<allocator_type>::value && | ||||
|             is_nothrow_move_assignable<key_compare>::value); | ||||
|     set& operator=(set&& s); | ||||
|     set& operator=(initializer_list<value_type> il); | ||||
|  | ||||
|     // iterators: | ||||
|           iterator begin() noexcept; | ||||
|     const_iterator begin() const noexcept; | ||||
|           iterator end() noexcept; | ||||
|     const_iterator end()   const noexcept; | ||||
|           iterator begin(); | ||||
|     const_iterator begin() const; | ||||
|           iterator end(); | ||||
|     const_iterator end()   const; | ||||
|  | ||||
|           reverse_iterator rbegin() noexcept; | ||||
|     const_reverse_iterator rbegin() const noexcept; | ||||
|           reverse_iterator rend() noexcept; | ||||
|     const_reverse_iterator rend()   const noexcept; | ||||
|           reverse_iterator rbegin(); | ||||
|     const_reverse_iterator rbegin() const; | ||||
|           reverse_iterator rend(); | ||||
|     const_reverse_iterator rend()   const; | ||||
|  | ||||
|     const_iterator         cbegin()  const noexcept; | ||||
|     const_iterator         cend()    const noexcept; | ||||
|     const_reverse_iterator crbegin() const noexcept; | ||||
|     const_reverse_iterator crend()   const noexcept; | ||||
|     const_iterator         cbegin()  const; | ||||
|     const_iterator         cend()    const; | ||||
|     const_reverse_iterator crbegin() const; | ||||
|     const_reverse_iterator crend()   const; | ||||
|  | ||||
|     // capacity: | ||||
|     bool      empty()    const noexcept; | ||||
|     size_type size()     const noexcept; | ||||
|     size_type max_size() const noexcept; | ||||
|     bool      empty()    const; | ||||
|     size_type size()     const; | ||||
|     size_type max_size() const; | ||||
|  | ||||
|     // modifiers: | ||||
|     template <class... Args> | ||||
| @@ -118,49 +101,25 @@ public: | ||||
|     iterator  erase(const_iterator position); | ||||
|     size_type erase(const key_type& k); | ||||
|     iterator  erase(const_iterator first, const_iterator last); | ||||
|     void clear() noexcept; | ||||
|     void clear(); | ||||
|  | ||||
|     void swap(set& s) | ||||
|         noexcept( | ||||
|             __is_nothrow_swappable<key_compare>::value && | ||||
|             (!allocator_type::propagate_on_container_swap::value || | ||||
|              __is_nothrow_swappable<allocator_type>::value)); | ||||
|     void swap(set& s); | ||||
|  | ||||
|     // observers: | ||||
|     allocator_type get_allocator() const noexcept; | ||||
|     allocator_type get_allocator() const; | ||||
|     key_compare    key_comp()      const; | ||||
|     value_compare  value_comp()    const; | ||||
|  | ||||
|     // set operations: | ||||
|           iterator find(const key_type& k); | ||||
|     const_iterator find(const key_type& k) const; | ||||
|     template<typename K> | ||||
|         iterator find(const K& x); | ||||
|     template<typename K> | ||||
|         const_iterator find(const K& x) const;  // C++14 | ||||
|     template<typename K> | ||||
|       size_type count(const K& x) const;        // C++14 | ||||
|  | ||||
|     size_type      count(const key_type& k) const; | ||||
|           iterator lower_bound(const key_type& k); | ||||
|     const_iterator lower_bound(const key_type& k) const; | ||||
|     template<typename K> | ||||
|         iterator lower_bound(const K& x);              // C++14 | ||||
|     template<typename K> | ||||
|         const_iterator lower_bound(const K& x) const;  // C++14 | ||||
|  | ||||
|           iterator upper_bound(const key_type& k); | ||||
|     const_iterator upper_bound(const key_type& k) const; | ||||
|     template<typename K> | ||||
|         iterator upper_bound(const K& x);              // C++14 | ||||
|     template<typename K> | ||||
|         const_iterator upper_bound(const K& x) const;  // C++14 | ||||
|     pair<iterator,iterator>             equal_range(const key_type& k); | ||||
|     pair<const_iterator,const_iterator> equal_range(const key_type& k) const; | ||||
|     template<typename K> | ||||
|         pair<iterator,iterator>             equal_range(const K& x);        // C++14 | ||||
|     template<typename K> | ||||
|         pair<const_iterator,const_iterator> equal_range(const K& x) const;  // C++14 | ||||
| }; | ||||
|  | ||||
| template <class Key, class Compare, class Allocator> | ||||
| @@ -196,8 +155,7 @@ operator<=(const set<Key, Compare, Allocator>& x, | ||||
| // specialized algorithms: | ||||
| template <class Key, class Compare, class Allocator> | ||||
| void | ||||
| swap(set<Key, Compare, Allocator>& x, set<Key, Compare, Allocator>& y) | ||||
|     noexcept(noexcept(x.swap(y))); | ||||
| swap(set<Key, Compare, Allocator>& x, set<Key, Compare, Allocator>& y); | ||||
|  | ||||
| template <class Key, class Compare = less<Key>, | ||||
|           class Allocator = allocator<Key>> | ||||
| @@ -223,12 +181,7 @@ public: | ||||
|     typedef std::reverse_iterator<const_iterator>    const_reverse_iterator; | ||||
|  | ||||
|     // construct/copy/destroy: | ||||
|     multiset() | ||||
|         noexcept( | ||||
|             is_nothrow_default_constructible<allocator_type>::value && | ||||
|             is_nothrow_default_constructible<key_compare>::value && | ||||
|             is_nothrow_copy_constructible<key_compare>::value); | ||||
|     explicit multiset(const value_compare& comp); | ||||
|     explicit multiset(const value_compare& comp = value_compare()); | ||||
|     multiset(const value_compare& comp, const allocator_type& a); | ||||
|     template <class InputIterator> | ||||
|         multiset(InputIterator first, InputIterator last, | ||||
| @@ -237,51 +190,39 @@ public: | ||||
|         multiset(InputIterator first, InputIterator last, | ||||
|                  const value_compare& comp, const allocator_type& a); | ||||
|     multiset(const multiset& s); | ||||
|     multiset(multiset&& s) | ||||
|         noexcept( | ||||
|             is_nothrow_move_constructible<allocator_type>::value && | ||||
|             is_nothrow_move_constructible<key_compare>::value); | ||||
|     multiset(multiset&& s); | ||||
|     explicit multiset(const allocator_type& a); | ||||
|     multiset(const multiset& s, const allocator_type& a); | ||||
|     multiset(multiset&& s, const allocator_type& a); | ||||
|     multiset(initializer_list<value_type> il, const value_compare& comp = value_compare()); | ||||
|     multiset(initializer_list<value_type> il, const value_compare& comp, | ||||
|              const allocator_type& a); | ||||
|     template <class InputIterator> | ||||
|         multiset(InputIterator first, InputIterator last, const allocator_type& a) | ||||
|             : set(first, last, Compare(), a) {}  // C++14 | ||||
|     multiset(initializer_list<value_type> il, const allocator_type& a) | ||||
|         : set(il, Compare(), a) {}  // C++14 | ||||
|     ~multiset(); | ||||
|  | ||||
|     multiset& operator=(const multiset& s); | ||||
|     multiset& operator=(multiset&& s) | ||||
|         noexcept( | ||||
|             allocator_type::propagate_on_container_move_assignment::value && | ||||
|             is_nothrow_move_assignable<allocator_type>::value && | ||||
|             is_nothrow_move_assignable<key_compare>::value); | ||||
|     multiset& operator=(multiset&& s); | ||||
|     multiset& operator=(initializer_list<value_type> il); | ||||
|  | ||||
|     // iterators: | ||||
|           iterator begin() noexcept; | ||||
|     const_iterator begin() const noexcept; | ||||
|           iterator end() noexcept; | ||||
|     const_iterator end()   const noexcept; | ||||
|           iterator begin(); | ||||
|     const_iterator begin() const; | ||||
|           iterator end(); | ||||
|     const_iterator end()   const; | ||||
|  | ||||
|           reverse_iterator rbegin() noexcept; | ||||
|     const_reverse_iterator rbegin() const noexcept; | ||||
|           reverse_iterator rend() noexcept; | ||||
|     const_reverse_iterator rend()   const noexcept; | ||||
|           reverse_iterator rbegin(); | ||||
|     const_reverse_iterator rbegin() const; | ||||
|           reverse_iterator rend(); | ||||
|     const_reverse_iterator rend()   const; | ||||
|  | ||||
|     const_iterator         cbegin()  const noexcept; | ||||
|     const_iterator         cend()    const noexcept; | ||||
|     const_reverse_iterator crbegin() const noexcept; | ||||
|     const_reverse_iterator crend()   const noexcept; | ||||
|     const_iterator         cbegin()  const; | ||||
|     const_iterator         cend()    const; | ||||
|     const_reverse_iterator crbegin() const; | ||||
|     const_reverse_iterator crend()   const; | ||||
|  | ||||
|     // capacity: | ||||
|     bool      empty()    const noexcept; | ||||
|     size_type size()     const noexcept; | ||||
|     size_type max_size() const noexcept; | ||||
|     bool      empty()    const; | ||||
|     size_type size()     const; | ||||
|     size_type max_size() const; | ||||
|  | ||||
|     // modifiers: | ||||
|     template <class... Args> | ||||
| @@ -299,48 +240,25 @@ public: | ||||
|     iterator  erase(const_iterator position); | ||||
|     size_type erase(const key_type& k); | ||||
|     iterator  erase(const_iterator first, const_iterator last); | ||||
|     void clear() noexcept; | ||||
|     void clear(); | ||||
|  | ||||
|     void swap(multiset& s) | ||||
|         noexcept( | ||||
|             __is_nothrow_swappable<key_compare>::value && | ||||
|             (!allocator_type::propagate_on_container_swap::value || | ||||
|              __is_nothrow_swappable<allocator_type>::value)); | ||||
|     void swap(multiset& s); | ||||
|  | ||||
|     // observers: | ||||
|     allocator_type get_allocator() const noexcept; | ||||
|     allocator_type get_allocator() const; | ||||
|     key_compare    key_comp()      const; | ||||
|     value_compare  value_comp()    const; | ||||
|  | ||||
|     // set operations: | ||||
|           iterator find(const key_type& k); | ||||
|     const_iterator find(const key_type& k) const; | ||||
|     template<typename K> | ||||
|         iterator find(const K& x); | ||||
|     template<typename K> | ||||
|         const_iterator find(const K& x) const;  // C++14 | ||||
|  | ||||
|     size_type      count(const key_type& k) const; | ||||
|           iterator lower_bound(const key_type& k); | ||||
|     const_iterator lower_bound(const key_type& k) const; | ||||
|     template<typename K> | ||||
|         iterator lower_bound(const K& x);              // C++14 | ||||
|     template<typename K> | ||||
|         const_iterator lower_bound(const K& x) const;  // C++14 | ||||
|  | ||||
|           iterator upper_bound(const key_type& k); | ||||
|     const_iterator upper_bound(const key_type& k) const; | ||||
|     template<typename K> | ||||
|         iterator upper_bound(const K& x);              // C++14 | ||||
|     template<typename K> | ||||
|         const_iterator upper_bound(const K& x) const;  // C++14 | ||||
|  | ||||
|     pair<iterator,iterator>             equal_range(const key_type& k); | ||||
|     pair<const_iterator,const_iterator> equal_range(const key_type& k) const; | ||||
|     template<typename K> | ||||
|         pair<iterator,iterator>             equal_range(const K& x);        // C++14 | ||||
|     template<typename K> | ||||
|         pair<const_iterator,const_iterator> equal_range(const K& x) const;  // C++14 | ||||
| }; | ||||
|  | ||||
| template <class Key, class Compare, class Allocator> | ||||
| @@ -376,8 +294,7 @@ operator<=(const multiset<Key, Compare, Allocator>& x, | ||||
| // specialized algorithms: | ||||
| template <class Key, class Compare, class Allocator> | ||||
| void | ||||
| swap(multiset<Key, Compare, Allocator>& x, multiset<Key, Compare, Allocator>& y) | ||||
|     noexcept(noexcept(x.swap(y))); | ||||
| swap(multiset<Key, Compare, Allocator>& x, multiset<Key, Compare, Allocator>& y); | ||||
|  | ||||
| }  // std | ||||
|  | ||||
| @@ -387,15 +304,13 @@ swap(multiset<Key, Compare, Allocator>& x, multiset<Key, Compare, Allocator>& y) | ||||
| #include <__tree> | ||||
| #include <functional> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template <class _Key, class _Compare = less<_Key>, | ||||
|           class _Allocator = allocator<_Key> > | ||||
| class _LIBCPP_TYPE_VIS_ONLY set | ||||
| class _LIBCPP_VISIBLE set | ||||
| { | ||||
| public: | ||||
|     // types: | ||||
| @@ -421,15 +336,11 @@ public: | ||||
|     typedef typename __base::difference_type       difference_type; | ||||
|     typedef typename __base::const_iterator        iterator; | ||||
|     typedef typename __base::const_iterator        const_iterator; | ||||
|     typedef _VSTD::reverse_iterator<iterator>       reverse_iterator; | ||||
|     typedef _VSTD::reverse_iterator<const_iterator> const_reverse_iterator; | ||||
|     typedef _STD::reverse_iterator<iterator>       reverse_iterator; | ||||
|     typedef _STD::reverse_iterator<const_iterator> const_reverse_iterator; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit set(const value_compare& __comp = value_compare()) | ||||
|         _NOEXCEPT_( | ||||
|             is_nothrow_default_constructible<allocator_type>::value && | ||||
|             is_nothrow_default_constructible<key_compare>::value && | ||||
|             is_nothrow_copy_constructible<key_compare>::value) | ||||
|         : __tree_(__comp) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     set(const value_compare& __comp, const allocator_type& __a) | ||||
| @@ -452,13 +363,6 @@ public: | ||||
|             insert(__f, __l); | ||||
|         } | ||||
|  | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|         template <class _InputIterator> | ||||
|         _LIBCPP_INLINE_VISIBILITY  | ||||
|         set(_InputIterator __f, _InputIterator __l, const allocator_type& __a) | ||||
|             : set(__f, __l, key_compare(), __a) {} | ||||
| #endif | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     set(const set& __s) | ||||
|         : __tree_(__s.__tree_) | ||||
| @@ -466,18 +370,10 @@ public: | ||||
|             insert(__s.begin(), __s.end()); | ||||
|         } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     set& operator=(const set& __s) | ||||
|         { | ||||
|             __tree_ = __s.__tree_; | ||||
|             return *this; | ||||
|         } | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     set(set&& __s) | ||||
|         _NOEXCEPT_(is_nothrow_move_constructible<__base>::value) | ||||
|         : __tree_(_VSTD::move(__s.__tree_)) {} | ||||
|         : __tree_(_STD::move(__s.__tree_)) {} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -495,7 +391,6 @@ public: | ||||
|     set(set&& __s, const allocator_type& __a); | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     set(initializer_list<value_type> __il, const value_compare& __comp = value_compare()) | ||||
|         : __tree_(__comp) | ||||
| @@ -511,78 +406,66 @@ public: | ||||
|             insert(__il.begin(), __il.end()); | ||||
|         } | ||||
|  | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|     _LIBCPP_INLINE_VISIBILITY  | ||||
|     set(initializer_list<value_type> __il, const allocator_type& __a) | ||||
|         : set(__il, key_compare(), __a) {} | ||||
| #endif | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     set& operator=(initializer_list<value_type> __il) | ||||
|         { | ||||
|             __tree_.__assign_unique(__il.begin(), __il.end()); | ||||
|             return *this; | ||||
|         } | ||||
| #endif  // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     set& operator=(set&& __s) | ||||
|         _NOEXCEPT_(is_nothrow_move_assignable<__base>::value) | ||||
|         { | ||||
|             __tree_ = _VSTD::move(__s.__tree_); | ||||
|             __tree_ = _STD::move(__s.__tree_); | ||||
|             return *this; | ||||
|         } | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|           iterator begin() _NOEXCEPT       {return __tree_.begin();} | ||||
|           iterator begin()       {return __tree_.begin();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator begin() const _NOEXCEPT {return __tree_.begin();} | ||||
|     const_iterator begin() const {return __tree_.begin();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|           iterator end() _NOEXCEPT         {return __tree_.end();} | ||||
|           iterator end()         {return __tree_.end();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator end()   const _NOEXCEPT {return __tree_.end();} | ||||
|     const_iterator end()   const {return __tree_.end();} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|           reverse_iterator rbegin() _NOEXCEPT | ||||
|             {return reverse_iterator(end());} | ||||
|           reverse_iterator rbegin()       {return       reverse_iterator(end());} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_reverse_iterator rbegin() const _NOEXCEPT | ||||
|         {return const_reverse_iterator(end());} | ||||
|     const_reverse_iterator rbegin() const {return const_reverse_iterator(end());} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|           reverse_iterator rend() _NOEXCEPT | ||||
|             {return reverse_iterator(begin());} | ||||
|           reverse_iterator rend()         {return       reverse_iterator(begin());} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_reverse_iterator rend() const _NOEXCEPT | ||||
|         {return const_reverse_iterator(begin());} | ||||
|     const_reverse_iterator rend()   const {return const_reverse_iterator(begin());} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator cbegin()  const _NOEXCEPT {return begin();} | ||||
|     const_iterator         cbegin()  const {return begin();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator cend() const _NOEXCEPT {return end();} | ||||
|     const_iterator         cend()    const {return end();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_reverse_iterator crbegin() const _NOEXCEPT {return rbegin();} | ||||
|     const_reverse_iterator crbegin() const {return rbegin();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_reverse_iterator crend() const _NOEXCEPT {return rend();} | ||||
|     const_reverse_iterator crend()   const {return rend();} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     bool empty() const _NOEXCEPT {return __tree_.size() == 0;} | ||||
|     bool      empty()    const {return __tree_.size() == 0;} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     size_type size() const _NOEXCEPT {return __tree_.size();} | ||||
|     size_type size()     const {return __tree_.size();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     size_type max_size() const _NOEXCEPT {return __tree_.max_size();} | ||||
|     size_type max_size() const {return __tree_.max_size();} | ||||
|  | ||||
|     // modifiers: | ||||
| #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||
|     template <class... _Args> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         pair<iterator, bool> emplace(_Args&&... __args) | ||||
|             {return __tree_.__emplace_unique(_VSTD::forward<_Args>(__args)...);} | ||||
|             {return __tree_.__emplace_unique(_STD::forward<_Args>(__args)...);} | ||||
|     template <class... _Args> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         iterator emplace_hint(const_iterator __p, _Args&&... __args) | ||||
|             {return __tree_.__emplace_hint_unique(__p, _VSTD::forward<_Args>(__args)...);} | ||||
|             {return __tree_.__emplace_hint_unique(__p, _STD::forward<_Args>(__args)...);} | ||||
| #endif  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     pair<iterator,bool> insert(const value_type& __v) | ||||
| @@ -590,7 +473,7 @@ public: | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     pair<iterator,bool> insert(value_type&& __v) | ||||
|         {return __tree_.__insert_unique(_VSTD::move(__v));} | ||||
|         {return __tree_.__insert_unique(_STD::move(__v));} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator insert(const_iterator __p, const value_type& __v) | ||||
| @@ -598,7 +481,7 @@ public: | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator insert(const_iterator __p, value_type&& __v) | ||||
|         {return __tree_.__insert_unique(__p, _VSTD::move(__v));} | ||||
|         {return __tree_.__insert_unique(__p, _STD::move(__v));} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     template <class _InputIterator> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -608,11 +491,9 @@ public: | ||||
|                 __tree_.__insert_unique(__e, *__f); | ||||
|         } | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void insert(initializer_list<value_type> __il) | ||||
|         {insert(__il.begin(), __il.end());} | ||||
| #endif  // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator  erase(const_iterator __p) {return __tree_.erase(__p);} | ||||
| @@ -623,14 +504,13 @@ public: | ||||
|     iterator  erase(const_iterator __f, const_iterator __l) | ||||
|         {return __tree_.erase(__f, __l);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void clear() _NOEXCEPT {__tree_.clear();} | ||||
|     void clear() {__tree_.clear();} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void swap(set& __s) _NOEXCEPT_(__is_nothrow_swappable<__base>::value) | ||||
|         {__tree_.swap(__s.__tree_);} | ||||
|     void swap(set& __s) {__tree_.swap(__s.__tree_);} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     allocator_type get_allocator() const _NOEXCEPT {return __tree_.__alloc();} | ||||
|     allocator_type get_allocator() const {return __tree_.__alloc();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     key_compare    key_comp()      const {return __tree_.value_comp();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -641,17 +521,6 @@ public: | ||||
|     iterator find(const key_type& __k)             {return __tree_.find(__k);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator find(const key_type& __k) const {return __tree_.find(__k);} | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename enable_if<__is_transparent<_Compare, _K2>::value,iterator>::type | ||||
|     find(const _K2& __k)                           {return __tree_.find(__k);} | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename enable_if<__is_transparent<_Compare, _K2>::value,const_iterator>::type | ||||
|     find(const _K2& __k) const                     {return __tree_.find(__k);} | ||||
| #endif | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     size_type      count(const key_type& __k) const | ||||
|         {return __tree_.__count_unique(__k);} | ||||
| @@ -661,64 +530,31 @@ public: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator lower_bound(const key_type& __k) const | ||||
|         {return __tree_.lower_bound(__k);} | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename enable_if<__is_transparent<_Compare, _K2>::value,iterator>::type | ||||
|     lower_bound(const _K2& __k)       {return __tree_.lower_bound(__k);} | ||||
|  | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename enable_if<__is_transparent<_Compare, _K2>::value,const_iterator>::type | ||||
|     lower_bound(const _K2& __k) const {return __tree_.lower_bound(__k);} | ||||
| #endif | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator upper_bound(const key_type& __k) | ||||
|         {return __tree_.upper_bound(__k);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator upper_bound(const key_type& __k) const | ||||
|         {return __tree_.upper_bound(__k);} | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename enable_if<__is_transparent<_Compare, _K2>::value,iterator>::type | ||||
|     upper_bound(const _K2& __k)       {return __tree_.upper_bound(__k);} | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename enable_if<__is_transparent<_Compare, _K2>::value,const_iterator>::type | ||||
|     upper_bound(const _K2& __k) const {return __tree_.upper_bound(__k);} | ||||
| #endif | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     pair<iterator,iterator> equal_range(const key_type& __k) | ||||
|         {return __tree_.__equal_range_unique(__k);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     pair<const_iterator,const_iterator> equal_range(const key_type& __k) const | ||||
|         {return __tree_.__equal_range_unique(__k);} | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename enable_if<__is_transparent<_Compare, _K2>::value,pair<iterator,iterator>>::type | ||||
|     equal_range(const _K2& __k)       {return __tree_.__equal_range_unique(__k);} | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename enable_if<__is_transparent<_Compare, _K2>::value,pair<const_iterator,const_iterator>>::type | ||||
|     equal_range(const _K2& __k) const {return __tree_.__equal_range_unique(__k);} | ||||
| #endif | ||||
| }; | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
| template <class _Key, class _Compare, class _Allocator> | ||||
| set<_Key, _Compare, _Allocator>::set(set&& __s, const allocator_type& __a) | ||||
|     : __tree_(_VSTD::move(__s.__tree_), __a) | ||||
|     : __tree_(_STD::move(__s.__tree_), __a) | ||||
| { | ||||
|     if (__a != __s.get_allocator()) | ||||
|     { | ||||
|         const_iterator __e = cend(); | ||||
|         while (!__s.empty()) | ||||
|             insert(__e, _VSTD::move(__s.__tree_.remove(__s.begin())->__value_)); | ||||
|             insert(__e, _STD::move(__s.__tree_.remove(__s.begin())->__value_)); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -730,7 +566,7 @@ bool | ||||
| operator==(const set<_Key, _Compare, _Allocator>& __x, | ||||
|            const set<_Key, _Compare, _Allocator>& __y) | ||||
| { | ||||
|     return __x.size() == __y.size() && _VSTD::equal(__x.begin(), __x.end(), __y.begin()); | ||||
|     return __x.size() == __y.size() && _STD::equal(__x.begin(), __x.end(), __y.begin()); | ||||
| } | ||||
|  | ||||
| template <class _Key, class _Compare, class _Allocator> | ||||
| @@ -739,7 +575,7 @@ bool | ||||
| operator< (const set<_Key, _Compare, _Allocator>& __x, | ||||
|            const set<_Key, _Compare, _Allocator>& __y) | ||||
| { | ||||
|     return _VSTD::lexicographical_compare(__x.begin(), __x.end(), __y.begin(), __y.end()); | ||||
|     return _STD::lexicographical_compare(__x.begin(), __x.end(), __y.begin(), __y.end()); | ||||
| } | ||||
|  | ||||
| template <class _Key, class _Compare, class _Allocator> | ||||
| @@ -784,14 +620,13 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| swap(set<_Key, _Compare, _Allocator>& __x, | ||||
|      set<_Key, _Compare, _Allocator>& __y) | ||||
|     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||
| { | ||||
|     __x.swap(__y); | ||||
| } | ||||
|  | ||||
| template <class _Key, class _Compare = less<_Key>, | ||||
|           class _Allocator = allocator<_Key> > | ||||
| class _LIBCPP_TYPE_VIS_ONLY multiset | ||||
| class _LIBCPP_VISIBLE multiset | ||||
| { | ||||
| public: | ||||
|     // types: | ||||
| @@ -817,16 +652,12 @@ public: | ||||
|     typedef typename __base::difference_type       difference_type; | ||||
|     typedef typename __base::const_iterator        iterator; | ||||
|     typedef typename __base::const_iterator        const_iterator; | ||||
|     typedef _VSTD::reverse_iterator<iterator>       reverse_iterator; | ||||
|     typedef _VSTD::reverse_iterator<const_iterator> const_reverse_iterator; | ||||
|     typedef _STD::reverse_iterator<iterator>       reverse_iterator; | ||||
|     typedef _STD::reverse_iterator<const_iterator> const_reverse_iterator; | ||||
|  | ||||
|     // construct/copy/destroy: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit multiset(const value_compare& __comp = value_compare()) | ||||
|         _NOEXCEPT_( | ||||
|             is_nothrow_default_constructible<allocator_type>::value && | ||||
|             is_nothrow_default_constructible<key_compare>::value && | ||||
|             is_nothrow_copy_constructible<key_compare>::value) | ||||
|         : __tree_(__comp) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     multiset(const value_compare& __comp, const allocator_type& __a) | ||||
| @@ -840,13 +671,6 @@ public: | ||||
|             insert(__f, __l); | ||||
|         } | ||||
|  | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|         template <class _InputIterator> | ||||
|         _LIBCPP_INLINE_VISIBILITY  | ||||
|         multiset(_InputIterator __f, _InputIterator __l, const allocator_type& __a) | ||||
|             : multiset(__f, __l, key_compare(), __a) {} | ||||
| #endif | ||||
|  | ||||
|     template <class _InputIterator> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         multiset(_InputIterator __f, _InputIterator __l, | ||||
| @@ -864,18 +688,10 @@ public: | ||||
|             insert(__s.begin(), __s.end()); | ||||
|         } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     multiset& operator=(const multiset& __s) | ||||
|         { | ||||
|             __tree_ = __s.__tree_; | ||||
|             return *this; | ||||
|         } | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     multiset(multiset&& __s) | ||||
|         _NOEXCEPT_(is_nothrow_move_constructible<__base>::value) | ||||
|         : __tree_(_VSTD::move(__s.__tree_)) {} | ||||
|         : __tree_(_STD::move(__s.__tree_)) {} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit multiset(const allocator_type& __a) | ||||
| @@ -890,7 +706,6 @@ public: | ||||
|     multiset(multiset&& __s, const allocator_type& __a); | ||||
| #endif | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     multiset(initializer_list<value_type> __il, const value_compare& __comp = value_compare()) | ||||
|         : __tree_(__comp) | ||||
| @@ -906,78 +721,66 @@ public: | ||||
|             insert(__il.begin(), __il.end()); | ||||
|         } | ||||
|  | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|     _LIBCPP_INLINE_VISIBILITY  | ||||
|     multiset(initializer_list<value_type> __il, const allocator_type& __a) | ||||
|         : multiset(__il, key_compare(), __a) {} | ||||
| #endif | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     multiset& operator=(initializer_list<value_type> __il) | ||||
|         { | ||||
|             __tree_.__assign_multi(__il.begin(), __il.end()); | ||||
|             return *this; | ||||
|         } | ||||
| #endif  // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     multiset& operator=(multiset&& __s) | ||||
|         _NOEXCEPT_(is_nothrow_move_assignable<__base>::value) | ||||
|         { | ||||
|             __tree_ = _VSTD::move(__s.__tree_); | ||||
|             __tree_ = _STD::move(__s.__tree_); | ||||
|             return *this; | ||||
|         } | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|           iterator begin() _NOEXCEPT       {return __tree_.begin();} | ||||
|           iterator begin()       {return __tree_.begin();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator begin() const _NOEXCEPT {return __tree_.begin();} | ||||
|     const_iterator begin() const {return __tree_.begin();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|           iterator end() _NOEXCEPT         {return __tree_.end();} | ||||
|           iterator end()         {return __tree_.end();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator end()   const _NOEXCEPT {return __tree_.end();} | ||||
|     const_iterator end()   const {return __tree_.end();} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|           reverse_iterator rbegin() _NOEXCEPT | ||||
|             {return reverse_iterator(end());} | ||||
|           reverse_iterator rbegin()       {return       reverse_iterator(end());} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_reverse_iterator rbegin() const _NOEXCEPT | ||||
|         {return const_reverse_iterator(end());} | ||||
|     const_reverse_iterator rbegin() const {return const_reverse_iterator(end());} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|           reverse_iterator rend() _NOEXCEPT | ||||
|             {return       reverse_iterator(begin());} | ||||
|           reverse_iterator rend()         {return       reverse_iterator(begin());} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_reverse_iterator rend() const _NOEXCEPT | ||||
|         {return const_reverse_iterator(begin());} | ||||
|     const_reverse_iterator rend()   const {return const_reverse_iterator(begin());} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator cbegin()  const _NOEXCEPT {return begin();} | ||||
|     const_iterator         cbegin()  const {return begin();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator cend() const _NOEXCEPT {return end();} | ||||
|     const_iterator         cend()    const {return end();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_reverse_iterator crbegin() const _NOEXCEPT {return rbegin();} | ||||
|     const_reverse_iterator crbegin() const {return rbegin();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_reverse_iterator crend() const _NOEXCEPT {return rend();} | ||||
|     const_reverse_iterator crend()   const {return rend();} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     bool empty() const _NOEXCEPT {return __tree_.size() == 0;} | ||||
|     bool      empty()    const {return __tree_.size() == 0;} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     size_type size() const _NOEXCEPT {return __tree_.size();} | ||||
|     size_type size()     const {return __tree_.size();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     size_type max_size() const _NOEXCEPT {return __tree_.max_size();} | ||||
|     size_type max_size() const {return __tree_.max_size();} | ||||
|  | ||||
|     // modifiers: | ||||
| #if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||
|     template <class... _Args> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         iterator emplace(_Args&&... __args) | ||||
|             {return __tree_.__emplace_multi(_VSTD::forward<_Args>(__args)...);} | ||||
|             {return __tree_.__emplace_multi(_STD::forward<_Args>(__args)...);} | ||||
|     template <class... _Args> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         iterator emplace_hint(const_iterator __p, _Args&&... __args) | ||||
|             {return __tree_.__emplace_hint_multi(__p, _VSTD::forward<_Args>(__args)...);} | ||||
|             {return __tree_.__emplace_hint_multi(__p, _STD::forward<_Args>(__args)...);} | ||||
| #endif  // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator insert(const value_type& __v) | ||||
| @@ -985,7 +788,7 @@ public: | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator insert(value_type&& __v) | ||||
|         {return __tree_.__insert_multi(_VSTD::move(__v));} | ||||
|         {return __tree_.__insert_multi(_STD::move(__v));} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator insert(const_iterator __p, const value_type& __v) | ||||
| @@ -993,7 +796,7 @@ public: | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator insert(const_iterator __p, value_type&& __v) | ||||
|         {return __tree_.__insert_multi(_VSTD::move(__v));} | ||||
|         {return __tree_.__insert_multi(_STD::move(__v));} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     template <class _InputIterator> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -1003,11 +806,9 @@ public: | ||||
|                 __tree_.__insert_multi(__e, *__f); | ||||
|         } | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void insert(initializer_list<value_type> __il) | ||||
|         {insert(__il.begin(), __il.end());} | ||||
| #endif  // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator  erase(const_iterator __p) {return __tree_.erase(__p);} | ||||
| @@ -1017,15 +818,13 @@ public: | ||||
|     iterator  erase(const_iterator __f, const_iterator __l) | ||||
|         {return __tree_.erase(__f, __l);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void clear() _NOEXCEPT {__tree_.clear();} | ||||
|     void clear() {__tree_.clear();} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void swap(multiset& __s) | ||||
|         _NOEXCEPT_(__is_nothrow_swappable<__base>::value) | ||||
|         {__tree_.swap(__s.__tree_);} | ||||
|     void swap(multiset& __s) {__tree_.swap(__s.__tree_);} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     allocator_type get_allocator() const _NOEXCEPT {return __tree_.__alloc();} | ||||
|     allocator_type get_allocator() const {return __tree_.__alloc();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     key_compare    key_comp()      const {return __tree_.value_comp();} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -1036,85 +835,40 @@ public: | ||||
|     iterator find(const key_type& __k)             {return __tree_.find(__k);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator find(const key_type& __k) const {return __tree_.find(__k);} | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename _VSTD::enable_if<_VSTD::__is_transparent<_Compare, _K2>::value,iterator>::type | ||||
|     find(const _K2& __k)                           {return __tree_.find(__k);} | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename _VSTD::enable_if<_VSTD::__is_transparent<_Compare, _K2>::value,const_iterator>::type | ||||
|     find(const _K2& __k) const                     {return __tree_.find(__k);} | ||||
| #endif | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     size_type      count(const key_type& __k) const | ||||
|         {return __tree_.__count_multi(__k);} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator lower_bound(const key_type& __k) | ||||
|         {return __tree_.lower_bound(__k);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator lower_bound(const key_type& __k) const | ||||
|             {return __tree_.lower_bound(__k);} | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename _VSTD::enable_if<_VSTD::__is_transparent<_Compare, _K2>::value,iterator>::type | ||||
|     lower_bound(const _K2& __k)       {return __tree_.lower_bound(__k);} | ||||
|  | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename _VSTD::enable_if<_VSTD::__is_transparent<_Compare, _K2>::value,const_iterator>::type | ||||
|     lower_bound(const _K2& __k) const {return __tree_.lower_bound(__k);} | ||||
| #endif | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     iterator upper_bound(const key_type& __k) | ||||
|             {return __tree_.upper_bound(__k);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     const_iterator upper_bound(const key_type& __k) const | ||||
|             {return __tree_.upper_bound(__k);} | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename _VSTD::enable_if<_VSTD::__is_transparent<_Compare, _K2>::value,iterator>::type | ||||
|     upper_bound(const _K2& __k)       {return __tree_.upper_bound(__k);} | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename _VSTD::enable_if<_VSTD::__is_transparent<_Compare, _K2>::value,const_iterator>::type | ||||
|     upper_bound(const _K2& __k) const {return __tree_.upper_bound(__k);} | ||||
| #endif | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     pair<iterator,iterator>             equal_range(const key_type& __k) | ||||
|             {return __tree_.__equal_range_multi(__k);} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     pair<const_iterator,const_iterator> equal_range(const key_type& __k) const | ||||
|             {return __tree_.__equal_range_multi(__k);} | ||||
| #if _LIBCPP_STD_VER > 11 | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename _VSTD::enable_if<_VSTD::__is_transparent<_Compare, _K2>::value,pair<iterator,iterator>>::type | ||||
|     equal_range(const _K2& __k)       {return __tree_.__equal_range_multi(__k);} | ||||
|     template <typename _K2> | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     typename _VSTD::enable_if<_VSTD::__is_transparent<_Compare, _K2>::value,pair<const_iterator,const_iterator>>::type | ||||
|     equal_range(const _K2& __k) const {return __tree_.__equal_range_multi(__k);} | ||||
| #endif | ||||
| }; | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
| template <class _Key, class _Compare, class _Allocator> | ||||
| multiset<_Key, _Compare, _Allocator>::multiset(multiset&& __s, const allocator_type& __a) | ||||
|     : __tree_(_VSTD::move(__s.__tree_), __a) | ||||
|     : __tree_(_STD::move(__s.__tree_), __a) | ||||
| { | ||||
|     if (__a != __s.get_allocator()) | ||||
|     { | ||||
|         const_iterator __e = cend(); | ||||
|         while (!__s.empty()) | ||||
|             insert(__e, _VSTD::move(__s.__tree_.remove(__s.begin())->__value_)); | ||||
|             insert(__e, _STD::move(__s.__tree_.remove(__s.begin())->__value_)); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -1126,7 +880,7 @@ bool | ||||
| operator==(const multiset<_Key, _Compare, _Allocator>& __x, | ||||
|            const multiset<_Key, _Compare, _Allocator>& __y) | ||||
| { | ||||
|     return __x.size() == __y.size() && _VSTD::equal(__x.begin(), __x.end(), __y.begin()); | ||||
|     return __x.size() == __y.size() && _STD::equal(__x.begin(), __x.end(), __y.begin()); | ||||
| } | ||||
|  | ||||
| template <class _Key, class _Compare, class _Allocator> | ||||
| @@ -1135,7 +889,7 @@ bool | ||||
| operator< (const multiset<_Key, _Compare, _Allocator>& __x, | ||||
|            const multiset<_Key, _Compare, _Allocator>& __y) | ||||
| { | ||||
|     return _VSTD::lexicographical_compare(__x.begin(), __x.end(), __y.begin(), __y.end()); | ||||
|     return _STD::lexicographical_compare(__x.begin(), __x.end(), __y.begin(), __y.end()); | ||||
| } | ||||
|  | ||||
| template <class _Key, class _Compare, class _Allocator> | ||||
| @@ -1179,7 +933,6 @@ inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| swap(multiset<_Key, _Compare, _Allocator>& __x, | ||||
|      multiset<_Key, _Compare, _Allocator>& __y) | ||||
|     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||
| { | ||||
|     __x.swap(__y); | ||||
| } | ||||
|   | ||||
| @@ -1,419 +0,0 @@ | ||||
| // -*- C++ -*- | ||||
| //===------------------------ shared_mutex --------------------------------===// | ||||
| // | ||||
| //                     The LLVM Compiler Infrastructure | ||||
| // | ||||
| // This file is dual licensed under the MIT and the University of Illinois Open | ||||
| // Source Licenses. See LICENSE.TXT for details. | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| #ifndef _LIBCPP_SHARED_MUTEX | ||||
| #define _LIBCPP_SHARED_MUTEX | ||||
|  | ||||
| /* | ||||
|     shared_mutex synopsis | ||||
|  | ||||
| // C++1y | ||||
|  | ||||
| namespace std | ||||
| { | ||||
|  | ||||
| class shared_mutex | ||||
| { | ||||
| public: | ||||
|     shared_mutex(); | ||||
|     ~shared_mutex(); | ||||
|  | ||||
|     shared_mutex(const shared_mutex&) = delete; | ||||
|     shared_mutex& operator=(const shared_mutex&) = delete; | ||||
|  | ||||
|     // Exclusive ownership | ||||
|     void lock(); // blocking | ||||
|     bool try_lock(); | ||||
|     template <class Rep, class Period> | ||||
|         bool try_lock_for(const chrono::duration<Rep, Period>& rel_time); | ||||
|     template <class Clock, class Duration> | ||||
|         bool try_lock_until(const chrono::time_point<Clock, Duration>& abs_time); | ||||
|     void unlock(); | ||||
|  | ||||
|     // Shared ownership | ||||
|     void lock_shared(); // blocking | ||||
|     bool try_lock_shared(); | ||||
|     template <class Rep, class Period> | ||||
|         bool | ||||
|         try_lock_shared_for(const chrono::duration<Rep, Period>& rel_time); | ||||
|     template <class Clock, class Duration> | ||||
|         bool | ||||
|         try_lock_shared_until(const chrono::time_point<Clock, Duration>& abs_time); | ||||
|     void unlock_shared(); | ||||
| }; | ||||
|  | ||||
| template <class Mutex> | ||||
| class shared_lock | ||||
| { | ||||
| public: | ||||
|     typedef Mutex mutex_type; | ||||
|  | ||||
|     // Shared locking | ||||
|     shared_lock() noexcept; | ||||
|     explicit shared_lock(mutex_type& m); // blocking | ||||
|     shared_lock(mutex_type& m, defer_lock_t) noexcept; | ||||
|     shared_lock(mutex_type& m, try_to_lock_t); | ||||
|     shared_lock(mutex_type& m, adopt_lock_t); | ||||
|     template <class Clock, class Duration> | ||||
|         shared_lock(mutex_type& m, | ||||
|                     const chrono::time_point<Clock, Duration>& abs_time); | ||||
|     template <class Rep, class Period> | ||||
|         shared_lock(mutex_type& m, | ||||
|                     const chrono::duration<Rep, Period>& rel_time); | ||||
|     ~shared_lock(); | ||||
|  | ||||
|     shared_lock(shared_lock const&) = delete; | ||||
|     shared_lock& operator=(shared_lock const&) = delete; | ||||
|  | ||||
|     shared_lock(shared_lock&& u) noexcept; | ||||
|     shared_lock& operator=(shared_lock&& u) noexcept; | ||||
|  | ||||
|     void lock(); // blocking | ||||
|     bool try_lock(); | ||||
|     template <class Rep, class Period> | ||||
|         bool try_lock_for(const chrono::duration<Rep, Period>& rel_time); | ||||
|     template <class Clock, class Duration> | ||||
|         bool try_lock_until(const chrono::time_point<Clock, Duration>& abs_time); | ||||
|     void unlock(); | ||||
|  | ||||
|     // Setters | ||||
|     void swap(shared_lock& u) noexcept; | ||||
|     mutex_type* release() noexcept; | ||||
|  | ||||
|     // Getters | ||||
|     bool owns_lock() const noexcept; | ||||
|     explicit operator bool () const noexcept; | ||||
|     mutex_type* mutex() const noexcept; | ||||
| }; | ||||
|  | ||||
| template <class Mutex> | ||||
|     void swap(shared_lock<Mutex>& x, shared_lock<Mutex>& y) noexcept; | ||||
|  | ||||
| }  // std | ||||
|  | ||||
| */ | ||||
|  | ||||
| #include <__config> | ||||
|  | ||||
| #if _LIBCPP_STD_VER > 11 || defined(_LIBCPP_BUILDING_SHARED_MUTEX) | ||||
|  | ||||
| #include <__mutex_base> | ||||
|  | ||||
| #include <__undef_min_max> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS shared_mutex | ||||
| { | ||||
|     mutex               __mut_; | ||||
|     condition_variable  __gate1_; | ||||
|     condition_variable  __gate2_; | ||||
|     unsigned            __state_; | ||||
|  | ||||
|     static const unsigned __write_entered_ = 1U << (sizeof(unsigned)*__CHAR_BIT__ - 1); | ||||
|     static const unsigned __n_readers_ = ~__write_entered_; | ||||
| public: | ||||
|     shared_mutex(); | ||||
|     _LIBCPP_INLINE_VISIBILITY ~shared_mutex() = default; | ||||
|  | ||||
|     shared_mutex(const shared_mutex&) = delete; | ||||
|     shared_mutex& operator=(const shared_mutex&) = delete; | ||||
|  | ||||
|     // Exclusive ownership | ||||
|     void lock(); | ||||
|     bool try_lock(); | ||||
|     template <class _Rep, class _Period> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         bool | ||||
|         try_lock_for(const chrono::duration<_Rep, _Period>& __rel_time) | ||||
|         { | ||||
|             return try_lock_until(chrono::steady_clock::now() + __rel_time); | ||||
|         } | ||||
|     template <class _Clock, class _Duration> | ||||
|         bool | ||||
|         try_lock_until(const chrono::time_point<_Clock, _Duration>& __abs_time); | ||||
|     void unlock(); | ||||
|  | ||||
|     // Shared ownership | ||||
|     void lock_shared(); | ||||
|     bool try_lock_shared(); | ||||
|     template <class _Rep, class _Period> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         bool | ||||
|         try_lock_shared_for(const chrono::duration<_Rep, _Period>& __rel_time) | ||||
|         { | ||||
|             return try_lock_shared_until(chrono::steady_clock::now() + __rel_time); | ||||
|         } | ||||
|     template <class _Clock, class _Duration> | ||||
|         bool | ||||
|         try_lock_shared_until(const chrono::time_point<_Clock, _Duration>& __abs_time); | ||||
|     void unlock_shared(); | ||||
| }; | ||||
|  | ||||
| template <class _Clock, class _Duration> | ||||
| bool | ||||
| shared_mutex::try_lock_until( | ||||
|                         const chrono::time_point<_Clock, _Duration>& __abs_time) | ||||
| { | ||||
|     unique_lock<mutex> __lk(__mut_); | ||||
|     if (__state_ & __write_entered_) | ||||
|     { | ||||
|         while (true) | ||||
|         { | ||||
|             cv_status __status = __gate1_.wait_until(__lk, __abs_time); | ||||
|             if ((__state_ & __write_entered_) == 0) | ||||
|                 break; | ||||
|             if (__status == cv_status::timeout) | ||||
|                 return false; | ||||
|         } | ||||
|     } | ||||
|     __state_ |= __write_entered_; | ||||
|     if (__state_ & __n_readers_) | ||||
|     { | ||||
|         while (true) | ||||
|         { | ||||
|             cv_status __status = __gate2_.wait_until(__lk, __abs_time); | ||||
|             if ((__state_ & __n_readers_) == 0) | ||||
|                 break; | ||||
|             if (__status == cv_status::timeout) | ||||
|             { | ||||
|                 __state_ &= ~__write_entered_; | ||||
|                 return false; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     return true; | ||||
| } | ||||
|  | ||||
| template <class _Clock, class _Duration> | ||||
| bool | ||||
| shared_mutex::try_lock_shared_until( | ||||
|                         const chrono::time_point<_Clock, _Duration>& __abs_time) | ||||
| { | ||||
|     unique_lock<mutex> __lk(__mut_); | ||||
|     if ((__state_ & __write_entered_) || (__state_ & __n_readers_) == __n_readers_) | ||||
|     { | ||||
|         while (true) | ||||
|         { | ||||
|             cv_status status = __gate1_.wait_until(__lk, __abs_time); | ||||
|             if ((__state_ & __write_entered_) == 0 && | ||||
|                                        (__state_ & __n_readers_) < __n_readers_) | ||||
|                 break; | ||||
|             if (status == cv_status::timeout) | ||||
|                 return false; | ||||
|         } | ||||
|     } | ||||
|     unsigned __num_readers = (__state_ & __n_readers_) + 1; | ||||
|     __state_ &= ~__n_readers_; | ||||
|     __state_ |= __num_readers; | ||||
|     return true; | ||||
| } | ||||
|  | ||||
| template <class _Mutex> | ||||
| class shared_lock | ||||
| { | ||||
| public: | ||||
|     typedef _Mutex mutex_type; | ||||
|  | ||||
| private: | ||||
|     mutex_type* __m_; | ||||
|     bool __owns_; | ||||
|  | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     shared_lock() noexcept | ||||
|         : __m_(nullptr), | ||||
|           __owns_(false) | ||||
|         {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit shared_lock(mutex_type& __m) | ||||
|         : __m_(&__m), | ||||
|           __owns_(true) | ||||
|         {__m_->lock_shared();} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     shared_lock(mutex_type& __m, defer_lock_t) noexcept | ||||
|         : __m_(&__m), | ||||
|           __owns_(false) | ||||
|         {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     shared_lock(mutex_type& __m, try_to_lock_t) | ||||
|         : __m_(&__m), | ||||
|           __owns_(__m.try_lock_shared()) | ||||
|         {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     shared_lock(mutex_type& __m, adopt_lock_t) | ||||
|         : __m_(&__m), | ||||
|           __owns_(true) | ||||
|         {} | ||||
|  | ||||
|     template <class _Clock, class _Duration> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         shared_lock(mutex_type& __m, | ||||
|                     const chrono::time_point<_Clock, _Duration>& __abs_time) | ||||
|             : __m_(&__m), | ||||
|               __owns_(__m.try_lock_shared_until(__abs_time)) | ||||
|             {} | ||||
|  | ||||
|     template <class _Rep, class _Period> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         shared_lock(mutex_type& __m, | ||||
|                     const chrono::duration<_Rep, _Period>& __rel_time) | ||||
|             : __m_(&__m), | ||||
|               __owns_(__m.try_lock_shared_for(__rel_time)) | ||||
|             {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     ~shared_lock() | ||||
|     { | ||||
|         if (__owns_) | ||||
|             __m_->unlock_shared(); | ||||
|     } | ||||
|  | ||||
|     shared_lock(shared_lock const&) = delete; | ||||
|     shared_lock& operator=(shared_lock const&) = delete; | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     shared_lock(shared_lock&& __u) noexcept | ||||
|         : __m_(__u.__m_), | ||||
|           __owns_(__u.__owns_) | ||||
|         { | ||||
|             __u.__m_ = nullptr; | ||||
|             __u.__owns_ = false; | ||||
|         } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     shared_lock& operator=(shared_lock&& __u) noexcept | ||||
|     { | ||||
|         if (__owns_) | ||||
|             __m_->unlock_shared(); | ||||
|         __m_ = nullptr; | ||||
|         __owns_ = false; | ||||
|         __m_ = __u.__m_; | ||||
|         __owns_ = __u.__owns_; | ||||
|         __u.__m_ = nullptr; | ||||
|         __u.__owns_ = false; | ||||
|         return *this; | ||||
|     } | ||||
|  | ||||
|     void lock(); | ||||
|     bool try_lock(); | ||||
|     template <class Rep, class Period> | ||||
|         bool try_lock_for(const chrono::duration<Rep, Period>& rel_time); | ||||
|     template <class Clock, class Duration> | ||||
|         bool try_lock_until(const chrono::time_point<Clock, Duration>& abs_time); | ||||
|     void unlock(); | ||||
|  | ||||
|     // Setters | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void swap(shared_lock& __u) noexcept | ||||
|     { | ||||
|         _VSTD::swap(__m_, __u.__m_); | ||||
|         _VSTD::swap(__owns_, __u.__owns_); | ||||
|     } | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     mutex_type* release() noexcept | ||||
|     { | ||||
|         mutex_type* __m = __m_; | ||||
|         __m_ = nullptr; | ||||
|         __owns_ = false; | ||||
|         return __m; | ||||
|     } | ||||
|  | ||||
|     // Getters | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     bool owns_lock() const noexcept {return __owns_;} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit operator bool () const noexcept {return __owns_;} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     mutex_type* mutex() const noexcept {return __m_;} | ||||
| }; | ||||
|  | ||||
| template <class _Mutex> | ||||
| void | ||||
| shared_lock<_Mutex>::lock() | ||||
| { | ||||
|     if (__m_ == nullptr) | ||||
|         __throw_system_error(EPERM, "shared_lock::lock: references null mutex"); | ||||
|     if (__owns_) | ||||
|         __throw_system_error(EDEADLK, "shared_lock::lock: already locked"); | ||||
|     __m_->lock_shared(); | ||||
|     __owns_ = true; | ||||
| } | ||||
|  | ||||
| template <class _Mutex> | ||||
| bool | ||||
| shared_lock<_Mutex>::try_lock() | ||||
| { | ||||
|     if (__m_ == nullptr) | ||||
|         __throw_system_error(EPERM, "shared_lock::try_lock: references null mutex"); | ||||
|     if (__owns_) | ||||
|         __throw_system_error(EDEADLK, "shared_lock::try_lock: already locked"); | ||||
|     __owns_ = __m_->try_lock_shared(); | ||||
|     return __owns_; | ||||
| } | ||||
|  | ||||
| template <class _Mutex> | ||||
| template <class _Rep, class _Period> | ||||
| bool | ||||
| shared_lock<_Mutex>::try_lock_for(const chrono::duration<_Rep, _Period>& __d) | ||||
| { | ||||
|     if (__m_ == nullptr) | ||||
|         __throw_system_error(EPERM, "shared_lock::try_lock_for: references null mutex"); | ||||
|     if (__owns_) | ||||
|         __throw_system_error(EDEADLK, "shared_lock::try_lock_for: already locked"); | ||||
|     __owns_ = __m_->try_lock_shared_for(__d); | ||||
|     return __owns_; | ||||
| } | ||||
|  | ||||
| template <class _Mutex> | ||||
| template <class _Clock, class _Duration> | ||||
| bool | ||||
| shared_lock<_Mutex>::try_lock_until(const chrono::time_point<_Clock, _Duration>& __t) | ||||
| { | ||||
|     if (__m_ == nullptr) | ||||
|         __throw_system_error(EPERM, "shared_lock::try_lock_until: references null mutex"); | ||||
|     if (__owns_) | ||||
|         __throw_system_error(EDEADLK, "shared_lock::try_lock_until: already locked"); | ||||
|     __owns_ = __m_->try_lock_shared_until(__t); | ||||
|     return __owns_; | ||||
| } | ||||
|  | ||||
| template <class _Mutex> | ||||
| void | ||||
| shared_lock<_Mutex>::unlock() | ||||
| { | ||||
|     if (!__owns_) | ||||
|         __throw_system_error(EPERM, "shared_lock::unlock: not locked"); | ||||
|     __m_->unlock_shared(); | ||||
|     __owns_ = false; | ||||
| } | ||||
|  | ||||
| template <class _Mutex> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| swap(shared_lock<_Mutex>& __x, shared_lock<_Mutex>& __y) noexcept | ||||
|     {__x.swap(__y);} | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
| #endif  // _LIBCPP_STD_VER > 11 | ||||
|  | ||||
| #endif  // _LIBCPP_SHARED_MUTEX | ||||
							
								
								
									
										206
									
								
								include/sstream
									
									
									
									
									
								
							
							
						
						
									
										206
									
								
								include/sstream
									
									
									
									
									
								
							| @@ -175,18 +175,14 @@ typedef basic_stringstream<wchar_t> wstringstream; | ||||
| #include <istream> | ||||
| #include <string> | ||||
|  | ||||
| #include <__undef_min_max> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| // basic_stringbuf | ||||
|  | ||||
| template <class _CharT, class _Traits, class _Allocator> | ||||
| class _LIBCPP_TYPE_VIS_ONLY basic_stringbuf | ||||
| class _LIBCPP_VISIBLE basic_stringbuf | ||||
|     : public basic_streambuf<_CharT, _Traits> | ||||
| { | ||||
| public: | ||||
| @@ -260,36 +256,17 @@ template <class _CharT, class _Traits, class _Allocator> | ||||
| basic_stringbuf<_CharT, _Traits, _Allocator>::basic_stringbuf(basic_stringbuf&& __rhs) | ||||
|     : __mode_(__rhs.__mode_) | ||||
| { | ||||
|     char_type* __p = const_cast<char_type*>(__rhs.__str_.data()); | ||||
|     ptrdiff_t __binp = -1; | ||||
|     ptrdiff_t __ninp = -1; | ||||
|     ptrdiff_t __einp = -1; | ||||
|     if (__rhs.eback() != nullptr) | ||||
|     { | ||||
|         __binp = __rhs.eback() - __p; | ||||
|         __ninp = __rhs.gptr() - __p; | ||||
|         __einp = __rhs.egptr() - __p; | ||||
|     } | ||||
|     ptrdiff_t __bout = -1; | ||||
|     ptrdiff_t __nout = -1; | ||||
|     ptrdiff_t __eout = -1; | ||||
|     if (__rhs.pbase() != nullptr) | ||||
|     { | ||||
|         __bout = __rhs.pbase() - __p; | ||||
|         __nout = __rhs.pptr() - __p; | ||||
|         __eout = __rhs.epptr() - __p; | ||||
|     } | ||||
|     ptrdiff_t __hm = __rhs.__hm_ == nullptr ? -1 : __rhs.__hm_ - __p; | ||||
|     __str_ = _VSTD::move(__rhs.__str_); | ||||
|     __p = const_cast<char_type*>(__str_.data()); | ||||
|     if (__binp != -1) | ||||
|         this->setg(__p + __binp, __p + __ninp, __p + __einp); | ||||
|     if (__bout != -1) | ||||
|     { | ||||
|         this->setp(__p + __bout, __p + __eout); | ||||
|         this->pbump(__nout); | ||||
|     } | ||||
|     __hm_ = __hm == -1 ? nullptr : __p + __hm; | ||||
|     ptrdiff_t __ninp = __rhs.gptr()  - __rhs.eback(); | ||||
|     ptrdiff_t __einp = __rhs.egptr() - __rhs.eback(); | ||||
|     ptrdiff_t __nout = __rhs.pptr()  - __rhs.pbase(); | ||||
|     ptrdiff_t __eout = __rhs.epptr() - __rhs.pbase(); | ||||
|     ptrdiff_t __hm   = __rhs.__hm_   - __rhs.pbase(); | ||||
|     __str_ = _STD::move(__rhs.__str_); | ||||
|     char_type* __p = const_cast<char_type*>(__str_.data()); | ||||
|     this->setg(__p, __p + __ninp, __p + __einp); | ||||
|     this->setp(__p, __p + __eout); | ||||
|     this->pbump(__nout); | ||||
|     __hm_ = __p + __hm; | ||||
|     __p = const_cast<char_type*>(__rhs.__str_.data()); | ||||
|     __rhs.setg(__p, __p, __p); | ||||
|     __rhs.setp(__p, __p); | ||||
| @@ -301,37 +278,18 @@ template <class _CharT, class _Traits, class _Allocator> | ||||
| basic_stringbuf<_CharT, _Traits, _Allocator>& | ||||
| basic_stringbuf<_CharT, _Traits, _Allocator>::operator=(basic_stringbuf&& __rhs) | ||||
| { | ||||
|     char_type* __p = const_cast<char_type*>(__rhs.__str_.data()); | ||||
|     ptrdiff_t __binp = -1; | ||||
|     ptrdiff_t __ninp = -1; | ||||
|     ptrdiff_t __einp = -1; | ||||
|     if (__rhs.eback() != nullptr) | ||||
|     { | ||||
|         __binp = __rhs.eback() - __p; | ||||
|         __ninp = __rhs.gptr() - __p; | ||||
|         __einp = __rhs.egptr() - __p; | ||||
|     } | ||||
|     ptrdiff_t __bout = -1; | ||||
|     ptrdiff_t __nout = -1; | ||||
|     ptrdiff_t __eout = -1; | ||||
|     if (__rhs.pbase() != nullptr) | ||||
|     { | ||||
|         __bout = __rhs.pbase() - __p; | ||||
|         __nout = __rhs.pptr() - __p; | ||||
|         __eout = __rhs.epptr() - __p; | ||||
|     } | ||||
|     ptrdiff_t __hm = __rhs.__hm_ == nullptr ? -1 : __rhs.__hm_ - __p; | ||||
|     __str_ = _VSTD::move(__rhs.__str_); | ||||
|     __p = const_cast<char_type*>(__str_.data()); | ||||
|     if (__binp != -1) | ||||
|         this->setg(__p + __binp, __p + __ninp, __p + __einp); | ||||
|     if (__bout != -1) | ||||
|     { | ||||
|         this->setp(__p + __bout, __p + __eout); | ||||
|         this->pbump(__nout); | ||||
|     } | ||||
|     __hm_ = __hm == -1 ? nullptr : __p + __hm; | ||||
|     ptrdiff_t __ninp = __rhs.gptr()  - __rhs.eback(); | ||||
|     ptrdiff_t __einp = __rhs.egptr() - __rhs.eback(); | ||||
|     ptrdiff_t __nout = __rhs.pptr()  - __rhs.pbase(); | ||||
|     ptrdiff_t __eout = __rhs.epptr() - __rhs.pbase(); | ||||
|     ptrdiff_t __hm   = __rhs.__hm_   - __rhs.pbase(); | ||||
|     __mode_ = __rhs.__mode_; | ||||
|     __str_ = _STD::move(__rhs.__str_); | ||||
|     char_type* __p = const_cast<char_type*>(__str_.data()); | ||||
|     this->setg(__p, __p + __ninp, __p + __einp); | ||||
|     this->setp(__p, __p + __eout); | ||||
|     this->pbump(__nout); | ||||
|     __hm_ = __p + __hm; | ||||
|     __p = const_cast<char_type*>(__rhs.__str_.data()); | ||||
|     __rhs.setg(__p, __p, __p); | ||||
|     __rhs.setp(__p, __p); | ||||
| @@ -346,74 +304,28 @@ template <class _CharT, class _Traits, class _Allocator> | ||||
| void | ||||
| basic_stringbuf<_CharT, _Traits, _Allocator>::swap(basic_stringbuf& __rhs) | ||||
| { | ||||
|     char_type* __p = const_cast<char_type*>(__rhs.__str_.data()); | ||||
|     ptrdiff_t __rbinp = -1; | ||||
|     ptrdiff_t __rninp = -1; | ||||
|     ptrdiff_t __reinp = -1; | ||||
|     if (__rhs.eback() != nullptr) | ||||
|     { | ||||
|         __rbinp = __rhs.eback() - __p; | ||||
|         __rninp = __rhs.gptr() - __p; | ||||
|         __reinp = __rhs.egptr() - __p; | ||||
|     } | ||||
|     ptrdiff_t __rbout = -1; | ||||
|     ptrdiff_t __rnout = -1; | ||||
|     ptrdiff_t __reout = -1; | ||||
|     if (__rhs.pbase() != nullptr) | ||||
|     { | ||||
|         __rbout = __rhs.pbase() - __p; | ||||
|         __rnout = __rhs.pptr() - __p; | ||||
|         __reout = __rhs.epptr() - __p; | ||||
|     } | ||||
|     ptrdiff_t __rhm = __rhs.__hm_ == nullptr ? -1 : __rhs.__hm_ - __p; | ||||
|     __p = const_cast<char_type*>(__str_.data()); | ||||
|     ptrdiff_t __lbinp = -1; | ||||
|     ptrdiff_t __lninp = -1; | ||||
|     ptrdiff_t __leinp = -1; | ||||
|     if (this->eback() != nullptr) | ||||
|     { | ||||
|         __lbinp = this->eback() - __p; | ||||
|         __lninp = this->gptr() - __p; | ||||
|         __leinp = this->egptr() - __p; | ||||
|     } | ||||
|     ptrdiff_t __lbout = -1; | ||||
|     ptrdiff_t __lnout = -1; | ||||
|     ptrdiff_t __leout = -1; | ||||
|     if (this->pbase() != nullptr) | ||||
|     { | ||||
|         __lbout = this->pbase() - __p; | ||||
|         __lnout = this->pptr() - __p; | ||||
|         __leout = this->epptr() - __p; | ||||
|     } | ||||
|     ptrdiff_t __lhm = __hm_ == nullptr ? -1 : __hm_ - __p; | ||||
|     _VSTD::swap(__mode_, __rhs.__mode_); | ||||
|     ptrdiff_t __rninp = __rhs.gptr()  - __rhs.eback(); | ||||
|     ptrdiff_t __reinp = __rhs.egptr() - __rhs.eback(); | ||||
|     ptrdiff_t __rnout = __rhs.pptr()  - __rhs.pbase(); | ||||
|     ptrdiff_t __reout = __rhs.epptr() - __rhs.pbase(); | ||||
|     ptrdiff_t __rhm   = __rhs.__hm_   - __rhs.pbase(); | ||||
|     ptrdiff_t __lninp = this->gptr()  - this->eback(); | ||||
|     ptrdiff_t __leinp = this->egptr() - this->eback(); | ||||
|     ptrdiff_t __lnout = this->pptr()  - this->pbase(); | ||||
|     ptrdiff_t __leout = this->epptr() - this->pbase(); | ||||
|     ptrdiff_t __lhm   = this->__hm_   - this->pbase(); | ||||
|     _STD::swap(__mode_, __rhs.__mode_); | ||||
|     __str_.swap(__rhs.__str_); | ||||
|     __p = const_cast<char_type*>(__str_.data()); | ||||
|     if (__rbinp != -1) | ||||
|         this->setg(__p + __rbinp, __p + __rninp, __p + __reinp); | ||||
|     else | ||||
|         this->setg(nullptr, nullptr, nullptr); | ||||
|     if (__rbout != -1) | ||||
|     { | ||||
|         this->setp(__p + __rbout, __p + __reout); | ||||
|         this->pbump(__rnout); | ||||
|     } | ||||
|     else | ||||
|         this->setp(nullptr, nullptr); | ||||
|     __hm_ = __rhm == -1 ? nullptr : __p + __rhm; | ||||
|     char_type* __p = const_cast<char_type*>(__str_.data()); | ||||
|     this->setg(__p, __p + __rninp, __p + __reinp); | ||||
|     this->setp(__p, __p + __reout); | ||||
|     this->pbump(__rnout); | ||||
|     __hm_ = __p + __rhm; | ||||
|     __p = const_cast<char_type*>(__rhs.__str_.data()); | ||||
|     if (__lbinp != -1) | ||||
|         __rhs.setg(__p + __lbinp, __p + __lninp, __p + __leinp); | ||||
|     else | ||||
|         __rhs.setg(nullptr, nullptr, nullptr); | ||||
|     if (__lbout != -1) | ||||
|     { | ||||
|         __rhs.setp(__p + __lbout, __p + __leout); | ||||
|         __rhs.pbump(__lnout); | ||||
|     } | ||||
|     else | ||||
|         __rhs.setp(nullptr, nullptr); | ||||
|     __rhs.__hm_ = __lhm == -1 ? nullptr : __p + __lhm; | ||||
|     __rhs.setg(__p, __p + __lninp, __p + __leinp); | ||||
|     __rhs.setp(__p, __p + __leout); | ||||
|     __rhs.pbump(__lnout); | ||||
|     __rhs.__hm_ = __p + __lhm; | ||||
|     locale __tl = __rhs.getloc(); | ||||
|     __rhs.pubimbue(this->getloc()); | ||||
|     this->pubimbue(__tl); | ||||
| @@ -539,7 +451,7 @@ basic_stringbuf<_CharT, _Traits, _Allocator>::overflow(int_type __c) | ||||
|             } | ||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | ||||
|         } | ||||
|         __hm_ = _VSTD::max(this->pptr() + 1, __hm_); | ||||
|         __hm_ = _STD::max(this->pptr() + 1, __hm_); | ||||
|         if (__mode_ & ios_base::in) | ||||
|         { | ||||
|             char_type* __p = const_cast<char_type*>(__str_.data()); | ||||
| @@ -613,7 +525,7 @@ basic_stringbuf<_CharT, _Traits, _Allocator>::seekpos(pos_type __sp, | ||||
| // basic_istringstream | ||||
|  | ||||
| template <class _CharT, class _Traits, class _Allocator> | ||||
| class _LIBCPP_TYPE_VIS_ONLY basic_istringstream | ||||
| class _LIBCPP_VISIBLE basic_istringstream | ||||
|     : public basic_istream<_CharT, _Traits> | ||||
| { | ||||
| public: | ||||
| @@ -670,8 +582,8 @@ basic_istringstream<_CharT, _Traits, _Allocator>::basic_istringstream(const stri | ||||
| template <class _CharT, class _Traits, class _Allocator> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| basic_istringstream<_CharT, _Traits, _Allocator>::basic_istringstream(basic_istringstream&& __rhs) | ||||
|     : basic_istream<_CharT, _Traits>(_VSTD::move(__rhs)), | ||||
|       __sb_(_VSTD::move(__rhs.__sb_)) | ||||
|     : basic_istream<_CharT, _Traits>(_STD::move(__rhs)), | ||||
|       __sb_(_STD::move(__rhs.__sb_)) | ||||
| { | ||||
|     basic_istream<_CharT, _Traits>::set_rdbuf(&__sb_); | ||||
| } | ||||
| @@ -680,8 +592,8 @@ template <class _CharT, class _Traits, class _Allocator> | ||||
| basic_istringstream<_CharT, _Traits, _Allocator>& | ||||
| basic_istringstream<_CharT, _Traits, _Allocator>::operator=(basic_istringstream&& __rhs) | ||||
| { | ||||
|     basic_istream<char_type, traits_type>::operator=(_VSTD::move(__rhs)); | ||||
|     __sb_ = _VSTD::move(__rhs.__sb_); | ||||
|     basic_istream<char_type, traits_type>::operator=(_STD::move(__rhs)); | ||||
|     __sb_ = _STD::move(__rhs.__sb_); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| @@ -732,7 +644,7 @@ basic_istringstream<_CharT, _Traits, _Allocator>::str(const string_type& __s) | ||||
| // basic_ostringstream | ||||
|  | ||||
| template <class _CharT, class _Traits, class _Allocator> | ||||
| class _LIBCPP_TYPE_VIS_ONLY basic_ostringstream | ||||
| class _LIBCPP_VISIBLE basic_ostringstream | ||||
|     : public basic_ostream<_CharT, _Traits> | ||||
| { | ||||
| public: | ||||
| @@ -789,8 +701,8 @@ basic_ostringstream<_CharT, _Traits, _Allocator>::basic_ostringstream(const stri | ||||
| template <class _CharT, class _Traits, class _Allocator> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| basic_ostringstream<_CharT, _Traits, _Allocator>::basic_ostringstream(basic_ostringstream&& __rhs) | ||||
|     : basic_ostream<_CharT, _Traits>(_VSTD::move(__rhs)), | ||||
|       __sb_(_VSTD::move(__rhs.__sb_)) | ||||
|     : basic_ostream<_CharT, _Traits>(_STD::move(__rhs)), | ||||
|       __sb_(_STD::move(__rhs.__sb_)) | ||||
| { | ||||
|     basic_ostream<_CharT, _Traits>::set_rdbuf(&__sb_); | ||||
| } | ||||
| @@ -799,8 +711,8 @@ template <class _CharT, class _Traits, class _Allocator> | ||||
| basic_ostringstream<_CharT, _Traits, _Allocator>& | ||||
| basic_ostringstream<_CharT, _Traits, _Allocator>::operator=(basic_ostringstream&& __rhs) | ||||
| { | ||||
|     basic_ostream<char_type, traits_type>::operator=(_VSTD::move(__rhs)); | ||||
|     __sb_ = _VSTD::move(__rhs.__sb_); | ||||
|     basic_ostream<char_type, traits_type>::operator=(_STD::move(__rhs)); | ||||
|     __sb_ = _STD::move(__rhs.__sb_); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| @@ -851,7 +763,7 @@ basic_ostringstream<_CharT, _Traits, _Allocator>::str(const string_type& __s) | ||||
| // basic_stringstream | ||||
|  | ||||
| template <class _CharT, class _Traits, class _Allocator> | ||||
| class _LIBCPP_TYPE_VIS_ONLY basic_stringstream | ||||
| class _LIBCPP_VISIBLE basic_stringstream | ||||
|     : public basic_iostream<_CharT, _Traits> | ||||
| { | ||||
| public: | ||||
| @@ -908,8 +820,8 @@ basic_stringstream<_CharT, _Traits, _Allocator>::basic_stringstream(const string | ||||
| template <class _CharT, class _Traits, class _Allocator> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| basic_stringstream<_CharT, _Traits, _Allocator>::basic_stringstream(basic_stringstream&& __rhs) | ||||
|     : basic_iostream<_CharT, _Traits>(_VSTD::move(__rhs)), | ||||
|       __sb_(_VSTD::move(__rhs.__sb_)) | ||||
|     : basic_iostream<_CharT, _Traits>(_STD::move(__rhs)), | ||||
|       __sb_(_STD::move(__rhs.__sb_)) | ||||
| { | ||||
|     basic_istream<_CharT, _Traits>::set_rdbuf(&__sb_); | ||||
| } | ||||
| @@ -918,8 +830,8 @@ template <class _CharT, class _Traits, class _Allocator> | ||||
| basic_stringstream<_CharT, _Traits, _Allocator>& | ||||
| basic_stringstream<_CharT, _Traits, _Allocator>::operator=(basic_stringstream&& __rhs) | ||||
| { | ||||
|     basic_iostream<char_type, traits_type>::operator=(_VSTD::move(__rhs)); | ||||
|     __sb_ = _VSTD::move(__rhs.__sb_); | ||||
|     basic_iostream<char_type, traits_type>::operator=(_STD::move(__rhs)); | ||||
|     __sb_ = _STD::move(__rhs.__sb_); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -31,21 +31,14 @@ protected: | ||||
|     container_type c; | ||||
|  | ||||
| public: | ||||
|     stack() = default; | ||||
|     ~stack() = default; | ||||
|  | ||||
|     stack(const stack& q) = default; | ||||
|     stack(stack&& q) = default; | ||||
|  | ||||
|     stack& operator=(const stack& q) = default; | ||||
|     stack& operator=(stack&& q) = default; | ||||
|  | ||||
|     explicit stack(); | ||||
|     explicit stack(const container_type& c); | ||||
|     explicit stack(container_type&& c); | ||||
|     stack(stack&& s); | ||||
|     stack& operator=(stack&& s); | ||||
|     template <class Alloc> explicit stack(const Alloc& a); | ||||
|     template <class Alloc> stack(const container_type& c, const Alloc& a); | ||||
|     template <class Alloc> stack(container_type&& c, const Alloc& a); | ||||
|     template <class Alloc> stack(const stack& c, const Alloc& a); | ||||
|     template <class Alloc> stack(stack&& c, const Alloc& a); | ||||
|  | ||||
|     bool empty() const; | ||||
| @@ -58,7 +51,7 @@ public: | ||||
|     template <class... Args> void emplace(Args&&... args); | ||||
|     void pop(); | ||||
|  | ||||
|     void swap(stack& c) noexcept(noexcept(swap(c, q.c))); | ||||
|     void swap(stack& c); | ||||
| }; | ||||
|  | ||||
| template <class T, class Container> | ||||
| @@ -75,8 +68,7 @@ template <class T, class Container> | ||||
|   bool operator<=(const stack<T, Container>& x, const stack<T, Container>& y); | ||||
|  | ||||
| template <class T, class Container> | ||||
|   void swap(stack<T, Container>& x, stack<T, Container>& y) | ||||
|   noexcept(noexcept(x.swap(y))); | ||||
|   void swap(stack<T, Container>& x, stack<T, Container>& y); | ||||
|  | ||||
| }  // std | ||||
|  | ||||
| @@ -85,26 +77,22 @@ template <class T, class Container> | ||||
| #include <__config> | ||||
| #include <deque> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template <class _Tp, class _Container> class _LIBCPP_TYPE_VIS_ONLY stack; | ||||
| template <class _Tp, class _Container> class stack; | ||||
|  | ||||
| template <class _Tp, class _Container> | ||||
| _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator==(const stack<_Tp, _Container>& __x, const stack<_Tp, _Container>& __y); | ||||
|  | ||||
| template <class _Tp, class _Container> | ||||
| _LIBCPP_INLINE_VISIBILITY | ||||
| bool | ||||
| operator< (const stack<_Tp, _Container>& __x, const stack<_Tp, _Container>& __y); | ||||
|  | ||||
| template <class _Tp, class _Container = deque<_Tp> > | ||||
| class _LIBCPP_TYPE_VIS_ONLY stack | ||||
| class _LIBCPP_VISIBLE stack | ||||
| { | ||||
| public: | ||||
|     typedef _Container                               container_type; | ||||
| @@ -118,35 +106,16 @@ protected: | ||||
|  | ||||
| public: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     stack() | ||||
|         _NOEXCEPT_(is_nothrow_default_constructible<container_type>::value) | ||||
|         : c() {} | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     stack(const stack& __q) : c(__q.c) {} | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     stack(stack&& __q) | ||||
|         _NOEXCEPT_(is_nothrow_move_constructible<container_type>::value) | ||||
|         : c(_VSTD::move(__q.c)) {} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     stack& operator=(const stack& __q) {c = __q.c; return *this;} | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     stack& operator=(stack&& __q) | ||||
|         _NOEXCEPT_(is_nothrow_move_assignable<container_type>::value) | ||||
|         {c = _VSTD::move(__q.c); return *this;} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
|     stack() : c() {} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit stack(const container_type& __c) : c(__c) {} | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     explicit stack(container_type&& __c) : c(_VSTD::move(__c)) {} | ||||
|     explicit stack(container_type&& __c) : c(_STD::move(__c)) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     stack(stack&& __s) : c(_STD::move(__s.c)) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     stack& operator=(stack&& __s) {c = _STD::move(__s.c); return *this;} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     template <class _Alloc> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -172,13 +141,13 @@ public: | ||||
|         stack(container_type&& __c, const _Alloc& __a, | ||||
|               typename enable_if<uses_allocator<container_type, | ||||
|                                                 _Alloc>::value>::type* = 0) | ||||
|             : c(_VSTD::move(__c), __a) {} | ||||
|             : c(_STD::move(__c), __a) {} | ||||
|     template <class _Alloc> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         stack(stack&& __s, const _Alloc& __a, | ||||
|               typename enable_if<uses_allocator<container_type, | ||||
|                                                 _Alloc>::value>::type* = 0) | ||||
|             : c(_VSTD::move(__s.c), __a) {} | ||||
|             : c(_STD::move(__s.c), __a) {} | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -194,12 +163,12 @@ public: | ||||
|     void push(const value_type& __v) {c.push_back(__v);} | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void push(value_type&& __v) {c.push_back(_VSTD::move(__v));} | ||||
|     void push(value_type&& __v) {c.push_back(_STD::move(__v));} | ||||
| #ifndef _LIBCPP_HAS_NO_VARIADICS | ||||
|     template <class... _Args> | ||||
|         _LIBCPP_INLINE_VISIBILITY | ||||
|         void emplace(_Args&&... __args) | ||||
|         {c.emplace_back(_VSTD::forward<_Args>(__args)...);} | ||||
|         {c.emplace_back(_STD::forward<_Args>(__args)...);} | ||||
| #endif  // _LIBCPP_HAS_NO_VARIADICS | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
| @@ -207,9 +176,8 @@ public: | ||||
|  | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     void swap(stack& __s) | ||||
|         _NOEXCEPT_(__is_nothrow_swappable<container_type>::value) | ||||
|     { | ||||
|         using _VSTD::swap; | ||||
|         using _STD::swap; | ||||
|         swap(c, __s.c); | ||||
|     } | ||||
|  | ||||
| @@ -276,13 +244,12 @@ template <class _Tp, class _Container> | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| void | ||||
| swap(stack<_Tp, _Container>& __x, stack<_Tp, _Container>& __y) | ||||
|     _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) | ||||
| { | ||||
|     __x.swap(__y); | ||||
| } | ||||
|  | ||||
| template <class _Tp, class _Container, class _Alloc> | ||||
| struct _LIBCPP_TYPE_VIS_ONLY uses_allocator<stack<_Tp, _Container>, _Alloc> | ||||
| struct _LIBCPP_VISIBLE uses_allocator<stack<_Tp, _Container>, _Alloc> | ||||
|     : public uses_allocator<_Container, _Alloc> | ||||
| { | ||||
| }; | ||||
|   | ||||
| @@ -33,9 +33,9 @@ class xxx_error : public exception // at least indirectly | ||||
| { | ||||
| public: | ||||
|     explicit xxx_error(const string& what_arg); | ||||
|     explicit xxx_error(const char*   what_arg); | ||||
|     explicit xxx_error(const char*   what_arg);  // extension | ||||
|  | ||||
|     virtual const char* what() const noexcept // returns what_arg | ||||
|     virtual const char* what() const // returns what_arg | ||||
| }; | ||||
|  | ||||
| }  // std | ||||
| @@ -46,9 +46,7 @@ public: | ||||
| #include <exception> | ||||
| #include <iosfwd>  // for string forward decl | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| namespace std  // purposefully not using versioning namespace | ||||
| { | ||||
| @@ -62,12 +60,12 @@ public: | ||||
|     explicit logic_error(const string&); | ||||
|     explicit logic_error(const char*); | ||||
|  | ||||
|     logic_error(const logic_error&) _NOEXCEPT; | ||||
|     logic_error& operator=(const logic_error&) _NOEXCEPT; | ||||
|     logic_error(const logic_error&) throw(); | ||||
|     logic_error& operator=(const logic_error&) throw(); | ||||
|  | ||||
|     virtual ~logic_error() _NOEXCEPT; | ||||
|     virtual ~logic_error() throw(); | ||||
|  | ||||
|     virtual const char* what() const _NOEXCEPT; | ||||
|     virtual const char* what() const throw(); | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_EXCEPTION_ABI runtime_error | ||||
| @@ -79,12 +77,12 @@ public: | ||||
|     explicit runtime_error(const string&); | ||||
|     explicit runtime_error(const char*); | ||||
|  | ||||
|     runtime_error(const runtime_error&) _NOEXCEPT; | ||||
|     runtime_error& operator=(const runtime_error&) _NOEXCEPT; | ||||
|     runtime_error(const runtime_error&) throw(); | ||||
|     runtime_error& operator=(const runtime_error&) throw(); | ||||
|  | ||||
|     virtual ~runtime_error() _NOEXCEPT; | ||||
|     virtual ~runtime_error() throw(); | ||||
|  | ||||
|     virtual const char* what() const _NOEXCEPT; | ||||
|     virtual const char* what() const throw(); | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_EXCEPTION_ABI domain_error | ||||
| @@ -94,7 +92,7 @@ public: | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit domain_error(const string& __s) : logic_error(__s) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit domain_error(const char* __s)   : logic_error(__s) {} | ||||
|  | ||||
|     virtual ~domain_error() _NOEXCEPT; | ||||
|     virtual ~domain_error() throw(); | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_EXCEPTION_ABI invalid_argument | ||||
| @@ -104,7 +102,7 @@ public: | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit invalid_argument(const string& __s) : logic_error(__s) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit invalid_argument(const char* __s)   : logic_error(__s) {} | ||||
|  | ||||
|     virtual ~invalid_argument() _NOEXCEPT; | ||||
|     virtual ~invalid_argument() throw(); | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_EXCEPTION_ABI length_error | ||||
| @@ -114,7 +112,7 @@ public: | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit length_error(const string& __s) : logic_error(__s) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit length_error(const char* __s)   : logic_error(__s) {} | ||||
|  | ||||
|     virtual ~length_error() _NOEXCEPT; | ||||
|     virtual ~length_error() throw(); | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_EXCEPTION_ABI out_of_range | ||||
| @@ -124,7 +122,7 @@ public: | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit out_of_range(const string& __s) : logic_error(__s) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit out_of_range(const char* __s)   : logic_error(__s) {} | ||||
|  | ||||
|     virtual ~out_of_range() _NOEXCEPT; | ||||
|     virtual ~out_of_range() throw(); | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_EXCEPTION_ABI range_error | ||||
| @@ -134,7 +132,7 @@ public: | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit range_error(const string& __s) : runtime_error(__s) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit range_error(const char* __s)   : runtime_error(__s) {} | ||||
|  | ||||
|     virtual ~range_error() _NOEXCEPT; | ||||
|     virtual ~range_error() throw(); | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_EXCEPTION_ABI overflow_error | ||||
| @@ -144,7 +142,7 @@ public: | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit overflow_error(const string& __s) : runtime_error(__s) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit overflow_error(const char* __s)   : runtime_error(__s) {} | ||||
|  | ||||
|     virtual ~overflow_error() _NOEXCEPT; | ||||
|     virtual ~overflow_error() throw(); | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_EXCEPTION_ABI underflow_error | ||||
| @@ -154,7 +152,7 @@ public: | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit underflow_error(const string& __s) : runtime_error(__s) {} | ||||
|     _LIBCPP_INLINE_VISIBILITY explicit underflow_error(const char* __s)   : runtime_error(__s) {} | ||||
|  | ||||
|     virtual ~underflow_error() _NOEXCEPT; | ||||
|     virtual ~underflow_error() throw(); | ||||
| }; | ||||
|  | ||||
| }  // std | ||||
|   | ||||
| @@ -112,14 +112,12 @@ protected: | ||||
| #include <iosfwd> | ||||
| #include <ios> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| class _LIBCPP_TYPE_VIS_ONLY basic_streambuf | ||||
| class _LIBCPP_VISIBLE basic_streambuf | ||||
| { | ||||
| public: | ||||
|     // types: | ||||
| @@ -401,13 +399,13 @@ template <class _CharT, class _Traits> | ||||
| void | ||||
| basic_streambuf<_CharT, _Traits>::swap(basic_streambuf& __sb) | ||||
| { | ||||
|     _VSTD::swap(__loc_, __sb.__loc_); | ||||
|     _VSTD::swap(__binp_, __sb.__binp_); | ||||
|     _VSTD::swap(__ninp_, __sb.__ninp_); | ||||
|     _VSTD::swap(__einp_, __sb.__einp_); | ||||
|     _VSTD::swap(__bout_, __sb.__bout_); | ||||
|     _VSTD::swap(__nout_, __sb.__nout_); | ||||
|     _VSTD::swap(__eout_, __sb.__eout_); | ||||
|     _STD::swap(__loc_, __sb.__loc_); | ||||
|     _STD::swap(__binp_, __sb.__binp_); | ||||
|     _STD::swap(__ninp_, __sb.__ninp_); | ||||
|     _STD::swap(__einp_, __sb.__einp_); | ||||
|     _STD::swap(__bout_, __sb.__bout_); | ||||
|     _STD::swap(__nout_, __sb.__nout_); | ||||
|     _STD::swap(__eout_, __sb.__eout_); | ||||
| } | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| @@ -461,15 +459,15 @@ basic_streambuf<_CharT, _Traits>::setbuf(char_type*, streamsize) | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| typename basic_streambuf<_CharT, _Traits>::pos_type | ||||
| basic_streambuf<_CharT, _Traits>::seekoff(off_type, ios_base::seekdir, | ||||
|                                           ios_base::openmode) | ||||
| basic_streambuf<_CharT, _Traits>::seekoff(off_type __off, ios_base::seekdir __way, | ||||
|                                           ios_base::openmode __which) | ||||
| { | ||||
|     return pos_type(off_type(-1)); | ||||
| } | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| typename basic_streambuf<_CharT, _Traits>::pos_type | ||||
| basic_streambuf<_CharT, _Traits>::seekpos(pos_type, ios_base::openmode) | ||||
| basic_streambuf<_CharT, _Traits>::seekpos(pos_type __sp, ios_base::openmode __which) | ||||
| { | ||||
|     return pos_type(off_type(-1)); | ||||
| } | ||||
| @@ -540,7 +538,7 @@ basic_streambuf<_CharT, _Traits>::xsputn(const char_type* __s, streamsize __n) | ||||
|     { | ||||
|         if (__nout_ < __eout_) | ||||
|             *__nout_++ = *__s; | ||||
|         else if (overflow(traits_type::to_int_type(*__s)) == __eof) | ||||
|         else if (overflow(*__s) == __eof) | ||||
|             break; | ||||
|     } | ||||
|     return __i; | ||||
| @@ -548,16 +546,16 @@ basic_streambuf<_CharT, _Traits>::xsputn(const char_type* __s, streamsize __n) | ||||
|  | ||||
| template <class _CharT, class _Traits> | ||||
| typename basic_streambuf<_CharT, _Traits>::int_type | ||||
| basic_streambuf<_CharT, _Traits>::overflow(int_type) | ||||
| basic_streambuf<_CharT, _Traits>::overflow(int_type __c) | ||||
| { | ||||
|     return traits_type::eof(); | ||||
| } | ||||
|  | ||||
| _LIBCPP_EXTERN_TEMPLATE(class _LIBCPP_TYPE_VIS basic_streambuf<char>) | ||||
| _LIBCPP_EXTERN_TEMPLATE(class _LIBCPP_TYPE_VIS basic_streambuf<wchar_t>) | ||||
| extern template class basic_streambuf<char>; | ||||
| extern template class basic_streambuf<wchar_t>; | ||||
|  | ||||
| _LIBCPP_EXTERN_TEMPLATE(class _LIBCPP_TYPE_VIS basic_ios<char>) | ||||
| _LIBCPP_EXTERN_TEMPLATE(class _LIBCPP_TYPE_VIS basic_ios<wchar_t>) | ||||
| extern template class basic_ios<char>; | ||||
| extern template class basic_ios<wchar_t>; | ||||
|  | ||||
| _LIBCPP_END_NAMESPACE_STD | ||||
|  | ||||
|   | ||||
							
								
								
									
										2203
									
								
								include/string
									
									
									
									
									
								
							
							
						
						
									
										2203
									
								
								include/string
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -131,13 +131,11 @@ private: | ||||
| #include <ostream> | ||||
| #include <istream> | ||||
|  | ||||
| #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) | ||||
| #pragma GCC system_header | ||||
| #endif | ||||
|  | ||||
| _LIBCPP_BEGIN_NAMESPACE_STD | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS strstreambuf | ||||
| class _LIBCPP_VISIBLE strstreambuf | ||||
|     : public streambuf | ||||
| { | ||||
| public: | ||||
| @@ -152,9 +150,7 @@ public: | ||||
|     strstreambuf(const unsigned char* __gnext, streamsize __n); | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     strstreambuf(strstreambuf&& __rhs); | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     strstreambuf& operator=(strstreambuf&& __rhs); | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
| @@ -191,44 +187,7 @@ private: | ||||
|     void __init(char* __gnext, streamsize __n, char* __pbeg); | ||||
| }; | ||||
|  | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| strstreambuf::strstreambuf(strstreambuf&& __rhs) | ||||
|     : streambuf(__rhs), | ||||
|       __strmode_(__rhs.__strmode_), | ||||
|       __alsize_(__rhs.__alsize_), | ||||
|       __palloc_(__rhs.__palloc_), | ||||
|       __pfree_(__rhs.__pfree_) | ||||
| { | ||||
|     __rhs.setg(nullptr, nullptr, nullptr); | ||||
|     __rhs.setp(nullptr, nullptr); | ||||
| } | ||||
|  | ||||
| inline _LIBCPP_INLINE_VISIBILITY | ||||
| strstreambuf& | ||||
| strstreambuf::operator=(strstreambuf&& __rhs) | ||||
| { | ||||
|     if (eback() && (__strmode_ & __allocated) != 0 && (__strmode_ & __frozen) == 0) | ||||
|     { | ||||
|         if (__pfree_) | ||||
|             __pfree_(eback()); | ||||
|         else | ||||
|             delete [] eback(); | ||||
|     } | ||||
|     streambuf::operator=(__rhs); | ||||
|     __strmode_ = __rhs.__strmode_; | ||||
|     __alsize_ = __rhs.__alsize_; | ||||
|     __palloc_ = __rhs.__palloc_; | ||||
|     __pfree_ = __rhs.__pfree_; | ||||
|     __rhs.setg(nullptr, nullptr, nullptr); | ||||
|     __rhs.setp(nullptr, nullptr); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS istrstream | ||||
| class _LIBCPP_VISIBLE istrstream | ||||
|     : public istream | ||||
| { | ||||
| public: | ||||
| @@ -248,8 +207,8 @@ public: | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     istrstream(istrstream&& __rhs) | ||||
|         : istream(_VSTD::move(__rhs)), | ||||
|           __sb_(_VSTD::move(__rhs.__sb_)) | ||||
|         : istream(_STD::move(__rhs)), | ||||
|           __sb_(_STD::move(__rhs.__sb_)) | ||||
|     { | ||||
|         istream::set_rdbuf(&__sb_); | ||||
|     } | ||||
| @@ -257,8 +216,8 @@ public: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     istrstream& operator=(istrstream&& __rhs) | ||||
|     { | ||||
|         istream::operator=(_VSTD::move(__rhs)); | ||||
|         __sb_ = _VSTD::move(__rhs.__sb_); | ||||
|         istream::operator=(_STD::move(__rhs)); | ||||
|         __sb_ = _STD::move(__rhs.__sb_); | ||||
|         return *this; | ||||
|     } | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| @@ -281,7 +240,7 @@ private: | ||||
|     strstreambuf __sb_; | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS ostrstream | ||||
| class _LIBCPP_VISIBLE ostrstream | ||||
|     : public ostream | ||||
| { | ||||
| public: | ||||
| @@ -297,8 +256,8 @@ public: | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     ostrstream(ostrstream&& __rhs) | ||||
|         : ostream(_VSTD::move(__rhs)), | ||||
|           __sb_(_VSTD::move(__rhs.__sb_)) | ||||
|         : ostream(_STD::move(__rhs)), | ||||
|           __sb_(_STD::move(__rhs.__sb_)) | ||||
|     { | ||||
|         ostream::set_rdbuf(&__sb_); | ||||
|     } | ||||
| @@ -306,8 +265,8 @@ public: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     ostrstream& operator=(ostrstream&& __rhs) | ||||
|     { | ||||
|         ostream::operator=(_VSTD::move(__rhs)); | ||||
|         __sb_ = _VSTD::move(__rhs.__sb_); | ||||
|         ostream::operator=(_STD::move(__rhs)); | ||||
|         __sb_ = _STD::move(__rhs.__sb_); | ||||
|         return *this; | ||||
|     } | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
| @@ -334,7 +293,7 @@ private: | ||||
|     strstreambuf __sb_; // exposition only | ||||
| }; | ||||
|  | ||||
| class _LIBCPP_TYPE_VIS strstream | ||||
| class _LIBCPP_VISIBLE strstream | ||||
|     : public iostream | ||||
| { | ||||
| public: | ||||
| @@ -357,8 +316,8 @@ public: | ||||
| #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     strstream(strstream&& __rhs) | ||||
|         : iostream(_VSTD::move(__rhs)), | ||||
|           __sb_(_VSTD::move(__rhs.__sb_)) | ||||
|         : iostream(_STD::move(__rhs)), | ||||
|           __sb_(_STD::move(__rhs.__sb_)) | ||||
|     { | ||||
|         iostream::set_rdbuf(&__sb_); | ||||
|     } | ||||
| @@ -366,8 +325,8 @@ public: | ||||
|     _LIBCPP_INLINE_VISIBILITY | ||||
|     strstream& operator=(strstream&& __rhs) | ||||
|     { | ||||
|         iostream::operator=(_VSTD::move(__rhs)); | ||||
|         __sb_ = _VSTD::move(__rhs.__sb_); | ||||
|         iostream::operator=(_STD::move(__rhs)); | ||||
|         __sb_ = _STD::move(__rhs.__sb_); | ||||
|         return *this; | ||||
|     } | ||||
| #endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES | ||||
|   | ||||
| @@ -1,99 +0,0 @@ | ||||
| // -*- C++ -*- | ||||
| //===--------------------- support/ibm/limits.h ---------------------------===// | ||||
| // | ||||
| //                     The LLVM Compiler Infrastructure | ||||
| // | ||||
| // This file is dual licensed under the MIT and the University of Illinois Open | ||||
| // Source Licenses. See LICENSE.TXT for details. | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| #ifndef _LIBCPP_SUPPORT_IBM_LIMITS_H | ||||
| #define _LIBCPP_SUPPORT_IBM_LIMITS_H | ||||
|  | ||||
| #if !defined(_AIX) // Linux | ||||
| #include <math.h> // for HUGE_VAL, HUGE_VALF, HUGE_VALL, and NAN | ||||
|  | ||||
| static const unsigned int _QNAN_F = 0x7fc00000; | ||||
| #define NANF (*((float *)(&_QNAN_F))) | ||||
| static const unsigned int _QNAN_LDBL128[4] = {0x7ff80000, 0x0, 0x0, 0x0}; | ||||
| #define NANL (*((long double *)(&_QNAN_LDBL128))) | ||||
| static const unsigned int _SNAN_F= 0x7f855555; | ||||
| #define NANSF (*((float *)(&_SNAN_F))) | ||||
| static const unsigned int _SNAN_D[2] = {0x7ff55555, 0x55555555}; | ||||
| #define NANS (*((double *)(&_SNAN_D))) | ||||
| static const unsigned int _SNAN_LDBL128[4] = {0x7ff55555, 0x55555555, 0x0, 0x0}; | ||||
| #define NANSL (*((long double *)(&_SNAN_LDBL128))) | ||||
|  | ||||
| #define __builtin_huge_val()     HUGE_VAL | ||||
| #define __builtin_huge_valf()    HUGE_VALF | ||||
| #define __builtin_huge_vall()    HUGE_VALL | ||||
| #define __builtin_nan(__dummy)   NAN | ||||
| #define __builtin_nanf(__dummy)  NANF | ||||
| #define __builtin_nanl(__dummy)  NANL | ||||
| #define __builtin_nans(__dummy)  NANS | ||||
| #define __builtin_nansf(__dummy) NANSF | ||||
| #define __builtin_nansl(__dummy) NANSL | ||||
|  | ||||
| #else | ||||
|  | ||||
| #include <math.h> | ||||
| #include <float.h> // limit constants | ||||
|  | ||||
| #define __builtin_huge_val()     HUGE_VAL  //0x7ff0000000000000 | ||||
| #define __builtin_huge_valf()    HUGE_VALF //0x7f800000 | ||||
| #define __builtin_huge_vall()    HUGE_VALL //0x7ff0000000000000 | ||||
| #define __builtin_nan(__dummy)   nan(__dummy) //0x7ff8000000000000 | ||||
| #define __builtin_nanf(__dummy)  nanf(__dummy) // 0x7ff80000 | ||||
| #define __builtin_nanl(__dummy)  nanl(__dummy) //0x7ff8000000000000 | ||||
| #define __builtin_nans(__dummy)  DBL_SNAN //0x7ff5555555555555 | ||||
| #define __builtin_nansf(__dummy) FLT_SNAN //0x7f855555 | ||||
| #define __builtin_nansl(__dummy) DBL_SNAN //0x7ff5555555555555 | ||||
|  | ||||
| #define __FLT_MANT_DIG__   FLT_MANT_DIG | ||||
| #define __FLT_DIG__        FLT_DIG | ||||
| #define __FLT_RADIX__      FLT_RADIX | ||||
| #define __FLT_MIN_EXP__    FLT_MIN_EXP | ||||
| #define __FLT_MIN_10_EXP__ FLT_MIN_10_EXP | ||||
| #define __FLT_MAX_EXP__    FLT_MAX_EXP | ||||
| #define __FLT_MAX_10_EXP__ FLT_MAX_10_EXP | ||||
| #define __FLT_MIN__        FLT_MIN | ||||
| #define __FLT_MAX__        FLT_MAX | ||||
| #define __FLT_EPSILON__    FLT_EPSILON | ||||
| // predefined by XLC on LoP | ||||
| #define __FLT_DENORM_MIN__ 1.40129846e-45F | ||||
|  | ||||
| #define __DBL_MANT_DIG__   DBL_MANT_DIG | ||||
| #define __DBL_DIG__        DBL_DIG | ||||
| #define __DBL_MIN_EXP__    DBL_MIN_EXP | ||||
| #define __DBL_MIN_10_EXP__ DBL_MIN_10_EXP | ||||
| #define __DBL_MAX_EXP__    DBL_MAX_EXP | ||||
| #define __DBL_MAX_10_EXP__ DBL_MAX_10_EXP | ||||
| #define __DBL_MIN__        DBL_MIN | ||||
| #define __DBL_MAX__        DBL_MAX | ||||
| #define __DBL_EPSILON__    DBL_EPSILON | ||||
| // predefined by XLC on LoP | ||||
| #define __DBL_DENORM_MIN__ 4.9406564584124654e-324 | ||||
|  | ||||
| #define __LDBL_MANT_DIG__   LDBL_MANT_DIG | ||||
| #define __LDBL_DIG__        LDBL_DIG | ||||
| #define __LDBL_MIN_EXP__    LDBL_MIN_EXP | ||||
| #define __LDBL_MIN_10_EXP__ LDBL_MIN_10_EXP | ||||
| #define __LDBL_MAX_EXP__    LDBL_MAX_EXP | ||||
| #define __LDBL_MAX_10_EXP__ LDBL_MAX_10_EXP | ||||
| #define __LDBL_MIN__        LDBL_MIN | ||||
| #define __LDBL_MAX__        LDBL_MAX | ||||
| #define __LDBL_EPSILON__    LDBL_EPSILON | ||||
| // predefined by XLC on LoP | ||||
| #if __LONGDOUBLE128 | ||||
| #define __LDBL_DENORM_MIN__ 4.94065645841246544176568792868221e-324L | ||||
| #else | ||||
| #define __LDBL_DENORM_MIN__ 4.9406564584124654e-324L | ||||
| #endif | ||||
|  | ||||
| // predefined by XLC on LoP | ||||
| #define __CHAR_BIT__    8 | ||||
|  | ||||
| #endif // _AIX | ||||
|  | ||||
| #endif // _LIBCPP_SUPPORT_IBM_LIMITS_H | ||||
| @@ -1,54 +0,0 @@ | ||||
| // -*- C++ -*- | ||||
| //===----------------------- support/ibm/support.h ----------------------===// | ||||
| // | ||||
| //                     The LLVM Compiler Infrastructure | ||||
| // | ||||
| // This file is dual licensed under the MIT and the University of Illinois Open | ||||
| // Source Licenses. See LICENSE.TXT for details. | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| #ifndef _LIBCPP_SUPPORT_IBM_SUPPORT_H | ||||
| #define _LIBCPP_SUPPORT_IBM_SUPPORT_H | ||||
|  | ||||
| extern "builtin" int __popcnt4(unsigned int); | ||||
| extern "builtin" int __popcnt8(unsigned long long); | ||||
| extern "builtin" unsigned int __cnttz4(unsigned int); | ||||
| extern "builtin" unsigned int __cnttz8(unsigned long long); | ||||
| extern "builtin" unsigned int __cntlz4(unsigned long long); | ||||
| extern "builtin" unsigned int __cntlz8(unsigned long long); | ||||
|  | ||||
| // Builtin functions for counting population | ||||
| #define __builtin_popcount(x) __popcnt4(x) | ||||
| #define __builtin_popcountll(x) __popcnt8(x) | ||||
| #if defined(__64BIT__) | ||||
| #define __builtin_popcountl(x) __builtin_popcountll(x) | ||||
| #else | ||||
| #define __builtin_popcountl(x) __builtin_popcount(x) | ||||
| #endif | ||||
|  | ||||
| // Builtin functions for counting trailing zeros | ||||
| #define __builtin_ctz(x) __cnttz4(x) | ||||
| #define __builtin_ctzll(x) __cnttz8(x) | ||||
| #if defined(__64BIT__) | ||||
| #define __builtin_ctzl(x) __builtin_ctzll(x) | ||||
| #else | ||||
| #define __builtin_ctzl(x) __builtin_ctz(x) | ||||
| #endif | ||||
|  | ||||
| // Builtin functions for counting leading zeros | ||||
| #define __builtin_clz(x) __cntlz4(x) | ||||
| #define __builtin_clzll(x) __cntlz8(x) | ||||
| #if defined(__64BIT__) | ||||
| #define __builtin_clzl(x) __builtin_clzll(x) | ||||
| #else | ||||
| #define __builtin_clzl(x) __builtin_clz(x) | ||||
| #endif | ||||
|  | ||||
| #if defined(__64BIT__) | ||||
| #define __SIZE_WIDTH__ 64 | ||||
| #else | ||||
| #define __SIZE_WIDTH__ 32 | ||||
| #endif | ||||
|  | ||||
| #endif // _LIBCPP_SUPPORT_IBM_SUPPORT_H | ||||
| @@ -1,326 +0,0 @@ | ||||
| // -*- C++ -*- | ||||
| //===--------------------- support/ibm/xlocale.h -------------------===// | ||||
| // | ||||
| //                     The LLVM Compiler Infrastructure | ||||
| // | ||||
| // This file is dual licensed under the MIT and the University of Illinois Open | ||||
| // Source Licenses. See LICENSE.TXT for details. | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| #ifndef _LIBCPP_SUPPORT_IBM_XLOCALE_H | ||||
| #define _LIBCPP_SUPPORT_IBM_XLOCALE_H | ||||
|  | ||||
| #if defined(_AIX) | ||||
| #include "cstdlib" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| #if !defined(_AIX71) | ||||
| // AIX 7.1 and higher has these definitions.  Definitions and stubs | ||||
| // are provied here as a temporary workaround on AIX 6.1. | ||||
|  | ||||
| #define LC_COLLATE_MASK         1 | ||||
| #define LC_CTYPE_MASK           2 | ||||
| #define LC_MESSAGES_MASK        4 | ||||
| #define LC_MONETARY_MASK        8 | ||||
| #define LC_NUMERIC_MASK         16 | ||||
| #define LC_TIME_MASK            32 | ||||
| #define LC_ALL_MASK             (LC_COLLATE_MASK | LC_CTYPE_MASK | \ | ||||
|                                  LC_MESSAGES_MASK | LC_MONETARY_MASK |\ | ||||
|                                  LC_NUMERIC_MASK | LC_TIME_MASK) | ||||
|  | ||||
| typedef void* locale_t; | ||||
|  | ||||
| // The following are stubs.  They are not supported on AIX 6.1. | ||||
| static inline | ||||
| locale_t newlocale(int category_mask, const char *locale, locale_t base) | ||||
| { | ||||
|   _LC_locale_t *newloc, *loc; | ||||
|   if ((loc = (_LC_locale_t *)__xopen_locale(locale)) == NULL) | ||||
|   { | ||||
|     errno = EINVAL; | ||||
|     return (locale_t)0; | ||||
|   } | ||||
|   if ((newloc = (_LC_locale_t *)calloc(1, sizeof(_LC_locale_t))) == NULL) | ||||
|   { | ||||
|     errno = ENOMEM; | ||||
|     return (locale_t)0; | ||||
|   } | ||||
|   if (!base) | ||||
|     base = (_LC_locale_t *)__xopen_locale("C"); | ||||
|   memcpy(newloc, base, sizeof (_LC_locale_t)); | ||||
|   if (category_mask & LC_COLLATE_MASK)  | ||||
|     newloc->lc_collate = loc->lc_collate; | ||||
|   if (category_mask & LC_CTYPE_MASK) | ||||
|     newloc->lc_ctype = loc->lc_ctype; | ||||
|   //if (category_mask & LC_MESSAGES_MASK) | ||||
|   //  newloc->lc_messages = loc->lc_messages; | ||||
|   if (category_mask & LC_MONETARY_MASK) | ||||
|     newloc->lc_monetary = loc->lc_monetary; | ||||
|   if (category_mask & LC_TIME_MASK) | ||||
|     newloc->lc_time = loc->lc_time; | ||||
|   if (category_mask & LC_NUMERIC_MASK) | ||||
|     newloc->lc_numeric = loc->lc_numeric; | ||||
|   return (locale_t)newloc;  | ||||
| } | ||||
| static inline | ||||
| void freelocale(locale_t locobj) | ||||
| { | ||||
|   free(locobj); | ||||
| } | ||||
| static inline | ||||
| locale_t uselocale(locale_t newloc) | ||||
| { | ||||
|   return (locale_t)0; | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int isalnum_l(int c, locale_t locale) | ||||
| { | ||||
|   return __xisalnum(locale, c); | ||||
| } | ||||
| static inline | ||||
| int isalpha_l(int c, locale_t locale) | ||||
| { | ||||
|   return __xisalpha(locale, c); | ||||
| } | ||||
| static inline | ||||
| int isblank_l(int c, locale_t locale) | ||||
| { | ||||
|   return __xisblank(locale, c); | ||||
| } | ||||
| static inline | ||||
| int iscntrl_l(int c, locale_t locale) | ||||
| { | ||||
|   return __xiscntrl(locale, c); | ||||
| } | ||||
| static inline | ||||
| int isdigit_l(int c, locale_t locale) | ||||
| { | ||||
|   return __xisdigit(locale, c); | ||||
| } | ||||
| static inline | ||||
| int isgraph_l(int c, locale_t locale) | ||||
| { | ||||
|   return __xisgraph(locale, c); | ||||
| } | ||||
| static inline | ||||
| int islower_l(int c, locale_t locale) | ||||
| { | ||||
|   return __xislower(locale, c); | ||||
| } | ||||
| static inline | ||||
| int isprint_l(int c, locale_t locale) | ||||
| { | ||||
|   return __xisprint(locale, c); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int ispunct_l(int c, locale_t locale) | ||||
| { | ||||
|   return __xispunct(locale, c); | ||||
| } | ||||
| static inline | ||||
| int isspace_l(int c, locale_t locale) | ||||
| { | ||||
|   return __xisspace(locale, c); | ||||
| } | ||||
| static inline | ||||
| int isupper_l(int c, locale_t locale) | ||||
| { | ||||
|   return __xisupper(locale, c); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int isxdigit_l(int c, locale_t locale) | ||||
| { | ||||
|   return __xisxdigit(locale, c); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int iswalnum_l(wchar_t wc, locale_t locale) | ||||
| { | ||||
|   return __xiswalnum(locale, wc);  | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int iswalpha_l(wchar_t wc, locale_t locale) | ||||
| { | ||||
|   return __xiswalpha(locale, wc); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int iswblank_l(wchar_t wc, locale_t locale) | ||||
| { | ||||
|   return __xiswblank(locale, wc); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int iswcntrl_l(wchar_t wc, locale_t locale) | ||||
| { | ||||
|   return __xiswcntrl(locale, wc); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int iswdigit_l(wchar_t wc, locale_t locale) | ||||
| { | ||||
|   return __xiswdigit(locale, wc); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int iswgraph_l(wchar_t wc, locale_t locale) | ||||
| { | ||||
|   return __xiswgraph(locale, wc); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int iswlower_l(wchar_t wc, locale_t locale) | ||||
| { | ||||
|   return __xiswlower(locale, wc); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int iswprint_l(wchar_t wc, locale_t locale) | ||||
| { | ||||
|   return __xiswprint(locale, wc); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int iswpunct_l(wchar_t wc, locale_t locale) | ||||
| { | ||||
|   return __xiswpunct(locale, wc); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int iswspace_l(wchar_t wc, locale_t locale) | ||||
| { | ||||
|   return __xiswspace(locale, wc); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int iswupper_l(wchar_t wc, locale_t locale) | ||||
| { | ||||
|   return __xiswupper(locale, wc); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int iswxdigit_l(wchar_t wc, locale_t locale) | ||||
| { | ||||
|   return __xiswxdigit(locale, wc); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int iswctype_l(wint_t wc, wctype_t desc, locale_t locale) | ||||
| { | ||||
|   return __xiswctype(locale, wc, desc);  | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int toupper_l(int c, locale_t locale) | ||||
| { | ||||
|   return __xtoupper(locale, c); | ||||
| } | ||||
| static inline | ||||
| int tolower_l(int c, locale_t locale) | ||||
| { | ||||
|   return __xtolower(locale, c); | ||||
| } | ||||
| static inline | ||||
| wint_t towupper_l(wint_t wc, locale_t locale) | ||||
| { | ||||
|   return __xtowupper(locale, wc); | ||||
| } | ||||
| static inline | ||||
| wint_t towlower_l(wint_t wc, locale_t locale) | ||||
| { | ||||
|   return __xtowlower(locale, wc); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int strcoll_l(const char *__s1, const char *__s2, locale_t locale) | ||||
| { | ||||
|   return __xstrcoll(locale, __s1, __s2); | ||||
| } | ||||
| static inline | ||||
| int wcscoll_l(const wchar_t *__s1, const wchar_t *__s2, locale_t locale) | ||||
| { | ||||
|   return __xwcscoll(locale, __s1, __s2); | ||||
| } | ||||
| static inline | ||||
| size_t strxfrm_l(char *__s1, const char *__s2, size_t __n, locale_t locale) | ||||
| { | ||||
|   return __xstrxfrm(locale, __s1, __s2, __n); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| size_t wcsxfrm_l(wchar_t *__ws1, const wchar_t *__ws2, size_t __n, | ||||
|     locale_t locale) | ||||
| { | ||||
|   return __xwcsxfrm(locale, __ws1, __ws2, __n); | ||||
| } | ||||
| #endif // !defined(_AIX71) | ||||
|  | ||||
| // strftime_l() is defined by POSIX. However, AIX 7.1 does not have it | ||||
| // implemented yet. | ||||
| static inline | ||||
| size_t strftime_l(char *__s, size_t __size, const char *__fmt, | ||||
|                   const struct tm *__tm, locale_t locale) { | ||||
|   return __xstrftime(locale, __s, __size, __fmt, __tm); | ||||
| } | ||||
|  | ||||
| // The following are not POSIX routines.  These are quick-and-dirty hacks | ||||
| // to make things pretend to work | ||||
| static inline | ||||
| long long strtoll_l(const char *__nptr, char **__endptr, | ||||
|     int __base, locale_t locale) { | ||||
|   return strtoll(__nptr, __endptr, __base); | ||||
| } | ||||
| static inline | ||||
| long strtol_l(const char *__nptr, char **__endptr, | ||||
|     int __base, locale_t locale) { | ||||
|   return strtol(__nptr, __endptr, __base); | ||||
| } | ||||
| static inline | ||||
| long double strtold_l(const char *__nptr, char **__endptr, | ||||
|     locale_t locale) { | ||||
|   return strtold(__nptr, __endptr); | ||||
| } | ||||
| static inline | ||||
| unsigned long long strtoull_l(const char *__nptr, char **__endptr, | ||||
|     int __base, locale_t locale) { | ||||
|   return strtoull(__nptr, __endptr, __base); | ||||
| } | ||||
| static inline | ||||
| unsigned long strtoul_l(const char *__nptr, char **__endptr, | ||||
|     int __base, locale_t locale) { | ||||
|   return strtoul(__nptr, __endptr, __base); | ||||
| } | ||||
|  | ||||
| static inline | ||||
| int vasprintf(char **strp, const char *fmt, va_list ap) | ||||
| { | ||||
|   const size_t buff_size = 256; | ||||
|   int str_size; | ||||
|   if ((*strp = (char *)malloc(buff_size)) == NULL) | ||||
|   { | ||||
|     return -1; | ||||
|   } | ||||
|   if ((str_size = vsnprintf(*strp, buff_size, fmt,  ap)) >= buff_size) | ||||
|   { | ||||
|     if ((*strp = (char *)realloc(*strp, str_size + 1)) == NULL) | ||||
|     { | ||||
|       return -1; | ||||
|     } | ||||
|     str_size = vsnprintf(*strp, str_size + 1, fmt,  ap); | ||||
|   } | ||||
|   return str_size; | ||||
| }   | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| #endif // defined(_AIX) | ||||
| #endif // _LIBCPP_SUPPORT_IBM_XLOCALE_H | ||||
| @@ -1,5 +0,0 @@ | ||||
| #define atof sun_atof | ||||
| #define strtod sun_strtod | ||||
| #include_next "floatingpoint.h" | ||||
| #undef atof | ||||
| #undef strtod | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user