 f66620c89c
			
		
	
	f66620c89c
	
	
	
		
			
			Without the member template it is not possible to pass an auto_ptr instantiated with a derived type to post() or broadcast(). The reason is that the conversion constructor and conversion operator of auto_ptr are equally good for that purpose, and hence the compilation ends with an error.
		
			
				
	
	
		
			85 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #pragma once
 | |
| /*
 | |
|  * Copyright (c) 2016 MariaDB Corporation Ab
 | |
|  *
 | |
|  * Use of this software is governed by the Business Source License included
 | |
|  * in the LICENSE.TXT file and at www.mariadb.com/bsl11.
 | |
|  *
 | |
|  * Change Date: 2019-07-01
 | |
|  *
 | |
|  * On the date above, in accordance with the Business Source License, use
 | |
|  * of this software will be governed by version 2 or later of the General
 | |
|  * Public License.
 | |
|  */
 | |
| 
 | |
| #include <maxscale/cppdefs.hh>
 | |
| 
 | |
| namespace maxscale
 | |
| {
 | |
| 
 | |
| class Worker;
 | |
| 
 | |
| /**
 | |
|  * A WorkerTask represents a task to be performed by a Worker.
 | |
|  */
 | |
| class WorkerTask
 | |
| {
 | |
| public:
 | |
|     /**
 | |
|      * Destructor
 | |
|      */
 | |
|     virtual ~WorkerTask();
 | |
| 
 | |
|     /**
 | |
|      * @brief Called in the context of a specific worker.
 | |
|      *
 | |
|      * @param worker  The worker in whose context `execute` is called.
 | |
|      *
 | |
|      * @attention As the function is called by a worker, the body of `execute`
 | |
|      *            should execute quickly and not perform any blocking operations.
 | |
|      */
 | |
|     virtual void execute(Worker& worker) = 0;
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * A WorkerDisposableTask represents a task to be performed by a Worker.
 | |
|  *
 | |
|  * When the task has been executed, the instance will automatically be
 | |
|  * deleted.
 | |
|  */
 | |
| class WorkerDisposableTask
 | |
| {
 | |
| public:
 | |
|     /**
 | |
|      * Destructor
 | |
|      */
 | |
|     virtual ~WorkerDisposableTask();
 | |
| 
 | |
| protected:
 | |
|     /**
 | |
|      * Constructor
 | |
|      */
 | |
|     WorkerDisposableTask();
 | |
| 
 | |
|     /**
 | |
|      * @brief Called in the context of a specific worker.
 | |
|      *
 | |
|      * @param worker  The worker in whose context `execute` is called.
 | |
|      *
 | |
|      * @attention As the function is called by a worker, the body of `execute`
 | |
|      *            should execute quickly and not perform any blocking operations.
 | |
|      */
 | |
|     virtual void execute(Worker& worker) = 0;
 | |
| 
 | |
| private:
 | |
|     friend class Worker;
 | |
| 
 | |
|     void inc_ref();
 | |
|     void dec_ref();
 | |
| 
 | |
| private:
 | |
|     int32_t m_count;
 | |
| };
 | |
| 
 | |
| }
 |