golden hour
/usr/include/c++/4.8.2/bits
⬆️ Go Up
Upload
File/Folder
Size
Actions
algorithmfwd.h
20.66 KB
Del
OK
alloc_traits.h
17.66 KB
Del
OK
allocator.h
6.1 KB
Del
OK
atomic_base.h
24.99 KB
Del
OK
atomic_lockfree_defines.h
2.2 KB
Del
OK
basic_ios.h
14.76 KB
Del
OK
basic_ios.tcc
5.89 KB
Del
OK
basic_string.h
109.49 KB
Del
OK
basic_string.tcc
38.43 KB
Del
OK
boost_concept_check.h
26.41 KB
Del
OK
c++0x_warning.h
1.47 KB
Del
OK
char_traits.h
16.95 KB
Del
OK
codecvt.h
16.23 KB
Del
OK
concept_check.h
3.26 KB
Del
OK
cpp_type_traits.h
9.56 KB
Del
OK
cxxabi_forced.h
1.77 KB
Del
OK
deque.tcc
31.91 KB
Del
OK
exception_defines.h
1.6 KB
Del
OK
exception_ptr.h
5.29 KB
Del
OK
forward_list.h
46.72 KB
Del
OK
forward_list.tcc
15.17 KB
Del
OK
fstream.tcc
28.3 KB
Del
OK
functexcept.h
3.04 KB
Del
OK
functional_hash.h
6.05 KB
Del
OK
gslice.h
5.39 KB
Del
OK
gslice_array.h
7.59 KB
Del
OK
hash_bytes.h
2.1 KB
Del
OK
hashtable.h
61.05 KB
Del
OK
hashtable_policy.h
52.72 KB
Del
OK
indirect_array.h
7.68 KB
Del
OK
ios_base.h
27.85 KB
Del
OK
istream.tcc
30.36 KB
Del
OK
list.tcc
12.2 KB
Del
OK
locale_classes.h
22.45 KB
Del
OK
locale_classes.tcc
8.18 KB
Del
OK
locale_facets.h
88.84 KB
Del
OK
locale_facets.tcc
38.02 KB
Del
OK
locale_facets_nonio.h
63.51 KB
Del
OK
locale_facets_nonio.tcc
40.85 KB
Del
OK
localefwd.h
5.1 KB
Del
OK
mask_array.h
7.41 KB
Del
OK
memoryfwd.h
2.36 KB
Del
OK
move.h
5.67 KB
Del
OK
nested_exception.h
4.58 KB
Del
OK
ostream.tcc
12.03 KB
Del
OK
ostream_insert.h
3.91 KB
Del
OK
postypes.h
8.02 KB
Del
OK
ptr_traits.h
5.17 KB
Del
OK
random.h
173.19 KB
Del
OK
random.tcc
106.59 KB
Del
OK
range_access.h
3.06 KB
Del
OK
regex.h
83.49 KB
Del
OK
regex_compiler.h
27.68 KB
Del
OK
regex_constants.h
10.81 KB
Del
OK
regex_cursor.h
2.7 KB
Del
OK
regex_error.h
4.5 KB
Del
OK
regex_grep_matcher.h
4.23 KB
Del
OK
regex_grep_matcher.tcc
5.41 KB
Del
OK
regex_nfa.h
10.65 KB
Del
OK
regex_nfa.tcc
4.85 KB
Del
OK
shared_ptr.h
18.97 KB
Del
OK
shared_ptr_base.h
40.65 KB
Del
OK
slice_array.h
9.12 KB
Del
OK
sstream.tcc
9.27 KB
Del
OK
stl_algo.h
212.55 KB
Del
OK
stl_algobase.h
41.41 KB
Del
OK
stl_bvector.h
28.98 KB
Del
OK
stl_construct.h
5.05 KB
Del
OK
stl_deque.h
66.41 KB
Del
OK
stl_function.h
22.06 KB
Del
OK
stl_heap.h
19.99 KB
Del
OK
stl_iterator.h
35.77 KB
Del
OK
stl_iterator_base_funcs.h
6.8 KB
Del
OK
stl_iterator_base_types.h
8.19 KB
Del
OK
stl_list.h
52.83 KB
Del
OK
stl_map.h
36.78 KB
Del
OK
stl_multimap.h
33.94 KB
Del
OK
stl_multiset.h
28.37 KB
Del
OK
stl_numeric.h
13.5 KB
Del
OK
stl_pair.h
9.63 KB
Del
OK
stl_queue.h
18.21 KB
Del
OK
stl_raw_storage_iter.h
3.37 KB
Del
OK
stl_relops.h
4.49 KB
Del
OK
stl_set.h
28.61 KB
Del
OK
stl_stack.h
9.65 KB
Del
OK
stl_tempbuf.h
8.15 KB
Del
OK
stl_tree.h
53.56 KB
Del
OK
stl_uninitialized.h
19.95 KB
Del
OK
stl_vector.h
48.64 KB
Del
OK
stream_iterator.h
6.44 KB
Del
OK
streambuf.tcc
4.81 KB
Del
OK
streambuf_iterator.h
12.33 KB
Del
OK
stringfwd.h
2.37 KB
Del
OK
unique_ptr.h
17.19 KB
Del
OK
unordered_map.h
47.76 KB
Del
OK
unordered_set.h
43.25 KB
Del
OK
uses_allocator.h
3.49 KB
Del
OK
valarray_after.h
22.12 KB
Del
OK
valarray_array.h
21.23 KB
Del
OK
valarray_array.tcc
7.08 KB
Del
OK
valarray_before.h
18.08 KB
Del
OK
vector.tcc
25.55 KB
Del
OK
Edit: stl_tempbuf.h
// Temporary buffer implementation -*- C++ -*- // Copyright (C) 2001-2013 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/>. /* * * Copyright (c) 1994 * Hewlett-Packard Company * * Permission to use, copy, modify, distribute and sell this software * and its documentation for any purpose is hereby granted without fee, * provided that the above copyright notice appear in all copies and * that both that copyright notice and this permission notice appear * in supporting documentation. Hewlett-Packard Company makes no * representations about the suitability of this software for any * purpose. It is provided "as is" without express or implied warranty. * * * Copyright (c) 1996,1997 * Silicon Graphics Computer Systems, Inc. * * Permission to use, copy, modify, distribute and sell this software * and its documentation for any purpose is hereby granted without fee, * provided that the above copyright notice appear in all copies and * that both that copyright notice and this permission notice appear * in supporting documentation. Silicon Graphics makes no * representations about the suitability of this software for any * purpose. It is provided "as is" without express or implied warranty. */ /** @file bits/stl_tempbuf.h * This is an internal header file, included by other library headers. * Do not attempt to use it directly. @headername{memory} */ #ifndef _STL_TEMPBUF_H #define _STL_TEMPBUF_H 1 #include <bits/stl_algobase.h> #include <bits/stl_construct.h> namespace std _GLIBCXX_VISIBILITY(default) { _GLIBCXX_BEGIN_NAMESPACE_VERSION /** * @brief Allocates a temporary buffer. * @param __len The number of objects of type Tp. * @return See full description. * * Reinventing the wheel, but this time with prettier spokes! * * This function tries to obtain storage for @c __len adjacent Tp * objects. The objects themselves are not constructed, of course. * A pair<> is returned containing <em>the buffer s address and * capacity (in the units of sizeof(_Tp)), or a pair of 0 values if * no storage can be obtained.</em> Note that the capacity obtained * may be less than that requested if the memory is unavailable; * you should compare len with the .second return value. * * Provides the nothrow exception guarantee. */ template<typename _Tp> pair<_Tp*, ptrdiff_t> get_temporary_buffer(ptrdiff_t __len) _GLIBCXX_NOEXCEPT { const ptrdiff_t __max = __gnu_cxx::__numeric_traits<ptrdiff_t>::__max / sizeof(_Tp); if (__len > __max) __len = __max; while (__len > 0) { _Tp* __tmp = static_cast<_Tp*>(::operator new(__len * sizeof(_Tp), std::nothrow)); if (__tmp != 0) return std::pair<_Tp*, ptrdiff_t>(__tmp, __len); __len /= 2; } return std::pair<_Tp*, ptrdiff_t>(static_cast<_Tp*>(0), 0); } /** * @brief The companion to get_temporary_buffer(). * @param __p A buffer previously allocated by get_temporary_buffer. * @return None. * * Frees the memory pointed to by __p. */ template<typename _Tp> inline void return_temporary_buffer(_Tp* __p) { ::operator delete(__p, std::nothrow); } /** * This class is used in two places: stl_algo.h and ext/memory, * where it is wrapped as the temporary_buffer class. See * temporary_buffer docs for more notes. */ template<typename _ForwardIterator, typename _Tp> class _Temporary_buffer { // concept requirements __glibcxx_class_requires(_ForwardIterator, _ForwardIteratorConcept) public: typedef _Tp value_type; typedef value_type* pointer; typedef pointer iterator; typedef ptrdiff_t size_type; protected: size_type _M_original_len; size_type _M_len; pointer _M_buffer; public: /// As per Table mumble. size_type size() const { return _M_len; } /// Returns the size requested by the constructor; may be >size(). size_type requested_size() const { return _M_original_len; } /// As per Table mumble. iterator begin() { return _M_buffer; } /// As per Table mumble. iterator end() { return _M_buffer + _M_len; } /** * Constructs a temporary buffer of a size somewhere between * zero and the size of the given range. */ _Temporary_buffer(_ForwardIterator __first, _ForwardIterator __last); ~_Temporary_buffer() { std::_Destroy(_M_buffer, _M_buffer + _M_len); std::return_temporary_buffer(_M_buffer); } private: // Disable copy constructor and assignment operator. _Temporary_buffer(const _Temporary_buffer&); void operator=(const _Temporary_buffer&); }; template<bool> struct __uninitialized_construct_buf_dispatch { template<typename _Pointer, typename _ForwardIterator> static void __ucr(_Pointer __first, _Pointer __last, _ForwardIterator __seed) { if(__first == __last) return; _Pointer __cur = __first; __try { std::_Construct(std::__addressof(*__first), _GLIBCXX_MOVE(*__seed)); _Pointer __prev = __cur; ++__cur; for(; __cur != __last; ++__cur, ++__prev) std::_Construct(std::__addressof(*__cur), _GLIBCXX_MOVE(*__prev)); *__seed = _GLIBCXX_MOVE(*__prev); } __catch(...) { std::_Destroy(__first, __cur); __throw_exception_again; } } }; template<> struct __uninitialized_construct_buf_dispatch<true> { template<typename _Pointer, typename _ForwardIterator> static void __ucr(_Pointer, _Pointer, _ForwardIterator) { } }; // Constructs objects in the range [first, last). // Note that while these new objects will take valid values, // their exact value is not defined. In particular they may // be 'moved from'. // // While *__seed may be altered during this algorithm, it will have // the same value when the algorithm finishes, unless one of the // constructions throws. // // Requirements: _Pointer::value_type(_Tp&&) is valid. template<typename _Pointer, typename _ForwardIterator> inline void __uninitialized_construct_buf(_Pointer __first, _Pointer __last, _ForwardIterator __seed) { typedef typename std::iterator_traits<_Pointer>::value_type _ValueType; std::__uninitialized_construct_buf_dispatch< __has_trivial_constructor(_ValueType)>:: __ucr(__first, __last, __seed); } template<typename _ForwardIterator, typename _Tp> _Temporary_buffer<_ForwardIterator, _Tp>:: _Temporary_buffer(_ForwardIterator __first, _ForwardIterator __last) : _M_original_len(std::distance(__first, __last)), _M_len(0), _M_buffer(0) { __try { std::pair<pointer, size_type> __p(std::get_temporary_buffer< value_type>(_M_original_len)); _M_buffer = __p.first; _M_len = __p.second; if (_M_buffer) std::__uninitialized_construct_buf(_M_buffer, _M_buffer + _M_len, __first); } __catch(...) { std::return_temporary_buffer(_M_buffer); _M_buffer = 0; _M_len = 0; __throw_exception_again; } } _GLIBCXX_END_NAMESPACE_VERSION } // namespace #endif /* _STL_TEMPBUF_H */
Save