PATH:
usr
/
include
/
c++
/
4.8.2
/
bits
// The template and inlines for the -*- C++ -*- gslice class. // Copyright (C) 1997-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/>. /** @file bits/gslice.h * This is an internal header file, included by other library headers. * Do not attempt to use it directly. @headername{valarray} */ // Written by Gabriel Dos Reis <Gabriel.Dos-Reis@DPTMaths.ENS-Cachan.Fr> #ifndef _GSLICE_H #define _GSLICE_H 1 #pragma GCC system_header namespace std _GLIBCXX_VISIBILITY(default) { _GLIBCXX_BEGIN_NAMESPACE_VERSION /** * @addtogroup numeric_arrays * @{ */ /** * @brief Class defining multi-dimensional subset of an array. * * The slice class represents a multi-dimensional subset of an array, * specified by three parameter sets: start offset, size array, and stride * array. The start offset is the index of the first element of the array * that is part of the subset. The size and stride array describe each * dimension of the slice. Size is the number of elements in that * dimension, and stride is the distance in the array between successive * elements in that dimension. Each dimension's size and stride is taken * to begin at an array element described by the previous dimension. The * size array and stride array must be the same size. * * For example, if you have offset==3, stride[0]==11, size[1]==3, * stride[1]==3, then slice[0,0]==array[3], slice[0,1]==array[6], * slice[0,2]==array[9], slice[1,0]==array[14], slice[1,1]==array[17], * slice[1,2]==array[20]. */ class gslice { public: /// Construct an empty slice. gslice(); /** * @brief Construct a slice. * * Constructs a slice with as many dimensions as the length of the @a l * and @a s arrays. * * @param __o Offset in array of first element. * @param __l Array of dimension lengths. * @param __s Array of dimension strides between array elements. */ gslice(size_t __o, const valarray<size_t>& __l, const valarray<size_t>& __s); // XXX: the IS says the copy-ctor and copy-assignment operators are // synthesized by the compiler but they are just unsuitable // for a ref-counted semantic /// Copy constructor. gslice(const gslice&); /// Destructor. ~gslice(); // XXX: See the note above. /// Assignment operator. gslice& operator=(const gslice&); /// Return array offset of first slice element. size_t start() const; /// Return array of sizes of slice dimensions. valarray<size_t> size() const; /// Return array of array strides for each dimension. valarray<size_t> stride() const; private: struct _Indexer { size_t _M_count; size_t _M_start; valarray<size_t> _M_size; valarray<size_t> _M_stride; valarray<size_t> _M_index; // Linear array of referenced indices _Indexer() : _M_count(1), _M_start(0), _M_size(), _M_stride(), _M_index() {} _Indexer(size_t, const valarray<size_t>&, const valarray<size_t>&); void _M_increment_use() { ++_M_count; } size_t _M_decrement_use() { return --_M_count; } }; _Indexer* _M_index; template<typename _Tp> friend class valarray; }; inline size_t gslice::start() const { return _M_index ? _M_index->_M_start : 0; } inline valarray<size_t> gslice::size() const { return _M_index ? _M_index->_M_size : valarray<size_t>(); } inline valarray<size_t> gslice::stride() const { return _M_index ? _M_index->_M_stride : valarray<size_t>(); } // _GLIBCXX_RESOLVE_LIB_DEFECTS // 543. valarray slice default constructor inline gslice::gslice() : _M_index(new gslice::_Indexer()) {} inline gslice::gslice(size_t __o, const valarray<size_t>& __l, const valarray<size_t>& __s) : _M_index(new gslice::_Indexer(__o, __l, __s)) {} inline gslice::gslice(const gslice& __g) : _M_index(__g._M_index) { if (_M_index) _M_index->_M_increment_use(); } inline gslice::~gslice() { if (_M_index && _M_index->_M_decrement_use() == 0) delete _M_index; } inline gslice& gslice::operator=(const gslice& __g) { if (__g._M_index) __g._M_index->_M_increment_use(); if (_M_index && _M_index->_M_decrement_use() == 0) delete _M_index; _M_index = __g._M_index; return *this; } // @} group numeric_arrays _GLIBCXX_END_NAMESPACE_VERSION } // namespace #endif /* _GSLICE_H */
[-] streambuf.tcc
[edit]
[-] unique_ptr.h
[edit]
[-] random.tcc
[edit]
[-] istream.tcc
[edit]
[-] functexcept.h
[edit]
[-] valarray_after.h
[edit]
[-] atomic_base.h
[edit]
[-] locale_classes.h
[edit]
[-] locale_facets_nonio.h
[edit]
[-] alloc_traits.h
[edit]
[-] memoryfwd.h
[edit]
[-] stl_algobase.h
[edit]
[-] locale_facets.h
[edit]
[-] hashtable.h
[edit]
[-] stl_multiset.h
[edit]
[-] stl_stack.h
[edit]
[+]
..
[-] stl_pair.h
[edit]
[-] boost_concept_check.h
[edit]
[-] unordered_map.h
[edit]
[-] stl_uninitialized.h
[edit]
[-] regex_grep_matcher.h
[edit]
[-] stl_set.h
[edit]
[-] concept_check.h
[edit]
[-] regex_nfa.h
[edit]
[-] stl_multimap.h
[edit]
[-] deque.tcc
[edit]
[-] valarray_array.tcc
[edit]
[-] basic_string.h
[edit]
[-] regex_nfa.tcc
[edit]
[-] vector.tcc
[edit]
[-] valarray_before.h
[edit]
[-] regex.h
[edit]
[-] stream_iterator.h
[edit]
[-] ptr_traits.h
[edit]
[-] stl_function.h
[edit]
[-] stl_vector.h
[edit]
[-] shared_ptr.h
[edit]
[-] list.tcc
[edit]
[-] stl_iterator_base_types.h
[edit]
[-] stl_tempbuf.h
[edit]
[-] algorithmfwd.h
[edit]
[-] move.h
[edit]
[-] shared_ptr_base.h
[edit]
[-] mask_array.h
[edit]
[-] hash_bytes.h
[edit]
[-] allocator.h
[edit]
[-] ostream.tcc
[edit]
[-] regex_compiler.h
[edit]
[-] cxxabi_forced.h
[edit]
[-] ostream_insert.h
[edit]
[-] uses_allocator.h
[edit]
[-] forward_list.h
[edit]
[-] exception_defines.h
[edit]
[-] streambuf_iterator.h
[edit]
[-] stl_iterator.h
[edit]
[-] gslice.h
[edit]
[-] locale_facets.tcc
[edit]
[-] c++0x_warning.h
[edit]
[-] cpp_type_traits.h
[edit]
[-] stl_numeric.h
[edit]
[-] stl_bvector.h
[edit]
[-] stl_tree.h
[edit]
[-] exception_ptr.h
[edit]
[-] stl_raw_storage_iter.h
[edit]
[-] ios_base.h
[edit]
[-] regex_cursor.h
[edit]
[-] regex_constants.h
[edit]
[-] indirect_array.h
[edit]
[-] valarray_array.h
[edit]
[-] stl_algo.h
[edit]
[-] basic_ios.tcc
[edit]
[-] stl_relops.h
[edit]
[-] char_traits.h
[edit]
[-] postypes.h
[edit]
[-] locale_facets_nonio.tcc
[edit]
[-] stl_list.h
[edit]
[-] nested_exception.h
[edit]
[-] hashtable_policy.h
[edit]
[-] stl_heap.h
[edit]
[-] slice_array.h
[edit]
[-] stringfwd.h
[edit]
[-] basic_ios.h
[edit]
[-] forward_list.tcc
[edit]
[-] basic_string.tcc
[edit]
[-] codecvt.h
[edit]
[-] locale_classes.tcc
[edit]
[-] atomic_lockfree_defines.h
[edit]
[-] fstream.tcc
[edit]
[-] range_access.h
[edit]
[-] stl_map.h
[edit]
[-] functional_hash.h
[edit]
[-] regex_error.h
[edit]
[-] stl_deque.h
[edit]
[-] stl_construct.h
[edit]
[-] stl_iterator_base_funcs.h
[edit]
[-] random.h
[edit]
[-] sstream.tcc
[edit]
[-] unordered_set.h
[edit]
[-] regex_grep_matcher.tcc
[edit]
[-] stl_queue.h
[edit]
[-] gslice_array.h
[edit]
[-] localefwd.h
[edit]