You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							80 lines
						
					
					
						
							2.8 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							80 lines
						
					
					
						
							2.8 KiB
						
					
					
				
								/*
							 | 
						|
								    Copyright 2005-2014 Intel Corporation.  All Rights Reserved.
							 | 
						|
								
							 | 
						|
								    This file is part of Threading Building Blocks.
							 | 
						|
								
							 | 
						|
								    Threading Building Blocks is free software; you can redistribute it
							 | 
						|
								    and/or modify it under the terms of the GNU General Public License
							 | 
						|
								    version 2 as published by the Free Software Foundation.
							 | 
						|
								
							 | 
						|
								    Threading Building Blocks 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.
							 | 
						|
								
							 | 
						|
								    You should have received a copy of the GNU General Public License
							 | 
						|
								    along with Threading Building Blocks; if not, write to the Free Software
							 | 
						|
								    Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
							 | 
						|
								
							 | 
						|
								    As a special exception, you may use this file as part of a free software
							 | 
						|
								    library without restriction.  Specifically, if other files instantiate
							 | 
						|
								    templates or use macros or inline functions from this file, or you compile
							 | 
						|
								    this file and link it with other files to produce an executable, this
							 | 
						|
								    file does not by itself cause the resulting executable to be covered by
							 | 
						|
								    the GNU General Public License.  This exception does not however
							 | 
						|
								    invalidate any other reasons why the executable file might be covered by
							 | 
						|
								    the GNU General Public License.
							 | 
						|
								*/
							 | 
						|
								
							 | 
						|
								#ifndef __TBB_combinable_H
							 | 
						|
								#define __TBB_combinable_H
							 | 
						|
								
							 | 
						|
								#include "enumerable_thread_specific.h"
							 | 
						|
								#include "cache_aligned_allocator.h"
							 | 
						|
								
							 | 
						|
								namespace tbb {
							 | 
						|
								/** \name combinable
							 | 
						|
								    **/
							 | 
						|
								//@{
							 | 
						|
								//! Thread-local storage with optional reduction
							 | 
						|
								/** @ingroup containers */
							 | 
						|
								    template <typename T>
							 | 
						|
								        class combinable {
							 | 
						|
								    private:
							 | 
						|
								        typedef typename tbb::cache_aligned_allocator<T> my_alloc;
							 | 
						|
								
							 | 
						|
								        typedef typename tbb::enumerable_thread_specific<T, my_alloc, ets_no_key> my_ets_type;
							 | 
						|
								        my_ets_type my_ets; 
							 | 
						|
								 
							 | 
						|
								    public:
							 | 
						|
								
							 | 
						|
								        combinable() { }
							 | 
						|
								
							 | 
						|
								        template <typename finit>
							 | 
						|
								        combinable( finit _finit) : my_ets(_finit) { }
							 | 
						|
								
							 | 
						|
								        //! destructor
							 | 
						|
								        ~combinable() { 
							 | 
						|
								        }
							 | 
						|
								
							 | 
						|
								        combinable(const combinable& other) : my_ets(other.my_ets) { }
							 | 
						|
								
							 | 
						|
								        combinable & operator=( const combinable & other) { my_ets = other.my_ets; return *this; }
							 | 
						|
								
							 | 
						|
								        void clear() { my_ets.clear(); }
							 | 
						|
								
							 | 
						|
								        T& local() { return my_ets.local(); }
							 | 
						|
								
							 | 
						|
								        T& local(bool & exists) { return my_ets.local(exists); }
							 | 
						|
								
							 | 
						|
								        // combine_func_t has signature T(T,T) or T(const T&, const T&)
							 | 
						|
								        template <typename combine_func_t>
							 | 
						|
								        T combine(combine_func_t f_combine) { return my_ets.combine(f_combine); }
							 | 
						|
								
							 | 
						|
								        // combine_func_t has signature void(T) or void(const T&)
							 | 
						|
								        template <typename combine_func_t>
							 | 
						|
								        void combine_each(combine_func_t f_combine) { my_ets.combine_each(f_combine); }
							 | 
						|
								
							 | 
						|
								    };
							 | 
						|
								} // namespace tbb
							 | 
						|
								#endif /* __TBB_combinable_H */
							 |