1 /*
2  * Copyright (C) 2014 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License
15  */
16 
17 package com.android.server.am;
18 
19 /**
20  * Common class for the various debug {@link android.util.Log} output configuration in the activity
21  * manager package.
22  */
23 class ActivityManagerDebugConfig {
24 
25     // All output logs in the activity manager package use the {@link #TAG_AM} string for tagging
26     // their log output. This makes it easy to identify the origin of the log message when sifting
27     // through a large amount of log output from multiple sources. However, it also makes trying
28     // to figure-out the origin of a log message while debugging the activity manager a little
29     // painful. By setting this constant to true, log messages from the activity manager package
30     // will be tagged with their class names instead fot the generic tag.
31     static final boolean TAG_WITH_CLASS_NAME = false;
32 
33     // While debugging it is sometimes useful to have the category name of the log appended to the
34     // base log tag to make sifting through logs with the same base tag easier. By setting this
35     // constant to true, the category name of the log point will be appended to the log tag.
36     static final boolean APPEND_CATEGORY_NAME = false;
37 
38     // Default log tag for the activity manager package.
39     static final String TAG_AM = "ActivityManager";
40 
41     // Enable all debug log categories.
42     static final boolean DEBUG_ALL = false;
43 
44     // Enable all debug log categories for activities.
45     static final boolean DEBUG_ALL_ACTIVITIES = DEBUG_ALL || false;
46 
47     // Available log categories in the activity manager package.
48     static final boolean DEBUG_ADD_REMOVE = DEBUG_ALL_ACTIVITIES || false;
49     static final boolean DEBUG_ANR = false;
50     static final boolean DEBUG_APP = DEBUG_ALL_ACTIVITIES || false;
51     static final boolean DEBUG_BACKGROUND_CHECK = DEBUG_ALL || false;
52     static final boolean DEBUG_BACKUP = DEBUG_ALL || false;
53     static final boolean DEBUG_BROADCAST = DEBUG_ALL || false;
54     static final boolean DEBUG_BROADCAST_BACKGROUND = DEBUG_BROADCAST || false;
55     static final boolean DEBUG_BROADCAST_LIGHT = DEBUG_BROADCAST || false;
56     static final boolean DEBUG_CLEANUP = DEBUG_ALL || false;
57     static final boolean DEBUG_CONFIGURATION = DEBUG_ALL || false;
58     static final boolean DEBUG_CONTAINERS = DEBUG_ALL_ACTIVITIES || false;
59     static final boolean DEBUG_FOCUS = false;
60     static final boolean DEBUG_IDLE = DEBUG_ALL_ACTIVITIES || false;
61     static final boolean DEBUG_IMMERSIVE = DEBUG_ALL || false;
62     static final boolean DEBUG_LOCKTASK = DEBUG_ALL || false;
63     static final boolean DEBUG_LRU = DEBUG_ALL || false;
64     static final boolean DEBUG_MU = DEBUG_ALL || false;
65     static final boolean DEBUG_NETWORK = DEBUG_ALL || false;
66     static final boolean DEBUG_OOM_ADJ = DEBUG_ALL || false;
67     static final boolean DEBUG_OOM_ADJ_REASON = DEBUG_ALL || false;
68     static final boolean DEBUG_PAUSE = DEBUG_ALL || false;
69     static final boolean DEBUG_POWER = DEBUG_ALL || false;
70     static final boolean DEBUG_POWER_QUICK = DEBUG_POWER || false;
71     static final boolean DEBUG_PROCESS_OBSERVERS = DEBUG_ALL || false;
72     static final boolean DEBUG_PROCESSES = DEBUG_ALL || false;
73     static final boolean DEBUG_PROVIDER = DEBUG_ALL || false;
74     static final boolean DEBUG_PSS = DEBUG_ALL || false;
75     static final boolean DEBUG_RECENTS = DEBUG_ALL || false;
76     static final boolean DEBUG_RECENTS_TRIM_TASKS = DEBUG_RECENTS || false;
77     static final boolean DEBUG_RELEASE = DEBUG_ALL_ACTIVITIES || false;
78     static final boolean DEBUG_RESULTS = DEBUG_ALL || false;
79     static final boolean DEBUG_SAVED_STATE = DEBUG_ALL_ACTIVITIES || false;
80     static final boolean DEBUG_SERVICE = DEBUG_ALL || false;
81     static final boolean DEBUG_FOREGROUND_SERVICE = DEBUG_ALL || false;
82     static final boolean DEBUG_SERVICE_EXECUTING = DEBUG_ALL || false;
83     static final boolean DEBUG_STACK = DEBUG_ALL || false;
84     static final boolean DEBUG_STATES = DEBUG_ALL_ACTIVITIES || false;
85     static final boolean DEBUG_SWITCH = DEBUG_ALL || false;
86     static final boolean DEBUG_TASKS = DEBUG_ALL || false;
87     static final boolean DEBUG_TRANSITION = DEBUG_ALL || false;
88     static final boolean DEBUG_UID_OBSERVERS = DEBUG_ALL || false;
89     static final boolean DEBUG_URI_PERMISSION = DEBUG_ALL || false;
90     static final boolean DEBUG_USER_LEAVING = DEBUG_ALL || false;
91     static final boolean DEBUG_VISIBILITY = DEBUG_ALL || false;
92     static final boolean DEBUG_USAGE_STATS = DEBUG_ALL || false;
93     static final boolean DEBUG_PERMISSIONS_REVIEW = DEBUG_ALL || false;
94     static final boolean DEBUG_WHITELISTS = DEBUG_ALL || false;
95     static final boolean DEBUG_METRICS = DEBUG_ALL || false;
96 
97     static final String POSTFIX_ADD_REMOVE = (APPEND_CATEGORY_NAME) ? "_AddRemove" : "";
98     static final String POSTFIX_APP = (APPEND_CATEGORY_NAME) ? "_App" : "";
99     static final String POSTFIX_BACKUP = (APPEND_CATEGORY_NAME) ? "_Backup" : "";
100     static final String POSTFIX_BROADCAST = (APPEND_CATEGORY_NAME) ? "_Broadcast" : "";
101     static final String POSTFIX_CLEANUP = (APPEND_CATEGORY_NAME) ? "_Cleanup" : "";
102     static final String POSTFIX_CONFIGURATION = (APPEND_CATEGORY_NAME) ? "_Configuration" : "";
103     static final String POSTFIX_CONTAINERS = (APPEND_CATEGORY_NAME) ? "_Containers" : "";
104     static final String POSTFIX_FOCUS = (APPEND_CATEGORY_NAME) ? "_Focus" : "";
105     static final String POSTFIX_IDLE = (APPEND_CATEGORY_NAME) ? "_Idle" : "";
106     static final String POSTFIX_IMMERSIVE = (APPEND_CATEGORY_NAME) ? "_Immersive" : "";
107     static final String POSTFIX_LOCKTASK = (APPEND_CATEGORY_NAME) ? "_LockTask" : "";
108     static final String POSTFIX_LRU = (APPEND_CATEGORY_NAME) ? "_LRU" : "";
109     static final String POSTFIX_MU = "_MU";
110     static final String POSTFIX_NETWORK = "_Network";
111     static final String POSTFIX_OOM_ADJ = (APPEND_CATEGORY_NAME) ? "_OomAdj" : "";
112     static final String POSTFIX_PAUSE = (APPEND_CATEGORY_NAME) ? "_Pause" : "";
113     static final String POSTFIX_POWER = (APPEND_CATEGORY_NAME) ? "_Power" : "";
114     static final String POSTFIX_PROCESS_OBSERVERS = (APPEND_CATEGORY_NAME)
115             ? "_ProcessObservers" : "";
116     static final String POSTFIX_PROCESSES = (APPEND_CATEGORY_NAME) ? "_Processes" : "";
117     static final String POSTFIX_PROVIDER = (APPEND_CATEGORY_NAME) ? "_Provider" : "";
118     static final String POSTFIX_PSS = (APPEND_CATEGORY_NAME) ? "_Pss" : "";
119     static final String POSTFIX_RECENTS = (APPEND_CATEGORY_NAME) ? "_Recents" : "";
120     static final String POSTFIX_RELEASE = (APPEND_CATEGORY_NAME) ? "_Release" : "";
121     static final String POSTFIX_RESULTS = (APPEND_CATEGORY_NAME) ? "_Results" : "";
122     static final String POSTFIX_SAVED_STATE = (APPEND_CATEGORY_NAME) ? "_SavedState" : "";
123     static final String POSTFIX_SERVICE = (APPEND_CATEGORY_NAME) ? "_Service" : "";
124     static final String POSTFIX_SERVICE_EXECUTING =
125             (APPEND_CATEGORY_NAME) ? "_ServiceExecuting" : "";
126     static final String POSTFIX_STACK = (APPEND_CATEGORY_NAME) ? "_Stack" : "";
127     static final String POSTFIX_STATES = (APPEND_CATEGORY_NAME) ? "_States" : "";
128     static final String POSTFIX_SWITCH = (APPEND_CATEGORY_NAME) ? "_Switch" : "";
129     static final String POSTFIX_TASKS = (APPEND_CATEGORY_NAME) ? "_Tasks" : "";
130     static final String POSTFIX_TRANSITION = (APPEND_CATEGORY_NAME) ? "_Transition" : "";
131     static final String POSTFIX_UID_OBSERVERS = (APPEND_CATEGORY_NAME)
132             ? "_UidObservers" : "";
133     static final String POSTFIX_URI_PERMISSION = (APPEND_CATEGORY_NAME) ? "_UriPermission" : "";
134     static final String POSTFIX_USER_LEAVING = (APPEND_CATEGORY_NAME) ? "_UserLeaving" : "";
135     static final String POSTFIX_VISIBILITY = (APPEND_CATEGORY_NAME) ? "_Visibility" : "";
136 
137 }
138