• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2021-2022 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #ifndef BASE_EVENTHANDLER_INTERFACES_INNER_API_EVENT_HANDLER_H
17 #define BASE_EVENTHANDLER_INTERFACES_INNER_API_EVENT_HANDLER_H
18 
19 #include "event_runner.h"
20 #include "dumper.h"
21 
22 #ifndef __has_builtin
23 #define __has_builtin(x) 0
24 #endif
25 
26 namespace OHOS {
27 namespace AppExecFwk {
28 enum class EventType {
29     SYNC_EVENT = 0,
30     DELAY_EVENT = 1,
31     TIMING_EVENT = 2,
32 };
33 
34 struct Caller {
35     std::string file_ {""};
36     int         line_ {0};
37     std::string func_ {""};
38 #if __has_builtin(__builtin_FILE)
39     Caller(std::string file = __builtin_FILE(), int line = __builtin_LINE(), std::string func = __builtin_FUNCTION())
file_Caller40         : file_(file), line_(line), func_(func) {
41     }
42 #else
CallerCaller43     Caller() {
44     }
45 #endif
ToStringCaller46     std::string ToString()
47     {
48         if (file_.empty()) {
49             return "[ ]";
50         }
51         size_t split = file_.find_last_of("/\\");
52         if (split == std::string::npos) {
53             split = 0;
54         }
55         std::string caller("[" + file_.substr(split + 1) + "(" + func_ + ":" + std::to_string(line_) + ")]");
56         return caller;
57     }
58 };
59 
60 template<typename T>
61 class ThreadLocalData;
62 
63 class EventHandler : public std::enable_shared_from_this<EventHandler> {
64 public:
65     using CallbackTimeout = std::function<void()>;
66     using Callback = InnerEvent::Callback;
67     using Priority = EventQueue::Priority;
68 
69     /**
70      * Constructor, set 'EventRunner' automatically.
71      *
72      * @param runner The 'EventRunner'.
73      */
74     explicit EventHandler(const std::shared_ptr<EventRunner> &runner = nullptr);
75     virtual ~EventHandler();
76     DISALLOW_COPY_AND_MOVE(EventHandler);
77 
78     /**
79      * Get event handler that running on current thread.
80      *
81      * @return Returns shared pointer of the current 'EventHandler'.
82      */
83     static std::shared_ptr<EventHandler> Current();
84 
85     /**
86      * Send an event.
87      *
88      * @param event Event which should be handled.
89      * @param delayTime Process the event after 'delayTime' milliseconds.
90      * @param priority Priority of the event queue for this event.
91      * @return Returns true if event has been sent successfully. If returns false, event should be released manually.
92      */
93     bool SendEvent(InnerEvent::Pointer &event, int64_t delayTime = 0, Priority priority = Priority::LOW);
94 
95     /**
96      * Send an event.
97      *
98      * @param event Event which should be handled.
99      * @param taskTime Process the event at taskTime.
100      * @param priority Priority of the event queue for this event.
101      * @return Returns true if event has been sent successfully. If returns false, event should be released manually.
102      */
103     bool SendTimingEvent(InnerEvent::Pointer &event, int64_t taskTime, Priority priority = Priority::LOW);
104 
105     /**
106      * Send an event.
107      *
108      * @param event Event which should be handled.
109      * @param priority Priority of the event queue for this event.
110      * @return Returns true if event has been sent successfully. If returns false, event should be released manually.
111      */
SendEvent(InnerEvent::Pointer & event,Priority priority)112     inline bool SendEvent(InnerEvent::Pointer &event, Priority priority)
113     {
114         return SendEvent(event, 0, priority);
115     }
116 
117     /**
118      * Send an event.
119      *
120      * @param event Event which should be handled.
121      * @param delayTime Process the event after 'delayTime' milliseconds.
122      * @param priority Priority of the event queue for this event.
123      * @return Returns true if event has been sent successfully.
124      */
125     inline bool SendEvent(InnerEvent::Pointer &&event, int64_t delayTime = 0, Priority priority = Priority::LOW)
126     {
127         return SendEvent(event, delayTime, priority);
128     }
129 
130     /**
131      * Send an event.
132      *
133      * @param innerEventId The id of the event.
134      * @param param Basic parameter of the event, default is 0.
135      * @param delayTime Process the event after 'delayTime' milliseconds.
136      * @return Returns true if event has been sent successfully.
137      */
SendEvent(uint32_t innerEventId,int64_t param,int64_t delayTime)138     inline bool SendEvent(uint32_t innerEventId, int64_t param, int64_t delayTime)
139     {
140         return SendEvent(InnerEvent::Get(innerEventId, param), delayTime);
141     }
142 
143     /**
144      * Send an event.
145      *
146      * @param innerEventId The id of the event.
147      * @param delayTime Process the event after 'delayTime' milliseconds.
148      * @param priority Priority of the event queue for this event.
149      * @return Returns true if event has been sent successfully.
150      */
151     inline bool SendEvent(uint32_t innerEventId, int64_t delayTime = 0, Priority priority = Priority::LOW)
152     {
153         return SendEvent(InnerEvent::Get(innerEventId, 0), delayTime, priority);
154     }
155 
156     /**
157      * Send an event.
158      *
159      * @param innerEventId The id of the event.
160      * @param priority Priority of the event queue for this event.
161      * @return Returns true if event has been sent successfully.
162      */
SendEvent(uint32_t innerEventId,Priority priority)163     inline bool SendEvent(uint32_t innerEventId, Priority priority)
164     {
165         return SendEvent(InnerEvent::Get(innerEventId, 0), 0, priority);
166     }
167 
168     /**
169      * Send an event.
170      *
171      * @param innerEventId The id of the event.
172      * @param object Shared pointer of object.
173      * @param delayTime Process the event after 'delayTime' milliseconds.
174      * @return Returns true if event has been sent successfully.
175      */
176     template<typename T>
177     inline bool SendEvent(uint32_t innerEventId, const std::shared_ptr<T> &object, int64_t delayTime = 0)
178     {
179         return SendEvent(InnerEvent::Get(innerEventId, object), delayTime);
180     }
181 
182     /**
183      * Send an event.
184      *
185      * @param innerEventId The id of the event.
186      * @param object Weak pointer of object.
187      * @param delayTime Process the event after 'delayTime' milliseconds.
188      * @return Returns true if event has been sent successfully.
189      */
190     template<typename T>
191     inline bool SendEvent(uint32_t innerEventId, const std::weak_ptr<T> &object, int64_t delayTime = 0)
192     {
193         return SendEvent(InnerEvent::Get(innerEventId, object), delayTime);
194     }
195 
196     /**
197      * Send an event.
198      *
199      * @param innerEventId The id of the event.
200      * @param object Unique pointer of object.
201      * @param delayTime Process the event after 'delayTime' milliseconds.
202      * @return Returns true if event has been sent successfully.
203      */
204     template<typename T, typename D>
205     inline bool SendEvent(uint32_t innerEventId, std::unique_ptr<T, D> &object, int64_t delayTime = 0)
206     {
207         return SendEvent(InnerEvent::Get(innerEventId, object), delayTime);
208     }
209 
210     /**
211      * Send an event.
212      *
213      * @param innerEventId The id of the event.
214      * @param object Unique pointer of object.
215      * @param delayTime Process the event after 'delayTime' milliseconds.
216      * @return Returns true if event has been sent successfully.
217      */
218     template<typename T, typename D>
219     inline bool SendEvent(uint32_t innerEventId, std::unique_ptr<T, D> &&object, int64_t delayTime = 0)
220     {
221         return SendEvent(InnerEvent::Get(innerEventId, object), delayTime);
222     }
223 
224     /**
225      * Send an immediate event.
226      *
227      * @param event Event which should be handled.
228      * @return Returns true if event has been sent successfully.
229      */
SendImmediateEvent(InnerEvent::Pointer & event)230     inline bool SendImmediateEvent(InnerEvent::Pointer &event)
231     {
232         return SendEvent(event, 0, Priority::IMMEDIATE);
233     }
234 
235     /**
236      * Send an immediate event.
237      *
238      * @param event Event which should be handled.
239      * @return Returns true if event has been sent successfully.
240      */
SendImmediateEvent(InnerEvent::Pointer && event)241     inline bool SendImmediateEvent(InnerEvent::Pointer &&event)
242     {
243         return SendImmediateEvent(event);
244     }
245 
246     /**
247      * Send an immediate event.
248      *
249      * @param innerEventId The id of the event.
250      * @param param Basic parameter of the event, default is 0.
251      * @return Returns true if event has been sent successfully.
252      */
253     inline bool SendImmediateEvent(uint32_t innerEventId, int64_t param = 0)
254     {
255         return SendImmediateEvent(InnerEvent::Get(innerEventId, param));
256     }
257 
258     /**
259      * Send an immediate event.
260      *
261      * @param innerEventId The id of the event.
262      * @param object Shared pointer of object.
263      * @return Returns true if event has been sent successfully.
264      */
265     template<typename T>
SendImmediateEvent(uint32_t innerEventId,const std::shared_ptr<T> & object)266     inline bool SendImmediateEvent(uint32_t innerEventId, const std::shared_ptr<T> &object)
267     {
268         return SendImmediateEvent(InnerEvent::Get(innerEventId, object));
269     }
270 
271     /**
272      * Send an immediate event.
273      *
274      * @param innerEventId The id of the event.
275      * @param object Weak pointer of object.
276      * @return Returns true if event has been sent successfully.
277      */
278     template<typename T>
SendImmediateEvent(uint32_t innerEventId,const std::weak_ptr<T> & object)279     inline bool SendImmediateEvent(uint32_t innerEventId, const std::weak_ptr<T> &object)
280     {
281         return SendImmediateEvent(InnerEvent::Get(innerEventId, object));
282     }
283 
284     /**
285      * Send an immediate event.
286      *
287      * @param innerEventId The id of the event.
288      * @param object Unique pointer of object.
289      * @return Returns true if event has been sent successfully.
290      */
291     template<typename T, typename D>
SendImmediateEvent(uint32_t innerEventId,std::unique_ptr<T,D> & object)292     inline bool SendImmediateEvent(uint32_t innerEventId, std::unique_ptr<T, D> &object)
293     {
294         return SendImmediateEvent(InnerEvent::Get(innerEventId, object));
295     }
296 
297     /**
298      * Send an immediate event.
299      *
300      * @param innerEventId The id of the event.
301      * @param object Unique pointer of object.
302      * @return Returns true if event has been sent successfully.
303      */
304     template<typename T, typename D>
SendImmediateEvent(uint32_t innerEventId,std::unique_ptr<T,D> && object)305     inline bool SendImmediateEvent(uint32_t innerEventId, std::unique_ptr<T, D> &&object)
306     {
307         return SendImmediateEvent(InnerEvent::Get(innerEventId, object));
308     }
309 
310     /**
311      * Send an high priority event.
312      *
313      * @param event Event which should be handled.
314      * @param delayTime Process the event after 'delayTime' milliseconds.
315      * @return Returns true if event has been sent successfully.
316      */
317     inline bool SendHighPriorityEvent(InnerEvent::Pointer &event, int64_t delayTime = 0)
318     {
319         return SendEvent(event, delayTime, Priority::HIGH);
320     }
321 
322     /**
323      * Send an high priority event.
324      *
325      * @param event Event which should be handled.
326      * @param delayTime Process the event after 'delayTime' milliseconds.
327      * @return Returns true if event has been sent successfully.
328      */
329     inline bool SendHighPriorityEvent(InnerEvent::Pointer &&event, int64_t delayTime = 0)
330     {
331         return SendHighPriorityEvent(event, delayTime);
332     }
333 
334     /**
335      * Send an high priority event.
336      *
337      * @param innerEventId The id of the event.
338      * @param param Basic parameter of the event, default is 0.
339      * @param delayTime Process the event after 'delayTime' milliseconds.
340      * @return Returns true if event has been sent successfully.
341      */
342     inline bool SendHighPriorityEvent(uint32_t innerEventId, int64_t param = 0, int64_t delayTime = 0)
343     {
344         return SendHighPriorityEvent(InnerEvent::Get(innerEventId, param), delayTime);
345     }
346 
347     /**
348      * Send an high priority event.
349      *
350      * @param innerEventId The id of the event.
351      * @param object Shared pointer of object.
352      * @param delayTime Process the event after 'delayTime' milliseconds.
353      * @return Returns true if event has been sent successfully.
354      */
355     template<typename T>
356     inline bool SendHighPriorityEvent(uint32_t innerEventId, const std::shared_ptr<T> &object, int64_t delayTime = 0)
357     {
358         return SendHighPriorityEvent(InnerEvent::Get(innerEventId, object), delayTime);
359     }
360 
361     /**
362      * Send an high priority event.
363      *
364      * @param innerEventId The id of the event.
365      * @param object Weak pointer of object.
366      * @param delayTime Process the event after 'delayTime' milliseconds.
367      * @return Returns true if event has been sent successfully.
368      */
369     template<typename T>
370     inline bool SendHighPriorityEvent(uint32_t innerEventId, const std::weak_ptr<T> &object, int64_t delayTime = 0)
371     {
372         return SendHighPriorityEvent(InnerEvent::Get(innerEventId, object), delayTime);
373     }
374 
375     /**
376      * Send an high priority event.
377      *
378      * @param innerEventId The id of the event.
379      * @param object Unique pointer of object.
380      * @param delayTime Process the event after 'delayTime' milliseconds.
381      * @return Returns true if event has been sent successfully.
382      */
383     template<typename T, typename D>
384     inline bool SendHighPriorityEvent(uint32_t innerEventId, std::unique_ptr<T, D> &object, int64_t delayTime = 0)
385     {
386         return SendHighPriorityEvent(InnerEvent::Get(innerEventId, object), delayTime);
387     }
388 
389     /**
390      * Send an high priority event.
391      *
392      * @param innerEventId The id of the event.
393      * @param object Unique pointer of object.
394      * @param delayTime Process the event after 'delayTime' milliseconds.
395      * @return Returns true if event has been sent successfully.
396      */
397     template<typename T, typename D>
398     inline bool SendHighPriorityEvent(uint32_t innerEventId, std::unique_ptr<T, D> &&object, int64_t delayTime = 0)
399     {
400         return SendHighPriorityEvent(InnerEvent::Get(innerEventId, object), delayTime);
401     }
402 
403     /**
404      * Post a task.
405      *
406      * @param callback Task callback.
407      * @param name Name of the task.
408      * @param delayTime Process the event after 'delayTime' milliseconds.
409      * @param priority Priority of the event queue for this event.
410      * @return Returns true if task has been sent successfully.
411      */
412     inline bool PostTask(const Callback &callback, const std::string &name = std::string(), int64_t delayTime = 0,
413         Priority priority = Priority::LOW, Caller caller = {})
414     {
415         return SendEvent(InnerEvent::Get(callback, name.empty() ? caller.ToString() : name), delayTime, priority);
416     }
417 
418     /**
419      * Set delivery time out callback.
420      *
421      * @param callback Delivery Time out callback.
422      */
SetDeliveryTimeoutCallback(const Callback & callback)423     void SetDeliveryTimeoutCallback(const Callback &callback)
424     {
425         deliveryTimeoutCallback_ = callback;
426     }
427 
428     /**
429      * Set distribute time out callback.
430      *
431      * @param callback Distribute Time out callback.
432      */
SetDistributeTimeoutCallback(const Callback & callback)433     void SetDistributeTimeoutCallback(const Callback &callback)
434     {
435         distributeTimeoutCallback_ = callback;
436     }
437 
438     /**
439      * Post a task.
440      *
441      * @param callback Task callback.
442      * @param priority Priority of the event queue for this event.
443      * @return Returns true if task has been sent successfully.
444      */
445     inline bool PostTask(const Callback &callback, Priority priority, Caller caller = {})
446     {
447         return PostTask(callback, caller.ToString(), 0, priority);
448     }
449 
450     /**
451      * Post a task.
452      *
453      * @param callback Task callback.
454      * @param delayTime Process the event after 'delayTime' milliseconds.
455      * @param priority Priority of the event queue for this event.
456      * @return Returns true if task has been sent successfully.
457      */
458     inline bool PostTask(const Callback &callback, int64_t delayTime, Priority priority = Priority::LOW,
459                          Caller caller = {})
460     {
461         return PostTask(callback, caller.ToString(), delayTime, priority);
462     }
463 
464     /**
465      * Post an immediate task.
466      *
467      * @param callback Task callback.
468      * @param name Remove events by name of the task.
469      * @return Returns true if task has been sent successfully.
470      */
471     inline bool PostImmediateTask(const Callback &callback, const std::string &name = std::string(),
472                                   Caller caller = {})
473     {
474         return SendEvent(InnerEvent::Get(callback, name.empty() ? caller.ToString() : name), 0, Priority::IMMEDIATE);
475     }
476 
477     /**
478      * Post a high priority task.
479      *
480      * @param callback Task callback.
481      * @param name Name of the task.
482      * @param delayTime Process the event after 'delayTime' milliseconds.
483      * @return Returns true if task has been sent successfully.
484      */
485     inline bool PostHighPriorityTask(const Callback &callback, const std::string &name = std::string(),
486                                      int64_t delayTime = 0, Caller caller = {})
487     {
488         return PostTask(callback, name.empty() ? caller.ToString() : name, delayTime, Priority::HIGH);
489     }
490 
491     /**
492      * Post a high priority task.
493      *
494      * @param callback Task callback.
495      * @param delayTime Process the event after 'delayTime' milliseconds.
496      * @return Returns true if task has been sent successfully.
497      */
498     inline bool PostHighPriorityTask(const Callback &callback, int64_t delayTime, Caller caller = {})
499     {
500         return PostHighPriorityTask(callback, caller.ToString(), delayTime);
501     }
502 
503     /**
504      * Post a idle task.
505      *
506      * @param callback task callback.
507      * @param name Name of the task.
508      * @param delayTime Process the event after 'delayTime' milliseconds.
509      * @return Returns true if task has been sent successfully.
510      */
511     inline bool PostIdleTask(const Callback &callback, const std::string &name = std::string(), int64_t delayTime = 0,
512                              Caller caller = {})
513     {
514         return PostTask(callback, name.empty() ? caller.ToString() : name, delayTime, Priority::IDLE);
515     }
516 
517     /**
518      * Post a idle task.
519      *
520      * @param callback Task callback.
521      * @param delayTime Process the event after 'delayTime' milliseconds.
522      * @return Returns true if task has been sent successfully.
523      */
524     inline bool PostIdleTask(const Callback &callback, int64_t delayTime, Caller caller = {})
525     {
526         return PostIdleTask(callback, caller.ToString(), delayTime);
527     }
528 
529     /**
530      * Send an event, and wait until this event has been handled.
531      *
532      * @param event Event which should be handled.
533      * @param priority Priority of the event queue for this event, IDLE is not permitted for sync event.
534      * @return Returns true if event has been sent successfully. If returns false, event should be released manually.
535      */
536     bool SendSyncEvent(InnerEvent::Pointer &event, Priority priority = Priority::LOW);
537 
538     /**
539      * Send an event.
540      *
541      * @param event Event which should be handled.
542      * @param priority Priority of the event queue for this event.
543      * @param priority Priority of the event queue for this event, IDLE is not permitted for sync event.
544      * @return Returns true if event has been sent successfully.
545      */
546     inline bool SendSyncEvent(InnerEvent::Pointer &&event, Priority priority = Priority::LOW)
547     {
548         return SendSyncEvent(event, priority);
549     }
550 
551     /**
552      * Send an event, and wait until this event has been handled.
553      *
554      * @param innerEventId The id of the event.
555      * @param param Basic parameter of the event, default is 0.
556      * @param priority Priority of the event queue for this event, IDLE is not permitted for sync event.
557      * @return Returns true if event has been sent successfully.
558      */
559     inline bool SendSyncEvent(uint32_t innerEventId, int64_t param = 0, Priority priority = Priority::LOW)
560     {
561         return SendSyncEvent(InnerEvent::Get(innerEventId, param), priority);
562     }
563 
564     /**
565      * Send an event, and wait until this event has been handled.
566      *
567      * @param innerEventId The id of the event.
568      * @param priority Priority of the event queue for this event, IDLE is not permitted for sync event.
569      * @return Returns true if event has been sent successfully.
570      */
SendSyncEvent(uint32_t innerEventId,Priority priority)571     inline bool SendSyncEvent(uint32_t innerEventId, Priority priority)
572     {
573         return SendSyncEvent(InnerEvent::Get(innerEventId, 0), priority);
574     }
575 
576     /**
577      * Send an event, and wait until this event has been handled.
578      *
579      * @param innerEventId The id of the event.
580      * @param object Shared pointer of object.
581      * @param priority Priority of the event queue for this event, IDLE is not permitted for sync event.
582      * @return Returns true if event has been sent successfully.
583      */
584     template<typename T>
585     inline bool SendSyncEvent(
586         uint32_t innerEventId, const std::shared_ptr<T> &object, Priority priority = Priority::LOW)
587     {
588         return SendSyncEvent(InnerEvent::Get(innerEventId, object), priority);
589     }
590 
591     /**
592      * Send an event, and wait until this event has been handled.
593      *
594      * @param innerEventId The id of the event.
595      * @param object Weak pointer of object.
596      * @param priority Priority of the event queue for this event, IDLE is not permitted for sync event.
597      * @return Returns true if event has been sent successfully.
598      */
599     template<typename T>
600     inline bool SendSyncEvent(uint32_t innerEventId, const std::weak_ptr<T> &object, Priority priority = Priority::LOW)
601     {
602         return SendSyncEvent(InnerEvent::Get(innerEventId, object), priority);
603     }
604 
605     /**
606      * Send an event, and wait until this event has been handled.
607      *
608      * @param innerEventId The id of the event.
609      * @param object Unique pointer of object.
610      * @param priority Priority of the event queue for this event, IDLE is not permitted for sync event.
611      * @return Returns true if event has been sent successfully.
612      */
613     template<typename T, typename D>
614     inline bool SendSyncEvent(uint32_t innerEventId, std::unique_ptr<T, D> &object, Priority priority = Priority::LOW)
615     {
616         return SendSyncEvent(InnerEvent::Get(innerEventId, object), priority);
617     }
618 
619     /**
620      * Send an event, and wait until this event has been handled.
621      *
622      * @param innerEventId The id of the event.
623      * @param object Unique pointer of object.
624      * @param priority Priority of the event queue for this event, IDLE is not permitted for sync event.
625      * @return Returns true if event has been sent successfully.
626      */
627     template<typename T, typename D>
628     inline bool SendSyncEvent(uint32_t innerEventId, std::unique_ptr<T, D> &&object, Priority priority = Priority::LOW)
629     {
630         return SendSyncEvent(InnerEvent::Get(innerEventId, object), priority);
631     }
632 
633     /**
634      * Post a task, and wait until this task has been handled.
635      *
636      * @param callback Task callback.
637      * @param name Name of the task.
638      * @param priority Priority of the event queue for this event, IDLE is not permitted for sync event.
639      * @return Returns true if task has been sent successfully.
640      */
641     inline bool PostSyncTask(const Callback &callback, const std::string &name, Priority priority = Priority::LOW,
642                              Caller caller = {})
643     {
644         return SendSyncEvent(InnerEvent::Get(callback, name.empty() ? caller.ToString() : name), priority);
645     }
646 
647     /**
648      * Post a task, and wait until this task has been handled.
649      *
650      * @param callback Task callback.
651      * @param priority Priority of the event queue for this event, IDLE is not permitted for sync event.
652      * @return Returns true if task has been sent successfully.
653      */
654     inline bool PostSyncTask(const Callback &callback, Priority priority = Priority::LOW, Caller caller = {})
655     {
656         return PostSyncTask(callback, caller.ToString(), priority);
657     }
658 
659     /**
660      * Send a timing event.
661      *
662      * @param event Event which should be handled.
663      * @param taskTime Process the event at taskTime.
664      * @param priority Priority of the event queue for this event.
665      * @return Returns true if event has been sent successfully.
666      */
SendTimingEvent(InnerEvent::Pointer && event,int64_t taskTime,Priority priority)667     inline bool SendTimingEvent(InnerEvent::Pointer &&event, int64_t taskTime, Priority priority)
668     {
669         return SendTimingEvent(event, taskTime, priority);
670     }
671 
672     /**
673      * Send a timing event.
674      *
675      * @param event Event which should be handled.
676      * @param taskTime Process the event at taskTime.
677      * @return Returns true if event has been sent successfully.
678      */
SendTimingEvent(InnerEvent::Pointer && event,int64_t taskTime)679     inline bool SendTimingEvent(InnerEvent::Pointer &&event, int64_t taskTime)
680     {
681         return SendTimingEvent(event, taskTime, Priority::LOW);
682     }
683 
684     /**
685      * Send a timing event.
686      *
687      * @param innerEventId The id of the event.
688      * @param taskTime Process the event at taskTime.
689      * @param param Basic parameter of the event.
690      * @return Returns true if event has been sent successfully.
691      */
SendTimingEvent(uint32_t innerEventId,int64_t taskTime,int64_t param)692     inline bool SendTimingEvent(uint32_t innerEventId, int64_t taskTime, int64_t param)
693     {
694         return SendTimingEvent(InnerEvent::Get(innerEventId, param), taskTime);
695     }
696 
697     /**
698      * Send a timing event.
699      *
700      * @param innerEventId The id of the event.
701      * @param taskTime Process the event at taskTime.
702      * @param priority Priority of the event queue for this event.
703      * @return Returns true if event has been sent successfully.
704      */
SendTimingEvent(uint32_t innerEventId,int64_t taskTime,Priority priority)705     inline bool SendTimingEvent(uint32_t innerEventId, int64_t taskTime, Priority priority)
706     {
707         return SendTimingEvent(InnerEvent::Get(innerEventId, 0), taskTime, priority);
708     }
709 
710     /**
711      * Send a timing event.
712      *
713      * @param innerEventId The id of the event.
714      * @param taskTime Process the event at taskTime.
715      * @param priority Priority of the event queue for this event.
716      * @return Returns true if event has been sent successfully.
717      */
SendTimingEvent(uint32_t innerEventId,int64_t taskTime)718     inline bool SendTimingEvent(uint32_t innerEventId, int64_t taskTime)
719     {
720         return SendTimingEvent(InnerEvent::Get(innerEventId, 0), taskTime, Priority::LOW);
721     }
722 
723     /**
724      * Send a timing event.
725      *
726      * @param innerEventId The id of the event.
727      * @param object Shared pointer of object.
728      * @param taskTime Process the event at taskTime.
729      * @param priority Priority of the event queue for this event
730      * @return Returns true if event has been sent successfully.
731      */
732     template<typename T>
733     inline bool SendTimingEvent(
734         uint32_t innerEventId, const std::shared_ptr<T> &object, int64_t taskTime, Priority priority = Priority::LOW)
735     {
736         return SendTimingEvent(InnerEvent::Get(innerEventId, object), taskTime, priority);
737     }
738 
739     /**
740      * Send a timing event.
741      *
742      * @param innerEventId The id of the event.
743      * @param object Weak pointer of object.
744      * @param taskTime Process the event at taskTime.
745      * @param priority Priority of the event queue for this event
746      * @return Returns true if event has been sent successfully.
747      */
748     template<typename T>
749     inline bool SendTimingEvent(
750         uint32_t innerEventId, const std::weak_ptr<T> &object, int64_t taskTime, Priority priority = Priority::LOW)
751     {
752         return SendTimingEvent(InnerEvent::Get(innerEventId, object), taskTime, priority);
753     }
754 
755     /**
756      * Send a timing event.
757      *
758      * @param innerEventId The id of the event.
759      * @param object Unique pointer of object.
760      * @param taskTime Process the event at taskTime.
761      * @param priority Priority of the event queue for this event
762      * @return Returns true if event has been sent successfully.
763      */
764     template<typename T, typename D>
765     inline bool SendTimingEvent(
766         uint32_t innerEventId, std::unique_ptr<T, D> &object, int64_t taskTime, Priority priority = Priority::LOW)
767     {
768         return SendTimingEvent(InnerEvent::Get(innerEventId, object), taskTime, priority);
769     }
770 
771     /**
772      * Send a timing event.
773      *
774      * @param innerEventId The id of the event.
775      * @param object Unique pointer of object.
776      * @param taskTime Process the event at taskTime.
777      * @param priority Priority of the event queue for this event
778      * @return Returns true if event has been sent successfully.
779      */
780     template<typename T, typename D>
781     inline bool SendTimingEvent(
782         uint32_t innerEventId, std::unique_ptr<T, D> &&object, int64_t taskTime, Priority priority = Priority::LOW)
783     {
784         return SendTimingEvent(InnerEvent::Get(innerEventId, object), taskTime, priority);
785     }
786 
787     /**
788      * Post a timing task.
789      *
790      * @param callback Task callback.
791      * @param taskTime Process the event at taskTime.
792      * @param name Name of the task.
793      * @param priority Priority of the event queue for this event.
794      * @return Returns true if task has been sent successfully.
795      */
796     inline bool PostTimingTask(const Callback &callback, int64_t taskTime, const std::string &name = std::string(),
797         Priority priority = Priority::LOW, Caller caller = {})
798     {
799         return SendTimingEvent(InnerEvent::Get(callback, name.empty() ? caller.ToString() : name), taskTime, priority);
800     }
801 
802     /**
803      * Post a timing task.
804      *
805      * @param callback Task callback.
806      * @param taskTime Process the event at taskTime.
807      * @param priority Priority of the event queue for this event.
808      * @return Returns true if task has been sent successfully.
809      */
810     inline bool PostTimingTask(const Callback &callback, int64_t taskTime, Priority priority = Priority::LOW,
811                                Caller caller = {})
812     {
813         return PostTimingTask(callback, taskTime, caller.ToString(), priority);
814     }
815 
816     /**
817      * Remove all sent events.
818      */
819     void RemoveAllEvents();
820 
821     /**
822      * Remove sent events.
823      *
824      * @param innerEventId The id of the event.
825      */
826     void RemoveEvent(uint32_t innerEventId);
827 
828     /**
829      * Remove sent events.
830      *
831      * @param innerEventId The id of the event.
832      * @param param Basic parameter of the event.
833      */
834     void RemoveEvent(uint32_t innerEventId, int64_t param);
835 
836     /**
837      * Remove a task.
838      *
839      * @param name Name of the task.
840      */
841     void RemoveTask(const std::string &name);
842 
843     /**
844      * Add file descriptor listener for a file descriptor.
845      *
846      * @param fileDescriptor File descriptor.
847      * @param events Events from file descriptor, such as input, output, error
848      * @param listener Listener callback.
849      * @return Return 'ERR_OK' on success.
850      */
851     ErrCode AddFileDescriptorListener(
852         int32_t fileDescriptor, uint32_t events, const std::shared_ptr<FileDescriptorListener> &listener);
853 
854     /**
855      * Remove all file descriptor listeners.
856      */
857     void RemoveAllFileDescriptorListeners();
858 
859     /**
860      * Remove file descriptor listener for a file descriptor.
861      *
862      * @param fileDescriptor File descriptor.
863      */
864     void RemoveFileDescriptorListener(int32_t fileDescriptor);
865 
866     /**
867      * Set the 'EventRunner' to the 'EventHandler'.
868      *
869      * @param runner The 'EventRunner'.
870      */
871     void SetEventRunner(const std::shared_ptr<EventRunner> &runner);
872 
873     /**
874      * Get the 'EventRunner' of the 'EventHandler'.
875      *
876      * @return Return the 'EventRunner'.
877      */
GetEventRunner()878     inline const std::shared_ptr<EventRunner> &GetEventRunner() const
879     {
880         return eventRunner_;
881     }
882 
883     /**
884      * Distribute the event.
885      *
886      * @param event The event should be distributed.
887      */
888     void DistributeEvent(const InnerEvent::Pointer &event);
889 
890     /**
891      * Distribute time out action.
892      *
893      * @param event The event should be distribute.
894      * @param nowStart Dotting before distribution.
895      */
896     void DistributeTimeAction(const InnerEvent::Pointer &event, InnerEvent::TimePoint nowStart);
897 
898     /**
899      * Delivery time out action.
900      *
901      * @param event The event should be distribute.
902      * @param nowStart Dotting before distribution.
903      */
904     void DeliveryTimeAction(const InnerEvent::Pointer &event, InnerEvent::TimePoint nowStart);
905 
906     /**
907      * Print out the internal information about an object in the specified format,
908      * helping you diagnose internal errors of the object.
909      *
910      * @param dumpr The Dumper object you have implemented to process the output internal information.
911      */
912     void Dump(Dumper &dumper);
913 
914     /**
915      * Check whether an event with the given ID can be found among the events that have been sent but not processed.
916      *
917      * @param innerEventId The id of the event.
918      */
919     bool HasInnerEvent(uint32_t innerEventId);
920 
921     /**
922      * Check whether an event carrying the given param can be found among the events that have been sent but not
923      * processed.
924      *
925      * @param param Basic parameter of the event.
926      */
927     bool HasInnerEvent(int64_t param);
928 
929     /**
930      * Check whether an event carrying the given param can be found among the events that have been sent but not
931      * processed.
932      *
933      * @param event InnerEvent whose name is to be obtained.
934      * @return Returns the task name if the given event contains a specific task; returns the event ID otherwise.
935      */
936     std::string GetEventName(const InnerEvent::Pointer &event);
937 
938     /**
939      * Checks whether the current event handler is idle
940      * @return Returns true if current event handler is idle otherwise return false.
941      */
942     bool IsIdle();
943 
944 protected:
945     /**
946      * Process the event. Developers should override this method.
947      *
948      * @param event The event should be processed.
949      */
950     virtual void ProcessEvent(const InnerEvent::Pointer &event);
951 
952 private:
953     std::shared_ptr<EventRunner> eventRunner_;
954     CallbackTimeout deliveryTimeoutCallback_;
955     CallbackTimeout distributeTimeoutCallback_;
956 
957     static thread_local std::weak_ptr<EventHandler> currentEventHandler;
958 };
959 }  // namespace AppExecFwk
960 namespace EventHandling = AppExecFwk;
961 }  // namespace OHOS
962 
963 #endif  // #ifndef BASE_EVENTHANDLER_INTERFACES_INNER_API_EVENT_HANDLER_H
964