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