1*38e8c45fSAndroid Build Coastguard Worker /*
2*38e8c45fSAndroid Build Coastguard Worker  * Copyright (C) 2022 The Android Open Source Project
3*38e8c45fSAndroid Build Coastguard Worker  *
4*38e8c45fSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*38e8c45fSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*38e8c45fSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*38e8c45fSAndroid Build Coastguard Worker  *
8*38e8c45fSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*38e8c45fSAndroid Build Coastguard Worker  *
10*38e8c45fSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*38e8c45fSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*38e8c45fSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*38e8c45fSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*38e8c45fSAndroid Build Coastguard Worker  * limitations under the License.
15*38e8c45fSAndroid Build Coastguard Worker  */
16*38e8c45fSAndroid Build Coastguard Worker 
17*38e8c45fSAndroid Build Coastguard Worker #pragma once
18*38e8c45fSAndroid Build Coastguard Worker 
19*38e8c45fSAndroid Build Coastguard Worker #include "InputListener.h"
20*38e8c45fSAndroid Build Coastguard Worker 
21*38e8c45fSAndroid Build Coastguard Worker namespace android {
22*38e8c45fSAndroid Build Coastguard Worker 
23*38e8c45fSAndroid Build Coastguard Worker /**
24*38e8c45fSAndroid Build Coastguard Worker  * Base interface for an InputListener stage.
25*38e8c45fSAndroid Build Coastguard Worker  * Blocks unintentional input events. Not thread safe. Must be called from the same
26*38e8c45fSAndroid Build Coastguard Worker  * thread. All work is performed on the calling threads.
27*38e8c45fSAndroid Build Coastguard Worker  */
28*38e8c45fSAndroid Build Coastguard Worker class UnwantedInteractionBlockerInterface : public InputListenerInterface {
29*38e8c45fSAndroid Build Coastguard Worker public:
30*38e8c45fSAndroid Build Coastguard Worker     /**
31*38e8c45fSAndroid Build Coastguard Worker      * Dump the state of the interaction blocker.
32*38e8c45fSAndroid Build Coastguard Worker      * This method may be called on any thread (usually by the input manager on a binder thread).
33*38e8c45fSAndroid Build Coastguard Worker      */
34*38e8c45fSAndroid Build Coastguard Worker     virtual void dump(std::string& dump) = 0;
35*38e8c45fSAndroid Build Coastguard Worker 
36*38e8c45fSAndroid Build Coastguard Worker     /* Called by the heartbeat to ensures that the blocker has not deadlocked. */
37*38e8c45fSAndroid Build Coastguard Worker     virtual void monitor() = 0;
38*38e8c45fSAndroid Build Coastguard Worker 
UnwantedInteractionBlockerInterface()39*38e8c45fSAndroid Build Coastguard Worker     UnwantedInteractionBlockerInterface() {}
~UnwantedInteractionBlockerInterface()40*38e8c45fSAndroid Build Coastguard Worker     ~UnwantedInteractionBlockerInterface() override {}
41*38e8c45fSAndroid Build Coastguard Worker };
42*38e8c45fSAndroid Build Coastguard Worker 
43*38e8c45fSAndroid Build Coastguard Worker } // namespace android
44