ROOT
master
Reference Guide
Loading...
Searching...
No Matches
RNTupleImtTaskScheduler.hxx
Go to the documentation of this file.
1
/// \file ROOT/RNTupleImtTaskScheduler.hxx
2
/// \ingroup NTuple
3
/// \author Jakob Blomer <jblomer@cern.ch>
4
/// \date 2024-02-19
5
/// \warning This is part of the ROOT 7 prototype! It will change without notice. It might trigger earthquakes. Feedback
6
/// is welcome!
7
8
/*************************************************************************
9
* Copyright (C) 1995-2024, Rene Brun and Fons Rademakers. *
10
* All rights reserved. *
11
* *
12
* For the licensing terms see $ROOTSYS/LICENSE. *
13
* For the list of contributors see $ROOTSYS/README/CREDITS. *
14
*************************************************************************/
15
16
#ifndef ROOT_RNTupleImtTaskScheduler
17
#define ROOT_RNTupleImtTaskScheduler
18
19
#ifdef R__USE_IMT
20
21
#include <
ROOT/RPageStorage.hxx
>
22
#include <
ROOT/TTaskGroup.hxx
>
23
24
#include <functional>
25
#include <utility>
26
27
namespace
ROOT
{
28
namespace
Experimental {
29
30
namespace
Internal
{
31
32
class
RNTupleImtTaskScheduler
:
public
ROOT::Internal::RPageStorage::RTaskScheduler
{
33
private
:
34
TTaskGroup
fTaskGroup
;
35
36
public
:
37
RNTupleImtTaskScheduler
() =
default
;
38
~RNTupleImtTaskScheduler
()
override
=
default
;
39
void
AddTask
(
const
std::function<
void
(
void
)> &
taskFunc
)
final
{
fTaskGroup
.
Run
(
taskFunc
); }
40
void
Wait
()
final
{
fTaskGroup
.
Wait
(); }
41
};
42
43
}
// namespace Internal
44
}
// namespace Experimental
45
}
// namespace ROOT
46
47
#endif
// R__USE_IMT
48
#endif
// ROOT_RNTupleImtTaskScheduler
RPageStorage.hxx
TTaskGroup.hxx
ROOT::Detail::TRangeCast
Definition
TCollection.h:311
ROOT::Experimental::Internal::RNTupleImtTaskScheduler
Definition
RNTupleImtTaskScheduler.hxx:32
ROOT::Experimental::Internal::RNTupleImtTaskScheduler::~RNTupleImtTaskScheduler
~RNTupleImtTaskScheduler() override=default
ROOT::Experimental::Internal::RNTupleImtTaskScheduler::AddTask
void AddTask(const std::function< void(void)> &taskFunc) final
Take a callable that represents a task.
Definition
RNTupleImtTaskScheduler.hxx:39
ROOT::Experimental::Internal::RNTupleImtTaskScheduler::RNTupleImtTaskScheduler
RNTupleImtTaskScheduler()=default
ROOT::Experimental::Internal::RNTupleImtTaskScheduler::Wait
void Wait() final
Blocks until all scheduled tasks finished.
Definition
RNTupleImtTaskScheduler.hxx:40
ROOT::Experimental::Internal::RNTupleImtTaskScheduler::fTaskGroup
TTaskGroup fTaskGroup
Definition
RNTupleImtTaskScheduler.hxx:34
ROOT::Experimental::TTaskGroup
A class to manage the asynchronous execution of work items.
Definition
TTaskGroup.hxx:26
ROOT::Experimental::TTaskGroup::Run
void Run(const std::function< void(void)> &closure)
Add to the group an item of work which will be ran asynchronously.
Definition
TTaskGroup.cxx:122
ROOT::Experimental::TTaskGroup::Wait
void Wait()
Wait until all submitted items of work are completed.
Definition
TTaskGroup.cxx:134
ROOT::Internal::RPageStorage::RTaskScheduler
The interface of a task scheduler to schedule page (de)compression tasks.
Definition
RPageStorage.hxx:76
ROOT::Minuit2::GradientParameterSpace::Internal
@ Internal
ROOT
Definition
EExecutionPolicy.hxx:4
tree
ntuple
inc
ROOT
RNTupleImtTaskScheduler.hxx
ROOT master - Reference Guide Generated on Fri Oct 24 2025 15:21:41 (GVA Time) using Doxygen 1.10.0