105 lines
3.7 KiB
C++
105 lines
3.7 KiB
C++
/*
|
|
* Copyright (C) 2022 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#define LOG_TAG "InputDispatcher"
|
|
|
|
#include <log/log.h>
|
|
#include <log/log_event_list.h>
|
|
|
|
namespace android::inputdispatcher {
|
|
|
|
static bool enableInputLog = false;
|
|
|
|
/**
|
|
* Signals whether this is a debuggable Android build.
|
|
* This is populated by reading the value of the "ro.debuggable" property.
|
|
*/
|
|
extern const bool IS_DEBUGGABLE_BUILD;
|
|
|
|
/**
|
|
* Log detailed debug messages about each inbound event notification to the dispatcher.
|
|
* Enable this via "adb shell setprop log.tag.InputDispatcherInboundEvent DEBUG".
|
|
* This requires a restart on non-debuggable (e.g. user) builds, but should take effect immediately
|
|
* on debuggable builds (e.g. userdebug).
|
|
*/
|
|
bool debugInboundEventDetails();
|
|
|
|
/**
|
|
* Log detailed debug messages about each outbound event processed by the dispatcher.
|
|
* Enable this via "adb shell setprop log.tag.InputDispatcherOutboundEvent DEBUG" (requires restart)
|
|
*/
|
|
static bool DEBUG_OUTBOUND_EVENT_DETAILS =
|
|
__android_log_is_loggable(ANDROID_LOG_DEBUG, LOG_TAG "OutboundEvent", ANDROID_LOG_INFO);
|
|
|
|
/**
|
|
* Log debug messages about the dispatch cycle.
|
|
* Enable this via "adb shell setprop log.tag.InputDispatcherDispatchCycle DEBUG" (requires restart)
|
|
*/
|
|
static bool DEBUG_DISPATCH_CYCLE =
|
|
__android_log_is_loggable(ANDROID_LOG_DEBUG, LOG_TAG "DispatchCycle", ANDROID_LOG_INFO);
|
|
|
|
/**
|
|
* Log debug messages about channel creation
|
|
* Enable this via "adb shell setprop log.tag.InputDispatcherChannelCreation DEBUG" (requires
|
|
* restart)
|
|
*/
|
|
static bool DEBUG_CHANNEL_CREATION =
|
|
__android_log_is_loggable(ANDROID_LOG_DEBUG, LOG_TAG "ChannelCreation", ANDROID_LOG_INFO);
|
|
|
|
/**
|
|
* Log debug messages about input event injection.
|
|
* Enable this via "adb shell setprop log.tag.InputDispatcherInjection DEBUG" (requires restart)
|
|
*/
|
|
static bool DEBUG_INJECTION =
|
|
__android_log_is_loggable(ANDROID_LOG_DEBUG, LOG_TAG "Injection", ANDROID_LOG_INFO);
|
|
|
|
/**
|
|
* Log debug messages about input focus tracking.
|
|
* Enable this via "adb shell setprop log.tag.InputDispatcherFocus DEBUG" (requires restart)
|
|
*/
|
|
static bool DEBUG_FOCUS =
|
|
__android_log_is_loggable(ANDROID_LOG_DEBUG, LOG_TAG "Focus", ANDROID_LOG_INFO);
|
|
|
|
/**
|
|
* Log debug messages about touch mode event
|
|
* Enable this via "adb shell setprop log.tag.InputDispatcherTouchMode DEBUG" (requires restart)
|
|
*/
|
|
static bool DEBUG_TOUCH_MODE =
|
|
__android_log_is_loggable(ANDROID_LOG_DEBUG, LOG_TAG "TouchMode", ANDROID_LOG_INFO);
|
|
|
|
/**
|
|
* Log debug messages about touch occlusion
|
|
*/
|
|
static bool DEBUG_TOUCH_OCCLUSION = true;
|
|
|
|
/**
|
|
* Log debug messages about the app switch latency optimization.
|
|
* Enable this via "adb shell setprop log.tag.InputDispatcherAppSwitch DEBUG" (requires restart)
|
|
*/
|
|
static bool DEBUG_APP_SWITCH =
|
|
__android_log_is_loggable(ANDROID_LOG_DEBUG, LOG_TAG "AppSwitch", ANDROID_LOG_INFO);
|
|
|
|
/**
|
|
* Log debug messages about hover events.
|
|
* Enable this via "adb shell setprop log.tag.InputDispatcherHover DEBUG" (requires restart)
|
|
*/
|
|
static bool DEBUG_HOVER =
|
|
__android_log_is_loggable(ANDROID_LOG_DEBUG, LOG_TAG "Hover", ANDROID_LOG_INFO);
|
|
|
|
} // namespace android::inputdispatcher
|