X7ROOT File Manager
Current Path:
/usr/include/c++/8/ext
usr
/
include
/
c++
/
8
/
ext
/
ðŸ“
..
📄
algorithm
(18.84 KB)
📄
aligned_buffer.h
(3.88 KB)
📄
alloc_traits.h
(5.57 KB)
📄
array_allocator.h
(5.26 KB)
📄
atomicity.h
(3.43 KB)
📄
bitmap_allocator.h
(31.08 KB)
📄
cast.h
(4.34 KB)
📄
cmath
(6.42 KB)
📄
codecvt_specializations.h
(15.97 KB)
📄
concurrence.h
(7.43 KB)
📄
debug_allocator.h
(5.58 KB)
📄
enc_filebuf.h
(2.19 KB)
📄
extptr_allocator.h
(6.04 KB)
📄
functional
(13.96 KB)
📄
hash_map
(17.36 KB)
📄
hash_set
(16.79 KB)
📄
iterator
(3.94 KB)
📄
malloc_allocator.h
(4.97 KB)
📄
memory
(6.99 KB)
📄
mt_allocator.h
(22.96 KB)
📄
new_allocator.h
(4.69 KB)
📄
numeric
(4.62 KB)
📄
numeric_traits.h
(4.47 KB)
ðŸ“
pb_ds
📄
pod_char_traits.h
(5.43 KB)
📄
pointer.h
(19.36 KB)
📄
pool_allocator.h
(8.61 KB)
📄
random
(108.78 KB)
📄
random.tcc
(58.83 KB)
📄
rb_tree
(3.23 KB)
📄
rc_string_base.h
(23.18 KB)
📄
rope
(85.58 KB)
📄
ropeimpl.h
(47.3 KB)
📄
slist
(28.91 KB)
📄
sso_string_base.h
(15.93 KB)
📄
stdio_filebuf.h
(5.54 KB)
📄
stdio_sync_filebuf.h
(8.58 KB)
📄
string_conversions.h
(3.51 KB)
📄
throw_allocator.h
(23.96 KB)
📄
type_traits.h
(5.78 KB)
📄
typelist.h
(16.09 KB)
📄
vstring.h
(107.98 KB)
📄
vstring.tcc
(23.06 KB)
📄
vstring_fwd.h
(3.15 KB)
📄
vstring_util.h
(5.63 KB)
Editing: aligned_buffer.h
// Aligned memory buffer -*- C++ -*- // Copyright (C) 2013-2018 Free Software Foundation, Inc. // // This file is part of the GNU ISO C++ Library. This library is free // software; you can redistribute it and/or modify it under the // terms of the GNU General Public License as published by the // Free Software Foundation; either version 3, or (at your option) // any later version. // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // Under Section 7 of GPL version 3, you are granted additional // permissions described in the GCC Runtime Library Exception, version // 3.1, as published by the Free Software Foundation. // You should have received a copy of the GNU General Public License and // a copy of the GCC Runtime Library Exception along with this program; // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see // <http://www.gnu.org/licenses/>. /** @file ext/aligned_buffer.h * This file is a GNU extension to the Standard C++ Library. */ #ifndef _ALIGNED_BUFFER_H #define _ALIGNED_BUFFER_H 1 #pragma GCC system_header #if __cplusplus >= 201103L # include <type_traits> #else # include <bits/c++0x_warning.h> #endif namespace __gnu_cxx { // A utility type containing a POD object that can hold an object of type // _Tp initialized via placement new or allocator_traits::construct. // Intended for use as a data member subobject, use __aligned_buffer for // complete objects. template<typename _Tp> struct __aligned_membuf { // Target macro ADJUST_FIELD_ALIGN can produce different alignment for // types when used as class members. __aligned_membuf is intended // for use as a class member, so align the buffer as for a class member. // Since GCC 8 we could just use alignof(_Tp) instead, but older // versions of non-GNU compilers might still need this trick. struct _Tp2 { _Tp _M_t; }; alignas(__alignof__(_Tp2::_M_t)) unsigned char _M_storage[sizeof(_Tp)]; __aligned_membuf() = default; // Can be used to avoid value-initialization zeroing _M_storage. __aligned_membuf(std::nullptr_t) { } void* _M_addr() noexcept { return static_cast<void*>(&_M_storage); } const void* _M_addr() const noexcept { return static_cast<const void*>(&_M_storage); } _Tp* _M_ptr() noexcept { return static_cast<_Tp*>(_M_addr()); } const _Tp* _M_ptr() const noexcept { return static_cast<const _Tp*>(_M_addr()); } }; #if _GLIBCXX_INLINE_VERSION template<typename _Tp> using __aligned_buffer = __aligned_membuf<_Tp>; #else // Similar to __aligned_membuf but aligned for complete objects, not members. // This type is used in <forward_list>, <future>, <bits/shared_ptr_base.h> // and <bits/hashtable_policy.h>, but ideally they would use __aligned_membuf // instead, as it has smaller size for some types on some targets. // This type is still used to avoid an ABI change. template<typename _Tp> struct __aligned_buffer : std::aligned_storage<sizeof(_Tp), __alignof__(_Tp)> { typename std::aligned_storage<sizeof(_Tp), __alignof__(_Tp)>::type _M_storage; __aligned_buffer() = default; // Can be used to avoid value-initialization __aligned_buffer(std::nullptr_t) { } void* _M_addr() noexcept { return static_cast<void*>(&_M_storage); } const void* _M_addr() const noexcept { return static_cast<const void*>(&_M_storage); } _Tp* _M_ptr() noexcept { return static_cast<_Tp*>(_M_addr()); } const _Tp* _M_ptr() const noexcept { return static_cast<const _Tp*>(_M_addr()); } }; #endif } // namespace #endif /* _ALIGNED_BUFFER_H */
Upload File
Create Folder