Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
Types.hh
Go to the documentation of this file.
1//
2// MIT License
3// Copyright (c) 2020 Jonathan R. Madsen
4// Permission is hereby granted, free of charge, to any person obtaining a copy
5// of this software and associated documentation files (the "Software"), to deal
6// in the Software without restriction, including without limitation the rights
7// to use, copy, modify, merge, publish, distribute, sublicense, and
8// copies of the Software, and to permit persons to whom the Software is
9// furnished to do so, subject to the following conditions:
10// The above copyright notice and this permission notice shall be included in
11// all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED
12// "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT
13// LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
14// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
15// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
16// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
17// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
18//
19// Tasking native types
20//
21
22#pragma once
23
24// This file defines types used to expose Tasking threading model.
25
26#pragma once
27
28#include <array>
29#include <cstddef>
30#include <future>
31#include <mutex>
32#include <thread>
33
34namespace PTL
35{
36// global thread types
37using Thread = std::thread;
38using NativeThread = std::thread::native_handle_type;
39// std::thread::id does not cast to integer
40using Pid_t = std::thread::id;
41
42// Condition
43using Condition = std::condition_variable;
44
45// Thread identifier
46using ThreadId = Thread::id;
47
48// will be used in the future when migrating threading to task-based style
49template <typename Tp>
50using Future = std::future<Tp>;
51template <typename Tp>
52using SharedFuture = std::shared_future<Tp>;
53template <typename Tp>
54using Promise = std::promise<Tp>;
55
56// global mutex types
57using Mutex = std::mutex;
58using RecursiveMutex = std::recursive_mutex;
59
60// static functions: get_id(), sleep_for(...), sleep_until(...), yield(),
61namespace ThisThread
62{
63using namespace std::this_thread;
64}
65
66// Helper function for getting a unique static mutex for a specific
67// class or type
68// Usage example:
69// a template class "Cache<T>" that required a static
70// mutex for specific to type T:
71// AutoLock l(TypeMutex<Cache<T>>());
72template <typename Tp, typename MutexTp = Mutex, size_t N = 4>
73MutexTp&
74TypeMutex(const unsigned int& _n = 0)
75{
76 static std::array<MutexTp, N> _mutex_array{};
77 return _mutex_array[_n % N];
78}
79
80} // namespace PTL
#define N
Definition crc32.c:57
Backports of C++ language features for use with C++11 compilers.
Definition AutoLock.hh:255