Microsoft Information Protection (MIP) SDK for C++: Reference 1.15
Doxygen-generated documentation for MIP SDK written in C++
Loading...
Searching...
No Matches
task_dispatcher_delegate.h
Go to the documentation of this file.
1/*
2 *
3 * Copyright (c) Microsoft Corporation.
4 * All rights reserved.
5 *
6 * This code is licensed under the MIT License.
7 *
8 * Permission is hereby granted, free of charge, to any person obtaining a copy
9 * of this software and associated documentation files(the "Software"), to deal
10 * in the Software without restriction, including without limitation the rights
11 * to use, copy, modify, merge, publish, distribute, sublicense, and / or sell
12 * copies of the Software, and to permit persons to whom the Software is
13 * furnished to do so, subject to the following conditions :
14 *
15 * The above copyright notice and this permission notice shall be included in
16 * all copies or substantial portions of the Software.
17 *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE
21 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24 * THE SOFTWARE.
25 *
26 */
27/**
28 * @brief A file containing the TaskDispatcherDelegate interface to be used to override MIP async task executor
29 *
30 * @file task_dispatcher_delegate.h
31 */
32
33
34#ifndef API_MIP_TASK_DISPATCHER_DELEGATE_H_
35#define API_MIP_TASK_DISPATCHER_DELEGATE_H_
36
37#include <functional>
38#include <memory>
39#include <string>
40
41#include "mip/mip_namespace.h"
42
43MIP_NAMESPACE_BEGIN
44
45/**
46 * @brief A class that defines the interface to the MIP SDK task dispatcher
47 */
49public:
50 /**
51 * @brief Execute a task on a background thread
52 *
53 * @param taskId ID to uniquely identify a task
54 * @param task Function to be executed
55 */
56 virtual void DispatchTask(const std::string& taskId, std::function<void()> task) = 0;
57
58 /**
59 * @brief Execute a task on a background thread
60 *
61 * @param taskId ID to uniquely identify a task
62 * @param task Function to be executed
63 * @param loggerContext logger context that should be used with the logger delegate before the task is run
64 */
65 virtual void DispatchTask(
66 const std::string& taskId,
67 std::function<void()> task,
68 const std::shared_ptr<void>& /*loggerContext*/) {
69 DispatchTask(taskId, task);
70 }
71
72 /**
73 * @brief Execute a task on a background thread with the given delay
74 *
75 * @param taskId ID to uniquely identify a task
76 * @param task Function to be executed
77 * @param delaySeconds Delay (in seconds) before executing task
78 */
79 virtual void DispatchTask(const std::string& taskId, std::function<void()> task, int64_t delaySeconds) = 0;
80
81 /**
82 * @brief Execute a task on a background thread with the given delay
83 *
84 * @param taskId ID to uniquely identify a task
85 * @param task Function to be executed
86 * @param delaySeconds Delay (in seconds) before executing task
87 * @param loggerContext logger context that should be used with the logger delegate before the task is run
88 */
89 virtual void DispatchTask(
90 const std::string& taskId,
91 std::function<void()> task,
92 int64_t delaySeconds,
93 const std::shared_ptr<void>& /*loggerContext*/) {
94 DispatchTask(taskId, task, delaySeconds);
95 }
96
97 /**
98 * @brief Immediately execute a task on an independent thread
99 *
100 * @param taskId ID to uniquely identify a task
101 * @param task Function to be executed
102 */
103 virtual void ExecuteTaskOnIndependentThread(const std::string& taskId, std::function<void()> task) = 0;
104
105 /**
106 * @brief Immediately execute a task on an independent thread
107 *
108 * @param taskId ID to uniquely identify a task
109 * @param task Function to be executed
110 * @param loggerContext logger context that should be used with the logger delegate before the task is run
111 */
113 const std::string& taskId,
114 std::function<void()> task,
115 const std::shared_ptr<void>& /*loggerContext*/) {
116 ExecuteTaskOnIndependentThread(taskId, task);
117 }
118
119 /**
120 * @brief Cancel a background task
121 *
122 * @param taskId ID of task to cancel
123 *
124 * @return True if task was successfully cancelled, else false
125 */
126 virtual bool CancelTask(const std::string& taskId) = 0;
127
128 /**
129 * @brief Cancel a background task
130 *
131 * @param taskId ID of task to cancel
132 * @param loggerContext logger context that should be used with the logger delegate for cancelation logging
133 *
134 * @return True if task was successfully cancelled, else false
135 */
136 virtual bool CancelTask(const std::string& taskId, const std::shared_ptr<void>& /*loggerContext*/) {
137 return CancelTask(taskId);
138 }
139
140 /**
141 * @brief Cancel all background tasks
142 */
143 virtual void CancelAllTasks() = 0;
144
145 /** @cond DOXYGEN_HIDE */
146 virtual ~TaskDispatcherDelegate() {}
147protected:
149 /** @endcond */
150};
151
152MIP_NAMESPACE_END
153#endif // API_MIP_TASK_DISPATCHER_DELEGATE_H_
A class that defines the interface to the MIP SDK task dispatcher.
virtual void DispatchTask(const std::string &taskId, std::function< void()> task, int64_t delaySeconds)=0
Execute a task on a background thread with the given delay.
virtual bool CancelTask(const std::string &taskId, const std::shared_ptr< void > &)
Cancel a background task.
virtual void DispatchTask(const std::string &taskId, std::function< void()> task)=0
Execute a task on a background thread.
virtual void DispatchTask(const std::string &taskId, std::function< void()> task, int64_t delaySeconds, const std::shared_ptr< void > &)
Execute a task on a background thread with the given delay.
virtual bool CancelTask(const std::string &taskId)=0
Cancel a background task.
virtual void CancelAllTasks()=0
Cancel all background tasks.
virtual void ExecuteTaskOnIndependentThread(const std::string &taskId, std::function< void()> task, const std::shared_ptr< void > &)
Immediately execute a task on an independent thread.
virtual void ExecuteTaskOnIndependentThread(const std::string &taskId, std::function< void()> task)=0
Immediately execute a task on an independent thread.
virtual void DispatchTask(const std::string &taskId, std::function< void()> task, const std::shared_ptr< void > &)
Execute a task on a background thread.
MIP namespace macros.